Initial load
diff --git a/jaxws/.hgignore b/jaxws/.hgignore
new file mode 100644
index 0000000..ca1b0b2
--- /dev/null
+++ b/jaxws/.hgignore
@@ -0,0 +1,3 @@
+^build/
+^dist/
+^nbproject/private/
diff --git a/jaxws/ASSEMBLY_EXCEPTION b/jaxws/ASSEMBLY_EXCEPTION
new file mode 100644
index 0000000..8b7ac1d
--- /dev/null
+++ b/jaxws/ASSEMBLY_EXCEPTION
@@ -0,0 +1,27 @@
+
+OPENJDK ASSEMBLY EXCEPTION
+
+The OpenJDK source code made available by Sun at openjdk.java.net and
+openjdk.dev.java.net ("OpenJDK Code") is distributed under the terms of the
+GNU General Public License <http://www.gnu.org/copyleft/gpl.html> version 2
+only ("GPL2"), with the following clarification and special exception.
+
+    Linking this OpenJDK Code statically or dynamically with other code
+    is making a combined work based on this library.  Thus, the terms
+    and conditions of GPL2 cover the whole combination.
+
+    As a special exception, Sun gives you permission to link this
+    OpenJDK Code with certain code licensed by Sun as indicated at
+    http://openjdk.java.net/legal/exception-modules-2007-05-08.html
+    ("Designated Exception Modules") to produce an executable,
+    regardless of the license terms of the Designated Exception Modules,
+    and to copy and distribute the resulting executable under GPL2,
+    provided that the Designated Exception Modules continue to be
+    governed by the licenses under which they were offered by Sun.
+
+As such, it allows licensees and sublicensees of Sun's GPL2 OpenJDK Code to
+build an executable that includes those portions of necessary code that Sun
+could not provide under GPL2 (or that Sun has provided under GPL2 with the
+Classpath exception).  If you modify or add to the OpenJDK code, that new
+GPL2 code may still be combined with Designated Exception Modules if the
+new code is made subject to this exception by its copyright holder.
diff --git a/jaxws/LICENSE b/jaxws/LICENSE
new file mode 100644
index 0000000..eeab58c
--- /dev/null
+++ b/jaxws/LICENSE
@@ -0,0 +1,347 @@
+The GNU General Public License (GPL)
+
+Version 2, June 1991
+
+Copyright (C) 1989, 1991 Free Software Foundation, Inc.
+59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+Everyone is permitted to copy and distribute verbatim copies of this license
+document, but changing it is not allowed.
+
+Preamble
+
+The licenses for most software are designed to take away your freedom to share
+and change it.  By contrast, the GNU General Public License is intended to
+guarantee your freedom to share and change free software--to make sure the
+software is free for all its users.  This General Public License applies to
+most of the Free Software Foundation's software and to any other program whose
+authors commit to using it.  (Some other Free Software Foundation software is
+covered by the GNU Library General Public License instead.) You can apply it to
+your programs, too.
+
+When we speak of free software, we are referring to freedom, not price.  Our
+General Public Licenses are designed to make sure that you have the freedom to
+distribute copies of free software (and charge for this service if you wish),
+that you receive source code or can get it if you want it, that you can change
+the software or use pieces of it in new free programs; and that you know you
+can do these things.
+
+To protect your rights, we need to make restrictions that forbid anyone to deny
+you these rights or to ask you to surrender the rights.  These restrictions
+translate to certain responsibilities for you if you distribute copies of the
+software, or if you modify it.
+
+For example, if you distribute copies of such a program, whether gratis or for
+a fee, you must give the recipients all the rights that you have.  You must
+make sure that they, too, receive or can get the source code.  And you must
+show them these terms so they know their rights.
+
+We protect your rights with two steps: (1) copyright the software, and (2)
+offer you this license which gives you legal permission to copy, distribute
+and/or modify the software.
+
+Also, for each author's protection and ours, we want to make certain that
+everyone understands that there is no warranty for this free software.  If the
+software is modified by someone else and passed on, we want its recipients to
+know that what they have is not the original, so that any problems introduced
+by others will not reflect on the original authors' reputations.
+
+Finally, any free program is threatened constantly by software patents.  We
+wish to avoid the danger that redistributors of a free program will
+individually obtain patent licenses, in effect making the program proprietary.
+To prevent this, we have made it clear that any patent must be licensed for
+everyone's free use or not licensed at all.
+
+The precise terms and conditions for copying, distribution and modification
+follow.
+
+TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+0. This License applies to any program or other work which contains a notice
+placed by the copyright holder saying it may be distributed under the terms of
+this General Public License.  The "Program", below, refers to any such program
+or work, and a "work based on the Program" means either the Program or any
+derivative work under copyright law: that is to say, a work containing the
+Program or a portion of it, either verbatim or with modifications and/or
+translated into another language.  (Hereinafter, translation is included
+without limitation in the term "modification".) Each licensee is addressed as
+"you".
+
+Activities other than copying, distribution and modification are not covered by
+this License; they are outside its scope.  The act of running the Program is
+not restricted, and the output from the Program is covered only if its contents
+constitute a work based on the Program (independent of having been made by
+running the Program).  Whether that is true depends on what the Program does.
+
+1. You may copy and distribute verbatim copies of the Program's source code as
+you receive it, in any medium, provided that you conspicuously and
+appropriately publish on each copy an appropriate copyright notice and
+disclaimer of warranty; keep intact all the notices that refer to this License
+and to the absence of any warranty; and give any other recipients of the
+Program a copy of this License along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and you may
+at your option offer warranty protection in exchange for a fee.
+
+2. You may modify your copy or copies of the Program or any portion of it, thus
+forming a work based on the Program, and copy and distribute such modifications
+or work under the terms of Section 1 above, provided that you also meet all of
+these conditions:
+
+    a) You must cause the modified files to carry prominent notices stating
+    that you changed the files and the date of any change.
+
+    b) You must cause any work that you distribute or publish, that in whole or
+    in part contains or is derived from the Program or any part thereof, to be
+    licensed as a whole at no charge to all third parties under the terms of
+    this License.
+
+    c) If the modified program normally reads commands interactively when run,
+    you must cause it, when started running for such interactive use in the
+    most ordinary way, to print or display an announcement including an
+    appropriate copyright notice and a notice that there is no warranty (or
+    else, saying that you provide a warranty) and that users may redistribute
+    the program under these conditions, and telling the user how to view a copy
+    of this License.  (Exception: if the Program itself is interactive but does
+    not normally print such an announcement, your work based on the Program is
+    not required to print an announcement.)
+
+These requirements apply to the modified work as a whole.  If identifiable
+sections of that work are not derived from the Program, and can be reasonably
+considered independent and separate works in themselves, then this License, and
+its terms, do not apply to those sections when you distribute them as separate
+works.  But when you distribute the same sections as part of a whole which is a
+work based on the Program, the distribution of the whole must be on the terms
+of this License, whose permissions for other licensees extend to the entire
+whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest your
+rights to work written entirely by you; rather, the intent is to exercise the
+right to control the distribution of derivative or collective works based on
+the Program.
+
+In addition, mere aggregation of another work not based on the Program with the
+Program (or with a work based on the Program) on a volume of a storage or
+distribution medium does not bring the other work under the scope of this
+License.
+
+3. You may copy and distribute the Program (or a work based on it, under
+Section 2) in object code or executable form under the terms of Sections 1 and
+2 above provided that you also do one of the following:
+
+    a) Accompany it with the complete corresponding machine-readable source
+    code, which must be distributed under the terms of Sections 1 and 2 above
+    on a medium customarily used for software interchange; or,
+
+    b) Accompany it with a written offer, valid for at least three years, to
+    give any third party, for a charge no more than your cost of physically
+    performing source distribution, a complete machine-readable copy of the
+    corresponding source code, to be distributed under the terms of Sections 1
+    and 2 above on a medium customarily used for software interchange; or,
+
+    c) Accompany it with the information you received as to the offer to
+    distribute corresponding source code.  (This alternative is allowed only
+    for noncommercial distribution and only if you received the program in
+    object code or executable form with such an offer, in accord with
+    Subsection b above.)
+
+The source code for a work means the preferred form of the work for making
+modifications to it.  For an executable work, complete source code means all
+the source code for all modules it contains, plus any associated interface
+definition files, plus the scripts used to control compilation and installation
+of the executable.  However, as a special exception, the source code
+distributed need not include anything that is normally distributed (in either
+source or binary form) with the major components (compiler, kernel, and so on)
+of the operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering access to copy
+from a designated place, then offering equivalent access to copy the source
+code from the same place counts as distribution of the source code, even though
+third parties are not compelled to copy the source along with the object code.
+
+4. You may not copy, modify, sublicense, or distribute the Program except as
+expressly provided under this License.  Any attempt otherwise to copy, modify,
+sublicense or distribute the Program is void, and will automatically terminate
+your rights under this License.  However, parties who have received copies, or
+rights, from you under this License will not have their licenses terminated so
+long as such parties remain in full compliance.
+
+5. You are not required to accept this License, since you have not signed it.
+However, nothing else grants you permission to modify or distribute the Program
+or its derivative works.  These actions are prohibited by law if you do not
+accept this License.  Therefore, by modifying or distributing the Program (or
+any work based on the Program), you indicate your acceptance of this License to
+do so, and all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+6. Each time you redistribute the Program (or any work based on the Program),
+the recipient automatically receives a license from the original licensor to
+copy, distribute or modify the Program subject to these terms and conditions.
+You may not impose any further restrictions on the recipients' exercise of the
+rights granted herein.  You are not responsible for enforcing compliance by
+third parties to this License.
+
+7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues), conditions
+are imposed on you (whether by court order, agreement or otherwise) that
+contradict the conditions of this License, they do not excuse you from the
+conditions of this License.  If you cannot distribute so as to satisfy
+simultaneously your obligations under this License and any other pertinent
+obligations, then as a consequence you may not distribute the Program at all.
+For example, if a patent license would not permit royalty-free redistribution
+of the Program by all those who receive copies directly or indirectly through
+you, then the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under any
+particular circumstance, the balance of the section is intended to apply and
+the section as a whole is intended to apply in other circumstances.
+
+It is not the purpose of this section to induce you to infringe any patents or
+other property right claims or to contest validity of any such claims; this
+section has the sole purpose of protecting the integrity of the free software
+distribution system, which is implemented by public license practices.  Many
+people have made generous contributions to the wide range of software
+distributed through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing to
+distribute software through any other system and a licensee cannot impose that
+choice.
+
+This section is intended to make thoroughly clear what is believed to be a
+consequence of the rest of this License.
+
+8. If the distribution and/or use of the Program is restricted in certain
+countries either by patents or by copyrighted interfaces, the original
+copyright holder who places the Program under this License may add an explicit
+geographical distribution limitation excluding those countries, so that
+distribution is permitted only in or among countries not thus excluded.  In
+such case, this License incorporates the limitation as if written in the body
+of this License.
+
+9. The Free Software Foundation may publish revised and/or new versions of the
+General Public License from time to time.  Such new versions will be similar in
+spirit to the present version, but may differ in detail to address new problems
+or concerns.
+
+Each version is given a distinguishing version number.  If the Program
+specifies a version number of this License which applies to it and "any later
+version", you have the option of following the terms and conditions either of
+that version or of any later version published by the Free Software Foundation.
+If the Program does not specify a version number of this License, you may
+choose any version ever published by the Free Software Foundation.
+
+10. If you wish to incorporate parts of the Program into other free programs
+whose distribution conditions are different, write to the author to ask for
+permission.  For software which is copyrighted by the Free Software Foundation,
+write to the Free Software Foundation; we sometimes make exceptions for this.
+Our decision will be guided by the two goals of preserving the free status of
+all derivatives of our free software and of promoting the sharing and reuse of
+software generally.
+
+NO WARRANTY
+
+11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR
+THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN OTHERWISE
+STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE
+PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED,
+INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND
+PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE PROGRAM PROVE DEFECTIVE,
+YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL
+ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE
+PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR
+INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA
+BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
+FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER
+OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
+
+END OF TERMS AND CONDITIONS
+
+How to Apply These Terms to Your New Programs
+
+If you develop a new program, and you want it to be of the greatest possible
+use to the public, the best way to achieve this is to make it free software
+which everyone can redistribute and change under these terms.
+
+To do so, attach the following notices to the program.  It is safest to attach
+them to the start of each source file to most effectively convey the exclusion
+of warranty; and each file should have at least the "copyright" line and a
+pointer to where the full notice is found.
+
+    One line to give the program's name and a brief idea of what it does.
+
+    Copyright (C) <year> <name of author>
+
+    This program is free software; you can redistribute it and/or modify it
+    under the terms of the GNU General Public License as published by the Free
+    Software Foundation; either version 2 of the License, or (at your option)
+    any later version.
+
+    This program is distributed in the hope that it will be useful, but WITHOUT
+    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
+    more details.
+
+    You should have received a copy of the GNU General Public License along
+    with this program; if not, write to the Free Software Foundation, Inc., 59
+    Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this when it
+starts in an interactive mode:
+
+    Gnomovision version 69, Copyright (C) year name of author Gnomovision comes
+    with ABSOLUTELY NO WARRANTY; for details type 'show w'.  This is free
+    software, and you are welcome to redistribute it under certain conditions;
+    type 'show c' for details.
+
+The hypothetical commands 'show w' and 'show c' should show the appropriate
+parts of the General Public License.  Of course, the commands you use may be
+called something other than 'show w' and 'show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your school,
+if any, to sign a "copyright disclaimer" for the program, if necessary.  Here
+is a sample; alter the names:
+
+    Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+    'Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+    signature of Ty Coon, 1 April 1989
+
+    Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs.  If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library.  If this is what you want to do, use the GNU Library General Public
+License instead of this License.
+
+
+"CLASSPATH" EXCEPTION TO THE GPL
+
+Certain source files distributed by Sun Microsystems, Inc.  are subject to
+the following clarification and special exception to the GPL, but only where
+Sun has expressly included in the particular source file's header the words
+"Sun designates this particular file as subject to the "Classpath" exception
+as provided by Sun in the LICENSE file that accompanied this code."
+
+    Linking this library statically or dynamically with other modules is making
+    a combined work based on this library.  Thus, the terms and conditions of
+    the GNU General Public License cover the whole combination.
+
+    As a special exception, the copyright holders of this library give you
+    permission to link this library with independent modules to produce an
+    executable, regardless of the license terms of these independent modules,
+    and to copy and distribute the resulting executable under terms of your
+    choice, provided that you also meet, for each linked independent module,
+    the terms and conditions of the license of that module.  An independent
+    module is a module which is not derived from or based on this library.  If
+    you modify this library, you may extend this exception to your version of
+    the library, but you are not obligated to do so.  If you do not wish to do
+    so, delete this exception statement from your version.
diff --git a/jaxws/README b/jaxws/README
new file mode 100644
index 0000000..3a06b29
--- /dev/null
+++ b/jaxws/README
@@ -0,0 +1,14 @@
+README:
+  This file should be located at the top of the jaxws Mercurial repository.
+
+  See http://openjdk.java.net/ for more information about the OpenJDK.
+
+  See ../README-builds.html for complete details on build machine requirements.
+
+Simple Build Instructions:
+
+    cd make && gnumake
+     
+  The files that will be imported into the jdk build will be in the "dist"
+  directory.
+
diff --git a/jaxws/THIRD_PARTY_README b/jaxws/THIRD_PARTY_README
new file mode 100644
index 0000000..9f4d7e5
--- /dev/null
+++ b/jaxws/THIRD_PARTY_README
@@ -0,0 +1,1616 @@
+DO NOT TRANSLATE OR LOCALIZE.
+
+%% This notice is provided with respect to Thai dictionary for text breaking, which may be included with this software: 
+
+--- begin of LICENSE file ---
+
+Copyright (C) 1982 The Royal Institute, Thai Royal Government.
+
+Copyright (C) 1998 National Electronics and Computer Technology Center,
+ National Science and Technology Development Agency,
+ Ministry of Science Technology and Environment,
+ Thai Royal Government.
+
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of this software and associated documentation files (the "Software"), to
+deal in the Software without restriction, including without
+limitation the rights to use, copy, modify, merge, publish, distribute,
+sublicense, and/or sell copies of the Software, and to permit persons to
+whom the Software is furnished to do so, subject to the following
+conditions:
+
+The above copyright notice and this permission notice shall be included
+in all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
+NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
+OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
+USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+--- end of LICENSE file ---
+%% This notice is provided with respect to ASM, which may be included with this software: 
+Copyright (c) 2000-2005 INRIA, France Telecom
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions
+are met:
+
+1. Redistributions of source code must retain the above copyright
+   notice, this list of conditions and the following disclaimer.
+
+2. Redistributions in binary form must reproduce the above copyright
+   notice, this list of conditions and the following disclaimer in the
+   documentation and/or other materials provided with the distribution.
+
+3. Neither the name of the copyright holders nor the names of its
+   contributors may be used to endorse or promote products derived from
+   this software without specific prior written permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+THE POSSIBILITY OF SUCH DAMAGE.
+%% This notice is provided with respect to zlib 1.1.3, which may be included with this software:   
+
+Acknowledgments:
+
+  The deflate format used by zlib was defined by Phil Katz. The deflate
+  and zlib specifications were written by L. Peter Deutsch. Thanks to all the
+  people who reported problems and suggested various improvements in zlib;
+  they are too numerous to cite here.
+
+Copyright notice:
+
+ (C) 1995-1998 Jean-loup Gailly and Mark Adler
+
+  This software is provided 'as-is', without any express or implied
+  warranty.  In no event will the authors be held liable for any damages
+  arising from the use of this software.
+
+  Permission is granted to anyone to use this software for any purpose,
+  including commercial applications, and to alter it and redistribute it
+  freely, subject to the following restrictions:
+
+  1. The origin of this software must not be misrepresented; you must not
+     claim that you wrote the original software. If you use this software
+     in a product, an acknowledgment in the product documentation would be
+     appreciated but is not required.
+  2. Altered source versions must be plainly marked as such, and must not be
+     misrepresented as being the original software.
+  3. This notice may not be removed or altered from any source distribution.
+
+  Jean-loup Gailly        Mark Adler
+  jloup@gzip.org          madler@alumni.caltech.edu
+
+If you use the zlib library in a product, we would appreciate *not*
+receiving lengthy legal documents to sign. The sources are provided
+for free but without warranty of any kind.  The library has been
+entirely written by Jean-loup Gailly and Mark Adler; it does not
+include third-party code.
+
+If you redistribute modified sources, we would appreciate that you include
+in the file ChangeLog history information documenting your changes.
+
+%% This notice is provided with respect to W3C (DTD for XML Signatures), which may be included with this software: 
+W3C® SOFTWARE NOTICE AND LICENSE
+Copyright © 1994-2002 World Wide Web Consortium, (Massachusetts Institute of Technology, Institut National de Recherche en Informatique et en Automatique, Keio University). All Rights Reserved. http://www.w3.org/Consortium/Legal/
+This W3C work (including software, documents, or other related items) is being provided by the copyright holders under the following license. By obtaining, using and/or copying this work, you (the licensee) agree that you have read, understood, and will comply with the following terms and conditions:
+Permission to use, copy, modify, and distribute this software and its documentation, with or without modification,  for any purpose and without fee or royalty is hereby granted, provided that you include the following on ALL copies of the software and documentation or portions thereof, including modifications, that you make:
+1.The full text of this NOTICE in a location viewable to users of the redistributed or derivative work. 
+2.Any pre-existing intellectual property disclaimers, notices, or terms and conditions. If none exist, a short notice of the following form (hypertext is preferred, text is permitted) should be used within the body of any redistributed or derivative code: "Copyright © [$date-of-software] World Wide Web Consortium, (Massachusetts Institute of Technology, Institut National de Recherche en Informatique et en Automatique, Keio University). All Rights Reserved. http://www.w3.org/Consortium/Legal/" 
+3.Notice of any changes or modifications to the W3C files, including the date changes were made. (We recommend you provide URIs to the location from which the code is derived.) 
+THIS SOFTWARE AND DOCUMENTATION IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO, WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF THE SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY THIRD PARTY PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS.
+COPYRIGHT HOLDERS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF ANY USE OF THE SOFTWARE OR DOCUMENTATION.
+The name and trademarks of copyright holders may NOT be used in advertising or publicity pertaining to the software without specific, written prior permission. Title to copyright in this software and any associated documentation will at all times remain with copyright holders.
+____________________________________
+This formulation of W3C's notice and license became active on August 14 1998 so as to improve compatibility with GPL. This version ensures that W3C software licensing terms are no more restrictive than GPL and consequently W3C software may be distributed in GPL packages. See the older formulation for the policy prior to this date. Please see our Copyright FAQ for common questions about using materials from our site, including specific terms and conditions for packages like libwww, Amaya, and Jigsaw. Other questions about this notice can be directed to site-policy@w3.org.

+%% This notice is provided with respect to jscheme.jar, which may be included with this software: 
+Software License Agreement
+Copyright © 1998-2002 by Peter Norvig. 
+Permission is granted to anyone to use this software, in source or object code form, on any computer system, and to modify, compile, decompile, run, and redistribute it to anyone else, subject to the following restrictions: 
+1.The author makes no warranty of any kind, either expressed or implied, about the suitability of this software for any purpose.
+2.The author accepts no liability of any kind for damages or other consequences of the use of this software, even if they arise from defects in the software.
+3.The origin of this software must not be misrepresented, either by explicit claim or by omission.
+4.Altered versions must be plainly marked as such, and must not be misrepresented as being the original software. Altered versions may be distributed in packages under other licenses (such as the GNU license). 
+If you find this software useful, it would be nice if you let me (peter@norvig.com) know about it, and nicer still if you send me modifications that you are willing to share. However, you are not required to do so.
+
+
+%% This notice is provided with respect to PC/SC Lite for Suse Linux v. 1.1.1, which may be included with this software: 
+
+Copyright (c) 1999-2004 David Corcoran 
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions
+are met:
+
+1. Redistributions of source code must retain the above copyright
+   notice, this list of conditions and the following disclaimer.
+2. Redistributions in binary form must reproduce the above copyright
+   notice, this list of conditions and the following disclaimer in the
+   documentation and/or other materials provided with the distribution.
+3. The name of the author may not be used to endorse or promote products
+   derived from this software without specific prior written permission.
+
+Changes to this license can be made only by the copyright author with 
+explicit written consent.
+
+THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+
+%% This notice is provided with respect to IAIK PKCS Wrapper, which may be included with this software: 
+
+Copyright (c) 2002 Graz University of Technology. All rights reserved.
+Redistribution and use in source and binary forms, with or without modification,are permitted provided that the following conditions are met:
+
+
+1. Redistributions of source code must retain the above copyright notice, this   list of conditions and the following disclaimer.
+
+2. Redistributions in binary form must reproduce the above copyright notice,   this list of conditions and the following disclaimer in the documentation   and/or other materials provided with the distribution.
+
+3. The end-user documentation included with the redistribution, if any, must   include the following acknowledgment:
+
+   "This product includes software developed by IAIK of Graz University of    Technology."
+
+   Alternately, this acknowledgment may appear in the software itself, if and   wherever such third-party acknowledgments normally appear.
+
+4. The names "Graz University of Technology" and "IAIK of Graz University of   Technology" must not be used to endorse or promote products derived from this   software without prior written permission.
+
+5. Products derived from this software may not be called "IAIK PKCS Wrapper",   nor may "IAIK" appear in their name, without prior written permission of   Graz University of Technology.
+
+THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED
+WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE LICENSOR BE
+LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
+OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
+OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGE.
+
+%% This notice is provided with respect to Document Object Model (DOM) v. Level 3, which may be included with this software: 
+
+W3Cýý SOFTWARE NOTICE AND LICENSE
+
+http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231
+
+This work (and included software, documentation such as READMEs, or other related items) is being
+provided by the copyright holders under the following license. By obtaining, using and/or copying this work, you
+(the licensee) agree that you have read, understood, and will comply with the following terms and conditions.
+
+Permission to copy, modify, and distribute this software and its documentation, with or without modification, for
+any purpose and without fee or royalty is hereby granted, provided that you include the following on ALL copies
+of the software and documentation or portions thereof, including modifications:
+   1.The full text of this NOTICE in a location viewable to users of the redistributed or derivative work. 
+   2.Any pre-existing intellectual property disclaimers, notices, or terms and conditions. If none exist, the
+     W3C Software Short Notice should be included (hypertext is preferred, text is permitted) within the body
+     of any redistributed or derivative code. 
+   3.Notice of any changes or modifications to the files, including the date changes were made. (We
+     recommend you provide URIs to the location from which the code is derived.) 
+THIS SOFTWARE AND DOCUMENTATION IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKENO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO,
+WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THEUSE OF THE SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY THIRD PARTY PATENTS,COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS.
+
+COPYRIGHT HOLDERS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL ORCONSEQUENTIAL DAMAGES ARISING OUT OF ANY USE OF THE SOFTWARE OR DOCUMENTATION.
+The name and trademarks of copyright holders may NOT be used in advertising or publicity pertaining to the
+software without specific, written prior permission. Title to copyright in this software and any associated
+documentation will at all times remain with copyright holders.
+
+____________________________________
+
+This formulation of W3C's notice and license became active on December 31 2002. This version removes the
+copyright ownership notice such that this license can be used with materials other than those owned by the
+W3C, reflects that ERCIM is now a host of the W3C, includes references to this specific dated version of the
+license, and removes the ambiguous grant of "use". Otherwise, this version is the same as the previous
+version and is written so as to preserve the Free Software Foundation's assessment of GPL compatibility and
+OSI's certification under the Open Source Definition. Please see our Copyright FAQ for common questions
+about using materials from our site, including specific terms and conditions for packages like libwww, Amaya,
+and Jigsaw. Other questions about this notice can be directed to 
+site-policy@w3.org.
+
+%% This notice is provided with respect to Xalan, Xerces, which may be included with this software: 
+
+/*
+ * The Apache Software License, Version 1.1
+ *
+ *
+ * Copyright (c) 1999-2003 The Apache Software Foundation.  All rights  * reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.  *
+ * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in
+ *    the documentation and/or other materials provided with the
+ *    distribution.
+ *
+ * 3. The end-user documentation included with the redistribution,
+ *    if any, must include the following acknowledgment:  
+ *       "This product includes software developed by the
+ *        Apache Software Foundation (http://www.apache.org/)."
+ *    Alternately, this acknowledgment may appear in the software itself, *    if and wherever such third-party acknowledgments normally appear. *
+ * 4. The names "Xerces" and "Apache Software Foundation" must
+ *    not be used to endorse or promote products derived from this
+ *    software without prior written permission. For written 
+ *    permission, please contact apache@apache.org.
+ *
+ * 5. Products derived from this software may not be called "Apache",
+ *    nor may "Apache" appear in their name, without prior written
+ *    permission of the Apache Software Foundation.
+ *
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
+ * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+ * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ * ==================================================================== *
+ * This software consists of voluntary contributions made by many
+ * individuals on behalf of the Apache Software Foundation and was
+ * originally based on software copyright (c) 1999, International
+ * Business Machines, Inc., http://www.ibm.com.  For more
+ * information on the Apache Software Foundation, please see
+ * 
+
+%% This notice is provided with respect to JavaScript, which may be included with this software: 
+
+AMENDMENTS 
+The Netscape Public License Version 1.1 ("NPL") consists of the Mozilla Public License Version 1.1 with the following Amendments, including Exhibit A-Netscape Public License.  Files identified with "Exhibit A-Netscape Public License" are governed by the Netscape Public License Version 1.1. 
+Additional Terms applicable to the Netscape Public License. 
+I. Effect. 
+These additional terms described in this Netscape Public License -- Amendments shall apply to the Mozilla Communicator client code and to all Covered Code under this License. 
+II. ''Netscape's Branded Code'' means Covered Code that Netscape distributes and/or permits others to distribute under one or more trademark(s) which are controlled by Netscape but which are not licensed for use under this License. 
+III. Netscape and logo. 
+This License does not grant any rights to use the trademarks "Netscape'', the "Netscape N and horizon'' logo or the "Netscape lighthouse" logo, "Netcenter", "Gecko", "Java" or "JavaScript", "Smart Browsing" even if such marks are included in the Original Code or Modifications. 
+IV. Inability to Comply Due to Contractual Obligation. 
+Prior to licensing the Original Code under this License, Netscape has licensed third party code for use in Netscape's Branded Code. To the extent that Netscape is limited contractually from making such third party code available under this License, Netscape may choose to reintegrate such code into Covered Code without being required to distribute such code in Source Code form, even if such code would otherwise be considered ''Modifications'' under this License. 
+V. Use of Modifications and Covered Code by Initial Developer. 
+V.1. In General. 
+The obligations of Section 3 apply to Netscape, except to the extent specified in this Amendment, Section V.2 and V.3. 
+V.2. Other Products. 
+Netscape may include Covered Code in products other than the Netscape's Branded Code which are released by Netscape during the two (2) years following the release date of the Original Code, without such additional products becoming subject to the terms of this License, and may license such additional products on different terms from those contained in this License. 
+V.3. Alternative Licensing. 
+Netscape may license the Source Code of Netscape's Branded Code, including Modifications incorporated therein, without such Netscape Branded Code becoming subject to the terms of this License, and may license such Netscape Branded Code on different terms from those contained in this License. 

+VI. Litigation. 
+Notwithstanding the limitations of Section 11 above, the provisions regarding litigation in Section 11(a), (b) and (c) of the License shall apply to all disputes relating to this License.
+
+EXHIBIT A-Netscape Public License. 

+''The contents of this file are subject to the Netscape Public License Version 1.1 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.mozilla.org/NPL/ 
+Software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the specific language governing rights and limitations under the License. 
+The Original Code is Mozilla Communicator client code, released March 31, 1998. 
+The Initial Developer of the Original Code is Netscape Communications Corporation. Portions created by Netscape are Copyright (C) 1998-1999 Netscape Communications Corporation. All Rights Reserved. 
+Contributor(s): ______________________________________.

+Alternatively, the contents of this file may be used under the terms of the _____ license (the  "[___] License"), in which case the provisions of [______] License are applicable  instead of those above.  If you wish to allow use of your version of this file only under the terms of the [____] License and not to allow others to use your version of this file under the NPL, indicate your decision by deleting  the provisions above and replace  them with the notice and other provisions required by the [___] License.  If you do not delete the provisions above, a recipient may use your version of this file under either the NPL or the [___] License."
+
+MOZILLA PUBLIC LICENSE 
+Version 1.1 
+
+1. Definitions. 
+1.0.1. "Commercial Use" means distribution or otherwise making the Covered Code available to a third party. 
+1.1. ''Contributor'' means each entity that creates or contributes to the creation of Modifications. 
+1.2. ''Contributor Version'' means the combination of the Original Code, prior Modifications used by a Contributor, and the Modifications made by that particular Contributor. 
+1.3. ''Covered Code'' means the Original Code or Modifications or the combination of the Original Code and Modifications, in each case including portions thereof. 
+1.4. ''Electronic Distribution Mechanism'' means a mechanism generally accepted in the software development community for the electronic transfer of data. 
+1.5. ''Executable'' means Covered Code in any form other than Source Code. 
+1.6. ''Initial Developer'' means the individual or entity identified as the Initial Developer in the Source Code notice required by Exhibit A. 
+1.7. ''Larger Work'' means a work which combines Covered Code or portions thereof with code not governed by the terms of this License. 
+1.8. ''License'' means this document. 
+1.8.1. "Licensable" means having the right to grant, to the maximum extent possible, whether at the time of the initial grant or subsequently acquired, any and all of the rights conveyed herein. 
+1.9. ''Modifications'' means any addition to or deletion from the substance or structure of either the Original Code or any previous Modifications. When Covered Code is released as a series of files, a Modification is: 
+A. Any addition to or deletion from the contents of a file containing Original Code or previous Modifications. 
+B. Any new file that contains any part of the Original Code or previous Modifications. 

+1.10. ''Original Code'' means Source Code of computer software code which is described in the Source Code notice required by Exhibit A as Original Code, and which, at the time of its release under this License is not already Covered Code governed by this License. 
+1.10.1. "Patent Claims" means any patent claim(s), now owned or hereafter acquired, including without limitation,  method, process, and apparatus claims, in any patent Licensable by grantor. 
+1.11. ''Source Code'' means the preferred form of the Covered Code for making modifications to it, including all modules it contains, plus any associated interface definition files, scripts used to control compilation and installation of an Executable, or source code differential comparisons against either the Original Code or another well known, available Covered Code of the Contributor's choice. The Source Code can be in a compressed or archival form, provided the appropriate decompression or de-archiving software is widely available for no charge. 
+1.12. "You'' (or "Your")  means an individual or a legal entity exercising rights under, and complying with all of the terms of, this License or a future version of this License issued under Section 6.1. For legal entities, "You'' includes any entity which controls, is controlled by, or is under common control with You. For purposes of this definition, "control'' means (a) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (b) ownership of more than fifty percent (50%) of the outstanding shares or beneficial ownership of such entity.
+2. Source Code License. 
+2.1. The Initial Developer Grant. 
+The Initial Developer hereby grants You a world-wide, royalty-free, non-exclusive license, subject to third party intellectual property claims: 
+(a)  under intellectual property rights (other than patent or trademark) Licensable by Initial Developer to use, reproduce, modify, display, perform, sublicense and distribute the Original Code (or portions thereof) with or without Modifications, and/or as part of a Larger Work; and 
+(b) under Patents Claims infringed by the making, using or selling of Original Code, to make, have made, use, practice, sell, and offer for sale, and/or otherwise dispose of the Original Code (or portions thereof). 

+(c) the licenses granted in this Section 2.1(a) and (b) are effective on the date Initial Developer first distributes Original Code under the terms of this License. 
+(d) Notwithstanding Section 2.1(b) above, no patent license is granted: 1) for code that You delete from the Original Code; 2) separate from the Original Code;  or 3) for infringements caused by: i) the modification of the Original Code or ii) the combination of the Original Code with other software or devices. 

+2.2. Contributor Grant. 
+Subject to third party intellectual property claims, each Contributor hereby grants You a world-wide, royalty-free, non-exclusive license 

+(a)  under intellectual property rights (other than patent or trademark) Licensable by Contributor, to use, reproduce, modify, display, perform, sublicense and distribute the Modifications created by such Contributor (or portions thereof) either on an unmodified basis, with other Modifications, as Covered Code and/or as part of a Larger Work; and 
+(b) under Patent Claims infringed by the making, using, or selling of  Modifications made by that Contributor either alone and/or in combination with its Contributor Version (or portions of such combination), to make, use, sell, offer for sale, have made, and/or otherwise dispose of: 1) Modifications made by that Contributor (or portions thereof); and 2) the combination of  Modifications made by that Contributor with its Contributor Version (or portions of such combination). 
+(c) the licenses granted in Sections 2.2(a) and 2.2(b) are effective on the date Contributor first makes Commercial Use of the Covered Code. 
+(d)    Notwithstanding Section 2.2(b) above, no patent license is granted: 1) for any code that Contributor has deleted from the Contributor Version; 2)  separate from the Contributor Version;  3)  for infringements caused by: i) third party modifications of Contributor Version or ii)  the combination of Modifications made by that Contributor with other software  (except as part of the Contributor Version) or other devices; or 4) under Patent Claims infringed by Covered Code in the absence of Modifications made by that Contributor.
+
+3. Distribution Obligations. 
+3.1. Application of License. 
+The Modifications which You create or to which You contribute are governed by the terms of this License, including without limitation Section 2.2. The Source Code version of Covered Code may be distributed only under the terms of this License or a future version of this License released under Section 6.1, and You must include a copy of this License with every copy of the Source Code You distribute. You may not offer or impose any terms on any Source Code version that alters or restricts the applicable version of this License or the recipients' rights hereunder. However, You may include an additional document offering the additional rights described in Section 3.5. 
+3.2. Availability of Source Code. 
+Any Modification which You create or to which You contribute must be made available in Source Code form under the terms of this License either on the same media as an Executable version or via an accepted Electronic Distribution Mechanism to anyone to whom you made an Executable version available; and if made available via Electronic Distribution Mechanism, must remain available for at least twelve (12) months after the date it initially became available, or at least six (6) months after a subsequent version of that particular Modification has been made available to such recipients. You are responsible for ensuring that the Source Code version remains available even if the Electronic Distribution Mechanism is maintained by a third party. 
+3.3. Description of Modifications. 
+You must cause all Covered Code to which You contribute to contain a file documenting the changes You made to create that Covered Code and the date of any change. You must include a prominent statement that the Modification is derived, directly or indirectly, from Original Code provided by the Initial Developer and including the name of the Initial Developer in (a) the Source Code, and (b) in any notice in an Executable version or related documentation in which You describe the origin or ownership of the Covered Code. 
+3.4. Intellectual Property Matters 
+(a) Third Party Claims. 
+If Contributor has knowledge that a license under a third party's intellectual property rights is required to exercise the rights granted by such Contributor under Sections 2.1 or 2.2, Contributor must include a text file with the Source Code distribution titled "LEGAL'' which describes the claim and the party making the claim in sufficient detail that a recipient will know whom to contact. If Contributor obtains such knowledge after the Modification is made available as described in Section 3.2, Contributor shall promptly modify the LEGAL file in all copies Contributor makes available thereafter and shall take other steps (such as notifying appropriate mailing lists or newsgroups) reasonably calculated to inform those who received the Covered Code that new knowledge has been obtained. 
+(b) Contributor APIs. 
+If Contributor's Modifications include an application programming interface and Contributor has knowledge of patent licenses which are reasonably necessary to implement that API, Contributor must also include this information in the LEGAL file. 

+          (c)    Representations. 
+Contributor represents that, except as disclosed pursuant to Section 3.4(a) above, Contributor believes that Contributor's Modifications are Contributor's original creation(s) and/or Contributor has sufficient rights to grant the rights conveyed by this License.
+
+3.5. Required Notices. 
+You must duplicate the notice in Exhibit A in each file of the Source Code.  If it is not possible to put such notice in a particular Source Code file due to its structure, then You must include such notice in a location (such as a relevant directory) where a user would be likely to look for such a notice.  If You created one or more Modification(s) You may add your name as a Contributor to the notice described in Exhibit A.  You must also duplicate this License in any documentation for the Source Code where You describe recipients' rights or ownership rights relating to Covered Code.  You may choose to offer, and to charge a fee for, warranty, support, indemnity or liability obligations to one or more recipients of Covered Code. However, You may do so only on Your own behalf, and not on behalf of the Initial Developer or any Contributor. You must make it absolutely clear than any such warranty, support, indemnity or liability obligation is offered by You alone, and You hereby agree to indemnify the Initial Developer and every Contributor for any liability incurred by the Initial Developer or such Contributor as a result of warranty, support, indemnity or liability terms You offer. 
+3.6. Distribution of Executable Versions. 
+You may distribute Covered Code in Executable form only if the requirements of Section 3.1-3.5 have been met for that Covered Code, and if You include a notice stating that the Source Code version of the Covered Code is available under the terms of this License, including a description of how and where You have fulfilled the obligations of Section 3.2. The notice must be conspicuously included in any notice in an Executable version, related documentation or collateral in which You describe recipients' rights relating to the Covered Code. You may distribute the Executable version of Covered Code or ownership rights under a license of Your choice, which may contain terms different from this License, provided that You are in compliance with the terms of this License and that the license for the Executable version does not attempt to limit or alter the recipient's rights in the Source Code version from the rights set forth in this License. If You distribute the Executable version under a different license You must make it absolutely clear that any terms which differ from this License are offered by You alone, not by the Initial Developer or any Contributor. You hereby agree to indemnify the Initial Developer and every Contributor for any liability incurred by the Initial Developer or such Contributor as a result of any such terms You offer. 
+3.7. Larger Works. 
+You may create a Larger Work by combining Covered Code with other code not governed by the terms of this License and distribute the Larger Work as a single product. In such a case, You must make sure the requirements of this License are fulfilled for the Covered Code.
+4. Inability to Comply Due to Statute or Regulation. 
+If it is impossible for You to comply with any of the terms of this License with respect to some or all of the Covered Code due to statute, judicial order, or regulation then You must: (a) comply with the terms of this License to the maximum extent possible; and (b) describe the limitations and the code they affect. Such description must be included in the LEGAL file described in Section 3.4 and must be included with all distributions of the Source Code. Except to the extent prohibited by statute or regulation, such description must be sufficiently detailed for a recipient of ordinary skill to be able to understand it.
+5. Application of this License. 
+This License applies to code to which the Initial Developer has attached the notice in Exhibit A and to related Covered Code.
+6. Versions of the License. 
+6.1. New Versions. 
+Netscape Communications Corporation (''Netscape'') may publish revised and/or new versions of the License from time to time. Each version will be given a distinguishing version number. 
+6.2. Effect of New Versions. 
+Once Covered Code has been published under a particular version of the License, You may always continue to use it under the terms of that version. You may also choose to use such Covered Code under the terms of any subsequent version of the License published by Netscape. No one other than Netscape has the right to modify the terms applicable to Covered Code created under this License. 
+6.3. Derivative Works. 
+If You create or use a modified version of this License (which you may only do in order to apply it to code which is not already Covered Code governed by this License), You must (a) rename Your license so that the phrases ''Mozilla'', ''MOZILLAPL'', ''MOZPL'', ''Netscape'', "MPL", ''NPL'' or any confusingly similar phrase do not appear in your license (except to note that your license differs from this License) and (b) otherwise make it clear that Your version of the license contains terms which differ from the Mozilla Public License and Netscape Public License. (Filling in the name of the Initial Developer, Original Code or Contributor in the notice described in Exhibit A shall not of themselves be deemed to be modifications of this License.)
+7. DISCLAIMER OF WARRANTY. 
+COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS'' BASIS, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES THAT THE COVERED CODE IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED CODE IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER.
+8. TERMINATION. 
+8.1.  This License and the rights granted hereunder will terminate automatically if You fail to comply with terms herein and fail to cure such breach within 30 days of becoming aware of the breach. All sublicenses to the Covered Code which are properly granted shall survive any termination of this License. Provisions which, by their nature, must remain in effect beyond the termination of this License shall survive. 
+8.2.  If You initiate litigation by asserting a patent infringement claim (excluding declatory judgment actions) against Initial Developer or a Contributor (the Initial Developer or Contributor against whom You file such action is referred to as "Participant")  alleging that: 
+(a)  such Participant's Contributor Version directly or indirectly infringes any patent, then any and all rights granted by such Participant to You under Sections 2.1 and/or 2.2 of this License shall, upon 60 days notice from Participant terminate prospectively, unless if within 60 days after receipt of notice You either: (i)  agree in writing to pay Participant a mutually agreeable reasonable royalty for Your past and future use of Modifications made by such Participant, or (ii) withdraw Your litigation claim with respect to the Contributor Version against such Participant.  If within 60 days of notice, a reasonable royalty and payment arrangement are not mutually agreed upon in writing by the parties or the litigation claim is not withdrawn, the rights granted by Participant to You under Sections 2.1 and/or 2.2 automatically terminate at the expiration of the 60 day notice period specified above. 
+(b)  any software, hardware, or device, other than such Participant's Contributor Version, directly or indirectly infringes any patent, then any rights granted to You by such Participant under Sections 2.1(b) and 2.2(b) are revoked effective as of the date You first made, used, sold, distributed, or had made, Modifications made by that Participant. 
+8.3.  If You assert a patent infringement claim against Participant alleging that such Participant's Contributor Version directly or indirectly infringes any patent where such claim is resolved (such as by license or settlement) prior to the initiation of patent infringement litigation, then the reasonable value of the licenses granted by such Participant under Sections 2.1 or 2.2 shall be taken into account in determining the amount or value of any payment or license. 
+8.4.  In the event of termination under Sections 8.1 or 8.2 above,  all end user license agreements (excluding distributors and resellers) which have been validly granted by You or any distributor hereunder prior to termination shall survive termination.
+9. LIMITATION OF LIABILITY. 
+UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, WHETHER TORT (INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE, SHALL YOU, THE INITIAL DEVELOPER, ANY OTHER CONTRIBUTOR, OR ANY DISTRIBUTOR OF COVERED CODE, OR ANY SUPPLIER OF ANY OF SUCH PARTIES, BE LIABLE TO ANY PERSON FOR ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL, WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER COMMERCIAL DAMAGES OR LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. THIS LIMITATION OF LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY RESULTING FROM SUCH PARTY'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU.
+10. U.S. GOVERNMENT END USERS. 
+The Covered Code is a ''commercial item,'' as that term is defined in 48 C.F.R. 2.101 (Oct. 1995), consisting of ''commercial computer software'' and ''commercial computer software documentation,'' as such terms are used in 48 C.F.R. 12.212 (Sept. 1995). Consistent with 48 C.F.R. 12.212 and 48 C.F.R. 227.7202-1 through 227.7202-4 (June 1995), all U.S. Government End Users acquire Covered Code with only those rights set forth herein.
+11. MISCELLANEOUS. 
+This License represents the complete agreement concerning subject matter hereof. If any provision of this License is held to be unenforceable, such provision shall be reformed only to the extent necessary to make it enforceable. This License shall be governed by California law provisions (except to the extent applicable law, if any, provides otherwise), excluding its conflict-of-law provisions. With respect to disputes in which at least one party is a citizen of, or an entity chartered or registered to do business in the United States of America, any litigation relating to this License shall be subject to the jurisdiction of the Federal Courts of the Northern District of California, with venue lying in Santa Clara County, California, with the losing party responsible for costs, including without limitation, court costs and reasonable attorneys' fees and expenses. The application of the United Nations Convention on Contracts for the International Sale of Goods is expressly excluded. Any law or regulation which provides that the language of a contract shall be construed against the drafter shall not apply to this License.
+12. RESPONSIBILITY FOR CLAIMS. 
+As between Initial Developer and the Contributors, each party is responsible for claims and damages arising, directly or indirectly, out of its utilization of rights under this License and You agree to work with Initial Developer and Contributors to distribute such responsibility on an equitable basis. Nothing herein is intended or shall be deemed to constitute any admission of liability.
+13. MULTIPLE-LICENSED CODE. 
+Initial Developer may designate portions of the Covered Code as "Multiple-Licensed".  "Multiple-Licensed" means that the Initial Developer permits you to utilize portions of the Covered Code under Your choice of the NPL or the alternative licenses, if any, specified by the Initial Developer in the file described in Exhibit A.
+
+EXHIBIT A -Mozilla Public License. 
+``The contents of this file are subject to the Mozilla Public License Version 1.1 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at 
+http://www.mozilla.org/MPL/ 
+Software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF 
+ANY KIND, either express or implied. See the License for the specific language governing rights and 
+limitations under the License. 
+The Original Code is ______________________________________. 
+The Initial Developer of the Original Code is ________________________. Portions created by 
+ ______________________ are Copyright (C) ______ _______________________. All Rights 
+Reserved. 
+Contributor(s): ______________________________________. 
+Alternatively, the contents of this file may be used under the terms of the _____ license (the  "[___] License"), in which case the provisions of [______] License are applicable  instead of those above.  If you wish to allow use of your version of this file only under the terms of the [____] License and not to allow others to use your version of this file under the MPL, indicate your decision by deleting  the provisions above and replace  them with the notice and other provisions required by the [___] License.  If you do not delete the provisions above, a recipient may use your version of this file under either the MPL or the [___] License." 
+[NOTE: The text of this Exhibit A may differ slightly from the text of the notices in the Source Code files of the Original Code. You should use the text of this Exhibit A rather than the text found in the Original Code Source Code for Your Modifications.] 
+
+%% This notice is provided with respect to Mesa 3-D graphics library v. 5, which may be included with this software: 
+
+Copyright (c) 2007 The Khronos Group Inc. 
+
+Permission is hereby granted, free of charge, to any person obtaining a 
+copy of this software and/or associated documentation files (the 
+"Materials"), to deal in the Materials without restriction, including 
+without limitation the rights to use, copy, modify, merge, publish, 
+distribute, sublicense, and/or sell copies of the Materials, and to 
+permit persons to whom the Materials are furnished to do so, subject to 
+the following conditions: 
+
+The above copyright notice and this permission notice shall be included 
+in all copies or substantial portions of the Materials. 
+
+THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 
+IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 
+CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 
+TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 
+MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. 
+
+%% This notice is provided with respect to Byte Code Engineering Library (BCEL), which may be included with this software: 
+
+                     Apache Software License 
+
+                     /*
+====================================================================                      * The Apache Software License, Version 1.1
+                      *
+                      * Copyright (c) 2001 The Apache Software Foundation.  Allrights
+                      * reserved.
+                      *
+                      * Redistribution and use in source and binary forms, withor without
+                      * modification, are permitted provided that the followingconditions
+                      * are met:
+                      *
+                      * 1. Redistributions of source code must retain the abovecopyright
+                      *    notice, this list of conditions and the followingdisclaimer.
+                      *
+                      * 2. Redistributions in binary form must reproduce theabove copyright
+                      *    notice, this list of conditions and the followingdisclaimer in
+                      *    the documentation and/or other materials providedwith the
+                      *    distribution.
+                      *
+                      * 3. The end-user documentation included with theredistribution,
+                      *    if any, must include the following acknowledgment:                      *       "This product includes software developed by the                      *        Apache Software Foundation
+(http://www.apache.org/)."
+                      *    Alternately, this acknowledgment may appear in thesoftware itself,
+                      *    if and wherever such third-party acknowledgmentsnormally appear.
+                      *
+                      * 4. The names "Apache" and "Apache Software Foundation"and 
+                      *    "Apache BCEL" must not be used to endorse or promoteproducts 
+                      *    derived from this software without prior writtenpermission. For 
+                      *    written permission, please contact apache@apache.org.                      *
+                      * 5. Products derived from this software may not be called"Apache",
+                      *    "Apache BCEL", nor may "Apache" appear in their name,without 
+                      *    prior written permission of the Apache SoftwareFoundation.
+                      *
+                      * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED ORIMPLIED
+                      * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIEDWARRANTIES
+                      * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSEARE
+                      * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWAREFOUNDATION OR
+                      * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,INCIDENTAL,
+                      * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,BUT NOT
+                      * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;LOSS OF
+                      * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVERCAUSED AND
+                      * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICTLIABILITY,
+                      * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING INANY WAY OUT
+                      * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THEPOSSIBILITY OF
+                      * SUCH DAMAGE.
+                      *
+====================================================================                      *
+                      * This software consists of voluntary contributions madeby many
+                      * individuals on behalf of the Apache Software
+Foundation.  For more
+                      * information on the Apache Software Foundation, pleasesee
+                      * .
+                      */
+
+%% This notice is provided with respect to Regexp, Regular Expression Package, which may be included with this software: 
+
+The Apache Software License, Version 1.1
+Copyright (c) 2001 The Apache Software Foundation.  All rights
+reserved.
+Redistribution and use in source and binary forms, with or without modification,are permitted provided that the following conditions are met:
+
+1. Redistributions of source code must retain the above copyright
+notice, this list of conditions and the following disclaimer.
+
+2. Redistributions in binary form must reproduce the above copyright
+notice, this list of conditions and the following disclaimer in
+the documentation and/or other materials provided with the
+distribution.
+
+3. The end-user documentation included with the redistribution,
+if any, must include the following acknowledgment:
+"This product includes software developed by the
+Apache Software Foundation (http://www.apache.org/)."
+Alternately, this acknowledgment may appear in the software itself,
+if and wherever such third-party acknowledgments normally appear.
+
+4. The names "Apache" and "Apache Software Foundation" and 
+"Apache Turbine" must not be used to endorse or promote products 
+derived from this software without prior written permission. For 
+written permission, please contact apache@apache.org.
+
+5. Products derived from this software may not be called "Apache",
+"Apache Turbine", nor may "Apache" appear in their name, without 
+prior written permission of the Apache Software Foundation.
+
+THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
+ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+SUCH DAMAGE.
+                                                             
+====================================================================
+This software consists of voluntary contributions made by many
+individuals on behalf of the Apache Software Foundation.  For more
+information on the Apache Software Foundation, please see
+                                                             
+http://www.apache.org.
+
+%% This notice is provided with respect to CUP Parser Generator for Java, which may be included with this software: 
+
+CUP Parser Generator Copyright Notice, License, and Disclaimer
+
+Copyright 1996-1999 by Scott Hudson, Frank Flannery, C. Scott Ananian 
+Permission to use, copy, modify, and distribute this software and its
+documentation for any purpose and without fee is hereby granted, provided thatthe above copyright notice appear in all copies and that both the copyrightnotice and this permission notice and warranty disclaimer appear in
+supporting documentation, and that the names of the authors or their employersnot be used in advertising or publicity pertaining to distribution of
+the software without specific, written prior permission. 
+
+The authors and their employers disclaim all warranties with regard to thissoftware, including all implied warranties of merchantability and
+fitness. In no event shall the authors or their employers be liable for anyspecial, indirect or consequential damages or any damages whatsoever
+resulting from loss of use, data or profits, whether in an action of contract,negligence or other tortious action, arising out of or in connection withthe use or performance of this software. 
+
+%% This notice is provided with respect to SAX v. 2.0.1, which may be included with this software: 
+
+Copyright Status
+
+                         SAX is free!
+
+                         In fact, it's not possible to own a license to SAX, since it's been placed in the public
+                         domain. 
+
+                         No Warranty
+
+                         Because SAX is released to the public domain, there is no warranty for the design or for
+                         the software implementation, to the extent permitted by applicable law. Except when
+                         otherwise stated in writing the copyright holders and/or other parties provide SAX "as is"
+                         without warranty of any kind, either expressed or implied, including, but not limited to, the
+                         implied warranties of merchantability and fitness for a particular purpose. The entire risk as
+                         to the quality and performance of SAX is with you. Should SAX prove defective, you
+                         assume the cost of all necessary servicing, repair or correction.
+
+                         In no event unless required by applicable law or agreed to in writing will any copyright
+                         holder, or any other party who may modify and/or redistribute SAX, be liable to you for
+                         damages, including any general, special, incidental or consequential damages arising out of
+                         the use or inability to use SAX (including but not limited to loss of data or data being
+                         rendered inaccurate or losses sustained by you or third parties or a failure of the SAX to
+                         operate with any other programs), even if such holder or other party has been advised of
+                         the possibility of such damages.
+
+                         Copyright Disclaimers 
+
+                         This page includes statements to that effect by David Megginson, who would have been
+                         able to claim copyright for the original work. 
+                         SAX 1.0 
+
+                         Version 1.0 of the Simple API for XML (SAX), created collectively by the membership of
+                         the XML-DEV mailing list, is hereby released into the public domain.
+
+                         No one owns SAX: you may use it freely in both commercial and non-commercial
+                         applications, bundle it with your software distribution, include it on a CD-ROM, list the
+                         source code in a book, mirror the documentation at your own web site, or use it in any
+                         other way you see fit.
+
+                         David Megginson, sax@megginson.com
+                         1998-05-11
+
+                         SAX 2.0 
+
+                         I hereby abandon any property rights to SAX 2.0 (the Simple API for XML), and release
+                         all of the SAX 2.0 source code, compiled code, and documentation contained in this
+                         distribution into the Public Domain. SAX comes with NO WARRANTY or guarantee of
+                         fitness for any purpose.
+
+                         David Megginson, david@megginson.com
+                         2000-05-05
+
+%% This notice is provided with respect to Cryptix, which may be included with this software: 
+
+Cryptix General License
+
+Copyright © 1995-2003 The Cryptix Foundation Limited. All rights reserved.
+Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions aremet:
+
+   1.Redistributions of source code must retain the copyright notice, this list of conditions and the following disclaimer.    2.Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the     documentation and/or other materials provided with the distribution. 
+THIS SOFTWARE IS PROVIDED BY THE CRYPTIX FOUNDATION LIMITED AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS ORIMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FORA PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE CRYPTIX FOUNDATION LIMITED OR CONTRIBUTORS BELIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOTLIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESSINTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OFTHE POSSIBILITY OF SUCH DAMAGE.
+
+%% This notice is provided with respect to X Window System, which may be included with this software: 
+
+Copyright  The Open Group
+
+Permission to use, copy, modify, distribute, and sell this software and itsdocumentation for any purpose is hereby granted without fee, provided that theabove copyright notice appear in all copies and that both that copyright noticeand this permission notice appear in supporting documentation.
+
+The above copyright notice and this permission notice shall be included in allcopies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS ORIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESSFOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUPBE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OFCONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THESOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+Except as contained in this notice, the name of The Open Group shall not be used in advertising or otherwise to promote the sale, use or other dealings in this Software without prior written authorization from The Open Group.
+
+Portions also covered by other licenses as noted in the above URL.
+
+%% This notice is provided with respect to Retroweaver, which may be included with this software: 
+
+Copyright (c) February 2004, Toby Reyelts
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
+
+Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 
+Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 
+Neither the name of Toby Reyelts nor the names of his contributors may be used to endorse or promote products derived from this software without specific prior written permission. 
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICTLIABILITY, 
+OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+%% This notice is provided with respect to stripper, which may be included with this software: 
+
+Stripper : debug information stripper
+ Copyright (c) 2003 Kohsuke Kawaguchi
+ All rights reserved.
+
+ Redistribution and use in source and binary forms, with or without
+ modification, are permitted provided that the following conditions
+ are met:
+ 1. Redistributions of source code must retain the above copyright
+    notice, this list of conditions and the following disclaimer.
+ 2. Redistributions in binary form must reproduce the above copyright
+    notice, this list of conditions and the following disclaimer in the    documentation and/or other materials provided with the distribution. 3. Neither the name of the copyright holders nor the names of its
+    contributors may be used to endorse or promote products derived from    this software without specific prior written permission.
+
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+%% This notice is provided with respect to libpng official PNG reference library, which may be included with this software: 
+
+This copy of the libpng notices is provided for your convenience.  In case ofany discrepancy between this copy and the notices in the file png.h that isincluded in the libpng distribution, the latter shall prevail.
+
+COPYRIGHT NOTICE, DISCLAIMER, and LICENSE:
+
+If you modify libpng you may insert additional notices immediately followingthis sentence.
+
+libpng version 1.2.6, December 3, 2004, is
+Copyright (c) 2004 Glenn Randers-Pehrson, and is
+distributed according to the same disclaimer and license as libpng-1.2.5with the following individual added to the list of Contributing Authors
+   Cosmin Truta
+
+libpng versions 1.0.7, July 1, 2000, through 1.2.5 - October 3, 2002, areCopyright (c) 2000-2002 Glenn Randers-Pehrson, and are
+distributed according to the same disclaimer and license as libpng-1.0.6with the following individuals added to the list of Contributing Authors
+   Simon-Pierre Cadieux
+   Eric S. Raymond
+   Gilles Vollant
+
+and with the following additions to the disclaimer:
+
+   There is no warranty against interference with your enjoyment of the   library or against infringement.  There is no warranty that our
+   efforts or the library will fulfill any of your particular purposes   or needs.  This library is provided with all faults, and the entire   risk of satisfactory quality, performance, accuracy, and effort is with   the user.
+
+libpng versions 0.97, January 1998, through 1.0.6, March 20, 2000, areCopyright (c) 1998, 1999 Glenn Randers-Pehrson, and are
+distributed according to the same disclaimer and license as libpng-0.96,with the following individuals added to the list of Contributing Authors:
+   Tom Lane
+   Glenn Randers-Pehrson
+   Willem van Schaik
+
+libpng versions 0.89, June 1996, through 0.96, May 1997, are
+Copyright (c) 1996, 1997 Andreas Dilger
+Distributed according to the same disclaimer and license as libpng-0.88,with the following individuals added to the list of Contributing Authors:
+   John Bowler
+   Kevin Bracey
+   Sam Bushell
+   Magnus Holmgren
+   Greg Roelofs
+   Tom Tanner
+
+libpng versions 0.5, May 1995, through 0.88, January 1996, are
+Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.
+
+For the purposes of this copyright and license, "Contributing Authors"is defined as the following set of individuals:
+
+   Andreas Dilger
+   Dave Martindale
+   Guy Eric Schalnat
+   Paul Schmidt
+   Tim Wegner
+
+The PNG Reference Library is supplied "AS IS".  The Contributing Authorsand Group 42, Inc. disclaim all warranties, expressed or implied,
+including, without limitation, the warranties of merchantability and offitness for any purpose.  The Contributing Authors and Group 42, Inc.
+assume no liability for direct, indirect, incidental, special, exemplary,or consequential damages, which may result from the use of the PNG
+Reference Library, even if advised of the possibility of such damage.
+
+Permission is hereby granted to use, copy, modify, and distribute thissource code, or portions hereof, for any purpose, without fee, subjectto the following restrictions:
+
+1. The origin of this source code must not be misrepresented.
+
+2. Altered versions must be plainly marked as such and must not
+   be misrepresented as being the original source.
+
+3. This Copyright notice may not be removed or altered from any
+   source or altered source distribution.
+
+The Contributing Authors and Group 42, Inc. specifically permit, withoutfee, and encourage the use of this source code as a component to
+supporting the PNG file format in commercial products.  If you use thissource code in a product, acknowledgment is not required but would be
+appreciated.
+
+
+A "png_get_copyright" function is available, for convenient use in "about"boxes and the like:
+
+   printf("%s",png_get_copyright(NULL));
+
+Also, the PNG logo (in PNG format, of course) is supplied in the
+files "pngbar.png" and "pngbar.jpg (88x31) and "pngnow.png" (98x31).
+
+Libpng is OSI Certified Open Source Software.  OSI Certified Open Source is acertification mark of the Open Source Initiative.
+
+Glenn Randers-Pehrson
+glennrp at users.sourceforge.net
+December 3, 2004
+
+%% This notice is provided with respect to Libungif - An uncompressed GIF library, which may be included with this software: 
+
+The GIFLIB distribution is Copyright (c) 1997  Eric S. Raymond
+
+Permission is hereby granted, free of charge, to any person obtaining a copyof this software and associated documentation files (the "Software"), to dealin the Software without restriction, including without limitation the rightsto use, copy, modify, merge, publish, distribute, sublicense, and/or sellcopies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included inall copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS ORIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THEAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHERLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS INTHE SOFTWARE.
+
+%% This notice is provided with respect to XML Resolver library, Xalan J2, and StAX API, which may be included with this software: 
+
+                                 Apache License
+                           Version 2.0, January 2004
+                        http://www.apache.org/licenses/
+
+   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+   1. Definitions.
+
+      "License" shall mean the terms and conditions for use, reproduction,      and distribution as defined by Sections 1 through 9 of this document.
+      "Licensor" shall mean the copyright owner or entity authorized by      the copyright owner that is granting the License.
+
+      "Legal Entity" shall mean the union of the acting entity and all      other entities that control, are controlled by, or are under common      control with that entity. For the purposes of this definition,
+      "control" means (i) the power, direct or indirect, to cause the
+      direction or management of such entity, whether by contract or
+      otherwise, or (ii) ownership of fifty percent (50%) or more of the      outstanding shares, or (iii) beneficial ownership of such entity.
+      "You" (or "Your") shall mean an individual or Legal Entity
+      exercising permissions granted by this License.
+
+      "Source" form shall mean the preferred form for making modifications,      including but not limited to software source code, documentation      source, and configuration files.
+
+      "Object" form shall mean any form resulting from mechanical
+      transformation or translation of a Source form, including but
+      not limited to compiled object code, generated documentation,
+      and conversions to other media types.
+
+      "Work" shall mean the work of authorship, whether in Source or
+      Object form, made available under the License, as indicated by a      copyright notice that is included in or attached to the work
+      (an example is provided in the Appendix below).
+
+      "Derivative Works" shall mean any work, whether in Source or Object      form, that is based on (or derived from) the Work and for which the      editorial revisions, annotations, elaborations, or other modifications      represent, as a whole, an original work of authorship. For the purposes      of this License, Derivative Works shall not include works that remain      separable from, or merely link (or bind by name) to the interfaces of,      the Work and Derivative Works thereof.
+
+      "Contribution" shall mean any work of authorship, including
+      the original version of the Work and any modifications or additions      to that Work or Derivative Works thereof, that is intentionally
+      submitted to Licensor for inclusion in the Work by the copyright owner      or by an individual or Legal Entity authorized to submit on behalf of      the copyright owner. For the purposes of this definition, "submitted"      means any form of electronic, verbal, or written communication sent      to the Licensor or its representatives, including but not limited to      communication on electronic mailing lists, source code control systems,      and issue tracking systems that are managed by, or on behalf of, the      Licensor for the purpose of discussing and improving the Work, but      excluding communication that is conspicuously marked or otherwise      designated in writing by the copyright owner as "Not a Contribution."
+      "Contributor" shall mean Licensor and any individual or Legal Entity      on behalf of whom a Contribution has been received by Licensor and      subsequently incorporated within the Work.
+
+   2. Grant of Copyright License. Subject to the terms and conditions of      this License, each Contributor hereby grants to You a perpetual,      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      copyright license to reproduce, prepare Derivative Works of,
+      publicly display, publicly perform, sublicense, and distribute the      Work and such Derivative Works in Source or Object form.
+
+   3. Grant of Patent License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      (except as stated in this section) patent license to make, have made,      use, offer to sell, sell, import, and otherwise transfer the Work,      where such license applies only to those patent claims licensable      by such Contributor that are necessarily infringed by their
+      Contribution(s) alone or by combination of their Contribution(s)      with the Work to which such Contribution(s) was submitted. If You      institute patent litigation against any entity (including a
+      cross-claim or counterclaim in a lawsuit) alleging that the Work      or a Contribution incorporated within the Work constitutes direct      or contributory patent infringement, then any patent licenses
+      granted to You under this License for that Work shall terminate
+      as of the date such litigation is filed.
+
+   4. Redistribution. You may reproduce and distribute copies of the
+      Work or Derivative Works thereof in any medium, with or without
+      modifications, and in Source or Object form, provided that You
+      meet the following conditions:
+
+      (a) You must give any other recipients of the Work or
+          Derivative Works a copy of this License; and
+
+      (b) You must cause any modified files to carry prominent notices          stating that You changed the files; and
+
+      (c) You must retain, in the Source form of any Derivative Works
+          that You distribute, all copyright, patent, trademark, and
+          attribution notices from the Source form of the Work,
+          excluding those notices that do not pertain to any part of
+          the Derivative Works; and
+
+      (d) If the Work includes a "NOTICE" text file as part of its
+          distribution, then any Derivative Works that You distribute must          include a readable copy of the attribution notices contained          within such NOTICE file, excluding those notices that do not          pertain to any part of the Derivative Works, in at least one          of the following places: within a NOTICE text file distributed          as part of the Derivative Works; within the Source form or
+          documentation, if provided along with the Derivative Works; or,          within a display generated by the Derivative Works, if and
+          wherever such third-party notices normally appear. The contents          of the NOTICE file are for informational purposes only and
+          do not modify the License. You may add Your own attribution
+          notices within Derivative Works that You distribute, alongside          or as an addendum to the NOTICE text from the Work, provided          that such additional attribution notices cannot be construed          as modifying the License.
+
+      You may add Your own copyright statement to Your modifications and      may provide additional or different license terms and conditions      for use, reproduction, or distribution of Your modifications, or      for any such Derivative Works as a whole, provided Your use,
+      reproduction, and distribution of the Work otherwise complies with      the conditions stated in this License.
+
+   5. Submission of Contributions. Unless You explicitly state otherwise,      any Contribution intentionally submitted for inclusion in the Work      by You to the Licensor shall be under the terms and conditions of      this License, without any additional terms or conditions.
+      Notwithstanding the above, nothing herein shall supersede or modify      the terms of any separate license agreement you may have executed      with Licensor regarding such Contributions.
+
+   6. Trademarks. This License does not grant permission to use the trade      names, trademarks, service marks, or product names of the Licensor,      except as required for reasonable and customary use in describing the      origin of the Work and reproducing the content of the NOTICE file.
+   7. Disclaimer of Warranty. Unless required by applicable law or
+      agreed to in writing, Licensor provides the Work (and each
+      Contributor provides its Contributions) on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied, including, without limitation, any warranties or conditions      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+      PARTICULAR PURPOSE. You are solely responsible for determining the      appropriateness of using or redistributing the Work and assume any      risks associated with Your exercise of permissions under this License.
+   8. Limitation of Liability. In no event and under no legal theory,
+      whether in tort (including negligence), contract, or otherwise,
+      unless required by applicable law (such as deliberate and grossly      negligent acts) or agreed to in writing, shall any Contributor be      liable to You for damages, including any direct, indirect, special,      incidental, or consequential damages of any character arising as a      result of this License or out of the use or inability to use the      Work (including but not limited to damages for loss of goodwill,      work stoppage, computer failure or malfunction, or any and all
+      other commercial damages or losses), even if such Contributor
+      has been advised of the possibility of such damages.
+
+   9. Accepting Warranty or Additional Liability. While redistributing      the Work or Derivative Works thereof, You may choose to offer,
+      and charge a fee for, acceptance of support, warranty, indemnity,      or other liability obligations and/or rights consistent with this      License. However, in accepting such obligations, You may act only      on Your own behalf and on Your sole responsibility, not on behalf      of any other Contributor, and only if You agree to indemnify,
+      defend, and hold each Contributor harmless for any liability
+      incurred by, or claims asserted against, such Contributor by reason      of your accepting any such warranty or additional liability.
+
+   END OF TERMS AND CONDITIONS
+
+   APPENDIX: How to apply the Apache License to your work.
+
+      To apply the Apache License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+   Copyright [yyyy] [name of copyright owner]
+
+   Licensed under the Apache License, Version 2.0 (the "License");
+   you may not use this file except in compliance with the License.
+   You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+   Unless required by applicable law or agreed to in writing, software   distributed under the License is distributed on an "AS IS" BASIS,
+   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   See the License for the specific language governing permissions and   limitations under the License.
+
+%% Some Portions licensed from IBM are available at: 
+http://www.ibm.com/software/globalization/icu/
+
+%% This notice is provided with respect to ICU4J, ICU 1.8.1 and later, which may be included with this software: 
+
+ICU License - ICU 1.8.1 and later COPYRIGHT AND PERMISSION NOTICE Cop
+yright (c)
+1995-2003 International Business Machines Corporation and others All rightsreserved. Permission is hereby granted, free of charge, to any person obtaininga copy of this software and associated documentation files (the "Software"), todeal in the Software without restriction, including without limitation therights to use, copy, modify, merge, publish, distribute, and/or sell copies ofthe Software, and to permit persons to whom the Software is furnished to do so,provided that the above copyright notice(s) and this permission notice appear inall copies of the Software and that both the above copyright notice(s) and thispermission notice appear in supporting documentation. THE SOFTWARE IS PROVIDED"AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOTLIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSEAND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHTHOLDER OR HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR ANY C
+ LAIM, OR ANYSPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTINGFROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCEOR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE ORPERFORMANCE OF THIS SOFTWARE. Except as contained in this notice, the name of acopyright holder shall not be used in advertising or otherwise to promote thesale, use or other dealings in this Software without prior written authorizationof the copyright holder.
+
+%% This notice is provided with respect to Jing, which may be included with this software: 
+
+Jing Copying Conditions
+
+Copyright (c) 2001-2003 Thai Open Source Software Center Ltd
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without modification,are permitted provided that the following conditions are met:
+
+    * Redistributions of source code must retain the above copyright notice,this list of conditions and the following disclaimer.
+    * Redistributions in binary form must reproduce the above copyright notice,this list of conditions and the following disclaimer in the documentation and/orother materials provided with the distribution.
+    * Neither the name of the Thai Open Source Software Center Ltd nor the namesof its contributors may be used to endorse or promote products derived from thissoftware without specific prior written permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" ANDANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIEDWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE AREDISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANYDIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ONANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THISSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+%% This notice is provided with respect to RELAX NG Object Model/Parser, which may be included with this software: 
+
+
+The MIT License
+
+Copyright (c)  
+
+Permission is hereby granted, free of charge, to any person obtaining a copy ofthis software and associated documentation files (the "Software"), to deal inthe Software without restriction, including without limitation the rights touse, copy, modify, merge, publish, distribute, sublicense, and/or sell copies ofthe Software, and to permit persons to whom the Software is furnished to do so,subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in allcopies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS ORIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESSFOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS ORCOPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHERIN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR INCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+%% This notice is provided with respect to XFree86-VidMode Extension, which may be included with this software: 
+
+Version 1.1 of XFree86 ProjectLicence.
+
+    Copyright (C) 1994-2004 The XFree86 Project, Inc.    All rights reserved.
+
+    Permission is hereby granted, free of charge, to any person obtaining a copyof this software and associated documentation files (the "Software"), to deal inthe Software without restriction, including without limitation the rights touse, copy, modify, merge, publish, distribute, sublicence, and/or sell copies ofthe Software, and to permit persons to whom the Software is furnished to do so,subject to the following conditions:
+
+       1. Redistributions of source code must retain the above copyright notice,this list of conditions, and the following disclaimer.
+       2. Redistributions in binary form must reproduce the above copyrightnotice, this list of conditions and the following disclaimer in the
+documentation and/or other materials provided with the distribution, and in thesame place and form as other copyright, license and disclaimer information.       3. The end-user documentation included with the redistribution, if any,must include the following acknowledgment: "This product includes softwaredeveloped by The XFree86 Project, Inc (http://www.xfree86.org/) and itscontributors", in the same place and form as other third-party acknowledgments.Alternately, this acknowledgment may appear in the software itself, in the sameform and location as other such third-party acknowledgments.
+       4. Except as contained in this notice, the name of The XFree86 Project,Inc shall not be used in advertising or otherwise to promote the sale, use orother dealings in this Software without prior written authorization from TheXFree86 Project, Inc.
+
+    THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY ANDFITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE XFREE86PROJECT, INC OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; ORBUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER INCONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISINGIN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITYOF SUCH DAMAGE.
+
+%% This notice is provided with respect to XML Security, which may be included with this software: 
+
+  The Apache Software License,
+                                       Version 1.1
+
+
+                                                                                 PDF
+
+
+                                       Copyright (C) 2002 The Apache SoftwareFoundation.
+                                       All rights reserved. Redistribution anduse in
+                                       source and binary forms, with or withoutmodifica-
+                                       tion, are permitted provided that thefollowing
+                                       conditions are met: 1. Redistributions ofsource
+                                       code must retain the above copyrightnotice, this
+                                       list of conditions and the followingdisclaimer.
+                                       2. Redistributions in binary form mustreproduce
+                                       the above copyright notice, this list of                                       conditions and the following disclaimerin the
+                                       documentation and/or other materialsprovided with
+                                       the distribution. 3. The end-userdocumentation
+                                       included with the redistribution, if any,must
+                                       include the following acknowledgment:"This
+                                       product includes software developed bythe Apache
+                                       Software Foundation
+(http://www.apache.org/)."
+                                       Alternately, this acknowledgment mayappear in the
+                                       software itself, if and wherever suchthird-party
+                                       acknowledgments normally appear. 4. Thenames
+                                       "Apache Forrest" and "Apache SoftwareFoundation"
+                                       must not be used to endorse or promoteproducts
+                                       derived from this software without priorwritten
+                                       permission. For written permission,please contact
+                                       apache@apache.org. 5. Products derivedfrom this
+                                       software may not be called "Apache", normay
+                                       "Apache" appear in their name, withoutprior
+                                       written permission of the Apache Software                                       Foundation. THIS SOFTWARE IS PROVIDED``AS IS''
+                                       AND ANY EXPRESSED OR IMPLIED WARRANTIES,                                       INCLUDING, BUT NOT LIMITED TO, THEIMPLIED
+                                       WARRANTIES OF MERCHANTABILITY AND FITNESSFOR A
+                                       PARTICULAR PURPOSE ARE DISCLAIMED. IN NOEVENT
+                                       SHALL THE APACHE SOFTWARE FOUNDATION ORITS
+                                       CONTRIBUTORS BE LIABLE FOR ANY DIRECT,INDIRECT,
+                                       INCIDENTAL, SPECIAL, EXEMPLARY, ORCONSEQUENTIAL
+                                       DAMAGES (INCLU- DING, BUT NOT LIMITED TO,                                       PROCUREMENT OF SUBSTITUTE GOODS ORSERVICES; LOSS
+                                       OF USE, DATA, OR PROFITS; OR BUSINESS                                       INTERRUPTION) HOWEVER CAUSED AND ON ANYTHEORY OF
+                                       LIABILITY, WHETHER IN CONTRACT, STRICTLIABILITY,
+                                       OR TORT (INCLUDING NEGLIGENCE OROTHERWISE)
+                                       ARISING IN ANY WAY OUT OF THE USE OF THIS                                       SOFTWARE, EVEN IF ADVISED OF THEPOSSIBILITY OF
+                                       SUCH DAMAGE. This software consists ofvoluntary
+                                       contributions made by many individuals onbehalf
+                                       of the Apache Software Foundation. Formore
+                                       information on the Apache SoftwareFoundation,
+                                       please see .
+
+%% This notice is provided with respect to Independent JPEG Group's software (libjpeg), which may be included with this software: 
+
+In plain English:
+
+1. We don't promise that this software works.  (But if you find any bugs,
+   please let us know!)
+2. You can use this software for whatever you want.  You don't have to pay us.
+3. You may not pretend that you wrote this software.  If you use it in a program, you must acknowledge somewhere in your documentation that you've used the IJG code.
+
+In legalese:
+
+The authors make NO WARRANTY or representation, either express or implied, with respect to this software, its quality, accuracy, merchantability, or fitness for a particular purpose.  This software is provided "AS IS", and you, its user, assume the entire risk as to its quality and accuracy.
+
+This software is copyright (C) 1991-1998, Thomas G. Lane.
+All Rights Reserved except as specified below.
+
+Permission is hereby granted to use, copy, modify, and distribute this software (or portions thereof) for any purpose, without fee, subject to these conditions:
+
+(1) If any part of the source code for this software is distributed, then this
+README file must be included, with this copyright and no-warranty notice unaltered; and any additions, deletions, or changes to the original files must be clearly indicated in accompanying documentation.
+
+(2) If only executable code is distributed, then the accompanying documentation must state that "this software is based in part on the work of the Independent JPEG Group".
+
+(3) Permission for use of this software is granted only if the user accepts full responsibility for any undesirable consequences; the authors accept NO LIABILITY for damages of any kind.
+
+These conditions apply to any software derived from or based on the IJG code, not just to the unmodified library.  If you use our work, you ought to acknowledge us.
+
+Permission is NOT granted for the use of any IJG author's name or company name in advertising or publicity relating to this software or products derived from it.  This software may be referred to only as "the Independent JPEG Group's software".
+
+We specifically permit and encourage the use of this software as the basis of commercial products, provided that all warranty or liability claims are assumed by the product vendor.
+
+ansi2knr.c is included in this distribution by permission of L. Peter Deutsch, sole proprietor of its copyright holder, Aladdin Enterprises of Menlo Park, CA. ansi2knr.c is NOT covered by the above copyright and conditions, but instead by the usual distribution terms of the Free Software Foundation; principally, that you must include source code if you redistribute it.  (See the file ansi2knr.c for full details.)  However, since ansi2knr.c is not needed as part of any program generated from the IJG code, this does not limit you more than the foregoing paragraphs do.
+
+The Unix configuration script "configure" was produced with GNU Autoconf. It is copyright by the Free Software Foundation but is freely distributable. The same holds for its supporting scripts (config.guess, config.sub, ltconfig, ltmain.sh).  Another support script, install-sh, is copyright by M.I.T. but is also freely distributable.
+
+It appears that the arithmetic coding option of the JPEG spec is covered by patents owned by IBM, AT&T, and Mitsubishi.  Hence arithmetic coding cannot legally be used without obtaining one or more licenses.  For this reason, support for arithmetic coding has been removed from the free JPEG software. (Since arithmetic coding provides only a marginal gain over the unpatented Huffman mode, it is unlikely that very many implementations will support it.) So far as we are aware, there are no patent restrictions on the remaining code.
+
+The IJG distribution formerly included code to read and write GIF files. To avoid entanglement with the Unisys LZW patent, GIF reading support has been removed altogether, and the GIF writer has been simplified to produce "uncompressed GIFs".  This technique does not use the LZW algorithm; the resulting GIF files are larger than usual, but are readable by all standard GIF decoders.
+
+We are required to state that
+    "The Graphics Interchange Format(c) is the Copyright property of
+    CompuServe Incorporated.  GIF(sm) is a Service Mark property of
+    CompuServe Incorporated."
+
+%% This notice is provided with respect to X Resize and Rotate (Xrandr) Extension, which may be included with this software: 
+2. XFree86 License
+
+XFree86 code without an explicit copyright is covered by the following
+copyright/license:
+
+Copyright (C) 1994-2003 The XFree86 Project, Inc. All Rights Reserved.
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated documentation files (the "Software"), to deal in
+the Software without restriction, including without limitation the rights to
+use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
+the Software, and to permit persons to whom the Software is furnished to do so,
+subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
+FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE XFREE86
+PROJECT BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
+ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+Except as contained in this notice, the name of the XFree86 Project shall not be
+used in advertising or otherwise to promote the sale, use or other dealings in
+this Software without prior written authorization from the XFree86 Project.
+
+%% This notice is provided with respect to fontconfig, which may be included with this software: 
+Id: COPYING,v 1.3 2003/04/04 20:17:40 keithp Exp $
+Copyright 2001,2003 Keith Packard
+
+Permission to use, copy, modify, distribute, and sell this software and its
+documentation for any purpose is hereby granted without fee, provided that
+the above copyright notice appear in all copies and that both that
+copyright notice and this permission notice appear in supporting
+documentation, and that the name of Keith Packard not be used in
+advertising or publicity pertaining to distribution of the software without
+specific, written prior permission.  Keith Packard makes no
+representations about the suitability of this software for any purpose.  It
+is provided "as is" without express or implied warranty.
+
+KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
+INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
+EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
+CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
+DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
+TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+PERFORMANCE OF THIS SOFTWARE.
+%% This notice is provided with respect to XFree86, which may be included with this software: 
+Copyright (C) 1994-2002 The XFree86 Project, Inc. All Rights Reserved.
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated
+documentation files (the "Software"), to deal in the Software without
+restriction, including without limitation
+the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
+sell copies of the Software, and to
+permit persons to whom the Software is furnished to do so, subject to the
+following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the
+Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT
+NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
+PURPOSE AND
+NONINFRINGEMENT. IN NO EVENT SHALL THE XFREE86 PROJECT BE LIABLE FOR ANY CLAIM,
+DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN
+CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+Except as contained in this notice, the name of the XFree86 Project shall not be
+used in advertising or otherwise
+to promote the sale, use or other dealings in this Software without prior
+written authorization from the XFree86
+Project.
+%% This notice is provided with respect to Fast Infoset, which may be included with this software: 
+* Fast Infoset ver. 0.1 software ("Software") 
+* 
+* Copyright, 2004-2005 Sun Microsystems, Inc. All Rights Reserved. 
+* 
+* Software is licensed under the Apache License, Version 2.0 (the "License"); 
+* you may not use this file except in compliance with the License. You may 
+* obtain a copy of the License at: 
+ * 
+ * http://www.apache.org/licenses/LICENSE-2.0 
+ * 
+ * Unless required by applicable law or agreed to in writing, software 
+* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 
+* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 
+* License for the specific language governing permissions and limitations. 
+* 
+* Sun supports and benefits from the global community of open source 
+* developers, and thanks the community for its important contributions and 
+* open standards-based technology, which Sun has adopted into many of its 
+* products. 
+* 
+* Please note that portions of Software may be provided with notices and 
+* open source licenses from such communities and third parties that govern the 
+* use of those portions, and any licenses granted hereunder do not alter any 
+* rights and obligations you may have under such open source licenses, 
+* however, the disclaimer of warranty and limitation of liability provisions 
+* in this License will apply to all Software in this distribution. 
+* 
+* You acknowledge that the Software is not designed, licensed or intended 
+* for use in the design, construction, operation or maintenance of any nuclear 
+* facility. 
+* 
+* Apache License 
+* Version 2.0, January 2004 
+* http://www.apache.org/licenses/ 
+* 
+*/ 
+/* 
+* ==================================================================== 
+* 
+* This code is subject to the freebxml License, Version 1.1 
+* 
+* Copyright (c) 2001 - 2005 freebxml.org. All rights reserved. 
+* 
+* $Header: /cvs/fi/FastInfoset/src/com/sun/xml/internal/fastinfoset/AbstractResourceBundle.java,v 1.2 
+*  ==================================================================== 
+*/ 
+%% This notice is provided with respect to Kerberos, which may be included with this software: 
+
+/* 
+ * Copyright (C) 1998 by the FundsXpress, INC. 
+ * 
+ * All rights reserved. 
+ * 
+ * Export of this software from the United States of America may require 
+ * a specific license from the United States Government.  It is the 
+ * responsibility of any person or organization contemplating export to 
+ * obtain such a license before exporting. 
+ * 
+ * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and 
+ * distribute this software and its documentation for any purpose and 
+ * without fee is hereby granted, provided that the above copyright 
+ * notice appear in all copies and that both that copyright notice and 
+ * this permission notice appear in supporting documentation, and that 
+ * the name of FundsXpress. not be used in advertising or publicity pertaining 
+ * to distribution of the software without specific, written prior 
+ * permission. FundsXpress makes no representations about the suitability of 
+ * this software for any purpose. It is provided "as is" without express 
+ * or implied warranty. 
+ * 
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR 
+ * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED 
+ * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. 
+ */ 
+
+%% This notice is provided with respect to Unicode's CLDR data repository, which may be included with this software: 
+
+ Unicode Copyright
+
+    For the general privacy policy governing access to this site, see the 
+Unicode Privacy Policy. For trademark usage, see the the Unicode Consortium
+Trademarks and Logo Policy.
+    Notice to End User: Terms of Use
+    Carefully read the following legal agreement ("Agreement"). Use or copying
+of the software and/or codes provided with this agreement (The "Software")
+constitutes your acceptance of these terms
+
+       1. Unicode Copyright.
+             1. Copyright © 1991-2005 Unicode, Inc. All rights reserved.
+             2. Certain documents and files on this website contain a legend
+indicating that "Modification is permitted." Any person is hereby authorized,
+without fee, to modify such documents and files to create derivative works
+conforming to the Unicode® Standard, subject to Terms and Conditions herein.
+             3. Any person is hereby authorized, without fee, to view, use,
+reproduce, and distribute all documents and files solely for informational
+purposes in the creation of products supporting the Unicode Standard, subject to
+the Terms and Conditions herein.
+             4. Further specifications of rights and restrictions pertaining to
+the use of the particular set of data files known as the "Unicode Character
+Database" can be found in Exhibit 1.
+             5. Further specifications of rights and restrictions pertaining to
+the use of the particular set of files that constitute the online edition of The
+Unicode Standard, Version 4.0, may be found in V4.0 online edition.
+             6. No license is granted to "mirror" the Unicode website where a
+fee is charged for access to the "mirror" site.
+             7. Modification is not permitted with respect to this document. All
+copies of this document must be verbatim.
+       2. Restricted Rights Legend. Any technical data or software which is
+licensed to the United States of America, its agencies and/or instrumentalities
+under this Agreement is commercial technical data or commercial computer
+software developed exclusively at private expense as defined in FAR 2.101, or
+DFARS 252.227-7014 (June 1995), as applicable. For technical data, use,
+duplication, or disclosure by the Government is subject to restrictions as set
+forth in DFARS 202.227-7015 Technical Data, Commercial and Items (Nov 1995) and
+this Agreement. For Software, in accordance with FAR 12-212 or DFARS 227-7202,
+as applicable, use, duplication or disclosure by the Government is subject to
+the restrictions set forth in this Agreement.
+       3. Warranties and Disclaimers.
+             1. This publication and/or website may include technical or
+typographical errors or other inaccuracies . Changes are periodically added to
+the information herein; these changes will be incorporated in new editions of
+the publication and/or website. Unicode may make improvements and/or changes in
+the product(s) and/or program(s) described in this publication and/or website at
+any time.
+             2. If this file has been purchased on magnetic or optical media
+from Unicode, Inc. the sole and exclusive remedy for any claim will be exchange
+of the defective media within ninety (90) days of original purchase.
+             3. EXCEPT AS PROVIDED IN SECTION C.2, THIS PUBLICATION AND/OR
+SOFTWARE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND EITHER EXPRESS,
+IMPLIED, OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. UNICODE
+AND ITS LICENSORS ASSUME NO RESPONSIBILITY FOR ERRORS OR OMISSIONS IN THIS
+PUBLICATION AND/OR SOFTWARE OR OTHER DOCUMENTS WHICH ARE REFERENCED BY OR LINKED
+TO THIS PUBLICATION OR THE UNICODE WEBSITE.
+       4. Waiver of Damages. In no event shall Unicode or its licensors be
+liable for any special, incidental, indirect or consequential damages of any
+kind, or any damages whatsoever, whether or not Unicode was advised of the
+possibility of the damage, including, without limitation, those resulting from
+the following: loss of use, data or profits, in connection with the use,
+modification or distribution of this information or its derivatives.
+       5. Trademarks.
+             1. Unicode and the Unicode logo are registered trademarks of
+Unicode, Inc. 
+             2. This site contains product names and corporate names of other
+companies. All product names and company names and logos mentioned herein are
+the trademarks or registered trademarks of their respective owners. Other
+products and corporate names mentioned herein which are trademarks of a third
+party are used only for explanation and for the owners' benefit and with no
+intent to infringe.
+             3. Use of third party products or information referred to herein is
+at the user's risk.
+       6. Miscellaneous.
+             1. Jurisdiction and Venue. This server is operated from a location
+in the State of California, United States of America. Unicode makes no
+representation that the materials are appropriate for use in other locations. If
+you access this server from other locations, you are responsible for compliance
+with local laws. This Agreement, all use of this site and any claims and damages
+resulting from use of this site are governed solely by the laws of the State of
+California without regard to any principles which would apply the laws of a
+different jurisdiction. The user agrees that any disputes regarding this site
+shall be resolved solely in the courts located in Santa Clara County,
+California. The user agrees said courts have personal jurisdiction and agree to
+waive any right to transfer the dispute to any other forum.
+             2. Modification by Unicode Unicode shall have the right to modify
+this Agreement at any time by posting it to this site. The user may not assign
+any part of this Agreement without Unicode's prior written consent.
+             3. Taxes. The user agrees to pay any taxes arising from access to
+this website or use of the information herein, except for those based on
+Unicode's net income.
+             4. Severability.  If any provision of this Agreement is declared
+invalid or unenforceable, the remaining provisions of this Agreement shall
+remain in effect.
+             5. Entire Agreement. This Agreement constitutes the entire
+agreement between the parties. 
+
+EXHIBIT 1
+UNICODE, INC. LICENSE AGREEMENT - DATA FILES AND SOFTWARE
+
+    Unicode Data Files include all data files under the directories
+http://www.unicode.org/Public/ and http://www.unicode.org/reports/. Unicode
+Software includes any source code under the directories
+http://www.unicode.org/Public/ and http://www.unicode.org/reports/.
+
+    NOTICE TO USER: Carefully read the following legal agreement. BY
+DOWNLOADING, INSTALLING, COPYING OR OTHERWISE USING UNICODE INC.'S DATA FILES
+("DATA FILES"), AND/OR SOFTWARE ("SOFTWARE"), YOU UNEQUIVOCALLY ACCEPT, AND
+AGREE TO BE BOUND BY, ALL OF THE TERMS AND CONDITIONS OF THIS AGREEMENT. IF YOU
+DO NOT AGREE, DO NOT DOWNLOAD, INSTALL, COPY, DISTRIBUTE OR USE THE DATA FILES
+OR SOFTWARE.
+
+    COPYRIGHT AND PERMISSION NOTICE
+
+    Copyright Ã?Â,Ã,© 1991-2004 Unicode, Inc. All rights reserved. Distributed under
+the Terms of Use in http://www.unicode.org/copyright.html.
+
+    Permission is hereby granted, free of charge, to any person obtaining a copy
+of the Unicode data files and associated documentation (the "Data Files") or
+Unicode software and associated documentation (the "Software") to deal in the
+Data Files or Software without restriction, including without limitation the
+rights to use, copy, modify, merge, publish, distribute, and/or sell copies of
+the Data Files or Software, and to permit persons to whom the Data Files or
+Software are furnished to do so, provided that (a) the above copyright notice(s)
+and this permission notice appear with all copies of the Data Files or Software,
+(b) both the above copyright notice(s) and this permission notice appear in
+associated documentation, and (c) there is clear notice in each modified Data
+File or in the Software as well as in the documentation associated with the Data
+File(s) or Software that the data or software has been modified.
+
+    THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
+KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD
+PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS
+NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL
+DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
+WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
+OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THE DATA FILES OR SOFTWARE.
+
+    Except as contained in this notice, the name of a copyright holder shall not
+be used in advertising or otherwise to promote the sale, use or other dealings
+in these Data Files or Software without prior written authorization of the
+copyright holder.
+
+    Unicode and the Unicode logo are trademarks of Unicode, Inc., and may be
+registered in some jurisdictions. All other trademarks and registered trademarks
+mentioned herein are the property of their respective owners.
+%% This notice is provided with respect to RSA PKCS#11 Header Files & Specification, which may be included with this software: 
+
+/* 
+ * Copyright (C) 1998 by the FundsXpress, INC. 
+ * 
+ * All rights reserved. 
+ * 
+ * Export of this software from the United States of America may require 
+ * a specific license from the United States Government.  It is the 
+ * responsibility of any person or organization contemplating export to 
+ * obtain such a license before exporting. 
+ * 
+ * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and 
+ * distribute this software and its documentation for any purpose and 
+ * without fee is hereby granted, provided that the above copyright 
+ * notice appear in all copies and that both that copyright notice and 
+ * this permission notice appear in supporting documentation, and that 
+ * the name of FundsXpress. not be used in advertising or publicity pertaining 
+ * to distribution of the software without specific, written prior 
+ * permission.  FundsXpress makes no representations about the suitability of 
+ * this software for any purpose.  It is provided "as is" without express 
+ * or implied warranty. 
+ * 
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR 
+ * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED 
+ * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. 
+ */ 
+
+%% This notice is provided with respect to certain files/code which may included in the implementation of AWT within the software: 
+
+****************************************************** 
+BEGIN  src/solaris/native/sun/awt/HPkeysym.h 
+Copyright 1987, 1998  The Open Group 
+
+All Rights Reserved. 
+
+The above copyright notice and this permission notice shall be included 
+in all copies or substantial portions of the Software. 
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 
+OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 
+IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR 
+OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 
+ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 
+OTHER DEALINGS IN THE SOFTWARE. 
+
+Except as contained in this notice, the name of The Open Group shall 
+not be used in advertising or otherwise to promote the sale, use or 
+other dealings in this Software without prior written authorization 
+from The Open Group. 
+
+Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts, 
+
+All Rights Reserved 
+
+Permission to use, copy, modify, and distribute this software and its 
+documentation for any purpose and without fee is hereby granted, 
+provided that the above copyright notice appear in all copies and that 
+both that copyright notice and this permission notice appear in 
+supporting documentation, and that the names of Hewlett Packard 
+or Digital not be 
+used in advertising or publicity pertaining to distribution of the 
+software without specific, written prior permission. 
+
+DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING 
+ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL 
+DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR 
+ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, 
+WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, 
+ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 
+SOFTWARE. 
+
+HEWLETT-PACKARD MAKES NO WARRANTY OF ANY KIND WITH REGARD 
+TO THIS SOFWARE, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
+WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
+PURPOSE.  Hewlett-Packard shall not be liable for errors 
+contained herein or direct, indirect, special, incidental or 
+consequential damages in connection with the furnishing, 
+performance, or use of this material. 
+
+END  src/solaris/native/sun/awt/HPkeysym.h 
+****************************************************** 
+****************************************************** 
+BEGIN src/solaris/native/sun/awt/Xrandr.h 
+/* 
+ * $XFree86: xc/lib/Xrandr/Xrandr.h,v 1.9 2002/09/29 23:39:44 keithp Exp $ 
+ * 
+ * Copyright © 2000 Compaq Computer Corporation, Inc. 
+ * Copyright © 2002 Hewlett-Packard Company, Inc. 
+ * 
+ * Permission to use, copy, modify, distribute, and sell this software and its 
+ * documentation for any purpose is hereby granted without fee, provided that 
+ * the above copyright notice appear in all copies and that both that 
+ * copyright notice and this permission notice appear in supporting 
+ * documentation, and that the name of Compaq not be used in advertising or 
+ * publicity pertaining to distribution of the software without specific, 
+ * written prior permission.  HP makes no representations about the 
+ * suitability of this software for any purpose.  It is provided "as is" 
+ * without express or implied warranty. 
+ * 
+ * HP DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL 
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL COMPAQ 
+ * BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION 
+ * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 
+ * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 
+ * 
+ * Author:  Jim Gettys, HP Labs, HP. 
+ */ 
+
+
+END src/solaris/native/sun/awt/Xrandr.h 
+****************************************************** 
+BEGIN src/solaris/native/sun/awt/extutil.h 
+/* 
+ * $Xorg: extutil.h,v 1.3 2000/08/18 04:05:45 coskrey Exp $ 
+ * 
+Copyright 1989, 1998  The Open Group 
+
+All Rights Reserved. 
+
+The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. 
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE 
+OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 
+AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 
+CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 
+
+Except as contained in this notice, the name of The Open Group shall not be 
+used in advertising or otherwise to promote the sale, use or other dealings 
+in this Software without prior written authorization from The Open Group. 
+ * 
+ * Author:  Jim Fulton, MIT The Open Group 
+ * 
+ *                     Xlib Extension-Writing Utilities 
+ * 
+ * This package contains utilities for writing the client API for various 
+ * protocol extensions.  THESE INTERFACES ARE NOT PART OF THE X STANDARD AND 
+ * ARE SUBJECT TO CHANGE! 
+ */ 
+/* $XFree86: xc/include/extensions/extutil.h,v 1.5 2001/01/17 17:53:20 dawes Exp $ */ 
+
+END src/solaris/native/sun/awt/extutil.h 
+****************************************************** 
+BEGIN   src/solaris/native/sun/awt/fontconfig.h 
+/* 
+ * $RCSId: xc/lib/fontconfig/fontconfig/fontconfig.h,v 1.30 2002/09/26 00:17:27 
+keithp Exp $ 
+ * 
+ * Copyright © 2001 Keith Packard 
+ * 
+ * Permission to use, copy, modify, distribute, and sell this software and its 
+ * documentation for any purpose is hereby granted without fee, provided that 
+ * the above copyright notice appear in all copies and that both that 
+ * copyright notice and this permission notice appear in supporting 
+ * documentation, and that the name of Keith Packard not be used in 
+ * advertising or publicity pertaining to distribution of the software without 
+ * specific, written prior permission.  Keith Packard makes no 
+ * representations about the suitability of this software for any purpose.  It 
+ * is provided "as is" without express or implied warranty. 
+ * 
+ * KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, 
+ * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO 
+ * EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR 
+ * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, 
+ * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER 
+ * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 
+ * PERFORMANCE OF THIS SOFTWARE. 
+
+END   src/solaris/native/sun/awt/fontconfig.h 
+****************************************************** 
+BEGIN src/solaris/native/sun/awt/list.c 
+AND  src/solaris/native/sun/awt/list.h 
+AND src/solaris/native/sun/awt/multiVis.c 
+AND  src/solaris/native/sun/awt/multiVis.h 
+AND  src/solaris/native/sun/awt/wsutils.h 
+
+Copyright (c) 1994 Hewlett-Packard Co. 
+Copyright (c) 1996  X Consortium 
+
+Permission is hereby granted, free of charge, to any person obtaining 
+a copy of this software and associated documentation files (the 
+"Software"), to deal in the Software without restriction, including 
+without limitation the rights to use, copy, modify, merge, publish, 
+distribute, sublicense, and sell copies of the Software, and to 
+permit persons to whom the Software is furnished to do so, subject to 
+the following conditions: 
+
+The above copyright notice and this permission notice shall be included 
+in all copies or substantial portions of the Software. 
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 
+OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 
+IN NO EVENT SHALL THE X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR 
+OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 
+ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 
+OTHER DEALINGS IN THE SOFTWARE. 
+
+Except as contained in this notice, the name of the X Consortium shall 
+not be used in advertising or otherwise to promote the sale, use or 
+other dealings in this Software without prior written authorization 
+from the X Consortium. 
+
+END src/solaris/native/sun/awt/list.c 
+AND  src/solaris/native/sun/awt/list.h 
+AND src/solaris/native/sun/awt/multiVis.c 
+AND  src/solaris/native/sun/awt/multiVis.h 
+AND  src/solaris/native/sun/awt/wsutils.h 
+
+***************************************************************** 
+BEGIN src/solaris/native/sun/awt/randr.h 
+
+ * 
+ * Copyright © 2000, Compaq Computer Corporation, 
+ * Copyright © 2002, Hewlett Packard, Inc. 
+ * 
+ * Permission to use, copy, modify, distribute, and sell this software and its 
+ * documentation for any purpose is hereby granted without fee, provided that 
+ * the above copyright notice appear in all copies and that both that 
+ * copyright notice and this permission notice appear in supporting 
+ * documentation, and that the name of Compaq or HP not be used in advertising 
+ * or publicity pertaining to distribution of the software without specific, 
+ * written prior permission.  HP makes no representations about the 
+ * suitability of this software for any purpose.  It is provided "as is" 
+ * without express or implied warranty. 
+ * 
+ * HP DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL 
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL HP 
+ * BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION 
+ * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 
+ * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 
+ * 
+ * Author:  Jim Gettys, HP Labs, Hewlett-Packard, Inc. 
+
+END src/solaris/native/sun/awt/randr.h 
+***************************************************** 
+
+BEGIN src/solaris/native/sun/java2d/opengl/J2D_GL/glx.h 
+ * Mesa 3-D graphics library 
+ * Version:  4.1 
+ * 
+ * Copyright (C) 1999-2002  Brian Paul   All Rights Reserved. 
+ * 
+ * Permission is hereby granted, free of charge, to any person obtaining a 
+ * copy of this software and associated documentation files (the "Software"), 
+ * to deal in the Software without restriction, including without limitation 
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense, 
+ * and/or sell copies of the Software, and to permit persons to whom the 
+ * Software is furnished to do so, subject to the following conditions: 
+ * 
+ * The above copyright notice and this permission notice shall be included 
+ * in all copies or substantial portions of the Software. 
+ * 
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL 
+ * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 
+ * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 
+ * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 
+
+END src/solaris/native/sun/java2d/opengl/J2D_GL/glx.h 
diff --git a/jaxws/make/Makefile b/jaxws/make/Makefile
new file mode 100644
index 0000000..3dab62b
--- /dev/null
+++ b/jaxws/make/Makefile
@@ -0,0 +1,134 @@
+#
+# Copyright 2007 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+#
+
+# Makefile for jaxws: wrapper around Ant build.xml file
+
+#
+# On Solaris, the 'make' utility from Sun will not work with these makefiles.
+#    This little rule is only understood by Sun's make, and is harmless
+#    when seen by the GNU make tool. If using Sun's make, this causes the
+#    make command to fail.
+#
+SUN_MAKE_TEST:sh = @echo "ERROR: PLEASE USE GNU VERSION OF MAKE"; exit 33
+
+ifdef QUIET
+  ANT_OPTIONS += -quiet
+endif
+
+ifdef VERBOSE
+  ANT_OPTIONS += -verbose
+endif
+
+ifdef JDK_VERSION
+  ANT_OPTIONS += -Djdk.version=$(JDK_VERSION)
+endif 
+
+ifdef FULL_VERSION
+  ANT_OPTIONS += -Dfull.version='$(FULL_VERSION)' # will contain spaces
+endif 
+
+ifdef MILESTONE
+  ANT_OPTIONS += -Dmilestone=$(MILESTONE)
+endif
+
+ifdef BUILD_NUMBER
+  ANT_OPTIONS += -Dbuild.number=$(BUILD_NUMBER)
+else
+  ifdef JDK_BUILD_NUMBER
+    ANT_OPTIONS += -Dbuild.number=$(JDK_BUILD_NUMBER)
+  endif
+endif
+
+ifeq ($(VARIANT), DBG)
+  ANT_OPTIONS += -Djavac.debug=true
+else
+  ifeq ($(VARIANT), OPT)
+    ANT_OPTIONS += -Djavac.debug=false
+  endif
+endif
+
+# Note: j2se/make/common/Defs.gmk uses LANGUAGE_VERSION (-source NN)
+# and the somewhat misnamed CLASS_VERSION (-target NN)
+ifdef TARGET_CLASS_VERSION
+  ANT_OPTIONS += -Djavac.target=$(TARGET_CLASS_VERSION)
+else
+  ifdef JAVAC_TARGET_ARG
+    ANT_OPTIONS += -Djavac.target=$(JAVAC_TARGET_ARG)
+  endif
+endif
+
+ifdef ALT_BOOTDIR
+  ANT_JAVA_HOME = JAVA_HOME=$(ALT_BOOTDIR)
+endif
+
+ifdef ALT_OUTPUTDIR
+  OUTPUTDIR = $(ALT_OUTPUTDIR)
+  ANT_OPTIONS += -Dbuild.dir=$(ALT_OUTPUTDIR)/build
+  ANT_OPTIONS += -Ddist.dir=$(ALT_OUTPUTDIR)/dist
+else
+  OUTPUTDIR = ..
+endif
+ABS_OUTPUTDIR = $(call FullPath,$(OUTPUTDIR))
+
+ifdef ALT_LANGTOOLS_DIST
+  ANT_OPTIONS += -Dbootstrap.dir=$(ALT_LANGTOOLS_DIST)/bootstrap
+endif
+
+ifdef FINDBUGS_HOME
+  ANT_OPTIONS += -Dfindbugs.home=$(FINDBUGS_HOME)
+endif
+
+ifdef ANT_HOME
+  ANT = $(ANT_HOME)/bin/ant
+  ifneq ($(shell test -x $(ANT); echo $$?), 0)
+    $(error "$(ANT) not found; please update ANT_HOME")
+  endif
+else
+  ANT = ant
+  ifneq ($(shell which $(ANT) > /dev/null; echo $$?), 0)
+    $(error "\"ant\" not found; please set ANT_HOME or put \"ant\" on your PATH")
+  endif
+endif
+
+# Default target and expected 'do everything' target
+all: build
+
+# Standard make clobber target
+clobber: clean
+
+# All ant targets of interest
+ANT_TARGETS = build clean sanity # for now
+
+# Create a make target for each
+$(ANT_TARGETS):
+	$(ANT_JAVA_HOME) $(ANT) -version
+	$(ANT_JAVA_HOME) $(ANT) $(ANT_OPTIONS) $@
+
+# Targets for Sun's internal JPRT build system
+jprt_build_product jprt_build_debug jprt_build_fastdebug: all
+
+# Declare these phony (not filenames)
+.PHONY: $(ANT_TARGETS) all clobber \
+	jprt_build_product jprt_build_debug jprt_build_fastdebug
diff --git a/jaxws/make/README b/jaxws/make/README
new file mode 100644
index 0000000..3a06b29
--- /dev/null
+++ b/jaxws/make/README
@@ -0,0 +1,14 @@
+README:
+  This file should be located at the top of the jaxws Mercurial repository.
+
+  See http://openjdk.java.net/ for more information about the OpenJDK.
+
+  See ../README-builds.html for complete details on build machine requirements.
+
+Simple Build Instructions:
+
+    cd make && gnumake
+     
+  The files that will be imported into the jdk build will be in the "dist"
+  directory.
+
diff --git a/jaxws/make/build.properties b/jaxws/make/build.properties
new file mode 100644
index 0000000..e022509
--- /dev/null
+++ b/jaxws/make/build.properties
@@ -0,0 +1,46 @@
+#
+# Copyright 2007 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+#
+
+# This is the JDK used to build and run the bootstrap version of javac.
+# The bootstrap javac is used to compile both boostrap versions of the
+# other tools, and product versions of all the tools.
+# Override this path as needed, either on the command line or in 
+# one of the standard user build.properties files (see build.xml)
+
+# options for the <javac> tasks used to compile the tools
+javac.target = 5
+javac.debug = true
+javac.debuglevel = source,lines
+javac.no.jdk.warnings = -XDignore.symbol.file=true
+# set the following to -version to verify the versions of javac being used
+javac.version.opt = 
+# in time, there should be no exceptions to -Xlint:all
+javac.lint.opts = -Xlint:all,-unchecked,-deprecation,-fallthrough,-cast,-serial -Werror
+
+# JVM memory size
+javac.memoryInitialSize = 128m
+javac.memoryMaximumSize = 256m
+
+#------------------------------------------------------------
diff --git a/jaxws/make/build.xml b/jaxws/make/build.xml
new file mode 100644
index 0000000..9f013e9
--- /dev/null
+++ b/jaxws/make/build.xml
@@ -0,0 +1,120 @@
+<?xml version="1.0"?>
+<!--
+ Copyright 2007 Sun Microsystems, Inc.  All Rights Reserved.
+ DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+ This code is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License version 2 only, as
+ published by the Free Software Foundation.  Sun designates this
+ particular file as subject to the "Classpath" exception as provided
+ by Sun in the LICENSE file that accompanied this code.
+
+ This code is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ version 2 for more details (a copy is included in the LICENSE file that
+ accompanied this code).
+
+ You should have received a copy of the GNU General Public License version
+ 2 along with this work; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+ Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ CA 95054 USA or visit www.sun.com if you need additional information or
+ have any questions.
+-->
+
+<!--
+ This is the main build file for the jaxws workspace.
+ -->
+
+<project name="jaxws" default="all" basedir=".">
+
+    <!-- Convenient shorthands for standard locations within the workspace. -->
+    <property file="build.properties"/>
+    <property name="topdir" value=".."/>
+    <property name="build.dir" location="${topdir}/build"/>
+    <property name="build.classes.dir" location="${build.dir}/classes"/>
+    <property name="build.gensrc.dir" location="${build.dir}/gensrc"/>
+    <property name="build.toolclasses.dir" location="${build.dir}/toolclasses"/>
+    <property name="dist.dir" location="${topdir}/dist"/>
+    <property name="dist.lib.dir" location="${dist.dir}/lib"/>
+    <property name="make.dir" location="${topdir}/make"/>
+    <property name="make.tools.dir" location="${make.dir}/tools"/>
+    <property name="src.dir" location="${topdir}/src"/>
+    <property name="src.classes.dir" location="${src.dir}/share/classes"/>
+    <property environment="env"/>
+
+    <target name="build" depends="banner, build-classes, build-tools, build-binaries">
+	<mkdir dir="${dist.lib.dir}"/>
+	<jar file="${dist.lib.dir}/classes.jar" basedir="${build.classes.dir}"/>
+	<zip file="${dist.lib.dir}/src.zip" basedir="${src.classes.dir}"/>
+    </target>
+
+    <!-- Debug information -->
+    <target name="sanity"
+        description="display settings of configuration values">
+        <echo level="info">ant.home = ${ant.home}</echo>
+        <echo level="info">java.home = ${env.JAVA_HOME}</echo>
+        <echo level="info">bootstrap.dir = ${bootstrap.dir}</echo>
+    </target>
+
+    <target name="build-tools" depends="-defs-pstrip">
+        <mkdir dir="${build.dir}"/>
+        <mkdir dir="${build.classes.dir}"/>
+	    <pstrip srcdir="${src.classes.dir}"
+                    destdir="${build.classes.dir}"
+		    includes="**/*.properties"/>
+    </target>
+
+    <target name="build-binaries">
+        <mkdir dir="${build.dir}"/>
+        <mkdir dir="${build.classes.dir}"/>
+            <copy todir="${build.classes.dir}">
+                 <fileset dir="${src.classes.dir}"
+                     includes="**/*.xsd, **/*.default"
+                     excludes="**/*.java, **/*.package.html, **/*.properties"/>
+            </copy>
+        <mkdir dir="${build.classes.dir}/META-INF/services"/>
+            <copy todir="${build.classes.dir}/META-INF/services"
+                  file="${src.classes.dir}/com/sun/tools/etc/META-INF/services/com.sun.mirror.apt.AnnotationProcessorFactory"/>
+    </target>
+
+    <target name="-defs-pstrip">
+      <mkdir dir="${build.toolclasses.dir}"/>
+      <javac srcdir="${make.tools.dir}/StripProperties"
+		destdir="${build.toolclasses.dir}/"
+		classpath="${ant.home}/lib/ant.jar"/>
+      <taskdef name="pstrip"
+		 classname="StripPropertiesTask"
+		 classpath="${build.toolclasses.dir}/"/>
+    </target>
+
+    <target name="build-classes" depends="sanity">
+      <mkdir dir="${build.dir}"/>
+      <mkdir dir="${build.classes.dir}"/>
+      <javac fork="true"
+             srcdir="${src.classes.dir}"
+             destdir="${build.classes.dir}"
+             memoryInitialSize="${javac.memoryInitialSize}"
+             memoryMaximumSize="${javac.memoryMaximumSize}"
+             target="${javac.target}"
+             excludes="com/sun/tools/internal/txw2/**">
+         <compilerarg value="-J-Xbootclasspath/p:${bootstrap.dir}/lib/javac.jar"/>
+         <compilerarg line="${javac.version.opt}"/>
+         <compilerarg line="${javac.no.jdk.warnings}"/>
+      </javac>
+    </target>
+
+    <target name="clean" description="Delete all generated files">
+	<delete dir="${build.dir}"/>
+	<delete dir="${dist.dir}"/>
+    </target>
+
+    <target name="banner">
+      <echo>+---------------------------------------+</echo>
+      <echo>+    Building JAX-WS Component          +</echo>
+      <echo>+---------------------------------------+</echo>
+    </target>
+
+</project>
diff --git a/jaxws/make/jprt.config b/jaxws/make/jprt.config
new file mode 100644
index 0000000..90200b1
--- /dev/null
+++ b/jaxws/make/jprt.config
@@ -0,0 +1,241 @@
+#!echo "This is not a shell script"
+#############################################################################
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+#
+#############################################################################
+#
+# JPRT shell configuration for building.
+#
+# Input environment variables:
+#    ALT_BOOTDIR
+#    ALT_SLASH_JAVA
+#    ALT_JDK_IMPORT_PATH
+#    Windows Only:
+#      PATH
+#      PROCESSOR_IDENTIFIER
+#      ROOTDIR
+#
+# Output variable settings:
+#    make    Full path to GNU make
+#
+# Output environment variables:
+#    PATH
+#    Windows Only:
+#      ALT_DEVTOOLS_PATH (To avoid the C:/UTILS default)
+#
+# After JDK6, most settings will be found via ALT_SLASH_JAVA or
+#   by way of other system environment variables. If this was JDK5
+#   or an older JDK, you might need to export more ALT_* variables.
+#
+#############################################################################
+
+#############################################################################
+# Error
+error() # message
+{
+  echo "ERROR: $1"
+  exit 6
+}
+# Directory must exist
+dirMustExist() # dir name
+{
+  if [ ! -d "$1" ] ; then
+    error "Directory for $2 does not exist: $1"
+  fi
+}
+# File must exist
+fileMustExist() # dir name
+{
+  if [ ! -f "$1" ] ; then
+    error "File for $2 does not exist: $1"
+  fi
+}
+#############################################################################
+
+# Should be set by JPRT as the 3 basic inputs
+bootdir="${ALT_BOOTDIR}"
+slashjava="${ALT_SLASH_JAVA}"
+jdk_import="${ALT_JDK_IMPORT_PATH}"
+
+# Check input
+dirMustExist "${bootdir}"    ALT_BOOTDIR
+dirMustExist "${slashjava}"  ALT_SLASH_JAVA
+dirMustExist "${jdk_import}" ALT_JDK_IMPORT_PATH
+
+# Uses 'uname -s', but only expect SunOS or Linux, assume Windows otherwise.
+osname=`uname -s`
+if [ "${osname}" = SunOS ] ; then
+   
+    # SOLARIS: Sparc or X86
+    osarch=`uname -p`
+    if [ "${osarch}" = sparc ] ; then
+	solaris_arch=sparc
+    else
+	solaris_arch=i386
+    fi
+
+    # Add basic solaris system paths
+    path4sdk=/usr/ccs/bin:/usr/ccs/lib:/usr/bin:/bin:/usr/sfw/bin
+
+    # Get the previous JDK to be used to bootstrap the build
+    path4sdk=${bootdir}/bin:${path4sdk}
+
+    # Ant
+    ANT_HOME=${slashjava}/devtools/share/ant/1.7.0
+    export ANT_HOME
+    antbindir=${ANT_HOME}/bin
+    fileMustExist "${antbindir}/ant" ant
+    path4sdk=${antbindir}:${path4sdk}
+
+    # Find GNU make
+    make=/usr/sfw/bin/gmake
+    if [ ! -f ${make} ] ; then
+	make=/opt/sfw/bin/gmake
+	if [ ! -f ${make} ] ; then
+	    make=${slashjava}/devtools/${solaris_arch}/bin/gnumake
+        fi 
+    fi
+    fileMustExist "${make}" make
+
+    # File creation mask
+    umask 002
+
+elif [ "${osname}" = Linux ] ; then
+   
+    # LINUX: X86, AMD64
+    osarch=`uname -m`
+    if [ "${osarch}" = i686 ] ; then
+	linux_arch=i586
+    elif [ "${osarch}" = x86_64 ] ; then
+	linux_arch=amd64
+    fi
+
+    # Add basic paths
+    path4sdk=/usr/bin:/bin:/usr/sbin:/sbin
+
+    # Get the previous JDK to be used to bootstrap the build
+    path4sdk=${bootdir}/bin:${path4sdk}
+
+    # Ant
+    ANT_HOME=${slashjava}/devtools/share/ant/1.7.0
+    export ANT_HOME
+    antbindir=${ANT_HOME}/bin
+    fileMustExist "${antbindir}/ant" ant
+    path4sdk=${antbindir}:${path4sdk}
+    
+    # Find GNU make
+    make=/usr/bin/make
+    fileMustExist "${make}" make
+
+    umask 002
+
+else
+
+    # Windows: Differs on CYGWIN vs. MKS.
+    #   Also, blanks in pathnames gives GNU make headaches, so anything placed
+    #   in any ALT_* variable should be the short windows dosname.
+   
+    # WINDOWS: Install and use MKS or CYGWIN (should have already been done)
+    #   Assumption here is that you are in a shell window via MKS or cygwin.
+    #   MKS install should have defined the environment variable ROOTDIR.
+    #   We also need to figure out which one we have: X86, AMD64
+    if [ "`echo ${PROCESSOR_IDENTIFIER} | fgrep AMD64`" != "" ] ; then
+	windows_arch=amd64
+    else
+	windows_arch=i586
+    fi
+    
+    # We need to determine if we are running a CYGWIN shell or an MKS shell
+    #    (if uname isn't available, then it will be unix_toolset=unknown)
+    unix_toolset=unknown
+    if [ "`uname -a | fgrep Cygwin`" = "" -a -d "${ROOTDIR}" ] ; then
+        # We kind of assume ROOTDIR is where MKS is and it's ok
+        unix_toolset=MKS
+        mkshome=`dosname -s "${ROOTDIR}"`
+	# Utility to convert to short pathnames without spaces
+	dosname="${mkshome}/mksnt/dosname -s"
+        # Most unix utilities are in the mksnt directory of ROOTDIR
+        unixcommand_path="${mkshome}/mksnt"
+        path4sdk="${unixcommand_path}"
+        dirMustExist "${unixcommand_path}" ALT_UNIXCOMMAND_PATH
+	devtools_path="${slashjava}/devtools/win32/bin"
+	path4sdk="${devtools_path};${path4sdk}"
+	# Normally this need not be set, but on Windows it's default is C:/UTILS
+        ALT_DEVTOOLS_PATH="${devtools_path}"
+	export ALT_DEVTOOLS_PATH
+        dirMustExist "${devtools_path}" ALT_DEVTOOLS_PATH
+        # Find GNU make
+        make="${devtools_path}/gnumake.exe"
+        fileMustExist "${make}" make
+    elif [ "`uname -a | fgrep Cygwin`" != "" -a -f /bin/cygpath ] ; then
+        # For CYGWIN, uname will have "Cygwin" in it, and /bin/cygpath should exist
+        unix_toolset=CYGWIN
+	# Utility to convert to short pathnames without spaces
+	dosname="/usr/bin/cygpath -a -m -s"
+        # Most unix utilities are in the /usr/bin
+        unixcommand_path="/usr/bin"
+        path4sdk="${unixcommand_path}"
+        dirMustExist "${unixcommand_path}" ALT_UNIXCOMMAND_PATH
+        # Find GNU make
+        make="${unixcommand_path}/make.exe"
+        fileMustExist "${make}" make
+    else
+      echo "WARNING: Cannot figure out if this is MKS or CYGWIN"
+    fi
+
+    # WINDOWS: Get the previous JDK to be used to bootstrap the build
+    path4sdk="${bootdir}/bin;${path4sdk}"
+
+    # Ant
+    ANT_HOME=${slashjava}/devtools/share/ant/1.7.0
+    export ANT_HOME
+    antbindir=${ANT_HOME}/bin
+    fileMustExist "${antbindir}/ant" ant
+    path4sdk="${antbindir};${path4sdk}"
+
+    # Turn all \\ into /, remove duplicates and trailing /
+    slash_path="`echo ${path4sdk} | sed -e 's@\\\\@/@g' -e 's@//@/@g' -e 's@/$@@' -e 's@/;@;@g'`"
+    
+    # For windows, it's hard to know where the system is, so we just add this
+    #    to PATH.
+    path4sdk="${slash_path};${PATH}"
+    
+    # Convert path4sdk to cygwin style
+    if [ "${unix_toolset}" = CYGWIN ] ; then
+	path4sdk="`/usr/bin/cygpath -p ${path4sdk}`"
+    fi
+
+fi
+
+# Export PATH setting
+PATH="${path4sdk}"
+export PATH
+
+# Things we need to unset
+unset LD_LIBRARY_PATH
+unset LD_LIBRARY_PATH_32
+unset LD_LIBRARY_PATH_64
+unset JAVA_HOME
+
diff --git a/jaxws/make/jprt.properties b/jaxws/make/jprt.properties
new file mode 100644
index 0000000..26ffd61
--- /dev/null
+++ b/jaxws/make/jprt.properties
@@ -0,0 +1,55 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+#
+
+# Properties for jprt
+jprt.tools.default.release=jdk1.7.0
+
+# Specific platform list
+jprt.build.platforms=\
+solaris_sparc_5.10,\
+solaris_sparcv9_5.10,\
+solaris_i586_5.10,\
+solaris_x64_5.10,\
+linux_i586,\
+linux_x64,\
+windows_i586,\
+windows_x64
+
+# The different build flavors we want
+jprt.build.flavors=product
+
+# Explicitly designate what the 32bit match is for the 64bit build
+jprt.solaris_sparcv9.build.platform.match32=solaris_sparc_5.10
+jprt.solaris_sparcv9_5.10.build.platform.match32=solaris_sparc_5.10
+jprt.solaris_x64.build.platform.match32=solaris_i586_5.10
+jprt.solaris_x64_5.10.build.platform.match32=solaris_i586_5.10
+
+# Standard list of jprt test targets for this workspace
+jprt.test.targets=
+
+# Directories needed to build
+jprt.bundle.src.dirs=make src
+jprt.bundle.exclude.src.dirs=build dist
+
diff --git a/jaxws/make/tools/StripProperties/StripProperties.java b/jaxws/make/tools/StripProperties/StripProperties.java
new file mode 100644
index 0000000..4a3943b
--- /dev/null
+++ b/jaxws/make/tools/StripProperties/StripProperties.java
@@ -0,0 +1,329 @@
+/*
+ * Copyright 2001 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+import java.io.BufferedInputStream;
+import java.io.BufferedWriter;
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.ArrayList;
+import java.util.Enumeration;
+import java.util.List;
+import java.util.Properties;
+
+/**
+ * Reads a properties file from standard input and writes an equivalent
+ * properties file without comments to standard output.
+ */
+public class StripProperties {
+
+    public static void main(String[] args) {
+        StripProperties sp = new StripProperties();
+        boolean ok = sp.run(args);
+        if ( !ok ) {
+            System.exit(1);
+        }
+    }
+
+    static interface Log {
+        void info(String msg);
+        void verbose(String msg);
+        void error(String msg, Exception e);
+    }
+
+    private String propfiles[];
+    private String outfiles[] ;
+    private int stripCount = 0;
+    private boolean quiet = false;
+    private Log log;
+
+    public void setLog(Log log) {
+        this.log = log;
+    }
+
+    private boolean parseOptions(String args[]) {
+        boolean ok = true;
+        if ( stripCount > 0 ) {
+            String new_propfiles[] = new String[stripCount + args.length];
+            String new_outfiles[]  = new String[stripCount + args.length];
+            System.arraycopy(propfiles, 0, new_propfiles, 0, stripCount);
+            System.arraycopy(outfiles, 0, new_outfiles, 0, stripCount);
+            propfiles = new_propfiles;
+            outfiles  = new_outfiles;
+        } else {
+            propfiles = new String[args.length];
+            outfiles  = new String[args.length];
+        }
+
+        for ( int i = 0; i < args.length ; i++ ) {
+            if ( "-strip".equals(args[i]) && i+2 < args.length ) {
+                propfiles[stripCount] = args[++i];
+                outfiles[stripCount]    = args[++i];
+                stripCount++;
+            } else if ( "-optionsfile".equals(args[i]) && i+1 < args.length ) {
+                String filename = args[++i];
+                FileInputStream finput = null;
+                byte contents[] = null;
+                try {
+                    finput = new FileInputStream(filename);
+                    int byteCount = finput.available();
+                    if ( byteCount <= 0 ) {
+                        log.error("The -optionsfile file is empty", null);
+                        ok = false;
+                    } else {
+                        contents = new byte[byteCount];
+                        int bytesRead = finput.read(contents);
+                        if ( byteCount != bytesRead ) {
+                            log.error("Cannot read all of -optionsfile file", null);
+                            ok = false;
+                        }
+                    }
+                } catch ( IOException e ) {
+                    log.error("cannot open " + filename, e);
+                    ok = false;
+                }
+                if ( finput != null ) {
+                    try {
+                        finput.close();
+                    } catch ( IOException e ) {
+                        ok = false;
+                        log.error("cannot close " + filename, e);
+                    }
+                }
+                if ( ok = true && contents != null ) {
+                    String tokens[] = (new String(contents)).split("\\s+");
+                    if ( tokens.length > 0 ) {
+                        ok = parseOptions(tokens);
+                    }
+                }
+                if ( !ok ) {
+                    break;
+                }
+        } else if ( "-quiet".equals(args[i]) ) {
+                quiet = true;
+        } else {
+                log.error("argument error", null);
+                ok = false;
+        }
+        }
+        return ok;
+    }
+
+    private boolean stripFiles(String propertiesPath, String outputPath) {
+        boolean ok = true;
+        Properties prop = new Properties();
+        InputStream in = null;
+        try {
+                in = new BufferedInputStream(new FileInputStream(propertiesPath));
+                prop.load(in);
+        } catch ( FileNotFoundException e ) {
+                log.error("Cannot access file " + propertiesPath, e);
+                ok = false;
+        } catch ( IOException e ) {
+                log.error("IO exception processing file " + propertiesPath, e);
+                ok = false;
+        }
+        if ( in != null ) {
+                try {
+                    in.close();
+                } catch ( IOException e ) {
+                    log.error("IO exception closing file " + propertiesPath, e);
+                    ok = false;
+                }
+        }
+
+        OutputStream out = null;
+        try {
+                out = new FileOutputStream(outputPath);
+                storeProperties(prop, out);
+                out.flush();
+        } catch ( IOException e ) {
+                log.error("IO exception processing file " + outputPath, e);
+                e.printStackTrace();
+                ok = false;
+        }
+        if ( out != null ) {
+           try {
+                    out.close();
+           } catch ( IOException e ) {
+                    log.error("IO exception closing file " + outputPath, e);
+                    ok = false;
+           }
+        }
+        return ok;
+    }
+
+    /**
+     * Strip the properties filenames supplied, replacing their contents.
+     * @param args Names of properties files to process and replace contents
+     */
+    public boolean run(String args[]) {
+        if (log == null) {
+            log = new Log() {
+                public void error(String msg, Exception e) {
+                    System.err.println("ERROR: StripProperties: " + msg);
+                    if ( e != null ) {
+                        System.err.println("EXCEPTION: " + e.toString());
+                        e.printStackTrace();
+                    }
+                }
+                public void info(String msg) {
+                    System.out.println(msg);
+                }
+                public void verbose(String msg) {
+                    if (!quiet)
+                        System.out.println(msg);
+                }
+            };
+        }
+
+        boolean ok = true;
+        ok = parseOptions(args);
+        if ( ok && stripCount == 0 ) {
+                log.error("options parsed but no files to compile", null);
+                ok = false;
+        }
+        /* Need at least one file. */
+        if ( !ok ) {
+            //usage(log);
+        } else {
+            /* Process files */
+            for ( int i = 0; i < stripCount && ok ; i++ ) {
+                    ok = stripFiles(propfiles[i], outfiles[i]);
+            }
+        }
+        return ok;
+    }
+
+    // --- code below here is adapted from java.util.Properties ---
+
+    private static final String specialSaveChars = "=: \t\r\n\f#!";
+
+    /*
+     * Converts unicodes to encoded &#92;uxxxx
+     * and writes out any of the characters in specialSaveChars
+     * with a preceding slash
+     */
+    private static String saveConvert(String theString, boolean escapeSpace) {
+        int len = theString.length();
+        StringBuffer outBuffer = new StringBuffer(len*2);
+
+        for(int x=0; x<len; x++) {
+            char aChar = theString.charAt(x);
+            switch(aChar) {
+                case ' ':
+                    if (x == 0 || escapeSpace) {
+                        outBuffer.append('\\');
+                    }
+                    outBuffer.append(' ');
+                    break;
+                case '\\':
+                    outBuffer.append('\\');
+                    outBuffer.append('\\');
+                    break;
+                case '\t':
+                    outBuffer.append('\\');
+                    outBuffer.append('t');
+                    break;
+                case '\n':
+                    outBuffer.append('\\');
+                    outBuffer.append('n');
+                    break;
+                case '\r':
+                    outBuffer.append('\\');
+                    outBuffer.append('r');
+                    break;
+                case '\f':
+                    outBuffer.append('\\');
+                    outBuffer.append('f');
+                    break;
+                default:
+                    if ((aChar < 0x0020) || (aChar == 0x007e) || (aChar > 0x00ff)) {
+                        outBuffer.append('\\');
+                        outBuffer.append('u');
+                        outBuffer.append(toHex((aChar >> 12) & 0xF));
+                        outBuffer.append(toHex((aChar >>  8) & 0xF));
+                        outBuffer.append(toHex((aChar >>  4) & 0xF));
+                        outBuffer.append(toHex( aChar        & 0xF));
+                    } else {
+                        if (specialSaveChars.indexOf(aChar) != -1) {
+                            outBuffer.append('\\');
+                        }
+                        outBuffer.append(aChar);
+                    }
+            }
+        }
+        return outBuffer.toString();
+    }
+
+    /**
+     * Writes the content of <code>properties</code> to <code>out</code>.
+     * The format is that of Properties.store with the following modifications:
+     * <ul>
+     * <li>No header or date is written
+     * <li>Latin-1 characters are written as single bytes, not escape sequences
+     * <li>Line breaks are indicated by a single \n independent of platform
+     * <ul>
+     */
+    private static void storeProperties(Properties properties, OutputStream out)
+    throws IOException {
+        BufferedWriter awriter;
+        awriter = new BufferedWriter(new OutputStreamWriter(out, "8859_1"));
+        for (Enumeration e = properties.keys(); e.hasMoreElements();) {
+            String key = (String)e.nextElement();
+            String val = (String)properties.get(key);
+            key = saveConvert(key, true);
+
+            /* No need to escape embedded and trailing spaces for value, hence
+             * pass false to flag.
+             */
+            val = saveConvert(val, false);
+            writeln(awriter, key + "=" + val);
+        }
+        awriter.flush();
+    }
+
+    private static void writeln(BufferedWriter bw, String s) throws IOException {
+        bw.write(s);
+        bw.write("\n");
+    }
+
+    /**
+     * Convert a nibble to a hex character
+     * @param   nibble  the nibble to convert.
+     */
+    private static char toHex(int nibble) {
+        return hexDigit[(nibble & 0xF)];
+    }
+
+    /** A table of hex digits */
+    private static final char[] hexDigit = {
+        '0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'
+    };
+}
diff --git a/jaxws/make/tools/StripProperties/StripPropertiesTask.java b/jaxws/make/tools/StripProperties/StripPropertiesTask.java
new file mode 100644
index 0000000..59a95ee
--- /dev/null
+++ b/jaxws/make/tools/StripProperties/StripPropertiesTask.java
@@ -0,0 +1,87 @@
+/*
+ * Copyright 2007 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+import java.io.File;
+import java.util.ArrayList;
+import java.util.List;
+
+import org.apache.tools.ant.BuildException;
+import org.apache.tools.ant.DirectoryScanner;
+import org.apache.tools.ant.Project;
+import org.apache.tools.ant.taskdefs.MatchingTask;
+
+public class StripPropertiesTask extends MatchingTask {
+    public void setSrcDir(File srcDir) {
+        this.srcDir = srcDir;
+    }
+
+    public void setDestDir(File destDir) {
+        this.destDir = destDir;
+    }
+
+    public void execute() {
+        StripProperties.Log log = new StripProperties.Log() {
+            public void error(String msg, Exception e) {
+                log(msg, Project.MSG_ERR);
+            }
+            public void info(String msg) {
+                log(msg, Project.MSG_INFO);
+            }
+            public void verbose(String msg) {
+                log(msg, Project.MSG_VERBOSE);
+            }
+        };
+        List<String> mainOpts = new ArrayList<String>();
+        int count = 0;
+        DirectoryScanner s = getDirectoryScanner(srcDir);
+        for (String path: s.getIncludedFiles()) {
+            if (path.endsWith(".properties")) {
+                File srcFile = new File(srcDir, path);
+                File destFile = new File(destDir, path);
+                // Arguably, the comparison in the next line should be ">", not ">="
+                // but that assumes the resolution of the last modified time is fine
+                // grained enough; in practice, it is better to use ">=".
+                if (destFile.exists() && destFile.lastModified() >= srcFile.lastModified())
+                    continue;
+                destFile.getParentFile().mkdirs();
+                mainOpts.add("-strip");
+                mainOpts.add(srcFile.getPath());
+                mainOpts.add(destFile.getPath());
+                count++;
+            }
+        }
+        if (mainOpts.size() > 0) {
+            log("Generating " + count + " resource files to " + destDir, Project.MSG_INFO);
+            StripProperties sp = new StripProperties();
+            sp.setLog(log);
+            boolean ok = sp.run((String[])mainOpts.toArray(new String[mainOpts.size()]));
+            if (!ok)
+                throw new BuildException("StripProperties failed.");
+        }
+    }
+
+    private File srcDir;
+    private File destDir;
+}
diff --git a/jaxws/src/share/classes/META-INF/mailcap.default b/jaxws/src/share/classes/META-INF/mailcap.default
new file mode 100644
index 0000000..542de7d
--- /dev/null
+++ b/jaxws/src/share/classes/META-INF/mailcap.default
@@ -0,0 +1,7 @@
+#
+# This is a very simple 'mailcap' file
+#
+image/gif;;		x-java-view=com.sun.activation.viewers.ImageViewer
+image/jpeg;;		x-java-view=com.sun.activation.viewers.ImageViewer
+text/*;;		x-java-view=com.sun.activation.viewers.TextViewer
+text/*;;		x-java-edit=com.sun.activation.viewers.TextEditor
diff --git a/jaxws/src/share/classes/META-INF/mimetypes.default b/jaxws/src/share/classes/META-INF/mimetypes.default
new file mode 100644
index 0000000..0c22eb2
--- /dev/null
+++ b/jaxws/src/share/classes/META-INF/mimetypes.default
@@ -0,0 +1,24 @@
+#
+# A simple, old format, mime.types file
+#
+text/html		html htm HTML HTM
+text/plain		txt text TXT TEXT
+image/gif		gif GIF
+image/ief		ief
+image/jpeg		jpeg jpg jpe JPG
+image/tiff		tiff tif
+image/x-xwindowdump	xwd
+application/postscript	ai eps ps
+application/rtf		rtf
+application/x-tex	tex
+application/x-texinfo	texinfo texi
+application/x-troff	t tr roff
+audio/basic		au
+audio/midi		midi mid
+audio/x-aifc		aifc
+audio/x-aiff            aif aiff
+audio/x-mpeg		mpeg mpg
+audio/x-wav             wav
+video/mpeg		mpeg mpg mpe
+video/quicktime		qt mov
+video/x-msvideo		avi
diff --git a/jaxws/src/share/classes/com/sun/activation/registries/LogSupport.java b/jaxws/src/share/classes/com/sun/activation/registries/LogSupport.java
new file mode 100644
index 0000000..dfc4f07
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/activation/registries/LogSupport.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2003-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.activation.registries;
+
+import java.io.*;
+import java.util.logging.*;
+
+/**
+ * Logging related methods.
+ */
+public class LogSupport {
+    private static boolean debug = false;
+    private static Logger logger;
+    private static final Level level = Level.FINE;
+
+    static {
+        try {
+            debug = Boolean.getBoolean("javax.activation.debug");
+        } catch (Throwable t) {
+            // ignore any errors
+        }
+        logger = Logger.getLogger("javax.activation");
+    }
+
+    /**
+     * Constructor.
+     */
+    private LogSupport() {
+        // private constructor, can't create instances
+    }
+
+    public static void log(String msg) {
+        if (debug)
+            System.out.println(msg);
+        logger.log(level, msg);
+    }
+
+    public static void log(String msg, Throwable t) {
+        if (debug)
+            System.out.println(msg + "; Exception: " + t);
+        logger.log(level, msg, t);
+    }
+
+    public static boolean isLoggable() {
+        return debug || logger.isLoggable(level);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/activation/registries/MailcapFile.java b/jaxws/src/share/classes/com/sun/activation/registries/MailcapFile.java
new file mode 100644
index 0000000..6e5e6a6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/activation/registries/MailcapFile.java
@@ -0,0 +1,560 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.activation.registries;
+
+import java.io.*;
+import java.util.*;
+
+public class MailcapFile {
+
+    /**
+     * A Map indexed by MIME type (string) that references
+     * a Map of commands for each type.  The comand Map
+     * is indexed by the command name and references a List of
+     * class names (strings) for each command.
+     */
+    private Map type_hash = new HashMap();
+
+    /**
+     * Another Map like above, but for fallback entries.
+     */
+    private Map fallback_hash = new HashMap();
+
+    /**
+     * A Map indexed by MIME type (string) that references
+     * a List of native commands (string) corresponding to the type.
+     */
+    private Map native_commands = new HashMap();
+
+    private static boolean addReverse = false;
+
+    static {
+        try {
+            addReverse = Boolean.getBoolean("javax.activation.addreverse");
+        } catch (Throwable t) {
+            // ignore any errors
+        }
+    }
+
+    /**
+     * The constructor that takes a filename as an argument.
+     *
+     * @param new_fname The file name of the mailcap file.
+     */
+    public MailcapFile(String new_fname) throws IOException {
+        if (LogSupport.isLoggable())
+            LogSupport.log("new MailcapFile: file " + new_fname);
+        FileReader reader = null;
+        try {
+            reader = new FileReader(new_fname);
+            parse(new BufferedReader(reader));
+        } finally {
+            if (reader != null) {
+                try {
+                    reader.close();
+                } catch (IOException ex) { }
+            }
+        }
+    }
+
+    /**
+     * The constructor that takes an input stream as an argument.
+     *
+     * @param is        the input stream
+     */
+    public MailcapFile(InputStream is) throws IOException {
+        if (LogSupport.isLoggable())
+            LogSupport.log("new MailcapFile: InputStream");
+        parse(new BufferedReader(new InputStreamReader(is, "iso-8859-1")));
+    }
+
+    /**
+     * Mailcap file default constructor.
+     */
+    public MailcapFile() {
+        if (LogSupport.isLoggable())
+            LogSupport.log("new MailcapFile: default");
+    }
+
+    /**
+     * Get the Map of MailcapEntries based on the MIME type.
+     *
+     * <p>
+     * <strong>Semantics:</strong> First check for the literal mime type,
+     * if that fails looks for wildcard <type>/\* and return that. Return the
+     * list of all that hit.
+     */
+    public Map getMailcapList(String mime_type) {
+        Map search_result = null;
+        Map wildcard_result = null;
+
+        // first try the literal
+        search_result = (Map)type_hash.get(mime_type);
+
+        // ok, now try the wildcard
+        int separator = mime_type.indexOf('/');
+        String subtype = mime_type.substring(separator + 1);
+        if (!subtype.equals("*")) {
+            String type = mime_type.substring(0, separator + 1) + "*";
+            wildcard_result = (Map)type_hash.get(type);
+
+            if (wildcard_result != null) { // damn, we have to merge!!!
+                if (search_result != null)
+                    search_result =
+                        mergeResults(search_result, wildcard_result);
+                else
+                    search_result = wildcard_result;
+            }
+        }
+        return search_result;
+    }
+
+    /**
+     * Get the Map of fallback MailcapEntries based on the MIME type.
+     *
+     * <p>
+     * <strong>Semantics:</strong> First check for the literal mime type,
+     * if that fails looks for wildcard <type>/\* and return that. Return the
+     * list of all that hit.
+     */
+    public Map getMailcapFallbackList(String mime_type) {
+        Map search_result = null;
+        Map wildcard_result = null;
+
+        // first try the literal
+        search_result = (Map)fallback_hash.get(mime_type);
+
+        // ok, now try the wildcard
+        int separator = mime_type.indexOf('/');
+        String subtype = mime_type.substring(separator + 1);
+        if (!subtype.equals("*")) {
+            String type = mime_type.substring(0, separator + 1) + "*";
+            wildcard_result = (Map)fallback_hash.get(type);
+
+            if (wildcard_result != null) { // damn, we have to merge!!!
+                if (search_result != null)
+                    search_result =
+                        mergeResults(search_result, wildcard_result);
+                else
+                    search_result = wildcard_result;
+            }
+        }
+        return search_result;
+    }
+
+    /**
+     * Return all the MIME types known to this mailcap file.
+     */
+    public String[] getMimeTypes() {
+        Set types = new HashSet(type_hash.keySet());
+        types.addAll(fallback_hash.keySet());
+        types.addAll(native_commands.keySet());
+        String[] mts = new String[types.size()];
+        mts = (String[])types.toArray(mts);
+        return mts;
+    }
+
+    /**
+     * Return all the native comands for the given MIME type.
+     */
+    public String[] getNativeCommands(String mime_type) {
+        String[] cmds = null;
+        List v = (List)native_commands.get(mime_type.toLowerCase());
+        if (v != null) {
+            cmds = new String[v.size()];
+            cmds = (String[])v.toArray(cmds);
+        }
+        return cmds;
+    }
+
+    /**
+     * Merge the first hash into the second.
+     * This merge will only effect the hashtable that is
+     * returned, we don't want to touch the one passed in since
+     * its integrity must be maintained.
+     */
+    private Map mergeResults(Map first, Map second) {
+        Iterator verb_enum = second.keySet().iterator();
+        Map clonedHash = new HashMap(first);
+
+        // iterate through the verbs in the second map
+        while (verb_enum.hasNext()) {
+            String verb = (String)verb_enum.next();
+            List cmdVector = (List)clonedHash.get(verb);
+            if (cmdVector == null) {
+                clonedHash.put(verb, second.get(verb));
+            } else {
+                // merge the two
+                List oldV = (List)second.get(verb);
+                cmdVector = new ArrayList(cmdVector);
+                cmdVector.addAll(oldV);
+                clonedHash.put(verb, cmdVector);
+            }
+        }
+        return clonedHash;
+    }
+
+    /**
+     * appendToMailcap: Append to this Mailcap DB, use the mailcap
+     * format:
+     * Comment == "# <i>comment string</i>
+     * Entry == "mimetype;        javabeanclass<nl>
+     *
+     * Example:
+     * # this is a comment
+     * image/gif       jaf.viewers.ImageViewer
+     */
+    public void appendToMailcap(String mail_cap) {
+        if (LogSupport.isLoggable())
+            LogSupport.log("appendToMailcap: " + mail_cap);
+        try {
+            parse(new StringReader(mail_cap));
+        } catch (IOException ex) {
+            // can't happen
+        }
+    }
+
+    /**
+     * parse file into a hash table of MC Type Entry Obj
+     */
+    private void parse(Reader reader) throws IOException {
+        BufferedReader buf_reader = new BufferedReader(reader);
+        String line = null;
+        String continued = null;
+
+        while ((line = buf_reader.readLine()) != null) {
+            //    LogSupport.log("parsing line: " + line);
+
+            line = line.trim();
+
+            try {
+                if (line.charAt(0) == '#')
+                    continue;
+                if (line.charAt(line.length() - 1) == '\\') {
+                    if (continued != null)
+                        continued += line.substring(0, line.length() - 1);
+                    else
+                        continued = line.substring(0, line.length() - 1);
+                } else if (continued != null) {
+                    // handle the two strings
+                    continued = continued + line;
+                    //  LogSupport.log("parse: " + continued);
+                    try {
+                        parseLine(continued);
+                    } catch (MailcapParseException e) {
+                        //e.printStackTrace();
+                    }
+                    continued = null;
+                }
+                else {
+                    //  LogSupport.log("parse: " + line);
+                    try {
+                        parseLine(line);
+                        // LogSupport.log("hash.size = " + type_hash.size());
+                    } catch (MailcapParseException e) {
+                        //e.printStackTrace();
+                    }
+                }
+            } catch (StringIndexOutOfBoundsException e) {}
+        }
+    }
+
+    /**
+     *  A routine to parse individual entries in a Mailcap file.
+     *
+     *  Note that this routine does not handle line continuations.
+     *  They should have been handled prior to calling this routine.
+     */
+    protected void parseLine(String mailcapEntry)
+                                throws MailcapParseException, IOException {
+        MailcapTokenizer tokenizer = new MailcapTokenizer(mailcapEntry);
+        tokenizer.setIsAutoquoting(false);
+
+        if (LogSupport.isLoggable())
+            LogSupport.log("parse: " + mailcapEntry);
+        //      parse the primary type
+        int currentToken = tokenizer.nextToken();
+        if (currentToken != MailcapTokenizer.STRING_TOKEN) {
+            reportParseError(MailcapTokenizer.STRING_TOKEN, currentToken,
+                                        tokenizer.getCurrentTokenValue());
+        }
+        String primaryType = tokenizer.getCurrentTokenValue().toLowerCase();
+        String subType = "*";
+
+        //      parse the '/' between primary and sub
+        //      if it's not present that's ok, we just don't have a subtype
+        currentToken = tokenizer.nextToken();
+        if ((currentToken != MailcapTokenizer.SLASH_TOKEN) &&
+                        (currentToken != MailcapTokenizer.SEMICOLON_TOKEN)) {
+            reportParseError(MailcapTokenizer.SLASH_TOKEN,
+                                MailcapTokenizer.SEMICOLON_TOKEN, currentToken,
+                                tokenizer.getCurrentTokenValue());
+        }
+
+        //      only need to look for a sub type if we got a '/'
+        if (currentToken == MailcapTokenizer.SLASH_TOKEN) {
+            //  parse the sub type
+            currentToken = tokenizer.nextToken();
+            if (currentToken != MailcapTokenizer.STRING_TOKEN) {
+                reportParseError(MailcapTokenizer.STRING_TOKEN,
+                            currentToken, tokenizer.getCurrentTokenValue());
+            }
+            subType = tokenizer.getCurrentTokenValue().toLowerCase();
+
+            //  get the next token to simplify the next step
+            currentToken = tokenizer.nextToken();
+        }
+
+        String mimeType = primaryType + "/" + subType;
+
+        if (LogSupport.isLoggable())
+            LogSupport.log("  Type: " + mimeType);
+
+        //      now setup the commands hashtable
+        Map commands = new LinkedHashMap();     // keep commands in order found
+
+        //      parse the ';' that separates the type from the parameters
+        if (currentToken != MailcapTokenizer.SEMICOLON_TOKEN) {
+            reportParseError(MailcapTokenizer.SEMICOLON_TOKEN,
+                            currentToken, tokenizer.getCurrentTokenValue());
+        }
+        //      eat it
+
+        //      parse the required view command
+        tokenizer.setIsAutoquoting(true);
+        currentToken = tokenizer.nextToken();
+        tokenizer.setIsAutoquoting(false);
+        if ((currentToken != MailcapTokenizer.STRING_TOKEN) &&
+                    (currentToken != MailcapTokenizer.SEMICOLON_TOKEN)) {
+            reportParseError(MailcapTokenizer.STRING_TOKEN,
+                            MailcapTokenizer.SEMICOLON_TOKEN, currentToken,
+                            tokenizer.getCurrentTokenValue());
+        }
+
+        if (currentToken == MailcapTokenizer.STRING_TOKEN) {
+            // have a native comand, save the entire mailcap entry
+            //String nativeCommand = tokenizer.getCurrentTokenValue();
+            List v = (List)native_commands.get(mimeType);
+            if (v == null) {
+                v = new ArrayList();
+                v.add(mailcapEntry);
+                native_commands.put(mimeType, v);
+            } else {
+                // XXX - check for duplicates?
+                v.add(mailcapEntry);
+            }
+        }
+
+        //      only have to get the next token if the current one isn't a ';'
+        if (currentToken != MailcapTokenizer.SEMICOLON_TOKEN) {
+            currentToken = tokenizer.nextToken();
+        }
+
+        // look for a ';' which will indicate whether
+        // a parameter list is present or not
+        if (currentToken == MailcapTokenizer.SEMICOLON_TOKEN) {
+            boolean isFallback = false;
+            do {
+                //      eat the ';'
+
+                //      parse the parameter name
+                currentToken = tokenizer.nextToken();
+                if (currentToken != MailcapTokenizer.STRING_TOKEN) {
+                    reportParseError(MailcapTokenizer.STRING_TOKEN,
+                            currentToken, tokenizer.getCurrentTokenValue());
+                }
+                String paramName =
+                    tokenizer.getCurrentTokenValue().toLowerCase();
+
+                //      parse the '=' which separates the name from the value
+                currentToken = tokenizer.nextToken();
+                if ((currentToken != MailcapTokenizer.EQUALS_TOKEN) &&
+                    (currentToken != MailcapTokenizer.SEMICOLON_TOKEN) &&
+                    (currentToken != MailcapTokenizer.EOI_TOKEN)) {
+                    reportParseError(MailcapTokenizer.EQUALS_TOKEN,
+                            MailcapTokenizer.SEMICOLON_TOKEN,
+                            MailcapTokenizer.EOI_TOKEN,
+                            currentToken, tokenizer.getCurrentTokenValue());
+                }
+
+                //      we only have a useful command if it is named
+                if (currentToken == MailcapTokenizer.EQUALS_TOKEN) {
+                    //  eat it
+
+                    //  parse the parameter value (which is autoquoted)
+                    tokenizer.setIsAutoquoting(true);
+                    currentToken = tokenizer.nextToken();
+                    tokenizer.setIsAutoquoting(false);
+                    if (currentToken != MailcapTokenizer.STRING_TOKEN) {
+                        reportParseError(MailcapTokenizer.STRING_TOKEN,
+                        currentToken, tokenizer.getCurrentTokenValue());
+                    }
+                    String paramValue =
+                                tokenizer.getCurrentTokenValue();
+
+                    // add the class to the list iff it is one we care about
+                    if (paramName.startsWith("x-java-")) {
+                        String commandName = paramName.substring(7);
+                        //      7 == "x-java-".length
+
+                        if (commandName.equals("fallback-entry") &&
+                            paramValue.equalsIgnoreCase("true")) {
+                            isFallback = true;
+                        } else {
+
+                            //  setup the class entry list
+                            if (LogSupport.isLoggable())
+                                LogSupport.log("    Command: " + commandName +
+                                                    ", Class: " + paramValue);
+                            List classes = (List)commands.get(commandName);
+                            if (classes == null) {
+                                classes = new ArrayList();
+                                commands.put(commandName, classes);
+                            }
+                            if (addReverse)
+                                classes.add(0, paramValue);
+                            else
+                                classes.add(paramValue);
+                        }
+                    }
+
+                    //  set up the next iteration
+                    currentToken = tokenizer.nextToken();
+                }
+            } while (currentToken == MailcapTokenizer.SEMICOLON_TOKEN);
+
+            Map masterHash = isFallback ? fallback_hash : type_hash;
+            Map curcommands =
+                (Map)masterHash.get(mimeType);
+            if (curcommands == null) {
+                masterHash.put(mimeType, commands);
+            } else {
+                if (LogSupport.isLoggable())
+                    LogSupport.log("Merging commands for type " + mimeType);
+                // have to merge current and new commands
+                // first, merge list of classes for commands already known
+                Iterator cn = curcommands.keySet().iterator();
+                while (cn.hasNext()) {
+                    String cmdName = (String)cn.next();
+                    List ccv = (List)curcommands.get(cmdName);
+                    List cv = (List)commands.get(cmdName);
+                    if (cv == null)
+                        continue;
+                    // add everything in cv to ccv, if it's not already there
+                    Iterator cvn = cv.iterator();
+                    while (cvn.hasNext()) {
+                        String clazz = (String)cvn.next();
+                        if (!ccv.contains(clazz))
+                            if (addReverse)
+                                ccv.add(0, clazz);
+                            else
+                                ccv.add(clazz);
+                    }
+                }
+                // now, add commands not previously known
+                cn = commands.keySet().iterator();
+                while (cn.hasNext()) {
+                    String cmdName = (String)cn.next();
+                    if (curcommands.containsKey(cmdName))
+                        continue;
+                    List cv = (List)commands.get(cmdName);
+                    curcommands.put(cmdName, cv);
+                }
+            }
+        } else if (currentToken != MailcapTokenizer.EOI_TOKEN) {
+            reportParseError(MailcapTokenizer.EOI_TOKEN,
+                MailcapTokenizer.SEMICOLON_TOKEN,
+                currentToken, tokenizer.getCurrentTokenValue());
+        }
+     }
+
+     protected static void reportParseError(int expectedToken, int actualToken,
+                String actualTokenValue) throws MailcapParseException {
+        throw new MailcapParseException("Encountered a " +
+                MailcapTokenizer.nameForToken(actualToken) + " token (" +
+                actualTokenValue + ") while expecting a " +
+                MailcapTokenizer.nameForToken(expectedToken) + " token.");
+     }
+
+     protected static void reportParseError(int expectedToken,
+        int otherExpectedToken, int actualToken, String actualTokenValue)
+                                        throws MailcapParseException {
+        throw new MailcapParseException("Encountered a " +
+                MailcapTokenizer.nameForToken(actualToken) + " token (" +
+                actualTokenValue + ") while expecting a " +
+                MailcapTokenizer.nameForToken(expectedToken) + " or a " +
+                MailcapTokenizer.nameForToken(otherExpectedToken) + " token.");
+     }
+
+     protected static void reportParseError(int expectedToken,
+            int otherExpectedToken, int anotherExpectedToken, int actualToken,
+            String actualTokenValue) throws MailcapParseException {
+        if (LogSupport.isLoggable())
+            LogSupport.log("PARSE ERROR: " + "Encountered a " +
+                MailcapTokenizer.nameForToken(actualToken) + " token (" +
+                actualTokenValue + ") while expecting a " +
+                MailcapTokenizer.nameForToken(expectedToken) + ", a " +
+                MailcapTokenizer.nameForToken(otherExpectedToken) + ", or a " +
+                MailcapTokenizer.nameForToken(anotherExpectedToken) + " token.");
+        throw new MailcapParseException("Encountered a " +
+                MailcapTokenizer.nameForToken(actualToken) + " token (" +
+                actualTokenValue + ") while expecting a " +
+                MailcapTokenizer.nameForToken(expectedToken) + ", a " +
+                MailcapTokenizer.nameForToken(otherExpectedToken) + ", or a " +
+                MailcapTokenizer.nameForToken(anotherExpectedToken) + " token.");
+     }
+
+     /** for debugging
+     public static void main(String[] args) throws Exception {
+        Map masterHash = new HashMap();
+        for (int i = 0; i < args.length; ++i) {
+            System.out.println("Entry " + i + ": " + args[i]);
+            parseLine(args[i], masterHash);
+        }
+
+        Enumeration types = masterHash.keys();
+        while (types.hasMoreElements()) {
+            String key = (String)types.nextElement();
+            System.out.println("MIME Type: " + key);
+
+            Map commandHash = (Map)masterHash.get(key);
+            Enumeration commands = commandHash.keys();
+            while (commands.hasMoreElements()) {
+                String command = (String)commands.nextElement();
+                System.out.println("    Command: " + command);
+
+                Vector classes = (Vector)commandHash.get(command);
+                for (int i = 0; i < classes.size(); ++i) {
+                        System.out.println("        Class: " +
+                                            (String)classes.elementAt(i));
+                }
+            }
+
+            System.out.println("");
+        }
+    }
+    */
+}
diff --git a/jaxws/src/share/classes/com/sun/activation/registries/MailcapParseException.java b/jaxws/src/share/classes/com/sun/activation/registries/MailcapParseException.java
new file mode 100644
index 0000000..7e05f32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/activation/registries/MailcapParseException.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 1997 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.activation.registries;
+
+/**
+ *      A class to encapsulate Mailcap parsing related exceptions
+ */
+public class MailcapParseException extends Exception {
+
+    public MailcapParseException() {
+        super();
+    }
+
+    public MailcapParseException(String inInfo) {
+        super(inInfo);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/activation/registries/MailcapTokenizer.java b/jaxws/src/share/classes/com/sun/activation/registries/MailcapTokenizer.java
new file mode 100644
index 0000000..0da8939
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/activation/registries/MailcapTokenizer.java
@@ -0,0 +1,321 @@
+/*
+ * Copyright 1997-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.activation.registries;
+
+/**
+ *      A tokenizer for strings in the form of "foo/bar; prop1=val1; ... ".
+ *      Useful for parsing MIME content types.
+ */
+public class MailcapTokenizer {
+
+    public static final int UNKNOWN_TOKEN = 0;
+    public static final int START_TOKEN = 1;
+    public static final int STRING_TOKEN = 2;
+    public static final int EOI_TOKEN = 5;
+    public static final int SLASH_TOKEN = '/';
+    public static final int SEMICOLON_TOKEN = ';';
+    public static final int EQUALS_TOKEN = '=';
+
+    /**
+     *  Constructor
+     *
+     *  @parameter  inputString the string to tokenize
+     */
+    public MailcapTokenizer(String inputString) {
+        data = inputString;
+        dataIndex = 0;
+        dataLength = inputString.length();
+
+        currentToken = START_TOKEN;
+        currentTokenValue = "";
+
+        isAutoquoting = false;
+        autoquoteChar = ';';
+    }
+
+    /**
+     *  Set whether auto-quoting is on or off.
+     *
+     *  Auto-quoting means that all characters after the first
+     *  non-whitespace, non-control character up to the auto-quote
+     *  terminator character or EOI (minus any whitespace immediatley
+     *  preceeding it) is considered a token.
+     *
+     *  This is required for handling command strings in a mailcap entry.
+     */
+    public void setIsAutoquoting(boolean value) {
+        isAutoquoting = value;
+    }
+
+    /**
+     *  Retrieve current token.
+     *
+     *  @returns    The current token value
+     */
+    public int getCurrentToken() {
+        return currentToken;
+    }
+
+    /*
+     *  Get a String that describes the given token.
+     */
+    public static String nameForToken(int token) {
+        String name = "really unknown";
+
+        switch(token) {
+            case UNKNOWN_TOKEN:
+                name = "unknown";
+                break;
+            case START_TOKEN:
+                name = "start";
+                break;
+            case STRING_TOKEN:
+                name = "string";
+                break;
+            case EOI_TOKEN:
+                name = "EOI";
+                break;
+            case SLASH_TOKEN:
+                name = "'/'";
+                break;
+            case SEMICOLON_TOKEN:
+                name = "';'";
+                break;
+            case EQUALS_TOKEN:
+                name = "'='";
+                break;
+        }
+
+        return name;
+    }
+
+    /*
+     *  Retrieve current token value.
+     *
+     *  @returns    A String containing the current token value
+     */
+    public String getCurrentTokenValue() {
+        return currentTokenValue;
+    }
+    /*
+     *  Process the next token.
+     *
+     *  @returns    the next token
+     */
+    public int nextToken() {
+        if (dataIndex < dataLength) {
+            //  skip white space
+            while ((dataIndex < dataLength) &&
+                    (isWhiteSpaceChar(data.charAt(dataIndex)))) {
+                ++dataIndex;
+            }
+
+            if (dataIndex < dataLength) {
+                //  examine the current character and see what kind of token we have
+                char c = data.charAt(dataIndex);
+                if (isAutoquoting) {
+                    if (c == ';' || c == '=') {
+                        currentToken = c;
+                        currentTokenValue = new Character(c).toString();
+                        ++dataIndex;
+                    } else {
+                        processAutoquoteToken();
+                    }
+                } else {
+                    if (isStringTokenChar(c)) {
+                        processStringToken();
+                    } else if ((c == '/') || (c == ';') || (c == '=')) {
+                        currentToken = c;
+                        currentTokenValue = new Character(c).toString();
+                        ++dataIndex;
+                    } else {
+                        currentToken = UNKNOWN_TOKEN;
+                        currentTokenValue = new Character(c).toString();
+                        ++dataIndex;
+                    }
+                }
+            } else {
+                currentToken = EOI_TOKEN;
+                currentTokenValue = null;
+            }
+        } else {
+            currentToken = EOI_TOKEN;
+            currentTokenValue = null;
+        }
+
+        return currentToken;
+    }
+
+    private void processStringToken() {
+        //  capture the initial index
+        int initialIndex = dataIndex;
+
+        //  skip to 1st non string token character
+        while ((dataIndex < dataLength) &&
+                isStringTokenChar(data.charAt(dataIndex))) {
+            ++dataIndex;
+        }
+
+        currentToken = STRING_TOKEN;
+        currentTokenValue = data.substring(initialIndex, dataIndex);
+    }
+
+    private void processAutoquoteToken() {
+        //  capture the initial index
+        int initialIndex = dataIndex;
+
+        //  now skip to the 1st non-escaped autoquote termination character
+        //  XXX - doesn't actually consider escaping
+        boolean foundTerminator = false;
+        while ((dataIndex < dataLength) && !foundTerminator) {
+            char c = data.charAt(dataIndex);
+            if (c != autoquoteChar) {
+                ++dataIndex;
+            } else {
+                foundTerminator = true;
+            }
+        }
+
+        currentToken = STRING_TOKEN;
+        currentTokenValue =
+            fixEscapeSequences(data.substring(initialIndex, dataIndex));
+    }
+
+    private static boolean isSpecialChar(char c) {
+        boolean lAnswer = false;
+
+        switch(c) {
+            case '(':
+            case ')':
+            case '<':
+            case '>':
+            case '@':
+            case ',':
+            case ';':
+            case ':':
+            case '\\':
+            case '"':
+            case '/':
+            case '[':
+            case ']':
+            case '?':
+            case '=':
+                lAnswer = true;
+                break;
+        }
+
+        return lAnswer;
+    }
+
+    private static boolean isControlChar(char c) {
+        return Character.isISOControl(c);
+    }
+
+    private static boolean isWhiteSpaceChar(char c) {
+        return Character.isWhitespace(c);
+    }
+
+    private static boolean isStringTokenChar(char c) {
+        return !isSpecialChar(c) && !isControlChar(c) && !isWhiteSpaceChar(c);
+    }
+
+    private static String fixEscapeSequences(String inputString) {
+        int inputLength = inputString.length();
+        StringBuffer buffer = new StringBuffer();
+        buffer.ensureCapacity(inputLength);
+
+        for (int i = 0; i < inputLength; ++i) {
+            char currentChar = inputString.charAt(i);
+            if (currentChar != '\\') {
+                buffer.append(currentChar);
+            } else {
+                if (i < inputLength - 1) {
+                    char nextChar = inputString.charAt(i + 1);
+                    buffer.append(nextChar);
+
+                    //  force a skip over the next character too
+                    ++i;
+                } else {
+                    buffer.append(currentChar);
+                }
+            }
+        }
+
+        return buffer.toString();
+    }
+
+    private String  data;
+    private int     dataIndex;
+    private int     dataLength;
+    private int     currentToken;
+    private String  currentTokenValue;
+    private boolean isAutoquoting;
+    private char    autoquoteChar;
+
+    /*
+    public static void main(String[] args) {
+        for (int i = 0; i < args.length; ++i) {
+            MailcapTokenizer tokenizer = new MailcapTokenizer(args[i]);
+
+            System.out.println("Original: |" + args[i] + "|");
+
+            int currentToken = tokenizer.nextToken();
+            while (currentToken != EOI_TOKEN) {
+                switch(currentToken) {
+                    case UNKNOWN_TOKEN:
+                        System.out.println("  Unknown Token:           |" + tokenizer.getCurrentTokenValue() + "|");
+                        break;
+                    case START_TOKEN:
+                        System.out.println("  Start Token:             |" + tokenizer.getCurrentTokenValue() + "|");
+                        break;
+                    case STRING_TOKEN:
+                        System.out.println("  String Token:            |" + tokenizer.getCurrentTokenValue() + "|");
+                        break;
+                    case EOI_TOKEN:
+                        System.out.println("  EOI Token:               |" + tokenizer.getCurrentTokenValue() + "|");
+                        break;
+                    case SLASH_TOKEN:
+                        System.out.println("  Slash Token:             |" + tokenizer.getCurrentTokenValue() + "|");
+                        break;
+                    case SEMICOLON_TOKEN:
+                        System.out.println("  Semicolon Token:         |" + tokenizer.getCurrentTokenValue() + "|");
+                        break;
+                    case EQUALS_TOKEN:
+                        System.out.println("  Equals Token:            |" + tokenizer.getCurrentTokenValue() + "|");
+                        break;
+                    default:
+                        System.out.println("  Really Unknown Token:    |" + tokenizer.getCurrentTokenValue() + "|");
+                        break;
+                }
+
+                currentToken = tokenizer.nextToken();
+            }
+
+            System.out.println("");
+        }
+    }
+    */
+}
diff --git a/jaxws/src/share/classes/com/sun/activation/registries/MimeTypeEntry.java b/jaxws/src/share/classes/com/sun/activation/registries/MimeTypeEntry.java
new file mode 100644
index 0000000..4ce1182
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/activation/registries/MimeTypeEntry.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 1997-1998 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.activation.registries;
+
+import java.lang.*;
+
+public class MimeTypeEntry {
+    private String type;
+    private String extension;
+
+    public MimeTypeEntry(String mime_type, String file_ext) {
+        type = mime_type;
+        extension = file_ext;
+    }
+
+    public String getMIMEType() {
+        return type;
+    }
+
+    public String getFileExtension() {
+        return extension;
+    }
+
+    public String toString() {
+        return "MIMETypeEntry: " + type + ", " + extension;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/activation/registries/MimeTypeFile.java b/jaxws/src/share/classes/com/sun/activation/registries/MimeTypeFile.java
new file mode 100644
index 0000000..96416dc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/activation/registries/MimeTypeFile.java
@@ -0,0 +1,317 @@
+/*
+ * Copyright 1997-2003 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.activation.registries;
+
+import java.io.*;
+import java.util.*;
+
+public class MimeTypeFile {
+    private String fname = null;
+    private Hashtable type_hash = new Hashtable();
+
+    /**
+     * The construtor that takes a filename as an argument.
+     *
+     * @param new_fname The file name of the mime types file.
+     */
+    public MimeTypeFile(String new_fname) throws IOException {
+        File mime_file = null;
+        FileReader fr = null;
+
+        fname = new_fname; // remember the file name
+
+        mime_file = new File(fname); // get a file object
+
+        fr = new FileReader(mime_file);
+
+        try {
+            parse(new BufferedReader(fr));
+        } finally {
+            try {
+                fr.close(); // close it
+            } catch (IOException e) {
+                // ignore it
+            }
+        }
+    }
+
+    public MimeTypeFile(InputStream is) throws IOException {
+        parse(new BufferedReader(new InputStreamReader(is, "iso-8859-1")));
+    }
+
+    /**
+     * Creates an empty DB.
+     */
+    public MimeTypeFile() {
+    }
+
+    /**
+     * get the MimeTypeEntry based on the file extension
+     */
+    public MimeTypeEntry getMimeTypeEntry(String file_ext) {
+        return (MimeTypeEntry)type_hash.get((Object)file_ext);
+    }
+
+    /**
+     * Get the MIME type string corresponding to the file extension.
+     */
+    public String getMIMETypeString(String file_ext) {
+        MimeTypeEntry entry = this.getMimeTypeEntry(file_ext);
+
+        if (entry != null)
+            return entry.getMIMEType();
+        else
+            return null;
+    }
+
+    /**
+     * Appends string of entries to the types registry, must be valid
+     * .mime.types format.
+     * A mime.types entry is one of two forms:
+     *
+     *  type/subtype    ext1 ext2 ...
+     * or
+     *  type=type/subtype desc="description of type" exts=ext1,ext2,...
+     *
+     * Example:
+     * # this is a test
+     * audio/basic            au
+     * text/plain             txt text
+     * type=application/postscript exts=ps,eps
+     */
+    public void appendToRegistry(String mime_types) {
+        try {
+            parse(new BufferedReader(new StringReader(mime_types)));
+        } catch (IOException ex) {
+            // can't happen
+        }
+    }
+
+    /**
+     * Parse a stream of mime.types entries.
+     */
+    private void parse(BufferedReader buf_reader) throws IOException {
+        String line = null, prev = null;
+
+        while ((line = buf_reader.readLine()) != null) {
+            if (prev == null)
+                prev = line;
+            else
+                prev += line;
+            int end = prev.length();
+            if (prev.length() > 0 && prev.charAt(end - 1) == '\\') {
+                prev = prev.substring(0, end - 1);
+                continue;
+            }
+            this.parseEntry(prev);
+            prev = null;
+        }
+        if (prev != null)
+            this.parseEntry(prev);
+    }
+
+    /**
+     * Parse single mime.types entry.
+     */
+    private void parseEntry(String line) {
+        String mime_type = null;
+        String file_ext = null;
+        line = line.trim();
+
+        if (line.length() == 0) // empty line...
+            return; // BAIL!
+
+        // check to see if this is a comment line?
+        if (line.charAt(0) == '#')
+            return; // then we are done!
+
+        // is it a new format line or old format?
+        if (line.indexOf('=') > 0) {
+            // new format
+            LineTokenizer lt = new LineTokenizer(line);
+            while (lt.hasMoreTokens()) {
+                String name = lt.nextToken();
+                String value = null;
+                if (lt.hasMoreTokens() && lt.nextToken().equals("=") &&
+                                                        lt.hasMoreTokens())
+                    value = lt.nextToken();
+                if (value == null) {
+                    if (LogSupport.isLoggable())
+                        LogSupport.log("Bad .mime.types entry: " + line);
+                    return;
+                }
+                if (name.equals("type"))
+                    mime_type = value;
+                else if (name.equals("exts")) {
+                    StringTokenizer st = new StringTokenizer(value, ",");
+                    while (st.hasMoreTokens()) {
+                        file_ext = st.nextToken();
+                        MimeTypeEntry entry =
+                                new MimeTypeEntry(mime_type, file_ext);
+                        type_hash.put(file_ext, entry);
+                        if (LogSupport.isLoggable())
+                            LogSupport.log("Added: " + entry.toString());
+                    }
+                }
+            }
+        } else {
+            // old format
+            // count the tokens
+            StringTokenizer strtok = new StringTokenizer(line);
+            int num_tok = strtok.countTokens();
+
+            if (num_tok == 0) // empty line
+                return;
+
+            mime_type = strtok.nextToken(); // get the MIME type
+
+            while (strtok.hasMoreTokens()) {
+                MimeTypeEntry entry = null;
+
+                file_ext = strtok.nextToken();
+                entry = new MimeTypeEntry(mime_type, file_ext);
+                type_hash.put(file_ext, entry);
+                if (LogSupport.isLoggable())
+                    LogSupport.log("Added: " + entry.toString());
+            }
+        }
+    }
+
+    // for debugging
+    /*
+    public static void main(String[] argv) throws Exception {
+        MimeTypeFile mf = new MimeTypeFile(argv[0]);
+        System.out.println("ext " + argv[1] + " type " +
+                                                mf.getMIMETypeString(argv[1]));
+        System.exit(0);
+    }
+    */
+}
+
+class LineTokenizer {
+    private int currentPosition;
+    private int maxPosition;
+    private String str;
+    private Vector stack = new Vector();
+    private static final String singles = "=";  // single character tokens
+
+    /**
+     * Constructs a tokenizer for the specified string.
+     * <p>
+     *
+     * @param   str            a string to be parsed.
+     */
+    public LineTokenizer(String str) {
+        currentPosition = 0;
+        this.str = str;
+        maxPosition = str.length();
+    }
+
+    /**
+     * Skips white space.
+     */
+    private void skipWhiteSpace() {
+        while ((currentPosition < maxPosition) &&
+               Character.isWhitespace(str.charAt(currentPosition))) {
+            currentPosition++;
+        }
+    }
+
+    /**
+     * Tests if there are more tokens available from this tokenizer's string.
+     *
+     * @return  <code>true</code> if there are more tokens available from this
+     *          tokenizer's string; <code>false</code> otherwise.
+     */
+    public boolean hasMoreTokens() {
+        if (stack.size() > 0)
+            return true;
+        skipWhiteSpace();
+        return (currentPosition < maxPosition);
+    }
+
+    /**
+     * Returns the next token from this tokenizer.
+     *
+     * @return     the next token from this tokenizer.
+     * @exception  NoSuchElementException  if there are no more tokens in this
+     *               tokenizer's string.
+     */
+    public String nextToken() {
+        int size = stack.size();
+        if (size > 0) {
+            String t = (String)stack.elementAt(size - 1);
+            stack.removeElementAt(size - 1);
+            return t;
+        }
+        skipWhiteSpace();
+
+        if (currentPosition >= maxPosition) {
+            throw new NoSuchElementException();
+        }
+
+        int start = currentPosition;
+        char c = str.charAt(start);
+        if (c == '"') {
+            currentPosition++;
+            boolean filter = false;
+            while (currentPosition < maxPosition) {
+                c = str.charAt(currentPosition++);
+                if (c == '\\') {
+                    currentPosition++;
+                    filter = true;
+                } else if (c == '"') {
+                    String s;
+
+                    if (filter) {
+                        StringBuffer sb = new StringBuffer();
+                        for (int i = start + 1; i < currentPosition - 1; i++) {
+                            c = str.charAt(i);
+                            if (c != '\\')
+                                sb.append(c);
+                        }
+                        s = sb.toString();
+                    } else
+                        s = str.substring(start + 1, currentPosition - 1);
+                    return s;
+                }
+            }
+        } else if (singles.indexOf(c) >= 0) {
+            currentPosition++;
+        } else {
+            while ((currentPosition < maxPosition) &&
+                   singles.indexOf(str.charAt(currentPosition)) < 0 &&
+                   !Character.isWhitespace(str.charAt(currentPosition))) {
+                currentPosition++;
+            }
+        }
+        return str.substring(start, currentPosition);
+    }
+
+    public void pushToken(String token) {
+        stack.addElement(token);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/ClassType.java b/jaxws/src/share/classes/com/sun/codemodel/internal/ClassType.java
new file mode 100644
index 0000000..7943701
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/ClassType.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+/**
+ * This helps enable whether the JDefinedClass is a Class or Interface or
+ * AnnotationTypeDeclaration or Enum
+ *
+ * @author
+ *     Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+public final class ClassType {
+
+    /**
+     * The keyword used to declare this type.
+     */
+    final String declarationToken;
+
+    private ClassType(String token) {
+        this.declarationToken = token;
+    }
+
+    public static final ClassType CLASS = new ClassType("class");
+    public static final ClassType INTERFACE = new ClassType("interface");
+    public static final ClassType ANNOTATION_TYPE_DECL = new ClassType("@interface");
+    public static final ClassType ENUM = new ClassType("enum");
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/CodeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/CodeWriter.java
new file mode 100644
index 0000000..9e2174d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/CodeWriter.java
@@ -0,0 +1,104 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+import java.nio.charset.CharsetEncoder;
+
+import com.sun.codemodel.internal.util.EncoderFactory;
+import com.sun.codemodel.internal.util.UnicodeEscapeWriter;
+
+/**
+ * Receives generated code and writes to the appropriate storage.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class CodeWriter {
+
+    /**
+     * Called by CodeModel to store the specified file.
+     * The callee must allocate a storage to store the specified file.
+     *
+     * <p>
+     * The returned stream will be closed before the next file is
+     * stored. So the callee can assume that only one OutputStream
+     * is active at any given time.
+     *
+     * @param   pkg
+     *      The package of the file to be written.
+     * @param   fileName
+     *      File name without the path. Something like
+     *      "Foo.java" or "Bar.properties"
+     */
+    public abstract OutputStream openBinary( JPackage pkg, String fileName ) throws IOException;
+
+    /**
+     * Called by CodeModel to store the specified file.
+     * The callee must allocate a storage to store the specified file.
+     *
+     * <p>
+     * The returned stream will be closed before the next file is
+     * stored. So the callee can assume that only one OutputStream
+     * is active at any given time.
+     *
+     * @param   pkg
+     *      The package of the file to be written.
+     * @param   fileName
+     *      File name without the path. Something like
+     *      "Foo.java" or "Bar.properties"
+     */
+    public Writer openSource( JPackage pkg, String fileName ) throws IOException {
+        final OutputStreamWriter bw = new OutputStreamWriter(openBinary(pkg,fileName));
+
+        // create writer
+        try {
+            return new UnicodeEscapeWriter(bw) {
+                // can't change this signature to Encoder because
+                // we can't have Encoder in method signature
+                private final CharsetEncoder encoder = EncoderFactory.createEncoder(bw.getEncoding());
+                protected boolean requireEscaping(int ch) {
+                    // control characters
+                    if( ch<0x20 && " \t\r\n".indexOf(ch)==-1 )  return true;
+                    // check ASCII chars, for better performance
+                    if( ch<0x80 )       return false;
+
+                    return !encoder.canEncode((char)ch);
+                }
+            };
+        } catch( Throwable t ) {
+            return new UnicodeEscapeWriter(bw);
+        }
+    }
+
+    /**
+     * Called by CodeModel at the end of the process.
+     */
+    public abstract void close() throws IOException;
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotatable.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotatable.java
new file mode 100644
index 0000000..1c9e580
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotatable.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.lang.annotation.Annotation;
+
+/**
+ * Annotatable program elements.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface JAnnotatable {
+    /**
+     * Adds an annotation to this program element.
+     * @param clazz
+     *          The annotation class to annotate the program element with
+     */
+    JAnnotationUse annotate(JClass clazz);
+
+    /**
+     * Adds an annotation to this program element.
+     *
+     * @param clazz
+     *          The annotation class to annotate the program element with
+     */
+    JAnnotationUse annotate(Class <? extends Annotation> clazz);
+
+    /**
+     * Adds an annotation to this program element
+     * and returns a type-safe writer to fill in the values of such annotations.
+     */
+    <W extends JAnnotationWriter> W annotate2(Class<W> clazz);
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationArrayMember.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationArrayMember.java
new file mode 100644
index 0000000..12d6828
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationArrayMember.java
@@ -0,0 +1,158 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+import java.lang.annotation.Annotation;
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * Represents an arrays as annotation members
+ *
+ * <p>
+ * This class implements {@link JAnnotatable} to allow
+ * new annotations to be added as a member of the array.
+ *
+ * @author
+ *     Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+public final class JAnnotationArrayMember extends JAnnotationValue implements JAnnotatable {
+    private final List<JAnnotationValue> values = new ArrayList<JAnnotationValue>();
+    private final JCodeModel owner;
+
+    JAnnotationArrayMember(JCodeModel owner) {
+        this.owner = owner;
+    }
+
+    /**
+     * Adds an array member to this annotation
+     *
+     * @param value Adds a string value to the array member
+     * @return The JAnnotationArrayMember. More elements can be added by calling
+     *         the same method multiple times
+     */
+    public JAnnotationArrayMember param(String value) {
+        JAnnotationValue annotationValue = new JAnnotationStringValue(JExpr.lit(value));
+        values.add(annotationValue);
+        return this;
+    }
+
+    public JAnnotationArrayMember param(boolean value) {
+        JAnnotationValue annotationValue = new JAnnotationStringValue(JExpr.lit(value));
+        values.add(annotationValue);
+        return this;
+    }
+
+    /**
+     * Adds an array member to this annotation
+     *
+     * @param value Adds an int value to the array member
+     * @return The JAnnotationArrayMember. More elements can be added by calling
+     *         the same method multiple times
+     */
+    public JAnnotationArrayMember param(int value) {
+        JAnnotationValue annotationValue = new JAnnotationStringValue(JExpr.lit(value));
+        values.add(annotationValue);
+        return this;
+    }
+
+    /**
+     * Adds an array member to this annotation
+     *
+     * @param value Adds a float value to the array member
+     * @return The JAnnotationArrayMember. More elements can be added by calling
+     *         the same method multiple times
+     */
+    public JAnnotationArrayMember param(float value) {
+        JAnnotationValue annotationValue = new JAnnotationStringValue(JExpr.lit(value));
+        values.add(annotationValue);
+        return this;
+    }
+
+    public JAnnotationArrayMember param(Class value){
+       JAnnotationValue annotationValue = new JAnnotationStringValue(JExpr.lit(value.getName()));
+       values.add(annotationValue);
+       return this;
+   }
+
+    public JAnnotationArrayMember param(JType type){
+        JClass clazz = type.boxify();
+        JAnnotationValue annotationValue = new JAnnotationStringValue ( clazz.dotclass() );
+        values.add(annotationValue);
+        return this;
+    }
+
+    /**
+     * Adds a new annotation to the array.
+     */
+    public JAnnotationUse annotate(Class<? extends Annotation> clazz){
+        return annotate(owner.ref(clazz));
+    }
+
+    /**
+     * Adds a new annotation to the array.
+     */
+    public JAnnotationUse annotate(JClass clazz){
+        JAnnotationUse a = new JAnnotationUse(clazz);
+        values.add(a);
+        return a;
+    }
+
+    public <W extends JAnnotationWriter> W annotate2(Class<W> clazz) {
+        return TypedAnnotationWriter.create(clazz,this);
+    }
+
+    /**
+     * Adds an annotation member to this annotation  array
+     * This can be used for e.g &#64;XmlCollection(values= &#64;XmlCollectionItem(type=Foo.class))
+     * @param value
+     *        Adds a annotation  to the array member
+     * @return
+     *        The JAnnotationArrayMember. More elements can be added by calling
+     *        the same method multiple times
+     *
+     * @deprecated
+     *      use {@link #annotate}
+     */
+    public JAnnotationArrayMember param (JAnnotationUse value ){
+        values.add(value);
+        return this;
+    }
+
+    public void generate(JFormatter f) {
+        f.p('{').nl().i();
+
+        boolean first = true;
+        for (JAnnotationValue aValue : values) {
+            if (!first)
+                f.p(',').nl();
+            f.g(aValue);
+            first = false;
+        }
+        f.nl().o().p('}');
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationStringValue.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationStringValue.java
new file mode 100644
index 0000000..f7bc5ea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationStringValue.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+
+/**
+ * Captures the value of the annotation.
+ *
+ * @author
+ *     Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+final class JAnnotationStringValue extends JAnnotationValue {
+
+    /**
+     * The value of the Annotation member
+     */
+    private final JExpression value;
+
+    JAnnotationStringValue(JExpression value) {
+        this.value = value;
+    }
+
+    public void generate(JFormatter f) {
+        f.g(value);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationUse.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationUse.java
new file mode 100644
index 0000000..df2d90c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationUse.java
@@ -0,0 +1,292 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+import java.lang.annotation.Annotation;
+import java.util.LinkedHashMap;
+import java.util.Map;
+
+/**
+ * Represents an annotation on a program element.
+ *
+ * TODO
+ *    How to add enums to the annotations
+ * @author
+ *     Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+public final class JAnnotationUse extends JAnnotationValue {
+
+    /**
+     * The {@link Annotation} class
+     */
+    private final JClass clazz;
+
+    /**
+     * Map of member values.
+     */
+    private Map<String,JAnnotationValue> memberValues;
+
+    JAnnotationUse(JClass clazz){
+        this.clazz = clazz;
+    }
+
+    private JCodeModel owner() {
+        return clazz.owner();
+    }
+
+    private void addValue(String name, JAnnotationValue annotationValue) {
+        // Use ordered map to keep the code generation the same on any JVM.
+        // Lazily created.
+        if(memberValues==null)
+            memberValues = new LinkedHashMap<String, JAnnotationValue>();
+        memberValues.put(name,annotationValue);
+    }
+
+    /**
+     * Adds a member value pair to this annotation
+     *
+     * @param name
+     *        The simple name for this annotation
+     *
+     * @param value
+     *        The boolean value for this annotation
+     * @return
+     *         The JAnnotationUse. More member value pairs can
+     *         be added to it using the same or the overloaded methods.
+     *
+     */
+    public JAnnotationUse param(String name, boolean value){
+        addValue(name, new JAnnotationStringValue(JExpr.lit(value)));
+        return this;
+    }
+
+    /**
+     * Adds a member value pair to this annotation
+     * @param name
+     *        The simple name for this annotation
+     *
+     * @param value
+     *        The int member value for this annotation
+     * @return
+     *         The JAnnotationUse. More member value pairs can
+     *         be added to it using the same or the overloaded methods.
+     *
+     */
+    public JAnnotationUse param(String name, int value){
+        addValue(name, new JAnnotationStringValue(JExpr.lit(value)));
+        return this;
+    }
+
+    /**
+     * Adds a member value pair to this annotation
+     * @param name
+     *        The simple name for this annotation
+     *
+     * @param value
+     *        The String member value for this annotation
+     * @return
+     *         The JAnnotationUse. More member value pairs can
+     *         be added to it using the same or the overloaded methods.
+     *
+     */
+    public JAnnotationUse param(String name, String value){
+        //Escape string values with quotes so that they can
+        //be generated accordingly
+        addValue(name, new JAnnotationStringValue(JExpr.lit(value)));
+        return this;
+    }
+
+    /**
+     * Adds a member value pair to this annotation
+     * For adding class values as param
+     * @see #param(String, Class)
+     * @param name
+     *        The simple name for this annotation
+     *
+     * @param value
+     *        The annotation class which is member value for this annotation
+     * @return
+     *         The JAnnotationUse. More member value pairs can
+     *         be added to it using the same or the overloaded methods.
+     *
+     */
+    public JAnnotationUse annotationParam(String name, Class<? extends Annotation> value) {
+        JAnnotationUse annotationUse = new JAnnotationUse(owner().ref(value));
+        addValue(name, annotationUse);
+        return annotationUse;
+    }
+
+    /**
+     * Adds a member value pair to this annotation
+     * @param name
+     *        The simple name for this annotation
+     *
+     * @param value
+     *        The enum class which is member value for this annotation
+     * @return
+     *         The JAnnotationUse. More member value pairs can
+     *         be added to it using the same or the overloaded methods.
+     *
+     */
+    public JAnnotationUse param(String name, final Enum value) {
+        addValue(name, new JAnnotationValue() {
+                    public void generate(JFormatter f) {
+                        f.t(owner().ref(value.getDeclaringClass())).p('.').p(value.name());
+                    }
+                });
+        return this;
+    }
+
+    /**
+     * Adds a member value pair to this annotation
+     * @param name
+     *        The simple name for this annotation
+     *
+     * @param value
+     *        The JEnumConstant which is member value for this annotation
+     * @return
+     *         The JAnnotationUse. More member value pairs can
+     *         be added to it using the same or the overloaded methods.
+     *
+     */
+    public JAnnotationUse param(String name, JEnumConstant value){
+        addValue(name, new JAnnotationStringValue(value));
+        return this;
+    }
+
+     /**
+      * Adds a member value pair to this annotation
+      *  This can be used for e.g to specify
+      * <pre>
+      *        &#64;XmlCollectionItem(type=Integer.class);
+      * <pre>
+      * For adding a value of Class<? extends Annotation>
+      * @link
+      * #annotationParam(java.lang.String, java.lang.Class<? extends java.lang.annotation.Annotation>)
+      * @param name
+      *        The simple name for this annotation param
+      *
+      * @param value
+      *        The class type of the param
+      * @return
+      *         The JAnnotationUse. More member value pairs can
+      *         be added to it using the same or the overloaded methods.
+      *
+      *
+      *
+      */
+     public JAnnotationUse param(String name, Class value){
+         addValue(name, new JAnnotationStringValue(JExpr.lit(value.getName())));
+         return this;
+    }
+
+    /**
+     * Adds a member value pair to this annotation based on the
+     * type represented by the given JType
+     *
+     * @param name The simple name for this annotation param
+     * @param type the JType representing the actual type
+     * @return The JAnnotationUse. More member value pairs can
+     *         be added to it using the same or the overloaded methods.
+     */
+    public JAnnotationUse param(String name, JType type){
+        JClass clazz = type.boxify();
+        addValue(name, new JAnnotationStringValue ( clazz.dotclass() ));
+        return this;
+    }
+
+    /**
+     * Adds a member value pair which is of type array to this annotation
+     * @param name
+     *        The simple name for this annotation
+     *
+     * @return
+     *         The JAnnotationArrayMember. For adding array values
+     *         @see JAnnotationArrayMember
+     *
+     */
+    public JAnnotationArrayMember paramArray(String name){
+        JAnnotationArrayMember arrayMember = new JAnnotationArrayMember(owner());
+        addValue(name, arrayMember);
+        return arrayMember;
+    }
+
+
+//    /**
+//     * This can be used to add annotations inside annotations
+//     * for e.g  &#64;XmlCollection(values= &#64;XmlCollectionItem(type=Foo.class))
+//     * @param className
+//     *         The classname of the annotation to be included
+//     * @return
+//     *         The JAnnotationUse that can be used as a member within this JAnnotationUse
+//     * @deprecated
+//     *      use {@link JAnnotationArrayMember#annotate}
+//     */
+//    public JAnnotationUse annotate(String className) {
+//        JAnnotationUse annotationUse = new JAnnotationUse(owner().ref(className));
+//        return annotationUse;
+//    }
+
+    /**
+     * This can be used to add annotations inside annotations
+     * for e.g  &#64;XmlCollection(values= &#64;XmlCollectionItem(type=Foo.class))
+     * @param clazz
+     *         The annotation class to be included
+     * @return
+     *     The JAnnotationUse that can be used as a member within this JAnnotationUse
+     * @deprecated
+     *      use {@link JAnnotationArrayMember#annotate}
+     */
+    public JAnnotationUse annotate(Class <? extends Annotation> clazz) {
+         JAnnotationUse annotationUse = new JAnnotationUse(owner().ref(clazz));
+         return annotationUse;
+    }
+
+    public void generate(JFormatter f) {
+        f.p('@').g(clazz);
+        if(memberValues!=null) {
+            f.p('(');
+            boolean first = true;
+
+            if(isOptimizable()) {
+                // short form
+                f.g(memberValues.get("value"));
+            } else {
+                for (Map.Entry<String, JAnnotationValue> mapEntry : memberValues.entrySet()) {
+                    if (!first) f.p(',');
+                    f.p(mapEntry.getKey()).p('=').g(mapEntry.getValue());
+                    first = false;
+                }
+            }
+            f.p(')');
+        }
+    }
+
+    private boolean isOptimizable() {
+        return memberValues.size()==1 && memberValues.containsKey("value");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationValue.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationValue.java
new file mode 100644
index 0000000..77e61ce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationValue.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * Things that can be values of an annotation element.
+ *
+ * @author
+ *     Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+public abstract class JAnnotationValue implements JGenerable {
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationWriter.java
new file mode 100644
index 0000000..426ebd5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnnotationWriter.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.lang.annotation.Annotation;
+
+/**
+ * Base interface for typed annotation writer.
+ *
+ * <p>
+ * Annotation compiler can generate a strongly typed annotation
+ * writer to assist applications to write uses of annotations.
+ * Such typed annotation writer interfaces all derive from
+ * this common interface.
+ *
+ * <p>
+ * The type parameter 'A' represents the
+ * @author Kohsuke Kawaguchi
+ */
+public interface JAnnotationWriter<A extends Annotation> {
+    /**
+     * Gets the underlying annotation use object to which we are writing.
+     */
+    JAnnotationUse getAnnotationUse();
+
+    /**
+     * The type of the annotation that this writer is writing.
+     */
+    Class<A> getAnnotationType();
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAnonymousClass.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnonymousClass.java
new file mode 100644
index 0000000..6a8727d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAnonymousClass.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * Anonymous class quick hack.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class JAnonymousClass extends JDefinedClass {
+
+    /**
+     * Base interface/class from which this anonymous class is built.
+     */
+    private final JClass base;
+
+    JAnonymousClass( JClass _base) {
+        super(_base.owner(), 0, null);
+        this.base = _base;
+    }
+
+    public String fullName() {
+        return base.fullName();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JArray.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JArray.java
new file mode 100644
index 0000000..a9d0efd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JArray.java
@@ -0,0 +1,87 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.List;
+
+
+/**
+ * array creation and initialization.
+ */
+public final class JArray extends JExpressionImpl {
+
+    private final JType type;
+    private final JExpression size;
+    private List<JExpression> exprs = null;
+
+    /**
+     * Add an element to the array initializer
+     */
+    public JArray add(JExpression e) {
+        if (exprs == null)
+            exprs = new ArrayList<JExpression>();
+        exprs.add(e);
+        return this;
+    }
+
+    JArray(JType type, JExpression size) {
+        this.type = type;
+        this.size = size;
+    }
+
+    public void generate(JFormatter f) {
+
+        // generally we produce new T[x], but when T is an array type (T=T'[])
+        // then new T'[][x] is wrong. It has to be new T'[x][].
+        int arrayCount = 0;
+        JType t = type;
+
+        while( t.isArray() ) {
+            t = t.elementType();
+            arrayCount++;
+        }
+
+        f.p("new").g(t).p('[');
+        if (size != null)
+            f.g(size);
+        f.p(']');
+
+        for( int i=0; i<arrayCount; i++ )
+            f.p("[]");
+
+        if ((size == null) || (exprs != null))
+            f.p('{');
+        if (exprs != null) {
+            f.g(exprs);
+        } else {
+            f.p(' ');
+        }
+        if ((size == null) || (exprs != null))
+            f.p('}');
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JArrayClass.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JArrayClass.java
new file mode 100644
index 0000000..b6934c9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JArrayClass.java
@@ -0,0 +1,123 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.Iterator;
+import java.util.Collections;
+import java.util.List;
+
+/**
+ * Array class.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class JArrayClass extends JClass {
+
+    // array component type
+    private final JType componentType;
+
+
+    JArrayClass( JCodeModel owner, JType component ) {
+        super(owner);
+        this.componentType = component;
+    }
+
+
+    public String name() {
+        return componentType.name()+"[]";
+    }
+
+    public String fullName() {
+        return componentType.fullName()+"[]";
+    }
+
+    public String binaryName() {
+        return componentType.binaryName()+"[]";
+    }
+
+    public void generate(JFormatter f) {
+        f.g(componentType).p("[]");
+    }
+
+    public JPackage _package() {
+        return owner().rootPackage();
+    }
+
+    public JClass _extends() {
+        return owner().ref(Object.class);
+    }
+
+    public Iterator<JClass> _implements() {
+        return Collections.<JClass>emptyList().iterator();
+    }
+
+    public boolean isInterface() {
+        return false;
+    }
+
+    public boolean isAbstract() {
+        return false;
+    }
+
+    public JType elementType() {
+        return componentType;
+    }
+
+    public boolean isArray() {
+        return true;
+    }
+
+
+    //
+    // Equality is based on value
+    //
+
+    public boolean equals(Object obj) {
+        if(!(obj instanceof JArrayClass))   return false;
+
+        if( componentType.equals( ((JArrayClass)obj).componentType ) )
+            return true;
+
+        return false;
+    }
+
+    public int hashCode() {
+        return componentType.hashCode();
+    }
+
+    protected JClass substituteParams(JTypeVar[] variables, List<JClass> bindings) {
+        if( componentType.isPrimitive() )
+            return this;
+
+        JClass c = ((JClass)componentType).substituteParams(variables,bindings);
+        if(c==componentType)
+            return this;
+
+        return new JArrayClass(owner(),c);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JArrayCompRef.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JArrayCompRef.java
new file mode 100644
index 0000000..87e78dd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JArrayCompRef.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * array component reference.
+ */
+final class JArrayCompRef extends JExpressionImpl implements JAssignmentTarget {
+    /**
+     * JArray expression upon which this component will be accessed.
+     */
+    private final JExpression array;
+
+    /**
+     * Integer expression representing index of the component
+     */
+    private final JExpression index;
+
+    /**
+     * JArray component reference constructor given an array expression
+     * and index.
+     *
+     * @param array
+     *        JExpression for the array upon which
+     *        the component will be accessed,
+     *
+     * @param index
+     *        JExpression for index of component to access
+     */
+    JArrayCompRef(JExpression array, JExpression index) {
+        if ((array == null) || (index == null)) {
+            throw new NullPointerException();
+        }
+        this.array = array;
+        this.index = index;
+    }
+
+    public void generate(JFormatter f) {
+        f.g(array).p('[').g(index).p(']');
+    }
+
+    public JExpression assign(JExpression rhs) {
+                return JExpr.assign(this,rhs);
+    }
+    public JExpression assignPlus(JExpression rhs) {
+                return JExpr.assignPlus(this,rhs);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAssignment.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAssignment.java
new file mode 100644
index 0000000..d5a1934
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAssignment.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Assignment statements, which are also expressions.
+ */
+public class JAssignment extends JExpressionImpl implements JStatement {
+
+    JAssignmentTarget lhs;
+    JExpression rhs;
+    String op = "";
+
+    JAssignment(JAssignmentTarget lhs, JExpression rhs) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    JAssignment(JAssignmentTarget lhs, JExpression rhs, String op) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+        this.op = op;
+    }
+
+    public void generate(JFormatter f) {
+        f.g(lhs).p(op + '=').g(rhs);
+    }
+
+    public void state(JFormatter f) {
+        f.g(this).p(';').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAssignmentTarget.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAssignmentTarget.java
new file mode 100644
index 0000000..75368a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAssignmentTarget.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Marker interface for code components that can be placed to
+ * the left of '=' in an assignment.
+ *
+ * A left hand value can always be a right hand value, so
+ * this interface derives from {@link JExpression}.
+ */
+public interface JAssignmentTarget extends JGenerable, JExpression {
+    JExpression assign(JExpression rhs);
+    JExpression assignPlus(JExpression rhs);
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JAtom.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JAtom.java
new file mode 100644
index 0000000..fe7bb36
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JAtom.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * JAtoms: Simple code components that merely generate themselves.
+ */
+final class JAtom extends JExpressionImpl {
+
+    private final String what;
+
+    JAtom(String what) {
+        this.what = what;
+    }
+
+    public void generate(JFormatter f) {
+        f.p(what);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JBlock.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JBlock.java
new file mode 100644
index 0000000..c64b5e9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JBlock.java
@@ -0,0 +1,451 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Collections;
+
+/**
+ * A block of Java code, which may contain statements and local declarations.
+ *
+ * <p>
+ * {@link JBlock} contains a large number of factory methods that creates new
+ * statements/declarations. Those newly created statements/declarations are
+ * inserted into the {@link #pos() "current position"}. The position advances
+ * one every time you add a new instruction.
+ */
+public final class JBlock implements JGenerable, JStatement {
+
+    /**
+     * Declarations and statements contained in this block.
+     * Either {@link JStatement} or {@link JDeclaration}.
+     */
+    private final List<Object> content = new ArrayList<Object>();
+
+    /**
+     * Whether or not this block must be braced and indented
+     */
+    private boolean bracesRequired = true;
+    private boolean indentRequired = true;
+
+    /**
+     * Current position.
+     */
+    private int pos;
+
+    public JBlock() {
+        this(true,true);
+    }
+
+    public JBlock(boolean bracesRequired, boolean indentRequired) {
+        this.bracesRequired = bracesRequired;
+        this.indentRequired = indentRequired;
+    }
+
+    /**
+     * Returns a read-only view of {@link JStatement}s and {@link JDeclaration}
+     * in this block.
+     */
+    public List<Object> getContents() {
+        return Collections.unmodifiableList(content);
+    }
+
+    private <T> T insert( T statementOrDeclaration ) {
+        content.add(pos,statementOrDeclaration);
+        pos++;
+        return statementOrDeclaration;
+    }
+
+    /**
+     * Gets the current position to which new statements will be inserted.
+     *
+     * For example if the value is 0, newly created instructions will be
+     * inserted at the very beginning of the block.
+     *
+     * @see #pos(int)
+     */
+    public int pos() {
+        return pos;
+    }
+
+    /**
+     * Sets the current position.
+     *
+     * @return
+     *      the old value of the current position.
+     * @throws IllegalArgumentException
+     *      if the new position value is illegal.
+     *
+     * @see #pos()
+     */
+    public int pos(int newPos) {
+        int r = pos;
+        if(newPos>content.size() || newPos<0)
+            throw new IllegalArgumentException();
+        pos = newPos;
+
+        return r;
+    }
+
+
+    /**
+     * Adds a local variable declaration to this block
+     *
+     * @param type
+     *        JType of the variable
+     *
+     * @param name
+     *        Name of the variable
+     *
+     * @return Newly generated JVar
+     */
+    public JVar decl(JType type, String name) {
+        return decl(JMod.NONE, type, name, null);
+    }
+
+    /**
+     * Adds a local variable declaration to this block
+     *
+     * @param type
+     *        JType of the variable
+     *
+     * @param name
+     *        Name of the variable
+     *
+     * @param init
+     *        Initialization expression for this variable.  May be null.
+     *
+     * @return Newly generated JVar
+     */
+    public JVar decl(JType type, String name, JExpression init) {
+        return decl(JMod.NONE, type, name, init);
+    }
+
+    /**
+     * Adds a local variable declaration to this block
+     *
+     * @param mods
+     *        Modifiers for the variable
+     *
+     * @param type
+     *        JType of the variable
+     *
+     * @param name
+     *        Name of the variable
+     *
+     * @param init
+     *        Initialization expression for this variable.  May be null.
+     *
+     * @return Newly generated JVar
+     */
+    public JVar decl(int mods, JType type, String name, JExpression init) {
+        JVar v = new JVar(JMods.forVar(mods), type, name, init);
+        insert(v);
+        bracesRequired = true;
+        indentRequired = true;
+        return v;
+    }
+
+    /**
+     * Creates an assignment statement and adds it to this block.
+     *
+     * @param lhs
+     *        Assignable variable or field for left hand side of expression
+     *
+     * @param exp
+     *        Right hand side expression
+     */
+    public JBlock assign(JAssignmentTarget lhs, JExpression exp) {
+        insert(new JAssignment(lhs, exp));
+        return this;
+    }
+
+    public JBlock assignPlus(JAssignmentTarget lhs, JExpression exp) {
+        insert(new JAssignment(lhs, exp, "+"));
+        return this;
+    }
+
+    /**
+     * Creates an invocation statement and adds it to this block.
+     *
+     * @param expr
+     *        JExpression evaluating to the class or object upon which
+     *        the named method will be invoked
+     *
+     * @param method
+     *        Name of method to invoke
+     *
+     * @return Newly generated JInvocation
+     */
+    public JInvocation invoke(JExpression expr, String method) {
+        JInvocation i = new JInvocation(expr, method);
+        insert(i);
+        return i;
+    }
+
+    /**
+     * Creates an invocation statement and adds it to this block.
+     *
+     * @param expr
+     *        JExpression evaluating to the class or object upon which
+     *        the method will be invoked
+     *
+     * @param method
+     *        JMethod to invoke
+     *
+     * @return Newly generated JInvocation
+     */
+    public JInvocation invoke(JExpression expr, JMethod method) {
+        return invoke(expr, method.name());
+    }
+
+    /**
+     * Creates a static invocation statement.
+     */
+    public JInvocation staticInvoke(JClass type, String method) {
+        JInvocation i = new JInvocation(type, method);
+        insert(i);
+        return i;
+    }
+
+    /**
+     * Creates an invocation statement and adds it to this block.
+     *
+     * @param method
+     *        Name of method to invoke
+     *
+     * @return Newly generated JInvocation
+     */
+    public JInvocation invoke(String method) {
+        JInvocation i = new JInvocation((JExpression)null, method);
+        insert(i);
+        return i;
+    }
+
+    /**
+     * Creates an invocation statement and adds it to this block.
+     *
+     * @param method
+     *        JMethod to invoke
+     *
+     * @return Newly generated JInvocation
+     */
+    public JInvocation invoke(JMethod method) {
+        return invoke(method.name());
+    }
+
+    /**
+     * Adds a statement to this block
+     *
+     * @param s
+     *        JStatement to be added
+     *
+     * @return This block
+     */
+    public JBlock add(JStatement s) { // ## Needed?
+        insert(s);
+        return this;
+    }
+
+    /**
+     * Create an If statement and add it to this block
+     *
+     * @param expr
+     *        JExpression to be tested to determine branching
+     *
+     * @return Newly generated conditional statement
+     */
+    public JConditional _if(JExpression expr) {
+        return insert(new JConditional(expr));
+    }
+
+    /**
+     * Create a For statement and add it to this block
+     *
+     * @return Newly generated For statement
+     */
+    public JForLoop _for() {
+        return insert(new JForLoop());
+    }
+
+    /**
+     * Create a While statement and add it to this block
+     *
+     * @return Newly generated While statement
+     */
+    public JWhileLoop _while(JExpression test) {
+        return insert(new JWhileLoop(test));
+    }
+
+    /**
+     * Create a switch/case statement and add it to this block
+     */
+    public JSwitch _switch(JExpression test) {
+        return insert(new JSwitch(test));
+    }
+
+    /**
+     * Create a Do statement and add it to this block
+     *
+     * @return Newly generated Do statement
+     */
+    public JDoLoop _do(JExpression test) {
+        return insert(new JDoLoop(test));
+    }
+
+    /**
+     * Create a Try statement and add it to this block
+     *
+     * @return Newly generated Try statement
+     */
+    public JTryBlock _try() {
+        return insert(new JTryBlock());
+    }
+
+    /**
+     * Create a return statement and add it to this block
+     */
+    public void _return() {
+        insert(new JReturn(null));
+    }
+
+    /**
+     * Create a return statement and add it to this block
+     */
+    public void _return(JExpression exp) {
+        insert(new JReturn(exp));
+    }
+
+    /**
+     * Create a throw statement and add it to this block
+     */
+    public void _throw(JExpression exp) {
+        insert(new JThrow(exp));
+    }
+
+    /**
+     * Create a break statement and add it to this block
+     */
+    public void _break() {
+        _break(null);
+    }
+
+    public void _break(JLabel label) {
+        insert(new JBreak(label));
+    }
+
+    /**
+     * Create a label, which can be referenced from
+     * <code>continue</code> and <code>break</code> statements.
+     */
+    public JLabel label(String name) {
+        JLabel l = new JLabel(name);
+        insert(l);
+        return l;
+    }
+
+    /**
+     * Create a continue statement and add it to this block
+     */
+    public void _continue(JLabel label) {
+        insert(new JContinue(label));
+    }
+
+    public void _continue() {
+        _continue(null);
+    }
+
+    /**
+     * Create a sub-block and add it to this block
+     */
+    public JBlock block() {
+        JBlock b = new JBlock();
+        b.bracesRequired = false;
+        b.indentRequired = false;
+        return insert(b);
+    }
+
+    /**
+     * Creates a "literal" statement directly.
+     *
+     * <p>
+     * Specified string is printed as-is.
+     * This is useful as a short-cut.
+     *
+     * <p>
+     * For example, you can invoke this method as:
+     * <code>directStatement("a=b+c;")</code>.
+     */
+    public JStatement directStatement(final String source) {
+        JStatement s = new JStatement() {
+            public void state(JFormatter f) {
+                f.p(source).nl();
+            }
+        };
+        add(s);
+        return s;
+    }
+
+    public void generate(JFormatter f) {
+        if (bracesRequired)
+            f.p('{').nl();
+        if (indentRequired)
+            f.i();
+        generateBody(f);
+        if (indentRequired)
+            f.o();
+        if (bracesRequired)
+            f.p('}');
+    }
+
+    void generateBody(JFormatter f) {
+        for (Object o : content) {
+            if (o instanceof JDeclaration)
+                f.d((JDeclaration) o);
+            else
+                f.s((JStatement) o);
+        }
+    }
+
+    /**
+     * Creates an enhanced For statement based on j2se 1.5 JLS
+     * and add it to this block
+     *
+     * @return Newly generated enhanced For statement per j2se 1.5
+     * specification
+    */
+    public JForEach forEach(JType varType, String name, JExpression collection) {
+        return insert(new JForEach( varType, name, collection));
+
+    }
+    public void state(JFormatter f) {
+        f.g(this);
+        if (bracesRequired)
+            f.nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JBreak.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JBreak.java
new file mode 100644
index 0000000..6d82275
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JBreak.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * JBreak statement
+ */
+final class JBreak implements JStatement {
+
+    private final JLabel label;
+
+    /**
+     * JBreak constructor
+     *
+     * @param   _label
+     *      break label or null.
+     */
+    JBreak( JLabel _label ) {
+        this.label = _label;
+    }
+
+    public void state(JFormatter f) {
+        if( label==null )
+            f.p("break;").nl();
+        else
+            f.p("break").p(label.label).p(';').nl();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JCase.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JCase.java
new file mode 100644
index 0000000..3b41503
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JCase.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * Case statement
+ */
+public final class JCase implements JStatement {
+
+    /**
+     * label part of the case statement
+     */
+    private JExpression label;
+
+    /**
+     * JBlock of statements which makes up body of this While statement
+     */
+    private JBlock body = null;
+
+    /**
+     * is this a regular case statement or a default case statement?
+     */
+    private boolean isDefaultCase = false;
+
+    /**
+     * Construct a case statement
+     */
+    JCase(JExpression label) {
+        this(label, false);
+    }
+
+    /**
+     * Construct a case statement.  If isDefaultCase is true, then
+     * label should be null since default cases don't have a label.
+     */
+    JCase(JExpression label, boolean isDefaultCase) {
+        this.label = label;
+        this.isDefaultCase = isDefaultCase;
+    }
+
+    public JExpression label() {
+        return label;
+    }
+
+    public JBlock body() {
+        if (body == null) body=new JBlock( false, true );
+        return body;
+    }
+
+    public void state(JFormatter f) {
+        f.i();
+        if( !isDefaultCase ) {
+            f.p("case ").g(label).p(':').nl();
+        } else {
+            f.p("default:").nl();
+        }
+        if (body != null)
+            f.s(body);
+        f.o();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JCast.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JCast.java
new file mode 100644
index 0000000..d840b49
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JCast.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+
+/**
+ * A cast operation.
+ */
+final class JCast extends JExpressionImpl {
+    /**
+     * JType to which the expression is to be cast.
+     */
+    private final JType type;
+
+    /**
+     * JExpression to be cast.
+     */
+    private final JExpression object;
+
+    /**
+     * JCast constructor
+     *
+     * @param type
+     *        JType to which the expression is cast
+     *
+     * @param object
+     *        JExpression for the object upon which
+     *        the cast is applied
+     */
+    JCast(JType type, JExpression object) {
+        this.type = type;
+        this.object = object;
+    }
+
+    public void generate(JFormatter f) {
+        f.p("((").g(type).p(')').g(object).p(')');
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JCatchBlock.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JCatchBlock.java
new file mode 100644
index 0000000..731e0b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JCatchBlock.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Catch block for a try/catch/finally statement
+ */
+
+public class JCatchBlock implements JGenerable {
+
+    JClass exception;
+    private JVar var = null;
+    private JBlock body = new JBlock();
+
+    JCatchBlock(JClass exception) {
+        this.exception = exception;
+    }
+
+    public JVar param(String name) {
+        if (var != null) throw new IllegalStateException();
+        var = new JVar(JMods.forVar(JMod.NONE), exception, name, null);
+        return var;
+    }
+
+    public JBlock body() {
+        return body;
+    }
+
+    public void generate(JFormatter f) {
+        if (var == null)
+            var = new JVar(JMods.forVar(JMod.NONE),
+                    exception, "_x", null);
+        f.p("catch (").b(var).p(')').g(body);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JClass.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JClass.java
new file mode 100644
index 0000000..d4b7a9d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JClass.java
@@ -0,0 +1,352 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.Iterator;
+import java.util.List;
+
+/**
+ * Represents a Java reference type, such as a class, an interface,
+ * an enum, an array type, a parameterized type.
+ *
+ * <p>
+ * To be exact, this object represents an "use" of a reference type,
+ * not necessarily a declaration of it, which is modeled as {@link JDefinedClass}.
+ */
+public abstract class JClass extends JType
+{
+    protected JClass( JCodeModel _owner ) {
+        this._owner = _owner;
+    }
+
+    /**
+     * Gets the name of this class.
+     *
+     * @return
+     *  name of this class, without any qualification.
+     *  For example, this method returns "String" for
+     *  <code>java.lang.String</code>.
+     */
+    abstract public String name();
+
+        /**
+     * Gets the package to which this class belongs.
+     * TODO: shall we move move this down?
+     */
+    abstract public JPackage _package();
+
+    /**
+     * Returns the class in which this class is nested, or <tt>null</tt> if
+     * this is a top-level class.
+     */
+    public JClass outer() {
+        return null;
+    }
+
+    private final JCodeModel _owner;
+    /** Gets the JCodeModel object to which this object belongs. */
+    public final JCodeModel owner() { return _owner; }
+
+    /**
+     * Gets the super class of this class.
+     *
+     * @return
+     *      Returns the JClass representing the superclass of the
+     *      entity (class or interface) represented by this {@link JClass}.
+     *      Even if no super class is given explicitly or this {@link JClass}
+     *      is not a class, this method still returns
+     *      {@link JClass} for {@link Object}.
+     *      If this JClass represents {@link Object}, return null.
+     */
+    abstract public JClass _extends();
+
+    /**
+     * Iterates all super interfaces directly implemented by
+     * this class/interface.
+     *
+     * @return
+     *          A non-null valid iterator that iterates all
+     *          {@link JClass} objects that represents those interfaces
+     *          implemented by this object.
+     */
+    abstract public Iterator<JClass> _implements();
+
+    /**
+     * Iterates all the type parameters of this class/interface.
+     *
+     * <p>
+     * For example, if this {@link JClass} represents
+     * <code>Set&lt;T></code>, this method returns an array
+     * that contains single {@link JTypeVar} for 'T'.
+     */
+    public JTypeVar[] typeParams() {
+        return EMPTY_ARRAY;
+    }
+
+    /**
+     * Sometimes useful reusable empty array.
+     */
+    protected static final JTypeVar[] EMPTY_ARRAY = new JTypeVar[0];
+
+    /**
+     * Checks if this object represents an interface.
+     */
+    abstract public boolean isInterface();
+
+    /**
+     * Checks if this class is an abstract class.
+     */
+    abstract public boolean isAbstract();
+
+    /**
+     * If this class represents one of the wrapper classes
+     * defined in the java.lang package, return the corresponding
+     * primitive type. Otherwise null.
+     */
+    public JPrimitiveType getPrimitiveType() { return null; }
+
+    /**
+     * @deprecated calling this method from {@link JClass}
+     * would be meaningless, since it's always guaranteed to
+     * return <tt>this</tt>.
+     */
+    public JClass boxify() { return this; }
+
+    public JType unboxify() {
+        JPrimitiveType pt = getPrimitiveType();
+        return pt==null ? (JType)this : pt;
+    }
+
+    public JClass erasure() {
+        return this;
+    }
+
+    /**
+     * Checks the relationship between two classes.
+     * <p>
+     * This method works in the same way as {@link Class#isAssignableFrom(Class)}
+     * works. For example, baseClass.isAssignableFrom(derivedClass)==true.
+     */
+    public final boolean isAssignableFrom( JClass derived ) {
+        // to avoid the confusion, always use "this" explicitly in this method.
+
+        // null can be assigned to any type.
+        if( derived instanceof JNullType )  return true;
+
+        if( this==derived )     return true;
+
+        // the only class that is assignable from an interface is
+        // java.lang.Object
+        if( this==_package().owner().ref(Object.class) )  return true;
+
+        JClass b = derived._extends();
+        if( b!=null && this.isAssignableFrom(b) )
+            return true;
+
+        if( this.isInterface() ) {
+            Iterator itfs = derived._implements();
+            while( itfs.hasNext() )
+                if( this.isAssignableFrom((JClass)itfs.next()) )
+                    return true;
+        }
+
+        return false;
+    }
+
+    /**
+     * Gets the parameterization of the given base type.
+     *
+     * <p>
+     * For example, given the following
+     * <pre><xmp>
+     * interface Foo<T> extends List<List<T>> {}
+     * interface Bar extends Foo<String> {}
+     * </xmp></pre>
+     * This method works like this:
+     * <pre><xmp>
+     * getBaseClass( Bar, List ) = List<List<String>
+     * getBaseClass( Bar, Foo  ) = Foo<String>
+     * getBaseClass( Foo<? extends Number>, Collection ) = Collection<List<? extends Number>>
+     * getBaseClass( ArrayList<? extends BigInteger>, List ) = List<? extends BigInteger>
+     * </xmp></pre>
+     *
+     * @param baseType
+     *      The class whose parameterization we are interested in.
+     * @return
+     *      The use of {@code baseType} in {@code this} type.
+     *      or null if the type is not assignable to the base type.
+     */
+    public final JClass getBaseClass( JClass baseType ) {
+
+        if( this.erasure().equals(baseType) )
+            return this;
+
+        JClass b = _extends();
+        if( b!=null ) {
+            JClass bc = b.getBaseClass(baseType);
+            if(bc!=null)
+                return bc;
+        }
+
+        Iterator<JClass> itfs = _implements();
+        while( itfs.hasNext() ) {
+            JClass bc = itfs.next().getBaseClass(baseType);
+            if(bc!=null)
+                return bc;
+        }
+
+        return null;
+    }
+
+    public final JClass getBaseClass( Class baseType ) {
+        return getBaseClass(owner().ref(baseType));
+    }
+
+
+    private JClass arrayClass;
+    public JClass array() {
+        if(arrayClass==null)
+            arrayClass = new JArrayClass(owner(),this);
+        return arrayClass;
+    }
+
+    /**
+     * "Narrows" a generic class to a concrete class by specifying
+     * a type argument.
+     *
+     * <p>
+     * <code>.narrow(X)</code> builds <code>Set&lt;X></code> from <code>Set</code>.
+     */
+    public JClass narrow( Class clazz ) {
+        return narrow(owner().ref(clazz));
+    }
+
+    public JClass narrow( Class... clazz ) {
+        JClass[] r = new JClass[clazz.length];
+        for( int i=0; i<clazz.length; i++ )
+            r[i] = owner().ref(clazz[i]);
+        return narrow(r);
+    }
+
+    /**
+     * "Narrows" a generic class to a concrete class by specifying
+     * a type argument.
+     *
+     * <p>
+     * <code>.narrow(X)</code> builds <code>Set&lt;X></code> from <code>Set</code>.
+     */
+    public JClass narrow( JClass clazz ) {
+        return new JNarrowedClass(this,clazz);
+    }
+
+    public JClass narrow( JClass... clazz ) {
+        return new JNarrowedClass(this,Arrays.asList(clazz.clone()));
+    }
+
+    public JClass narrow( List<? extends JClass> clazz ) {
+        return new JNarrowedClass(this,new ArrayList(clazz));
+    }
+
+    /**
+     * If this class is parameterized, return the type parameter of the given index.
+     */
+    public List<JClass> getTypeParameters() {
+        return Collections.emptyList();
+    }
+
+    /**
+     * Returns true if this class is a parameterized class.
+     */
+    public final boolean isParameterized() {
+        return erasure()!=this;
+    }
+
+    /**
+     * Create "? extends T" from T.
+     *
+     * @return never null
+     */
+    public final JClass wildcard() {
+        return new JTypeWildcard(this);
+    }
+
+    /**
+     * Substitutes the type variables with their actual arguments.
+     *
+     * <p>
+     * For example, when this class is Map&lt;String,Map&lt;V>>,
+     * (where V then doing
+     * substituteParams( V, Integer ) returns a {@link JClass}
+     * for <code>Map&lt;String,Map&lt;Integer>></code>.
+     *
+     * <p>
+     * This method needs to work recursively.
+     */
+    protected abstract JClass substituteParams( JTypeVar[] variables, List<JClass> bindings );
+
+    public String toString() {
+        return this.getClass().getName() + '(' + name() + ')';
+    }
+
+
+    public final JExpression dotclass() {
+        return JExpr.dotclass(this);
+    }
+
+    /** Generates a static method invocation. */
+    public final JInvocation staticInvoke(JMethod method) {
+        return staticInvoke(method.name());
+    }
+
+    /** Generates a static method invocation. */
+    public final JInvocation staticInvoke(String method) {
+        return new JInvocation(this,method);
+    }
+
+    /** Static field reference. */
+    public final JFieldRef staticRef(String field) {
+        return new JFieldRef(this, field);
+    }
+
+    /** Static field reference. */
+    public final JFieldRef staticRef(JVar field) {
+        return new JFieldRef(this, field);
+    }
+
+    public void generate(JFormatter f) {
+        f.t(this);
+    }
+
+    /**
+     * Prints the class name in javadoc @link format.
+     */
+    void printLink(JFormatter f) {
+        f.p("{@link ").g(this).p('}');
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JClassAlreadyExistsException.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JClassAlreadyExistsException.java
new file mode 100644
index 0000000..21b9511
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JClassAlreadyExistsException.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * Indicates that the class is already created.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JClassAlreadyExistsException extends Exception {
+    private final JDefinedClass existing;
+
+    public JClassAlreadyExistsException( JDefinedClass _existing ) {
+        this.existing = _existing;
+    }
+
+    /**
+     * Gets a reference to the existing {@link JDefinedClass}.
+     *
+     * @return
+     *      This method always return non-null valid object.
+     */
+    public JDefinedClass getExistingClass() {
+        return existing;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JClassContainer.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JClassContainer.java
new file mode 100644
index 0000000..43cf24c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JClassContainer.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.Iterator;
+
+/**
+ * The common aspect of a package and a class.
+ */
+public interface JClassContainer {
+
+    /**
+     * Returns true if the container is a class.
+     */
+    boolean isClass();
+    /**
+     * Returns true if the container is a package.
+     */
+    boolean isPackage();
+
+    /**
+     * Add a new class to this package/class.
+     *
+     * @param mods
+     *        Modifiers for this class declaration
+     *
+     * @param name
+     *        Name of class to be added to this package
+     *
+     * @return Newly generated class
+     *
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+     */
+    JDefinedClass _class(int mods, String name) throws JClassAlreadyExistsException;
+
+    /**
+     * Add a new public class to this class/package.
+     *
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+     */
+    public JDefinedClass _class(String name) throws JClassAlreadyExistsException;
+
+    /**
+     * Add an interface to this class/package.
+     *
+     * @param mods
+     *        Modifiers for this interface declaration
+     *
+     * @param name
+     *        Name of interface to be added to this package
+     *
+     * @return Newly generated interface
+     *
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+     */
+    public JDefinedClass _interface(int mods, String name) throws JClassAlreadyExistsException;
+
+    /**
+     * Adds a public interface to this package.
+     *
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+     */
+    public JDefinedClass _interface(String name) throws JClassAlreadyExistsException;
+
+    /**
+     * Create a new class or a new interface.
+     *
+     * @deprecated
+     *      use {@link #_class(int, String, ClassType)}
+     */
+    public JDefinedClass _class(int mods, String name, boolean isInterface )
+        throws JClassAlreadyExistsException;
+
+    /**
+     * Creates a new class/enum/interface/annotation.
+     */
+    public JDefinedClass _class(int mods, String name, ClassType kind )
+        throws JClassAlreadyExistsException;
+
+
+    /**
+     * Returns an iterator that walks the nested classes defined in this
+     * class.
+     */
+    public Iterator<JDefinedClass> classes();
+
+    /**
+     * Parent JClassContainer.
+     *
+     * If this is a package, this method returns a parent package,
+     * or null if this package is the root package.
+     *
+     * If this is an outer-most class, this method returns a package
+     * to which it belongs.
+     *
+     * If this is an inner class, this method returns the outer
+     * class.
+     */
+    public JClassContainer parentContainer();
+
+    /**
+     * Gets the nearest package parent.
+     *
+     * <p>
+     * If <tt>this.isPackage()</tt>, then return <tt>this</tt>.
+     */
+    public JPackage getPackage();
+
+    /**
+     * Get the root code model object.
+     */
+    public JCodeModel owner();
+
+    /**
+     * Add an annotationType Declaration to this package
+     * @param name
+     *      Name of the annotation Type declaration to be added to this package
+     * @return
+     *      newly created Annotation Type Declaration
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+
+     */
+    public JDefinedClass _annotationTypeDeclaration(String name) throws JClassAlreadyExistsException;
+
+    /**
+     * Add a public enum to this package
+     * @param name
+     *      Name of the enum to be added to this package
+     * @return
+     *      newly created Enum
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+
+     */
+    public JDefinedClass _enum (String name) throws JClassAlreadyExistsException;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JCodeModel.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JCodeModel.java
new file mode 100644
index 0000000..25791e0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JCodeModel.java
@@ -0,0 +1,641 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.PrintStream;
+import java.lang.reflect.Modifier;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import com.sun.codemodel.internal.writer.FileCodeWriter;
+import com.sun.codemodel.internal.writer.ProgressCodeWriter;
+
+
+/**
+ * Root of the code DOM.
+ *
+ * <p>
+ * Here's your typical CodeModel application.
+ *
+ * <pre>
+ * JCodeModel cm = new JCodeModel();
+ *
+ * // generate source code by populating the 'cm' tree.
+ * cm._class(...);
+ * ...
+ *
+ * // write them out
+ * cm.build(new File("."));
+ * </pre>
+ *
+ * <p>
+ * Every CodeModel node is always owned by one {@link JCodeModel} object
+ * at any given time (which can be often accesesd by the <tt>owner()</tt> method.)
+ *
+ * As such, when you generate Java code, most of the operation works
+ * in a top-down fashion. For example, you create a class from {@link JCodeModel},
+ * which gives you a {@link JDefinedClass}. Then you invoke a method on it
+ * to generate a new method, which gives you {@link JMethod}, and so on.
+ *
+ * There are a few exceptions to this, most notably building {@link JExpression}s,
+ * but generally you work with CodeModel in a top-down fashion.
+ *
+ * Because of this design, most of the CodeModel classes aren't directly instanciable.
+ *
+ *
+ * <h2>Where to go from here?</h2>
+ * <p>
+ * Most of the time you'd want to populate new type definitions in a {@link JCodeModel}.
+ * See {@link #_class(String, ClassType)}.
+ */
+public final class JCodeModel {
+
+    /** The packages that this JCodeWriter contains. */
+    private HashMap<String,JPackage> packages = new HashMap<String,JPackage>();
+
+    /** All JReferencedClasses are pooled here. */
+    private final HashMap<Class,JReferencedClass> refClasses = new HashMap<Class,JReferencedClass>();
+
+
+    /** Obtains a reference to the special "null" type. */
+    public final JNullType NULL = new JNullType(this);
+    // primitive types
+    public final JPrimitiveType VOID    = new JPrimitiveType(this,"void",   Void.class);
+    public final JPrimitiveType BOOLEAN = new JPrimitiveType(this,"boolean",Boolean.class);
+    public final JPrimitiveType BYTE    = new JPrimitiveType(this,"byte",   Byte.class);
+    public final JPrimitiveType SHORT   = new JPrimitiveType(this,"short",  Short.class);
+    public final JPrimitiveType CHAR    = new JPrimitiveType(this,"char",   Character.class);
+    public final JPrimitiveType INT     = new JPrimitiveType(this,"int",    Integer.class);
+    public final JPrimitiveType FLOAT   = new JPrimitiveType(this,"float",  Float.class);
+    public final JPrimitiveType LONG    = new JPrimitiveType(this,"long",   Long.class);
+    public final JPrimitiveType DOUBLE  = new JPrimitiveType(this,"double", Double.class);
+
+    /**
+     * If the flag is true, we will consider two classes "Foo" and "foo"
+     * as a collision.
+     */
+    protected static final boolean isCaseSensitiveFileSystem = getFileSystemCaseSensitivity();
+
+    private static boolean getFileSystemCaseSensitivity() {
+        try {
+            // let the system property override, in case the user really
+            // wants to override.
+            if( System.getProperty("com.sun.codemodel.internal.FileSystemCaseSensitive")!=null )
+                return true;
+        } catch( Exception e ) {}
+
+        // on Unix, it's case sensitive.
+        return (File.separatorChar == '/');
+    }
+
+
+    public JCodeModel() {}
+
+    /**
+     * Add a package to the list of packages to be generated
+     *
+     * @param name
+     *        Name of the package. Use "" to indicate the root package.
+     *
+     * @return Newly generated package
+     */
+    public JPackage _package(String name) {
+        JPackage p = packages.get(name);
+        if (p == null) {
+            p = new JPackage(name, this);
+            packages.put(name, p);
+        }
+        return p;
+    }
+
+    public final JPackage rootPackage() {
+        return _package("");
+    }
+
+    /**
+     * Returns an iterator that walks the packages defined using this code
+     * writer.
+     */
+    public Iterator<JPackage> packages() {
+        return packages.values().iterator();
+    }
+
+    /**
+     * Creates a new generated class.
+     *
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+     */
+    public JDefinedClass _class(String fullyqualifiedName) throws JClassAlreadyExistsException {
+        return _class(fullyqualifiedName,ClassType.CLASS);
+    }
+
+    /**
+     * Creates a dummy, unknown {@link JClass} that represents a given name.
+     *
+     * <p>
+     * This method is useful when the code generation needs to include the user-specified
+     * class that may or may not exist, and only thing known about it is a class name.
+     */
+    public JClass directClass(String name) {
+        return new JDirectClass(this,name);
+    }
+
+    /**
+     * Creates a new generated class.
+     *
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+     */
+    public JDefinedClass _class(String fullyqualifiedName,ClassType t) throws JClassAlreadyExistsException {
+        int idx = fullyqualifiedName.lastIndexOf('.');
+        if( idx<0 )     return rootPackage()._class(fullyqualifiedName);
+        else
+            return _package(fullyqualifiedName.substring(0,idx))
+                ._class( JMod.PUBLIC, fullyqualifiedName.substring(idx+1), t );
+    }
+
+    /**
+     * Gets a reference to the already created generated class.
+     *
+     * @return null
+     *      If the class is not yet created.
+     * @see JPackage#_getClass(String)
+     */
+    public JDefinedClass _getClass(String fullyQualifiedName) {
+        int idx = fullyQualifiedName.lastIndexOf('.');
+        if( idx<0 )     return rootPackage()._getClass(fullyQualifiedName);
+        else
+            return _package(fullyQualifiedName.substring(0,idx))
+                ._getClass( fullyQualifiedName.substring(idx+1) );
+    }
+
+    /**
+     * Creates a new anonymous class.
+     *
+     * @deprecated
+     *      The naming convention doesn't match the rest of the CodeModel.
+     *      Use {@link #anonymousClass(JClass)} instead.
+     */
+    public JDefinedClass newAnonymousClass(JClass baseType) {
+        return new JAnonymousClass(baseType);
+    }
+
+    /**
+     * Creates a new anonymous class.
+     */
+    public JDefinedClass anonymousClass(JClass baseType) {
+        return new JAnonymousClass(baseType);
+    }
+
+    public JDefinedClass anonymousClass(Class baseType) {
+        return anonymousClass(ref(baseType));
+    }
+
+    /**
+     * Generates Java source code.
+     * A convenience method for <code>build(destDir,destDir,System.out)</code>.
+     *
+     * @param   destDir
+     *          source files are generated into this directory.
+     * @param   status
+     *      if non-null, progress indication will be sent to this stream.
+     */
+    public void build( File destDir, PrintStream status ) throws IOException {
+        build(destDir,destDir,status);
+    }
+
+    /**
+     * Generates Java source code.
+     * A convenience method that calls {@link #build(CodeWriter,CodeWriter)}.
+     *
+     * @param   srcDir
+     *          Java source files are generated into this directory.
+     * @param   resourceDir
+     *          Other resource files are generated into this directory.
+     * @param   status
+     *      if non-null, progress indication will be sent to this stream.
+     */
+    public void build( File srcDir, File resourceDir, PrintStream status ) throws IOException {
+        CodeWriter src = new FileCodeWriter(srcDir);
+        CodeWriter res = new FileCodeWriter(resourceDir);
+        if(status!=null) {
+            src = new ProgressCodeWriter(src, status );
+            res = new ProgressCodeWriter(res, status );
+        }
+        build(src,res);
+    }
+
+    /**
+     * A convenience method for <code>build(destDir,System.out)</code>.
+     */
+    public void build( File destDir ) throws IOException {
+        build(destDir,System.out);
+    }
+
+    /**
+     * A convenience method for <code>build(srcDir,resourceDir,System.out)</code>.
+     */
+    public void build( File srcDir, File resourceDir ) throws IOException {
+        build(srcDir,resourceDir,System.out);
+    }
+
+    /**
+     * A convenience method for <code>build(out,out)</code>.
+     */
+    public void build( CodeWriter out ) throws IOException {
+        build(out,out);
+    }
+
+    /**
+     * Generates Java source code.
+     */
+    public void build( CodeWriter source, CodeWriter resource ) throws IOException {
+        JPackage[] pkgs = packages.values().toArray(new JPackage[packages.size()]);
+        // avoid concurrent modification exception
+        for( JPackage pkg : pkgs )
+            pkg.build(source,resource);
+        source.close();
+        resource.close();
+    }
+
+    /**
+     * Returns the number of files to be generated if
+     * {@link #build} is invoked now.
+     */
+    public int countArtifacts() {
+        int r = 0;
+        JPackage[] pkgs = packages.values().toArray(new JPackage[packages.size()]);
+        // avoid concurrent modification exception
+        for( JPackage pkg : pkgs )
+            r += pkg.countArtifacts();
+        return r;
+    }
+
+
+    /**
+     * Obtains a reference to an existing class from its Class object.
+     *
+     * <p>
+     * The parameter may not be primitive.
+     *
+     * @see #_ref(Class) for the version that handles more cases.
+     */
+    public JClass ref(Class clazz) {
+        JReferencedClass jrc = (JReferencedClass)refClasses.get(clazz);
+        if (jrc == null) {
+            if (clazz.isPrimitive())
+                throw new IllegalArgumentException(clazz+" is a primitive");
+            if (clazz.isArray()) {
+                return new JArrayClass(this, _ref(clazz.getComponentType()));
+            } else {
+                jrc = new JReferencedClass(clazz);
+                refClasses.put(clazz, jrc);
+            }
+        }
+        return jrc;
+    }
+
+    public JType _ref(Class c) {
+        if(c.isPrimitive())
+            return JType.parse(this,c.getName());
+        else
+            return ref(c);
+    }
+
+    /**
+     * Obtains a reference to an existing class from its fully-qualified
+     * class name.
+     *
+     * <p>
+     * First, this method attempts to load the class of the given name.
+     * If that fails, we assume that the class is derived straight from
+     * {@link Object}, and return a {@link JClass}.
+     */
+    public JClass ref(String fullyQualifiedClassName) {
+        try {
+            // try the context class loader first
+            return ref(Thread.currentThread().getContextClassLoader().loadClass(fullyQualifiedClassName));
+        } catch (ClassNotFoundException e) {
+            // fall through
+        }
+        // then the default mechanism.
+        try {
+            return ref(Class.forName(fullyQualifiedClassName));
+        } catch (ClassNotFoundException e1) {
+            // fall through
+        }
+
+        // assume it's not visible to us.
+        return new JDirectClass(this,fullyQualifiedClassName);
+    }
+
+    /**
+     * Cached for {@link #wildcard()}.
+     */
+    private JClass wildcard;
+
+    /**
+     * Gets a {@link JClass} representation for "?",
+     * which is equivalent to "? extends Object".
+     */
+    public JClass wildcard() {
+        if(wildcard==null)
+            wildcard = ref(Object.class).wildcard();
+        return wildcard;
+    }
+
+    /**
+     * Obtains a type object from a type name.
+     *
+     * <p>
+     * This method handles primitive types, arrays, and existing {@link Class}es.
+     *
+     * @exception ClassNotFoundException
+     *      If the specified type is not found.
+     */
+    public JType parseType(String name) throws ClassNotFoundException {
+        // array
+        if(name.endsWith("[]"))
+            return parseType(name.substring(0,name.length()-2)).array();
+
+        // try primitive type
+        try {
+            return JType.parse(this,name);
+        } catch (IllegalArgumentException e) {
+            ;
+        }
+
+        // existing class
+        return new TypeNameParser(name).parseTypeName();
+    }
+
+    private final class TypeNameParser {
+        private final String s;
+        private int idx;
+
+        public TypeNameParser(String s) {
+            this.s = s;
+        }
+
+        /**
+         * Parses a type name token T (which can be potentially of the form Tr&ly;T1,T2,...>,
+         * or "? extends/super T".)
+         *
+         * @return the index of the character next to T.
+         */
+        JClass parseTypeName() throws ClassNotFoundException {
+            int start = idx;
+
+            if(s.charAt(idx)=='?') {
+                // wildcard
+                idx++;
+                ws();
+                String head = s.substring(idx);
+                if(head.startsWith("extends")) {
+                    idx+=7;
+                    ws();
+                    return parseTypeName().wildcard();
+                } else
+                if(head.startsWith("super")) {
+                    throw new UnsupportedOperationException("? super T not implemented");
+                } else {
+                    // not supported
+                    throw new IllegalArgumentException("only extends/super can follow ?, but found "+s.substring(idx));
+                }
+            }
+
+            while(idx<s.length()) {
+                char ch = s.charAt(idx);
+                if(Character.isJavaIdentifierStart(ch)
+                || Character.isJavaIdentifierPart(ch)
+                || ch=='.')
+                    idx++;
+                else
+                    break;
+            }
+
+            JClass clazz = ref(s.substring(start,idx));
+
+            if(idx==s.length())
+                return clazz; // hit EOL
+
+            char ch = s.charAt(idx);
+
+            if(ch=='<')
+                return parseArguments(clazz);
+
+            return clazz;
+        }
+
+        /**
+         * Skips whitespaces
+         */
+        private void ws() {
+            while(Character.isWhitespace(s.charAt(idx)) && idx<s.length())
+                idx++;
+        }
+
+        /**
+         * Parses '&lt;T1,T2,...,Tn>'
+         *
+         * @return the index of the character next to '>'
+         */
+        private JClass parseArguments(JClass rawType) throws ClassNotFoundException {
+            if(s.charAt(idx)!='<')
+                throw new IllegalArgumentException();
+            idx++;
+
+            List<JClass> args = new ArrayList<JClass>();
+
+            while(true) {
+                args.add(parseTypeName());
+                if(idx==s.length())
+                    throw new IllegalArgumentException("Missing '>' in "+s);
+                char ch = s.charAt(idx);
+                if(ch=='>')
+                    return rawType.narrow(args.toArray(new JClass[args.size()]));
+
+                if(ch!=',')
+                    throw new IllegalArgumentException(s);
+                idx++;
+            }
+
+        }
+    }
+
+    /**
+     * References to existing classes.
+     *
+     * <p>
+     * JReferencedClass is kept in a pool so that they are shared.
+     * There is one pool for each JCodeModel object.
+     *
+     * <p>
+     * It is impossible to cache JReferencedClass globally only because
+     * there is the _package() method, which obtains the owner JPackage
+     * object, which is scoped to JCodeModel.
+     */
+    private class JReferencedClass extends JClass implements JDeclaration {
+        private final Class _class;
+
+        JReferencedClass(Class _clazz) {
+            super(JCodeModel.this);
+            this._class = _clazz;
+            assert !_class.isArray();
+        }
+
+        public String name() {
+            return _class.getSimpleName().replace('$','.');
+        }
+
+        public String fullName() {
+            return _class.getName().replace('$','.');
+        }
+
+        public String binaryName() {
+            return _class.getName();
+        }
+
+        public JClass outer() {
+            Class p = _class.getDeclaringClass();
+            if(p==null)     return null;
+            return ref(p);
+        }
+
+        public JPackage _package() {
+            String name = fullName();
+
+            // this type is array
+            if (name.indexOf('[') != -1)
+                return JCodeModel.this._package("");
+
+            // other normal case
+            int idx = name.lastIndexOf('.');
+            if (idx < 0)
+                return JCodeModel.this._package("");
+            else
+                return JCodeModel.this._package(name.substring(0, idx));
+        }
+
+        public JClass _extends() {
+            Class sp = _class.getSuperclass();
+            if (sp == null) {
+                if(isInterface())
+                    return owner().ref(Object.class);
+                return null;
+            } else
+                return ref(sp);
+        }
+
+        public Iterator<JClass> _implements() {
+            final Class[] interfaces = _class.getInterfaces();
+            return new Iterator<JClass>() {
+                private int idx = 0;
+                public boolean hasNext() {
+                    return idx < interfaces.length;
+                }
+                public JClass next() {
+                    return JCodeModel.this.ref(interfaces[idx++]);
+                }
+                public void remove() {
+                    throw new UnsupportedOperationException();
+                }
+            };
+        }
+
+        public boolean isInterface() {
+            return _class.isInterface();
+        }
+
+        public boolean isAbstract() {
+            return Modifier.isAbstract(_class.getModifiers());
+        }
+
+        public JPrimitiveType getPrimitiveType() {
+            Class v = boxToPrimitive.get(_class);
+            if(v!=null)
+                return JType.parse(JCodeModel.this,v.getName());
+            else
+                return null;
+        }
+
+        public boolean isArray() {
+            return false;
+        }
+
+        public void declare(JFormatter f) {
+        }
+
+        public JTypeVar[] typeParams() {
+            // TODO: does JDK 1.5 reflection provides these information?
+            return super.typeParams();
+        }
+
+        protected JClass substituteParams(JTypeVar[] variables, List<JClass> bindings) {
+            // TODO: does JDK 1.5 reflection provides these information?
+            return this;
+        }
+    }
+
+    /**
+     * Conversion from primitive type {@link Class} (such as {@link Integer#TYPE}
+     * to its boxed type (such as <tt>Integer.class</tt>)
+     */
+    public static final Map<Class,Class> primitiveToBox;
+    /**
+     * The reverse look up for {@link #primitiveToBox}
+     */
+    public static final Map<Class,Class> boxToPrimitive;
+
+    static {
+        Map<Class,Class> m1 = new HashMap<Class,Class>();
+        Map<Class,Class> m2 = new HashMap<Class,Class>();
+
+        m1.put(Boolean.class,Boolean.TYPE);
+        m1.put(Byte.class,Byte.TYPE);
+        m1.put(Character.class,Character.TYPE);
+        m1.put(Double.class,Double.TYPE);
+        m1.put(Float.class,Float.TYPE);
+        m1.put(Integer.class,Integer.TYPE);
+        m1.put(Long.class,Long.TYPE);
+        m1.put(Short.class,Short.TYPE);
+        m1.put(Void.class,Void.TYPE);
+
+        for (Map.Entry<Class, Class> e : m1.entrySet())
+            m2.put(e.getValue(),e.getKey());
+
+        boxToPrimitive = Collections.unmodifiableMap(m1);
+        primitiveToBox = Collections.unmodifiableMap(m2);
+
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JCommentPart.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JCommentPart.java
new file mode 100644
index 0000000..3001b3c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JCommentPart.java
@@ -0,0 +1,121 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Iterator;
+
+/**
+ * A part is a part of a javadoc comment, and it is a list of values.
+ *
+ * <p>
+ * A part can contain a free-form text. This text is modeled as a collection of 'values'
+ * in this class. A value can be a {@link JType} (which will be prinited with a @link tag),
+ * anything that can be turned into a {@link String} via the {@link Object#toString()} method,
+ * or a {@link Collection}/array of those objects.
+ *
+ * <p>
+ * Values can be added through the various append methods one by one or in a bulk.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class JCommentPart extends ArrayList<Object> {
+    /**
+     * Appends a new value.
+     *
+     * If the value is {@link JType} it will be printed as a @link tag.
+     * Otherwise it will be converted to String via {@link Object#toString()}.
+     */
+    public JCommentPart append(Object o) {
+        add(o);
+        return this;
+    }
+
+    public boolean add(Object o) {
+        flattenAppend(o);
+        return true;
+    }
+
+    private void flattenAppend(Object value) {
+        if(value==null) return;
+        if(value instanceof Object[]) {
+            for( Object o : (Object[])value)
+                flattenAppend(o);
+        } else
+        if(value instanceof Collection) {
+            for( Object o : (Collection)value)
+                flattenAppend(o);
+        } else
+            super.add(value);
+    }
+
+    /**
+     * Writes this part into the formatter by using the specified indentation.
+     */
+    protected void format( JFormatter f, String indent ) {
+        if(!f.isPrinting()) {
+            // quickly pass the types to JFormatter
+            for( Object o : this )
+                if(o instanceof JClass)
+                    f.g((JClass)o);
+            return;
+        }
+
+        if(!isEmpty())
+            f.p(indent);
+
+        Iterator itr = iterator();
+        while(itr.hasNext()) {
+            Object o = itr.next();
+
+            if(o instanceof String) {
+                int idx;
+                String s = (String)o;
+                while( (idx=s.indexOf('\n'))!=-1 ) {
+                    String line = s.substring(0,idx);
+                    if(line.length()>0)
+                        f.p(line);
+                    s = s.substring(idx+1);
+                    f.nl().p(indent);
+                }
+                if(s.length()!=0)
+                    f.p(s);
+            } else
+            if(o instanceof JClass) {
+                // TODO: this doesn't print the parameterized type properly
+                ((JClass)o).printLink(f);
+            } else
+            if(o instanceof JType) {
+                f.g((JType)o);
+            } else
+                throw new IllegalStateException();
+        }
+
+        if(!isEmpty())
+            f.nl();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JConditional.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JConditional.java
new file mode 100644
index 0000000..58534f4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JConditional.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * If statement, with optional else clause
+ */
+
+public class JConditional implements JStatement {
+
+    /**
+     * JExpression to test to determine branching
+     */
+    private JExpression test = null;
+
+    /**
+     * JBlock of statements for "then" clause
+     */
+    private JBlock _then = new JBlock();
+
+    /**
+     * JBlock of statements for optional "else" clause
+     */
+    private JBlock _else = null;
+
+    /**
+     * Constructor
+     *
+     * @param test
+     *        JExpression which will determine branching
+     */
+    JConditional(JExpression test) {
+       this.test = test;
+    }
+
+    /**
+     * Return the block to be excuted by the "then" branch
+     *
+     * @return Then block
+     */
+    public JBlock _then() {
+        return _then;
+    }
+
+    /**
+     * Create a block to be executed by "else" branch
+     *
+     * @return Newly generated else block
+     */
+    public JBlock _else() {
+        if (_else == null) _else = new JBlock();
+        return _else;
+    }
+
+    public void state(JFormatter f) {
+        if(test==JExpr.TRUE) {
+            _then.generateBody(f);
+            return;
+        }
+        if(test==JExpr.FALSE) {
+            _else.generateBody(f);
+            return;
+        }
+
+        if (JOp.hasTopOp(test)) {
+            f.p("if ").g(test);
+        } else {
+            f.p("if (").g(test).p(')');
+        }
+        f.g(_then);
+        if (_else != null)
+            f.p("else").g(_else);
+        f.nl();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JContinue.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JContinue.java
new file mode 100644
index 0000000..bc49f81
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JContinue.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * JContinue statement
+ */
+class JContinue implements JStatement {
+
+    private final JLabel label;
+
+    /**
+     * JContinue constructor.
+     *
+     * @param _label
+     *      a valid label or null.
+     */
+    JContinue(JLabel _label) {
+        this.label = _label;
+    }
+
+    public void state(JFormatter f) {
+        if( label==null )
+            f.p("continue;").nl();
+        else
+            f.p("continue").p(label.label).p(';').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JDeclaration.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JDeclaration.java
new file mode 100644
index 0000000..79ddbe1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JDeclaration.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Common interface for code components that can generate declarations
+ * of themselves.
+ */
+
+public interface JDeclaration {
+
+    public void declare(JFormatter f);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JDefinedClass.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JDefinedClass.java
new file mode 100644
index 0000000..b95e415
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JDefinedClass.java
@@ -0,0 +1,866 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.lang.annotation.Annotation;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.Iterator;
+import java.util.LinkedHashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeMap;
+import java.util.TreeSet;
+
+/**
+ * A generated Java class/interface/enum/....
+ *
+ * <p>
+ * This class models a declaration, and since a declaration can be always
+ * used as a reference, it inherits {@link JClass}.
+ *
+ * <h2>Where to go from here?</h2>
+ * <p>
+ * You'd want to generate fields and methods on a class.
+ * See {@link #method(int, JType, String)} and {@link #field(int, JType, String)}.
+ */
+public class JDefinedClass
+    extends JClass
+    implements JDeclaration, JClassContainer, JGenerifiable, JAnnotatable {
+
+    /** Name of this class. Null if anonymous. */
+    private String name = null;
+
+
+    /** Modifiers for the class declaration */
+    private JMods mods;
+
+    /** Name of the super class of this class. */
+    private JClass superClass;
+
+    /** List of interfaces that this class implements */
+    private final Set<JClass> interfaces = new TreeSet<JClass>();
+
+    /** Fields keyed by their names. */
+    /*package*/ final Map<String,JFieldVar> fields = new LinkedHashMap<String,JFieldVar>();
+
+    /** Static initializer, if this class has one */
+    private JBlock init = null;
+
+    /** class javadoc */
+    private JDocComment jdoc = null;
+
+    /** Set of constructors for this class, if any */
+    private final List<JMethod> constructors = new ArrayList<JMethod>();
+
+    /** Set of methods that are members of this class */
+    private final List<JMethod> methods = new ArrayList<JMethod>();
+
+    /**
+     * Nested classes as a map from name to JDefinedClass.
+     * The name is all capitalized in a case sensitive file system
+     * ({@link JCodeModel#isCaseSensitiveFileSystem}) to avoid conflicts.
+     *
+     * Lazily created to save footprint.
+     *
+     * @see #getClasses()
+     */
+    private Map<String,JDefinedClass> classes;
+
+
+    /**
+     * Flag that controls whether this class should be really generated or not.
+     *
+     * Sometimes it is useful to generate code that refers to class X,
+     * without actually generating the code of X.
+     * This flag is used to surpress X.java file in the output.
+     */
+    private boolean hideFile = false;
+
+    /**
+     * Client-app spcific metadata associated with this user-created class.
+     */
+    public Object metadata;
+
+    /**
+     * String that will be put directly inside the generated code.
+     * Can be null.
+     */
+    private String directBlock;
+
+    /**
+     * If this is a package-member class, this is {@link JPackage}.
+     * If this is a nested class, this is {@link JDefinedClass}.
+     * If this is an anonymous class, this constructor shouldn't be used.
+     */
+    private JClassContainer outer = null;
+
+
+    /** Default value is class or interface
+     *  or annotationTypeDeclaration
+     *  or enum
+     *
+     */
+    private final ClassType classType;
+
+    /** List containing the enum value declarations
+     *
+     */
+//    private List enumValues = new ArrayList();
+
+    /**
+     * Set of enum constants that are keyed by names.
+     * In Java, enum constant order is actually significant,
+     * because of order ID they get. So let's preserve the order.
+     */
+    private final Map<String,JEnumConstant> enumConstantsByName = new LinkedHashMap<String,JEnumConstant>();
+
+    /**
+     * Annotations on this variable. Lazily created.
+     */
+    private List<JAnnotationUse> annotations = null;
+
+
+    /**
+     * Helper class to implement {@link JGenerifiable}.
+     */
+    private final JGenerifiableImpl generifiable = new JGenerifiableImpl() {
+        protected JCodeModel owner() {
+            return JDefinedClass.this.owner();
+        }
+    };
+
+    JDefinedClass(JClassContainer parent, int mods, String name, ClassType classTypeval) {
+        this(mods, name, parent, parent.owner(), classTypeval);
+    }
+
+    /**
+     * Constructor for creating anonymous inner class.
+     */
+    JDefinedClass(
+        JCodeModel owner,
+        int mods,
+        String name) {
+        this(mods, name, null, owner);
+    }
+
+    private JDefinedClass(
+            int mods,
+            String name,
+            JClassContainer parent,
+            JCodeModel owner) {
+        this (mods,name,parent,owner,ClassType.CLASS);
+    }
+
+    /**
+     * JClass constructor
+     *
+     * @param mods
+     *        Modifiers for this class declaration
+     *
+     * @param name
+     *        Name of this class
+     */
+    private JDefinedClass(
+        int mods,
+        String name,
+        JClassContainer parent,
+        JCodeModel owner,
+                ClassType classTypeVal) {
+        super(owner);
+
+        if(name!=null) {
+            if (name.trim().length() == 0)
+                throw new IllegalArgumentException("JClass name empty");
+
+            if (!Character.isJavaIdentifierStart(name.charAt(0))) {
+                String msg =
+                    "JClass name "
+                        + name
+                        + " contains illegal character"
+                        + " for beginning of identifier: "
+                        + name.charAt(0);
+                throw new IllegalArgumentException(msg);
+            }
+            for (int i = 1; i < name.length(); i++) {
+                if (!Character.isJavaIdentifierPart(name.charAt(i))) {
+                    String msg =
+                        "JClass name "
+                            + name
+                            + " contains illegal character "
+                            + name.charAt(i);
+                    throw new IllegalArgumentException(msg);
+                }
+            }
+        }
+
+        this.classType = classTypeVal;
+        if (isInterface())
+            this.mods = JMods.forInterface(mods);
+        else
+            this.mods = JMods.forClass(mods);
+
+        this.name = name;
+
+        this.outer = parent;
+    }
+
+    /**
+     * Returns true if this is an anonymous class.
+     */
+    public final boolean isAnonymous() {
+        return name == null;
+    }
+
+    /**
+     * This class extends the specifed class.
+     *
+     * @param superClass
+     *        Superclass for this class
+     *
+     * @return This class
+     */
+    public JDefinedClass _extends(JClass superClass) {
+        if (this.classType==ClassType.INTERFACE)
+            throw new IllegalArgumentException("unable to set the super class for an interface");
+        if (superClass == null)
+            throw new NullPointerException();
+
+        this.superClass = superClass;
+        return this;
+    }
+
+    public JDefinedClass _extends(Class superClass) {
+        return _extends(owner().ref(superClass));
+    }
+
+    /**
+     * Returns the class extended by this class.
+     */
+    public JClass _extends() {
+        if(superClass==null)
+            superClass = owner().ref(Object.class);
+        return superClass;
+    }
+
+    /**
+     * This class implements the specifed interface.
+     *
+     * @param iface
+     *        Interface that this class implements
+     *
+     * @return This class
+     */
+    public JDefinedClass _implements(JClass iface) {
+        interfaces.add(iface);
+        return this;
+    }
+
+    public JDefinedClass _implements(Class iface) {
+        return _implements(owner().ref(iface));
+    }
+
+    /**
+     * Returns an iterator that walks the nested classes defined in this
+     * class.
+     */
+    public Iterator<JClass> _implements() {
+        return interfaces.iterator();
+    }
+
+    /**
+     * JClass name accessor.
+     *
+     * <p>
+     * For example, for <code>java.util.List</code>, this method
+     * returns <code>"List"</code>"
+     *
+     * @return Name of this class
+     */
+    public String name() {
+        return name;
+    }
+
+    /**
+     * This method generates reference to the JEnumConstant in
+     * the class
+     *
+     * @param name
+     *          The name of the constant.
+     * @return
+     *      The generated type-safe enum constant.
+     */
+    public JEnumConstant enumConstant(String name){
+        JEnumConstant ec = new JEnumConstant(this, name);
+        enumConstantsByName.put(name, ec);
+        return ec;
+    }
+
+    /**
+     * Gets the fully qualified name of this class.
+     */
+    public String fullName() {
+        if (outer instanceof JDefinedClass)
+            return ((JDefinedClass) outer).fullName() + '.' + name();
+
+        JPackage p = _package();
+        if (p.isUnnamed())
+            return name();
+        else
+            return p.name() + '.' + name();
+    }
+
+    public String binaryName() {
+        if (outer instanceof JDefinedClass)
+            return ((JDefinedClass) outer).binaryName() + '$' + name();
+        else
+            return fullName();
+    }
+
+    public boolean isInterface() {
+        return this.classType==ClassType.INTERFACE;
+    }
+
+    public boolean isAbstract() {
+        return mods.isAbstract();
+    }
+
+    /**
+     * Adds a field to the list of field members of this JDefinedClass.
+     *
+     * @param mods
+     *        Modifiers for this field
+     *
+     * @param type
+     *        JType of this field
+     *
+     * @param name
+     *        Name of this field
+     *
+     * @return Newly generated field
+     */
+    public JFieldVar field(int mods, JType type, String name) {
+        return field(mods, type, name, null);
+    }
+
+    public JFieldVar field(int mods, Class type, String name) {
+        return field(mods, owner()._ref(type), name);
+    }
+
+    /**
+     * Adds a field to the list of field members of this JDefinedClass.
+     *
+     * @param mods
+     *        Modifiers for this field.
+     * @param type
+     *        JType of this field.
+     * @param name
+     *        Name of this field.
+     * @param init
+     *        Initial value of this field.
+     *
+     * @return Newly generated field
+     */
+    public JFieldVar field(
+        int mods,
+        JType type,
+        String name,
+        JExpression init) {
+        JFieldVar f = new JFieldVar(this,JMods.forField(mods), type, name, init);
+
+        if(fields.put(name, f)!=null)
+            throw new IllegalArgumentException("trying to create the same field twice: "+name);
+
+        return f;
+    }
+
+    /**  This method indicates if the interface
+     *   is an annotationTypeDeclaration
+     *
+     */
+    public boolean isAnnotationTypeDeclaration() {
+        return this.classType==ClassType.ANNOTATION_TYPE_DECL;
+
+
+    }
+
+    /**
+     * Add an annotationType Declaration to this package
+     * @param name
+     *      Name of the annotation Type declaration to be added to this package
+     * @return
+     *      newly created Annotation Type Declaration
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+
+     */
+    public JDefinedClass _annotationTypeDeclaration(String name) throws JClassAlreadyExistsException {
+        return _class (JMod.PUBLIC,name,ClassType.ANNOTATION_TYPE_DECL);
+    }
+
+    /**
+     * Add a public enum to this package
+     * @param name
+     *      Name of the enum to be added to this package
+     * @return
+     *      newly created Enum
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+
+     */
+    public JDefinedClass _enum (String name) throws JClassAlreadyExistsException {
+        return _class (JMod.PUBLIC,name,ClassType.ENUM);
+    }
+
+    /**
+     * Add a public enum to this package
+     * @param name
+     *      Name of the enum to be added to this package
+     * @param mods
+     *          Modifiers for this enum declaration
+     * @return
+     *      newly created Enum
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+
+     */
+    public JDefinedClass _enum (int mods,String name) throws JClassAlreadyExistsException {
+        return _class (mods,name,ClassType.ENUM);
+    }
+
+
+
+
+
+    public ClassType getClassType(){
+        return this.classType;
+    }
+
+    public JFieldVar field(
+        int mods,
+        Class type,
+        String name,
+        JExpression init) {
+        return field(mods, owner()._ref(type), name, init);
+    }
+
+    /**
+     * Returns all the fields declred in this class.
+     * The returned {@link Map} is a read-only live view.
+     *
+     * @return always non-null.
+     */
+    public Map<String,JFieldVar> fields() {
+        return Collections.unmodifiableMap(fields);
+    }
+
+    /**
+     * Removes a {@link JFieldVar} from this class.
+     *
+     * @throws IllegalArgumentException
+     *      if the given field is not a field on this class.
+     */
+    public void removeField(JFieldVar field) {
+        if(fields.remove(field.name())!=field)
+            throw new IllegalArgumentException();
+    }
+
+    /**
+     * Creates, if necessary, and returns the static initializer
+     * for this class.
+     *
+     * @return JBlock containing initialization statements for this class
+     */
+    public JBlock init() {
+        if (init == null)
+            init = new JBlock();
+        return init;
+    }
+
+    /**
+     * Adds a constructor to this class.
+     *
+     * @param mods
+     *        Modifiers for this constructor
+     */
+    public JMethod constructor(int mods) {
+        JMethod c = new JMethod(mods, this);
+        constructors.add(c);
+        return c;
+    }
+
+    /**
+     * Returns an iterator that walks the constructors defined in this class.
+     */
+    public Iterator constructors() {
+        return constructors.iterator();
+    }
+
+    /**
+     * Looks for a method that has the specified method signature
+     * and return it.
+     *
+     * @return
+     *      null if not found.
+     */
+    public JMethod getConstructor(JType[] argTypes) {
+        for (JMethod m : constructors) {
+            if (m.hasSignature(argTypes))
+                return m;
+        }
+        return null;
+    }
+
+    /**
+     * Add a method to the list of method members of this JDefinedClass instance.
+     *
+     * @param mods
+     *        Modifiers for this method
+     *
+     * @param type
+     *        Return type for this method
+     *
+     * @param name
+     *        Name of the method
+     *
+     * @return Newly generated JMethod
+     */
+    public JMethod method(int mods, JType type, String name) {
+        // XXX problems caught in M constructor
+        JMethod m = new JMethod(this, mods, type, name);
+        methods.add(m);
+        return m;
+    }
+
+    public JMethod method(int mods, Class type, String name) {
+        return method(mods, owner()._ref(type), name);
+    }
+
+    /**
+     * Returns the set of methods defined in this class.
+     */
+    public Collection<JMethod> methods() {
+        return methods;
+    }
+
+    /**
+     * Looks for a method that has the specified method signature
+     * and return it.
+     *
+     * @return
+     *      null if not found.
+     */
+    public JMethod getMethod(String name, JType[] argTypes) {
+        outer :
+        for (JMethod m : methods) {
+            if (!m.name().equals(name))
+                continue;
+
+            if (m.hasSignature(argTypes))
+                return m;
+        }
+        return null;
+    }
+
+    public boolean isClass() {
+        return true;
+    }
+    public boolean isPackage() {
+        return false;
+    }
+    public JPackage getPackage() { return parentContainer().getPackage(); }
+
+    /**
+     * Add a new nested class to this class.
+     *
+     * @param mods
+     *        Modifiers for this class declaration
+     *
+     * @param name
+     *        Name of class to be added to this package
+     *
+     * @return Newly generated class
+     */
+    public JDefinedClass _class(int mods, String name)
+        throws JClassAlreadyExistsException {
+        return _class(mods, name, ClassType.CLASS);
+    }
+
+    /**
+     * {@inheritDoc}
+     *
+     * @deprecated
+     */
+    public JDefinedClass _class(int mods, String name, boolean isInterface) throws JClassAlreadyExistsException {
+        return _class(mods,name,isInterface?ClassType.INTERFACE:ClassType.CLASS);
+    }
+
+    public JDefinedClass _class(int mods, String name, ClassType classTypeVal)
+        throws JClassAlreadyExistsException {
+
+        String NAME;
+        if (JCodeModel.isCaseSensitiveFileSystem)
+            NAME = name.toUpperCase();
+        else
+            NAME = name;
+
+        if (getClasses().containsKey(NAME))
+            throw new JClassAlreadyExistsException(getClasses().get(NAME));
+        else {
+            // XXX problems caught in the NC constructor
+            JDefinedClass c = new JDefinedClass(this, mods, name, classTypeVal);
+            getClasses().put(NAME,c);
+            return c;
+        }
+    }
+
+    /**
+     * Add a new public nested class to this class.
+     */
+    public JDefinedClass _class(String name)
+        throws JClassAlreadyExistsException {
+        return _class(JMod.PUBLIC, name);
+    }
+
+    /**
+     * Add an interface to this package.
+     *
+     * @param mods
+     *        Modifiers for this interface declaration
+     *
+     * @param name
+     *        Name of interface to be added to this package
+     *
+     * @return Newly generated interface
+     */
+    public JDefinedClass _interface(int mods, String name)
+        throws JClassAlreadyExistsException {
+        return _class(mods, name, ClassType.INTERFACE);
+    }
+
+    /**
+     * Adds a public interface to this package.
+     */
+    public JDefinedClass _interface(String name)
+        throws JClassAlreadyExistsException {
+        return _interface(JMod.PUBLIC, name);
+    }
+
+    /**
+     * Creates, if necessary, and returns the class javadoc for this
+     * JDefinedClass
+     *
+     * @return JDocComment containing javadocs for this class
+     */
+    public JDocComment javadoc() {
+        if (jdoc == null)
+            jdoc = new JDocComment(owner());
+        return jdoc;
+    }
+
+    /**
+     * Mark this file as hidden, so that this file won't be
+     * generated.
+     *
+     * <p>
+     * This feature could be used to generate code that refers
+     * to class X, without actually generating X.java.
+     */
+    public void hide() {
+        hideFile = true;
+    }
+
+    public boolean isHidden() {
+        return hideFile;
+    }
+
+    /**
+     * Returns an iterator that walks the nested classes defined in this
+     * class.
+     */
+    public final Iterator<JDefinedClass> classes() {
+        if(classes==null)
+            return Collections.<JDefinedClass>emptyList().iterator();
+        else
+            return classes.values().iterator();
+    }
+
+    private Map<String,JDefinedClass> getClasses() {
+        if(classes==null)
+            classes = new TreeMap<String,JDefinedClass>();
+        return classes;
+    }
+
+
+    /**
+     * Returns all the nested classes defined in this class.
+     */
+    public final JClass[] listClasses() {
+        if(classes==null)
+            return new JClass[0];
+        else
+            return classes.values().toArray(new JClass[classes.values().size()]);
+    }
+
+    @Override
+    public JClass outer() {
+        if (outer.isClass())
+            return (JClass) outer;
+        else
+            return null;
+    }
+
+    public void declare(JFormatter f) {
+        if (jdoc != null)
+            f.nl().g(jdoc);
+
+        if (annotations != null){
+            for( int i=0; i<annotations.size(); i++ )
+                f.g(annotations.get(i)).nl();
+        }
+
+        f.g(mods).p(classType.declarationToken).id(name).d(generifiable);
+
+        if (superClass != null && superClass != owner().ref(Object.class))
+            f.nl().i().p("extends").g(superClass).nl().o();
+
+        if (!interfaces.isEmpty()) {
+            if (superClass == null)
+                f.nl();
+            f.i().p(classType==ClassType.INTERFACE ? "extends" : "implements");
+            f.g(interfaces);
+            f.nl().o();
+        }
+        declareBody(f);
+    }
+
+    /**
+     * prints the body of a class.
+     */
+    protected void declareBody(JFormatter f) {
+        f.p('{').nl().nl().i();
+        boolean first = true;
+
+        if (!enumConstantsByName.isEmpty()) {
+            for (JEnumConstant c : enumConstantsByName.values()) {
+                if (!first) f.p(',').nl();
+                f.d(c);
+                first = false;
+            }
+                f.p(';').nl();
+        }
+
+        for( JFieldVar field : fields.values() )
+            f.d(field);
+        if (init != null)
+            f.nl().p("static").s(init);
+        for (JMethod m : constructors) {
+            f.nl().d(m);
+        }
+        for (JMethod m : methods) {
+            f.nl().d(m);
+        }
+        if(classes!=null)
+            for (JDefinedClass dc : classes.values())
+                f.nl().d(dc);
+
+
+        if (directBlock != null)
+            f.p(directBlock);
+        f.nl().o().p('}').nl();
+    }
+
+    /**
+     * Places the given string directly inside the generated class.
+     *
+     * This method can be used to add methods/fields that are not
+     * generated by CodeModel.
+     * This method should be used only as the last resort.
+     */
+    public void direct(String string) {
+        if (directBlock == null)
+            directBlock = string;
+        else
+            directBlock += string;
+    }
+
+    public final JPackage _package() {
+        JClassContainer p = outer;
+        while (!(p instanceof JPackage))
+            p = p.parentContainer();
+        return (JPackage) p;
+    }
+
+    public final JClassContainer parentContainer() {
+        return outer;
+    }
+
+    public JTypeVar generify(String name) {
+        return generifiable.generify(name);
+    }
+    public JTypeVar generify(String name, Class bound) {
+        return generifiable.generify(name, bound);
+    }
+    public JTypeVar generify(String name, JClass bound) {
+        return generifiable.generify(name, bound);
+    }
+    @Override
+    public JTypeVar[] typeParams() {
+        return generifiable.typeParams();
+    }
+
+    protected JClass substituteParams(
+        JTypeVar[] variables,
+        List<JClass> bindings) {
+        return this;
+    }
+
+    /** Adding ability to annotate a class
+     * @param clazz
+     *          The annotation class to annotate the class with
+     */
+    public JAnnotationUse annotate(Class <? extends Annotation> clazz){
+        return annotate(owner().ref(clazz));
+    }
+
+    /** Adding ability to annotate a class
+      * @param clazz
+      *          The annotation class to annotate the class with
+      */
+     public JAnnotationUse annotate(JClass clazz){
+        if(annotations==null)
+           annotations = new ArrayList<JAnnotationUse>();
+        JAnnotationUse a = new JAnnotationUse(clazz);
+        annotations.add(a);
+        return a;
+    }
+
+    public <W extends JAnnotationWriter> W annotate2(Class<W> clazz) {
+        return TypedAnnotationWriter.create(clazz,this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JDirectClass.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JDirectClass.java
new file mode 100644
index 0000000..0a355e4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JDirectClass.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.Iterator;
+import java.util.List;
+import java.util.Collections;
+
+/**
+ * A special {@link JClass} that represents an unknown class (except its name.)
+ *
+ * @author Kohsuke Kawaguchi
+ * @see JCodeModel#directClass(String)
+ */
+final class JDirectClass extends JClass {
+
+    private final String fullName;
+
+    public JDirectClass(JCodeModel _owner,String fullName) {
+        super(_owner);
+        this.fullName = fullName;
+    }
+
+    public String name() {
+        int i = fullName.lastIndexOf('.');
+        if(i>=0)    return fullName.substring(i+1);
+        return fullName;
+    }
+
+    public String fullName() {
+        return fullName;
+    }
+
+    public JPackage _package() {
+        int i = fullName.lastIndexOf('.');
+        if(i>=0)    return owner()._package(fullName.substring(0,i));
+        else        return owner().rootPackage();
+    }
+
+    public JClass _extends() {
+        return owner().ref(Object.class);
+    }
+
+    public Iterator<JClass> _implements() {
+        return Collections.<JClass>emptyList().iterator();
+    }
+
+    public boolean isInterface() {
+        return false;
+    }
+
+    public boolean isAbstract() {
+        return false;
+    }
+
+    protected JClass substituteParams(JTypeVar[] variables, List<JClass> bindings) {
+        return this;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JDoLoop.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JDoLoop.java
new file mode 100644
index 0000000..a7ce4a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JDoLoop.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Do loops
+ */
+
+public class JDoLoop implements JStatement {
+
+    /**
+     * Test part of Do statement for determining exit state
+     */
+    private JExpression test;
+
+    /**
+     * JBlock of statements which makes up body of this Do statement
+     */
+    private JBlock body = null;
+
+    /**
+     * Construct a Do statment
+     */
+    JDoLoop(JExpression test) {
+        this.test = test;
+    }
+
+    public JBlock body() {
+        if (body == null) body = new JBlock();
+        return body;
+    }
+
+    public void state(JFormatter f) {
+        f.p("do");
+        if (body != null)
+            f.g(body);
+        else
+            f.p("{ }");
+
+        if (JOp.hasTopOp(test)) {
+            f.p("while ").g(test);
+        } else {
+            f.p("while (").g(test).p(')');
+        }
+        f.p(';').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JDocComment.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JDocComment.java
new file mode 100644
index 0000000..2bca54e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JDocComment.java
@@ -0,0 +1,196 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * JavaDoc comment.
+ *
+ * <p>
+ * A javadoc comment consists of multiple parts. There's the main part (that comes the first in
+ * in the comment section), then the parameter parts (@param), the return part (@return),
+ * and the throws parts (@throws).
+ *
+ * TODO: it would be nice if we have JComment class and we can derive this class from there.
+ */
+public class JDocComment extends JCommentPart implements JGenerable {
+
+
+    /** list of @param tags */
+    private final Map<String,JCommentPart> atParams = new HashMap<String,JCommentPart>();
+
+    /** list of xdoclets */
+    private final Map<String,Map<String,String>> atXdoclets = new HashMap<String,Map<String,String>>();
+
+    /** list of @throws tags */
+    private final Map<JClass,JCommentPart> atThrows = new HashMap<JClass,JCommentPart>();
+
+    /**
+     * The @return tag part.
+     */
+    private JCommentPart atReturn = null;
+
+    /** The @deprecated tag */
+    private JCommentPart atDeprecated = null;
+
+    private final JCodeModel owner;
+
+
+    public JDocComment(JCodeModel owner) {
+        this.owner = owner;
+    }
+
+    public JDocComment append(Object o) {
+        add(o);
+        return this;
+    }
+
+    /**
+     * Append a text to a @param tag to the javadoc
+     */
+    public JCommentPart addParam( String param ) {
+        JCommentPart p = atParams.get(param);
+        if(p==null)
+            atParams.put(param,p=new JCommentPart());
+        return p;
+    }
+
+    /**
+     * Append a text to an @param tag.
+     */
+    public JCommentPart addParam( JVar param ) {
+        return addParam( param.name() );
+    }
+
+
+    /**
+     * add an @throws tag to the javadoc
+     */
+    public JCommentPart addThrows( Class exception ) {
+        return addThrows( owner.ref(exception) );
+    }
+
+    /**
+     * add an @throws tag to the javadoc
+     */
+    public JCommentPart addThrows( JClass exception ) {
+        JCommentPart p = atThrows.get(exception);
+        if(p==null)
+            atThrows.put(exception,p=new JCommentPart());
+        return p;
+    }
+
+    /**
+     * Appends a text to @return tag.
+     */
+    public JCommentPart addReturn() {
+        if(atReturn==null)
+            atReturn = new JCommentPart();
+        return atReturn;
+    }
+
+    /**
+     * add an @deprecated tag to the javadoc, with the associated message.
+     */
+    public JCommentPart addDeprecated() {
+        if(atDeprecated==null)
+            atDeprecated = new JCommentPart();
+        return atDeprecated;
+    }
+
+    /**
+     * add an xdoclet.
+     */
+    public Map<String,String> addXdoclet(String name) {
+        Map<String,String> p = atXdoclets.get(name);
+        if(p==null)
+            atXdoclets.put(name,p=new HashMap<String,String>());
+        return p;
+    }
+
+    /**
+     * add an xdoclet.
+     */
+    public Map<String,String> addXdoclet(String name, Map<String,String> attributes) {
+        Map<String,String> p = atXdoclets.get(name);
+        if(p==null)
+            atXdoclets.put(name,p=new HashMap<String,String>());
+        p.putAll(attributes);
+        return p;
+    }
+
+    /**
+     * add an xdoclet.
+     */
+    public Map<String,String> addXdoclet(String name, String attribute, String value) {
+        Map<String,String> p = atXdoclets.get(name);
+        if(p==null)
+            atXdoclets.put(name,p=new HashMap<String,String>());
+        p.put(attribute, value);
+        return p;
+    }
+
+    public void generate(JFormatter f) {
+        // I realized that we can't use StringTokenizer because
+        // this will recognize multiple \n as one token.
+
+        f.p("/**").nl();
+
+        format(f," * ");
+
+        f.p(" * ").nl();
+        for (Map.Entry<String,JCommentPart> e : atParams.entrySet()) {
+            f.p(" * @param ").p(e.getKey()).nl();
+            e.getValue().format(f,INDENT);
+        }
+        if( atReturn != null ) {
+            f.p(" * @return").nl();
+            atReturn.format(f,INDENT);
+        }
+        for (Map.Entry<JClass,JCommentPart> e : atThrows.entrySet()) {
+            f.p(" * @throws ").t(e.getKey()).nl();
+            e.getValue().format(f,INDENT);
+        }
+        if( atDeprecated != null ) {
+            f.p(" * @deprecated").nl();
+            atDeprecated.format(f,INDENT);
+        }
+        for (Map.Entry<String,Map<String,String>> e : atXdoclets.entrySet()) {
+            f.p(" * @").p(e.getKey());
+            if (e.getValue() != null) {
+                for (Map.Entry<String,String> a : e.getValue().entrySet()) {
+                    f.p(" ").p(a.getKey()).p("= \"").p(a.getValue()).p("\"");
+                }
+            }
+            f.nl();
+        }
+        f.p(" */").nl();
+    }
+
+    private static final String INDENT = " *     ";
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JEnumConstant.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JEnumConstant.java
new file mode 100644
index 0000000..63dde62
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JEnumConstant.java
@@ -0,0 +1,149 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.lang.annotation.Annotation;
+
+/**
+ * Enum Constant.
+ *
+ * When used as an {@link JExpression}, this object represents a reference to the enum constant.
+ *
+ * @author
+ *     Bhakti Mehta (Bhakti.Mehta@sun.com)
+ */
+public final class JEnumConstant extends JExpressionImpl implements JDeclaration, JAnnotatable {
+
+    /**
+     * The constant.
+     */
+    private final String name;
+    /**
+     * The enum class.
+     */
+    private final JDefinedClass type;
+    /**
+     * javadoc comments, if any.
+     */
+    private JDocComment jdoc = null;
+
+    /**
+     * Annotations on this variable. Lazily created.
+     */
+    private List<JAnnotationUse> annotations = null;
+
+
+    /**
+     * List of the constructor argument expressions.
+     * Lazily constructed.
+     */
+    private List<JExpression> args = null;
+
+    JEnumConstant(JDefinedClass type,String name) {
+        this.name = name;
+        this.type = type;
+    }
+
+    /**
+     *  Add an expression to this constructor's argument list
+     *
+     * @param arg
+     *        Argument to add to argument list
+     */
+    public JEnumConstant arg(JExpression arg) {
+        if(arg==null)   throw new IllegalArgumentException();
+        if(args==null)
+            args = new ArrayList<JExpression>();
+        args.add(arg);
+        return this;
+    }
+
+    /**
+     * Returns the name of this constant.
+     *
+     * @return never null.
+     */
+    public String getName() {
+        return this.type.fullName().concat(".").concat(this.name);
+    }
+
+    /**
+     * Creates, if necessary, and returns the enum constant javadoc.
+     *
+     * @return JDocComment containing javadocs for this constant.
+     */
+    public JDocComment javadoc() {
+        if (jdoc == null)
+            jdoc = new JDocComment(type.owner());
+        return jdoc;
+    }
+
+    /**
+     * Adds an annotation to this variable.
+     * @param clazz
+     *          The annotation class to annotate the field with
+     */
+    public JAnnotationUse annotate(JClass clazz){
+        if(annotations==null)
+           annotations = new ArrayList<JAnnotationUse>();
+        JAnnotationUse a = new JAnnotationUse(clazz);
+        annotations.add(a);
+        return a;
+    }
+
+    /**
+     * Adds an annotation to this variable.
+     *
+     * @param clazz
+     *          The annotation class to annotate the field with
+     */
+    public JAnnotationUse annotate(Class <? extends Annotation> clazz){
+        return annotate(type.owner().ref(clazz));
+    }
+
+    public <W extends JAnnotationWriter> W annotate2(Class<W> clazz) {
+        return TypedAnnotationWriter.create(clazz,this);
+    }
+
+    public void declare(JFormatter f) {
+        if( jdoc != null )
+            f.nl().g( jdoc );
+        if (annotations != null) {
+            for( int i=0; i<annotations.size(); i++ )
+                f.g(annotations.get(i)).nl();
+        }
+        f.id(name);
+        if(args!=null) {
+            f.p('(').g(args).p(')');
+        }
+    }
+
+    public void generate(JFormatter f) {
+        f.t(type).p('.').p(name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JExpr.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JExpr.java
new file mode 100644
index 0000000..4ae2f99
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JExpr.java
@@ -0,0 +1,255 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Factory methods that generate various {@link JExpression}s.
+ */
+public abstract class JExpr {
+
+    /**
+     * This class is not instanciable.
+     */
+    private JExpr() { }
+
+    public static JExpression assign(JAssignmentTarget lhs, JExpression rhs) {
+        return new JAssignment(lhs, rhs);
+    }
+
+    public static JExpression assignPlus(JAssignmentTarget lhs, JExpression rhs) {
+        return new JAssignment(lhs, rhs, "+");
+    }
+
+    public static JInvocation _new(JClass c) {
+        return new JInvocation(c);
+    }
+
+    public static JInvocation _new(JType t) {
+        return new JInvocation(t);
+    }
+
+    public static JInvocation invoke(String method) {
+        return new JInvocation((JExpression)null, method);
+    }
+
+    public static JInvocation invoke(JMethod method) {
+        return new JInvocation((JExpression)null,method.name());
+    }
+
+    public static JInvocation invoke(JExpression lhs, JMethod method) {
+        return new JInvocation(lhs, method.name());
+    }
+
+    public static JInvocation invoke(JExpression lhs, String method) {
+        return new JInvocation(lhs, method);
+    }
+
+    public static JFieldRef ref(String field) {
+        return new JFieldRef((JExpression)null, field);
+    }
+
+    public static JFieldRef ref(JExpression lhs, JVar field) {
+        return new JFieldRef(lhs,field);
+    }
+
+    public static JFieldRef ref(JExpression lhs, String field) {
+        return new JFieldRef(lhs, field);
+    }
+
+    public static JFieldRef refthis(String field) {
+         return new JFieldRef(null, field, true);
+    }
+
+    public static JExpression dotclass(final JClass cl) {
+        return new JExpressionImpl() {
+                public void generate(JFormatter f) {
+                    JClass c;
+                    if(cl instanceof JNarrowedClass)
+                        c = ((JNarrowedClass)cl).basis;
+                    else
+                        c = cl;
+                    f.g(c).p(".class");
+                }
+            };
+    }
+
+    public static JArrayCompRef component(JExpression lhs, JExpression index) {
+        return new JArrayCompRef(lhs, index);
+    }
+
+    public static JCast cast(JType type, JExpression expr) {
+        return new JCast(type, expr);
+    }
+
+    public static JArray newArray(JType type) {
+        return newArray(type,null);
+    }
+
+    /**
+     * Generates {@code new T[size]}.
+     *
+     * @param type
+     *      The type of the array component. 'T' or {@code new T[size]}.
+     */
+    public static JArray newArray(JType type, JExpression size) {
+        // you cannot create an array whose component type is a generic
+        return new JArray(type.erasure(), size);
+    }
+
+    /**
+     * Generates {@code new T[size]}.
+     *
+     * @param type
+     *      The type of the array component. 'T' or {@code new T[size]}.
+     */
+    public static JArray newArray(JType type, int size) {
+        return newArray(type,lit(size));
+    }
+
+
+    private static final JExpression __this = new JAtom("this");
+    /**
+     * Returns a reference to "this", an implicit reference
+     * to the current object.
+     */
+    public static JExpression _this() { return __this; }
+
+    private static final JExpression __super = new JAtom("super");
+    /**
+     * Returns a reference to "super", an implicit reference
+     * to the super class.
+     */
+    public static JExpression _super() { return __super; }
+
+
+    /* -- Literals -- */
+
+    private static final JExpression __null = new JAtom("null");
+    public static JExpression _null() {
+        return __null;
+    }
+
+    /**
+     * Boolean constant that represents <code>true</code>
+     */
+    public static final JExpression TRUE = new JAtom("true");
+
+    /**
+     * Boolean constant that represents <code>false</code>
+     */
+    public static final JExpression FALSE = new JAtom("false");
+
+    public static JExpression lit(boolean b) {
+        return b?TRUE:FALSE;
+    }
+
+    public static JExpression lit(int n) {
+        return new JAtom(Integer.toString(n));
+    }
+
+    public static JExpression lit(long n) {
+        return new JAtom(Long.toString(n) + "L");
+    }
+
+    public static JExpression lit(float f) {
+        return new JAtom(Float.toString(f) + "F");
+    }
+
+    public static JExpression lit(double d) {
+        return new JAtom(Double.toString(d) + "D");
+    }
+
+    static final String charEscape = "\b\t\n\f\r\"\'\\";
+    static final String charMacro  = "btnfr\"'\\";
+
+    /**
+     * Escapes the given string, then surrounds it by the specified
+     * quotation mark.
+     */
+    public static String quotify(char quote, String s) {
+        int n = s.length();
+        StringBuilder sb = new StringBuilder(n + 2);
+        sb.append(quote);
+        for (int i = 0; i < n; i++) {
+            char c = s.charAt(i);
+            int j = charEscape.indexOf(c);
+            if(j>=0) {
+                sb.append('\\');
+                sb.append(charMacro.charAt(j));
+            } else {
+                // technically Unicode escape shouldn't be done here,
+                // for it's a lexical level handling.
+                //
+                // However, various tools are so broken around this area,
+                // so just to be on the safe side, it's better to do
+                // the escaping here (regardless of the actual file encoding)
+                //
+                // see bug
+                if( c<0x20 || 0x7E<c ) {
+                    // not printable. use Unicode escape
+                    sb.append("\\u");
+                    String hex = Integer.toHexString(((int)c)&0xFFFF);
+                    for( int k=hex.length(); k<4; k++ )
+                        sb.append('0');
+                    sb.append(hex);
+                } else {
+                    sb.append(c);
+                }
+            }
+        }
+        sb.append(quote);
+        return sb.toString();
+    }
+
+    public static JExpression lit(char c) {
+        return new JAtom(quotify('\'', "" + c));
+    }
+
+    public static JExpression lit(String s) {
+        return new JStringLiteral(s);
+    }
+
+    /**
+     * Creates an expression directly from a source code fragment.
+     *
+     * <p>
+     * This method can be used as a short-cut to create a JExpression.
+     * For example, instead of <code>_a.gt(_b)</code>, you can write
+     * it as: <code>JExpr.direct("a>b")</code>.
+     *
+     * <p>
+     * Be warned that there is a danger in using this method,
+     * as it obfuscates the object model.
+     */
+    public static JExpression direct( final String source ) {
+        return new JExpressionImpl(){
+            public void generate( JFormatter f ) {
+                    f.p('(').p(source).p(')');
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JExpression.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JExpression.java
new file mode 100644
index 0000000..e9873b5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JExpression.java
@@ -0,0 +1,150 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * A Java expression.
+ *
+ * <p>
+ * Unlike most of CodeModel, JExpressions are built bottom-up (
+ * meaning you start from leaves and then gradually build compliated expressions
+ * by combining them.)
+ *
+ * <p>
+ * {@link JExpression} defines a series of composer methods,
+ * which returns a complicated expression (by often taking other {@link JExpression}s
+ * as parameters.
+ * For example, you can build "5+2" by
+ * <tt>JExpr.lit(5).add(JExpr.lit(2))</tt>
+ */
+public interface JExpression extends JGenerable {
+    /**
+     * Returns "-[this]" from "[this]".
+     */
+    JExpression minus();
+
+    /**
+     * Returns "![this]" from "[this]".
+     */
+    JExpression not();
+    /**
+     * Returns "~[this]" from "[this]".
+     */
+    JExpression complement();
+
+    /**
+     * Returns "[this]++" from "[this]".
+     */
+    JExpression incr();
+
+    /**
+     * Returns "[this]--" from "[this]".
+     */
+    JExpression decr();
+
+    /**
+     * Returns "[this]+[right]"
+     */
+    JExpression plus(JExpression right);
+
+    /**
+     * Returns "[this]-[right]"
+     */
+    JExpression minus(JExpression right);
+
+    /**
+     * Returns "[this]*[right]"
+     */
+    JExpression mul(JExpression right);
+
+    /**
+     * Returns "[this]/[right]"
+     */
+    JExpression div(JExpression right);
+
+    /**
+     * Returns "[this]%[right]"
+     */
+    JExpression mod(JExpression right);
+
+    /**
+     * Returns "[this]&lt;&lt;[right]"
+     */
+    JExpression shl(JExpression right);
+
+    /**
+     * Returns "[this]>>[right]"
+     */
+    JExpression shr(JExpression right);
+
+    /**
+     * Returns "[this]>>>[right]"
+     */
+    JExpression shrz(JExpression right);
+
+    /** Bit-wise AND '&amp;'. */
+    JExpression band(JExpression right);
+
+    /** Bit-wise OR '|'. */
+    JExpression bor(JExpression right);
+
+    /** Logical AND '&amp;&amp;'. */
+    JExpression cand(JExpression right);
+
+    /** Logical OR '||'. */
+    JExpression cor(JExpression right);
+
+    JExpression xor(JExpression right);
+    JExpression lt(JExpression right);
+    JExpression lte(JExpression right);
+    JExpression gt(JExpression right);
+    JExpression gte(JExpression right);
+    JExpression eq(JExpression right);
+    JExpression ne(JExpression right);
+
+    /**
+     * Returns "[this] instanceof [right]"
+     */
+    JExpression _instanceof(JType right);
+
+    /**
+     * Returns "[this].[method]".
+     *
+     * Arguments shall be added to the returned {@link JInvocation} object.
+     */
+    JInvocation invoke(JMethod method);
+
+    /**
+     * Returns "[this].[method]".
+     *
+     * Arguments shall be added to the returned {@link JInvocation} object.
+     */
+    JInvocation invoke(String method);
+    JFieldRef ref(JVar field);
+    JFieldRef ref(String field);
+    JArrayCompRef component(JExpression index);
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JExpressionImpl.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JExpressionImpl.java
new file mode 100644
index 0000000..8cdcb06
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JExpressionImpl.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * Provides default implementations for {@link JExpression}.
+ */
+public abstract class JExpressionImpl implements JExpression
+{
+    //
+    //
+    // from JOp
+    //
+    //
+    public final JExpression minus() {
+        return JOp.minus(this);
+    }
+
+    /**
+     * Logical not <tt>'!x'</tt>.
+     */
+    public final JExpression not() {
+        return JOp.not(this);
+    }
+
+    public final JExpression complement() {
+        return JOp.complement(this);
+    }
+
+    public final JExpression incr() {
+        return JOp.incr(this);
+    }
+
+    public final JExpression decr() {
+        return JOp.decr(this);
+    }
+
+    public final JExpression plus(JExpression right) {
+        return JOp.plus(this, right);
+    }
+
+    public final JExpression minus(JExpression right) {
+        return JOp.minus(this, right);
+    }
+
+    public final JExpression mul(JExpression right) {
+        return JOp.mul(this, right);
+    }
+
+    public final JExpression div(JExpression right) {
+        return JOp.div(this, right);
+    }
+
+    public final JExpression mod(JExpression right) {
+        return JOp.mod(this, right);
+    }
+
+    public final JExpression shl(JExpression right) {
+        return JOp.shl(this, right);
+    }
+
+    public final JExpression shr(JExpression right) {
+        return JOp.shr(this, right);
+    }
+
+    public final JExpression shrz(JExpression right) {
+        return JOp.shrz(this, right);
+    }
+
+    public final JExpression band(JExpression right) {
+        return JOp.band(this, right);
+    }
+
+    public final JExpression bor(JExpression right) {
+        return JOp.bor(this, right);
+    }
+
+    public final JExpression cand(JExpression right) {
+        return JOp.cand(this, right);
+    }
+
+    public final JExpression cor(JExpression right) {
+        return JOp.cor(this, right);
+    }
+
+    public final JExpression xor(JExpression right) {
+        return JOp.xor(this, right);
+    }
+
+    public final JExpression lt(JExpression right) {
+        return JOp.lt(this, right);
+    }
+
+    public final JExpression lte(JExpression right) {
+        return JOp.lte(this, right);
+    }
+
+    public final JExpression gt(JExpression right) {
+        return JOp.gt(this, right);
+    }
+
+    public final JExpression gte(JExpression right) {
+        return JOp.gte(this, right);
+    }
+
+    public final JExpression eq(JExpression right) {
+        return JOp.eq(this, right);
+    }
+
+    public final JExpression ne(JExpression right) {
+        return JOp.ne(this, right);
+    }
+
+    public final JExpression _instanceof(JType right) {
+        return JOp._instanceof(this, right);
+    }
+
+    //
+    //
+    // from JExpr
+    //
+    //
+    public final JInvocation invoke(JMethod method) {
+        return JExpr.invoke(this, method);
+    }
+
+    public final JInvocation invoke(String method) {
+        return JExpr.invoke(this, method);
+    }
+
+    public final JFieldRef ref(JVar field) {
+        return JExpr.ref(this, field);
+    }
+
+    public final JFieldRef ref(String field) {
+        return JExpr.ref(this, field);
+    }
+
+    public final JArrayCompRef component(JExpression index) {
+        return JExpr.component(this, index);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JFieldRef.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JFieldRef.java
new file mode 100644
index 0000000..17737c4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JFieldRef.java
@@ -0,0 +1,119 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Field Reference
+ */
+
+public class JFieldRef extends JExpressionImpl implements JAssignmentTarget {
+    /**
+     * Object expression upon which this field will be accessed, or
+     * null for the implicit 'this'.
+     */
+    private JGenerable object;
+
+    /**
+     * Name of the field to be accessed. Either this or {@link #var} is set.
+     */
+    private String name;
+
+    /**
+     * Variable to be accessed.
+     */
+    private JVar var;
+
+    /**
+     * Indicates if an explicit this should be generated
+     */
+    private boolean explicitThis;
+
+    /**
+     * Field reference constructor given an object expression and field name
+     *
+     * @param object
+     *        JExpression for the object upon which
+     *        the named field will be accessed,
+     *
+     * @param name
+     *        Name of field to access
+     */
+    JFieldRef(JExpression object, String name) {
+        this(object, name, false);
+    }
+
+    JFieldRef(JExpression object, JVar v) {
+        this(object, v, false);
+    }
+
+    /**
+     * Static field reference.
+     */
+    JFieldRef(JType type, String name) {
+        this(type, name, false);
+    }
+
+    JFieldRef(JType type, JVar v) {
+        this(type, v, false);
+    }
+
+    JFieldRef(JGenerable object, String name, boolean explicitThis) {
+        this.explicitThis = explicitThis;
+        this.object = object;
+        if (name.indexOf('.') >= 0)
+            throw new IllegalArgumentException("Field name contains '.': " + name);
+        this.name = name;
+    }
+
+    JFieldRef(JGenerable object, JVar var, boolean explicitThis) {
+        this.explicitThis = explicitThis;
+        this.object = object;
+        this.var = var;
+    }
+
+    public void generate(JFormatter f) {
+        String name = this.name;
+        if(name==null)  name=var.name();
+
+        if (object != null) {
+            f.g(object).p('.').p(name);
+        } else {
+            if (explicitThis) {
+                f.p("this.").p(name);
+            } else {
+                f.id(name);
+            }
+        }
+    }
+
+    public JExpression assign(JExpression rhs) {
+        return JExpr.assign(this, rhs);
+    }
+    public JExpression assignPlus(JExpression rhs) {
+        return JExpr.assignPlus(this, rhs);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JFieldVar.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JFieldVar.java
new file mode 100644
index 0000000..f7b2b26
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JFieldVar.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+
+
+/**
+ * A field that can have a {@link JDocComment} associated with it
+ */
+public class JFieldVar extends JVar {
+
+    /**
+     * javadoc comments for this JFieldVar
+     */
+    private JDocComment jdoc = null;
+
+    private final JDefinedClass owner;
+
+
+    /**
+     * JFieldVar constructor
+     *
+     * @param type
+     *        Datatype of this variable
+     *
+     * @param name
+     *        Name of this variable
+     *
+     * @param init
+     *        Value to initialize this variable to
+     */
+    JFieldVar(JDefinedClass owner, JMods mods, JType type, String name, JExpression init) {
+        super( mods, type, name, init );
+        this.owner = owner;
+    }
+
+    @Override
+    public void name(String name) {
+        // make sure that the new name is available
+        if(owner.fields.containsKey(name))
+            throw new IllegalArgumentException("name "+name+" is already in use");
+        String oldName = name();
+        super.name(name);
+        owner.fields.remove(oldName);
+        owner.fields.put(name,this);
+    }
+
+    /**
+     * Creates, if necessary, and returns the class javadoc for this
+     * JDefinedClass
+     *
+     * @return JDocComment containing javadocs for this class
+     */
+    public JDocComment javadoc() {
+        if( jdoc == null )
+            jdoc = new JDocComment(owner.owner());
+        return jdoc;
+    }
+
+    public void declare(JFormatter f) {
+        if( jdoc != null )
+            f.g( jdoc );
+        super.declare( f );
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JForEach.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JForEach.java
new file mode 100644
index 0000000..d2860a2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JForEach.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * ForEach Statement
+ * This will generate the code for statement based on the new
+ * j2se 1.5 j.l.s.
+ *
+ * @author Bhakti
+ */
+public final class JForEach implements JStatement {
+
+        private final JType type;
+        private final String var;
+        private JBlock body = null; // lazily created
+        private final JExpression collection;
+    private final JVar loopVar;
+
+        public JForEach(JType vartype, String variable, JExpression collection) {
+
+                this.type = vartype;
+                this.var = variable;
+                this.collection = collection;
+        loopVar = new JVar(JMods.forVar(JMod.NONE), type, var, collection);
+    }
+
+
+    /**
+     * Returns a reference to the loop variable.
+     */
+        public JVar var() {
+                return loopVar;
+        }
+
+        public JBlock body() {
+                if (body == null)
+                        body = new JBlock();
+                return body;
+        }
+
+        public void state(JFormatter f) {
+                f.p("for (");
+                f.g(type).id(var).p(": ").g(collection);
+                f.p(')');
+                if (body != null)
+                        f.g(body).nl();
+                else
+                        f.p(';').nl();
+        }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JForLoop.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JForLoop.java
new file mode 100644
index 0000000..b36b07f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JForLoop.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.List;
+
+
+/**
+ * For statement
+ */
+
+public class JForLoop implements JStatement {
+
+    private List<Object> inits = new ArrayList<Object>();
+    private JExpression test = null;
+    private List<JExpression> updates = new ArrayList<JExpression>();
+    private JBlock body = null;
+
+    public JVar init(int mods, JType type, String var, JExpression e) {
+        JVar v = new JVar(JMods.forVar(mods), type, var, e);
+        inits.add(v);
+        return v;
+    }
+
+    public JVar init(JType type, String var, JExpression e) {
+        return init(JMod.NONE, type, var, e);
+    }
+
+    public void init(JVar v, JExpression e) {
+        inits.add(JExpr.assign(v, e));
+    }
+
+    public void test(JExpression e) {
+        this.test = e;
+    }
+
+    public void update(JExpression e) {
+        updates.add(e);
+    }
+
+    public JBlock body() {
+        if (body == null) body = new JBlock();
+        return body;
+    }
+
+    public void state(JFormatter f) {
+        f.p("for (");
+        boolean first = true;
+        for (Object o : inits) {
+            if (!first) f.p(',');
+            if (o instanceof JVar)
+                f.b((JVar) o);
+            else
+                f.g((JExpression) o);
+            first = false;
+        }
+        f.p(';').g(test).p(';').g(updates).p(')');
+        if (body != null)
+            f.g(body).nl();
+        else
+            f.p(';').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JFormatter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JFormatter.java
new file mode 100644
index 0000000..d7b7777
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JFormatter.java
@@ -0,0 +1,541 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.io.PrintWriter;
+import java.io.Writer;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+
+
+/**
+ * This is a utility class for managing indentation and other basic
+ * formatting for PrintWriter.
+ */
+public final class JFormatter {
+    /** all classes and ids encountered during the collection mode **/
+    /** map from short type name to ReferenceList (list of JClass and ids sharing that name) **/
+    private HashMap<String,ReferenceList> collectedReferences;
+
+    /** set of imported types (including package java types, eventhough we won't generate imports for them) */
+    private HashSet<JClass> importedClasses;
+
+    private static enum Mode {
+        /**
+         * Collect all the type names and identifiers.
+         * In this mode we don't actually generate anything.
+         */
+        COLLECTING,
+        /**
+         * Print the actual source code.
+         */
+        PRINTING
+    }
+
+    /**
+     * The current running mode.
+     * Set to PRINTING so that a casual client can use a formatter just like before.
+     */
+    private Mode mode = Mode.PRINTING;
+
+    /**
+     * Current number of indentation strings to print
+     */
+    private int indentLevel;
+
+    /**
+     * String to be used for each indentation.
+     * Defaults to four spaces.
+     */
+    private final String indentSpace;
+
+    /**
+     * Stream associated with this JFormatter
+     */
+    private final PrintWriter pw;
+
+    /**
+     * Creates a JFormatter.
+     *
+     * @param s
+     *        PrintWriter to JFormatter to use.
+     *
+     * @param space
+     *        Incremental indentation string, similar to tab value.
+     */
+    public JFormatter(PrintWriter s, String space) {
+        pw = s;
+        indentSpace = space;
+        collectedReferences = new HashMap<String,ReferenceList>();
+        //ids = new HashSet<String>();
+        importedClasses = new HashSet<JClass>();
+    }
+
+    /**
+     * Creates a formatter with default incremental indentations of
+     * four spaces.
+     */
+    public JFormatter(PrintWriter s) {
+        this(s, "    ");
+    }
+
+    /**
+     * Creates a formatter with default incremental indentations of
+     * four spaces.
+     */
+    public JFormatter(Writer w) {
+        this(new PrintWriter(w));
+    }
+
+    /**
+     * Closes this formatter.
+     */
+    public void close() {
+        pw.close();
+    }
+
+    /**
+     * Returns true if we are in the printing mode,
+     * where we actually produce text.
+     *
+     * The other mode is the "collecting mode'
+     */
+    public boolean isPrinting() {
+        return mode == Mode.PRINTING;
+    }
+
+    /**
+     * Decrement the indentation level.
+     */
+    public JFormatter o() {
+        indentLevel--;
+        return this;
+    }
+
+    /**
+     * Increment the indentation level.
+     */
+    public JFormatter i() {
+        indentLevel++;
+        return this;
+    }
+
+    private boolean needSpace(char c1, char c2) {
+        if ((c1 == ']') && (c2 == '{')) return true;
+        if (c1 == ';') return true;
+        if (c1 == CLOSE_TYPE_ARGS) {
+            // e.g., "public Foo<Bar> test;"
+            if(c2=='(') // but not "new Foo<Bar>()"
+                return false;
+            return true;
+        }
+        if ((c1 == ')') && (c2 == '{')) return true;
+        if ((c1 == ',') || (c1 == '=')) return true;
+        if (c2 == '=') return true;
+        if (Character.isDigit(c1)) {
+            if ((c2 == '(') || (c2 == ')') || (c2 == ';') || (c2 == ','))
+                return false;
+            return true;
+        }
+        if (Character.isJavaIdentifierPart(c1)) {
+            switch (c2) {
+            case '{':
+            case '}':
+            case '+':
+            case '>':
+            case '@':
+                return true;
+            default:
+                return Character.isJavaIdentifierStart(c2);
+            }
+        }
+        if (Character.isJavaIdentifierStart(c2)) {
+            switch (c1) {
+            case ']':
+            case ')':
+            case '}':
+            case '+':
+                return true;
+            default:
+                return false;
+            }
+        }
+        if (Character.isDigit(c2)) {
+            if (c1 == '(') return false;
+            return true;
+        }
+        return false;
+    }
+
+    private char lastChar = 0;
+    private boolean atBeginningOfLine = true;
+
+    private void spaceIfNeeded(char c) {
+        if (atBeginningOfLine) {
+            for (int i = 0; i < indentLevel; i++)
+                pw.print(indentSpace);
+            atBeginningOfLine = false;
+        } else if ((lastChar != 0) && needSpace(lastChar, c))
+            pw.print(' ');
+    }
+
+    /**
+     * Print a char into the stream
+     *
+     * @param c the char
+     */
+    public JFormatter p(char c) {
+        if(mode==Mode.PRINTING) {
+            if(c==CLOSE_TYPE_ARGS) {
+                pw.print('>');
+            } else {
+                spaceIfNeeded(c);
+                pw.print(c);
+            }
+            lastChar = c;
+        }
+        return this;
+    }
+
+    /**
+     * Print a String into the stream
+     *
+     * @param s the String
+     */
+    public JFormatter p(String s) {
+        if(mode==Mode.PRINTING) {
+            spaceIfNeeded(s.charAt(0));
+            pw.print(s);
+            lastChar = s.charAt(s.length() - 1);
+        }
+        return this;
+    }
+
+    public JFormatter t(JType type) {
+        if(type.isReference()) {
+            return t((JClass)type);
+        } else {
+            return g(type);
+        }
+    }
+
+    /**
+     * Print a type name.
+     *
+     * <p>
+     * In the collecting mode we use this information to
+     * decide what types to import and what not to.
+     */
+    public JFormatter t(JClass type) {
+        switch(mode) {
+        case PRINTING:
+            // many of the JTypes in this list are either primitive or belong to package java
+            // so we don't need a FQCN
+            if(importedClasses.contains(type)) {
+                p(type.name()); // FQCN imported or not necessary, so generate short name
+            } else {
+                if(type.outer()!=null)
+                    t(type.outer()).p('.').p(type.name());
+                else
+                    p(type.fullName()); // collision was detected, so generate FQCN
+            }
+            break;
+        case COLLECTING:
+            final String shortName = type.name();
+            if(collectedReferences.containsKey(shortName)) {
+                collectedReferences.get(shortName).add(type);
+            } else {
+                ReferenceList tl = new ReferenceList();
+                tl.add(type);
+                collectedReferences.put(shortName, tl);
+            }
+            break;
+        }
+        return this;
+    }
+
+    /**
+     * Print an identifier
+     */
+    public JFormatter id(String id) {
+        switch(mode) {
+        case PRINTING:
+            p(id);
+            break;
+        case COLLECTING:
+            // see if there is a type name that collides with this id
+            if(collectedReferences.containsKey(id)) {
+                if( !collectedReferences.get(id).getClasses().isEmpty() ) {
+                    for( JClass type : collectedReferences.get(id).getClasses() ) {
+                        if (type.outer()!=null) {
+                            collectedReferences.get(id).setId(false);
+                            return this;
+                        }
+                    }
+                }
+                collectedReferences.get(id).setId(true);
+            } else {
+                // not a type, but we need to create a place holder to
+                // see if there might be a collision with a type
+                ReferenceList tl = new ReferenceList();
+                tl.setId(true);
+                collectedReferences.put(id, tl);
+            }
+            break;
+        }
+        return this;
+    }
+
+    /**
+     * Print a new line into the stream
+     */
+    public JFormatter nl() {
+        if(mode==Mode.PRINTING) {
+            pw.println();
+            lastChar = 0;
+            atBeginningOfLine = true;
+        }
+        return this;
+    }
+
+    /**
+     * Cause the JGenerable object to generate source for iteself
+     *
+     * @param g the JGenerable object
+     */
+    public JFormatter g(JGenerable g) {
+        g.generate(this);
+        return this;
+    }
+
+    /**
+     * Produces {@link JGenerable}s separated by ','
+     */
+    public JFormatter g(Collection<? extends JGenerable> list) {
+        boolean first = true;
+        if(!list.isEmpty()) {
+            for (JGenerable item : list) {
+                if (!first)
+                    p(',');
+                g(item);
+                first = false;
+            }
+        }
+        return this;
+    }
+
+    /**
+     * Cause the JDeclaration to generate source for itself
+     *
+     * @param d the JDeclaration object
+     */
+    public JFormatter d(JDeclaration d) {
+        d.declare(this);
+        return this;
+    }
+
+    /**
+     * Cause the JStatement to generate source for itself
+     *
+     * @param s the JStatement object
+     */
+    public JFormatter s(JStatement s) {
+        s.state(this);
+        return this;
+    }
+
+    /**
+     * Cause the JVar to generate source for itself
+     *
+     * @param v the JVar object
+     */
+    public JFormatter b(JVar v) {
+        v.bind(this);
+        return this;
+    }
+
+    /**
+     * Generates the whole source code out of the specified class.
+     */
+    void write(JDefinedClass c) {
+        // first collect all the types and identifiers
+        mode = Mode.COLLECTING;
+        d(c);
+
+        javaLang = c.owner()._package("java.lang");
+
+        // collate type names and identifiers to determine which types can be imported
+        for( ReferenceList tl : collectedReferences.values() ) {
+            if(!tl.collisions(c) && !tl.isId()) {
+                assert tl.getClasses().size() == 1;
+
+                // add to list of collected types
+                importedClasses.add(tl.getClasses().get(0));
+            }
+        }
+
+        // the class itself that we will be generating is always accessible
+        importedClasses.add(c);
+
+        // then print the declaration
+        mode = Mode.PRINTING;
+
+        assert c.parentContainer().isPackage() : "this method is only for a pacakge-level class";
+        JPackage pkg = (JPackage) c.parentContainer();
+        if (!pkg.isUnnamed()) {
+            nl().d(pkg);
+            nl();
+        }
+
+        // generate import statements
+        JClass[] imports = importedClasses.toArray(new JClass[importedClasses.size()]);
+        Arrays.sort(imports);
+        for (JClass clazz : imports) {
+            // suppress import statements for primitive types, built-in types,
+            // types in the root package, and types in
+            // the same package as the current type
+            if(!supressImport(clazz, c)) {
+                p("import").p(clazz.fullName()).p(';').nl();
+            }
+        }
+        nl();
+
+        d(c);
+    }
+
+    /**
+     * determine if an import statement should be supressed
+     *
+     * @param clazz JType that may or may not have an import
+     * @param c JType that is the current class being processed
+     * @return true if an import statement should be suppressed, false otherwise
+     */
+    private boolean supressImport(JClass clazz, JClass c) {
+        if(clazz._package().isUnnamed())
+            return true;
+
+        final String packageName = clazz._package().name();
+        if(packageName.equals("java.lang"))
+            return true;    // no need to explicitly import java.lang classes
+
+        if (clazz._package() == c._package()){
+            // inner classes require an import stmt.
+            // All other pkg local classes do not need an
+            // import stmt for ref.
+            if(clazz.outer()==null) {
+                return true;    // no need to explicitly import a class into itself
+            }
+        }
+        return false;
+    }
+
+    private JPackage javaLang;
+
+
+
+    /**
+     * Special character token we use to differenciate '>' as an operator and
+     * '>' as the end of the type arguments. The former uses '>' and it requires
+     * a preceding whitespace. The latter uses this, and it does not have a preceding
+     * whitespace.
+     */
+    /*package*/ static final char CLOSE_TYPE_ARGS = '\uFFFF';
+
+    /**
+     * Used during the optimization of class imports.
+     *
+     * List of {@link JClass}es whose short name is the same.
+     *
+     * @author Ryan.Shoemaker@Sun.COM
+     */
+    final class ReferenceList {
+        private final ArrayList<JClass> classes = new ArrayList<JClass>();
+
+        /** true if this name is used as an identifier (like a variable name.) **/
+        private boolean id;
+
+        /**
+         * Returns true if the symbol represented by the short name
+         * is "importable".
+         */
+        public boolean collisions(JDefinedClass enclosingClass) {
+            // special case where a generated type collides with a type in package java
+
+            // more than one type with the same name
+            if(classes.size() > 1)
+                return true;
+
+            // an id and (at least one) type with the same name
+            if(id && classes.size() != 0)
+                return true;
+
+            for(JClass c : classes) {
+                if(c._package()==javaLang) {
+                    // make sure that there's no other class with this name within the same package
+                    Iterator itr = enclosingClass._package().classes();
+                    while(itr.hasNext()) {
+                        // even if this is the only "String" class we use,
+                        // if the class called "String" is in the same package,
+                        // we still need to import it.
+                        JDefinedClass n = (JDefinedClass)itr.next();
+                        if(n.name().equals(c.name()))
+                            return true;    //collision
+                    }
+                }
+                if(c.outer()!=null)
+                    return true; // avoid importing inner class to work around 6431987. Also see jaxb issue 166
+            }
+
+            return false;
+        }
+
+        public void add(JClass clazz) {
+            if(!classes.contains(clazz))
+                classes.add(clazz);
+        }
+
+        public List<JClass> getClasses() {
+            return classes;
+        }
+
+        public void setId(boolean value) {
+            id = value;
+        }
+
+        /**
+         * Return true iff this is strictly an id, meaning that there
+         * are no collisions with type names.
+         */
+        public boolean isId() {
+            return id && classes.size() == 0;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerable.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerable.java
new file mode 100644
index 0000000..00bed55
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerable.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Common interface for code components that can generate
+ * uses of themselves.
+ */
+
+interface JGenerable {
+
+    public void generate(JFormatter f);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerifiable.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerifiable.java
new file mode 100644
index 0000000..849b057
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerifiable.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * Declarations that can have type variables.
+ *
+ * Something that can be made into a generic.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface JGenerifiable {
+    /**
+     * Adds a new type variable to this declaration.
+     */
+    JTypeVar generify( String name );
+
+    /**
+     * Adds a new type variable to this declaration with a bound.
+     */
+    JTypeVar generify( String name, Class bound );
+
+    /**
+     * Adds a new type variable to this declaration with a bound.
+     */
+    JTypeVar generify( String name, JClass bound );
+
+    /**
+     * Iterates all the type parameters of this class/interface.
+     */
+    JTypeVar[] typeParams();
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerifiableImpl.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerifiableImpl.java
new file mode 100644
index 0000000..0623457
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JGenerifiableImpl.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * Implementation of {@link JGenerifiable}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+abstract class JGenerifiableImpl implements JGenerifiable, JDeclaration {
+
+    /** Lazily created list of {@link JTypeVar}s. */
+    private List<JTypeVar> typeVariables = null;
+
+    protected abstract JCodeModel owner();
+
+    public void declare( JFormatter f ) {
+        if(typeVariables!=null) {
+            f.p('<');
+            for (int i = 0; i < typeVariables.size(); i++) {
+                if(i!=0)    f.p(',');
+                f.d(typeVariables.get(i));
+            }
+            f.p('>');
+        }
+    }
+
+
+    public JTypeVar generify(String name) {
+        JTypeVar v = new JTypeVar(owner(),name);
+        if(typeVariables==null)
+            typeVariables = new ArrayList<JTypeVar>(3);
+        typeVariables.add(v);
+        return v;
+    }
+
+    public JTypeVar generify(String name, Class bound) {
+        return generify(name,owner().ref(bound));
+    }
+
+    public JTypeVar generify(String name, JClass bound) {
+        return generify(name).bound(bound);
+    }
+
+    public JTypeVar[] typeParams() {
+        if(typeVariables==null)
+            return JTypeVar.EMPTY_ARRAY;
+        else
+            return typeVariables.toArray(new JTypeVar[typeVariables.size()]);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JInvocation.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JInvocation.java
new file mode 100644
index 0000000..1e5b87f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JInvocation.java
@@ -0,0 +1,156 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.List;
+
+
+/**
+ * JMethod invocation
+ */
+public final class JInvocation extends JExpressionImpl implements JStatement {
+
+    /**
+     * Object expression upon which this method will be invoked, or null if
+     * this is a constructor invocation
+     */
+    private JGenerable object;
+
+    /**
+     * Name of the method to be invoked
+     */
+    private String name;
+
+    private boolean isConstructor = false;
+
+    /**
+     * List of argument expressions for this method invocation
+     */
+    private List<JExpression> args = new ArrayList<JExpression>();
+
+    /**
+     * If isConstructor==true, this field keeps the type to be created.
+     */
+    private JType type = null;
+
+    /**
+     * Invokes a method on an object.
+     *
+     * @param object
+     *        JExpression for the object upon which
+     *        the named method will be invoked,
+     *        or null if none
+     *
+     * @param name
+     *        Name of method to invoke
+     */
+    JInvocation(JExpression object, String name) {
+        this( (JGenerable)object, name );
+    }
+
+    /**
+     * Invokes a static method on a class.
+     */
+    JInvocation(JClass type, String name) {
+        this( (JGenerable)type, name );
+    }
+
+    private JInvocation(JGenerable object, String name) {
+        this.object = object;
+        if (name.indexOf('.') >= 0)
+            throw new IllegalArgumentException("JClass name contains '.': "
+                                               + name);
+        this.name = name;
+    }
+
+    /**
+     * Invokes a constructor of an object (i.e., creates
+     * a new object.)
+     *
+     * @param c
+     *      Type of the object to be created. If this type is
+     *      an array type, added arguments are treated as array
+     *      initializer. Thus you can create an expression like
+     *      <code>new int[]{1,2,3,4,5}</code>.
+     */
+    JInvocation(JType c) {
+        this.isConstructor = true;
+        this.type = c;
+    }
+
+    /**
+     *  Add an expression to this invocation's argument list
+     *
+     * @param arg
+     *        Argument to add to argument list
+     */
+    public JInvocation arg(JExpression arg) {
+        if(arg==null)   throw new IllegalArgumentException();
+        args.add(arg);
+        return this;
+    }
+
+    /**
+     * Adds a literal argument.
+     *
+     * Short for {@code arg(JExpr.lit(v))}
+     */
+    public JInvocation arg(String v) {
+        return arg(JExpr.lit(v));
+    }
+
+
+    public void generate(JFormatter f) {
+        if (isConstructor && type.isArray()) {
+            // [RESULT] new T[]{arg1,arg2,arg3,...};
+            f.p("new").g(type).p('{');
+        } else {
+            if (isConstructor)
+                f.p("new").g(type).p('(');
+            else if (object != null)
+                f.g(object).p('.').p(name).p('(');
+            else
+                f.id(name).p('(');
+        }
+
+        f.g(args);
+
+        if (isConstructor && type.isArray())
+            f.p('}');
+        else
+            f.p(')');
+
+        if( type instanceof JDefinedClass && ((JDefinedClass)type).isAnonymous() ) {
+            ((JAnonymousClass)type).declareBody(f);
+        }
+    }
+
+    public void state(JFormatter f) {
+        f.g(this).p(';').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JJavaName.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JJavaName.java
new file mode 100644
index 0000000..3cf2c87
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JJavaName.java
@@ -0,0 +1,244 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.HashSet;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+/**
+ * Utility methods that convert arbitrary strings into Java identifiers.
+ */
+public class JJavaName {
+
+
+    /**
+     * Checks if a given string is usable as a Java identifier.
+     */
+    public static boolean isJavaIdentifier(String s) {
+        if(s.length()==0)   return false;
+        if( reservedKeywords.contains(s) )  return false;
+
+        if(!Character.isJavaIdentifierStart(s.charAt(0)))   return false;
+
+        for (int i = 1; i < s.length(); i++)
+            if (!Character.isJavaIdentifierPart(s.charAt(i)))
+                return false;
+
+        return true;
+    }
+
+    /**
+     * Checks if the given string is a valid Java package name.
+     */
+    public static boolean isJavaPackageName(String s) {
+        while(s.length()!=0) {
+            int idx = s.indexOf('.');
+            if(idx==-1) idx=s.length();
+            if( !isJavaIdentifier(s.substring(0,idx)) )
+                return false;
+
+            s = s.substring(idx);
+            if(s.length()!=0)    s = s.substring(1);    // remove '.'
+        }
+        return true;
+    }
+
+    /**
+     * <b>Experimental API:</b> converts an English word into a plural form.
+     *
+     * @param word
+     *      a word, such as "child", "apple". Must not be null.
+     *      It accepts word concatanation forms
+     *      that are common in programming languages, such as "my_child", "MyChild",
+     *      "myChild", "MY-CHILD", "CODE003-child", etc, and mostly tries to do the right thing.
+     *      ("my_children","MyChildren","myChildren", and "MY-CHILDREN", "CODE003-children" respectively)
+     *      <p>
+     *      Although this method only works for English words, it handles non-English
+     *      words gracefully (by just returning it as-is.) For example, &#x65E5;&#x672C;&#x8A9E;
+     *      will be returned as-is without modified, not "&#x65E5;&#x672C;&#x8A9E;s"
+     *      <p>
+     *      This method doesn't handle suffixes very well. For example, passing
+     *      "person56" will return "person56s", not "people56".
+     *
+     * @return
+     *      always non-null.
+     */
+    public static String getPluralForm(String word) {
+        // remember the casing of the word
+        boolean allUpper = true;
+
+        // check if the word looks like an English word.
+        // if we see non-ASCII characters, abort
+        for(int i=0; i<word.length(); i++ ) {
+            char ch = word.charAt(i);
+            if(ch >=0x80)
+                return word;
+
+            // note that this isn't the same as allUpper &= Character.isUpperCase(ch);
+            allUpper &= !Character.isLowerCase(ch);
+        }
+
+        for (Entry e : TABLE) {
+            String r = e.apply(word);
+            if(r!=null) {
+                if(allUpper)    r=r.toUpperCase();
+                return r;
+            }
+        }
+
+        // failed
+        return word;
+    }
+
+
+    /** All reserved keywords of Java. */
+    private static HashSet<String> reservedKeywords = new HashSet<String>();
+
+    static {
+        // see http://java.sun.com/docs/books/tutorial/java/nutsandbolts/_keywords.html
+        String[] words = new String[]{
+            "abstract",
+            "boolean",
+            "break",
+            "byte",
+            "case",
+            "catch",
+            "char",
+            "class",
+            "const",
+            "continue",
+            "default",
+            "do",
+            "double",
+            "else",
+            "extends",
+            "final",
+            "finally",
+            "float",
+            "for",
+            "goto",
+            "if",
+            "implements",
+            "import",
+            "instanceof",
+            "int",
+            "interface",
+            "long",
+            "native",
+            "new",
+            "package",
+            "private",
+            "protected",
+            "public",
+            "return",
+            "short",
+            "static",
+            "strictfp",
+            "super",
+            "switch",
+            "synchronized",
+            "this",
+            "throw",
+            "throws",
+            "transient",
+            "try",
+            "void",
+            "volatile",
+            "while",
+
+            // technically these are not reserved words but they cannot be used as identifiers.
+            "true",
+            "false",
+            "null",
+
+            // and I believe assert is also a new keyword
+            "assert",
+
+            // and 5.0 keywords
+            "enum"
+            };
+        for (String w : words)
+            reservedKeywords.add(w);
+    }
+
+
+    private static class Entry {
+        private final Pattern pattern;
+        private final String replacement;
+
+        public Entry(String pattern, String replacement) {
+            this.pattern = Pattern.compile(pattern,Pattern.CASE_INSENSITIVE);
+            this.replacement = replacement;
+        }
+
+        String apply(String word) {
+            Matcher m = pattern.matcher(word);
+            if(m.matches()) {
+                StringBuffer buf = new StringBuffer();
+                m.appendReplacement(buf,replacement);
+                return buf.toString();
+            } else {
+                return null;
+            }
+        }
+    }
+
+    private static final Entry[] TABLE;
+
+    static {
+        String[] source = {
+              "(.*)child","$1children",
+                 "(.+)fe","$1ves",
+              "(.*)mouse","$1mise",
+                  "(.+)f","$1ves",
+                 "(.+)ch","$1ches",
+                 "(.+)sh","$1shes",
+              "(.*)tooth","$1teeth",
+                 "(.+)um","$1a",
+                 "(.+)an","$1en",
+                "(.+)ato","$1atoes",
+              "(.*)basis","$1bases",
+               "(.*)axis","$1axes",
+                 "(.+)is","$1ises",
+                 "(.+)us","$1uses",
+                  "(.+)s","$1s",
+               "(.*)foot","$1feet",
+                 "(.+)ix","$1ixes",
+                 "(.+)ex","$1ices",
+                 "(.+)nx","$1nxes",
+                  "(.+)x","$1xes",
+                  "(.+)y","$1ies",
+                   "(.+)","$1s",
+        };
+
+        TABLE = new Entry[source.length/2];
+
+        for( int i=0; i<source.length; i+=2 ) {
+            TABLE[i/2] = new Entry(source[i],source[i+1]);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JLabel.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JLabel.java
new file mode 100644
index 0000000..84a4b57
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JLabel.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * Label that can be used for continue and break.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JLabel implements JStatement {
+
+    final String label;
+
+    /**
+     * JBreak constructor
+     *
+     * @param   _label
+     *      break label or null.
+     */
+    JLabel( String _label ) {
+        this.label = _label;
+    }
+
+    public void state(JFormatter f) {
+        f.p(label+':').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JMethod.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JMethod.java
new file mode 100644
index 0000000..13c3c8b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JMethod.java
@@ -0,0 +1,442 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.lang.annotation.Annotation;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Set;
+import java.util.TreeSet;
+
+import com.sun.codemodel.internal.util.ClassNameComparator;
+
+/**
+ * Java method.
+ */
+public class JMethod extends JGenerifiableImpl implements JDeclaration, JAnnotatable {
+
+        /**
+         * Modifiers for this method
+         */
+        private JMods mods;
+
+        /**
+         * Return type for this method
+         */
+        private JType type = null;
+
+        /**
+         * Name of this method
+         */
+        private String name = null;
+
+        /**
+         * List of parameters for this method's declaration
+         */
+        private final List<JVar> params = new ArrayList<JVar>();
+
+        /**
+         * Set of exceptions that this method may throw.
+     * A set instance lazily created.
+         */
+        private Set<JClass> _throws;
+
+        /**
+         * JBlock of statements that makes up the body this method
+         */
+        private JBlock body = null;
+
+        private JDefinedClass outer;
+
+        /**
+         * javadoc comments for this JMethod
+         */
+        private JDocComment jdoc = null;
+
+        /**
+         * Variable parameter for this method's varargs declaration
+         * introduced in J2SE 1.5
+         */
+        private JVar varParam = null;
+
+    /**
+     * Annotations on this variable. Lazily created.
+     */
+    private List<JAnnotationUse> annotations = null;
+
+
+        private boolean isConstructor() {
+                return type == null;
+        }
+
+    /** To set the default value for the
+     *  annotation member
+     */
+    private JExpression defaultValue = null;
+
+
+        /**
+         * JMethod constructor
+         *
+         * @param mods
+         *        Modifiers for this method's declaration
+         *
+         * @param type
+         *        Return type for the method
+         *
+         * @param name
+         *        Name of this method
+         */
+        JMethod(JDefinedClass outer, int mods, JType type, String name) {
+                this.mods = JMods.forMethod(mods);
+                this.type = type;
+                this.name = name;
+                this.outer = outer;
+        }
+
+        /**
+         * Constructor constructor
+         *
+         * @param mods
+         *        Modifiers for this constructor's declaration
+         *
+         * @param _class
+         *        JClass containing this constructor
+         */
+        JMethod(int mods, JDefinedClass _class) {
+                this.mods = JMods.forMethod(mods);
+                this.type = null;
+                this.name = _class.name();
+                this.outer = _class;
+        }
+
+    private Set<JClass> getThrows() {
+        if(_throws==null)
+            _throws = new TreeSet<JClass>(ClassNameComparator.theInstance);
+        return _throws;
+    }
+
+        /**
+         * Add an exception to the list of exceptions that this
+         * method may throw.
+         *
+         * @param exception
+         *        Name of an exception that this method may throw
+         */
+        public JMethod _throws(JClass exception) {
+        getThrows().add(exception);
+                return this;
+        }
+
+        public JMethod _throws(Class exception) {
+                return _throws(outer.owner().ref(exception));
+        }
+
+        /**
+         * Add the specified variable to the list of parameters
+         * for this method signature.
+         *
+         * @param type
+         *        JType of the parameter being added
+         *
+         * @param name
+         *        Name of the parameter being added
+         *
+         * @return New parameter variable
+         */
+        public JVar param(int mods, JType type, String name) {
+                JVar v = new JVar(JMods.forVar(mods), type, name, null);
+                params.add(v);
+                return v;
+        }
+
+        public JVar param(JType type, String name) {
+                return param(JMod.NONE, type, name);
+        }
+
+        public JVar param(int mods, Class type, String name) {
+                return param(mods, outer.owner()._ref(type), name);
+        }
+
+        public JVar param(Class type, String name) {
+                return param(outer.owner()._ref(type), name);
+        }
+
+        /**
+         * @see #varParam(JType, String)
+         */
+        public JVar varParam(Class type, String name) {
+        return varParam(outer.owner()._ref(type),name);
+    }
+
+    /**
+     * Add the specified variable argument to the list of parameters
+     * for this method signature.
+     *
+     * @param type
+     *      Type of the parameter being added.
+     *
+     * @param name
+     *        Name of the parameter being added
+     *
+     * @return the variable parameter
+     *
+     * @throws IllegalStateException
+     *      If this method is called twice.
+     *      varargs in J2SE 1.5 can appear only once in the
+     *      method signature.
+     */
+    public JVar varParam(JType type, String name) {
+                if (!hasVarArgs()) {
+
+            varParam =
+                                new JVar(
+                                        JMods.forVar(JMod.NONE),
+                                        type.array(),
+                                        name,
+                                        null);
+                        return varParam;
+                } else {
+                        throw new IllegalStateException(
+                                "Cannot have two varargs in a method,\n"
+                                        + "Check if varParam method of JMethod is"
+                                        + " invoked more than once");
+
+                }
+
+        }
+
+    /**
+     * Adds an annotation to this variable.
+     * @param clazz
+     *          The annotation class to annotate the field with
+     */
+    public JAnnotationUse annotate(JClass clazz){
+        if(annotations==null)
+           annotations = new ArrayList<JAnnotationUse>();
+        JAnnotationUse a = new JAnnotationUse(clazz);
+        annotations.add(a);
+        return a;
+    }
+
+    /**
+     * Adds an annotation to this variable.
+     *
+     * @param clazz
+     *          The annotation class to annotate the field with
+     */
+    public JAnnotationUse annotate(Class <? extends Annotation> clazz){
+        return annotate(owner().ref(clazz));
+    }
+
+    public <W extends JAnnotationWriter> W annotate2(Class<W> clazz) {
+        return TypedAnnotationWriter.create(clazz,this);
+    }
+
+        /**
+         * Check if there are any varargs declared
+         * for this method signature.
+         */
+        public boolean hasVarArgs() {
+                return this.varParam!=null;
+        }
+
+        public String name() {
+                return name;
+        }
+
+        /**
+         * Returns the return type.
+         */
+        public JType type() {
+                return type;
+        }
+
+        /**
+         * Returns all the parameter types in an array.
+         * @return
+         *      If there's no parameter, an empty array will be returned.
+         */
+        public JType[] listParamTypes() {
+                JType[] r = new JType[params.size()];
+                for (int i = 0; i < r.length; i++)
+                        r[i] = params.get(i).type();
+                return r;
+        }
+
+        /**
+         * Returns  the varags parameter type.
+         * @return
+         * If there's no vararg parameter type, null will be returned.
+         */
+        public JType listVarParamType() {
+                if (varParam != null)
+                        return varParam.type();
+                else
+                        return null;
+        }
+
+        /**
+         * Returns all the parameters in an array.
+         * @return
+         *      If there's no parameter, an empty array will be returned.
+         */
+        public JVar[] listParams() {
+                return params.toArray(new JVar[params.size()]);
+        }
+
+        /**
+         * Returns the variable parameter
+         * @return
+         *      If there's no parameter, null will be returned.
+         */
+        public JVar listVarParam() {
+                return varParam;
+        }
+
+        /**
+         * Returns true if the method has the specified signature.
+         */
+        public boolean hasSignature(JType[] argTypes) {
+                JVar[] p = listParams();
+                if (p.length != argTypes.length)
+                        return false;
+
+                for (int i = 0; i < p.length; i++)
+                        if (!p[i].type().equals(argTypes[i]))
+                                return false;
+
+                return true;
+        }
+
+        /**
+         * Get the block that makes up body of this method
+         *
+         * @return Body of method
+         */
+        public JBlock body() {
+                if (body == null)
+                        body = new JBlock();
+                return body;
+        }
+
+    /**
+     * Specify the default value for this annotation member
+     * @param value
+     *           Default value for the annotation member
+     *
+     */
+    public void declareDefaultValue(JExpression value){
+        this.defaultValue = value;
+    }
+
+        /**
+         * Creates, if necessary, and returns the class javadoc for this
+         * JDefinedClass
+         *
+         * @return JDocComment containing javadocs for this class
+         */
+        public JDocComment javadoc() {
+                if (jdoc == null)
+                        jdoc = new JDocComment(owner());
+                return jdoc;
+        }
+
+        public void declare(JFormatter f) {
+                if (jdoc != null)
+                        f.g(jdoc);
+
+        if (annotations != null){
+            for (JAnnotationUse a : annotations)
+                f.g(a).nl();
+        }
+
+                // declare the generics parameters
+                super.declare(f);
+
+                f.g(mods);
+                if (!isConstructor())
+                        f.g(type);
+                f.id(name).p('(').i();
+        // when parameters are printed in new lines, we want them to be indented.
+        // there's a good chance no newlines happen, too, but just in case it does.
+                boolean first = true;
+        for (JVar var : params) {
+            if (!first)
+                f.p(',');
+            if(var.isAnnotated())
+                f.nl();
+            f.b(var);
+            first = false;
+        }
+                if (hasVarArgs()) {
+                        if (!first)
+                                f.p(',');
+                        f.g(varParam.type().elementType());
+                        f.p("... ");
+                        f.id(varParam.name());
+                }
+
+                f.o().p(')');
+                if (_throws!=null && !_throws.isEmpty()) {
+                        f.nl().i().p("throws").g(_throws).nl().o();
+                }
+
+        if (defaultValue != null) {
+            f.p("default ");
+            f.g(defaultValue);
+        }
+                if (body != null) {
+                        f.s(body);
+                } else if (
+                        !outer.isInterface() && !outer.isAnnotationTypeDeclaration() && !mods.isAbstract() && !mods.isNative()) {
+                        // Print an empty body for non-native, non-abstract methods
+                        f.s(new JBlock());
+                } else {
+                        f.p(';').nl();
+                }
+        }
+
+    /**
+     * @return
+     *      the current modifiers of this method.
+     *      Always return non-null valid object.
+     */
+    public JMods mods() {
+        return mods;
+    }
+
+    /**
+     * @deprecated use {@link #mods()}
+     */
+    public JMods getMods() {
+                return mods;
+        }
+
+        protected JCodeModel owner() {
+                return outer.owner();
+        }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JMod.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JMod.java
new file mode 100644
index 0000000..0f32e76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JMod.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Modifier constants.
+ */
+public final class JMod {
+    public final static int NONE         = 0x000;
+    public final static int PUBLIC       = 0x001;
+    public final static int PROTECTED    = 0x002;
+    public final static int PRIVATE      = 0x004;
+    public final static int FINAL        = 0x008;
+    public final static int STATIC       = 0x010;
+    public final static int ABSTRACT     = 0x020;
+    public final static int NATIVE       = 0x040;
+    public final static int SYNCHRONIZED = 0x080;
+    public final static int TRANSIENT    = 0x100;
+    public final static int VOLATILE     = 0x200;
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JMods.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JMods.java
new file mode 100644
index 0000000..daf5b85
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JMods.java
@@ -0,0 +1,147 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.io.PrintWriter;
+import java.io.StringWriter;
+
+
+/**
+ * Modifier groups.
+ */
+public class JMods implements JGenerable {
+
+//
+// mask
+//
+    private static int VAR
+        = JMod.FINAL;
+
+    private static int FIELD
+        = (JMod.PUBLIC | JMod.PRIVATE | JMod.PROTECTED
+           | JMod.STATIC | JMod.FINAL
+           | JMod.TRANSIENT | JMod.VOLATILE);
+
+    private static int METHOD
+        = (JMod.PUBLIC | JMod.PRIVATE | JMod.PROTECTED | JMod.FINAL
+           | JMod.ABSTRACT | JMod.STATIC | JMod.NATIVE | JMod.SYNCHRONIZED);
+
+    private static int CLASS
+        = (JMod.PUBLIC | JMod.PRIVATE | JMod.PROTECTED
+           | JMod.STATIC | JMod.FINAL | JMod.ABSTRACT );
+
+    private static int INTERFACE = JMod.PUBLIC;
+
+    /** bit-packed representation of modifiers. */
+    private int mods;
+
+    private JMods(int mods) {
+        this.mods = mods;
+    }
+
+    /**
+     * Gets the bit-packed representaion of modifiers.
+     */
+    public int getValue() {
+        return mods;
+    }
+
+    private static void check(int mods, int legal, String what) {
+        if ((mods & ~legal) != 0)
+            throw new IllegalArgumentException("Illegal modifiers for "
+                    + what + ": "
+                    + new JMods(mods).toString());
+        /* ## check for illegal combinations too */
+    }
+
+    static JMods forVar(int mods) {
+        check(mods, VAR, "variable");
+        return new JMods(mods);
+    }
+
+    static JMods forField(int mods) {
+        check(mods, FIELD, "field");
+        return new JMods(mods);
+    }
+
+    static JMods forMethod(int mods) {
+        check(mods, METHOD, "method");
+        return new JMods(mods);
+    }
+
+    static JMods forClass(int mods) {
+        check(mods, CLASS, "class");
+        return new JMods(mods);
+    }
+
+    static JMods forInterface(int mods) {
+        check(mods, INTERFACE, "class");
+        return new JMods(mods);
+    }
+
+    public boolean isAbstract() {
+        return (mods & JMod.ABSTRACT) != 0;
+    }
+
+    public boolean isNative() {
+        return (mods & JMod.NATIVE) != 0;
+    }
+
+    public boolean isSynchronized() {
+        return (mods & JMod.SYNCHRONIZED) != 0;
+    }
+
+    public void setSynchronized(boolean newValue) {
+        setFlag( JMod.SYNCHRONIZED, newValue );
+    }
+
+    // TODO: more
+
+    private void setFlag( int bit, boolean newValue ) {
+        mods = (mods & ~bit) | (newValue?bit:0);
+    }
+
+    public void generate(JFormatter f) {
+        if ((mods & JMod.PUBLIC) != 0)        f.p("public");
+        if ((mods & JMod.PROTECTED) != 0)     f.p("protected");
+        if ((mods & JMod.PRIVATE) != 0)       f.p("private");
+        if ((mods & JMod.FINAL) != 0)         f.p("final");
+        if ((mods & JMod.STATIC) != 0)        f.p("static");
+        if ((mods & JMod.ABSTRACT) != 0)      f.p("abstract");
+        if ((mods & JMod.NATIVE) != 0)        f.p("native");
+        if ((mods & JMod.SYNCHRONIZED) != 0)  f.p("synchronized");
+        if ((mods & JMod.TRANSIENT) != 0)     f.p("transient");
+        if ((mods & JMod.VOLATILE) != 0)      f.p("volatile");
+    }
+
+    public String toString() {
+        StringWriter s = new StringWriter();
+        JFormatter f = new JFormatter(new PrintWriter(s));
+        this.generate(f);
+        return s.toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JNarrowedClass.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JNarrowedClass.java
new file mode 100644
index 0000000..dc136f4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JNarrowedClass.java
@@ -0,0 +1,217 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.Iterator;
+import java.util.List;
+import java.util.Collections;
+import java.util.ArrayList;
+
+/**
+ * Represents X&lt;Y>.
+ *
+ * TODO: consider separating the decl and the use.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class JNarrowedClass extends JClass {
+    /**
+     * A generic class with type parameters.
+     */
+    final JClass basis;
+    /**
+     * Arguments to those parameters.
+     */
+    private final List<JClass> args;
+
+    JNarrowedClass(JClass basis, JClass arg) {
+        this(basis,Collections.singletonList(arg));
+    }
+
+    JNarrowedClass(JClass basis, List<JClass> args) {
+        super(basis.owner());
+        this.basis = basis;
+        assert !(basis instanceof JNarrowedClass);
+        this.args = args;
+    }
+
+    public JClass narrow( JClass clazz ) {
+        List<JClass> newArgs = new ArrayList<JClass>(args);
+        newArgs.add(clazz);
+        return new JNarrowedClass(basis,newArgs);
+    }
+
+    public JClass narrow( JClass... clazz ) {
+        List<JClass> newArgs = new ArrayList<JClass>(args);
+        for (JClass c : clazz)
+            newArgs.add(c);
+        return new JNarrowedClass(basis,newArgs);
+    }
+
+    public String name() {
+        StringBuffer buf = new StringBuffer();
+        buf.append(basis.name());
+        buf.append('<');
+        boolean first = true;
+        for (JClass c : args) {
+            if(first)
+                first = false;
+            else
+                buf.append(',');
+            buf.append(c.name());
+        }
+        buf.append('>');
+        return buf.toString();
+    }
+
+    public String fullName() {
+        StringBuilder buf = new StringBuilder();
+        buf.append(basis.fullName());
+        buf.append('<');
+        boolean first = true;
+        for (JClass c : args) {
+            if(first)
+                first = false;
+            else
+                buf.append(',');
+            buf.append(c.fullName());
+        }
+        buf.append('>');
+        return buf.toString();
+    }
+
+    public String binaryName() {
+        StringBuilder buf = new StringBuilder();
+        buf.append(basis.binaryName());
+        buf.append('<');
+        boolean first = true;
+        for (JClass c : args) {
+            if(first)
+                first = false;
+            else
+                buf.append(',');
+            buf.append(c.binaryName());
+        }
+        buf.append('>');
+        return buf.toString();
+    }
+
+    public void generate(JFormatter f) {
+        f.t(basis).p('<').g(args).p(JFormatter.CLOSE_TYPE_ARGS);
+    }
+
+    @Override
+    void printLink(JFormatter f) {
+        basis.printLink(f);
+        f.p("{@code <}");
+        boolean first = true;
+        for( JClass c : args ) {
+            if(first)
+                first = false;
+            else
+                f.p(',');
+            c.printLink(f);
+        }
+        f.p("{@code >}");
+    }
+
+    public JPackage _package() {
+        return basis._package();
+    }
+
+    public JClass _extends() {
+        JClass base = basis._extends();
+        if(base==null)  return base;
+        return base.substituteParams(basis.typeParams(),args);
+    }
+
+    public Iterator<JClass> _implements() {
+        return new Iterator<JClass>() {
+            private final Iterator<JClass> core = basis._implements();
+            public void remove() {
+                core.remove();
+            }
+            public JClass next() {
+                return core.next().substituteParams(basis.typeParams(),args);
+            }
+            public boolean hasNext() {
+                return core.hasNext();
+            }
+        };
+    }
+
+    public JClass erasure() {
+        return basis;
+    }
+
+    public boolean isInterface() {
+        return basis.isInterface();
+    }
+
+    public boolean isAbstract() {
+        return basis.isAbstract();
+    }
+
+    public boolean isArray() {
+        return false;
+    }
+
+
+    //
+    // Equality is based on value
+    //
+
+    public boolean equals(Object obj) {
+        if(!(obj instanceof JNarrowedClass))   return false;
+        return fullName().equals(((JClass)obj).fullName());
+    }
+
+    public int hashCode() {
+        return fullName().hashCode();
+    }
+
+    protected JClass substituteParams(JTypeVar[] variables, List<JClass> bindings) {
+        JClass b = basis.substituteParams(variables,bindings);
+        boolean different = b!=basis;
+
+        List<JClass> clazz = new ArrayList<JClass>(args.size());
+        for( int i=0; i<clazz.size(); i++ ) {
+            JClass c = args.get(i).substituteParams(variables,bindings);
+            clazz.set(i,c);
+            different |= c != args.get(i);
+        }
+
+        if(different)
+            return new JNarrowedClass(b,clazz);
+        else
+            return this;
+    }
+
+    public List<JClass> getTypeParameters() {
+        return args;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JNullType.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JNullType.java
new file mode 100644
index 0000000..7be3c06
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JNullType.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.Collections;
+import java.util.Iterator;
+import java.util.List;
+
+/**
+ * Special class object that represents the type of "null".
+ *
+ * <p>
+ * Use this class with care.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class JNullType extends JClass {
+
+    JNullType(JCodeModel _owner) {
+        super(_owner);
+    }
+
+    public String name() { return "null"; }
+    public String fullName() { return "null"; }
+
+    public JPackage _package() { return owner()._package(""); }
+
+    public JClass _extends() { return null; }
+
+    public Iterator<JClass> _implements() {
+        return Collections.<JClass>emptyList().iterator();
+    }
+
+    public boolean isInterface() { return false; }
+    public boolean isAbstract() { return false; }
+
+    protected JClass substituteParams(JTypeVar[] variables, List<JClass> bindings) {
+        return this;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JOp.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JOp.java
new file mode 100644
index 0000000..cd43654
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JOp.java
@@ -0,0 +1,254 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * JClass for generating expressions containing operators
+ */
+
+abstract public class JOp {
+
+    private JOp() {
+    }
+
+
+    /**
+     * Determine whether the top level of an expression involves an
+     * operator.
+     */
+    static boolean hasTopOp(JExpression e) {
+        return (e instanceof UnaryOp) || (e instanceof BinaryOp);
+    }
+
+    /* -- Unary operators -- */
+
+    static private class UnaryOp extends JExpressionImpl {
+
+        protected String op;
+        protected JExpression e;
+        protected boolean opFirst = true;
+
+        UnaryOp(String op, JExpression e) {
+            this.op = op;
+            this.e = e;
+        }
+
+        UnaryOp(JExpression e, String op) {
+            this.op = op;
+            this.e = e;
+            opFirst = false;
+        }
+
+        public void generate(JFormatter f) {
+            if (opFirst)
+                f.p('(').p(op).g(e).p(')');
+            else
+                f.p('(').g(e).p(op).p(')');
+        }
+
+    }
+
+    public static JExpression minus(JExpression e) {
+        return new UnaryOp("-", e);
+    }
+
+    /**
+     * Logical not <tt>'!x'</tt>.
+     */
+    public static JExpression not(JExpression e) {
+        if (e == JExpr.TRUE) return JExpr.FALSE;
+        if (e == JExpr.FALSE) return JExpr.TRUE;
+        return new UnaryOp("!", e);
+    }
+
+    public static JExpression complement(JExpression e) {
+        return new UnaryOp("~", e);
+    }
+
+    static private class TightUnaryOp extends UnaryOp {
+
+        TightUnaryOp(JExpression e, String op) {
+            super(e, op);
+        }
+
+        public void generate(JFormatter f) {
+            if (opFirst)
+                f.p(op).g(e);
+            else
+                f.g(e).p(op);
+        }
+
+    }
+
+    public static JExpression incr(JExpression e) {
+        return new TightUnaryOp(e, "++");
+    }
+
+    public static JExpression decr(JExpression e) {
+        return new TightUnaryOp(e, "--");
+    }
+
+
+    /* -- Binary operators -- */
+
+    static private class BinaryOp extends JExpressionImpl {
+
+        String op;
+        JExpression left;
+        JGenerable right;
+
+        BinaryOp(String op, JExpression left, JGenerable right) {
+            this.left = left;
+            this.op = op;
+            this.right = right;
+        }
+
+        public void generate(JFormatter f) {
+            f.p('(').g(left).p(op).g(right).p(')');
+        }
+
+    }
+
+    public static JExpression plus(JExpression left, JExpression right) {
+        return new BinaryOp("+", left, right);
+    }
+
+    public static JExpression minus(JExpression left, JExpression right) {
+        return new BinaryOp("-", left, right);
+    }
+
+    public static JExpression mul(JExpression left, JExpression right) {
+        return new BinaryOp("*", left, right);
+    }
+
+    public static JExpression div(JExpression left, JExpression right) {
+        return new BinaryOp("/", left, right);
+    }
+
+    public static JExpression mod(JExpression left, JExpression right) {
+        return new BinaryOp("%", left, right);
+    }
+
+    public static JExpression shl(JExpression left, JExpression right) {
+        return new BinaryOp("<<", left, right);
+    }
+
+    public static JExpression shr(JExpression left, JExpression right) {
+        return new BinaryOp(">>", left, right);
+    }
+
+    public static JExpression shrz(JExpression left, JExpression right) {
+        return new BinaryOp(">>>", left, right);
+    }
+
+    public static JExpression band(JExpression left, JExpression right) {
+        return new BinaryOp("&", left, right);
+    }
+
+    public static JExpression bor(JExpression left, JExpression right) {
+        return new BinaryOp("|", left, right);
+    }
+
+    public static JExpression cand(JExpression left, JExpression right) {
+        if (left == JExpr.TRUE) return right;
+        if (right == JExpr.TRUE) return left;
+        if (left == JExpr.FALSE) return left;    // JExpr.FALSE
+        if (right == JExpr.FALSE) return right;   // JExpr.FALSE
+        return new BinaryOp("&&", left, right);
+    }
+
+    public static JExpression cor(JExpression left, JExpression right) {
+        if (left == JExpr.TRUE) return left;    // JExpr.TRUE
+        if (right == JExpr.TRUE) return right;   // JExpr.FALSE
+        if (left == JExpr.FALSE) return right;
+        if (right == JExpr.FALSE) return left;
+        return new BinaryOp("||", left, right);
+    }
+
+    public static JExpression xor(JExpression left, JExpression right) {
+        return new BinaryOp("^", left, right);
+    }
+
+    public static JExpression lt(JExpression left, JExpression right) {
+        return new BinaryOp("<", left, right);
+    }
+
+    public static JExpression lte(JExpression left, JExpression right) {
+        return new BinaryOp("<=", left, right);
+    }
+
+    public static JExpression gt(JExpression left, JExpression right) {
+        return new BinaryOp(">", left, right);
+    }
+
+    public static JExpression gte(JExpression left, JExpression right) {
+        return new BinaryOp(">=", left, right);
+    }
+
+    public static JExpression eq(JExpression left, JExpression right) {
+        return new BinaryOp("==", left, right);
+    }
+
+    public static JExpression ne(JExpression left, JExpression right) {
+        return new BinaryOp("!=", left, right);
+    }
+
+    public static JExpression _instanceof(JExpression left, JType right) {
+        return new BinaryOp("instanceof", left, right);
+    }
+
+    /* -- Ternary operators -- */
+
+    static private class TernaryOp extends JExpressionImpl {
+
+        String op1;
+        String op2;
+        JExpression e1;
+        JExpression e2;
+        JExpression e3;
+
+        TernaryOp(String op1, String op2,
+                  JExpression e1, JExpression e2, JExpression e3) {
+            this.e1 = e1;
+            this.op1 = op1;
+            this.e2 = e2;
+            this.op2 = op2;
+            this.e3 = e3;
+        }
+
+        public void generate(JFormatter f) {
+            f.p('(').g(e1).p(op1).g(e2).p(op2).g(e3).p(')');
+        }
+
+    }
+
+    public static JExpression cond(JExpression cond,
+                                   JExpression ifTrue, JExpression ifFalse) {
+        return new TernaryOp("?", ":", cond, ifTrue, ifFalse);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JPackage.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JPackage.java
new file mode 100644
index 0000000..76b0252
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JPackage.java
@@ -0,0 +1,492 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.io.BufferedOutputStream;
+import java.io.BufferedWriter;
+import java.io.File;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.PrintWriter;
+import java.io.Writer;
+import java.lang.annotation.Annotation;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeMap;
+
+
+/**
+ * A Java package.
+ */
+public final class JPackage implements JDeclaration, JGenerable, JClassContainer, JAnnotatable, Comparable<JPackage> {
+
+    /**
+     * Name of the package.
+     * May be the empty string for the root package.
+     */
+    private String name;
+
+    private final JCodeModel owner;
+
+    /**
+     * List of classes contained within this package keyed by their name.
+     */
+    private final Map<String,JDefinedClass> classes = new TreeMap<String,JDefinedClass>();
+
+    /**
+     * List of resources files inside this package.
+     */
+    private final Set<JResourceFile> resources = new HashSet<JResourceFile>();
+
+    /**
+     * All {@link JClass}s in this package keyed the upper case class name.
+     *
+     * This field is non-null only on Windows, to detect
+     * "Foo" and "foo" as a collision.
+     */
+    private final Map<String,JDefinedClass> upperCaseClassMap;
+
+    /**
+     * Lazily created list of package annotations.
+     */
+    private List<JAnnotationUse> annotations = null;
+
+    /**
+     * package javadoc.
+     */
+    private JDocComment jdoc = null;
+
+    /**
+     * JPackage constructor
+     *
+     * @param name
+     *        Name of package
+     *
+     * @param  cw  The code writer being used to create this package
+     *
+     * @throws IllegalArgumentException
+     *         If each part of the package name is not a valid identifier
+     */
+    JPackage(String name, JCodeModel cw) {
+        this.owner = cw;
+        if (name.equals(".")) {
+            String msg = "JPackage name . is not allowed";
+            throw new IllegalArgumentException(msg);
+        }
+
+        int dots = 1;
+        for (int i = 0; i < name.length(); i++) {
+            char c = name.charAt(i);
+            if (c == '.') {
+                dots++;
+                continue;
+            }
+            if (dots > 1) {
+                String msg = "JPackage name " + name + " missing identifier";
+                throw new IllegalArgumentException(msg);
+            } else if (dots == 1 && !Character.isJavaIdentifierStart(c)) {
+                String msg =
+                    "JPackage name " + name + " contains illegal " + "character for beginning of identifier: " + c;
+                throw new IllegalArgumentException(msg);
+            } else if (!Character.isJavaIdentifierPart(c)) {
+                String msg = "JPackage name " + name + "contains illegal " + "character: " + c;
+                throw new IllegalArgumentException(msg);
+            }
+            dots = 0;
+        }
+        if (!name.trim().equals("") && dots != 0) {
+            String msg = "JPackage name not allowed to end with .";
+            throw new IllegalArgumentException(msg);
+        }
+
+        if(JCodeModel.isCaseSensitiveFileSystem)
+            upperCaseClassMap = null;
+        else
+            upperCaseClassMap = new HashMap<String,JDefinedClass>();
+
+        this.name = name;
+    }
+
+
+    public JClassContainer parentContainer() {
+        return parent();
+    }
+
+    /**
+     * Gets the parent package, or null if this class is the root package.
+     */
+    public JPackage parent() {
+        if(name.length()==0)    return null;
+
+        int idx = name.lastIndexOf('.');
+        return owner._package(name.substring(0,idx));
+    }
+
+    public boolean isClass() { return false; }
+    public boolean isPackage() { return true; }
+    public JPackage getPackage() { return this; }
+
+    /**
+     * Add a class to this package.
+     *
+     * @param mods
+     *        Modifiers for this class declaration
+     *
+     * @param name
+     *        Name of class to be added to this package
+     *
+     * @return Newly generated class
+     *
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+     */
+    public JDefinedClass _class(int mods, String name) throws JClassAlreadyExistsException {
+        return _class(mods,name,ClassType.CLASS);
+    }
+
+    /**
+     * {@inheritDoc}
+     * @deprecated
+     */
+    public JDefinedClass _class( int mods, String name, boolean isInterface ) throws JClassAlreadyExistsException {
+        return _class(mods,name, isInterface?ClassType.INTERFACE:ClassType.CLASS );
+    }
+
+    public JDefinedClass _class( int mods, String name, ClassType classTypeVal ) throws JClassAlreadyExistsException {
+        if(classes.containsKey(name))
+            throw new JClassAlreadyExistsException(classes.get(name));
+        else {
+            // XXX problems caught in the NC constructor
+            JDefinedClass c = new JDefinedClass(this, mods, name, classTypeVal);
+
+            if( upperCaseClassMap!=null ) {
+                JDefinedClass dc = upperCaseClassMap.get(name.toUpperCase());
+                if(dc!=null)
+                    throw new JClassAlreadyExistsException(dc);
+                upperCaseClassMap.put(name.toUpperCase(),c);
+            }
+            classes.put(name,c);
+            return c;
+        }
+    }
+
+        /**
+         * Adds a public class to this package.
+         */
+    public JDefinedClass _class(String name) throws JClassAlreadyExistsException {
+                return _class( JMod.PUBLIC, name );
+        }
+
+    /**
+     * Gets a reference to the already created {@link JDefinedClass}.
+     *
+     * @return null
+     *      If the class is not yet created.
+     */
+    public JDefinedClass _getClass(String name) {
+        if(classes.containsKey(name))
+            return classes.get(name);
+        else
+            return null;
+    }
+
+    /**
+     * Order is based on the lexicological order of the package name.
+     */
+    public int compareTo(JPackage that) {
+        return this.name.compareTo(that.name);
+    }
+
+    /**
+     * Add an interface to this package.
+     *
+     * @param mods
+     *        Modifiers for this interface declaration
+     *
+     * @param name
+     *        Name of interface to be added to this package
+     *
+     * @return Newly generated interface
+     */
+    public JDefinedClass _interface(int mods, String name) throws JClassAlreadyExistsException {
+        return _class(mods,name,ClassType.INTERFACE);
+    }
+
+    /**
+     * Adds a public interface to this package.
+     */
+    public JDefinedClass _interface(String name) throws JClassAlreadyExistsException {
+        return _interface(JMod.PUBLIC, name);
+    }
+
+    /**
+     * Add an annotationType Declaration to this package
+     * @param name
+     *      Name of the annotation Type declaration to be added to this package
+     * @return
+     *      newly created Annotation Type Declaration
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+
+     */
+    public JDefinedClass _annotationTypeDeclaration(String name) throws JClassAlreadyExistsException {
+        return _class (JMod.PUBLIC,name,ClassType.ANNOTATION_TYPE_DECL);
+    }
+
+    /**
+     * Add a public enum to this package
+     * @param name
+     *      Name of the enum to be added to this package
+     * @return
+     *      newly created Enum
+     * @exception JClassAlreadyExistsException
+     *      When the specified class/interface was already created.
+
+     */
+    public JDefinedClass _enum (String name) throws JClassAlreadyExistsException {
+        return _class (JMod.PUBLIC,name,ClassType.ENUM);
+    }
+    /**
+     * Adds a new resource file to this package.
+     */
+    public JResourceFile addResourceFile(JResourceFile rsrc) {
+        resources.add(rsrc);
+        return rsrc;
+    }
+
+    /**
+     * Checks if a resource of the given name exists.
+     */
+    public boolean hasResourceFile(String name) {
+        for (JResourceFile r : resources)
+            if (r.name().equals(name))
+                return true;
+        return false;
+    }
+
+    /**
+     * Iterates all resource files in this package.
+     */
+    public Iterator propertyFiles() {
+        return resources.iterator();
+    }
+
+    /**
+     * Creates, if necessary, and returns the package javadoc for this
+     * JDefinedClass.
+     *
+     * @return JDocComment containing javadocs for this class
+     */
+    public JDocComment javadoc() {
+        if (jdoc == null)
+            jdoc = new JDocComment(owner());
+        return jdoc;
+    }
+
+    /**
+     * Removes a class from this package.
+     */
+    public void remove(JClass c) {
+        if (c._package() != this)
+            throw new IllegalArgumentException(
+                "the specified class is not a member of this package," + " or it is a referenced class");
+
+        // note that c may not be a member of classes.
+        // this happens when someone is trying to remove a non generated class
+        classes.remove(c.name());
+        if (upperCaseClassMap != null)
+            upperCaseClassMap.remove(c.name().toUpperCase());
+    }
+
+    /**
+     * Reference a class within this package.
+     */
+    public JClass ref(String name) throws ClassNotFoundException {
+        if (name.indexOf('.') >= 0)
+            throw new IllegalArgumentException("JClass name contains '.': " + name);
+
+        String n = "";
+        if (!isUnnamed())
+            n = this.name + '.';
+        n += name;
+
+        return owner.ref(Class.forName(n));
+    }
+
+    /**
+     * Gets a reference to a sub package of this package.
+     */
+    public JPackage subPackage( String pkg ) {
+        if(isUnnamed())     return owner()._package(pkg);
+        else                return owner()._package(name+'.'+pkg);
+    }
+
+    /**
+     * Returns an iterator that walks the top-level classes defined in this
+     * package.
+     */
+    public Iterator<JDefinedClass> classes() {
+        return classes.values().iterator();
+    }
+
+    /**
+     * Checks if a given name is already defined as a class/interface
+     */
+    public boolean isDefined(String classLocalName) {
+        Iterator itr = classes();
+        while (itr.hasNext()) {
+            if (((JClass)itr.next()).name().equals(classLocalName))
+                return true;
+        }
+
+        return false;
+    }
+
+    /**
+     * Checks if this package is the root, unnamed package.
+     */
+    public final boolean isUnnamed() { return name.length() == 0; }
+
+    /**
+     * Get the name of this package
+     *
+     * @return
+     *          The name of this package, or the empty string if this is the
+     *          null package. For example, this method returns strings like
+     *          <code>"java.lang"</code>
+     */
+    public String name() {
+        return name;
+    }
+
+    /**
+     * Return the code model root object being used to create this package.
+     */
+    public final JCodeModel owner() { return owner; }
+
+
+    public JAnnotationUse annotate(JClass clazz) {
+        if(isUnnamed())
+            throw new IllegalArgumentException("the root package cannot be annotated");
+        if(annotations==null)
+           annotations = new ArrayList<JAnnotationUse>();
+        JAnnotationUse a = new JAnnotationUse(clazz);
+        annotations.add(a);
+        return a;
+    }
+
+    public JAnnotationUse annotate(Class<? extends Annotation> clazz) {
+        return annotate(owner.ref(clazz));
+    }
+
+    public <W extends JAnnotationWriter> W annotate2(Class<W> clazz) {
+        return TypedAnnotationWriter.create(clazz,this);
+    }
+
+
+    /**
+     * Convert the package name to directory path equivalent
+     */
+    File toPath(File dir) {
+        if (name == null) return dir;
+        return new File(dir, name.replace('.', File.separatorChar));
+    }
+
+    public void declare(JFormatter f ) {
+        if (name.length() != 0)
+            f.p("package").p(name).p(';').nl();
+    }
+
+    public void generate(JFormatter f) {
+        f.p(name);
+    }
+
+
+    void build( CodeWriter src, CodeWriter res ) throws IOException {
+
+        // write classes
+        for (JDefinedClass c : classes.values()) {
+            if (c.isHidden())
+                continue;   // don't generate this file
+
+            JFormatter f = createJavaSourceFileWriter(src, c.name());
+            f.write(c);
+            f.close();
+        }
+
+        // write package annotations
+        if(annotations!=null || jdoc!=null) {
+            JFormatter f = createJavaSourceFileWriter(src,"package-info");
+
+            if (jdoc != null)
+                f.g(jdoc);
+
+            // TODO: think about importing
+            if (annotations != null){
+                for (JAnnotationUse a : annotations)
+                    f.g(a).nl();
+            }
+            f.d(this);
+
+            f.close();
+        }
+
+        // write resources
+        for (JResourceFile rsrc : resources) {
+            CodeWriter cw = rsrc.isResource() ? res : src;
+            OutputStream os = new BufferedOutputStream(cw.openBinary(this, rsrc.name()));
+            rsrc.build(os);
+            os.close();
+        }
+    }
+
+    /*package*/ int countArtifacts() {
+        int r = 0;
+        for (JDefinedClass c : classes.values()) {
+            if (c.isHidden())
+                continue;   // don't generate this file
+            r++;
+        }
+
+        if(annotations!=null || jdoc!=null) {
+            r++;
+        }
+
+        r+= resources.size();
+
+        return r;
+    }
+
+    private JFormatter createJavaSourceFileWriter(CodeWriter src, String className) throws IOException {
+        Writer bw = new BufferedWriter(src.openSource(this,className+".java"));
+        return new JFormatter(new PrintWriter(bw));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JPrimitiveType.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JPrimitiveType.java
new file mode 100644
index 0000000..8e6fbfe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JPrimitiveType.java
@@ -0,0 +1,123 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Java built-in primitive types.
+ *
+ * Instances of this class can be obtained as constants of {@link JCodeModel},
+ * such as {@link JCodeModel#BOOLEAN}.
+ */
+public final class JPrimitiveType extends JType {
+
+    private final String typeName;
+    private final JCodeModel owner;
+    /**
+     * Corresponding wrapper class.
+     * For example, this would be "java.lang.Short" for short.
+     */
+    private final JClass wrapperClass;
+
+    JPrimitiveType(JCodeModel owner, String typeName, Class wrapper ) {
+        this.owner = owner;
+        this.typeName = typeName;
+        this.wrapperClass = owner.ref(wrapper);
+    }
+
+    public JCodeModel owner() { return owner; }
+
+    public String fullName() {
+        return typeName;
+    }
+
+    public String name() {
+        return fullName();
+    }
+
+    public boolean isPrimitive() {
+        return true;
+    }
+
+    private JClass arrayClass;
+    public JClass array() {
+        if(arrayClass==null)
+            arrayClass = new JArrayClass(owner,this);
+        return arrayClass;
+    }
+
+    /**
+     * Obtains the wrapper class for this primitive type.
+     * For example, this method returns a reference to java.lang.Integer
+     * if this object represents int.
+     */
+    public JClass boxify() {
+        return wrapperClass;
+    }
+
+    /**
+     * @deprecated calling this method from {@link JPrimitiveType}
+     * would be meaningless, since it's always guaranteed to
+     * return <tt>this</tt>.
+     */
+    public JType unboxify() {
+        return this;
+    }
+
+    /**
+     * @deprecated
+     *      Use {@link #boxify()}.
+     */
+    public JClass getWrapperClass() {
+        return boxify();
+    }
+
+    /**
+     * Wraps an expression of this type to the corresponding wrapper class.
+     * For example, if this class represents "float", this method will return
+     * the expression <code>new Float(x)</code> for the paramter x.
+     *
+     * REVISIT: it's not clear how this method works for VOID.
+     */
+    public JExpression wrap( JExpression exp ) {
+        return JExpr._new(boxify()).arg(exp);
+    }
+
+    /**
+     * Do the opposite of the wrap method.
+     *
+     * REVISIT: it's not clear how this method works for VOID.
+     */
+    public JExpression unwrap( JExpression exp ) {
+        // it just so happens that the unwrap method is always
+        // things like "intValue" or "booleanValue".
+        return exp.invoke(typeName+"Value");
+    }
+
+    public void generate(JFormatter f) {
+        f.p(typeName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JResourceFile.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JResourceFile.java
new file mode 100644
index 0000000..d1e0925
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JResourceFile.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.io.IOException;
+import java.io.OutputStream;
+
+/**
+ * Represents a resource file in the application-specific file format.
+ */
+public abstract class JResourceFile {
+
+    private final String name;
+
+    protected JResourceFile( String name ) {
+        this.name = name;
+    }
+
+    /**
+     * Gets the name of this property file
+     */
+    public String name() {
+        return name;
+    }
+
+    /**
+     * Returns true if this file should be generated into the directory
+     * that the resource files go into.
+     *
+     * <p>
+     * Returns false if this file should be generated into the directory
+     * where other source files go.
+     */
+    protected boolean isResource() {
+        return true;
+    }
+
+    /**
+     * called by JPackage to produce the file image.
+     */
+    protected abstract void build( OutputStream os ) throws IOException;
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JReturn.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JReturn.java
new file mode 100644
index 0000000..7df5214
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JReturn.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * A return statement
+ */
+class JReturn implements JStatement {
+
+    /**
+     * JExpression to return; may be null.
+     */
+    private JExpression expr;
+
+    /**
+     * JReturn constructor
+     *
+     * @param expr
+     *        JExpression which evaluates to return value
+     */
+    JReturn(JExpression expr) {
+       this.expr = expr;
+    }
+
+    public void state(JFormatter f) {
+        f.p("return ");
+        if (expr != null) f.g(expr);
+        f.p(';').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JStatement.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JStatement.java
new file mode 100644
index 0000000..51a9492
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JStatement.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * Common interface for code components that can generate
+ * uses of themselves as statements.
+ */
+
+public interface JStatement {
+
+    public void state(JFormatter f);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JStringLiteral.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JStringLiteral.java
new file mode 100644
index 0000000..6178a58
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JStringLiteral.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+/**
+ * String literal.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JStringLiteral extends JExpressionImpl {
+
+    public final String str;
+
+
+    JStringLiteral(String what) {
+        this.str = what;
+
+    }
+
+
+    public void generate(JFormatter f) {
+        f.p(JExpr.quotify('"', str));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JSwitch.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JSwitch.java
new file mode 100644
index 0000000..1bb0bdb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JSwitch.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+/**
+ * Switch statement
+ */
+public final class JSwitch implements JStatement {
+
+    /**
+     * Test part of switch statement.
+     */
+    private JExpression test;
+
+    /**
+     * vector of JCases.
+     */
+    private List<JCase> cases = new ArrayList<JCase>();
+
+    /**
+     * a single default case
+     */
+    private JCase defaultCase = null;
+
+    /**
+     * Construct a While statment
+     */
+    JSwitch(JExpression test) {
+        this.test = test;
+    }
+
+    public JExpression test() { return test; }
+
+    public Iterator cases() { return cases.iterator(); }
+
+    public JCase _case( JExpression label ) {
+        JCase c = new JCase( label );
+        cases.add(c);
+        return c;
+    }
+
+    public JCase _default() {
+        // what if (default != null) ???
+
+        // default cases statements don't have a label
+        defaultCase = new JCase(null, true);
+        return defaultCase;
+    }
+
+    public void state(JFormatter f) {
+        if (JOp.hasTopOp(test)) {
+            f.p("switch ").g(test).p(" {").nl();
+        } else {
+            f.p("switch (").g(test).p(')').p(" {").nl();
+        }
+        for( JCase c : cases )
+            f.s(c);
+        if( defaultCase != null )
+            f.s( defaultCase );
+        f.p('}').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JThrow.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JThrow.java
new file mode 100644
index 0000000..7bf099f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JThrow.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * JThrow statement
+ */
+
+class JThrow implements JStatement {
+
+    /**
+     * JExpression to throw
+     */
+    private JExpression expr;
+
+    /**
+     * JThrow constructor
+     *
+     * @param expr
+     *        JExpression which evaluates to JThrow value
+     */
+    JThrow(JExpression expr) {
+       this.expr = expr;
+    }
+
+    public void state(JFormatter f) {
+        f.p("throw");
+        f.g(expr);
+        f.p(';').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JTryBlock.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JTryBlock.java
new file mode 100644
index 0000000..35cc1e5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JTryBlock.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.ArrayList;
+import java.util.List;
+
+
+/**
+ * Try statement with Catch and/or Finally clause
+ */
+
+public class JTryBlock implements JStatement {
+
+    private JBlock body = new JBlock();
+    private List<JCatchBlock> catches = new ArrayList<JCatchBlock>();
+    private JBlock _finally = null;
+
+    JTryBlock() {
+    }
+
+    public JBlock body() {
+        return body;
+    }
+
+    public JCatchBlock _catch(JClass exception) {
+        JCatchBlock cb = new JCatchBlock(exception);
+        catches.add(cb);
+        return cb;
+    }
+
+    public JBlock _finally() {
+        if (_finally == null) _finally = new JBlock();
+        return _finally;
+    }
+
+    public void state(JFormatter f) {
+        f.p("try").g(body);
+        for (JCatchBlock cb : catches)
+            f.g(cb);
+        if (_finally != null)
+            f.p("finally").g(_finally);
+        f.nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JType.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JType.java
new file mode 100644
index 0000000..489cc17
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JType.java
@@ -0,0 +1,182 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * A representation of a type in codeModel.
+ *
+ * A type is always either primitive ({@link JPrimitiveType}) or
+ * a reference type ({@link JClass}).
+ */
+public abstract class JType implements JGenerable, Comparable {
+
+    /**
+     * Obtains a reference to the primitive type object from a type name.
+     */
+    public static JPrimitiveType parse(JCodeModel codeModel, String typeName) {
+        if (typeName.equals("void"))
+            return codeModel.VOID;
+        else if (typeName.equals("boolean"))
+            return codeModel.BOOLEAN;
+        else if (typeName.equals("byte"))
+            return codeModel.BYTE;
+        else if (typeName.equals("short"))
+            return codeModel.SHORT;
+        else if (typeName.equals("char"))
+            return codeModel.CHAR;
+        else if (typeName.equals("int"))
+            return codeModel.INT;
+        else if (typeName.equals("float"))
+            return codeModel.FLOAT;
+        else if (typeName.equals("long"))
+            return codeModel.LONG;
+        else if (typeName.equals("double"))
+            return codeModel.DOUBLE;
+        else
+            throw new IllegalArgumentException("Not a primitive type: " + typeName);
+    }
+
+    /** Gets the owner code model object. */
+    public abstract JCodeModel owner();
+
+    /**
+     * Gets the full name of the type.
+     *
+     * See http://java.sun.com/docs/books/jls/second_edition/html/names.doc.html#25430 for the details.
+     *
+     * @return
+     *      Strings like "int", "java.lang.String",
+     *      "java.io.File[]". Never null.
+     */
+    public abstract String fullName();
+
+    /**
+     * Gets the binary name of the type.
+     *
+     * See http://java.sun.com/docs/books/jls/third_edition/html/binaryComp.html#44909
+     *
+     * @return
+     *      Name like "Foo$Bar", "int", "java.lang.String", "java.io.File[]". Never null.
+     */
+    public String binaryName() {
+        return fullName();
+    }
+
+    /**
+     * Gets the name of this type.
+     *
+     * @return
+     *     Names like "int", "void", "BigInteger".
+     */
+    public abstract String name();
+
+    /**
+     * Create an array type of this type.
+     *
+     * This method is undefined for primitive void type, which
+     * doesn't have any corresponding array representation.
+     *
+     * @return A {@link JClass} representing the array type
+     *         whose element type is this type
+     */
+    public abstract JClass array();
+
+    /** Tell whether or not this is an array type. */
+    public boolean isArray() {
+        return false;
+    }
+
+    /** Tell whether or not this is a built-in primitive type, such as int or void. */
+    public boolean isPrimitive() {
+        return false;
+    }
+
+    /**
+     * If this class is a primitive type, return the boxed class. Otherwise return <tt>this</tt>.
+     *
+     * <p>
+     * For example, for "int", this method returns "java.lang.Integer".
+     */
+    public abstract JClass boxify();
+
+    /**
+     * If this class is a wrapper type for a primitive, return the primitive type.
+     * Otherwise return <tt>this</tt>.
+     *
+     * <p>
+     * For example, for "java.lang.Integer", this method returns "int".
+     */
+    public abstract JType unboxify();
+
+    /**
+     * Returns the erasure of this type.
+     */
+    public JType erasure() {
+        return this;
+    }
+
+    /**
+     * Returns true if this is a referenced type.
+     */
+    public final boolean isReference() {
+        return !isPrimitive();
+    }
+
+    /**
+     * If this is an array, returns the component type of the array.
+     * (T of T[])
+     */
+    public JType elementType() {
+        throw new IllegalArgumentException("Not an array type");
+    }
+
+    public String toString() {
+        return this.getClass().getName()
+                + '(' + fullName() + ')';
+    }
+
+    /**
+     * Compare two JTypes by FQCN, giving sorting precedence to types
+     * that belong to packages java and javax over all others.
+     *
+     * This method is used to sort generated import statments in a
+     * conventional way for readability.
+     */
+    public int compareTo(Object o) {
+        final String rhs = ((JType)o).fullName();
+        boolean p = fullName().startsWith("java");
+        boolean q = rhs.startsWith("java");
+
+        if( p && !q ) {
+            return -1;
+        } else if( !p && q ) {
+            return 1;
+        } else {
+            return fullName().compareTo(rhs);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JTypeVar.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JTypeVar.java
new file mode 100644
index 0000000..ce9c8ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JTypeVar.java
@@ -0,0 +1,121 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.Iterator;
+import java.util.List;
+
+/**
+ * Type variable used to declare generics.
+ *
+ * @see JGenerifiable
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class JTypeVar extends JClass implements JDeclaration {
+
+    private final String name;
+
+    private JClass bound;
+
+    JTypeVar(JCodeModel owner, String _name) {
+        super(owner);
+        this.name = _name;
+    }
+
+    public String name() {
+        return name;
+    }
+
+    public String fullName() {
+        return name;
+    }
+
+    public JPackage _package() {
+        return null;
+    }
+
+    /**
+     * Adds a bound to this variable.
+     *
+     * @return  this
+     */
+    public JTypeVar bound( JClass c ) {
+        if(bound!=null)
+            throw new IllegalArgumentException("type variable has an existing class bound "+bound);
+        bound = c;
+        return this;
+    }
+
+    /**
+     * Returns the class bound of this variable.
+     *
+     * <p>
+     * If no bound is given, this method returns {@link Object}.
+     */
+    public JClass _extends() {
+        if(bound!=null)
+            return bound;
+        else
+            return owner().ref(Object.class);
+    }
+
+    /**
+     * Returns the interface bounds of this variable.
+     */
+    public Iterator<JClass> _implements() {
+        return bound._implements();
+    }
+
+    public boolean isInterface() {
+        return false;
+    }
+
+    public boolean isAbstract() {
+        return false;
+    }
+
+    /**
+     * Prints out the declaration of the variable.
+     */
+    public void declare(JFormatter f) {
+        f.id(name);
+        if(bound!=null)
+            f.p("extends").g(bound);
+    }
+
+
+    protected JClass substituteParams(JTypeVar[] variables, List<JClass> bindings) {
+        for(int i=0;i<variables.length;i++)
+            if(variables[i]==this)
+                return bindings.get(i);
+        return this;
+    }
+
+    public void generate(JFormatter f) {
+        f.id(name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JTypeWildcard.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JTypeWildcard.java
new file mode 100644
index 0000000..4bb2511
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JTypeWildcard.java
@@ -0,0 +1,109 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.util.Iterator;
+import java.util.List;
+
+/**
+ * Represents a wildcard type like "? extends Foo".
+ *
+ * <p>
+ * Instances of this class can be obtained from {@link JClass#wildcard()}
+ *
+ * TODO: extend this to cover "? super Integer".
+ *
+ * <p>
+ * Our modeling of types are starting to look really ugly.
+ * ideally it should have been done somewhat like APT,
+ * but it's too late now.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class JTypeWildcard extends JClass {
+
+    private final JClass bound;
+
+    JTypeWildcard(JClass bound) {
+        super(bound.owner());
+        this.bound = bound;
+    }
+
+    public String name() {
+        return "? extends "+bound.name();
+    }
+
+    public String fullName() {
+        return "? extends "+bound.fullName();
+    }
+
+    public JPackage _package() {
+        return null;
+    }
+
+    /**
+     * Returns the class bound of this variable.
+     *
+     * <p>
+     * If no bound is given, this method returns {@link Object}.
+     */
+    public JClass _extends() {
+        if(bound!=null)
+            return bound;
+        else
+            return owner().ref(Object.class);
+    }
+
+    /**
+     * Returns the interface bounds of this variable.
+     */
+    public Iterator<JClass> _implements() {
+        return bound._implements();
+    }
+
+    public boolean isInterface() {
+        return false;
+    }
+
+    public boolean isAbstract() {
+        return false;
+    }
+
+    protected JClass substituteParams(JTypeVar[] variables, List<JClass> bindings) {
+        JClass nb = bound.substituteParams(variables,bindings);
+        if(nb==bound)
+            return this;
+        else
+            return new JTypeWildcard(nb);
+    }
+
+    public void generate(JFormatter f) {
+        if(bound._extends()==null)
+            f.p("?");   // instead of "? extends Object"
+        else
+            f.p("? extends").g(bound);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JVar.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JVar.java
new file mode 100644
index 0000000..0a94f73
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JVar.java
@@ -0,0 +1,208 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.lang.annotation.Annotation;
+import java.util.ArrayList;
+import java.util.List;
+
+
+/**
+ * Variables and fields.
+ */
+
+public class JVar extends JExpressionImpl implements JDeclaration, JAssignmentTarget, JAnnotatable {
+
+    /**
+     * Modifiers.
+     */
+    private JMods mods;
+
+    /**
+     * JType of the variable
+     */
+    private JType type;
+
+    /**
+     * Name of the variable
+     */
+    private String name;
+
+    /**
+     * Initialization of the variable in its declaration
+     */
+    private JExpression init;
+
+    /**
+     * Annotations on this variable. Lazily created.
+     */
+    private List<JAnnotationUse> annotations = null;
+
+
+
+    /**
+     * JVar constructor
+     *
+     * @param type
+     *        Datatype of this variable
+     *
+     * @param name
+     *        Name of this variable
+     *
+     * @param init
+     *        Value to initialize this variable to
+     */
+    JVar(JMods mods, JType type, String name, JExpression init) {
+        this.mods = mods;
+        this.type = type;
+        this.name = name;
+        this.init = init;
+    }
+
+
+    /**
+     * Initialize this variable
+     *
+     * @param init
+     *        JExpression to be used to initialize this field
+     */
+    public JVar init(JExpression init) {
+        this.init = init;
+        return this;
+    }
+
+    /**
+     * Get the name of this variable
+     *
+     * @return Name of the variable
+     */
+    public String name() {
+        return name;
+    }
+
+    /**
+     * Changes the name of this variable.
+     */
+    public void name(String name) {
+        if(!JJavaName.isJavaIdentifier(name))
+            throw new IllegalArgumentException();
+        this.name = name;
+    }
+
+    /**
+     * Return the type of this variable.
+     * @return
+     *      always non-null.
+     */
+    public JType type() {
+        return type;
+    }
+
+    /**
+     * @return
+     *      the current modifiers of this method.
+     *      Always return non-null valid object.
+     */
+    public JMods mods() {
+        return mods;
+    }
+
+    /**
+     * Sets the type of this variable.
+     *
+     * @param newType
+     *      must not be null.
+     *
+     * @return
+     *      the old type value. always non-null.
+     */
+    public JType type(JType newType) {
+        JType r = type;
+        if(newType==null)
+            throw new IllegalArgumentException();
+        type = newType;
+        return r;
+    }
+
+
+    /**
+     * Adds an annotation to this variable.
+     * @param clazz
+     *          The annotation class to annotate the field with
+     */
+    public JAnnotationUse annotate(JClass clazz){
+        if(annotations==null)
+           annotations = new ArrayList<JAnnotationUse>();
+        JAnnotationUse a = new JAnnotationUse(clazz);
+        annotations.add(a);
+        return a;
+    }
+
+    /**
+     * Adds an annotation to this variable.
+     *
+     * @param clazz
+     *          The annotation class to annotate the field with
+     */
+    public JAnnotationUse annotate(Class <? extends Annotation> clazz){
+        return annotate(type.owner().ref(clazz));
+    }
+
+    public <W extends JAnnotationWriter> W annotate2(Class<W> clazz) {
+        return TypedAnnotationWriter.create(clazz,this);
+    }
+
+    protected boolean isAnnotated() {
+        return annotations!=null;
+    }
+
+    public void bind(JFormatter f) {
+        if (annotations != null){
+            for( int i=0; i<annotations.size(); i++ )
+                f.g(annotations.get(i)).nl();
+        }
+        f.g(mods).g(type).id(name);
+        if (init != null)
+            f.p('=').g(init);
+    }
+
+    public void declare(JFormatter f) {
+        f.b(this).p(';').nl();
+    }
+
+    public void generate(JFormatter f) {
+        f.id(name);
+    }
+
+
+    public JExpression assign(JExpression rhs) {
+                return JExpr.assign(this,rhs);
+    }
+    public JExpression assignPlus(JExpression rhs) {
+                return JExpr.assignPlus(this,rhs);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/JWhileLoop.java b/jaxws/src/share/classes/com/sun/codemodel/internal/JWhileLoop.java
new file mode 100644
index 0000000..4c67388
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/JWhileLoop.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+
+/**
+ * While statement
+ */
+
+public class JWhileLoop implements JStatement {
+
+    /**
+     * Test part of While statement for determining exit state
+     */
+    private JExpression test;
+
+    /**
+     * JBlock of statements which makes up body of this While statement
+     */
+    private JBlock body = null;
+
+    /**
+     * Construct a While statment
+     */
+    JWhileLoop(JExpression test) {
+        this.test = test;
+    }
+
+    public JExpression test() {
+        return test;
+    }
+
+    public JBlock body() {
+        if (body == null) body = new JBlock();
+        return body;
+    }
+
+    public void state(JFormatter f) {
+        if (JOp.hasTopOp(test)) {
+            f.p("while ").g(test);
+        } else {
+            f.p("while (").g(test).p(')');
+        }
+        if (body != null)
+            f.s(body);
+        else
+            f.p(';').nl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/TypedAnnotationWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/TypedAnnotationWriter.java
new file mode 100644
index 0000000..11fa7e3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/TypedAnnotationWriter.java
@@ -0,0 +1,246 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal;
+
+import java.lang.reflect.InvocationHandler;
+import java.lang.reflect.Method;
+import java.lang.reflect.Proxy;
+import java.lang.reflect.Type;
+import java.lang.reflect.ParameterizedType;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.annotation.Annotation;
+import java.util.Map;
+import java.util.HashMap;
+
+/**
+ * Dynamically implements the typed annotation writer interfaces.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class TypedAnnotationWriter<A extends Annotation,W extends JAnnotationWriter<A>>
+    implements InvocationHandler, JAnnotationWriter<A> {
+    /**
+     * This is what we are writing to.
+     */
+    private final JAnnotationUse use;
+
+    /**
+     * The annotation that we are writing.
+     */
+    private final Class<A> annotation;
+
+    /**
+     * The type of the writer.
+     */
+    private final Class<W> writerType;
+
+    /**
+     * Keeps track of writers for array members.
+     * Lazily created.
+     */
+    private Map<String,JAnnotationArrayMember> arrays;
+
+    public TypedAnnotationWriter(Class<A> annotation, Class<W> writer, JAnnotationUse use) {
+        this.annotation = annotation;
+        this.writerType = writer;
+        this.use = use;
+    }
+
+    public JAnnotationUse getAnnotationUse() {
+        return use;
+    }
+
+    public Class<A> getAnnotationType() {
+        return annotation;
+    }
+
+    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
+
+        if(method.getDeclaringClass()==JAnnotationWriter.class) {
+            try {
+                return method.invoke(this,args);
+            } catch (InvocationTargetException e) {
+                throw e.getTargetException();
+            }
+        }
+
+        String name = method.getName();
+        Object arg=null;
+        if(args!=null && args.length>0)
+            arg = args[0];
+
+        // check how it's defined on the annotation
+        Method m = annotation.getDeclaredMethod(name);
+        Class<?> rt = m.getReturnType();
+
+        // array value
+        if(rt.isArray()) {
+            return addArrayValue(proxy,name,rt.getComponentType(),method.getReturnType(),arg);
+        }
+
+        // sub annotation
+        if(Annotation.class.isAssignableFrom(rt)) {
+            Class<? extends Annotation> r = (Class<? extends Annotation>)rt;
+            return new TypedAnnotationWriter(
+                r,method.getReturnType(),use.annotationParam(name,r)).createProxy();
+        }
+
+        // scalar value
+
+        if(arg instanceof JType) {
+            JType targ = (JType) arg;
+            checkType(Class.class,rt);
+            if(m.getDefaultValue()!=null) {
+                // check the default
+                if(targ.equals(targ.owner().ref((Class)m.getDefaultValue())))
+                    return proxy;   // defaulted
+            }
+            use.param(name,targ);
+            return proxy;
+        }
+
+        // other Java built-in types
+        checkType(arg.getClass(),rt);
+        if(m.getDefaultValue()!=null && m.getDefaultValue().equals(arg))
+            // defaulted. no need to write out.
+            return proxy;
+
+        if(arg instanceof String) {
+            use.param(name,(String)arg);
+            return proxy;
+        }
+        if(arg instanceof Boolean) {
+            use.param(name,(Boolean)arg);
+            return proxy;
+        }
+        if(arg instanceof Integer) {
+            use.param(name,(Integer)arg);
+            return proxy;
+        }
+        if(arg instanceof Class) {
+            use.param(name,(Class)arg);
+            return proxy;
+        }
+        if(arg instanceof Enum) {
+            use.param(name,(Enum)arg);
+            return proxy;
+        }
+
+        throw new IllegalArgumentException("Unable to handle this method call "+method.toString());
+    }
+
+    private Object addArrayValue(Object proxy,String name, Class itemType, Class expectedReturnType, Object arg) {
+        if(arrays==null)
+            arrays = new HashMap<String,JAnnotationArrayMember>();
+        JAnnotationArrayMember m = arrays.get(name);
+        if(m==null) {
+            m = use.paramArray(name);
+            arrays.put(name,m);
+        }
+
+        // sub annotation
+        if(Annotation.class.isAssignableFrom(itemType)) {
+            Class<? extends Annotation> r = (Class<? extends Annotation>)itemType;
+            if(!JAnnotationWriter.class.isAssignableFrom(expectedReturnType))
+                throw new IllegalArgumentException("Unexpected return type "+expectedReturnType);
+            return new TypedAnnotationWriter(r,expectedReturnType,m.annotate(r)).createProxy();
+        }
+
+        // primitive
+        if(arg instanceof JType) {
+            checkType(Class.class,itemType);
+            m.param((JType)arg);
+            return proxy;
+        }
+        checkType(arg.getClass(),itemType);
+        if(arg instanceof String) {
+            m.param((String)arg);
+            return proxy;
+        }
+        if(arg instanceof Boolean) {
+            m.param((Boolean)arg);
+            return proxy;
+        }
+        if(arg instanceof Integer) {
+            m.param((Integer)arg);
+            return proxy;
+        }
+        if(arg instanceof Class) {
+            m.param((Class)arg);
+            return proxy;
+        }
+        // TODO: enum constant. how should we handle it?
+
+        throw new IllegalArgumentException("Unable to handle this method call ");
+    }
+
+
+    /**
+     * Check if the type of the argument matches our expectation.
+     * If not, report an error.
+     */
+    private void checkType(Class actual, Class expected) {
+        if(expected==actual || expected.isAssignableFrom(actual))
+            return; // no problem
+
+        if( expected==JCodeModel.boxToPrimitive.get(actual) )
+            return; // no problem
+
+        throw new IllegalArgumentException("Expected "+expected+" but found "+actual);
+    }
+
+    /**
+     * Creates a proxy and returns it.
+     */
+    private W createProxy() {
+        return (W)Proxy.newProxyInstance(
+            writerType.getClassLoader(),new Class[]{writerType},this);
+    }
+
+    /**
+     * Creates a new typed annotation writer.
+     */
+    static <W extends JAnnotationWriter<?>> W create(Class<W> w, JAnnotatable annotatable) {
+        Class<? extends Annotation> a = findAnnotationType(w);
+        return (W)new TypedAnnotationWriter(a,w,annotatable.annotate(a)).createProxy();
+    }
+
+    private static Class<? extends Annotation> findAnnotationType(Class clazz) {
+        for( Type t : clazz.getGenericInterfaces()) {
+            if(t instanceof ParameterizedType) {
+                ParameterizedType p = (ParameterizedType) t;
+                if(p.getRawType()==JAnnotationWriter.class)
+                    return (Class<? extends Annotation>)p.getActualTypeArguments()[0];
+            }
+            if(t instanceof Class) {
+                // recurisve search
+                Class<? extends Annotation> r = findAnnotationType((Class)t);
+                if(r!=null)     return r;
+            }
+        }
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JBinaryFile.java b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JBinaryFile.java
new file mode 100644
index 0000000..f53937f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JBinaryFile.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.fmt;
+
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+
+import com.sun.codemodel.internal.JResourceFile;
+
+/**
+ * Allows the application to use OutputStream to define data
+ * that will be stored into a file.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class JBinaryFile extends JResourceFile {
+
+    private final ByteArrayOutputStream baos = new ByteArrayOutputStream();
+
+    public JBinaryFile( String name ) {
+        super(name);
+    }
+
+    /**
+     *
+     * @return
+     *      Data written to the returned output stream will be written
+     *      to the file.
+     */
+    public OutputStream getDataStore() {
+        return baos;
+    }
+
+    public void build(OutputStream os) throws IOException {
+        os.write( baos.toByteArray() );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JPropertyFile.java b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JPropertyFile.java
new file mode 100644
index 0000000..67c09b7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JPropertyFile.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.fmt;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.Properties;
+
+import com.sun.codemodel.internal.JResourceFile;
+
+/**
+ * A property file.
+ */
+public class JPropertyFile extends JResourceFile
+{
+    public JPropertyFile( String name ) {
+        super(name);
+    }
+
+    private final Properties data = new Properties();
+
+    /**
+     * Adds key/value pair into the property file.
+     * If you call this method twice with the same key,
+     * the old one is overriden by the new one.
+     */
+    public void add( String key, String value ) {
+        data.put(key,value);
+    }
+
+    // TODO: method to iterate values in data?
+    // TODO: should we rather expose Properties object directly via
+    // public Properties body() { return data; } ?
+
+    public void build( OutputStream out ) throws IOException {
+        data.store(out,null);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JSerializedObject.java b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JSerializedObject.java
new file mode 100644
index 0000000..68e8b8d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JSerializedObject.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.fmt;
+
+import java.io.IOException;
+import java.io.ObjectOutputStream;
+import java.io.OutputStream;
+
+import com.sun.codemodel.internal.JResourceFile;
+
+
+/**
+ * A simple class that takes an object and serializes it into a file
+ * in the parent package with the given name.
+ */
+public class JSerializedObject extends JResourceFile {
+
+    private final Object obj;
+
+    /**
+     * @exception   IOException
+     *      If the serialization fails, this exception is thrown
+     */
+    public JSerializedObject( String name, Object obj ) throws IOException {
+        super(name);
+        this.obj = obj;
+    }
+
+    /**
+     * called by JPackage to serialize the object
+     */
+    protected void build( OutputStream os ) throws IOException {
+        // serialize the obj into a ByteArrayOutputStream
+        ObjectOutputStream oos = new ObjectOutputStream(os);
+        oos.writeObject(obj);
+        oos.close();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JStaticFile.java b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JStaticFile.java
new file mode 100644
index 0000000..3c5d912
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JStaticFile.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.fmt;
+
+import java.io.DataInputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+
+import com.sun.codemodel.internal.JResourceFile;
+
+/**
+ * Allows an application to copy a resource file to the output.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class JStaticFile extends JResourceFile {
+
+    private final ClassLoader classLoader;
+    private final String resourceName;
+    private final boolean isResource;
+
+    public JStaticFile(String _resourceName) {
+        this(_resourceName,!_resourceName.endsWith(".java"));
+    }
+
+    public JStaticFile(String _resourceName,boolean isResource) {
+        this( JStaticFile.class.getClassLoader(), _resourceName, isResource );
+    }
+
+    /**
+     * @param isResource
+     *      false if this is a Java source file. True if this is other resource files.
+     */
+    public JStaticFile(ClassLoader _classLoader, String _resourceName, boolean isResource) {
+        super(_resourceName.substring(_resourceName.lastIndexOf('/')+1));
+        this.classLoader = _classLoader;
+        this.resourceName = _resourceName;
+        this.isResource = isResource;
+    }
+
+    protected boolean isResource() {
+        return isResource;
+    }
+
+    protected void build(OutputStream os) throws IOException {
+        DataInputStream dis = new DataInputStream(classLoader.getResourceAsStream(resourceName));
+
+        byte[] buf = new byte[256];
+        int sz;
+        while( (sz=dis.read(buf))>0 )
+            os.write(buf,0,sz);
+
+        dis.close();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JStaticJavaFile.java b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JStaticJavaFile.java
new file mode 100644
index 0000000..234b768
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JStaticJavaFile.java
@@ -0,0 +1,239 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.fmt;
+
+import java.io.BufferedReader;
+import java.io.BufferedWriter;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.PrintWriter;
+import java.net.URL;
+import java.text.ParseException;
+import java.util.Iterator;
+import java.util.List;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JResourceFile;
+import com.sun.codemodel.internal.JTypeVar;
+
+/**
+ * Statically generated Java soruce file.
+ *
+ * <p>
+ * This {@link JResourceFile} implementation will generate a Java source
+ * file by copying the source code from a resource.
+ * <p>
+ * While copying a resource, we look for a package declaration and
+ * replace it with the target package name. This allows the static Java
+ * source code to have an arbitrary package declaration.
+ * <p>
+ * You can also use the getJClass method to obtain a {@link JClass}
+ * object that represents the static file. This allows the client code
+ * to refer to the class from other CodeModel generated code.
+ * <p>
+ * Note that because we don't parse the static Java source code,
+ * the returned {@link JClass} object doesn't respond to methods like
+ * "isInterface" or "_extends",
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class JStaticJavaFile extends JResourceFile {
+
+    private final JPackage pkg;
+    private final String className;
+    private final URL source;
+    private final JStaticClass clazz;
+    private final LineFilter filter;
+
+    public JStaticJavaFile(JPackage _pkg, String className, String _resourceName) {
+        this( _pkg, className,
+            JStaticJavaFile.class.getClassLoader().getResource(_resourceName), null );
+    }
+
+    public JStaticJavaFile(JPackage _pkg, String _className, URL _source, LineFilter _filter ) {
+        super(_className+".java");
+        if(_source==null)   throw new NullPointerException();
+        this.pkg = _pkg;
+        this.clazz = new JStaticClass();
+        this.className = _className;
+        this.source = _source;
+        this.filter = _filter;
+    }
+
+    /**
+     * Returns a class object that represents a statically generated code.
+     */
+    public final JClass getJClass() {
+        return clazz;
+    }
+
+    protected boolean isResource() {
+        return false;
+    }
+
+    protected  void build(OutputStream os) throws IOException {
+        InputStream is = source.openStream();
+
+        BufferedReader r = new BufferedReader(new InputStreamReader(is));
+        PrintWriter w = new PrintWriter(new BufferedWriter(new OutputStreamWriter(os)));
+        LineFilter filter = createLineFilter();
+        int lineNumber=1;
+
+        try {
+            String line;
+            while((line=r.readLine())!=null) {
+                line = filter.process(line);
+                if(line!=null)
+                    w.println(line);
+                lineNumber++;
+            }
+        } catch( ParseException e ) {
+            throw new IOException("unable to process "+source+" line:"+lineNumber+"\n"+e.getMessage());
+        }
+
+        w.close();
+        r.close();
+    }
+
+    /**
+     * Creates a {@link LineFilter}.
+     * <p>
+     * A derived class can override this method to process
+     * the contents of the source file.
+     */
+    private LineFilter createLineFilter() {
+        // this filter replaces the package declaration.
+        LineFilter f = new LineFilter() {
+            public String process(String line) {
+                if(!line.startsWith("package ")) return line;
+
+                // replace package decl
+                if( pkg.isUnnamed() )
+                    return null;
+                else
+                    return "package "+pkg.name()+";";
+            }
+        };
+        if( filter!=null )
+            return new ChainFilter(filter,f);
+        else
+            return f;
+    }
+
+    /**
+     * Filter that alters the Java source code.
+     * <p>
+     * By implementing this interface, derived classes
+     * can modify the Java source file before it's written out.
+     */
+    public interface LineFilter {
+        /**
+         * @param line
+         *      a non-null valid String that corresponds to one line.
+         *      No '\n' included.
+         * @return
+         *      null to strip the line off. Otherwise the returned
+         *      String will be written out. Do not add '\n' at the end
+         *      of this string.
+         *
+         * @exception ParseException
+         *      when for some reason there's an error in the line.
+         */
+        String process(String line) throws ParseException;
+    }
+
+    /**
+     * A {@link LineFilter} that combines two {@link LineFilter}s.
+     */
+    public final static class ChainFilter implements LineFilter {
+        private final LineFilter first,second;
+        public ChainFilter( LineFilter first, LineFilter second ) {
+            this.first=first;
+            this.second=second;
+        }
+        public String process(String line) throws ParseException {
+            line = first.process(line);
+            if(line==null)  return null;
+            return second.process(line);
+        }
+    }
+
+
+    private class JStaticClass extends JClass {
+
+        private final JTypeVar[] typeParams;
+
+        JStaticClass() {
+            super(pkg.owner());
+            // TODO: allow those to be specified
+            typeParams = new JTypeVar[0];
+        }
+
+        public String name() {
+            return className;
+        }
+
+        public String fullName() {
+            if(pkg.isUnnamed())
+                return className;
+            else
+                return pkg.name()+'.'+className;
+        }
+
+        public JPackage _package() {
+            return pkg;
+        }
+
+        public JClass _extends() {
+            throw new UnsupportedOperationException();
+        }
+
+        public Iterator _implements() {
+            throw new UnsupportedOperationException();
+        }
+
+        public boolean isInterface() {
+            throw new UnsupportedOperationException();
+        }
+
+        public boolean isAbstract() {
+            throw new UnsupportedOperationException();
+        }
+
+        public JTypeVar[] typeParams() {
+            return typeParams;
+        }
+
+        protected JClass substituteParams(JTypeVar[] variables, List<JClass> bindings) {
+            return this;
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JTextFile.java b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JTextFile.java
new file mode 100644
index 0000000..ee9b629
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/JTextFile.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.fmt;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+
+import com.sun.codemodel.internal.JResourceFile;
+
+
+/**
+ * Simple text file.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JTextFile extends JResourceFile
+{
+    public JTextFile( String name ) {
+        super(name);
+    }
+
+    private String contents = null;
+
+    public void setContents( String _contents ) {
+        this.contents = _contents;
+    }
+
+    public void build( OutputStream out ) throws IOException {
+        Writer w = new OutputStreamWriter(out);
+        w.write(contents);
+        w.close();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/package.html b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/package.html
new file mode 100644
index 0000000..c5227a2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/fmt/package.html
@@ -0,0 +1,5 @@
+<HTML>
+<BODY>
+Various resource file formats (classes that implement <code>JResourceFile</code>).
+</BODY>
+</HTML>
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/package-info.java b/jaxws/src/share/classes/com/sun/codemodel/internal/package-info.java
new file mode 100644
index 0000000..45f2d5f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/package-info.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * <h1>Library for generating Java source code</h1>.
+ *
+ * <p>
+ * CodeModel is a library that allows you to generate Java source
+ * code in a type-safe fashion.
+ *
+ * <p>
+ * With CodeModel, you build the java source code by first building AST,
+ * then writing it out as text files that is Java source files.
+ * The AST looks like this:
+ *
+ * {@DotDiagram
+    digraph G {
+        cls1 [label="JDefinedClass"];
+        cls2 [label="JDefinedClass"];
+        JCodeModel -> cls1 [label="generated class"];
+        JCodeModel -> cls2 [label="generated class"];
+
+        m1 [label="JMethod"];
+        m2 [label="JMethod"];
+
+        cls1 -> m1;
+        cls1 -> m2;
+        cls1 -> JField;
+
+        m1 -> JVar [label="method parameter"];
+        m1 -> JBlock [label="code"];
+    }
+ * }
+ *
+ * <p>
+ * You bulid this tree mostly from top-down. So, you first create
+ * a new {@link JDefinedClass} from {@link JCodeModel}, then you
+ * create a {@link JMethod} from {@link JDefinedClass}, and so on.
+ *
+ * <p>
+ * This design brings the following beneefits:
+ *
+ * <ul>
+ *  <li>source code can be written in random order
+ *  <li>generated source code nicely imports other classes
+ *  <li>generated source code is lexically always correct
+ *      (no unbalanced parenthesis, etc.)
+ *  <li>code generation becomes relatively type-safe
+ * </ul>
+ *
+ * The price you pay for that is
+ * increased memory footprint and the generation speed.
+ * See <a href="#performance">performance section</a> for
+ * more discussions about the performance and possible improvements.
+ *
+ *
+ * <h2>Using CodeModel</h2>
+ * <p>
+ * {@link com.sun.codemodel.internal.JCodeModel} is the entry point to
+ * the library. See its javadoc for more details about how to use
+ * CodeModel.
+ *
+ *
+ *
+ * <h2>Performance</h2>
+ * <p>
+ * Generally speaking, CodeModel is expected to be used in
+ * an environment where the resource constraint is not severe.
+ * Therefore, we haven't spent much effort in trying to make
+ * this library lean and mean.
+ *
+ * <p>
+ * That said, we did some benchmark and performance analysis.
+ * In case anyone is interested in making this library
+ * better performance wise, here's the findings.
+ *
+ * <p>
+ * {@link List}s {@link Map}s, and other collections take up
+ * a lot of space. Allocating those things lazily is generally
+ * a good idea.
+ *
+ * <p>
+ * Compared to template-based code generator, the writing operation
+ * is slow, as it needs to traverse each AST node. Consider
+ * pre-encoding tokens (like 'public') to the target encoding,
+ * and consider exploting the subtree equivalence.
+ *
+ * @ArchitectureDocument
+ */
+package com.sun.codemodel.internal;
+
+import java.util.List;
+import java.util.Map;
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/util/ClassNameComparator.java b/jaxws/src/share/classes/com/sun/codemodel/internal/util/ClassNameComparator.java
new file mode 100644
index 0000000..4087436
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/util/ClassNameComparator.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.util;
+
+import java.util.Comparator;
+import com.sun.codemodel.internal.JClass;
+
+/**
+ * Comparator object that sorts {@link JClass}es in the order
+ * of their names.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ClassNameComparator implements Comparator<JClass> {
+    private ClassNameComparator() {}
+
+    public int compare(JClass l, JClass r) {
+        return l.fullName().compareTo(r.fullName());
+    }
+
+    public static final Comparator<JClass> theInstance = new ClassNameComparator();
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/util/EncoderFactory.java b/jaxws/src/share/classes/com/sun/codemodel/internal/util/EncoderFactory.java
new file mode 100644
index 0000000..c4d3f07
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/util/EncoderFactory.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.util;
+
+import java.lang.reflect.Constructor;
+import java.nio.charset.Charset;
+import java.nio.charset.CharsetEncoder;
+
+/**
+ * Creates {@link CharsetEncoder} from a charset name.
+ *
+ * Fixes a MS1252 handling bug in JDK1.4.2.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class EncoderFactory {
+    public static CharsetEncoder createEncoder( String encodin ) {
+        Charset cs = Charset.forName(System.getProperty("file.encoding"));
+        CharsetEncoder encoder = cs.newEncoder();
+
+        if( cs.getClass().getName().equals("sun.nio.cs.MS1252") ) {
+            try {
+                // at least JDK1.4.2_01 has a bug in MS1252 encoder.
+                // specifically, it returns true for any character.
+                // return a correct encoder to workaround this problem
+
+                // statically binding to MS1252Encoder will cause a Link error
+                // (at least in IBM JDK1.4.1)
+                Class ms1252encoder = Class.forName("com.sun.codemodel.internal.util.MS1252Encoder");
+                Constructor c = ms1252encoder.getConstructor(new Class[]{
+                    Charset.class
+                });
+                return (CharsetEncoder)c.newInstance(new Object[]{cs});
+            } catch( Throwable t ) {
+                // if something funny happens, ignore it and fall back to
+                // a broken MS1252 encoder. It's probably still better
+                // than choking here.
+                return encoder;
+            }
+        }
+
+        return encoder;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/util/JavadocEscapeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/util/JavadocEscapeWriter.java
new file mode 100644
index 0000000..d8947ff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/util/JavadocEscapeWriter.java
@@ -0,0 +1,85 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.util;
+
+import java.io.FilterWriter;
+import java.io.IOException;
+import java.io.Writer;
+
+/**
+ * {@link Writer} that escapes characters that are unsafe
+ * as Javadoc comments.
+ *
+ * Such characters include '&lt;' and '&amp;'.
+ *
+ * <p>
+ * Note that this class doesn't escape other Unicode characters
+ * that are typically unsafe. For example, &#x611B; (A kanji
+ * that means "love") can be considered as unsafe because
+ * javac with English Windows cannot accept this character in the
+ * source code.
+ *
+ * <p>
+ * If the application needs to escape such characters as well, then
+ * they are on their own.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JavadocEscapeWriter extends FilterWriter {
+
+    public JavadocEscapeWriter( Writer next ) {
+        super(next);
+    }
+
+    public void write(int ch) throws IOException {
+        if(ch=='<')
+            out.write("&lt;");
+        else
+        if(ch=='&')
+            out.write("&amp;");
+        else
+            out.write(ch);
+    }
+
+    public void write(char[] buf, int off, int len) throws IOException {
+        for( int i=0; i<len; i++ )
+            write(buf[off+i]);
+    }
+
+    public void write(char[] buf) throws IOException {
+        write(buf,0,buf.length);
+    }
+
+    public void write(String buf, int off, int len) throws IOException {
+        write( buf.toCharArray(), off, len );
+    }
+
+    public void write(String buf) throws IOException {
+        write( buf.toCharArray(), 0, buf.length() );
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/util/MS1252Encoder.java b/jaxws/src/share/classes/com/sun/codemodel/internal/util/MS1252Encoder.java
new file mode 100644
index 0000000..2dbcd78
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/util/MS1252Encoder.java
@@ -0,0 +1,220 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.util;
+
+import java.nio.charset.Charset;
+
+/**
+ * MS1252 encoder that corrects a bug in JDK1.4.2_01.
+ *
+ * <p>
+ * See
+ * http://www.microsoft.com/globaldev/reference/sbcs/1252.htm
+ * for the normative definition.
+ *
+ * This code depends on Sun internal package, so we have to make sure
+ * it won't be executed on other JDKs.
+ */
+public final class MS1252Encoder extends SingleByteEncoder {
+
+    public MS1252Encoder(Charset cs) {
+        super(cs, index1, index2, 0xFF00, 0x00FF, 8);
+    }
+
+    private final static String index2 =
+        "\u0000\u0001\u0002\u0003\u0004\u0005\u0006\u0007" +
+        "\b\t\n\u000B\f\r\u000E\u000F" +
+        "\u0010\u0011\u0012\u0013\u0014\u0015\u0016\u0017" +
+        "\u0018\u0019\u001A\u001B\u001C\u001D\u001E\u001F" +
+        "\u0020\u0021\"\u0023\u0024\u0025\u0026\'" +
+        "\u0028\u0029\u002A\u002B\u002C\u002D\u002E\u002F" +
+        "\u0030\u0031\u0032\u0033\u0034\u0035\u0036\u0037" +
+        "\u0038\u0039\u003A\u003B\u003C\u003D\u003E\u003F" +
+        "\u0040\u0041\u0042\u0043\u0044\u0045\u0046\u0047" +
+        "\u0048\u0049\u004A\u004B\u004C\u004D\u004E\u004F" +
+        "\u0050\u0051\u0052\u0053\u0054\u0055\u0056\u0057" +
+        "\u0058\u0059\u005A\u005B\\\u005D\u005E\u005F" +
+        "\u0060\u0061\u0062\u0063\u0064\u0065\u0066\u0067" +
+        "\u0068\u0069\u006A\u006B\u006C\u006D\u006E\u006F" +
+        "\u0070\u0071\u0072\u0073\u0074\u0075\u0076\u0077" +
+        "\u0078\u0079\u007A\u007B\u007C\u007D\u007E\u007F" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u00A0\u00A1\u00A2\u00A3\u00A4\u00A5\u00A6\u00A7" +
+        "\u00A8\u00A9\u00AA\u00AB\u00AC\u00AD\u00AE\u00AF" +
+        "\u00B0\u00B1\u00B2\u00B3\u00B4\u00B5\u00B6\u00B7" +
+        "\u00B8\u00B9\u00BA\u00BB\u00BC\u00BD\u00BE\u00BF" +
+        "\u00C0\u00C1\u00C2\u00C3\u00C4\u00C5\u00C6\u00C7" +
+        "\u00C8\u00C9\u00CA\u00CB\u00CC\u00CD\u00CE\u00CF" +
+        "\u00D0\u00D1\u00D2\u00D3\u00D4\u00D5\u00D6\u00D7" +
+        "\u00D8\u00D9\u00DA\u00DB\u00DC\u00DD\u00DE\u00DF" +
+        "\u00E0\u00E1\u00E2\u00E3\u00E4\u00E5\u00E6\u00E7" +
+        "\u00E8\u00E9\u00EA\u00EB\u00EC\u00ED\u00EE\u00EF" +
+        "\u00F0\u00F1\u00F2\u00F3\u00F4\u00F5\u00F6\u00F7" +
+        "\u00F8\u00F9\u00FA\u00FB\u00FC\u00FD\u00FE\u00FF" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u008C\u009C\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u008A\u009A\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u009F\u0000\u0000\u0000\u0000\u008E\u009E\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0083\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0088\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0098\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0096\u0097\u0000" +
+        "\u0000\u0000\u0091\u0092\u0082\u0000\u0093\u0094" +
+        "\u0084\u0000\u0086\u0087\u0095\u0000\u0000\u0000" +
+        "\u0085\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0089\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u008B\u009B\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0080\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0099\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000" +
+        "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000";
+
+    private final static short index1[] = {
+        0, 256, 461, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        698, 920, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+        403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403, 403,
+    };
+
+    public boolean canEncode(char c) {
+        char test = index2.charAt( index1[(c&0xFF00)>>8] + (c&0xFF) );
+        return test!=0;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/util/SingleByteEncoder.java b/jaxws/src/share/classes/com/sun/codemodel/internal/util/SingleByteEncoder.java
new file mode 100644
index 0000000..3f0d313
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/util/SingleByteEncoder.java
@@ -0,0 +1,155 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.util;
+
+import java.nio.ByteBuffer;
+import java.nio.CharBuffer;
+import java.nio.charset.Charset;
+import java.nio.charset.CharsetEncoder;
+import java.nio.charset.CoderResult;
+
+import sun.nio.cs.Surrogate;
+
+
+abstract class SingleByteEncoder
+    extends CharsetEncoder
+{
+
+    private final short index1[];
+    private final String index2;
+    private final int mask1;
+    private final int mask2;
+    private final int shift;
+
+    private final Surrogate.Parser sgp = new Surrogate.Parser();
+
+    protected SingleByteEncoder(Charset cs,
+                                short[] index1, String index2,
+                                int mask1, int mask2, int shift)
+    {
+        super(cs, 1.0f, 1.0f);
+        this.index1 = index1;
+        this.index2 = index2;
+        this.mask1 = mask1;
+        this.mask2 = mask2;
+        this.shift = shift;
+    }
+
+    public boolean canEncode(char c) {
+        char testEncode;
+        testEncode = index2.charAt(index1[(c & mask1) >> shift]
+                                   + (c & mask2));
+        if (testEncode == '\u0000')
+            return false;
+        else
+            return true;
+    }
+
+    private CoderResult encodeArrayLoop(CharBuffer src, ByteBuffer dst) {
+        char[] sa = src.array();
+        int sp = src.arrayOffset() + src.position();
+        int sl = src.arrayOffset() + src.limit();
+        sp = (sp <= sl ? sp : sl);
+        byte[] da = dst.array();
+        int dp = dst.arrayOffset() + dst.position();
+        int dl = dst.arrayOffset() + dst.limit();
+        dp = (dp <= dl ? dp : dl);
+
+        try {
+            while (sp < sl) {
+                char c = sa[sp];
+                if (Surrogate.is(c)) {
+                    if (sgp.parse(c, sa, sp, sl) < 0)
+                        return sgp.error();
+                    return sgp.unmappableResult();
+                }
+                if (c >= '\uFFFE')
+                    return CoderResult.unmappableForLength(1);
+                if (dl - dp < 1)
+                    return CoderResult.OVERFLOW;
+
+                char e = index2.charAt(index1[(c & mask1) >> shift]
+                                       + (c & mask2));
+
+                // If output byte is zero because input char is zero
+                // then character is mappable, o.w. fail
+                if (e == '\u0000' && c != '\u0000')
+                    return CoderResult.unmappableForLength(1);
+
+                sp++;
+                da[dp++] = (byte)e;
+            }
+            return CoderResult.UNDERFLOW;
+        } finally {
+            src.position(sp - src.arrayOffset());
+            dst.position(dp - dst.arrayOffset());
+        }
+    }
+
+    private CoderResult encodeBufferLoop(CharBuffer src, ByteBuffer dst) {
+        int mark = src.position();
+        try {
+            while (src.hasRemaining()) {
+                char c = src.get();
+                if (Surrogate.is(c)) {
+                    if (sgp.parse(c, src) < 0)
+                        return sgp.error();
+                    return sgp.unmappableResult();
+                }
+                if (c >= '\uFFFE')
+                    return CoderResult.unmappableForLength(1);
+                if (!dst.hasRemaining())
+                    return CoderResult.OVERFLOW;
+
+                char e = index2.charAt(index1[(c & mask1) >> shift]
+                                       + (c & mask2));
+
+                // If output byte is zero because input char is zero
+                // then character is mappable, o.w. fail
+                if (e == '\u0000' && c != '\u0000')
+                    return CoderResult.unmappableForLength(1);
+
+                mark++;
+                dst.put((byte)e);
+            }
+            return CoderResult.UNDERFLOW;
+        } finally {
+            src.position(mark);
+        }
+    }
+
+    protected CoderResult encodeLoop(CharBuffer src, ByteBuffer dst) {
+        if (true && src.hasArray() && dst.hasArray())
+            return encodeArrayLoop(src, dst);
+        else
+            return encodeBufferLoop(src, dst);
+    }
+
+    public byte encode(char inputChar) {
+        return (byte)index2.charAt(index1[(inputChar & mask1) >> shift] +
+                (inputChar & mask2));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/util/Surrogate.java b/jaxws/src/share/classes/com/sun/codemodel/internal/util/Surrogate.java
new file mode 100644
index 0000000..0081f24
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/util/Surrogate.java
@@ -0,0 +1,354 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.util;
+
+import java.nio.CharBuffer;
+import java.nio.charset.CoderResult;
+
+
+/**
+ * Utility class for dealing with surrogates.
+ *
+ * @author Mark Reinhold
+ */
+
+class Surrogate {
+
+    private Surrogate() { }
+
+    // UTF-16 surrogate-character ranges
+    //
+    public static final char MIN_HIGH = '\uD800';
+    public static final char MAX_HIGH = '\uDBFF';
+    public static final char MIN_LOW  = '\uDC00';
+    public static final char MAX_LOW  = '\uDFFF';
+    public static final char MIN = MIN_HIGH;
+    public static final char MAX = MAX_LOW;
+
+    // Range of UCS-4 values that need surrogates in UTF-16
+    //
+    public static final int UCS4_MIN = 0x10000;
+    public static final int UCS4_MAX = (1 << 20) + UCS4_MIN - 1;
+
+    /**
+     * Tells whether or not the given UTF-16 value is a high surrogate.
+     */
+    public static boolean isHigh(int c) {
+        return (MIN_HIGH <= c) && (c <= MAX_HIGH);
+    }
+
+    /**
+     * Tells whether or not the given UTF-16 value is a low surrogate.
+     */
+    public static boolean isLow(int c) {
+        return (MIN_LOW <= c) && (c <= MAX_LOW);
+    }
+
+    /**
+     * Tells whether or not the given UTF-16 value is a surrogate character,
+     */
+    public static boolean is(int c) {
+        return (MIN <= c) && (c <= MAX);
+    }
+
+    /**
+     * Tells whether or not the given UCS-4 character must be represented as a
+     * surrogate pair in UTF-16.
+     */
+    public static boolean neededFor(int uc) {
+        return (uc >= UCS4_MIN) && (uc <= UCS4_MAX);
+    }
+
+    /**
+     * Returns the high UTF-16 surrogate for the given UCS-4 character.
+     */
+    public static char high(int uc) {
+        return (char)(0xd800 | (((uc - UCS4_MIN) >> 10) & 0x3ff));
+    }
+
+    /**
+     * Returns the low UTF-16 surrogate for the given UCS-4 character.
+     */
+    public static char low(int uc) {
+        return (char)(0xdc00 | ((uc - UCS4_MIN) & 0x3ff));
+    }
+
+    /**
+     * Converts the given surrogate pair into a 32-bit UCS-4 character.
+     */
+    public static int toUCS4(char c, char d) {
+        return (((c & 0x3ff) << 10) | (d & 0x3ff)) + 0x10000;
+    }
+
+    /**
+     * Surrogate parsing support.  Charset implementations may use instances of
+     * this class to handle the details of parsing UTF-16 surrogate pairs.
+     */
+    public static class Parser {
+
+        public Parser() { }
+
+        private int character;          // UCS-4
+        private CoderResult error = CoderResult.UNDERFLOW;
+        private boolean isPair;
+
+        /**
+         * Returns the UCS-4 character previously parsed.
+         */
+        public int character() {
+            return character;
+        }
+
+        /**
+         * Tells whether or not the previously-parsed UCS-4 character was
+         * originally represented by a surrogate pair.
+         */
+        public boolean isPair() {
+            return isPair;
+        }
+
+        /**
+         * Returns the number of UTF-16 characters consumed by the previous
+         * parse.
+         */
+        public int increment() {
+            return isPair ? 2 : 1;
+        }
+
+        /**
+         * If the previous parse operation detected an error, return the object
+         * describing that error.
+         */
+        public CoderResult error() {
+            return error;
+        }
+
+        /**
+         * Returns an unmappable-input result object, with the appropriate
+         * input length, for the previously-parsed character.
+         */
+        public CoderResult unmappableResult() {
+            return CoderResult.unmappableForLength(isPair ? 2 : 1);
+        }
+
+        /**
+         * Parses a UCS-4 character from the given source buffer, handling
+         * surrogates.
+         *
+         * @param  c    The first character
+         * @param  in   The source buffer, from which one more character
+         *              will be consumed if c is a high surrogate
+         *
+         * @return   Either a parsed UCS-4 character, in which case the isPair()
+         *           and increment() methods will return meaningful values, or
+         *           -1, in which case error() will return a descriptive result
+         *           object
+         */
+        public int parse(char c, CharBuffer in) {
+            if (isHigh(c)) {
+                if (!in.hasRemaining()) {
+                    error = CoderResult.UNDERFLOW;
+                    return -1;
+                }
+                char d = in.get();
+                if (isLow(d)) {
+                    character = toUCS4(c, d);
+                    isPair = true;
+                    error = null;
+                    return character;
+                }
+                error = CoderResult.malformedForLength(1);
+                return -1;
+            }
+            if (isLow(c)) {
+                error = CoderResult.malformedForLength(1);
+                return -1;
+            }
+            character = c;
+            isPair = false;
+            error = null;
+            return character;
+        }
+
+        /**
+         * Parses a UCS-4 character from the given source buffer, handling
+         * surrogates.
+         *
+         * @param  c    The first character
+         * @param  ia   The input array, from which one more character
+         *              will be consumed if c is a high surrogate
+         * @param  ip   The input index
+         * @param  il   The input limit
+         *
+         * @return   Either a parsed UCS-4 character, in which case the isPair()
+         *           and increment() methods will return meaningful values, or
+         *           -1, in which case error() will return a descriptive result
+         *           object
+         */
+        public int parse(char c, char[] ia, int ip, int il) {
+            if (isHigh(c)) {
+                if (il - ip < 2) {
+                    error = CoderResult.UNDERFLOW;
+                    return -1;
+                }
+                char d = ia[ip + 1];
+                if (isLow(d)) {
+                    character = toUCS4(c, d);
+                    isPair = true;
+                    error = null;
+                    return character;
+                }
+                error = CoderResult.malformedForLength(1);
+                return -1;
+            }
+            if (isLow(c)) {
+                error = CoderResult.malformedForLength(1);
+                return -1;
+            }
+            character = c;
+            isPair = false;
+            error = null;
+            return character;
+        }
+
+    }
+
+    /**
+     * Surrogate generation support.  Charset implementations may use instances
+     * of this class to handle the details of generating UTF-16 surrogate
+     * pairs.
+     */
+    public static class Generator {
+
+        public Generator() { }
+
+        private CoderResult error = CoderResult.OVERFLOW;
+
+        /**
+         * If the previous generation operation detected an error, return the
+         * object describing that error.
+         */
+        public CoderResult error() {
+            return error;
+        }
+
+        /**
+         * Generates one or two UTF-16 characters to represent the given UCS-4
+         * character.
+         *
+         * @param  uc   The UCS-4 character
+         * @param  len  The number of input bytes from which the UCS-4 value
+         *              was constructed (used when creating result objects)
+         * @param  dst  The destination buffer, to which one or two UTF-16
+         *              characters will be written
+         *
+         * @return   Either a positive count of the number of UTF-16 characters
+         *           written to the destination buffer, or -1, in which case
+         *           error() will return a descriptive result object
+         */
+        public int generate(int uc, int len, CharBuffer dst) {
+            if (uc <= 0xffff) {
+                if (is(uc)) {
+                    error = CoderResult.malformedForLength(len);
+                    return -1;
+                }
+                if (dst.remaining() < 1) {
+                    error = CoderResult.OVERFLOW;
+                    return -1;
+                }
+                dst.put((char)uc);
+                error = null;
+                return 1;
+            }
+            if (uc < UCS4_MIN) {
+                error = CoderResult.malformedForLength(len);
+                return -1;
+            }
+            if (uc <= UCS4_MAX) {
+                if (dst.remaining() < 2) {
+                    error = CoderResult.OVERFLOW;
+                    return -1;
+                }
+                dst.put(high(uc));
+                dst.put(low(uc));
+                error = null;
+                return 2;
+            }
+            error = CoderResult.unmappableForLength(len);
+            return -1;
+        }
+
+        /**
+         * Generates one or two UTF-16 characters to represent the given UCS-4
+         * character.
+         *
+         * @param  uc   The UCS-4 character
+         * @param  len  The number of input bytes from which the UCS-4 value
+         *              was constructed (used when creating result objects)
+         * @param  da   The destination array, to which one or two UTF-16
+         *              characters will be written
+         * @param  dp   The destination position
+         * @param  dl   The destination limit
+         *
+         * @return   Either a positive count of the number of UTF-16 characters
+         *           written to the destination buffer, or -1, in which case
+         *           error() will return a descriptive result object
+         */
+        public int generate(int uc, int len, char[] da, int dp, int dl) {
+            if (uc <= 0xffff) {
+                if (is(uc)) {
+                    error = CoderResult.malformedForLength(len);
+                    return -1;
+                }
+                if (dl - dp < 1) {
+                    error = CoderResult.OVERFLOW;
+                    return -1;
+                }
+                da[dp] = (char)uc;
+                error = null;
+                return 1;
+            }
+            if (uc < UCS4_MIN) {
+                error = CoderResult.malformedForLength(len);
+                return -1;
+            }
+            if (uc <= UCS4_MAX) {
+                if (dl - dp < 2) {
+                    error = CoderResult.OVERFLOW;
+                    return -1;
+                }
+                da[dp] = high(uc);
+                da[dp + 1] = low(uc);
+                error = null;
+                return 2;
+            }
+            error = CoderResult.unmappableForLength(len);
+            return -1;
+        }
+
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/util/UnicodeEscapeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/util/UnicodeEscapeWriter.java
new file mode 100644
index 0000000..549c89c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/util/UnicodeEscapeWriter.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.util;
+
+import java.io.FilterWriter;
+import java.io.IOException;
+import java.io.Writer;
+
+/**
+ * {@link Writer} that escapes non US-ASCII characters into
+ * Java Unicode escape \\uXXXX.
+ *
+ * This process is necessary if the method names or field names
+ * contain non US-ASCII characters.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class UnicodeEscapeWriter extends FilterWriter {
+
+    public UnicodeEscapeWriter( Writer next ) {
+        super(next);
+    }
+
+    public final void write(int ch) throws IOException {
+        if(!requireEscaping(ch))  out.write(ch);
+        else {
+            // need to escape
+            out.write("\\u");
+            String s = Integer.toHexString(ch);
+            for( int i=s.length(); i<4; i++ )
+                out.write('0');
+            out.write(s);
+        }
+    }
+
+    /**
+     * Can be overrided. Return true if the character
+     * needs to be escaped.
+     */
+    protected boolean requireEscaping(int ch) {
+        if(ch>=128)     return true;
+
+        // control characters
+        if( ch<0x20 && " \t\r\n".indexOf(ch)==-1 )  return true;
+
+        return false;
+    }
+
+    public final void write(char[] buf, int off, int len) throws IOException {
+        for( int i=0; i<len; i++ )
+            write(buf[off+i]);
+    }
+
+    public final void write(char[] buf) throws IOException {
+        write(buf,0,buf.length);
+    }
+
+    public final void write(String buf, int off, int len) throws IOException {
+        write( buf.toCharArray(), off, len );
+    }
+
+    public final void write(String buf) throws IOException {
+        write( buf.toCharArray(), 0, buf.length() );
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/writer/FileCodeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/FileCodeWriter.java
new file mode 100644
index 0000000..58cd9d7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/FileCodeWriter.java
@@ -0,0 +1,103 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.writer;
+
+import java.io.File;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.HashSet;
+import java.util.Set;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+
+/**
+ * Writes all the source files under the specified file folder.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class FileCodeWriter extends CodeWriter {
+
+    /** The target directory to put source code. */
+    private final File target;
+
+    /** specify whether or not to mark the generated files read-only */
+    private final boolean readOnly;
+
+    /** Files that shall be marked as read only. */
+    private final Set<File> readonlyFiles = new HashSet<File>();
+
+    public FileCodeWriter( File target ) throws IOException {
+        this(target,false);
+    }
+
+    public FileCodeWriter( File target, boolean readOnly ) throws IOException {
+        this.target = target;
+        this.readOnly = readOnly;
+        if(!target.exists() || !target.isDirectory())
+            throw new IOException(target + ": non-existent directory");
+    }
+
+
+    public OutputStream openBinary(JPackage pkg, String fileName) throws IOException {
+        return new FileOutputStream(getFile(pkg,fileName));
+    }
+
+    protected File getFile(JPackage pkg, String fileName ) throws IOException {
+        File dir;
+        if(pkg.isUnnamed())
+            dir = target;
+        else
+            dir = new File(target, toDirName(pkg));
+
+        if(!dir.exists())   dir.mkdirs();
+
+        File fn = new File(dir,fileName);
+
+        if (fn.exists()) {
+            if (!fn.delete())
+                throw new IOException(fn + ": Can't delete previous version");
+        }
+
+
+        if(readOnly)        readonlyFiles.add(fn);
+        return fn;
+    }
+
+    public void close() throws IOException {
+        // mark files as read-onnly if necessary
+        for (File f : readonlyFiles)
+            f.setReadOnly();
+    }
+
+    /** Converts a package name to the directory name. */
+    private static String toDirName( JPackage pkg ) {
+        return pkg.name().replace('.',File.separatorChar);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/writer/FilterCodeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/FilterCodeWriter.java
new file mode 100644
index 0000000..cad99ce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/FilterCodeWriter.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.writer;
+
+import java.io.OutputStream;
+import java.io.IOException;
+import java.io.Writer;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+
+/**
+ * {@link CodeWriter} that delegates to another {@link CodeWriter}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FilterCodeWriter extends CodeWriter {
+    protected CodeWriter core;
+
+    public FilterCodeWriter(CodeWriter core) {
+        this.core = core;
+    }
+
+    public OutputStream openBinary( JPackage pkg, String fileName ) throws IOException {
+        return core.openBinary(pkg, fileName);
+    }
+
+    public Writer openSource( JPackage pkg, String fileName ) throws IOException {
+        return core.openSource(pkg, fileName);
+    }
+
+    public void close() throws IOException {
+        core.close();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/writer/ProgressCodeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/ProgressCodeWriter.java
new file mode 100644
index 0000000..4b923ad
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/ProgressCodeWriter.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.writer;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.PrintStream;
+import java.io.Writer;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+
+/**
+ * Filter CodeWriter that writes a progress message to the specified
+ * PrintStream.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ProgressCodeWriter extends FilterCodeWriter {
+    public ProgressCodeWriter( CodeWriter output, PrintStream progress ) {
+        super(output);
+        this.progress = progress;
+        if(progress==null)
+            throw new IllegalArgumentException();
+    }
+
+    private final PrintStream progress;
+
+    public OutputStream openBinary(JPackage pkg, String fileName) throws IOException {
+        report(pkg, fileName);
+        return super.openBinary(pkg,fileName);
+    }
+
+    public Writer openSource(JPackage pkg, String fileName) throws IOException {
+        report(pkg, fileName);
+        return super.openSource(pkg,fileName);
+    }
+
+    private void report(JPackage pkg, String fileName) {
+        if(pkg.isUnnamed()) progress.println(fileName);
+        else
+            progress.println(
+                pkg.name().replace('.',File.separatorChar)
+                    +File.separatorChar+fileName);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/writer/PrologCodeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/PrologCodeWriter.java
new file mode 100644
index 0000000..cb785a7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/PrologCodeWriter.java
@@ -0,0 +1,87 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.writer;
+
+import java.io.IOException;
+import java.io.PrintWriter;
+import java.io.Writer;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+
+/**
+ * Writes all the source files under the specified file folder and
+ * inserts a file prolog comment in each java source file.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class PrologCodeWriter extends FilterCodeWriter {
+
+    /** prolog comment */
+    private final String prolog;
+
+    /**
+     * @param core
+     *      This CodeWriter will be used to actually create a storage for files.
+     *      PrologCodeWriter simply decorates this underlying CodeWriter by
+     *      adding prolog comments.
+     * @param prolog
+     *      Strings that will be added as comments.
+     *      This string may contain newlines to produce multi-line comments.
+     *      '//' will be inserted at the beginning of each line to make it
+     *      a valid Java comment, so the caller can just pass strings like
+     *      "abc\ndef"
+     */
+    public PrologCodeWriter( CodeWriter core, String prolog ) {
+        super(core);
+        this.prolog = prolog;
+    }
+
+
+    public Writer openSource(JPackage pkg, String fileName) throws IOException {
+        Writer w = super.openSource(pkg,fileName);
+
+        PrintWriter out = new PrintWriter(w);
+
+        // write prolog if this is a java source file
+        if( prolog != null ) {
+            out.println( "//" );
+
+            String s = prolog;
+            int idx;
+            while( (idx=s.indexOf('\n'))!=-1 ) {
+                out.println("// "+ s.substring(0,idx) );
+                s = s.substring(idx+1);
+            }
+            out.println("//");
+            out.println();
+        }
+        out.flush();    // we can't close the stream for that would close the undelying stream.
+
+        return w;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/writer/SingleStreamCodeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/SingleStreamCodeWriter.java
new file mode 100644
index 0000000..52b9597
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/SingleStreamCodeWriter.java
@@ -0,0 +1,77 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.writer;
+
+import java.io.FilterOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.PrintStream;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+
+/**
+ * Output all source files into a single stream with a little
+ * formatting header in front of each file.
+ *
+ * This is primarily for human consumption of the generated source
+ * code, such as to debug/test CodeModel or to quickly inspect the result.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class SingleStreamCodeWriter extends CodeWriter {
+
+    private final PrintStream out;
+
+    /**
+     * @param os
+     *      This stream will be closed at the end of the code generation.
+     */
+    public SingleStreamCodeWriter( OutputStream os ) {
+        out = new PrintStream(os);
+    }
+
+    public OutputStream openBinary(JPackage pkg, String fileName) throws IOException {
+        String pkgName = pkg.name();
+        if(pkgName.length()!=0)     pkgName += '.';
+
+        out.println(
+            "-----------------------------------" + pkgName+fileName +
+            "-----------------------------------");
+
+        return new FilterOutputStream(out) {
+            public void close() {
+                // don't let this stream close
+            }
+        };
+    }
+
+    public void close() throws IOException {
+        out.close();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/codemodel/internal/writer/ZipCodeWriter.java b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/ZipCodeWriter.java
new file mode 100644
index 0000000..44975d9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/codemodel/internal/writer/ZipCodeWriter.java
@@ -0,0 +1,77 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.codemodel.internal.writer;
+
+import java.io.FilterOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.zip.ZipEntry;
+import java.util.zip.ZipOutputStream;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+
+/**
+ * Writes all the files into a zip file.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ZipCodeWriter extends CodeWriter {
+    /**
+     * @param target
+     *      Zip file will be written to this stream.
+     */
+    public ZipCodeWriter( OutputStream target ) {
+        zip = new ZipOutputStream(target);
+        // nullify the close method.
+        filter = new FilterOutputStream(zip){
+            public void close() {}
+        };
+    }
+
+    private final ZipOutputStream zip;
+
+    private final OutputStream filter;
+
+    public OutputStream openBinary(JPackage pkg, String fileName) throws IOException {
+        String name = fileName;
+        if(!pkg.isUnnamed())    name = toDirName(pkg)+name;
+
+        zip.putNextEntry(new ZipEntry(name));
+        return filter;
+    }
+
+    /** Converts a package name to the directory name. */
+    private static String toDirName( JPackage pkg ) {
+        return pkg.name().replace('.','/')+'/';
+    }
+
+    public void close() throws IOException {
+        zip.close();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/ByteArrayDataSource.java b/jaxws/src/share/classes/com/sun/istack/internal/ByteArrayDataSource.java
new file mode 100644
index 0000000..7419349
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/ByteArrayDataSource.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import javax.activation.DataSource;
+import java.io.InputStream;
+import java.io.ByteArrayInputStream;
+import java.io.OutputStream;
+
+/**
+ * {@link DataSource} backed by a byte buffer.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ByteArrayDataSource implements DataSource {
+
+    private final String contentType;
+    private final byte[] buf;
+    private final int len;
+
+    public ByteArrayDataSource(byte[] buf, String contentType) {
+        this(buf,buf.length,contentType);
+    }
+    public ByteArrayDataSource(byte[] buf, int length, String contentType) {
+        this.buf = buf;
+        this.len = length;
+        this.contentType = contentType;
+    }
+
+    public String getContentType() {
+        if(contentType==null)
+            return "application/octet-stream";
+        return contentType;
+    }
+
+    public InputStream getInputStream() {
+        return new ByteArrayInputStream(buf,0,len);
+    }
+
+    public String getName() {
+        return null;
+    }
+
+    public OutputStream getOutputStream() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/FinalArrayList.java b/jaxws/src/share/classes/com/sun/istack/internal/FinalArrayList.java
new file mode 100644
index 0000000..357e6ff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/FinalArrayList.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import java.util.ArrayList;
+import java.util.Collection;
+
+/**
+ * {@link ArrayList} with the final keyword.
+ *
+ * <p>
+ * This gives HotSpot a better hint that all methods can be inlined.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class FinalArrayList<T> extends ArrayList<T> {
+    public FinalArrayList(int initialCapacity) {
+        super(initialCapacity);
+    }
+
+    public FinalArrayList() {
+    }
+
+    public FinalArrayList(Collection<? extends T> ts) {
+        super(ts);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/FragmentContentHandler.java b/jaxws/src/share/classes/com/sun/istack/internal/FragmentContentHandler.java
new file mode 100644
index 0000000..81a71be
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/FragmentContentHandler.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import org.xml.sax.helpers.XMLFilterImpl;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.ContentHandler;
+
+/**
+ * {@link XMLFilterImpl} that masks start/end document SAX events.
+ * @author Kohsuke Kawaguchi
+ */
+public class FragmentContentHandler extends XMLFilterImpl {
+    public FragmentContentHandler() {
+    }
+
+    public FragmentContentHandler(XMLReader parent) {
+        super(parent);
+    }
+
+    public FragmentContentHandler(ContentHandler handler) {
+        super();
+        setContentHandler(handler);
+    }
+
+    public void startDocument() throws SAXException {
+        // noop
+    }
+
+    public void endDocument() throws SAXException {
+        // noop
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/Interned.java b/jaxws/src/share/classes/com/sun/istack/internal/Interned.java
new file mode 100644
index 0000000..17bf5c3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/Interned.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Designates that a field, return value, argument, or a variable is supposed
+ * to be an {@link String#intern() interned} string.
+ *
+ * <p>
+ * In many places in the istack, we assume Strings to be interned for
+ * the performance reason. Similarly, In many other places, we don't
+ * make such an assumption for the performance reason (because intern
+ * isn't free.)
+ *
+ * <p>
+ * Therefore, distinguishing which part is supposed to be interned and
+ * which part is supposed to be not is important. This annotation
+ * allows us to capture that in the code.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Documented
+@Retention(RetentionPolicy.CLASS)
+@Target({ElementType.FIELD,ElementType.METHOD,ElementType.PARAMETER,ElementType.LOCAL_VARIABLE})
+public @interface Interned {
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/NotNull.java b/jaxws/src/share/classes/com/sun/istack/internal/NotNull.java
new file mode 100644
index 0000000..b8a103c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/NotNull.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Designates that a field, return value, argument, or a variable is guaranteed to be non-null.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Documented
+@Retention(RetentionPolicy.CLASS)
+@Target({ElementType.FIELD,ElementType.METHOD,ElementType.PARAMETER,ElementType.LOCAL_VARIABLE})
+public @interface NotNull {
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/Nullable.java b/jaxws/src/share/classes/com/sun/istack/internal/Nullable.java
new file mode 100644
index 0000000..2a785fe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/Nullable.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Designates that a field, return value, argument, or a variable may be null.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Documented
+@Retention(RetentionPolicy.CLASS)
+@Target({ElementType.FIELD,ElementType.METHOD,ElementType.PARAMETER,ElementType.LOCAL_VARIABLE})
+public @interface Nullable {
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/Pool.java b/jaxws/src/share/classes/com/sun/istack/internal/Pool.java
new file mode 100644
index 0000000..6740521
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/Pool.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import java.util.concurrent.ConcurrentLinkedQueue;
+
+/**
+ * Pool of reusable objects that are indistinguishable from each other,
+ * such as JAXB marshallers.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Pool<T> {
+    /**
+     * Gets a new object from the pool.
+     *
+     * <p>
+     * If no object is available in the pool, this method creates a new one.
+     */
+    @NotNull T take();
+
+    /**
+     * Returns an object back to the pool.
+     */
+    void recycle(@NotNull T t);
+
+
+    /**
+     * Default implementation that uses {@link ConcurrentLinkedQueue}
+     * as the data store.
+     *
+     * <h2>Note for Implementors</h2>
+     * <p>
+     * Don't rely on the fact that this class extends from {@link ConcurrentLinkedQueue}.
+     */
+    public abstract class Impl<T> extends ConcurrentLinkedQueue<T> implements Pool<T> {
+        /**
+         * Gets a new object from the pool.
+         *
+         * <p>
+         * If no object is available in the pool, this method creates a new one.
+         *
+         * @return
+         *      always non-null.
+         */
+        public final @NotNull T take() {
+            T t = super.poll();
+            if(t==null)
+                return create();
+            return t;
+        }
+
+        /**
+         * Returns an object back to the pool.
+         */
+        public final void recycle(T t) {
+            super.offer(t);
+        }
+
+        /**
+         * Creates a new instance of object.
+         *
+         * <p>
+         * This method is used when someone wants to
+         * {@link #take() take} an object from an empty pool.
+         *
+         * <p>
+         * Also note that multiple threads may call this method
+         * concurrently.
+         */
+        protected abstract @NotNull T create();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/SAXException2.java b/jaxws/src/share/classes/com/sun/istack/internal/SAXException2.java
new file mode 100644
index 0000000..99fb663
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/SAXException2.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link SAXException} that handles exception chaining correctly.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since 2.0 FCS
+ */
+public class SAXException2 extends SAXException {
+    public SAXException2(String message) {
+        super(message);
+    }
+
+    public SAXException2(Exception e) {
+        super(e);
+    }
+
+    public SAXException2(String message, Exception e) {
+        super(message, e);
+    }
+
+    public Throwable getCause() {
+        return getException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/SAXParseException2.java b/jaxws/src/share/classes/com/sun/istack/internal/SAXParseException2.java
new file mode 100644
index 0000000..dfd68fe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/SAXParseException2.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal;
+
+import org.xml.sax.SAXParseException;
+import org.xml.sax.Locator;
+
+/**
+ * {@link SAXParseException} that handles exception chaining correctly.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since 2.0 FCS
+ */
+public class SAXParseException2 extends SAXParseException {
+    public SAXParseException2(String message, Locator locator) {
+        super(message, locator);
+    }
+
+    public SAXParseException2(String message, Locator locator, Exception e) {
+        super(message, locator, e);
+    }
+
+    public SAXParseException2(String message, String publicId, String systemId, int lineNumber, int columnNumber) {
+        super(message, publicId, systemId, lineNumber, columnNumber);
+    }
+
+    public SAXParseException2(String message, String publicId, String systemId, int lineNumber, int columnNumber, Exception e) {
+        super(message, publicId, systemId, lineNumber, columnNumber, e);
+    }
+
+    public Throwable getCause() {
+        return getException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/package-info.java b/jaxws/src/share/classes/com/sun/istack/internal/package-info.java
new file mode 100644
index 0000000..a977293
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/package-info.java
@@ -0,0 +1,29 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * istack-commons runtime utilities.
+ */
+package com.sun.istack.internal;
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/tools/APTTypeVisitor.java b/jaxws/src/share/classes/com/sun/istack/internal/tools/APTTypeVisitor.java
new file mode 100644
index 0000000..55dd90b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/tools/APTTypeVisitor.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.istack.internal.tools;
+
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.type.ArrayType;
+import com.sun.mirror.type.ClassType;
+import com.sun.mirror.type.InterfaceType;
+import com.sun.mirror.type.TypeVariable;
+import com.sun.mirror.type.VoidType;
+import com.sun.mirror.type.WildcardType;
+import com.sun.mirror.type.PrimitiveType;
+
+/**
+ * Visitor that works on APT {@link TypeMirror} and computes a value.
+ *
+ * <p>
+ * This visitor takes a parameter 'P' so that visitor code can be made stateless.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class APTTypeVisitor<T,P> {
+    public final T apply(TypeMirror type, P param) {
+        if( type instanceof ArrayType)
+            return onArrayType((ArrayType)type,param);
+        if( type instanceof PrimitiveType)
+            return onPrimitiveType((PrimitiveType)type,param);
+        if (type instanceof ClassType )
+            return onClassType((ClassType)type,param);
+        if (type instanceof InterfaceType )
+            return onInterfaceType((InterfaceType)type,param);
+        if (type instanceof TypeVariable )
+            return onTypeVariable((TypeVariable)type,param);
+        if (type instanceof VoidType )
+            return onVoidType((VoidType)type,param);
+        if(type instanceof WildcardType)
+            return onWildcard((WildcardType) type,param);
+        assert false;
+        throw new IllegalArgumentException();
+    }
+
+    protected abstract T onPrimitiveType(PrimitiveType type, P param);
+    protected abstract T onArrayType(ArrayType type, P param);
+    protected abstract T onClassType(ClassType type, P param);
+    protected abstract T onInterfaceType(InterfaceType type, P param);
+    protected abstract T onTypeVariable(TypeVariable type, P param);
+    protected abstract T onVoidType(VoidType type, P param);
+    protected abstract T onWildcard(WildcardType type, P param);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/tools/package-info.java b/jaxws/src/share/classes/com/sun/istack/internal/tools/package-info.java
new file mode 100644
index 0000000..f770483
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/tools/package-info.java
@@ -0,0 +1,32 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * istack-commons tool time utilities.
+ *
+ * <p>
+ * This includes code that relies on APT, javac, etc.
+ */
+package com.sun.istack.internal.tools;
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/ws/AnnotationProcessorFactoryImpl.java b/jaxws/src/share/classes/com/sun/istack/internal/ws/AnnotationProcessorFactoryImpl.java
new file mode 100644
index 0000000..d976cd6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/ws/AnnotationProcessorFactoryImpl.java
@@ -0,0 +1,112 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.istack.internal.ws;
+
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashSet;
+import java.util.Set;
+
+import com.sun.mirror.apt.*;
+import com.sun.mirror.declaration.*;
+
+
+import com.sun.tools.internal.ws.processor.modeler.annotation.AnnotationProcessorContext;
+import com.sun.tools.internal.ws.processor.modeler.annotation.WebServiceAP;
+
+/*
+ * The JAX-WS {@com.sun.mirror.apt.AnnotationProcessorFactory AnnotationProcessorFactory}
+ * class used by the <a href="http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/apt.html">APT</a>
+ * framework.
+ */
+public class AnnotationProcessorFactoryImpl implements AnnotationProcessorFactory {
+
+    private static WebServiceAP wsAP;
+    /*
+     * Processor doesn't examine any options.
+     */
+    static final Collection<String> supportedOptions = Collections.unmodifiableSet(new HashSet<String>());
+
+
+    /*
+     * Supports javax.jws.*, javax.jws.soap.* and javax.xml.ws.* annotations.
+     */
+    static Collection<String> supportedAnnotations;
+    static {
+        Collection<String> types = new HashSet<String>();
+        types.add("javax.jws.HandlerChain");
+        types.add("javax.jws.Oneway");
+        types.add("javax.jws.WebMethod");
+        types.add("javax.jws.WebParam");
+        types.add("javax.jws.WebResult");
+        types.add("javax.jws.WebService");
+        types.add("javax.jws.soap.InitParam");
+        types.add("javax.jws.soap.SOAPBinding");
+        types.add("javax.jws.soap.SOAPMessageHandler");
+        types.add("javax.jws.soap.SOAPMessageHandlers");
+        types.add("javax.xml.ws.BeginService");
+        types.add("javax.xml.ws.EndService");
+        types.add("javax.xml.ws.BindingType");
+        types.add("javax.xml.ws.ParameterIndex");
+        types.add("javax.xml.ws.RequestWrapper");
+        types.add("javax.xml.ws.ResponseWrapper");
+        types.add("javax.xml.ws.ServiceMode");
+        types.add("javax.xml.ws.WebEndpoint");
+        types.add("javax.xml.ws.WebFault");
+        types.add("javax.xml.ws.WebServiceClient");
+        types.add("javax.xml.ws.WebServiceProvider");
+        types.add("javax.xml.ws.WebServiceRef");
+
+        types.add("javax.xml.ws.security.MessageSecurity");
+        supportedAnnotations = Collections.unmodifiableCollection(types);
+    }
+
+    public AnnotationProcessorFactoryImpl() {
+    }
+
+
+    public Collection<String> supportedOptions() {
+        return supportedOptions;
+    }
+
+    public Collection<String> supportedAnnotationTypes() {
+        return supportedAnnotations;
+    }
+
+    /*
+     * Return an instance of the {@link com.sun.istack.internal.ws.WSAP WSAP} AnnotationProcesor.
+     */
+    public AnnotationProcessor getProcessorFor(Set<AnnotationTypeDeclaration> atds,
+                                        AnnotationProcessorEnvironment apEnv) {
+
+        if (wsAP == null) {
+            AnnotationProcessorContext context = new AnnotationProcessorContext();
+            wsAP = new WebServiceAP(null, null, null, context);
+
+        }
+        wsAP.init(apEnv);
+        return wsAP;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/istack/internal/ws/package-info.java b/jaxws/src/share/classes/com/sun/istack/internal/ws/package-info.java
new file mode 100644
index 0000000..9cf4425
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/istack/internal/ws/package-info.java
@@ -0,0 +1,39 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *
+ * <P>This document describes the {@link com.sun.mirror.apt.AnnotationProcessor AnnotationProcessor}
+ * included with JAX-WS 2.0.
+ *
+ * <p>The {@link com.sun.istack.internal.ws.AnnotationProcessorFactoryImpl AnnoatationnProcessorFactoryImpl} class
+ * tells the <a href="http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/apt.html">APT</a>
+ * framework that there exists an {@com.sun.mirror.apt.AnnotationProcessor AnnotationProcessor}
+ * ({@link com.sun.istak.ws.WSAP WSAP}) for for processing javax.jws.*, javax.jws.soap.*,
+ *  and javax.xml.ws.* annotations.
+ *
+ * @ArchitectureDocument
+*/
+package com.sun.istack.internal.ws;
diff --git a/jaxws/src/share/classes/com/sun/tools/etc/META-INF/services/com.sun.mirror.apt.AnnotationProcessorFactory b/jaxws/src/share/classes/com/sun/tools/etc/META-INF/services/com.sun.mirror.apt.AnnotationProcessorFactory
new file mode 100644
index 0000000..8399fe5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/etc/META-INF/services/com.sun.mirror.apt.AnnotationProcessorFactory
@@ -0,0 +1 @@
+com.sun.istack.internal.ws.AnnotationProcessorFactoryImpl
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/ConfigReader.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/ConfigReader.java
new file mode 100644
index 0000000..c9afcaa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/ConfigReader.java
@@ -0,0 +1,283 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc;
+
+import java.io.File;
+import java.io.IOException;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.parsers.SAXParserFactory;
+import javax.xml.transform.Result;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.validation.ValidatorHandler;
+
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.tools.internal.jxc.gen.config.Config;
+import com.sun.tools.internal.jxc.gen.config.Schema;
+import com.sun.tools.internal.xjc.SchemaCache;
+import com.sun.tools.internal.xjc.api.Reference;
+import com.sun.tools.internal.xjc.util.ForkContentHandler;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+
+
+/**
+ * This reads the config files passed by the user to apt
+ * and obtains a list of classes that need to be included
+ * for a particular config from the set of classes passed
+ * by the user to apt.
+ *
+ * @author Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+public final class ConfigReader  {
+
+    /**
+     * The set of classes to be passed to XJC
+     *
+     */
+    private final Set<Reference> classesToBeIncluded = new HashSet<Reference>();;
+
+
+    /**
+     *  The SchemaOutputResolver used to generate the schemas
+     */
+    private final SchemaOutputResolver schemaOutputResolver;
+
+    private final AnnotationProcessorEnvironment env;
+
+    /**
+     *
+     * @param classes
+     *      The set of classes passed to the AnnotationProcessor
+     * @param xmlFile
+     *      The configuration file.
+     * @throws SAXException
+     *      If this is thrown, the error has already been reported.
+     * @throws IOException
+     *     If any IO errors occur.
+     */
+    public ConfigReader( AnnotationProcessorEnvironment env, Collection <? extends TypeDeclaration> classes, File xmlFile, ErrorHandler errorHandler)throws SAXException,IOException{
+        this.env = env;
+        Config config = parseAndGetConfig(xmlFile,errorHandler);
+        checkAllClasses(config,classes);
+        String path =   xmlFile.getAbsolutePath();
+        String xmlPath = path.substring(0,path.lastIndexOf(File.separatorChar));
+        schemaOutputResolver = createSchemaOutputResolver(config,xmlPath);
+
+    }
+
+
+    /**
+     * This creates creates a regular expression
+     * for the user pattern , matches the input classes
+     * passed by the user and returns the final
+     * list of classes that need to be included for a config file
+     * after applying those patterns
+     *
+     */
+    public Collection<Reference> getClassesToBeIncluded() {
+        return classesToBeIncluded;
+    }
+
+    private void checkAllClasses(Config config ,Collection<? extends TypeDeclaration> rootClasses){
+
+        List<Pattern> includeRegexList = config.getClasses().getIncludes();
+        List<Pattern>  excludeRegexList = config.getClasses().getExcludes();
+
+        OUTER:
+        for (TypeDeclaration typeDecl : rootClasses) {
+
+            String qualifiedName = typeDecl.getQualifiedName();
+
+            for (Pattern pattern : excludeRegexList) {
+                boolean match = checkPatternMatch(qualifiedName, pattern);
+                if (match)
+                    continue OUTER; // excluded
+            }
+
+            for (Pattern pattern : includeRegexList) {
+                boolean match = checkPatternMatch(qualifiedName, pattern);
+                if (match) {
+                    classesToBeIncluded.add(new Reference(typeDecl,env));
+                    break;
+                }
+            }
+        }
+    }
+
+    /**
+     * This returns the SchemaOutputResolver to generate the schemas
+     */
+    public SchemaOutputResolver getSchemaOutputResolver(){
+        return schemaOutputResolver;
+    }
+
+    private SchemaOutputResolver createSchemaOutputResolver(Config config, String xmlpath) {
+        File baseDir = new File(xmlpath, config.getBaseDir().getPath());
+        SchemaOutputResolverImpl schemaOutputResolver = new SchemaOutputResolverImpl (baseDir);
+
+        for( Schema schema : (List<Schema>)config.getSchema() ) {
+            String namespace = schema.getNamespace();
+            File location = schema.getLocation();
+            schemaOutputResolver.addSchemaInfo(namespace,location);
+        }
+        return schemaOutputResolver;
+    }
+
+    /**
+     * This will  check if the qualified name matches the pattern
+     *
+     * @param qualifiedName
+     *      The qualified name of the TypeDeclaration
+     * @param pattern
+     *       The  pattern obtained from the users input
+     *
+     */
+    private boolean checkPatternMatch(String qualifiedName, Pattern pattern) {
+        Matcher matcher = pattern.matcher(qualifiedName);
+        return matcher.matches();
+    }
+
+
+
+    /**
+     * Lazily parsed schema for the binding file.
+     */
+    private static SchemaCache configSchema = new SchemaCache(Config.class.getResource("config.xsd"));
+
+
+    /**
+     * Parses an xml config file and returns a Config object.
+     *
+     * @param xmlFile
+     *        The xml config file which is passed by the user to apt
+     * @return
+     *        A non null Config object
+     */
+    private Config parseAndGetConfig (File xmlFile, ErrorHandler errorHandler) throws SAXException, IOException {
+        XMLReader reader;
+        try {
+            SAXParserFactory factory = SAXParserFactory.newInstance();
+            factory.setNamespaceAware(true);
+            reader = factory.newSAXParser().getXMLReader();
+        } catch (ParserConfigurationException e) {
+            // in practice this will never happen
+            throw new Error(e);
+        }
+        NGCCRuntimeEx runtime = new NGCCRuntimeEx(errorHandler);
+
+        // set up validator
+        ValidatorHandler validator = configSchema.newValidator();
+        validator.setErrorHandler(errorHandler);
+
+        // the validator will receive events first, then the parser.
+        reader.setContentHandler(new ForkContentHandler(validator,runtime));
+
+        reader.setErrorHandler(errorHandler);
+        Config config = new Config(runtime);
+        runtime.setRootHandler(config);
+        reader.parse(new InputSource(xmlFile.toURL().toExternalForm()));
+        runtime.reset();
+
+        return config;
+    }
+    /**
+     * Controls where the JAXB RI puts the generates
+     * schema files.
+     * @author
+     *     Bhakti Mehta (bhakti.mehta@sun.com)
+     */
+    private static final class SchemaOutputResolverImpl extends SchemaOutputResolver{
+
+        /**
+         * Directory to which we put the rest of the files.
+         * Never be null.
+         */
+        private final File baseDir;
+
+        /**
+         * Namespace URI to the location of the schema.
+         * This captures what the user specifies.
+         */
+        private final Map<String,File> schemas = new HashMap<String,File>();
+
+
+        /**
+         * Decides where the schema file (of the given namespace URI)
+         * will be written, and return it as a {@link Result} object.
+         *
+         */
+        public Result createOutput( String namespaceUri, String suggestedFileName ) {
+
+            // the user's preference takes a precedence
+            if(schemas.containsKey(namespaceUri)) {
+                File loc = schemas.get(namespaceUri);
+                if(loc==null)   return null;    // specifically not to generate a schema
+
+                // create directories if necessary. we've already checked that the baseDir
+                // exists, so this should be no surprise to users.
+                loc.getParentFile().mkdirs();
+
+                return new StreamResult(loc);   // generate into a file the user specified.
+            }
+
+            // if the user didn't say anything about this namespace,
+            // generate it into the default directory with a default name.
+
+             File schemaFile = new File (baseDir, suggestedFileName);
+             // The systemId for the result will be schemaFile
+             return new StreamResult(schemaFile);
+        }
+
+
+        public SchemaOutputResolverImpl(File baseDir) {
+            assert baseDir!=null;
+            this.baseDir = baseDir;
+        }
+
+        public void addSchemaInfo(String namespaceUri, File location) {
+            if (namespaceUri == null )
+                //generate elements in no namespace
+                namespaceUri = "";
+            schemas.put(namespaceUri, location);
+
+        }
+
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/jxc/MessageBundle.properties
new file mode 100644
index 0000000..ddc5a4a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/MessageBundle.properties
@@ -0,0 +1,19 @@
+UNEXPECTED_NGCC_TOKEN = \
+    Unexpected {0} appears at line {1} column {2}
+
+BASEDIR_DOESNT_EXIST = \
+    Non-existent directory: {0}
+
+VERSION = \
+	schemagen version "JAXB 2.0 in JDK 1.6" \n\
+	JavaTM Architecture for XML Binding(JAXB) Reference Implementation, (build JAXB 2.0 in JDK 1.6)	
+
+USAGE = \
+Usage: schemagen [-options ...] <java files> \n\
+Options: \n\
+\ \ \ \ -d <path>         :  specify where to place processor and javac generated class files \n\
+\ \ \ \ -cp <path>        :  specify where to find user specified files  \n\
+\ \ \ \ -classpath <path> :  specify where to find user specified files  \n\
+\ \ \ \ -version          :  display version information
+\ \ \ \ -help             :  display this usage message
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/Messages.java
new file mode 100644
index 0000000..b1f22f4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/Messages.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+enum Messages {
+    // Accessor
+    UNEXPECTED_NGCC_TOKEN, // 3 args
+    BASEDIR_DOESNT_EXIST, // 1 arg
+    USAGE, //0 args
+    VERSION, // 0 args
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getPackage().getName() +".MessageBundle");
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/NGCCRuntimeEx.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/NGCCRuntimeEx.java
new file mode 100644
index 0000000..8f53807
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/NGCCRuntimeEx.java
@@ -0,0 +1,168 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc;
+
+import java.io.File;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.regex.Pattern;
+
+import com.sun.tools.internal.jxc.gen.config.NGCCRuntime;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+
+/**
+ * Controls the  validating and converting  of values obtained
+ * from the config file.
+ *
+ * @author
+ *     Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+public final class NGCCRuntimeEx extends NGCCRuntime {
+    /**
+     * All the errors shall be sent to this object.
+     */
+    private final ErrorHandler errorHandler;
+
+    public NGCCRuntimeEx(ErrorHandler errorHandler) {
+        this.errorHandler = errorHandler;
+    }
+
+    /**
+     *  This will check if the baseDir provided by the user
+     *  in the config file exists. If not it throws an error
+     * @param baseDir
+     *    The baseDir attribute passed by the user in the xml config file as a path
+     * @return
+     *     The file representation of the path name
+     */
+    public File getBaseDir(String baseDir) throws SAXException {
+        File dir = new File(baseDir);
+        if (dir.exists()) {
+            return dir;
+        } else {
+            SAXParseException e = new SAXParseException(
+                                Messages.BASEDIR_DOESNT_EXIST.format(dir.getAbsolutePath()),
+                                getLocator());
+            errorHandler.error(e);
+            throw e;    // we can't recover from this error
+        }
+    }
+
+    /**
+     * This takes the include list provided by the user in the config file
+     * It converts the user values to {@link Pattern}
+     * @param includeContent
+     *        The include list specified by the user
+     * @return
+     *        A list of regular expression patterns {@link Pattern}
+     */
+    public List<Pattern> getIncludePatterns(List includeContent ) {
+        List<Pattern> includeRegexList = new ArrayList<Pattern>();
+        for (int i = 0 ; i < includeContent.size(); i ++){
+            String includes = (String)includeContent.get(i);
+            String regex = convertToRegex(includes);
+            Pattern pattern = Pattern.compile(regex);
+            includeRegexList.add(pattern);
+        }
+        return includeRegexList;
+    }
+
+
+    /**
+     * This takes the exclude list provided by the user in the config file
+     * It converts the user values to {@link Pattern}
+     * @param excludeContent
+     *        The exclude list specified by the user
+     * @return
+     *        A list of regular expression patterns {@link Pattern}
+     */
+    public List getExcludePatterns(List excludeContent ) {
+        List excludeRegexList = new ArrayList();
+        for (int i = 0 ; i < excludeContent.size(); i ++){
+            String excludes = (String)excludeContent.get(i);
+            String regex = convertToRegex(excludes);
+            Pattern pattern = Pattern.compile(regex);
+            excludeRegexList.add(pattern);
+        }
+        return excludeRegexList;
+    }
+
+
+    /**
+     * This will tokenize the pattern and convert it into a regular expression
+     * @param pattern
+     */
+    private String convertToRegex(String pattern) {
+        StringBuilder regex = new StringBuilder();
+        char nc = ' ';
+        if (pattern.length() >0 ) {
+
+            for ( int i = 0 ; i < pattern.length(); i ++ ) {
+                char c = pattern.charAt(i);
+                int j = i;
+                nc = ' ';
+                if ((j+1) != pattern.length()) {
+                    nc = pattern.charAt(j+1);
+                }
+                //escape single '.'
+                if ((c=='.') && ( nc !='.')){
+                    regex.append('\\');
+                    regex.append('.');
+                    //do not allow patterns like a..b
+                } else if ((c=='.') && ( nc =='.')){
+                    continue;
+                    // "**" gets replaced by ".*"
+                } else if ((c=='*') && (nc == '*')) {
+                    regex.append(".*");
+                    break;
+                    //'*' replaced by anything but '.' i.e [^\\.]+
+                } else if (c=='*') {
+                    regex.append("[^\\.]+");
+                    continue;
+                    //'?' replaced by anything but '.' i.e [^\\.]
+                } else if (c=='?') {
+                    regex.append("[^\\.]");
+                    //else leave the chars as they occur in the pattern
+                } else
+                    regex.append(c);
+            }
+
+        }
+
+        return regex.toString();
+    }
+
+    protected void unexpectedX(String token) throws SAXException {
+        errorHandler.error(
+            new SAXParseException(Messages.UNEXPECTED_NGCC_TOKEN.format(
+                token, getLocator().getLineNumber(), getLocator().getColumnNumber()),
+                getLocator()));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/SchemaGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/SchemaGenerator.java
new file mode 100644
index 0000000..ef17830
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/SchemaGenerator.java
@@ -0,0 +1,214 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc;
+
+import java.io.File;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.List;
+
+import javax.xml.bind.JAXBContext;
+
+import com.sun.mirror.apt.AnnotationProcessorFactory;
+import com.sun.tools.internal.jxc.apt.Options;
+import com.sun.tools.internal.xjc.BadCommandLineException;
+import com.sun.tools.internal.xjc.api.util.APTClassLoader;
+import com.sun.tools.internal.xjc.api.util.ToolsJarNotFoundException;
+import com.sun.xml.internal.bind.util.Which;
+
+/**
+ * CLI entry-point to the schema generator.
+ *
+ * @author Bhakti Mehta
+ */
+public class SchemaGenerator {
+    /**
+     * Runs the schema generator.
+     */
+    public static void main(String[] args) throws Exception {
+        System.exit(run(args));
+    }
+
+    public static int run(String[] args) throws Exception {
+        try {
+            ClassLoader cl = SchemaGenerator.class.getClassLoader();
+            if(cl==null)    cl = ClassLoader.getSystemClassLoader();
+            ClassLoader classLoader = new APTClassLoader(cl,packagePrefixes);
+            return run(args, classLoader);
+        } catch( ToolsJarNotFoundException e) {
+            System.err.println(e.getMessage());
+            return -1;
+        }
+    }
+
+    /**
+     * List of package prefixes we want to load in the same package
+     */
+    private static final String[] packagePrefixes = {
+        "com.sun.tools.internal.jxc.",
+        "com.sun.tools.internal.xjc.",
+        "com.sun.istack.internal.tools.",
+        "com.sun.tools.apt.",
+        "com.sun.tools.javac.",
+        "com.sun.tools.javadoc.",
+        "com.sun.mirror."
+    };
+
+    /**
+     * Runs the schema generator.
+     *
+     * @param classLoader
+     *      the schema generator will run in this classLoader.
+     *      It needs to be able to load APT and JAXB RI classes. Note that
+     *      JAXB RI classes refer to APT classes. Must not be null.
+     *
+     * @return
+     *      exit code. 0 if success.
+     *
+     */
+    public static int run(String[] args, ClassLoader classLoader) throws ClassNotFoundException, NoSuchMethodException, IllegalAccessException, InvocationTargetException {
+        final Options options = new Options();
+        if (args.length ==0) {
+            usage();
+            return -1;
+        }
+        for (String arg : args) {
+            if (arg.equals("-help")) {
+                usage();
+                return -1;
+            }
+
+            if (arg.equals("-version")) {
+                System.out.println(Messages.VERSION.format());
+                return -1;
+            }
+        }
+
+        try {
+            options.parseArguments(args);
+        } catch (BadCommandLineException e) {
+            // there was an error in the command line.
+            // print usage and abort.
+            System.out.println(e.getMessage());
+            System.out.println();
+            usage();
+            return -1;
+        }
+
+        Class schemagenRunner = classLoader.loadClass(Runner.class.getName());
+        Method mainMethod = schemagenRunner.getDeclaredMethod("main",String[].class);
+
+        List<String> aptargs = new ArrayList<String>();
+
+        if(hasClass(options.arguments))
+            aptargs.add("-XclassesAsDecls");
+
+        // make jaxb-api.jar visible to classpath
+        File jaxbApi = findJaxbApiJar();
+        if(jaxbApi!=null) {
+            if(options.classpath!=null) {
+                options.classpath = options.classpath+File.pathSeparatorChar+jaxbApi;
+            } else {
+                options.classpath = jaxbApi.getPath();
+            }
+        }
+
+        aptargs.add("-cp");
+        aptargs.add(options.classpath);
+
+        if(options.targetDir!=null) {
+            aptargs.add("-d");
+            aptargs.add(options.targetDir.getPath());
+        }
+
+        aptargs.addAll(options.arguments);
+
+        String[] argsarray = aptargs.toArray(new String[aptargs.size()]);
+        return (Integer)mainMethod.invoke(null,new Object[]{argsarray});
+    }
+
+    /**
+     * Computes the file system path of <tt>jaxb-api.jar</tt> so that
+     * APT will see them in the <tt>-cp</tt> option.
+     *
+     * <p>
+     * In Java, you can't do this reliably (for that matter there's no guarantee
+     * that such a jar file exists, such as in Glassfish), so we do the best we can.
+     *
+     * @return
+     *      null if failed to locate it.
+     */
+    private static File findJaxbApiJar() {
+        String url = Which.which(JAXBContext.class);
+        if(url==null)       return null;    // impossible, but hey, let's be defensive
+
+        if(!url.startsWith("jar:") || url.lastIndexOf('!')==-1)
+            // no jar file
+            return null;
+
+        String jarFileUrl = url.substring(4,url.lastIndexOf('!'));
+        if(!jarFileUrl.startsWith("file:"))
+            return null;    // not from file system
+
+        try {
+            File f = new File(new URL(jarFileUrl).getFile());
+            if(f.exists() && f.getName().endsWith(".jar"))
+                return f;
+            else
+                return null;
+        } catch (MalformedURLException e) {
+            return null;    // impossible
+        }
+    }
+
+    /**
+     * Returns true if the list of arguments have an argument
+     * that looks like a class name.
+     */
+    private static boolean hasClass(List<String> args) {
+        for (String arg : args) {
+            if(!arg.endsWith(".java"))
+                return true;
+        }
+        return false;
+    }
+
+    private static void usage( ) {
+        System.out.println(Messages.USAGE.format());
+    }
+
+    public static final class Runner {
+        public static int main(String[] args) throws Exception {
+            ClassLoader cl = Runner.class.getClassLoader();
+            Class apt = cl.loadClass("com.sun.tools.apt.Main");
+            Method processMethod = apt.getMethod("process",AnnotationProcessorFactory.class, String[].class);
+            return (Integer) processMethod.invoke(null, new com.sun.tools.internal.jxc.apt.SchemaGenerator(), args);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/AnnotationParser.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/AnnotationParser.java
new file mode 100644
index 0000000..0917523
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/AnnotationParser.java
@@ -0,0 +1,121 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.apt;
+
+import java.io.File;
+import java.io.IOException;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.Map;
+import java.util.Set;
+import java.util.StringTokenizer;
+
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.namespace.QName;
+
+import com.sun.mirror.apt.AnnotationProcessor;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.declaration.AnnotationTypeDeclaration;
+import com.sun.tools.internal.jxc.ConfigReader;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.api.J2SJAXBModel;
+import com.sun.tools.internal.xjc.api.Reference;
+import com.sun.tools.internal.xjc.api.XJC;
+
+import org.xml.sax.SAXException;
+
+
+
+/**
+ * This class behaves as a JAXB Annotation Processor,
+ * It reads the user specified typeDeclarations
+ * and the config files
+ * It also reads config files
+ *
+ * @author Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+final class AnnotationParser implements AnnotationProcessor  {
+
+    /**
+     * This is the environment available to the annotationProcessor
+     */
+    private final AnnotationProcessorEnvironment env;
+
+    private ErrorReceiver errorListener;
+
+    public AnnotationProcessorEnvironment getEnv() {
+        return env;
+    }
+
+
+    AnnotationParser(Set<AnnotationTypeDeclaration> atds, AnnotationProcessorEnvironment env) {
+        this.env = env;
+        errorListener = new ErrorReceiverImpl(env.getMessager(),env.getOptions().containsKey(Const.DEBUG_OPTION));
+    }
+
+    public void process() {
+        for( Map.Entry<String,String> me : env.getOptions().entrySet() ) {
+            String key =  me.getKey();
+            if (key.startsWith(Const.CONFIG_FILE_OPTION+'=')) {
+                // somehow the values are passed as a part of the key in APT.
+                // this is ugly
+                String value = key.substring(Const.CONFIG_FILE_OPTION.length()+1);
+
+                // For multiple config files we are following the format
+                // -Aconfig=foo.config:bar.config where : is the pathSeparatorChar
+                StringTokenizer st = new StringTokenizer(value,File.pathSeparator);
+                if(!st.hasMoreTokens()) {
+                    errorListener.error(null,Messages.NO_FILE_SPECIFIED.format());
+                    continue;
+                }
+
+                while (st.hasMoreTokens())   {
+                    File configFile = new File(st.nextToken());
+                    if(!configFile.exists()) {
+                        errorListener.error(null,Messages.NON_EXISTENT_FILE.format());
+                        continue;
+                    }
+
+                    try {
+                        ConfigReader configReader = new ConfigReader(env,env.getTypeDeclarations(),configFile,errorListener);
+
+                        Collection<Reference> classesToBeIncluded = configReader.getClassesToBeIncluded();
+                        J2SJAXBModel model = XJC.createJavaCompiler().bind(
+                                classesToBeIncluded,Collections.<QName,Reference>emptyMap(),null,env);
+
+                        SchemaOutputResolver schemaOutputResolver = configReader.getSchemaOutputResolver();
+
+                        model.generateSchema(schemaOutputResolver,errorListener);
+                    } catch (IOException e) {
+                        errorListener.error(e.getMessage(),e);
+                    } catch (SAXException e) {
+                        // the error should have already been reported
+                    }
+                }
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/AnnotationProcessorFactoryImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/AnnotationProcessorFactoryImpl.java
new file mode 100644
index 0000000..ce842f9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/AnnotationProcessorFactoryImpl.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.apt;
+
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.Set;
+
+import com.sun.mirror.apt.AnnotationProcessor;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.apt.AnnotationProcessorFactory;
+import com.sun.mirror.declaration.AnnotationTypeDeclaration;
+
+/**
+ * {@link AnnotationProcessorFactory} for JAXB.
+ *
+ * <p>
+ * This is the entry point for the APT driver.
+ */
+public class AnnotationProcessorFactoryImpl implements AnnotationProcessorFactory {
+    public Collection<String> supportedOptions() {
+        return Arrays.asList(Const.CONFIG_FILE_OPTION);
+    }
+
+    public Collection<String> supportedAnnotationTypes() {
+        return Arrays.asList("javax.xml.bind.annotation.*");
+    }
+
+    public AnnotationProcessor getProcessorFor(Set<AnnotationTypeDeclaration> atds, AnnotationProcessorEnvironment env) {
+        return new AnnotationParser(atds,env);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Const.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Const.java
new file mode 100644
index 0000000..6b6008b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Const.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.apt;
+
+import java.io.File;
+
+/**
+ * Defines constants used in the APT driver.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Const {
+    private Const() {}
+
+    /**
+     * Name of the APT command-line option to take user-specified config files.
+     *
+     * <p>
+     * It can take multiple file names separately by {@link File#pathSeparator}.
+     */
+    public static final String CONFIG_FILE_OPTION = "-Ajaxb.config";
+
+    public static final String DEBUG_OPTION = "-Ajaxb.debug";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/ErrorReceiverImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/ErrorReceiverImpl.java
new file mode 100644
index 0000000..117fec7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/ErrorReceiverImpl.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.apt;
+
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.apt.Messager;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+
+import org.xml.sax.SAXParseException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class ErrorReceiverImpl extends ErrorReceiver {
+    private final Messager messager;
+    private final boolean debug;
+
+    public ErrorReceiverImpl(Messager messager, boolean debug) {
+        this.messager = messager;
+        this.debug = debug;
+    }
+
+    public ErrorReceiverImpl(Messager messager) {
+        this(messager,false);
+    }
+
+    public ErrorReceiverImpl(AnnotationProcessorEnvironment env) {
+        this(env.getMessager());
+    }
+
+    public void error(SAXParseException exception) {
+        messager.printError(exception.getMessage());
+        messager.printError(getLocation(exception));
+        printDetail(exception);
+    }
+
+    public void fatalError(SAXParseException exception) {
+        messager.printError(exception.getMessage());
+        messager.printError(getLocation(exception));
+        printDetail(exception);
+    }
+
+    public void warning(SAXParseException exception) {
+        messager.printWarning(exception.getMessage());
+        messager.printWarning(getLocation(exception));
+        printDetail(exception);
+    }
+
+    public void info(SAXParseException exception) {
+        printDetail(exception);
+    }
+
+    private String getLocation(SAXParseException e) {
+        // TODO: format the location information for printing
+        return "";
+    }
+
+    private void printDetail(SAXParseException e) {
+        if(debug) {
+            e.printStackTrace(System.out);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/InlineAnnotationReaderImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/InlineAnnotationReaderImpl.java
new file mode 100644
index 0000000..553dc68
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/InlineAnnotationReaderImpl.java
@@ -0,0 +1,141 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.apt;
+
+import java.lang.annotation.Annotation;
+import java.lang.reflect.InvocationTargetException;
+import java.util.List;
+import java.util.ArrayList;
+
+import com.sun.mirror.declaration.FieldDeclaration;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.ParameterDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.declaration.AnnotationMirror;
+import com.sun.mirror.declaration.Declaration;
+import com.sun.mirror.type.MirroredTypeException;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.xml.internal.bind.v2.model.annotation.AbstractInlineAnnotationReaderImpl;
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.annotation.LocatableAnnotation;
+
+/**
+ * {@link AnnotationReader} implementation that reads annotation inline from APT.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public final class InlineAnnotationReaderImpl extends AbstractInlineAnnotationReaderImpl<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration> {
+
+    /** The singleton instance. */
+    public static final InlineAnnotationReaderImpl theInstance = new InlineAnnotationReaderImpl();
+
+    private InlineAnnotationReaderImpl() {}
+
+    public <A extends Annotation> A getClassAnnotation(Class<A> a, TypeDeclaration clazz, Locatable srcPos) {
+        return LocatableAnnotation.create(clazz.getAnnotation(a),srcPos);
+    }
+
+    public <A extends Annotation> A getFieldAnnotation(Class<A> a, FieldDeclaration f, Locatable srcPos) {
+        return LocatableAnnotation.create(f.getAnnotation(a),srcPos);
+    }
+
+    public boolean hasFieldAnnotation(Class<? extends Annotation> annotationType, FieldDeclaration f) {
+        return f.getAnnotation(annotationType)!=null;
+    }
+
+    public Annotation[] getAllFieldAnnotations(FieldDeclaration field, Locatable srcPos) {
+        return getAllAnnotations(field,srcPos);
+    }
+
+    public <A extends Annotation> A getMethodAnnotation(Class<A> a, MethodDeclaration method, Locatable srcPos) {
+        return LocatableAnnotation.create(method.getAnnotation(a),srcPos);
+    }
+
+    public boolean hasMethodAnnotation(Class<? extends Annotation> a, MethodDeclaration method) {
+        return method.getAnnotation(a)!=null;
+    }
+
+    private static final Annotation[] EMPTY_ANNOTATION = new Annotation[0];
+
+    public Annotation[] getAllMethodAnnotations(MethodDeclaration method, Locatable srcPos) {
+        return getAllAnnotations(method,srcPos);
+    }
+
+    /**
+     * Gets all the annotations on the given declaration.
+     */
+    private Annotation[] getAllAnnotations(Declaration decl, Locatable srcPos) {
+        List<Annotation> r = new ArrayList<Annotation>();
+
+        for( AnnotationMirror m : decl.getAnnotationMirrors() ) {
+            try {
+                String fullName = m.getAnnotationType().getDeclaration().getQualifiedName();
+                Class type = getClass().getClassLoader().loadClass(fullName);
+                Annotation annotation = decl.getAnnotation(type);
+                if(annotation!=null)
+                    r.add( LocatableAnnotation.create(annotation,srcPos) );
+            } catch (ClassNotFoundException e) {
+                // just continue
+            }
+        }
+
+        return r.toArray(EMPTY_ANNOTATION);
+    }
+
+    public <A extends Annotation> A getMethodParameterAnnotation(Class<A> a, MethodDeclaration m, int paramIndex, Locatable srcPos) {
+        ParameterDeclaration[] params = m.getParameters().toArray(new ParameterDeclaration[0]);
+        return LocatableAnnotation.create(
+            params[paramIndex].getAnnotation(a), srcPos );
+    }
+
+    public <A extends Annotation> A getPackageAnnotation(Class<A> a, TypeDeclaration clazz, Locatable srcPos) {
+        return LocatableAnnotation.create(clazz.getPackage().getAnnotation(a),srcPos);
+    }
+
+    public TypeMirror getClassValue(Annotation a, String name) {
+        try {
+            a.annotationType().getMethod(name).invoke(a);
+            assert false;
+            throw new IllegalStateException("should throw a MirroredTypeException");
+        } catch (IllegalAccessException e) {
+            throw new IllegalAccessError(e.getMessage());
+        } catch (InvocationTargetException e) {
+            if( e.getCause() instanceof MirroredTypeException ) {
+                MirroredTypeException me = (MirroredTypeException)e.getCause();
+                return me.getTypeMirror();
+            }
+            // impossible
+            throw new RuntimeException(e);
+        } catch (NoSuchMethodException e) {
+            throw new NoSuchMethodError(e.getMessage());
+        }
+    }
+
+    protected String fullName(MethodDeclaration m) {
+        return m.getDeclaringType().getQualifiedName()+'#'+m.getSimpleName();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/MessageBundle.properties
new file mode 100644
index 0000000..9f69124
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/MessageBundle.properties
@@ -0,0 +1,12 @@
+NON_EXISTENT_FILE = \
+    Directory "{0}" doesn't exist.
+
+UNRECOGNIZED_PARAMETER = \
+    Unrecognized option {0} is not valid.
+
+NO_FILE_SPECIFIED = \
+    No directory was specified.
+
+NO_CLASSPATH_SPECIFIED = \
+    No classpath was specified.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Messages.java
new file mode 100644
index 0000000..61fc613
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Messages.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.apt;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+enum Messages {
+    // Accessor
+    NON_EXISTENT_FILE, // 1 arg
+    NO_FILE_SPECIFIED, // 0 args
+    NO_CLASSPATH_SPECIFIED, // 0 args
+    UNRECOGNIZED_PARAMETER, //1 arg
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getPackage().getName() +".MessageBundle");
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Options.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Options.java
new file mode 100644
index 0000000..a63f4f9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/Options.java
@@ -0,0 +1,89 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.apt;
+
+import java.io.File;
+import java.util.ArrayList;
+import java.util.List;
+
+import com.sun.tools.internal.xjc.BadCommandLineException;
+
+/**
+ * This stores the invocation configuration for
+ * SchemaGenerator
+ *
+ * @author Bhakti Mehta
+ */
+public class Options  {
+
+    // honor CLASSPATH environment variable, but it will be overrided by -cp
+    public String classpath = System.getenv("CLASSPATH");
+
+    public File targetDir = null;
+
+    public final List<String> arguments = new ArrayList<String>();
+
+    public void parseArguments(String[] args) throws BadCommandLineException {
+        for (int i = 0 ; i <args.length; i++) {
+            if (args[i].charAt(0)== '-') {
+                int j = parseArgument(args,i);
+                if(j==0)
+                    throw new BadCommandLineException(
+                            Messages.UNRECOGNIZED_PARAMETER.format(args[i]));
+                i += j;
+            } else {
+                arguments.add(args[i]);
+            }
+        }
+    }
+
+    private int parseArgument( String[] args, int i ) throws BadCommandLineException {
+        if (args[i].equals("-d")) {
+            if (i == args.length - 1)
+                throw new BadCommandLineException(
+                        (Messages.NO_FILE_SPECIFIED.format()));
+            targetDir = new File(args[++i]);
+            if( !targetDir.exists() )
+                throw new BadCommandLineException(
+                        Messages.NON_EXISTENT_FILE.format(targetDir));
+            return 1;
+        }
+
+        if (args[i].equals("-cp") || args[i].equals("-classpath")) {
+            if (i == args.length - 1)
+                throw new BadCommandLineException(
+                        (Messages.NO_CLASSPATH_SPECIFIED.format()));
+            classpath = args[++i];
+
+            return 1;
+        }
+
+        return 0;
+
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/SchemaGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/SchemaGenerator.java
new file mode 100644
index 0000000..63f1a50
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/SchemaGenerator.java
@@ -0,0 +1,130 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.apt;
+
+import java.io.File;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Result;
+import javax.xml.transform.stream.StreamResult;
+
+import com.sun.mirror.apt.AnnotationProcessor;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.apt.AnnotationProcessorFactory;
+import com.sun.mirror.apt.Filer;
+import com.sun.mirror.declaration.AnnotationTypeDeclaration;
+import com.sun.mirror.declaration.ClassDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.tools.internal.xjc.api.J2SJAXBModel;
+import com.sun.tools.internal.xjc.api.Reference;
+import com.sun.tools.internal.xjc.api.XJC;
+
+/**
+ * {@link AnnotationProcessorFactory} that implements the schema generator
+ * command line tool.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class SchemaGenerator implements AnnotationProcessorFactory {
+
+    /**
+     * User-specified schema locations, if any.
+     */
+    private final Map<String,File> schemaLocations = new HashMap<String, File>();
+
+    public SchemaGenerator() {
+    }
+
+    public SchemaGenerator( Map<String,File> m ) {
+        schemaLocations.putAll(m);
+    }
+
+    public Collection<String> supportedOptions() {
+        return Collections.emptyList();
+    }
+
+    public Collection<String> supportedAnnotationTypes() {
+        return Arrays.asList("*");
+    }
+
+    public AnnotationProcessor getProcessorFor(Set<AnnotationTypeDeclaration> atds, final AnnotationProcessorEnvironment env) {
+        return new AnnotationProcessor() {
+            final ErrorReceiverImpl errorListener = new ErrorReceiverImpl(env);
+
+            public void process() {
+                List<Reference> decls = new ArrayList<Reference>();
+                for(TypeDeclaration d : env.getTypeDeclarations()) {
+                    // simply ignore all the interface definitions,
+                    // so that users won't have to manually exclude interfaces, which is silly.
+                    if(d instanceof ClassDeclaration)
+                        decls.add(new Reference(d,env));
+                }
+
+                J2SJAXBModel model = XJC.createJavaCompiler().bind(decls,Collections.<QName,Reference>emptyMap(),null,env);
+                if(model==null)
+                    return; // error
+
+                try {
+                    model.generateSchema(
+                        new SchemaOutputResolver() {
+                            public Result createOutput(String namespaceUri, String suggestedFileName) throws IOException {
+                                File file;
+                                OutputStream out;
+                                if(schemaLocations.containsKey(namespaceUri)) {
+                                    file = schemaLocations.get(namespaceUri);
+                                    if(file==null)  return null;    // don't generate
+                                    out = new FileOutputStream(file);
+                                } else {
+                                    // use the default
+                                    file = new File(suggestedFileName);
+                                    out = env.getFiler().createBinaryFile(Filer.Location.CLASS_TREE,"",file);
+                                }
+
+                                StreamResult ss = new StreamResult(out);
+                                env.getMessager().printNotice("Writing "+file);
+                                ss.setSystemId(file.getPath());
+                                return ss;
+                            }
+                        }, errorListener);
+                } catch (IOException e) {
+                    errorListener.error(e.getMessage(),e);
+                }
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/package.html b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/package.html
new file mode 100644
index 0000000..6042da9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/apt/package.html
@@ -0,0 +1,6 @@
+<heml><body>
+APT related code.
+
+This package hosts a driver that runs inside APT for java-to-schema processing,
+and additional implementations that deal primarily with APT.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/AttributesImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/AttributesImpl.java
new file mode 100644
index 0000000..e6e3a92
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/AttributesImpl.java
@@ -0,0 +1,625 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+// AttributesImpl.java - default implementation of Attributes.
+// Written by David Megginson, sax@megginson.com
+// NO WARRANTY!  This class is in the public domain.
+
+// $Id: AttributesImpl.java,v 1.4 2002/09/29 02:55:48 okajima Exp $
+
+//fixed bug at removeAttribute!! by Daisuke OKAJIMA 2002.4.21
+
+package com.sun.tools.internal.jxc.gen.config;
+
+import org.xml.sax.Attributes;
+
+
+/**
+ * Default implementation of the Attributes interface.
+ *
+ * <blockquote>
+ * <em>This module, both source code and documentation, is in the
+ * Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
+ * </blockquote>
+ *
+ * <p>This class provides a default implementation of the SAX2
+ * {@link org.xml.sax.Attributes Attributes} interface, with the
+ * addition of manipulators so that the list can be modified or
+ * reused.</p>
+ *
+ * <p>There are two typical uses of this class:</p>
+ *
+ * <ol>
+ * <li>to take a persistent snapshot of an Attributes object
+ *  in a {@link org.xml.sax.ContentHandler#startElement startElement} event; or</li>
+ * <li>to construct or modify an Attributes object in a SAX2 driver or filter.</li>
+ * </ol>
+ *
+ * <p>This class replaces the now-deprecated SAX1 {@link
+ * org.xml.sax.helpers.AttributeListImpl AttributeListImpl}
+ * class; in addition to supporting the updated Attributes
+ * interface rather than the deprecated {@link org.xml.sax.AttributeList
+ * AttributeList} interface, it also includes a much more efficient
+ * implementation using a single array rather than a set of Vectors.</p>
+ *
+ * @since SAX 2.0
+ * @author David Megginson,
+ *         <a href="mailto:sax@megginson.com">sax@megginson.com</a>
+ */
+public class AttributesImpl implements Attributes
+{
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constructors.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Construct a new, empty AttributesImpl object.
+     */
+    public AttributesImpl ()
+    {
+    length = 0;
+    data = null;
+    }
+
+
+    /**
+     * Copy an existing Attributes object.
+     *
+     * <p>This constructor is especially useful inside a
+     * {@link org.xml.sax.ContentHandler#startElement startElement} event.</p>
+     *
+     * @param atts The existing Attributes object.
+     */
+    public AttributesImpl (Attributes atts)
+    {
+    setAttributes(atts);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Implementation of org.xml.sax.Attributes.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Return the number of attributes in the list.
+     *
+     * @return The number of attributes in the list.
+     * @see org.xml.sax.Attributes#getLength
+     */
+    public int getLength ()
+    {
+    return length;
+    }
+
+
+    /**
+     * Return an attribute's Namespace URI.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The Namespace URI, the empty string if none is
+     *         available, or null if the index is out of range.
+     * @see org.xml.sax.Attributes#getURI
+     */
+    public String getURI (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Return an attribute's local name.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's local name, the empty string if
+     *         none is available, or null if the index if out of range.
+     * @see org.xml.sax.Attributes#getLocalName
+     */
+    public String getLocalName (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5+1];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Return an attribute's qualified (prefixed) name.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's qualified name, the empty string if
+     *         none is available, or null if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getQName
+     */
+    public String getQName (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5+2];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Return an attribute's type by index.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's type, "CDATA" if the type is unknown, or null
+     *         if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getType(int)
+     */
+    public String getType (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5+3];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Return an attribute's value by index.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's value or null if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getValue(int)
+     */
+    public String getValue (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5+4];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Look up an attribute's index by Namespace name.
+     *
+     * <p>In many cases, it will be more efficient to look up the name once and
+     * use the index query methods rather than using the name query methods
+     * repeatedly.</p>
+     *
+     * @param uri The attribute's Namespace URI, or the empty
+     *        string if none is available.
+     * @param localName The attribute's local name.
+     * @return The attribute's index, or -1 if none matches.
+     * @see org.xml.sax.Attributes#getIndex(java.lang.String,java.lang.String)
+     */
+    public int getIndex (String uri, String localName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i].equals(uri) && data[i+1].equals(localName)) {
+        return i / 5;
+        }
+    }
+    return -1;
+    }
+
+
+    /**
+     * Look up an attribute's index by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's index, or -1 if none matches.
+     * @see org.xml.sax.Attributes#getIndex(java.lang.String)
+     */
+    public int getIndex (String qName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i+2].equals(qName)) {
+        return i / 5;
+        }
+    }
+    return -1;
+    }
+
+
+    /**
+     * Look up an attribute's type by Namespace-qualified name.
+     *
+     * @param uri The Namespace URI, or the empty string for a name
+     *        with no explicit Namespace URI.
+     * @param localName The local name.
+     * @return The attribute's type, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getType(java.lang.String,java.lang.String)
+     */
+    public String getType (String uri, String localName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i].equals(uri) && data[i+1].equals(localName)) {
+        return data[i+3];
+        }
+    }
+    return null;
+    }
+
+
+    /**
+     * Look up an attribute's type by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's type, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getType(java.lang.String)
+     */
+    public String getType (String qName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i+2].equals(qName)) {
+        return data[i+3];
+        }
+    }
+    return null;
+    }
+
+
+    /**
+     * Look up an attribute's value by Namespace-qualified name.
+     *
+     * @param uri The Namespace URI, or the empty string for a name
+     *        with no explicit Namespace URI.
+     * @param localName The local name.
+     * @return The attribute's value, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getValue(java.lang.String,java.lang.String)
+     */
+    public String getValue (String uri, String localName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i].equals(uri) && data[i+1].equals(localName)) {
+        return data[i+4];
+        }
+    }
+    return null;
+    }
+
+
+    /**
+     * Look up an attribute's value by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's value, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getValue(java.lang.String)
+     */
+    public String getValue (String qName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i+2].equals(qName)) {
+        return data[i+4];
+        }
+    }
+    return null;
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Manipulators.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Clear the attribute list for reuse.
+     *
+     * <p>Note that no memory is actually freed by this call:
+     * the current arrays are kept so that they can be
+     * reused.</p>
+     */
+    public void clear ()
+    {
+    length = 0;
+    }
+
+
+    /**
+     * Copy an entire Attributes object.
+     *
+     * <p>It may be more efficient to reuse an existing object
+     * rather than constantly allocating new ones.</p>
+     *
+     * @param atts The attributes to copy.
+     */
+    public void setAttributes (Attributes atts)
+    {
+    clear();
+    length = atts.getLength();
+    data = new String[length*5];
+    for (int i = 0; i < length; i++) {
+        data[i*5] = atts.getURI(i);
+        data[i*5+1] = atts.getLocalName(i);
+        data[i*5+2] = atts.getQName(i);
+        data[i*5+3] = atts.getType(i);
+        data[i*5+4] = atts.getValue(i);
+    }
+    }
+
+
+    /**
+     * Add an attribute to the end of the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * to see if the attribute is already in the list: that is
+     * the responsibility of the application.</p>
+     *
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified (prefixed) name, or the empty string
+     *        if qualified names are not available.
+     * @param type The attribute type as a string.
+     * @param value The attribute value.
+     */
+    public void addAttribute (String uri, String localName, String qName,
+                  String type, String value)
+    {
+    ensureCapacity(length+1);
+    data[length*5] = uri;
+    data[length*5+1] = localName;
+    data[length*5+2] = qName;
+    data[length*5+3] = type;
+    data[length*5+4] = value;
+    length++;
+    }
+
+
+    /**
+     * Set an attribute in the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * for name conflicts or well-formedness: such checks are the
+     * responsibility of the application.</p>
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified name, or the empty string
+     *        if qualified names are not available.
+     * @param type The attribute type as a string.
+     * @param value The attribute value.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setAttribute (int index, String uri, String localName,
+                  String qName, String type, String value)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5] = uri;
+        data[index*5+1] = localName;
+        data[index*5+2] = qName;
+        data[index*5+3] = type;
+        data[index*5+4] = value;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Remove an attribute from the list.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void removeAttribute (int index)
+    {
+        if (index >= 0 && index < length) {
+            if (index < length - 1) {
+                System.arraycopy(data, (index+1)*5, data, index*5,
+                         (length-index-1)*5);
+            }
+            length--;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+    /**
+     * Set the Namespace URI of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param uri The attribute's Namespace URI, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setURI (int index, String uri)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5] = uri;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Set the local name of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param localName The attribute's local name, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setLocalName (int index, String localName)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5+1] = localName;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Set the qualified name of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param qName The attribute's qualified name, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setQName (int index, String qName)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5+2] = qName;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Set the type of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param type The attribute's type.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setType (int index, String type)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5+3] = type;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Set the value of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param value The attribute's value.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setValue (int index, String value)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5+4] = value;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Ensure the internal array's capacity.
+     *
+     * @param n The minimum number of attributes that the array must
+     *        be able to hold.
+     */
+    private void ensureCapacity (int n)
+    {
+    if (n > 0 && (data == null || data.length==0)) {
+        data = new String[25];
+    }
+
+    int max = data.length;
+    if (max >= n * 5) {
+        return;
+    }
+
+
+    while (max < n * 5) {
+        max *= 2;
+    }
+    String newData[] = new String[max];
+    System.arraycopy(data, 0, newData, 0, length*5);
+    data = newData;
+    }
+
+
+    /**
+     * Report a bad array index in a manipulator.
+     *
+     * @param index The index to report.
+     * @exception java.lang.ArrayIndexOutOfBoundsException Always.
+     */
+    private void badIndex (int index)
+    throws ArrayIndexOutOfBoundsException
+    {
+    String msg =
+        "Attempt to modify attribute at illegal index: " + index;
+    throw new ArrayIndexOutOfBoundsException(msg);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    int length;
+    String data [];
+
+}
+
+// end of AttributesImpl.java
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Classes.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Classes.java
new file mode 100644
index 0000000..ad701c2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Classes.java
@@ -0,0 +1,328 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.tools.internal.jxc.gen.config;
+import org.xml.sax.SAXException;
+import org.xml.sax.Attributes;
+import com.sun.tools.internal.jxc.NGCCRuntimeEx;
+
+import java.util.List;
+    import java.util.ArrayList;
+
+
+public class Classes extends NGCCHandler {
+    private String __text;
+    private String exclude_content;
+    private String include_content;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public Classes(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 12;
+    }
+
+    public Classes(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+         this.excludes.add(exclude_content);
+}
+
+    private void action1()throws SAXException {
+        $runtime.processList(__text);}
+
+    private void action2()throws SAXException {
+         this.includes.add(include_content);
+}
+
+    private void action3()throws SAXException {
+        $runtime.processList(__text);}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 12:
+            {
+                if(($__uri == "" && $__local == "classes")) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 11;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri == "" && $__local == "excludes")) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($__uri == "" && $__local == "includes")) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 10;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri == "" && $__local == "classes")) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                if(($__uri == "" && $__local == "includes")) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 2;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 3:
+            {
+                if(($__uri == "" && $__local == "excludes")) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                exclude_content = $value;
+                $_ngcc_current_state = 3;
+                action0();
+            }
+            break;
+        case 9:
+            {
+                include_content = $value;
+                $_ngcc_current_state = 8;
+                action2();
+            }
+            break;
+        case 6:
+            {
+                __text = $value;
+                $_ngcc_current_state = 4;
+                action1();
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        case 8:
+            {
+                include_content = $value;
+                $_ngcc_current_state = 8;
+                action2();
+            }
+            break;
+        case 10:
+            {
+                __text = $value;
+                $_ngcc_current_state = 9;
+                action3();
+            }
+            break;
+        case 3:
+            {
+                exclude_content = $value;
+                $_ngcc_current_state = 3;
+                action0();
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+       private List includes = new ArrayList();
+       public List getIncludes() { return $runtime.getIncludePatterns(this.includes);}
+       private List excludes = new ArrayList();
+       public List getExcludes() { return $runtime.getExcludePatterns(this.excludes);}
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Config.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Config.java
new file mode 100644
index 0000000..961df1c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Config.java
@@ -0,0 +1,327 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.tools.internal.jxc.gen.config;
+import org.xml.sax.SAXException;
+import org.xml.sax.Attributes;
+import com.sun.tools.internal.jxc.NGCCRuntimeEx;
+
+import java.util.List;
+    import java.util.ArrayList;
+    import java.io.File;
+
+
+public class Config extends NGCCHandler {
+    private String bd;
+    private Schema _schema;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public Config(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 8;
+    }
+
+    public Config(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+        this.schema.add (_schema);
+}
+
+    private void action1()throws SAXException {
+        baseDir = $runtime.getBaseDir(bd);
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri == "" && $__local == "schema")) {
+                    NGCCHandler h = new Schema(this, super._source, $runtime, 31, baseDir);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                if(($__uri == "" && $__local == "config")) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 7;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri == "" && $__local == "schema")) {
+                    NGCCHandler h = new Schema(this, super._source, $runtime, 32, baseDir);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","baseDir"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 4:
+            {
+                if(($__uri == "" && $__local == "classes")) {
+                    NGCCHandler h = new Classes(this, super._source, $runtime, 34);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri == "" && $__local == "config")) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","baseDir"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                if(($__uri == "" && $__local == "baseDir")) {
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 5:
+            {
+                if(($__uri == "" && $__local == "baseDir")) {
+                    $_ngcc_current_state = 4;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 6:
+            {
+                bd = $value;
+                $_ngcc_current_state = 5;
+                action1();
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","baseDir"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 31:
+            {
+                _schema = ((Schema)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 32:
+            {
+                _schema = ((Schema)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 34:
+            {
+                classes = ((Classes)$__result__);
+                $_ngcc_current_state = 2;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+   private File baseDir;
+   private Classes classes;
+   private List schema = new ArrayList();
+   public Classes getClasses() { return this.classes;}
+   public File getBaseDir() { return baseDir;}
+   public List getSchema() { return this.schema;}
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCEventReceiver.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCEventReceiver.java
new file mode 100644
index 0000000..b4ee989
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCEventReceiver.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.gen.config;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ *
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface NGCCEventReceiver {
+    void enterElement(String uri, String localName, String qname,Attributes atts) throws SAXException;
+    void leaveElement(String uri, String localName, String qname) throws SAXException;
+    void text(String value) throws SAXException;
+    void enterAttribute(String uri, String localName, String qname) throws SAXException;
+    void leaveAttribute(String uri, String localName, String qname) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCEventSource.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCEventSource.java
new file mode 100644
index 0000000..ed59a08
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCEventSource.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.gen.config;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ *
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface NGCCEventSource {
+    /**
+     * Replaces an old handler with a new handler, and returns
+     * ID of the EventReceiver thread.
+     */
+    int replace( NGCCEventReceiver _old, NGCCEventReceiver _new );
+
+    /** Sends an enter element event to the specified EventReceiver thread. */
+    void sendEnterElement( int receiverThreadId, String uri, String local, String qname, Attributes atts ) throws SAXException;
+
+    void sendLeaveElement( int receiverThreadId, String uri, String local, String qname ) throws SAXException;
+    void sendEnterAttribute( int receiverThreadId, String uri, String local, String qname ) throws SAXException;
+    void sendLeaveAttribute( int receiverThreadId, String uri, String local, String qname ) throws SAXException;
+    void sendText( int receiverThreadId, String value ) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCHandler.java
new file mode 100644
index 0000000..db72354
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCHandler.java
@@ -0,0 +1,190 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.gen.config;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ *
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class NGCCHandler implements NGCCEventReceiver {
+    protected NGCCHandler( NGCCEventSource source, NGCCHandler parent, int parentCookie ) {
+
+        _parent = parent;
+        _source = source;
+        _cookie = parentCookie;
+    }
+
+    /**
+     * Parent NGCCHandler, if any.
+     * If this is the root handler, this field will be null.
+     */
+    protected final NGCCHandler _parent;
+
+    /**
+     * Event source.
+     */
+    protected final NGCCEventSource _source;
+
+    /**
+     * This method will be implemented by the generated code
+     * and returns a reference to the current runtime.
+     */
+    protected abstract NGCCRuntime getRuntime();
+
+    /**
+     * Cookie assigned by the parent.
+     *
+     * This value will be passed to the onChildCompleted handler
+     * of the parent.
+     */
+    protected final int _cookie;
+
+    // used to copy parameters to (enter|leave)(Element|Attribute) events.
+    //protected String localName,uri,qname;
+
+
+    /**
+     * Notifies the completion of a child object.
+     *
+     * @param result
+     *      The parsing result of the child state.
+     * @param cookie
+     *      The cookie value passed to the child object
+     *      when it is created.
+     * @param needAttCheck
+     *      This flag is true when the callee needs to call the
+     *      processAttribute method to check attribute transitions.
+     *      This flag is set to false when this method is triggered by
+     *      attribute transition.
+     */
+    protected abstract void onChildCompleted( Object result, int cookie, boolean needAttCheck ) throws SAXException;
+
+//
+//
+// spawns a new child object from event handlers.
+//
+//
+    public void spawnChildFromEnterElement( NGCCEventReceiver child,
+        String uri, String localname, String qname, Attributes atts) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendEnterElement(id,uri,localname,qname,atts);
+    }
+    public void spawnChildFromEnterAttribute( NGCCEventReceiver child,
+        String uri, String localname, String qname) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendEnterAttribute(id,uri,localname,qname);
+    }
+    public void spawnChildFromLeaveElement( NGCCEventReceiver child,
+        String uri, String localname, String qname) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendLeaveElement(id,uri,localname,qname);
+    }
+    public void spawnChildFromLeaveAttribute( NGCCEventReceiver child,
+        String uri, String localname, String qname) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendLeaveAttribute(id,uri,localname,qname);
+    }
+    public void spawnChildFromText( NGCCEventReceiver child,
+        String value) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendText(id,value);
+    }
+
+//
+//
+// reverts to the parent object from the child handler
+//
+//
+    public void revertToParentFromEnterElement( Object result, int cookie,
+        String uri,String local,String qname, Attributes atts ) throws SAXException {
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendEnterElement(id,uri,local,qname,atts);
+    }
+    public void revertToParentFromLeaveElement( Object result, int cookie,
+        String uri,String local,String qname ) throws SAXException {
+
+        if(uri==NGCCRuntime.IMPOSSIBLE && uri==local && uri==qname && _parent==null )
+            // all the handlers are properly finalized.
+            // quit now, because we don't have any more NGCCHandler.
+            // see the endDocument handler for detail
+            return;
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendLeaveElement(id,uri,local,qname);
+    }
+    public void revertToParentFromEnterAttribute( Object result, int cookie,
+        String uri,String local,String qname ) throws SAXException {
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendEnterAttribute(id,uri,local,qname);
+    }
+    public void revertToParentFromLeaveAttribute( Object result, int cookie,
+        String uri,String local,String qname ) throws SAXException {
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendLeaveAttribute(id,uri,local,qname);
+    }
+    public void revertToParentFromText( Object result, int cookie,
+        String text ) throws SAXException {
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendText(id,text);
+    }
+
+
+//
+//
+// error handler
+//
+//
+    public void unexpectedEnterElement(String qname) throws SAXException {
+        getRuntime().unexpectedX('<'+qname+'>');
+    }
+    public void unexpectedLeaveElement(String qname) throws SAXException {
+        getRuntime().unexpectedX("</"+qname+'>');
+    }
+    public void unexpectedEnterAttribute(String qname) throws SAXException {
+        getRuntime().unexpectedX('@'+qname);
+    }
+    public void unexpectedLeaveAttribute(String qname) throws SAXException {
+        getRuntime().unexpectedX("/@"+qname);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCInterleaveFilter.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCInterleaveFilter.java
new file mode 100644
index 0000000..180a830
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCInterleaveFilter.java
@@ -0,0 +1,350 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.gen.config;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ * Dispatches incoming events into sub handlers appropriately
+ * so that the interleaving semantics will be correctly realized.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class NGCCInterleaveFilter implements NGCCEventSource, NGCCEventReceiver {
+    protected NGCCInterleaveFilter( NGCCHandler parent, int cookie ) {
+        this._parent = parent;
+        this._cookie = cookie;
+    }
+
+    protected void setHandlers( NGCCEventReceiver[] receivers ) {
+        this._receivers = receivers;
+    }
+
+    /** event receiverse. */
+    protected NGCCEventReceiver[] _receivers;
+
+    public int replace(NGCCEventReceiver oldHandler, NGCCEventReceiver newHandler) {
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]==oldHandler ) {
+                _receivers[i]=newHandler;
+                return i;
+            }
+        throw new InternalError(); // a bug in RelaxNGCC.
+    }
+
+
+    /** Parent handler. */
+    private final NGCCHandler _parent;
+    /** Cookie given by the parent. */
+    private final int _cookie;
+
+
+
+//
+//
+// event handler
+//
+//
+    /**
+     * Receiver that is being locked and therefore receives all the events.
+     * <pre><xmp>
+     * <interleave>
+     *   <element name="foo"/>
+     *   <element name="bar">
+     *     <element name="foo"/>
+     *   </element>
+     * </interlaeve>
+     * </xmp></pre>
+     * When processing inside the bar element, this receiver is
+     * "locked" so that it can correctly receive its child foo element.
+     */
+    private int lockedReceiver;
+    /**
+     * Nest level. Lock will be release when the lockCount becomes 0.
+     */
+    private int lockCount=0;
+
+    public void enterElement(
+        String uri, String localName, String qname,Attributes atts) throws SAXException {
+
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if(lockCount++==0) {
+            lockedReceiver = findReceiverOfElement(uri,localName);
+            if(lockedReceiver==-1) {
+                // we can't process this token. join.
+                joinByEnterElement(null,uri,localName,qname,atts);
+                return;
+            }
+        }
+
+        _receivers[lockedReceiver].enterElement(uri,localName,qname,atts);
+    }
+    public void leaveElement(String uri, String localName, String qname) throws SAXException {
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if( lockCount-- == 0 )
+            joinByLeaveElement(null,uri,localName,qname);
+        else
+            _receivers[lockedReceiver].leaveElement(uri,localName,qname);
+    }
+    public void enterAttribute(String uri, String localName, String qname) throws SAXException {
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if(lockCount++==0) {
+            lockedReceiver = findReceiverOfAttribute(uri,localName);
+            if(lockedReceiver==-1) {
+                // we can't process this token. join.
+                joinByEnterAttribute(null,uri,localName,qname);
+                return;
+            }
+        }
+
+        _receivers[lockedReceiver].enterAttribute(uri,localName,qname);
+    }
+    public void leaveAttribute(String uri, String localName, String qname) throws SAXException {
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if( lockCount-- == 0 )
+            joinByLeaveAttribute(null,uri,localName,qname);
+        else
+            _receivers[lockedReceiver].leaveAttribute(uri,localName,qname);
+    }
+    public void text(String value) throws SAXException {
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if(lockCount!=0)
+            _receivers[lockedReceiver].text(value);
+        else {
+            int receiver = findReceiverOfText();
+            if(receiver!=-1)    _receivers[receiver].text(value);
+            else                joinByText(null,value);
+        }
+    }
+
+
+
+    /**
+     * Implemented by the generated code to determine the handler
+     * that can receive the given element.
+     *
+     * @return
+     *      Thread ID of the receiver that can handle this event,
+     *      or -1 if none.
+     */
+    protected abstract int findReceiverOfElement( String uri, String local );
+
+    /**
+     * Returns the handler that can receive the given attribute, or null.
+     */
+    protected abstract int findReceiverOfAttribute( String uri, String local );
+
+    /**
+     * Returns the handler that can receive text events, or null.
+     */
+    protected abstract int findReceiverOfText();
+
+
+
+
+//
+//
+// join method
+//
+//
+
+
+    /**
+     * Set to true when this handler is in the process of
+     * joining all branches.
+     */
+    private boolean isJoining = false;
+
+    /**
+     * Joins all the child receivers.
+     *
+     * <p>
+     * This method is called by a child receiver when it sees
+     * something that it cannot handle, or by this object itself
+     * when it sees an event that it can't process.
+     *
+     * <p>
+     * This method forces children to move to its final state,
+     * then revert to the parent.
+     *
+     * @param source
+     *      If this method is called by one of the child receivers,
+     *      the receiver object. If this method is called by itself,
+     *      null.
+     */
+    public void joinByEnterElement( NGCCEventReceiver source,
+        String uri, String local, String qname, Attributes atts ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].enterElement(uri,local,qname,atts);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.enterElement(uri,local,qname,atts);
+    }
+
+    public void joinByLeaveElement( NGCCEventReceiver source,
+        String uri, String local, String qname ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].leaveElement(uri,local,qname);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.leaveElement(uri,local,qname);
+    }
+
+    public void joinByEnterAttribute( NGCCEventReceiver source,
+        String uri, String local, String qname ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].enterAttribute(uri,local,qname);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.enterAttribute(uri,local,qname);
+    }
+
+    public void joinByLeaveAttribute( NGCCEventReceiver source,
+        String uri, String local, String qname ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].leaveAttribute(uri,local,qname);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.leaveAttribute(uri,local,qname);
+    }
+
+    public void joinByText( NGCCEventReceiver source,
+        String value ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].text(value);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.text(value);
+    }
+
+
+
+//
+//
+// event dispatching methods
+//
+//
+
+    public void sendEnterAttribute( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        _receivers[threadId].enterAttribute(uri,local,qname);
+    }
+
+    public void sendEnterElement( int threadId,
+        String uri, String local, String qname, Attributes atts) throws SAXException {
+
+        _receivers[threadId].enterElement(uri,local,qname,atts);
+    }
+
+    public void sendLeaveAttribute( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        _receivers[threadId].leaveAttribute(uri,local,qname);
+    }
+
+    public void sendLeaveElement( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        _receivers[threadId].leaveElement(uri,local,qname);
+    }
+
+    public void sendText(int threadId, String value) throws SAXException {
+        _receivers[threadId].text(value);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCRuntime.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCRuntime.java
new file mode 100644
index 0000000..6d942a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/NGCCRuntime.java
@@ -0,0 +1,562 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.gen.config;
+
+import java.text.MessageFormat;
+import java.util.ArrayList;
+import java.util.Stack;
+import java.util.StringTokenizer;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Runtime Engine for RELAXNGCC execution.
+ *
+ * This class has the following functionalities:
+ *
+ * <ol>
+ *  <li>Managing a stack of NGCCHandler objects and
+ *      switching between them appropriately.
+ *
+ *  <li>Keep track of all Attributes.
+ *
+ *  <li>manage mapping between namespace URIs and prefixes.
+ *
+ *  <li>TODO: provide support for interleaving.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class NGCCRuntime implements ContentHandler, NGCCEventSource {
+
+    public NGCCRuntime() {
+        reset();
+    }
+
+    /**
+     * Sets the root handler, which will be used to parse the
+     * root element.
+     * <p>
+     * This method can be called right after the object is created
+     * or the reset method is called. You can't replace the root
+     * handler while parsing is in progress.
+     * <p>
+     * Usually a generated class that corresponds to the &lt;start>
+     * pattern will be used as the root handler, but any NGCCHandler
+     * can be a root handler.
+     *
+     * @exception IllegalStateException
+     *      If this method is called but it doesn't satisfy the
+     *      pre-condition stated above.
+     */
+    public void setRootHandler( NGCCHandler rootHandler ) {
+        if(currentHandler!=null)
+            throw new IllegalStateException();
+        currentHandler = rootHandler;
+    }
+
+
+    /**
+     * Cleans up all the data structure so that the object can be reused later.
+     * Normally, applications do not need to call this method directly,
+     *
+     * as the runtime resets itself after the endDocument method.
+     */
+    public void reset() {
+        attStack.clear();
+        currentAtts = null;
+        currentHandler = null;
+        indent=0;
+        locator = null;
+        namespaces.clear();
+        needIndent = true;
+        redirect = null;
+        redirectionDepth = 0;
+        text = new StringBuffer();
+
+        // add a dummy attributes at the bottom as a "centinel."
+        attStack.push(new AttributesImpl());
+    }
+
+    // current content handler can be acccessed via set/getContentHandler.
+
+    private Locator locator;
+    public void setDocumentLocator( Locator _loc ) { this.locator=_loc; }
+    /**
+     * Gets the source location of the current event.
+     *
+     * <p>
+     * One can call this method from RelaxNGCC handlers to access
+     * the line number information. Note that to
+     */
+    public Locator getLocator() { return locator; }
+
+
+    /** stack of {@link Attributes}. */
+    private final Stack attStack = new Stack();
+    /** current attributes set. always equal to attStack.peek() */
+    private AttributesImpl currentAtts;
+
+    /**
+     * Attributes that belong to the current element.
+     * <p>
+     * It's generally not recommended for applications to use
+     * this method. RelaxNGCC internally removes processed attributes,
+     * so this doesn't correctly reflect all the attributes an element
+     * carries.
+     */
+    public Attributes getCurrentAttributes() {
+        return currentAtts;
+    }
+
+    /** accumulated text. */
+    private StringBuffer text = new StringBuffer();
+
+
+
+
+    /** The current NGCCHandler. Always equals to handlerStack.peek() */
+    private NGCCEventReceiver currentHandler;
+
+    public int replace( NGCCEventReceiver o, NGCCEventReceiver n ) {
+        if(o!=currentHandler)
+            throw new IllegalStateException();  // bug of RelaxNGCC
+        currentHandler = n;
+
+        return 0;   // we only have one thread.
+    }
+
+    /**
+     * Processes buffered text.
+     *
+     * This method will be called by the start/endElement event to process
+     * buffered text as a text event.
+     *
+     * <p>
+     * Whitespace handling is a tricky business. Consider the following
+     * schema fragment:
+     *
+     * <xmp>
+     * <element name="foo">
+     *   <choice>
+     *     <element name="bar"><empty/></element>
+     *     <text/>
+     *   </choice>
+     * </element>
+     * </xmp>
+     *
+     * Assume we hit the following instance:
+     * <xmp>
+     * <foo> <bar/></foo>
+     * </xmp>
+     *
+     * Then this first space needs to be ignored (for otherwise, we will
+     * end up treating this space as the match to &lt;text/> and won't
+     * be able to process &lt;bar>.)
+     *
+     * Now assume the following instance:
+     * <xmp>
+     * <foo/>
+     * </xmp>
+     *
+     * This time, we need to treat this empty string as a text, for
+     * otherwise we won't be able to accept this instance.
+     *
+     * <p>
+     * This is very difficult to solve in general, but one seemingly
+     * easy solution is to use the type of next event. If a text is
+     * followed by a start tag, it follows from the constraint on
+     * RELAX NG that that text must be either whitespaces or a match
+     * to &lt;text/>.
+     *
+     * <p>
+     * On the contrary, if a text is followed by a end tag, then it
+     * cannot be whitespace unless the content model can accept empty,
+     * in which case sending a text event will be harmlessly ignored
+     * by the NGCCHandler.
+     *
+     * <p>
+     * Thus this method take one parameter, which controls the
+     * behavior of this method.
+     *
+     * <p>
+     * TODO: according to the constraint of RELAX NG, if characters
+     * follow an end tag, then they must be either whitespaces or
+     * must match to &lt;text/>.
+     *
+     * @param   possiblyWhitespace
+     *      True if the buffered character can be ignorabale. False if
+     *      it needs to be consumed.
+     */
+    private void processPendingText(boolean ignorable) throws SAXException {
+        if(ignorable && text.toString().trim().length()==0)
+            ; // ignore. See the above javadoc comment for the description
+        else
+            currentHandler.text(text.toString());   // otherwise consume this token
+
+        // truncate StringBuffer, but avoid excessive allocation.
+        if(text.length()>1024)  text = new StringBuffer();
+        else                    text.setLength(0);
+    }
+
+    public void processList( String str ) throws SAXException {
+        StringTokenizer t = new StringTokenizer(str, " \t\r\n");
+        while(t.hasMoreTokens())
+            currentHandler.text(t.nextToken());
+    }
+
+    public void startElement(String uri, String localname, String qname, Attributes atts)
+            throws SAXException {
+
+        uri = uri.intern();
+        localname = localname.intern();
+        qname = qname.intern();
+
+        if(redirect!=null) {
+            redirect.startElement(uri,localname,qname,atts);
+            redirectionDepth++;
+        } else {
+            processPendingText(true);
+    //        System.out.println("startElement:"+localname+"->"+_attrStack.size());
+            currentHandler.enterElement(uri, localname, qname, atts);
+        }
+    }
+
+    /**
+     * Called by the generated handler code when an enter element
+     * event is consumed.
+     *
+     * <p>
+     * Pushes a new attribute set.
+     *
+     * <p>
+     * Note that attributes are NOT pushed at the startElement method,
+     * because the processing of the enterElement event can trigger
+     * other attribute events and etc.
+     * <p>
+     * This method will be called from one of handlers when it truely
+     * consumes the enterElement event.
+     */
+    public void onEnterElementConsumed(
+        String uri, String localName, String qname,Attributes atts) throws SAXException {
+        attStack.push(currentAtts=new AttributesImpl(atts));
+        nsEffectiveStack.push( new Integer(nsEffectivePtr) );
+        nsEffectivePtr = namespaces.size();
+    }
+
+    public void onLeaveElementConsumed(String uri, String localName, String qname) throws SAXException {
+        attStack.pop();
+        if(attStack.isEmpty())
+            currentAtts = null;
+        else
+            currentAtts = (AttributesImpl)attStack.peek();
+        nsEffectivePtr = ((Integer)nsEffectiveStack.pop()).intValue();
+    }
+
+    public void endElement(String uri, String localname, String qname)
+            throws SAXException {
+
+        uri = uri.intern();
+        localname = localname.intern();
+        qname = qname.intern();
+
+        if(redirect!=null) {
+            redirect.endElement(uri,localname,qname);
+            redirectionDepth--;
+
+            if(redirectionDepth!=0)
+                return;
+
+            // finished redirection.
+            for( int i=0; i<namespaces.size(); i+=2 )
+                redirect.endPrefixMapping((String)namespaces.get(i));
+            redirect.endDocument();
+
+            redirect = null;
+            // then process this element normally
+        }
+
+        processPendingText(false);
+
+        currentHandler.leaveElement(uri, localname, qname);
+//        System.out.println("endElement:"+localname);
+    }
+
+    public void characters(char[] ch, int start, int length) throws SAXException {
+        if(redirect!=null)
+            redirect.characters(ch,start,length);
+        else
+            text.append(ch,start,length);
+    }
+    public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
+        if(redirect!=null)
+            redirect.ignorableWhitespace(ch,start,length);
+        else
+            text.append(ch,start,length);
+    }
+
+    public int getAttributeIndex(String uri, String localname) {
+        return currentAtts.getIndex(uri, localname);
+    }
+    public void consumeAttribute(int index) throws SAXException {
+        final String uri    = currentAtts.getURI(index).intern();
+        final String local  = currentAtts.getLocalName(index).intern();
+        final String qname  = currentAtts.getQName(index).intern();
+        final String value  = currentAtts.getValue(index);
+        currentAtts.removeAttribute(index);
+
+        currentHandler.enterAttribute(uri,local,qname);
+        currentHandler.text(value);
+        currentHandler.leaveAttribute(uri,local,qname);
+    }
+
+
+    public void startPrefixMapping( String prefix, String uri ) throws SAXException {
+        if(redirect!=null)
+            redirect.startPrefixMapping(prefix,uri);
+        else {
+            namespaces.add(prefix);
+            namespaces.add(uri);
+        }
+    }
+
+    public void endPrefixMapping( String prefix ) throws SAXException {
+        if(redirect!=null)
+            redirect.endPrefixMapping(prefix);
+        else {
+            namespaces.remove(namespaces.size()-1);
+            namespaces.remove(namespaces.size()-1);
+        }
+    }
+
+    public void skippedEntity( String name ) throws SAXException {
+        if(redirect!=null)
+            redirect.skippedEntity(name);
+    }
+
+    public void processingInstruction( String target, String data ) throws SAXException {
+        if(redirect!=null)
+            redirect.processingInstruction(target,data);
+    }
+
+    /** Impossible token. This value can never be a valid XML name. */
+    static final String IMPOSSIBLE = "\u0000";
+
+    public void endDocument() throws SAXException {
+        // consume the special "end document" token so that all the handlers
+        // currently at the stack will revert to their respective parents.
+        //
+        // this is necessary to handle a grammar like
+        // <start><ref name="X"/></start>
+        // <define name="X">
+        //   <element name="root"><empty/></element>
+        // </define>
+        //
+        // With this grammar, when the endElement event is consumed, two handlers
+        // are on the stack (because a child object won't revert to its parent
+        // unless it sees a next event.)
+
+        // pass around an "impossible" token.
+        currentHandler.leaveElement(IMPOSSIBLE,IMPOSSIBLE,IMPOSSIBLE);
+
+        reset();
+    }
+    public void startDocument() throws SAXException {}
+
+
+
+
+//
+//
+// event dispatching methods
+//
+//
+
+    public void sendEnterAttribute( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        currentHandler.enterAttribute(uri,local,qname);
+    }
+
+    public void sendEnterElement( int threadId,
+        String uri, String local, String qname, Attributes atts) throws SAXException {
+
+        currentHandler.enterElement(uri,local,qname,atts);
+    }
+
+    public void sendLeaveAttribute( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        currentHandler.leaveAttribute(uri,local,qname);
+    }
+
+    public void sendLeaveElement( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        currentHandler.leaveElement(uri,local,qname);
+    }
+
+    public void sendText(int threadId, String value) throws SAXException {
+        currentHandler.text(value);
+    }
+
+
+//
+//
+// redirection of SAX2 events.
+//
+//
+    /** When redirecting a sub-tree, this value will be non-null. */
+    private ContentHandler redirect = null;
+
+    /**
+     * Counts the depth of the elements when we are re-directing
+     * a sub-tree to another ContentHandler.
+     */
+    private int redirectionDepth = 0;
+
+    /**
+     * This method can be called only from the enterElement handler.
+     * The sub-tree rooted at the new element will be redirected
+     * to the specified ContentHandler.
+     *
+     * <p>
+     * Currently active NGCCHandler will only receive the leaveElement
+     * event of the newly started element.
+     *
+     * @param   uri,local,qname
+     *      Parameters passed to the enter element event. Used to
+     *      simulate the startElement event for the new ContentHandler.
+     */
+    public void redirectSubtree( ContentHandler child,
+        String uri, String local, String qname ) throws SAXException {
+
+        redirect = child;
+        redirect.setDocumentLocator(locator);
+        redirect.startDocument();
+
+        // TODO: when a prefix is re-bound to something else,
+        // the following code is potentially dangerous. It should be
+        // modified to report active bindings only.
+        for( int i=0; i<namespaces.size(); i+=2 )
+            redirect.startPrefixMapping(
+                (String)namespaces.get(i),
+                (String)namespaces.get(i+1)
+            );
+
+        redirect.startElement(uri,local,qname,currentAtts);
+        redirectionDepth=1;
+    }
+
+//
+//
+// validation context implementation
+//
+//
+    /** in-scope namespace mapping.
+     * namespaces[2n  ] := prefix
+     * namespaces[2n+1] := namespace URI */
+    private final ArrayList namespaces = new ArrayList();
+    /**
+     * Index on the namespaces array, which points to
+     * the top of the effective bindings. Because of the
+     * timing difference between the startPrefixMapping method
+     * and the execution of the corresponding actions,
+     * this value can be different from <code>namespaces.size()</code>.
+     * <p>
+     * For example, consider the following schema:
+     * <pre><xmp>
+     *  <oneOrMore>
+     *   <element name="foo"><empty/></element>
+     *  </oneOrMore>
+     *  code fragment X
+     *  <element name="bob"/>
+     * </xmp></pre>
+     * Code fragment X is executed after we see a startElement event,
+     * but at this time the namespaces variable already include new
+     * namespace bindings declared on "bob".
+     */
+    private int nsEffectivePtr=0;
+
+    /**
+     * Stack to preserve old nsEffectivePtr values.
+     */
+    private final Stack nsEffectiveStack = new Stack();
+
+    public String resolveNamespacePrefix( String prefix ) {
+        for( int i = nsEffectivePtr-2; i>=0; i-=2 )
+            if( namespaces.get(i).equals(prefix) )
+                return (String)namespaces.get(i+1);
+
+        // no binding was found.
+        if(prefix.equals(""))   return "";  // return the default no-namespace
+        if(prefix.equals("xml"))    // pre-defined xml prefix
+            return "http://www.w3.org/XML/1998/namespace";
+        else    return null;    // prefix undefined
+    }
+
+
+// error reporting
+    protected void unexpectedX(String token) throws SAXException {
+        throw new SAXParseException(MessageFormat.format(
+            "Unexpected {0} appears at line {1} column {2}",
+            new Object[]{
+                token,
+                new Integer(getLocator().getLineNumber()),
+                new Integer(getLocator().getColumnNumber()) }),
+            getLocator());
+    }
+
+
+
+
+//
+//
+// trace functions
+//
+//
+    private int indent=0;
+    private boolean needIndent=true;
+    private void printIndent() {
+        for( int i=0; i<indent; i++ )
+            System.out.print("  ");
+    }
+    public void trace( String s ) {
+        if(needIndent) {
+            needIndent=false;
+            printIndent();
+        }
+        System.out.print(s);
+    }
+    public void traceln( String s ) {
+        trace(s);
+        trace("\n");
+        needIndent=true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Schema.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Schema.java
new file mode 100644
index 0000000..4895421
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/Schema.java
@@ -0,0 +1,324 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.tools.internal.jxc.gen.config;
+import org.xml.sax.SAXException;
+import org.xml.sax.Attributes;
+import com.sun.tools.internal.jxc.NGCCRuntimeEx;
+
+import java.io.File;
+
+
+public class Schema extends NGCCHandler {
+    private File baseDir;
+    private String loc;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public Schema(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, File _baseDir) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.baseDir = _baseDir;
+        $_ngcc_current_state = 10;
+    }
+
+    public Schema(NGCCRuntimeEx runtime, File _baseDir) {
+        this(null, runtime, runtime, -1, _baseDir);
+    }
+
+    private void action0()throws SAXException {
+        location = new File(baseDir,loc);
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                if(($ai = $runtime.getAttributeIndex("","location"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($__uri == "" && $__local == "schema")) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if(($__uri == "" && $__local == "schema")) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($ai = $runtime.getAttributeIndex("","location"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                if(($__uri == "" && $__local == "location")) {
+                    $_ngcc_current_state = 4;
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                if(($__uri == "" && $__local == "namespace")) {
+                    $_ngcc_current_state = 8;
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 7:
+            {
+                if(($__uri == "" && $__local == "namespace")) {
+                    $_ngcc_current_state = 2;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 3:
+            {
+                if(($__uri == "" && $__local == "location")) {
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                loc = $value;
+                $_ngcc_current_state = 3;
+                action0();
+            }
+            break;
+        case 2:
+            {
+                if(($ai = $runtime.getAttributeIndex("","location"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 8:
+            {
+                namespace = $value;
+                $_ngcc_current_state = 7;
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+       private File location;
+       private String namespace;
+       public String getNamespace() { return this.namespace;}
+       public File getLocation() { return this.location;}
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/config.rng b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/config.rng
new file mode 100644
index 0000000..697f3ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/config.rng
@@ -0,0 +1,106 @@
+<?xml version="1.0"?>
+<grammar
+ xmlns="http://relaxng.org/ns/structure/1.0"
+ xmlns:r="http://relaxng.org/ns/structure/1.0"
+ xmlns:a="http://relaxng.org/ns/annotation/1.0"
+ xmlns:ref="urn:crossreference"
+ xmlns:c="http://www.xml.gr.jp/xmlns/relaxngcc"
+ c:runtime-type="com.sun.tools.internal.jxc.NGCCRuntimeEx"
+ datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes"
+ c:package="com.sun.tools.internal.jxc.gen.config">
+
+
+<start c:class="Config" c:access="public">
+
+ <c:java-import>
+    import java.util.List;
+    import java.util.ArrayList;
+    import java.io.File;
+ </c:java-import>
+
+<c:java-body>
+   private File baseDir;
+   private Classes classes;
+   private List schema = new ArrayList();
+   public Classes getClasses() { return this.classes;}
+   public File getBaseDir() { return baseDir;}
+   public List getSchema() { return this.schema;}
+</c:java-body>
+
+  <element name="config">
+     <attribute name="baseDir">
+        bd = <data type="string"/>
+        baseDir = $runtime.getBaseDir(bd);
+     </attribute>
+     <ref name="Classes" c:alias="classes"/>
+     <zeroOrMore>
+        <ref name="Schema" c:alias="_schema" />(baseDir);
+        this.schema.add (_schema);
+     </zeroOrMore>
+     </element>
+  </start>
+
+
+   <define name="Classes" c:access="public">
+   <c:java-import>
+    import java.util.List;
+    import java.util.ArrayList;
+    </c:java-import>
+     <c:java-body>
+       private List includes = new ArrayList();
+       public List getIncludes() { return $runtime.getIncludePatterns(this.includes);}
+       private List excludes = new ArrayList();
+       public List getExcludes() { return $runtime.getExcludePatterns(this.excludes);}
+       </c:java-body>
+     <element name="classes">
+
+        <element name="includes">
+            <list>
+               <oneOrMore>
+                <data type="string" c:alias="include_content"/>
+                <c:java> this.includes.add(include_content); </c:java>
+               </oneOrMore>
+            </list>
+
+         </element>
+        <optional>
+        <element name="excludes">
+            <list>
+               <zeroOrMore>
+                <data type="string" c:alias="exclude_content"/>
+                <c:java> this.excludes.add(exclude_content); </c:java>
+               </zeroOrMore>
+            </list>
+
+         </element>
+        </optional>
+     </element>
+    </define>
+
+
+   <define name="Schema" c:access="public" c:params="File baseDir">
+     <c:java-import>
+       import java.io.File;
+     </c:java-import>
+     <c:java-body>
+       private File location;
+       private String namespace;
+       public String getNamespace() { return this.namespace;}
+       public File getLocation() { return this.location;}
+     </c:java-body>
+     <element name="schema">
+       <optional>
+         <attribute name="namespace">
+           namespace = <data type="string" />
+         </attribute>
+       </optional>
+
+       <optional>
+         <attribute name="location">
+           loc = <data type="string" />
+           location = new File(baseDir,loc);
+         </attribute>
+       </optional>
+     </element>
+  </define>
+</grammar>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/config.xsd b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/config.xsd
new file mode 100644
index 0000000..7d6456c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/gen/config/config.xsd
@@ -0,0 +1,68 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!--
+ Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+ This code is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License version 2 only, as
+ published by the Free Software Foundation.  Sun designates this
+ particular file as subject to the "Classpath" exception as provided
+ by Sun in the LICENSE file that accompanied this code.
+
+ This code is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ version 2 for more details (a copy is included in the LICENSE file that
+ accompanied this code).
+
+ You should have received a copy of the GNU General Public License version
+ 2 along with this work; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+ Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ CA 95054 USA or visit www.sun.com if you need additional information or
+ have any questions.
+-->
+
+<!-- THIS IS A GENERATED FILE. DO NOT MODIFY. -->
+<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified">
+  <xs:element name="config">
+    <xs:complexType>
+      <xs:sequence>
+        <xs:element ref="classes"/>
+        <xs:element minOccurs="0" maxOccurs="unbounded" ref="schema"/>
+      </xs:sequence>
+      <xs:attribute name="baseDir" use="required" type="xs:string"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="classes">
+    <xs:complexType>
+      <xs:sequence>
+        <xs:element ref="includes"/>
+        <xs:element minOccurs="0" ref="excludes"/>
+      </xs:sequence>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="includes">
+    <xs:simpleType>
+      <xs:restriction>
+        <xs:simpleType>
+          <xs:list itemType="xs:string"/>
+        </xs:simpleType>
+        <xs:minLength value="1"/>
+      </xs:restriction>
+    </xs:simpleType>
+  </xs:element>
+  <xs:element name="excludes">
+    <xs:simpleType>
+      <xs:list itemType="xs:string"/>
+    </xs:simpleType>
+  </xs:element>
+  <xs:element name="schema">
+    <xs:complexType>
+      <xs:attribute name="namespace" type="xs:string"/>
+      <xs:attribute name="location" type="xs:string"/>
+    </xs:complexType>
+  </xs:element>
+</xs:schema>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/jxc/model/nav/APTNavigator.java b/jaxws/src/share/classes/com/sun/tools/internal/jxc/model/nav/APTNavigator.java
new file mode 100644
index 0000000..836f191
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/jxc/model/nav/APTNavigator.java
@@ -0,0 +1,551 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.jxc.model.nav;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import com.sun.istack.internal.tools.APTTypeVisitor;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.declaration.ClassDeclaration;
+import com.sun.mirror.declaration.ConstructorDeclaration;
+import com.sun.mirror.declaration.Declaration;
+import com.sun.mirror.declaration.EnumConstantDeclaration;
+import com.sun.mirror.declaration.EnumDeclaration;
+import com.sun.mirror.declaration.FieldDeclaration;
+import com.sun.mirror.declaration.InterfaceDeclaration;
+import com.sun.mirror.declaration.MemberDeclaration;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.Modifier;
+import com.sun.mirror.declaration.ParameterDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.type.ArrayType;
+import com.sun.mirror.type.ClassType;
+import com.sun.mirror.type.DeclaredType;
+import com.sun.mirror.type.InterfaceType;
+import com.sun.mirror.type.PrimitiveType;
+import com.sun.mirror.type.ReferenceType;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.type.TypeVariable;
+import com.sun.mirror.type.VoidType;
+import com.sun.mirror.type.WildcardType;
+import com.sun.mirror.util.Declarations;
+import com.sun.mirror.util.SourcePosition;
+import com.sun.mirror.util.TypeVisitor;
+import com.sun.mirror.util.Types;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link Navigator} implementation for APT.
+ *
+ * TODO: check the spec on how generics are supposed to be handled
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class APTNavigator implements Navigator<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration> {
+
+    private final AnnotationProcessorEnvironment env;
+
+    private final PrimitiveType primitiveByte;
+
+    public APTNavigator(AnnotationProcessorEnvironment env) {
+        this.env = env;
+        this.primitiveByte = env.getTypeUtils().getPrimitiveType(PrimitiveType.Kind.BYTE);
+    }
+
+    public TypeDeclaration getSuperClass(TypeDeclaration t) {
+        if (t instanceof ClassDeclaration) {
+            ClassDeclaration c = (ClassDeclaration) t;
+            ClassType sup = c.getSuperclass();
+            if(sup!=null)
+                return sup.getDeclaration();
+            else
+                return null;
+        }
+        return env.getTypeDeclaration(Object.class.getName());
+    }
+
+    public TypeMirror getBaseClass(TypeMirror type, TypeDeclaration sup) {
+        return baseClassFinder.apply(type,sup);
+    }
+
+    public String getClassName(TypeDeclaration t) {
+        return t.getQualifiedName();
+    }
+
+    public String getTypeName(TypeMirror typeMirror) {
+        return typeMirror.toString();
+    }
+
+    public String getClassShortName(TypeDeclaration t) {
+        return t.getSimpleName();
+    }
+
+    public Collection<FieldDeclaration> getDeclaredFields(TypeDeclaration c) {
+        List<FieldDeclaration> l = new ArrayList<FieldDeclaration>(c.getFields());
+        return sort(l);
+    }
+
+    public FieldDeclaration getDeclaredField(TypeDeclaration clazz, String fieldName) {
+        for( FieldDeclaration fd : clazz.getFields() ) {
+            if(fd.getSimpleName().equals(fieldName))
+                return fd;
+        }
+        return null;
+    }
+
+    public Collection<MethodDeclaration> getDeclaredMethods(TypeDeclaration c) {
+        List<MethodDeclaration> l = new ArrayList<MethodDeclaration>(c.getMethods());
+        return sort(l);
+    }
+
+    private <A extends Declaration> List<A> sort(List<A> l) {
+        if(l.isEmpty())     return l;
+
+        // APT supports the operation mode where it creates Declarations from
+        // a class file, in which case the source position is not available
+        // use that as a key to sort them correctly. This isn't "correct" in
+        // the sense that it relies on undocumented behavior of APT where
+        // it returns declarations in the reverse order, but this makes things work.
+        SourcePosition pos = l.get(0).getPosition();
+        if(pos!=null)
+            Collections.sort(l,SOURCE_POS_COMPARATOR);
+        else
+            Collections.reverse(l);
+        return l;
+    }
+
+    public ClassDeclaration getDeclaringClassForField(FieldDeclaration f) {
+        return (ClassDeclaration)f.getDeclaringType();
+    }
+
+    public ClassDeclaration getDeclaringClassForMethod(MethodDeclaration m) {
+        return (ClassDeclaration)m.getDeclaringType();
+    }
+
+    public TypeMirror getFieldType(FieldDeclaration f) {
+        return f.getType();
+    }
+
+    public String getFieldName(FieldDeclaration f) {
+        return f.getSimpleName();
+    }
+
+    public String getMethodName(MethodDeclaration m) {
+        return m.getSimpleName();
+    }
+
+    public TypeMirror getReturnType(MethodDeclaration m) {
+        return m.getReturnType();
+    }
+
+    public TypeMirror[] getMethodParameters(MethodDeclaration m) {
+        Collection<ParameterDeclaration> ps = m.getParameters();
+        TypeMirror[] r = new TypeMirror[ps.size()];
+        int i=0;
+        for( ParameterDeclaration p : ps )
+            r[i++] = p.getType();
+        return r;
+    }
+
+    public boolean isStaticMethod(MethodDeclaration m) {
+        return hasModifier(m, Modifier.STATIC);
+    }
+
+    private boolean hasModifier(Declaration d, Modifier mod) {
+        return d.getModifiers().contains(mod);
+    }
+
+    public boolean isSubClassOf(TypeMirror sub, TypeMirror sup) {
+        if(sup==DUMMY)
+            // see ref(). if the sub type is known to APT,
+            // its base class must be known. Thus if the sup is DUMMY,
+            // it cannot possibly be the super type.
+            return false;
+        return env.getTypeUtils().isSubtype(sub,sup);
+    }
+
+    private String getSourceClassName(Class clazz) {
+        Class<?> d = clazz.getDeclaringClass();
+        if(d==null)
+            return clazz.getName();
+        else {
+            String shortName = clazz.getName().substring(d.getName().length()+1/*for $*/);
+            return getSourceClassName(d)+'.'+shortName;
+        }
+    }
+
+    public TypeMirror ref(Class c) {
+        if(c.isArray())
+            return env.getTypeUtils().getArrayType( ref(c.getComponentType()) );
+        if(c.isPrimitive())
+            return getPrimitive(c);
+        TypeDeclaration t = env.getTypeDeclaration(getSourceClassName(c));
+        // APT only operates on a set of classes used in the compilation,
+        // and it won't recognize additional classes (even if they are visible from javac)
+        // and return null.
+        //
+        // this is causing a problem where we check if a type is collection.
+        // so until the problem is fixed in APT, work around the issue
+        // by returning a dummy token
+        if(t==null)
+            return DUMMY;
+        return env.getTypeUtils().getDeclaredType(t);
+    }
+
+    public TypeMirror use(TypeDeclaration t) {
+        assert t!=null;
+        return env.getTypeUtils().getDeclaredType(t);
+    }
+
+    public TypeDeclaration asDecl(TypeMirror m) {
+        m = env.getTypeUtils().getErasure(m);
+        if (m instanceof DeclaredType) {
+            DeclaredType d = (DeclaredType) m;
+            return d.getDeclaration();
+        } else
+            return null;
+    }
+
+    public TypeDeclaration asDecl(Class c) {
+        return env.getTypeDeclaration(getSourceClassName(c));
+    }
+
+    public <T> TypeMirror erasure(TypeMirror t) {
+        Types tu = env.getTypeUtils();
+        t = tu.getErasure(t);
+        if(t instanceof DeclaredType) {
+            DeclaredType dt = (DeclaredType)t;
+            if(!dt.getActualTypeArguments().isEmpty())
+            return tu.getDeclaredType(dt.getDeclaration());
+        }
+        return t;
+    }
+
+    public boolean isAbstract(TypeDeclaration clazz) {
+        return hasModifier(clazz,Modifier.ABSTRACT);
+    }
+
+    public boolean isFinal(TypeDeclaration clazz) {
+        return hasModifier(clazz,Modifier.FINAL);
+    }
+
+    public FieldDeclaration[] getEnumConstants(TypeDeclaration clazz) {
+        EnumDeclaration ed = (EnumDeclaration) clazz;
+        Collection<EnumConstantDeclaration> constants = ed.getEnumConstants();
+        return constants.toArray(new EnumConstantDeclaration[constants.size()]);
+    }
+
+    public TypeMirror getVoidType() {
+        return env.getTypeUtils().getVoidType();
+    }
+
+    public String getPackageName(TypeDeclaration clazz) {
+        return clazz.getPackage().getQualifiedName();
+    }
+
+    public TypeDeclaration findClass(String className, TypeDeclaration referencePoint) {
+        return env.getTypeDeclaration(className);
+    }
+
+    public boolean isBridgeMethod(MethodDeclaration method) {
+        return method.getModifiers().contains(Modifier.VOLATILE);
+    }
+
+    public boolean isOverriding(MethodDeclaration method) {
+        TypeDeclaration declaringType = method.getDeclaringType();
+        if(!(declaringType instanceof ClassDeclaration))
+            return false;   // act defensively. this might be because we are recovering from errors
+        ClassDeclaration sc = (ClassDeclaration) declaringType;
+
+        Declarations declUtil = env.getDeclarationUtils();
+
+        while(sc.getSuperclass()!=null) {
+            sc = sc.getSuperclass().getDeclaration();
+
+            for (MethodDeclaration m : sc.getMethods()) {
+                if(declUtil.overrides(method,m))
+                    return true;
+            }
+        }
+
+        return false;
+    }
+
+    public boolean isInterface(TypeDeclaration clazz) {
+        return clazz instanceof InterfaceDeclaration;
+    }
+
+    public boolean isTransient(FieldDeclaration f) {
+        return f.getModifiers().contains(Modifier.TRANSIENT);
+    }
+
+    public boolean isArray(TypeMirror t) {
+        return t instanceof ArrayType;
+    }
+
+    public boolean isArrayButNotByteArray(TypeMirror t) {
+        if(!isArray(t))
+            return false;
+
+        ArrayType at = (ArrayType) t;
+        TypeMirror ct = at.getComponentType();
+
+        return !ct.equals(primitiveByte);
+    }
+
+    public TypeMirror getComponentType(TypeMirror t) {
+        if (t instanceof ArrayType) {
+            ArrayType at = (ArrayType) t;
+            return at.getComponentType();
+        }
+
+        throw new IllegalArgumentException();
+    }
+
+    public TypeMirror getTypeArgument(TypeMirror typeMirror, int i) {
+        if (typeMirror instanceof DeclaredType){
+            DeclaredType d = (DeclaredType)typeMirror;
+            TypeMirror[] args = d.getActualTypeArguments().toArray(new TypeMirror[0]);
+            return args[i];
+        } else throw  new IllegalArgumentException();
+    }
+
+    public boolean isParameterizedType(TypeMirror t) {
+        if (t instanceof DeclaredType) {
+            DeclaredType d = (DeclaredType) t;
+            return !d.getActualTypeArguments().isEmpty();
+        }
+        return false;
+    }
+
+    public boolean isPrimitive(TypeMirror t) {
+        return t instanceof PrimitiveType;
+    }
+
+    private static final Map<Class,PrimitiveType.Kind> primitives = new HashMap<Class,PrimitiveType.Kind>();
+
+    static {
+        primitives.put(Integer.TYPE,    PrimitiveType.Kind.INT);
+        primitives.put(Byte.TYPE,       PrimitiveType.Kind.BYTE);
+        primitives.put(Float.TYPE,      PrimitiveType.Kind.FLOAT);
+        primitives.put(Boolean.TYPE, PrimitiveType.Kind.BOOLEAN);
+        primitives.put(Short.TYPE,      PrimitiveType.Kind.SHORT);
+        primitives.put(Long.TYPE,      PrimitiveType.Kind.LONG);
+        primitives.put(Double.TYPE,      PrimitiveType.Kind.DOUBLE);
+        primitives.put(Character.TYPE,      PrimitiveType.Kind.CHAR);
+
+    }
+
+    public TypeMirror getPrimitive(Class primitiveType) {
+        assert primitiveType.isPrimitive();
+        if(primitiveType==void.class)
+            return getVoidType();
+        return env.getTypeUtils().getPrimitiveType(primitives.get(primitiveType));
+    }
+
+    /**
+     * see {@link #ref(Class)}.
+     */
+    private static final TypeMirror DUMMY = new TypeMirror() {
+        public void accept(TypeVisitor v) {
+            throw new IllegalStateException();
+        }
+    };
+
+    /**
+     * Implements {@link #getBaseClass}.
+     */
+    private final APTTypeVisitor<TypeMirror,TypeDeclaration> baseClassFinder = new APTTypeVisitor<TypeMirror,TypeDeclaration>(){
+        public TypeMirror onClassType(ClassType type, TypeDeclaration sup) {
+            TypeMirror r = onDeclaredType(type,sup);
+            if(r!=null)     return r;
+
+            // otherwise recursively apply super class and base types
+            if(type.getSuperclass()!=null) {
+                r = onClassType(type.getSuperclass(),sup);
+                if(r!=null)     return r;
+            }
+
+            return null;
+        }
+
+        protected TypeMirror onPrimitiveType(PrimitiveType type, TypeDeclaration param) {
+            return type;
+        }
+
+        protected TypeMirror onVoidType(VoidType type, TypeDeclaration param) {
+            return type;
+        }
+
+        public TypeMirror onInterfaceType(InterfaceType type, TypeDeclaration sup) {
+            return onDeclaredType(type,sup);
+        }
+
+        private TypeMirror onDeclaredType(DeclaredType t, TypeDeclaration sup) {
+            // t = sup<...>
+            if(t.getDeclaration().equals(sup))
+                return t;
+
+            for(InterfaceType i : t.getSuperinterfaces()) {
+                TypeMirror r = onInterfaceType(i,sup);
+                if(r!=null)     return r;
+            }
+
+            return null;
+        }
+
+        public TypeMirror onTypeVariable(TypeVariable t, TypeDeclaration sup) {
+            // we are checking if T (declared as T extends A&B&C) is assignable to sup.
+            // so apply bounds recursively.
+            for( ReferenceType r : t.getDeclaration().getBounds() ) {
+                TypeMirror m = apply(r,sup);
+                if(m!=null)     return m;
+            }
+            return null;
+        }
+
+        public TypeMirror onArrayType(ArrayType type, TypeDeclaration sup) {
+            // we are checking if t=T[] is assignable to sup.
+            // the only case this is allowed is sup=Object,
+            // and Object isn't parameterized.
+            return null;
+        }
+
+        public TypeMirror onWildcard(WildcardType type, TypeDeclaration sup) {
+            // we are checking if T (= ? extends A&B&C) is assignable to sup.
+            // so apply bounds recursively.
+            for( ReferenceType r : type.getLowerBounds() ) {
+                TypeMirror m = apply(r,sup);
+                if(m!=null)     return m;
+            }
+            return null;
+        }
+    } ;
+
+
+    public Location getClassLocation(TypeDeclaration decl) {
+        return getLocation(decl.getQualifiedName(),decl.getPosition());
+    }
+
+    public Location getFieldLocation(FieldDeclaration decl) {
+        return getLocation(decl);
+    }
+
+    public Location getMethodLocation(MethodDeclaration decl) {
+        return getLocation(decl);
+    }
+
+    public boolean hasDefaultConstructor(TypeDeclaration t) {
+        if(!(t instanceof ClassDeclaration))
+            return false;
+
+        ClassDeclaration c = (ClassDeclaration) t;
+        for( ConstructorDeclaration init : c.getConstructors() ) {
+            if(init.getParameters().isEmpty())
+                return true;
+        }
+        return false;
+    }
+
+    public boolean isStaticField(FieldDeclaration f) {
+        return hasModifier(f,Modifier.STATIC);
+    }
+
+    public boolean isPublicMethod(MethodDeclaration m) {
+        return hasModifier(m,Modifier.PUBLIC);
+    }
+
+    public boolean isPublicField(FieldDeclaration f) {
+        return hasModifier(f,Modifier.PUBLIC);
+    }
+
+    public boolean isEnum(TypeDeclaration t) {
+        return t instanceof EnumDeclaration;
+    }
+
+    private Location getLocation(MemberDeclaration decl) {
+        return getLocation(decl.getDeclaringType().getQualifiedName()+'.'+decl.getSimpleName(),decl.getPosition());
+    }
+
+    private Location getLocation(final String name, final SourcePosition sp) {
+        return new Location() {
+            public String toString() {
+                if(sp==null)
+                    return name+" (Unknown Source)";
+                // just like stack trace, we just print the file name and
+                // not the whole path. The idea is that the pakage name should
+                // provide enough clue on which directory it lives.
+                return name+'('+sp.file().getName()+':'+sp.line()+')';
+            }
+        };
+    }
+
+    /**
+     * Comparator that uses the source position
+     */
+    private static final Comparator<Declaration> SOURCE_POS_COMPARATOR = new Comparator<Declaration>() {
+        public int compare(Declaration d1, Declaration d2) {
+            if (d1 == d2)
+                return 0;
+
+            SourcePosition p1 = d1.getPosition();
+            SourcePosition p2 = d2.getPosition();
+
+            if (p1 == null) {
+                return (p2 == null) ? 0 : 1;
+            } else {
+                if (p2 == null)
+                    return -1;
+
+                int fileComp = p1.file().compareTo(p2.file());
+                if (fileComp == 0) {
+                    long diff = (long) p1.line() - (long) p2.line();
+                    if (diff == 0) {
+                        diff = Long.signum((long) p1.column() - (long) p2.column());
+                        if (diff != 0)
+                            return (int) diff;
+                        else {
+                            // declarations may be two
+                            // compiler-generated members with the
+                            // same source position
+                            return (Long.signum((long) System.identityHashCode(d1) -
+                                    (long) System.identityHashCode(d2)));
+                        }
+                    } else
+                        return (diff < 0) ? -1 : 1;
+                } else
+                    return fileComp;
+            }
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/AntErrorListener.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/AntErrorListener.java
new file mode 100644
index 0000000..9a666ee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/AntErrorListener.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import org.apache.tools.ant.Project;
+import org.xml.sax.SAXParseException;
+
+import java.text.MessageFormat;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class AntErrorListener implements ErrorListener {
+    private final Project project;
+
+    public AntErrorListener(Project p) {
+        this.project = p;
+    }
+
+    public void error(SAXParseException e) {
+        print(e,Project.MSG_ERR);
+    }
+
+    public void fatalError(SAXParseException e) {
+        print(e,Project.MSG_ERR);
+    }
+
+    public void warning(SAXParseException e) {
+        print(e,Project.MSG_WARN);
+    }
+
+    private void print(SAXParseException e, int level) {
+        project.log(e.getMessage(),level);
+        project.log(getLocation(e),level);
+    }
+
+    String getLocation(SAXParseException e) {
+        return MessageFormat.format("  {0}:{1} of {2}",
+            new Object[]{
+                String.valueOf(e.getLineNumber()),
+                String.valueOf(e.getColumnNumber()),
+                e.getSystemId()});
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/ConsoleErrorReporter.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/ConsoleErrorReporter.java
new file mode 100644
index 0000000..6798506
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/ConsoleErrorReporter.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import org.xml.sax.SAXParseException;
+
+import java.io.PrintStream;
+import java.text.MessageFormat;
+
+/**
+ * Prints the error to a stream.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ConsoleErrorReporter implements ErrorListener {
+    private final PrintStream out;
+
+    public ConsoleErrorReporter(PrintStream out) {
+        this.out = out;
+    }
+
+    public void error(SAXParseException exception) {
+        out.print("[ERROR]   ");
+        print(exception);
+    }
+
+    public void fatalError(SAXParseException exception) {
+        out.print("[FATAL]   ");
+        print(exception);
+    }
+
+    public void warning(SAXParseException exception) {
+        out.print("[WARNING] ");
+        print(exception);
+    }
+
+    private void print(SAXParseException e) {
+        out.println(e.getMessage());
+        out.println(MessageFormat.format("  {0}:{1} of {2}",
+            new Object[]{
+                String.valueOf(e.getLineNumber()),
+                String.valueOf(e.getColumnNumber()),
+                e.getSystemId()}));
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/ErrorListener.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/ErrorListener.java
new file mode 100644
index 0000000..0602a26
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/ErrorListener.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Used internally to report errors.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface ErrorListener extends ErrorHandler {
+    abstract void error (SAXParseException exception);
+    abstract void fatalError (SAXParseException exception);
+    abstract void warning (SAXParseException exception);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/Main.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/Main.java
new file mode 100644
index 0000000..7776fee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/Main.java
@@ -0,0 +1,222 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import com.sun.codemodel.writer.FileCodeWriter;
+import com.sun.codemodel.writer.SingleStreamCodeWriter;
+import com.sun.tools.internal.txw2.model.NodeSet;
+import org.kohsuke.args4j.CmdLineException;
+import org.kohsuke.args4j.CmdLineParser;
+import org.kohsuke.args4j.opts.BooleanOption;
+import org.kohsuke.args4j.opts.StringOption;
+import org.kohsuke.rngom.parse.IllegalSchemaException;
+import org.kohsuke.rngom.parse.Parseable;
+import org.kohsuke.rngom.parse.compact.CompactParseable;
+import org.kohsuke.rngom.parse.xml.SAXParseable;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+import java.io.File;
+import java.io.IOException;
+import java.net.MalformedURLException;
+import java.util.Properties;
+
+/**
+ * Programatic entry point to the TXW compiler.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class Main {
+    private final TxwOptions opts;
+
+    public Main(TxwOptions opts) {
+        this.opts = opts;
+    }
+
+    public static void main(String[] args) {
+        System.exit(run(args));
+    }
+
+    public static class Options {
+        public StringOption output = new StringOption("-o");
+        public StringOption pkg = new StringOption("-p");
+        public BooleanOption compact = new BooleanOption("-c");
+        public BooleanOption xml = new BooleanOption("-x");
+        public BooleanOption xsd = new BooleanOption("-xsd");
+        public BooleanOption chain = new BooleanOption("-h");
+    }
+
+    public static int run(String[] args) {
+        Options opts = new Options();
+        CmdLineParser parser = new CmdLineParser();
+        parser.addOptionClass(opts);
+
+        try {
+            parser.parse(args);
+        } catch (CmdLineException e) {
+            System.out.println(e.getMessage());
+            printUsage();
+            return 1;
+        }
+
+        TxwOptions topts = new TxwOptions();
+        topts.errorListener = new ConsoleErrorReporter(System.out);
+
+        if(opts.output.value!=null) {
+            try {
+                topts.codeWriter = new FileCodeWriter(new File(opts.output.value));
+            } catch( IOException e ) {
+                System.out.println(e.getMessage());
+                printUsage();
+                return 1;
+            }
+        } else {
+            topts.codeWriter = new SingleStreamCodeWriter(System.out);
+        }
+
+        if(opts.chain.isOn()) {
+            topts.chainMethod = true;
+        }
+
+        if(opts.pkg.value!=null) {
+            topts._package = topts.codeModel._package(opts.pkg.value);
+        } else {
+            topts._package = topts.codeModel.rootPackage();
+        }
+
+        // make sure that there's only one argument (namely the schema)
+        if(parser.getArguments().size()!=1) {
+            printUsage();
+            return 1;
+        }
+
+        try {
+            topts.source = makeSourceSchema(parser,opts,topts.errorListener);
+        } catch (MalformedURLException e) {
+            System.out.println(e.getMessage());
+            printUsage();
+            return 1;
+        }
+
+        return run(topts);
+    }
+
+    /**
+     * Parses the command line and makes a {@link Parseable} object
+     * out of the specified schema file.
+     */
+    private static SchemaBuilder makeSourceSchema(CmdLineParser parser, Options opts, ErrorHandler eh) throws MalformedURLException {
+        File f = new File((String)parser.getArguments().get(0));
+        final InputSource in = new InputSource(f.toURL().toExternalForm());
+
+        if(opts.xsd.isOff() && opts.xml.isOff() && opts.compact.isOff()) {
+            // auto detect
+            if(in.getSystemId().endsWith(".rnc"))
+                opts.compact.value=true;
+            else
+            if(in.getSystemId().endsWith(".rng"))
+                opts.xml.value=true;
+            else
+                opts.xsd.value=true;
+        }
+
+        if(opts.xsd.isOn())
+            return new XmlSchemaLoader(in);
+
+        final Parseable parseable = makeRELAXNGSource(opts, in, eh, f);
+
+        return new RELAXNGLoader(parseable);
+    }
+
+    private static Parseable makeRELAXNGSource(Options opts, final InputSource in, ErrorHandler eh, File f) {
+        if(opts.compact.isOn())
+            return new CompactParseable(in,eh);
+
+        if(opts.xml.isOn())
+            return new SAXParseable(in,eh);
+
+        // otherwise sniff from the file extension
+        if(f.getPath().toLowerCase().endsWith("rnc"))
+            return new CompactParseable(in,eh);
+        else
+            return new SAXParseable(in,eh);
+    }
+
+    private static void printUsage() {
+        System.out.println("Typed Xml Writer ver."+getVersion());
+        System.out.println(
+            "txw <schema file>\n"+
+            " -o <dir>   : Specify the directory to place generated source files\n"+
+            " -p <pkg>   : Specify the Java package to put the generated classes into\n"+
+            " -c         : The input schema is written in the RELAX NG compact syntax\n"+
+            " -x         : The input schema is written in the RELAX NG XML syntax\n"+
+            " -xsd       : The input schema is written in the XML SChema\n"+
+            " -h         : Generate code that allows method invocation chaining\n"
+        );
+    }
+
+    public static int run(TxwOptions opts) {
+        return new Main(opts).run();
+    }
+
+    private int run() {
+        try {
+            NodeSet ns = opts.source.build(opts);
+            ns.write(opts);
+            opts.codeModel.build(opts.codeWriter);
+            return 0;
+        } catch (IOException e) {
+            opts.errorListener.error(new SAXParseException(e.getMessage(),null,e));
+            return 1;
+        } catch (IllegalSchemaException e) {
+            opts.errorListener.error(new SAXParseException(e.getMessage(),null,e));
+            return 1;
+        } catch (SAXParseException e) {
+            opts.errorListener.error(e);
+            return 1;
+        } catch (SAXException e) {
+            opts.errorListener.error(new SAXParseException(e.getMessage(),null,e));
+            return 1;
+        }
+    }
+
+
+    /**
+     * Gets the version number of TXW.
+     */
+    public static String getVersion() {
+        try {
+            Properties p = new Properties();
+            p.load(Main.class.getResourceAsStream("version.properties"));
+            return p.get("version").toString();
+        } catch( Throwable _ ) {
+            return "unknown";
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/NameUtil.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/NameUtil.java
new file mode 100644
index 0000000..99ac2db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/NameUtil.java
@@ -0,0 +1,348 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import com.sun.codemodel.JJavaName;
+
+import java.util.ArrayList;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class NameUtil {
+
+    protected static boolean isPunct(char c) {
+        return (c == '-' || c == '.' || c == ':' || c == '_' || c == '\u00b7'
+                || c == '\u0387' || c == '\u06dd' || c == '\u06de');
+    }
+
+    protected static boolean isDigit(char c) {
+        return ((c >= '0' && c <= '9') || Character.isDigit(c));
+    }
+
+    protected static boolean isUpper(char c) {
+        return ((c >= 'A' && c <= 'Z') || Character.isUpperCase(c));
+    }
+
+    protected static boolean isLower(char c) {
+        return ((c >= 'a' && c <= 'z') || Character.isLowerCase(c));
+    }
+
+    protected static boolean isLetter(char c) {
+        return ((c >= 'A' && c <= 'Z')
+                || (c >= 'a' && c <= 'z')
+                || Character.isLetter(c));
+    }
+
+    /**
+     * Capitalizes the first character of the specified string,
+     * and de-capitalize the rest of characters.
+     */
+    public static String capitalize(String s) {
+        if (!isLower(s.charAt(0)))
+            return s;
+        StringBuffer sb = new StringBuffer(s.length());
+        sb.append(Character.toUpperCase(s.charAt(0)));
+        sb.append(s.substring(1).toLowerCase());
+        return sb.toString();
+    }
+
+    // Precondition: s[start] is not punctuation
+    protected static int nextBreak(String s, int start) {
+        int n = s.length();
+        for (int i = start; i < n; i++) {
+            char c0 = s.charAt(i);
+            if (i < n - 1) {
+                char c1 = s.charAt(i + 1);
+                if (isPunct(c1)) return i + 1;
+                if (isDigit(c0) && !isDigit(c1)) return i + 1;
+                if (!isDigit(c0) && isDigit(c1)) return i + 1;
+                if (isLower(c0) && !isLower(c1)) return i + 1;
+                if (isLetter(c0) && !isLetter(c1)) return i + 1;
+                if (!isLetter(c0) && isLetter(c1)) return i + 1;
+                if (i < n - 2) {
+                    char c2 = s.charAt(i + 2);
+                    if (isUpper(c0) && isUpper(c1) && isLower(c2))
+                        return i + 1;
+                }
+            }
+        }
+        return -1;
+    }
+
+
+    /**
+     * Tokenizes a string into words and capitalizes the first
+     * character of each word.
+     *
+     * <p>
+     * This method uses a change in character type as a splitter
+     * of two words. For example, "abc100ghi" will be splitted into
+     * {"Abc", "100","Ghi"}.
+     */
+    public static String[] toWordList(String s) {
+        ArrayList ss = new ArrayList();
+        int n = s.length();
+        for (int i = 0; i < n;) {
+
+            // Skip punctuation
+            while (i < n) {
+                if (!isPunct(s.charAt(i)))
+                    break;
+                i++;
+            }
+            if (i >= n) break;
+
+            // Find next break and collect word
+            int b = nextBreak(s, i);
+            String w = (b == -1) ? s.substring(i) : s.substring(i, b);
+            ss.add(escape(capitalize(w)));
+            if (b == -1) break;
+            i = b;
+        }
+
+//      we can't guarantee a valid Java identifier anyway,
+//      so there's not much point in rejecting things in this way.
+//        if (ss.size() == 0)
+//            throw new IllegalArgumentException("Zero-length identifier");
+        return (String[])(ss.toArray(new String[0]));
+    }
+
+    protected static String toMixedCaseName(String[] ss, boolean startUpper) {
+        StringBuffer sb = new StringBuffer();
+        if(ss.length>0) {
+            sb.append(startUpper ? ss[0] : ss[0].toLowerCase());
+            for (int i = 1; i < ss.length; i++)
+                sb.append(ss[i]);
+        }
+        return sb.toString();
+    }
+
+    protected static  String toMixedCaseVariableName(String[] ss,
+                                                  boolean startUpper,
+                                                  boolean cdrUpper) {
+        if (cdrUpper)
+            for (int i = 1; i < ss.length; i++)
+                ss[i] = capitalize(ss[i]);
+        StringBuffer sb = new StringBuffer();
+        if( ss.length>0 ) {
+            sb.append(startUpper ? ss[0] : ss[0].toLowerCase());
+            for (int i = 1; i < ss.length; i++)
+                sb.append(ss[i]);
+        }
+        return sb.toString();
+    }
+
+
+    /**
+     * Formats a string into "THIS_KIND_OF_FORMAT_ABC_DEF".
+     *
+     * @return
+     *      Always return a string but there's no guarantee that
+     *      the generated code is a valid Java identifier.
+     */
+    public static String toConstantName(String s) {
+        return toConstantName(toWordList(s));
+    }
+
+    /**
+     * Formats a string into "THIS_KIND_OF_FORMAT_ABC_DEF".
+     *
+     * @return
+     *      Always return a string but there's no guarantee that
+     *      the generated code is a valid Java identifier.
+     */
+    public static String toConstantName(String[] ss) {
+        StringBuffer sb = new StringBuffer();
+        if( ss.length>0 ) {
+            sb.append(ss[0].toUpperCase());
+            for (int i = 1; i < ss.length; i++) {
+                sb.append('_');
+                sb.append(ss[i].toUpperCase());
+            }
+        }
+        return sb.toString();
+    }
+
+
+
+    /**
+     * Escapes characters is the given string so that they can be
+     * printed by only using US-ASCII characters.
+     *
+     * The escaped characters will be appended to the given
+     * StringBuffer.
+     *
+     * @param sb
+     *      StringBuffer that receives escaped string.
+     * @param s
+     *      String to be escaped. <code>s.substring(start)</code>
+     *      will be escaped and copied to the string buffer.
+     */
+    public static void escape(StringBuffer sb, String s, int start) {
+        int n = s.length();
+        for (int i = start; i < n; i++) {
+            char c = s.charAt(i);
+            if (Character.isJavaIdentifierPart(c))
+                sb.append(c);
+            else {
+                sb.append("_");
+                if (c <= '\u000f') sb.append("000");
+                else if (c <= '\u00ff') sb.append("00");
+                else if (c <= '\u0fff') sb.append("0");
+                sb.append(Integer.toString(c, 16));
+            }
+        }
+    }
+
+    /**
+     * Escapes characters that are unusable as Java identifiers
+     * by replacing unsafe characters with safe characters.
+     */
+    private static String escape(String s) {
+        int n = s.length();
+        for (int i = 0; i < n; i++)
+            if (!Character.isJavaIdentifierPart(s.charAt(i))) {
+                StringBuffer sb = new StringBuffer(s.substring(0, i));
+                escape(sb, s, i);
+                return sb.toString();
+            }
+        return s;
+    }
+
+    /**
+     * Escape any characters that would cause the single arg constructor
+     * of java.net.URI to complain about illegal chars.
+     *
+     * @param s source string to be escaped
+     */
+    public static String escapeURI(String s) {
+        StringBuffer sb = new StringBuffer();
+        for( int i = 0; i < s.length(); i++ ) {
+            char c = s.charAt(i);
+            if(Character.isSpaceChar(c)) {
+                sb.append("%20");
+            } else {
+                sb.append(c);
+            }
+        }
+        return sb.toString();
+    }
+
+    /**
+     * Calculate the parent URI path of the given URI path.
+     *
+     * @param uriPath the uriPath (as returned by java.net.URI#getPath()
+     * @return the parent URI path of the given URI path
+     */
+    public static String getParentUriPath(String uriPath) {
+        int idx = uriPath.lastIndexOf('/');
+
+        if (uriPath.endsWith("/")) {
+            uriPath = uriPath.substring(0,idx); // trim trailing slash
+            idx = uriPath.lastIndexOf('/'); // move idx to parent context
+        }
+
+        return uriPath.substring(0, idx)+"/";
+    }
+
+    /**
+     * Calculate the normalized form of the given uriPath.
+     *
+     * For example:
+     *    /a/b/c/ -> /a/b/c/
+     *    /a/b/c  -> /a/b/
+     *    /a/     -> /a/
+     *    /a      -> /
+     *
+     * @param uriPath path of a URI (as returned by java.net.URI#getPath()
+     * @return the normalized uri path
+     */
+    public static String normalizeUriPath(String uriPath) {
+        if (uriPath.endsWith("/"))
+            return uriPath;
+
+        // the uri path should always have at least a leading slash,
+        // so no need to make sure that ( idx == -1 )
+        int idx = uriPath.lastIndexOf('/');
+        return uriPath.substring(0, idx+1);
+    }
+
+    /**
+     * determine if two Strings are equal ignoring case allowing null values
+     *
+     * @param s string 1
+     * @param t string 2
+     * @return true iff the given strings are equal ignoring case, false if they aren't
+     * equal or either of them are null.
+     */
+    public static boolean equalsIgnoreCase(String s, String t) {
+        if (s == t) return true;
+        if ((s != null) && (t != null)) {
+            return s.equalsIgnoreCase(t);
+        }
+        return false;
+    }
+
+    /**
+     * determine if two Strings are iqual allowing null values
+     *
+     * @param s string 1
+     * @param t string 2
+     * @return true iff the strings are equal, false if they aren't equal or either of
+     * them are null.
+     */
+    public static boolean equal(String s, String t) {
+        if (s == t) return true;
+        if ((s != null) && (t != null)) {
+            return s.equals(t);
+        }
+        return false;
+    }
+
+    public static String toClassName(String s) {
+        return toMixedCaseName(toWordList(s), true);
+    }
+    public static String toVariableName(String s) {
+        return toMixedCaseName(toWordList(s), false);
+    }
+    public static String toMethodName(String s) {
+        String m = toMixedCaseName(toWordList(s), false);
+        if(JJavaName.isJavaIdentifier(m))
+            return m;
+        else
+            return '_'+m;
+    }
+    public static String toInterfaceName( String token ) {
+        return toClassName(token);
+    }
+    public static String toPropertyName(String s) {
+        return toClassName(s);
+    }
+    public static  String toPackageName( String s ) {
+        return toMixedCaseName(toWordList(s), false );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/RELAXNGLoader.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/RELAXNGLoader.java
new file mode 100644
index 0000000..854bfb2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/RELAXNGLoader.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import org.kohsuke.rngom.parse.Parseable;
+import org.kohsuke.rngom.parse.IllegalSchemaException;
+import org.kohsuke.rngom.ast.util.CheckingSchemaBuilder;
+import org.kohsuke.rngom.dt.CascadingDatatypeLibraryFactory;
+import org.kohsuke.rngom.dt.builtin.BuiltinDatatypeLibraryFactory;
+import org.relaxng.datatype.helpers.DatatypeLibraryLoader;
+import com.sun.tools.internal.txw2.model.NodeSet;
+import com.sun.tools.internal.txw2.model.Leaf;
+import com.sun.tools.internal.txw2.builder.relaxng.SchemaBuilderImpl;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class RELAXNGLoader implements SchemaBuilder {
+    private final Parseable parseable;
+
+    public RELAXNGLoader(Parseable parseable) {
+        this.parseable = parseable;
+    }
+
+    public NodeSet build(TxwOptions options) throws IllegalSchemaException {
+        SchemaBuilderImpl stage1 = new SchemaBuilderImpl(options.codeModel);
+        Leaf pattern = (Leaf)parseable.parse(new CheckingSchemaBuilder(stage1,options.errorListener,
+            new CascadingDatatypeLibraryFactory(
+                new BuiltinDatatypeLibraryFactory(new DatatypeLibraryLoader()),
+                new DatatypeLibraryLoader())));
+
+        return new NodeSet(options,pattern);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/SchemaBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/SchemaBuilder.java
new file mode 100644
index 0000000..686ca6d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/SchemaBuilder.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import com.sun.tools.internal.txw2.model.NodeSet;
+import org.kohsuke.rngom.parse.IllegalSchemaException;
+import org.xml.sax.SAXException;
+
+/**
+ * Encapsulation of the schema file and the builder.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface SchemaBuilder {
+    NodeSet build(TxwOptions options) throws IllegalSchemaException, SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/TxwOptions.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/TxwOptions.java
new file mode 100644
index 0000000..85e616c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/TxwOptions.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import com.sun.codemodel.CodeWriter;
+import com.sun.codemodel.JCodeModel;
+import com.sun.codemodel.JPackage;
+import com.sun.xml.internal.txw2.annotation.XmlNamespace;
+
+/**
+ * Controls the various aspects of the TXW generation.
+ *
+ * But this doesn't contain options for the command-line interface
+ * nor any of the driver-level configuration (such as where to place
+ * the generated source code, etc.)
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class TxwOptions {
+    public final JCodeModel codeModel = new JCodeModel();
+
+    /**
+     * The package to put the generated code into.
+     */
+    public JPackage _package;
+
+    /**
+     * Always non-null.
+     */
+    public ErrorListener errorListener;
+
+    /**
+     * The generated code will be sent to this.
+     */
+    CodeWriter codeWriter;
+
+    /**
+     * Schema file.
+     */
+    SchemaBuilder source;
+
+    /**
+     * If true, generate attribute/value methods that
+     * returns the <tt>this</tt> object for chaining.
+     */
+    public boolean chainMethod;
+
+    /**
+     * If true, the generated code will not use the package-level
+     * {@link XmlNamespace} annotation.
+     */
+    public boolean noPackageNamespace;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/TxwTask.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/TxwTask.java
new file mode 100644
index 0000000..e8f8d5a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/TxwTask.java
@@ -0,0 +1,163 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import com.sun.codemodel.writer.FileCodeWriter;
+import org.apache.tools.ant.BuildException;
+import org.apache.tools.ant.Project;
+import org.kohsuke.rngom.parse.compact.CompactParseable;
+import org.kohsuke.rngom.parse.xml.SAXParseable;
+import org.xml.sax.InputSource;
+
+import java.io.File;
+import java.io.IOException;
+import java.net.MalformedURLException;
+
+/**
+ * Ant task interface for txw compiler.
+ *
+ * @author ryan_shoemaker@dev.java.net
+ */
+public class TxwTask extends org.apache.tools.ant.Task {
+
+    // txw options - reuse command line options from the main driver
+    private final TxwOptions options = new TxwOptions();
+
+    // schema file
+    private File schemaFile;
+
+    // syntax style of RELAX NG source schema - "xml" or "compact"
+    private static enum Style {
+        COMPACT, XML, XMLSCHEMA, AUTO_DETECT
+    }
+    private Style style = Style.AUTO_DETECT;
+
+    public TxwTask() {
+        // default package
+        options._package = options.codeModel.rootPackage();
+
+        // default codewriter
+        try {
+            options.codeWriter = new FileCodeWriter(new File("."));
+        } catch (IOException e) {
+            throw new BuildException(e);
+        }
+    }
+
+    /**
+     * Parse @package
+     *
+     * @param pkg name of the package to generate the java classes into
+     */
+    public void setPackage( String pkg ) {
+        options._package = options.codeModel._package( pkg );
+    }
+
+    /**
+     * Parse @syntax
+     *
+     * @param style either "compact" for RELAX NG compact syntax or "XML"
+     * for RELAX NG xml syntax
+     */
+    public void setSyntax( String style ) {
+        this.style = Style.valueOf(style.toUpperCase());
+    }
+
+    /**
+     * parse @schema
+     *
+     * @param schema the schema file to be processed by txw
+     */
+    public void setSchema( File schema ) {
+        schemaFile = schema;
+    }
+
+    /**
+     * parse @destdir
+     *
+     * @param dir the directory to produce generated source code in
+     */
+    public void setDestdir( File dir ) {
+        try {
+            options.codeWriter = new FileCodeWriter(dir);
+        } catch (IOException e) {
+            throw new BuildException(e);
+        }
+    }
+
+    /**
+     * parse @methodChaining
+     *
+     * @param flg true if the txw should generate api's that allow
+     * method chaining (when possible, false otherwise
+     */
+    public void setMethodChaining( boolean flg ) {
+        options.chainMethod = flg;
+    }
+
+    /**
+     * launch txw
+     */
+    public void execute() throws BuildException {
+        options.errorListener = new AntErrorListener(getProject());
+
+        try {
+            InputSource in = new InputSource(schemaFile.toURL().toExternalForm());
+
+            String msg = "Compiling: " + in.getSystemId();
+            log( msg, Project.MSG_INFO );
+
+            if(style==Style.AUTO_DETECT) {
+                String fileName = schemaFile.getPath().toLowerCase();
+                if(fileName.endsWith("rnc"))
+                    style = Style.COMPACT;
+                else
+                if(fileName.endsWith("xsd"))
+                    style = Style.XMLSCHEMA;
+                else
+                    style = Style.XML;
+            }
+
+            switch(style) {
+            case COMPACT:
+                options.source = new RELAXNGLoader(new CompactParseable(in,options.errorListener));
+                break;
+            case XML:
+                options.source = new RELAXNGLoader(new SAXParseable(in,options.errorListener));
+                break;
+            case XMLSCHEMA:
+                options.source = new XmlSchemaLoader(in);
+                break;
+            }
+        } catch (MalformedURLException e) {
+            throw new BuildException(e);
+        }
+
+        // kick off the compiler
+        Main.run(options);
+        log( "Compilation complete.", Project.MSG_INFO );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/XmlSchemaLoader.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/XmlSchemaLoader.java
new file mode 100644
index 0000000..545e4fa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/XmlSchemaLoader.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2;
+
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import com.sun.tools.internal.txw2.model.NodeSet;
+import com.sun.tools.internal.txw2.builder.xsd.XmlSchemaBuilder;
+import com.sun.xml.xsom.parser.XSOMParser;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class XmlSchemaLoader implements SchemaBuilder {
+    private final InputSource in;
+
+    public XmlSchemaLoader(InputSource in) {
+        this.in = in;
+    }
+
+    public NodeSet build(TxwOptions options) throws SAXException {
+        XSOMParser xsom = new XSOMParser();
+        xsom.parse(in);
+        return XmlSchemaBuilder.build(xsom.getResult(),options);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/AnnotationsImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/AnnotationsImpl.java
new file mode 100644
index 0000000..2d78820
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/AnnotationsImpl.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import org.kohsuke.rngom.ast.builder.Annotations;
+import org.kohsuke.rngom.ast.builder.BuildException;
+import org.kohsuke.rngom.ast.om.ParsedElementAnnotation;
+import org.kohsuke.rngom.ast.util.LocatorImpl;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class AnnotationsImpl implements Annotations<ParsedElementAnnotation,LocatorImpl,CommentListImpl> {
+    public void addAttribute(String ns, String localName, String prefix, String value, LocatorImpl locator) throws BuildException {
+    }
+
+    public void addElement(ParsedElementAnnotation parsedElementAnnotation) throws BuildException {
+    }
+
+    public void addComment(CommentListImpl commentList) throws BuildException {
+    }
+
+    public void addLeadingComment(CommentListImpl commentList) throws BuildException {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/CommentListImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/CommentListImpl.java
new file mode 100644
index 0000000..43f8e34
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/CommentListImpl.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import org.kohsuke.rngom.ast.builder.CommentList;
+import org.kohsuke.rngom.ast.util.LocatorImpl;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface CommentListImpl extends CommentList<LocatorImpl> {
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DataPatternBuilderImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DataPatternBuilderImpl.java
new file mode 100644
index 0000000..0c219e6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DataPatternBuilderImpl.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.model.Data;
+import com.sun.tools.internal.txw2.model.Leaf;
+import org.kohsuke.rngom.ast.builder.BuildException;
+import org.kohsuke.rngom.ast.builder.DataPatternBuilder;
+import org.kohsuke.rngom.ast.om.ParsedElementAnnotation;
+import org.kohsuke.rngom.ast.util.LocatorImpl;
+import org.kohsuke.rngom.parse.Context;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class DataPatternBuilderImpl implements DataPatternBuilder<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> {
+    final JType type;
+
+    public DataPatternBuilderImpl(JType type) {
+        this.type = type;
+    }
+
+    public Leaf makePattern(LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return new Data(locator,type);
+    }
+
+    public void addParam(String name, String value, Context context, String ns, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+    }
+
+    public void annotation(ParsedElementAnnotation parsedElementAnnotation) {
+    }
+
+    public Leaf makePattern(Leaf except, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return makePattern(locator,annotations);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DatatypeFactory.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DatatypeFactory.java
new file mode 100644
index 0000000..37dd621
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DatatypeFactory.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import com.sun.tools.internal.txw2.model.Data;
+import com.sun.codemodel.JType;
+import com.sun.codemodel.JCodeModel;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Builds {@link Data} from a XML Schema datatype.
+ * @author Kohsuke Kawaguchi
+ */
+public class DatatypeFactory {
+    private final JCodeModel codeModel;
+
+    public DatatypeFactory(JCodeModel codeModel) {
+        this.codeModel = codeModel;
+    }
+
+    /**
+     * Decides the Java datatype from XML datatype.
+     *
+     * @return null
+     *      if none is found.
+     */
+    public JType getType(String datatypeLibrary, String type) {
+        if(datatypeLibrary.equals("http://www.w3.org/2001/XMLSchema-datatypes")
+        || datatypeLibrary.equals("http://www.w3.org/2001/XMLSchema")) {
+            type = type.intern();
+
+            if(type=="boolean")
+                return codeModel.BOOLEAN;
+            if(type=="int" || type=="nonNegativeInteger" || type=="positiveInteger")
+                return codeModel.INT;
+            if(type=="QName")
+                return codeModel.ref(QName.class);
+            if(type=="float")
+                return codeModel.FLOAT;
+            if(type=="double")
+                return codeModel.DOUBLE;
+            if(type=="anySimpleType" || type=="anyType")
+                return codeModel.ref(String.class);
+        }
+
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DivImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DivImpl.java
new file mode 100644
index 0000000..2b68817
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/DivImpl.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import com.sun.tools.internal.txw2.model.Grammar;
+import com.sun.tools.internal.txw2.model.Leaf;
+import org.kohsuke.rngom.ast.builder.Div;
+import org.kohsuke.rngom.ast.builder.Scope;
+import org.kohsuke.rngom.ast.om.ParsedElementAnnotation;
+import org.kohsuke.rngom.ast.util.LocatorImpl;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class DivImpl
+    extends GrammarSectionImpl
+    implements Div<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> {
+
+    DivImpl(Scope<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> parent, Grammar grammar) {
+        super(parent,grammar);
+    }
+
+    public void endDiv(LocatorImpl locator, AnnotationsImpl annotations) {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/ElementAnnotationBuilderImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/ElementAnnotationBuilderImpl.java
new file mode 100644
index 0000000..0acec82
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/ElementAnnotationBuilderImpl.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import org.kohsuke.rngom.ast.builder.BuildException;
+import org.kohsuke.rngom.ast.builder.CommentList;
+import org.kohsuke.rngom.ast.builder.ElementAnnotationBuilder;
+import org.kohsuke.rngom.ast.om.Location;
+import org.kohsuke.rngom.ast.om.ParsedElementAnnotation;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class ElementAnnotationBuilderImpl implements ElementAnnotationBuilder {
+    public void addText(String value, Location location, CommentList commentList) throws BuildException {
+    }
+
+    public ParsedElementAnnotation makeElementAnnotation() throws BuildException {
+        return null;
+    }
+
+    public void addAttribute(String ns, String localName, String prefix, String value, Location location) throws BuildException {
+    }
+
+    public void addElement(ParsedElementAnnotation parsedElementAnnotation) throws BuildException {
+    }
+
+    public void addComment(CommentList commentList) throws BuildException {
+    }
+
+    public void addLeadingComment(CommentList commentList) throws BuildException {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/GrammarImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/GrammarImpl.java
new file mode 100644
index 0000000..cc49844
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/GrammarImpl.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import com.sun.tools.internal.txw2.model.Leaf;
+import com.sun.tools.internal.txw2.model.Ref;
+import org.kohsuke.rngom.ast.builder.BuildException;
+import org.kohsuke.rngom.ast.builder.Grammar;
+import org.kohsuke.rngom.ast.builder.Scope;
+import org.kohsuke.rngom.ast.om.ParsedElementAnnotation;
+import org.kohsuke.rngom.ast.util.LocatorImpl;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class GrammarImpl extends GrammarSectionImpl
+    implements Grammar<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> {
+
+    GrammarImpl(Scope<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> scope) {
+        super(scope,new com.sun.tools.internal.txw2.model.Grammar());
+    }
+
+    public Leaf endGrammar(LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return new Ref(locator,grammar,com.sun.tools.internal.txw2.model.Grammar.START);
+    }
+
+    public Leaf makeParentRef(String name, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return parent.makeRef(name,locator,annotations);
+    }
+
+    public Leaf makeRef(String name, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return new Ref(locator,grammar,name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/GrammarSectionImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/GrammarSectionImpl.java
new file mode 100644
index 0000000..6350749
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/GrammarSectionImpl.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import com.sun.tools.internal.txw2.model.Define;
+import com.sun.tools.internal.txw2.model.Grammar;
+import com.sun.tools.internal.txw2.model.Leaf;
+import org.kohsuke.rngom.ast.builder.BuildException;
+import org.kohsuke.rngom.ast.builder.Div;
+import org.kohsuke.rngom.ast.builder.GrammarSection;
+import org.kohsuke.rngom.ast.builder.Include;
+import org.kohsuke.rngom.ast.builder.Scope;
+import org.kohsuke.rngom.ast.om.ParsedElementAnnotation;
+import org.kohsuke.rngom.ast.util.LocatorImpl;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class GrammarSectionImpl implements GrammarSection<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> {
+
+    protected final Scope<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> parent;
+
+    protected final Grammar grammar;
+
+    GrammarSectionImpl(
+        Scope<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> scope,
+        Grammar grammar ) {
+        this.parent = scope;
+        this.grammar = grammar;
+    }
+
+    public void topLevelAnnotation(ParsedElementAnnotation parsedElementAnnotation) throws BuildException {
+    }
+
+    public void topLevelComment(CommentListImpl commentList) throws BuildException {
+    }
+
+    public Div<Leaf, ParsedElementAnnotation, LocatorImpl, AnnotationsImpl, CommentListImpl> makeDiv() {
+        return new DivImpl(parent,grammar);
+    }
+
+    public Include<Leaf, ParsedElementAnnotation, LocatorImpl, AnnotationsImpl, CommentListImpl> makeInclude() {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void define(String name, Combine combine, Leaf leaf, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        Define def = grammar.get(name);
+        def.location = locator;
+
+        if(combine==null || def.leaf==null) {
+            def.leaf = leaf;
+        } else {
+            def.leaf.merge(leaf);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/SchemaBuilderImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/SchemaBuilderImpl.java
new file mode 100644
index 0000000..921676d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/SchemaBuilderImpl.java
@@ -0,0 +1,213 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.relaxng;
+
+import com.sun.codemodel.JClass;
+import com.sun.codemodel.JCodeModel;
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.model.Attribute;
+import com.sun.tools.internal.txw2.model.Data;
+import com.sun.tools.internal.txw2.model.Element;
+import com.sun.tools.internal.txw2.model.Empty;
+import com.sun.tools.internal.txw2.model.Leaf;
+import com.sun.tools.internal.txw2.model.List;
+import com.sun.tools.internal.txw2.model.Value;
+import org.kohsuke.rngom.ast.builder.BuildException;
+import org.kohsuke.rngom.ast.builder.DataPatternBuilder;
+import org.kohsuke.rngom.ast.builder.ElementAnnotationBuilder;
+import org.kohsuke.rngom.ast.builder.Grammar;
+import org.kohsuke.rngom.ast.builder.NameClassBuilder;
+import org.kohsuke.rngom.ast.builder.SchemaBuilder;
+import org.kohsuke.rngom.ast.builder.Scope;
+import org.kohsuke.rngom.ast.om.ParsedElementAnnotation;
+import org.kohsuke.rngom.ast.util.LocatorImpl;
+import org.kohsuke.rngom.nc.NameClass;
+import org.kohsuke.rngom.nc.NameClassBuilderImpl;
+import org.kohsuke.rngom.parse.Context;
+import org.kohsuke.rngom.parse.IllegalSchemaException;
+import org.kohsuke.rngom.parse.Parseable;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Builds a model from a RELAX NG grammar.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class SchemaBuilderImpl implements SchemaBuilder<NameClass,Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> {
+    private final NameClassBuilderImpl ncb = new NameClassBuilderImpl();
+    private final JClass string;
+    private final DatatypeFactory dtf;
+
+    public SchemaBuilderImpl(JCodeModel codeModel) {
+        string = codeModel.ref(String.class);
+        dtf = new DatatypeFactory(codeModel);
+    }
+
+
+    public Leaf expandPattern(Leaf leaf) throws BuildException {
+        return leaf;
+    }
+
+
+
+    public NameClassBuilder getNameClassBuilder() throws BuildException {
+        return ncb;
+    }
+
+    private Leaf merge(java.util.List<Leaf> leaves) {
+        for( int i=1; i<leaves.size(); i++ )
+            leaves.get(0).merge(leaves.get(i));
+        return leaves.get(0);
+    }
+
+    public Leaf makeChoice(java.util.List<Leaf> leaves, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return merge(leaves);
+    }
+
+    public Leaf makeInterleave(java.util.List<Leaf> leaves, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return merge(leaves);
+    }
+
+    public Leaf makeGroup(java.util.List<Leaf> leaves, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return merge(leaves);
+    }
+
+    public Leaf makeOneOrMore(Leaf leaf, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return leaf;
+    }
+
+    public Leaf makeZeroOrMore(Leaf leaf, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return leaf.merge(new Empty(locator));
+    }
+
+    public Leaf makeOptional(Leaf leaf, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return leaf.merge(new Empty(locator));
+    }
+
+    public Leaf makeList(Leaf leaf, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return new List(locator,leaf);
+    }
+
+    public Leaf makeMixed(Leaf leaf, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return leaf.merge(new Data(locator,string));
+    }
+
+    public Leaf makeEmpty(LocatorImpl locator, AnnotationsImpl annotations) {
+        return new Empty(locator);
+    }
+
+    public Leaf makeNotAllowed(LocatorImpl locator, AnnotationsImpl annotations) {
+        // technically this is incorrect, but we won't be
+        // able to handle <notAllowed/> correctly anyway.
+        return new Empty(locator);
+    }
+
+    public Leaf makeText(LocatorImpl locator, AnnotationsImpl annotations) {
+        return new Data(locator,string);
+    }
+
+    public Leaf makeAttribute(NameClass nameClass, Leaf leaf, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        Leaf r = null;
+        for( QName n : nameClass.listNames() ) {
+            Leaf l = new Attribute(locator,n,leaf);
+            if(r!=null)     r = r.merge(l);
+            else            r = l;
+        }
+        if(r==null)     return new Empty(locator);
+        return r;
+    }
+
+    public Leaf makeElement(NameClass nameClass, Leaf leaf, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        Leaf r = null;
+        for( QName n : nameClass.listNames() ) {
+            Leaf l = new Element(locator,n,leaf);
+            if(r!=null)     r = r.merge(l);
+            else            r = l;
+        }
+        if(r==null)     return new Empty(locator);
+        return r;
+    }
+
+    public DataPatternBuilder makeDataPatternBuilder(String datatypeLibrary, String type, LocatorImpl locator) throws BuildException {
+        return new DataPatternBuilderImpl(getType(datatypeLibrary, type));
+    }
+
+    private JType getType(String datatypeLibrary, String type) {
+        JType t = dtf.getType(datatypeLibrary,type);
+        if(t==null) t = string;
+        return t;
+    }
+
+    public Leaf makeValue(String datatypeLibrary, String type, String value, Context c, String ns, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException {
+        return new Value(locator,getType(datatypeLibrary, type),value);
+    }
+
+    public Grammar<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> makeGrammar(Scope<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> scope) {
+        return new GrammarImpl(scope);
+    }
+
+    public Leaf annotate(Leaf leaf, AnnotationsImpl annotations) throws BuildException {
+        return leaf;
+    }
+
+    public Leaf annotateAfter(Leaf leaf, ParsedElementAnnotation parsedElementAnnotation) throws BuildException {
+        return leaf;
+    }
+
+    public Leaf makeErrorPattern() {
+        return new Empty(null);
+    }
+
+    public boolean usesComments() {
+        return false;
+    }
+
+    public Leaf makeExternalRef(Parseable current, String uri, String ns, Scope<Leaf,ParsedElementAnnotation,LocatorImpl,AnnotationsImpl,CommentListImpl> scope, LocatorImpl locator, AnnotationsImpl annotations) throws BuildException, IllegalSchemaException {
+        // I'm not too sure if this is correct
+        return current.parseExternal(uri, this, scope, ns );
+    }
+
+    public LocatorImpl makeLocation(String systemId, int lineNumber, int columnNumber) {
+        return new LocatorImpl(systemId,lineNumber,columnNumber);
+    }
+
+    public AnnotationsImpl makeAnnotations(CommentListImpl commentList, Context context) {
+        return new AnnotationsImpl();
+    }
+
+    public ElementAnnotationBuilder<Leaf, ParsedElementAnnotation, LocatorImpl, AnnotationsImpl, CommentListImpl> makeElementAnnotationBuilder(String ns, String localName, String prefix, LocatorImpl locator, CommentListImpl commentList, Context context) {
+        return new ElementAnnotationBuilderImpl();
+    }
+
+    public CommentListImpl makeCommentList() {
+        return null;
+    }
+
+    public Leaf commentAfter(Leaf leaf, CommentListImpl commentList) throws BuildException {
+        return leaf;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/package.html b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/package.html
new file mode 100644
index 0000000..587ef12
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/relaxng/package.html
@@ -0,0 +1,3 @@
+<html><body>
+  Reads RELAX NG grammar from RNGOM and builds the model for TXW.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/xsd/XmlSchemaBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/xsd/XmlSchemaBuilder.java
new file mode 100644
index 0000000..804a215
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/xsd/XmlSchemaBuilder.java
@@ -0,0 +1,282 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.builder.xsd;
+
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.TxwOptions;
+import com.sun.tools.internal.txw2.builder.relaxng.DatatypeFactory;
+import com.sun.tools.internal.txw2.model.Attribute;
+import com.sun.tools.internal.txw2.model.Data;
+import com.sun.tools.internal.txw2.model.Define;
+import com.sun.tools.internal.txw2.model.Empty;
+import com.sun.tools.internal.txw2.model.Grammar;
+import com.sun.tools.internal.txw2.model.Leaf;
+import com.sun.tools.internal.txw2.model.List;
+import com.sun.tools.internal.txw2.model.NodeSet;
+import com.sun.tools.internal.txw2.model.Element;
+import com.sun.tools.internal.txw2.model.Ref;
+import com.sun.xml.xsom.XSAnnotation;
+import com.sun.xml.xsom.XSAttributeDecl;
+import com.sun.xml.xsom.XSAttributeUse;
+import com.sun.xml.xsom.XSComplexType;
+import com.sun.xml.xsom.XSContentType;
+import com.sun.xml.xsom.XSDeclaration;
+import com.sun.xml.xsom.XSFacet;
+import com.sun.xml.xsom.XSIdentityConstraint;
+import com.sun.xml.xsom.XSListSimpleType;
+import com.sun.xml.xsom.XSNotation;
+import com.sun.xml.xsom.XSParticle;
+import com.sun.xml.xsom.XSRestrictionSimpleType;
+import com.sun.xml.xsom.XSSchema;
+import com.sun.xml.xsom.XSSchemaSet;
+import com.sun.xml.xsom.XSSimpleType;
+import com.sun.xml.xsom.XSUnionSimpleType;
+import com.sun.xml.xsom.XSXPath;
+import com.sun.xml.xsom.XSWildcard;
+import com.sun.xml.xsom.XSModelGroupDecl;
+import com.sun.xml.xsom.XSModelGroup;
+import com.sun.xml.xsom.XSElementDecl;
+import com.sun.xml.xsom.XSType;
+import com.sun.xml.xsom.XSAttContainer;
+import com.sun.xml.xsom.XSAttGroupDecl;
+import com.sun.xml.xsom.visitor.XSFunction;
+import com.sun.xml.xsom.visitor.XSSimpleTypeFunction;
+
+import javax.xml.namespace.QName;
+import java.util.Map;
+import java.util.HashMap;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public final class XmlSchemaBuilder implements XSFunction<Leaf>, XSSimpleTypeFunction<Leaf> {
+    public static NodeSet build( XSSchemaSet xs, TxwOptions opts ) {
+        XmlSchemaBuilder builder = new XmlSchemaBuilder(xs,opts);
+        builder.build(xs);
+        return builder.nodeSet;
+    }
+
+    private void build(XSSchemaSet xs) {
+        // make sure that we bind all complex types
+        for( XSSchema s : xs.getSchemas() ) {
+            for( XSComplexType t : s.getComplexTypes().values() ) {
+                t.apply(this);
+            }
+        }
+
+        nodeSet.addAll(complexTypes.values());
+        nodeSet.addAll(modelGroups.values());
+        nodeSet.addAll(attGroups.values());
+    }
+
+    public Leaf simpleType(XSSimpleType simpleType) {
+        return simpleType.apply((XSSimpleTypeFunction<Leaf>)this);
+    }
+
+    public Leaf particle(XSParticle particle) {
+        return particle.getTerm().apply(this);
+    }
+
+    public Leaf empty(XSContentType empty) {
+        return new Empty(empty.getLocator());
+    }
+
+    public Attribute attributeDecl(XSAttributeDecl decl) {
+        return new Attribute(decl.getLocator(),
+                        getQName(decl),
+                        simpleType(decl.getType()));
+    }
+
+    public Attribute attributeUse(XSAttributeUse use) {
+        return attributeDecl(use.getDecl());
+    }
+
+    public Leaf wildcard(XSWildcard wc) {
+        // wildcard can be always written through the well-formedness method.
+        // no need to generate anything for this.
+        return new Empty(wc.getLocator());
+    }
+
+    public Leaf modelGroupDecl(XSModelGroupDecl mg) {
+        Define def = modelGroups.get(mg);
+        if(def==null) {
+            def = grammar.get(mg.getName()); // TODO: name collision detection and avoidance
+            modelGroups.put(mg,def);
+
+            def.addChild(mg.getModelGroup().apply(this));
+        }
+        return new Ref(mg.getLocator(),def);
+    }
+
+    public Leaf modelGroup(XSModelGroup mg) {
+        XSParticle[] children = mg.getChildren();
+        if(children.length==0)  return new Empty(mg.getLocator());
+
+        Leaf l = particle(children[0]);
+        for( int i=1; i<children.length; i++ )
+            l.merge(particle(children[i]));
+        return l;
+    }
+
+    public Leaf elementDecl(XSElementDecl e) {
+        Element el = new Element(e.getLocator(),getQName(e),e.getType().apply(this));
+        nodeSet.add(el);
+        return el;
+    }
+
+    public Leaf complexType(XSComplexType ct) {
+        Define def = complexTypes.get(ct);
+        if(def==null) {
+            // TODO: consider name collision and such
+            String name = ct.getName();
+            if(ct.isLocal()) {
+                name = ct.getScope().getName();
+            }
+            def = grammar.get(name);
+            complexTypes.put(ct,def);
+
+            XSType baseType = ct.getBaseType();
+            if(baseType.isComplexType() && !isAnyType(baseType)) {
+                // copy inheritance
+                def.addChild(baseType.apply(this));
+
+                if(ct.getDerivationMethod()==XSType.EXTENSION) {
+                    XSContentType explicitContent = ct.getExplicitContent();
+                    if(explicitContent!=null)
+                        def.addChild(explicitContent.apply(this));
+                    attHolder(ct, def);
+                }
+            } else {
+                // just start from fresh
+                def.addChild(ct.getContentType().apply(this));
+                attHolder(ct, def);
+            }
+        }
+
+        return new Ref(ct.getLocator(),def);
+    }
+
+    private void attHolder(XSAttContainer ct, Define def) {
+        for( XSAttributeUse use : ct.getDeclaredAttributeUses() ) {
+            def.addChild(attributeUse(use));
+        }
+        for (XSAttGroupDecl ag : ct.getAttGroups()) {
+            def.addChild(attGroupDecl(ag));
+        }
+    }
+
+    public Leaf attGroupDecl(XSAttGroupDecl ag) {
+        Define def = attGroups.get(ag);
+        if(def==null) {
+            def = grammar.get(ag.getName());
+            attGroups.put(ag,def);
+            attHolder(ag,def);
+        }
+        return new Ref(ag.getLocator(),def);
+    }
+
+    private boolean isAnyType(XSType t) {
+        return t.getName().equals("anyType") && t.getTargetNamespace().equals("http://www.w3.org/2001/XMLSchema");
+    }
+
+    public Leaf restrictionSimpleType(XSRestrictionSimpleType rst) {
+        JType t = dtf.getType(rst.getTargetNamespace(),rst.getName());
+        if(t!=null) return new Data(rst.getLocator(),t);
+        return simpleType(rst.getSimpleBaseType());
+    }
+
+    public Leaf unionSimpleType(XSUnionSimpleType st) {
+        Leaf l = simpleType(st.getMember(0));
+        for( int i=1; i<st.getMemberSize(); i++ )
+            l.merge(simpleType(st.getMember(i)));
+        return l;
+    }
+
+    public Leaf listSimpleType(XSListSimpleType st) {
+        return new List(st.getLocator(),simpleType(st.getItemType()));
+    }
+
+    private QName getQName(XSDeclaration decl) {
+        return new QName(decl.getTargetNamespace(),decl.getName());
+    }
+
+    protected final XSSchemaSet schemaSet;
+
+    protected final NodeSet nodeSet;
+
+    private final DatatypeFactory dtf;
+
+    /**
+     * We map model groups to interfaces.
+     */
+    private final Map<XSModelGroupDecl,Define> modelGroups = new HashMap<XSModelGroupDecl, Define>();
+
+    /**
+     * We map complex types to interfaces.
+     */
+    private final Map<XSComplexType,Define> complexTypes = new HashMap<XSComplexType,Define>();
+
+    /**
+     * ... and attribute groups
+     */
+    private final Map<XSAttGroupDecl,Define> attGroups = new HashMap<XSAttGroupDecl,Define>();
+
+    private final Grammar grammar = new Grammar();
+
+    private XmlSchemaBuilder(XSSchemaSet xs,TxwOptions opts) {
+        this.schemaSet = xs;
+        grammar.addChild(new Empty(null));
+        this.nodeSet = new NodeSet(opts,grammar);
+        this.dtf = new DatatypeFactory(opts.codeModel);
+    }
+
+
+
+// won't be used
+    public Leaf annotation(XSAnnotation xsAnnotation) {
+        throw new IllegalStateException();
+    }
+
+    public Leaf schema(XSSchema xsSchema) {
+        throw new IllegalStateException();
+    }
+
+    public Leaf facet(XSFacet xsFacet) {
+        throw new IllegalStateException();
+    }
+
+    public Leaf notation(XSNotation xsNotation) {
+        throw new IllegalStateException();
+    }
+
+    public Leaf identityConstraint(XSIdentityConstraint xsIdentityConstraint) {
+        throw new IllegalStateException();
+    }
+
+    public Leaf xpath(XSXPath xsxPath) {
+        throw new IllegalStateException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/xsd/package.html b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/xsd/package.html
new file mode 100644
index 0000000..1b90dc3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/builder/xsd/package.html
@@ -0,0 +1,3 @@
+<html><body>
+  Reads XML Schema grammar from XSOM and builds the model for TXW.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Attribute.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Attribute.java
new file mode 100644
index 0000000..8b901d1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Attribute.java
@@ -0,0 +1,93 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JAnnotationUse;
+import com.sun.codemodel.JDefinedClass;
+import com.sun.codemodel.JMethod;
+import com.sun.codemodel.JMod;
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.NameUtil;
+import com.sun.tools.internal.txw2.model.prop.AttributeProp;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import org.xml.sax.Locator;
+
+import javax.xml.namespace.QName;
+import java.util.HashSet;
+import java.util.Set;
+
+/**
+ * Attribute declaration.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class Attribute extends XmlNode {
+    public Attribute(Locator location, QName name, Leaf leaf) {
+        super(location, name, leaf);
+    }
+
+    void declare(NodeSet nset) {
+        ; // attributes won't produce a class
+    }
+
+    void generate(NodeSet nset) {
+        ; // nothing
+    }
+
+    void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+        Set<JType> types = new HashSet<JType>();
+
+        for( Leaf l : collectChildren() ) {
+            if (l instanceof Text) {
+                types.add(((Text)l).getDatatype(nset));
+            }
+        }
+
+        String methodName = NameUtil.toMethodName(name.getLocalPart());
+
+        for( JType t : types ) {
+            if(!props.add(new AttributeProp(name,t)))
+                continue;
+
+            JMethod m = clazz.method(JMod.PUBLIC,
+                nset.opts.chainMethod? (JType)clazz : nset.codeModel.VOID,
+                methodName);
+            m.param(t,"value");
+
+            JAnnotationUse a = m.annotate(XmlAttribute.class);
+            if(!methodName.equals(name.getLocalPart()))
+                a.param("value",name.getLocalPart());
+            if(!name.getNamespaceURI().equals(""))
+                a.param("ns",name.getNamespaceURI());
+
+        }
+    }
+
+    public String toString() {
+        return "Attribute "+name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/CycleIterator.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/CycleIterator.java
new file mode 100644
index 0000000..fe9edf7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/CycleIterator.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import java.util.Iterator;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class CycleIterator implements Iterator<Leaf> {
+    private Leaf start;
+    private Leaf current;
+    private boolean hasNext = true;
+
+    public CycleIterator(Leaf start) {
+        assert start!=null;
+        this.start = start;
+        this.current = start;
+    }
+
+    public boolean hasNext() {
+        return hasNext;
+    }
+
+    public Leaf next() {
+        Leaf last = current;
+        current = current.getNext();
+        if(current==start)
+            hasNext = false;
+
+        return last;
+    }
+
+    public void remove() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Data.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Data.java
new file mode 100644
index 0000000..93f5acc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Data.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JDefinedClass;
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import org.xml.sax.Locator;
+
+import java.util.Set;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class Data extends Leaf implements Text {
+    /**
+     * The Java representation of the datatype.
+     */
+    public final JType type;
+
+    public Data(Locator location, JType type) {
+        super(location);
+        this.type = type;
+    }
+
+    public JType getDatatype(NodeSet nset) {
+        return type;
+    }
+
+    void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+        createDataMethod(clazz,type,nset,props);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Define.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Define.java
new file mode 100644
index 0000000..c25127f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Define.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JDefinedClass;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+
+import java.util.HashSet;
+import java.util.Set;
+
+
+/**
+ * A named pattern.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class Define extends WriterNode {
+    public final Grammar scope;
+    public final String name;
+
+    JDefinedClass clazz;
+
+    public Define(Grammar scope, String name) {
+        super(null,null);
+        if(scope==null)     scope = (Grammar)this;  // hack for start pattern
+        this.scope = scope;
+        this.name = name;
+        assert name!=null;
+    }
+
+    /**
+     * Returns true if this define only contains
+     * one child (and thus considered inlinable.)
+     *
+     * A pattern definition is also inlineable if
+     * it's the start of the grammar (because "start" isn't a meaningful name)
+     */
+    public boolean isInline() {
+        return hasOneChild() || name==Grammar.START;
+    }
+
+    void declare(NodeSet nset) {
+        if(isInline())  return;
+
+        clazz = nset.createClass(name);
+        clazz._implements(TypedXmlWriter.class);
+    }
+
+    void generate(NodeSet nset) {
+        if(clazz==null)     return;
+
+        HashSet<Prop> props = new HashSet<Prop>();
+        for( Leaf l : this )
+            l.generate(clazz,nset,props);
+    }
+
+    void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+        if(isInline()) {
+            for( Leaf l : this )
+                l.generate(clazz,nset, props);
+        } else {
+            assert this.clazz!=null;
+            clazz._implements(this.clazz);
+        }
+    }
+
+    void prepare(NodeSet nset) {
+        if(isInline() && leaf instanceof WriterNode && !name.equals(Grammar.START))
+            ((WriterNode)leaf).alternativeName = name;
+    }
+
+    public String toString() {
+        return "Define "+name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Element.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Element.java
new file mode 100644
index 0000000..8dad70f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Element.java
@@ -0,0 +1,201 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JAnnotationUse;
+import com.sun.codemodel.JDefinedClass;
+import com.sun.codemodel.JMethod;
+import com.sun.codemodel.JMod;
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.NameUtil;
+import com.sun.tools.internal.txw2.model.prop.ElementProp;
+import com.sun.tools.internal.txw2.model.prop.LeafElementProp;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import org.xml.sax.Locator;
+
+import javax.xml.namespace.QName;
+import java.util.HashSet;
+import java.util.Set;
+
+/**
+ * Element declaration.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class Element extends XmlNode {
+    /**
+     * True if this element can be a root element.
+     */
+    public boolean isRoot;
+
+    private Strategy strategy;
+
+    public Element(Locator location, QName name, Leaf leaf) {
+        super(location, name, leaf);
+    }
+
+    /**
+     * Returns true if this element should generate an interface.
+     */
+    private Strategy decideStrategy() {
+        if(isRoot)
+            return new ToInterface();
+
+        if(hasOneChild() && leaf instanceof Ref && !((Ref)leaf).isInline())
+            return new HasOneRef((Ref)leaf);
+
+        Set<Leaf> children = collectChildren();
+        for( Leaf l : children ) {
+            if( l instanceof XmlNode )
+                // if it has attributes/elements in children
+                // generate an interface
+                return new ToInterface();
+        }
+
+        // otherwise this element only has data, so just generate methods for them.
+        return new DataOnly();
+    }
+
+    void declare(NodeSet nset) {
+        strategy = decideStrategy();
+        strategy.declare(nset);
+    }
+
+    void generate(NodeSet nset) {
+        strategy.generate(nset);
+    }
+
+    void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+        strategy.generate(clazz,nset,props);
+    }
+
+
+    private JMethod generateMethod(JDefinedClass clazz, NodeSet nset, JType retT) {
+        String methodName = NameUtil.toMethodName(name.getLocalPart());
+
+        JMethod m = clazz.method(JMod.PUBLIC, retT, methodName);
+
+        JAnnotationUse a = m.annotate(XmlElement.class);
+        if(!methodName.equals(name.getLocalPart()))
+            a.param("value",name.getLocalPart());
+        if(nset.defaultNamespace==null || !nset.defaultNamespace.equals(name.getNamespaceURI()))
+            a.param("ns",name.getNamespaceURI());
+
+        return m;
+    }
+
+    public String toString() {
+        return "Element "+name;
+    }
+
+
+    interface Strategy {
+        void declare(NodeSet nset);
+        void generate(NodeSet nset);
+        void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props);
+    }
+
+    /**
+     * Maps to an interface
+     */
+    private class ToInterface implements Strategy {
+        private JDefinedClass clazz;
+
+        public void declare(NodeSet nset) {
+            String cname;
+            if(alternativeName!=null)
+                cname = alternativeName;
+            else
+                cname = name.getLocalPart();
+            clazz = nset.createClass(cname);
+            clazz._implements(TypedXmlWriter.class);
+
+            clazz.annotate(XmlElement.class)
+                .param("value",name.getLocalPart());
+            // TODO: namespace
+        }
+
+        public void generate(NodeSet nset) {
+            HashSet<Prop> props = new HashSet<Prop>();
+            for( Leaf l : Element.this )
+                l.generate(clazz,nset, props);
+        }
+
+        public void generate(JDefinedClass outer, NodeSet nset, Set<Prop> props) {
+            if(props.add(new ElementProp(name,clazz)))
+                generateMethod(outer, nset, clazz);
+        }
+    }
+
+    /**
+     * For things like "element foo {refToAnotherPattern}"
+     */
+    private class HasOneRef implements Strategy {
+        private final Ref ref;
+
+        public HasOneRef(Ref ref) {
+            this.ref = ref;
+        }
+
+        public void declare(NodeSet nset) {
+        }
+        public void generate(NodeSet nset) {
+        }
+
+        public void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+            if(props.add(new ElementProp(name,ref.def.clazz)))
+                generateMethod(clazz, nset, ref.def.clazz);
+        }
+    }
+
+    private class DataOnly implements Strategy {
+        public void declare(NodeSet nset) {
+        }
+        public void generate(NodeSet nset) {
+        }
+
+        // TODO: code share with Attribute
+        public void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+            Set<JType> types = new HashSet<JType>();
+
+            for( Leaf l : collectChildren() ) {
+                if (l instanceof Text) {
+                    types.add(((Text)l).getDatatype(nset));
+                }
+            }
+
+            for( JType t : types ) {
+                if(!props.add(new LeafElementProp(name,t)))
+                    continue;
+                generateMethod(clazz,
+                        nset, nset.opts.chainMethod? (JType)clazz : nset.codeModel.VOID
+                ).param(t,"value");
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Empty.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Empty.java
new file mode 100644
index 0000000..4c209a4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Empty.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JDefinedClass;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import org.xml.sax.Locator;
+
+import java.util.Set;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class Empty extends Leaf {
+    public Empty(Locator location) {
+        super(location);
+    }
+
+    void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+        // noop
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Grammar.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Grammar.java
new file mode 100644
index 0000000..1a5e97c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Grammar.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import org.kohsuke.rngom.ast.builder.GrammarSection;
+
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Collection;
+
+/**
+ * Represents a RELAX NG grammar.
+ *
+ * A {@link Grammar} extends a {@link Define} as "start"
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class Grammar extends Define {
+    private final Map<String,Define> patterns = new HashMap<String,Define>();
+
+    public Grammar() {
+        super(null,START);
+        patterns.put(START,this);
+    }
+
+    public Define get(String name) {
+        Define def = patterns.get(name);
+        if(def==null)
+            patterns.put(name,def=new Define(this,name));
+        return def;
+    }
+
+    public Collection<Define> getDefinitions() {
+        return patterns.values();
+    }
+
+    /**
+     * The name for the start pattern
+     */
+    public static final String START = GrammarSection.START;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Leaf.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Leaf.java
new file mode 100644
index 0000000..5fccf0c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Leaf.java
@@ -0,0 +1,125 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JDefinedClass;
+import com.sun.codemodel.JMethod;
+import com.sun.codemodel.JMod;
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import com.sun.tools.internal.txw2.model.prop.ValueProp;
+import com.sun.xml.internal.txw2.annotation.XmlValue;
+import org.kohsuke.rngom.ast.om.ParsedPattern;
+import org.xml.sax.Locator;
+
+import java.util.Iterator;
+import java.util.Set;
+
+/**
+ * {@link Leaf}s form a set (by a cyclic doubly-linked list.)
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Leaf implements ParsedPattern {
+    private Leaf next;
+    private Leaf prev;
+
+    /**
+     * Source location where this leaf was defined.
+     */
+    public Locator location;
+
+    protected Leaf(Locator location) {
+        this.location = location;
+        prev = next = this;
+    }
+
+    public final Leaf getNext() {
+        assert next!=null;
+        assert next.prev == this;
+        return next;
+    }
+
+    public final Leaf getPrev() {
+        assert prev!=null;
+        assert prev.next == this;
+        return prev;
+    }
+
+    /**
+     * Combines two sets into one set.
+     *
+     * @return this
+     */
+    public final Leaf merge(Leaf that) {
+        Leaf n1 = this.next;
+        Leaf n2 = that.next;
+
+        that.next = n1;
+        that.next.prev = that;
+        this.next = n2;
+        this.next.prev = this;
+
+        return this;
+    }
+
+    /**
+     * Returns the collection of all the siblings
+     * (including itself)
+     */
+    public final Iterable<Leaf> siblings() {
+        return new Iterable<Leaf>() {
+            public Iterator<Leaf> iterator() {
+                return new CycleIterator(Leaf.this);
+            }
+        };
+    }
+
+    /**
+     * Populate the body of the writer class.
+     *
+     * @param props
+     *      captures the generatesd {@link Prop}s to
+     */
+    abstract void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props);
+
+
+
+
+    /**
+     * Creates a prop of the data value method.
+     */
+    protected final void createDataMethod(JDefinedClass clazz, JType valueType, NodeSet nset, Set<Prop> props) {
+        if(!props.add(new ValueProp(valueType)))
+            return;
+
+        JMethod m = clazz.method(JMod.PUBLIC,
+            nset.opts.chainMethod? (JType)clazz : nset.codeModel.VOID,
+            "_text");
+        m.annotate(XmlValue.class);
+        m.param(valueType,"value");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/List.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/List.java
new file mode 100644
index 0000000..543a1a7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/List.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JDefinedClass;
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import org.xml.sax.Locator;
+
+import java.util.Set;
+
+/**
+ * List of {@link Data} or {@link Value}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class List extends Node implements Text {
+    public List(Locator location, Leaf leaf) {
+        super(location, leaf);
+    }
+
+    public JType getDatatype(NodeSet nset) {
+        if(hasOneChild() && leaf instanceof Text) {
+            return ((Text)leaf).getDatatype(nset).array();
+        } else {
+            return nset.codeModel.ref(String.class).array();
+        }
+    }
+
+    void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+        createDataMethod(clazz,getDatatype(nset),nset,props);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Node.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Node.java
new file mode 100644
index 0000000..7f90e83
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Node.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import org.xml.sax.Locator;
+
+import java.util.Iterator;
+
+/**
+ * {@link Node} is a {@link Leaf} that has children.
+ *
+ * Children are orderless.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Node extends Leaf implements Iterable<Leaf> {
+
+    /**
+     * Children of this node.
+     */
+    public Leaf leaf;
+
+    protected Node(Locator location, Leaf leaf) {
+        super(location);
+        this.leaf = leaf;
+    }
+
+    /**
+     * Iterates all the children.
+     */
+    public final Iterator<Leaf> iterator() {
+        return new CycleIterator(leaf);
+    }
+
+    /**
+     * Returns true if this node has only one child node.
+     */
+    public final boolean hasOneChild() {
+        return leaf==leaf.getNext();
+    }
+
+    /**
+     * Adds the given {@link Leaf} and their sibling as children of this {@link Node}.
+     */
+    public final void addChild(Leaf child) {
+        if(this.leaf==null)
+            leaf = child;
+        else
+            leaf.merge(child);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/NodeSet.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/NodeSet.java
new file mode 100644
index 0000000..64c3839
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/NodeSet.java
@@ -0,0 +1,163 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.ClassType;
+import com.sun.codemodel.JClassAlreadyExistsException;
+import com.sun.codemodel.JCodeModel;
+import com.sun.codemodel.JDefinedClass;
+import com.sun.codemodel.JMod;
+import com.sun.tools.internal.txw2.NameUtil;
+import com.sun.tools.internal.txw2.TxwOptions;
+import com.sun.xml.internal.txw2.annotation.XmlNamespace;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.LinkedHashSet;
+import java.util.Set;
+
+/**
+ * Root of the model.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class NodeSet extends LinkedHashSet<WriterNode> {
+
+    /*package*/ final TxwOptions opts;
+    /*package*/ final JCodeModel codeModel;
+
+    /**
+     * Set of all the {@link Element}s that can be root.
+     */
+    private final Set<Element> rootElements = new HashSet<Element>();
+
+    /** The namespace URI declared in {@link XmlNamespace}. */
+    /*package*/ final String defaultNamespace;
+
+    public NodeSet(TxwOptions opts, Leaf entry) {
+        this.opts = opts;
+        this.codeModel = opts.codeModel;
+        addAll(entry.siblings());
+        markRoot(entry.siblings(),rootElements);
+
+        // decide what to put in @XmlNamespace
+        Set<String> ns = new HashSet<String>();
+        for( Element e : rootElements )
+            ns.add(e.name.getNamespaceURI());
+
+        if(ns.size()!=1 || opts.noPackageNamespace || opts._package.isUnnamed())
+            defaultNamespace = null;
+        else {
+            defaultNamespace = ns.iterator().next();
+
+            opts._package.annotate(XmlNamespace.class)
+                .param("value",defaultNamespace);
+        }
+    }
+
+    /**
+     * Marks all the element children as root.
+     */
+    private void markRoot(Iterable<Leaf> c, Set<Element> rootElements) {
+        for( Leaf l : c ) {
+            if( l instanceof Element ) {
+                Element e = (Element)l;
+                rootElements.add(e);
+                e.isRoot = true;
+            }
+            if( l instanceof Ref ) {
+                markRoot(((Ref)l).def,rootElements);
+            }
+        }
+    }
+
+    private void addAll(Iterable<Leaf> c) {
+        for( Leaf l : c ) {
+            if(l instanceof Element)
+                if(add((Element)l))
+                    addAll((Element)l);
+            if(l instanceof Grammar) {
+                Grammar g = (Grammar)l;
+                for( Define d : g.getDefinitions() )
+                    add(d);
+            }
+            if(l instanceof Ref) {
+                Ref r = (Ref)l;
+                Define def = r.def;
+//                if(def instanceof Grammar) {
+//                    for( Define d : ((Grammar)def).getDefinitions() )
+//                        if(add(d))
+//                            addAll(d);
+//                }
+                add(def);
+            }
+        }
+    }
+
+    private boolean add(Define def) {
+        boolean b = super.add(def);
+        if(b)
+            addAll(def);
+        return b;
+    }
+
+    public <T extends WriterNode> Collection<T> subset(Class<T> t) {
+        ArrayList<T> r = new ArrayList<T>(size());
+        for( WriterNode n : this )
+            if(t.isInstance(n))
+                r.add((T)n);
+        return r;
+    }
+
+    /**
+     * Generate code
+     */
+    public void write(TxwOptions opts) {
+        for( WriterNode n : this )
+            n.prepare(this);
+        for( WriterNode n : this )
+            n.declare(this);
+        for( WriterNode n : this )
+            n.generate(this);
+    }
+
+    /*package*/ final JDefinedClass createClass(String name) {
+        try {
+            return opts._package._class(
+                JMod.PUBLIC, NameUtil.toClassName(name), ClassType.INTERFACE );
+        } catch (JClassAlreadyExistsException e) {
+            for( int i=2; true; i++ ) {
+                try {
+                    return opts._package._class(
+                        JMod.PUBLIC, NameUtil.toClassName(name+String.valueOf(i)), ClassType.INTERFACE );
+                } catch (JClassAlreadyExistsException e1) {
+                    ; // continue
+                }
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Ref.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Ref.java
new file mode 100644
index 0000000..4c0f23c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Ref.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JDefinedClass;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import org.xml.sax.Locator;
+
+import java.util.Set;
+
+/**
+ * A reference to a named pattern.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Ref extends Leaf {
+    public final Define def;
+
+    public Ref(Locator location, Grammar scope, String name) {
+        super(location);
+        this.def = scope.get(name);
+    }
+
+    public Ref(Locator location, Define def) {
+        super(location);
+        this.def = def;
+    }
+
+    public boolean isInline() {
+        return def.isInline();
+    }
+
+    void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+        def.generate(clazz,nset,props);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Text.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Text.java
new file mode 100644
index 0000000..03ac075
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Text.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JType;
+
+/**
+ * Implemented by {@link Leaf}s that map to PCDATA in XML.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Text {
+    /**
+     * Obtains the Java class of this {@link Text}.
+     */
+    JType getDatatype(NodeSet nset);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Value.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Value.java
new file mode 100644
index 0000000..60d8bd4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/Value.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import com.sun.codemodel.JDefinedClass;
+import com.sun.codemodel.JType;
+import com.sun.tools.internal.txw2.model.prop.Prop;
+import org.xml.sax.Locator;
+
+import java.util.Set;
+
+/**
+ * A constant value.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class Value extends Leaf implements Text {
+    /**
+     * The underlying datatype, in case
+     * we need to revert to {@link Data}.
+     */
+    public final JType type;
+    /**
+     * Constant name.
+     */
+    public final String name;
+
+    public Value(Locator location, JType type, String name) {
+        super(location);
+        this.type = type;
+        this.name = name;
+    }
+
+    void generate(JDefinedClass clazz, NodeSet nset, Set<Prop> props) {
+        createDataMethod(clazz,type,nset,props);
+    }
+
+    public JType getDatatype(NodeSet nset) {
+        // TODO: enum support
+        return type;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/WriterNode.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/WriterNode.java
new file mode 100644
index 0000000..67f1762
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/WriterNode.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import org.xml.sax.Locator;
+
+/**
+ * The {@link Node} that maps to the program element.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class WriterNode extends Node {
+    /**
+     * If this node is the sole child of a pattern block,
+     * this field points to its name.
+     *
+     * <p>
+     * When the element names are in conflict, this can be used.
+     */
+    protected String alternativeName;
+
+    public WriterNode(Locator location, Leaf leaf) {
+        super(location, leaf);
+    }
+
+    /**
+     * Declares the class without its contents.
+     *
+     * The first step of the code generation.
+     */
+    abstract void declare(NodeSet nset);
+
+    /**
+     * Generates the contents.
+     */
+    abstract void generate(NodeSet nset);
+
+    /**
+     * Prepares for the code generation.
+     */
+    void prepare(NodeSet nset) {}
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/XmlNode.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/XmlNode.java
new file mode 100644
index 0000000..d1bf961
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/XmlNode.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model;
+
+import org.xml.sax.Locator;
+
+import javax.xml.namespace.QName;
+import java.util.HashSet;
+import java.util.Set;
+import java.util.Stack;
+
+/**
+ * Either an {@link Element} or {@link Attribute}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class XmlNode extends WriterNode {
+    /**
+     * Name of the attribute/element.
+     *
+     * In TXW, we ignore all infinite names.
+     * (finite name class will be expanded to a list of {@link XmlNode}s.
+     */
+    public final QName name;
+
+    protected XmlNode(Locator location, QName name, Leaf leaf) {
+        super(location, leaf);
+        this.name = name;
+    }
+
+    /**
+     * Expand all refs and collect all children.
+     */
+    protected final Set<Leaf> collectChildren() {
+        Set<Leaf> result = new HashSet<Leaf>();
+
+        Stack<Node> work = new Stack<Node>();
+        work.push(this);
+
+        while(!work.isEmpty()) {
+            for( Leaf l : work.pop() ) {
+                if( l instanceof Ref ) {
+                    work.push( ((Ref)l).def );
+                } else {
+                    result.add(l);
+                }
+            }
+        }
+
+        return result;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/AttributeProp.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/AttributeProp.java
new file mode 100644
index 0000000..d8c2fe8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/AttributeProp.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model.prop;
+
+import com.sun.codemodel.JType;
+
+import javax.xml.namespace.QName;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public final class AttributeProp extends XmlItemProp {
+    public AttributeProp(QName name, JType valueType) {
+        super(name, valueType);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/ElementProp.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/ElementProp.java
new file mode 100644
index 0000000..f20bd34
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/ElementProp.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model.prop;
+
+import com.sun.codemodel.JType;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Property generated from elements.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ElementProp extends XmlItemProp {
+    public ElementProp(QName name, JType valueType) {
+        super(name, valueType);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/LeafElementProp.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/LeafElementProp.java
new file mode 100644
index 0000000..c3d2b88
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/LeafElementProp.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model.prop;
+
+import com.sun.codemodel.JType;
+
+import javax.xml.namespace.QName;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public final class LeafElementProp extends XmlItemProp {
+    public LeafElementProp(QName name, JType valueType) {
+        super(name, valueType);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/Prop.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/Prop.java
new file mode 100644
index 0000000..876ac6f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/Prop.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model.prop;
+
+/**
+ * Immutable object that captures the characterstic
+ * of the generated writer method.
+ *
+ * <p>
+ * Instances of this class implement {@link #equals(Object)}
+ * and {@link #hashCode()}. By using these we avoid generating
+ * the same method twice.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Prop {
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/ValueProp.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/ValueProp.java
new file mode 100644
index 0000000..57c17c5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/ValueProp.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model.prop;
+
+import com.sun.codemodel.JType;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class ValueProp extends Prop {
+    private final JType type;
+
+    public ValueProp(JType type) {
+        this.type = type;
+    }
+
+    public boolean equals(Object o) {
+        if (!(o instanceof ValueProp)) return false;
+
+        final ValueProp that = (ValueProp) o;
+
+        return type.equals(that.type);
+    }
+
+    public int hashCode() {
+        return type.hashCode();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/XmlItemProp.java b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/XmlItemProp.java
new file mode 100644
index 0000000..aad2a5e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/txw2/model/prop/XmlItemProp.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.txw2.model.prop;
+
+import com.sun.codemodel.JType;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Common implementation between elements and attributes.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class XmlItemProp extends Prop {
+    private final QName name;
+    private final JType type;
+
+    public XmlItemProp(QName name, JType valueType) {
+        this.name = name;
+        this.type = valueType;
+    }
+
+    public final boolean equals(Object o) {
+        if (this.getClass()!=o.getClass()) return false;
+
+        XmlItemProp that = (XmlItemProp)o;
+
+        return this.name.equals(that.name)
+            && this.type.equals(that.type);
+    }
+
+    public final int hashCode() {
+        return name.hashCode()*29 + type.hashCode();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/Invoker.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/Invoker.java
new file mode 100644
index 0000000..d2edca8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/Invoker.java
@@ -0,0 +1,78 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws;
+
+import com.sun.tools.internal.xjc.api.util.APTClassLoader;
+import com.sun.tools.internal.xjc.api.util.ToolsJarNotFoundException;
+
+import java.io.OutputStream;
+import java.lang.reflect.Constructor;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+
+/**
+ * Invokes JAX-WS tools in a special class loader that can pick up APT classes,
+ * even if it's not available in the tool launcher classpath.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class Invoker {
+    /**
+     * List of packages that need to be loaded in {@link APTClassLoader}.
+     */
+    private static final String[] prefixes = {
+        "com.sun.tools.internal.jxc.",
+        "com.sun.tools.internal.xjc.",
+        "com.sun.tools.apt.",
+        "com.sun.tools.internal.ws.",
+        "com.sun.tools.javac.",
+        "com.sun.tools.javadoc.",
+        "com.sun.mirror."
+    };
+
+    static void main(String toolName, String[] args) throws Throwable {
+        ClassLoader oldcc = Thread.currentThread().getContextClassLoader();
+        try {
+            APTClassLoader cl = new APTClassLoader(Invoker.class.getClassLoader(),prefixes);
+            Thread.currentThread().setContextClassLoader(cl);
+
+            Class compileTool = cl.loadClass("com.sun.tools.internal.ws.wscompile.CompileTool");
+            Constructor ctor = compileTool.getConstructor(OutputStream.class,String.class);
+            Object tool = ctor.newInstance(System.out,toolName);
+            Method runMethod = compileTool.getMethod("run",String[].class);
+            boolean r = (Boolean)runMethod.invoke(tool,new Object[]{args});
+            System.exit(r ? 0 : 1);
+        } catch (ToolsJarNotFoundException e) {
+            System.err.println(e.getMessage());
+        } catch (InvocationTargetException e) {
+            throw e.getCause();
+        } finally {
+            Thread.currentThread().setContextClassLoader(oldcc);
+        }
+
+        System.exit(1);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/ToolVersion.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/ToolVersion.java
new file mode 100644
index 0000000..fa3c513
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/ToolVersion.java
@@ -0,0 +1,38 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws;
+
+import com.sun.xml.internal.ws.util.Version;
+
+/**
+ * Obtains the version number of the JAX-WS tools.
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class ToolVersion {
+    private ToolVersion() {}    // no instanciation please
+
+    public static final Version VERSION = Version.create(ToolVersion.class.getResourceAsStream("version.properties"));
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/WsGen.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/WsGen.java
new file mode 100644
index 0000000..7f6fc1e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/WsGen.java
@@ -0,0 +1,35 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws;
+
+/**
+ * @author Vivek Pandey
+ */
+
+public class WsGen {
+    public static void main(String[] args) throws Throwable {
+        Invoker.main("wsgen",args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/WsImport.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/WsImport.java
new file mode 100644
index 0000000..98be298
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/WsImport.java
@@ -0,0 +1,35 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws;
+
+/**
+ * @author Vivek Pandey
+ */
+
+public class WsImport {
+    public static void main(String[] args) throws Throwable {
+        Invoker.main("wsimport",args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/package-info.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/package-info.java
new file mode 100644
index 0000000..1889080
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/package-info.java
@@ -0,0 +1,138 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * <h1>JAX-WS 2.0 Tools</h1>
+ * This document describes the tools included with JAX-WS 2.0.
+ *
+ * {@DotDiagram
+     digraph G {
+       // external tools
+       APT;
+
+       // ANT tasks
+       node [style=filled,color=lightyellow];
+       "WsGen ANT Task"; "WsImport ANT Task"; "Apt ANT Task";
+
+      // commandline
+       node [style=filled,color=lightpink];
+       wsgen; wsimport;
+
+       // libraries
+      node [style=filled,color=lightblue];
+      CompileTool; "WSAP"; WebServiceAP; Processor; Modeler; ProcessorActions;
+
+       // aps
+#       node [style=filled,color=lightpink];
+#       "JAX-WS"; tools; runtime; SPI; "Annotation Processor";
+
+       "Apt ANT Task" -> APT;
+       "WsGen ANT Task" -> wsgen -> CompileTool;
+       "WsImport ANT Task" -> wsimport -> CompileTool;
+
+       CompileTool -> APT -> WSAP -> WebServiceAP;
+       CompileTool -> Processor;
+       CompileTool -> Modeler;
+       CompileTool -> ProcessorActions;
+       CompileTool -> WebServiceAP;
+
+       Modeler -> WSDLModeler;
+     }
+ * }
+ * <div align=right>
+ * <b>Legend:</b> blue: implementation classes, pink: command-line toosl, white: external tool, yellow: ANT tasks
+ * </div>
+ *
+ * <h2>ANT Tasks</h2>
+   <d1>
+ *  <dt>{@link com.sun.tools.internal.ws.ant.Apt Apt}
+ *  <dd>An ANT task to invoke <a href="http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/apt.html">APT</a>.
+
+ *  <dt>{@link com.sun.tools.internal.ws.ant.WsGen WsGen}
+ *  <dd>
+ *    An ANT task to invoke {@link com.sun.tools.internal.ws.WsGen WsGen}
+
+ *  <dt>{@link com.sun.tools.internal.ws.ant.WsImport WsImport}
+ *  <dd>
+ *    An ANT task to invoke {@link com.sun.tools.internal.ws.WsImport WsImport}
+ *
+ *  </d1>
+ * <h2>Command-line Tools</h2>
+   <d1>
+ *  <dt><a href="http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/apt.html">APT</a>
+     <dd>A Java SE tool and framework for processing annotations. APT will invoke a JAX-WS AnnotationProcossor for
+ *   processing Java source  files with javax.jws.* annotations and making them web services.
+ *   APT will compile the Java source files and generate any additional classes needed to make an javax.jws.WebService
+ *   annotated class a Web service.
+ *
+ *  <dt>{@link com.sun.tools.internal.ws.WsGen WsGen}
+ *  <dd>Tool to process a compiled javax.jws.WebService annotated class and to generate the necessary classes to make
+ *  it a Web service.
+
+ *  <dt>{@link com.sun.tools.internal.ws.ant.WsImport WsImport}
+ *  <dd>
+ *    Tool to import a WSDL and to generate an SEI (a javax.jws.WebService) interface that can be either implemented
+ *    on the server to build a web service, or can be used on the client to invoke the web service.
+ *  </d1>
+ * <h2>Implementation Classes</h2>
+ *  <d1>
+      <dt>{@link com.sun.tools.internal.ws.wscompile.CompileTool CompileTool}
+ *    <dd> This is the main implementation class for both WsGen and WsImport.
+ *
+ *
+ * <dt>{@link com.sun.tools.internal.ws.processor.Processor Processor}
+ *    <dd>This abstract class is used to process a particular {@link com.sun.tools.internal.ws.processor.config.Configuration
+ *    Configuration} to build a {@link com.sun.tools.internal.ws.processor.model Model} and to run
+ *   {@link com.sun.tools.internal.ws.processor.ProcessorAction ProcessorActions} on that model.
+
+ *    <dt>{@link com.sun.tools.internal.ws.processor.model.Model Model}
+ *    <dd>The model is used to represent the entire Web Service.  The JAX-WS ProcessorActions can process
+ *    this Model to generate Java artifacts such as the service interface.
+ *
+      <dt>{@link com.sun.tools.internal.ws.processor.ProcessorAction ProcessorActions}
+ *    <dd>A ProcessorAction is used to perform some operation on a Model object such as
+ *    generating a Java source file.
+ *
+ *    <dt>{@link com.sun.tools.internal.ws.processor.modeler.Modeler Modeler}
+ *    <dd>A Modeler is used to create a Model of a Web Service from a particular Web
+ *    Web Service description such as a WSDL
+ *    file.
+ *
+ *    <dt>{@link com.sun.tools.internal.ws.processor.modeler.wsdl.WSDLModeler WSDLModeler}
+ *    <dd>The WSDLModeler processes a WSDL to create a Model.
+ *
+ *    <dt>{@link com.sun.tools.internal.ws.processor.modeler.annotation.WebServiceAP WebServiceAP}
+ *    <dd>WebServiceAP is a APT AnnotationProcessor for processing javax.jws.* and
+ *    javax.xml.ws.* annotations. This class is used either by the WsGen (CompileTool) tool or
+ *    idirectly via the {@link com.sun.istack.internal.ws.WSAP WSAP} when invoked by APT.
+ *
+ *    <dt>{@link com.sun.istack.internal.ws.WSAP WSAP}
+ *    <dd>This is the entry point for the WebServiceAP when APT is invoked on a SEI
+ *    annotated with the javax.jws.WebService annotation.
+ *   </d1>
+ *
+ * @ArchitectureDocument
+ **/
+package com.sun.tools.internal.ws;
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/Processor.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/Processor.java
new file mode 100644
index 0000000..8b899c5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/Processor.java
@@ -0,0 +1,118 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor;
+
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.config.ModelInfo;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Properties;
+
+/**
+ * This abstract class contains methods for getting a Modeler and creating a model
+ * from that Modeler given a particular configuration. ProcessorActions can also
+ * be registered and run with instances of this class.
+ *
+ * @author WS Development Team
+ *
+ */
+public class Processor {
+
+    public Processor(Configuration configuration, Properties options, Model model) {
+        this(configuration,options);
+        _model = model;
+    }
+
+    public Processor(Configuration configuration, Properties options) {
+        _configuration = configuration;
+        _options = options;
+
+        // find the value of the "print stack traces" property
+        _printStackTrace = Boolean.valueOf(_options.getProperty(ProcessorOptions.PRINT_STACK_TRACE_PROPERTY));
+        _env = _configuration.getEnvironment();
+    }
+
+    public void add(ProcessorAction action) {
+        _actions.add(action);
+    }
+
+    public Model getModel() {
+        return _model;
+    }
+
+    public void run() {
+        runModeler();
+        if (_model != null) {
+            runActions();
+        }
+    }
+
+    public void runModeler() {
+        try {
+            ModelInfo modelInfo = _configuration.getModelInfo();
+            if (modelInfo == null) {
+                throw new ProcessorException("processor.missing.model");
+            }
+
+            _model = modelInfo.buildModel(_options);
+
+        } catch (JAXWSExceptionBase e) {
+            if (_printStackTrace) {
+                _env.printStackTrace(e);
+            }
+            _env.error(e);
+        }
+    }
+
+    public void runActions() {
+        try {
+            if (_model == null) {
+                // avoid reporting yet another error here
+                return;
+            }
+
+            for (ProcessorAction action : _actions) {
+                action.perform(_model, _configuration, _options);
+            }
+        } catch (JAXWSExceptionBase e) {
+            if (_printStackTrace || _env.verbose()) {
+                _env.printStackTrace(e);
+            }
+            _env.error(e);
+        }
+    }
+
+    private final Properties _options;
+    private final Configuration _configuration;
+    private final List<ProcessorAction> _actions = new ArrayList<ProcessorAction>();
+    private Model _model;
+    private final boolean _printStackTrace;
+    private final ProcessorEnvironment _env;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorAction.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorAction.java
new file mode 100644
index 0000000..626d73d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorAction.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor;
+
+import java.util.Properties;
+
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+
+/**
+ * A ProcessorAction is used to perform some operation on a
+ * {@link com.sun.tools.internal.ws.processor.model.Model Model} such as
+ * generating a Java source file.
+ *
+ * @author WS Development Team
+ */
+public interface ProcessorAction {
+    public void perform(Model model, Configuration config, Properties options);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorActionVersion.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorActionVersion.java
new file mode 100644
index 0000000..54eb4cb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorActionVersion.java
@@ -0,0 +1,44 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor;
+
+/**
+ * @author WS Development Team
+ *
+ * Typesafe enum class to hold the ProcessorActionVersion
+ */
+public enum ProcessorActionVersion {
+    PRE_20("1.1.2"), VERSION_20("2.0");
+
+    ProcessorActionVersion(String version) {
+        this.version = version;
+    }
+
+    public String value() {
+        return version;
+    }
+
+    private final String version;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorConstants.java
new file mode 100644
index 0000000..b334511
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorConstants.java
@@ -0,0 +1,36 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor;
+
+/**
+ * Constants used by Model, Modelers, Config ProcessorActions
+ *
+ * @author WS Development Team
+ */
+public class ProcessorConstants {
+    public final static String SOAP_VERSION_1_1 = "SOAP 1.1";
+    public final static String SOAP_VERSION_1_2 = "SOAP 1.2";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorException.java
new file mode 100644
index 0000000..6f13aff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorException.java
@@ -0,0 +1,52 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * ProcessorException represents an exception that occurred while processing
+ * a web service.
+ *
+ * @see JAXWSExceptionBase
+ *
+ * @author WS Development Team
+ */
+public class ProcessorException extends JAXWSExceptionBase {
+
+    public ProcessorException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ProcessorException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.processor";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorNotificationListener.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorNotificationListener.java
new file mode 100644
index 0000000..9259e1f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorNotificationListener.java
@@ -0,0 +1,40 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor;
+
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * A ProcessorNotificationListener is registered with a Processor and receives
+ * notifications of errors, warnings and informational messages.
+ *
+ * @author WS Development Team
+ */
+public interface ProcessorNotificationListener {
+    public void onError(Localizable msg);
+    public void onWarning(Localizable msg);
+    public void onInfo(Localizable msg);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorOptions.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorOptions.java
new file mode 100644
index 0000000..de198cd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/ProcessorOptions.java
@@ -0,0 +1,57 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor;
+
+/**
+ * Property names used by ProcessorActions
+ *
+ * @author WS Development Team
+ */
+public class ProcessorOptions {
+
+    public final static String SOURCE_DIRECTORY_PROPERTY = "sourceDirectory";
+    public final static String DESTINATION_DIRECTORY_PROPERTY =
+        "destinationDirectory";
+    public final static String NONCLASS_DESTINATION_DIRECTORY_PROPERTY =
+        "nonclassDestinationDirectory";
+    public final static String VALIDATE_WSDL_PROPERTY = "validationWSDL";
+    public final static String EXPLICIT_SERVICE_CONTEXT_PROPERTY =
+        "explicitServiceContext";
+    public final static String PRINT_STACK_TRACE_PROPERTY = "printStackTrace";
+    public final static String DONOT_OVERWRITE_CLASSES = "doNotOverWrite";
+    public final static String NO_DATA_BINDING_PROPERTY = "noDataBinding";
+    public final static String USE_WSI_BASIC_PROFILE = "useWSIBasicProfile";
+    public final static String STRICT_COMPLIANCE = "strictCompliance";
+    public final static String JAXWS_SOURCE_VERSION = "sourceVersion";
+    public final static String UNWRAP_DOC_LITERAL_WRAPPERS =
+        "unwrapDocLitWrappers";
+    public final static String BINDING_FILES = "bindingFiles";
+    public final static String EXTENSION = "extension";
+    public final static String PROTOCOL = "protocol";
+    public final static String TRANSPORT = "transport";
+    public final static String WSDL_LOCATION = "wsdllocation";
+    public final static String DEFAULT_PACKAGE = "defaultpackage";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ClassModelInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ClassModelInfo.java
new file mode 100644
index 0000000..eda6fa2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ClassModelInfo.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Properties;
+
+import com.sun.tools.internal.ws.processor.modeler.Modeler;
+import com.sun.tools.internal.ws.processor.ProcessorOptions;
+import com.sun.xml.internal.ws.util.VersionUtil;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class ClassModelInfo extends ModelInfo {
+
+    public ClassModelInfo(String className) {
+        this.className = className;
+    }
+
+
+    public Modeler getModeler(Properties properties) {
+        return null;
+    }
+
+    public void setClassName(String className) {
+        this.className = className;
+    }
+
+    public String getClassName() {
+        return className;
+    }
+
+    private String className;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/Configuration.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/Configuration.java
new file mode 100644
index 0000000..f82c6a9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/Configuration.java
@@ -0,0 +1,55 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config;
+
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Configuration {
+
+    public Configuration(ProcessorEnvironment env) {
+        _env = (ProcessorEnvironment)env;
+    }
+
+    public ModelInfo getModelInfo() {
+        return _modelInfo;
+    }
+
+    public void setModelInfo(ModelInfo i) {
+        _modelInfo = (ModelInfo)i;
+        _modelInfo.setParent(this);
+    }
+
+    public ProcessorEnvironment getEnvironment() {
+        return _env;
+    }
+
+    private ProcessorEnvironment _env;
+    private ModelInfo _modelInfo;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ConfigurationException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ConfigurationException.java
new file mode 100644
index 0000000..8677de2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ConfigurationException.java
@@ -0,0 +1,49 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config;
+
+import com.sun.tools.internal.ws.processor.ProcessorException;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class ConfigurationException extends ProcessorException {
+
+    public ConfigurationException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ConfigurationException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.configuration";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/HandlerChainInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/HandlerChainInfo.java
new file mode 100644
index 0000000..9ac381e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/HandlerChainInfo.java
@@ -0,0 +1,82 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class HandlerChainInfo {
+
+    public HandlerChainInfo() {
+        handlers = new ArrayList();
+        roles = new HashSet();
+    }
+
+    public void add(HandlerInfo i) {
+        handlers.add(i);
+    }
+
+    public Iterator getHandlers() {
+        return handlers.iterator();
+    }
+
+    public int getHandlersCount() {
+        return handlers.size();
+    }
+
+    /* serialization */
+    public List getHandlersList() {
+        return handlers;
+    }
+
+    /* serialization */
+    public void setHandlersList(List l) {
+        handlers = l;
+    }
+
+    public void addRole(String s) {
+        roles.add(s);
+    }
+
+    public Set getRoles() {
+        return roles;
+    }
+
+    /* serialization */
+    public void setRoles(Set s) {
+        roles = s;
+    }
+
+    private List handlers;
+    private Set roles;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/HandlerInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/HandlerInfo.java
new file mode 100644
index 0000000..332480b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/HandlerInfo.java
@@ -0,0 +1,78 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config;
+
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+import javax.xml.namespace.QName;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class HandlerInfo {
+
+    public HandlerInfo() {
+        properties = new HashMap();
+        headerNames = new HashSet();
+    }
+
+    public String getHandlerClassName() {
+        return handlerClassName;
+    }
+
+    public void setHandlerClassName(String s) {
+        handlerClassName = s;
+    }
+
+    public Map getProperties() {
+        return properties;
+    }
+
+    /* serialization */
+    public void setProperties(Map m) {
+        properties = m;
+    }
+
+    public void addHeaderName(QName name) {
+        headerNames.add(name);
+    }
+
+    public Set getHeaderNames() {
+        return headerNames;
+    }
+
+    /* serialization */
+    public void setHeaderNames(Set s) {
+        headerNames = s;
+    }
+
+    private String handlerClassName;
+    private Map properties;
+    private Set headerNames;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ModelInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ModelInfo.java
new file mode 100644
index 0000000..ca07bc5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/ModelInfo.java
@@ -0,0 +1,118 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config;
+
+import java.util.Properties;
+
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.modeler.Modeler;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import org.xml.sax.EntityResolver;
+
+/**
+ * This class contiains information used by {@link com.sun.tools.internal.ws.processor.modeler.Modeler
+ * Modelers} to build {@link com.sun.tools.internal.ws.processor.model.Model Models}.
+ *
+ * @author WS Development Team
+ */
+public abstract class ModelInfo {
+
+    protected ModelInfo() {}
+
+    public Configuration getParent() {
+        return _parent;
+    }
+
+    public void setParent(Configuration c) {
+        _parent = c;
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String s) {
+        _name = s;
+    }
+
+    public Configuration getConfiguration() {
+        return _parent;
+    }
+
+    public HandlerChainInfo getClientHandlerChainInfo() {
+        return _clientHandlerChainInfo;
+    }
+
+    public void setClientHandlerChainInfo(HandlerChainInfo i) {
+        _clientHandlerChainInfo = i;
+    }
+
+    public HandlerChainInfo getServerHandlerChainInfo() {
+        return _serverHandlerChainInfo;
+    }
+
+    public void setServerHandlerChainInfo(HandlerChainInfo i) {
+        _serverHandlerChainInfo = i;
+    }
+
+    public String getJavaPackageName() {
+        return _javaPackageName;
+    }
+
+    public void setJavaPackageName(String s) {
+        _javaPackageName = s;
+    }
+
+    public Model buildModel(Properties options){
+        return getModeler(options).buildModel();
+    }
+
+    public EntityResolver getEntityResolver() {
+        return entityResolver;
+    }
+
+    public void setEntityResolver(EntityResolver entityResolver) {
+        this.entityResolver = entityResolver;
+    }
+
+    public String getDefaultJavaPackage() {
+        return _defaultJavaPackage;
+    }
+
+    public void setDefaultJavaPackage(String _defaultJavaPackage) {
+        this._defaultJavaPackage = _defaultJavaPackage;
+    }
+
+    protected abstract Modeler getModeler(Properties options);
+
+    private Configuration _parent;
+    private String _name;
+    private String _javaPackageName;
+    private String _defaultJavaPackage;
+    private HandlerChainInfo _clientHandlerChainInfo;
+    private HandlerChainInfo _serverHandlerChainInfo;
+    private EntityResolver entityResolver;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/WSDLModelInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/WSDLModelInfo.java
new file mode 100644
index 0000000..12eab00
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/WSDLModelInfo.java
@@ -0,0 +1,92 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config;
+
+
+import java.util.*;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.Document;
+import org.xml.sax.InputSource;
+
+import com.sun.tools.internal.ws.processor.modeler.Modeler;
+import com.sun.tools.internal.ws.util.JAXWSClassFactory;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class WSDLModelInfo extends ModelInfo {
+
+    public WSDLModelInfo() {}
+
+    protected Modeler getModeler(Properties options) {
+        return JAXWSClassFactory.newInstance().createWSDLModeler(this, options);
+    }
+
+    public String getLocation() {
+        return _location;
+    }
+
+    public void setLocation(String s) {
+        _location = s;
+    }
+
+    public Map<String, Document> getJAXWSBindings(){
+        return _jaxwsBindings;
+    }
+
+    public void putJAXWSBindings(String systemId, Document binding){
+        _jaxwsBindings.put(systemId, binding);
+    }
+
+    public Set<InputSource> getJAXBBindings(){
+        return _jaxbBindings;
+    }
+
+    public void addJAXBBIndings(InputSource jaxbBinding){
+        _jaxbBindings.add(jaxbBinding);
+    }
+
+    public void setHandlerConfig(Element handlerConfig){
+        this.handlerConfig = handlerConfig;
+    }
+
+    public Element getHandlerConfig(){
+        return handlerConfig;
+    }
+
+    private Element handlerConfig;
+
+    private String _location;
+
+    //external jaxws:bindings elements
+    private Map<String, Document> _jaxwsBindings = new HashMap<String, Document>();
+
+    //we need an array of jaxb:binding elements, they are children of jaxws:bindings
+    //and could come from an external customization file or wsdl.
+    private Set<InputSource> _jaxbBindings = new HashSet<InputSource>();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/ClassModelParser.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/ClassModelParser.java
new file mode 100644
index 0000000..d34ada7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/ClassModelParser.java
@@ -0,0 +1,58 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config.parser;
+
+
+import java.io.File;
+import java.util.List;
+import java.util.Properties;
+
+import com.sun.tools.internal.ws.processor.config.ClassModelInfo;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class ClassModelParser extends InputParser {
+
+    public ClassModelParser(ProcessorEnvironment env, Properties options) {
+        super(env, options);
+    }
+
+    public Configuration parse(List<String> inputClasses) {
+        return parse(new File(inputClasses.get(0)));
+    }
+
+    public Configuration parse(File file) {
+        Configuration config = new Configuration(getEnv());
+
+        config.setModelInfo(new ClassModelInfo(file.getName()));
+        return config;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/CustomizationParser.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/CustomizationParser.java
new file mode 100644
index 0000000..72670bf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/CustomizationParser.java
@@ -0,0 +1,144 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.config.parser;
+
+import java.net.URL;
+import java.util.*;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.NodeList;
+import org.w3c.dom.Document;
+import org.xml.sax.InputSource;
+import org.xml.sax.EntityResolver;
+
+import com.sun.tools.internal.ws.processor.ProcessorOptions;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderFactory;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.JAXWSBindingsConstants;
+
+import javax.xml.stream.XMLStreamReader;
+
+/**
+ * @author Vivek Pandey
+ *
+ */
+public class CustomizationParser extends InputParser {
+
+    /**
+     * @param entityResolver
+     * @param env
+     * @param options
+     */
+    public CustomizationParser(EntityResolver entityResolver, ProcessorEnvironment env, Properties options) {
+        super(env, options);
+        this.entityResolver = entityResolver;
+    }
+
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.processor.config.parser.InputParser#parse(java.io.File[], java.lang.String)
+     */
+    protected Configuration parse(List<String> inputFiles) throws Exception{
+        //File wsdlFile = inputFiles[0];
+        Configuration configuration = new Configuration(getEnv());
+        wsdlModelInfo = new WSDLModelInfo();
+        wsdlModelInfo.setLocation(inputFiles.get(0));
+        if(_options.get(ProcessorOptions.WSDL_LOCATION) == null)
+            _options.setProperty(ProcessorOptions.WSDL_LOCATION, inputFiles.get(0));
+
+        //modelInfoParser = (JAXWSBindingInfoParser)getModelInfoParsers().get(JAXWSBindingsConstants.JAXWS_BINDINGS);
+        modelInfoParser = new JAXWSBindingInfoParser(getEnv());
+
+        //get the jaxws bindingd file and add it to the modelInfo
+        Set<String> bindingFiles = (Set<String>)_options.get(ProcessorOptions.BINDING_FILES);
+        for(String bindingFile : bindingFiles){
+            addBinding(bindingFile);
+        }
+
+
+        for(InputSource jaxwsBinding : jaxwsBindings){
+            Document doc = modelInfoParser.parse(jaxwsBinding);
+            if(doc != null){
+                wsdlModelInfo.putJAXWSBindings(jaxwsBinding.getSystemId(), doc);
+            }
+        }
+
+        //copy jaxb binding sources in modelInfo
+        for(InputSource jaxbBinding : jaxbBindings){
+            wsdlModelInfo.addJAXBBIndings(jaxbBinding);
+        }
+
+        addHandlerChainInfo();
+        configuration.setModelInfo(wsdlModelInfo);
+        return configuration;
+    }
+
+    private void addBinding(String bindingLocation) throws Exception{
+        JAXWSUtils.checkAbsoluteness(bindingLocation);
+        InputSource is = null;
+        if(entityResolver != null){
+            is = entityResolver.resolveEntity(null, bindingLocation);
+        }
+        if(is == null)
+            is = new InputSource(bindingLocation);
+
+        XMLStreamReader reader =
+                XMLStreamReaderFactory.createFreshXMLStreamReader(is, true);
+        XMLStreamReaderUtil.nextElementContent(reader);
+        if(reader.getName().equals(JAXWSBindingsConstants.JAXWS_BINDINGS)){
+            jaxwsBindings.add(is);
+        }else if(reader.getName().equals(JAXWSBindingsConstants.JAXB_BINDINGS)){
+            jaxbBindings.add(is);
+        }else{
+            warn("configuration.notBindingFile");
+        }
+    }
+
+    private void addHandlerChainInfo() throws Exception{
+        //setup handler chain info
+        for(Map.Entry<String, Document> entry:wsdlModelInfo.getJAXWSBindings().entrySet()){
+            Element e = entry.getValue().getDocumentElement();
+            NodeList nl = e.getElementsByTagNameNS(
+                "http://java.sun.com/xml/ns/javaee", "handler-chains");
+            if(nl.getLength()== 0)
+                continue;
+            //take the first one, anyway its 1 handler-config per customization
+            Element hc = (Element)nl.item(0);
+            wsdlModelInfo.setHandlerConfig(hc);
+            return;
+        }
+    }
+
+    private WSDLModelInfo wsdlModelInfo;
+    private JAXWSBindingInfoParser modelInfoParser;
+    private Set<InputSource> jaxwsBindings = new HashSet<InputSource>();
+    private Set<InputSource> jaxbBindings = new HashSet<InputSource>();
+    private EntityResolver entityResolver;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/InputParser.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/InputParser.java
new file mode 100644
index 0000000..a2e2b08
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/InputParser.java
@@ -0,0 +1,122 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.config.parser;
+
+import java.io.InputStream;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Properties;
+
+import javax.xml.namespace.QName;
+
+import org.xml.sax.InputSource;
+
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+
+/**
+ * @author Vivek Pandey
+ *
+ *
+ */
+public abstract class InputParser{
+    protected LocalizableMessageFactory _messageFactory =
+        new LocalizableMessageFactory(
+            "com.sun.tools.internal.ws.resources.configuration");
+
+    public InputParser(ProcessorEnvironment env, Properties options) {
+        this._env = env;
+        this._options = options;
+        _modelInfoParsers = new HashMap<QName, Object>();
+
+//        /*
+//         * Load modelinfo parsers from the plugins which want to extend
+//         * this functionality
+//         */
+//        Iterator i = ToolPluginFactory.getInstance().getExtensions(
+//            ToolPluginConstants.WSCOMPILE_PLUGIN,
+//            ToolPluginConstants.WSCOMPILE_MODEL_INFO_EXT_POINT);
+//        while(i != null && i.hasNext()) {
+//            ModelInfoPlugin plugin = (ModelInfoPlugin)i.next();
+//            _modelInfoParsers.put(plugin.getModelInfoName(),
+//                plugin.createModelInfoParser(env));
+//        }
+    }
+
+    protected Configuration parse(InputStream is) throws Exception{
+        //TODO: Not implemented exception
+        return null;
+    }
+
+    protected Configuration parse(InputSource is) throws Exception{
+        //TODO: Not implemented exception
+        return null;
+    }
+
+    protected Configuration parse(List<String> inputSources) throws Exception{
+        //TODO: Not implemented exception
+        return null;
+    }
+
+    /**
+     * @return Returns the _env.
+     */
+    public  ProcessorEnvironment getEnv(){
+        return _env;
+    }
+
+    /**
+     * @param env The ProcessorEnvironment to set.
+     */
+    public void setEnv(ProcessorEnvironment env){
+        this._env = env;
+    }
+
+    protected void warn(String key) {
+        _env.warn(_messageFactory.getMessage(key));
+    }
+
+    protected void warn(String key, String arg) {
+        _env.warn(_messageFactory.getMessage(key, arg));
+    }
+
+    protected void warn(String key, Object[] args) {
+        _env.warn(_messageFactory.getMessage(key, args));
+    }
+
+    protected void info(String key) {
+        _env.info(_messageFactory.getMessage(key));
+    }
+
+    protected void info(String key, String arg) {
+        _env.info(_messageFactory.getMessage(key, arg));
+    }
+
+    protected ProcessorEnvironment _env;
+    protected Properties _options;
+    protected Map<QName, Object> _modelInfoParsers;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/JAXWSBindingInfoParser.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/JAXWSBindingInfoParser.java
new file mode 100644
index 0000000..e4e560f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/JAXWSBindingInfoParser.java
@@ -0,0 +1,100 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.config.parser;
+
+import java.io.IOException;
+import java.util.HashSet;
+import java.util.Set;
+
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.FactoryConfigurationError;
+import javax.xml.parsers.ParserConfigurationException;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.util.xml.NullEntityResolver;
+import com.sun.tools.internal.ws.wsdl.framework.ParseException;
+
+/**
+ * @author Vivek Pandey
+ *
+ * External jaxws:bindings parser
+ */
+public class JAXWSBindingInfoParser {
+
+    private ProcessorEnvironment env;
+
+    /**
+     * @param env
+     */
+    public JAXWSBindingInfoParser(ProcessorEnvironment env) {
+        this.env = env;
+    }
+
+    public Document parse(InputSource source) {
+        try {
+            DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
+            builderFactory.setNamespaceAware(true);
+            builderFactory.setValidating(false);
+            DocumentBuilder builder = builderFactory.newDocumentBuilder();
+            builder.setErrorHandler(new ErrorHandler() {
+                public void error(SAXParseException e)
+                    throws SAXParseException {
+                    throw e;
+                }
+
+                public void fatalError(SAXParseException e)
+                    throws SAXParseException {
+                    throw e;
+                }
+
+                public void warning(SAXParseException err)
+                    throws SAXParseException {
+                    // do nothing
+                }
+            });
+
+            builder.setEntityResolver(new NullEntityResolver());
+            return builder.parse(source);
+        } catch (ParserConfigurationException e) {
+            throw new ParseException("parsing.parserConfigException",e);
+        } catch (FactoryConfigurationError e) {
+            throw new ParseException("parsing.factoryConfigException",e);
+        }catch(SAXException e){
+            throw new ParseException("parsing.saxException",e);
+        }catch(IOException e){
+            throw new ParseException("parsing.saxException",e);
+        }
+    }
+
+    public final Set<Element> outerBindings = new HashSet<Element>();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/ParserUtil.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/ParserUtil.java
new file mode 100644
index 0000000..84b18c8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/ParserUtil.java
@@ -0,0 +1,50 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.config.parser;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamReader;
+
+import com.sun.tools.internal.ws.processor.config.ConfigurationException;
+import com.sun.xml.internal.ws.streaming.Attributes;
+import com.sun.xml.internal.ws.streaming.XMLReader;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class ParserUtil {
+    public static void failWithFullName(String key, String file, XMLReader reader) {
+        throw new ConfigurationException(key, new Object[] { file, Integer.toString(
+            reader.getLineNumber()), reader.getName().toString() });
+    }
+
+    public static void failWithFullName(String key, String file, XMLStreamReader reader) {
+        throw new ConfigurationException(key, new Object[] { file, Integer.toString(
+            reader.getLocation().getLineNumber()), reader.getName().toString() });
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/Reader.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/Reader.java
new file mode 100644
index 0000000..cd9a100
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/config/parser/Reader.java
@@ -0,0 +1,110 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.config.parser;
+
+
+import java.net.URL;
+import java.util.List;
+import java.util.Properties;
+
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.tools.internal.ws.wsdl.document.WSDLConstants;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderFactory;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+
+import javax.xml.stream.XMLStreamReader;
+
+import org.xml.sax.EntityResolver;
+
+/**
+ * @author Vivek Pandey
+ *
+ * Main entry point from CompileTool
+ */
+public class Reader {
+
+    /**
+     *
+     */
+    public Reader(ProcessorEnvironment env, Properties options) {
+        this._env = env;
+        this._options = options;
+    }
+
+    public Configuration parse(EntityResolver entityResolver, List<String> inputSources)
+            throws Exception {
+        //reset the input type flags before parsing
+        isClassFile = false;
+
+        InputParser parser = null;
+        //now its just the first file. do we expect more than one input files?
+        validateInput(inputSources.get(0));
+
+        if(isClassFile){
+            parser = new ClassModelParser(_env, _options);
+        } else {
+            parser = new CustomizationParser(entityResolver, _env, _options);
+        }
+        return parser.parse(inputSources);
+    }
+
+    protected void validateInput(String file) throws Exception{
+        if(isClass(file)){
+            isClassFile = true;
+            return;
+        }
+
+//        JAXWSUtils.checkAbsoluteness(file);
+//        URL url = new URL(file);
+//
+//        XMLStreamReader reader =
+//                XMLStreamReaderFactory.createXMLStreamReader(url.openStream(), true);
+//
+//        XMLStreamReaderUtil.nextElementContent(reader);
+//        if(!reader.getName().equals(WSDLConstants.QNAME_DEFINITIONS)){
+//            //we are here, means invalid element
+//            ParserUtil.failWithFullName("configuration.invalidElement", file, reader);
+//        }
+    }
+
+    public boolean isClass(String className) {
+        try {
+            _env.getClassLoader().loadClass(className);
+        } catch (ClassNotFoundException e) {
+            return false;
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        return true;
+    }
+
+    private boolean isClassFile;
+
+    protected ProcessorEnvironment _env;
+
+    protected Properties _options;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/CustomExceptionGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/CustomExceptionGenerator.java
new file mode 100644
index 0000000..4726a47
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/CustomExceptionGenerator.java
@@ -0,0 +1,165 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import com.sun.codemodel.internal.*;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.model.Fault;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+
+import javax.xml.ws.WebFault;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Properties;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class CustomExceptionGenerator extends GeneratorBase {
+    private Map<String, JClass> faults = new HashMap<String, JClass>();
+
+    public CustomExceptionGenerator() {
+    }
+
+    public GeneratorBase getGenerator(
+        Model model,
+        Configuration config,
+        Properties properties) {
+        return new CustomExceptionGenerator(model, config, properties);
+    }
+
+    public GeneratorBase getGenerator(
+        Model model,
+        Configuration config,
+        Properties properties,
+        SOAPVersion ver) {
+        return new CustomExceptionGenerator(model, config, properties);
+    }
+
+    protected CustomExceptionGenerator(
+        Model model,
+        Configuration config,
+        Properties properties) {
+        super(model, config, properties);
+    }
+
+    protected void preVisitModel(Model model) throws Exception {
+    }
+
+    protected void postVisitModel(Model model) throws Exception {
+        faults = null;
+    }
+
+    protected void preVisitFault(Fault fault) throws Exception {
+        if (isRegistered(fault))
+            return;
+        registerFault(fault);
+    }
+
+    private boolean isRegistered(Fault fault) {
+        if(faults.keySet().contains(fault.getJavaException().getName())){
+            fault.setExceptionClass(faults.get(fault.getJavaException().getName()));
+            return true;
+        }
+        return false;
+    }
+
+    private void registerFault(Fault fault) {
+         try {
+            write(fault);
+            faults.put(fault.getJavaException().getName(), fault.getExceptionClass());
+        } catch (Exception e) {
+            throw new GeneratorException("generator.nestedGeneratorError",e);
+        }
+    }
+
+    private void write(Fault fault) throws Exception{
+        String className = env.getNames().customExceptionClassName(fault);
+
+        JDefinedClass cls = cm._class(className, ClassType.CLASS);
+        JDocComment comment = cls.javadoc();
+        if(fault.getJavaDoc() != null){
+            comment.add(fault.getJavaDoc());
+            comment.add("\n\n");
+        }
+
+        for (String doc : getJAXWSClassComment()) {
+            comment.add(doc);
+        }
+
+        cls._extends(java.lang.Exception.class);
+
+        //@WebFault
+        JAnnotationUse faultAnn = cls.annotate(WebFault.class);
+        faultAnn.param("name", fault.getBlock().getName().getLocalPart());
+        faultAnn.param("targetNamespace", fault.getBlock().getName().getNamespaceURI());
+
+        JType faultBean = fault.getBlock().getType().getJavaType().getType().getType();
+
+        //faultInfo filed
+        JFieldVar fi = cls.field(JMod.PRIVATE, faultBean, "faultInfo");
+
+        //add jaxb annotations
+        fault.getBlock().getType().getJavaType().getType().annotate(fi);
+
+        fi.javadoc().add("Java type that goes as soapenv:Fault detail element.");
+        JFieldRef fr = JExpr.ref(JExpr._this(), fi);
+
+        //Constructor
+        JMethod constrc1 = cls.constructor(JMod.PUBLIC);
+        JVar var1 = constrc1.param(String.class, "message");
+        JVar var2 = constrc1.param(faultBean, "faultInfo");
+        constrc1.javadoc().addParam(var1);
+        constrc1.javadoc().addParam(var2);
+        JBlock cb1 = constrc1.body();
+        cb1.invoke("super").arg(var1);
+
+        cb1.assign(fr, var2);
+
+        //constructor with Throwable
+        JMethod constrc2 = cls.constructor(JMod.PUBLIC);
+        var1 = constrc2.param(String.class, "message");
+        var2 = constrc2.param(faultBean, "faultInfo");
+        JVar var3 = constrc2.param(Throwable.class, "cause");
+        constrc2.javadoc().addParam(var1);
+        constrc2.javadoc().addParam(var2);
+        constrc2.javadoc().addParam(var3);
+        JBlock cb2 = constrc2.body();
+        cb2.invoke("super").arg(var1).arg(var3);
+        cb2.assign(fr, var2);
+
+
+        //getFaultInfo() method
+        JMethod fim = cls.method(JMod.PUBLIC, faultBean, "getFaultInfo");
+        fim.javadoc().addReturn().add("returns fault bean: "+faultBean.fullName());
+        JBlock fib = fim.body();
+        fib._return(fi);
+        fault.setExceptionClass(cls);
+
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorBase.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorBase.java
new file mode 100644
index 0000000..49382cf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorBase.java
@@ -0,0 +1,627 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.OutputStreamWriter;
+import java.io.FileOutputStream;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Properties;
+
+import com.sun.tools.internal.ws.processor.ProcessorAction;
+import com.sun.tools.internal.ws.processor.ProcessorOptions;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.model.AbstractType;
+import com.sun.tools.internal.ws.processor.model.Block;
+import com.sun.tools.internal.ws.processor.model.Fault;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.model.ModelVisitor;
+import com.sun.tools.internal.ws.processor.model.Operation;
+import com.sun.tools.internal.ws.processor.model.Parameter;
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.model.Request;
+import com.sun.tools.internal.ws.processor.model.Response;
+import com.sun.tools.internal.ws.processor.model.Service;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBType;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBTypeVisitor;
+import com.sun.tools.internal.ws.processor.model.jaxb.RpcLitStructure;
+import com.sun.tools.internal.ws.processor.util.IndentingWriter;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.processor.util.DirectoryUtil;
+import com.sun.tools.internal.ws.processor.util.GeneratedFileInfo;
+import com.sun.tools.internal.ws.ToolVersion;
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import com.sun.codemodel.internal.*;
+import org.w3c.dom.Element;
+import org.w3c.dom.NodeList;
+
+import javax.jws.HandlerChain;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.OutputKeys;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.transform.dom.DOMSource;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public abstract class GeneratorBase
+    implements
+        GeneratorConstants,
+        ProcessorAction,
+        ModelVisitor,
+        JAXBTypeVisitor {
+    protected File sourceDir;
+    protected File destDir;
+    protected File nonclassDestDir;
+    protected ProcessorEnvironment env;
+    protected Model model;
+    protected Service service;
+    protected SOAPVersion curSOAPVersion;
+    protected String targetVersion;
+    protected boolean donotOverride;
+    protected String servicePackage;
+    protected JCodeModel cm;
+    protected boolean printStackTrace;
+    protected String wsdlLocation;
+
+    private LocalizableMessageFactory messageFactory;
+
+    public GeneratorBase() {
+        sourceDir = null;
+        destDir = null;
+        nonclassDestDir = null;
+        env = null;
+        model = null;
+    }
+
+    public void perform(
+        Model model,
+        Configuration config,
+        Properties properties) {
+        GeneratorBase generator = getGenerator(model, config, properties);
+
+        generator.doGeneration();
+    }
+
+    public abstract GeneratorBase getGenerator(
+        Model model,
+        Configuration config,
+        Properties properties);
+    public abstract GeneratorBase getGenerator(
+        Model model,
+        Configuration config,
+        Properties properties,
+        SOAPVersion ver);
+
+    protected GeneratorBase(
+        Model model,
+        Configuration config,
+        Properties properties) {
+
+        this.model = model;
+
+        if(model.getJAXBModel().getS2JJAXBModel() != null)
+            cm = model.getJAXBModel().getS2JJAXBModel().generateCode(null, new JAXBTypeGenerator.JAXBErrorListener());
+        else
+            cm = new JCodeModel();
+
+        this.env = (ProcessorEnvironment) config.getEnvironment();
+        String key = ProcessorOptions.DESTINATION_DIRECTORY_PROPERTY;
+        String dirPath = properties.getProperty(key);
+        this.destDir = new File(dirPath);
+        key = ProcessorOptions.SOURCE_DIRECTORY_PROPERTY;
+        String sourcePath = properties.getProperty(key);
+        this.sourceDir = new File(sourcePath);
+        key = ProcessorOptions.NONCLASS_DESTINATION_DIRECTORY_PROPERTY;
+        String nonclassDestPath = properties.getProperty(key);
+        this.nonclassDestDir = new File(nonclassDestPath);
+        if (nonclassDestDir == null)
+            nonclassDestDir = destDir;
+        messageFactory =
+            new LocalizableMessageFactory("com.sun.tools.internal.ws.resources.generator");
+        this.targetVersion =
+            properties.getProperty(ProcessorOptions.JAXWS_SOURCE_VERSION);
+        key = ProcessorOptions.DONOT_OVERWRITE_CLASSES;
+        this.donotOverride =
+            Boolean.valueOf(properties.getProperty(key)).booleanValue();
+        this.printStackTrace = Boolean.valueOf(properties.getProperty(ProcessorOptions.PRINT_STACK_TRACE_PROPERTY));
+        this.wsdlLocation = properties.getProperty(ProcessorOptions.WSDL_LOCATION);
+    }
+
+    protected void doGeneration() {
+        try {
+            model.accept(this);
+        } catch (Exception e) {
+            if (env.verbose())
+                e.printStackTrace();
+            throw new GeneratorException("generator.nestedGeneratorError",e);
+        }
+    }
+
+    public void visit(Model model) throws Exception {
+        preVisitModel(model);
+        visitModel(model);
+        postVisitModel(model);
+    }
+
+    protected void preVisitModel(Model model) throws Exception {
+    }
+
+    protected void visitModel(Model model) throws Exception {
+        env.getNames().resetPrefixFactory();
+        for (Service service : model.getServices()) {
+            service.accept(this);
+        }
+    }
+
+    protected void postVisitModel(Model model) throws Exception {
+    }
+
+    public void visit(Service service) throws Exception {
+        preVisitService(service);
+        visitService(service);
+        postVisitService(service);
+    }
+
+    protected void preVisitService(Service service) throws Exception {
+        servicePackage = Names.getPackageName(service);
+    }
+
+    protected void visitService(Service service) throws Exception {
+        this.service = service;
+//        Iterator ports = service.getPorts();
+        for (Port port : service.getPorts()) {
+            port.accept(this);
+        }
+        this.service = null;
+    }
+
+    protected void postVisitService(Service service) throws Exception {
+        Iterator extraTypes = model.getExtraTypes();
+        while (extraTypes.hasNext()) {
+            AbstractType type = (AbstractType) extraTypes.next();
+        }
+        servicePackage = null;
+    }
+
+    public void visit(Port port) throws Exception {
+        preVisitPort(port);
+        visitPort(port);
+        postVisitPort(port);
+    }
+
+    protected void preVisitPort(Port port) throws Exception {
+        curSOAPVersion = port.getSOAPVersion();
+    }
+
+    protected void visitPort(Port port) throws Exception {
+        for (Operation operation : port.getOperations()) {
+            operation.accept(this);
+        }
+    }
+
+    protected void postVisitPort(Port port) throws Exception {
+        curSOAPVersion = null;
+    }
+
+    public void visit(Operation operation) throws Exception {
+        preVisitOperation(operation);
+        visitOperation(operation);
+        postVisitOperation(operation);
+    }
+
+    protected void preVisitOperation(Operation operation) throws Exception {
+    }
+
+    protected void visitOperation(Operation operation) throws Exception {
+        operation.getRequest().accept(this);
+        if (operation.getResponse() != null)
+            operation.getResponse().accept(this);
+        Iterator faults = operation.getFaultsSet().iterator();
+        if (faults != null) {
+            Fault fault;
+            while (faults.hasNext()) {
+                fault = (Fault) faults.next();
+                fault.accept(this);
+            }
+        }
+    }
+
+    protected void postVisitOperation(Operation operation) throws Exception {
+    }
+
+    public void visit(Parameter param) throws Exception {
+        preVisitParameter(param);
+        visitParameter(param);
+        postVisitParameter(param);
+    }
+
+    protected void preVisitParameter(Parameter param) throws Exception {
+    }
+
+    protected void visitParameter(Parameter param) throws Exception {
+    }
+
+    protected void postVisitParameter(Parameter param) throws Exception {
+    }
+
+    public void visit(Block block) throws Exception {
+        preVisitBlock(block);
+        visitBlock(block);
+        postVisitBlock(block);
+    }
+
+    protected void preVisitBlock(Block block) throws Exception {
+    }
+
+    protected void visitBlock(Block block) throws Exception {
+    }
+
+    protected void postVisitBlock(Block block) throws Exception {
+    }
+
+    public void visit(Response response) throws Exception {
+        preVisitResponse(response);
+        visitResponse(response);
+        postVisitResponse(response);
+    }
+
+    protected void preVisitResponse(Response response) throws Exception {
+    }
+
+    protected void visitResponse(Response response) throws Exception {
+        Iterator iter = response.getParameters();
+        AbstractType type;
+        Block block;
+        while (iter.hasNext()) {
+            ((Parameter) iter.next()).accept(this);
+        }
+        iter = response.getBodyBlocks();
+        while (iter.hasNext()) {
+            block = (Block) iter.next();
+            type = block.getType();
+            if(type instanceof JAXBType)
+                ((JAXBType) type).accept(this);
+            else if(type instanceof RpcLitStructure)
+                ((RpcLitStructure) type).accept(this);
+
+            responseBodyBlock(block);
+        }
+        iter = response.getHeaderBlocks();
+        while (iter.hasNext()) {
+            block = (Block) iter.next();
+            type = block.getType();
+            if(type instanceof JAXBType)
+                ((JAXBType) type).accept(this);
+            responseHeaderBlock(block);
+        }
+
+        //attachment
+        iter = response.getAttachmentBlocks();
+        while (iter.hasNext()) {
+            block = (Block) iter.next();
+            type = block.getType();
+            if(type instanceof JAXBType)
+                ((JAXBType) type).accept(this);
+            responseAttachmentBlock(block);
+        }
+
+    }
+
+    protected void responseBodyBlock(Block block) throws Exception {
+    }
+
+    protected void responseHeaderBlock(Block block) throws Exception {
+    }
+
+    protected void responseAttachmentBlock(Block block) throws Exception {
+    }
+
+    protected void postVisitResponse(Response response) throws Exception {
+    }
+
+    public void visit(Request request) throws Exception {
+        preVisitRequest(request);
+        visitRequest(request);
+        postVisitRequest(request);
+    }
+
+    protected void preVisitRequest(Request request) throws Exception {
+    }
+
+    protected void visitRequest(Request request) throws Exception {
+        Iterator iter = request.getParameters();
+        AbstractType type;
+        Block block;
+        while (iter.hasNext()) {
+            ((Parameter) iter.next()).accept(this);
+        }
+        iter = request.getBodyBlocks();
+        while (iter.hasNext()) {
+            block = (Block) iter.next();
+            type = block.getType();
+            if(type instanceof JAXBType)
+                ((JAXBType) type).accept(this);
+            else if(type instanceof RpcLitStructure)
+                ((RpcLitStructure) type).accept(this);
+            requestBodyBlock(block);
+        }
+        iter = request.getHeaderBlocks();
+        while (iter.hasNext()) {
+            block = (Block) iter.next();
+            type = block.getType();
+            if(type instanceof JAXBType)
+                ((JAXBType) type).accept(this);
+            requestHeaderBlock(block);
+        }
+    }
+
+    protected void requestBodyBlock(Block block) throws Exception {
+    }
+
+    protected void requestHeaderBlock(Block block) throws Exception {
+    }
+
+    protected void postVisitRequest(Request request) throws Exception {
+    }
+
+    public void visit(Fault fault) throws Exception {
+        preVisitFault(fault);
+        visitFault(fault);
+        postVisitFault(fault);
+    }
+
+    protected void preVisitFault(Fault fault) throws Exception {
+    }
+
+    protected void visitFault(Fault fault) throws Exception {
+    }
+
+    protected void postVisitFault(Fault fault) throws Exception {
+    }
+
+    protected void writeWarning(IndentingWriter p) throws IOException {
+        writeWarning(p, targetVersion);
+    }
+
+    public List<String> getJAXWSClassComment(){
+        return getJAXWSClassComment(targetVersion);
+    }
+
+    public static List<String> getJAXWSClassComment(String targetVersion) {
+        List<String> comments = new ArrayList<String>();
+        comments.add("This class was generated by the JAXWS SI.\n");
+        comments.add(ToolVersion.VERSION.BUILD_VERSION+"\n");
+        comments.add("Generated source version: " + targetVersion);
+        return comments;
+    }
+
+    public static void writeWarning(IndentingWriter p,
+                                    String targetVersion) throws IOException {
+        /*
+         * Write boiler plate comment.
+         */
+        p.pln("// This class was generated by the JAX SI, do not edit.");
+        p.pln("// Contents subject to change without notice.");
+        p.pln("// " + ToolVersion.VERSION.BUILD_VERSION);
+        p.pln("// Generated source version: " + targetVersion);
+        p.pln();
+    }
+
+    public void writePackage(IndentingWriter p, String classNameStr)
+        throws IOException {
+
+        writePackage(p, classNameStr, targetVersion);
+    }
+
+    public static void writePackage(
+        IndentingWriter p,
+        String classNameStr,
+        String sourceVersion)
+        throws IOException {
+
+        writeWarning(p, sourceVersion);
+        writePackageOnly(p, classNameStr);
+    }
+
+    public static void writePackageOnly(IndentingWriter p, String classNameStr)
+        throws IOException {
+        int idx = classNameStr.lastIndexOf(".");
+        if (idx > 0) {
+            p.pln("package " + classNameStr.substring(0, idx) + ";");
+            p.pln();
+        }
+    }
+
+
+    protected JDefinedClass getClass(String className, ClassType type) {
+        JDefinedClass cls = null;
+        try {
+            cls = cm._class(className, type);
+        } catch (JClassAlreadyExistsException e){
+            cls = cm._getClass(className);
+        }
+        return cls;
+    }
+
+    protected void log(String msg) {
+        if (env.verbose()) {
+            System.out.println(
+                "["
+                    + Names.stripQualifier(this.getClass().getName())
+                    + ": "
+                    + msg
+                    + "]");
+        }
+    }
+
+    protected void warn(String key) {
+        env.warn(messageFactory.getMessage(key));
+    }
+
+    protected void warn(String key, String arg) {
+        env.warn(messageFactory.getMessage(key, arg));
+    }
+
+    protected void warn(String key, Object[] args) {
+        env.warn(messageFactory.getMessage(key, args));
+    }
+
+    protected void info(String key) {
+        env.info(messageFactory.getMessage(key));
+    }
+
+    protected void info(String key, String arg) {
+        env.info(messageFactory.getMessage(key, arg));
+    }
+
+    protected static void fail(String key) {
+        throw new GeneratorException(key);
+    }
+
+    protected static void fail(String key, String arg) {
+        throw new GeneratorException(key, arg);
+    }
+
+    protected static void fail(String key, String arg1, String arg2) {
+        throw new GeneratorException(key, new Object[] { arg1, arg2 });
+    }
+
+    protected static void fail(Localizable arg) {
+        throw new GeneratorException("generator.nestedGeneratorError", arg);
+    }
+
+    protected static void fail(Throwable arg) {
+        throw new GeneratorException(
+            "generator.nestedGeneratorError",
+            arg);
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.processor.model.jaxb.JAXBTypeVisitor#visit(com.sun.xml.internal.ws.processor.model.jaxb.JAXBType)
+     */
+    public void visit(JAXBType type) throws Exception {
+        preVisitJAXBType(type);
+        visitJAXBType(type);
+        postVisitJAXBType(type);
+
+    }
+
+    /**
+     * @param type
+     */
+    protected void postVisitJAXBType(JAXBType type) {
+        // TODO Auto-generated method stub
+
+    }
+
+    /**
+     * @param type
+     */
+    protected void visitJAXBType(JAXBType type) {
+        // TODO Auto-generated method stub
+
+    }
+
+    /**
+     * @param type
+     */
+    protected void preVisitJAXBType(JAXBType type) {
+        // TODO Auto-generated method stub
+
+    }
+
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.processor.model.jaxb.JAXBTypeVisitor#visit(com.sun.xml.internal.ws.processor.model.jaxb.RpcLitStructure)
+     */
+    public void visit(RpcLitStructure type) throws Exception {
+        // TODO Auto-generated method stub
+
+    }
+
+    protected void writeHandlerConfig(String className, JDefinedClass cls, WSDLModelInfo wsdlModelInfo) {
+        Element e = wsdlModelInfo.getHandlerConfig();
+        if(e == null)
+            return;
+        JAnnotationUse handlerChainAnn = cls.annotate(cm.ref(HandlerChain.class));
+        //String fullName = env.getNames().customJavaTypeClassName(port.getJavaInterface());
+        NodeList nl = e.getElementsByTagNameNS(
+            "http://java.sun.com/xml/ns/javaee", "handler-chain");
+        if(nl.getLength() > 0){
+            Element hn = (Element)nl.item(0);
+            String fName = getHandlerConfigFileName(className);
+            handlerChainAnn.param("file", fName);
+            generateHandlerChainFile(e, className);
+        }
+    }
+
+     private String getHandlerConfigFileName(String fullName){
+        String name = Names.stripQualifier(fullName);
+        return name+"_handler.xml";
+    }
+
+    private void generateHandlerChainFile(Element hChains, String name) {
+        String hcName = getHandlerConfigFileName(name);
+
+        File packageDir = DirectoryUtil.getOutputDirectoryFor(name, destDir, env);
+        File hcFile = new File(packageDir, hcName);
+
+        /* adding the file name and its type */
+        GeneratedFileInfo fi = new GeneratedFileInfo();
+        fi.setFile(hcFile);
+        fi.setType("HandlerConfig");
+        env.addGeneratedFile(fi);
+
+        try {
+            IndentingWriter p =
+                new IndentingWriter(
+                    new OutputStreamWriter(new FileOutputStream(hcFile)));
+            Transformer it = XmlUtil.newTransformer();
+
+            it.setOutputProperty(OutputKeys.METHOD, "xml");
+            it.setOutputProperty(OutputKeys.INDENT, "yes");
+            it.setOutputProperty(
+                "{http://xml.apache.org/xslt}indent-amount",
+                "2");
+            it.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
+            it.transform( new DOMSource(hChains), new StreamResult(p) );
+        } catch (Exception e) {
+            throw new GeneratorException(
+                    "generator.nestedGeneratorError",
+                    e);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorConstants.java
new file mode 100644
index 0000000..c8fcd51
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorConstants.java
@@ -0,0 +1,86 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import com.sun.tools.internal.ws.processor.modeler.ModelerConstants;
+
+/**
+ * @author WS Development Team
+ */
+public interface GeneratorConstants extends ModelerConstants {
+
+    /*
+     * Constants used in the generators
+     */
+    public static final String FILE_TYPE_WSDL = "Wsdl";
+    public static final String FILE_TYPE_REMOTE_INTERFACE = "RemoteInterface";
+    public static final String FILE_TYPE_SERVICE = "Service";
+    public static final String FILE_TYPE_HANDLER_CONFIG = "HandlerConfig";
+    public static final String FILE_TYPE_SERVICE_IMPL = "ServiceImpl";
+    public static final String FILE_TYPE_EXCEPTION = "Exception";
+    public static final String FILE_TYPE_WRAPPER_BEAN = "WrapperBean";
+    public static final String FILE_TYPE_EXCEPTION_BEAN = "ExceptionBean";
+    /*
+     * Identifiers potentially useful for all Generators
+     */
+
+    public static final String ID_DELEGATE_BASE = "com.sun.xml.internal.ws.soap.internal.DelegateBase";
+
+
+    public static final char DOTC = '.';
+    public static final String SIG_INNERCLASS = "$";
+
+    public static final String UNDERSCORE = "_";
+    public static final String STUB_SUFFIX = "_Stub";
+
+    public static final String CLIENT_DELEGATE_SUFFIX = "_Delegate";
+    public static final String CLIENT_CONTACTINFOLIST_SUFFIX = "_ContactInfoList";
+
+    public static final String CLIENT_ENCODER_DECODER_SUFFIX = "_CED";
+    public static final String SERVER_ENCODER_DECODER_SUFFIX = "_SED";
+    public static final String TIE_SUFFIX = "_Tie";
+
+    public static final String PEPT_TIE_SUFFIX = "_PTie";
+    public static final String EPTFF_SUFFIX = "_EPTFF";
+    public static final String JAVA_SRC_SUFFIX = ".java";
+    public static final String IMPL_SUFFIX = "_Impl";
+    public static final String ARRAY = "Array";
+    public static final String MEMBER_PREFIX = "my";
+
+    public static final String OPCODE_SUFFIX = "_OPCODE";
+    public static final String QNAME_SUFFIX = "_QNAME";
+    public static final String TYPE_QNAME_SUFFIX = "_TYPE" + QNAME_SUFFIX;
+
+    public static final String GET = "get";
+    public static final String IS = "is";
+    public static final String SET = "set";
+    public static final String RESPONSE = "Response";
+    public static final String NS_PREFIX = "ns";
+    public static final String SERVICE_SUFFIX = "_Service";
+    public static final String JAVA_PACKAGE_PREFIX = "java.";
+    public static final String JAVAX_PACKAGE_PREFIX = "javax.";
+    public static final String FAULT_CLASS_MEMBER_NAME = "faultInfo";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorException.java
new file mode 100644
index 0000000..12c5038
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorException.java
@@ -0,0 +1,48 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import com.sun.tools.internal.ws.processor.ProcessorException;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class GeneratorException extends ProcessorException {
+
+    public GeneratorException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public GeneratorException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.generator";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorUtil.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorUtil.java
new file mode 100644
index 0000000..6f55211
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/GeneratorUtil.java
@@ -0,0 +1,183 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import java.io.IOException;
+import java.util.Comparator;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.Block;
+import com.sun.tools.internal.ws.processor.model.Fault;
+import com.sun.tools.internal.ws.processor.model.Operation;
+import com.sun.tools.internal.ws.processor.model.java.JavaStructureType;
+import com.sun.tools.internal.ws.processor.util.IndentingWriter;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class GeneratorUtil implements GeneratorConstants {
+
+    public static void writeNewQName(IndentingWriter p, QName name)
+        throws IOException {
+        p.p(
+            "new QName(\""
+                + name.getNamespaceURI()
+                + "\", \""
+                + name.getLocalPart()
+                + "\")");
+    }
+
+
+    public static void writeBlockQNameDeclaration(
+        IndentingWriter p,
+        Operation operation,
+        Block block,
+        Names names)
+        throws IOException {
+        String qname = names.getBlockQNameName(operation, block);
+        p.p("private static final QName ");
+        p.p(qname + " = ");
+        writeNewQName(p, block.getName());
+        p.pln(";");
+    }
+
+    public static void writeQNameDeclaration(
+        IndentingWriter p,
+        QName name,
+        Names names)
+        throws IOException {
+        String qname = names.getQNameName(name);
+        p.p("private static final QName ");
+        p.p(qname + " = ");
+        writeNewQName(p, name);
+        p.pln(";");
+    }
+
+    public static void writeQNameTypeDeclaration(
+        IndentingWriter p,
+        QName name,
+        Names names)
+        throws IOException {
+        String qname = names.getTypeQName(name);
+        p.p("private static final QName ");
+        p.p(qname + " = ");
+        writeNewQName(p, name);
+        p.pln(";");
+    }
+
+    public static boolean classExists(
+        ProcessorEnvironment env,
+        String className) {
+        try {
+            // Takes care of inner classes.
+            getLoadableClassName(className, env.getClassLoader());
+            return true;
+        } catch(ClassNotFoundException ce) {
+        }
+        return false;
+    }
+
+    public static String getLoadableClassName(
+        String className,
+        ClassLoader classLoader)
+        throws ClassNotFoundException {
+
+        try {
+            Class.forName(className, true, classLoader);
+        } catch (ClassNotFoundException e) {
+            int idx = className.lastIndexOf(DOTC);
+            if (idx > -1) {
+                String tmp = className.substring(0, idx) + SIG_INNERCLASS;
+                tmp += className.substring(idx + 1);
+                return getLoadableClassName(tmp, classLoader);
+            }
+            throw e;
+        }
+        return className;
+    }
+
+    public static class FaultComparator implements Comparator {
+        private boolean sortName = false;
+        public FaultComparator() {
+        }
+        public FaultComparator(boolean sortName) {
+            this.sortName = sortName;
+        }
+
+        public int compare(Object o1, Object o2) {
+            if (sortName) {
+                QName name1 = ((Fault) o1).getBlock().getName();
+                QName name2 = ((Fault) o2).getBlock().getName();
+                // Faults that are processed by name first, then type
+                if (!name1.equals(name2)) {
+                    return name1.toString().compareTo(name2.toString());
+                }
+            }
+            JavaStructureType type1 = ((Fault) o1).getJavaException();
+            JavaStructureType type2 = ((Fault) o2).getJavaException();
+            int result = sort(type1, type2);
+            return result;
+        }
+
+        protected int sort(JavaStructureType type1, JavaStructureType type2) {
+            if (type1.getName().equals(type2.getName())) {
+                return 0;
+            }
+            JavaStructureType superType;
+            superType = type1.getSuperclass();
+            while (superType != null) {
+                if (superType.equals(type2)) {
+                    return -1;
+                }
+                superType = superType.getSuperclass();
+            }
+            superType = type2.getSuperclass();
+            while (superType != null) {
+                if (superType.equals(type1)) {
+                    return 1;
+                }
+                superType = superType.getSuperclass();
+            }
+            if (type1.getSubclasses() == null && type2.getSubclasses() != null)
+                return -1;
+            if (type1.getSubclasses() != null && type2.getSubclasses() == null)
+                return 1;
+            if (type1.getSuperclass() != null
+                && type2.getSuperclass() == null) {
+                return 1;
+            }
+            if (type1.getSuperclass() == null
+                && type2.getSuperclass() != null) {
+                return -1;
+            }
+            return type1.getName().compareTo(type2.getName());
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/JAXBTypeGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/JAXBTypeGenerator.java
new file mode 100644
index 0000000..a4c201b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/JAXBTypeGenerator.java
@@ -0,0 +1,174 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.generator;
+
+import java.util.Properties;
+
+import org.xml.sax.SAXParseException;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.writer.ProgressCodeWriter;
+//import com.sun.tools.internal.xjc.addon.Augmenter;
+import com.sun.tools.internal.xjc.api.ErrorListener;
+import com.sun.tools.internal.xjc.api.JAXBModel;
+import com.sun.tools.internal.xjc.api.S2JJAXBModel;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBType;
+import com.sun.tools.internal.ws.processor.model.jaxb.RpcLitStructure;
+import com.sun.tools.internal.ws.processor.modeler.wsdl.ConsoleErrorReporter;
+import com.sun.tools.internal.ws.processor.ProcessorOptions;
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+import com.sun.tools.internal.ws.wscompile.WSCodeWriter;
+
+/**
+ * @author Vivek Pandey
+ *
+ * To change the template for this generated type comment go to
+ * Window&gt;Preferences&gt;Java&gt;Code Generation&gt;Code and Comments
+ */
+public class JAXBTypeGenerator extends GeneratorBase {
+
+    /**
+     * @author Vivek Pandey
+     *
+     * To change the template for this generated type comment go to
+     * Window&gt;Preferences&gt;Java&gt;Code Generation&gt;Code and Comments
+     */
+    public static class JAXBErrorListener implements ErrorListener {
+
+        /**
+         *
+         */
+        public JAXBErrorListener() {
+            super();
+        }
+
+        /* (non-Javadoc)
+         * @see org.xml.sax.ErrorHandler#error(org.xml.sax.SAXParseException)
+         */
+        public void error(SAXParseException arg0) {
+            // TODO Auto-generated method stub
+
+        }
+
+        /* (non-Javadoc)
+         * @see org.xml.sax.ErrorHandler#fatalError(org.xml.sax.SAXParseException)
+         */
+        public void fatalError(SAXParseException arg0) {
+            // TODO Auto-generated method stub
+
+        }
+
+        /* (non-Javadoc)
+         * @see org.xml.sax.ErrorHandler#warning(org.xml.sax.SAXParseException)
+         */
+        public void warning(SAXParseException arg0) {
+            // TODO Auto-generated method stub
+
+        }
+
+        /* (non-Javadoc)
+         * @see com.sun.tools.internal.xjc.api.ErrorListener#info(org.xml.sax.SAXParseException)
+         */
+        public void info(SAXParseException arg0) {
+            // TODO Auto-generated method stub
+
+        }
+
+    }
+    /**
+     *
+     */
+    public JAXBTypeGenerator() {
+        super();
+        // TODO Auto-generated constructor stub
+    }
+    /**
+     * @param model
+     * @param config
+     * @param properties
+     */
+    public JAXBTypeGenerator(Model model, Configuration config,
+            Properties properties) {
+        super(model, config, properties);
+    }
+    /* (non-Javadoc)
+     * @see GeneratorBase#getGenerator(com.sun.xml.internal.ws.processor.model.Model, com.sun.xml.internal.ws.processor.config.Configuration, java.util.Properties)
+     */
+    public GeneratorBase getGenerator(Model model, Configuration config,
+            Properties properties) {
+        return new JAXBTypeGenerator(model, config, properties);
+    }
+    /* (non-Javadoc)
+     * @see cGeneratorBase#getGenerator(com.sun.xml.internal.ws.processor.model.Model, com.sun.xml.internal.ws.processor.config.Configuration, java.util.Properties, com.sun.xml.internal.ws.soap.SOAPVersion)
+     */
+    public GeneratorBase getGenerator(Model model, Configuration config,
+            Properties properties, SOAPVersion ver) {
+        return new JAXBTypeGenerator(model, config, properties);
+    }
+
+    /* (non-Javadoc)
+     * @see JAXBTypeVisitor#visit(JAXBType)
+     */
+    public void visit(JAXBType type) throws Exception {
+        //this is a raw type, probably from rpclit
+        if(type.getJaxbModel() == null)
+            return;
+        S2JJAXBModel model = type.getJaxbModel().getS2JJAXBModel();
+        if (model != null)
+            generateJAXBClasses(model);
+    }
+
+
+    /* (non-Javadoc)
+     * @see JAXBTypeVisitor#visit(com.sun.xml.internal.ws.processor.model.jaxb.RpcLitStructure)
+     */
+    public void visit(RpcLitStructure type) throws Exception {
+        S2JJAXBModel model = type.getJaxbModel().getS2JJAXBModel();
+        generateJAXBClasses(model);
+    }
+
+    private static boolean doneGeneration = true;
+    private void generateJAXBClasses(S2JJAXBModel model) throws Exception{
+        if(doneGeneration)
+            return;
+        JCodeModel cm = null;
+
+        // get the list of jaxb source files
+        CodeWriter cw = new WSCodeWriter(sourceDir,env);
+
+        if(env.verbose())
+            cw = new ProgressCodeWriter(cw, System.out); // TODO this should not be System.out, should be
+                                                         // something from ProcessorEnvironment
+        //TODO:set package level javadoc in JPackage
+        cm = model.generateCode(null, new ConsoleErrorReporter(env, printStackTrace));
+        cm.build(cw);
+        doneGeneration = true;
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/Names.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/Names.java
new file mode 100644
index 0000000..a768205
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/Names.java
@@ -0,0 +1,424 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import com.sun.tools.internal.ws.processor.model.*;
+import com.sun.tools.internal.ws.processor.model.java.JavaInterface;
+import com.sun.tools.internal.ws.processor.model.java.JavaStructureMember;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBProperty;
+import com.sun.tools.internal.ws.processor.util.DirectoryUtil;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.util.ClassNameInfo;
+import com.sun.xml.internal.ws.streaming.PrefixFactory;
+import com.sun.xml.internal.ws.streaming.PrefixFactoryImpl;
+import com.sun.xml.internal.ws.util.StringUtils;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+
+import javax.xml.namespace.QName;
+import java.io.File;
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * Names provides utility methods used by other wscompile classes
+ * for dealing with identifiers.
+ *
+ * @author WS Development Team
+ */
+public class Names implements GeneratorConstants{
+
+    public Names() {
+    }
+
+    public String stubFor(Port port, String infix) {
+        String result =
+            (String) port.getProperty(ModelProperties.PROPERTY_STUB_CLASS_NAME);
+        if (result == null) {
+            result =
+                makeDerivedClassName(
+                    port.getJavaInterface(),
+                    STUB_SUFFIX,
+                    infix);
+        }
+        return result;
+    }
+
+    public String tieFor(Port port, String infix) {
+        String result =
+            (String) port.getProperty(ModelProperties.PROPERTY_TIE_CLASS_NAME);
+        if (result == null) {
+            result =
+                makeDerivedClassName(
+                    port.getJavaInterface(),
+                    TIE_SUFFIX,
+                    infix);
+        }
+        return result;
+    }
+
+    public String makeDerivedClassName(
+        JavaInterface javaInterface,
+        String suffix,
+        String infix) {
+
+        String name =
+            ClassNameInfo.replaceInnerClassSym(javaInterface.getRealName());
+        return name + (infix == null ? "" : UNDERSCORE + infix) + suffix;
+    }
+
+    public static String getPortName(Port port) {
+        String javaPortName =
+            (String) port.getProperty(ModelProperties.PROPERTY_JAVA_PORT_NAME);
+        if (javaPortName != null) {
+            return javaPortName;
+        } else {
+            QName portName =
+                (QName) port.getProperty(
+                    ModelProperties.PROPERTY_WSDL_PORT_NAME);
+            if (portName != null) {
+                return portName.getLocalPart();
+            } else {
+                String name = stripQualifier(port.getJavaInterface().getName());
+                return ClassNameInfo.replaceInnerClassSym(name);
+            }
+        }
+    }
+
+    public static String stripQualifier(Class classObj) {
+        String name = classObj.getName();
+        return stripQualifier(name);
+    }
+
+    public static String stripQualifier(String name) {
+        return ClassNameInfo.getName(name);
+    }
+
+    public static String getPackageName(String className) {
+        String packageName = ClassNameInfo.getQualifier(className);
+        return packageName != null ? packageName : "";
+    }
+
+    public static String getUnqualifiedClassName(String className) {
+        return ClassNameInfo.getName(className).replace('$', '.');
+    }
+
+    /**
+     * Return the File object that should be used as the source file
+     * for the given Java class, using the supplied destination
+     * directory for the top of the package hierarchy.
+     */
+    public File sourceFileForClass(
+        String className,
+        String outputClassName,
+        File destDir,
+        ProcessorEnvironment env)
+        throws GeneratorException {
+        File packageDir =
+            DirectoryUtil.getOutputDirectoryFor(className, destDir, env);
+        String outputName = stripQualifier(outputClassName);
+
+        String outputFileName = outputName + JAVA_SRC_SUFFIX;
+        return new File(packageDir, outputFileName);
+    }
+
+    public static String getPackageName(Service service) {
+        String portPackage =
+            getPackageName(service.getJavaInterface().getName());
+        return portPackage;
+    }
+
+    public String customJavaTypeClassName(JavaInterface intf) {
+        String intName = intf.getName();
+        return intName;
+    }
+
+    public String customExceptionClassName(Fault fault) {
+        String typeName = fault.getJavaException().getName();
+        return typeName;
+    }
+
+    public String getExceptionClassMemberName(){
+        return FAULT_CLASS_MEMBER_NAME;
+    }
+
+    public String getQNameName(QName name) {
+        String qname =
+            getPrefix(name) + UNDERSCORE + name.getLocalPart() + QNAME_SUFFIX;
+        return validInternalJavaIdentifier(qname);
+    }
+
+    public String getBlockQNameName(Operation operation, Block block) {
+        QName blockName = block.getName();
+        String qname = getPrefix(blockName);
+        if (operation != null)
+            qname += UNDERSCORE + operation.getUniqueName();
+        qname += UNDERSCORE + blockName.getLocalPart() + QNAME_SUFFIX;
+        return validInternalJavaIdentifier(qname);
+    }
+
+    public String getTypeQName(QName name) {
+        String qname =
+            getPrefix(name)
+                + UNDERSCORE
+                + name.getLocalPart()
+                + TYPE_QNAME_SUFFIX;
+        return validInternalJavaIdentifier(qname);
+    }
+
+    /* (non-Javadoc)
+     * @see Names#validJavaClassName(String)
+     */
+    public String validJavaClassName(String name) {
+        return JAXBRIContext.mangleNameToClassName(name);
+    }
+
+    /* (non-Javadoc)
+     * @see Names#validJavaMemberName(String)
+     */
+    public String validJavaMemberName(String name) {
+        return JAXBRIContext.mangleNameToVariableName(name);
+    }
+
+    public String validInternalJavaIdentifier(String name) {
+        // return a valid java identifier without dropping characters (i.e. do not apply
+        // the mapping of XML names to Java identifiers in the spec); it's only meant
+        // to be used to generate internal identifiers (e.g. variable names in generated code)
+
+        StringBuffer sb = new StringBuffer();
+        for (int i = 0; i < name.length(); ++i) {
+            char ch = name.charAt(i);
+            if (i == 0) {
+                if (Character.isJavaIdentifierStart(ch)) {
+                    sb.append(ch);
+                } else {
+                    sb.append("_$");
+                    sb.append(Integer.toHexString((int) ch));
+                    sb.append("$");
+                }
+            } else {
+                if (Character.isJavaIdentifierPart(ch)) {
+                    sb.append(ch);
+                } else {
+                    sb.append("$");
+                    sb.append(Integer.toHexString((int) ch));
+                    sb.append("$");
+                }
+            }
+        }
+
+        String id = sb.toString();
+
+        String tmp = (String) reservedWords.get(id);
+        if (tmp != null)
+            id = tmp;
+        return id;
+    }
+
+    public String validExternalJavaIdentifier(String name) {
+        return validInternalJavaIdentifier(name).replace('$', '_');
+    }
+
+    public String validJavaName(String name) {
+        name = wordBreakString(name);
+        name = removeWhiteSpace(name);
+
+        String tmp = (String) reservedWords.get(name);
+        if (tmp != null)
+            name = tmp;
+        return name;
+    }
+
+    public boolean isJavaReservedWord(String name) {
+        return reservedWords.get(name) != null;
+    }
+
+    /* here we check on wether return values datatype is
+       boolean. If its boolean, instead of a get method
+       its set a is<MethodName> to comply with JavaBeans
+       Pattern spec */
+    public String getJavaMemberReadMethod(JavaStructureMember member) {
+        String return_value = null;
+        if ((member.getType().getRealName()) == "boolean") {
+            return_value = IS + StringUtils.capitalize(member.getName());
+        } else {
+            return_value = GET + StringUtils.capitalize(member.getName());
+        }
+        return (return_value);
+    }
+
+    public String getJavaMemberWriteMethod(JavaStructureMember member) {
+        return SET + StringUtils.capitalize(member.getName());
+    }
+
+    public static String getResponseName(String messageName) {
+        return messageName + RESPONSE;
+    }
+
+
+    public String getJavaReadMethod(JAXBProperty prop){
+        if(prop.getType().getName().equals("boolean"))
+            return IS + StringUtils.capitalize(prop.getName());
+        return getJavaReadMethod(prop.getName());
+    }
+
+    public String getJavaWriteMethod(JAXBProperty prop){
+        return getJavaWriteMethod(prop.getName());
+    }
+
+    public String getJavaReadMethod(String prop){
+        return GET + StringUtils.capitalize(prop);
+    }
+
+    public String getJavaWriteMethod(String prop){
+        return SET + StringUtils.capitalize(prop);
+    }
+
+    public String removeWhiteSpace(String str) {
+        String tmp = removeCharacter(' ', str);
+        return tmp;
+    }
+
+    public String wordBreakString(String str) {
+        StringBuffer buf = new StringBuffer(str);
+        char ch;
+        for (int i = 0; i < buf.length(); i++) {
+            ch = buf.charAt(i);
+            if (Character.isDigit(ch)) {
+                if (i + 1 < buf.length()
+                    && !Character.isDigit(buf.charAt(i + 1))) {
+                    buf.insert(1 + i++, ' ');
+                }
+            } else if (Character.isSpaceChar(ch) || ch == '_') {
+                continue;
+            } else if (!Character.isJavaIdentifierPart(ch)) {
+                buf.setCharAt(i, ' ');
+            } else if (!Character.isLetter(ch)) {
+                buf.setCharAt(i, ' ');
+            }
+        }
+        return buf.toString();
+    }
+
+    public String removeCharacter(int ch, String str) {
+        String tmp;
+        int idx = str.indexOf(ch);
+        while (idx >= 0) {
+            str =
+                str.substring(0, idx)
+                    + StringUtils.capitalize(str.substring(idx + 1).trim());
+            idx = str.indexOf(' ');
+        }
+
+        return str;
+    }
+
+    public String getPrefix(QName name) {
+        return getPrefix(name.getNamespaceURI());
+    }
+
+    public String getPrefix(String uri) {
+        return prefixFactory.getPrefix(uri);
+    }
+
+    public void resetPrefixFactory() {
+        prefixFactory = new PrefixFactoryImpl(NS_PREFIX);
+    }
+
+    public void setSerializerNameInfix(String serNameInfix) {
+        if (serNameInfix != null && serNameInfix.length() > 0)
+            serializerNameInfix = UNDERSCORE + serNameInfix;
+    }
+
+    public String getSerializerNameInfix() {
+        // Fix for bug 4811625 and 4778136, undoing what setter does (remove beginning underscore)
+        String str = serializerNameInfix;
+        if ((serializerNameInfix != null)
+            && (serializerNameInfix.charAt(0) == '_'))
+            str = serializerNameInfix.substring(1);
+        return str;
+    }
+
+    protected String serializerNameInfix = null;
+    protected PrefixFactory prefixFactory = new PrefixFactoryImpl(NS_PREFIX);
+    protected static Map reservedWords;
+
+    static {
+        reservedWords = new HashMap();
+        reservedWords.put("abstract", "_abstract");
+        reservedWords.put("assert", "_assert");
+        reservedWords.put("boolean", "_boolean");
+        reservedWords.put("break", "_break");
+        reservedWords.put("byte", "_byte");
+        reservedWords.put("case", "_case");
+        reservedWords.put("catch", "_catch");
+        reservedWords.put("char", "_char");
+        reservedWords.put("class", "_class");
+        reservedWords.put("const", "_const");
+        reservedWords.put("continue", "_continue");
+        reservedWords.put("default", "_default");
+        reservedWords.put("do", "_do");
+        reservedWords.put("double", "_double");
+        reservedWords.put("else", "_else");
+        reservedWords.put("extends", "_extends");
+        reservedWords.put("false", "_false");
+        reservedWords.put("final", "_final");
+        reservedWords.put("finally", "_finally");
+        reservedWords.put("float", "_float");
+        reservedWords.put("for", "_for");
+        reservedWords.put("goto", "_goto");
+        reservedWords.put("if", "_if");
+        reservedWords.put("implements", "_implements");
+        reservedWords.put("import", "_import");
+        reservedWords.put("instanceof", "_instanceof");
+        reservedWords.put("int", "_int");
+        reservedWords.put("interface", "_interface");
+        reservedWords.put("long", "_long");
+        reservedWords.put("native", "_native");
+        reservedWords.put("new", "_new");
+        reservedWords.put("null", "_null");
+        reservedWords.put("package", "_package");
+        reservedWords.put("private", "_private");
+        reservedWords.put("protected", "_protected");
+        reservedWords.put("public", "_public");
+        reservedWords.put("return", "_return");
+        reservedWords.put("short", "_short");
+        reservedWords.put("static", "_static");
+        reservedWords.put("strictfp", "_strictfp");
+        reservedWords.put("super", "_super");
+        reservedWords.put("switch", "_switch");
+        reservedWords.put("synchronized", "_synchronized");
+        reservedWords.put("this", "_this");
+        reservedWords.put("throw", "_throw");
+        reservedWords.put("throws", "_throws");
+        reservedWords.put("transient", "_transient");
+        reservedWords.put("true", "_true");
+        reservedWords.put("try", "_try");
+        reservedWords.put("void", "_void");
+        reservedWords.put("volatile", "_volatile");
+        reservedWords.put("while", "_while");
+        reservedWords.put("enum", "_enum");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/SeiGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/SeiGenerator.java
new file mode 100644
index 0000000..542f161
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/SeiGenerator.java
@@ -0,0 +1,477 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import com.sun.codemodel.internal.*;
+import com.sun.codemodel.internal.writer.ProgressCodeWriter;
+import com.sun.tools.internal.ws.processor.ProcessorAction;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.model.*;
+import com.sun.tools.internal.ws.processor.model.java.JavaInterface;
+import com.sun.tools.internal.ws.processor.model.java.JavaMethod;
+import com.sun.tools.internal.ws.processor.model.java.JavaParameter;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBType;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBTypeAndAnnotation;
+import com.sun.tools.internal.ws.processor.util.DirectoryUtil;
+import com.sun.tools.internal.ws.processor.util.GeneratedFileInfo;
+import com.sun.tools.internal.ws.processor.util.IndentingWriter;
+import com.sun.tools.internal.ws.wscompile.WSCodeWriter;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPStyle;
+import com.sun.tools.internal.ws.wsdl.document.PortType;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import org.w3c.dom.Element;
+import org.w3c.dom.NodeList;
+
+import javax.jws.HandlerChain;
+import javax.jws.WebMethod;
+import javax.jws.WebParam;
+import javax.jws.WebService;
+import javax.jws.soap.SOAPBinding;
+import javax.xml.transform.OutputKeys;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.ws.Holder;
+import javax.xml.namespace.QName;
+import java.io.File;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.OutputStreamWriter;
+import java.util.List;
+import java.util.Properties;
+import java.util.Iterator;
+
+public class SeiGenerator extends GeneratorBase implements ProcessorAction {
+    private WSDLModelInfo wsdlModelInfo;
+    private String serviceNS;
+
+    public SeiGenerator() {
+    }
+
+    protected void doGeneration() {
+        try {
+            model.accept(this);
+        } catch (Exception e) {
+            if (env.verbose())
+                e.printStackTrace();
+            throw new GeneratorException(
+                "generator.nestedGeneratorError",
+                e);
+        }
+    }
+
+    public GeneratorBase getGenerator(Model model, Configuration config, Properties properties) {
+        return new SeiGenerator(model, config, properties);
+    }
+
+    public SeiGenerator(Model model, Configuration config, Properties properties) {
+        super(model, config, properties);
+        this.model = model;
+        this.wsdlModelInfo = (WSDLModelInfo)config.getModelInfo();
+    }
+
+    public GeneratorBase getGenerator(Model model, Configuration config, Properties properties, SOAPVersion ver) {
+        return new SeiGenerator(model, config, properties);
+    }
+
+
+    private void write(Service service, Port port) throws Exception{
+        JavaInterface intf = port.getJavaInterface();
+        String className = env.getNames().customJavaTypeClassName(intf);
+
+        if (donotOverride && GeneratorUtil.classExists(env, className)) {
+            log("Class " + className + " exists. Not overriding.");
+            return;
+        }
+
+
+        JDefinedClass cls = getClass(className, ClassType.INTERFACE);
+        if (cls == null)
+            return;
+
+        // If the class has methods it has already been defined
+        // so skip it.
+        if (!cls.methods().isEmpty())
+            return;
+
+        //write class comment - JAXWS warning
+        JDocComment comment = cls.javadoc();
+
+        String ptDoc = intf.getJavaDoc();
+        if(ptDoc != null){
+            comment.add(ptDoc);
+            comment.add("\n\n");
+        }
+
+        for(String doc:getJAXWSClassComment()){
+                comment.add(doc);
+        }
+
+
+        //@WebService
+        JAnnotationUse webServiceAnn = cls.annotate(cm.ref(WebService.class));
+        writeWebServiceAnnotation(service, port, webServiceAnn);
+
+        //@HandlerChain
+        writeHandlerConfig(env.getNames().customJavaTypeClassName(port.getJavaInterface()), cls, wsdlModelInfo);
+
+        //@SOAPBinding
+        writeSOAPBinding(port, cls);
+
+        for (Operation operation: port.getOperations()) {
+            JavaMethod method = operation.getJavaMethod();
+
+            //@WebMethod
+            JMethod m = null;
+            JDocComment methodDoc = null;
+            String methodJavaDoc = operation.getJavaDoc();
+            if(method.getReturnType().getName().equals("void")){
+                m = cls.method(JMod.PUBLIC, void.class, method.getName());
+                methodDoc = m.javadoc();
+            }else {
+                JAXBTypeAndAnnotation retType = method.getReturnType().getType();
+                m = cls.method(JMod.PUBLIC, retType.getType(), method.getName());
+                retType.annotate(m);
+                methodDoc = m.javadoc();
+                JCommentPart ret = methodDoc.addReturn();
+                ret.add("returns "+retType.getName());
+            }
+            if(methodJavaDoc != null)
+                methodDoc.add(methodJavaDoc);
+
+            writeWebMethod(operation, m);
+            JClass holder = cm.ref(Holder.class);
+            for (JavaParameter parameter: method.getParametersList()) {
+                JVar var = null;
+                JAXBTypeAndAnnotation paramType = parameter.getType().getType();
+                if (parameter.isHolder()) {
+                    var = m.param(holder.narrow(paramType.getType().boxify()), parameter.getName());
+                }else{
+                    var = m.param(paramType.getType(), parameter.getName());
+                }
+
+                //annotate parameter with JAXB annotations
+                paramType.annotate(var);
+                methodDoc.addParam(var);
+                JAnnotationUse paramAnn = var.annotate(cm.ref(WebParam.class));
+                writeWebParam(operation, parameter, paramAnn);
+            }
+            for(Fault fault:operation.getFaultsSet()){
+                m._throws(fault.getExceptionClass());
+                methodDoc.addThrows(fault.getExceptionClass());
+            }
+        }
+        CodeWriter cw = new WSCodeWriter(sourceDir,env);
+
+        if(env.verbose())
+            cw = new ProgressCodeWriter(cw, System.out);
+        cm.build(cw);
+    }
+
+    private void writeWebMethod(Operation operation, JMethod m) {
+        Response response = operation.getResponse();
+        JAnnotationUse webMethodAnn = m.annotate(cm.ref(WebMethod.class));;
+        String operationName = (operation instanceof AsyncOperation)?
+                ((AsyncOperation)operation).getNormalOperation().getName().getLocalPart():
+                operation.getName().getLocalPart();
+
+        if(!m.name().equals(operationName)){
+            webMethodAnn.param("operationName", operationName);
+        }
+
+        if (operation.getSOAPAction() != null && operation.getSOAPAction().length() > 0){
+            webMethodAnn.param("action", operation.getSOAPAction());
+        }
+
+        if (operation.getResponse() == null){
+            m.annotate(javax.jws.Oneway.class);
+        }else if (!operation.getJavaMethod().getReturnType().getName().equals("void") &&
+                 operation.getResponse().getParametersList().size() > 0){
+            Block block = null;
+            String resultName = null;
+            String nsURI = null;
+            if (operation.getResponse().getBodyBlocks().hasNext()) {
+                block = operation.getResponse().getBodyBlocks().next();
+                resultName = block.getName().getLocalPart();
+                if(isDocStyle || block.getLocation() == Block.HEADER){
+                    nsURI = block.getName().getNamespaceURI();
+                }
+            }
+
+            for (Parameter parameter : operation.getResponse().getParametersList()) {
+                if (parameter.getParameterIndex() == -1) {
+                    if(operation.isWrapped()||!isDocStyle){
+                        if(parameter.getBlock().getLocation() == Block.HEADER){
+                            resultName = parameter.getBlock().getName().getLocalPart();
+                        }else{
+                            resultName = parameter.getName();
+                        }
+                        if (isDocStyle || (parameter.getBlock().getLocation() == Block.HEADER)) {
+                            nsURI = parameter.getType().getName().getNamespaceURI();
+                        }
+                    }else if(isDocStyle){
+                        JAXBType t = (JAXBType)parameter.getType();
+                        resultName = t.getName().getLocalPart();
+                        nsURI = t.getName().getNamespaceURI();
+                    }
+                    if(!(operation instanceof AsyncOperation)){
+                        JAnnotationUse wr = null;
+
+                        if(!resultName.equals("return")){
+                            if(wr == null)
+                                wr = m.annotate(javax.jws.WebResult.class);
+                            wr.param("name", resultName);
+                        }
+                        //if (operation.getStyle().equals(SOAPStyle.DOCUMENT) && !(nsURI.equals(serviceNS))) {
+                        if((nsURI != null) && (!nsURI.equals(serviceNS) || (isDocStyle && operation.isWrapped()))){
+                            if(wr == null)
+                                wr = m.annotate(javax.jws.WebResult.class);
+                            wr.param("targetNamespace", nsURI);
+                        }
+                        //doclit wrapped could have additional headers
+                        if(!(isDocStyle && operation.isWrapped()) ||
+                                (parameter.getBlock().getLocation() == Block.HEADER)){
+                            if(wr == null)
+                                wr = m.annotate(javax.jws.WebResult.class);
+                            wr.param("partName", parameter.getName());
+                        }
+                        if(parameter.getBlock().getLocation() == Block.HEADER){
+                            if(wr == null)
+                                wr = m.annotate(javax.jws.WebResult.class);
+                            wr.param("header",true);
+                        }
+                    }
+                }
+
+            }
+        }
+
+        //DOC/BARE
+        if (!sameParamStyle) {
+            if(!operation.isWrapped()) {
+               JAnnotationUse sb = m.annotate(SOAPBinding.class);
+               sb.param("parameterStyle", SOAPBinding.ParameterStyle.BARE);
+            }
+        }
+
+        if (operation.isWrapped() && operation.getStyle().equals(SOAPStyle.DOCUMENT)) {
+            Block reqBlock = operation.getRequest().getBodyBlocks().next();
+            JAnnotationUse reqW = m.annotate(javax.xml.ws.RequestWrapper.class);
+            reqW.param("localName", reqBlock.getName().getLocalPart());
+            reqW.param("targetNamespace", reqBlock.getName().getNamespaceURI());
+            reqW.param("className", reqBlock.getType().getJavaType().getName());
+
+            if (response != null) {
+                JAnnotationUse resW = m.annotate(javax.xml.ws.ResponseWrapper.class);
+                Block resBlock = response.getBodyBlocks().next();
+                resW.param("localName", resBlock.getName().getLocalPart());
+                resW.param("targetNamespace", resBlock.getName().getNamespaceURI());
+                resW.param("className", resBlock.getType().getJavaType().getName());
+            }
+        }
+    }
+
+    //TODO: JAXB should expose the annotations so that it can be added to JAnnotationUse
+    protected void writeJAXBTypeAnnotations(JAnnotationUse annUse, Parameter param) throws IOException{
+        List<String> annotations = param.getAnnotations();
+        if(annotations == null)
+            return;
+
+        for(String annotation:param.getAnnotations()){
+            //p.pln(annotation);
+            //annUse.
+        }
+    }
+
+    private boolean isMessageParam(Parameter param, Message message) {
+        Block block = param.getBlock();
+
+        return (message.getBodyBlockCount() > 0 && block.equals(message.getBodyBlocks().next())) ||
+               (message.getHeaderBlockCount() > 0 &&
+               block.equals(message.getHeaderBlocks().next()));
+    }
+
+    private boolean isHeaderParam(Parameter param, Message message) {
+        if (message.getHeaderBlockCount() == 0)
+            return false;
+
+        for (Block headerBlock : message.getHeaderBlocksMap().values())
+            if (param.getBlock().equals(headerBlock))
+                return true;
+
+        return false;
+    }
+
+    private boolean isAttachmentParam(Parameter param, Message message){
+        if (message.getAttachmentBlockCount() == 0)
+            return false;
+
+        for (Block attBlock : message.getAttachmentBlocksMap().values())
+            if (param.getBlock().equals(attBlock))
+                return true;
+
+        return false;
+    }
+
+    private boolean isUnboundParam(Parameter param, Message message){
+        if (message.getUnboundBlocksCount() == 0)
+            return false;
+
+        for (Block unboundBlock : message.getUnboundBlocksMap().values())
+            if (param.getBlock().equals(unboundBlock))
+                return true;
+
+        return false;
+    }
+
+    private void writeWebParam(Operation operation, JavaParameter javaParameter, JAnnotationUse paramAnno) {
+        Parameter param = javaParameter.getParameter();
+        Request req = operation.getRequest();
+        Response res = operation.getResponse();
+
+        boolean header = isHeaderParam(param, req) ||
+            (res != null ? isHeaderParam(param, res) : false);
+
+        String name;
+        boolean isWrapped = operation.isWrapped();
+
+        if((param.getBlock().getLocation() == Block.HEADER) || (isDocStyle && !isWrapped))
+            name = param.getBlock().getName().getLocalPart();
+        else
+            name = param.getName();
+
+        paramAnno.param("name", name);
+
+        String ns= null;
+
+        if (isDocStyle) {
+            ns = param.getBlock().getName().getNamespaceURI(); // its bare nsuri
+            if(isWrapped){
+                ns = ((JAXBType)param.getType()).getName().getNamespaceURI();
+            }
+        }else if(!isDocStyle && header){
+            ns = param.getBlock().getName().getNamespaceURI();
+        }
+
+        if((ns != null) && (!ns.equals(serviceNS) || (isDocStyle && isWrapped)))
+            paramAnno.param("targetNamespace", ns);
+
+        if (header) {
+            paramAnno.param("header", true);
+        }
+
+        if (param.isINOUT()){
+            paramAnno.param("mode", javax.jws.WebParam.Mode.INOUT);
+        }else if ((res != null) && (isMessageParam(param, res) || isHeaderParam(param, res) || isAttachmentParam(param, res) ||
+                isUnboundParam(param,res))){
+            paramAnno.param("mode", javax.jws.WebParam.Mode.OUT);
+        }
+
+        //doclit wrapped could have additional headers
+        if(!(isDocStyle && isWrapped) || header)
+            paramAnno.param("partName", javaParameter.getParameter().getName());
+    }
+
+    boolean isDocStyle = true;
+    boolean sameParamStyle = true;
+    private void writeSOAPBinding(Port port, JDefinedClass cls) {
+        JAnnotationUse soapBindingAnn = null;
+        isDocStyle = port.getStyle() != null ? port.getStyle().equals(SOAPStyle.DOCUMENT) : true;
+        if(!isDocStyle){
+            if(soapBindingAnn == null)
+                soapBindingAnn = cls.annotate(SOAPBinding.class);
+            soapBindingAnn.param("style", SOAPBinding.Style.RPC);
+            port.setWrapped(true);
+        }
+        if(isDocStyle){
+            boolean first = true;
+            boolean isWrapper = true;
+            for(Operation operation:port.getOperations()){
+                if(first){
+                    isWrapper = operation.isWrapped();
+                    first = false;
+                    continue;
+                }
+                sameParamStyle = (isWrapper == operation.isWrapped());
+                if(!sameParamStyle)
+                    break;
+            }
+            if(sameParamStyle)
+                port.setWrapped(isWrapper);
+        }
+        if(sameParamStyle && !port.isWrapped()){
+            if(soapBindingAnn == null)
+                soapBindingAnn = cls.annotate(SOAPBinding.class);
+            soapBindingAnn.param("parameterStyle", SOAPBinding.ParameterStyle.BARE);
+        }
+    }
+
+    private void writeWebServiceAnnotation(Service service, Port port, JAnnotationUse wsa) {
+        QName name = (QName) port.getProperty(ModelProperties.PROPERTY_WSDL_PORT_TYPE_NAME);
+        wsa.param("name", name.getLocalPart());
+        wsa.param("targetNamespace", name.getNamespaceURI());
+    }
+
+
+
+
+    public void visit(Model model) throws Exception {
+        for(Service s:model.getServices()){
+            s.accept(this);
+        }
+    }
+
+    public void visit(Service service) throws Exception {
+        String jd = model.getJavaDoc();
+        if(jd != null){
+            JPackage pkg = cm._package(wsdlModelInfo.getJavaPackageName());
+            pkg.javadoc().add(jd);
+        }
+
+        for(Port p:service.getPorts()){
+            visitPort(service, p);
+        }
+    }
+
+    private void visitPort(Service service, Port port) {
+        if (port.isProvider()) {
+            return;                // Not generating for Provider based endpoint
+        }
+
+
+        try {
+            write(service, port);
+        } catch (Exception e) {
+            throw new GeneratorException(
+                "generator.nestedGeneratorError",
+                e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/ServiceGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/ServiceGenerator.java
new file mode 100644
index 0000000..1e2eadb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/ServiceGenerator.java
@@ -0,0 +1,231 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import com.sun.codemodel.internal.JClassAlreadyExistsException;
+import com.sun.codemodel.internal.ClassType;
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JAnnotationUse;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCommentPart;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JDocComment;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.*;
+import com.sun.codemodel.internal.writer.ProgressCodeWriter;
+import java.util.Properties;
+
+import com.sun.tools.internal.xjc.api.XJC;
+import com.sun.tools.internal.ws.processor.ProcessorAction;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.model.Service;
+import com.sun.tools.internal.ws.processor.model.java.JavaInterface;
+import com.sun.tools.internal.ws.wscompile.WSCodeWriter;
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.xml.internal.ws.util.StringUtils;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+
+import java.io.File;
+import java.io.IOException;
+import java.net.URL;
+import java.net.MalformedURLException;
+import javax.xml.ws.WebEndpoint;
+import javax.xml.ws.WebServiceClient;
+import javax.xml.namespace.QName;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class ServiceGenerator extends GeneratorBase implements ProcessorAction {
+    private String serviceNS;
+    private WSDLModelInfo wsdlModelInfo;
+
+    public ServiceGenerator() {
+        super();
+    }
+
+    private ServiceGenerator(
+        Model model,
+        Configuration config,
+        Properties properties) {
+        super(model, config, properties);
+        this.wsdlModelInfo = (WSDLModelInfo)config.getModelInfo();
+    }
+
+    public GeneratorBase getGenerator(
+        Model model,
+        Configuration config,
+        Properties properties) {
+        return new ServiceGenerator(model, config, properties);
+    }
+
+    public GeneratorBase getGenerator(
+        Model model,
+        Configuration config,
+        Properties properties,
+        SOAPVersion ver) {
+        return new ServiceGenerator(model, config, properties);
+    }
+
+    /**
+     * Generates an expression that evaluates to "new QName(...)"
+     */
+    private JInvocation createQName(QName name) {
+        return JExpr._new(cm.ref(QName.class)).arg(name.getNamespaceURI()).arg(name.getLocalPart());
+    }
+
+    private JInvocation createURL(URL url) {
+        return JExpr._new(cm.ref(URL.class)).arg(url.toExternalForm());
+    }
+
+    protected void visitService(Service service) {
+        try {
+            JavaInterface intf = (JavaInterface) service.getJavaInterface();
+            String className = env.getNames().customJavaTypeClassName(intf);
+            if (donotOverride && GeneratorUtil.classExists(env, className)) {
+                log("Class " + className + " exists. Not overriding.");
+                return;
+            }
+
+            JDefinedClass cls = getClass(className, ClassType.CLASS);
+
+            cls._extends(javax.xml.ws.Service.class);
+            String serviceFieldName = JAXBRIContext.mangleNameToClassName(service.getName().getLocalPart()).toUpperCase();
+            String wsdlLocationName = serviceFieldName+"_WSDL_LOCATION";
+            JFieldVar urlField = cls.field(JMod.PRIVATE|JMod.STATIC|JMod.FINAL, URL.class, wsdlLocationName);
+            JClass qNameCls = cm.ref(QName.class);
+            JInvocation inv;
+            inv = JExpr._new(qNameCls);
+            inv.arg("namespace");
+            inv.arg("localpart");
+
+
+            JBlock staticBlock = cls.init();
+            URL url = new URL(JAXWSUtils.absolutize(JAXWSUtils.getFileOrURLName(wsdlLocation)));
+            JVar urlVar = staticBlock.decl(cm.ref(URL.class),"url", JExpr._null());
+            JTryBlock tryBlock = staticBlock._try();
+            tryBlock.body().assign(urlVar, createURL(url));
+            JCatchBlock catchBlock = tryBlock._catch(cm.ref(MalformedURLException.class));
+            catchBlock.param("e");
+            catchBlock.body().directStatement("e.printStackTrace();");
+            staticBlock.assign(urlField, urlVar);
+
+            //write class comment - JAXWS warning
+            JDocComment comment = cls.javadoc();
+
+            if(service.getJavaDoc() != null){
+                comment.add(service.getJavaDoc());
+                comment.add("\n\n");
+            }
+
+            for (String doc : getJAXWSClassComment()) {
+                comment.add(doc);
+            }
+
+            JMethod constructor = cls.constructor(JMod.PUBLIC);
+            constructor.param(URL.class, "wsdlLocation");
+            constructor.param(QName.class, "serviceName");
+            constructor.body().directStatement("super(wsdlLocation, serviceName);");
+
+            constructor = cls.constructor(JMod.PUBLIC);
+            constructor.body().directStatement("super("+wsdlLocationName+", new QName(\""+service.getName().getNamespaceURI()+"\", \""+service.getName().getLocalPart()+"\"));");
+
+            //@WebService
+            JAnnotationUse webServiceClientAnn = cls.annotate(cm.ref(WebServiceClient.class));
+            writeWebServiceClientAnnotation(service, webServiceClientAnn);
+
+            //@HandlerChain
+            writeHandlerConfig(env.getNames().customJavaTypeClassName(service.getJavaInterface()), cls, wsdlModelInfo);
+
+            for (Port port: service.getPorts()) {
+                if (port.isProvider()) {
+                    continue;  // No getXYZPort() for porvider based endpoint
+                }
+                //@WebEndpoint
+                JMethod m = null;
+                JDocComment methodDoc = null;
+                JType retType = getClass(port.getJavaInterface().getName(), ClassType.INTERFACE);
+                m = cls.method(JMod.PUBLIC, retType, port.getPortGetter());
+                methodDoc = m.javadoc();
+                if(port.getJavaDoc() != null)
+                    methodDoc.add(port.getJavaDoc());
+                JCommentPart ret = methodDoc.addReturn();
+                ret.add("returns "+retType.name());
+                JBlock body = m.body();
+                StringBuffer statement = new StringBuffer("return (");
+                statement.append(retType.name());
+                statement.append(")super.getPort(new QName(\""+port.getName().getNamespaceURI()+"\", \""+ port.getName().getLocalPart()+"\"), ");
+                statement.append(retType.name());
+                statement.append(".class);");
+                body.directStatement(statement.toString());
+                writeWebEndpoint(port, m);
+            }
+            CodeWriter cw = new WSCodeWriter(sourceDir,env);
+
+            if(env.verbose())
+                cw = new ProgressCodeWriter(cw, System.out);
+            cm.build(cw);
+
+        } catch (IOException e) {
+            throw new GeneratorException(
+                "generator.nestedGeneratorError",
+                e);
+        }
+    }
+
+    protected JDefinedClass getClass(String className, ClassType type) {
+        JDefinedClass cls = null;
+        try {
+            cls = cm._class(className, type);
+        } catch (JClassAlreadyExistsException e){
+            cls = cm._getClass(className);
+        }
+        return cls;
+    }
+
+    private void writeWebServiceClientAnnotation(Service service, JAnnotationUse wsa) {
+        String serviceName = service.getName().getLocalPart();
+        serviceNS = service.getName().getNamespaceURI();
+        wsa.param("name", serviceName);
+        wsa.param("targetNamespace", serviceNS);
+        wsa.param("wsdlLocation", wsdlLocation);
+    }
+
+    private void writeWebEndpoint(Port port, JMethod m) {
+        JAnnotationUse webEndpointAnn = m.annotate(cm.ref(WebEndpoint.class));
+        webEndpointAnn.param("name", port.getName().getLocalPart());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/SimpleToBoxedUtil.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/SimpleToBoxedUtil.java
new file mode 100644
index 0000000..20ba880
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/generator/SimpleToBoxedUtil.java
@@ -0,0 +1,113 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.generator;
+
+import java.util.HashSet;
+import java.util.Set;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public final class SimpleToBoxedUtil {
+
+    public static String getBoxedExpressionOfType(String s, String c) {
+        if (isPrimitive(c)) {
+            StringBuffer sb = new StringBuffer();
+            sb.append("new ");
+            sb.append(getBoxedClassName(c));
+            sb.append('(');
+            sb.append(s);
+            sb.append(')');
+            return sb.toString();
+        } else
+            return s;
+    }
+
+    public static String getUnboxedExpressionOfType(String s, String c) {
+        if (isPrimitive(c)) {
+            StringBuffer sb = new StringBuffer();
+            sb.append('(');
+            sb.append(s);
+            sb.append(").");
+            sb.append(c);
+            sb.append("Value()");
+            return sb.toString();
+        } else
+            return s;
+    }
+
+    public static String convertExpressionFromTypeToType(
+        String s,
+        String from,
+        String to)
+        throws Exception {
+        if (from.equals(to))
+            return s;
+        else {
+            if (!isPrimitive(to) && isPrimitive(from))
+                return getBoxedExpressionOfType(s, from);
+            else if (isPrimitive(to) && isPrimitive(from))
+                return getUnboxedExpressionOfType(s, to);
+            else
+                return s;
+        }
+    }
+
+    public static String getBoxedClassName(String className) {
+        if (isPrimitive(className)) {
+            StringBuffer sb = new StringBuffer();
+            sb.append("java.lang.");
+            if (className.equals(int.class.getName()))
+                sb.append("Integer");
+            else if (className.equals(char.class.getName()))
+                sb.append("Character");
+            else {
+                sb.append(Character.toUpperCase(className.charAt(0)));
+                sb.append(className.substring(1));
+            }
+            return sb.toString();
+        } else
+            return className;
+    }
+
+    public static boolean isPrimitive(String className) {
+        return primitiveSet.contains(className);
+    }
+
+    static Set primitiveSet = null;
+
+    static {
+        primitiveSet = new HashSet();
+        primitiveSet.add("boolean");
+        primitiveSet.add("byte");
+        primitiveSet.add("double");
+        primitiveSet.add("float");
+        primitiveSet.add("int");
+        primitiveSet.add("long");
+        primitiveSet.add("short");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AbstractType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AbstractType.java
new file mode 100644
index 0000000..56aadfb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AbstractType.java
@@ -0,0 +1,146 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.java.JavaType;
+import com.sun.xml.internal.ws.util.NullIterator;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public abstract class AbstractType {
+
+    protected AbstractType() {}
+
+    protected AbstractType(QName name) {
+        this(name, null, null);
+    }
+
+    protected AbstractType(QName name, String version) {
+        this(name, null, version);
+    }
+
+    protected AbstractType(QName name, JavaType javaType) {
+        this(name, javaType, null);
+    }
+
+    protected AbstractType(QName name, JavaType javaType, String version) {
+        this.name = name;
+        this.javaType = javaType;
+        this.version = version;
+    }
+
+    public QName getName() {
+        return name;
+    }
+
+    public void setName(QName name) {
+        this.name = name;
+    }
+
+    public JavaType getJavaType() {
+        return javaType;
+    }
+
+    public void setJavaType(JavaType javaType) {
+        this.javaType = javaType;
+    }
+
+    public String getVersion() {
+        return version;
+    }
+
+    public void setVersion(String version) {
+        this.version = version;
+    }
+
+    public boolean isNillable() {
+        return false;
+    }
+
+    public boolean isSOAPType() {
+        return false;
+    }
+
+    public boolean isLiteralType() {
+        return false;
+    }
+
+    public Object getProperty(String key) {
+        if (properties == null) {
+            return null;
+        }
+        return properties.get(key);
+    }
+
+    public void setProperty(String key, Object value) {
+        if (value == null) {
+            removeProperty(key);
+            return;
+        }
+
+        if (properties == null) {
+            properties = new HashMap();
+        }
+        properties.put(key, value);
+    }
+
+    public void removeProperty(String key) {
+        if (properties != null) {
+            properties.remove(key);
+        }
+    }
+
+    public Iterator getProperties() {
+        if (properties == null) {
+            return NullIterator.getInstance();
+        } else {
+            return properties.keySet().iterator();
+        }
+    }
+
+    /* serialization */
+    public Map getPropertiesMap() {
+        return properties;
+    }
+
+    /* serialization */
+    public void setPropertiesMap(Map m) {
+        properties = m;
+    }
+
+    private QName name;
+    private JavaType javaType;
+    private String version = null;
+    private Map properties;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AsyncOperation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AsyncOperation.java
new file mode 100644
index 0000000..282c3ea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AsyncOperation.java
@@ -0,0 +1,132 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBType;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBTypeAndAnnotation;
+import com.sun.tools.internal.ws.processor.model.java.JavaType;
+import com.sun.tools.internal.ws.processor.model.java.JavaSimpleType;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+
+
+/**
+ * @author Vivek Pandey
+ *
+ *
+ */
+public class AsyncOperation extends Operation {
+
+    /**
+     *
+     */
+    public AsyncOperation() {
+        super();
+        // TODO Auto-generated constructor stub
+    }
+
+    /**
+     * @param operation
+     */
+    public AsyncOperation(Operation operation) {
+        super(operation);
+        this.operation = operation;
+    }
+
+    /**
+     * @param name
+     */
+    public AsyncOperation(QName name) {
+        super(name);
+        // TODO Auto-generated constructor stub
+    }
+
+    /**
+     * @return Returns the async.
+     */
+    public boolean isAsync() {
+        return _async;
+    }
+
+    public void setAsyncType(AsyncOperationType type) {
+        this._asyncOpType = type;
+        _async = true;
+    }
+
+    public AsyncOperationType getAsyncType(){
+        return _asyncOpType;
+    }
+
+    public void setResponseBean(AbstractType type){
+        _responseBean = type;
+    }
+
+    public AbstractType getResponseBeanType(){
+        return _responseBean;
+    }
+
+    public JavaType getResponseBeanJavaType(){
+        JCodeModel cm = _responseBean.getJavaType().getType().getType().owner();
+        if(_asyncOpType.equals(AsyncOperationType.CALLBACK)){
+            JClass future = cm.ref(java.util.concurrent.Future.class).narrow(cm.ref(Object.class).wildcard());
+            return new JavaSimpleType(new JAXBTypeAndAnnotation(future));
+        }else if(_asyncOpType.equals(AsyncOperationType.POLLING)){
+            JClass polling = cm.ref(javax.xml.ws.Response.class).narrow(_responseBean.getJavaType().getType().getType().boxify());
+            return new JavaSimpleType(new JAXBTypeAndAnnotation(polling));
+        }
+        return null;
+    }
+
+    public JavaType getCallBackType(){
+        if(_asyncOpType.equals(AsyncOperationType.CALLBACK)){
+            JCodeModel cm = _responseBean.getJavaType().getType().getType().owner();
+            JClass cb = cm.ref(javax.xml.ws.AsyncHandler.class).narrow(_responseBean.getJavaType().getType().getType().boxify());
+            return new JavaSimpleType(new JAXBTypeAndAnnotation(cb));
+
+        }
+        return null;
+    }
+
+    public Operation getNormalOperation(){
+        return operation;
+    }
+
+    public void setNormalOperation(Operation operation){
+        this.operation = operation;
+    }
+
+    @Override public String getJavaMethodName() {
+        return super.getJavaMethodName() + "Async";
+    }
+
+    //Normal operation
+    private Operation operation;
+    private boolean _async;
+    private AsyncOperationType _asyncOpType;
+    private AbstractType _responseBean;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AsyncOperationType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AsyncOperationType.java
new file mode 100644
index 0000000..2875899
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/AsyncOperationType.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model;
+
+
+
+/**
+ * @author Vivek Pandey
+ *
+ * Async Operation type
+ */
+public final class AsyncOperationType {
+
+    public static final AsyncOperationType POLLING = new AsyncOperationType();
+    public static final AsyncOperationType CALLBACK = new AsyncOperationType();
+
+    private AsyncOperationType() {
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Block.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Block.java
new file mode 100644
index 0000000..5732853
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Block.java
@@ -0,0 +1,91 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model;
+
+import javax.xml.namespace.QName;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Block extends ModelObject {
+
+    public static final int UNBOUND = 0;
+    public static final int BODY   = 1;
+    public static final int HEADER = 2;
+    public static final int ATTACHMENT = 3;
+
+    public Block() {}
+
+    public Block(QName name) {
+        this.name = name;
+    }
+
+    public Block(QName name, AbstractType type) {
+        this.name = name;
+        this.type = type;
+    }
+
+    public QName getName() {
+        return name;
+    }
+
+    public void setName(QName n) {
+        name = n;
+    }
+
+    public AbstractType getType() {
+        return type;
+    }
+
+    public void setType(AbstractType type) {
+        this.type = type;
+    }
+
+    public int getLocation() {
+        return location;
+    }
+
+    public void setLocation(int i) {
+        location = i;
+    }
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    private QName name;
+    private AbstractType type;
+    private int location;
+
+    /**
+     * @return true if the block is unbound
+     */
+    public boolean isUnbound() {
+        if(location == UNBOUND)
+            return true;
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ExtendedModelVisitor.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ExtendedModelVisitor.java
new file mode 100644
index 0000000..4897843
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ExtendedModelVisitor.java
@@ -0,0 +1,137 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.Iterator;
+
+/**
+ *
+ * A model visitor incorporating all the logic required to walk through the model.
+ *
+ * @author WS Development Team
+ */
+public class ExtendedModelVisitor {
+
+    public ExtendedModelVisitor() {}
+
+    public void visit(Model model) throws Exception {
+        preVisit(model);
+        for (Service service : model.getServices()) {
+            preVisit(service);
+            for (Port port : service.getPorts()) {
+                preVisit(port);
+                if (shouldVisit(port)) {
+                    for (Operation operation : port.getOperations()) {
+                        preVisit(operation);
+                        Request request = operation.getRequest();
+                        if (request != null) {
+                            preVisit(request);
+                            for (Iterator iter4 = request.getHeaderBlocks();
+                                iter4.hasNext();) {
+
+                                Block block = (Block) iter4.next();
+                                visitHeaderBlock(block);
+                            }
+                            for (Iterator iter4 = request.getBodyBlocks();
+                                iter4.hasNext();) {
+
+                                Block block = (Block) iter4.next();
+                                visitBodyBlock(block);
+                            }
+                            for (Iterator iter4 = request.getParameters();
+                                iter4.hasNext();) {
+
+                                Parameter parameter = (Parameter) iter4.next();
+                                visit(parameter);
+                            }
+                            postVisit(request);
+                        }
+
+                        Response response = operation.getResponse();
+                        if (response != null) {
+                            preVisit(response);
+                            for (Iterator iter4 = response.getHeaderBlocks();
+                                iter4.hasNext();) {
+
+                                Block block = (Block) iter4.next();
+                                visitHeaderBlock(block);
+                            }
+                            for (Iterator iter4 = response.getBodyBlocks();
+                                iter4.hasNext();) {
+
+                                Block block = (Block) iter4.next();
+                                visitBodyBlock(block);
+                            }
+                            for (Iterator iter4 = response.getParameters();
+                                iter4.hasNext();) {
+
+                                Parameter parameter = (Parameter) iter4.next();
+                                visit(parameter);
+                            }
+                            postVisit(response);
+                        }
+
+                        for (Iterator iter4 = operation.getFaults();
+                            iter4.hasNext();) {
+
+                            Fault fault = (Fault) iter4.next();
+                            preVisit(fault);
+                            visitFaultBlock(fault.getBlock());
+                            postVisit(fault);
+                        }
+                        postVisit(operation);
+                    }
+                }
+                postVisit(port);
+            }
+            postVisit(service);
+        }
+        postVisit(model);
+    }
+
+    protected boolean shouldVisit(Port port) {
+        return true;
+    }
+
+    // these methods are intended for subclasses
+    protected void preVisit(Model model) throws Exception {}
+    protected void postVisit(Model model) throws Exception {}
+    protected void preVisit(Service service) throws Exception {}
+    protected void postVisit(Service service) throws Exception {}
+    protected void preVisit(Port port) throws Exception {}
+    protected void postVisit(Port port) throws Exception {}
+    protected void preVisit(Operation operation) throws Exception {}
+    protected void postVisit(Operation operation) throws Exception {}
+    protected void preVisit(Request request) throws Exception {}
+    protected void postVisit(Request request) throws Exception {}
+    protected void preVisit(Response response) throws Exception {}
+    protected void postVisit(Response response) throws Exception {}
+    protected void preVisit(Fault fault) throws Exception {}
+    protected void postVisit(Fault fault) throws Exception {}
+    protected void visitBodyBlock(Block block) throws Exception {}
+    protected void visitHeaderBlock(Block block) throws Exception {}
+    protected void visitFaultBlock(Block block) throws Exception {}
+    protected void visit(Parameter parameter) throws Exception {}
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Fault.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Fault.java
new file mode 100644
index 0000000..4b62705
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Fault.java
@@ -0,0 +1,190 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Set;
+import java.util.TreeSet;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.generator.GeneratorUtil;
+import com.sun.tools.internal.ws.processor.model.java.JavaException;
+import com.sun.codemodel.internal.JClass;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Fault extends ModelObject {
+
+    public Fault() {}
+
+    public Fault(String name) {
+        this.name = name;
+        parentFault = null;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public void setName(String s) {
+        name = s;
+    }
+
+    public Block getBlock() {
+        return block;
+    }
+
+    public void setBlock(Block b) {
+        block = b;
+    }
+
+    public JavaException getJavaException() {
+        return javaException;
+    }
+
+    public void setJavaException(JavaException e) {
+        javaException = e;
+    }
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    public Fault getParentFault() {
+        return parentFault;
+    }
+
+    public void setParentFault(Fault parentFault) {
+        if (this.parentFault != null &&
+            parentFault != null &&
+            !this.parentFault.equals(parentFault)) {
+
+            throw new ModelException("model.parent.fault.already.set",
+                new Object[] {
+                    getName(),
+                    this.parentFault.getName(),
+                    parentFault.getName()
+            });
+        }
+        this.parentFault = parentFault;
+    }
+
+    public void addSubfault(Fault fault) {
+        subfaults.add(fault);
+        fault.setParentFault(this);
+    }
+
+    public Iterator getSubfaults() {
+        if (subfaults.size() == 0) {
+            return null;
+        }
+        return subfaults.iterator();
+    }
+
+    public Iterator getSortedSubfaults() {
+        Set sortedFaults = new TreeSet(new GeneratorUtil.FaultComparator());
+        sortedFaults.addAll(subfaults);
+        return sortedFaults.iterator();
+    }
+
+    /* serialization */
+    public Set getSubfaultsSet() {
+        return subfaults;
+    }
+
+    /* serialization */
+    public void setSubfaultsSet(Set s) {
+        subfaults = s;
+    }
+
+    public Iterator getAllFaults() {
+        Set allFaults = getAllFaultsSet();
+        if (allFaults.size() == 0) {
+            return null;
+        }
+        return allFaults.iterator();
+    }
+
+    public Set getAllFaultsSet() {
+        Set transSet = new HashSet();
+        Iterator iter = subfaults.iterator();
+        while (iter.hasNext()) {
+            transSet.addAll(((Fault)iter.next()).getAllFaultsSet());
+        }
+        transSet.addAll(subfaults);
+        return transSet;
+    }
+
+    public QName getElementName() {
+        return elementName;
+    }
+
+    public void setElementName(QName elementName) {
+        this.elementName = elementName;
+    }
+
+    public String getJavaMemberName() {
+        return javaMemberName;
+    }
+
+    public void setJavaMemberName(String javaMemberName) {
+        this.javaMemberName = javaMemberName;
+    }
+
+    /**
+     * @return Returns the wsdlFault.
+     */
+    public boolean isWsdlException() {
+            return wsdlException;
+    }
+    /**
+     * @param wsdlFault The wsdlFault to set.
+     */
+    public void setWsdlException(boolean wsdlFault) {
+            this.wsdlException = wsdlFault;
+    }
+
+    public void setExceptionClass(JClass ex){
+        exceptionClass = ex;
+    }
+
+    public JClass getExceptionClass(){
+        return exceptionClass;
+    }
+
+    private boolean wsdlException = true;
+    private String name;
+    private Block block;
+    private JavaException javaException;
+    private Fault parentFault;
+    private Set subfaults = new HashSet();
+    private QName elementName = null;
+    private String javaMemberName = null;
+    private JClass exceptionClass;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/HeaderFault.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/HeaderFault.java
new file mode 100644
index 0000000..bf9ad8f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/HeaderFault.java
@@ -0,0 +1,55 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model;
+
+import javax.xml.namespace.QName;
+
+public class HeaderFault extends Fault {
+
+    public HeaderFault() {}
+
+    public HeaderFault(String name) {
+        super(name);
+    }
+
+    public QName getMessage() {
+        return _message;
+    }
+
+    public void setMessage(QName message) {
+        _message = message;
+    }
+
+    public String getPart() {
+        return _part;
+    }
+
+    public void setPart(String part) {
+        _part = part;
+    }
+
+    private QName _message;
+    private String _part;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Message.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Message.java
new file mode 100644
index 0000000..ed807ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Message.java
@@ -0,0 +1,228 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public abstract class Message extends ModelObject {
+
+    public void addBodyBlock(Block b) {
+        if (_bodyBlocks.containsKey(b.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        _bodyBlocks.put(b.getName(), b);
+        b.setLocation(Block.BODY);
+    }
+
+    public Iterator<Block> getBodyBlocks() {
+        return _bodyBlocks.values().iterator();
+    }
+
+    public int getBodyBlockCount() {
+        return _bodyBlocks.size();
+    }
+
+    /* serialization */
+    public Map<QName, Block> getBodyBlocksMap() {
+        return _bodyBlocks;
+    }
+
+    /* serialization */
+    public void setBodyBlocksMap(Map<QName, Block> m) {
+        _bodyBlocks = m;
+    }
+
+    public boolean isBodyEmpty() {
+        return getBodyBlocks().hasNext();
+    }
+
+    public boolean isBodyEncoded() {
+        boolean isEncoded = false;
+        for (Iterator iter = getBodyBlocks(); iter.hasNext();) {
+            Block bodyBlock = (Block) iter.next();
+            if (bodyBlock.getType().isSOAPType()) {
+                isEncoded = true;
+            }
+        }
+        return isEncoded;
+    }
+
+    public void addHeaderBlock(Block b) {
+        if (_headerBlocks.containsKey(b.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        _headerBlocks.put(b.getName(), b);
+        b.setLocation(Block.HEADER);
+    }
+
+    public Iterator<Block> getHeaderBlocks() {
+        return _headerBlocks.values().iterator();
+    }
+
+    public Collection<Block> getHeaderBlockCollection() {
+        return _headerBlocks.values();
+    }
+
+    public int getHeaderBlockCount() {
+        return _headerBlocks.size();
+    }
+
+    /* serialization */
+    public Map<QName, Block> getHeaderBlocksMap() {
+        return _headerBlocks;
+    }
+
+    /* serialization */
+    public void setHeaderBlocksMap(Map<QName, Block> m) {
+        _headerBlocks = m;
+    }
+
+    /** attachment block */
+    public void addAttachmentBlock(Block b) {
+        if (_attachmentBlocks.containsKey(b.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        _attachmentBlocks.put(b.getName(), b);
+        b.setLocation(Block.ATTACHMENT);
+    }
+
+    public void addUnboundBlock(Block b) {
+        if (_unboundBlocks.containsKey(b.getName())) {
+            return;
+        }
+        _unboundBlocks.put(b.getName(), b);
+        b.setLocation(Block.UNBOUND);
+    }
+
+    public Iterator<Block> getUnboundBlocks() {
+        return _unboundBlocks.values().iterator();
+    }
+
+    /* serialization */
+    public Map<QName, Block> getUnboundBlocksMap() {
+        return _unboundBlocks;
+    }
+
+    public int getUnboundBlocksCount() {
+        return _unboundBlocks.size();
+    }
+
+    /* serialization */
+    public void setUnboundBlocksMap(Map<QName, Block> m) {
+        _unboundBlocks = m;
+    }
+
+
+    public Iterator<Block> getAttachmentBlocks() {
+        return _attachmentBlocks.values().iterator();
+    }
+
+    public int getAttachmentBlockCount () {
+        return _attachmentBlocks.size();
+    }
+
+        /* serialization */
+    public Map<QName, Block> getAttachmentBlocksMap() {
+        return _attachmentBlocks;
+    }
+
+    /* serialization */
+    public void setAttachmentBlocksMap(Map<QName, Block> m) {
+        _attachmentBlocks = m;
+    }
+
+    public void addParameter(Parameter p) {
+        if (_parametersByName.containsKey(p.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        _parameters.add(p);
+        _parametersByName.put(p.getName(), p);
+    }
+
+    public Parameter getParameterByName(String name) {
+        if (_parametersByName.size() != _parameters.size()) {
+            initializeParametersByName();
+        }
+        return (Parameter) _parametersByName.get(name);
+    }
+
+    public Iterator<Parameter> getParameters() {
+        return _parameters.iterator();
+    }
+
+    /* serialization */
+    public List<Parameter> getParametersList() {
+        return _parameters;
+    }
+
+    /* serialization */
+    public void setParametersList(List<Parameter> l) {
+        _parameters = l;
+    }
+
+    private void initializeParametersByName() {
+        _parametersByName = new HashMap();
+        if (_parameters != null) {
+            for (Iterator iter = _parameters.iterator(); iter.hasNext();) {
+                Parameter param = (Parameter) iter.next();
+                if (param.getName() != null &&
+                    _parametersByName.containsKey(param.getName())) {
+
+                    throw new ModelException("model.uniqueness");
+                }
+                _parametersByName.put(param.getName(), param);
+            }
+        }
+    }
+
+    public Set<Block> getAllBlocks(){
+        Set<Block> blocks = new HashSet<Block>();
+        blocks.addAll(_bodyBlocks.values());
+        blocks.addAll(_headerBlocks.values());
+        blocks.addAll(_attachmentBlocks.values());
+        return blocks;
+    }
+
+    private Map<QName, Block> _attachmentBlocks = new HashMap<QName, Block>();
+    private Map<QName, Block> _bodyBlocks = new HashMap<QName, Block>();
+    private Map<QName, Block> _headerBlocks = new HashMap<QName, Block>();
+    private Map<QName, Block> _unboundBlocks = new HashMap<QName, Block>();
+    private List<Parameter> _parameters = new ArrayList<Parameter>();
+    private Map<String, Parameter> _parametersByName = new HashMap<String, Parameter>();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Model.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Model.java
new file mode 100644
index 0000000..59ae490
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Model.java
@@ -0,0 +1,189 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.EnumSet;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBModel;
+import com.sun.tools.internal.ws.processor.ProcessorActionVersion;
+
+/**
+ * The model is used to represent the entire Web Service.  The JAX-WS ProcessorActions can process
+ * this Model to generate Java artifacts such as the service interface.
+ *
+ * @author WS Development Team
+ */
+public class Model extends ModelObject {
+
+    public Model() {
+    }
+
+    public Model(QName name) {
+        this.name = name;
+    }
+
+    public QName getName() {
+        return name;
+    }
+
+    public void setName(QName n) {
+        name = n;
+    }
+
+    public String getTargetNamespaceURI() {
+        return targetNamespace;
+    }
+
+    public void setTargetNamespaceURI(String s) {
+        targetNamespace = s;
+    }
+
+    public void addService(Service service) {
+        if (servicesByName.containsKey(service.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        services.add(service);
+        servicesByName.put(service.getName(), service);
+    }
+
+    public Service getServiceByName(QName name) {
+        if (servicesByName.size() != services.size()) {
+            initializeServicesByName();
+        }
+        return (Service)servicesByName.get(name);
+    }
+
+    /* serialization */
+    public List<Service> getServices() {
+        return services;
+    }
+
+    /* serialization */
+    public void setServices(List<Service> l) {
+        services = l;
+    }
+
+    private void initializeServicesByName() {
+        servicesByName = new HashMap();
+        if (services != null) {
+            for (Service service : services) {
+                if (service.getName() != null &&
+                    servicesByName.containsKey(service.getName())) {
+
+                    throw new ModelException("model.uniqueness");
+                }
+                servicesByName.put(service.getName(), service);
+            }
+        }
+    }
+
+    public void addExtraType(AbstractType type) {
+        extraTypes.add(type);
+    }
+
+    public Iterator getExtraTypes() {
+        return extraTypes.iterator();
+    }
+
+    /* serialization */
+    public Set<AbstractType> getExtraTypesSet() {
+        return extraTypes;
+    }
+
+    /* serialization */
+    public void setExtraTypesSet(Set<AbstractType> s) {
+        extraTypes = s;
+    }
+
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    /**
+     * @return the source version
+     */
+    public String getSource() {
+        return source;
+    }
+
+    /**
+     * @param string
+     */
+    public void setSource(String string) {
+        source = string;
+    }
+
+    public ProcessorActionVersion getProcessorActionVersion(){
+        return processorActionVersion;
+    }
+
+    public void setProcessorActionVersion(ProcessorActionVersion version){
+        this.processorActionVersion = version;
+    }
+
+    public void setProcessorActionVersion(String version){
+        for(ProcessorActionVersion paVersion : EnumSet.allOf(ProcessorActionVersion.class)){
+            switch(paVersion){
+                case PRE_20:
+                    if(version.equals(ProcessorActionVersion.PRE_20.toString()))
+                        processorActionVersion = ProcessorActionVersion.PRE_20;
+                    break;
+                case VERSION_20:
+                    if(version.equals(ProcessorActionVersion.VERSION_20.toString()))
+                        processorActionVersion = ProcessorActionVersion.VERSION_20;
+                    break;
+                default:
+                    throw new ModelException("model.invalid.processorActionVersion", new Object[]{version});
+            }
+        }
+    }
+
+    public void setJAXBModel(JAXBModel jaxBModel) {
+        this.jaxBModel = jaxBModel;
+    }
+
+    public JAXBModel getJAXBModel() {
+        return jaxBModel;
+    }
+
+    private QName name;
+    private String targetNamespace;
+    private List<Service> services = new ArrayList<Service>();
+    private Map<QName, Service> servicesByName = new HashMap<QName, Service>();
+    private Set<AbstractType> extraTypes = new HashSet<AbstractType>();
+    private String source;
+    private JAXBModel jaxBModel = null;
+    private ProcessorActionVersion processorActionVersion = ProcessorActionVersion.VERSION_20;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelException.java
new file mode 100644
index 0000000..11b49a7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelException.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import com.sun.tools.internal.ws.processor.ProcessorException;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * ModelException represents an exception that occurred while
+ * visiting service model.
+ *
+ * @see ProcessorException
+ *
+ * @author WS Development Team
+ */
+public class ModelException extends ProcessorException {
+
+    public ModelException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ModelException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public ModelException(Localizable arg) {
+        super("model.nestedModelError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.model";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelObject.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelObject.java
new file mode 100644
index 0000000..c0c47ea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelObject.java
@@ -0,0 +1,95 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+
+import com.sun.xml.internal.ws.util.NullIterator;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public abstract class ModelObject {
+
+    public abstract void accept(ModelVisitor visitor) throws Exception;
+
+    public Object getProperty(String key) {
+        if (_properties == null) {
+            return null;
+        }
+        return _properties.get(key);
+    }
+
+    public void setProperty(String key, Object value) {
+        if (value == null) {
+            removeProperty(key);
+            return;
+        }
+
+        if (_properties == null) {
+            _properties = new HashMap();
+        }
+        _properties.put(key, value);
+    }
+
+    public void removeProperty(String key) {
+        if (_properties != null) {
+            _properties.remove(key);
+        }
+    }
+
+    public Iterator getProperties() {
+        if (_properties == null) {
+            return NullIterator.getInstance();
+        } else {
+            return _properties.keySet().iterator();
+        }
+    }
+
+    /* serialization */
+    public Map getPropertiesMap() {
+        return _properties;
+    }
+
+    /* serialization */
+    public void setPropertiesMap(Map m) {
+        _properties = m;
+    }
+
+    public String getJavaDoc() {
+        return javaDoc;
+    }
+
+    public void setJavaDoc(String javaDoc) {
+        this.javaDoc = javaDoc;
+    }
+
+    private String javaDoc;
+    private Map _properties;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelProperties.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelProperties.java
new file mode 100644
index 0000000..abea8d6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelProperties.java
@@ -0,0 +1,76 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface ModelProperties {
+
+    //to set WSDL_MODELER_NAME from inside WSDLModeler
+    public static final String WSDL_MODELER_NAME =
+        "com.sun.xml.internal.ws.processor.modeler.wsdl.WSDLModeler";
+    public static final String PROPERTY_PARAM_MESSAGE_PART_NAME =
+        "com.sun.xml.internal.ws.processor.model.ParamMessagePartName";
+    public static final String PROPERTY_ANONYMOUS_TYPE_NAME =
+        "com.sun.xml.internal.ws.processor.model.AnonymousTypeName";
+    public static final String PROPERTY_ANONYMOUS_ARRAY_TYPE_NAME =
+        "com.sun.xml.internal.ws.processor.model.AnonymousArrayTypeName";
+    public static final String PROPERTY_ANONYMOUS_ARRAY_JAVA_TYPE =
+        "com.sun.xml.internal.ws.processor.model.AnonymousArrayJavaType";
+
+    public static final String PROPERTY_PTIE_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.PtieClassName";
+    public static final String PROPERTY_EPTFF_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.EPTFFClassName";
+    public static final String PROPERTY_SED_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.SEDClassName";
+        public static final String PROPERTY_WSDL_PORT_NAME =
+        "com.sun.xml.internal.ws.processor.model.WSDLPortName";
+    public static final String PROPERTY_WSDL_PORT_TYPE_NAME =
+        "com.sun.xml.internal.ws.processor.model.WSDLPortTypeName";
+    public static final String PROPERTY_WSDL_BINDING_NAME =
+        "com.sun.xml.internal.ws.processor.model.WSDLBindingName";
+    public static final String PROPERTY_WSDL_MESSAGE_NAME =
+        "com.sun.xml.internal.ws.processor.model.WSDLMessageName";
+    public static final String PROPERTY_MODELER_NAME =
+        "com.sun.xml.internal.ws.processor.model.ModelerName";
+    public static final String PROPERTY_STUB_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.StubClassName";
+    public static final String PROPERTY_STUB_OLD_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.StubOldClassName";
+    public static final String PROPERTY_DELEGATE_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.DelegateClassName";
+    public static final String PROPERTY_CLIENT_ENCODER_DECODER_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.ClientEncoderClassName";
+    public static final String PROPERTY_CLIENT_CONTACTINFOLIST_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.ClientContactInfoListClassName";
+    public static final String PROPERTY_TIE_CLASS_NAME =
+        "com.sun.xml.internal.ws.processor.model.TieClassName";
+    public static final String PROPERTY_JAVA_PORT_NAME =
+        "com.sun.xml.internal.ws.processor.model.JavaPortName";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelVisitor.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelVisitor.java
new file mode 100644
index 0000000..b28755e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/ModelVisitor.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface ModelVisitor {
+    public void visit(Model model) throws Exception;
+    public void visit(Service service) throws Exception;
+    public void visit(Port port) throws Exception;
+    public void visit(Operation operation) throws Exception;
+    public void visit(Request request) throws Exception;
+    public void visit(Response response) throws Exception;
+    public void visit(Fault fault) throws Exception;
+    public void visit(Block block) throws Exception;
+    public void visit(Parameter parameter) throws Exception;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Operation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Operation.java
new file mode 100644
index 0000000..6b482ee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Operation.java
@@ -0,0 +1,242 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import com.sun.tools.internal.ws.processor.model.java.JavaMethod;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPStyle;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPUse;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+
+import javax.xml.namespace.QName;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Set;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Operation extends ModelObject {
+
+    public Operation() {}
+
+    public Operation(Operation operation){
+        this(operation._name);
+        this._style = operation._style;
+        this._use = operation._use;
+        this.customizedName = operation.customizedName;
+    }
+    public Operation(QName name) {
+        _name = name;
+        _uniqueName = name.getLocalPart();
+        _faultNames = new HashSet<String>();
+        _faults = new HashSet<Fault>();
+    }
+
+    public QName getName() {
+        return _name;
+    }
+
+    public void setName(QName n) {
+        _name = n;
+    }
+
+    public String getUniqueName() {
+        return _uniqueName;
+    }
+
+    public void setUniqueName(String s) {
+        _uniqueName = s;
+    }
+
+    public Request getRequest() {
+        return _request;
+    }
+
+    public void setRequest(Request r) {
+        _request = r;
+    }
+
+    public Response getResponse() {
+        return _response;
+    }
+
+    public void setResponse(Response r) {
+        _response = r;
+    }
+
+    public boolean isOverloaded() {
+        return !_name.getLocalPart().equals(_uniqueName);
+    }
+
+    public void addFault(Fault f) {
+        if (_faultNames.contains(f.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        _faultNames.add(f.getName());
+        _faults.add(f);
+    }
+
+    public Iterator<Fault> getFaults() {
+        return _faults.iterator();
+    }
+
+    public Set<Fault> getFaultsSet() {
+        return _faults;
+    }
+
+    /* serialization */
+    public void setFaultsSet(Set<Fault> s) {
+        _faults = s;
+        initializeFaultNames();
+    }
+
+    private void initializeFaultNames() {
+        _faultNames = new HashSet<String>();
+        if (_faults != null) {
+            for (Iterator iter = _faults.iterator(); iter.hasNext();) {
+                Fault f = (Fault) iter.next();
+                if (f.getName() != null && _faultNames.contains(f.getName())) {
+                    throw new ModelException("model.uniqueness");
+                }
+                _faultNames.add(f.getName());
+            }
+        }
+    }
+
+    public Iterator<Fault> getAllFaults() {
+        Set<Fault> allFaults = getAllFaultsSet();
+        return allFaults.iterator();
+    }
+
+    public Set<Fault> getAllFaultsSet() {
+        Set transSet = new HashSet();
+        transSet.addAll(_faults);
+        Iterator iter = _faults.iterator();
+        Fault fault;
+        Set tmpSet;
+        while (iter.hasNext()) {
+            tmpSet = ((Fault)iter.next()).getAllFaultsSet();
+            transSet.addAll(tmpSet);
+        }
+        return transSet;
+    }
+
+    public int getFaultCount() {
+        return _faults.size();
+    }
+
+    public Set<Block> getAllFaultBlocks(){
+        Set<Block> blocks = new HashSet<Block>();
+        Iterator faults = _faults.iterator();
+        while(faults.hasNext()){
+            Fault f = (Fault)faults.next();
+            blocks.add(f.getBlock());
+        }
+        return blocks;
+    }
+
+    public JavaMethod getJavaMethod() {
+        return _javaMethod;
+    }
+
+    public void setJavaMethod(JavaMethod i) {
+        _javaMethod = i;
+    }
+
+    public String getSOAPAction() {
+        return _soapAction;
+    }
+
+    public void setSOAPAction(String s) {
+        _soapAction = s;
+    }
+
+    public SOAPStyle getStyle() {
+        return _style;
+    }
+
+    public void setStyle(SOAPStyle s) {
+        _style = s;
+    }
+
+    public SOAPUse getUse() {
+        return _use;
+    }
+
+    public void setUse(SOAPUse u) {
+        _use = u;
+    }
+
+    public boolean isWrapped() {
+        return _isWrapped;
+    }
+
+    public void setWrapped(boolean isWrapped) {
+        _isWrapped = isWrapped;
+    }
+
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    public void setCustomizedName(String name){
+        this.customizedName = name;
+    }
+
+    public String getCustomizedName(){
+        return customizedName;
+    }
+
+    public String getJavaMethodName(){
+        //if JavaMethod is created return the name
+        if(_javaMethod != null){
+            return _javaMethod.getName();
+        }
+
+        //return the customized operation name if any without mangling
+        if(customizedName != null){
+            return customizedName;
+        }
+
+        return JAXBRIContext.mangleNameToVariableName(_name.getLocalPart());
+    }
+
+    private String customizedName;
+    private boolean _isWrapped = true;
+    private QName _name;
+    private String _uniqueName;
+    private Request _request;
+    private Response _response;
+    private JavaMethod _javaMethod;
+    private String _soapAction;
+    private SOAPStyle _style = SOAPStyle.DOCUMENT;
+    private SOAPUse _use = SOAPUse.LITERAL;
+    private Set<String> _faultNames;
+    private Set<Fault> _faults;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Parameter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Parameter.java
new file mode 100644
index 0000000..4f220ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Parameter.java
@@ -0,0 +1,178 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import com.sun.tools.internal.ws.processor.model.java.JavaParameter;
+import com.sun.xml.internal.ws.model.Mode;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Parameter extends ModelObject {
+
+    public Parameter() {}
+
+    public Parameter(String name) {
+        this.name = name;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public void setName(String s) {
+        name = s;
+    }
+
+    public JavaParameter getJavaParameter() {
+        return javaParameter;
+    }
+
+    public void setJavaParameter(JavaParameter p) {
+        javaParameter = p;
+    }
+
+    public AbstractType getType() {
+        return type;
+    }
+
+    public void setType(AbstractType t) {
+        type = t;
+    }
+
+    public String getTypeName() {
+        return typeName;
+    }
+
+    public void setTypeName(String t) {
+        typeName = t;
+    }
+
+    public Block getBlock() {
+        return block;
+    }
+
+    public void setBlock(Block d) {
+        block = d;
+    }
+
+    public Parameter getLinkedParameter() {
+        return link;
+    }
+
+    public void setLinkedParameter(Parameter p) {
+        link = p;
+    }
+
+    public boolean isEmbedded() {
+        return embedded;
+    }
+
+    public void setEmbedded(boolean b) {
+        embedded = b;
+    }
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    private String name;
+    private JavaParameter javaParameter;
+    private AbstractType type;
+    private Block block;
+    private Parameter link;
+    private boolean embedded;
+    private String typeName;
+    private String customName;
+    private Mode mode;
+
+    public int getParameterIndex() {
+        return parameterOrderPosition;
+    }
+
+    public void setParameterIndex(int parameterOrderPosition) {
+        this.parameterOrderPosition = parameterOrderPosition;
+    }
+
+    public boolean isReturn(){
+        return (parameterOrderPosition == -1);
+    }
+
+    // 0 is the first parameter, -1 is the return type
+    private int parameterOrderPosition;
+    /**
+     * @return Returns the customName.
+     */
+    public String getCustomName() {
+        return customName;
+    }
+    /**
+     * @param customName The customName to set.
+     */
+    public void setCustomName(String customName) {
+        this.customName = customName;
+    }
+
+    private List<String> annotations = new ArrayList<String>();
+
+    /**
+     * @return Returns the annotations.
+     */
+    public List<String> getAnnotations() {
+        return annotations;
+    }
+
+
+    /**
+     * @param annotations The annotations to set.
+     */
+    public void setAnnotations(List<String> annotations) {
+        this.annotations = annotations;
+    }
+
+    public void setMode(Mode mode){
+        this.mode = mode;
+    }
+
+    public boolean isIN(){
+        return (mode == Mode.IN);
+    }
+
+    public boolean isOUT(){
+        return (mode == Mode.OUT);
+    }
+
+    public boolean isINOUT(){
+        return (mode == Mode.INOUT);
+    }
+
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Port.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Port.java
new file mode 100644
index 0000000..a5680b6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Port.java
@@ -0,0 +1,211 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.config.HandlerChainInfo;
+import com.sun.tools.internal.ws.processor.model.java.JavaInterface;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPUse;
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPStyle;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPUse;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Port extends ModelObject {
+
+    public Port() {}
+
+    public Port(QName name) {
+        _name = name;
+    }
+
+    public QName getName() {
+        return _name;
+    }
+
+    public void setName(QName n) {
+        _name = n;
+    }
+
+    public void addOperation(Operation operation) {
+        _operations.add(operation);
+        operationsByName.put(operation.getUniqueName(), operation);
+    }
+
+    public Operation getOperationByUniqueName(String name) {
+        if (operationsByName.size() != _operations.size()) {
+            initializeOperationsByName();
+        }
+        return (Operation)operationsByName.get(name);
+    }
+
+    private void initializeOperationsByName() {
+        operationsByName = new HashMap();
+        if (_operations != null) {
+            for (Operation operation : _operations) {
+                if (operation.getUniqueName() != null &&
+                    operationsByName.containsKey(operation.getUniqueName())) {
+
+                    throw new ModelException("model.uniqueness");
+                }
+                operationsByName.put(operation.getUniqueName(), operation);
+            }
+        }
+    }
+
+    /* serialization */
+    public List<Operation> getOperations() {
+        return _operations;
+    }
+
+    /* serialization */
+    public void setOperations(List<Operation> l) {
+        _operations = l;
+    }
+
+    public JavaInterface getJavaInterface() {
+        return _javaInterface;
+    }
+
+    public void setJavaInterface(JavaInterface i) {
+        _javaInterface = i;
+    }
+
+    public String getAddress() {
+        return _address;
+    }
+
+    public void setAddress(String s) {
+        _address = s;
+    }
+
+    public HandlerChainInfo getClientHandlerChainInfo() {
+        if (_clientHandlerChainInfo == null) {
+            _clientHandlerChainInfo  = new HandlerChainInfo();
+        }
+        return _clientHandlerChainInfo;
+    }
+
+    public void setClientHandlerChainInfo(HandlerChainInfo i) {
+        _clientHandlerChainInfo = i;
+    }
+
+    public HandlerChainInfo getServerHandlerChainInfo() {
+        if (_serverHandlerChainInfo == null) {
+            _serverHandlerChainInfo  = new HandlerChainInfo();
+        }
+        return _serverHandlerChainInfo;
+    }
+
+    public void setServerHandlerChainInfo(HandlerChainInfo i) {
+        _serverHandlerChainInfo = i;
+    }
+
+    public SOAPVersion getSOAPVersion() {
+        return _soapVersion;
+    }
+
+    public void setSOAPVersion(SOAPVersion soapVersion) {
+        _soapVersion = soapVersion;
+    }
+
+    public String getServiceImplName() {
+        return _serviceImplName;
+    }
+
+    public void setServiceImplName(String name) {
+        _serviceImplName = name;
+    }
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    public boolean isProvider() {
+        JavaInterface intf = getJavaInterface();
+        if (intf != null) {
+            String sei = intf.getName();
+            if (sei.equals(javax.xml.ws.Provider.class.getName())) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    /**
+    * XYZ_Service.getABC() method name
+    * @return Returns the portGetterName.
+    */
+    public String getPortGetter() {
+        return portGetter;
+    }
+
+    /**
+    * @param portGetterName The portGetterName to set.
+    */
+    public void setPortGetter(String portGetterName) {
+        this.portGetter = portGetterName;
+    }
+
+    public SOAPStyle getStyle() {
+        return _style;
+    }
+
+    public void setStyle(SOAPStyle s) {
+        _style = s;
+    }
+
+    public boolean isWrapped() {
+        return _isWrapped;
+    }
+
+    public void setWrapped(boolean isWrapped) {
+        _isWrapped = isWrapped;
+    }
+
+    private SOAPStyle _style = null;
+    private boolean _isWrapped = true;
+
+    private String portGetter;
+    private QName _name;
+    private List<Operation> _operations = new ArrayList();
+    private JavaInterface _javaInterface;
+    private String _address;
+    private String _serviceImplName;
+    private Map operationsByName = new HashMap();
+    private HandlerChainInfo _clientHandlerChainInfo;
+    private HandlerChainInfo _serverHandlerChainInfo;
+    private SOAPVersion _soapVersion = SOAPVersion.SOAP_11;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Request.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Request.java
new file mode 100644
index 0000000..172704d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Request.java
@@ -0,0 +1,39 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Request extends Message {
+
+    public Request() {}
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Response.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Response.java
new file mode 100644
index 0000000..a5199b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Response.java
@@ -0,0 +1,69 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Response extends Message {
+
+    public Response() {}
+
+    public void addFaultBlock(Block b) {
+        if (_faultBlocks.containsKey(b.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        _faultBlocks.put(b.getName(), b);
+    }
+
+    public Iterator getFaultBlocks() {
+        return _faultBlocks.values().iterator();
+    }
+
+    public int getFaultBlockCount () {
+        return _faultBlocks.size();
+    }
+
+    /* serialization */
+    public Map getFaultBlocksMap() {
+        return _faultBlocks;
+    }
+
+    public void setFaultBlocksMap(Map m) {
+        _faultBlocks = m;
+    }
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    private Map _faultBlocks = new HashMap();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Service.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Service.java
new file mode 100644
index 0000000..d3678ce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/Service.java
@@ -0,0 +1,121 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model;
+
+import com.sun.tools.internal.ws.processor.model.java.JavaInterface;
+
+import javax.xml.namespace.QName;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Service extends ModelObject {
+
+    public Service() {}
+
+    public Service(QName name, JavaInterface javaInterface) {
+        this.name = name;
+        this.javaInterface = javaInterface;
+    }
+
+    public QName getName() {
+        return name;
+    }
+
+    public void setName(QName n) {
+        name = n;
+    }
+
+    public void addPort(Port port) {
+        if (portsByName.containsKey(port.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        ports.add(port);
+        portsByName.put(port.getName(), port);
+    }
+
+
+    public Port getPortByName(QName n) {
+        if (portsByName.size() != ports.size()) {
+            initializePortsByName();
+        }
+        return (Port) portsByName.get(n);
+    }
+
+    /* serialization */
+    public List<Port> getPorts() {
+        return ports;
+    }
+
+    /* serialization */
+    public void setPorts(List<Port> m) {
+        ports = m;
+//        initializePortsByName();
+    }
+
+    private void initializePortsByName() {
+        portsByName = new HashMap();
+        if (ports != null) {
+            for (Iterator iter = ports.iterator(); iter.hasNext();) {
+                Port port = (Port) iter.next();
+                if (port.getName() != null &&
+                    portsByName.containsKey(port.getName())) {
+
+                    throw new ModelException("model.uniqueness");
+                }
+                portsByName.put(port.getName(), port);
+            }
+        }
+    }
+
+    public JavaInterface getJavaIntf() {
+        return getJavaInterface();
+    }
+
+    public JavaInterface getJavaInterface() {
+        return javaInterface;
+    }
+
+    public void setJavaInterface(JavaInterface i) {
+        javaInterface = i;
+    }
+
+    public void accept(ModelVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    private QName name;
+    private List<Port> ports = new ArrayList();
+    private Map<QName, Port> portsByName = new HashMap<QName, Port>();
+    private JavaInterface javaInterface;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/exporter/ExternalObject.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/exporter/ExternalObject.java
new file mode 100644
index 0000000..224c60d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/exporter/ExternalObject.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.exporter;
+
+import org.xml.sax.ContentHandler;
+
+/**
+ * "Opaque" object in the object graph that knows how
+ * to persist itself to XML.
+ *
+ * TODO: ExternalObjectReader
+ *
+ */
+public interface ExternalObject {
+    /**
+     * Type name of this object. This will be used
+     * when loading the object back from XML.
+     */
+    String getType();
+
+    /**
+     * Saves the object into XML.
+     */
+    void saveTo(ContentHandler receiver);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaArrayType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaArrayType.java
new file mode 100644
index 0000000..7d8cbd2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaArrayType.java
@@ -0,0 +1,77 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaArrayType extends JavaType {
+
+    public JavaArrayType() {
+    }
+
+    public JavaArrayType(String name) {
+        super(name, true, "null");
+    }
+
+    public JavaArrayType(String name, String elementName,
+        JavaType elementType) {
+
+        super(name, true, "null");
+        this.elementName = elementName;
+        this.elementType = elementType;
+    }
+
+    public String getElementName() {
+        return elementName;
+    }
+
+    public void setElementName(String name) {
+        elementName = name;
+    }
+
+    public JavaType getElementType() {
+        return elementType;
+    }
+
+    public void setElementType(JavaType type) {
+        elementType = type;
+    }
+
+    // bug fix:4904604
+    public String getSOAPArrayHolderName() {
+        return soapArrayHolderName;
+    }
+
+    public void setSOAPArrayHolderName(String holderName) {
+        this.soapArrayHolderName = holderName;
+    }
+
+    private String elementName;
+    private JavaType elementType;
+    private String soapArrayHolderName;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaException.java
new file mode 100644
index 0000000..019aedc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaException.java
@@ -0,0 +1,39 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaException extends JavaStructureType {
+
+    public JavaException() {}
+
+    public JavaException(String name, boolean present, Object owner) {
+        super(name, present, owner);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaInterface.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaInterface.java
new file mode 100644
index 0000000..9bf221f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaInterface.java
@@ -0,0 +1,167 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import com.sun.tools.internal.ws.util.ClassNameInfo;
+
+import com.sun.tools.internal.ws.processor.model.ModelException;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaInterface {
+
+    public JavaInterface() {}
+
+    public JavaInterface(String name) {
+        this(name, null);
+    }
+
+    public JavaInterface(String name, String impl) {
+        this.realName = name;
+        this.name = name.replace('$', '.');
+        this.impl = impl;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public String getFormalName() {
+        return name;
+    }
+
+    public void setFormalName(String s) {
+        name = s;
+    }
+
+    public String getRealName() {
+        return realName;
+    }
+
+    public void setRealName(String s) {
+        realName = s;
+    }
+
+    public String getImpl() {
+        return impl;
+    }
+
+    public void setImpl(String s) {
+        impl = s;
+    }
+
+    public Iterator getMethods() {
+        return methods.iterator();
+    }
+
+    public boolean hasMethod(JavaMethod method) {
+        for (int i=0; i<methods.size();i++) {
+            if (method.equals(((JavaMethod)methods.get(i)))) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    public void addMethod(JavaMethod method) {
+
+        if (hasMethod(method)) {
+            throw new ModelException("model.uniqueness");
+        }
+        methods.add(method);
+    }
+
+    /* serialization */
+    public List getMethodsList() {
+        return methods;
+    }
+
+    /* serialization */
+    public void setMethodsList(List l) {
+        methods = l;
+    }
+
+    public boolean hasInterface(String interfaceName) {
+        for (int i=0; i<interfaces.size();i++) {
+            if (interfaceName.equals((String)interfaces.get(i))) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    public void addInterface(String interfaceName) {
+
+        // verify that an exception with this name does not already exist
+        if (hasInterface(interfaceName)) {
+            return;
+        }
+        interfaces.add(interfaceName);
+    }
+
+    public Iterator getInterfaces() {
+        return interfaces.iterator();
+    }
+
+    /* serialization */
+    public List getInterfacesList() {
+        return interfaces;
+    }
+
+    /* serialization */
+    public void setInterfacesList(List l) {
+        interfaces = l;
+    }
+
+    public String getSimpleName() {
+        return ClassNameInfo.getName(name);
+    }
+
+    /* NOTE - all these fields (except "interfaces") were final, but had to
+     * remove this modifier to enable serialization
+     */
+    private String javadoc;
+
+    public String getJavaDoc() {
+        return javadoc;
+    }
+
+    public void setJavaDoc(String javadoc) {
+        this.javadoc = javadoc;
+    }
+
+    private String name;
+    private String realName;
+    private String impl;
+    private List methods = new ArrayList();
+    private List interfaces = new ArrayList();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaMethod.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaMethod.java
new file mode 100644
index 0000000..6999e5c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaMethod.java
@@ -0,0 +1,169 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import com.sun.tools.internal.ws.processor.model.ModelException;
+import com.sun.codemodel.internal.JClass;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaMethod {
+
+    public JavaMethod() {}
+
+    public JavaMethod(String name) {
+        this.name = name;
+        this.returnType = null;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public void setName(String name) {
+        this.name = name;
+    }
+
+    public JavaType getReturnType() {
+        return returnType;
+    }
+
+    public void setReturnType(JavaType returnType) {
+        this.returnType = returnType;
+    }
+
+    public boolean hasParameter(String paramName) {
+        for (int i=0; i<parameters.size();i++) {
+            if (paramName.equals(
+                ((JavaParameter)parameters.get(i)).getName())) {
+
+                return true;
+            }
+        }
+        return false;
+    }
+
+    public void addParameter(JavaParameter param) {
+        // verify that this member does not already exist
+        if (hasParameter(param.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        parameters.add(param);
+    }
+
+    public JavaParameter getParameter(String paramName){
+        for (int i=0; i<parameters.size();i++) {
+            JavaParameter jParam = parameters.get(i);
+            if (paramName.equals(jParam.getParameter().getName())) {
+                return jParam;
+            }
+        }
+        return null;
+    }
+
+    public Iterator<JavaParameter> getParameters() {
+        return parameters.iterator();
+    }
+
+    public int getParameterCount() {
+        return parameters.size();
+    }
+
+    /* serialization */
+    public List<JavaParameter> getParametersList() {
+        return parameters;
+    }
+
+    /* serialization */
+    public void setParametersList(List<JavaParameter> l) {
+        parameters = l;
+    }
+
+    public boolean hasException(String exception) {
+        return exceptions.contains(exception);
+    }
+
+    public void addException(String exception) {
+
+        // verify that this exception does not already exist
+        if (hasException(exception)) {
+            throw new ModelException("model.uniqueness");
+        }
+        exceptions.add(exception);
+    }
+
+    public Iterator getExceptions() {
+        return exceptions.iterator();
+    }
+
+    /* serialization */
+    public List getExceptionsList() {
+        return exceptions;
+    }
+
+    /* serialization */
+    public void setExceptionsList(List l) {
+        exceptions = l;
+    }
+
+    public String getDeclaringClass() {
+        return declaringClass;
+    }
+    public void setDeclaringClass(String declaringClass) {
+        this.declaringClass = declaringClass;
+    }
+
+    // TODO fix model importer/exporter to handle this
+    public boolean getThrowsRemoteException() {
+        return throwsRemoteException;
+    }
+    public void setThrowsRemoteException(boolean throwsRemoteException) {
+        this.throwsRemoteException = throwsRemoteException;
+    }
+
+    public void addExceptionClass(JClass ex){
+        exceptionClasses.add(ex);
+    }
+
+    public List<JClass> getExceptionClasses(){
+        return exceptionClasses;
+    }
+
+    private String name;
+    private List<JavaParameter> parameters = new ArrayList<JavaParameter>();
+    private List<String> exceptions = new ArrayList<String>();
+    private List<JClass> exceptionClasses = new ArrayList<JClass>();
+
+    private JavaType returnType;
+    private String declaringClass;
+    private boolean throwsRemoteException = true;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaParameter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaParameter.java
new file mode 100644
index 0000000..e341b82
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaParameter.java
@@ -0,0 +1,96 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+import com.sun.tools.internal.ws.processor.model.Parameter;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaParameter {
+
+    public JavaParameter() {}
+
+    public JavaParameter(String name, JavaType type, Parameter parameter) {
+        this(name, type, parameter, false);
+    }
+
+    public JavaParameter(String name, JavaType type, Parameter parameter,
+        boolean holder) {
+
+        this.name = name;
+        this.type = type;
+        this.parameter = parameter;
+        this.holder = holder;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public void setName(String s) {
+        name = s;
+    }
+
+    public JavaType getType() {
+        return type;
+    }
+
+    public void setType(JavaType t) {
+        type = t;
+    }
+
+    public Parameter getParameter() {
+        return parameter;
+    }
+
+    public void setParameter(Parameter p) {
+        parameter = p;
+    }
+
+    public boolean isHolder() {
+        return holder;
+    }
+
+    public void setHolder(boolean b) {
+        holder = b;
+    }
+
+    public String getHolderName() {
+        return holderName;
+    }
+
+    public void setHolderName(String holderName) {
+        this.holderName = holderName;
+    }
+
+    private String name;
+    private JavaType type;
+    private Parameter parameter;
+    private boolean holder;
+    private String holderName;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaSimpleType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaSimpleType.java
new file mode 100644
index 0000000..678a234
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaSimpleType.java
@@ -0,0 +1,48 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBTypeAndAnnotation;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaSimpleType extends JavaType {
+
+    public JavaSimpleType() {}
+
+    public JavaSimpleType(String name, String initString) {
+        super(name, true, initString);
+    }
+
+    public JavaSimpleType(JAXBTypeAndAnnotation jtype) {
+        super(jtype);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaStructureMember.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaStructureMember.java
new file mode 100644
index 0000000..c0b08d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaStructureMember.java
@@ -0,0 +1,129 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaStructureMember {
+
+    public JavaStructureMember() {}
+
+    public JavaStructureMember(String name, JavaType type, Object owner) {
+        this(name, type, owner, false);
+    }
+    public JavaStructureMember(String name, JavaType type,
+        Object owner, boolean isPublic) {
+
+        this.name = name;
+        this.type = type;
+        this.owner = owner;
+        this.isPublic = isPublic;
+        constructorPos = -1;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public void setName(String s) {
+        name = s;
+    }
+
+    public JavaType getType() {
+        return type;
+    }
+
+    public void setType(JavaType t) {
+        type = t;
+    }
+
+    public boolean isPublic() {
+        return isPublic;
+    }
+
+    public void setPublic(boolean b) {
+        isPublic = b;
+    }
+
+    public boolean isInherited() {
+        return isInherited;
+    }
+
+    public void setInherited(boolean b) {
+        isInherited = b;
+    }
+
+    public String getReadMethod() {
+        return readMethod;
+    }
+
+    public void setReadMethod(String readMethod) {
+        this.readMethod = readMethod;
+    }
+
+    public String getWriteMethod() {
+        return writeMethod;
+    }
+
+    public void setWriteMethod(String writeMethod) {
+        this.writeMethod = writeMethod;
+    }
+
+    public String getDeclaringClass() {
+        return declaringClass;
+    }
+    public void setDeclaringClass(String declaringClass) {
+        this.declaringClass = declaringClass;
+    }
+
+    public Object getOwner() {
+        return owner;
+    }
+
+    public void setOwner(Object owner) {
+        this.owner = owner;
+    }
+
+    public int getConstructorPos() {
+        return constructorPos;
+    }
+
+    public void setConstructorPos(int idx) {
+        constructorPos = idx;
+    }
+
+    private String name;
+    private JavaType type;
+    private boolean isPublic = false;
+    private boolean isInherited = false;
+    private String readMethod;
+    private String writeMethod;
+    private String declaringClass;
+    private Object owner;
+    private int constructorPos;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaStructureType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaStructureType.java
new file mode 100644
index 0000000..907a526
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaStructureType.java
@@ -0,0 +1,181 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import com.sun.tools.internal.ws.processor.model.ModelException;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaStructureType extends JavaType {
+
+    public JavaStructureType() {}
+
+    public JavaStructureType(String name, boolean present, Object owner) {
+        super(name, present, "null");
+        this.owner = owner;
+    }
+
+    public void add(JavaStructureMember m) {
+        if (membersByName.containsKey(m.getName())) {
+            throw new ModelException("model.uniqueness.javastructuretype",
+                new Object[] {m.getName(), getRealName()});
+        }
+        members.add(m);
+        membersByName.put(m.getName(), m);
+    }
+
+
+    public JavaStructureMember getMemberByName(String name) {
+        if (membersByName.size() != members.size()) {
+            initializeMembersByName();
+        }
+        return membersByName.get(name);
+    }
+
+    public Iterator getMembers() {
+        return members.iterator();
+    }
+
+    public int getMembersCount() {
+        return members.size();
+    }
+
+    /* serialization */
+    public List<JavaStructureMember> getMembersList() {
+        return members;
+    }
+
+    /* serialization */
+    public void setMembersList(List<JavaStructureMember> l) {
+        members = l;
+    }
+
+    private void initializeMembersByName() {
+        membersByName = new HashMap<String, JavaStructureMember>();
+        if (members != null) {
+            for (JavaStructureMember m : members) {
+                if (m.getName() != null &&
+                    membersByName.containsKey(m.getName())) {
+
+                    throw new ModelException("model.uniqueness");
+                }
+                membersByName.put(m.getName(), m);
+            }
+        }
+    }
+
+    public boolean isAbstract() {
+        return isAbstract;
+    }
+
+    public void setAbstract(boolean isAbstract) {
+        this.isAbstract = isAbstract;
+    }
+
+    public JavaStructureType getSuperclass() {
+        return superclass;
+    }
+
+    public void setSuperclass(JavaStructureType superclassType) {
+        superclass = superclassType;
+    }
+
+    public void addSubclass(JavaStructureType subclassType) {
+        subclasses.add(subclassType);
+        subclassType.setSuperclass(this);
+    }
+
+    public Iterator getSubclasses() {
+        if (subclasses == null || subclasses.size() == 0) {
+            return null;
+        }
+        return subclasses.iterator();
+    }
+
+    public Set getSubclassesSet() {
+        return subclasses;
+    }
+
+    /* serialization */
+    public void setSubclassesSet(Set s) {
+        subclasses = s;
+        for (Iterator iter = s.iterator(); iter.hasNext();) {
+            ((JavaStructureType) iter.next()).setSuperclass(this);
+        }
+    }
+
+    public Iterator getAllSubclasses() {
+        Set subs = getAllSubclassesSet();
+        if (subs.size() == 0) {
+            return null;
+        }
+        return subs.iterator();
+    }
+
+    public Set getAllSubclassesSet() {
+        Set transitiveSet = new HashSet();
+        Iterator subs = subclasses.iterator();
+        while (subs.hasNext()) {
+            transitiveSet.addAll(
+                ((JavaStructureType)subs.next()).getAllSubclassesSet());
+        }
+        transitiveSet.addAll(subclasses);
+        return transitiveSet;
+    }
+
+    public Object getOwner() {
+
+        // usually a SOAPStructureType
+        return owner;
+    }
+
+    public void setOwner(Object owner) {
+
+        // usually a SOAPStructureType
+        this.owner = owner;
+    }
+
+    private List<JavaStructureMember> members = new ArrayList();
+    private Map<String, JavaStructureMember> membersByName = new HashMap();
+
+    // known subclasses of this type
+    private Set subclasses = new HashSet();
+    private JavaStructureType superclass;
+
+    // usually a SOAPStructureType
+    private Object owner;
+    private boolean isAbstract = false;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaType.java
new file mode 100644
index 0000000..8722088
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/java/JavaType.java
@@ -0,0 +1,147 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.model.java;
+
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBTypeAndAnnotation;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public abstract class JavaType {
+
+    private String name;
+    private String realName;
+    private boolean present;
+    private boolean holder;
+    private boolean holderPresent;
+    private String initString;
+    private String holderName;
+    private JAXBTypeAndAnnotation type;
+
+    public JavaType() {}
+
+    public JavaType(JAXBTypeAndAnnotation type){
+        this.type = type;
+        init(type.getName(), false, null, null);
+    }
+
+    public JavaType(String name, boolean present, String initString) {
+        init(name, present, initString, null);
+    }
+
+    public JavaType(String name, boolean present, String initString,
+        String holderName) {
+
+        init(name, present, initString, holderName);
+    }
+
+    public JAXBTypeAndAnnotation getType(){
+        return type;
+    }
+
+    private void init(String name, boolean present, String initString,
+        String holderName) {
+
+        this.realName = name;
+        this.name = name.replace('$', '.');
+        this.present = present;
+        this.initString = initString;
+        this.holderName = holderName;
+        holder = holderName != null;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public void doSetName(String name) {
+
+        // renamed to avoid creating a "name" property with broken semantics
+        this.realName = name;
+        this.name = name.replace('$', '.');
+    }
+
+    public String getRealName() {
+        return realName;
+    }
+
+    /* serialization */
+    public void setRealName(String s) {
+        realName = s;
+    }
+
+    public String getFormalName() {
+        return name;
+    }
+
+    public void setFormalName(String s) {
+        name = s;
+    }
+
+    public boolean isPresent() {
+        return present;
+    }
+
+    /* serialization */
+    public void setPresent(boolean b) {
+        present = b;
+    }
+
+    public boolean isHolder() {
+        return holder;
+    }
+
+    public void setHolder(boolean holder) {
+        this.holder = holder;
+    }
+
+    public boolean isHolderPresent() {
+        return holderPresent;
+    }
+    public void setHolderPresent(boolean holderPresent) {
+        this.holderPresent = holderPresent;
+    }
+
+    public String getInitString() {
+        return initString;
+    }
+
+    /* serialization */
+    public void setInitString(String s) {
+        initString = s;
+    }
+
+    public String getHolderName() {
+        return holderName;
+    }
+
+    public void setHolderName(String holderName) {
+        this.holderName = holderName;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBElementMember.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBElementMember.java
new file mode 100644
index 0000000..ef242eb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBElementMember.java
@@ -0,0 +1,98 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.java.JavaStructureMember;
+/**
+ * @author Kathy Walsh, Vivek Pandey
+ *
+ *
+ */
+
+public class JAXBElementMember {
+    public JAXBElementMember() {
+    }
+    public JAXBElementMember(QName name, JAXBType type) {
+        this(name, type, null);
+    }
+    public JAXBElementMember(QName name, JAXBType type,
+            JavaStructureMember javaStructureMember) {
+        _name = name;
+        _type = type;
+        _javaStructureMember = javaStructureMember;
+    }
+    public QName getName() {
+        return _name;
+    }
+    public void setName(QName n) {
+        _name = n;
+    }
+    public JAXBType getType() {
+        return _type;
+    }
+    public void setType(JAXBType t) {
+        _type = t;
+    }
+    public boolean isRepeated() {
+        return _repeated;
+    }
+    public void setRepeated(boolean b) {
+        _repeated = b;
+    }
+    public JavaStructureMember getJavaStructureMember() {
+        return _javaStructureMember;
+    }
+    public void setJavaStructureMember(JavaStructureMember javaStructureMember) {
+        _javaStructureMember = javaStructureMember;
+    }
+    public boolean isInherited() {
+        return isInherited;
+    }
+    public void setInherited(boolean b) {
+        isInherited = b;
+    }
+    public JAXBProperty getProperty() {
+        if(_prop == null && _type != null) {
+            for (JAXBProperty prop: _type.getWrapperChildren()){
+                if(prop.getElementName().equals(_name))
+                    setProperty(prop);
+            }
+        }
+        return _prop;
+    }
+    public void setProperty(JAXBProperty prop) {
+        _prop = prop;
+    }
+
+    private QName _name;
+    private JAXBType _type;
+    private JavaStructureMember _javaStructureMember;
+    private boolean _repeated;
+    private boolean isInherited = false;
+    private JAXBProperty _prop;
+    private static final String JAXB_UNIQUE_PARRAM = "__jaxbUniqueParam_";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBMapping.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBMapping.java
new file mode 100644
index 0000000..6964389
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBMapping.java
@@ -0,0 +1,102 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import java.util.List;
+import java.util.ArrayList;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.api.Mapping;
+import com.sun.tools.internal.xjc.api.Property;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.codemodel.internal.JType;
+
+/**
+ * @author Kohsuke Kawaguchi, Vivek Pandey
+ */
+public class JAXBMapping {
+
+    /**
+     * @see Mapping#getElement()
+     */
+    private QName elementName;
+
+    /**
+     *
+     */
+    private JAXBTypeAndAnnotation type;
+
+    /**
+     * @see Mapping#getWrapperStyleDrilldown()
+     */
+    private List<JAXBProperty> wrapperStyleDrilldown;
+
+    /**
+     * Default constructor for the persistence.
+     */
+    public JAXBMapping() {}
+
+    /**
+     * Constructor that fills in the values from the given raw model
+     */
+    JAXBMapping( com.sun.tools.internal.xjc.api.Mapping rawModel ) {
+        elementName = rawModel.getElement();
+        TypeAndAnnotation typeAndAnno = rawModel.getType();
+        type = new JAXBTypeAndAnnotation(typeAndAnno);
+        List<? extends Property> list = rawModel.getWrapperStyleDrilldown();
+        if(list==null)
+            wrapperStyleDrilldown = null;
+        else {
+            wrapperStyleDrilldown = new ArrayList<JAXBProperty>(list.size());
+            for( Property p : list )
+                wrapperStyleDrilldown.add(new JAXBProperty(p));
+        }
+
+    }
+
+    /**
+     * @see Mapping#getElement()
+     */
+    public QName getElementName() {
+        return elementName;
+    }
+
+    public void setElementName(QName elementName) {
+        this.elementName = elementName;
+    }
+
+
+    public JAXBTypeAndAnnotation getType() {
+        return type;
+    }
+
+    /**
+     * @see Mapping#getWrapperStyleDrilldown()
+     */
+    public List<JAXBProperty> getWrapperStyleDrilldown() {
+        return wrapperStyleDrilldown;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBModel.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBModel.java
new file mode 100644
index 0000000..6fb25cf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBModel.java
@@ -0,0 +1,146 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import com.sun.tools.internal.xjc.api.*;
+
+import javax.xml.namespace.QName;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import com.sun.codemodel.internal.JType;
+
+/**
+ * Root of the JAXB Model.
+ *
+ * <p>
+ * This is just a wrapper around a list of {@link JAXBMapping}s.
+ *
+ * @author Kohsuke Kawaguchi, Vivek Pandey
+ */
+public class JAXBModel {
+
+    /**
+     * All the mappings known to this model.
+     */
+    private List<JAXBMapping> mappings;
+
+    // index for faster access.
+    private final Map<QName,JAXBMapping> byQName = new HashMap<QName,JAXBMapping>();
+    private final Map<String,JAXBMapping> byClassName = new HashMap<String,JAXBMapping>();
+
+    private com.sun.tools.internal.xjc.api.JAXBModel rawJAXBModel;
+
+    public com.sun.tools.internal.xjc.api.JAXBModel getRawJAXBModel() {
+        return rawJAXBModel;
+    }
+
+    /**
+     * @return Schema to Java model
+     */
+    public S2JJAXBModel getS2JJAXBModel(){
+        if(rawJAXBModel instanceof S2JJAXBModel)
+            return (S2JJAXBModel)rawJAXBModel;
+        return null;
+    }
+
+    /**
+     * @return Java to Schema JAXBModel
+     */
+    public J2SJAXBModel getJ2SJAXBModel(){
+        if(rawJAXBModel instanceof J2SJAXBModel)
+            return (J2SJAXBModel)rawJAXBModel;
+        return null;
+    }
+
+
+    /**
+     * Default constructor for the persistence.
+     */
+    public JAXBModel() {}
+
+    /**
+     * Constructor that fills in the values from the given raw model
+     */
+    public JAXBModel( com.sun.tools.internal.xjc.api.JAXBModel rawModel ) {
+        this.rawJAXBModel = rawModel;
+        if(rawModel instanceof S2JJAXBModel){
+            S2JJAXBModel model = (S2JJAXBModel)rawModel;
+            List<JAXBMapping> ms = new ArrayList<JAXBMapping>(model.getMappings().size());
+            for( Mapping m : model.getMappings())
+                ms.add(new JAXBMapping(m));
+            setMappings(ms);
+        }
+    }
+
+    /**
+     */
+    public List<JAXBMapping> getMappings() {
+        return mappings;
+    }
+
+    //public void setMappings(List<JAXBMapping> mappings) {
+    public void setMappings(List<JAXBMapping> mappings) {
+        this.mappings = mappings;
+        byQName.clear();
+        byClassName.clear();
+        for( JAXBMapping m : mappings ) {
+            byQName.put(m.getElementName(),m);
+            byClassName.put(m.getType().getName(),m);
+        }
+    }
+
+    /**
+     */
+    public JAXBMapping get( QName elementName ) {
+        return byQName.get(elementName);
+    }
+
+    /**
+     */
+    public JAXBMapping get( String className ) {
+        return byClassName.get(className);
+    }
+
+
+    /**
+     *
+     * @return set of full qualified class names that jaxb will generate
+     */
+    public Set<String> getGeneratedClassNames() {
+        return generatedClassNames;
+    }
+
+    public void setGeneratedClassNames(Set<String> generatedClassNames) {
+        this.generatedClassNames = generatedClassNames;
+    }
+
+    private Set<String> generatedClassNames;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBProperty.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBProperty.java
new file mode 100644
index 0000000..7e7a7c3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBProperty.java
@@ -0,0 +1,83 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.api.Property;
+
+import com.sun.codemodel.internal.JType;
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class JAXBProperty {
+
+    /**
+     * @see Property#name()
+     */
+    private String name;
+
+    private JAXBTypeAndAnnotation type;
+    /**
+     * @see Property#elementName()
+     */
+    private QName elementName;
+
+    /**
+     * Default constructor for the persistence.
+     */
+    public JAXBProperty() {}
+
+    /**
+     * Constructor that fills in the values from the given raw model
+     */
+    JAXBProperty( Property prop ) {
+        this.name = prop.name();
+        this.type = new JAXBTypeAndAnnotation(prop.type());
+        this.elementName = prop.elementName();
+    }
+
+    /**
+     * @see Property#name()
+     */
+    public String getName() {
+        return name;
+    }
+
+    public void setName(String name) {
+        this.name = name;
+    }
+
+    public JAXBTypeAndAnnotation getType() {
+        return type;
+    }
+
+    /**
+     * @see Property#elementName()
+     */
+    public QName getElementName() {
+        return elementName;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBStructuredType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBStructuredType.java
new file mode 100644
index 0000000..bd5940b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBStructuredType.java
@@ -0,0 +1,144 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.ModelException;
+import com.sun.tools.internal.ws.processor.model.java.JavaStructureType;
+
+/**
+ * Top-level binding between JAXB generated Java type
+ * and XML Schema element declaration.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JAXBStructuredType extends JAXBType {
+
+    public JAXBStructuredType(JAXBType jaxbType){
+        super(jaxbType);
+    }
+
+    public JAXBStructuredType() {}
+
+    public JAXBStructuredType(QName name) {
+        this(name, null);
+    }
+
+    public JAXBStructuredType(QName name, JavaStructureType javaType) {
+        super(name, javaType);
+    }
+
+    public void add(JAXBElementMember m) {
+        if (_elementMembersByName.containsKey(m.getName())) {
+            throw new ModelException("model.uniqueness");
+        }
+        _elementMembers.add(m);
+        if (m.getName() != null) {
+            _elementMembersByName.put(m.getName().getLocalPart(), m);
+        }
+    }
+
+    public Iterator getElementMembers() {
+        return _elementMembers.iterator();
+    }
+
+    public int getElementMembersCount() {
+        return _elementMembers.size();
+    }
+
+    /* serialization */
+    public List getElementMembersList() {
+        return _elementMembers;
+    }
+
+    /* serialization */
+    public void setElementMembersList(List l) {
+        _elementMembers = l;
+    }
+
+    public void addSubtype(JAXBStructuredType type) {
+        if (_subtypes == null) {
+            _subtypes = new HashSet();
+        }
+        _subtypes.add(type);
+        type.setParentType(this);
+    }
+
+    public Iterator getSubtypes() {
+        if (_subtypes != null) {
+            return _subtypes.iterator();
+        }
+        return null;
+    }
+
+    /* (non-Javadoc)
+     * @see JAXBType#isUnwrapped()
+     */
+    public boolean isUnwrapped() {
+        return true;
+    }
+    /* serialization */
+    public Set getSubtypesSet() {
+        return _subtypes;
+    }
+
+    /* serialization */
+    public void setSubtypesSet(Set s) {
+        _subtypes = s;
+    }
+
+    public void setParentType(JAXBStructuredType parent) {
+        if (_parentType != null &&
+            parent != null &&
+            !_parentType.equals(parent)) {
+
+            throw new ModelException("model.parent.type.already.set",
+                new Object[] { getName().toString(),
+                    _parentType.getName().toString(),
+                    parent.getName().toString()});
+        }
+        this._parentType = parent;
+    }
+
+    public JAXBStructuredType getParentType() {
+        return _parentType;
+    }
+
+
+    private List _elementMembers = new ArrayList();
+    private Map _elementMembersByName = new HashMap();
+    private Set _subtypes = null;
+    private JAXBStructuredType _parentType = null;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBType.java
new file mode 100644
index 0000000..ad34628
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBType.java
@@ -0,0 +1,125 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import com.sun.tools.internal.ws.processor.model.AbstractType;
+import com.sun.tools.internal.ws.processor.model.java.JavaType;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.codemodel.internal.JType;
+
+import javax.xml.namespace.QName;
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * Top-level binding between JAXB generated Java type
+ * and XML Schema element declaration.
+ *
+ * @author
+ *     Vivek Pandey
+ */
+public class JAXBType extends AbstractType{
+    public JAXBType(JAXBType jaxbType){
+        setName(jaxbType.getName());
+        this.jaxbMapping = jaxbType.getJaxbMapping();
+        this.jaxbModel = jaxbType.getJaxbModel();
+        init();
+    }
+
+    public JAXBType(){}
+
+    public JAXBType(QName name, JavaType type){
+        super(name, type);
+    }
+
+    public JAXBType(QName name, JavaType type, JAXBMapping jaxbMapping, JAXBModel jaxbModel){
+        super(name, type);
+        this.jaxbMapping = jaxbMapping;
+        this.jaxbModel = jaxbModel;
+        init();
+    }
+
+    public void accept(JAXBTypeVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    private void init() {
+        if (jaxbMapping != null)
+            wrapperChildren = jaxbMapping.getWrapperStyleDrilldown();
+        else
+            wrapperChildren =  new ArrayList<JAXBProperty>();
+    }
+
+    public boolean isUnwrappable(){
+        return getJaxbMapping().getWrapperStyleDrilldown() != null;
+    }
+
+    public boolean hasWrapperChildren(){
+        return (getWrapperChildren().size() > 0) ? true : false;
+    }
+
+    public boolean isLiteralType() {
+        return true;
+    }
+
+    public List<JAXBProperty> getWrapperChildren(){
+        return wrapperChildren;
+    }
+
+    public void setWrapperChildren(List<JAXBProperty> children) {
+        wrapperChildren = children;
+    }
+
+    public JAXBMapping getJaxbMapping() {
+        return jaxbMapping;
+    }
+
+    public void setJaxbMapping(JAXBMapping jaxbMapping) {
+        this.jaxbMapping = jaxbMapping;
+        init();
+    }
+
+    public void setUnwrapped(boolean unwrapped) {
+        this.unwrapped = unwrapped;
+    }
+
+    public boolean isUnwrapped() {
+        return unwrapped;
+    }
+
+    private JAXBMapping jaxbMapping;
+
+    public JAXBModel getJaxbModel() {
+        return jaxbModel;
+    }
+
+    public void setJaxbModel(JAXBModel jaxbModel) {
+        this.jaxbModel = jaxbModel;
+    }
+
+    private JAXBModel jaxbModel;
+    private boolean unwrapped = false;
+    private List<JAXBProperty> wrapperChildren;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBTypeAndAnnotation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBTypeAndAnnotation.java
new file mode 100644
index 0000000..cfa340c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBTypeAndAnnotation.java
@@ -0,0 +1,77 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JAnnotatable;
+
+/**
+ * Holds JAXB JType and TypeAndAnnotation. This provides abstration over
+ * types from JAXBMapping and Property.
+ */
+public class JAXBTypeAndAnnotation {
+    TypeAndAnnotation typeAnn;
+    JType type;
+
+    public JAXBTypeAndAnnotation(TypeAndAnnotation typeAnn) {
+        this.typeAnn = typeAnn;
+        this.type = typeAnn.getTypeClass();
+    }
+
+    public JAXBTypeAndAnnotation(JType type) {
+        this.type = type;
+    }
+
+    public JAXBTypeAndAnnotation(TypeAndAnnotation typeAnn, JType type) {
+        this.typeAnn = typeAnn;
+        this.type = type;
+    }
+
+    public void annotate(JAnnotatable typeVar) {
+        if(typeAnn != null)
+            typeAnn.annotate(typeVar);
+    }
+
+    public JType getType() {
+        return type;
+    }
+
+    public String getName(){
+        return type.fullName();
+    }
+
+    public TypeAndAnnotation getTypeAnn() {
+        return typeAnn;
+    }
+
+    public void setTypeAnn(TypeAndAnnotation typeAnn) {
+        this.typeAnn = typeAnn;
+    }
+
+    public void setType(JType type) {
+        this.type = type;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBTypeVisitor.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBTypeVisitor.java
new file mode 100644
index 0000000..94fba8b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/JAXBTypeVisitor.java
@@ -0,0 +1,36 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+/**
+ * @author Vivek Pandey
+ *
+ * To change the template for this generated type comment go to
+ * Window&gt;Preferences&gt;Java&gt;Code Generation&gt;Code and Comments
+ */
+public interface JAXBTypeVisitor {
+    public void visit(JAXBType type) throws Exception;
+    public void visit(RpcLitStructure type) throws Exception;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/RpcLitMember.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/RpcLitMember.java
new file mode 100644
index 0000000..0e4d6fb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/RpcLitMember.java
@@ -0,0 +1,84 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.AbstractType;
+
+/**
+ * @author Vivek Pandey
+ *
+ * Represents RpcLit member parts
+ */
+public class RpcLitMember extends AbstractType {
+
+    //wsdl:part type attribute java mapped object
+    private String javaTypeName;
+    private QName schemaTypeName;
+
+    /**
+     *
+     */
+    public RpcLitMember() {
+        super();
+        // TODO Auto-generated constructor stub
+    }
+    public RpcLitMember(QName name, String javaTypeName){
+        setName(name);
+        this.javaTypeName = javaTypeName;
+    }
+    public RpcLitMember(QName name, String javaTypeName, QName schemaTypeName){
+        setName(name);
+        this.javaTypeName = javaTypeName;
+        this.schemaTypeName = schemaTypeName;
+    }
+
+    /**
+     * @return Returns the type.
+     */
+    public String getJavaTypeName() {
+        return javaTypeName;
+    }
+    /**
+     * @param type The type to set.
+     */
+    public void setJavaTypeName(String type) {
+        this.javaTypeName = type;
+    }
+
+    /**
+     * @return Returns the type.
+     */
+    public QName getSchemaTypeName() {
+        return schemaTypeName;
+    }
+    /**
+     * @param type The type to set.
+     */
+    public void setSchemaTypeName(QName type) {
+        this.schemaTypeName = type;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/RpcLitStructure.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/RpcLitStructure.java
new file mode 100644
index 0000000..17d58c7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/RpcLitStructure.java
@@ -0,0 +1,92 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.AbstractType;
+
+/**
+ * @author Vivek Pandey
+ *
+ * RPC Structure that will be used to create RpcLitPayload latter
+ */
+public class RpcLitStructure extends AbstractType {
+    private List<RpcLitMember> members;
+    private JAXBModel jaxbModel;
+
+    /**
+     *
+     */
+    public RpcLitStructure() {
+        super();
+        // TODO Auto-generated constructor stub
+    }
+    public RpcLitStructure(QName name, JAXBModel jaxbModel){
+        setName(name);
+        this.jaxbModel = jaxbModel;
+        this.members = new ArrayList<RpcLitMember>();
+
+    }
+    public RpcLitStructure(QName name, JAXBModel jaxbModel, List<RpcLitMember> members){
+        setName(name);
+        this.members = members;
+    }
+
+    public void accept(JAXBTypeVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    public List<RpcLitMember> getRpcLitMembers(){
+        return members;
+    }
+
+    public List<RpcLitMember> setRpcLitMembers(List<RpcLitMember> members){
+        return this.members = members;
+    }
+
+    public void addRpcLitMember(RpcLitMember member){
+        members.add(member);
+    }
+    /**
+     * @return Returns the jaxbModel.
+     */
+    public JAXBModel getJaxbModel() {
+        return jaxbModel;
+    }
+    /**
+     * @param jaxbModel The jaxbModel to set.
+     */
+    public void setJaxbModel(JAXBModel jaxbModel) {
+        this.jaxbModel = jaxbModel;
+    }
+
+    public boolean isLiteralType() {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/Util.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/Util.java
new file mode 100644
index 0000000..5fb77a7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/model/jaxb/Util.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.model.jaxb;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class Util {
+    /**
+     * Replaces the marcros in the first string by the actual given arguments.
+     */
+    static String replace( String macro, String... args ) {
+        int len = macro.length();
+        StringBuilder buf = new StringBuilder(len);
+        for( int i=0; i<len; i++ ) {
+            char ch = macro.charAt(i);
+            if(ch=='=' && i+2<len) {
+                char tail = macro.charAt(i+1);
+                char ch2 = macro.charAt(i+2);
+                if('0'<=ch2 && ch2<='9' && tail==':') {
+                    buf.append(args[ch2-'0']);
+                    i+=2;
+                    continue;
+                }
+            }
+            buf.append(ch);
+        }
+        return buf.toString();
+    }
+
+    /**
+     * Creates a macro tempate so that it can be later used with {@link #replace(String, String[])}.
+     */
+    static String createMacroTemplate( String s ) {
+        return s;
+    }
+
+    static final String MAGIC = "=:";
+
+    static final String MAGIC0 = MAGIC+"0";
+    static final String MAGIC1 = MAGIC+"1";
+    static final String MAGIC2 = MAGIC+"2";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/JavaSimpleTypeCreator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/JavaSimpleTypeCreator.java
new file mode 100644
index 0000000..44243e7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/JavaSimpleTypeCreator.java
@@ -0,0 +1,165 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.modeler;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import com.sun.tools.internal.ws.processor.model.java.JavaSimpleType;
+import com.sun.xml.internal.ws.util.VersionUtil;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class JavaSimpleTypeCreator implements ModelerConstants {
+
+    /*
+     * Mapped JavaSimpleTypes
+     */
+    public JavaSimpleType BOOLEAN_JAVATYPE;
+    public JavaSimpleType BOXED_BOOLEAN_JAVATYPE;
+    public JavaSimpleType BYTE_JAVATYPE;
+    public JavaSimpleType BYTE_ARRAY_JAVATYPE;
+    public JavaSimpleType BOXED_BYTE_JAVATYPE;
+    public JavaSimpleType BOXED_BYTE_ARRAY_JAVATYPE;
+    public JavaSimpleType DOUBLE_JAVATYPE;
+    public JavaSimpleType BOXED_DOUBLE_JAVATYPE;
+    public JavaSimpleType FLOAT_JAVATYPE;
+    public JavaSimpleType BOXED_FLOAT_JAVATYPE;
+    public JavaSimpleType INT_JAVATYPE;
+    public JavaSimpleType BOXED_INTEGER_JAVATYPE;
+    public JavaSimpleType LONG_JAVATYPE;
+    public JavaSimpleType BOXED_LONG_JAVATYPE;
+    public JavaSimpleType SHORT_JAVATYPE;
+    public JavaSimpleType BOXED_SHORT_JAVATYPE;
+    public JavaSimpleType DECIMAL_JAVATYPE;
+    public JavaSimpleType BIG_INTEGER_JAVATYPE;
+    public JavaSimpleType CALENDAR_JAVATYPE;
+    public JavaSimpleType DATE_JAVATYPE;
+    public JavaSimpleType STRING_JAVATYPE;
+    public JavaSimpleType STRING_ARRAY_JAVATYPE;
+    public JavaSimpleType QNAME_JAVATYPE;
+    public JavaSimpleType VOID_JAVATYPE;
+    public JavaSimpleType OBJECT_JAVATYPE;
+    public JavaSimpleType SOAPELEMENT_JAVATYPE;
+    public JavaSimpleType URI_JAVATYPE;
+
+    // Attachment types
+    public JavaSimpleType IMAGE_JAVATYPE;
+    public JavaSimpleType MIME_MULTIPART_JAVATYPE;
+    public JavaSimpleType SOURCE_JAVATYPE;
+    public JavaSimpleType DATA_HANDLER_JAVATYPE;
+
+    // bug fix: 4923650
+    private Map javaTypes = new HashMap();
+
+    public JavaSimpleTypeCreator() {
+        BOOLEAN_JAVATYPE = new JavaSimpleType(BOOLEAN_CLASSNAME, FALSE_STR);
+        javaTypes.put(BOOLEAN_CLASSNAME, BOOLEAN_JAVATYPE);
+        BOXED_BOOLEAN_JAVATYPE =
+            new JavaSimpleType(BOXED_BOOLEAN_CLASSNAME, NULL_STR);
+        javaTypes.put(BOXED_BOOLEAN_CLASSNAME, BOXED_BOOLEAN_JAVATYPE);
+        BYTE_JAVATYPE = new JavaSimpleType(BYTE_CLASSNAME, "(byte)"+ZERO_STR);
+        javaTypes.put(BYTE_CLASSNAME, BYTE_JAVATYPE);
+        BYTE_ARRAY_JAVATYPE =
+            new JavaSimpleType(BYTE_ARRAY_CLASSNAME, NULL_STR);
+        javaTypes.put(BYTE_ARRAY_CLASSNAME, BYTE_ARRAY_JAVATYPE);
+        BOXED_BYTE_JAVATYPE =
+            new JavaSimpleType(BOXED_BYTE_CLASSNAME, NULL_STR);
+        javaTypes.put(BOXED_BYTE_CLASSNAME, BOXED_BYTE_JAVATYPE);
+        BOXED_BYTE_ARRAY_JAVATYPE =
+            new JavaSimpleType(BOXED_BYTE_ARRAY_CLASSNAME, NULL_STR);
+        javaTypes.put(BOXED_BYTE_ARRAY_CLASSNAME, BOXED_BYTE_ARRAY_JAVATYPE);
+        DOUBLE_JAVATYPE = new JavaSimpleType(DOUBLE_CLASSNAME, ZERO_STR);
+        javaTypes.put(DOUBLE_CLASSNAME, DOUBLE_JAVATYPE);
+        BOXED_DOUBLE_JAVATYPE =
+            new JavaSimpleType(BOXED_DOUBLE_CLASSNAME, NULL_STR);
+        javaTypes.put(BOXED_DOUBLE_CLASSNAME, BOXED_DOUBLE_JAVATYPE);
+        FLOAT_JAVATYPE = new JavaSimpleType(FLOAT_CLASSNAME, ZERO_STR);
+        javaTypes.put(FLOAT_CLASSNAME, FLOAT_JAVATYPE);
+        BOXED_FLOAT_JAVATYPE =
+            new JavaSimpleType(BOXED_FLOAT_CLASSNAME, NULL_STR);
+        javaTypes.put(BOXED_FLOAT_CLASSNAME, BOXED_FLOAT_JAVATYPE);
+        INT_JAVATYPE = new JavaSimpleType(INT_CLASSNAME, ZERO_STR);
+        javaTypes.put(INT_CLASSNAME, INT_JAVATYPE);
+        BOXED_INTEGER_JAVATYPE =
+            new JavaSimpleType(BOXED_INTEGER_CLASSNAME, NULL_STR);
+        javaTypes.put(BOXED_INTEGER_CLASSNAME, BOXED_INTEGER_JAVATYPE);
+        LONG_JAVATYPE = new JavaSimpleType(LONG_CLASSNAME, ZERO_STR);
+        javaTypes.put(LONG_CLASSNAME, LONG_JAVATYPE);
+        BOXED_LONG_JAVATYPE =
+            new JavaSimpleType(BOXED_LONG_CLASSNAME, NULL_STR);
+        javaTypes.put(BOXED_LONG_CLASSNAME, BOXED_LONG_JAVATYPE);
+        SHORT_JAVATYPE =
+            new JavaSimpleType(SHORT_CLASSNAME, "(short)"+ZERO_STR);
+        javaTypes.put(SHORT_CLASSNAME, SHORT_JAVATYPE);
+        BOXED_SHORT_JAVATYPE =
+            new JavaSimpleType(BOXED_SHORT_CLASSNAME, NULL_STR);
+        javaTypes.put(BOXED_SHORT_CLASSNAME, BOXED_SHORT_JAVATYPE);
+        DECIMAL_JAVATYPE = new JavaSimpleType(BIGDECIMAL_CLASSNAME, NULL_STR);
+        javaTypes.put(BIGDECIMAL_CLASSNAME, DECIMAL_JAVATYPE);
+        BIG_INTEGER_JAVATYPE =
+            new JavaSimpleType(BIGINTEGER_CLASSNAME, NULL_STR);
+        javaTypes.put(BIGINTEGER_CLASSNAME, BIG_INTEGER_JAVATYPE);
+        CALENDAR_JAVATYPE = new JavaSimpleType(CALENDAR_CLASSNAME, NULL_STR);
+        javaTypes.put(CALENDAR_CLASSNAME, CALENDAR_JAVATYPE);
+        DATE_JAVATYPE = new JavaSimpleType(DATE_CLASSNAME, NULL_STR);
+        javaTypes.put(DATE_CLASSNAME, DATE_JAVATYPE);
+        STRING_JAVATYPE = new JavaSimpleType(STRING_CLASSNAME, NULL_STR);
+        javaTypes.put(STRING_CLASSNAME, STRING_JAVATYPE);
+        STRING_ARRAY_JAVATYPE =
+            new JavaSimpleType(STRING_ARRAY_CLASSNAME, NULL_STR);
+        javaTypes.put(STRING_ARRAY_CLASSNAME, STRING_ARRAY_JAVATYPE);
+        QNAME_JAVATYPE = new JavaSimpleType(QNAME_CLASSNAME, NULL_STR);
+        javaTypes.put(QNAME_CLASSNAME, QNAME_JAVATYPE);
+
+
+        VOID_JAVATYPE = new JavaSimpleType(VOID_CLASSNAME, null);
+        javaTypes.put(VOID_CLASSNAME, VOID_JAVATYPE);
+        OBJECT_JAVATYPE = new JavaSimpleType(OBJECT_CLASSNAME, null);
+        javaTypes.put(OBJECT_CLASSNAME, OBJECT_JAVATYPE);
+        SOAPELEMENT_JAVATYPE = new JavaSimpleType(SOAPELEMENT_CLASSNAME, null);
+        javaTypes.put(SOAPELEMENT_CLASSNAME, SOAPELEMENT_JAVATYPE);
+        URI_JAVATYPE = new JavaSimpleType(URI_CLASSNAME, null);
+        javaTypes.put(URI_CLASSNAME, URI_JAVATYPE);
+
+        // Attachment types
+        IMAGE_JAVATYPE = new JavaSimpleType(IMAGE_CLASSNAME, null);
+        javaTypes.put(IMAGE_CLASSNAME, IMAGE_JAVATYPE);
+        MIME_MULTIPART_JAVATYPE = new JavaSimpleType(MIME_MULTIPART_CLASSNAME, null);
+        javaTypes.put(MIME_MULTIPART_CLASSNAME, MIME_MULTIPART_JAVATYPE);
+        SOURCE_JAVATYPE = new JavaSimpleType(SOURCE_CLASSNAME, null);
+        javaTypes.put(SOURCE_CLASSNAME, SOURCE_JAVATYPE);
+        DATA_HANDLER_JAVATYPE = new JavaSimpleType(DATA_HANDLER_CLASSNAME, null);
+        javaTypes.put(DATA_HANDLER_CLASSNAME, DATA_HANDLER_JAVATYPE);
+    }
+
+    //  bug fix: 4923650
+    public JavaSimpleType getJavaSimpleType(String classname) {
+        return (JavaSimpleType) javaTypes.get(classname);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/Modeler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/Modeler.java
new file mode 100644
index 0000000..88091d0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/Modeler.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.ws.processor.modeler;
+
+import com.sun.tools.internal.ws.processor.model.Model;
+
+/**
+ * A Modeler is used to create a Model of a Web Service from a particular Web
+ * Web Service description such as a WSDL
+ *
+ * @author WS Development Team
+*/
+public interface Modeler {
+    /**
+     * Returns the top model of a Web Service. May throw a
+     * ModelException if there is a problem with the model.
+     *
+     * @return Model - the root Node of the model of the Web Service
+     *
+     * @exception ModelerException
+     */
+    public Model buildModel();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerConstants.java
new file mode 100644
index 0000000..1362f84
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerConstants.java
@@ -0,0 +1,103 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.modeler;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface ModelerConstants {
+
+    public static final String BRACKETS  = "[]";
+    public static final String FALSE_STR = "false";
+    public static final String ZERO_STR  = "0";
+    public static final String NULL_STR  = "null";
+    public static final String ARRAY_STR = "Array";
+
+    /*
+     * Java ClassNames
+     */
+    /*
+      * Java ClassNames
+      */
+     public static final String IOEXCEPTION_CLASSNAME         = "java.io.IOException";
+     public static final String BOOLEAN_CLASSNAME             = "boolean";
+     public static final String BOXED_BOOLEAN_CLASSNAME       = "java.lang.Boolean";
+     public static final String BYTE_CLASSNAME                = "byte";
+     public static final String BYTE_ARRAY_CLASSNAME          = BYTE_CLASSNAME+BRACKETS;
+     public static final String BOXED_BYTE_CLASSNAME          = "java.lang.Byte";
+     public static final String BOXED_BYTE_ARRAY_CLASSNAME    = BOXED_BYTE_CLASSNAME+BRACKETS;
+     public static final String CLASS_CLASSNAME               = "java.lang.Class";
+     public static final String CHAR_CLASSNAME                = "char";
+     public static final String BOXED_CHAR_CLASSNAME          = "java.lang.Character";
+     public static final String DOUBLE_CLASSNAME              = "double";
+     public static final String BOXED_DOUBLE_CLASSNAME        = "java.lang.Double";
+     public static final String FLOAT_CLASSNAME               = "float";
+     public static final String BOXED_FLOAT_CLASSNAME         = "java.lang.Float";
+     public static final String INT_CLASSNAME                 = "int";
+     public static final String BOXED_INTEGER_CLASSNAME       = "java.lang.Integer";
+     public static final String LONG_CLASSNAME                = "long";
+     public static final String BOXED_LONG_CLASSNAME          = "java.lang.Long";
+     public static final String SHORT_CLASSNAME               = "short";
+     public static final String BOXED_SHORT_CLASSNAME         = "java.lang.Short";
+     public static final String BIGDECIMAL_CLASSNAME          = "java.math.BigDecimal";
+     public static final String BIGINTEGER_CLASSNAME          = "java.math.BigInteger";
+     public static final String CALENDAR_CLASSNAME            = "java.util.Calendar";
+     public static final String DATE_CLASSNAME                = "java.util.Date";
+     public static final String STRING_CLASSNAME              = "java.lang.String";
+     public static final String STRING_ARRAY_CLASSNAME        = STRING_CLASSNAME+BRACKETS;
+     public static final String QNAME_CLASSNAME               = "javax.xml.namespace.QName";
+     public static final String VOID_CLASSNAME                = "void";
+     public static final String OBJECT_CLASSNAME              = "java.lang.Object";
+     public static final String SOAPELEMENT_CLASSNAME         = "javax.xml.soap.SOAPElement";
+     public static final String IMAGE_CLASSNAME               = "java.awt.Image";
+     public static final String MIME_MULTIPART_CLASSNAME      = "javax.mail.internet.MimeMultipart";
+     public static final String SOURCE_CLASSNAME              = "javax.xml.transform.Source";
+     public static final String DATA_HANDLER_CLASSNAME        = "javax.activation.DataHandler";
+     public static final String URI_CLASSNAME                 = "java.net.URI";
+//     public static final String URI_CLASSNAME                  = "java.lang.String";
+     // Collections
+     public static final String COLLECTION_CLASSNAME          = "java.util.Collection";
+     public static final String LIST_CLASSNAME                = "java.util.List";
+     public static final String SET_CLASSNAME                 = "java.util.Set";
+     public static final String VECTOR_CLASSNAME              = "java.util.Vector";
+     public static final String STACK_CLASSNAME               = "java.util.Stack";
+     public static final String LINKED_LIST_CLASSNAME         = "java.util.LinkedList";
+     public static final String ARRAY_LIST_CLASSNAME          = "java.util.ArrayList";
+     public static final String HASH_SET_CLASSNAME            = "java.util.HashSet";
+     public static final String TREE_SET_CLASSNAME            = "java.util.TreeSet";
+
+     // Maps
+     public static final String MAP_CLASSNAME                 = "java.util.Map";
+     public static final String HASH_MAP_CLASSNAME            = "java.util.HashMap";
+     public static final String TREE_MAP_CLASSNAME            = "java.util.TreeMap";
+     public static final String HASHTABLE_CLASSNAME           = "java.util.Hashtable";
+     public static final String PROPERTIES_CLASSNAME          = "java.util.Properties";
+//     public static final String WEAK_HASH_MAP_CLASSNAME       = "java.util.WeakHashMap";
+     public static final String JAX_WS_MAP_ENTRY_CLASSNAME   = "com.sun.xml.internal.ws.encoding.soap.JAXWSMapEntry";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerException.java
new file mode 100644
index 0000000..2f85349
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerException.java
@@ -0,0 +1,57 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.modeler;
+
+import com.sun.tools.internal.ws.processor.ProcessorException;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * ModelerException represents an exception that occurred while
+ * visiting service model.
+ *
+ * @see ProcessorException
+ *
+ * @author WS Development Team
+*/
+public class ModelerException extends ProcessorException {
+
+    public ModelerException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ModelerException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public ModelerException(Localizable arg) {
+        super("modeler.nestedModelError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.modeler";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerUtils.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerUtils.java
new file mode 100644
index 0000000..4fd476c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/ModelerUtils.java
@@ -0,0 +1,260 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.api.S2JJAXBModel;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.ws.processor.model.AbstractType;
+import com.sun.tools.internal.ws.processor.model.Block;
+import com.sun.tools.internal.ws.processor.model.ModelProperties;
+import com.sun.tools.internal.ws.processor.model.Parameter;
+import com.sun.tools.internal.ws.processor.model.java.JavaSimpleType;
+import com.sun.tools.internal.ws.processor.model.java.JavaStructureMember;
+import com.sun.tools.internal.ws.processor.model.java.JavaStructureType;
+import com.sun.tools.internal.ws.processor.model.java.JavaType;
+import com.sun.tools.internal.ws.processor.model.jaxb.*;
+import com.sun.tools.internal.ws.util.ClassNameInfo;
+import com.sun.tools.internal.ws.wsdl.document.Message;
+import com.sun.tools.internal.ws.wsdl.document.MessagePart;
+
+/**
+ * Utilities to be used by modelers such as WSDLModeler and Rmimodeler
+ *
+ * @author Vivek Pandey
+ *
+ */
+public class ModelerUtils {
+
+    /**
+     * This method should be called incase of wrapper style operations. This is
+     * equivalent to wrapper style schema component or JAXB Mapping object.
+     *
+     * @param jaxbType JAXBType from which a JAXBStructured type will be created.
+     * @return returns JAXBStructured type
+     */
+    public static JAXBStructuredType createJAXBStructureType(JAXBType jaxbType) {
+        JAXBStructuredType type = new JAXBStructuredType(jaxbType);
+        type.setName(jaxbType.getName());
+        type.setJavaType(jaxbType.getJavaType());
+        return type;
+    }
+
+    /**
+     * This method uses JAXBStructured type (wrapper style operations) and
+     * unwraps it to create list of parameters.
+     *
+     *
+     * @param jaxbType instance of JAXBType, could be JAXBStructured type.
+     * @param block The Block (body/Header/Attachment) to which the created Parameter belong.
+     * @return list of Parameters
+     */
+    public static List<Parameter> createUnwrappedParameters(JAXBType jaxbType,
+            Block block) {
+        List<Parameter> paramList = new ArrayList<Parameter>();
+        JAXBStructuredType type = null;
+        if (!(jaxbType instanceof JAXBStructuredType))
+            type = createJAXBStructureType(jaxbType);
+        else
+            type = (JAXBStructuredType) jaxbType;
+
+        JavaStructureType jst = new JavaStructureType(jaxbType.getJavaType()
+                .getRealName(), true, type);
+        type.setJavaType(jst);
+        block.setType(type);
+        List memberList = jaxbType.getWrapperChildren();
+        Iterator props = memberList.iterator();
+        while (props.hasNext()) {
+            JAXBProperty prop = (JAXBProperty) props.next();
+            paramList.add(createUnwrappedParameter(prop, jaxbType, block, type,
+                    jst));
+        }
+
+        return paramList;
+    }
+
+    /**
+     * @param prop
+     * @param jaxbType
+     * @param block
+     * @return
+     */
+    private static Parameter createUnwrappedParameter(JAXBProperty prop,
+            JAXBType jaxbType, Block block, JAXBStructuredType type,
+            JavaStructureType jst) {
+        QName elementName = prop.getElementName();
+        JavaType javaType = new JavaSimpleType(prop.getType());
+        JAXBElementMember eType = new JAXBElementMember(elementName, jaxbType);
+        JavaStructureMember jsm = new JavaStructureMember(elementName
+                .getLocalPart(), javaType, eType);
+        eType.setJavaStructureMember(jsm);
+        jst.add(jsm);
+        eType.setProperty(prop);
+        type.add(eType);
+        JAXBType t = new JAXBType(elementName, javaType, jaxbType
+                .getJaxbMapping(), jaxbType.getJaxbModel());
+        t.setUnwrapped(true);
+        Parameter parameter = createParameter(elementName.getLocalPart(), t, block);
+        parameter.setEmbedded(true);
+        return parameter;
+    }
+
+    public static List<Parameter> createRpcLitParameters(Message message, Block block, S2JJAXBModel jaxbModel){
+        RpcLitStructure rpcStruct = (RpcLitStructure)block.getType();
+
+        List<Parameter> parameters = new ArrayList<Parameter>();
+        for(MessagePart part : message.getParts()){
+            if(!ModelerUtils.isBoundToSOAPBody(part))
+                continue;
+            QName name = part.getDescriptor();
+            TypeAndAnnotation typeAndAnn = jaxbModel.getJavaType(name);
+            if(typeAndAnn == null){
+                String msgQName = "{"+message.getDefining().getTargetNamespaceURI()+"}"+message.getName();
+                throw new ModelerException("wsdlmodeler.rpclit.unkownschematype", name.toString(),
+                        part.getName(), msgQName);
+            }
+            String type = typeAndAnn.getTypeClass().fullName();
+            type = ClassNameInfo.getGenericClass(type);
+            RpcLitMember param = new RpcLitMember(new QName("", part.getName()), type);
+            JavaType javaType = new JavaSimpleType(new JAXBTypeAndAnnotation(typeAndAnn));
+            param.setJavaType(javaType);
+            rpcStruct.addRpcLitMember(param);
+            Parameter parameter = ModelerUtils.createParameter(part.getName(), param, block);
+            parameter.setEmbedded(true);
+            parameters.add(parameter);
+        }
+        return parameters;
+    }
+
+    /**
+     * Called for non-wrapper style operations. It returns a Parameter constructed
+     * using the JAXBType and the Block.
+     *
+     * @param partName typically wsdl:part or any name to be given to the parameter
+     * @param jaxbType type of Parameter
+     * @param block Block to which the parameter belongs to
+     * @return Parameter created.
+     */
+    public static Parameter createParameter(String partName, AbstractType jaxbType,
+            Block block) {
+        Parameter parameter = new Parameter(partName);
+        parameter.setProperty(ModelProperties.PROPERTY_PARAM_MESSAGE_PART_NAME,
+                partName);
+        parameter.setEmbedded(false);
+        parameter.setType(jaxbType);
+        parameter.setTypeName(jaxbType.getJavaType().getType().getName());
+        parameter.setBlock(block);
+        return parameter;
+    }
+
+    /**
+     * Get Parameter from the list of parameters.
+     *
+     * @param paramName
+     * @param parameters
+     * @return the Parameter with name paramName from parameters
+     */
+    public static Parameter getParameter(String paramName, List<Parameter> parameters){
+        if(parameters == null)
+            return null;
+        for(Parameter param: parameters){
+            //if(param.getName().equals("_return") && paramName.equals("return") || param.getName().equals(paramName)) {
+            if(param.getName().equals(paramName)){
+                return param;
+            }
+        }
+        return null;
+    }
+
+    /**
+     * Compares two JAXBStructures.
+     *
+     * @param struct1
+     * @param struct2
+     * @return true if struct1 and struct2 are equivalent.
+     */
+    public static boolean isEquivalentLiteralStructures(
+        JAXBStructuredType struct1,
+        JAXBStructuredType struct2) {
+        if (struct1.getElementMembersCount() != struct2.getElementMembersCount())
+            return false;
+        Iterator members = struct1.getElementMembers();
+        JAXBElementMember member1;
+        JavaStructureMember javaMember1, javaMember2;
+        for (int i = 0; members.hasNext(); i++) {
+            member1 = (JAXBElementMember)members.next();
+            javaMember1 = member1.getJavaStructureMember();
+            javaMember2 =
+                ((JavaStructureType)struct2.getJavaType()).getMemberByName(
+                    member1.getJavaStructureMember().getName());
+            if (javaMember2.getConstructorPos() != i
+                || !javaMember1.getType().equals(javaMember2.getType())) {
+                return false;
+            }
+        }
+        return false;
+    }
+
+    /**
+     * @param part
+     * @return true if part is bound to Mime content
+     */
+    public static boolean isBoundToMimeContent(MessagePart part) {
+        if((part != null) && part.getBindingExtensibilityElementKind() == MessagePart.WSDL_MIME_BINDING)
+            return true;
+        return false;
+    }
+
+    /**
+     * @param part
+     * @return true if part is bound to SOAPBody
+     */
+    public static boolean isBoundToSOAPBody(MessagePart part) {
+        if((part != null) && part.getBindingExtensibilityElementKind() == MessagePart.SOAP_BODY_BINDING)
+            return true;
+        return false;
+    }
+
+    /**
+     * @param part
+     * @return true if part is bound to SOAPHeader
+     */
+    public static boolean isBoundToSOAPHeader(MessagePart part) {
+        if((part != null) && part.getBindingExtensibilityElementKind() == MessagePart.SOAP_HEADER_BINDING)
+            return true;
+        return false;
+    }
+
+    public static boolean isUnbound(MessagePart part) {
+        if((part != null) && part.getBindingExtensibilityElementKind() == MessagePart.PART_NOT_BOUNDED)
+            return true;
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/AnnotationProcessorContext.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/AnnotationProcessorContext.java
new file mode 100644
index 0000000..eaeb814
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/AnnotationProcessorContext.java
@@ -0,0 +1,299 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.ParameterDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.model.Operation;
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.model.Service;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBModel;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPUse;
+
+import com.sun.tools.internal.xjc.api.Reference;
+
+import javax.xml.namespace.QName;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import com.sun.tools.internal.ws.processor.modeler.annotation.*;
+
+
+/**
+ *
+ * @author  dkohlert
+ */
+public class AnnotationProcessorContext {
+
+    private Map<String, SEIContext> seiContextMap;
+    private int round = 1;
+    private boolean modelCompleted = false;
+
+    /** Creates a new instance of AnnotationProcessorContext */
+    public AnnotationProcessorContext() {
+        seiContextMap = new HashMap<String, SEIContext>();
+    }
+
+    public void addSEIContext(String seiName, SEIContext seiContext) {
+        seiContextMap.put(seiName, seiContext);
+    }
+
+    public SEIContext getSEIContext(String seiName) {
+        SEIContext context =  seiContextMap.get(seiName);
+        if (context == null) {
+            context = new SEIContext(seiName);
+            addSEIContext(seiName, context);
+        }
+        return context;
+    }
+
+    public SEIContext getSEIContext(TypeDeclaration d) {
+        SEIContext context = getSEIContext(d.getQualifiedName());
+        return context;
+    }
+
+    public Collection<SEIContext> getSEIContexts() {
+        return seiContextMap.values();
+    }
+
+    public boolean allEncoded() {
+        for (SEIContext seiContext : seiContextMap.values()) {
+            if (!isEncoded(seiContext.getModel()))
+                return false;
+        }
+        return true;
+    }
+
+    public int getRound() {
+        return round;
+    }
+
+    public void incrementRound() {
+        round++;
+    }
+
+    public static boolean isEncoded(Model model) {
+        if (model == null)
+            return false;
+        for (Service service : model.getServices()) {
+            for (Port port : service.getPorts()) {
+                for (Operation operation : port.getOperations()) {
+                    if (operation.getUse() != null && operation.getUse().equals(SOAPUse.LITERAL))
+                        return false;
+                }
+            }
+        }
+        return true;
+    }
+
+    public void setModelCompleted(boolean modelCompleted) {
+        this.modelCompleted = modelCompleted;
+    }
+
+    public boolean isModelCompleted() {
+        return modelCompleted;
+    }
+
+    public static class SEIContext {
+        private Map<String, WrapperInfo> reqOperationWrapperMap;
+        private Map<String, WrapperInfo> resOperationWrapperMap;
+        private Map<String, FaultInfo> exceptionBeanMap;
+
+        private Model model;
+        private Map<Object, Reference> schemaReferences;
+        private Map<QName, Reference> schemaElements;
+
+        private boolean modelCompiled = false;
+        private String seiName;
+        private String seiImplName;
+        private boolean implementsSEI = false;
+        private JAXBModel jaxBModel;
+        private String namespaceURI = null;
+
+        public SEIContext(String seiName) {
+            reqOperationWrapperMap = new HashMap<String, WrapperInfo>();
+            resOperationWrapperMap = new HashMap<String, WrapperInfo>();
+            exceptionBeanMap = new HashMap<String,FaultInfo>();
+            schemaReferences = new HashMap<Object, Reference>();
+            schemaElements = new HashMap<QName, Reference>();
+            this.seiName = seiName;
+        }
+
+        public void setImplementsSEI(boolean implementsSEI) {
+            this.implementsSEI = implementsSEI;
+        }
+
+        public boolean getImplementsSEI() {
+            return implementsSEI;
+        }
+
+        public void setNamespaceURI(String namespaceURI) {
+            this.namespaceURI = namespaceURI;
+        }
+
+        public String getNamespaceURI() {
+            return namespaceURI;
+        }
+
+        public void setJAXBModel(JAXBModel model) {
+            this.jaxBModel = model;
+            if (this.model != null)
+                this.model.setJAXBModel(model);
+        }
+
+        public JAXBModel getJAXBModel() {
+            return jaxBModel;
+        }
+
+        public String getSEIName() {
+            return seiName;
+        }
+
+        public String getSEIImplName() {
+            return seiImplName;
+        }
+
+        public void setSEIImplName(String implName) {
+            seiImplName = implName;
+        }
+
+        public void setReqWrapperOperation(MethodDeclaration method, WrapperInfo wrapperInfo) {
+            reqOperationWrapperMap.put(methodToString(method), wrapperInfo);
+        }
+
+        public WrapperInfo getReqOperationWrapper(MethodDeclaration method) {
+            return reqOperationWrapperMap.get(methodToString(method));
+        }
+
+        public void setResWrapperOperation(MethodDeclaration method, WrapperInfo wrapperInfo) {
+            resOperationWrapperMap.put(methodToString(method), wrapperInfo);
+        }
+
+        public WrapperInfo getResOperationWrapper(MethodDeclaration method) {
+            return resOperationWrapperMap.get(methodToString(method));
+        }
+
+        public String methodToString(MethodDeclaration method) {
+            StringBuffer buf = new StringBuffer(method.getSimpleName());
+            for (ParameterDeclaration param : method.getParameters())
+                buf.append(";"+param.getType().toString());
+            return buf.toString();
+        }
+
+        public void setModel(Model model) {
+            this.model = model;
+            model.setJAXBModel(jaxBModel);
+        }
+
+        public Model getModel() {
+            return model;
+        }
+
+        public boolean getModelCompiled() {
+            return modelCompiled;
+        }
+
+        public void setModelCompiled(boolean compiled) {
+            modelCompiled = compiled;
+        }
+
+        public Collection<Reference> getSchemaReferences(ModelBuilder builder) {
+            return schemaReferences.values();
+        }
+
+        public Map<QName, Reference> getSchemaElementMap(ModelBuilder builder) {
+            return schemaElements;
+        }
+
+        public Collection<Reference> getSchemaReferences() {
+            return schemaReferences.values();
+        }
+
+        public void clearExceptionMap() {
+            exceptionBeanMap.clear();
+        }
+
+        public void addExceptionBeanEntry(String exception, FaultInfo faultInfo, ModelBuilder builder) {
+            exceptionBeanMap.put(exception,faultInfo);
+        }
+
+        public FaultInfo getExceptionBeanName(String exception) {
+            return exceptionBeanMap.get(exception);
+        }
+
+        public Reference addReference(MethodDeclaration method) {
+            Reference ref = schemaReferences.get(method);
+            if (ref == null)
+                ref = new Reference(method);
+            addReference(method, ref);
+            return ref;
+        }
+
+        public Reference addReference(ParameterDeclaration param) {
+            Reference ref = schemaReferences.get(param);
+            if (ref == null)
+                ref = new Reference(param);
+            addReference(param, ref);
+            return ref;
+        }
+
+        public Reference addReference(TypeMirror type, ParameterDeclaration param) {
+            Reference ref = schemaReferences.get(param);
+            if (ref == null)
+                ref = new Reference(type, param);
+            addReference(param, ref);
+            return ref;
+        }
+
+        public Reference addReference(TypeDeclaration type, AnnotationProcessorEnvironment apEnv) {
+            Reference ref = schemaReferences.get(type);
+            if (ref == null)
+                ref = new Reference(type, apEnv);
+            addReference(type, ref);
+            return ref;
+        }
+
+        private void addReference(Object key, Reference reference) {
+            schemaReferences.put(key, reference);
+        }
+
+        public Reference getReference(Object key) {
+            return schemaReferences.get(key);
+        }
+
+        public void addSchemaElement(QName elemName, Reference reference) {
+            if (elemName == null)
+                throw new RuntimeException();
+            schemaElements.put(elemName, reference);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/FaultInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/FaultInfo.java
new file mode 100644
index 0000000..e14c647
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/FaultInfo.java
@@ -0,0 +1,98 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import javax.xml.namespace.QName;
+import java.util.ArrayList;
+import java.util.List;
+import com.sun.tools.internal.ws.processor.modeler.annotation.*;
+
+/**
+ *
+ * @author  dkohlert
+ */
+public class FaultInfo {
+    public String beanName;
+    public TypeMoniker beanTypeMoniker;
+    public boolean isWSDLException;
+    public QName elementName;
+    public List<MemberInfo> members;
+
+    /** Creates a new instance of FaultInfo */
+    public FaultInfo() {
+    }
+    public FaultInfo(String beanName) {
+        this.beanName = beanName;
+    }
+    public FaultInfo(String beanName, boolean isWSDLException) {
+        this.beanName = beanName;
+        this.isWSDLException = isWSDLException;
+    }
+    public FaultInfo(TypeMoniker typeMoniker, boolean isWSDLException) {
+        this.beanTypeMoniker = typeMoniker;
+        this.isWSDLException = isWSDLException;
+    }
+
+    public void setIsWSDLException(boolean isWSDLException) {
+        this.isWSDLException = isWSDLException;
+    }
+
+    public boolean isWSDLException() {
+        return isWSDLException;
+    }
+
+    public void setBeanName(String beanName) {
+        this.beanName = beanName;
+    }
+
+    public String getBeanName() {
+        return beanName;
+    }
+
+    public void setElementName(QName elementName) {
+        this.elementName =  elementName;
+    }
+
+    public QName getElementName() {
+        return elementName;
+    }
+    public void setBeanTypeMoniker(TypeMoniker typeMoniker) {
+        this.beanTypeMoniker = typeMoniker;
+    }
+    public TypeMoniker getBeanTypeMoniker() {
+        return beanTypeMoniker;
+    }
+    public List<MemberInfo> getMembers() {
+        return members;
+    }
+    public void setMembers(List<MemberInfo> members) {
+        this.members = members;
+    }
+    public void addMember(MemberInfo member) {
+        if (members == null)
+            members = new ArrayList<MemberInfo>();
+        members.add(member);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/MakeSafeTypeVisitor.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/MakeSafeTypeVisitor.java
new file mode 100644
index 0000000..1666e50
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/MakeSafeTypeVisitor.java
@@ -0,0 +1,108 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+
+
+import com.sun.istack.internal.tools.APTTypeVisitor;
+
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.type.ArrayType;
+import com.sun.mirror.type.ClassType;
+import com.sun.mirror.type.DeclaredType;
+import com.sun.mirror.type.InterfaceType;
+import com.sun.mirror.type.PrimitiveType;
+import com.sun.mirror.type.ReferenceType;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.type.TypeVariable;
+import com.sun.mirror.type.VoidType;
+import com.sun.mirror.type.WildcardType;
+import com.sun.mirror.util.Types;
+
+import java.lang.reflect.Array;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.List;
+
+/**
+ *
+ * @author dkohlert
+ */
+public class MakeSafeTypeVisitor extends APTTypeVisitor<TypeMirror, Types> implements WebServiceConstants {
+    TypeDeclaration collectionDecl;
+    TypeDeclaration mapDecl;
+
+    /**
+     * Creates a new instance of MakeSafeTypeVisitor
+     */
+    public MakeSafeTypeVisitor(AnnotationProcessorEnvironment apEnv) {
+        collectionDecl = apEnv.getTypeDeclaration(COLLECTION_CLASSNAME);
+        mapDecl = apEnv.getTypeDeclaration(MAP_CLASSNAME);
+    }
+
+    protected TypeMirror onArrayType(ArrayType type, Types apTypes) {
+        return apTypes.getErasure(type);
+    }
+
+    protected TypeMirror onPrimitiveType(PrimitiveType type, Types apTypes) {
+        return apTypes.getErasure(type);
+    }
+
+    protected TypeMirror onClassType(ClassType type, Types apTypes) {
+        return processDeclaredType(type, apTypes);
+    }
+
+    protected TypeMirror onInterfaceType(InterfaceType type, Types apTypes) {
+        return processDeclaredType(type, apTypes);
+    }
+
+    private TypeMirror processDeclaredType(DeclaredType type, Types apTypes) {
+        if (TypeModeler.isSubtype(type.getDeclaration(), collectionDecl) ||
+            TypeModeler.isSubtype(type.getDeclaration(), mapDecl)) {
+            Collection<TypeMirror> args = type.getActualTypeArguments();
+            TypeMirror[] safeArgs = new TypeMirror[args.size()];
+            int i = 0;
+            for (TypeMirror arg : args) {
+                safeArgs[i++]= apply(arg, apTypes);
+            }
+            return apTypes.getDeclaredType(type.getDeclaration(), safeArgs);
+        }
+        return apTypes.getErasure(type);
+    }
+
+    protected TypeMirror onTypeVariable(TypeVariable type, Types apTypes) {
+        return apTypes.getErasure(type);
+    }
+
+    protected TypeMirror onVoidType(VoidType type, Types apTypes) {
+        return type;
+    }
+
+    protected TypeMirror onWildcard(WildcardType type, Types apTypes) {
+        return apTypes.getErasure(type);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/MemberInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/MemberInfo.java
new file mode 100644
index 0000000..e3aa05e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/MemberInfo.java
@@ -0,0 +1,68 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import javax.xml.namespace.QName;
+
+import com.sun.mirror.type.TypeMirror;
+
+/**
+ *
+ * @author  WS Development Team
+ */
+public class MemberInfo implements Comparable<MemberInfo> {
+    int paramIndex;
+    TypeMirror paramType;
+    String paramName;
+    QName elementName;
+
+    public MemberInfo(int paramIndex, TypeMirror paramType, String paramName,
+        QName elementName) {
+        this.paramIndex = paramIndex;
+        this.paramType = paramType;
+        this.paramName = paramName;
+        this.elementName = elementName;
+    }
+
+    public int getParamIndex() {
+        return paramIndex;
+    }
+
+    public TypeMirror getParamType() {
+        return paramType;
+    }
+
+    public String getParamName() {
+        return paramName;
+    }
+
+    public QName getElementName() {
+        return elementName;
+    }
+
+    public int compareTo(MemberInfo member) {
+        return paramName.compareTo(member.paramName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/ModelBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/ModelBuilder.java
new file mode 100644
index 0000000..13b26c5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/ModelBuilder.java
@@ -0,0 +1,75 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import java.io.File;
+
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.model.Service;
+import com.sun.tools.internal.ws.processor.modeler.ModelerException;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+import java.net.URL;
+import java.util.Properties;
+
+import com.sun.mirror.apt.*;
+import com.sun.mirror.declaration.*;
+import com.sun.mirror.type.*;
+import com.sun.mirror.util.*;
+
+import javax.xml.namespace.QName;
+import com.sun.tools.internal.ws.processor.modeler.annotation.*;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface ModelBuilder {
+    public AnnotationProcessorEnvironment getAPEnv();
+    public void createModel(TypeDeclaration d, QName modelName, String targetNamespace, String modelerClassName);
+    public void setService(Service service);
+    public void setPort(Port port);
+    public String getOperationName(String methodName);
+    public String getResponseName(String operationName);
+    public TypeMirror getHolderValueType(TypeMirror type);
+    public boolean checkAndSetProcessed(TypeDeclaration typeDecl);
+    public boolean isRemoteException(TypeDeclaration typeDecl);
+    public boolean isRemote(TypeDeclaration typeDecl);
+    public boolean canOverWriteClass(String className);
+    public void setWrapperGenerated(boolean wrapperGenerated);
+    public TypeDeclaration getTypeDeclaration(String typeName);
+    public String getSourceVersion();
+    public ProcessorEnvironment getProcessorEnvironment();
+    public File getSourceDir();
+    public String getXMLName(String javaName);
+    public void onError(String key);
+    public void onError(String key, Object[] args) throws ModelerException;
+    public void onError(SourcePosition srcPos, String key, Object[] args) throws ModelerException;
+    public void onError(Localizable msg) throws ModelerException;
+    public void onWarning(Localizable msg);
+    public void onInfo(Localizable msg);
+    public void log(String msg);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeModeler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeModeler.java
new file mode 100644
index 0000000..959acba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeModeler.java
@@ -0,0 +1,285 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+
+import com.sun.mirror.apt.*;
+import com.sun.mirror.declaration.*;
+import com.sun.mirror.type.*;
+import com.sun.mirror.util.*;
+
+import com.sun.tools.internal.ws.processor.modeler.annotation.*;
+import com.sun.xml.internal.ws.util.StringUtils;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class TypeModeler implements WebServiceConstants {
+
+    public static TypeDeclaration getDeclaration(TypeMirror typeMirror) {
+        TypeDeclaration retDecl = null;
+        if (typeMirror instanceof DeclaredType)
+            return ((DeclaredType)typeMirror).getDeclaration();
+        return null;
+    }
+
+    public static TypeDeclaration getTypeDeclaration(TypeMirror type) {
+        TypeDeclaration typeDecl = null;
+        if (type instanceof ClassType)
+            typeDecl = ((ClassType)type).getDeclaration();
+        else
+            typeDecl = ((InterfaceType)type).getDeclaration();
+        return typeDecl;
+    }
+
+    public static Collection<InterfaceType> getSuperinterfaces(TypeMirror type) {
+        Collection<InterfaceType> interfaces = null;
+        if (type instanceof ClassType)
+            interfaces = ((ClassType)type).getSuperinterfaces();
+        else
+            interfaces = ((InterfaceType)type).getSuperinterfaces();
+        return interfaces;
+    }
+
+    public static Collection<InterfaceType> getSuperinterfaces(TypeDeclaration type) {
+        Collection<InterfaceType> interfaces = null;
+        if (type instanceof ClassDeclaration)
+            interfaces = ((ClassDeclaration)type).getSuperinterfaces();
+        else
+            interfaces = ((InterfaceDeclaration)type).getSuperinterfaces();
+        return interfaces;
+    }
+
+    public static TypeDeclaration getDeclaringClassMethod(
+        TypeMirror theClass,
+        String methodName,
+        TypeMirror[] args) {
+
+        return getDeclaringClassMethod(getDeclaration(theClass), methodName, args);
+    }
+
+    public static TypeDeclaration getDeclaringClassMethod(
+        TypeDeclaration theClass,
+        String methodName,
+        TypeMirror[] args) {
+
+        TypeDeclaration retClass = null;
+        if (theClass instanceof ClassDeclaration) {
+            ClassType superClass = ((ClassDeclaration)theClass).getSuperclass();
+            if (superClass != null)
+                retClass = getDeclaringClassMethod(superClass, methodName, args);
+        }
+        if (retClass == null) {
+            for (InterfaceType interfaceType : getSuperinterfaces(theClass))
+                retClass =
+                    getDeclaringClassMethod(interfaceType, methodName, args);
+        }
+        if (retClass == null) {
+            Collection<? extends MethodDeclaration> methods;
+            methods = theClass.getMethods();
+            for (MethodDeclaration method : methods) {
+                if (method.getSimpleName().equals(methodName) &&
+                    method.getDeclaringType().equals(theClass)) {
+                    retClass = theClass;
+                    break;
+                }
+            }
+        }
+        return retClass;
+    }
+
+    public static Collection<InterfaceType> collectInterfaces(TypeDeclaration type) {
+        Collection<InterfaceType> superInterfaces = type.getSuperinterfaces();
+        Collection<InterfaceType> interfaces = type.getSuperinterfaces();
+        for (InterfaceType interfaceType : superInterfaces) {
+            interfaces.addAll(collectInterfaces(getDeclaration(interfaceType)));
+        }
+        return interfaces;
+    }
+
+    public static boolean isSubclass(String subTypeName, String superTypeName,
+        AnnotationProcessorEnvironment env) {
+        return isSubclass(env.getTypeDeclaration(subTypeName),
+                          env.getTypeDeclaration(superTypeName));
+    }
+
+    public static boolean isSubclass(
+        TypeDeclaration subType,
+        TypeDeclaration superType) {
+
+        if (subType.equals(superType))
+            return false;
+        return isSubtype(subType, superType);
+    }
+
+    public static TypeMirror getHolderValueType(
+        TypeMirror type,
+        TypeDeclaration defHolder,
+        AnnotationProcessorEnvironment env) {
+
+        TypeDeclaration typeDecl = getDeclaration(type);
+        if (typeDecl == null)
+            return null;
+
+        if (isSubtype(typeDecl, defHolder)) {
+            if  (type instanceof DeclaredType) {
+                Collection<TypeMirror> argTypes = ((DeclaredType)type).getActualTypeArguments();
+                if (argTypes.size() == 1) {
+                    TypeMirror mirror = argTypes.iterator().next();
+//                        System.out.println("argsTypes.iterator().next(): "+mirror);
+                    return mirror;
+                }
+                else if (argTypes.size() == 0) {
+                    FieldDeclaration member = getValueMember(typeDecl);
+                    if (member != null) {
+//                            System.out.println("member: "+member+" getType(): "+member.getType());
+                        return member.getType();
+                    }
+                }
+            }
+        }
+        return null;
+    }
+
+    public static FieldDeclaration getValueMember(TypeMirror classType) {
+        return getValueMember(getDeclaration(classType));
+    }
+
+    public static FieldDeclaration getValueMember(TypeDeclaration type) {
+        FieldDeclaration member = null;
+        for (FieldDeclaration field : type.getFields()){
+            if (field.getSimpleName().equals("value")) {
+                member = field;
+                break;
+            }
+        }
+        if (member == null) {
+            if (type instanceof ClassDeclaration)
+                member = getValueMember(((ClassDeclaration)type).getSuperclass());
+        }
+        return member;
+    }
+
+
+    /* is d1 a subtype of d2 */
+    public static boolean isSubtype(TypeDeclaration d1, TypeDeclaration d2) {
+        if (d1.equals(d2))
+            return true;
+        ClassDeclaration superClassDecl = null;
+        if (d1 instanceof ClassDeclaration) {
+            ClassType superClass = ((ClassDeclaration)d1).getSuperclass();
+            if (superClass != null) {
+                superClassDecl = superClass.getDeclaration();
+                if (superClassDecl.equals(d2))
+                    return true;
+            }
+        }
+        for (InterfaceType superIntf : d1.getSuperinterfaces()) {
+            if (superIntf.getDeclaration().equals(d2)) {
+                return true;
+            }
+            if (isSubtype(superIntf.getDeclaration(), d2)) {
+                return true;
+            } else if (superClassDecl != null && isSubtype(superClassDecl, d2)) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    public static Map<String,TypeMirror> getExceptionProperties(TypeMirror type) {
+        return getExceptionProperties(getDeclaration(type));
+    }
+
+    public static Map<String,TypeMirror> getExceptionProperties(TypeDeclaration type) {
+        Map<String, TypeMirror> members = new HashMap<String, TypeMirror>();
+        collectExceptionProperties(type, members);
+        return members;
+    }
+
+    public static void collectExceptionProperties(TypeMirror type, Map<String,TypeMirror> members) {
+        collectExceptionProperties(getDeclaration(type), members);
+    }
+
+    public static void collectExceptionProperties(TypeDeclaration type, Map<String,TypeMirror> members) {
+//        System.out.println("type: "+type.toString());
+        Collection<? extends MethodDeclaration> methods;
+        methods = type.getMethods();
+        for (MethodDeclaration method : methods) {
+            Collection<Modifier> modifiers = method.getModifiers();
+            if (!modifiers.contains(Modifier.PUBLIC)
+                || (modifiers.contains(Modifier.FINAL) &&
+                    modifiers.contains(Modifier.STATIC))
+                || modifiers.contains(Modifier.TRANSIENT)) { // no final static, transient, non-public
+                continue;
+            }
+            String name = method.getSimpleName();
+            if (name.length() <= 3 && !name.startsWith(IS_PREFIX) ||
+                skipProperties.contains(name)) {
+                // Optimization. Don't bother with invalid propertyNames.
+                continue;
+            }
+            TypeMirror resultType = method.getReturnType();
+            Collection<ParameterDeclaration> params = method.getParameters();
+            if (params.size() == 0) {
+                if (name.startsWith(GET_PREFIX) &&
+                    !(resultType instanceof PrimitiveType &&
+                           ((PrimitiveType)resultType).getKind() == PrimitiveType.Kind.BOOLEAN)) {
+                    // Simple getter
+//                    System.out.println("exception property: "+ StringUtils.decapitalize(name.substring(3)));
+                members.put(StringUtils.decapitalize(name.substring(3)), resultType);
+            } else if (resultType instanceof PrimitiveType &&
+                           ((PrimitiveType)resultType).getKind() == PrimitiveType.Kind.BOOLEAN &&
+                           name.startsWith(IS_PREFIX)) {
+                    // Boolean getter
+//                    System.out.println("exception property: "+ StringUtils.decapitalize(name.substring(2)));
+                    members.put(StringUtils.decapitalize(name.substring(2)), resultType);
+                }
+            }
+        }
+//        System.out.println("type class: "+type.getClass().toString());
+        if (type instanceof ClassDeclaration && ((ClassDeclaration)type).getSuperclass() != null)  {
+            collectExceptionProperties(((ClassDeclaration)type).getSuperclass(), members);
+        }
+        for (InterfaceType intfType : getSuperinterfaces(type)) {
+            collectExceptionProperties(intfType, members);
+        }
+    }
+
+    private static Set<String> skipProperties = new HashSet<String> ();
+    static{
+        skipProperties.add("getCause");
+        skipProperties.add("getLocalizedMessage");
+        skipProperties.add("getClass");
+        skipProperties.add("getStackTrace");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeMoniker.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeMoniker.java
new file mode 100644
index 0000000..41934cb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeMoniker.java
@@ -0,0 +1,38 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.tools.internal.ws.processor.modeler.annotation.*;
+
+/**
+ *
+ * @author  dkohlert
+ */
+public interface TypeMoniker {
+
+    public TypeMirror create(AnnotationProcessorEnvironment apEnv);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeMonikerFactory.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeMonikerFactory.java
new file mode 100644
index 0000000..c4dba54
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/TypeMonikerFactory.java
@@ -0,0 +1,110 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.type.*;
+import com.sun.mirror.util.Types;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+
+import java.util.Collection;
+import java.util.ArrayList;
+import com.sun.tools.internal.ws.processor.modeler.annotation.*;
+
+/**
+ *
+ * @author  dkohlert
+ */
+public class TypeMonikerFactory {
+
+    public static TypeMoniker getTypeMoniker(TypeMirror typeMirror) {
+        if (typeMirror instanceof PrimitiveType)
+            return new PrimitiveTypeMoniker((PrimitiveType)typeMirror);
+        else if (typeMirror instanceof ArrayType)
+            return new ArrayTypeMoniker((ArrayType)typeMirror);
+        else if (typeMirror instanceof DeclaredType)
+            return new DeclaredTypeMoniker((DeclaredType)typeMirror);
+        return getTypeMoniker(typeMirror.toString());
+    }
+
+    public static TypeMoniker getTypeMoniker(String typeName) {
+        return new StringMoniker(typeName);
+    }
+
+    static class ArrayTypeMoniker implements TypeMoniker {
+        private TypeMoniker arrayType;
+
+        public ArrayTypeMoniker(ArrayType type) {
+            arrayType = TypeMonikerFactory.getTypeMoniker(type.getComponentType());
+        }
+
+        public TypeMirror create(AnnotationProcessorEnvironment apEnv) {
+            return apEnv.getTypeUtils().getArrayType(arrayType.create(apEnv));
+        }
+    }
+    static class DeclaredTypeMoniker implements TypeMoniker {
+        private String typeDeclName;
+        private Collection<TypeMoniker> typeArgs = new ArrayList<TypeMoniker>();
+
+        public DeclaredTypeMoniker(DeclaredType type) {
+            typeDeclName = type.getDeclaration().getQualifiedName();
+            for (TypeMirror arg : type.getActualTypeArguments())
+                typeArgs.add(TypeMonikerFactory.getTypeMoniker(arg));
+        }
+
+        public TypeMirror create(AnnotationProcessorEnvironment apEnv) {
+            TypeDeclaration typeDecl = apEnv.getTypeDeclaration(typeDeclName);
+            TypeMirror[] tmpArgs = new TypeMirror[typeArgs.size()];
+            int idx = 0;
+            for (TypeMoniker moniker : typeArgs)
+                tmpArgs[idx++] = moniker.create(apEnv);
+
+            return apEnv.getTypeUtils().getDeclaredType(typeDecl, tmpArgs);
+        }
+    }
+    static class PrimitiveTypeMoniker implements TypeMoniker {
+        private PrimitiveType.Kind kind;
+
+        public PrimitiveTypeMoniker(PrimitiveType type) {
+            kind = type.getKind();
+        }
+
+        public TypeMirror create(AnnotationProcessorEnvironment apEnv) {
+            return apEnv.getTypeUtils().getPrimitiveType(kind);
+        }
+    }
+    static class StringMoniker implements TypeMoniker {
+        private String typeName;
+
+        public StringMoniker(String typeName) {
+            this.typeName = typeName;
+        }
+
+        public TypeMirror create(AnnotationProcessorEnvironment apEnv) {
+            return apEnv.getTypeUtils().getDeclaredType(apEnv.getTypeDeclaration(typeName));
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceAP.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceAP.java
new file mode 100644
index 0000000..db23b74
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceAP.java
@@ -0,0 +1,492 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import com.sun.mirror.apt.AnnotationProcessor;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.apt.Messager;
+import com.sun.mirror.declaration.ClassDeclaration;
+import com.sun.mirror.declaration.InterfaceDeclaration;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.declaration.TypeParameterDeclaration;
+import com.sun.mirror.type.ClassType;
+import com.sun.mirror.type.InterfaceType;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.util.SourcePosition;
+import com.sun.tools.internal.ws.processor.ProcessorNotificationListener;
+import com.sun.tools.internal.ws.processor.ProcessorOptions;
+import com.sun.tools.internal.ws.processor.generator.GeneratorUtil;
+import com.sun.tools.internal.ws.processor.generator.Names;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.model.ModelProperties;
+import com.sun.tools.internal.ws.processor.model.Operation;
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.model.Service;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBModel;
+import com.sun.tools.internal.ws.processor.modeler.ModelerException;
+import com.sun.tools.internal.ws.processor.modeler.annotation.AnnotationProcessorContext.SEIContext;
+import com.sun.tools.internal.ws.processor.util.ClientProcessorEnvironment;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.util.ToolBase;
+import com.sun.tools.internal.ws.ToolVersion;
+import com.sun.tools.internal.xjc.api.JavaCompiler;
+import com.sun.tools.internal.xjc.api.Reference;
+import com.sun.tools.internal.xjc.api.XJC;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessage;
+
+import javax.jws.WebService;
+import javax.xml.namespace.QName;
+import javax.xml.ws.WebServiceProvider;
+
+import java.io.ByteArrayOutputStream;
+import java.io.File;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Properties;
+import java.util.Set;
+
+
+
+/**
+ * WebServiceAP is a APT AnnotationProcessor for processing javax.jws.* and
+ * javax.xml.ws.* annotations. This class is used either by the WsGen (CompileTool) tool or
+ *    idirectly via the {@link com.sun.istack.internal.ws.WSAP WSAP} when invoked by APT.
+ *
+ * @author WS Development Team
+ */
+public class WebServiceAP extends ToolBase implements AnnotationProcessor, ModelBuilder, WebServiceConstants,
+    ProcessorNotificationListener {
+
+    protected AnnotationProcessorEnvironment apEnv;
+    protected ProcessorEnvironment env;
+
+    private File sourceDir;
+
+    // the model being build
+    private Model model;
+
+    private TypeDeclaration remoteDecl;
+    private TypeDeclaration remoteExceptionDecl;
+    private TypeDeclaration exceptionDecl;
+    private TypeDeclaration defHolderDecl;
+    private Service service;
+    private Port port;
+    protected AnnotationProcessorContext context;
+    private Set<TypeDeclaration> processedTypeDecls = new HashSet<TypeDeclaration>();
+    protected Messager messager;
+    private ByteArrayOutputStream output;
+    private ToolBase tool;
+    private boolean doNotOverWrite = false;
+    private boolean wrapperGenerated = false;
+    /*
+     * Is this invocation from APT or JavaC?
+     */
+    private boolean isAPTInvocation = false;
+
+
+    public void run() {
+    }
+
+    protected  boolean parseArguments(String[] args) {
+       return true;
+    }
+
+    public WebServiceAP(ToolBase tool, ProcessorEnvironment env, Properties options,  AnnotationProcessorContext context) {
+        super(System.out, "WebServiceAP");
+        this.context = context;
+        this.tool = tool;
+        this.env = env;
+        if (options != null) {
+            sourceDir = new File(options.getProperty(ProcessorOptions.SOURCE_DIRECTORY_PROPERTY));
+            String key = ProcessorOptions.DONOT_OVERWRITE_CLASSES;
+            this.doNotOverWrite =
+                Boolean.valueOf(options.getProperty(key));
+        }
+    }
+
+    public void init(AnnotationProcessorEnvironment apEnv) {
+        this.apEnv = apEnv;
+        remoteDecl = this.apEnv.getTypeDeclaration(REMOTE_CLASSNAME);
+        remoteExceptionDecl = this.apEnv.getTypeDeclaration(REMOTE_EXCEPTION_CLASSNAME);
+        exceptionDecl = this.apEnv.getTypeDeclaration(EXCEPTION_CLASSNAME);
+        defHolderDecl = this.apEnv.getTypeDeclaration(HOLDER_CLASSNAME);
+
+        if (env == null) {
+            Map<String, String> apOptions = apEnv.getOptions();
+            output = new ByteArrayOutputStream();
+            String classDir = apOptions.get("-d");
+            if (classDir == null)
+                classDir = ".";
+            if (apOptions.get("-s") != null)
+                sourceDir = new File(apOptions.get("-s"));
+            else
+                sourceDir = new File(classDir);
+            String cp = apOptions.get("-classpath");
+            String cpath = classDir +
+                    File.pathSeparator +
+                    cp + File.pathSeparator +
+                    System.getProperty("java.class.path");
+            env = new ClientProcessorEnvironment(output, cpath, this);
+            ((ClientProcessorEnvironment) env).setNames(new Names());
+            boolean setVerbose = false;
+            for (String key : apOptions.keySet()) {
+                if (key.equals("-verbose"))
+                    setVerbose=true;
+            }
+            if (setVerbose) {
+                env.setFlags(ProcessorEnvironment.F_VERBOSE);
+            }
+            messager = apEnv.getMessager();
+            isAPTInvocation = true;
+        }
+        env.setFiler(apEnv.getFiler());
+    }
+
+    public AnnotationProcessorEnvironment getAPEnv() {
+        return apEnv;
+    }
+
+    public ProcessorEnvironment getEnvironment() {
+        return env;
+    }
+
+    public ProcessorEnvironment getProcessorEnvironment() {
+        return env;
+    }
+
+    public File getSourceDir() {
+        return sourceDir;
+    }
+
+    public void onError(String key) {
+        onError(new LocalizableMessage(getResourceBundleName(), key));
+    }
+
+    public void onError(String key, Object[] args) throws ModelerException {
+        onError(null, key, args);
+    }
+
+    public void onError(SourcePosition pos, String key, Object[] args) throws ModelerException {
+        onError(pos, new LocalizableMessage(getResourceBundleName(), key, args));
+    }
+
+    public void onError(Localizable msg) throws ModelerException {
+        onError(null, msg);
+    }
+
+    public void onError(SourcePosition pos, Localizable msg) throws ModelerException {
+        if (messager != null) {
+            messager.printError(pos, localizer.localize(msg));
+        } else {
+            throw new ModelerException(msg);
+        }
+    }
+
+    public void onWarning(String key) {
+        onWarning(new LocalizableMessage(getResourceBundleName(), key));
+    }
+
+    public void onWarning(Localizable msg) {
+        String message = localizer.localize(getMessage("webserviceap.warning", localizer.localize(msg)));
+        if (messager != null) {
+            messager.printWarning(message);
+        } else {
+            report(message);
+        }
+    }
+    public void onInfo(Localizable msg) {
+        if (messager != null) {
+            String message = localizer.localize(msg);
+            messager.printNotice(message);
+        } else {
+            String message = localizer.localize(getMessage("webserviceap.info", localizer.localize(msg)));
+            report(message);
+        }
+    }
+
+    public void process() {
+        if (context.getRound() == 1) {
+            buildModel();
+        }
+        if (!wrapperGenerated  || // the wrappers already exist
+            context.getRound() == 2 ||
+            context.allEncoded()) {
+            if ((context.getRound() == 2 || !wrapperGenerated) && !context.isModelCompleted()) {
+                completeModel();
+                context.setModelCompleted(true);
+            }
+            try {
+                for (SEIContext seiContext : context.getSEIContexts()) {
+                    if (!seiContext.getModelCompiled()) {
+                        runProcessorActions(seiContext.getModel());
+                        seiContext.setModelCompiled(true);
+                    }
+                }
+            } catch(Exception e) {
+                e.printStackTrace();
+            } finally {
+                if (messager != null && output != null && output.size() > 0) {
+                    messager.printNotice(output.toString());
+                }
+            }
+        }
+        context.incrementRound();
+    }
+
+    public boolean checkAndSetProcessed(TypeDeclaration typeDecl) {
+        if (!processedTypeDecls.contains(typeDecl)) {
+            processedTypeDecls.add(typeDecl);
+            return false;
+        }
+        return true;
+    }
+
+    public void clearProcessed() {
+        processedTypeDecls.clear();
+    }
+
+    protected void runProcessorActions(Model model) throws Exception {
+        if (tool != null)
+            tool.runProcessorActions();
+    }
+
+
+    protected String getGenericErrorMessage() {
+        return "webserviceap.error";
+    }
+
+    protected String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.webserviceap";
+    }
+
+    public void createModel(TypeDeclaration d, QName modelName, String targetNamespace,
+        String modelerClassName){
+
+        SEIContext seiContext = context.getSEIContext(d);
+        if (seiContext.getModel() != null) {
+            onError("webserviceap.model.already.exists");
+            return;
+        }
+        log("creating model: " + modelName);
+        model = new Model(modelName);
+        model.setTargetNamespaceURI(targetNamespace);
+        model.setProperty(
+            ModelProperties.PROPERTY_MODELER_NAME,
+            modelerClassName);
+        seiContext.setModel(model);
+    }
+
+    public void setService(Service service) {
+        this.service = service;
+        model.addService(service);
+    }
+
+    public void setPort(Port port) {
+        this.port = port;
+        service.addPort(port);
+    }
+
+    public void addOperation(Operation operation) {
+        port.addOperation(operation);
+    }
+
+    public void setWrapperGenerated(boolean wrapperGenerated) {
+        this.wrapperGenerated = wrapperGenerated;
+    }
+
+    public TypeDeclaration getTypeDeclaration(String typeName) {
+        return apEnv.getTypeDeclaration(typeName);
+    }
+
+    public String getSourceVersion() {
+        return ToolVersion.VERSION.MAJOR_VERSION;
+    }
+
+    private void buildModel() {
+        WebService webService;
+        WebServiceProvider webServiceProvider = null;
+        WebServiceVisitor wrapperGenerator = createWrapperGenerator();
+        boolean processedEndpoint = false;
+        for (TypeDeclaration typedecl: apEnv.getTypeDeclarations()) {
+            if (!(typedecl instanceof ClassDeclaration))
+                continue;
+            webServiceProvider = typedecl.getAnnotation(WebServiceProvider.class);
+            webService = typedecl.getAnnotation(WebService.class);
+            if (webServiceProvider != null) {
+                if (webService != null) {
+                    onError("webserviceap.webservice.and.webserviceprovider",
+                            new Object[] {typedecl.getQualifiedName()});
+                }
+                processedEndpoint = true;
+            }
+            if (!shouldProcessWebService(webService))
+                continue;
+            typedecl.accept(wrapperGenerator);
+            processedEndpoint = true;
+        }
+        if (!processedEndpoint) {
+            if (isAPTInvocation)
+                onWarning("webserviceap.no.webservice.endpoint.found");
+            else
+                onError("webserviceap.no.webservice.endpoint.found");
+        }
+    }
+
+    protected WebServiceVisitor createWrapperGenerator() {
+        return new WebServiceWrapperGenerator(this, context);
+    }
+
+    protected WebServiceVisitor createReferenceCollector() {
+        return new WebServiceReferenceCollector(this, context);
+    }
+
+    protected boolean shouldProcessWebService(WebService webService) {
+        return webService != null;
+    }
+
+
+    private void completeModel() {
+        clearProcessed();
+        JavaCompiler javaC = XJC.createJavaCompiler();
+        JAXBModel jaxBModel;
+        WebServiceVisitor referenceCollector = createReferenceCollector();
+        for (SEIContext seiContext : context.getSEIContexts()) {
+            log("completing model for endpoint: "+seiContext.getSEIImplName());
+            TypeDeclaration decl = apEnv.getTypeDeclaration(seiContext.getSEIImplName());
+            if (decl == null)
+                onError("webserviceap.could.not.find.typedecl",
+                         new Object[] {seiContext.getSEIImplName(), context.getRound()});
+            decl.accept(referenceCollector);
+        }
+        clearProcessed();
+        for (SEIContext seiContext : context.getSEIContexts()) {
+            TypeDeclaration decl = apEnv.getTypeDeclaration(seiContext.getSEIName());
+            Collection<Reference> schemaMirrors = seiContext.getSchemaReferences(this);
+
+//            System.out.println("schemaMirrors count: " + schemaMirrors.size());
+//            for (Reference reference : schemaMirrors) {System.out.println("reference: "+reference.type);}
+//        System.out.println("schemaElementMap count: "+ seiContext.getSchemaElementMap(this).entrySet().size());
+//            for (Map.Entry<QName, ? extends Reference> entry : seiContext.getSchemaElementMap(this).entrySet()) {
+//               System.out.println("name: " + entry.getKey()+" value: "+entry.getValue().type);
+//            }
+
+//            System.out.println("setting default namespaceURI: "+seiContext.getNamespaceURI());
+            jaxBModel = new JAXBModel(javaC.bind(schemaMirrors, seiContext.getSchemaElementMap(this),
+                seiContext.getNamespaceURI(), apEnv));
+//            for (JAXBMapping map : jaxBModel.getMappings()) {System.out.println("map.getClazz: "+map.getClazz());}
+            seiContext.setJAXBModel(jaxBModel);
+        }
+    }
+
+    public boolean isException(TypeDeclaration typeDecl) {
+        return isSubtype(typeDecl, exceptionDecl);
+    }
+
+    public boolean isRemoteException(TypeDeclaration typeDecl) {
+        return isSubtype(typeDecl, remoteExceptionDecl);
+    }
+
+    public boolean isRemote(TypeDeclaration typeDecl) {
+        return isSubtype(typeDecl, remoteDecl);
+    }
+
+
+    public static boolean isSubtype(TypeDeclaration d1, TypeDeclaration d2) {
+        if (d1.equals(d2))
+            return true;
+        ClassDeclaration superClassDecl = null;
+        if (d1 instanceof ClassDeclaration) {
+            ClassType superClass = ((ClassDeclaration)d1).getSuperclass();
+            if (superClass != null) {
+                superClassDecl = superClass.getDeclaration();
+                if (superClassDecl.equals(d2))
+                    return true;
+            }
+        }
+        InterfaceDeclaration superIntf = null;
+        for (InterfaceType interfaceType : d1.getSuperinterfaces()) {
+            superIntf = interfaceType.getDeclaration();
+            if (superIntf.equals(d2))
+                return true;
+        }
+        if (superIntf != null && isSubtype(superIntf, d2)) {
+            return true;
+        } else if (superClassDecl != null && isSubtype(superClassDecl, d2)) {
+            return true;
+        }
+        return false;
+    }
+
+
+    public static String getMethodSig(MethodDeclaration method) {
+        StringBuffer buf = new StringBuffer(method.getSimpleName() + "(");
+        Iterator<TypeParameterDeclaration> params = method.getFormalTypeParameters().iterator();
+        TypeParameterDeclaration param;
+        for (int i =0; params.hasNext(); i++) {
+            if (i > 0)
+                buf.append(", ");
+            param = params.next();
+            buf.append(param.getSimpleName());
+        }
+        buf.append(")");
+        return buf.toString();
+    }
+
+    public String getOperationName(String messageName) {
+        return messageName;
+    }
+
+    public String getResponseName(String operationName) {
+        return Names.getResponseName(operationName);
+    }
+
+
+    public TypeMirror getHolderValueType(TypeMirror type) {
+        return TypeModeler.getHolderValueType(type, defHolderDecl, apEnv);
+    }
+
+    public boolean canOverWriteClass(String className) {
+        return !((doNotOverWrite && GeneratorUtil.classExists(env, className)));
+    }
+
+    public void log(String msg) {
+        if (env != null && env.verbose()) {
+            String message = "[" + msg + "]";
+            if (messager != null) {
+                messager.printNotice(message);
+            } else {
+                System.out.println(message);
+            }
+        }
+    }
+
+    public String getXMLName(String javaName) {
+        return javaName;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceConstants.java
new file mode 100644
index 0000000..9ff20b7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceConstants.java
@@ -0,0 +1,95 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+
+import javax.xml.ws.Holder;
+/**
+ *
+ * @author  dkohlert
+ */
+public interface WebServiceConstants { //extends RmiConstants {
+
+    public static final String RETURN                       = "return";
+    public static final String RETURN_CAPPED                = "Return";
+    public static final String RETURN_VALUE                 = "_return";
+    public static final String SERVICE                      = "Service";
+    public static final String PD                           = ".";
+    public static final String JAXWS                        = "jaxws";
+    public static final String JAXWS_PACKAGE_PD             = JAXWS+PD;
+    public static final String PD_JAXWS_PACKAGE_PD          = PD+JAXWS+PD;
+    public static final String BEAN                         = "Bean";
+    public static final String GET_PREFIX                   = "get";
+    public static final String IS_PREFIX                    = "is";
+    public static final String FAULT_INFO                   = "faultInfo";
+    public static final String GET_FAULT_INFO               = "getFaultInfo";
+    public static final String HTTP_PREFIX                  = "http://";
+    public static final String JAVA_LANG_OBJECT             = "java.lang.Object";
+    public static final String EMTPY_NAMESPACE_ID           = "";
+
+
+    public static final char SIGC_INNERCLASS  = '$';
+    public static final char SIGC_UNDERSCORE  = '_';
+
+    public static final String DOT = ".";
+    public static final String PORT = "Port";
+    public static final String BINDING = "Binding";
+    public static final String RESPONSE = "Response";
+
+    /*
+     * Identifiers potentially useful for all Generators
+     */
+    public static final String EXCEPTION_CLASSNAME =
+        java.lang.Exception.class.getName();
+    public static final String REMOTE_CLASSNAME =
+        java.rmi.Remote.class.getName();
+    public static final String REMOTE_EXCEPTION_CLASSNAME =
+        java.rmi.RemoteException.class.getName();
+    public static final String RUNTIME_EXCEPTION_CLASSNAME =
+        java.lang.RuntimeException.class.getName();
+    public static final String SERIALIZABLE_CLASSNAME =
+        java.io.Serializable.class.getName();
+    public static final String HOLDER_CLASSNAME =
+        javax.xml.ws.Holder.class.getName();
+    public static final String COLLECTION_CLASSNAME =
+        java.util.Collection.class.getName();
+    public static final String MAP_CLASSNAME =
+        java.util.Map.class.getName();
+
+
+    // 181 constants
+    public static final String WEBSERVICE_NAMESPACE         = "http://www.bea.com/xml/ns/jws";
+    public static final String HANDLER_CONFIG               = "handler-config";
+    public static final String HANDLER_CHAIN                = "handler-chain";
+    public static final String HANDLER_CHAIN_NAME           = "handler-chain-name";
+    public static final String HANDLER                      = "handler";
+    public static final String HANDLER_NAME                 = "handler-name";
+    public static final String HANDLER_CLASS                = "handler-class";
+    public static final String INIT_PARAM                   = "init-param";
+    public static final String SOAP_ROLE                    = "soap-role";
+    public static final String SOAP_HEADER                  = "soap-header";
+    public static final String PARAM_NAME                   = "param-name";
+    public static final String PARAM_VALUE                  = "param-value";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceReferenceCollector.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceReferenceCollector.java
new file mode 100644
index 0000000..5d53ce3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceReferenceCollector.java
@@ -0,0 +1,87 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import com.sun.mirror.apt.*;
+import com.sun.mirror.declaration.*;
+import com.sun.mirror.type.*;
+
+import com.sun.tools.internal.xjc.api.*;
+
+import javax.jws.*;
+
+/**
+ *
+ * @author  WS Development Team
+ */
+public class WebServiceReferenceCollector extends WebServiceVisitor {
+
+    public WebServiceReferenceCollector(ModelBuilder builder, AnnotationProcessorContext context) {
+        super(builder, context);
+    }
+
+
+    protected void processWebService(WebService webService, TypeDeclaration d) {
+    }
+
+    protected void processMethod(MethodDeclaration method, WebMethod webMethod) {
+        boolean isOneway = method.getAnnotation(Oneway.class) != null;
+        boolean generatedWrapper = false;
+        builder.log("WebServiceReferenceCollector - method: "+method);
+        collectTypes(method, webMethod, seiContext.getReqOperationWrapper(method) != null);
+        if (seiContext.getReqOperationWrapper(method) != null) {
+            AnnotationProcessorEnvironment apEnv = builder.getAPEnv();
+            TypeDeclaration typeDecl;
+            typeDecl = builder.getTypeDeclaration(seiContext.getReqOperationWrapper(method).getWrapperName());
+            seiContext.addReference(typeDecl, apEnv);
+            if (!isOneway) {
+                typeDecl = builder.getTypeDeclaration(seiContext.getResOperationWrapper(method).getWrapperName());
+                seiContext.addReference(typeDecl, apEnv);
+            }
+        }
+        collectExceptionBeans(method);
+    }
+
+    private void collectTypes(MethodDeclaration method, WebMethod webMethod, boolean isDocLitWrapped) {
+        addSchemaElements(method, isDocLitWrapped);
+    }
+
+
+    private void collectExceptionBeans(MethodDeclaration method) {
+        AnnotationProcessorEnvironment apEnv = builder.getAPEnv();
+        for (ReferenceType thrownType : method.getThrownTypes()) {
+            FaultInfo faultInfo = seiContext.getExceptionBeanName(thrownType.toString());
+            if (faultInfo != null) {
+                if (!faultInfo.isWSDLException()) {
+                    seiContext.addReference(builder.getTypeDeclaration(faultInfo.getBeanName()), apEnv);
+                } else {
+                    TypeMirror bean = faultInfo.beanTypeMoniker.create(apEnv);
+                    Reference ref = seiContext.addReference(((DeclaredType)bean).getDeclaration(), apEnv);
+                    seiContext.addSchemaElement(faultInfo.getElementName(), ref);
+                }
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceVisitor.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceVisitor.java
new file mode 100644
index 0000000..6c78b15
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceVisitor.java
@@ -0,0 +1,905 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+
+import com.sun.mirror.declaration.ClassDeclaration;
+import com.sun.mirror.declaration.ConstructorDeclaration;
+import com.sun.mirror.declaration.Declaration;
+import com.sun.mirror.declaration.FieldDeclaration;
+import com.sun.mirror.declaration.InterfaceDeclaration;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.Modifier;
+import com.sun.mirror.declaration.PackageDeclaration;
+import com.sun.mirror.declaration.ParameterDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.type.ClassType;
+import com.sun.mirror.type.DeclaredType;
+import com.sun.mirror.type.InterfaceType;
+import com.sun.mirror.type.ReferenceType;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.type.VoidType;
+import com.sun.mirror.util.DeclarationVisitor;
+import com.sun.mirror.util.SimpleDeclarationVisitor;
+import com.sun.mirror.util.SourcePosition;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+import java.util.Stack;
+import java.util.StringTokenizer;
+
+import com.sun.xml.internal.ws.modeler.RuntimeModeler;
+import com.sun.tools.internal.ws.processor.model.Parameter;
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.model.Service;
+import com.sun.tools.internal.ws.processor.model.java.JavaInterface;
+import com.sun.tools.internal.ws.processor.model.java.JavaSimpleType;
+import com.sun.tools.internal.ws.processor.model.java.JavaType;
+import com.sun.tools.internal.ws.processor.modeler.JavaSimpleTypeCreator;
+import com.sun.tools.internal.ws.processor.modeler.annotation.AnnotationProcessorContext.SEIContext;
+import com.sun.tools.internal.ws.util.ClassNameInfo;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPStyle;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPUse;
+
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+
+import javax.jws.HandlerChain;
+import javax.jws.Oneway;
+import javax.jws.WebMethod;
+import javax.jws.WebParam;
+import javax.jws.WebResult;
+import javax.jws.WebService;
+import javax.jws.soap.SOAPBinding;
+import javax.jws.soap.SOAPBinding.ParameterStyle;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.api.Reference;
+import com.sun.tools.internal.ws.processor.modeler.annotation.AnnotationProcessorContext;
+import com.sun.tools.internal.ws.processor.modeler.annotation.ModelBuilder;
+import com.sun.tools.internal.ws.processor.modeler.annotation.WebServiceConstants;
+
+/**
+ *
+ * @author  WS Development Team
+ */
+public abstract class WebServiceVisitor extends SimpleDeclarationVisitor implements WebServiceConstants {
+    protected ModelBuilder builder;
+    protected String wsdlNamespace;
+    protected String typeNamespace;
+    protected Stack<SOAPBinding> soapBindingStack;
+    protected SOAPBinding typeDeclSOAPBinding;
+    protected SOAPUse soapUse = SOAPUse.LITERAL;
+    protected SOAPStyle soapStyle = SOAPStyle.DOCUMENT;
+    protected boolean wrapped = true;
+    protected HandlerChain hChain;
+    protected Port port;
+    protected String serviceImplName;
+    protected String endpointInterfaceName;
+    protected AnnotationProcessorContext context;
+    protected SEIContext seiContext;
+    protected boolean processingSEI = false;
+    protected String serviceName;
+    protected String packageName;
+    protected String portName;
+    protected boolean endpointReferencesInterface = false;
+    protected boolean hasWebMethods = false;
+    protected JavaSimpleTypeCreator simpleTypeCreator;
+    protected TypeDeclaration typeDecl;
+    protected Set<String> processedMethods;
+    protected boolean pushedSOAPBinding = false;
+    protected static final String ANNOTATION_ELEMENT_ERROR = "webserviceap.endpointinteface.plus.element";
+
+
+
+    public WebServiceVisitor(ModelBuilder builder, AnnotationProcessorContext context) {
+        this.builder = builder;
+        this.context = context;
+        this.simpleTypeCreator = new JavaSimpleTypeCreator();
+        soapBindingStack = new Stack<SOAPBinding>();
+        processedMethods = new HashSet<String>();
+    }
+
+    public void visitInterfaceDeclaration(InterfaceDeclaration d) {
+        WebService webService = (WebService)d.getAnnotation(WebService.class);
+        if (!shouldProcessWebService(webService, d))
+            return;
+        if (builder.checkAndSetProcessed(d))
+            return;
+        typeDecl = d;
+        if (endpointInterfaceName != null && !endpointInterfaceName.equals(d.getQualifiedName())) {
+            builder.onError(d.getPosition(), "webserviceap.endpointinterfaces.do.not.match", new Object[]
+            {endpointInterfaceName, d.getQualifiedName()});
+        }
+        verifySEIAnnotations(webService, d);
+        endpointInterfaceName = d.getQualifiedName();
+        processingSEI = true;
+        preProcessWebService(webService, d);
+        processWebService(webService, d);
+        postProcessWebService(webService, d);
+    }
+
+    public void visitClassDeclaration(ClassDeclaration d) {
+        WebService webService = d.getAnnotation(WebService.class);
+        if (!shouldProcessWebService(webService, d))
+            return;
+        if (builder.checkAndSetProcessed(d))
+            return;
+        typeDeclSOAPBinding = d.getAnnotation(SOAPBinding.class);
+        typeDecl = d;
+        if (serviceImplName == null)
+            serviceImplName = d.getQualifiedName();
+        String endpointInterfaceName = webService != null ? webService.endpointInterface() : null;
+        if (endpointInterfaceName != null && endpointInterfaceName.length() > 0) {
+            SourcePosition pos = pos = d.getPosition();
+            checkForInvalidImplAnnotation(d, SOAPBinding.class);
+            if (webService.name().length() > 0)
+                annotationError(pos, ANNOTATION_ELEMENT_ERROR,"name");
+            endpointReferencesInterface = true;
+            verifyImplAnnotations(d);
+            inspectEndpointInterface(endpointInterfaceName, d);
+            serviceImplName = null;
+            return;
+        }
+        processingSEI = false;
+        preProcessWebService(webService, d);
+        processWebService(webService, d);
+        serviceImplName = null;
+        postProcessWebService(webService, d);
+        serviceImplName = null;
+    }
+
+    protected void verifySEIAnnotations(WebService webService, InterfaceDeclaration d) {
+        if (webService.endpointInterface().length() > 0) {
+            builder.onError(d.getPosition(), "webservicefactory.endpointinterface.on.interface",
+                    new Object[] {d.getQualifiedName(), webService.endpointInterface()});
+        }
+        if (webService.serviceName().length() > 0) {
+            builder.onError(d.getPosition(), "webserviceap.invalid.sei.annotation.element",
+                    new Object[] {"serviceName", d.getQualifiedName()});
+        }
+        if (webService.portName().length() > 0) {
+            builder.onError(d.getPosition(), "webserviceap.invalid.sei.annotation.element",
+                    new Object[] {"portName", d.getQualifiedName()});
+        }
+    }
+
+    protected void verifyImplAnnotations(ClassDeclaration d) {
+        for (MethodDeclaration method : d.getMethods()) {
+            checkForInvalidImplAnnotation(method, WebMethod.class);
+            checkForInvalidImplAnnotation(method, Oneway.class);
+            checkForInvalidImplAnnotation(method, WebResult.class);
+            for (ParameterDeclaration param : method.getParameters()) {
+                checkForInvalidImplAnnotation(param, WebParam.class);
+            }
+        }
+    }
+
+    protected void checkForInvalidSEIAnnotation(InterfaceDeclaration d, Class annotationClass) {
+        Object annotation = d.getAnnotation(annotationClass);
+        if (annotation != null) {
+            SourcePosition pos = d.getPosition();
+            annotationError(pos, "webserviceap.invalid.sei.annotation",
+                    new Object[] {annotationClass.getName(), d.getQualifiedName()});
+        }
+    }
+
+    protected void checkForInvalidImplAnnotation(Declaration d, Class annotationClass) {
+        Object annotation = d.getAnnotation(annotationClass);
+        if (annotation != null) {
+            SourcePosition pos = d.getPosition();
+            annotationError(pos, "webserviceap.endpointinteface.plus.annotation",
+                    annotationClass.getName());
+        }
+    }
+
+    protected void annotationError(SourcePosition pos, String key, String element) {
+        annotationError(pos, key, new Object[] {element});
+    }
+
+    protected void annotationError(SourcePosition pos, String key, Object[] args) {
+        builder.onError(pos, key, args);
+    }
+
+
+    protected void preProcessWebService(WebService webService, TypeDeclaration d) {
+        seiContext = context.getSEIContext(d);
+        String targetNamespace = null;
+        if (webService != null)
+            targetNamespace = webService.targetNamespace();
+        if (targetNamespace == null || targetNamespace.length() == 0) {
+            String packageName = d.getPackage().getQualifiedName();
+            if (packageName == null || packageName.length() == 0) {
+                builder.onError(d.getPosition(), "webserviceap.no.package.class.must.have.targetnamespace",
+                        new Object[] {d.getQualifiedName()});
+            }
+            targetNamespace = getNamespace(d.getPackage());
+        }
+        seiContext.setNamespaceURI(targetNamespace);
+        if (serviceImplName == null)
+            serviceImplName = seiContext.getSEIImplName();
+        if (serviceImplName != null) {
+            seiContext.setSEIImplName(serviceImplName);
+            context.addSEIContext(serviceImplName, seiContext);
+        }
+        portName = ClassNameInfo.getName(
+                d.getSimpleName().replace(
+                SIGC_INNERCLASS,
+                SIGC_UNDERSCORE));;
+                packageName = d.getPackage().getQualifiedName();
+                portName = webService != null && webService.name() != null && webService.name().length() >0 ?
+                    webService.name() : portName;
+                serviceName = ClassNameInfo.getName(d.getQualifiedName())+SERVICE;
+                serviceName = webService != null && webService.serviceName() != null &&
+                        webService.serviceName().length() > 0 ?
+                            webService.serviceName() : serviceName;
+                wsdlNamespace = seiContext.getNamespaceURI();
+                typeNamespace = wsdlNamespace;
+
+                SOAPBinding soapBinding = d.getAnnotation(SOAPBinding.class);
+                if (soapBinding != null) {
+                    pushedSOAPBinding = pushSOAPBinding(soapBinding, d, d);
+                } else if (d.equals(typeDecl)) {
+                    pushedSOAPBinding = pushSOAPBinding(new MySOAPBinding(), d, d);
+                }
+    }
+
+    public static boolean sameStyle(SOAPBinding.Style style, SOAPStyle soapStyle) {
+        if (style.equals(SOAPBinding.Style.DOCUMENT) &&
+                soapStyle.equals(SOAPStyle.DOCUMENT))
+            return true;
+        if (style.equals(SOAPBinding.Style.RPC) &&
+                soapStyle.equals(SOAPStyle.RPC))
+            return true;
+        return false;
+    }
+
+    protected boolean pushSOAPBinding(SOAPBinding soapBinding, Declaration bindingDecl,
+            TypeDeclaration classDecl) {
+        boolean changed = false;
+        if (!sameStyle(soapBinding.style(), soapStyle)) {
+            changed = true;
+            if (pushedSOAPBinding)
+                builder.onError(bindingDecl.getPosition(), "webserviceap.mixed.binding.style",
+                        new Object[] {classDecl.getQualifiedName()});
+        }
+        if (soapBinding.style().equals(SOAPBinding.Style.RPC)) {
+            soapStyle = SOAPStyle.RPC;
+            wrapped = true;
+            if (soapBinding.parameterStyle().equals(ParameterStyle.BARE)) {
+                builder.onError(bindingDecl.getPosition(), "webserviceap.rpc.literal.must.not.be.bare",
+                        new Object[] {classDecl.getQualifiedName()});
+            }
+
+        } else {
+            soapStyle = SOAPStyle.DOCUMENT;
+            if (wrapped != soapBinding.parameterStyle().equals(ParameterStyle.WRAPPED)) {
+                wrapped = soapBinding.parameterStyle().equals(ParameterStyle.WRAPPED);
+                changed = true;
+            }
+        }
+        if (soapBinding.use().equals(SOAPBinding.Use.ENCODED)) {
+            builder.onError(bindingDecl.getPosition(), "webserviceap.rpc.encoded.not.supported",
+                    new Object[] {classDecl.getQualifiedName()});
+        }
+        if (changed || soapBindingStack.empty()) {
+            soapBindingStack.push(soapBinding);
+            pushedSOAPBinding = true;
+        }
+        return changed;
+    }
+
+
+    protected SOAPBinding popSOAPBinding() {
+        if (pushedSOAPBinding)
+            soapBindingStack.pop();
+        SOAPBinding soapBinding = null;
+        if (!soapBindingStack.empty()) {
+            soapBinding = soapBindingStack.peek();
+            if (soapBinding.style().equals(SOAPBinding.Style.RPC)) {
+                soapStyle = SOAPStyle.RPC;
+                wrapped = true;
+            } else {
+                soapStyle = SOAPStyle.DOCUMENT;
+                wrapped = soapBinding.parameterStyle().equals(ParameterStyle.WRAPPED);
+            }
+        }
+        return soapBinding;
+    }
+
+    protected String getNamespace(PackageDeclaration packageDecl) {
+        return RuntimeModeler.getNamespace(packageDecl.getQualifiedName());
+    }
+
+//    abstract protected boolean shouldProcessWebService(WebService webService, InterfaceDeclaration intf);
+
+//    abstract protected boolean shouldProcessWebService(WebService webService, ClassDeclaration decl);
+    protected boolean shouldProcessWebService(WebService webService, InterfaceDeclaration intf) {
+        hasWebMethods = false;
+        if (webService == null)
+            builder.onError(intf.getPosition(), "webserviceap.endpointinterface.has.no.webservice.annotation",
+                    new Object[] {intf.getQualifiedName()});
+        if (isLegalSEI(intf))
+            return true;
+        return false;
+    }
+
+    protected boolean shouldProcessWebService(WebService webService, ClassDeclaration classDecl) {
+        if (webService == null)
+            return false;
+        hasWebMethods = hasWebMethods(classDecl);
+        return isLegalImplementation(webService, classDecl);
+    }
+
+    abstract protected void processWebService(WebService webService, TypeDeclaration d);
+
+    protected void postProcessWebService(WebService webService, InterfaceDeclaration d) {
+        processMethods(d);
+        popSOAPBinding();
+    }
+
+    protected void postProcessWebService(WebService webService, ClassDeclaration d) {
+        processMethods(d);
+        popSOAPBinding();
+    }
+
+
+    protected boolean hasWebMethods(ClassDeclaration d) {
+        if (d.getQualifiedName().equals(JAVA_LANG_OBJECT))
+            return false;
+        WebMethod webMethod;
+        for (MethodDeclaration method : d.getMethods()) {
+            webMethod = method.getAnnotation(WebMethod.class);
+            if (webMethod != null) {
+                if (webMethod.exclude()) {
+                    if (webMethod.operationName().length() > 0)
+                        builder.onError(method.getPosition(), "webserviceap.invalid.webmethod.element.with.exclude",
+                                new Object[] {"operationName", d.getQualifiedName(), method.toString()});
+                                if (webMethod.action().length() > 0)
+                                    builder.onError(method.getPosition(), "webserviceap.invalid.webmethod.element.with.exclude",
+                                            new Object[] {"action", d.getQualifiedName(), method.toString()});
+                } else {
+                    return true;
+                }
+            }
+        }
+        return false;//hasWebMethods(d.getSuperclass().getDeclaration());
+    }
+
+    protected void processMethods(InterfaceDeclaration d) {
+        builder.log("ProcessedMethods Interface: "+d);
+        hasWebMethods = false;
+        for (MethodDeclaration methodDecl : d.getMethods()) {
+            methodDecl.accept((DeclarationVisitor)this);
+        }
+        for (InterfaceType superType : d.getSuperinterfaces())
+            processMethods(superType.getDeclaration());
+    }
+
+    protected void processMethods(ClassDeclaration d) {
+        builder.log("ProcessedMethods Class: "+d);
+        hasWebMethods = hasWebMethods(d);
+        if (d.getQualifiedName().equals(JAVA_LANG_OBJECT))
+            return;
+        if (d.getAnnotation(WebService.class) != null) {
+            // Super classes must have @WebService annotations to pick up their methods
+            for (MethodDeclaration methodDecl : d.getMethods()) {
+                methodDecl.accept((DeclarationVisitor)this);
+            }
+        }
+        if (d.getSuperclass() != null) {
+            processMethods(d.getSuperclass().getDeclaration());
+        }
+    }
+
+    private InterfaceDeclaration getEndpointInterfaceDecl(String endpointInterfaceName,
+            ClassDeclaration d) {
+        InterfaceDeclaration intTypeDecl = null;
+        for (InterfaceType interfaceType : d.getSuperinterfaces()) {
+            if (endpointInterfaceName.equals(interfaceType.toString())) {
+                intTypeDecl = interfaceType.getDeclaration();
+                seiContext = context.getSEIContext(intTypeDecl.getQualifiedName());
+                assert(seiContext != null);
+                seiContext.setImplementsSEI(true);
+                break;
+            }
+        }
+        if (intTypeDecl == null) {
+            intTypeDecl = (InterfaceDeclaration)builder.getTypeDeclaration(endpointInterfaceName);
+        }
+        if (intTypeDecl == null)
+            builder.onError("webserviceap.endpointinterface.class.not.found",
+                    new Object[] {endpointInterfaceName});
+                    return intTypeDecl;
+    }
+
+
+    private void inspectEndpointInterface(String endpointInterfaceName, ClassDeclaration d) {
+        TypeDeclaration intTypeDecl = getEndpointInterfaceDecl(endpointInterfaceName, d);
+        if (intTypeDecl != null)
+            intTypeDecl.accept((DeclarationVisitor)this);
+    }
+
+    public void visitMethodDeclaration(MethodDeclaration method) {
+        // Methods must be public
+        if (!method.getModifiers().contains(Modifier.PUBLIC))
+            return;
+        if (processedMethod(method))
+            return;
+        WebMethod webMethod = method.getAnnotation(WebMethod.class);
+        if (webMethod != null && webMethod.exclude())
+            return;
+        SOAPBinding soapBinding = method.getAnnotation(SOAPBinding.class);
+        if (soapBinding == null && !method.getDeclaringType().equals(typeDecl)) {
+            if (method.getDeclaringType() instanceof ClassDeclaration) {
+                soapBinding = method.getDeclaringType().getAnnotation(SOAPBinding.class);
+                if (soapBinding != null)
+                    builder.log("using "+method.getDeclaringType()+"'s SOAPBinding.");
+                else {
+                    soapBinding = new MySOAPBinding();
+                }
+            }
+        }
+        boolean newBinding = false;
+        if (soapBinding != null) {
+            newBinding = pushSOAPBinding(soapBinding, method, typeDecl);
+        }
+        try {
+            if (shouldProcessMethod(method, webMethod)) {
+                processMethod(method, webMethod);
+            }
+        } finally {
+            if (newBinding) {
+                popSOAPBinding();
+            }
+        }
+    }
+
+    protected boolean processedMethod(MethodDeclaration method) {
+        String id = method.toString();
+        if (processedMethods.contains(id))
+            return true;
+        processedMethods.add(id);
+        return false;
+    }
+
+
+    protected boolean shouldProcessMethod(MethodDeclaration method, WebMethod webMethod) {
+        builder.log("should process method: "+method.getSimpleName()+" hasWebMethods: "+ hasWebMethods+" ");
+        if (hasWebMethods && webMethod == null) {
+            builder.log("webMethod == null");
+            return false;
+        }
+        boolean retval = (endpointReferencesInterface ||
+                method.getDeclaringType().equals(typeDecl) ||
+                (method.getDeclaringType().getAnnotation(WebService.class) != null));
+        builder.log("endpointReferencesInterface: "+endpointReferencesInterface);
+        builder.log("declaring class has WebSevice: "+(method.getDeclaringType().getAnnotation(WebService.class) != null));
+        builder.log("returning: "+retval);
+        return  retval;
+    }
+
+    abstract protected void processMethod(MethodDeclaration method, WebMethod webMethod);
+
+
+    protected boolean isLegalImplementation(WebService webService, ClassDeclaration classDecl) {
+        Collection<Modifier> modifiers = classDecl.getModifiers();
+        if (!modifiers.contains(Modifier.PUBLIC)){
+            builder.onError(classDecl.getPosition(), "webserviceap.webservice.class.not.public",
+                    new Object[] {classDecl.getQualifiedName()});
+                    return false;
+        }
+        if (modifiers.contains(Modifier.FINAL)) {
+            builder.onError(classDecl.getPosition(), "webserviceap.webservice.class.is.final",
+                    new Object[] {classDecl.getQualifiedName()});
+                    return false;
+        }
+        if (modifiers.contains(Modifier.ABSTRACT)) {
+            builder.onError(classDecl.getPosition(), "webserviceap.webservice.class.is.abstract",
+                    new Object[] {classDecl.getQualifiedName()});
+                    return false;
+        }
+        if (classDecl.getDeclaringType() != null && !modifiers.contains(Modifier.STATIC)) {
+            builder.onError(classDecl.getPosition(), "webserviceap.webservice.class.is.innerclass.not.static",
+                    new Object[] {classDecl.getQualifiedName()});
+                    return false;
+        }
+        boolean hasDefaultConstructor = false;
+        for (ConstructorDeclaration constructor : classDecl.getConstructors()) {
+            if (constructor.getModifiers().contains(Modifier.PUBLIC) &&
+                    constructor.getParameters().size() == 0) {
+                hasDefaultConstructor = true;
+                break;
+            }
+        }
+        if (!hasDefaultConstructor) {
+            builder.onError(classDecl.getPosition(), "webserviceap.webservice.no.default.constructor",
+                    new Object[] {classDecl.getQualifiedName()});
+                    return false;
+        }
+        if (webService.endpointInterface().length() == 0) {
+            if (!methodsAreLegal(classDecl))
+                return false;
+        } else {
+            InterfaceDeclaration intfDecl = getEndpointInterfaceDecl(webService.endpointInterface(), classDecl);
+            if (!classImplementsSEI(classDecl, intfDecl))
+                return false;
+        }
+
+        return true;
+    }
+
+    protected boolean classImplementsSEI(ClassDeclaration classDecl,
+            InterfaceDeclaration intfDecl) {
+        for (InterfaceType interfaceType : classDecl.getSuperinterfaces()) {
+            if (interfaceType.getDeclaration().equals(intfDecl))
+                return true;
+        }
+        boolean implementsMethod;
+        for (MethodDeclaration method : intfDecl.getMethods()) {
+            implementsMethod = false;
+            for (MethodDeclaration classMethod : classDecl.getMethods()) {
+                if (sameMethod(method, classMethod)) {
+                    implementsMethod = true;
+                    break;
+                }
+            }
+            if (!implementsMethod) {
+                builder.onError(method.getPosition(), "webserviceap.method.not.implemented",
+                        new Object[] {intfDecl.getSimpleName(), classDecl.getSimpleName(),
+                                method});
+                                return false;
+            }
+        }
+        return true;
+    }
+
+    protected boolean sameMethod(MethodDeclaration method1, MethodDeclaration method2) {
+        if (!method1.getSimpleName().equals(method2.getSimpleName()))
+            return false;
+        if (!method1.getReturnType().equals(method2.getReturnType()))
+            return false;
+        ParameterDeclaration[] params1 = method1.getParameters().toArray(new ParameterDeclaration[0]);
+        ParameterDeclaration[] params2 = method2.getParameters().toArray(new ParameterDeclaration[0]);
+        if (params1.length != params2.length)
+            return false;
+        int pos = 0;
+        for (ParameterDeclaration param1 : method1.getParameters()) {
+            if (!param1.getType().equals(params2[pos++].getType()))
+                return false;
+        }
+        return true;
+    }
+
+    protected boolean isLegalSEI(InterfaceDeclaration intf) {
+        for (FieldDeclaration field : intf.getFields()) {
+            if (field.getConstantValue() != null) {
+                builder.onError("webserviceap.sei.cannot.contain.constant.values",
+                        new Object[] {intf.getQualifiedName(), field.getSimpleName()});
+                        return false;
+            }
+        }
+        if (!methodsAreLegal(intf))
+            return false;
+        return true;
+    }
+
+    protected boolean methodsAreLegal(InterfaceDeclaration intfDecl) {
+        hasWebMethods = false;
+        for (MethodDeclaration method : intfDecl.getMethods()) {
+            if (!isLegalMethod(method, intfDecl))
+                return false;
+        }
+        for (InterfaceType superIntf : intfDecl.getSuperinterfaces()) {
+            if (!methodsAreLegal(superIntf.getDeclaration()))
+                return false;
+        }
+        return true;
+    }
+
+    protected boolean methodsAreLegal(ClassDeclaration classDecl) {
+        hasWebMethods = hasWebMethods(classDecl);
+        for (MethodDeclaration method : classDecl.getMethods()) {
+            if (!isLegalMethod(method, classDecl))
+                return false;
+        }
+        ClassType superClass = classDecl.getSuperclass();
+        if (superClass != null && !methodsAreLegal(superClass.getDeclaration())) {
+            return false;
+        }
+        return true;
+    }
+
+
+    protected boolean isLegalMethod(MethodDeclaration method, TypeDeclaration typeDecl) {
+        if (hasWebMethods && method.getAnnotation(WebMethod.class) == null)
+            return true;
+        if (typeDecl instanceof ClassDeclaration && method.getModifiers().contains(Modifier.ABSTRACT)) {
+            builder.onError(method.getPosition(), "webserviceap.webservice.method.is.abstract",
+                    new Object[] {typeDecl.getQualifiedName(), method.getSimpleName()});
+                    return false;
+        }
+
+        if (!isLegalType(method.getReturnType())) {
+            builder.onError(method.getPosition(), "webserviceap.method.return.type.cannot.implement.remote",
+                    new Object[] {typeDecl.getQualifiedName(),
+                            method.getSimpleName(),
+                            method.getReturnType()});
+        }
+        boolean isOneway = method.getAnnotation(Oneway.class) != null;
+        if (isOneway && !isValidOnewayMethod(method, typeDecl))
+            return false;
+
+
+        SOAPBinding soapBinding = method.getAnnotation(SOAPBinding.class);
+        if (soapBinding != null) {
+            if (soapBinding.style().equals(SOAPBinding.Style.RPC)) {
+                builder.onError(method.getPosition(),"webserviceap.rpc.soapbinding.not.allowed.on.method",
+                        new Object[] {typeDecl.getQualifiedName(), method.toString()});
+            }
+        }
+
+        int paramIndex = 0;
+        for (ParameterDeclaration parameter : method.getParameters()) {
+            if (!isLegalParameter(parameter, method, typeDecl, paramIndex++))
+                return false;
+        }
+
+        if (!isDocLitWrapped() &&
+                soapStyle.equals(SOAPStyle.DOCUMENT)) {
+            ParameterDeclaration outParam = getOutParameter(method);
+            int inParams = getModeParameterCount(method, WebParam.Mode.IN);
+            int outParams = getModeParameterCount(method, WebParam.Mode.OUT);
+            if (inParams != 1) {
+                builder.onError(method.getPosition(),
+                        "webserviceap.doc.bare.and.no.one.in",
+                        new Object[] {typeDecl.getQualifiedName(), method.toString()});
+            }
+            if (method.getReturnType() instanceof VoidType) {
+                if (outParam == null && !isOneway) {
+                    builder.onError(method.getPosition(),
+                            "webserviceap.doc.bare.no.out",
+                            new Object[] {typeDecl.getQualifiedName(), method.toString()});
+                }
+                if (outParams != 1) {
+                    if (!isOneway && outParams != 0)
+                        builder.onError(method.getPosition(),
+                                "webserviceap.doc.bare.no.return.and.no.out",
+                                new Object[] {typeDecl.getQualifiedName(), method.toString()});
+                }
+            } else {
+                if (outParams > 0) {
+                    builder.onError(outParam.getPosition(),
+                            "webserviceap.doc.bare.return.and.out",
+                            new Object[] {typeDecl.getQualifiedName(), method.toString()});
+                }
+            }
+        }
+        return true;
+    }
+
+    protected boolean isLegalParameter(ParameterDeclaration param,
+            MethodDeclaration method,
+            TypeDeclaration typeDecl,
+            int paramIndex) {
+        if (!isLegalType(param.getType())) {
+            builder.onError(param.getPosition(), "webserviceap.method.parameter.types.cannot.implement.remote",
+                    new Object[] {typeDecl.getQualifiedName(),
+                            method.getSimpleName(),
+                            param.getSimpleName(),
+                            param.getType().toString()});
+                            return false;
+        }
+        TypeMirror holderType;
+        holderType = builder.getHolderValueType(param.getType());
+        WebParam webParam = param.getAnnotation(WebParam.class);
+        WebParam.Mode mode = null;
+        if (webParam != null)
+            mode = webParam.mode();
+
+        if (holderType != null) {
+            if (mode != null &&  mode.equals(WebParam.Mode.IN))
+                builder.onError(param.getPosition(), "webserviceap.holder.parameters.must.not.be.in.only",
+                        new Object[] {typeDecl.getQualifiedName(), method.toString(), paramIndex});
+        } else if (mode != null && !mode.equals(WebParam.Mode.IN)) {
+            builder.onError(param.getPosition(), "webserviceap.non.in.parameters.must.be.holder",
+                    new Object[] {typeDecl.getQualifiedName(), method.toString(), paramIndex});
+        }
+
+        return true;
+    }
+
+    protected boolean isDocLitWrapped() {
+        return soapStyle.equals(SOAPStyle.DOCUMENT) && wrapped;
+    }
+
+    protected boolean isValidOnewayMethod(MethodDeclaration method, TypeDeclaration typeDecl) {
+        boolean valid = true;
+        if (!(method.getReturnType() instanceof VoidType)) {
+            // this is an error, cannot be Oneway and have a return type
+            builder.onError(method.getPosition(), "webserviceap.oneway.operation.cannot.have.return.type",
+                    new Object[] {typeDecl.getQualifiedName(), method.toString()});
+            valid = false;
+        }
+        ParameterDeclaration outParam = getOutParameter(method);
+        if (outParam != null) {
+            builder.onError(outParam.getPosition(),
+                    "webserviceap.oneway.and.out",
+                    new Object[] {typeDecl.getQualifiedName(), method.toString()});
+            valid = false;
+        }
+        if (!isDocLitWrapped() && soapStyle.equals(SOAPStyle.DOCUMENT)) {
+            int inCnt = getModeParameterCount(method, WebParam.Mode.IN);
+            if (inCnt != 1) {
+                builder.onError(method.getPosition(),
+                        "webserviceap.oneway.and.not.one.in",
+                        new Object[] {typeDecl.getQualifiedName(), method.toString()});
+                valid = false;
+            }
+        }
+        ClassDeclaration exDecl;
+        for (ReferenceType thrownType : method.getThrownTypes()) {
+            exDecl = ((ClassType)thrownType).getDeclaration();
+            if (!builder.isRemoteException(exDecl)) {
+                builder.onError(method.getPosition(), "webserviceap.oneway.operation.cannot.declare.exceptions",
+                        new Object[] {typeDecl.getQualifiedName(), method.toString(), exDecl.getQualifiedName()});
+                valid = false;
+            }
+        }
+        return valid;
+    }
+
+    protected int getModeParameterCount(MethodDeclaration method, WebParam.Mode mode) {
+        WebParam webParam;
+        int cnt = 0;
+        for (ParameterDeclaration param : method.getParameters()) {
+            webParam = param.getAnnotation(WebParam.class);
+            if (webParam != null) {
+                if (webParam.header())
+                    continue;
+                if (isEquivalentModes(mode, webParam.mode()))
+                    cnt++;
+            } else {
+                if (isEquivalentModes(mode, WebParam.Mode.IN)) {
+                    cnt++;
+                }
+            }
+        }
+        return cnt;
+    }
+
+    protected boolean isEquivalentModes(WebParam.Mode mode1, WebParam.Mode mode2) {
+        if (mode1.equals(mode2))
+            return true;
+        assert(mode1.equals(WebParam.Mode.IN) ||
+                mode1.equals(WebParam.Mode.OUT));
+        if (mode1.equals(WebParam.Mode.IN) &&
+                !(mode2.equals(WebParam.Mode.OUT)))
+            return true;
+        if (mode1.equals(WebParam.Mode.OUT) &&
+                !(mode2.equals(WebParam.Mode.IN)))
+            return true;
+        return false;
+    }
+
+    protected boolean isHolder(ParameterDeclaration param) {
+        return builder.getHolderValueType(param.getType()) != null;
+    }
+
+    protected boolean isLegalType(TypeMirror type) {
+        if (!(type instanceof DeclaredType))
+            return true;
+        return !builder.isRemote(((DeclaredType)type).getDeclaration());
+    }
+
+    public void addSchemaElements(MethodDeclaration method, boolean isDocLitWrapped) {
+        addReturnSchemaElement(method, isDocLitWrapped);
+        boolean hasInParam = false;
+        for (ParameterDeclaration param : method.getParameters()) {
+            hasInParam |= addParamSchemaElement(param, method, isDocLitWrapped);
+        }
+        if (!hasInParam && soapStyle.equals(SOAPStyle.DOCUMENT) && !isDocLitWrapped) {
+            QName paramQName = new QName(wsdlNamespace, method.getSimpleName());
+            seiContext.addSchemaElement(paramQName, null);
+        }
+    }
+
+    public void addReturnSchemaElement(MethodDeclaration method, boolean isDocLitWrapped) {
+        TypeMirror returnType = method.getReturnType();
+        WebResult webResult = method.getAnnotation(WebResult.class);
+        String responseName = builder.getResponseName(method.getSimpleName());
+        String responseNamespace = wsdlNamespace;
+        boolean isResultHeader = false;
+        if (webResult != null) {
+            responseName = webResult.name().length() > 0 ? webResult.name() : responseName;
+            responseNamespace = webResult.targetNamespace().length() > 0 ? webResult.targetNamespace() : responseNamespace;
+            isResultHeader = webResult.header();
+        }
+        QName typeName = new QName(responseNamespace, responseName);
+        if (!(returnType instanceof VoidType) &&
+                (!isDocLitWrapped || isResultHeader)) {
+            Reference ref = seiContext.addReference(method);
+            if (!soapStyle.equals(SOAPStyle.RPC))
+                seiContext.addSchemaElement(typeName, ref);
+        }
+    }
+
+    public boolean addParamSchemaElement(ParameterDeclaration param, MethodDeclaration method, boolean isDocLitWrappped) {
+        boolean isInParam = false;
+        WebParam webParam = param.getAnnotation(WebParam.class);
+        String paramName = param.getSimpleName();
+        String paramNamespace = wsdlNamespace;
+        TypeMirror paramType = param.getType();
+        TypeMirror holderType = builder.getHolderValueType(paramType);
+        boolean isHeader = false;
+        if (soapStyle.equals(SOAPStyle.DOCUMENT) && !wrapped) {
+            paramName = method.getSimpleName();
+        }
+        if (webParam != null) {
+            paramName = webParam.name() != null && webParam.name().length() > 0 ? webParam.name() : paramName;
+            isHeader = webParam.header();
+            paramNamespace = webParam.targetNamespace().length() > 0 ? webParam.targetNamespace() : paramNamespace;
+        }
+        if (holderType != null) {
+            paramType = holderType;
+        }
+        if (isHeader || soapStyle.equals(SOAPStyle.DOCUMENT)) {
+            if (isHeader || !isDocLitWrappped) {
+                QName paramQName = new QName(paramNamespace, paramName);
+                Reference ref = seiContext.addReference(paramType, param);
+                seiContext.addSchemaElement(paramQName, ref);
+            }
+        } else
+            seiContext.addReference(paramType, param);
+        if (!isHeader && (holderType == null ||
+                (webParam == null || !webParam.mode().equals(WebParam.Mode.OUT)))) {
+            isInParam = true;
+        }
+        return isInParam;
+    }
+
+    protected ParameterDeclaration getOutParameter(MethodDeclaration method) {
+        WebParam webParam;
+        for (ParameterDeclaration param : method.getParameters()) {
+            webParam = (WebParam)param.getAnnotation(WebParam.class);
+            if (webParam != null &&
+                    !webParam.mode().equals(WebParam.Mode.IN)) {
+                return param;
+            }
+        }
+        return null;
+    }
+
+    protected static class MySOAPBinding implements SOAPBinding {
+        public Style style() {return SOAPBinding.Style.DOCUMENT;}
+        public Use use() {return SOAPBinding.Use.LITERAL; }
+        public ParameterStyle parameterStyle() { return SOAPBinding.ParameterStyle.WRAPPED;}
+        public Class<? extends java.lang.annotation.Annotation> annotationType() {
+            return SOAPBinding.class;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceWrapperGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceWrapperGenerator.java
new file mode 100644
index 0000000..dffd689
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WebServiceWrapperGenerator.java
@@ -0,0 +1,608 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import static com.sun.codemodel.internal.ClassType.CLASS;
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JAnnotationArrayMember;
+import com.sun.codemodel.internal.JAnnotationUse;
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JCommentPart;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JDocComment;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.codemodel.internal.writer.ProgressCodeWriter;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.declaration.ClassDeclaration;
+import com.sun.mirror.declaration.FieldDeclaration;
+import com.sun.mirror.declaration.InterfaceDeclaration;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.ParameterDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+
+import com.sun.mirror.type.ClassType;
+import com.sun.mirror.type.ReferenceType;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.type.VoidType;
+
+import com.sun.tools.internal.ws.processor.generator.GeneratorBase;
+import com.sun.tools.internal.ws.processor.modeler.ModelerException;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.util.ClassNameInfo;
+import com.sun.tools.internal.ws.wscompile.FilerCodeWriter;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPStyle;
+import com.sun.tools.internal.ws.ToolVersion;
+import com.sun.xml.internal.ws.util.StringUtils;
+
+import javax.jws.Oneway;
+import javax.jws.WebMethod;
+import javax.jws.WebParam;
+import javax.jws.WebResult;
+import javax.jws.WebService;
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.XmlValue;
+import javax.xml.namespace.QName;
+import javax.xml.ws.RequestWrapper;
+import javax.xml.ws.ResponseWrapper;
+import javax.xml.ws.WebFault;
+import java.io.File;
+import java.io.IOException;
+import java.lang.reflect.Array;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeSet;
+
+
+/**
+ * This class generates the request/response and Exception Beans
+ * used by the JAX-WS runtime.
+ *
+ * @author  WS Development Team
+ */
+public class WebServiceWrapperGenerator extends WebServiceVisitor {
+    protected Set<String> wrapperNames;
+    protected Set<String> processedExceptions;
+    protected JCodeModel cm;
+    protected MakeSafeTypeVisitor makeSafeVisitor;
+
+
+    public WebServiceWrapperGenerator(ModelBuilder builder, AnnotationProcessorContext context) {
+        super(builder, context);
+        makeSafeVisitor = new MakeSafeTypeVisitor(builder.getAPEnv());
+    }
+
+    protected void processWebService(WebService webService, TypeDeclaration d) {
+        cm =  new JCodeModel();
+        wrapperNames = new HashSet<String>();
+        processedExceptions = new HashSet<String>();
+    }
+
+    protected void postProcessWebService(WebService webService, InterfaceDeclaration d) {
+        super.postProcessWebService(webService, d);
+        doPostProcessWebService(webService, d);
+    }
+    protected void postProcessWebService(WebService webService, ClassDeclaration d) {
+        super.postProcessWebService(webService, d);
+        doPostProcessWebService(webService, d);
+    }
+
+    protected  void doPostProcessWebService(WebService webService, TypeDeclaration d) {
+        if (cm != null) {
+            File sourceDir = builder.getSourceDir();
+            assert(sourceDir != null);
+            ProcessorEnvironment env = builder.getProcessorEnvironment();
+            try {
+                CodeWriter cw = new FilerCodeWriter(sourceDir, env);
+
+                if(env.verbose())
+                    cw = new ProgressCodeWriter(cw, System.out);
+                cm.build(cw);
+            } catch (IOException e) {
+                e.printStackTrace();
+            }
+        }
+    }
+
+    protected void processMethod(MethodDeclaration method, WebMethod webMethod) {
+        builder.log("WrapperGen - method: "+method);
+        builder.log("method.getDeclaringType(): "+method.getDeclaringType());
+        boolean generatedWrapper = false;
+        if (wrapped && soapStyle.equals(SOAPStyle.DOCUMENT)) {
+            generatedWrapper = generateWrappers(method, webMethod);
+        }
+        generatedWrapper = generateExceptionBeans(method) || generatedWrapper;
+        if (generatedWrapper) {
+            // Theres not going to be a second round
+            builder.setWrapperGenerated(generatedWrapper);
+        }
+    }
+
+    private boolean generateExceptionBeans(MethodDeclaration method) {
+        String beanPackage = packageName + PD_JAXWS_PACKAGE_PD;
+        if (packageName.length() == 0)
+            beanPackage = JAXWS_PACKAGE_PD;
+        boolean beanGenerated = false;
+        try {
+            for (ReferenceType thrownType : method.getThrownTypes()) {
+                ClassDeclaration typeDecl = ((ClassType)thrownType).getDeclaration();
+                if (typeDecl == null)
+                    builder.onError("webserviceap.could.not.find.typedecl",
+                         new Object[] {thrownType.toString(), context.getRound()});
+                boolean tmp = generateExceptionBean(typeDecl, beanPackage);
+                beanGenerated = beanGenerated || tmp;
+            }
+        } catch (Exception e) {
+            throw new ModelerException("modeler.nestedGeneratorError",e);
+        }
+        return beanGenerated;
+    }
+
+    private boolean duplicateName(String name) {
+        for (String str : wrapperNames) {
+            if (str.equalsIgnoreCase(name))
+                return true;
+        }
+        wrapperNames.add(name);
+        return false;
+    }
+
+    private boolean generateWrappers(MethodDeclaration method, WebMethod webMethod) {
+        boolean isOneway = method.getAnnotation(Oneway.class) != null;
+        String beanPackage = packageName + PD_JAXWS_PACKAGE_PD;
+        if (packageName.length() == 0)
+            beanPackage = JAXWS_PACKAGE_PD;
+        String methodName = method.getSimpleName();
+        String operationName = builder.getOperationName(methodName);
+        operationName = webMethod != null && webMethod.operationName().length() > 0 ?
+                        webMethod.operationName() : operationName;
+        String reqName = operationName;
+        String resName = operationName+RESPONSE;
+        String reqNamespace = typeNamespace;
+        String resNamespace = typeNamespace;
+
+        String requestClassName = beanPackage + StringUtils.capitalize(method.getSimpleName());
+        RequestWrapper reqWrapper = method.getAnnotation(RequestWrapper.class);
+        if (reqWrapper != null) {
+            if (reqWrapper.className().length() > 0)
+                requestClassName = reqWrapper.className();
+            if (reqWrapper.localName().length() > 0)
+                reqName = reqWrapper.localName();
+            if (reqWrapper.targetNamespace().length() > 0)
+                reqNamespace = reqWrapper.targetNamespace();
+        }
+        builder.log("requestWrapper: "+requestClassName);
+        boolean canOverwriteRequest = builder.canOverWriteClass(requestClassName);
+        if (!canOverwriteRequest) {
+            builder.log("Class " + requestClassName + " exists. Not overwriting.");
+        }
+        if (duplicateName(requestClassName) && canOverwriteRequest) {
+            builder.onError("webserviceap.method.request.wrapper.bean.name.not.unique",
+                             new Object[] {typeDecl.getQualifiedName(), method.toString()});
+        }
+
+        String responseClassName = null;
+        boolean canOverwriteResponse = canOverwriteRequest;
+        if (!isOneway) {
+            responseClassName = beanPackage+StringUtils.capitalize(method.getSimpleName())+RESPONSE;
+            ResponseWrapper resWrapper = method.getAnnotation(ResponseWrapper.class);
+            if(resWrapper != null) {
+                if (resWrapper.className().length() > 0)
+                    responseClassName = resWrapper.className();
+                if (resWrapper.localName().length() > 0)
+                    resName = resWrapper.localName();
+                if (resWrapper.targetNamespace().length() > 0)
+                    resNamespace = resWrapper.targetNamespace();
+            }
+            canOverwriteResponse = builder.canOverWriteClass(requestClassName);
+            if (!canOverwriteResponse) {
+                builder.log("Class " + responseClassName + " exists. Not overwriting.");
+            }
+            if (duplicateName(responseClassName) && canOverwriteResponse) {
+                builder.onError("webserviceap.method.response.wrapper.bean.name.not.unique",
+                                 new Object[] {typeDecl.getQualifiedName(), method.toString()});
+            }
+        }
+        ArrayList<MemberInfo> reqMembers = new ArrayList<MemberInfo>();
+        ArrayList<MemberInfo> resMembers = new ArrayList<MemberInfo>();
+        WrapperInfo reqWrapperInfo = new WrapperInfo(requestClassName);
+        reqWrapperInfo.setMembers(reqMembers);
+        WrapperInfo resWrapperInfo = null;
+        if (!isOneway) {
+            resWrapperInfo = new WrapperInfo(responseClassName);
+            resWrapperInfo.setMembers(resMembers);
+        }
+        seiContext.setReqWrapperOperation(method, reqWrapperInfo);
+        if (!isOneway)
+            seiContext.setResWrapperOperation(method, resWrapperInfo);
+        try {
+            if (!canOverwriteRequest && !canOverwriteResponse) {
+//                getWrapperMembers(reqWrapperInfo);
+//                getWrapperMembers(resWrapperInfo);
+                return false;
+            }
+
+            JDefinedClass reqCls = null;
+            if (canOverwriteRequest) {
+                reqCls = getCMClass(requestClassName, CLASS);
+            }
+
+            JDefinedClass resCls = null;
+            if (!isOneway && canOverwriteResponse) {
+                resCls = getCMClass(responseClassName, CLASS);
+            }
+
+            // XMLElement Declarations
+            writeXmlElementDeclaration(reqCls, reqName,reqNamespace);
+            writeXmlElementDeclaration(resCls, resName, resNamespace);
+
+            collectMembers(method, operationName, typeNamespace, reqMembers, resMembers);
+
+            // XmlType
+            writeXmlTypeDeclaration(reqCls, reqName, reqNamespace, reqMembers);
+            writeXmlTypeDeclaration(resCls, resName, resNamespace, resMembers);
+
+            // class members
+            writeMembers(reqCls, reqMembers);
+            writeMembers(resCls, resMembers);
+        } catch (Exception e) {
+            throw new ModelerException("modeler.nestedGeneratorError",e);
+        }
+        return true;
+    }
+
+/*    private void getWrapperMembers(WrapperInfo wrapperInfo) throws Exception {
+        if (wrapperInfo == null)
+            return;
+        TypeDeclaration type = builder.getTypeDeclaration(wrapperInfo.getWrapperName());
+        Collection<FieldDeclaration> fields = type.getFields();
+        ArrayList<MemberInfo> members = new ArrayList<MemberInfo>();
+        MemberInfo member;
+        int i=0;
+        for (FieldDeclaration field : fields) {
+            XmlElement xmlElement = field.getAnnotation(XmlElement.class);
+            String fieldName = field.getSimpleName();
+//            String typeName = field.getType().toString();
+            String elementName = xmlElement != null ? xmlElement.name() : fieldName;
+            String namespace =  xmlElement != null ? xmlElement.namespace() : "";
+
+            String idxStr = fieldName.substring(3);
+            int index = Integer.parseInt(idxStr);
+            member = new MemberInfo(index, field.getType(),
+                                    field.getSimpleName(),
+                                    new QName(namespace, elementName));
+            int j=0;
+            while (j<members.size() && members.get(j++).getParamIndex() < index) {
+                break;
+            }
+            members.add(j, member);
+            i++;
+        }
+        for (MemberInfo member2 : members) {
+            wrapperInfo.addMember(member2);
+        }
+    }*/
+
+    private void collectMembers(MethodDeclaration method, String operationName, String namespace,
+                               ArrayList<MemberInfo> requestMembers,
+                               ArrayList<MemberInfo> responseMembers) {
+
+        AnnotationProcessorEnvironment apEnv = builder.getAPEnv();
+        WebResult webResult = method.getAnnotation(WebResult.class);
+        String responseElementName = RETURN;
+        String responseNamespace = wrapped ? EMTPY_NAMESPACE_ID : typeNamespace;
+        boolean isResultHeader = false;
+        if (webResult != null) {
+            if (webResult.name().length() > 0) {
+                responseElementName = webResult.name();
+            }
+            responseNamespace = webResult.targetNamespace().length() > 1 ?
+                webResult.targetNamespace() :
+                responseNamespace;
+            isResultHeader = webResult.header();
+        }
+
+        // class members
+        WebParam webParam;
+        TypeMirror paramType;
+        String paramName;
+        String paramNamespace;
+        TypeMirror holderType;
+        int paramIndex = -1;
+//        System.out.println("method: "+method.toString());
+//        System.out.println("returnType: "+ method.getReturnType());
+
+//        TypeMirror typeMirror = apEnv.getTypeUtils().getErasure(method.getReturnType());
+        TypeMirror typeMirror = getSafeType(method.getReturnType());
+        String retType = typeMirror.toString();
+        if (!(method.getReturnType() instanceof VoidType) && !isResultHeader) {
+            responseMembers.add(new MemberInfo(-1, typeMirror, RETURN_VALUE,
+                new QName(responseNamespace, responseElementName)));
+        }
+
+        for (ParameterDeclaration param : method.getParameters()) {
+            WebParam.Mode mode = null;
+            paramIndex++;
+//            System.out.println("param.getType(): "+param.getType());
+            holderType = builder.getHolderValueType(param.getType());
+            webParam = param.getAnnotation(WebParam.class);
+//            typeMirror = apEnv.getTypeUtils().getErasure(param.getType());
+            typeMirror =  getSafeType(param.getType());
+            paramType = typeMirror;
+            paramNamespace = wrapped ? EMTPY_NAMESPACE_ID : typeNamespace;
+            if (holderType != null) {
+                paramType = holderType;
+            }
+            paramName =  "arg"+paramIndex;
+            if (webParam != null && webParam.header()) {
+                continue;
+            }
+            if (webParam != null) {
+                mode = webParam.mode();
+                if (webParam.name().length() > 0)
+                    paramName = webParam.name();
+                if (webParam.targetNamespace().length() > 0)
+                    paramNamespace = webParam.targetNamespace();
+            }
+            MemberInfo memInfo = new MemberInfo(paramIndex, paramType, paramName,
+                new QName(paramNamespace, paramName));
+            if (holderType != null) {
+                if (mode == null || mode.equals(WebParam.Mode.INOUT)) {
+                    requestMembers.add(memInfo);
+                }
+                responseMembers.add(memInfo);
+            } else {
+                requestMembers.add(memInfo);
+            }
+        }
+    }
+
+    private TypeMirror getSafeType(TypeMirror type) {
+//        System.out.println("type: "+type+" type.getClass(): "+type.getClass());
+        TypeMirror retType = makeSafeVisitor.apply(type, builder.getAPEnv().getTypeUtils());
+//        System.out.println("retType: "+retType+" retType.getClass(): "+retType.getClass());
+        return retType;
+    }
+
+    private JType getType(TypeMirror typeMirror) throws IOException {
+        String type = typeMirror.toString();
+        JType jType = null;
+        try {
+//            System.out.println("typeName: "+typeName);
+            jType = cm.parseType(type);
+//            System.out.println("type: "+type);
+            return jType;
+        } catch (ClassNotFoundException e) {
+            jType = cm.ref(type);
+        }
+        return jType;
+    }
+
+    private ArrayList<MemberInfo> sortMembers(ArrayList<MemberInfo> members) {
+        Map<String, MemberInfo> sortedMap = new java.util.TreeMap<String, MemberInfo>();
+        for (MemberInfo member : members) {
+            sortedMap.put(member.getParamName(), member);
+        }
+        ArrayList<MemberInfo> sortedMembers = new ArrayList<MemberInfo>();
+        sortedMembers.addAll(sortedMap.values());
+        return sortedMembers;
+    }
+
+    private void writeMembers(JDefinedClass cls, ArrayList<MemberInfo> members) throws IOException {
+        if (cls == null)
+            return;
+        for (MemberInfo memInfo : members) {
+            JType type = getType(memInfo.getParamType());
+            JFieldVar field = cls.field(JMod.PRIVATE, type, memInfo.getParamName());
+            QName elementName = memInfo.getElementName();
+            if (elementName != null) {
+                if (soapStyle.equals(SOAPStyle.RPC) || wrapped) {
+                    JAnnotationUse xmlElementAnn = field.annotate(XmlElement.class);
+                    xmlElementAnn.param("name", elementName.getLocalPart());
+                    xmlElementAnn.param("namespace", elementName.getNamespaceURI());
+                } else {
+                    JAnnotationUse xmlValueAnnn = field.annotate(XmlValue.class);
+                }
+            }
+        }
+        for (MemberInfo memInfo : members) {
+            writeMember(cls, memInfo.getParamIndex(), memInfo.getParamType(),
+                        memInfo.getParamName(), memInfo.getElementName());
+        }
+    }
+
+    protected JDefinedClass getCMClass(String className, com.sun.codemodel.internal.ClassType type) {
+        JDefinedClass cls = null;
+        try {
+            cls = cm._class(className, type);
+        } catch (com.sun.codemodel.internal.JClassAlreadyExistsException e){
+            cls = cm._getClass(className);
+        }
+        return cls;
+    }
+
+    private boolean generateExceptionBean(ClassDeclaration thrownDecl, String beanPackage) throws IOException {
+        if (builder.isRemoteException(thrownDecl))
+            return false;
+        AnnotationProcessorEnvironment apEnv = builder.getAPEnv();
+        String exceptionName = ClassNameInfo.getName(thrownDecl.getQualifiedName());
+        if (processedExceptions.contains(exceptionName))
+            return false;
+        processedExceptions.add(exceptionName);
+        WebFault webFault = thrownDecl.getAnnotation(WebFault.class);
+        String className = beanPackage+ exceptionName + BEAN;
+
+        Map<String, TypeMirror> propertyToTypeMap;
+        propertyToTypeMap = TypeModeler.getExceptionProperties(thrownDecl);
+        boolean isWSDLException = isWSDLException(propertyToTypeMap, thrownDecl);
+        String namespace = typeNamespace;
+        String name = exceptionName;
+        FaultInfo faultInfo;
+        if (isWSDLException) {
+            TypeMirror beanType =  getSafeType(propertyToTypeMap.get(FAULT_INFO));
+            faultInfo = new FaultInfo(TypeMonikerFactory.getTypeMoniker(beanType), true);
+            namespace = webFault.targetNamespace().length()>0 ?
+                               webFault.targetNamespace() : namespace;
+            name = webFault.name().length()>0 ?
+                          webFault.name() : name;
+            faultInfo.setElementName(new QName(namespace, name));
+            seiContext.addExceptionBeanEntry(thrownDecl.getQualifiedName(), faultInfo, builder);
+            return false;
+        }
+        if (webFault != null) {
+            namespace = webFault.targetNamespace().length()>0 ?
+                        webFault.targetNamespace() : namespace;
+            name = webFault.name().length()>0 ?
+                   webFault.name() : name;
+            className = webFault.faultBean().length()>0 ?
+                        webFault.faultBean() : className;
+
+        }
+        JDefinedClass cls = getCMClass(className, CLASS);
+        faultInfo = new FaultInfo(className, false);
+
+        if (duplicateName(className)) {
+            builder.onError("webserviceap.method.exception.bean.name.not.unique",
+                             new Object[] {typeDecl.getQualifiedName(), thrownDecl.getQualifiedName()});
+        }
+
+        ArrayList<MemberInfo> members = new ArrayList<MemberInfo>();
+        MemberInfo member;
+        String typeString;
+        TypeMirror erasureType;
+        TreeSet<String> keys = new TreeSet<String>(propertyToTypeMap.keySet());
+        for (String key : keys) {
+            TypeMirror type = propertyToTypeMap.get(key);
+            erasureType =  getSafeType(type);
+            member = new MemberInfo(-10, erasureType, key, null);
+            members.add(member);
+        }
+        faultInfo.setMembers(members);
+
+        boolean canOverWriteBean = builder.canOverWriteClass(className);
+        if (!canOverWriteBean) {
+            builder.log("Class " + className + " exists. Not overwriting.");
+            seiContext.addExceptionBeanEntry(thrownDecl.getQualifiedName(), faultInfo, builder);
+            return false;
+        }
+        if (seiContext.getExceptionBeanName(thrownDecl.getQualifiedName()) != null)
+            return false;
+
+        //write class comment - JAXWS warning
+        JDocComment comment = cls.javadoc();
+        for (String doc : GeneratorBase.getJAXWSClassComment(builder.getSourceVersion())) {
+            comment.add(doc);
+        }
+
+        // XmlElement Declarations
+        writeXmlElementDeclaration(cls, name, namespace);
+
+        // XmlType Declaration
+        members = sortMembers(members);
+        writeXmlTypeDeclaration(cls, exceptionName, typeNamespace, members);
+
+        writeMembers(cls, members);
+
+        seiContext.addExceptionBeanEntry(thrownDecl.getQualifiedName(), faultInfo, builder);
+        return true;
+    }
+
+    protected boolean isWSDLException(Map<String, TypeMirror>map, ClassDeclaration thrownDecl) {
+        WebFault webFault = thrownDecl.getAnnotation(WebFault.class);
+        if (webFault == null)
+            return false;
+        if (map.size() != 2 || map.get(FAULT_INFO) == null)
+            return false;
+        return true;
+    }
+
+    private void writeXmlElementDeclaration(JDefinedClass cls, String elementName, String namespaceUri)
+        throws IOException {
+
+       if (cls == null)
+            return;
+        JAnnotationUse xmlRootElementAnn = cls.annotate(XmlRootElement.class);
+        xmlRootElementAnn.param("name", elementName);
+        if (namespaceUri.length() > 0) {
+            xmlRootElementAnn.param("namespace", namespaceUri);
+        }
+        JAnnotationUse xmlAccessorTypeAnn = cls.annotate(cm.ref(XmlAccessorType.class));
+        xmlAccessorTypeAnn.param("value", XmlAccessType.FIELD);
+    }
+
+    private void writeXmlTypeDeclaration(JDefinedClass cls, String typeName, String namespaceUri,
+                                         ArrayList<MemberInfo> members) throws IOException {
+        if (cls == null)
+            return;
+        JAnnotationUse xmlTypeAnn = cls.annotate(cm.ref(XmlType.class));
+        xmlTypeAnn.param("name", typeName);
+        xmlTypeAnn.param("namespace", namespaceUri);
+        if (members.size() > 1) {
+            JAnnotationArrayMember paramArray = xmlTypeAnn.paramArray("propOrder");
+            for (MemberInfo memInfo : members) {
+                paramArray.param(memInfo.getParamName());
+            }
+        }
+    }
+
+    private void writeMember(JDefinedClass cls, int paramIndex, TypeMirror paramType,
+        String paramName, QName elementName) throws IOException {
+
+        if (cls == null)
+            return;
+        String capPropName = StringUtils.capitalize(paramName);
+        String getterPrefix = paramType.equals("boolean") || paramType.equals("java.lang.Boolean") ? "is" : "get";
+        JMethod m = null;
+        JDocComment methodDoc = null;
+        JType propType = getType(paramType);
+        m = cls.method(JMod.PUBLIC, propType, getterPrefix+capPropName);
+        methodDoc = m.javadoc();
+        JCommentPart ret = methodDoc.addReturn();
+        ret.add("returns "+propType.name());
+        JBlock body = m.body();
+        body._return( JExpr._this().ref(paramName) );
+
+        m = cls.method(JMod.PUBLIC, cm.VOID, "set"+capPropName);
+        JVar param = m.param(propType, paramName);
+        methodDoc = m.javadoc();
+        JCommentPart part = methodDoc.addParam(paramName);
+        part.add("the value for the "+ paramName+" property");
+        body = m.body();
+        body.assign( JExpr._this().ref(paramName), param );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WrapperInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WrapperInfo.java
new file mode 100644
index 0000000..43ce925
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/annotation/WrapperInfo.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.annotation;
+
+import javax.xml.namespace.QName;
+import java.util.ArrayList;
+import java.util.List;
+import com.sun.tools.internal.ws.processor.modeler.annotation.*;
+
+/**
+ *
+ * @author  dkohlert
+ */
+public class WrapperInfo {
+    public String wrapperName;
+    public List<MemberInfo> members;
+
+    /** Creates a new instance of FaultInfo */
+    public WrapperInfo() {
+    }
+    public WrapperInfo(String wrapperName) {
+        this.wrapperName = wrapperName;
+    }
+
+    public void setWrapperName(String wrapperName) {
+        this.wrapperName = wrapperName;
+    }
+
+    public String getWrapperName() {
+        return wrapperName;
+    }
+    public List<MemberInfo> getMembers() {
+        return members;
+    }
+    public void setMembers(List<MemberInfo> members) {
+        this.members = members;
+    }
+    public void addMember(MemberInfo member) {
+        if (members == null)
+            members = new ArrayList<MemberInfo>();
+        members.add(member);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/AccessorElement.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/AccessorElement.java
new file mode 100644
index 0000000..19eb4e2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/AccessorElement.java
@@ -0,0 +1,73 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.wsdl;
+
+import javax.xml.namespace.QName;
+
+
+/**
+ * @author Vivek Pandey
+ *
+ * Rpc/Lit AccessorElement to be used to generate pseudo schema
+ */
+class AccessorElement {
+
+    private QName type;
+    private String name;
+
+
+    /**
+     * @param type
+     * @param name
+     */
+    public AccessorElement(String name, QName type) {
+        this.type = type;
+        this.name = name;
+    }
+    /**
+     * @return Returns the type.
+     */
+    public QName getType() {
+        return type;
+    }
+    /**
+     * @param type The type to set.
+     */
+    public void setType(QName type) {
+        this.type = type;
+    }
+    /**
+     * @return Returns the name.
+     */
+    public String getName() {
+        return name;
+    }
+    /**
+     * @param name The name to set.
+     */
+    public void setName(String name) {
+        this.name = name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/ClassNameAllocatorImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/ClassNameAllocatorImpl.java
new file mode 100644
index 0000000..f3ab1e2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/ClassNameAllocatorImpl.java
@@ -0,0 +1,79 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.wsdl;
+
+import com.sun.tools.internal.xjc.api.ClassNameAllocator;
+import com.sun.tools.internal.ws.processor.util.ClassNameCollector;
+
+import java.util.Set;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.HashMap;
+
+/**
+ * @author Vivek Pandey
+ *         <p/>
+ *         Implementation of Callback interface that allows the driver of the XJC API to rename JAXB-generated classes/interfaces/enums.
+ */
+public class ClassNameAllocatorImpl implements ClassNameAllocator {
+    public ClassNameAllocatorImpl(ClassNameCollector classNameCollector) {
+        this.classNameCollector = classNameCollector;
+        this.jaxbClasses = new HashSet<String>();
+    }
+
+    public String assignClassName(String packageName, String className) {
+        if(packageName== null || className == null){
+            //TODO: throw Exception
+            return className;
+        }
+
+        //if either of the values are empty string return the default className
+        if(packageName.equals("") || className.equals(""))
+            return className;
+
+        String fullClassName = packageName+"."+className;
+
+        // Check if there is any conflict with jaxws generated classes
+        Set<String> seiClassNames = classNameCollector.getSeiClassNames();
+        if(seiClassNames != null && seiClassNames.contains(fullClassName)){
+            className += TYPE_SUFFIX;
+        }
+
+        jaxbClasses.add(packageName+"."+className);
+        return className;
+    }
+
+    /**
+     *
+     * @return jaxbGenerated classNames
+     */
+    public Set<String> getJaxbGeneratedClasses() {
+        return jaxbClasses;
+    }
+
+    private final static String TYPE_SUFFIX = "_Type";
+    private ClassNameCollector classNameCollector;
+    private Set<String> jaxbClasses;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/ConsoleErrorReporter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/ConsoleErrorReporter.java
new file mode 100644
index 0000000..240a6e9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/ConsoleErrorReporter.java
@@ -0,0 +1,123 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.modeler.wsdl;
+
+import com.sun.tools.internal.xjc.api.ErrorListener;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import org.xml.sax.SAXParseException;
+
+import java.util.ResourceBundle;
+import java.text.MessageFormat;
+
+public class ConsoleErrorReporter implements ErrorListener{
+
+    private LocalizableMessageFactory messageFactory;
+    private ProcessorEnvironment env;
+    private boolean printStackTrace;
+    private boolean hasError;
+
+    public ConsoleErrorReporter(ProcessorEnvironment env, boolean printStackTrace) {
+        this.env = env;
+        this.printStackTrace = printStackTrace;
+        messageFactory =
+            new LocalizableMessageFactory("com.sun.tools.internal.ws.resources.model");
+    }
+
+    public boolean hasError() {
+        return hasError;
+    }
+
+    // will be null unless set in #error or #fatalError
+    //TODO: remove it after error handling is straightened
+    private Exception e;
+    Exception getException(){
+        return e;
+    }
+
+    public void error(SAXParseException e) {
+        hasError = true;
+        this.e = e;
+        if(printStackTrace)
+            e.printStackTrace();
+        env.error(messageFactory.getMessage("model.saxparser.exception",
+                new Object[]{e.getMessage(), getLocationString(e)}));
+    }
+
+    public void fatalError(SAXParseException e) {
+        hasError = true;
+        this.e = e;
+        if(printStackTrace)
+            e.printStackTrace();
+
+        env.error(messageFactory.getMessage("model.saxparser.exception",
+                new Object[]{e.getMessage(), getLocationString(e)}));
+    }
+
+    public void warning(SAXParseException e) {
+        env.warn(messageFactory.getMessage("model.saxparser.exception",
+                new Object[]{e.getMessage(), getLocationString(e)}));
+    }
+
+    /**
+     * Used to report possibly verbose information that
+     * can be safely ignored.
+     */
+    public void info(SAXParseException e) {
+        env.info(messageFactory.getMessage("model.saxparser.exception",
+                new Object[]{e.getMessage(), getLocationString(e)}));
+    }
+
+     /**
+    * Returns the human readable string representation of the
+    * {@link org.xml.sax.Locator} part of the specified
+    * {@link SAXParseException}.
+    *
+    * @return  non-null valid object.
+    */
+    protected final String getLocationString( SAXParseException e ) {
+      if(e.getLineNumber()!=-1 || e.getSystemId()!=null) {
+          int line = e.getLineNumber();
+          return format("ConsoleErrorReporter.LineXOfY", line==-1?"?":Integer.toString( line ),
+              getShortName( e.getSystemId() ) );
+      } else {
+          return format("ConsoleErrorReporter.UnknownLocation");
+      }
+    }
+
+    /** Computes a short name of a given URL for display. */
+    private String getShortName( String url ) {
+        if(url==null)
+            return format("ConsoleErrorReporter.UnknownLocation");
+        return url;
+    }
+
+    private String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle("com.sun.tools.internal.ws.resources.model").getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/JAXBModelBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/JAXBModelBuilder.java
new file mode 100644
index 0000000..b85e021
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/JAXBModelBuilder.java
@@ -0,0 +1,169 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.wsdl;
+
+import java.util.Iterator;
+import java.util.List;
+import java.util.Properties;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.Element;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXParseException;
+
+import com.sun.tools.internal.xjc.api.ErrorListener;
+import com.sun.tools.internal.xjc.api.SchemaCompiler;
+import com.sun.tools.internal.xjc.api.XJC;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.ws.processor.ProcessorOptions;
+import com.sun.tools.internal.ws.processor.config.ModelInfo;
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.model.ModelException;
+import com.sun.tools.internal.ws.processor.model.java.JavaSimpleType;
+import com.sun.tools.internal.ws.processor.model.java.JavaType;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBMapping;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBModel;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBType;
+import com.sun.tools.internal.ws.processor.modeler.JavaSimpleTypeCreator;
+import com.sun.tools.internal.ws.processor.util.ClassNameCollector;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+
+/**
+ * @author Kathy Walsh, Vivek Pandey
+ *
+ * Uses JAXB XJC apis to build JAXBModel and resolves xml to java type mapping from JAXBModel
+ */
+public class JAXBModelBuilder {
+    public JAXBModelBuilder(ModelInfo modelInfo,
+                            Properties options, ClassNameCollector classNameCollector, List elements) {
+        _messageFactory =
+            new LocalizableMessageFactory("com.sun.tools.internal.ws.resources.model");
+        _modelInfo = modelInfo;
+        _env = (ProcessorEnvironment) modelInfo.getParent().getEnvironment();
+        _classNameAllocator = new ClassNameAllocatorImpl(classNameCollector);
+
+        printstacktrace = Boolean.valueOf(options.getProperty(ProcessorOptions.PRINT_STACK_TRACE_PROPERTY));
+        consoleErrorReporter = new ConsoleErrorReporter(_env, false);
+        internalBuildJAXBModel(elements);
+    }
+
+    /**
+     * Builds model from WSDL document. Model contains abstraction which is used by the
+     * generators to generate the stub/tie/serializers etc. code.
+     *
+     * @see com.sun.tools.internal.ws.processor.modeler.Modeler#buildModel()
+     */
+
+    private void internalBuildJAXBModel(List elements){
+        try {
+            schemaCompiler = XJC.createSchemaCompiler();
+            schemaCompiler.setClassNameAllocator(_classNameAllocator);
+            schemaCompiler.setErrorListener(consoleErrorReporter);
+            schemaCompiler.setEntityResolver(_modelInfo.getEntityResolver());
+            int schemaElementCount = 1;
+            for(Iterator iter = elements.iterator(); iter.hasNext();){
+                Element schemaElement = (Element)iter.next();
+                String location = schemaElement.getOwnerDocument().getDocumentURI();
+                String systemId = new String(location + "#types?schema"+schemaElementCount++);
+                schemaCompiler.parseSchema(systemId,schemaElement);
+            }
+
+            //feed external jaxb:bindings file
+            Set<InputSource> externalBindings = ((WSDLModelInfo)_modelInfo).getJAXBBindings();
+            if(externalBindings != null){
+                for(InputSource jaxbBinding : externalBindings){
+                    schemaCompiler.parseSchema(jaxbBinding);
+                }
+            }
+        } catch (Exception e) {
+            throw new ModelException(e);
+        }
+    }
+
+    public JAXBType  getJAXBType(QName qname){
+        JAXBMapping mapping = jaxbModel.get(qname);
+        if (mapping == null){
+            fail("model.schema.elementNotFound", new Object[]{qname});
+        }
+
+        JavaType javaType = new JavaSimpleType(mapping.getType());
+        JAXBType type =  new JAXBType(qname, javaType, mapping, jaxbModel);
+        return type;
+    }
+
+    public TypeAndAnnotation getElementTypeAndAnn(QName qname){
+        JAXBMapping mapping = jaxbModel.get(qname);
+        if (mapping == null){
+            fail("model.schema.elementNotFound", new Object[]{qname});
+        }
+        return mapping.getType().getTypeAnn();
+    }
+
+    protected void bind(){
+        com.sun.tools.internal.xjc.api.JAXBModel rawJaxbModel = schemaCompiler.bind();
+        if(consoleErrorReporter.hasError()){
+            throw new ModelException(consoleErrorReporter.getException());
+        }
+        jaxbModel = new JAXBModel(rawJaxbModel);
+        jaxbModel.setGeneratedClassNames(_classNameAllocator.getJaxbGeneratedClasses());
+    }
+
+    protected SchemaCompiler getJAXBSchemaCompiler(){
+        return schemaCompiler;
+    }
+
+    protected void fail(String key, Object[] arg) {
+        throw new ModelException(key, arg);
+    }
+
+    protected void error(String key, Object[] args){
+        _env.error(_messageFactory.getMessage(key, args));
+    }
+
+    protected void warn(String key, Object[] args) {
+        _env.warn(_messageFactory.getMessage(key, args));
+    }
+
+    protected void inform(String key, Object[] args) {
+        _env.info(_messageFactory.getMessage(key, args));
+    }
+
+    public JAXBModel getJAXBModel(){
+        return jaxbModel;
+    }
+
+    private JAXBModel jaxbModel;
+    private SchemaCompiler schemaCompiler;
+    private final LocalizableMessageFactory _messageFactory;
+    private final ModelInfo _modelInfo;
+    private final ProcessorEnvironment _env;
+    private final boolean printstacktrace;
+    private final ClassNameAllocatorImpl _classNameAllocator;
+    private final ConsoleErrorReporter consoleErrorReporter;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/MimeHelper.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/MimeHelper.java
new file mode 100644
index 0000000..80a17dc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/MimeHelper.java
@@ -0,0 +1,106 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.wsdl;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import com.sun.tools.internal.ws.processor.modeler.JavaSimpleTypeCreator;
+
+/**
+ * @author Vivek Pandey
+ *
+ */
+public class MimeHelper {
+    /**
+     * @param mimePart
+     * @return unique attachment ID
+     */
+    protected static String getAttachmentUniqueID(String mimePart) {
+        //return "uuid@" + mimePart;
+        return mimePart;
+    }
+
+    /**
+     * @param mimeType
+     * @return true if mimeType is a binary type
+     */
+    protected static boolean isMimeTypeBinary(String mimeType) {
+        if (mimeType.equals(JPEG_IMAGE_MIME_TYPE)
+            || mimeType.equals(GIF_IMAGE_MIME_TYPE)
+        ) {
+            return true;
+        } else if (
+            mimeType.equals(TEXT_XML_MIME_TYPE)
+                || mimeType.equals(TEXT_HTML_MIME_TYPE)
+                || mimeType.equals(TEXT_PLAIN_MIME_TYPE)
+                || mimeType.equals(APPLICATION_XML_MIME_TYPE)
+                || mimeType.equals(MULTIPART_MIME_TYPE)) {
+            return false;
+        }
+        //some unknown mime type, will be mapped to DataHandler java type so
+        // return true
+        return true;
+    }
+
+    protected static void initMimeTypeToJavaType() {
+        mimeTypeToJavaType.put(JPEG_IMAGE_MIME_TYPE, javaType.IMAGE_JAVATYPE);
+        //mimeTypeToJavaType.put(PNG_IMAGE_MIME_TYPE, javaType.IMAGE_JAVATYPE);
+        mimeTypeToJavaType.put(GIF_IMAGE_MIME_TYPE,
+         javaType.IMAGE_JAVATYPE);
+        mimeTypeToJavaType.put(TEXT_XML_MIME_TYPE, javaType.SOURCE_JAVATYPE);
+        //mimeTypeToJavaType.put(TEXT_HTML_MIME_TYPE, javaType.SOURCE_JAVATYPE);
+        mimeTypeToJavaType.put(
+            APPLICATION_XML_MIME_TYPE,
+            javaType.SOURCE_JAVATYPE);
+        mimeTypeToJavaType.put(TEXT_PLAIN_MIME_TYPE, javaType.STRING_JAVATYPE);
+        mimeTypeToJavaType.put(
+            MULTIPART_MIME_TYPE,
+            javaType.MIME_MULTIPART_JAVATYPE);
+
+    }
+
+    protected static Map mimeTypeToJavaType;
+    protected static JavaSimpleTypeCreator javaType;
+
+    public static final String JPEG_IMAGE_MIME_TYPE = "image/jpeg";
+    //public static final String PNG_IMAGE_MIME_TYPE = "image/png";
+    public static final String GIF_IMAGE_MIME_TYPE = "image/gif";
+    public static final String TEXT_XML_MIME_TYPE = "text/xml";
+    public static final String TEXT_HTML_MIME_TYPE = "text/html";
+    public static final String TEXT_PLAIN_MIME_TYPE = "text/plain";
+    public static final String APPLICATION_XML_MIME_TYPE = "application/xml";
+    public static final String MULTIPART_MIME_TYPE = "multipart/*";
+
+    /**
+     *
+     */
+    public MimeHelper() {
+        mimeTypeToJavaType = new HashMap();
+        javaType = new JavaSimpleTypeCreator();
+        initMimeTypeToJavaType();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/PseudoSchemaBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/PseudoSchemaBuilder.java
new file mode 100644
index 0000000..33ab8c2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/PseudoSchemaBuilder.java
@@ -0,0 +1,280 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.wsdl;
+
+import static com.sun.tools.internal.ws.processor.modeler.wsdl.WSDLModelerBase.*;
+import com.sun.tools.internal.ws.processor.config.ModelInfo;
+import com.sun.tools.internal.ws.processor.modeler.wsdl.WSDLModelerBase.ProcessSOAPOperationInfo;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaKinds;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.NoSuchEntityException;
+
+import org.xml.sax.InputSource;
+
+import javax.xml.namespace.QName;
+import java.io.StringReader;
+import java.io.StringWriter;
+import java.text.MessageFormat;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+import com.sun.tools.internal.ws.wsdl.document.MessagePart;
+import com.sun.tools.internal.ws.wsdl.document.Operation;
+import com.sun.tools.internal.ws.wsdl.document.Kinds;
+import com.sun.tools.internal.ws.wsdl.document.Message;
+import com.sun.tools.internal.ws.wsdl.document.PortType;
+import com.sun.tools.internal.ws.wsdl.document.Port;
+import com.sun.tools.internal.ws.wsdl.document.Service;
+import com.sun.tools.internal.ws.wsdl.document.WSDLDocument;
+import com.sun.tools.internal.ws.wsdl.document.Binding;
+import com.sun.tools.internal.ws.wsdl.document.BindingOperation;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.JAXWSBinding;
+import com.sun.tools.internal.ws.wsdl.document.soap.*;
+
+
+
+/**
+ * @author Vivek Pandey
+ *
+ * Builds all possible pseudo schemas for async operation ResponseBean to feed to XJC.
+ */
+public class PseudoSchemaBuilder {
+
+    private final StringWriter buf = new StringWriter();
+    private final WSDLDocument wsdlDocument;
+    private final ModelInfo modelInfo;
+    private WSDLModeler wsdlModeler;
+    private final List<InputSource> schemas = new ArrayList<InputSource>();
+    private final HashMap<QName, Port> bindingNameToPortMap = new HashMap<QName, Port>();
+
+    public static List<InputSource> build(WSDLModeler wsdlModeler, ModelInfo modelInfo) {
+        PseudoSchemaBuilder b = new PseudoSchemaBuilder(wsdlModeler.document, modelInfo);
+        b.wsdlModeler = wsdlModeler;
+        JAXBModelBuilder analyzer = wsdlModeler.getJAXBModelBuilder();
+        b.build();
+        for(int i = 0; i < b.schemas.size(); i++){
+            InputSource is = b.schemas.get(i);
+            is.setSystemId("http://dummy.pseudo-schema#schema"+(i+1));
+        }
+        return b.schemas;
+    }
+
+    private PseudoSchemaBuilder(WSDLDocument _wsdl, ModelInfo _modelInfo) {
+        this.wsdlDocument = _wsdl;
+        this.modelInfo = _modelInfo;
+    }
+
+    private void build() {
+        for(Iterator<Service> itr=wsdlDocument.getDefinitions().services(); itr.hasNext(); )
+            build(itr.next());
+    }
+
+    private void build(Service service) {
+        for( Iterator<Port> itr=service.ports(); itr.hasNext(); )
+            build(itr.next() );
+    }
+
+    private void build(Port port) {
+        if(wsdlModeler.isProvider(port))
+            return;
+        Binding binding = port.resolveBinding(wsdlDocument);
+
+        SOAPBinding soapBinding =
+                    (SOAPBinding)getExtensionOfType(binding, SOAPBinding.class);
+        //lets try and see if its SOAP 1.2. dont worry about extension flag, its
+        // handled much earlier
+        if (soapBinding == null) {
+                    soapBinding =
+                            (SOAPBinding)getExtensionOfType(binding, SOAP12Binding.class);
+        }
+        if(soapBinding == null)
+            return;
+        PortType portType = binding.resolvePortType(wsdlDocument);
+
+        QName bindingName = WSDLModelerBase.getQNameOf(binding);
+
+        //we dont want to process the port bound to the binding processed earlier
+        if(bindingNameToPortMap.containsKey(bindingName))
+            return;
+
+        bindingNameToPortMap.put(bindingName, port);
+
+
+        for(Iterator itr=binding.operations(); itr.hasNext();){
+            BindingOperation bindingOperation = (BindingOperation)itr.next();
+            SOAPOperation soapOperation =
+            (SOAPOperation)getExtensionOfType(bindingOperation,
+                SOAPOperation.class);
+
+            // get only the bounded operations
+            Set boundedOps = portType.getOperationsNamed(bindingOperation.getName());
+            if(boundedOps.size() != 1)
+                continue;
+            Operation operation = (Operation)boundedOps.iterator().next();
+
+            // No pseudo schema required for doc/lit
+            SOAPStyle bindingStyle = soapBinding.getStyle();
+            SOAPStyle operationStyle = (soapOperation != null) ? soapOperation.getStyle() : bindingStyle;
+            if(wsdlModeler.isAsync(portType, operation)){
+                buildAsync(portType, operation, bindingOperation);
+            }
+        }
+    }
+
+    /**
+     * @param portType
+     * @param operation
+     * @param bindingOperation
+     */
+    private void buildAsync(PortType portType, Operation operation, BindingOperation bindingOperation) {
+        String operationName = getCustomizedOperationName(operation);//operation.getName();
+        if(operationName == null)
+            return;
+        Message outputMessage = null;
+        if(operation.getOutput() != null)
+            outputMessage = operation.getOutput().resolveMessage(wsdlDocument);
+        if(outputMessage != null){
+            List<MessagePart> allParts = new ArrayList<MessagePart>(outputMessage.getParts());
+            if(allParts.size() > 1)
+                build(getOperationName(portType, operationName, bindingOperation.getOutput()), allParts);
+        }
+
+    }
+
+    private String getCustomizedOperationName(Operation operation) {
+        JAXWSBinding jaxwsCustomization = (JAXWSBinding)getExtensionOfType(operation, JAXWSBinding.class);
+        String operationName = (jaxwsCustomization != null)?((jaxwsCustomization.getMethodName() != null)?jaxwsCustomization.getMethodName().getName():null):null;
+        if(operationName != null){
+            if(wsdlModeler.getEnvironment().getNames().isJavaReservedWord(operationName)){
+                return null;
+            }
+
+            return operationName;
+        }
+        return operation.getName();
+    }
+
+    private void writeImports(QName elementName, List<MessagePart> parts){
+        Set<String> uris = new HashSet<String>();
+        for(MessagePart p:parts){
+            String ns = p.getDescriptor().getNamespaceURI();
+            if(!uris.contains(ns) && !ns.equals("http://www.w3.org/2001/XMLSchema") && !ns.equals(elementName.getNamespaceURI())){
+                print("<xs:import namespace=''{0}''/>", ns);
+                uris.add(ns);
+            }
+        }
+    }
+
+    boolean asyncRespBeanBinding = false;
+    private void build(QName elementName, List<MessagePart> allParts){
+
+        print(
+                "<xs:schema xmlns:xs=''http://www.w3.org/2001/XMLSchema''" +
+                "           xmlns:jaxb=''http://java.sun.com/xml/ns/jaxb''" +
+                "           xmlns:xjc=''http://java.sun.com/xml/ns/jaxb/xjc''" +
+                "           jaxb:extensionBindingPrefixes=''xjc''" +
+                "           jaxb:version=''1.0''");
+        if((elementName != null) && elementName.getNamespaceURI().length() > 0){
+            print("           targetNamespace=''{0}''>", elementName.getNamespaceURI());
+        }else{
+            print("           >");
+        }
+
+        writeImports(elementName, allParts);
+
+        if(!asyncRespBeanBinding){
+            print(
+                    "<xs:annotation><xs:appinfo>" +
+                    "  <jaxb:schemaBindings>" +
+                    "    <jaxb:package name=''{0}'' />" +
+                    "  </jaxb:schemaBindings>" +
+                    "</xs:appinfo></xs:annotation>",
+                    wsdlModeler.getJavaPackage() );
+            asyncRespBeanBinding = true;
+        }
+
+        print("<xs:element name=''{0}''>", elementName.getLocalPart());
+        print("<xs:complexType>");
+        print("<xs:sequence>");
+
+
+        for(MessagePart p:allParts) {
+            //rpclit wsdl:part must reference schema type not element, also it must exclude headers and mime parts
+            if(p.getDescriptorKind() == SchemaKinds.XSD_ELEMENT){
+                print("<xs:element ref=''types:{0}'' xmlns:types=''{1}''/>",p.getDescriptor().getLocalPart(), p.getDescriptor().getNamespaceURI());
+            }else{
+                print("<xs:element name=''{0}'' type=''{1}'' xmlns=''{2}'' />",
+                    p.getName(),
+                    p.getDescriptor().getLocalPart(),
+                    p.getDescriptor().getNamespaceURI() );
+            }
+        }
+
+        print("</xs:sequence>");
+        print("</xs:complexType>");
+        print("</xs:element>");
+        print("</xs:schema>");
+
+        // reset the StringWriter, so that next operation element could be written
+        if(buf.toString().length() > 0){
+//            System.out.println("Response bean Schema for operation========> "+ elementName+"\n\n"+buf);
+            InputSource is = new InputSource(new StringReader(buf.toString()));
+            schemas.add(is);
+            buf.getBuffer().setLength(0);
+        }
+    }
+
+    private QName getOperationName(PortType portType, String operationName, Extensible binding){
+        if(operationName == null)
+            return null;
+//        String namespaceURI = wsdlDocument.getDefinitions().getTargetNamespaceURI()+"?"+portType.getName()+"?" + operationName;
+        String namespaceURI = "";
+        return new QName(namespaceURI, operationName+"Response");
+    }
+
+    private void print( String msg ) {
+        print( msg, new Object[0] );
+    }
+    private void print( String msg, Object arg1 ) {
+        print( msg, new Object[]{arg1} );
+    }
+    private void print( String msg, Object arg1, Object arg2 ) {
+        print( msg, new Object[]{arg1, arg2} );
+    }
+    private void print( String msg, Object arg1, Object arg2, Object arg3 ) {
+        print( msg, new Object[]{arg1,arg2,arg3} );
+    }
+    private void print( String msg, Object[] args ) {
+        buf.write(MessageFormat.format(msg,args));
+        buf.write('\n');
+    }
+
+    private static final Set<QName> nspaceToPackageSchema = new HashSet<QName>();
+    private static int  schemaCounter;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/WSDLModeler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/WSDLModeler.java
new file mode 100644
index 0000000..1070438
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/WSDLModeler.java
@@ -0,0 +1,2795 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.processor.modeler.wsdl;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.ws.processor.ProcessorOptions;
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.generator.GeneratorConstants;
+import com.sun.tools.internal.ws.processor.model.AsyncOperation;
+import com.sun.tools.internal.ws.processor.model.AsyncOperationType;
+import com.sun.tools.internal.ws.processor.model.Block;
+import com.sun.tools.internal.ws.processor.model.Fault;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.model.ModelException;
+import com.sun.tools.internal.ws.processor.model.ModelObject;
+import com.sun.tools.internal.ws.processor.model.ModelProperties;
+import com.sun.tools.internal.ws.processor.model.Operation;
+import com.sun.tools.internal.ws.processor.model.Parameter;
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.model.Request;
+import com.sun.tools.internal.ws.processor.model.Response;
+import com.sun.tools.internal.ws.processor.model.Service;
+import com.sun.tools.internal.ws.processor.model.java.JavaException;
+import com.sun.tools.internal.ws.processor.model.java.JavaInterface;
+import com.sun.tools.internal.ws.processor.model.java.JavaMethod;
+import com.sun.tools.internal.ws.processor.model.java.JavaParameter;
+import com.sun.tools.internal.ws.processor.model.java.JavaSimpleType;
+import com.sun.tools.internal.ws.processor.model.java.JavaStructureMember;
+import com.sun.tools.internal.ws.processor.model.java.JavaType;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBElementMember;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBProperty;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBStructuredType;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBType;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBTypeAndAnnotation;
+import com.sun.tools.internal.ws.processor.model.jaxb.RpcLitMember;
+import com.sun.tools.internal.ws.processor.model.jaxb.RpcLitStructure;
+import com.sun.tools.internal.ws.processor.modeler.JavaSimpleTypeCreator;
+import com.sun.tools.internal.ws.processor.modeler.ModelerException;
+import com.sun.tools.internal.ws.processor.modeler.ModelerUtils;
+import com.sun.tools.internal.ws.processor.util.ClassNameCollector;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.wsdl.document.Binding;
+import com.sun.tools.internal.ws.wsdl.document.BindingFault;
+import com.sun.tools.internal.ws.wsdl.document.BindingOperation;
+import com.sun.tools.internal.ws.wsdl.document.Documentation;
+import com.sun.tools.internal.ws.wsdl.document.Kinds;
+import com.sun.tools.internal.ws.wsdl.document.Message;
+import com.sun.tools.internal.ws.wsdl.document.MessagePart;
+import com.sun.tools.internal.ws.wsdl.document.OperationStyle;
+import com.sun.tools.internal.ws.wsdl.document.PortType;
+import com.sun.tools.internal.ws.wsdl.document.WSDLConstants;
+import com.sun.tools.internal.ws.wsdl.document.WSDLDocument;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.CustomName;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.JAXWSBinding;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEContent;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaKinds;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAP12Binding;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAP12Constants;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPAddress;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPBinding;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPBody;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPConstants;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPFault;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPHeader;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPOperation;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPStyle;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPUse;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.NoSuchEntityException;
+import com.sun.tools.internal.ws.wsdl.framework.ParseException;
+import com.sun.tools.internal.ws.wsdl.framework.ParserListener;
+import com.sun.tools.internal.ws.wsdl.framework.ValidationException;
+import com.sun.tools.internal.ws.wsdl.parser.SOAPEntityReferenceValidator;
+import com.sun.tools.internal.ws.wsdl.parser.WSDLParser;
+import com.sun.tools.internal.xjc.api.S2JJAXBModel;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.xjc.api.XJC;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.ws.model.Mode;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import org.xml.sax.InputSource;
+
+import javax.xml.namespace.QName;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Properties;
+import java.util.Set;
+import java.util.StringTokenizer;
+
+
+/**
+ * The WSDLModeler processes a WSDL to create a Model.
+ *
+ * @author WS Development Team
+ */
+public class WSDLModeler extends WSDLModelerBase {
+
+    //map of wsdl:operation QName to <soapenv:Body> child, as per BP it must be unique in a port
+    private final Map<QName, QName> uniqueBodyBlocks = new HashMap<QName, QName>();
+    private final QName VOID_BODYBLOCK = new QName("");
+    private ClassNameCollector classNameCollector;
+    private boolean extensions = false;
+    protected enum StyleAndUse  {RPC_LITERAL, DOC_LITERAL};
+    private ModelerUtils modelerUtils;
+    private JAXBModelBuilder jaxbModelBuilder;
+
+    /**
+     * @param modelInfo
+     * @param options
+     */
+    public WSDLModeler(WSDLModelInfo modelInfo, Properties options) {
+        super(modelInfo, options);
+        classNameCollector = new ClassNameCollector();
+    }
+
+    public Model buildModel() {
+        try {
+
+            parser = new WSDLParser(_modelInfo);
+            parser.addParserListener(new ParserListener() {
+                public void ignoringExtension(QName name, QName parent) {
+                    if (parent.equals(WSDLConstants.QNAME_TYPES)) {
+                        // check for a schema element with the wrong namespace URI
+                        if (name.getLocalPart().equals("schema")
+                            && !name.getNamespaceURI().equals("")) {
+                            warn(
+                                "wsdlmodeler.warning.ignoringUnrecognizedSchemaExtension",
+                                name.getNamespaceURI());
+                        }
+                    }
+                }
+                public void doneParsingEntity(QName element, Entity entity) {
+                }
+            });
+            hSet = parser.getUse();
+
+            extensions = Boolean.valueOf(_options.getProperty(ProcessorOptions.EXTENSION));
+
+            useWSIBasicProfile = !extensions;
+            document =
+                parser.parse();
+            document.validateLocally();
+
+            boolean validateWSDL =
+                Boolean
+                    .valueOf(
+                        _options.getProperty(
+                            ProcessorOptions.VALIDATE_WSDL_PROPERTY))
+                    .booleanValue();
+            if (validateWSDL) {
+                document.validate(new SOAPEntityReferenceValidator());
+            }
+
+
+            Model model = internalBuildModel(document);
+            //ClassNameCollector classNameCollector = new ClassNameCollector();
+            classNameCollector.process(model);
+            if (classNameCollector.getConflictingClassNames().isEmpty()) {
+                return model;
+            }
+            // do another pass, this time with conflict resolution enabled
+            model = internalBuildModel(document);
+            classNameCollector.process(model);
+            if (classNameCollector.getConflictingClassNames().isEmpty()) {
+                // we're done
+                return model;
+            }
+            // give up
+            StringBuffer conflictList = new StringBuffer();
+            boolean first = true;
+            for (Iterator iter =
+                classNameCollector.getConflictingClassNames().iterator();
+                iter.hasNext();
+                ) {
+                if (!first) {
+                    conflictList.append(", ");
+                } else {
+                    first = false;
+                }
+                conflictList.append((String)iter.next());
+            }
+            throw new ModelerException(
+                "wsdlmodeler.unsolvableNamingConflicts",
+                conflictList.toString());
+
+        } catch (ModelException e) {
+            throw new ModelerException((Exception)e);
+        } catch (ParseException e) {
+            throw new ModelerException((Exception)e);
+        } catch (ValidationException e) {
+            throw new ModelerException((Exception)e);
+        }
+    }
+
+    private Model internalBuildModel(WSDLDocument document) {
+
+        //build the jaxbModel to be used latter
+        buildJAXBModel(document, _modelInfo, classNameCollector);
+
+        QName modelName =
+            new QName(
+                document.getDefinitions().getTargetNamespaceURI(),
+                document.getDefinitions().getName() == null
+                    ? "model"
+                    : document.getDefinitions().getName());
+        Model model = new Model(modelName);
+        model.setJAXBModel(getJAXBModelBuilder().getJAXBModel());
+
+        // This fails with the changed classname (WSDLModeler to WSDLModeler11 etc.)
+        // with this source comaptibility change the WSDL Modeler class name is changed. Right now hardcoding the
+        // modeler class name to the same one being checked in WSDLGenerator.
+
+        model.setProperty(
+            ModelProperties.PROPERTY_MODELER_NAME,
+            ModelProperties.WSDL_MODELER_NAME);
+
+        _javaTypes = new JavaSimpleTypeCreator();
+        _javaExceptions = new HashMap();
+        _bindingNameToPortMap = new HashMap();
+
+        // grab target namespace
+        model.setTargetNamespaceURI(document.getDefinitions().getTargetNamespaceURI());
+
+        setDocumentationIfPresent(model,
+            document.getDefinitions().getDocumentation());
+
+        boolean hasServices = document.getDefinitions().services().hasNext();
+        if (hasServices) {
+            for (Iterator iter = document.getDefinitions().services();
+                iter.hasNext();
+                ) {
+                processService((com.sun.tools.internal.ws.wsdl.document.Service)iter.next(),
+                                model, document);
+                hasServices = true;
+            }
+        } else {
+            // emit a warning if there are no service definitions
+            warn("wsdlmodeler.warning.noServiceDefinitionsFound");
+        }
+
+        return model;
+    }
+
+
+    /* (non-Javadoc)
+     * @see WSDLModelerBase#processService(Service, Model, WSDLDocument)
+     */
+    protected void processService(com.sun.tools.internal.ws.wsdl.document.Service wsdlService, Model model, WSDLDocument document) {
+        String serviceInterface = "";
+        QName serviceQName = getQNameOf(wsdlService);
+        serviceInterface = getServiceInterfaceName(serviceQName, wsdlService);
+        if (isConflictingServiceClassName(serviceInterface)) {
+            serviceInterface += "_Service";
+        }
+        Service service =
+            new Service(
+                serviceQName,
+                new JavaInterface(serviceInterface, serviceInterface + "Impl"));
+
+        setDocumentationIfPresent(service, wsdlService.getDocumentation());
+        boolean hasPorts = false;
+        for (Iterator iter = wsdlService.ports(); iter.hasNext();) {
+            boolean processed =
+                processPort(
+                    (com.sun.tools.internal.ws.wsdl.document.Port)iter.next(),
+                    service,
+                    document);
+            hasPorts = hasPorts || processed;
+        }
+        if (!hasPorts) {
+            // emit a warning if there are no ports
+            warn("wsdlmodeler.warning.noPortsInService", wsdlService.getName());
+        }else{
+            model.addService(service);
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see WSDLModelerBase#processPort(Port, Service, WSDLDocument)
+     */
+    protected boolean processPort(com.sun.tools.internal.ws.wsdl.document.Port wsdlPort,
+            Service service, WSDLDocument document) {
+        try {
+
+            //clear the  unique block map
+            uniqueBodyBlocks.clear();
+
+            QName portQName = getQNameOf(wsdlPort);
+            Port port = new Port(portQName);
+
+            setDocumentationIfPresent(port, wsdlPort.getDocumentation());
+
+            SOAPAddress soapAddress =
+                (SOAPAddress)getExtensionOfType(wsdlPort, SOAPAddress.class);
+            if (soapAddress == null) {
+                // not a SOAP port, ignore it
+                warn("wsdlmodeler.warning.ignoringNonSOAPPort.noAddress", wsdlPort.getName());
+                return false;
+            }
+
+            port.setAddress(soapAddress.getLocation());
+            Binding binding = wsdlPort.resolveBinding(document);
+            QName bindingName = getQNameOf(binding);
+            PortType portType = binding.resolvePortType(document);
+
+            port.setProperty(
+                ModelProperties.PROPERTY_WSDL_PORT_NAME,
+                getQNameOf(wsdlPort));
+            port.setProperty(
+                ModelProperties.PROPERTY_WSDL_PORT_TYPE_NAME,
+                getQNameOf(portType));
+            port.setProperty(
+                ModelProperties.PROPERTY_WSDL_BINDING_NAME,
+                bindingName);
+
+            boolean isProvider = isProvider(wsdlPort);
+            if (_bindingNameToPortMap.containsKey(bindingName) && !isProvider) {
+                // this binding has been processed before
+                Port existingPort =
+                    _bindingNameToPortMap.get(bindingName);
+                port.setOperations(existingPort.getOperations());
+                port.setJavaInterface(existingPort.getJavaInterface());
+                port.setStyle(existingPort.getStyle());
+                port.setWrapped(existingPort.isWrapped());
+            } else {
+                // find out the SOAP binding extension, if any
+                SOAPBinding soapBinding =
+                    (SOAPBinding)getExtensionOfType(binding, SOAPBinding.class);
+
+                if (soapBinding == null) {
+                    soapBinding =
+                            (SOAPBinding)getExtensionOfType(binding, SOAP12Binding.class);
+                    if (soapBinding == null) {
+                        // cannot deal with non-SOAP ports
+                        warn(
+                            "wsdlmodeler.warning.ignoringNonSOAPPort",
+                            wsdlPort.getName());
+                        return false;
+                    }
+                    // we can only do soap1.2 if extensions are on
+                    if (extensions) {
+                        warn("wsdlmodeler.warning.port.SOAPBinding12", wsdlPort.getName());
+                    } else {
+                        warn("wsdlmodeler.warning.ignoringSOAPBinding12",
+                                wsdlPort.getName());
+                        return false;
+                    }
+                }
+
+                if (soapBinding.getTransport() == null
+                    || (!soapBinding.getTransport().equals(
+                        SOAPConstants.URI_SOAP_TRANSPORT_HTTP) && !soapBinding.getTransport().equals(
+                        SOAP12Constants.URI_SOAP_TRANSPORT_HTTP))) {
+                    // cannot deal with non-HTTP ports
+                    warn(
+                        "wsdlmodeler.warning.ignoringSOAPBinding.nonHTTPTransport",
+                        wsdlPort.getName());
+                    return false;
+                }
+
+                /**
+                 * validate wsdl:binding uniqueness in style, e.g. rpclit or doclit
+                 * ref: WSI BP 1.1 R 2705
+                 */
+                if(!validateWSDLBindingStyle(binding)){
+                    if(extensions){
+                        warn("wsdlmodeler.warning.port.SOAPBinding.mixedStyle", wsdlPort.getName());
+                    }else{
+                        fail("wsdlmodeler.warning.ignoringSOAPBinding.mixedStyle",
+                                wsdlPort.getName());
+                        return false;
+                    }
+                }
+
+                port.setStyle(soapBinding.getStyle());
+                boolean hasOverloadedOperations = false;
+                Set<String> operationNames = new HashSet<String>();
+                for (Iterator iter = portType.operations(); iter.hasNext();) {
+                    com.sun.tools.internal.ws.wsdl.document.Operation operation =
+                        (com.sun.tools.internal.ws.wsdl.document.Operation)iter.next();
+
+                    if (operationNames.contains(operation.getName())) {
+                        hasOverloadedOperations = true;
+                        break;
+                    }
+                    operationNames.add(operation.getName());
+
+                    for (Iterator itr = binding.operations();
+                        iter.hasNext();
+                        ) {
+                        BindingOperation bindingOperation =
+                            (BindingOperation)itr.next();
+                        if (operation
+                            .getName()
+                            .equals(bindingOperation.getName())) {
+                            break;
+                        } else if (!itr.hasNext()) {
+                            throw new ModelerException(
+                                "wsdlmodeler.invalid.bindingOperation.notFound",
+                                new Object[] {
+                                    operation.getName(),
+                                    binding.getName()});
+                        }
+                    }
+                }
+
+                Map headers = new HashMap();
+                boolean hasOperations = false;
+                for (Iterator iter = binding.operations(); iter.hasNext();) {
+                    BindingOperation bindingOperation =
+                        (BindingOperation)iter.next();
+
+                    com.sun.tools.internal.ws.wsdl.document.Operation portTypeOperation =
+                        null;
+                    Set operations =
+                        portType.getOperationsNamed(bindingOperation.getName());
+                    if (operations.size() == 0) {
+                        // the WSDL document is invalid
+                        throw new ModelerException(
+                            "wsdlmodeler.invalid.bindingOperation.notInPortType",
+                            new Object[] {
+                                bindingOperation.getName(),
+                                binding.getName()});
+                    } else if (operations.size() == 1) {
+                        portTypeOperation =
+                            (com.sun.tools.internal.ws.wsdl.document.Operation)operations
+                                .iterator()
+                                .next();
+                    } else {
+                        boolean found = false;
+                        String expectedInputName =
+                            bindingOperation.getInput().getName();
+                        String expectedOutputName =
+                            bindingOperation.getOutput().getName();
+
+                        for (Iterator iter2 = operations.iterator();iter2.hasNext();) {
+                            com.sun.tools.internal.ws.wsdl.document.Operation candidateOperation =
+                                (com.sun.tools.internal.ws.wsdl.document.Operation)iter2
+                                    .next();
+
+                            if (expectedInputName == null) {
+                                // the WSDL document is invalid
+                                throw new ModelerException(
+                                    "wsdlmodeler.invalid.bindingOperation.missingInputName",
+                                    new Object[] {
+                                        bindingOperation.getName(),
+                                        binding.getName()});
+                            }
+                            if (expectedOutputName == null) {
+                                // the WSDL document is invalid
+                                throw new ModelerException(
+                                    "wsdlmodeler.invalid.bindingOperation.missingOutputName",
+                                    new Object[] {
+                                        bindingOperation.getName(),
+                                        binding.getName()});
+                            }
+                            if (expectedInputName
+                                .equals(candidateOperation.getInput().getName())
+                                && expectedOutputName.equals(
+                                    candidateOperation
+                                        .getOutput()
+                                        .getName())) {
+                                if (found) {
+                                    // the WSDL document is invalid
+                                    throw new ModelerException(
+                                        "wsdlmodeler.invalid.bindingOperation.multipleMatchingOperations",
+                                        new Object[] {
+                                            bindingOperation.getName(),
+                                            binding.getName()});
+                                }
+                                // got it!
+                                found = true;
+                                portTypeOperation = candidateOperation;
+                            }
+                        }
+                        if (!found) {
+                            // the WSDL document is invalid
+                            throw new ModelerException(
+                                "wsdlmodeler.invalid.bindingOperation.notFound",
+                                new Object[] {
+                                    bindingOperation.getName(),
+                                    binding.getName()});
+                        }
+                    }
+                    if(!isProvider){
+                        this.info =
+                            new ProcessSOAPOperationInfo(
+                                port,
+                                wsdlPort,
+                                portTypeOperation,
+                                bindingOperation,
+                                soapBinding,
+                                document,
+                                hasOverloadedOperations,
+                                headers);
+
+                        Operation operation = processSOAPOperation();
+                        if (operation != null) {
+                            port.addOperation(operation);
+                            hasOperations = true;
+                        }
+                    }
+                }
+                if (!isProvider && !hasOperations) {
+                    // emit a warning if there are no operations, except when its a provider port
+                    warn("wsdlmodeler.warning.noOperationsInPort",
+                        wsdlPort.getName());
+                    return false;
+                }
+                createJavaInterfaceForPort(port, isProvider);
+                PortType pt = binding.resolvePortType(document);
+                String jd = (pt.getDocumentation() != null)?pt.getDocumentation().getContent():null;
+                port.getJavaInterface().setJavaDoc(jd);
+                _bindingNameToPortMap.put(bindingName, port);
+            }
+
+            // now deal with the configured handlers
+            port.setClientHandlerChainInfo(
+                _modelInfo.getClientHandlerChainInfo());
+            port.setServerHandlerChainInfo(
+                _modelInfo.getServerHandlerChainInfo());
+
+            service.addPort(port);
+            applyPortMethodCustomization(port, wsdlPort);
+            applyWrapperStyleCustomization(port, binding.resolvePortType(document));
+
+            return true;
+
+        } catch (NoSuchEntityException e) {
+            warn(e);
+            // should not happen
+            return false;
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see WSDLModelerBase#processSOAPOperation()
+     */
+    protected Operation processSOAPOperation() {
+        Operation operation =
+            new Operation(new QName(null, info.bindingOperation.getName()));
+
+        setDocumentationIfPresent(
+            operation,
+            info.portTypeOperation.getDocumentation());
+
+        if (info.portTypeOperation.getStyle()
+            != OperationStyle.REQUEST_RESPONSE
+            && info.portTypeOperation.getStyle() != OperationStyle.ONE_WAY) {
+            if(extensions){
+                warn(
+                    "wsdlmodeler.warning.ignoringOperation.notSupportedStyle",
+                    info.portTypeOperation.getName());
+                return null;
+            }
+            fail("wsdlmodeler.invalid.operation.notSupportedStyle",
+                    new Object[]{info.portTypeOperation.getName(),
+                    info.port.resolveBinding(document).resolvePortType(document).getName()});
+        }
+
+        SOAPStyle soapStyle = info.soapBinding.getStyle();
+
+        // find out the SOAP operation extension, if any
+        SOAPOperation soapOperation =
+            (SOAPOperation)getExtensionOfType(info.bindingOperation,
+                SOAPOperation.class);
+
+        if (soapOperation != null) {
+            if (soapOperation.getStyle() != null) {
+                soapStyle = soapOperation.getStyle();
+            }
+            if (soapOperation.getSOAPAction() != null) {
+                operation.setSOAPAction(soapOperation.getSOAPAction());
+            }
+        }
+
+        operation.setStyle(soapStyle);
+
+        String uniqueOperationName =
+            getUniqueName(info.portTypeOperation, info.hasOverloadedOperations);
+        if (info.hasOverloadedOperations) {
+            operation.setUniqueName(uniqueOperationName);
+        }
+
+        info.operation = operation;
+        info.uniqueOperationName = uniqueOperationName;
+
+        //attachment
+        SOAPBody soapRequestBody = getSOAPRequestBody();
+        if (soapRequestBody == null) {
+            // the WSDL document is invalid
+            throw new ModelerException(
+                "wsdlmodeler.invalid.bindingOperation.inputMissingSoapBody",
+                new Object[] { info.bindingOperation.getName()});
+        }
+
+        if (soapStyle == SOAPStyle.RPC) {
+            if (soapRequestBody.isEncoded()) {
+                throw new ModelerException("wsdlmodeler20.rpcenc.not.supported");
+            }
+            return processLiteralSOAPOperation(StyleAndUse.RPC_LITERAL);
+        }
+        // document style
+        return processLiteralSOAPOperation(StyleAndUse.DOC_LITERAL);
+    }
+
+    protected Operation processLiteralSOAPOperation(StyleAndUse styleAndUse){
+        //returns false if the operation name is not acceptable
+        if(!applyOperationNameCustomization())
+            return null;
+
+        boolean isRequestResponse = info.portTypeOperation.getStyle() == OperationStyle.REQUEST_RESPONSE;
+        Request request = new Request();
+        Response response = new Response();
+        info.operation.setUse(SOAPUse.LITERAL);
+        SOAPBody soapRequestBody = getSOAPRequestBody();
+        if((StyleAndUse.DOC_LITERAL == styleAndUse) && (soapRequestBody.getNamespace() != null)){
+            warn("wsdlmodeler.warning.r2716", new Object[]{"soapbind:body", info.bindingOperation.getName()});
+        }
+
+        Message inputMessage = getInputMessage();
+
+        SOAPBody soapResponseBody = null;
+        Message outputMessage = null;
+        if (isRequestResponse) {
+            soapResponseBody = getSOAPResponseBody();
+            if (isOperationDocumentLiteral(styleAndUse) && (soapResponseBody.getNamespace() != null)) {
+                warn("wsdlmodeler.warning.r2716", new Object[]{"soapbind:body", info.bindingOperation.getName()});
+            }
+            outputMessage = getOutputMessage();
+        }
+
+        //ignore operation if there are more than one root part
+        if(!validateMimeParts(getMimeParts(info.bindingOperation.getInput())) ||
+                !validateMimeParts(getMimeParts(info.bindingOperation.getOutput())))
+            return null;
+
+
+        if(!validateBodyParts(info.bindingOperation)){
+            // BP 1.1
+            // R2204   A document-literal binding in a DESCRIPTION MUST refer, in each of its soapbind:body element(s),
+            // only to wsdl:part element(s) that have been defined using the element attribute.
+
+            // R2203   An rpc-literal binding in a DESCRIPTION MUST refer, in its soapbind:body element(s),
+            // only to wsdNl:part element(s) that have been defined using the type attribute.
+            if(isOperationDocumentLiteral(styleAndUse))
+                if(extensions)
+                    warn("wsdlmodeler.warning.ignoringOperation.cannotHandleTypeMessagePart", info.portTypeOperation.getName());
+                else
+                    fail("wsdlmodeler.invalid.doclitoperation", info.portTypeOperation.getName());
+            else if(isOperationRpcLiteral(styleAndUse)) {
+                if(extensions)
+                    warn("wsdlmodeler.warning.ignoringOperation.cannotHandleElementMessagePart", info.portTypeOperation.getName());
+                else
+                    fail("wsdlmodeler.invalid.rpclitoperation", info.portTypeOperation.getName());
+            }
+            return null;
+        }
+
+        // Process parameterOrder and get the parameterList
+        List<MessagePart> parameterList = getParameterOrder();
+
+        //binding is invalid in the wsdl, ignore the operation.
+        if(!setMessagePartsBinding(styleAndUse))
+            return null;
+
+        List<Parameter> params = null;
+        boolean unwrappable = isUnwrappable();
+        info.operation.setWrapped(unwrappable);
+        if(isOperationDocumentLiteral(styleAndUse)){
+            params = getDoclitParameters(request, response, parameterList);
+        }else if(isOperationRpcLiteral(styleAndUse)){
+            String operationName = info.bindingOperation.getName();
+            Block reqBlock = null;
+            if (inputMessage != null) {
+                QName name = new QName(getRequestNamespaceURI(soapRequestBody), operationName);
+                RpcLitStructure rpcStruct = new RpcLitStructure(name, getJAXBModelBuilder().getJAXBModel());
+                rpcStruct.setJavaType(new JavaSimpleType("com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload", null));
+                reqBlock = new Block(name, rpcStruct);
+                request.addBodyBlock(reqBlock);
+            }
+
+            Block resBlock = null;
+            if (isRequestResponse && outputMessage != null) {
+                QName name = new QName(getResponseNamespaceURI(soapResponseBody), operationName + "Response");
+                RpcLitStructure rpcStruct = new RpcLitStructure(name, getJAXBModelBuilder().getJAXBModel());
+                rpcStruct.setJavaType(new JavaSimpleType("com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload", null));
+                resBlock = new Block(name, rpcStruct);
+                response.addBodyBlock(resBlock);
+            }
+            params = getRpcLitParameters(request, response, reqBlock, resBlock, parameterList);
+        }
+
+
+        if(!validateParameterName(params)) {
+            return null;
+        }
+
+        // create a definitive list of parameters to match what we'd like to get
+        // in the java interface (which is generated much later), parameterOrder
+        List<Parameter> definitiveParameterList = new ArrayList<Parameter>();
+        for (Parameter param: params) {
+            if(param.isReturn()){
+                info.operation.setProperty(WSDL_RESULT_PARAMETER, param);
+                response.addParameter(param);
+                continue;
+            }
+            if(param.isIN()){
+                request.addParameter(param);
+            }else if(param.isOUT()){
+                response.addParameter(param);
+            }else if(param.isINOUT()){
+                request.addParameter(param);
+                response.addParameter(param);
+            }
+            definitiveParameterList.add(param);
+        }
+
+        info.operation.setRequest(request);
+
+        if (isRequestResponse) {
+            info.operation.setResponse(response);
+        }
+
+        Iterator<Block> bb = request.getBodyBlocks();
+        QName body = VOID_BODYBLOCK;
+        QName opName = null;
+
+        if(bb.hasNext()){
+            body = bb.next().getName();
+            opName = uniqueBodyBlocks.get(body);
+        }else{
+            //there is no body block
+            body = VOID_BODYBLOCK;
+            opName = uniqueBodyBlocks.get(VOID_BODYBLOCK);
+        }
+        if(opName != null){
+            fail("wsdlmodeler.nonUnique.body", new Object[]{info.port.getName(), info.operation.getName(), opName, body});
+        }else{
+            uniqueBodyBlocks.put(body, info.operation.getName());
+        }
+
+        // faults with duplicate names
+        Set duplicateNames = getDuplicateFaultNames();
+
+        // handle soap:fault
+        handleLiteralSOAPFault(response, duplicateNames);
+        info.operation.setProperty(
+                WSDL_PARAMETER_ORDER,
+                definitiveParameterList);
+
+        //set Async property
+        Binding binding = info.port.resolveBinding(document);
+        PortType portType = binding.resolvePortType(document);
+        if(isAsync(portType, info.portTypeOperation)){
+            addAsyncOperations(info.operation, styleAndUse);
+        }
+
+        return info.operation;
+    }
+
+    /**
+     *
+     * @param params
+     * @return
+     */
+    private boolean validateParameterName(List<Parameter> params) {
+        Message msg = getInputMessage();
+        for(Parameter param : params){
+            if(param.isOUT())
+                continue;
+            if(param.getCustomName() != null){
+                if(getEnvironment().getNames().isJavaReservedWord(param.getCustomName())){
+                    if(extensions)
+                        warn("wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.customName",
+                                new Object[]{info.operation.getName(), param.getCustomName()});
+                    else
+                        fail("wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.customName",
+                                new Object[]{info.operation.getName(), param.getCustomName()});
+                    return false;
+                }
+                return true;
+            }
+            //process doclit wrapper style
+            if(param.isEmbedded() && !(param.getBlock().getType() instanceof RpcLitStructure)){
+                if(getEnvironment().getNames().isJavaReservedWord(param.getName())){
+                    if(extensions)
+                        warn("wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.wrapperStyle", new Object[]{info.operation.getName(), param.getName(), param.getBlock().getName()});
+                    else
+                        fail("wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.wrapperStyle", new Object[]{info.operation.getName(), param.getName(), param.getBlock().getName()});
+                    return false;
+                }
+            }else{
+                //non-wrapper style and rpclit
+                if(getEnvironment().getNames().isJavaReservedWord(param.getName())){
+                    if(extensions)
+                        warn("wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.nonWrapperStyle", new Object[]{info.operation.getName(), msg.getName(), param.getName()});
+                    else
+                        fail("wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.nonWrapperStyle", new Object[]{info.operation.getName(), msg.getName(), param.getName()});
+                    return false;
+                }
+            }
+        }
+
+        boolean isRequestResponse = info.portTypeOperation.getStyle() == OperationStyle.REQUEST_RESPONSE;
+        if(isRequestResponse){
+            msg = getOutputMessage();
+            for(Parameter param : params){
+                if(param.isIN())
+                    continue;
+                if(param.getCustomName() != null){
+                    if(getEnvironment().getNames().isJavaReservedWord(param.getCustomName())){
+                        if(extensions)
+                            warn("wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.customName",
+                                    new Object[]{info.operation.getName(), param.getCustomName()});
+                        else
+                            fail("wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.customName",
+                                    new Object[]{info.operation.getName(), param.getCustomName()});
+                        return false;
+                    }
+                    return true;
+                }
+                //process doclit wrapper style
+                if(param.isEmbedded() && !(param.getBlock().getType() instanceof RpcLitStructure)){
+                    if(param.isReturn())
+                        continue;
+                    if(!param.getName().equals("return") && getEnvironment().getNames().isJavaReservedWord(param.getName())){
+                        if(extensions)
+                            warn("wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.wrapperStyle",
+                                    new Object[]{info.operation.getName(), param.getName(), param.getBlock().getName()});
+                        else
+                            fail("wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.wrapperStyle",
+                                    new Object[]{info.operation.getName(), param.getName(), param.getBlock().getName()});
+                        return false;
+                    }
+                }else{
+                    if(param.isReturn())
+                        continue;
+
+                    //non-wrapper style and rpclit
+                    if(getEnvironment().getNames().isJavaReservedWord(param.getName())){
+                        if(extensions)
+                            warn("wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.nonWrapperStyle", new Object[]{info.operation.getName(), msg.getName(), param.getName()});
+                        else
+                            fail("wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.nonWrapperStyle",
+                                    new Object[]{info.operation.getName(), msg.getName(), param.getName()});
+                        return false;
+                    }
+                }
+            }
+        }
+
+        return true;
+    }
+
+    /**
+     * @return
+     */
+    private boolean enableMimeContent() {
+        //first we look at binding operation
+        JAXWSBinding jaxwsCustomization = (JAXWSBinding)getExtensionOfType(info.bindingOperation, JAXWSBinding.class);
+        Boolean mimeContentMapping = (jaxwsCustomization != null)?jaxwsCustomization.isEnableMimeContentMapping():null;
+        if(mimeContentMapping != null)
+            return mimeContentMapping;
+
+        //then in wsdl:binding
+        Binding binding = info.port.resolveBinding(info.document);
+        jaxwsCustomization = (JAXWSBinding)getExtensionOfType(binding, JAXWSBinding.class);
+        mimeContentMapping = (jaxwsCustomization != null)?jaxwsCustomization.isEnableMimeContentMapping():null;
+        if(mimeContentMapping != null)
+            return mimeContentMapping;
+
+        //at last look in wsdl:definitions
+        jaxwsCustomization = (JAXWSBinding)getExtensionOfType(info.document.getDefinitions(), JAXWSBinding.class);
+        mimeContentMapping = (jaxwsCustomization != null)?jaxwsCustomization.isEnableMimeContentMapping():null;
+        if(mimeContentMapping != null)
+            return mimeContentMapping;
+        return false;
+    }
+
+    /**
+     *
+     */
+    private boolean applyOperationNameCustomization() {
+        JAXWSBinding jaxwsCustomization = (JAXWSBinding)getExtensionOfType(info.portTypeOperation, JAXWSBinding.class);
+        String operationName = (jaxwsCustomization != null)?((jaxwsCustomization.getMethodName() != null)?jaxwsCustomization.getMethodName().getName():null):null;
+        if(operationName != null){
+            if(getEnvironment().getNames().isJavaReservedWord(operationName)){
+                if(extensions)
+                    warn("wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.customizedOperationName", new Object[]{info.operation.getName(), operationName});
+                else
+                    fail("wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.customizedOperationName", new Object[]{info.operation.getName(), operationName});
+                return false;
+            }
+
+            info.operation.setCustomizedName(operationName);
+        }
+
+        if(getEnvironment().getNames().isJavaReservedWord(info.operation.getJavaMethodName())){
+            if(extensions)
+                warn("wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.operationName", new Object[]{info.operation.getName()});
+            else
+                fail("wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.operationName", new Object[]{info.operation.getName()});
+            return false;
+        }
+        return true;
+    }
+
+    protected String getAsyncOperationName(Operation operation){
+        String name = operation.getCustomizedName();
+        if(name == null)
+            name = operation.getUniqueName();
+        return name;
+    }
+
+    /**
+     * @param styleAndUse
+     */
+    private void addAsyncOperations(Operation syncOperation, StyleAndUse styleAndUse) {
+        Operation operation = createAsyncOperation(syncOperation, styleAndUse, AsyncOperationType.POLLING);
+        if(operation != null)
+            info.modelPort.addOperation(operation);
+
+        operation = createAsyncOperation(syncOperation, styleAndUse, AsyncOperationType.CALLBACK);
+        if(operation != null)
+            info.modelPort.addOperation(operation);
+    }
+
+    /**
+     *
+     * @param syncOperation
+     * @param styleAndUse
+     * @param asyncType
+     * @return
+     */
+    private Operation createAsyncOperation(Operation syncOperation, StyleAndUse styleAndUse, AsyncOperationType asyncType) {
+        boolean isRequestResponse = info.portTypeOperation.getStyle() == OperationStyle.REQUEST_RESPONSE;
+        if(!isRequestResponse)
+            return null;
+        Request request = new Request();
+        Response response = new Response();
+
+        //create async operations
+        AsyncOperation operation = new AsyncOperation(info.operation);
+
+        //creation the async operation name: operationName+Async or customized name
+        //operation.setName(new QName(operation.getName().getNamespaceURI(), getAsyncOperationName(info.portTypeOperation, operation)));
+        if(asyncType.equals(AsyncOperationType.CALLBACK))
+            operation.setUniqueName(info.operation.getUniqueName()+"_async_callback");
+        else if(asyncType.equals(AsyncOperationType.POLLING))
+            operation.setUniqueName(info.operation.getUniqueName()+"_async_polling");
+
+        setDocumentationIfPresent(
+            operation,
+            info.portTypeOperation.getDocumentation());
+
+        operation.setAsyncType(asyncType);
+        operation.setSOAPAction(info.operation.getSOAPAction());
+        boolean unwrappable = info.operation.isWrapped();
+        operation.setWrapped(unwrappable);
+        SOAPBody soapRequestBody = getSOAPRequestBody();
+
+        Message inputMessage = getInputMessage();
+
+        SOAPBody soapResponseBody = null;
+        Message outputMessage = null;
+        if (isRequestResponse) {
+            soapResponseBody = getSOAPResponseBody();
+            outputMessage = getOutputMessage();
+        }
+
+        // Process parameterOrder and get the parameterList
+        java.util.List<String> parameterList = getAsynParameterOrder();
+
+        List<Parameter> inParameters = null;
+        if(isOperationDocumentLiteral(styleAndUse)){
+            inParameters = getRequestParameters(request, parameterList);
+            // outParameters = getResponseParameters(response);
+            // re-create parameterList with unwrapped parameters
+            if(unwrappable){
+                List<String> unwrappedParameterList = new ArrayList<String>();
+                if(inputMessage != null){
+                    Iterator<MessagePart> parts = inputMessage.parts();
+                    if(parts.hasNext()){
+                        MessagePart part = parts.next();
+                        JAXBType jaxbType = getJAXBType(part.getDescriptor());
+                        List<JAXBProperty> memberList = jaxbType.getWrapperChildren();
+                        Iterator<JAXBProperty> props = memberList.iterator();
+                        while(props.hasNext()){
+                            JAXBProperty prop = props.next();
+                            unwrappedParameterList.add(prop.getElementName().getLocalPart());
+                        }
+                    }
+                }
+
+                parameterList.clear();
+                parameterList.addAll(unwrappedParameterList);
+            }
+        }else if(isOperationRpcLiteral(styleAndUse)){
+            String operationName = info.bindingOperation.getName();
+            Block reqBlock = null;
+            if (inputMessage != null) {
+                QName name = new QName(getRequestNamespaceURI(soapRequestBody), operationName);
+                RpcLitStructure rpcStruct = new RpcLitStructure(name, getJAXBModelBuilder().getJAXBModel());
+                rpcStruct.setJavaType(new JavaSimpleType("com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload", null));
+                reqBlock = new Block(name, rpcStruct);
+                request.addBodyBlock(reqBlock);
+            }
+            inParameters = createRpcLitRequestParameters(request, parameterList, reqBlock);
+        }
+
+        // add response blocks, we dont need to create respnse parameters, just blocks will be fine, lets
+        // copy them from sync optraions
+        //copy the response blocks from the sync operation
+        Iterator<Block> blocks = info.operation.getResponse().getBodyBlocks();
+
+        while(blocks.hasNext()){
+            response.addBodyBlock(blocks.next());
+        }
+
+        blocks = info.operation.getResponse().getHeaderBlocks();
+        while(blocks.hasNext()){
+            response.addHeaderBlock(blocks.next());
+        }
+
+        blocks = info.operation.getResponse().getAttachmentBlocks();
+        while(blocks.hasNext()){
+            response.addAttachmentBlock(blocks.next());
+        }
+
+        List<MessagePart> outputParts = outputMessage.getParts();
+
+        // handle headers
+        int numOfOutMsgParts = outputParts.size();
+
+        if(isRequestResponse){
+            if(numOfOutMsgParts == 1){
+                MessagePart part = outputParts.get(0);
+                if(isOperationDocumentLiteral(styleAndUse)){
+                    JAXBType type = getJAXBType(part.getDescriptor());
+                    operation.setResponseBean(type);
+                }else if(isOperationRpcLiteral(styleAndUse)){
+                    String operationName = info.bindingOperation.getName();
+                    Block resBlock = null;
+                    if (isRequestResponse && outputMessage != null) {
+                        resBlock = info.operation.getResponse().getBodyBlocksMap().get(new QName(getResponseNamespaceURI(soapResponseBody),
+                                operationName + "Response"));
+                    }
+                    RpcLitStructure resBean = (resBlock == null) ? null : (RpcLitStructure)resBlock.getType();
+                    List<RpcLitMember> members = resBean.getRpcLitMembers();
+
+                    operation.setResponseBean(members.get(0));
+                }
+            }else{
+                //create response bean
+                String nspace = "";
+                QName responseBeanName = new QName(nspace,getAsyncOperationName(info.operation) +"Response");
+                JAXBType responseBeanType = getJAXBType(responseBeanName);
+                operation.setResponseBean(responseBeanType);
+            }
+        }
+        QName respBeanName = new QName(soapResponseBody.getNamespace(),getAsyncOperationName(info.operation)+"Response");
+        Block block = new Block(respBeanName, operation.getResponseBeanType());
+        JavaType respJavaType = operation.getResponseBeanJavaType();
+        JAXBType respType = new JAXBType(respBeanName, respJavaType);
+        Parameter respParam = ModelerUtils.createParameter(info.operation.getName()+"Response", respType, block);
+        respParam.setParameterIndex(-1);
+        response.addParameter(respParam);
+        operation.setProperty(WSDL_RESULT_PARAMETER, respParam.getName());
+
+
+        List<String> definitiveParameterList = new ArrayList<String>();
+        int parameterOrderPosition = 0;
+        for (String name: parameterList) {
+            Parameter inParameter = null;
+
+            inParameter = ModelerUtils.getParameter(name, inParameters);
+            if(inParameter == null){
+                if(extensions)
+                    warn("wsdlmodeler.warning.ignoringOperation.partNotFound", new Object[]{info.operation.getName().getLocalPart(), name});
+                else
+                    fail("wsdlmodeler.error.partNotFound", new Object[]{info.operation.getName().getLocalPart(), name});
+                return null;
+            }
+            request.addParameter(inParameter);
+            inParameter.setParameterIndex(parameterOrderPosition);
+            definitiveParameterList.add(name);
+            parameterOrderPosition++;
+        }
+
+        if (isRequestResponse) {
+            operation.setResponse(response);
+        }
+
+        //  add callback handlerb Parameter to request
+        if(operation.getAsyncType().equals(AsyncOperationType.CALLBACK)){
+            JavaType cbJavaType = operation.getCallBackType();
+            JAXBType callbackType = new JAXBType(respBeanName, cbJavaType);
+            Parameter cbParam = ModelerUtils.createParameter("asyncHandler", callbackType, block);
+            request.addParameter(cbParam);
+        }
+
+        operation.setRequest(request);
+
+        return operation;
+    }
+
+    protected boolean isAsync(com.sun.tools.internal.ws.wsdl.document.PortType portType, com.sun.tools.internal.ws.wsdl.document.Operation wsdlOperation){
+        //First look into wsdl:operation
+        JAXWSBinding jaxwsCustomization = (JAXWSBinding)getExtensionOfType(wsdlOperation, JAXWSBinding.class);
+        Boolean isAsync = (jaxwsCustomization != null)?jaxwsCustomization.isEnableAsyncMapping():null;
+
+        if(isAsync != null)
+            return isAsync;
+
+        // then into wsdl:portType
+        QName portTypeName = new QName(portType.getDefining().getTargetNamespaceURI(), portType.getName());
+        if(portTypeName != null){
+            jaxwsCustomization = (JAXWSBinding)getExtensionOfType(portType, JAXWSBinding.class);
+            isAsync = (jaxwsCustomization != null)?jaxwsCustomization.isEnableAsyncMapping():null;
+            if(isAsync != null)
+                return isAsync;
+        }
+
+        //then wsdl:definitions
+        jaxwsCustomization = (JAXWSBinding)getExtensionOfType(document.getDefinitions(), JAXWSBinding.class);
+        isAsync = (jaxwsCustomization != null)?jaxwsCustomization.isEnableAsyncMapping():null;
+        if(isAsync != null)
+            return isAsync;
+        return false;
+    }
+
+    protected void handleLiteralSOAPHeaders(Request request, Response response, Iterator headerParts, Set duplicateNames, List definitiveParameterList, boolean processRequest) {
+        QName headerName = null;
+        Block headerBlock = null;
+        JAXBType jaxbType = null;
+        int parameterOrderPosition = definitiveParameterList.size();
+        while(headerParts.hasNext()){
+            MessagePart part = (MessagePart)headerParts.next();
+            headerName = part.getDescriptor();
+            jaxbType = getJAXBType(headerName);
+            headerBlock = new Block(headerName, jaxbType);
+            Extensible ext;
+            if(processRequest){
+                ext = info.bindingOperation.getInput();
+            }else{
+                ext = info.bindingOperation.getOutput();
+            }
+            Message headerMessage = getHeaderMessage(part, ext);
+
+            if(processRequest){
+                request.addHeaderBlock(headerBlock);
+            }else{
+                response.addHeaderBlock(headerBlock);
+            }
+
+            Parameter parameter = ModelerUtils.createParameter(part.getName(), jaxbType, headerBlock);
+            parameter.setParameterIndex(parameterOrderPosition);
+            setCustomizedParameterName(info.bindingOperation, headerMessage, part, parameter, false);
+            if (processRequest && definitiveParameterList != null) {
+                request.addParameter(parameter);
+                definitiveParameterList.add(parameter.getName());
+            } else {
+                if (definitiveParameterList != null) {
+                    for (Iterator iterInParams = definitiveParameterList.iterator(); iterInParams.hasNext();) {
+                        String inParamName =
+                            (String)iterInParams.next();
+                        if (inParamName.equals(parameter.getName())) {
+                            Parameter inParam = request.getParameterByName(inParamName);
+                            parameter.setLinkedParameter(inParam);
+                            inParam.setLinkedParameter(parameter);
+                            //its in/out parameter, input and output parameter have the same order position.
+                            parameter.setParameterIndex(inParam.getParameterIndex());
+                        }
+                    }
+                    if (!definitiveParameterList.contains(parameter.getName())) {
+                        definitiveParameterList.add(parameter.getName());
+                    }
+                }
+                response.addParameter(parameter);
+            }
+            parameterOrderPosition++;
+        }
+
+    }
+
+    protected void handleLiteralSOAPFault(Response response, Set duplicateNames){
+        for (Iterator iter = info.bindingOperation.faults(); iter.hasNext();){
+            BindingFault bindingFault = (BindingFault)iter.next();
+            com.sun.tools.internal.ws.wsdl.document.Fault portTypeFault = null;
+            for(Iterator iter2 = info.portTypeOperation.faults(); iter2.hasNext();){
+                com.sun.tools.internal.ws.wsdl.document.Fault aFault =
+                    (com.sun.tools.internal.ws.wsdl.document.Fault)iter2.next();
+                if(aFault.getName().equals(bindingFault.getName())){
+                    if(portTypeFault != null){
+                        // the WSDL document is invalid, a wsld:fault in a wsdl:operation of a portType can be bound only once
+                        throw new ModelerException("wsdlmodeler.invalid.bindingFault.notUnique",
+                                new Object[]{bindingFault.getName(), info.bindingOperation.getName()});
+                    }
+                    portTypeFault = aFault;
+                }
+            }
+
+            // The WSDL document is invalid, the wsdl:fault in abstract operation is does not have any binding
+            if(portTypeFault == null){
+                throw new ModelerException("wsdlmodeler.invalid.bindingFault.notFound",
+                        new Object[] {bindingFault.getName(), info.bindingOperation.getName()});
+
+            }
+
+            // wsdl:fault message name is used to create the java exception name later on
+            String faultName = getFaultClassName(portTypeFault);
+            Fault fault = new Fault(faultName);
+            setDocumentationIfPresent(fault, portTypeFault.getDocumentation());
+
+            //get the soapbind:fault from wsdl:fault in the binding
+            SOAPFault soapFault = (SOAPFault)getExtensionOfType(bindingFault, SOAPFault.class);
+
+            // The WSDL document is invalid, can't have wsdl:fault without soapbind:fault
+            if(soapFault == null){
+                throw new ModelerException("wsdlmodeler.invalid.bindingFault.outputMissingSoapFault",
+                    new Object[]{bindingFault.getName(), info.bindingOperation.getName()});
+            }
+
+            //the soapbind:fault must have use="literal" or no use attribute, in that case its assumed "literal"
+            if(!soapFault.isLiteral()){
+                if(extensions)
+                warn("wsdlmodeler.warning.ignoringFault.notLiteral",
+                    new Object[]{bindingFault.getName(), info.bindingOperation.getName()});
+                else
+                    fail("wsdlmodeler.invalid.operation.fault.notLiteral",
+                            new Object[]{bindingFault.getName(), info.bindingOperation.getName()});
+                continue;
+            }
+
+            // the soapFault name must be present
+            if(soapFault.getName() == null){
+                warn("wsdlmodeler.invalid.bindingFault.noSoapFaultName",
+                    new Object[]{bindingFault.getName(), info.bindingOperation.getName()});
+            }else if (!soapFault.getName().equals(bindingFault.getName())) {
+                // the soapFault name must match bindingFault name
+                warn("wsdlmodeler.invalid.bindingFault.wrongSoapFaultName",
+                    new Object[]{soapFault.getName(), bindingFault.getName(), info.bindingOperation.getName()});
+            }else if(soapFault.getNamespace() != null){
+                // bug fix: 4852729
+                warn("wsdlmodeler.warning.r2716r2726",
+                    new Object[] { "soapbind:fault", soapFault.getName()});
+            }
+
+            String faultNamespaceURI = soapFault.getNamespace();
+            if(faultNamespaceURI == null){
+                faultNamespaceURI = portTypeFault.getMessage().getNamespaceURI();
+            }
+
+            com.sun.tools.internal.ws.wsdl.document.Message faultMessage = portTypeFault.resolveMessage(info.document);
+            Iterator iter2 = faultMessage.parts();
+            if(!iter2.hasNext()){
+                // the WSDL document is invalid
+                throw new ModelerException("wsdlmodeler.invalid.bindingFault.emptyMessage",
+                    new Object[]{bindingFault.getName(), faultMessage.getName()});
+            }
+            MessagePart faultPart = (MessagePart)iter2.next();
+            QName faultQName = faultPart.getDescriptor();
+
+            // Don't include fault messages with non-unique soap:fault names
+            if (duplicateNames.contains(faultQName)) {
+                warn("wsdlmodeler.duplicate.fault.soap.name",
+                    new Object[] {bindingFault.getName(), info.portTypeOperation.getName(), faultPart.getName()});
+                continue;
+            }
+
+            if (iter2.hasNext()) {
+                // the WSDL document is invalid
+                throw new ModelerException("wsdlmodeler.invalid.bindingFault.messageHasMoreThanOnePart",
+                    new Object[]{bindingFault.getName(), faultMessage.getName()});
+            }
+
+            if (faultPart.getDescriptorKind() != SchemaKinds.XSD_ELEMENT) {
+                throw new ModelerException("wsdlmodeler.invalid.message.partMustHaveElementDescriptor",
+                    new Object[]{faultMessage.getName(), faultPart.getName()});
+            }
+
+            JAXBType jaxbType = getJAXBType(faultPart.getDescriptor());
+
+            fault.setElementName(faultPart.getDescriptor());
+            fault.setJavaMemberName(getEnvironment().getNames().getExceptionClassMemberName());
+
+            Block faultBlock = new Block(faultQName, jaxbType);
+            fault.setBlock(faultBlock);
+            createParentFault(fault);
+            createSubfaults(fault);
+            if(!response.getFaultBlocksMap().containsKey(faultBlock.getName()))
+                response.addFaultBlock(faultBlock);
+            info.operation.addFault(fault);
+        }
+    }
+
+    /**
+     * @param portTypeFault
+     * @return
+     */
+    private String getFaultClassName(com.sun.tools.internal.ws.wsdl.document.Fault portTypeFault) {
+        JAXWSBinding jaxwsBinding = (JAXWSBinding)getExtensionOfType(portTypeFault, JAXWSBinding.class);
+        if(jaxwsBinding != null){
+            CustomName className = jaxwsBinding.getClassName();
+            if(className != null){
+                return className.getName();
+            }
+        }
+        return portTypeFault.getMessage().getLocalPart();
+    }
+
+    protected  boolean setMessagePartsBinding(StyleAndUse styleAndUse){
+        SOAPBody inBody = getSOAPRequestBody();
+        Message inMessage = getInputMessage();
+        if(!setMessagePartsBinding(inBody, inMessage, styleAndUse, true))
+            return false;
+
+        if(isRequestResponse()){
+            SOAPBody outBody = getSOAPResponseBody();
+            Message outMessage = getOutputMessage();
+            if(!setMessagePartsBinding(outBody, outMessage, styleAndUse, false))
+                return false;
+        }
+        return true;
+    }
+
+    //returns false if the wsdl is invalid and operation should be ignored
+    protected boolean setMessagePartsBinding(SOAPBody body, Message message, StyleAndUse styleAndUse, boolean isInput) {
+        List<MessagePart> parts = new ArrayList<MessagePart>();
+
+        //get Mime parts
+        List<MessagePart> mimeParts = null;
+        List<MessagePart> headerParts = null;
+        List<MessagePart> bodyParts = getBodyParts(body, message);
+
+        if(isInput){
+            headerParts = getHeaderPartsFromMessage(message, isInput);
+            mimeParts = getMimeContentParts(message, info.bindingOperation.getInput());
+        }else{
+            headerParts = getHeaderPartsFromMessage(message, isInput);
+            mimeParts = getMimeContentParts(message, info.bindingOperation.getOutput());
+        }
+
+        //As of now WSDL MIME binding is not supported, so throw the exception when such binding is encounterd
+//        if(mimeParts.size() > 0){
+//            fail("wsdlmodeler.unsupportedBinding.mime", new Object[]{});
+//        }
+
+        //if soap:body parts attribute not there, then all unbounded message parts will
+        // belong to the soap body
+        if(bodyParts == null){
+            bodyParts = new ArrayList<MessagePart>();
+            for(Iterator<MessagePart> iter = message.parts();iter.hasNext();) {
+                MessagePart mPart = iter.next();
+                //Its a safe assumption that the parts in the message not belonging to header or mime will
+                // belong to the body?
+                if(mimeParts.contains(mPart) || headerParts.contains(mPart) || boundToFault(mPart.getName())){
+                    //throw error that a part cant be bound multiple times, not ignoring operation, if there
+                    //is conflict it will fail latter
+                    if(extensions)
+                        warn("wsdlmodeler.warning.bindingOperation.multiplePartBinding",
+                                new Object[]{info.bindingOperation.getName(), mPart.getName()});
+                    else
+                        fail("wsdlmodeler.invalid.bindingOperation.multiplePartBinding",
+                                new Object[]{info.bindingOperation.getName(), mPart.getName()});
+                }
+                bodyParts.add(mPart);
+            }
+        }
+
+        //now build the final parts list with header, mime parts and body parts
+        for(Iterator iter = message.parts();iter.hasNext();) {
+            MessagePart mPart = (MessagePart)iter.next();
+            if(mimeParts.contains(mPart)) {
+                mPart.setBindingExtensibilityElementKind(MessagePart.WSDL_MIME_BINDING);
+                parts.add(mPart);
+            }else if(headerParts.contains(mPart)) {
+                mPart.setBindingExtensibilityElementKind(MessagePart.SOAP_HEADER_BINDING);
+                parts.add(mPart);
+            }else if(bodyParts.contains(mPart)) {
+                mPart.setBindingExtensibilityElementKind(MessagePart.SOAP_BODY_BINDING);
+                parts.add(mPart);
+            }else{
+                mPart.setBindingExtensibilityElementKind(MessagePart.PART_NOT_BOUNDED);
+            }
+        }
+
+        if(isOperationDocumentLiteral(styleAndUse) && bodyParts.size() > 1){
+            if(extensions)
+                warn("wsdlmodeler.warning.operation.MoreThanOnePartInMessage",
+                            info.portTypeOperation.getName());
+            else
+                fail("wsdlmodeler.invalid.operation.MoreThanOnePartInMessage", info.portTypeOperation.getName());
+            return false;
+        }
+        return true;
+    }
+
+    private boolean boundToFault(String partName){
+        for (Iterator iter = info.bindingOperation.faults(); iter.hasNext();){
+            BindingFault bindingFault = (BindingFault)iter.next();
+            if(partName.equals(bindingFault.getName()))
+                return true;
+        }
+        return false;
+    }
+
+    //get MessagePart(s) referenced by parts attribute of soap:body element
+    private List<MessagePart> getBodyParts(SOAPBody body, Message message){
+        String bodyParts = body.getParts();
+        if (bodyParts != null) {
+            List<MessagePart> partsList = new ArrayList<MessagePart>();
+            StringTokenizer in = new StringTokenizer(bodyParts.trim(), " ");
+            while (in.hasMoreTokens()) {
+                String part = in.nextToken();
+                MessagePart mPart = message.getPart(part);
+                if (null == mPart) {
+                    throw new ModelerException(
+                        "wsdlmodeler.error.partsNotFound",
+                        new Object[] { part, message.getName()});
+                }
+                mPart.setBindingExtensibilityElementKind(MessagePart.SOAP_BODY_BINDING);
+                partsList.add(mPart);
+            }
+            return partsList;
+        }
+        return null;
+    }
+
+    private List<MessagePart> getHeaderPartsFromMessage(Message message, boolean isInput){
+        List<MessagePart> headerParts = new ArrayList<MessagePart>();
+        Iterator<MessagePart> parts = message.parts();
+        List<MessagePart> headers = getHeaderParts(isInput);
+        while(parts.hasNext()){
+            MessagePart part = parts.next();
+            if(headers.contains(part)){
+                headerParts.add(part);
+            }
+        }
+        return headerParts;
+    }
+
+    private Message getHeaderMessage(MessagePart part, Extensible ext) {
+        Iterator<SOAPHeader> headers =  getHeaderExtensions(ext).iterator();
+        while(headers.hasNext()){
+            SOAPHeader header = headers.next();
+            if (!header.isLiteral())
+                continue;
+            com.sun.tools.internal.ws.wsdl.document.Message headerMessage = findMessage(header.getMessage(), info);
+            if (headerMessage == null)
+                continue;
+
+            MessagePart headerPart = headerMessage.getPart(header.getPart());
+            if(headerPart == part)
+                return headerMessage;
+        }
+        return null;
+    }
+
+    private List<MessagePart> getHeaderPartsNotFromMessage(Message message, boolean isInput){
+        List<MessagePart> headerParts = new ArrayList<MessagePart>();
+        List<MessagePart> parts = message.getParts();
+        Iterator<MessagePart> headers = getHeaderParts(isInput).iterator();
+        while(headers.hasNext()){
+            MessagePart part = headers.next();
+            if(!parts.contains(part)){
+                headerParts.add(part);
+            }
+        }
+        return headerParts;
+    }
+
+    private List<MessagePart> getHeaderParts(boolean isInput) {
+        Extensible ext;
+        if(isInput){
+            ext = info.bindingOperation.getInput();
+        }else{
+            ext = info.bindingOperation.getOutput();
+        }
+
+        List<MessagePart> parts = new ArrayList<MessagePart>();
+        Iterator<SOAPHeader> headers =  getHeaderExtensions(ext).iterator();
+        while(headers.hasNext()){
+            SOAPHeader header = headers.next();
+            if (!header.isLiteral()){
+                fail("wsdlmodeler.invalid.header.notLiteral",
+                        new Object[] {header.getPart(), info.bindingOperation.getName()});
+            }
+
+            if (header.getNamespace() != null){
+                warn("wsdlmodeler.warning.r2716r2726",
+                        new Object[]{"soapbind:header", info.bindingOperation.getName()});
+            }
+            com.sun.tools.internal.ws.wsdl.document.Message headerMessage = findMessage(header.getMessage(), info);
+            if (headerMessage == null){
+                fail("wsdlmodeler.invalid.header.cant.resolve.message",
+                        new Object[]{header.getMessage(), info.bindingOperation.getName()});
+            }
+
+            MessagePart part = headerMessage.getPart(header.getPart());
+            if (part == null){
+                fail("wsdlmodeler.invalid.header.notFound",
+                        new Object[]{header.getPart(), info.bindingOperation.getName()});
+            }
+            if (part.getDescriptorKind() != SchemaKinds.XSD_ELEMENT) {
+                fail("wsdlmodeler.invalid.header.message.partMustHaveElementDescriptor",
+                        new Object[]{part.getName(), info.bindingOperation.getName()});
+            }
+            part.setBindingExtensibilityElementKind(MessagePart.SOAP_HEADER_BINDING);
+            parts.add(part);
+        }
+        return parts;
+    }
+
+    private boolean isOperationDocumentLiteral(StyleAndUse styleAndUse){
+        return StyleAndUse.DOC_LITERAL == styleAndUse;
+    }
+
+    private boolean isOperationRpcLiteral(StyleAndUse styleAndUse){
+        return StyleAndUse.RPC_LITERAL == styleAndUse;
+    }
+
+    /**
+     * @param part
+     * @return Returns a JAXBType object
+     */
+    private JAXBType getJAXBType(MessagePart part){
+        JAXBType type=null;
+        QName name = part.getDescriptor();
+        if(part.getDescriptorKind().equals(SchemaKinds.XSD_ELEMENT)){
+            type = getJAXBType(name);
+        }else {
+            S2JJAXBModel jaxbModel = getJAXBModelBuilder().getJAXBModel().getS2JJAXBModel();
+            TypeAndAnnotation typeAnno = jaxbModel.getJavaType(name);
+            if(typeAnno == null){
+                fail("wsdlmodeler.jaxb.javatype.notfound", new Object[]{name, part.getName()});
+            }
+            JavaType javaType = new  JavaSimpleType(new JAXBTypeAndAnnotation(typeAnno));
+            type = new JAXBType(new QName("", part.getName()), javaType);
+        }
+        return type;
+    }
+
+    private List<Parameter> getDoclitParameters(Request req, Response res, List<MessagePart> parameterList){
+        if(parameterList.size() == 0)
+            return new ArrayList<Parameter>();
+        List<Parameter> params = null;
+        Message inMsg = getInputMessage();
+        Message outMsg = getOutputMessage();
+        boolean unwrappable = isUnwrappable();
+        List<Parameter> outParams = null;
+        int pIndex = 0;
+        for(MessagePart part:parameterList){
+            QName reqBodyName = part.getDescriptor();
+            JAXBType jaxbType = getJAXBType(part);
+            Block block = new Block(reqBodyName, jaxbType);
+            if(unwrappable){
+                //So build body and header blocks and set to request and response
+                JAXBStructuredType jaxbStructType = ModelerUtils.createJAXBStructureType(jaxbType);
+                block = new Block(reqBodyName, jaxbStructType);
+                if(ModelerUtils.isBoundToSOAPBody(part)){
+                    if(part.isIN()){
+                        req.addBodyBlock(block);
+                    }else if(part.isOUT()){
+                        res.addBodyBlock(block);
+                    }else if(part.isINOUT()){
+                        req.addBodyBlock(block);
+                        res.addBodyBlock(block);
+                    }
+                }else if(ModelerUtils.isUnbound(part)){
+                    if(part.isIN())
+                        req.addUnboundBlock(block);
+                    else if(part.isOUT())
+                        res.addUnboundBlock(block);
+                    else if(part.isINOUT()){
+                        req.addUnboundBlock(block);
+                        res.addUnboundBlock(block);
+                    }
+
+                }
+                if(part.isIN() || part.isINOUT()){
+                    params = ModelerUtils.createUnwrappedParameters(jaxbStructType, block);
+                    int index = 0;
+                    Mode mode = (part.isINOUT())?Mode.INOUT:Mode.IN;
+                    for(Parameter param: params){
+                        param.setParameterIndex(index++);
+                        param.setMode(mode);
+                        setCustomizedParameterName(info.portTypeOperation, inMsg, part, param, unwrappable);
+                    }
+                }else if(part.isOUT()){
+                    outParams = ModelerUtils.createUnwrappedParameters(jaxbStructType, block);
+                    for(Parameter param: outParams){
+                        param.setMode(Mode.OUT);
+                        setCustomizedParameterName(info.portTypeOperation, outMsg, part, param, unwrappable);
+                    }
+                }
+            }else{
+                if(ModelerUtils.isBoundToSOAPBody(part)){
+                    if(part.isIN()){
+                        req.addBodyBlock(block);
+                    }else if(part.isOUT()){
+                        res.addBodyBlock(block);
+                    }else if(part.isINOUT()){
+                        req.addBodyBlock(block);
+                        res.addBodyBlock(block);
+                    }
+                }else if(ModelerUtils.isBoundToSOAPHeader(part)){
+                    if(part.isIN()){
+                        req.addHeaderBlock(block);
+                    }else if(part.isOUT()){
+                        res.addHeaderBlock(block);
+                    }else if(part.isINOUT()){
+                        req.addHeaderBlock(block);
+                        res.addHeaderBlock(block);
+                    }
+                }else if(ModelerUtils.isBoundToMimeContent(part)){
+                    List<MIMEContent> mimeContents = null;
+
+                    if(part.isIN()){
+                        mimeContents = getMimeContents(info.bindingOperation.getInput(),
+                                        getInputMessage(), part.getName());
+                        jaxbType = getAttachmentType(mimeContents, part);
+                        block = new Block(jaxbType.getName(), jaxbType);
+                        req.addAttachmentBlock(block);
+                    }else if(part.isOUT()){
+                        mimeContents = getMimeContents(info.bindingOperation.getOutput(),
+                                        getOutputMessage(), part.getName());
+                        jaxbType = getAttachmentType(mimeContents, part);
+                        block = new Block(jaxbType.getName(), jaxbType);
+                        res.addAttachmentBlock(block);
+                    }else if(part.isINOUT()){
+                        mimeContents = getMimeContents(info.bindingOperation.getInput(),
+                                        getInputMessage(), part.getName());
+                        jaxbType = getAttachmentType(mimeContents, part);
+                        block = new Block(jaxbType.getName(), jaxbType);
+                        req.addAttachmentBlock(block);
+                        res.addAttachmentBlock(block);
+
+                        mimeContents = getMimeContents(info.bindingOperation.getOutput(),
+                                        getOutputMessage(), part.getName());
+                        JAXBType outJaxbType = getAttachmentType(mimeContents, part);
+
+                        String inType = jaxbType.getJavaType().getType().getName();
+                        String outType = outJaxbType.getJavaType().getType().getName();
+
+                        TypeAndAnnotation inTa = jaxbType.getJavaType().getType().getTypeAnn();
+                        TypeAndAnnotation outTa = outJaxbType.getJavaType().getType().getTypeAnn();
+                        if((((inTa != null) && (outTa != null) && inTa.equals(outTa))) && !inType.equals(outType)){
+                            String javaType = "javax.activation.DataHandler";
+
+                            S2JJAXBModel jaxbModel = getJAXBModelBuilder().getJAXBModel().getS2JJAXBModel();
+                            JCodeModel cm = jaxbModel.generateCode(null,
+                                        new ConsoleErrorReporter(getEnvironment(), false));
+                            JType jt= null;
+                            jt = cm.ref(javaType);
+                            JAXBTypeAndAnnotation jaxbTa = jaxbType.getJavaType().getType();
+                            jaxbTa.setType(jt);
+                        }
+                    }
+                }else if(ModelerUtils.isUnbound(part)){
+                    if(part.isIN()){
+                        req.addUnboundBlock(block);
+                    }else if(part.isOUT()){
+                        res.addUnboundBlock(block);
+                    }else if(part.isINOUT()){
+                        req.addUnboundBlock(block);
+                        res.addUnboundBlock(block);
+                    }
+                }
+                if(params == null)
+                    params = new ArrayList<Parameter>();
+                Parameter param = ModelerUtils.createParameter(part.getName(), jaxbType, block);
+                param.setMode(part.getMode());
+                if(part.isReturn()){
+                    param.setParameterIndex(-1);
+                }else{
+                    param.setParameterIndex(pIndex++);
+                }
+
+                if(part.isIN())
+                    setCustomizedParameterName(info.portTypeOperation, inMsg, part, param, false);
+                else if(outMsg != null)
+                    setCustomizedParameterName(info.portTypeOperation, outMsg, part, param, false);
+
+                params.add(param);
+            }
+        }
+        if(unwrappable && (outParams != null)){
+            int index = params.size();
+            for(Parameter param:outParams){
+                if(param.getName().equals("return")){
+                    param.setParameterIndex(-1);
+                }else{
+                    Parameter inParam = ModelerUtils.getParameter(param.getName(), params);
+                    if((inParam != null) && inParam.isIN()){
+                        QName inElementName = ((JAXBType)inParam.getType()).getName();
+                        QName outElementName = ((JAXBType)param.getType()).getName();
+                        String inJavaType = inParam.getTypeName();
+                        String outJavaType = param.getTypeName();
+                        TypeAndAnnotation inTa = inParam.getType().getJavaType().getType().getTypeAnn();
+                        TypeAndAnnotation outTa = param.getType().getJavaType().getType().getTypeAnn();
+                        if(inElementName.getLocalPart().equals(outElementName.getLocalPart()) &&
+                                inJavaType.equals(outJavaType) &&
+                                ((inTa == null || outTa == null)||
+                                ((inTa != null) && (outTa != null) && inTa.equals(outTa)))) {
+                            inParam.setMode(Mode.INOUT);
+                            continue;
+                        }
+                    }else if(outParams.size() == 1){
+                        param.setParameterIndex(-1);
+                    }else{
+                        param.setParameterIndex(index++);
+                    }
+                }
+                params.add(param);
+            }
+        }
+        return params;
+    }
+
+    private List<Parameter> getRpcLitParameters(Request req, Response res, Block reqBlock, Block resBlock, List<MessagePart> paramList){
+        List<Parameter> params = new ArrayList<Parameter>();
+        Message inMsg = getInputMessage();
+        Message outMsg = getOutputMessage();
+        S2JJAXBModel jaxbModel = ((RpcLitStructure)reqBlock.getType()).getJaxbModel().getS2JJAXBModel();
+        List<Parameter> inParams = ModelerUtils.createRpcLitParameters(inMsg, reqBlock, jaxbModel);
+        List<Parameter> outParams = null;
+        if(outMsg != null)
+            outParams = ModelerUtils.createRpcLitParameters(outMsg, resBlock, jaxbModel);
+
+        //create parameters for header and mime parts
+        int index = 0;
+        for(MessagePart part: paramList){
+             Parameter param = null;
+            if(ModelerUtils.isBoundToSOAPBody(part)){
+                if(part.isIN()){
+                    param = ModelerUtils.getParameter(part.getName(), inParams);
+                }else if(outParams != null){
+                    param = ModelerUtils.getParameter(part.getName(), outParams);
+                }
+            }else if(ModelerUtils.isBoundToSOAPHeader(part)){
+                QName headerName = part.getDescriptor();
+                JAXBType jaxbType = getJAXBType(headerName);
+                Block headerBlock = new Block(headerName, jaxbType);
+                param = ModelerUtils.createParameter(part.getName(), jaxbType, headerBlock);
+                if(part.isIN()){
+                    req.addHeaderBlock(headerBlock);
+                }else if(part.isOUT()){
+                    res.addHeaderBlock(headerBlock);
+                }else if(part.isINOUT()){
+                    req.addHeaderBlock(headerBlock);
+                    res.addHeaderBlock(headerBlock);
+                }
+            }else if(ModelerUtils.isBoundToMimeContent(part)){
+                List<MIMEContent> mimeContents = null;
+                if(part.isIN() || part.isINOUT())
+                    mimeContents = getMimeContents(info.bindingOperation.getInput(),
+                            getInputMessage(), part.getName());
+                else
+                    mimeContents = getMimeContents(info.bindingOperation.getOutput(),
+                            getOutputMessage(), part.getName());
+
+                JAXBType type = getAttachmentType(mimeContents, part);
+                //create Parameters in request or response
+                //Block mimeBlock = new Block(new QName(part.getName()), type);
+                Block mimeBlock = new Block(type.getName(), type);
+                param = ModelerUtils.createParameter(part.getName(), type, mimeBlock);
+                if(part.isIN()){
+                    req.addAttachmentBlock(mimeBlock);
+                }else if(part.isOUT()){
+                    res.addAttachmentBlock(mimeBlock);
+                }else if(part.isINOUT()){
+                    mimeContents = getMimeContents(info.bindingOperation.getOutput(),
+                                    getOutputMessage(), part.getName());
+                    JAXBType outJaxbType = getAttachmentType(mimeContents, part);
+
+                    String inType = type.getJavaType().getType().getName();
+                    String outType = outJaxbType.getJavaType().getType().getName();
+                    if(!inType.equals(outType)){
+                        String javaType = "javax.activation.DataHandler";
+                        JCodeModel cm = jaxbModel.generateCode(null,
+                                    new ConsoleErrorReporter(getEnvironment(), false));
+                        JType jt= null;
+                        jt = cm.ref(javaType);
+                        JAXBTypeAndAnnotation jaxbTa = type.getJavaType().getType();
+                        jaxbTa.setType(jt);
+                    }
+                    req.addAttachmentBlock(mimeBlock);
+                    res.addAttachmentBlock(mimeBlock);
+                }
+            }else if(ModelerUtils.isUnbound(part)){
+                QName name = part.getDescriptor();
+                JAXBType type = getJAXBType(part);
+                Block unboundBlock = new Block(name, type);
+                if(part.isIN()){
+                    req.addUnboundBlock(unboundBlock);
+                }else if(part.isOUT()){
+                    res.addUnboundBlock(unboundBlock);
+                }else if(part.isINOUT()){
+                    req.addUnboundBlock(unboundBlock);
+                    res.addUnboundBlock(unboundBlock);
+                }
+                param = ModelerUtils.createParameter(part.getName(), type, unboundBlock);
+            }
+            if(param != null){
+                if(part.isReturn()){
+                    param.setParameterIndex(-1);
+                }else{
+                    param.setParameterIndex(index++);
+                }
+                param.setMode(part.getMode());
+                params.add(param);
+            }
+        }
+        for(Parameter param : params){
+            if(param.isIN())
+                setCustomizedParameterName(info.portTypeOperation, inMsg, inMsg.getPart(param.getName()), param, false);
+            else if(outMsg != null)
+                setCustomizedParameterName(info.portTypeOperation, outMsg, outMsg.getPart(param.getName()), param, false);
+        }
+        return params;
+    }
+
+    private List<Parameter> getRequestParameters(Request request, List<String> parameterList) {
+        Message inputMessage = getInputMessage();
+        //there is no input message, return zero parameters
+        if(inputMessage != null && !inputMessage.parts().hasNext())
+            return new ArrayList<Parameter>();
+
+        List<Parameter> inParameters = null;
+        QName reqBodyName = null;
+        Block reqBlock = null;
+        JAXBType jaxbReqType = null;
+        boolean unwrappable = isUnwrappable();
+        boolean doneSOAPBody = false;
+        //setup request parameters
+        for(String inParamName: parameterList){
+            MessagePart part = inputMessage.getPart(inParamName);
+            if(part == null)
+                continue;
+            reqBodyName = part.getDescriptor();
+            jaxbReqType = getJAXBType(part);
+            if(unwrappable){
+                //So build body and header blocks and set to request and response
+                JAXBStructuredType jaxbRequestType = ModelerUtils.createJAXBStructureType(jaxbReqType);
+                reqBlock = new Block(reqBodyName, jaxbRequestType);
+                if(ModelerUtils.isBoundToSOAPBody(part)){
+                    request.addBodyBlock(reqBlock);
+                }else if(ModelerUtils.isUnbound(part)){
+                    request.addUnboundBlock(reqBlock);
+                }
+                inParameters = ModelerUtils.createUnwrappedParameters(jaxbRequestType, reqBlock);
+                for(Parameter param: inParameters){
+                    setCustomizedParameterName(info.portTypeOperation, inputMessage, part, param, unwrappable);
+                }
+            }else{
+                reqBlock = new Block(reqBodyName, jaxbReqType);
+                if(ModelerUtils.isBoundToSOAPBody(part) && !doneSOAPBody){
+                    doneSOAPBody = true;
+                    request.addBodyBlock(reqBlock);
+                }else if(ModelerUtils.isBoundToSOAPHeader(part)){
+                    request.addHeaderBlock(reqBlock);
+                }else if(ModelerUtils.isBoundToMimeContent(part)){
+                    List<MIMEContent> mimeContents = getMimeContents(info.bindingOperation.getInput(),
+                        getInputMessage(), part.getName());
+                    jaxbReqType = getAttachmentType(mimeContents, part);
+                    //reqBlock = new Block(new QName(part.getName()), jaxbReqType);
+                    reqBlock = new Block(jaxbReqType.getName(), jaxbReqType);
+                    request.addAttachmentBlock(reqBlock);
+                }else if(ModelerUtils.isUnbound(part)){
+                    request.addUnboundBlock(reqBlock);
+                }
+                if(inParameters == null)
+                    inParameters = new ArrayList<Parameter>();
+                Parameter param = ModelerUtils.createParameter(part.getName(), jaxbReqType, reqBlock);
+                setCustomizedParameterName(info.portTypeOperation, inputMessage, part, param, false);
+                inParameters.add(param);
+            }
+        }
+        return inParameters;
+    }
+
+    /**
+     * @param part
+     * @param param
+     * @param wrapperStyle TODO
+     */
+    private void setCustomizedParameterName(Extensible extension, Message msg, MessagePart part, Parameter param, boolean wrapperStyle) {
+        JAXWSBinding jaxwsBinding = (JAXWSBinding)getExtensionOfType(extension, JAXWSBinding.class);
+        if(jaxwsBinding == null)
+            return;
+        String paramName = part.getName();
+        QName elementName = part.getDescriptor();
+        if(wrapperStyle)
+            elementName = param.getType().getName();
+        String customName = jaxwsBinding.getParameterName(msg.getName(), paramName, elementName, wrapperStyle);
+        if(customName != null && !customName.equals("")){
+            param.setCustomName(customName);
+        }
+    }
+
+    /**
+     * @param name
+     * @return
+     */
+    private JAXBType getJAXBType(QName name) {
+        return jaxbModelBuilder.getJAXBType(name);
+    }
+
+    protected boolean isConflictingPortClassName(String name) {
+        return false;
+    }
+
+    /* (non-Javadoc)
+     * @see WSDLModelerBase#getJAXBSchemaAnalyzerInstnace(WSDLModelInfo, Properties, org.w3c.dom.Element)
+     */
+    protected JAXBModelBuilder getJAXBSchemaAnalyzerInstnace(WSDLModelInfo info,
+                                                             Properties options,
+                                                             ClassNameCollector classNameCollector, List elements) {
+        return new JAXBModelBuilder(info, options, classNameCollector, elements);
+    }
+
+    /* (non-Javadoc)
+     * @see WSDLModelerBase#isUnwrappable()
+     */
+    protected boolean isUnwrappable() {
+        if(!getWrapperStyleCustomization())
+            return false;
+
+        com.sun.tools.internal.ws.wsdl.document.Message inputMessage = getInputMessage();
+        com.sun.tools.internal.ws.wsdl.document.Message outputMessage = getOutputMessage();
+
+        // Wrapper style if the operation's input and output messages each contain
+        // only a single part
+        if ((inputMessage != null && inputMessage.numParts() != 1)
+            || (outputMessage != null && outputMessage.numParts() != 1)) {
+            return false;
+        }
+
+        MessagePart inputPart = inputMessage != null
+                ? (MessagePart)inputMessage.parts().next() : null;
+        MessagePart outputPart = outputMessage != null
+                ? (MessagePart)outputMessage.parts().next() : null;
+        String operationName = info.portTypeOperation.getName();
+
+        // Wrapper style if the input message part refers to a global element declaration whose localname
+        // is equal to the operation name
+        // Wrapper style if the output message part refers to a global element declaration
+        if ((inputPart != null && !inputPart.getDescriptor().getLocalPart().equals(operationName)) ||
+            (outputPart != null && outputPart.getDescriptorKind() != SchemaKinds.XSD_ELEMENT))
+            return false;
+
+        //check to see if either input or output message part not bound to soapbing:body
+        //in that case the operation is not wrapper style
+        if(((inputPart != null) && (inputPart.getBindingExtensibilityElementKind() != MessagePart.SOAP_BODY_BINDING)) ||
+                ((outputPart != null) &&(outputPart.getBindingExtensibilityElementKind() != MessagePart.SOAP_BODY_BINDING)))
+            return false;
+
+        // Wrapper style if the elements referred to by the input and output message parts
+        // (henceforth referred to as wrapper elements) are both complex types defined
+        // using the xsd:sequence compositor
+        // Wrapper style if the wrapper elements only contain child elements, they must not
+        // contain other structures such as xsd:choice, substitution groups1 or attributes
+        //These checkins are done by jaxb, we just check if jaxb has wrapper children. If there
+        // are then its wrapper style
+        //if(inputPart != null && outputPart != null){
+        if(inputPart != null){
+            boolean inputWrappable = false;
+            JAXBType inputType = getJAXBType(inputPart.getDescriptor());
+            if(inputType != null){
+                inputWrappable = inputType.isUnwrappable();
+            }
+            //if there are no output part (oneway), the operation can still be wrapper style
+            if(outputPart == null){
+               return inputWrappable;
+            }
+            JAXBType outputType = getJAXBType(outputPart.getDescriptor());
+            if((inputType != null) && (outputType != null))
+                return inputType.isUnwrappable() && outputType.isUnwrappable();
+        }
+
+        return false;
+    }
+
+    /**
+     * @return
+     */
+    private boolean getWrapperStyleCustomization() {
+        //first we look into wsdl:portType/wsdl:operation
+        com.sun.tools.internal.ws.wsdl.document.Operation portTypeOperation = info.portTypeOperation;
+        JAXWSBinding jaxwsBinding = (JAXWSBinding)getExtensionOfType(portTypeOperation, JAXWSBinding.class);
+        if(jaxwsBinding != null){
+             Boolean isWrappable = jaxwsBinding.isEnableWrapperStyle();
+             if(isWrappable != null)
+                 return isWrappable;
+        }
+
+        //then into wsdl:portType
+        PortType portType = info.port.resolveBinding(document).resolvePortType(document);
+        jaxwsBinding = (JAXWSBinding)getExtensionOfType(portType, JAXWSBinding.class);
+        if(jaxwsBinding != null){
+             Boolean isWrappable = jaxwsBinding.isEnableWrapperStyle();
+             if(isWrappable != null)
+                 return isWrappable;
+        }
+
+        //then wsdl:definitions
+        jaxwsBinding = (JAXWSBinding)getExtensionOfType(document.getDefinitions(), JAXWSBinding.class);
+        if(jaxwsBinding != null){
+             Boolean isWrappable = jaxwsBinding.isEnableWrapperStyle();
+             if(isWrappable != null)
+                 return isWrappable;
+        }
+        return true;
+    }
+
+    /* (non-Javadoc)
+     * @see WSDLModelerBase#isSingleInOutPart(Set, MessagePart)
+     */
+    protected boolean isSingleInOutPart(Set inputParameterNames,
+            MessagePart outputPart) {
+        // As of now, we dont have support for in/out in doc-lit. So return false.
+        SOAPOperation soapOperation =
+            (SOAPOperation) getExtensionOfType(info.bindingOperation,
+                    SOAPOperation.class);
+        if((soapOperation != null) && (soapOperation.isDocument() || info.soapBinding.isDocument())) {
+            Iterator iter = getInputMessage().parts();
+            while(iter.hasNext()){
+                MessagePart part = (MessagePart)iter.next();
+                if(outputPart.getName().equals(part.getName()) && outputPart.getDescriptor().equals(part.getDescriptor()))
+                    return true;
+            }
+        }else if(soapOperation != null && soapOperation.isRPC()|| info.soapBinding.isRPC()){
+            com.sun.tools.internal.ws.wsdl.document.Message inputMessage = getInputMessage();
+            if(inputParameterNames.contains(outputPart.getName())) {
+                if (inputMessage.getPart(outputPart.getName()).getDescriptor().equals(outputPart.getDescriptor())) {
+                    return true;
+                }
+            }
+        }
+        return false;
+    }
+
+    private List<Parameter> createRpcLitRequestParameters(Request request, List<String> parameterList, Block block) {
+        Message message = getInputMessage();
+        S2JJAXBModel jaxbModel = ((RpcLitStructure)block.getType()).getJaxbModel().getS2JJAXBModel();
+        List<Parameter> parameters = ModelerUtils.createRpcLitParameters(message, block, jaxbModel);
+
+        //create parameters for header and mime parts
+        for(String paramName: parameterList){
+            MessagePart part = message.getPart(paramName);
+            if(part == null)
+                continue;
+            if(ModelerUtils.isBoundToSOAPHeader(part)){
+                if(parameters == null)
+                    parameters = new ArrayList<Parameter>();
+                QName headerName = part.getDescriptor();
+                JAXBType jaxbType = getJAXBType(headerName);
+                Block headerBlock = new Block(headerName, jaxbType);
+                request.addHeaderBlock(headerBlock);
+                Parameter param = ModelerUtils.createParameter(part.getName(), jaxbType, headerBlock);
+                if(param != null){
+                    parameters.add(param);
+                }
+            }else if(ModelerUtils.isBoundToMimeContent(part)){
+                if(parameters == null)
+                    parameters = new ArrayList<Parameter>();
+                List<MIMEContent> mimeContents = getMimeContents(info.bindingOperation.getInput(),
+                        getInputMessage(), paramName);
+
+                JAXBType type = getAttachmentType(mimeContents, part);
+                //create Parameters in request or response
+                //Block mimeBlock = new Block(new QName(part.getName()), type);
+                Block mimeBlock = new Block(type.getName(), type);
+                request.addAttachmentBlock(mimeBlock);
+                Parameter param = ModelerUtils.createParameter(part.getName(), type, mimeBlock);
+                if(param != null){
+                    parameters.add(param);
+                }
+            }else if(ModelerUtils.isUnbound(part)){
+                if(parameters == null)
+                    parameters = new ArrayList<Parameter>();
+                QName name = part.getDescriptor();
+                JAXBType type = getJAXBType(part);
+                Block unboundBlock = new Block(name, type);
+                request.addUnboundBlock(unboundBlock);
+                Parameter param = ModelerUtils.createParameter(part.getName(), type, unboundBlock);
+                if(param != null){
+                    parameters.add(param);
+                }
+            }
+        }
+        for(Parameter param : parameters){
+            setCustomizedParameterName(info.portTypeOperation, message, message.getPart(param.getName()), param, false);
+        }
+        return parameters;
+    }
+
+    private String getJavaTypeForMimeType(String mimeType){
+        if(mimeType.equals("image/jpeg") || mimeType.equals("image/gif")){
+            return "java.awt.Image";
+        }else if(mimeType.equals("text/xml") || mimeType.equals("application/xml")){
+            return "javax.xml.transform.Source";
+        }
+        return "javax.activation.DataHandler";
+    }
+
+    /**
+     * @param mimeContents
+     * @return
+     */
+    private JAXBType getAttachmentType(List<MIMEContent> mimeContents, MessagePart part) {
+        if(!enableMimeContent()){
+            return getJAXBType(part);
+        }
+        String javaType = null;
+        List<String> mimeTypes = getAlternateMimeTypes(mimeContents);
+        if(mimeTypes.size() > 1) {
+            javaType = "javax.activation.DataHandler";
+        }else{
+           javaType = getJavaTypeForMimeType(mimeTypes.get(0));
+        }
+
+        S2JJAXBModel jaxbModel = getJAXBModelBuilder().getJAXBModel().getS2JJAXBModel();
+        JCodeModel cm = jaxbModel.generateCode(null,
+                    new ConsoleErrorReporter(getEnvironment(), false));
+        JType jt= null;
+        jt = cm.ref(javaType);
+        QName desc = part.getDescriptor();
+        TypeAndAnnotation typeAnno = null;
+
+        if (part.getDescriptorKind() == SchemaKinds.XSD_TYPE) {
+            typeAnno = jaxbModel.getJavaType(desc);
+            desc = new QName("", part.getName());
+        } else if (part.getDescriptorKind()== SchemaKinds.XSD_ELEMENT) {
+            typeAnno = getJAXBModelBuilder().getElementTypeAndAnn(desc);
+            for(Iterator mimeTypeIter = mimeTypes.iterator(); mimeTypeIter.hasNext();) {
+                String mimeType = (String)mimeTypeIter.next();
+                if((!mimeType.equals("text/xml") &&
+                        !mimeType.equals("application/xml"))){
+                    //According to AP 1.0,
+                    //RZZZZ: In a DESCRIPTION, if a wsdl:part element refers to a
+                    //global element declaration (via the element attribute of the wsdl:part
+                    //element) then the value of the type attribute of a mime:content element
+                    //that binds that part MUST be a content type suitable for carrying an
+                    //XML serialization.
+                    //should we throw warning?
+                    //type = MimeHelper.javaType.DATA_HANDLER_JAVATYPE;
+                    warn("mimemodeler.elementPart.invalidElementMimeType",
+                            new Object[] {
+                            part.getName(), mimeType});
+                }
+            }
+        }
+        if(typeAnno == null){
+            fail("wsdlmodeler.jaxb.javatype.notfound", new Object[]{desc, part.getName()});
+        }
+        return new JAXBType(desc, new JavaSimpleType(new JAXBTypeAndAnnotation(typeAnno, jt)),
+                null, getJAXBModelBuilder().getJAXBModel());
+    }
+
+    protected void buildJAXBModel(WSDLDocument wsdlDocument, WSDLModelInfo modelInfo, ClassNameCollector classNameCollector) {
+        JAXBModelBuilder jaxbModelBuilder = new JAXBModelBuilder(getWSDLModelInfo(), _options, classNameCollector, parser.getSchemaElements());
+        //set the java package where wsdl artifacts will be generated
+        //if user provided package name  using -p switch (or package property on wsimport ant task)
+        //ignore the package customization in the wsdl and schema bidnings
+        if(getWSDLModelInfo().getDefaultJavaPackage() != null){
+            getWSDLModelInfo().setJavaPackageName(getWSDLModelInfo().getDefaultJavaPackage());
+            jaxbModelBuilder.getJAXBSchemaCompiler().forcePackageName(getWSDLModelInfo().getJavaPackageName());
+        }else{
+            String jaxwsPackage = getJavaPackage();
+            getWSDLModelInfo().setJavaPackageName(jaxwsPackage);
+        }
+
+        //create pseudo schema for async operations(if any) response bean
+        List<InputSource> schemas = PseudoSchemaBuilder.build(this, _modelInfo);
+        for(InputSource schema : schemas){
+            jaxbModelBuilder.getJAXBSchemaCompiler().parseSchema(schema);
+        }
+        jaxbModelBuilder.bind();
+        this.jaxbModelBuilder = jaxbModelBuilder;
+    }
+
+    protected String getJavaPackage(){
+        String jaxwsPackage = null;
+        JAXWSBinding jaxwsCustomization = (JAXWSBinding)getExtensionOfType(document.getDefinitions(), JAXWSBinding.class);
+        if(jaxwsCustomization != null && jaxwsCustomization.getJaxwsPackage() != null){
+            jaxwsPackage = jaxwsCustomization.getJaxwsPackage().getName();
+        }
+        if(jaxwsPackage != null){
+            return jaxwsPackage;
+        }
+        String wsdlUri = document.getDefinitions().getTargetNamespaceURI();
+        return XJC.getDefaultPackageName(wsdlUri);
+
+    }
+
+    protected void createJavaInterfaceForProviderPort(Port port) {
+        String interfaceName = "javax.xml.ws.Provider";
+        JavaInterface intf = new JavaInterface(interfaceName);
+        port.setJavaInterface(intf);
+    }
+
+    protected void createJavaInterfaceForPort(Port port, boolean isProvider) {
+        if(isProvider){
+            createJavaInterfaceForProviderPort(port);
+            return;
+        }
+        String interfaceName = getJavaNameOfSEI(port);
+
+        if (isConflictingPortClassName(interfaceName)) {
+            interfaceName += "_PortType";
+        }
+
+        JavaInterface intf = new JavaInterface(interfaceName);
+        for (Operation operation : port.getOperations()) {
+            createJavaMethodForOperation(
+                port,
+                operation,
+                intf);
+
+            for(JavaParameter jParam : operation.getJavaMethod().getParametersList()){
+                Parameter param = jParam.getParameter();
+                if(param.getCustomName() != null)
+                    jParam.setName(param.getCustomName());
+            }
+        }
+
+        port.setJavaInterface(intf);
+    }
+
+    protected String getServiceInterfaceName(QName serviceQName, com.sun.tools.internal.ws.wsdl.document.Service wsdlService) {
+        String serviceName = wsdlService.getName();
+        JAXWSBinding jaxwsCust = (JAXWSBinding)getExtensionOfType(wsdlService, JAXWSBinding.class);
+        if(jaxwsCust != null && jaxwsCust.getClassName() != null){
+            CustomName name = jaxwsCust.getClassName();
+            if(name != null && !name.equals(""))
+                serviceName = name.getName();
+        }
+        String serviceInterface = "";
+        String javaPackageName = null;
+        if (_modelInfo.getJavaPackageName() != null
+            && !_modelInfo.getJavaPackageName().equals("")) {
+            javaPackageName = _modelInfo.getJavaPackageName();
+        }
+        if (javaPackageName != null) {
+            serviceInterface = javaPackageName + ".";
+        }
+        serviceInterface
+            += getEnvironment().getNames().validJavaClassName(serviceName);
+        return serviceInterface;
+    }
+
+    protected String getJavaNameOfSEI(Port port) {
+        QName portTypeName =
+            (QName)port.getProperty(
+                ModelProperties.PROPERTY_WSDL_PORT_TYPE_NAME);
+        PortType pt = (PortType)document.find(Kinds.PORT_TYPE, portTypeName);
+        JAXWSBinding jaxwsCust = (JAXWSBinding)getExtensionOfType(pt, JAXWSBinding.class);
+        if(jaxwsCust != null && jaxwsCust.getClassName() != null){
+            CustomName name = jaxwsCust.getClassName();
+            if(name != null && !name.equals("")){
+                return makePackageQualified(
+                        name.getName(),
+                        portTypeName,
+                        false);
+            }
+        }
+
+        String interfaceName = null;
+        if (portTypeName != null) {
+            // got portType information from WSDL, use it to name the interface
+            interfaceName =
+                makePackageQualified(JAXBRIContext.mangleNameToClassName(portTypeName.getLocalPart()),
+                                        portTypeName,
+                                        false);
+        } else {
+            // somehow we only got the port name, so we use that
+            interfaceName =
+                makePackageQualified(
+                    JAXBRIContext.mangleNameToClassName(port.getName().getLocalPart()),
+                    port.getName(),
+                    false);
+        }
+        return interfaceName;
+    }
+
+    private void createJavaMethodForAsyncOperation(Port port, Operation operation,
+            JavaInterface intf){
+        String candidateName = getJavaNameForOperation(operation);
+        JavaMethod method = new JavaMethod(candidateName);
+        method.setThrowsRemoteException(false);
+        Request request = operation.getRequest();
+        Iterator requestBodyBlocks = request.getBodyBlocks();
+        Block requestBlock =
+            (requestBodyBlocks.hasNext()
+                ? (Block)request.getBodyBlocks().next()
+                : null);
+
+        Response response = operation.getResponse();
+        Iterator responseBodyBlocks = null;
+        Block responseBlock = null;
+        if (response != null) {
+            responseBodyBlocks = response.getBodyBlocks();
+            responseBlock =
+                responseBodyBlocks.hasNext()
+                    ? (Block)response.getBodyBlocks().next()
+                    : null;
+        }
+
+        // build a signature of the form "opName%arg1type%arg2type%...%argntype so that we
+        // detect overloading conflicts in the generated java interface/classes
+        String signature = candidateName;
+        for (Iterator iter = request.getParameters(); iter.hasNext();) {
+            Parameter parameter = (Parameter)iter.next();
+
+            if (parameter.getJavaParameter() != null) {
+                throw new ModelerException(
+                    "wsdlmodeler.invalidOperation",
+                    operation.getName().getLocalPart());
+            }
+
+            JavaType parameterType = parameter.getType().getJavaType();
+            JavaParameter javaParameter =
+                new JavaParameter(
+                    JAXBRIContext.mangleNameToVariableName(parameter.getName()),
+                    parameterType,
+                    parameter,
+                    parameter.getLinkedParameter() != null);
+            if (javaParameter.isHolder()) {
+                javaParameter.setHolderName(javax.xml.ws.Holder.class.getName());
+            }
+            method.addParameter(javaParameter);
+            parameter.setJavaParameter(javaParameter);
+
+            signature += "%" + parameterType.getName();
+        }
+
+        if (response != null) {
+            String resultParameterName =
+                (String)operation.getProperty(WSDL_RESULT_PARAMETER);
+            Parameter resultParameter =
+                response.getParameterByName(resultParameterName);
+            JavaType returnType = resultParameter.getType().getJavaType();
+            method.setReturnType(returnType);
+
+        }
+        operation.setJavaMethod(method);
+        intf.addMethod(method);
+    }
+
+    /* (non-Javadoc)
+     * @see WSDLModelerBase#createJavaMethodForOperation(Port, Operation, JavaInterface, Set, Set)
+     */
+    protected void createJavaMethodForOperation(Port port, Operation operation, JavaInterface intf) {
+        if((operation instanceof AsyncOperation)){
+            createJavaMethodForAsyncOperation(port, operation, intf);
+            return;
+        }
+        String candidateName = getJavaNameForOperation(operation);
+        JavaMethod method = new JavaMethod(candidateName);
+        Request request = operation.getRequest();
+        Parameter returnParam = (Parameter)operation.getProperty(WSDL_RESULT_PARAMETER);
+        if(returnParam != null){
+            JavaType parameterType = returnParam.getType().getJavaType();
+            method.setReturnType(parameterType);
+        }else{
+            JavaType ret = new JavaSimpleTypeCreator().VOID_JAVATYPE;
+            method.setReturnType(ret);
+        }
+        List<Parameter> parameterOrder = (List<Parameter>)operation.getProperty(WSDL_PARAMETER_ORDER);
+        for(Parameter param:parameterOrder){
+            JavaType parameterType = param.getType().getJavaType();
+            String name = (param.getCustomName() != null)?param.getCustomName():param.getName();
+            JavaParameter javaParameter =
+                new JavaParameter(
+                    JAXBRIContext.mangleNameToVariableName(name),
+                    parameterType,
+                    param,
+                    param.isINOUT()||param.isOUT());
+            if (javaParameter.isHolder()) {
+                javaParameter.setHolderName(javax.xml.ws.Holder.class.getName());
+            }
+            method.addParameter(javaParameter);
+            param.setJavaParameter(javaParameter);
+        }
+        operation.setJavaMethod(method);
+        intf.addMethod(method);
+
+        String opName = JAXBRIContext.mangleNameToVariableName(operation.getName().getLocalPart());
+        for (Iterator iter = operation.getFaults();
+            iter != null && iter.hasNext();
+            ) {
+            Fault fault = (Fault)iter.next();
+            createJavaExceptionFromLiteralType(fault, port, opName);
+        }
+        JavaException javaException;
+        Fault fault;
+        for (Iterator iter = operation.getFaults(); iter.hasNext();) {
+            fault = (Fault)iter.next();
+            javaException = fault.getJavaException();
+            method.addException(javaException.getName());
+        }
+
+    }
+
+    protected boolean createJavaExceptionFromLiteralType(Fault fault, com.sun.tools.internal.ws.processor.model.Port port, String operationName) {
+        ProcessorEnvironment _env = getProcessorEnvironment();
+
+        JAXBType faultType = (JAXBType)fault.getBlock().getType();
+
+        String exceptionName =
+            makePackageQualified(
+                _env.getNames().validJavaClassName(fault.getName()),
+                port.getName());
+
+        // use fault namespace attribute
+        JAXBStructuredType jaxbStruct = new JAXBStructuredType(new QName(
+                                            fault.getBlock().getName().getNamespaceURI(),
+                                            fault.getName()));
+
+        QName memberName = fault.getElementName();
+        JAXBElementMember jaxbMember =
+            new JAXBElementMember(memberName, faultType);
+        //jaxbMember.setNillable(faultType.isNillable());
+
+        String javaMemberName = getLiteralJavaMemberName(fault);
+        JavaStructureMember javaMember = new JavaStructureMember(
+                                            javaMemberName,
+                                            faultType.getJavaType(),
+                                            jaxbMember);
+        jaxbMember.setJavaStructureMember(javaMember);
+        javaMember.setReadMethod(_env.getNames().getJavaMemberReadMethod(javaMember));
+        javaMember.setInherited(false);
+        jaxbMember.setJavaStructureMember(javaMember);
+        jaxbStruct.add(jaxbMember);
+
+        if (isConflictingExceptionClassName(exceptionName)) {
+            exceptionName += "_Exception";
+        }
+
+        JavaException existingJavaException = (JavaException)_javaExceptions.get(exceptionName);
+        if (existingJavaException != null) {
+            if (existingJavaException.getName().equals(exceptionName)) {
+                if (((JAXBType)existingJavaException.getOwner()).getName().equals(jaxbStruct.getName())
+                    || ModelerUtils.isEquivalentLiteralStructures(jaxbStruct, (JAXBStructuredType) existingJavaException.getOwner())) {
+                    // we have mapped this fault already
+                    if (faultType instanceof JAXBStructuredType) {
+                        fault.getBlock().setType((JAXBType) existingJavaException.getOwner());
+                    }
+                    fault.setJavaException(existingJavaException);
+                    return false;
+                }
+            }
+        }
+
+        JavaException javaException = new JavaException(exceptionName, false, jaxbStruct);
+        javaException.add(javaMember);
+        jaxbStruct.setJavaType(javaException);
+
+        _javaExceptions.put(javaException.getName(), javaException);
+
+        fault.setJavaException(javaException);
+        return true;
+    }
+
+    protected boolean isRequestResponse(){
+        return info.portTypeOperation.getStyle() == OperationStyle.REQUEST_RESPONSE;
+    }
+
+    protected java.util.List<String> getAsynParameterOrder(){
+        //for async operation ignore the parameterOrder
+        java.util.List<String> parameterList = new ArrayList<String>();
+        Message inputMessage = getInputMessage();
+        List<MessagePart> inputParts = inputMessage.getParts();
+        for(MessagePart part: inputParts){
+            parameterList.add(part.getName());
+        }
+        return parameterList;
+    }
+
+
+    protected List<MessagePart> getParameterOrder(){
+        List<MessagePart> params = new ArrayList<MessagePart>();
+        String parameterOrder = info.portTypeOperation.getParameterOrder();
+        java.util.List<String> parameterList = new ArrayList<String>();
+        boolean parameterOrderPresent = false;
+        if ((parameterOrder != null) && !(parameterOrder.trim().equals(""))) {
+            parameterList = XmlUtil.parseTokenList(parameterOrder);
+            parameterOrderPresent = true;
+        } else {
+            parameterList = new ArrayList<String>();
+        }
+        Message inputMessage = getInputMessage();
+        Message outputMessage = getOutputMessage();
+        List<MessagePart> outputParts = null;
+        List<MessagePart> inputParts = inputMessage.getParts();
+        //reset the mode and ret flag, as MEssagePArts aer shared across ports
+        for(MessagePart part:inputParts){
+            part.setMode(Mode.IN);
+            part.setReturn(false);
+        }
+        if(isRequestResponse()){
+            outputParts = outputMessage.getParts();
+            for(MessagePart part:outputParts){
+                part.setMode(Mode.OUT);
+                part.setReturn(false);
+            }
+        }
+
+        if(parameterOrderPresent){
+            boolean validParameterOrder = true;
+            Iterator<String> paramOrders = parameterList.iterator();
+            // If any part in the parameterOrder is not present in the request or
+            // response message, we completely ignore the parameterOrder hint
+            while(paramOrders.hasNext()){
+                String param = paramOrders.next();
+                boolean partFound = false;
+                for(MessagePart part : inputParts){
+                    if(param.equals(part.getName())){
+                        partFound = true;
+                        break;
+                    }
+                }
+                // if not found, check in output parts
+                if(!partFound){
+                    for(MessagePart part : outputParts){
+                        if(param.equals(part.getName())){
+                            partFound = true;
+                            break;
+                        }
+                    }
+                }
+                if(!partFound){
+                    warn("wsdlmodeler.invalid.parameterorder.parameter",
+                            new Object[] {param, info.operation.getName().getLocalPart()});
+                    validParameterOrder = false;
+                }
+            }
+
+            List<MessagePart> inputUnlistedParts = new ArrayList<MessagePart>();
+            List<MessagePart> outputUnlistedParts = new ArrayList<MessagePart>();
+
+            //gather input Parts
+            if(validParameterOrder){
+                for(String param:parameterList){
+                    MessagePart part = inputMessage.getPart(param);
+                    if(part != null){
+                        params.add(part);
+                        continue;
+                    }
+                    if(isRequestResponse()){
+                        MessagePart outPart = outputMessage.getPart(param);
+                        if(outPart != null){
+                            params.add(outPart);
+                            continue;
+                        }
+                    }
+                }
+
+                for(MessagePart part: inputParts){
+                    if(!parameterList.contains(part.getName())) {
+                        inputUnlistedParts.add(part);
+                    }
+                }
+
+                if(isRequestResponse()){
+                    // at most one output part should be unlisted
+                    for(MessagePart part: outputParts){
+                        if(!parameterList.contains(part.getName())) {
+                            MessagePart inPart = inputMessage.getPart(part.getName());
+                            //dont add inout as unlisted part
+                            if((inPart != null) && inPart.getDescriptor().equals(part.getDescriptor())){
+                                inPart.setMode(Mode.INOUT);
+                            }else{
+                                outputUnlistedParts.add(part);
+                            }
+                        }else{
+                            //param list may contain it, check if its INOUT
+                            MessagePart inPart = inputMessage.getPart(part.getName());
+                            //dont add inout as unlisted part
+                            if((inPart != null) && inPart.getDescriptor().equals(part.getDescriptor())){
+                                inPart.setMode(Mode.INOUT);
+                            }else if(!params.contains(part)){
+                                params.add(part);
+                            }
+                        }
+                    }
+                    if(outputUnlistedParts.size() == 1){
+                        MessagePart resultPart = outputUnlistedParts.get(0);
+                        resultPart.setReturn(true);
+                        params.add(resultPart);
+                        outputUnlistedParts.clear();
+                    }
+                }
+
+                //add the input and output unlisted parts
+                for(MessagePart part : inputUnlistedParts){
+                    params.add(part);
+                }
+
+                for(MessagePart part : outputUnlistedParts){
+                    params.add(part);
+                }
+                return params;
+
+            }
+            //parameterOrder attribute is not valid, we ignore it
+            warn("wsdlmodeler.invalid.parameterOrder.invalidParameterOrder",
+                    new Object[] {info.operation.getName().getLocalPart()});
+            parameterOrderPresent = false;
+            parameterList.clear();
+        }
+
+        List<MessagePart> outParts = new ArrayList<MessagePart>();
+
+        //construct input parameter list with the same order as in input message
+        for(MessagePart part: inputParts){
+            params.add(part);
+        }
+
+        if(isRequestResponse()){
+            for(MessagePart part:outputParts){
+                MessagePart inPart = inputMessage.getPart(part.getName());
+                if(inPart != null && part.getDescriptorKind() == inPart.getDescriptorKind() &&
+                        part.getDescriptor().equals(inPart.getDescriptor())){
+                    inPart.setMode(Mode.INOUT);
+                    continue;
+                }
+                outParts.add(part);
+            }
+
+            //append the out parts to the parameterList
+            for(MessagePart part : outParts){
+                if(outParts.size() == 1)
+                    part.setReturn(true);
+                params.add(part);
+            }
+        }
+        return params;
+    }
+
+    /**
+     *
+     * @param port
+     * @param suffix
+     * @return the Java ClassName for a port
+     */
+    protected String getClassName(Port port, String suffix) {
+        String name = "";
+        String javaPackageName = "";
+        if (_modelInfo.getJavaPackageName() != null
+            && !_modelInfo.getJavaPackageName().equals("")) {
+            javaPackageName = _modelInfo.getJavaPackageName();
+        }
+        String prefix = getEnvironment().getNames().validJavaClassName(port.getName().getLocalPart());
+        name = javaPackageName+"."+prefix+suffix;
+        return name;
+    }
+
+    protected boolean isConflictingServiceClassName(String name) {
+       if(conflictsWithSEIClass(name) || conflictsWithJAXBClass(name) ||conflictsWithExceptionClass(name)){
+            return true;
+        }
+        return false;
+    }
+
+    private boolean conflictsWithSEIClass(String name){
+        Set<String> seiNames = classNameCollector.getSeiClassNames();
+        if(seiNames != null && seiNames.contains(name))
+            return true;
+        return false;
+    }
+
+    private boolean conflictsWithJAXBClass(String name){
+        Set<String> jaxbNames = classNameCollector.getJaxbGeneratedClassNames();
+        if(jaxbNames != null && jaxbNames.contains(name))
+            return true;
+        return false;
+    }
+
+    private boolean conflictsWithExceptionClass(String name){
+        Set<String> exceptionNames = classNameCollector.getExceptionClassNames();
+        if(exceptionNames != null && exceptionNames.contains(name))
+            return true;
+        return false;
+    }
+
+    protected boolean isConflictingExceptionClassName(String name) {
+        if(conflictsWithSEIClass(name) || conflictsWithJAXBClass(name)){
+            return true;
+        }
+        return false;
+    }
+
+    protected JAXBModelBuilder getJAXBModelBuilder() {
+        return jaxbModelBuilder;
+    }
+
+    protected boolean validateWSDLBindingStyle(Binding binding) {
+        boolean mixedStyle = false;
+        SOAPBinding soapBinding =
+            (SOAPBinding)getExtensionOfType(binding, SOAPBinding.class);
+
+        //dont process the binding
+        if(soapBinding == null)
+            soapBinding =
+                (SOAPBinding)getExtensionOfType(binding, SOAP12Binding.class);
+        if(soapBinding == null)
+            return false;
+
+        //if soapbind:binding has no style attribute, the default is DOCUMENT
+        if(soapBinding.getStyle() == null)
+            soapBinding.setStyle(SOAPStyle.DOCUMENT);
+
+        SOAPStyle opStyle = soapBinding.getStyle();
+        for (Iterator iter = binding.operations(); iter.hasNext();) {
+            BindingOperation bindingOperation =
+                (BindingOperation)iter.next();
+            SOAPOperation soapOperation =
+                (SOAPOperation) getExtensionOfType(bindingOperation,
+                    SOAPOperation.class);
+            if(soapOperation != null){
+                SOAPStyle currOpStyle = (soapOperation.getStyle() != null)?soapOperation.getStyle():soapBinding.getStyle();
+                //dont check for the first operation
+                if(!currOpStyle.equals(opStyle))
+                    return false;
+            }
+        }
+        return true;
+    }
+
+    /**
+     * @param port
+     */
+    private void applyWrapperStyleCustomization(Port port, PortType portType) {
+        JAXWSBinding jaxwsBinding = (JAXWSBinding)getExtensionOfType(portType, JAXWSBinding.class);
+        Boolean wrapperStyle = (jaxwsBinding != null)?jaxwsBinding.isEnableWrapperStyle():null;
+        if(wrapperStyle != null){
+            port.setWrapped(wrapperStyle);
+        }
+    }
+
+    protected static void setDocumentationIfPresent(
+        ModelObject obj,
+        Documentation documentation) {
+        if (documentation != null && documentation.getContent() != null) {
+            obj.setJavaDoc(documentation.getContent());
+        }
+    }
+
+    protected String getJavaNameForOperation(Operation operation) {
+        String name = operation.getJavaMethodName();
+        if(getEnvironment().getNames().isJavaReservedWord(name)){
+            name = "_"+name;
+        }
+        return name;
+    }
+
+    protected void fail(String key, String arg){
+        throw new ModelerException(key, arg);
+    }
+    protected void fail(String key, Object[] args){
+        throw new ModelerException(key, args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/WSDLModelerBase.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/WSDLModelerBase.java
new file mode 100644
index 0000000..fc5f028
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/modeler/wsdl/WSDLModelerBase.java
@@ -0,0 +1,1086 @@
+
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.modeler.wsdl;
+
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.generator.Names;
+import com.sun.tools.internal.ws.processor.model.AbstractType;
+import com.sun.tools.internal.ws.processor.model.Block;
+import com.sun.tools.internal.ws.processor.model.Fault;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.model.ModelObject;
+import com.sun.tools.internal.ws.processor.model.ModelProperties;
+import com.sun.tools.internal.ws.processor.model.Operation;
+import com.sun.tools.internal.ws.processor.model.Parameter;
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.modeler.JavaSimpleTypeCreator;
+import com.sun.tools.internal.ws.processor.modeler.Modeler;
+import com.sun.tools.internal.ws.processor.modeler.ModelerException;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.wsdl.document.Binding;
+import com.sun.tools.internal.ws.wsdl.document.BindingFault;
+import com.sun.tools.internal.ws.wsdl.document.BindingOperation;
+import com.sun.tools.internal.ws.wsdl.document.Documentation;
+import com.sun.tools.internal.ws.wsdl.document.Kinds;
+import com.sun.tools.internal.ws.wsdl.document.Message;
+import com.sun.tools.internal.ws.wsdl.document.MessagePart;
+import com.sun.tools.internal.ws.wsdl.document.OperationStyle;
+import com.sun.tools.internal.ws.wsdl.document.WSDLDocument;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.JAXWSBinding;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEContent;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEMultipartRelated;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEPart;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaKinds;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPBinding;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPBody;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPFault;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPHeader;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPOperation;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.GloballyKnown;
+import com.sun.tools.internal.ws.wsdl.framework.NoSuchEntityException;
+import com.sun.tools.internal.ws.wsdl.parser.Constants;
+import com.sun.tools.internal.ws.wsdl.parser.Util;
+import com.sun.tools.internal.ws.wsdl.parser.WSDLParser;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import org.w3c.dom.Element;
+
+import javax.xml.namespace.QName;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Properties;
+import java.util.Set;
+import java.util.StringTokenizer;
+
+/**
+ *
+ * @author WS Development Team
+ *
+ * Base class for WSDL->Model classes.
+ */
+public abstract class WSDLModelerBase implements Modeler {
+    public WSDLModelerBase(WSDLModelInfo modelInfo, Properties options) {
+        //init();
+        _modelInfo = modelInfo;
+        _options = options;
+        _messageFactory =
+            new LocalizableMessageFactory("com.sun.tools.internal.ws.resources.modeler");
+        _conflictingClassNames = null;
+        _env = (ProcessorEnvironment)modelInfo.getParent().getEnvironment();
+        hSet = null;
+        reqResNames = new HashSet();
+    }
+
+
+    protected WSDLParser createWSDLParser(){
+        return new WSDLParser(_modelInfo);
+    }
+
+    /**
+     * Builds model from WSDL document. Model contains abstraction which is used by the
+     * generators to generate the stub/tie/serializers etc. code.
+     *
+     * @see Modeler#buildModel()
+     */
+    public Model buildModel() {
+        return null;
+    }
+
+    protected WSDLModelInfo getWSDLModelInfo(){
+        return _modelInfo;
+    }
+
+    protected Documentation getDocumentationFor(Element e) {
+        String s = XmlUtil.getTextForNode(e);
+        if (s == null) {
+            return null;
+        } else {
+            return new Documentation(s);
+        }
+    }
+
+    protected void checkNotWsdlElement(Element e) {
+        // possible extensibility element -- must live outside the WSDL namespace
+        if (e.getNamespaceURI().equals(Constants.NS_WSDL))
+            Util.fail("parsing.invalidWsdlElement", e.getTagName());
+    }
+
+    /**
+     * @param port
+     * @param wsdlPort
+     */
+    protected void applyPortMethodCustomization(Port port, com.sun.tools.internal.ws.wsdl.document.Port wsdlPort) {
+        if(isProvider(wsdlPort))
+            return;
+        JAXWSBinding jaxwsBinding = (JAXWSBinding)getExtensionOfType(wsdlPort, JAXWSBinding.class);
+
+        String portMethodName = (jaxwsBinding != null)?((jaxwsBinding.getMethodName() != null)?jaxwsBinding.getMethodName().getName():null):null;
+        if(portMethodName != null){
+            port.setPortGetter(portMethodName);
+        }else{
+            portMethodName = Names.getPortName(port);
+            portMethodName = getEnvironment().getNames().validJavaClassName(portMethodName);
+            port.setPortGetter("get"+portMethodName);
+        }
+
+    }
+
+    protected boolean isProvider(com.sun.tools.internal.ws.wsdl.document.Port wsdlPort){
+        JAXWSBinding portCustomization = (JAXWSBinding)getExtensionOfType(wsdlPort, JAXWSBinding.class);
+        Boolean isProvider = (portCustomization != null)?portCustomization.isProvider():null;
+        if(isProvider != null){
+            return isProvider;
+        }
+
+        JAXWSBinding jaxwsGlobalCustomization = (JAXWSBinding)getExtensionOfType(document.getDefinitions(), JAXWSBinding.class);
+        isProvider = (jaxwsGlobalCustomization != null)?jaxwsGlobalCustomization.isProvider():null;
+        if(isProvider != null)
+            return isProvider;
+        return false;
+    }
+
+    protected void createParentFault(Fault fault) {
+        AbstractType faultType = fault.getBlock().getType();
+        AbstractType parentType = null;
+
+
+        if (parentType == null) {
+            return;
+        }
+
+        if (fault.getParentFault() != null) {
+            return;
+        }
+        Fault parentFault =
+            new Fault(((AbstractType)parentType).getName().getLocalPart());
+        /* this is what it really should be but for interop with JAXRPC 1.0.1 we are not doing
+         * this at this time.
+         *
+         * TODO - we should double-check this; the above statement might not be true anymore.
+         */
+        QName faultQName =
+            new QName(
+                fault.getBlock().getName().getNamespaceURI(),
+                parentFault.getName());
+        Block block = new Block(faultQName);
+        block.setType((AbstractType)parentType);
+        parentFault.setBlock(block);
+        parentFault.addSubfault(fault);
+        createParentFault(parentFault);
+    }
+
+    protected void createSubfaults(Fault fault) {
+        AbstractType faultType = fault.getBlock().getType();
+        Iterator subtypes = null;
+        if (subtypes != null) {
+            AbstractType subtype;
+            while (subtypes.hasNext()) {
+                subtype = (AbstractType)subtypes.next();
+                Fault subFault = new Fault(subtype.getName().getLocalPart());
+                /* this is what it really is but for interop with JAXRPC 1.0.1 we are not doing
+                 * this at this time
+                 *
+                 * TODO - we should double-check this; the above statement might not be true anymore.
+                 */
+                QName faultQName =
+                    new QName(
+                        fault.getBlock().getName().getNamespaceURI(),
+                        subFault.getName());
+                Block block = new Block(faultQName);
+                block.setType(subtype);
+                subFault.setBlock(block);
+                fault.addSubfault(subFault);
+                createSubfaults(subFault);
+            }
+        }
+    }
+
+    protected SOAPBody getSOAPRequestBody() {
+        SOAPBody requestBody =
+            (SOAPBody)getAnyExtensionOfType(info.bindingOperation.getInput(),
+                SOAPBody.class);
+        if (requestBody == null) {
+            // the WSDL document is invalid
+            throw new ModelerException(
+                "wsdlmodeler.invalid.bindingOperation.inputMissingSoapBody",
+                new Object[] { info.bindingOperation.getName()});
+        }
+        return requestBody;
+    }
+
+    protected boolean isRequestMimeMultipart() {
+        for (Iterator iter = info.bindingOperation.getInput().extensions(); iter.hasNext();) {
+            Extension extension = (Extension)iter.next();
+            if (extension.getClass().equals(MIMEMultipartRelated.class)) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    protected boolean isResponseMimeMultipart() {
+        for (Iterator iter = info.bindingOperation.getOutput().extensions(); iter.hasNext();) {
+            Extension extension = (Extension)iter.next();
+            if (extension.getClass().equals(MIMEMultipartRelated.class)) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+
+
+
+    protected SOAPBody getSOAPResponseBody() {
+        SOAPBody responseBody =
+            (SOAPBody)getAnyExtensionOfType(info.bindingOperation.getOutput(),
+                SOAPBody.class);
+        if (responseBody == null) {
+            // the WSDL document is invalid
+            throw new ModelerException(
+                "wsdlmodeler.invalid.bindingOperation.outputMissingSoapBody",
+                new Object[] { info.bindingOperation.getName()});
+        }
+        return responseBody;
+    }
+
+    protected com.sun.tools.internal.ws.wsdl.document.Message getOutputMessage() {
+        if (info.portTypeOperation.getOutput() == null)
+            return null;
+        return info.portTypeOperation.getOutput().resolveMessage(info.document);
+    }
+
+    protected com.sun.tools.internal.ws.wsdl.document.Message getInputMessage() {
+        return info.portTypeOperation.getInput().resolveMessage(info.document);
+    }
+
+    /**
+     * @param body request or response body, represents soap:body
+     * @param message Input or output message, equivalent to wsdl:message
+     * @return iterator over MessagePart
+     */
+    protected List getMessageParts(
+        SOAPBody body,
+        com.sun.tools.internal.ws.wsdl.document.Message message, boolean isInput) {
+        String bodyParts = body.getParts();
+        ArrayList partsList = new ArrayList();
+        List parts = new ArrayList();
+
+        //get Mime parts
+        List mimeParts = null;
+        if(isInput)
+            mimeParts = getMimeContentParts(message, info.bindingOperation.getInput());
+        else
+            mimeParts = getMimeContentParts(message, info.bindingOperation.getOutput());
+
+        if (bodyParts != null) {
+            StringTokenizer in = new StringTokenizer(bodyParts.trim(), " ");
+            while (in.hasMoreTokens()) {
+                String part = in.nextToken();
+                MessagePart mPart = (MessagePart)message.getPart(part);
+                if (null == mPart) {
+                    throw new ModelerException(
+                        "wsdlmodeler.error.partsNotFound",
+                        new Object[] { part, message.getName()});
+                }
+                mPart.setBindingExtensibilityElementKind(MessagePart.SOAP_BODY_BINDING);
+                partsList.add(mPart);
+            }
+        } else {
+            for(Iterator iter = message.parts();iter.hasNext();) {
+                MessagePart mPart = (MessagePart)iter.next();
+                if(!mimeParts.contains(mPart))
+                    mPart.setBindingExtensibilityElementKind(MessagePart.SOAP_BODY_BINDING);
+                partsList.add(mPart);
+            }
+        }
+
+        for(Iterator iter = message.parts();iter.hasNext();) {
+            MessagePart mPart = (MessagePart)iter.next();
+            if(mimeParts.contains(mPart)) {
+                mPart.setBindingExtensibilityElementKind(MessagePart.WSDL_MIME_BINDING);
+                parts.add(mPart);
+            }else if(partsList.contains(mPart)) {
+                mPart.setBindingExtensibilityElementKind(MessagePart.SOAP_BODY_BINDING);
+                parts.add(mPart);
+            }
+        }
+
+        return parts;
+    }
+
+    /**
+     * @param message
+     * @return MessageParts referenced by the mime:content
+     */
+    protected List getMimeContentParts(Message message, Extensible ext) {
+        ArrayList mimeContentParts = new ArrayList();
+        String mimeContentPartName = null;
+        Iterator mimeParts = getMimeParts(ext);
+
+        while(mimeParts.hasNext()) {
+            MessagePart part = getMimeContentPart(message, (MIMEPart)mimeParts.next());
+            if(part != null)
+                mimeContentParts.add(part);
+        }
+        return mimeContentParts;
+    }
+
+    /**
+     * @param mimeParts
+     */
+    protected boolean validateMimeParts(Iterator mimeParts) {
+        boolean gotRootPart = false;
+        List mimeContents = new ArrayList();
+        while(mimeParts.hasNext()) {
+            MIMEPart mPart = (MIMEPart)mimeParts.next();
+            Iterator extns = mPart.extensions();
+            while(extns.hasNext()){
+                Object obj = extns.next();
+                if(obj instanceof SOAPBody){
+                    if(gotRootPart) {
+                        //bug fix: 5024020
+                        warn("mimemodeler.invalidMimePart.moreThanOneSOAPBody",
+                                new Object[] {info.operation.getName().getLocalPart()});
+                        return false;
+                    }
+                    gotRootPart = true;
+                }else if (obj instanceof MIMEContent) {
+                    mimeContents.add((MIMEContent)obj);
+                }
+            }
+            if(!validateMimeContentPartNames(mimeContents.iterator()))
+                return false;
+            if(mPart.getName() != null) {
+                //bug fix: 5024018
+                warn("mimemodeler.invalidMimePart.nameNotAllowed",
+                        info.portTypeOperation.getName());
+            }
+        }
+        return true;
+
+    }
+
+    private MessagePart getMimeContentPart(Message message, MIMEPart part) {
+        String mimeContentPartName = null;
+        Iterator mimeContents = getMimeContents(part).iterator();
+        if(mimeContents.hasNext()) {
+            mimeContentPartName = ((MIMEContent)mimeContents.next()).getPart();
+            MessagePart mPart = (MessagePart)message.getPart(mimeContentPartName);
+            //RXXXX mime:content MUST have part attribute
+            if(null == mPart) {
+                throw new ModelerException("wsdlmodeler.error.partsNotFound",
+                        new Object[] {mimeContentPartName, message.getName()});
+            }
+            mPart.setBindingExtensibilityElementKind(MessagePart.WSDL_MIME_BINDING);
+            return mPart;
+        }
+        return null;
+    }
+
+    //List of mimeTypes
+    protected List<String> getAlternateMimeTypes(List<MIMEContent> mimeContents) {
+        List<String> mimeTypes = new ArrayList<String>();
+        //validateMimeContentPartNames(mimeContents.iterator());
+//        String mimeType = null;
+        for(MIMEContent mimeContent:mimeContents){
+            String mimeType = getMimeContentType(mimeContent);
+            if(!mimeTypes.contains(mimeType))
+                mimeTypes.add(mimeType);
+        }
+        return mimeTypes;
+    }
+
+    /**
+     * @param iterator
+     */
+    private boolean validateMimeContentPartNames(Iterator mimeContents) {
+        //validate mime:content(s) in the mime:part as per R2909
+        while(mimeContents.hasNext()){
+            String mimeContnetPart = null;
+            if(mimeContnetPart == null) {
+                mimeContnetPart = getMimeContentPartName((MIMEContent)mimeContents.next());
+                if(mimeContnetPart == null) {
+                    warn("mimemodeler.invalidMimeContent.missingPartAttribute",
+                            new Object[] {info.operation.getName().getLocalPart()});
+                    return false;
+                }
+            }else {
+                String newMimeContnetPart = getMimeContentPartName((MIMEContent)mimeContents.next());
+                if(newMimeContnetPart == null) {
+                    warn("mimemodeler.invalidMimeContent.missingPartAttribute",
+                            new Object[] {info.operation.getName().getLocalPart()});
+                    return false;
+                }else if(!newMimeContnetPart.equals(mimeContnetPart)) {
+                    //throw new ModelerException("mimemodeler.invalidMimeContent.differentPart");
+                    warn("mimemodeler.invalidMimeContent.differentPart");
+                    return false;
+                }
+            }
+        }
+        return true;
+    }
+
+    protected Iterator<MIMEPart> getMimeParts(Extensible ext) {
+        MIMEMultipartRelated multiPartRelated =
+            (MIMEMultipartRelated) getAnyExtensionOfType(ext,
+                    MIMEMultipartRelated.class);
+        if(multiPartRelated == null) {
+            List<MIMEPart> parts = new ArrayList<MIMEPart>();
+            return parts.iterator();
+        }
+        return multiPartRelated.getParts();
+    }
+
+    //returns MIMEContents
+    protected List<MIMEContent> getMimeContents(MIMEPart part) {
+        List<MIMEContent> mimeContents = new ArrayList<MIMEContent>();
+        Iterator parts = part.extensions();
+        while(parts.hasNext()) {
+            Extension mimeContent = (Extension) parts.next();
+            if (mimeContent instanceof MIMEContent) {
+                mimeContents.add((MIMEContent)mimeContent);
+            }
+        }
+        //validateMimeContentPartNames(mimeContents.iterator());
+        return mimeContents;
+    }
+
+    private String getMimeContentPartName(MIMEContent mimeContent){
+        /*String partName = mimeContent.getPart();
+        if(partName == null){
+            throw new ModelerException("mimemodeler.invalidMimeContent.missingPartAttribute",
+                    new Object[] {info.operation.getName().getLocalPart()});
+        }
+        return partName;*/
+        return mimeContent.getPart();
+    }
+
+    private String getMimeContentType(MIMEContent mimeContent){
+        String mimeType = mimeContent.getType();
+        if(mimeType == null){
+            throw new ModelerException("mimemodeler.invalidMimeContent.missingTypeAttribute",
+                    new Object[] {info.operation.getName().getLocalPart()});
+        }
+        return mimeType;
+    }
+
+    /**
+     * For Document/Lit the wsdl:part should only have element attribute and
+     * for RPC/Lit or RPC/Encoded the wsdl:part should only have type attribute
+     * inside wsdl:message.
+     */
+    protected boolean isStyleAndPartMatch(
+        SOAPOperation soapOperation,
+        MessagePart part) {
+
+        // style attribute on soap:operation takes precedence over the
+        // style attribute on soap:binding
+
+        if ((soapOperation != null) && (soapOperation.getStyle() != null)) {
+            if ((soapOperation.isDocument()
+                && (part.getDescriptorKind() != SchemaKinds.XSD_ELEMENT))
+                || (soapOperation.isRPC()
+                    && (part.getDescriptorKind() != SchemaKinds.XSD_TYPE))) {
+                return false;
+            }
+        } else {
+            if ((info.soapBinding.isDocument()
+                && (part.getDescriptorKind() != SchemaKinds.XSD_ELEMENT))
+                || (info.soapBinding.isRPC()
+                    && (part.getDescriptorKind() != SchemaKinds.XSD_TYPE))) {
+                return false;
+            }
+        }
+
+        return true;
+    }
+
+
+
+    protected String getRequestNamespaceURI(SOAPBody body) {
+        String namespaceURI = body.getNamespace();
+        if (namespaceURI == null) {
+            // the WSDL document is invalid
+            // at least, that's my interpretation of section 3.5 of the WSDL 1.1 spec!
+            throw new ModelerException(
+                "wsdlmodeler.invalid.bindingOperation.inputSoapBody.missingNamespace",
+                new Object[] { info.bindingOperation.getName()});
+        }
+        return namespaceURI;
+    }
+
+    protected String getResponseNamespaceURI(SOAPBody body) {
+        String namespaceURI = body.getNamespace();
+        if (namespaceURI == null) {
+            // the WSDL document is invalid
+            // at least, that's my interpretation of section 3.5 of the WSDL 1.1 spec!
+            throw new ModelerException(
+                "wsdlmodeler.invalid.bindingOperation.outputSoapBody.missingNamespace",
+                new Object[] { info.bindingOperation.getName()});
+        }
+        return namespaceURI;
+    }
+
+    /**
+     * @return List of SOAPHeader extensions
+     */
+    protected List<SOAPHeader> getHeaderExtensions(Extensible extensible) {
+        List<SOAPHeader> headerList = new ArrayList<SOAPHeader>();
+        Iterator bindingIter = extensible.extensions();
+        while (bindingIter.hasNext()) {
+            Extension extension = (Extension) bindingIter.next();
+            if (extension.getClass().equals(MIMEMultipartRelated.class)) {
+                for (Iterator parts = ((MIMEMultipartRelated) extension).getParts();
+                parts.hasNext();) {
+                    Extension part = (Extension) parts.next();
+                    if (part.getClass().equals(MIMEPart.class)) {
+                        boolean isRootPart = isRootPart((MIMEPart)part);
+                        Iterator iter = ((MIMEPart)part).extensions();
+                        while(iter.hasNext()) {
+                            Object obj = iter.next();
+                            if(obj instanceof SOAPHeader){
+                                //bug fix: 5024015
+                                if(!isRootPart) {
+                                    warn(
+                                            "mimemodeler.warning.IgnoringinvalidHeaderPart.notDeclaredInRootPart",
+                                            new Object[] {
+                                                    info.bindingOperation.getName()});
+                                    return new ArrayList<SOAPHeader>();
+                                }
+                                headerList.add((SOAPHeader)obj);
+                            }
+                        }
+                    }
+
+                }
+            }else if(extension instanceof SOAPHeader) {
+                headerList.add((SOAPHeader)extension);
+            }
+         }
+         return headerList;
+    }
+
+    /**
+     * @param part
+     * @return true if part is the Root part
+     */
+    private boolean isRootPart(MIMEPart part) {
+        Iterator iter = part.extensions();
+        while(iter.hasNext()){
+            if(iter.next() instanceof SOAPBody)
+                return true;
+        }
+        return false;
+    }
+
+    protected Set getDuplicateFaultNames() {
+        // look for fault messages with the same soap:fault name
+        Set faultNames = new HashSet();
+        Set duplicateNames = new HashSet();
+        for (Iterator iter = info.bindingOperation.faults(); iter.hasNext();) {
+            BindingFault bindingFault = (BindingFault)iter.next();
+            com.sun.tools.internal.ws.wsdl.document.Fault portTypeFault = null;
+            for (Iterator iter2 = info.portTypeOperation.faults();
+                iter2.hasNext();
+                ) {
+                com.sun.tools.internal.ws.wsdl.document.Fault aFault =
+                    (com.sun.tools.internal.ws.wsdl.document.Fault)iter2.next();
+
+                if (aFault.getName().equals(bindingFault.getName())) {
+                    if (portTypeFault != null) {
+                        // the WSDL document is invalid
+                        throw new ModelerException(
+                            "wsdlmodeler.invalid.bindingFault.notUnique",
+                            new Object[] {
+                                bindingFault.getName(),
+                                info.bindingOperation.getName()});
+                    } else {
+                        portTypeFault = aFault;
+                    }
+                }
+            }
+            if (portTypeFault == null) {
+                // the WSDL document is invalid
+                throw new ModelerException(
+                    "wsdlmodeler.invalid.bindingFault.notFound",
+                    new Object[] {
+                        bindingFault.getName(),
+                        info.bindingOperation.getName()});
+
+            }
+            SOAPFault soapFault =
+                (SOAPFault)getExtensionOfType(bindingFault, SOAPFault.class);
+            if (soapFault == null) {
+                // the WSDL document is invalid
+                throw new ModelerException(
+                    "wsdlmodeler.invalid.bindingFault.outputMissingSoapFault",
+                    new Object[] {
+                        bindingFault.getName(),
+                        info.bindingOperation.getName()});
+            }
+
+            com.sun.tools.internal.ws.wsdl.document.Message faultMessage =
+                portTypeFault.resolveMessage(info.document);
+            Iterator iter2 = faultMessage.parts();
+            if (!iter2.hasNext()) {
+                // the WSDL document is invalid
+                throw new ModelerException(
+                    "wsdlmodeler.invalid.bindingFault.emptyMessage",
+                    new Object[] {
+                        bindingFault.getName(),
+                        faultMessage.getName()});
+            }
+            //  bug fix: 4852729
+            if (useWSIBasicProfile && (soapFault.getNamespace() != null)) {
+                warn(
+                    "wsdlmodeler.warning.r2716r2726",
+                    new Object[] { "soapbind:fault", soapFault.getName()});
+            }
+            String faultNamespaceURI = soapFault.getNamespace();
+            if (faultNamespaceURI == null) {
+                faultNamespaceURI =
+                    portTypeFault.getMessage().getNamespaceURI();
+            }
+            String faultName = faultMessage.getName();
+            QName faultQName = new QName(faultNamespaceURI, faultName);
+            if (faultNames.contains(faultQName)) {
+                duplicateNames.add(faultQName);
+            } else {
+                faultNames.add(faultQName);
+            }
+        }
+        return duplicateNames;
+    }
+
+
+    /**
+     * @param operation
+     * @return true if operation has valid body parts
+     */
+    protected boolean validateBodyParts(BindingOperation operation) {
+        boolean isRequestResponse =
+            info.portTypeOperation.getStyle()
+            == OperationStyle.REQUEST_RESPONSE;
+        List inputParts = getMessageParts(getSOAPRequestBody(), getInputMessage(), true);
+        if(!validateStyleAndPart(operation, inputParts))
+            return false;
+
+        if(isRequestResponse){
+            List outputParts = getMessageParts(getSOAPResponseBody(), getOutputMessage(), false);
+            if(!validateStyleAndPart(operation, outputParts))
+                return false;
+        }
+        return true;
+    }
+
+    /**
+     * @param operation
+     * @return true if operation has valid style and part
+     */
+    private boolean validateStyleAndPart(BindingOperation operation, List parts) {
+        SOAPOperation soapOperation =
+            (SOAPOperation) getExtensionOfType(operation, SOAPOperation.class);
+        for(Iterator iter = parts.iterator(); iter.hasNext();){
+            MessagePart part = (MessagePart)iter.next();
+            if(part.getBindingExtensibilityElementKind() == MessagePart.SOAP_BODY_BINDING){
+                if(!isStyleAndPartMatch(soapOperation, part))
+                    return false;
+            }
+        }
+        return true;
+    }
+
+    protected String getLiteralJavaMemberName(Fault fault) {
+        String javaMemberName;
+
+        QName memberName = fault.getElementName();
+        javaMemberName = fault.getJavaMemberName();
+        if (javaMemberName == null)
+            javaMemberName = memberName.getLocalPart();
+        return javaMemberName;
+    }
+
+    /**
+     * @param ext
+     * @param message
+     * @param name
+     * @return List of MimeContents from ext
+     */
+    protected List<MIMEContent> getMimeContents(Extensible ext, Message message, String name) {
+        Iterator mimeParts = getMimeParts(ext);
+        while(mimeParts.hasNext()){
+            MIMEPart mimePart = (MIMEPart)mimeParts.next();
+            List<MIMEContent> mimeContents = getMimeContents(mimePart);
+            for(MIMEContent mimeContent:mimeContents){
+                if(mimeContent.getPart().equals(name))
+                    return mimeContents;
+            }
+        }
+        return null;
+    }
+
+    protected ProcessorEnvironment getEnvironment() {
+        return _env;
+    }
+
+    protected void warn(Localizable msg) {
+        getEnvironment().warn(msg);
+    }
+
+    protected void warn(String key) {
+        getEnvironment().warn(_messageFactory.getMessage(key));
+    }
+
+    protected void warn(String key, String arg) {
+        getEnvironment().warn(_messageFactory.getMessage(key, arg));
+    }
+
+    protected void error(String key, String arg) {
+        getEnvironment().error(_messageFactory.getMessage(key, arg));
+    }
+
+    protected void warn(String key, Object[] args) {
+        getEnvironment().warn(_messageFactory.getMessage(key, args));
+    }
+
+    protected void info(String key) {
+        getEnvironment().info(_messageFactory.getMessage(key));
+    }
+
+    protected void info(String key, String arg) {
+        getEnvironment().info(_messageFactory.getMessage(key, arg));
+    }
+
+    protected String makePackageQualified(String s, QName name) {
+        return makePackageQualified(s, name, true);
+    }
+
+    protected String makePackageQualified(
+        String s,
+        QName name,
+        boolean useNamespaceMapping) {
+        String javaPackageName = null;
+        if (useNamespaceMapping) {
+            javaPackageName = getJavaPackageName(name);
+        }
+        if (javaPackageName != null) {
+            return javaPackageName + "." + s;
+        } else if (
+            _modelInfo.getJavaPackageName() != null
+                && !_modelInfo.getJavaPackageName().equals("")) {
+            return _modelInfo.getJavaPackageName() + "." + s;
+        } else {
+            return s;
+        }
+    }
+
+    protected QName makePackageQualified(QName name) {
+        return makePackageQualified(name, true);
+    }
+
+    protected QName makePackageQualified(
+        QName name,
+        boolean useNamespaceMapping) {
+        return new QName(
+            name.getNamespaceURI(),
+            makePackageQualified(name.getLocalPart(), name));
+    }
+
+    protected String makeNameUniqueInSet(String candidateName, Set names) {
+        String baseName = candidateName;
+        String name = baseName;
+        for (int i = 2; names.contains(name); ++i) {
+            name = baseName + Integer.toString(i);
+        }
+        return name;
+    }
+
+    protected String getUniqueName(
+        com.sun.tools.internal.ws.wsdl.document.Operation operation,
+        boolean hasOverloadedOperations) {
+        if (hasOverloadedOperations) {
+            return operation.getUniqueKey().replace(' ', '_');
+        } else {
+            return operation.getName();
+        }
+    }
+
+    protected String getUniqueParameterName(
+        Operation operation,
+        String baseName) {
+        Set names = new HashSet();
+        for (Iterator iter = operation.getRequest().getParameters();
+            iter.hasNext();
+            ) {
+            Parameter p = (Parameter)iter.next();
+            names.add(p.getName());
+        }
+        for (Iterator iter = operation.getResponse().getParameters();
+            iter.hasNext();
+            ) {
+            Parameter p = (Parameter)iter.next();
+            names.add(p.getName());
+        }
+        String candidateName = baseName;
+        while (names.contains(candidateName)) {
+            candidateName += "_prime";
+        }
+        return candidateName;
+    }
+
+    protected String getNonQualifiedNameFor(QName name) {
+        return _env.getNames().validJavaClassName(name.getLocalPart());
+    }
+
+    protected static void setDocumentationIfPresent(
+        ModelObject obj,
+        Documentation documentation) {
+        if (documentation != null && documentation.getContent() != null) {
+            obj.setProperty(WSDL_DOCUMENTATION, documentation.getContent());
+        }
+    }
+
+    protected static QName getQNameOf(GloballyKnown entity) {
+        return new QName(
+            entity.getDefining().getTargetNamespaceURI(),
+            entity.getName());
+    }
+
+    protected static Extension getExtensionOfType(
+            Extensible extensible,
+            Class type) {
+        for (Iterator iter = extensible.extensions(); iter.hasNext();) {
+            Extension extension = (Extension)iter.next();
+            if (extension.getClass().equals(type)) {
+                return extension;
+            }
+        }
+
+        return null;
+    }
+
+    protected Extension getAnyExtensionOfType(
+        Extensible extensible,
+        Class type) {
+        if(extensible == null)
+            return null;
+        for (Iterator iter = extensible.extensions(); iter.hasNext();) {
+            Extension extension = (Extension)iter.next();
+            if(extension.getClass().equals(type)) {
+                return extension;
+            }else if (extension.getClass().equals(MIMEMultipartRelated.class) &&
+                    (type.equals(SOAPBody.class) || type.equals(MIMEContent.class)
+                            || type.equals(MIMEPart.class))) {
+                for (Iterator parts =
+                    ((MIMEMultipartRelated) extension).getParts();
+                parts.hasNext();
+                ) {
+                    Extension part = (Extension) parts.next();
+                    if (part.getClass().equals(MIMEPart.class)) {
+                        MIMEPart mPart = (MIMEPart)part;
+                        //bug fix: 5024001
+                        Extension extn =  getExtensionOfType((Extensible) part, type);
+                        if(extn != null)
+                            return extn;
+                    }
+                }
+            }
+        }
+
+        return null;
+    }
+
+    // bug fix: 4857100
+    protected static com.sun.tools.internal.ws.wsdl.document.Message findMessage(
+        QName messageName,
+        ProcessSOAPOperationInfo info) {
+        com.sun.tools.internal.ws.wsdl.document.Message message = null;
+        try {
+            message =
+                (com.sun.tools.internal.ws.wsdl.document.Message)info.document.find(
+                    Kinds.MESSAGE,
+                    messageName);
+        } catch (NoSuchEntityException e) {
+        }
+        return message;
+    }
+
+    protected static boolean tokenListContains(
+        String tokenList,
+        String target) {
+        if (tokenList == null) {
+            return false;
+        }
+
+        StringTokenizer tokenizer = new StringTokenizer(tokenList, " ");
+        while (tokenizer.hasMoreTokens()) {
+            String s = tokenizer.nextToken();
+            if (target.equals(s)) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    protected String getUniqueClassName(String className) {
+        int cnt = 2;
+        String uniqueName = className;
+        while (reqResNames.contains(uniqueName.toLowerCase())) {
+            uniqueName = className + cnt;
+            cnt++;
+        }
+        reqResNames.add(uniqueName.toLowerCase());
+        return uniqueName;
+    }
+
+    private String getJavaPackageName(QName name) {
+        String packageName = null;
+/*        if (_modelInfo.getNamespaceMappingRegistry() != null) {
+            NamespaceMappingInfo i =
+                _modelInfo
+                    .getNamespaceMappingRegistry()
+                    .getNamespaceMappingInfo(
+                    name);
+            if (i != null)
+                return i.getJavaPackageName();
+        }*/
+        return packageName;
+    }
+
+    protected boolean isConflictingClassName(String name) {
+        if (_conflictingClassNames == null) {
+            return false;
+        }
+
+        return _conflictingClassNames.contains(name);
+    }
+
+    protected boolean isConflictingServiceClassName(String name) {
+        return isConflictingClassName(name);
+    }
+
+    protected boolean isConflictingStubClassName(String name) {
+        return isConflictingClassName(name);
+    }
+
+    protected boolean isConflictingTieClassName(String name) {
+        return isConflictingClassName(name);
+    }
+
+    protected boolean isConflictingPortClassName(String name) {
+        return isConflictingClassName(name);
+    }
+
+    protected boolean isConflictingExceptionClassName(String name) {
+        return isConflictingClassName(name);
+    }
+
+    protected static final String OPERATION_HAS_VOID_RETURN_TYPE =
+        "com.sun.xml.internal.ws.processor.modeler.wsdl.operationHasVoidReturnType";
+    private static final String WSDL_DOCUMENTATION =
+        "com.sun.xml.internal.ws.processor.modeler.wsdl.documentation";
+    protected static final String WSDL_PARAMETER_ORDER =
+        "com.sun.xml.internal.ws.processor.modeler.wsdl.parameterOrder";
+    public static final String WSDL_RESULT_PARAMETER =
+        "com.sun.xml.internal.ws.processor.modeler.wsdl.resultParameter";
+    public static final String MESSAGE_HAS_MIME_MULTIPART_RELATED_BINDING =
+        "com.sun.xml.internal.ws.processor.modeler.wsdl.mimeMultipartRelatedBinding";
+
+
+    public ProcessorEnvironment getProcessorEnvironment(){
+        return _env;
+    }
+    protected ProcessSOAPOperationInfo info;
+
+    protected WSDLModelInfo _modelInfo;
+    protected Properties _options;
+    protected LocalizableMessageFactory _messageFactory;
+    private Set _conflictingClassNames;
+    protected Map _javaExceptions;
+    protected Map _faultTypeToStructureMap;
+    private ProcessorEnvironment _env;
+    protected JavaSimpleTypeCreator _javaTypes;
+    protected Map<QName, Port> _bindingNameToPortMap;
+    protected boolean useWSIBasicProfile = true;
+
+    private Set reqResNames;
+    public class ProcessSOAPOperationInfo {
+
+        public ProcessSOAPOperationInfo(
+            Port modelPort,
+            com.sun.tools.internal.ws.wsdl.document.Port port,
+            com.sun.tools.internal.ws.wsdl.document.Operation portTypeOperation,
+            BindingOperation bindingOperation,
+            SOAPBinding soapBinding,
+            WSDLDocument document,
+            boolean hasOverloadedOperations,
+            Map headers) {
+            this.modelPort = modelPort;
+            this.port = port;
+            this.portTypeOperation = portTypeOperation;
+            this.bindingOperation = bindingOperation;
+            this.soapBinding = soapBinding;
+            this.document = document;
+            this.hasOverloadedOperations = hasOverloadedOperations;
+            this.headers = headers;
+        }
+
+        public Port modelPort;
+        public com.sun.tools.internal.ws.wsdl.document.Port port;
+        public com.sun.tools.internal.ws.wsdl.document.Operation portTypeOperation;
+        public BindingOperation bindingOperation;
+        public SOAPBinding soapBinding;
+        public WSDLDocument document;
+        public boolean hasOverloadedOperations;
+        public Map headers;
+
+        // additional data
+        public Operation operation;
+        public String uniqueOperationName;
+    }
+
+    public static class WSDLExceptionInfo {
+        public String exceptionType;
+        public QName wsdlMessage;
+        public String wsdlMessagePartName;
+        public HashMap constructorOrder; // mapping of element name to
+                                             // constructor order (of type Integer)
+    };
+
+
+    protected WSDLParser parser;
+    protected WSDLDocument document;
+    protected HashSet hSet;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ClassNameCollector.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ClassNameCollector.java
new file mode 100644
index 0000000..9c75e79
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ClassNameCollector.java
@@ -0,0 +1,271 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.util;
+
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.processor.model.AbstractType;
+import com.sun.tools.internal.ws.processor.model.Block;
+import com.sun.tools.internal.ws.processor.model.ExtendedModelVisitor;
+import com.sun.tools.internal.ws.processor.model.Fault;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.model.ModelProperties;
+import com.sun.tools.internal.ws.processor.model.Parameter;
+import com.sun.tools.internal.ws.processor.model.Port;
+import com.sun.tools.internal.ws.processor.model.Service;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBType;
+import com.sun.tools.internal.ws.processor.model.jaxb.JAXBTypeVisitor;
+import com.sun.tools.internal.ws.processor.model.jaxb.RpcLitStructure;
+import com.sun.tools.internal.ws.processor.model.java.JavaInterface;
+import com.sun.xml.internal.ws.util.VersionUtil;
+
+/**
+ * This class writes out a Model as an XML document.
+ *
+ * @author WS Development Team
+ */
+public class ClassNameCollector extends ExtendedModelVisitor
+    implements JAXBTypeVisitor {
+
+    public ClassNameCollector() {
+    }
+
+    public void process(Model model) {
+        try {
+            _allClassNames = new HashSet();
+            _exceptions = new HashSet();
+            _wsdlBindingNames = new HashSet();
+            _conflictingClassNames = new HashSet();
+            _seiClassNames = new HashSet<String>();
+            _jaxbGeneratedClassNames = new HashSet<String>();
+            _exceptionClassNames = new HashSet<String>();
+            _portTypeNames = new HashSet<QName>();
+            visit(model);
+        } catch (Exception e) {
+            e.printStackTrace();
+            // fail silently
+        } finally {
+            _allClassNames = null;
+            _exceptions = null;
+        }
+    }
+
+    public Set getConflictingClassNames() {
+        return _conflictingClassNames;
+    }
+
+    protected void postVisit(Model model) throws Exception {
+        for (Iterator iter = model.getExtraTypes(); iter.hasNext();) {
+            visitType((AbstractType)iter.next());
+        }
+    }
+
+    protected void preVisit(Service service) throws Exception {
+        registerClassName(
+            ((JavaInterface)service.getJavaInterface()).getName());
+        registerClassName(
+            ((JavaInterface)service.getJavaInterface()).getImpl());
+    }
+
+    protected void processPort11x(Port port){
+        QName wsdlBindingName = (QName) port.getProperty(
+            ModelProperties.PROPERTY_WSDL_BINDING_NAME);
+        if (!_wsdlBindingNames.contains(wsdlBindingName)) {
+
+            // multiple ports can share a binding without causing a conflict
+            registerClassName(port.getJavaInterface().getName());
+        }
+        registerClassName((String) port.getProperty(
+            ModelProperties.PROPERTY_STUB_CLASS_NAME));
+        registerClassName((String) port.getProperty(
+            ModelProperties.PROPERTY_TIE_CLASS_NAME));
+    }
+
+    protected void preVisit(Port port) throws Exception {
+        QName portTypeName = (QName)port.getProperty(ModelProperties.PROPERTY_WSDL_PORT_TYPE_NAME);
+        if(_portTypeNames.contains(portTypeName))
+            return;
+
+        //in 2.0, stub/tie class are binding agnostic so they should be per port, that is multiple
+        // bindings can share the same port
+
+        addSEIClassName(port.getJavaInterface().getName());
+    }
+
+    private void addSEIClassName(String s) {
+        _seiClassNames.add(s);
+        registerClassName(s);
+    }
+
+    protected void postVisit(Port port) throws Exception {
+        QName wsdlBindingName = (QName) port.getProperty(
+            ModelProperties.PROPERTY_WSDL_BINDING_NAME);
+        if (!_wsdlBindingNames.contains(wsdlBindingName)) {
+            _wsdlBindingNames.add(wsdlBindingName);
+        }
+
+        QName portTypeName = (QName)port.getProperty(ModelProperties.PROPERTY_WSDL_PORT_TYPE_NAME);
+        if(!_portTypeNames.contains(portTypeName)){
+            _portTypeNames.add(portTypeName);
+        }
+    }
+
+    protected boolean shouldVisit(Port port) {
+        QName wsdlBindingName = (QName) port.getProperty(
+            ModelProperties.PROPERTY_WSDL_BINDING_NAME);
+        return !_wsdlBindingNames.contains(wsdlBindingName);
+    }
+
+    protected void preVisit(Fault fault) throws Exception {
+        if (!_exceptions.contains(fault.getJavaException())) {
+
+            /* the same exception can be used in several faults, but that
+             * doesn't mean that there is a conflict
+             */
+            _exceptions.add(fault.getJavaException());
+            addExceptionClassName(fault.getJavaException().getName());
+
+            if (fault.getParentFault() != null) {
+                preVisit(fault.getParentFault());
+            }
+            for (Iterator iter = fault.getSubfaults();
+                iter != null && iter.hasNext();) {
+
+                Fault subfault = (Fault) iter.next();
+                preVisit(subfault);
+            }
+        }
+    }
+
+    private void addExceptionClassName(String name) {
+        if(_allClassNames.contains(name))
+            _exceptionClassNames.add(name);
+        registerClassName(name);
+        //To change body of created methods use File | Settings | File Templates.
+    }
+
+    protected void visitBodyBlock(Block block) throws Exception {
+        visitBlock(block);
+    }
+
+    protected void visitHeaderBlock(Block block) throws Exception {
+        visitBlock(block);
+    }
+
+    protected void visitFaultBlock(Block block) throws Exception {
+    }
+
+    protected void visitBlock(Block block) throws Exception {
+        visitType(block.getType());
+    }
+
+    protected void visit(Parameter parameter) throws Exception {
+        visitType(parameter.getType());
+    }
+
+    private void visitType(AbstractType type) throws Exception {
+        if (type != null) {
+            if (type instanceof JAXBType)
+                visitType((JAXBType)type);
+            else if (type instanceof RpcLitStructure)
+                visitType((RpcLitStructure)type);
+        }
+    }
+
+
+    private void visitType(JAXBType type) throws Exception {
+        type.accept(this);
+    }
+
+    private void visitType(RpcLitStructure type) throws Exception {
+        type.accept(this);
+    }
+    private void registerClassName(String name) {
+        if (name == null || name.equals("")) {
+            return;
+        }
+        if (_allClassNames.contains(name)) {
+            _conflictingClassNames.add(name);
+        } else {
+            _allClassNames.add(name);
+        }
+    }
+
+    public Set<String> getSeiClassNames() {
+        return _seiClassNames;
+    }
+
+    private Set<String> _seiClassNames;
+
+    public Set<String> getJaxbGeneratedClassNames() {
+        return _jaxbGeneratedClassNames;
+    }
+
+    private Set<String> _jaxbGeneratedClassNames;
+
+
+    public Set<String> getExceptionClassNames() {
+        return _exceptionClassNames;
+    }
+
+    private Set<String> _exceptionClassNames;
+    boolean doneVisitingJAXBModel = false;
+    public void visit(JAXBType type) throws Exception {
+        if(!doneVisitingJAXBModel){
+            Set<String> classNames = type.getJaxbModel().getGeneratedClassNames();
+            for(String className : classNames){
+                addJAXBGeneratedClassName(className);
+            }
+            doneVisitingJAXBModel = true;
+        }
+    }
+
+    public void visit(RpcLitStructure type) throws Exception {
+        if(!doneVisitingJAXBModel){
+            Set<String> classNames = type.getJaxbModel().getGeneratedClassNames();
+            for(String className : classNames){
+                addJAXBGeneratedClassName(className);
+            }
+            doneVisitingJAXBModel = true;
+        }
+    }
+
+
+    private void addJAXBGeneratedClassName(String name) {
+        _jaxbGeneratedClassNames.add(name);
+        registerClassName(name);
+    }
+
+    private Set _allClassNames;
+    private Set _exceptions;
+    private Set _wsdlBindingNames;
+    private Set _conflictingClassNames;
+    private Set<QName> _portTypeNames;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ClientProcessorEnvironment.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ClientProcessorEnvironment.java
new file mode 100644
index 0000000..5dad023
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ClientProcessorEnvironment.java
@@ -0,0 +1,224 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.util;
+
+import java.io.File;
+import java.io.OutputStream;
+import java.io.PrintStream;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import com.sun.tools.internal.ws.processor.ProcessorNotificationListener;
+import com.sun.tools.internal.ws.processor.generator.Names;
+import com.sun.tools.internal.ws.util.JAXWSClassFactory;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class ClientProcessorEnvironment extends ProcessorEnvironmentBase
+    implements ProcessorEnvironment {
+
+    /**
+     * The stream where error message are printed.
+     */
+    private OutputStream out;
+
+    /**
+     * A printwriter created lazily in case there are exceptions to report.
+     */
+    private PrintStream outprintstream;
+
+    /**
+     * listener for error/warning/info notifications
+     */
+    private ProcessorNotificationListener listener;
+
+    /**
+     * The classpath to use
+     */
+    private String classPath;
+
+    /**
+     * list of generated source files created in this environment and
+     * its type
+     */
+    private List generatedFiles = new ArrayList();
+
+    /**
+     * The number of errors and warnings
+     */
+    private int nwarnings;
+    private int nerrors;
+
+    /**
+     * flags
+     */
+    private int flags;
+
+    private Names names;
+
+    /**
+     * Create a ClientProcessorEnvironment with the given class path,
+     * stream for messages and ProcessorNotificationListener.
+     */
+    public ClientProcessorEnvironment(
+        OutputStream out,
+        String classPath,
+        ProcessorNotificationListener listener) {
+
+        this.out = out;
+        this.classPath = classPath;
+        this.listener = listener;
+        flags = 0;
+
+        //bug fix:4904604
+        names = JAXWSClassFactory.newInstance().createNames();
+    }
+
+    /**
+     * Set the environment flags
+     */
+    public void setFlags(int flags) {
+        this.flags = flags;
+    }
+
+    /**
+     * Get the environment flags
+     */
+    public int getFlags() {
+        return flags;
+    }
+
+    /**
+     * Get the ClassPath.
+     */
+    public String getClassPath() {
+        return classPath;
+    }
+
+    /**
+     * Is verbose turned on
+     */
+    public boolean verbose() {
+        return (flags & F_VERBOSE) != 0;
+    }
+
+    /**
+     * Remember info on  generated source file generated so that it
+     * can be removed later, if appropriate.
+     */
+    public void addGeneratedFile(GeneratedFileInfo file) {
+        generatedFiles.add(file);
+    }
+
+    /**
+     * Return all the generated files and its types.
+     */
+    public Iterator getGeneratedFiles() {
+        return generatedFiles.iterator();
+    }
+
+    /**
+     * Delete all the generated source files made during the execution
+     * of this environment (those that have been registered with the
+     * "addGeneratedFile" method).
+     */
+    public void deleteGeneratedFiles() {
+        synchronized (generatedFiles) {
+            Iterator iter = generatedFiles.iterator();
+            while (iter.hasNext()) {
+                File file = ((GeneratedFileInfo)iter.next()).getFile();
+                if (file.getName().endsWith(".java")) {
+                    file.delete();
+                }
+            }
+            generatedFiles.clear();
+        }
+    }
+
+    /**
+     * Release resources, if any.
+     */
+    public void shutdown() {
+        listener = null;
+        generatedFiles = null;
+    }
+
+    public void error(Localizable msg) {
+        if (listener != null) {
+            listener.onError(msg);
+        }
+        nerrors++;
+    }
+
+    public void warn(Localizable msg) {
+        if (warnings()) {
+            nwarnings++;
+            if (listener != null) {
+                listener.onWarning(msg);
+            }
+        }
+    }
+
+    public void info(Localizable msg) {
+        if (listener != null) {
+            listener.onInfo(msg);
+        }
+    }
+
+    public void printStackTrace(Throwable t) {
+        if (outprintstream == null) {
+            outprintstream = new PrintStream(out);
+        }
+        t.printStackTrace(outprintstream);
+    }
+
+    public Names getNames() {
+        return names;
+    }
+
+    public int getErrorCount() {
+        return nerrors;
+    }
+
+    public int getWarningCount() {
+        return nwarnings;
+    }
+
+    private boolean warnings() {
+        return (flags & F_WARNINGS) != 0;
+    }
+
+    //bug fix:4904604
+    //to called in compileTool after env is
+    public void setNames(Names names) {
+        this.names = names;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/DirectoryUtil.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/DirectoryUtil.java
new file mode 100644
index 0000000..3a9e079
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/DirectoryUtil.java
@@ -0,0 +1,103 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.util;
+
+import java.io.File;
+
+import com.sun.tools.internal.ws.processor.generator.GeneratorException;
+import com.sun.tools.internal.ws.util.ClassNameInfo;
+
+/**
+ * Util provides static utility methods used by other wscompile classes.
+ *
+ * @author WS Development Team
+ */
+public class DirectoryUtil  {
+
+    public static File getOutputDirectoryFor(String theClass,
+        File rootDir, ProcessorEnvironment env) throws GeneratorException {
+
+        File outputDir = null;
+        String qualifiedClassName = theClass;
+        String packagePath = null;
+        String packageName = ClassNameInfo.getQualifier(qualifiedClassName);
+        if (packageName != null && packageName.length() > 0) {
+            packagePath = packageName.replace('.', File.separatorChar);
+        }
+
+        // Do we have a root directory?
+        if (rootDir != null) {
+
+            // Yes, do we have a package name?
+            if (packagePath != null) {
+
+                // Yes, so use it as the root. Open the directory...
+                outputDir = new File(rootDir, packagePath);
+
+                // Make sure the directory exists...
+                ensureDirectory(outputDir,env);
+            } else {
+
+                // Default package, so use root as output dir...
+                outputDir = rootDir;
+            }
+        } else {
+
+            // No root directory. Get the current working directory...
+            String workingDirPath = System.getProperty("user.dir");
+            File workingDir = new File(workingDirPath);
+
+            // Do we have a package name?
+            if (packagePath == null) {
+
+                // No, so use working directory...
+                outputDir = workingDir;
+            } else {
+
+                // Yes, so use working directory as the root...
+                outputDir = new File(workingDir, packagePath);
+
+                // Make sure the directory exists...
+                ensureDirectory(outputDir,env);
+            }
+        }
+
+        // Finally, return the directory...
+        return outputDir;
+    }
+
+    private static void ensureDirectory(File dir, ProcessorEnvironment env)
+        throws GeneratorException {
+
+        if (!dir.exists()) {
+            dir.mkdirs();
+            if (!dir.exists()) {
+                throw new GeneratorException("generator.cannot.create.dir",
+                    dir.getAbsolutePath());
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/GeneratedFileInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/GeneratedFileInfo.java
new file mode 100644
index 0000000..b56cc96
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/GeneratedFileInfo.java
@@ -0,0 +1,82 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.util;
+
+import java.io.File;
+
+/**
+ * A container to hold info on the files that get
+ * generated.
+ *
+ * @author WS Development Team
+ */
+public class GeneratedFileInfo {
+
+    /**
+     * local variables
+     */
+    private File file = null;
+    private String type = null;
+
+    /* constructor */
+    public GeneratedFileInfo() {}
+
+    /**
+     * Adds the file object to the container
+     *
+     * @param file instance of the file to be added
+     */
+    public void setFile( File file ) {
+        this.file = file;
+    }
+
+    /**
+     * Adds the type of file it is the container
+     *
+     * @param type string which specifices the type
+     */
+    public void setType( String type ) {
+        this.type = type;
+    }
+
+    /**
+     * Gets the file that got added
+     *
+     * @return File that got added
+     */
+    public File getFile() {
+        return( file );
+    }
+
+    /**
+     * Get the file type that got added
+     *
+     * @return File type of datatype String
+     */
+    public String getType() {
+        return ( type );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/IndentingWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/IndentingWriter.java
new file mode 100644
index 0000000..9953023
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/IndentingWriter.java
@@ -0,0 +1,330 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.util;
+
+import java.io.BufferedWriter;
+import java.io.IOException;
+import java.io.Writer;
+
+import java.nio.charset.Charset;
+import java.nio.charset.CharsetEncoder;
+import java.text.MessageFormat;
+import com.sun.tools.internal.ws.processor.generator.GeneratorException;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class IndentingWriter extends BufferedWriter {
+
+    private boolean beginningOfLine = true;
+    private int currentIndent = 0;
+    private int indentStep = 4;
+
+    public IndentingWriter(Writer out) {
+        super(out);
+    }
+
+    public IndentingWriter(Writer out,int step) {
+        this(out);
+
+        if (indentStep < 0) {
+            throw new IllegalArgumentException("negative indent step");
+        }
+        indentStep = step;
+    }
+
+    public void write(int c) throws IOException {
+        checkWrite();
+        super.write(c);
+    }
+
+    public void write(char[] cbuf, int off, int len) throws IOException {
+        if (len > 0) {
+            checkWrite();
+        }
+        super.write(cbuf, off, len);
+    }
+
+    public void write(String s, int off, int len) throws IOException {
+        if (len > 0) {
+            checkWrite();
+        }
+        super.write(s, off, len);
+    }
+
+    public void newLine() throws IOException {
+        super.newLine();
+        beginningOfLine = true;
+    }
+
+    protected void checkWrite() throws IOException {
+        if (beginningOfLine) {
+            beginningOfLine = false;
+            int i = currentIndent;
+            while (i > 0) {
+                super.write(' ');
+                -- i;
+            }
+        }
+    }
+
+    protected void indentIn() {
+        currentIndent += indentStep;
+    }
+
+    protected void indentOut() {
+        currentIndent -= indentStep;
+        if (currentIndent < 0) {
+            currentIndent = 0;
+        }
+    }
+
+    public void pI() {
+        indentIn();
+    }
+
+    public void pO() {
+        indentOut();
+    }
+
+    public void pI(int levels) {
+        for (int i = 0; i < levels; ++i) {
+            indentIn();
+        }
+    }
+
+    public void pO(int levels) {
+        for (int i = 0; i < levels; ++i) {
+            indentOut();
+        }
+    }
+
+    public void p(String s) throws IOException {
+        /*
+        int tabCount = 0;
+        for (int i = 0; i < s.length(); ++i) {
+            if (s.charAt(i) == '\t') {
+                ++tabCount;
+                indentIn();
+            }
+        }
+
+        String printStr = s.substring(tabCount);
+         */
+        boolean canEncode = true;
+
+        //bug fix: 4839636
+        try{
+            if(!canEncode(s)) {
+                canEncode = false;
+            }
+        } catch (Throwable t) {
+
+            // there was some exception, what should we do?
+            // lets ignore it for now and proceed with the code generation!
+        }
+
+        if(!canEncode) {
+            throw new GeneratorException(
+                "generator.indentingwriter.charset.cantencode", s);
+        }
+        write(s);
+/*
+        while (tabCount-- > 0) {
+            indentOut();
+        }
+ */
+    }
+
+    /**
+     * Check if encode can handle the chars in this string.
+     *
+     */
+    protected boolean canEncode(String s) {
+        final CharsetEncoder encoder =
+            Charset.forName(System.getProperty("file.encoding")).newEncoder();
+        char[] chars = s.toCharArray();
+        for (int i=0; i<chars.length; i++) {
+            if(!encoder.canEncode(chars[i])) {
+                return false;
+            }
+        }
+        return true;
+    }
+
+    public void p(String s1, String s2) throws IOException {
+        p(s1);
+        p(s2);
+    }
+
+    public void p(String s1, String s2, String s3) throws IOException {
+        p(s1);
+        p(s2);
+        p(s3);
+    }
+
+    public void p(String s1, String s2, String s3, String s4) throws IOException {
+        p(s1);
+        p(s2);
+        p(s3);
+        p(s4);
+    }
+
+    public void p(String s1, String s2, String s3, String s4, String s5) throws IOException {
+        p(s1);
+        p(s2);
+        p(s3);
+        p(s4);
+        p(s5);
+    }
+
+    public void pln() throws IOException {
+        newLine();
+    }
+
+    public void pln(String s) throws IOException {
+        p(s);
+        pln();
+    }
+
+    public void pln(String s1, String s2) throws IOException {
+        p(s1, s2);
+        pln();
+    }
+
+    public void pln(String s1, String s2, String s3) throws IOException {
+        p(s1, s2, s3);
+        pln();
+    }
+
+    public void pln(String s1, String s2, String s3, String s4) throws IOException {
+        p(s1, s2, s3, s4);
+        pln();
+    }
+
+    public void pln(String s1, String s2, String s3, String s4, String s5) throws IOException {
+        p(s1, s2, s3, s4, s5);
+        pln();
+    }
+
+    public void plnI(String s) throws IOException {
+        p(s);
+        pln();
+        pI();
+    }
+
+    public void pO(String s) throws IOException {
+        pO();
+        p(s);
+    }
+
+    public void pOln(String s) throws IOException {
+        pO(s);
+        pln();
+    }
+
+    public void pOlnI(String s) throws IOException {
+        pO(s);
+        pln();
+        pI();
+    }
+
+    public void p(Object o) throws IOException {
+        write(o.toString());
+    }
+
+    public void pln(Object o) throws IOException {
+        p(o.toString());
+        pln();
+    }
+
+    public void plnI(Object o) throws IOException {
+        p(o.toString());
+        pln();
+        pI();
+    }
+
+    public void pO(Object o) throws IOException {
+        pO();
+        p(o.toString());
+    }
+
+    public void pOln(Object o) throws IOException {
+        pO(o.toString());
+        pln();
+    }
+
+    public void pOlnI(Object o) throws IOException {
+        pO(o.toString());
+        pln();
+        pI();
+    }
+
+    public void pM(String s) throws IOException {
+        int i = 0;
+        while (i < s.length()) {
+            int j = s.indexOf('\n', i);
+            if (j == -1) {
+                p(s.substring(i));
+                break;
+            } else {
+                pln(s.substring(i, j));
+                i = j + 1;
+            }
+        }
+    }
+
+    public void pMln(String s) throws IOException {
+        pM(s);
+        pln();
+    }
+
+    public void pMlnI(String s) throws IOException {
+        pM(s);
+        pln();
+        pI();
+    }
+
+    public void pMO(String s) throws IOException {
+        pO();
+        pM(s);
+    }
+
+    public void pMOln(String s) throws IOException {
+        pMO(s);
+        pln();
+    }
+
+    public void pF(String pattern, Object[] arguments) throws IOException {
+        pM(MessageFormat.format(pattern, arguments));
+    }
+
+    public void pFln(String pattern, Object[] arguments) throws IOException {
+        pF(pattern, arguments);
+        pln();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ProcessorEnvironment.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ProcessorEnvironment.java
new file mode 100644
index 0000000..10d704d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ProcessorEnvironment.java
@@ -0,0 +1,108 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.util;
+
+import java.net.URLClassLoader;
+import java.util.Iterator;
+
+import com.sun.tools.internal.ws.processor.generator.Names;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+import com.sun.mirror.apt.Filer;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface ProcessorEnvironment {
+
+    /*
+     * Flags
+     */
+    int F_VERBOSE       = 1 << 0;
+    int F_WARNINGS      = 1 << 1;
+
+    /**
+     * Set the environment flags
+     */
+    public void setFlags(int flags);
+
+    /**
+     * Get the environment flags
+     */
+    public int getFlags();
+
+    /**
+     * Get the ClassPath.
+     */
+    public String getClassPath();
+
+    /**
+     * Is verbose turned on
+     */
+    public boolean verbose();
+
+    /**
+     * Remember a generated file and its type so that it
+     * can be removed later, if appropriate.
+     */
+    public void addGeneratedFile(GeneratedFileInfo file);
+
+    public Filer getFiler();
+    public void setFiler(Filer filer);
+
+    /**
+     * Delete all the generated files made during the execution of this
+     * environment (those that have been registered with the "addGeneratedFile"
+     * method)
+     */
+    public void deleteGeneratedFiles();
+
+    /**
+     * Get a URLClassLoader from using the classpath
+     */
+    public URLClassLoader getClassLoader();
+
+    public Iterator getGeneratedFiles();
+
+    /**
+     * Release resources, if any.
+     */
+    public void shutdown();
+
+    public void error(Localizable msg);
+
+    public void warn(Localizable msg);
+
+    public void info(Localizable msg);
+
+    public void printStackTrace(Throwable t);
+
+    public Names getNames();
+
+    public int getErrorCount();
+    public int getWarningCount();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ProcessorEnvironmentBase.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ProcessorEnvironmentBase.java
new file mode 100644
index 0000000..815d923
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/processor/util/ProcessorEnvironmentBase.java
@@ -0,0 +1,119 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.processor.util;
+
+import java.io.File;
+import java.io.IOException;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.net.URLClassLoader;
+import java.util.StringTokenizer;
+import com.sun.mirror.apt.Filer;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public abstract class ProcessorEnvironmentBase implements ProcessorEnvironment {
+
+    protected URLClassLoader classLoader = null;
+    protected Filer filer = null;
+
+    /**
+     * Get a URLClassLoader from using the classpath
+     */
+    public URLClassLoader getClassLoader() {
+        if (classLoader == null) {
+            classLoader =
+                new URLClassLoader(pathToURLs(getClassPath()),
+                    this.getClass().getClassLoader());
+        }
+        return classLoader;
+    }
+
+    /**
+     * Utility method for converting a search path string to an array
+     * of directory and JAR file URLs.
+     *
+     * @param path the search path string
+     * @return the resulting array of directory and JAR file URLs
+     */
+    public static URL[] pathToURLs(String path) {
+        StringTokenizer st = new StringTokenizer(path, File.pathSeparator);
+        URL[] urls = new URL[st.countTokens()];
+        int count = 0;
+        while (st.hasMoreTokens()) {
+            URL url = fileToURL(new File(st.nextToken()));
+            if (url != null) {
+                urls[count++] = url;
+            }
+        }
+        if (urls.length != count) {
+            URL[] tmp = new URL[count];
+            System.arraycopy(urls, 0, tmp, 0, count);
+            urls = tmp;
+        }
+        return urls;
+    }
+
+    /**
+     * Returns the directory or JAR file URL corresponding to the specified
+     * local file name.
+     *
+     * @param file the File object
+     * @return the resulting directory or JAR file URL, or null if unknown
+     */
+    public static URL fileToURL(File file) {
+        String name;
+        try {
+            name = file.getCanonicalPath();
+        } catch (IOException e) {
+            name = file.getAbsolutePath();
+        }
+        name = name.replace(File.separatorChar, '/');
+        if (!name.startsWith("/")) {
+            name = "/" + name;
+        }
+
+        // If the file does not exist, then assume that it's a directory
+        if (!file.isFile()) {
+            name = name + "/";
+        }
+        try {
+            return new URL("file", "", name);
+        } catch (MalformedURLException e) {
+            throw new IllegalArgumentException("file");
+        }
+    }
+
+    public Filer getFiler() {
+        return filer;
+    }
+
+    public void setFiler(Filer filer) {
+        this.filer = filer;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/configuration.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/configuration.properties
new file mode 100644
index 0000000..7c81f48
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/configuration.properties
@@ -0,0 +1,28 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+configuration.invalidElement=invalid element \"{2}\" in file \"{0}\" (line {1})
+configuration.notBindingFile=Ignoring: binding file "\"{0}\". It is not a jaxws or a jaxb binding file.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/generator.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/generator.properties
new file mode 100644
index 0000000..1c96d86
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/generator.properties
@@ -0,0 +1,35 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+# Generator
+generator.nestedGeneratorError=generator error: {0}
+generator.cant.write=can''t write file: {0}
+generator.cannot.create.dir=can''t create directory: {0}
+generator.internal.error.should.not.happen=internal error (should not happen): {0}
+
+
+#IndentingWriter
+generator.indentingwriter.charset.cantencode=WSDL has some characters which native java encoder can''t encode: \"{0}\"
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/javacompiler.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/javacompiler.properties
new file mode 100644
index 0000000..281ecf8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/javacompiler.properties
@@ -0,0 +1,32 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+#
+# Generic Messages
+#
+javacompiler.classpath.error={0} is not available in the classpath.
+javacompiler.nosuchmethod.error=There is no such method {0} available.
+javacompiler.error=error : {0}.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/model.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/model.properties
new file mode 100644
index 0000000..2cdeb7d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/model.properties
@@ -0,0 +1,89 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+model.nestedModelError=model error: {0}
+model.duplicate.porttype=duplicate PortType added to model: {0}
+model.duplicate.operation=duplicate Operation added to model: {0}
+model.duplicate.faultmessage=duplicate fault message added to model: {0}
+model.duplicate.part=duplicate part added to model: {0}
+model.duplicate.property=duplicate property added to model: {0}
+model.duplicate.service=duplicate service added to model: {0}
+model.invalid.message.type=invalid message type: {0}
+model.invalid.processorActionVersion=invalid ProcessorActionVersion: {0}
+
+model.schema.notImplemented=unsupported XML Schema feature ({0})
+model.schema.circularity=circularity detected in schema: \"{0}\"
+
+model.schema.unsupportedType=unsupported type ({0}): \"{1}\" (namespace: {2})
+model.schema.unsupportedType.anonymous=unsupported anonymous type ({0})
+model.schema.invalidLiteralInEnumeration=invalid literal \"{0}\" in enumeration \"{1}\" (namespace: {2})
+model.schema.invalidLiteralInEnumeration.anonymous=invalid literal \"{0}\" in anonymous enumeration
+
+model.schema.notImplemented.generatingSOAPElement=unsupported XML Schema feature: \"{0}\" in component {1}, mapping it to javax.xml.soap.SOAPElement
+
+//replacement for Uxxx codes
+model.schema.unsupportedSchemaType=unsupported schema type: \"{0}\"
+model.schema.invalidSimpleType=invalid simpleType: \"{0}\"
+model.schema.invalidSimpleType.noJavaType=no java mapping for simpleType: \"{0}\"
+model.schema.simpleTypeWithFacets=facet \"{0}\" not supported on simple type: \"{0}\"
+model.schema.unionNotSupported=simpleType: \"{0}\" derivation by xsd:union not supported
+model.schema.listNotSupported=simpleType: \"{0}\" derivation by xsd:list not supported
+model.schema.invalidSimpleType.invalidItemType=in simpleType: \"{0}\", itemType \"{1}\" can not be derived by list
+model.schema.invalidSimpleType.noItemLiteralType=in simpleType: \"{0}\", xsd:list itemType \"{1}\" is invalid
+model.schema.invalidSimpleType.noNamespaceURI=invalid simpleType: \"{0}\", had null namespaceURI
+model.schema.encoderNotFound=no encoder found for simpleType: \"{0}\"
+model.schema.invalidWildcard.allCompositor=xsd:all compositor not supported for the wildcard in schema type: \"{0}\"
+
+model.uniqueness=uniqueness constraint violation
+model.uniqueness.javastructuretype=uniqueness constraint violation, duplicate member \"{0}\" added to JavaStructureType \"{1}\"
+model.parent.type.already.set=parent of type \"{0}\" already set to \"{1}\", new value = \"{2}\"
+model.parent.fault.already.set=parent of fault \"{0}\" already set to \"{1}\", new value = \"{2}\"
+model.exporter.unsupportedClass=model exporter: unsupported class: {0}
+model.importer.nonModel=not a valid model document
+model.importer.syntaxError=syntax error in model document (line {0})
+model.importer.invalidVersion=invalid version \"{1}\" in model document (line {0})
+model.importer.invalidMinorMinorOrPatchVersion=model version \"{1}\" newer than runtime version \"{2}\" (line {0}): need to upgrade to a newer runtime
+model.importer.invalidClass=invalid class name \"{1}\" in model document (line {0})
+model.importer.invalidId=invalid id \"{1}\ in model document (line {0})
+model.importer.invalidLiteral=invalid literal value in model document (line {0})
+model.importer.invalidProperty=invalid property in model document (line {0}
+model.arraywrapper.only.one.member=LiteralArrayWrapper may only have one element member.
+model.arraywrapper.member.already.set=LiteralArrayWrapper element member already set.
+model.arraywrapper.no.parent=LiteralArrayWrapper cannot have a parent type
+model.arraywrapper.no.subtypes=LiteralArrayWrapper cannot have subtypes
+model.arraywrapper.no.content.member=LiteralArrayWrapper cannot have a content member
+model.complexType.simpleContent.reservedName=invalid attribute name: "_value" in complexType: \"{0}\", _value is JAXWS reserved name, this name is generated in the generated javabean class to hold content value in the generated javabean class for complexType/simpleContent.
+
+//JAXWS 2.0
+model.schema.elementNotFound=Element \"{0}\" not found.
+model.schema.jaxbException.message="{0}"
+model.saxparser.exception:{0}\n{1}
+
+ConsoleErrorReporter.UnknownLocation = \
+	unknown location
+
+ConsoleErrorReporter.LineXOfY = \
+	\ \ line {0} of {1}
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/modeler.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/modeler.properties
new file mode 100644
index 0000000..906ddc4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/modeler.properties
@@ -0,0 +1,213 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+# general
+modeler.nestedModelError=modeler error: {0}
+
+
+# WSDLModeler
+wsdlmodeler.multipleOutputParameters=multiple \"out\" parameters in operation: {0}
+wsdlmodeler.invalidOperation=invalid operation: {0}
+wsdlmodeler.invalidState.modelingOperation=invalid state while modeling operation: {0}
+wsdlmodeler.resultIsInOutParameter=result is \"inout\" parameter in operation: {0}
+wsdlmodeler.invalid.parameterorder.parameter=\"{0}\" specified in the parameterOrder attribute of operation \"{1}\" is not a valid part of the message.
+wsdlmodeler.invalid.parameterOrder.tooManyUnmentionedParts=more than one part left out in the parameterOrder attribute of operation \"{0}\"
+wsdlmodeler.invalid.parameterOrder.invalidParameterOrder=parameterOrder attribute on operation \"{0}\" is invalid, ignoring parameterOrder hint
+wsdlmodeler.invalid.parameter.differentTypes=parameter \"{0}\" of operation \"{1}\" appears with different types in the input and output messages
+wsdlmodeler.invalid.bindingOperation.notInPortType=in binding \"{1}\", operation \"{0}\" does not appear in the corresponding port type
+wsdlmodeler.invalid.bindingOperation.inputMissingSoapBody=input message of binding operation \"{0}\" does not have a SOAP body extension
+wsdlmodeler.invalid.bindingOperation.outputMissingSoapBody=output message of binding operation \"{0}\" does not have a SOAP body extension
+wsdlmodeler.invalid.bindingOperation.missingInputName=binding operation \"{0}\" must specify a name for its input message
+wsdlmodeler.invalid.bindingOperation.missingOutputName=binding operation \"{0}\" must specify a name for its output message
+wsdlmodeler.invalid.bindingOperation.multipleMatchingOperations=in binding \"{1}\", operation \"{0}\" does not reference a unique operation in the corresponding port type
+wsdlmodeler.invalid.bindingOperation.notFound=in binding \"{1}\", operation \"{0}\" does not match any operation in the corresponding port type
+wsdlmodeler.invalid.bindingOperation.inputSoapBody.missingNamespace=input message of binding operation \"{0}\" must specify a value for the \"namespace\" attribute
+wsdlmodeler.invalid.bindingOperation.outputSoapBody.missingNamespace=output message of binding operation \"{0}\" must specify a value for the \"namespace\" attribute
+wsdlmodeler.invalid.bindingOperation.inputHeader.missingNamespace=input header \"{1}\" of binding operation \"{0}\" must specify a value for the \"namespace\" attribute
+wsdlmodeler.invalid.bindingOperation.outputHeader.missingNamespace=output header \"{1}\" of binding operation \"{0}\" must specify a value for the \"namespace\" attribute
+wsdlmodeler.invalid.bindingFault.notUnique=fault \"{0}\" in operation \"{1}\" matches more than one fault in the corresponding port type operation
+wsdlmodeler.invalid.bindingFault.notFound=fault \"{0}\" in operation \"{1}\" does not match any fault in the corresponding port type operation
+wsdlmodeler.invalid.bindingFault.outputMissingSoapFault=fault \"{0}\" in operation \"{1}\" does not have a SOAP fault extension
+wsdlmodeler.invalid.bindingFault.missingName=fault \"{0}\" in operation \"{1}\" must specify a value for the \"name\" attribute
+wsdlmodeler.invalid.bindingFault.missingNamespace=fault \"{0}\" in operation \"{1}\" must specify a value for the \"namespace\" attribute
+wsdlmodeler.invalid.bindingFault.emptyMessage=fault \"{0}\" refers to message \"{1}\", but the message has no parts
+wsdlmodeler.invalid.bindingFault.messageHasMoreThanOnePart=fault \"{0}\" refers to message \"{1}\", but the message has more than one parts
+wsdlmodeler.invalid.message.partMustHaveTypeDescriptor=in message \"{0}\", part \"{1}\" must specify a \"type\" attribute
+wsdlmodeler.invalid.message.partMustHaveElementDescriptor=in message \"{0}\", part \"{1}\" must specify a \"element\" attribute
+wsdlmodeler.invalid=invalid WSDL document
+wsdlmodeler.unsolvableNamingConflicts=the following naming conflicts occurred: {0}
+#
+wsdlmodeler.warning.ignoringUnrecognizedSchemaExtension=ignoring schema element (unsupported version): {0}
+wsdlmodeler.warning.searchSchema.unrecognizedTypes=encountered {0} unrecognized type(s)
+wsdlmodeler.warning.noServiceDefinitionsFound=WSDL document does not define any services
+wsdlmodeler.warning.noPortsInService=Service \"{0}\" does not contain any usable ports
+wsdlmodeler.warning.noOperationsInPort=Port \"{0}\" does not contain any usable operations
+wsdlmodeler.warning.ignoringNonSOAPPort=ignoring port \"{0}\": not a SOAP port
+wsdlmodeler.warning.ignoringNonSOAPPort.noAddress=ignoring port \"{0}\": no SOAP address specified
+wsdlmodeler.warning.ignoringSOAPBinding.nonHTTPTransport:ignoring SOAP port \"{0}\": unrecognized transport
+
+#BP1.1 R2705
+wsdlmodeler.warning.ignoringSOAPBinding.mixedStyle=ignoring SOAP port \"{0}\", its not WS-I BP 1.1 compliant: the wsdl binding has mixed style, it must be rpc-literal or document-literal operation!
+wsdlmodeler.warning.port.SOAPBinding.mixedStyle=not a WS-I BP1.1 compliant SOAP port \"{0}\": the wsdl binding has mixed style, it must be rpc-literal or document-literal operation!
+
+wsdlmodeler.warning.ignoringOperation.notSupportedStyle=ignoring operation \"{0}\": not request-response or one-way
+wsdlmodeler.invalid.operation.notSupportedStyle=Invalid WSDL, wsdl:operation \"{0}\" in wsdl:portType \"{1}\": not request-response or one-way
+wsdlmodeler.warning.ignoringOperation.notEncoded=ignoring RPC-style operation \"{0}\": parameters are not encoded
+wsdlmodeler.warning.ignoringOperation.cannotHandleBodyPartsAttribute=ignoring operation \"{0}\": cannot handle \"parts\" attribute of \"soap:body\" element
+
+wsdlmodeler.warning.ignoringOperation.cannotHandleTypeMessagePart=ignoring operation \"{0}\": message part does not refer to a schema element declaration
+wsdlmodeler.invalid.doclitoperation=Invalid wsdl:operation \"{0}\": its a document-literal operation,  message part must refer to a schema element declaration
+
+wsdlmodeler.warning.ignoringOperation.cannotHandleElementMessagePart=ignoring operation \"{0}\": message part does not refer to a schema type declaration
+wsdlmodeler.invalid.rpclitoperation=Invalid wsdl:operation \"{0}\": its a rpc-literal operation,  message part must refer to a schema type declaration
+
+
+wsdlmodeler.warning.ignoringOperation.cannotHandleDocumentStyle=ignoring operation \"{0}\": cannot handle document-style operations
+wsdlmodeler.warning.bindingOperation.multiplePartBinding=Check the abstract operation \"{0}\" binding, part \"{1}\" has multiple binding. Will try to generated artiffacts anyway...
+wsdlmodeler.invalid.bindingOperation.multiplePartBinding=abstract operation \"{0}\" binding, part \"{1}\" has multiple binding.
+wsdlmodeler.warning.ignoringFaults=ignoring faults declared by operation \"{0}\"
+wsdlmodeler.warning.ignoringFault.notEncoded=ignoring literal fault \"{0}\" of binding operation \"{1}\"
+wsdlmodeler.warning.ignoringFault.notLiteral=ignoring encoded fault \"{0}\" of binding operation \"{1}\"
+wsdlmodeler.invalid.operation.fault.notLiteral=ignoring encoded fault \"{0}\" in literal binding operation \"{1}\"
+wsdlmodeler.warning.ignoringHeader=ignoring header \"{0}\" of binding operation \"{1}\"
+wsdlmodeler.warning.ignoringHeader.partFromBody=header part: \"{0}\" already bound by soapbind:body, illegal to bind the part twice
+wsdlmodeler.warning.ignoringHeader.notLiteral=ignoring header \"{0}\" of binding operation \"{1}\": not literal
+wsdlmodeler.invalid.header.notLiteral=Invalid header \"{0}\" of binding operation \"{1}\": not literal
+wsdlmodeler.warning.ignoringHeader.notFound=ignoring header \"{0}\" of binding operation \"{1}\": not found
+wsdlmodeler.invalid.header.notFound=header \"{0}\" of binding operation \"{1}\": not found
+wsdlmodeler.warning.ignoringHeader.cant.resolve.message=ignoring header \"{0}\" of binding operation \"{1}\": cannot resolve message
+wsdlmodeler.invalid.header.cant.resolve.message=header \"{0}\" of binding operation \"{1}\": cannot resolve message
+
+wsdlmodeler.warning.ignoringFault.cant.resolve.message=ignoring fault \"{0}\" of binding operation \"{1}\": cannot resolve message
+wsdlmodeler.invalid.fault.cant.resolve.message=fault message \"{0}\" in binding operation \"{1}\" could not be resolved
+
+wsdlmodeler.warning.ignoringHeader.notEncoded=ignoring header \"{0}\" of binding operation \"{1}\": not SOAP-encoded
+wsdlmodeler.warning.ignoringHeader.inconsistentDefinition=ignoring header \"{0}\" of operation \"{1}\": part not found
+#
+wsdlmodeler.warning.ignoringOperation.notLiteral=ignoring document-style operation \"{0}\": parameters are not literal
+wsdlmodeler.warning.ignoringOperation.cannotHandleMoreThanOnePartInInputMessage=ignoring operation \"{0}\": more than one part in input message
+wsdlmodeler.warning.ignoringOperation.cannotHandleEmptyInputMessage=ignoring operation \"{0}\": input message is empty
+wsdlmodeler.warning.ignoringOperation.cannotHandleMoreThanOnePartInOutputMessage=ignoring operation \"{0}\": more than one part in output message
+wsdlmodeler.warning.operation.MoreThanOnePartInMessage=Ingoring operation \"{0}\": more than one part bound to body
+wsdlmodeler.invalid.operation.MoreThanOnePartInMessage=operation \"{0}\": more than one part bound to body
+wsdlmodeler.warning.ignoringOperation.cannotHandleEmptyOutputMessage=ignoring operation \"{0}\": output message is empty
+wsdlmodeler.warning.ignoringOperation.conflictStyleInWSIMode=ignoring operation \"{0}\": binding style and operation style are conflicting
+wsdlmodeler.warning.ignoringOperation.partNotFound=ignoring operation \"{0}\": part \"{1}\" not found
+wsdlmodeler.error.partNotFound=part \"{1}\" of operation \"{0}\" could not be resolved!
+wsdlmodeler.warning.ignoringFault.documentOperation=ignoring fault \"{0}\" of document-style operation \"{1}\"
+wsdlmodler.warning.operation.use=The WSDL used has operations with literal and encoded use. -f:searchschema is not supported for this scenario.
+#wsdlmodeler.invalid.bindingFault.wrongSoapFaultName=The name of the SOAP fault extension does not match the name of the \"{0}\" fault in operation \"{1}\"
+wsdlmodeler.invalid.bindingFault.wrongSoapFaultName=name of soap:fault \"{0}\" doesn''t match the name of wsdl:fault \"{1}\" in operation \"{2}\"
+#wsdlmodeler.invalid.bindingFault.noSoapFaultName=The name of the SOAP fault extension is missing from the fault \"{0}\" in operation \"{1}\"
+wsdlmodeler.invalid.bindingFault.noSoapFaultName=soap:fault name not specified, wsdl:fault \"{0}\" in operation \"{1}\"
+
+wsdlmodeler.duplicate.fault.part.name=ignoring fault \"{0}\" of operation \"{1}\", part name \"{2}\" is not unique
+wsdlmodeler.duplicate.fault.soap.name=ignoring fault \"{0}\" of operation \"{1}\", soap:fault name \"{2}\" is not unique
+
+wsdlmodeler.warning.ignoringHeaderFault.notFound=ignoring header fault \"{0}\", cannot find part \"{1}\" in binding \"{2}\"
+wsdlmodeler.headerfault.part.notFound=part \"{1}\" not found for the header fault \"{0}\", in binding \"{2}\"
+
+wsdlmodeler.warning.ignoringHeaderFault.notLiteral=ignoring header fault part=\"{0}\" message=\"{1}\" of operation {2}, use attribute MUST be \"literal\"
+
+wsdlmodeler.warning.ignoringHeaderFault.noElementAttribute=ignoring header fault part=\"{0}\" message=\"{1}\" of operation {2}
+
+wsdlmodeler.invalid.headerfault.notLiteral=Invalid headerfault \"{0}\" of binding operation \"{1}\": not literal
+wsdlmodeler.invalid.headerfault.message.partMustHaveElementDescriptor=Invalid headerfault \"{0}\" for header {1} in operation {2}: part must specify a \"element\" attribute
+wsdlmodeler.invalid.header.message.partMustHaveElementDescriptor=Invalid header \"{0}\" in operation {1}: part must specify a \"element\" attribute
+
+
+#wsi warnings
+wsdlmodeler.warning.nonconforming.wsdl.import=Non conforming WS-I WSDL used for wsdl:import
+wsdlmodeler.warning.nonconforming.wsdl.types=Non conforming WS-I WSDL used for wsdl:types
+wsdlmodeler.warning.nonconforming.wsdl.use=Processing WS-I non conforming operation \"{0}\" with RPC-Style and SOAP-encoded
+
+# optional parts
+wsdlmodeler.error.partsNotFound=parts \"{0}\" not found in the message \"{1}\", wrong WSDL
+
+# soap 1.2
+wsdlmodeler.warning.port.SOAPBinding12=SOAP port \"{0}\": uses a non-standard SOAP 1.2 binding.
+wsdlmodeler.warning.ignoringSOAPBinding12=Ignoring SOAP port \"{0}\": it uses non-standard SOAP 1.2 binding.\nYou must specify the \"-extension\" option to use this binding.
+
+#WSI-BP1.0 Warning/Errors
+wsdlmodeler.warning.r2716=R2716 WSI-BasicProfile ver. 1.0, namespace attribute not allowed in doc/lit for {0}: \"{1}\"
+wsdlmodeler.warning.r2716r2726=R2716/R2726 WSI-BasicProfile ver. 1.0, namespace attribute not allowed in doc/lit or rpc/lit for {0}: \"{1}\"
+
+#WSI-BP 1.1 Warning/Errors
+//R2911
+mimemodeler.invalidMimePart.moreThanOneSOAPBody=Ignoring operation \"{0}\". The Multipart/Related structure has invalid root part: more than one soap:body parts found
+
+//R2906
+mimemodeler.warning.IgnoringinvalidHeaderPart.notDeclaredInRootPart=Headers not in root mime:part with soap:body, ignoring headers in operation \"{0}\"
+
+//R2909
+mimemodeler.invalidMimeContent.differentPart=Ignoring the mime:part. Invalid mime:part, the mime:content has different part attribute.
+
+mimemodeler.invalidMimeContent.invalidSchemaType=Ignoring the mime:part. mime part: {0} can not be mapped to schema type: {1}
+
+//Rxxxx A mime:content in a DESCRIPTION MUST refer to a wsdl:part element defined using the type attribute.
+mimemodeler.invalidMimeContent.mesagePartElementKind=wsdl:part element referenced by mime:content part attribute: {0} must be defined using type attribute!
+
+//RXXXX RYYYY: In a description, a mime:content element MUST include the part attribute.
+mimemodeler.invalidMimeContent.missingPartAttribute=Ignoring operation \"{0}\", missing part attribute in mime:content. part attribute must be present in mime:content declaration.
+
+mimemodeler.invalidMimeContent.missingTypeAttribute=Missing type attribute in mime:content in operation \"{0}\". part attribute must be present in mime:content declaration.
+
+//unknown schematype
+mimemodeler.invalidMimeContent.unknownSchemaType=Unknown schema type: {1} for mime:content part: {0}
+mimemodeler.invalidMimeContent.errorLoadingJavaClass=Couldn't find class \"{0}\" for mime type \"{1}\"
+
+//missing wsdl:part referenced by the mime:content
+wsdlmodeler.warning.ignoringMimePart.notFound=ignoring mime:part, cannot find part \"{0}\" referenced by the mime:content in the wsdl:operation \"{1}\"
+
+mimemodeler.elementPart.invalidElementMimeType=The mime:content part refers to wsdl:part \"{0}\", defined using element attribute. Please make sure the mime type: \"{1}\" is appropriate to serialize XML.
+
+//R2708 The mime:part element in a DESCRIPTION MUST NOT have a name attribute.
+mimemodeler.invalidMimePart.nameNotAllowed=name attribute on wsdl:part in Operation \"{0}\" is ignored. Its not allowed as per WS-I AP 1.0.
+
+
+wsdlmodeler20.rpcenc.not.supported=rpc/encoded wsdl's are not supported in JAXWS 2.0. 
+wsdlmodeler.warning.ignoringOperation.notNCName=Ignoring operation \"{0}\", it has illegal character ''{1}'' in its name. Its rpc-literal operation - jaxws won't be able to serialize it!
+
+wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.nonWrapperStyle=Ignoring operation \"{0}\", can''t generate java method. Parameter: part "{2}\" in wsdl:message \"{1}\", is a java keyword. Use customization to change the parameter name or change the wsdl:part name.
+wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.nonWrapperStyle=Invalid operation \"{0}\", can''t generate java method. Parameter: part "{2}\" in wsdl:message \"{1}\", is a java keyword. Use customization to change the parameter name or change the wsdl:part name.
+
+wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.wrapperStyle=Ignoring operation \"{0}\", can''t generate java method parameter. Local name of the wrapper child \"{1}\" in the global element \"{2}\" is a java keyword. Use customization to change the parameter name.
+wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.wrapperStyle=Invalid operation \"{0}\", can''t generate java method parameter. Local name of the wrapper child \"{1}\" in the global element \"{2}\" is a java keyword. Use customization to change the parameter name.
+
+wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.customName=Ignoring operation \"{0}\", can''t generate java method. Parameter,customized name \"{1}\" is a java keyword.
+wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.customName=Invalid operation \"{0}\", can''t generate java method. Parameter,customized name \"{1}\"  is a java keyword.
+
+wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.operationName=Ignoring operation \"{0}\", it''s java reserved word, can''t generate java method. Use customization to change the operation name.
+wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.operationName=Invalid operation \"{0}\", it''s java reserved word, can''t generate java method. Use customization to change the operation name.
+
+wsdlmodeler.warning.ignoringOperation.javaReservedWordNotAllowed.customizedOperationName=Ignoring operation \"{0}\", can''t generate java method ,customized name \"{1}\" of the wsdl:operation is a java keyword.
+wsdlmodeler.invalid.operation.javaReservedWordNotAllowed.customizedOperationName=Invalid operation \"{0}\", can''t generate java method ,customized name \"{1}\" of the wsdl:operation is a java keyword.
+
+wsdlmodeler.jaxb.javatype.notfound=Schema descriptor {0} in message part {1} could not be bound to Java!
+wsdlmodeler.unsupportedBinding.mime=WSDL MIME binding is not currently supported!
+
+wsdlmodeler.nonUnique.body=Non unique body parts! In a port, operations must have unique operation signaure on the wire for successful dispatch. In port {0}, Operations \"{1}\" and \"{2}\" have the same request body block {3}
+wsdlmodeler.rpclit.unkownschematype=XML type \"{0}\" could not be resolved, XML to JAVA binding failed! Please check the wsdl:part \"{1}\" in the wsdl:message \"{2}\".    
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/processor.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/processor.properties
new file mode 100644
index 0000000..48cc23a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/processor.properties
@@ -0,0 +1,27 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+processor.missing.model=model is missing
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/util.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/util.properties
new file mode 100644
index 0000000..799bafd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/util.properties
@@ -0,0 +1,29 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+holder.valuefield.not.found=Could not find the field in the Holder that contains the Holder''s value: {0}
+null.namespace.found=Encountered error in wsdl. Check namespace of element <{0}>
+sax2dom.notsupported.createelement=SAX2DOMEx.DomImplDoesntSupportCreateElementNs: {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/webserviceap.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/webserviceap.properties
new file mode 100644
index 0000000..eb73597
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/webserviceap.properties
@@ -0,0 +1,152 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+webserviceap.nestedModelError=modeler error: {0}
+webserviceap.fileNotFound=error: file not found: {0}
+webserviceap.error=error: {0}
+webserviceap.warning=warning: {0}
+webserviceap.info=info: {0}
+webserviceap.compilationFailed=compilation failed, errors should have been reported
+webserviceap.succeeded: Success
+
+webserviceap.method.not.annotated=The method {0} on class {1} is not annotated.
+webserviceap.rpc.encoded.not.supported=The {0} class has a rpc/encoded SOAPBinding.  Rpc/encoded SOAPBindings are not supported in JAXWS 2.0. 
+webserviceap.model.already.exists=model already exists
+webserviceap.endpointinterface.on.interface=Service endpointpoint interface\: {0} has cannot have a WebService.endpointInterface annotation\: {1}
+webserviceap.java.typeNotFound=The type: {0} was not found in the mapping
+webserviceap.endpointinterfaces.do.not.match=The endpoint interface {0} does not match the interface {1}.
+
+webserviceap.could.not.find.typedecl=Could not get TypeDeclaration for:\ {0} in apt round:\ {1}
+
+webserviceap.no.webservice.endpoint.found=A web service endpoint could not be found
+
+webserviceap.endpointinterface.has.no.webservice.annotation=The endpoint interface {0} must have a WebService annotation
+
+webserviceap.oneway.operation.cannot.have.return.type=The method {1} of class {0} is annotated @Oneway but has a return type.
+
+webserviceap.oneway.operation.cannot.have.holders=The method {1} of class {0} is annotated @Oneway but contains inout or out paramerters (javax.xml.ws.Holder)
+
+webserviceap.oneway.operation.cannot.declare.exceptions=The method {1} of class {0} is annotated @Oneway but declares the exception {2}
+  
+webserviceap.cannot.combine.handlerchain.soapmessagehandlers=You cannot specify both HanlderChain and SOAPMessageHandlers annotations
+
+webserviceap.invalid.handlerchain.file.nohandler-config=The handlerchain file {0} is invalid, it does not contain a handler-config element
+
+webserviceap.could.not.find.handlerchain=Could not find the handlerchain {0} in the handler file {1}
+
+webserviceap.handlerclass.notspecified=A handler in the HandlerChain file\: {0} does not specify a handler-class
+
+webserviceap.init_param.format.error=a <init-param> element must have exactly 1 <param-name> and 1 <param-value>
+
+webserviceap.document.literal.bare.method.return.not.unique=Document literal bare methods must have a unique result name return type combination.  Class {0} method\: {1}, result name\: {2} return type\: {3}
+
+webserviceap.document.literal.bare.method.not.unique=Document literal bare methods must have unique parameter names.  Class\: {0} method\: {1} parameter name\: {2}
+
+webserviceap.document.literal.bare.cannot.have.more.than.one.out=Document literal bare methods must have a return value or one out parameter.  Class\: {0} Method\: {1}
+
+webserviceap.document.literal.bare.must.have.only.one.in.parameter=Document literal bare methods must have no more than 1 non-header in parameter. Class\: {0} method\: {1} number of non-header parameters\: {2}
+
+webserviceap.document.literal.bare.must.have.one.in.or.out=Document literal bare methods must have at least one of: a return, an in parameter or an out parameter.  Class\: {0} Method\: {1}
+
+webserviceap.holder.parameters.must.not.be.in.only=javax.xml.ws.Holder parameters must not be annotated with the WebParam.Mode.IN property.  Class\: {0} method\: {1} parameter\: {2}
+
+webserviceap.document.bare.holder.parameters.must.not.be.inout=javax.xml.ws.Holder parameters in document bare operations must be WebParam.Mode.INOUT;  Class\: {0} method\: {1} parameter\: {2}
+
+webserviceap.endpointinterface.class.not.found=The endpointInterface class {0} could not be found
+
+webserviceap.sei.cannot.contain.constant.values=An service endpoint interface cannot contain constant declaration\: Interface\: {0} field\: {1}.
+
+webserviceap.method.return.type.cannot.implement.remote=Method return types cannot implement java.rmi.Remote.  Class\: {0} method\: {1} return type\: {2}
+
+webserviceap.method.parameter.types.cannot.implement.remote=Method parameter types cannot implement java.rmi.Remote.  Class\: {0} method\: {1} parameter\: {2} type\: {3}
+
+webserviceap.operation.name.not.unique=Operation names must be unique.  Class\: {0} method\: {1} operation name\: {2}
+
+webserviceap.method.request.wrapper.bean.name.not.unique=Request wrapper bean names must be unique and must not clash with other generated classes.  Class\: {0} method {1}
+
+webserviceap.method.response.wrapper.bean.name.not.unique=Response wrapper bean names must be unique and must not clash with other generated classes.  Class\: {0} method {1}
+
+webserviceap.method.exception.bean.name.not.unique=Exception bean names must be unique and must not clash with other generated classes.  Class\: {0} exception {1}
+
+webserviceap.rpc.literal.parameters.must.have.webparam=All rpc literal parameters must have a WebParam annotation.  Class\: {0} method\: {1} parameter {2}
+
+webserviceap.rpc.literal.webparams.must.specify.name=All rpc literal WebParams must specify a name.  Class\: {0} method {1} paramter {2}
+
+webserviceap.rpc.literal.must.not.be.bare=RPC literal SOAPBindings must have parameterStyle WRAPPPED. Class\: {0}.
+
+webserviceap.header.parameters.must.have.webparam.name=All WebParam annotations on header parameters must specify a name.  Class\: {0} method {1} paramter {2}
+
+webserviceap.failed.to.find.handlerchain.file=Cannot find HandlerChain file. class\: {0}, file:\ {1}
+
+webserviceap.failed.to.parse.handlerchain.file=Failed to parse HandlerChain file. Class\: {0}, file\: {1}
+
+webserviceap.class.not.found=Class Not Found: {0}
+
+webserviceap.rpc.soapbinding.not.allowed.on.method=SOAPBinding.Style.RPC binding annotations are not allowed on methods.  Class\: {0} Method\: {1}
+
+webserviceap.mixed.binding.style=Class\: {0} contains mixed bindings.  SOAPBinding.Style.RPC and SOAPBinding.Style.DOCUMENT cannot be mixed.
+
+webserviceap.endpointinteface.plus.annotation=The @{0} annotation cannot be used in with @javax.jws.WebService.endpointInterface element. 
+
+webserviceap.endpointinteface.plus.element=The @javax.jws.WebService.{0} element cannot be used in with @javax.jws.WebService.endpointInterface element. 
+
+webserviceap.non.in.parameters.must.be.holder=Class:\ {0}, method: {1}, parameter: {2} is not WebParam.Mode.IN and is not of type javax.xml.ws.Holder. 
+
+webserviceap.invalid.sei.annotation.element=The @javax.jws.WebService.{0} element cannot be specified on a service endpoint interface. Class\: {1} 
+
+webserviceap.invalid.sei.annotation=The @{0} annotation cannot be used on a service endpoint interface. Class\: {1} 
+
+webserviceap.invalid.webmethod.element.with.exclude=The @javax.jws.WebMethod.{0} element cannot be specified with the @javax.jws.WebMethod.exclude element. Class\: {1} method\: {0} 
+
+webserviceap.doc.bare.no.out=Document/literal bare methods with no return type or OUT/INOUT parameters must be annotated as @Oneway. Class\: {0}, method: {1}
+webserviceap.doc.bare.return.and.out=Document/literal bare methods cannot have a return type and out parameters. Class\: {0}, method: {1}
+webserviceap.oneway.and.out=@Oneway methods cannot have out parameters. Class\: {0} method {1}
+
+webserviceap.webservice.class.not.public=Classes annotated with @javax.jws.WebService must be public. Class\: {0}
+
+webserviceap.webservice.class.is.final=Classes annotated with @javax.jws.WebService must not be final. Class\: {0}
+
+webserviceap.webservice.class.is.abstract=Classes annotated with @javax.jws.WebService must not be abstract. Class\: {0}
+
+webserviceap.webservice.class.is.innerclass.not.static=Inner classes annotated with @javax.jws.WebService must be static. Class\: {0}
+
+webserviceap.webservice.method.is.abstract=Classes annotated with @javax.jws.WebService must not have abstract methods. Class\: {0} Method: {1}
+
+webserviceap.doc.bare.return.and.out=Document literal bare methods must not have a return value and an OUT/INOUT parameter.  Class\: {0} Method\: {1} 
+
+webserviceap.webservice.no.default.constructor=Classes annotated with @javax.jws.WebService must have a public default constructor. Class\: {0}
+
+webserviceap.oneway.and.not.one.in=Document literal bare methods annotated with @javax.jws.Oneway must have one non-header IN parameter.  Class\: {0} Method\: {1} 
+
+webserviceap.doc.bare.no.return.and.no.out=Document literal bare methods that do not have a return value must have a single OUT/INOUT parameter.  Class\: {0} Method\: {1} 
+
+webserviceap.doc.bare.and.no.one.in=Document literal bare methods must have one non-header, IN/INOUT parameter.  Class\: {0} Method\: {1} 
+
+webserviceap.method.not.implemented=Methods in an endpointInterface must be implemented in the implementation class.  Interface Class\:{0} Implementation Class\:{1} Method\: {2}
+
+webserviceap.no.package.class.must.have.targetnamespace=@javax.jws.Webservice annotated classes that do not belong to a package must have the @javax.jws.Webservice.targetNamespace element.  Class\: {0}
+
+webserviceap.webservice.and.webserviceprovider=Classes cannot be annotated with both @javax.jws.WebService and @javax.xml.ws.WebServiceProvider.  Class\: {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/wscompile.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/wscompile.properties
new file mode 100644
index 0000000..f3a6cb1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/wscompile.properties
@@ -0,0 +1,123 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+wsimport.usage=Usage: {0} [options] <WSDL_URI>\n\n\
+Use "wsimport -help" for a detailed description of options.
+
+wsimport.help=\nUsage: {0} [options] <WSDL_URI>\n\n\
+\where [options] include:\n\
+\  -b <path>                 specify external jaxws or jaxb binding files\n\
+\                            (Each <file> must have its own -b)\n\
+\  -catalog <file>           specify catalog file to resolve external entity references\n\
+\                            supports TR9401, XCatalog, and OASIS XML Catalog format.\n\
+\  -d <directory>            specify where to place generated output files\n\
+\  -extension                allow vendor extensions - functionality not specified\n\
+\                            by the specification.  Use of extensions may\n\
+\                            result in applications that are not portable or\n\
+\                            may not interoperate with other implementations\n\
+\  -help                     display help\n\
+\  -httpproxy:<host>:<port>  specify a HTTP proxy server (port defaults to 8080)\n\
+\  -keep                     keep generated files\n\
+\  -p <pkg>                  specifies the target package\n\
+\  -s <directory>            specify where to place generated source files\n\
+\  -verbose                  output messages about what the compiler is doing\n\
+\  -version                  print version information\n\
+\  -wsdllocation <location>  @WebService.wsdlLocation and @WebServiceClient.wsdlLocation value
+
+wsimport.usage.examples=\n\
+\Examples:\n\
+\  wsimport stock.wsdl -b stock.xml -b stock.xjb\n\
+\  wsimport -d generated http://example.org/stock?wsdl\n\
+
+
+wsgen.usage=Usage: {0} [options] <SEI>\n\n\
+Use "wsgen -help" for a detailed description of options.
+
+wsgen.help=\nUsage: {0} [options] <SEI>\n\n\
+\where [options] include:\n\
+\  -classpath <path>          specify where to find input class files\n\
+\  -cp <path>                 same as -classpath <path>\n\
+\  -d <directory>             specify where to place generated output files\n\
+\  -extension                 allow vendor extensions - functionality not specified\n\
+\                             by the specification.  Use of extensions may\n\
+\                             result in applications that are not portable or\n\
+\                             may not interoperate with other implementations\n\
+\  -help                      display help\n\
+\  -keep                      keep generated files\n\
+\  -r <directory>             resource destination directory, specify where to\n\
+\                             place resouce files such as WSDLs\n\
+\  -s <directory>             specify where to place generated source files\n\
+\  -verbose                   output messages about what the compiler is doing\n\
+\  -version                   print version information\n\
+\  -wsdl[:protocol]           generate a WSDL file.  The protocol is optional.\n\
+\                             Valid protocols are soap1.1 and Xsoap1.2, the default\n\
+\                             is soap1.1.  Xsoap1.2 is not standard and can only be\n\
+\                             used in conjunction with the -extension option\n\
+\  -servicename <name>        specify the Service name to use in the generated WSDL\n\
+\                             Used in conjunction with the -wsdl option.\n\
+\  -portname <name>           specify the Port name to use in the generated WSDL\n\
+\                             Used in conjunction with the -wsdl option.
+
+wsgen.usage.examples=\n\
+\Examples:\n\
+\  wsgen -cp . example.Stock\n\
+\  wsgen -cp . example.Stock -wsdl -servicename '{http://mynamespace}MyService'\n\
+
+
+
+#
+# Generic Messages
+#
+wscompile.invalidOption={0} is an invalid option or argument
+wscompile.error=error: {0}
+wscompile.warning=warning: {0}
+wscompile.info=info: {0}
+wscompile.duplicateOption=duplicate option: {0}
+wscompile.noSuchDirectory=directory not found: {0}
+wscompile.missingOptionArgument=option \"{0}\" requires an argument
+wscompile.compilationFailed=compilation failed, errors should have been reported
+wscompile.classmodelinfo.expected=Expected a ClassModelInfo but got a {0}.
+
+wsimport.missingFile=Missing WSDL_URI
+
+wsgen.invalid.protocol=\"{0}\" is not a supported protocol.  Supported protocols include: {1}.
+wsgen.invalid.transport=\"{0}\" is not a supported transport.  Supported transport include: {1}.
+wsgen.class.not.found=Class not found: \"{0}\"
+wsgen.could.not.create.file="Could not create file: "\{0}\"
+wsgen.missingFile=Missing SEI
+wsgen.soap12.without.extension=The optional protocol \"Xsoap1.2\" must be used in conjunction with the \"-extension\" option.
+wsgen.wsdl.arg.no.genwsdl=The \"{0}\" option can only be in conjunction with the "-wsdl" option. 
+wsgen.servicename.missing.namespace=The service name \"{0}\" is missing a namespace.
+wsgen.servicename.missing.localname=The service name \"{0}\" is missing a localname.
+wsgen.portname.missing.namespace=The port name \"{0}\" is missing a namespace.
+wsgen.portname.missing.localname=The port name \"{0}\" is missing a localname.
+wsgen.class.must.be.implementation.class=The class \"{0}\" is not an endpoint implementation class.
+wsgen.cannot.gen.wsdl.for.non.soap.binding=The -wsdl option cannot be used with non-SOAP bindings. Class \"{0}\" binding: \"{1}\".
+wsgen.cannot.gen.wsdl.for.soap12.binding=The -wsdl option cannot be used with SOAP1.2 bindings.\n\
+Try using \"-wsdl:Xsoap1.2 -extension\".\n\
+Class \"{0}\" binding: \"{1}\".
+wsgen.cannot.gen.wsdl.for.xsoap12.binding.wo.extention=The -wsdl option cannot be used with the SOAP1.2 extension binding without the \"-extension\" option.\n\
+Class \"{0}\" binding: \"{1}\".
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/wsdl.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/wsdl.properties
new file mode 100644
index 0000000..f84184f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/resources/wsdl.properties
@@ -0,0 +1,102 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+parsing.wsdlNotDefaultNamespace=default namespace must be \"{0}\"
+parsing.onlyOneOfElementOrTypeRequired=only one of the \"element\" or \"type\" attributes is allowed in part \"{0}\"
+parsing.elementOrTypeRequired=either the \"element\" or the \"type\" attribute is required in part \"{0}\"
+parsing.invalidElement=invalid element: \"{0}\" (in namespace \"{1}\")
+parsing.invalidAttributeValue=invalid value \"{1}\" for attribute \"{0}\"
+parsing.invalidExtensionElement=invalid extension element: \"{0}\" (in namespace \"{1}\")
+parsing.invalidWsdlElement=invalid WSDL element: \"{0}\"
+parsing.requiredExtensibilityElement=unknown required extensibility element \"{0}\" (in namespace \"{1}\")
+parsing.tooManyElements=too many \"{0}\" elements under \"{1}\" element \"{2}\"
+parsing.invalidOperationStyle=operation \"{0}\" has an invalid style
+parsing.onlyOneTypesAllowed=only one "types" element allowed in "{0}"
+parsing.onlyOneDocumentationAllowed=only one "documentation" element allowed in "{0}"
+parsing.incorrectRootElement=expected root element \"{2}\" (in namespace \"{3}\"), found element \"{0}\" (in namespace \"{1}\")
+parsing.unknownImportedDocumentType=imported document is of unknown type: {0}
+parsing.unknownNamespacePrefix=undeclared namespace prefix: \"{0}\"
+parsing.invalidURI=invalid URI: {0}
+parsing.ioExceptionWithSystemId=failed to parse document at \"{0}\": {1}
+parsing.ioException=parsing failed: {0}
+parsing.saxExceptionWithSystemId=invalid WSDL file! failed to parse document at \"{0}\": {1}
+parsing.saxException=invalid WSDL file! parsing failed: {0}
+parsing.parserConfigException=invalid WSDL file! parsing failed: {0}
+parsing.factoryConfigException=invalid WSDL file! parsing failed: {0}
+
+#
+parsing.missingRequiredAttribute=missing required attribute \"{1}\" of element \"{0}\"
+parsing.invalidTag=expected element \"{1}\", found \"{0}\"
+parsing.invalidTagNS=expected element \"{2}\" (in namespace \"{3}\"), found element \"{0}\" (in namespace \"{1}\")
+parsing.nonWhitespaceTextFound=found unexpected non whitespace text: \"{0}\"
+parsing.elementExpected=unexpected non-element found
+#
+entity.duplicate=duplicate entity: \"{0}\"
+entity.duplicateWithType=duplicate \"{0}\" entity: \"{1}\"
+entity.notFoundByQName=invalid entity name: \"{0}\" (in namespace: \"{1}\")
+entity.notFoundByID=invalid entity id: \"{0}\"
+#
+validation.missingRequiredAttribute=missing required attribute \"{0}\" of element \"{1}\"
+validation.missingRequiredProperty=missing required property \"{0}\" of element \"{1}\"
+validation.missingRequiredSubEntity=missing required sub-entity \"{0}\" of element \"{1}\"
+validation.invalidElement=invalid element: \"{0}\"
+validation.invalidComplexTypeInElement=invalid element: \"{1}\", has named complexType: \"{0}\"
+validation.invalidSimpleTypeInElement=invalid element: \"{1}\", has named simpleType: \"{0}\"
+validation.duplicatedElement=duplicated element: \"{0}\"
+validation.duplicateName=duplicated part name: \"{0}\"
+validation.invalidSubEntity=invalid sub-element \"{0}\" of element \"{1}\"
+validation.invalidAttribute=invalid attribute \"{0}\" of element \"{1}\"
+validation.invalidAttributeValue=invalid value \"{1}\" for attribute \"{0}\"
+validation.invalidRange=invalid range found (min: {0}, max: {1})
+validation.exclusiveAttributes=exclusive attributes: \"{0}\", \"{1}\"
+validation.incorrectTargetNamespace=target namespace is incorrect (expected: {1}, found: {0})
+validation.unsupportedSchemaFeature=unsupported XML Schema feature: \"{0}\"
+validation.shouldNotHappen=internal error ("{0}")
+validation.invalidToken=invalid token \"{0}\"
+validation.notSimpleType=not a simple type: \"{0}\"
+validation.ambiguousName=ambiguous operation name: \"{0}\"
+validation.invalidPrefix=undeclared namespace prefix: \"{0}\"
+
+#wsi compliant WSDL warnings
+warning.wsi.r2001=Not a WSI-BP compliant WSDL (R2001, R2002). wsdl:import must only import WSDL document. Its trying to import: \"{0}\"
+warning.wsi.r2002=Not a WSI-BP compliant WSDL (R2002). wsdl:import must not be used to import XML Schema embedded in the WSDL document. Expected wsdl namesapce: {0}, found: {1}
+warning.wsi.r2003=Not a WSI-BP compliant WSDL (R2003). xsd:import must only be used inside xsd:schema element.
+warning.wsi.r2004=Not a WSI-BP compliant WSDL (R2001, R2004). xsd:import must not import XML Schema definition emmbedded inline within WSDLDocument.
+
+#Internalizer
+internalizer.targetNotAnElement= \
+    Target node is not an element
+internalizer.targetNotFound= \
+    No target found for the wsdlLocation: {0}
+internalizer.XPathEvaluationError = \
+    XPath error: {0}
+internalizer.XPathEvaluatesToNoTarget = \
+    XPath evaluation of "{0}" results in empty target node
+internalizer.XPathEvaulatesToTooManyTargets = \
+    XPath evaluation of "{0}" results in too many ({1}) target nodes
+internalizer.XPathEvaluatesToNonElement = \
+    XPath evaluation of "{0}" needs to result in an element.
+invalid.customization.namespace=Ignoring customization: \"{0}\", it has no namespace. It must belong to the customization namespace.    
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/spi/WSToolsObjectFactory.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/spi/WSToolsObjectFactory.java
new file mode 100644
index 0000000..73282cd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/spi/WSToolsObjectFactory.java
@@ -0,0 +1,67 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.spi;
+
+import com.sun.tools.internal.ws.util.WSToolsObjectFactoryImpl;
+import java.io.OutputStream;
+
+
+/**
+ * Singleton abstract factory used to produce JAX-WS tools related objects.
+ *
+ * @author JAX-WS Development Team
+ */
+public abstract class WSToolsObjectFactory {
+
+    private static WSToolsObjectFactory factory;
+
+    /**
+     * Obtain an instance of a factory. Don't worry about synchronization(at the
+     * most, one more factory is created).
+     */
+    public static WSToolsObjectFactory newInstance() {
+        if (factory == null) {
+            factory = new WSToolsObjectFactoryImpl();
+        }
+        return factory;
+    }
+
+    /**
+     * Invokes wsimport on the wsdl URL argument, and generates the necessary
+     * portable artifacts like SEI, Service, Bean classes etc.
+     *
+     * @return true if there is no error, otherwise false
+     */
+    public abstract boolean wsimport(OutputStream logStream, String[] args);
+
+    /**
+     * Invokes wsgen on the endpoint implementation, and generates the necessary
+     * artifacts like wrapper, exception bean classes etc.
+     *
+     * @return true if there is no error, otherwise false
+     */
+    public abstract boolean wsgen(OutputStream logStream, String[] args);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/spi/package-info.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/spi/package-info.java
new file mode 100644
index 0000000..6d95579
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/spi/package-info.java
@@ -0,0 +1,32 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *
+ * <P>This document describes the SPI for the JAX-WS 2.0 tools.
+ *  The WSToolsObjectFactory is used to create instances of WsGen
+ *  and WsImport that other applications can use.
+*/
+package com.sun.tools.internal.ws.spi;
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ClassNameInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ClassNameInfo.java
new file mode 100644
index 0000000..86b1e48
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ClassNameInfo.java
@@ -0,0 +1,73 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util;
+
+/**
+ * @author WS Development Team
+ */
+
+public final class ClassNameInfo {
+
+    public static String getName(String className) {
+        String qual = getQualifier(className);
+        int len = className.length();
+        int closingBracket = className.indexOf('>');
+        if(closingBracket > 0)
+            len = closingBracket;
+        return qual != null
+            ? className.substring(qual.length() + 1, len)
+            : className;
+    }
+
+
+    /**
+     *
+     *
+     * @param className Generic class, such as java.util.List<java.lang.String>
+     * @return the generic class, such as java.util.List
+     */
+    public static String getGenericClass(String className) {
+       int index = className.indexOf('<');
+       if(index < 0)
+           return className;
+       return (index > 0)?className.substring(0, index):className;
+    }
+
+
+    public static String getQualifier(String className) {
+        int idot = className.indexOf(' ');
+        if (idot <= 0)
+            idot = className.length();
+        else
+            idot -= 1; // back up over previous dot
+        int index = className.lastIndexOf('.', idot - 1);
+        return (index < 0) ? null : className.substring(0, index);
+    }
+
+    public static String replaceInnerClassSym(String name) {
+        return name.replace('$', '_');
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ForkEntityResolver.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ForkEntityResolver.java
new file mode 100644
index 0000000..f79d2de
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ForkEntityResolver.java
@@ -0,0 +1,54 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util;
+
+import java.io.IOException;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+/**
+ * {@link EntityResolver} that delegates to two {@link EntityResolver}s.
+ *
+ * @author WS Development Team
+ */
+public class ForkEntityResolver implements EntityResolver {
+    private final EntityResolver lhs;
+    private final EntityResolver rhs;
+
+    public ForkEntityResolver(EntityResolver lhs, EntityResolver rhs) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public InputSource resolveEntity(String publicId, String systemId) throws SAXException, IOException {
+        InputSource is = lhs.resolveEntity(publicId, systemId);
+        if(is!=null)
+            return is;
+        return rhs.resolveEntity(systemId,systemId);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/JAXWSClassFactory.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/JAXWSClassFactory.java
new file mode 100644
index 0000000..fc0209c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/JAXWSClassFactory.java
@@ -0,0 +1,105 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util;
+
+import java.util.Properties;
+
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.generator.Names;
+import com.sun.tools.internal.ws.processor.modeler.wsdl.WSDLModeler;
+import com.sun.tools.internal.ws.processor.modeler.wsdl.WSDLModelerBase;
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.xml.internal.ws.util.VersionUtil;
+
+/**
+ * Singleton factory class to instantiate concrete classes based on the jaxws version
+ * to be used to generate the code.
+ *
+ * @author WS Development Team
+ */
+public class JAXWSClassFactory {
+    private static final JAXWSClassFactory factory = new JAXWSClassFactory();
+
+    private static String classVersion = VersionUtil.JAXWS_VERSION_DEFAULT;
+
+    private JAXWSClassFactory() {
+    }
+
+    /**
+     * Get the factory instance for the default version.
+     * @return        JAXWSClassFactory instance
+     */
+    public static JAXWSClassFactory newInstance() {
+        return factory;
+    }
+
+    /**
+     * Sets the version to a static classVersion
+     * @param version
+     */
+    public void setSourceVersion(String version) {
+        if (version == null)
+            version = VersionUtil.JAXWS_VERSION_DEFAULT;
+
+        if (!VersionUtil.isValidVersion(version)) {
+            // TODO: throw exception
+        } else
+            classVersion = version;
+    }
+
+    /**
+     * Returns the WSDLModeler for specific target version.
+     *
+     * @param modelInfo
+     * @param options
+     * @return the WSDLModeler for specific target version.
+     */
+    public WSDLModelerBase createWSDLModeler(
+        WSDLModelInfo modelInfo,
+        Properties options) {
+        WSDLModelerBase wsdlModeler = null;
+        if (classVersion.equals(VersionUtil.JAXWS_VERSION_20))
+            wsdlModeler = new WSDLModeler(modelInfo, options);
+        else {
+            // TODO: throw exception
+        }
+        return wsdlModeler;
+    }
+
+    /**
+     * Returns the Names for specific target version.
+     * //bug fix:4904604
+     * @return instance of Names
+     */
+    public Names createNames() {
+        Names names = new Names();
+        return names;
+    }
+
+    public String getVersion() {
+        return classVersion;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/JavaCompilerHelper.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/JavaCompilerHelper.java
new file mode 100644
index 0000000..b252e7d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/JavaCompilerHelper.java
@@ -0,0 +1,176 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util;
+
+import java.io.OutputStream;
+import java.io.PrintWriter;
+import java.lang.reflect.Constructor;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * A helper class to invoke javac.
+ *
+ * @author WS Development Team
+ */
+public class JavaCompilerHelper extends ToolBase {
+
+    public JavaCompilerHelper(OutputStream out) {
+        super(out, " ");
+        this.out = out;
+    }
+
+    public boolean compile(String[] args) {
+        return internalCompile(args);
+    }
+
+    protected String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.javacompiler";
+    }
+
+    protected boolean internalCompile(String[] args) {
+        ClassLoader cl = Thread.currentThread().getContextClassLoader();
+        Class comSunToolsJavacMainClass = null;
+        try {
+            /* try to use the new compiler */
+            comSunToolsJavacMainClass =
+                    cl.loadClass("com.sun.tools.javac.Main");
+            try {
+                Method compileMethod =
+                        comSunToolsJavacMainClass.getMethod(
+                                "compile",
+                                compile141MethodSignature);
+                try {
+                    Object result =
+                            compileMethod.invoke(
+                                    null,
+                                    new Object[] { args, new PrintWriter(out)});
+                    if (!(result instanceof Integer)) {
+                        return false;
+                    }
+                    return ((Integer) result).intValue() == 0;
+                } catch (IllegalAccessException e3) {
+                    return false;
+                } catch (IllegalArgumentException e3) {
+                    return false;
+                } catch (InvocationTargetException e3) {
+                    return false;
+                }
+            } catch (NoSuchMethodException e2) {
+                //tryout 1.3.1 signature
+                return internalCompilePre141(args);
+                //onError(getMessage("javacompiler.nosuchmethod.error", "getMethod(\"compile\", compile141MethodSignature)"));
+                //return false;
+            }
+        } catch (ClassNotFoundException e) {
+            onError(
+                    getMessage(
+                            "javacompiler.classpath.error",
+                            "com.sun.tools.javac.Main"));
+            return false;
+        } catch (SecurityException e) {
+            return false;
+        }
+    }
+
+    protected boolean internalCompilePre141(String[] args) {
+            ClassLoader cl = Thread.currentThread().getContextClassLoader();
+            try {
+                    Class sunToolsJavacMainClass = cl.loadClass("sun.tools.javac.Main");
+                    try {
+                            Constructor constructor =
+                                    sunToolsJavacMainClass.getConstructor(constructorSignature);
+                            try {
+                                    Object javacMain =
+                                            constructor.newInstance(new Object[] { out, "javac" });
+                                    Method compileMethod =
+                                            sunToolsJavacMainClass.getMethod(
+                                                    "compile",
+                                                    compileMethodSignature);
+                                    Object result =
+                                            compileMethod.invoke(javacMain, new Object[] { args });
+                                    if (!(result instanceof Boolean)) {
+                                            return false;
+                                    }
+                                    return ((Boolean) result).booleanValue();
+                            } catch (InstantiationException e4) {
+                                    return false;
+                            } catch (IllegalAccessException e4) {
+                                    return false;
+                            } catch (IllegalArgumentException e4) {
+                                    return false;
+                            } catch (InvocationTargetException e4) {
+                                    return false;
+                            }
+
+                    } catch (NoSuchMethodException e3) {
+                            onError(
+                                    getMessage(
+                                            "javacompiler.nosuchmethod.error",
+                                            "getMethod(\"compile\", compileMethodSignature)"));
+                            return false;
+                    }
+            } catch (ClassNotFoundException e2) {
+                    return false;
+            }
+    }
+
+    protected String getGenericErrorMessage() {
+            return "javacompiler.error";
+    }
+
+    protected void run() {
+    }
+
+    protected boolean parseArguments(String[] args) {
+            return false;
+    }
+
+    public void onError(Localizable msg) {
+            report(getMessage("javacompiler.error", localizer.localize(msg)));
+    }
+
+    protected OutputStream out;
+
+    protected static final Class[] compile141MethodSignature;
+    protected static final Class[] constructorSignature;
+    protected static final Class[] compileMethodSignature;
+
+    static {
+            compile141MethodSignature = new Class[2];
+            compile141MethodSignature[0] = (new String[0]).getClass();
+            compile141MethodSignature[1] = PrintWriter.class;
+            //jdk version < 1.4.1 signature
+            constructorSignature = new Class[2];
+            constructorSignature[0] = OutputStream.class;
+            constructorSignature[1] = String.class;
+            compileMethodSignature = new Class[1];
+            compileMethodSignature[0] = compile141MethodSignature[0]; // String[]
+
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/MapBase.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/MapBase.java
new file mode 100644
index 0000000..99debcf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/MapBase.java
@@ -0,0 +1,691 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util;
+
+import java.util.AbstractCollection;
+import java.util.AbstractSet;
+import java.util.Collection;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Set;
+
+/*
+ * This class was lifted from JDK 1.4 (where it's called java.util.AbstractMap)
+ * so that we can use it on 1.3.1.
+ *
+ * @author WS Development Team
+ */
+
+/**
+ * This class provides a skeletal implementation of the <tt>Map</tt>
+ * interface, to minimize the effort required to implement this interface. <p>
+ *
+ * To implement an unmodifiable map, the programmer needs only to extend this
+ * class and provide an implementation for the <tt>entrySet</tt> method, which
+ * returns a set-view of the map's mappings.  Typically, the returned set
+ * will, in turn, be implemented atop <tt>AbstractSet</tt>.  This set should
+ * not support the <tt>add</tt> or <tt>remove</tt> methods, and its iterator
+ * should not support the <tt>remove</tt> method.<p>
+ *
+ * To implement a modifiable map, the programmer must additionally override
+ * this class's <tt>put</tt> method (which otherwise throws an
+ * <tt>UnsupportedOperationException</tt>), and the iterator returned by
+ * <tt>entrySet().iterator()</tt> must additionally implement its
+ * <tt>remove</tt> method.<p>
+ *
+ * The programmer should generally provide a void (no argument) and map
+ * constructor, as per the recommendation in the <tt>Map</tt> interface
+ * specification.<p>
+ *
+ * The documentation for each non-abstract methods in this class describes its
+ * implementation in detail.  Each of these methods may be overridden if the
+ * map being implemented admits a more efficient implementation.
+ *
+ * @author  Josh Bloch
+ * @see Map
+ * @see Collection
+ * @since 1.2
+ */
+
+public abstract class MapBase implements Map {
+    /**
+     * Sole constructor.  (For invocation by subclass constructors, typically
+     * implicit.)
+     */
+    protected MapBase() {
+    }
+
+    // Query Operations
+
+    /**
+     * Returns the number of key-value mappings in this map.  If the map
+     * contains more than <tt>Integer.MAX_VALUE</tt> elements, returns
+     * <tt>Integer.MAX_VALUE</tt>.<p>
+     *
+     * This implementation returns <tt>entrySet().size()</tt>.
+     *
+     * @return the number of key-value mappings in this map.
+     */
+    public int size() {
+        return entrySet().size();
+    }
+
+    /**
+     * Returns <tt>true</tt> if this map contains no key-value mappings. <p>
+     *
+     * This implementation returns <tt>size() == 0</tt>.
+     *
+     * @return <tt>true</tt> if this map contains no key-value mappings.
+     */
+    public boolean isEmpty() {
+        return size() == 0;
+    }
+
+    /**
+     * Returns <tt>true</tt> if this map maps one or more keys to this value.
+     * More formally, returns <tt>true</tt> if and only if this map contains
+     * at least one mapping to a value <tt>v</tt> such that <tt>(value==null ?
+     * v==null : value.equals(v))</tt>.  This operation will probably require
+     * time linear in the map size for most implementations of map.<p>
+     *
+     * This implementation iterates over entrySet() searching for an entry
+     * with the specified value.  If such an entry is found, <tt>true</tt> is
+     * returned.  If the iteration terminates without finding such an entry,
+     * <tt>false</tt> is returned.  Note that this implementation requires
+     * linear time in the size of the map.
+     *
+     * @param value value whose presence in this map is to be tested.
+     *
+     * @return <tt>true</tt> if this map maps one or more keys to this value.
+     */
+    public boolean containsValue(Object value) {
+        Iterator i = entrySet().iterator();
+        if (value == null) {
+            while (i.hasNext()) {
+                Entry e = (Entry) i.next();
+                if (e.getValue() == null)
+                    return true;
+            }
+        } else {
+            while (i.hasNext()) {
+                Entry e = (Entry) i.next();
+                if (value.equals(e.getValue()))
+                    return true;
+            }
+        }
+        return false;
+    }
+
+    /**
+     * Returns <tt>true</tt> if this map contains a mapping for the specified
+     * key. <p>
+     *
+     * This implementation iterates over <tt>entrySet()</tt> searching for an
+     * entry with the specified key.  If such an entry is found, <tt>true</tt>
+     * is returned.  If the iteration terminates without finding such an
+     * entry, <tt>false</tt> is returned.  Note that this implementation
+     * requires linear time in the size of the map; many implementations will
+     * override this method.
+     *
+     * @param key key whose presence in this map is to be tested.
+     * @return <tt>true</tt> if this map contains a mapping for the specified
+     *            key.
+     *
+     * @throws NullPointerException key is <tt>null</tt> and this map does not
+     *            not permit <tt>null</tt> keys.
+     */
+    public boolean containsKey(Object key) {
+        Iterator i = entrySet().iterator();
+        if (key == null) {
+            while (i.hasNext()) {
+                Entry e = (Entry) i.next();
+                if (e.getKey() == null)
+                    return true;
+            }
+        } else {
+            while (i.hasNext()) {
+                Entry e = (Entry) i.next();
+                if (key.equals(e.getKey()))
+                    return true;
+            }
+        }
+        return false;
+    }
+
+    /**
+     * Returns the value to which this map maps the specified key.  Returns
+     * <tt>null</tt> if the map contains no mapping for this key.  A return
+     * value of <tt>null</tt> does not <i>necessarily</i> indicate that the
+     * map contains no mapping for the key; it's also possible that the map
+     * explicitly maps the key to <tt>null</tt>.  The containsKey operation
+     * may be used to distinguish these two cases. <p>
+     *
+     * This implementation iterates over <tt>entrySet()</tt> searching for an
+     * entry with the specified key.  If such an entry is found, the entry's
+     * value is returned.  If the iteration terminates without finding such an
+     * entry, <tt>null</tt> is returned.  Note that this implementation
+     * requires linear time in the size of the map; many implementations will
+     * override this method.
+     *
+     * @param key key whose associated value is to be returned.
+     * @return the value to which this map maps the specified key.
+     *
+     * @throws NullPointerException if the key is <tt>null</tt> and this map
+     *        does not not permit <tt>null</tt> keys.
+     *
+     * @see #containsKey(Object)
+     */
+    public Object get(Object key) {
+        Iterator i = entrySet().iterator();
+        if (key == null) {
+            while (i.hasNext()) {
+                Entry e = (Entry) i.next();
+                if (e.getKey() == null)
+                    return e.getValue();
+            }
+        } else {
+            while (i.hasNext()) {
+                Entry e = (Entry) i.next();
+                if (key.equals(e.getKey()))
+                    return e.getValue();
+            }
+        }
+        return null;
+    }
+
+    // Modification Operations
+
+    /**
+     * Associates the specified value with the specified key in this map
+     * (optional operation).  If the map previously contained a mapping for
+     * this key, the old value is replaced.<p>
+     *
+     * This implementation always throws an
+     * <tt>UnsupportedOperationException</tt>.
+     *
+     * @param key key with which the specified value is to be associated.
+     * @param value value to be associated with the specified key.
+     *
+     * @return previous value associated with specified key, or <tt>null</tt>
+     *         if there was no mapping for key.  (A <tt>null</tt> return can
+     *         also indicate that the map previously associated <tt>null</tt>
+     *         with the specified key, if the implementation supports
+     *         <tt>null</tt> values.)
+     *
+     * @throws UnsupportedOperationException if the <tt>put</tt> operation is
+     *            not supported by this map.
+     *
+     * @throws ClassCastException if the class of the specified key or value
+     *            prevents it from being stored in this map.
+     *
+     * @throws IllegalArgumentException if some aspect of this key or value *
+     *            prevents it from being stored in this map.
+     *
+     * @throws NullPointerException this map does not permit <tt>null</tt>
+     *            keys or values, and the specified key or value is
+     *            <tt>null</tt>.
+     */
+    public Object put(Object key, Object value) {
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * Removes the mapping for this key from this map if present (optional
+     * operation). <p>
+     *
+     * This implementation iterates over <tt>entrySet()</tt> searching for an
+     * entry with the specified key.  If such an entry is found, its value is
+     * obtained with its <tt>getValue</tt> operation, the entry is is removed
+     * from the Collection (and the backing map) with the iterator's
+     * <tt>remove</tt> operation, and the saved value is returned.  If the
+     * iteration terminates without finding such an entry, <tt>null</tt> is
+     * returned.  Note that this implementation requires linear time in the
+     * size of the map; many implementations will override this method.<p>
+     *
+     * Note that this implementation throws an
+     * <tt>UnsupportedOperationException</tt> if the <tt>entrySet</tt> iterator
+     * does not support the <tt>remove</tt> method and this map contains a
+     * mapping for the specified key.
+     *
+     * @param key key whose mapping is to be removed from the map.
+     * @return previous value associated with specified key, or <tt>null</tt>
+     *         if there was no entry for key.  (A <tt>null</tt> return can
+     *         also indicate that the map previously associated <tt>null</tt>
+     *         with the specified key, if the implementation supports
+     *         <tt>null</tt> values.)
+     * @throws UnsupportedOperationException if the <tt>remove</tt> operation
+     *        is not supported by this map.
+     */
+    public Object remove(Object key) {
+        Iterator i = entrySet().iterator();
+        Entry correctEntry = null;
+        if (key == null) {
+            while (correctEntry == null && i.hasNext()) {
+                Entry e = (Entry) i.next();
+                if (e.getKey() == null)
+                    correctEntry = e;
+            }
+        } else {
+            while (correctEntry == null && i.hasNext()) {
+                Entry e = (Entry) i.next();
+                if (key.equals(e.getKey()))
+                    correctEntry = e;
+            }
+        }
+
+        Object oldValue = null;
+        if (correctEntry != null) {
+            oldValue = correctEntry.getValue();
+            i.remove();
+        }
+        return oldValue;
+    }
+
+    // Bulk Operations
+
+    /**
+     * Copies all of the mappings from the specified map to this map
+     * (optional operation).  These mappings will replace any mappings that
+     * this map had for any of the keys currently in the specified map.<p>
+     *
+     * This implementation iterates over the specified map's
+     * <tt>entrySet()</tt> collection, and calls this map's <tt>put</tt>
+     * operation once for each entry returned by the iteration.<p>
+     *
+     * Note that this implementation throws an
+     * <tt>UnsupportedOperationException</tt> if this map does not support
+     * the <tt>put</tt> operation and the specified map is nonempty.
+     *
+     * @param t mappings to be stored in this map.
+     *
+     * @throws UnsupportedOperationException if the <tt>putAll</tt> operation
+     *        is not supported by this map.
+     *
+     * @throws ClassCastException if the class of a key or value in the
+     *            specified map prevents it from being stored in this map.
+     *
+     * @throws IllegalArgumentException if some aspect of a key or value in
+     *            the specified map prevents it from being stored in this map.
+     * @throws NullPointerException the specified map is <tt>null</tt>, or if
+     *         this map does not permit <tt>null</tt> keys or values, and the
+     *         specified map contains <tt>null</tt> keys or values.
+     */
+    public void putAll(Map t) {
+        Iterator i = t.entrySet().iterator();
+        while (i.hasNext()) {
+            Entry e = (Entry) i.next();
+            put(e.getKey(), e.getValue());
+        }
+    }
+
+    /**
+     * Removes all mappings from this map (optional operation). <p>
+     *
+     * This implementation calls <tt>entrySet().clear()</tt>.
+     *
+     * Note that this implementation throws an
+     * <tt>UnsupportedOperationException</tt> if the <tt>entrySet</tt>
+     * does not support the <tt>clear</tt> operation.
+     *
+     * @throws    UnsupportedOperationException clear is not supported
+     *        by this map.
+     */
+    public void clear() {
+        entrySet().clear();
+    }
+
+    // Views
+
+    /**
+     * Each of these fields are initialized to contain an instance of the
+     * appropriate view the first time this view is requested.  The views are
+     * stateless, so there's no reason to create more than one of each.
+     */
+    transient volatile Set keySet = null;
+    transient volatile Collection values = null;
+
+    /**
+     * Returns a Set view of the keys contained in this map.  The Set is
+     * backed by the map, so changes to the map are reflected in the Set,
+     * and vice-versa.  (If the map is modified while an iteration over
+     * the Set is in progress, the results of the iteration are undefined.)
+     * The Set supports element removal, which removes the corresponding entry
+     * from the map, via the Iterator.remove, Set.remove,  removeAll
+     * retainAll, and clear operations.  It does not support the add or
+     * addAll operations.<p>
+     *
+     * This implementation returns a Set that subclasses
+     * AbstractSet.  The subclass's iterator method returns a "wrapper
+     * object" over this map's entrySet() iterator.  The size method delegates
+     * to this map's size method and the contains method delegates to this
+     * map's containsKey method.<p>
+     *
+     * The Set is created the first time this method is called,
+     * and returned in response to all subsequent calls.  No synchronization
+     * is performed, so there is a slight chance that multiple calls to this
+     * method will not all return the same Set.
+     *
+     * @return a Set view of the keys contained in this map.
+     */
+    public Set keySet() {
+        if (keySet == null) {
+            keySet = new AbstractSet() {
+                public Iterator iterator() {
+                    return new Iterator() {
+                        private Iterator i = entrySet().iterator();
+
+                        public boolean hasNext() {
+                            return i.hasNext();
+                        }
+
+                        public Object next() {
+                            return ((Entry) i.next()).getKey();
+                        }
+
+                        public void remove() {
+                            i.remove();
+                        }
+                    };
+                }
+
+                public int size() {
+                    return MapBase.this.size();
+                }
+
+                public boolean contains(Object k) {
+                    return MapBase.this.containsKey(k);
+                }
+            };
+        }
+        return keySet;
+    }
+
+    /**
+     * Returns a collection view of the values contained in this map.  The
+     * collection is backed by the map, so changes to the map are reflected in
+     * the collection, and vice-versa.  (If the map is modified while an
+     * iteration over the collection is in progress, the results of the
+     * iteration are undefined.)  The collection supports element removal,
+     * which removes the corresponding entry from the map, via the
+     * <tt>Iterator.remove</tt>, <tt>Collection.remove</tt>,
+     * <tt>removeAll</tt>, <tt>retainAll</tt> and <tt>clear</tt> operations.
+     * It does not support the <tt>add</tt> or <tt>addAll</tt> operations.<p>
+     *
+     * This implementation returns a collection that subclasses abstract
+     * collection.  The subclass's iterator method returns a "wrapper object"
+     * over this map's <tt>entrySet()</tt> iterator.  The size method
+     * delegates to this map's size method and the contains method delegates
+     * to this map's containsValue method.<p>
+     *
+     * The collection is created the first time this method is called, and
+     * returned in response to all subsequent calls.  No synchronization is
+     * performed, so there is a slight chance that multiple calls to this
+     * method will not all return the same Collection.
+     *
+     * @return a collection view of the values contained in this map.
+     */
+    public Collection values() {
+        if (values == null) {
+            values = new AbstractCollection() {
+                public Iterator iterator() {
+                    return new Iterator() {
+                        private Iterator i = entrySet().iterator();
+
+                        public boolean hasNext() {
+                            return i.hasNext();
+                        }
+
+                        public Object next() {
+                            return ((Entry) i.next()).getValue();
+                        }
+
+                        public void remove() {
+                            i.remove();
+                        }
+                    };
+                }
+
+                public int size() {
+                    return MapBase.this.size();
+                }
+
+                public boolean contains(Object v) {
+                    return MapBase.this.containsValue(v);
+                }
+            };
+        }
+        return values;
+    }
+
+    /**
+     * Returns a set view of the mappings contained in this map.  Each element
+     * in this set is a Map.Entry.  The set is backed by the map, so changes
+     * to the map are reflected in the set, and vice-versa.  (If the map is
+     * modified while an iteration over the set is in progress, the results of
+     * the iteration are undefined.)  The set supports element removal, which
+     * removes the corresponding entry from the map, via the
+     * <tt>Iterator.remove</tt>, <tt>Set.remove</tt>, <tt>removeAll</tt>,
+     * <tt>retainAll</tt> and <tt>clear</tt> operations.  It does not support
+     * the <tt>add</tt> or <tt>addAll</tt> operations.
+     *
+     * @return a set view of the mappings contained in this map.
+     */
+    public abstract Set entrySet();
+
+    // Comparison and hashing
+
+    /**
+     * Compares the specified object with this map for equality.  Returns
+     * <tt>true</tt> if the given object is also a map and the two maps
+     * represent the same mappings.  More formally, two maps <tt>t1</tt> and
+     * <tt>t2</tt> represent the same mappings if
+     * <tt>t1.keySet().equals(t2.keySet())</tt> and for every key <tt>k</tt>
+     * in <tt>t1.keySet()</tt>, <tt> (t1.get(k)==null ? t2.get(k)==null :
+     * t1.get(k).equals(t2.get(k))) </tt>.  This ensures that the
+     * <tt>equals</tt> method works properly across different implementations
+     * of the map interface.<p>
+     *
+     * This implementation first checks if the specified object is this map;
+     * if so it returns <tt>true</tt>.  Then, it checks if the specified
+     * object is a map whose size is identical to the size of this set; if
+     * not, it it returns <tt>false</tt>.  If so, it iterates over this map's
+     * <tt>entrySet</tt> collection, and checks that the specified map
+     * contains each mapping that this map contains.  If the specified map
+     * fails to contain such a mapping, <tt>false</tt> is returned.  If the
+     * iteration completes, <tt>true</tt> is returned.
+     *
+     * @param o object to be compared for equality with this map.
+     * @return <tt>true</tt> if the specified object is equal to this map.
+     */
+    public boolean equals(Object o) {
+        if (o == this)
+            return true;
+
+        if (!(o instanceof Map))
+            return false;
+        Map t = (Map) o;
+        if (t.size() != size())
+            return false;
+
+        try {
+            Iterator i = entrySet().iterator();
+            while (i.hasNext()) {
+                Entry e = (Entry) i.next();
+                Object key = e.getKey();
+                Object value = e.getValue();
+                if (value == null) {
+                    if (!(t.get(key) == null && t.containsKey(key)))
+                        return false;
+                } else {
+                    if (!value.equals(t.get(key)))
+                        return false;
+                }
+            }
+        } catch (ClassCastException unused) {
+            return false;
+        } catch (NullPointerException unused) {
+            return false;
+        }
+
+        return true;
+    }
+
+    /**
+     * Returns the hash code value for this map.  The hash code of a map is
+     * defined to be the sum of the hash codes of each entry in the map's
+     * <tt>entrySet()</tt> view.  This ensures that <tt>t1.equals(t2)</tt>
+     * implies that <tt>t1.hashCode()==t2.hashCode()</tt> for any two maps
+     * <tt>t1</tt> and <tt>t2</tt>, as required by the general contract of
+     * Object.hashCode.<p>
+     *
+     * This implementation iterates over <tt>entrySet()</tt>, calling
+     * <tt>hashCode</tt> on each element (entry) in the Collection, and adding
+     * up the results.
+     *
+     * @return the hash code value for this map.
+     * @see java.util.Map.Entry#hashCode()
+     * @see Object#hashCode()
+     * @see Object#equals(Object)
+     * @see Set#equals(Object)
+     */
+    public int hashCode() {
+        int h = 0;
+        Iterator i = entrySet().iterator();
+        while (i.hasNext())
+            h += i.next().hashCode();
+        return h;
+    }
+
+    /**
+     * Returns a string representation of this map.  The string representation
+     * consists of a list of key-value mappings in the order returned by the
+     * map's <tt>entrySet</tt> view's iterator, enclosed in braces
+     * (<tt>"{}"</tt>).  Adjacent mappings are separated by the characters
+     * <tt>", "</tt> (comma and space).  Each key-value mapping is rendered as
+     * the key followed by an equals sign (<tt>"="</tt>) followed by the
+     * associated value.  Keys and values are converted to strings as by
+     * <tt>String.valueOf(Object)</tt>.<p>
+     *
+     * This implementation creates an empty string buffer, appends a left
+     * brace, and iterates over the map's <tt>entrySet</tt> view, appending
+     * the string representation of each <tt>map.entry</tt> in turn.  After
+     * appending each entry except the last, the string <tt>", "</tt> is
+     * appended.  Finally a right brace is appended.  A string is obtained
+     * from the stringbuffer, and returned.
+     *
+     * @return a String representation of this map.
+     */
+    public String toString() {
+        StringBuffer buf = new StringBuffer();
+        buf.append("{");
+
+        Iterator i = entrySet().iterator();
+        boolean hasNext = i.hasNext();
+        while (hasNext) {
+            Entry e = (Entry) (i.next());
+            Object key = e.getKey();
+            Object value = e.getValue();
+            buf.append(
+                (key == this ? "(this Map)" : key)
+                    + "="
+                    + (value == this ? "(this Map)" : value));
+
+            hasNext = i.hasNext();
+            if (hasNext)
+                buf.append(", ");
+        }
+
+        buf.append("}");
+        return buf.toString();
+    }
+
+    /**
+     * Returns a shallow copy of this <tt>MapBase</tt> instance: the keys
+     * and values themselves are not cloned.
+     *
+     * @return a shallow copy of this map.
+     */
+    protected Object clone() throws CloneNotSupportedException {
+        MapBase result = (MapBase) super.clone();
+        result.keySet = null;
+        result.values = null;
+        return result;
+    }
+
+    /**
+     * This should be made public as soon as possible.  It greately simplifies
+     * the task of implementing Map.
+     */
+    static class SimpleEntry implements Entry {
+        Object key;
+        Object value;
+
+        public SimpleEntry(Object key, Object value) {
+            this.key = key;
+            this.value = value;
+        }
+
+        public SimpleEntry(Map.Entry e) {
+            this.key = e.getKey();
+            this.value = e.getValue();
+        }
+
+        public Object getKey() {
+            return key;
+        }
+
+        public Object getValue() {
+            return value;
+        }
+
+        public Object setValue(Object value) {
+            Object oldValue = this.value;
+            this.value = value;
+            return oldValue;
+        }
+
+        public boolean equals(Object o) {
+            if (!(o instanceof Map.Entry))
+                return false;
+            Map.Entry e = (Map.Entry) o;
+            return eq(key, e.getKey()) && eq(value, e.getValue());
+        }
+
+        public int hashCode() {
+            Object v;
+            return ((key == null) ? 0 : key.hashCode())
+                ^ ((value == null) ? 0 : value.hashCode());
+        }
+
+        public String toString() {
+            return key + "=" + value;
+        }
+
+        private static boolean eq(Object o1, Object o2) {
+            return (o1 == null ? o2 == null : o1.equals(o2));
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ToolBase.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ToolBase.java
new file mode 100644
index 0000000..4d11c85
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/ToolBase.java
@@ -0,0 +1,142 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util;
+
+import java.io.OutputStream;
+import java.io.PrintStream;
+
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.xml.internal.ws.util.localization.Localizer;
+
+/**
+ * A base class for command-line tools.
+ *
+ * @author WS Development Team
+ */
+public abstract class ToolBase {
+
+    public ToolBase(OutputStream out, String program) {
+        this.out = out;
+        this.program = program;
+        initialize();
+    }
+
+    protected void initialize() {
+        messageFactory = new LocalizableMessageFactory(getResourceBundleName());
+        localizer = new Localizer();
+    }
+
+    public boolean run(String[] args) {
+        if (!parseArguments(args)) {
+            return false;
+        }
+
+        try {
+            run();
+            return wasSuccessful();
+        } catch (Exception e) {
+            if (e instanceof Localizable) {
+                report((Localizable) e);
+            } else {
+                report(getMessage(getGenericErrorMessage(), e.toString()));
+            }
+            printStackTrace(e);
+            return false;
+        }
+    }
+
+    public boolean wasSuccessful() {
+        return true;
+    }
+
+    protected abstract boolean parseArguments(String[] args);
+    protected abstract void run() throws Exception;
+    public void runProcessorActions() {}
+    protected abstract String getGenericErrorMessage();
+    protected abstract String getResourceBundleName();
+
+    public void printStackTrace(Throwable t) {
+        PrintStream outstream =
+                out instanceof PrintStream
+                        ? (PrintStream) out
+                        : new PrintStream(out, true);
+        t.printStackTrace(outstream);
+        outstream.flush();
+    }
+
+    protected void report(String msg) {
+        PrintStream outstream =
+                out instanceof PrintStream
+                        ? (PrintStream) out
+                        : new PrintStream(out, true);
+        outstream.println(msg);
+        outstream.flush();
+    }
+
+    protected void report(Localizable msg) {
+        report(localizer.localize(msg));
+    }
+
+    public Localizable getMessage(String key) {
+        return getMessage(key, (Object[]) null);
+    }
+
+    public Localizable getMessage(String key, String arg) {
+        return messageFactory.getMessage(key, new Object[] { arg });
+    }
+
+    public Localizable getMessage(String key, String arg1, String arg2) {
+        return messageFactory.getMessage(key, new Object[] { arg1, arg2 });
+    }
+
+    public Localizable getMessage(
+        String key,
+        String arg1,
+        String arg2,
+        String arg3) {
+        return messageFactory.getMessage(
+                key,
+                new Object[] { arg1, arg2, arg3 });
+    }
+
+    public Localizable getMessage(String key, Localizable localizable) {
+        return messageFactory.getMessage(key, new Object[] { localizable });
+    }
+
+    public Localizable getMessage(String key, Object[] args) {
+        return messageFactory.getMessage(key, args);
+    }
+
+    protected OutputStream out;
+    protected String program;
+    protected Localizer localizer;
+    protected LocalizableMessageFactory messageFactory;
+
+    protected final static String TRUE = "true";
+    protected final static String FALSE = "false";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/WSDLParseException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/WSDLParseException.java
new file mode 100644
index 0000000..059f746
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/WSDLParseException.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+  * @author WS Development Team
+  */
+public class WSDLParseException extends JAXWSExceptionBase {
+
+    public WSDLParseException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public WSDLParseException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.util";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/WSToolsObjectFactoryImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/WSToolsObjectFactoryImpl.java
new file mode 100644
index 0000000..42c8bc45
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/WSToolsObjectFactoryImpl.java
@@ -0,0 +1,49 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.util;
+
+import com.sun.tools.internal.ws.spi.WSToolsObjectFactory;
+import com.sun.tools.internal.ws.wscompile.CompileTool;
+import java.io.OutputStream;
+
+/**
+ * Factory implementation class to instantiate concrete objects for JAX-WS tools.
+ *
+ * @author JAX-WS Development Team
+ */
+public class WSToolsObjectFactoryImpl extends WSToolsObjectFactory {
+
+    @Override
+    public boolean wsimport(OutputStream logStream, String[] args) {
+        CompileTool tool = new CompileTool(logStream, "wsimport");
+        return tool.run(args);
+    }
+
+    @Override
+    public boolean wsgen(OutputStream logStream, String[] args) {
+        CompileTool tool = new CompileTool(logStream, "wsgen");
+        return tool.run(args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/NodeListIterator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/NodeListIterator.java
new file mode 100644
index 0000000..d7f504e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/NodeListIterator.java
@@ -0,0 +1,64 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util.xml;
+
+import java.util.Iterator;
+import java.util.NoSuchElementException;
+
+import org.w3c.dom.NodeList;
+
+/**
+ * @author WS Development Team
+ */
+public class NodeListIterator implements Iterator {
+
+    protected NodeList _list;
+    protected int _index;
+
+    public NodeListIterator(NodeList list) {
+        _list = list;
+        _index = 0;
+    }
+
+    public boolean hasNext() {
+        if (_list == null)
+            return false;
+        return _index < _list.getLength();
+    }
+
+    public Object next() throws NoSuchElementException {
+        if (_list.getLength() == 0)
+            throw new NoSuchElementException();
+        Object obj = _list.item(_index);
+        if (obj != null)
+            ++_index;
+        return obj;
+    }
+
+    public void remove() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/NullEntityResolver.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/NullEntityResolver.java
new file mode 100644
index 0000000..6378e64
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/NullEntityResolver.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util.xml;
+
+import java.io.StringReader;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+
+/**
+ * @author WS Development Team
+ */
+public class NullEntityResolver implements EntityResolver {
+
+    public NullEntityResolver() {
+    }
+
+    public InputSource resolveEntity(String publicId, String systemId) {
+        // always resolve to an empty document
+        return new InputSource(new StringReader(""));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/PrettyPrintingXmlWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/PrettyPrintingXmlWriter.java
new file mode 100644
index 0000000..d128876
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/PrettyPrintingXmlWriter.java
@@ -0,0 +1,646 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util.xml;
+
+import java.io.BufferedWriter;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.UnsupportedEncodingException;
+
+import com.sun.xml.internal.ws.util.xml.CDATA;
+
+// ## Delay IOExceptions until flush or close
+// ## Need DOM, SAX output
+
+/**
+ * A writer of XML output streams.
+ *
+ * <p> An XML writer knows hardly anything about XML document well-formedness,
+ * to say nothing of validity.  It relies upon the invoker to ensure that the
+ * generated document is well-formed and, if required, valid.
+ *
+ *
+ * @author WS Development Team
+ */
+
+public class PrettyPrintingXmlWriter {
+
+    private static final boolean shouldPrettyprint = true;
+
+    private BufferedWriter out;
+
+    private PrettyPrintingXmlWriter(OutputStreamWriter w, boolean declare)
+        throws IOException {
+        // XXX-NOTE - set the buffer size to 1024 here
+        this.out = new BufferedWriter(w, 1024);
+        String enc = w.getEncoding();
+
+        /* Work around bogus canonical encoding names */
+        if (enc.equals("UTF8"))
+            enc = "UTF-8";
+        else if (enc.equals("ASCII"))
+            enc = "US-ASCII";
+
+        if (declare) {
+            out.write("<?xml version=\"1.0\" encoding=\"" + enc + "\"?>");
+            out.newLine();
+            needNewline = true;
+        }
+    }
+
+    /**
+     * Creates a new writer that will write to the given byte-output stream
+     * using the given encoding.  An initial XML declaration will optionally be
+     * written to the stream.  </p>
+     *
+     * @param  out
+     *         The target byte-output stream
+     *
+     * @param  enc
+     *         The character encoding to be used
+     *
+     * @param  declare
+     *         If <tt>true</tt>, write the XML declaration to the output stream
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     *
+     * @throws  UnsupportedEncodingException
+     *          If the named encoding is not supported
+     */
+    public PrettyPrintingXmlWriter(
+        OutputStream out,
+        String enc,
+        boolean declare)
+        throws UnsupportedEncodingException, IOException {
+        this(new OutputStreamWriter(out, enc), declare);
+    }
+
+    /**
+     * Creates a new writer that will write to the given byte-output stream
+     * using the given encoding.  An initial XML declaration will be written to
+     * the stream.  </p>
+     *
+     * @param  out
+     *         The target byte-output stream
+     *
+     * @param  enc
+     *         The character encoding to be used
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     *
+     * @throws  UnsupportedEncodingException
+     *          If the named encoding is not supported
+     */
+    public PrettyPrintingXmlWriter(OutputStream out, String enc)
+        throws UnsupportedEncodingException, IOException {
+        this(new OutputStreamWriter(out, enc), true);
+    }
+
+    /**
+     * Creates a new writer that will write to the given byte-output stream
+     * using the UTF-8 encoding.  An initial XML declaration will be written to
+     * the stream.  </p>
+     *
+     * @param  out
+     *         The target byte-output stream
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public PrettyPrintingXmlWriter(OutputStream out) throws IOException {
+        this(new OutputStreamWriter(out, "UTF-8"), true);
+    }
+
+    private char quoteChar = '"';
+
+    /**
+     * Sets the quote character to be used by this writer when writing
+     * attribute values.  </p>
+     *
+     * @param  quote  The new quote character, either a
+     *                <small>QUOTATION MARK</small> (<tt>'&#92;u0022'</tt>),
+     *                or an <small>APOSTROPHE-QUOTE</small>
+     *                (<tt>'&#92;u0027'</tt>)
+     *
+     * @throws  IllegalArgumentException
+     *          If the argument is neither of the above characters
+     */
+    public void setQuote(char quote) {
+        if (quote != '"' && quote != '\'')
+            throw new IllegalArgumentException(
+                "Illegal quote character: " + quote);
+        quoteChar = quote;
+    }
+
+    // Quote a character
+    private void quote(char c) throws IOException {
+        switch (c) {
+            case '&' :
+                out.write("&amp;");
+                break;
+            case '<' :
+                out.write("&lt;");
+                break;
+            case '>' :
+                out.write("&gt;");
+                break;
+            default :
+                out.write(c);
+                break;
+        }
+    }
+
+    // Quote a character in an attribute value
+    private void aquote(char c) throws IOException {
+        switch (c) {
+            case '\'' :
+                if (quoteChar == c)
+                    out.write("&apos;");
+                else
+                    out.write(c);
+                break;
+            case '"' :
+                if (quoteChar == c)
+                    out.write("&quot;");
+                else
+                    out.write(c);
+                break;
+            default :
+                quote(c);
+                break;
+        }
+    }
+
+    //
+    private void nonQuote(char c) throws IOException {
+        out.write(c);
+    }
+
+    // Quote a string containing character data
+    private void quote(String s) throws IOException {
+        for (int i = 0; i < s.length(); i++)
+            quote(s.charAt(i));
+    }
+
+    /* Allowing support for CDATA */
+    private void nonQuote(String s) throws IOException {
+        for (int i = 0; i < s.length(); i++)
+            nonQuote(s.charAt(i));
+    }
+
+    // Quote a string containing an attribute value
+    private void aquote(String s) throws IOException {
+        for (int i = 0; i < s.length(); i++)
+            aquote(s.charAt(i));
+    }
+
+    private void indent(int depth) throws IOException {
+        for (int i = 0; i < depth; i++)
+            out.write("  ");
+    }
+
+    // Formatting state
+    private int depth = 0;
+    private boolean inStart = false;
+    private boolean needNewline = false;
+    private boolean writtenChars = false;
+    private boolean inAttribute = false;
+    private boolean inAttributeValue = false;
+
+    /**
+     * Writes a DOCTYPE declaration.  </p>
+     *
+     * @param  root  The name of the root element
+     *
+     * @param  dtd   The URI of the document-type definition
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void doctype(String root, String dtd) throws IOException {
+        if (shouldPrettyprint && needNewline)
+            out.newLine();
+        needNewline = true;
+        out.write("<!DOCTYPE " + root + " SYSTEM " + quoteChar);
+        quote(dtd);
+        out.write(quoteChar + ">");
+        if (shouldPrettyprint)
+            out.newLine();
+    }
+
+    private void start0(String name) throws IOException {
+        finishStart();
+        if (shouldPrettyprint && !writtenChars) {
+            needNewline = true;
+            indent(depth);
+        }
+        out.write('<');
+        out.write(name);
+        inStart = true;
+        writtenChars = false;
+        depth++;
+    }
+
+    private void start1(String name) throws IOException {
+        finishStart();
+        if (shouldPrettyprint && !writtenChars) {
+            if (needNewline)
+                out.newLine();
+            needNewline = true;
+            indent(depth);
+        }
+        out.write('<');
+        out.write(name);
+        inStart = true;
+        writtenChars = false;
+        depth++;
+    }
+
+    private void finishStart() throws IOException {
+        if (inStart) {
+            if (inAttribute)
+                out.write(quoteChar);
+            out.write('>');
+            inStart = false;
+            inAttribute = false;
+            inAttributeValue = false;
+        }
+    }
+
+    /**
+     * Writes a start tag for the named element.  </p>
+     *
+     * @param  name  The name to be used in the start tag
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void start(String name) throws IOException {
+        start1(name);
+    }
+
+    /**
+     * Writes an attribute for the current element.  </p>
+     *
+     * @param  name  The attribute's name
+     *
+     * @param  value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void attribute(String name, String value) throws IOException {
+        attributeName(name);
+        attributeValue(value);
+    }
+
+    /**
+     * Writes an attribute (unquoted) for the current element.  </p>
+     *
+     * @param  name  The attribute's name
+     *
+     * @param  value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void attributeUnquoted(String name, String value)
+        throws IOException {
+        attributeName(name);
+        attributeValueUnquoted(value);
+    }
+
+    /**
+     * Writes an attribute for the current element.  </p>
+     *
+     * @param  prefix  The attribute's prefix
+     *
+     * @param  name  The attribute's name
+     *
+     * @param  value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void attribute(String prefix, String name, String value)
+        throws IOException {
+        attributeName(prefix, name);
+        attributeValue(value);
+    }
+
+    /**
+     * Writes an attribute (unquoted) for the current element.  </p>
+     *
+     * @param  prefix  The attribute's prefix
+     *
+     * @param  name  The attribute's name
+     *
+     * @param  value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void attributeUnquoted(String prefix, String name, String value)
+        throws IOException {
+        attributeName(prefix, name);
+        attributeValueUnquoted(value);
+    }
+
+    /**
+     * Writes an attribute name for the current element.  After invoking this
+     * method, invoke the {@link #attributeValue attributeValue} method to
+     * write the attribute value, or invoke the {@link #attributeValueToken
+     * attributeValueToken} method to write one or more space-separated value
+     * tokens.  </p>
+     *
+     * @param   name  The attribute's name
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     */
+    public void attributeName(String name) throws IOException {
+        if (!inStart)
+            throw new IllegalStateException();
+        if (inAttribute) {
+            out.write(quoteChar);
+            inAttribute = false;
+            inAttributeValue = false;
+        }
+        out.write(' ');
+        out.write(name);
+        out.write('=');
+        out.write(quoteChar);
+        inAttribute = true;
+    }
+
+    /**
+     * Writes an attribute name for the current element.  After invoking this
+     * method, invoke the {@link #attributeValue attributeValue} method to
+     * write the attribute value, or invoke the {@link #attributeValueToken
+     * attributeValueToken} method to write one or more space-separated value
+     * tokens.  </p>
+     *
+     * @param   prefix The attribute's prefix
+     * @param   name  The attribute's name
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     */
+    public void attributeName(String prefix, String name) throws IOException {
+        if (!inStart)
+            throw new IllegalStateException();
+        if (inAttribute) {
+            out.write(quoteChar);
+            inAttribute = false;
+            inAttributeValue = false;
+        }
+        out.write(' ');
+        out.write(prefix);
+        out.write(':');
+        out.write(name);
+        out.write('=');
+        out.write(quoteChar);
+        inAttribute = true;
+    }
+
+    /**
+     * Writes a value for the current attribute.  </p>
+     *
+     * @param   value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was not
+     *          {@link #attributeName attributeName}
+     */
+    public void attributeValue(String value) throws IOException {
+        if (!inAttribute || inAttributeValue)
+            throw new IllegalStateException();
+        aquote(value);
+        out.write(quoteChar);
+        inAttribute = false;
+    }
+
+    /**
+     * Writes a value (unquoted) for the current attribute.  </p>
+     *
+     * @param   value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was not
+     *          {@link #attributeName attributeName}
+     */
+    public void attributeValueUnquoted(String value) throws IOException {
+        if (!inAttribute || inAttributeValue)
+            throw new IllegalStateException();
+        out.write(value, 0, value.length());
+        out.write(quoteChar);
+        inAttribute = false;
+    }
+
+    /**
+     * Writes one token of the current attribute's value.  Adjacent tokens will
+     * be separated by single space characters.  </p>
+     *
+     * @param   token  The token to be written
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #attributeName attributeName} nor
+     *          {@link #attributeValueToken attributeValueToken}
+     */
+    public void attributeValueToken(String token) throws IOException {
+        if (!inAttribute)
+            throw new IllegalStateException();
+        if (inAttributeValue)
+            out.write(' ');
+        aquote(token);
+        inAttributeValue = true;
+    }
+
+    /**
+     * Writes an end tag for the named element.  </p>
+     *
+     * @param  name  The name to be used in the end tag
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void end(String name) throws IOException {
+        if (inStart) {
+            if (inAttribute)
+                out.write(quoteChar);
+            out.write("/>");
+            inStart = false;
+            inAttribute = false;
+            inAttributeValue = false;
+        } else {
+            out.write("</");
+            out.write(name);
+            out.write('>');
+        }
+        depth--;
+        writtenChars = false;
+    }
+
+    /**
+     * Writes some character data.  </p>
+     *
+     * @param  chars  The character data to be written
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void chars(String chars) throws IOException {
+        finishStart();
+        quote(chars);
+        writtenChars = true;
+    }
+
+    public void chars(CDATA chars) throws IOException {
+        finishStart();
+        nonQuote(chars.getText());
+        writtenChars = true;
+    }
+
+    /**
+     * Writes some character data, skipping quoting.  </p>
+     *
+     * @param  chars  The character data to be written
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void charsUnquoted(String chars) throws IOException {
+        finishStart();
+        out.write(chars, 0, chars.length());
+        writtenChars = true;
+    }
+
+    /**
+     * Writes some character data, skipping quoting.  </p>
+     *
+     * @param  buf   Buffer containing the character data to be written
+     * @param  off    The offset of the data to be written
+     * @param  len    The length of the data to be written
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void charsUnquoted(char[] buf, int off, int len)
+        throws IOException {
+        finishStart();
+        out.write(buf, off, len);
+        writtenChars = true;
+    }
+
+    /**
+     * Writes a leaf element with the given character content.  </p>
+     *
+     * @param name  ame to be used in the start and end tags
+     *
+     * @param chars  character data to be written
+     *
+     * <p> This method writes a start tag with the given name, followed by the
+     * given character data, followed by an end tag.  If the <tt>chars</tt>
+     * parameter is <tt>null</tt> or the empty string then an empty tag is
+     * written.  </p>
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void leaf(String name, String chars) throws IOException {
+        start1(name);
+        if ((chars != null) && (chars.length() != 0))
+            chars(chars);
+        end(name);
+    }
+
+    public void inlineLeaf(String name, String chars) throws IOException {
+        start0(name);
+        if ((chars != null) && (chars.length() != 0))
+            chars(chars);
+        end(name);
+    }
+
+    /**
+     * Writes an empty leaf element.  </p>
+     *
+     * @param  name name to be used in the empty-element tag
+     */
+    public void leaf(String name) throws IOException {
+        leaf(name, null);
+    }
+
+    public void inlineLeaf(String name) throws IOException {
+        inlineLeaf(name, null);
+    }
+
+    /**
+     * Flushes the writer.  </p>
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void flush() throws IOException {
+        if (depth != 0)
+            throw new IllegalStateException("Nonzero depth");
+        // if (shouldPrettyprint)
+        out.newLine();
+        out.flush();
+    }
+
+    /**
+     * Flushes the writer and closes the underlying byte-output stream.  </p>
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void close() throws IOException {
+        flush();
+        out.close();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/XmlUtil.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/XmlUtil.java
new file mode 100644
index 0000000..b1e40e7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/XmlUtil.java
@@ -0,0 +1,87 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util.xml;
+
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.StringTokenizer;
+
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerConfigurationException;
+import javax.xml.transform.TransformerFactory;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Element;
+import org.w3c.dom.EntityReference;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+import org.w3c.dom.Text;
+
+import com.sun.xml.internal.messaging.saaj.util.ByteInputStream;
+import com.sun.tools.internal.ws.util.WSDLParseException;
+import com.sun.xml.internal.ws.util.xml.NamedNodeMapIterator;
+import com.sun.xml.internal.ws.util.xml.NodeListIterator;
+
+/**
+ * @author WS Development Team
+ */
+public class XmlUtil extends com.sun.xml.internal.ws.util.xml.XmlUtil {
+
+    public static boolean matchesTagNS(Element e, String tag, String nsURI) {
+        try {
+            return e.getLocalName().equals(tag)
+                && e.getNamespaceURI().equals(nsURI);
+        } catch (NullPointerException npe) {
+
+            // localname not null since parsing would fail before here
+            throw new WSDLParseException(
+                "null.namespace.found",
+                e.getLocalName());
+        }
+    }
+
+    public static boolean matchesTagNS(
+        Element e,
+        javax.xml.namespace.QName name) {
+        try {
+            return e.getLocalName().equals(name.getLocalPart())
+                && e.getNamespaceURI().equals(name.getNamespaceURI());
+        } catch (NullPointerException npe) {
+
+            // localname not null since parsing would fail before here
+            throw new WSDLParseException(
+                "null.namespace.found",
+                e.getLocalName());
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/XmlWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/XmlWriter.java
new file mode 100644
index 0000000..e846f04
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/util/xml/XmlWriter.java
@@ -0,0 +1,643 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.util.xml;
+
+import java.io.BufferedWriter;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.UnsupportedEncodingException;
+
+import com.sun.xml.internal.ws.util.xml.CDATA;
+
+// ## Delay IOExceptions until flush or close
+// ## Need DOM, SAX output
+
+/**
+ * A writer of XML output streams.
+ *
+ * <p> An XML writer knows hardly anything about XML document well-formedness,
+ * to say nothing of validity.  It relies upon the invoker to ensure that the
+ * generated document is well-formed and, if required, valid.
+ *
+ *
+ * @author WS Development Team
+ */
+
+public class XmlWriter {
+
+    private static final boolean shouldPrettyprint = false;
+
+    private BufferedWriter out;
+
+    private XmlWriter(OutputStreamWriter w, boolean declare)
+        throws IOException {
+        // XXX-NOTE - set the buffer size to 1024 here
+        this.out = new BufferedWriter(w, 1024);
+        String enc = w.getEncoding();
+
+        /* Work around bogus canonical encoding names */
+        if (enc.equals("UTF8"))
+            enc = "UTF-8";
+        else if (enc.equals("ASCII"))
+            enc = "US-ASCII";
+
+        if (declare) {
+            out.write("<?xml version=\"1.0\" encoding=\"" + enc + "\"?>");
+            out.newLine();
+            needNewline = true;
+        }
+    }
+
+    /**
+     * Creates a new writer that will write to the given byte-output stream
+     * using the given encoding.  An initial XML declaration will optionally be
+     * written to the stream.  </p>
+     *
+     * @param  out
+     *         The target byte-output stream
+     *
+     * @param  enc
+     *         The character encoding to be used
+     *
+     * @param  declare
+     *         If <tt>true</tt>, write the XML declaration to the output stream
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     *
+     * @throws  UnsupportedEncodingException
+     *          If the named encoding is not supported
+     */
+    public XmlWriter(OutputStream out, String enc, boolean declare)
+        throws UnsupportedEncodingException, IOException {
+        this(new OutputStreamWriter(out, enc), declare);
+    }
+
+    /**
+     * Creates a new writer that will write to the given byte-output stream
+     * using the given encoding.  An initial XML declaration will be written to
+     * the stream.  </p>
+     *
+     * @param  out
+     *         The target byte-output stream
+     *
+     * @param  enc
+     *         The character encoding to be used
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     *
+     * @throws  UnsupportedEncodingException
+     *          If the named encoding is not supported
+     */
+    public XmlWriter(OutputStream out, String enc)
+        throws UnsupportedEncodingException, IOException {
+        this(new OutputStreamWriter(out, enc), true);
+    }
+
+    /**
+     * Creates a new writer that will write to the given byte-output stream
+     * using the UTF-8 encoding.  An initial XML declaration will be written to
+     * the stream.  </p>
+     *
+     * @param  out
+     *         The target byte-output stream
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public XmlWriter(OutputStream out) throws IOException {
+        this(new OutputStreamWriter(out, "UTF-8"), true);
+    }
+
+    private char quoteChar = '"';
+
+    /**
+     * Sets the quote character to be used by this writer when writing
+     * attribute values.  </p>
+     *
+     * @param  quote  The new quote character, either a
+     *                <small>QUOTATION MARK</small> (<tt>'&#92;u0022'</tt>),
+     *                or an <small>APOSTROPHE-QUOTE</small>
+     *                (<tt>'&#92;u0027'</tt>)
+     *
+     * @throws  IllegalArgumentException
+     *          If the argument is neither of the above characters
+     */
+    public void setQuote(char quote) {
+        if (quote != '"' && quote != '\'')
+            throw new IllegalArgumentException(
+                "Illegal quote character: " + quote);
+        quoteChar = quote;
+    }
+
+    // Quote a character
+    private void quote(char c) throws IOException {
+        switch (c) {
+            case '&' :
+                out.write("&amp;");
+                break;
+            case '<' :
+                out.write("&lt;");
+                break;
+            case '>' :
+                out.write("&gt;");
+                break;
+            default :
+                out.write(c);
+                break;
+        }
+    }
+
+    //
+    private void nonQuote(char c) throws IOException {
+        out.write(c);
+    }
+
+    // Quote a character in an attribute value
+    private void aquote(char c) throws IOException {
+        switch (c) {
+            case '\'' :
+                if (quoteChar == c)
+                    out.write("&apos;");
+                else
+                    out.write(c);
+                break;
+            case '"' :
+                if (quoteChar == c)
+                    out.write("&quot;");
+                else
+                    out.write(c);
+                break;
+            default :
+                quote(c);
+                break;
+        }
+    }
+
+    // Quote a string containing character data
+    private void quote(String s) throws IOException {
+        for (int i = 0; i < s.length(); i++)
+            quote(s.charAt(i));
+    }
+
+    /* Allowing support for CDATA */
+    private void nonQuote(String s) throws IOException {
+        for (int i = 0; i < s.length(); i++)
+            nonQuote(s.charAt(i));
+    }
+
+    // Quote a string containing an attribute value
+    private void aquote(String s) throws IOException {
+        for (int i = 0; i < s.length(); i++)
+            aquote(s.charAt(i));
+    }
+
+    private void indent(int depth) throws IOException {
+        for (int i = 0; i < depth; i++)
+            out.write("  ");
+    }
+
+    // Formatting state
+    private int depth = 0;
+    private boolean inStart = false;
+    private boolean needNewline = false;
+    private boolean writtenChars = false;
+    private boolean inAttribute = false;
+    private boolean inAttributeValue = false;
+
+    /**
+     * Writes a DOCTYPE declaration.  </p>
+     *
+     * @param  root  The name of the root element
+     *
+     * @param  dtd   The URI of the document-type definition
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void doctype(String root, String dtd) throws IOException {
+        if (shouldPrettyprint && needNewline)
+            out.newLine();
+        needNewline = true;
+        out.write("<!DOCTYPE " + root + " SYSTEM " + quoteChar);
+        quote(dtd);
+        out.write(quoteChar + ">");
+        if (shouldPrettyprint)
+            out.newLine();
+    }
+
+    private void start0(String name) throws IOException {
+        finishStart();
+        if (shouldPrettyprint && !writtenChars) {
+            needNewline = true;
+            indent(depth);
+        }
+        out.write('<');
+        out.write(name);
+        inStart = true;
+        writtenChars = false;
+        depth++;
+    }
+
+    private void start1(String name) throws IOException {
+        finishStart();
+        if (shouldPrettyprint && !writtenChars) {
+            if (needNewline)
+                out.newLine();
+            needNewline = true;
+            indent(depth);
+        }
+        out.write('<');
+        out.write(name);
+        inStart = true;
+        writtenChars = false;
+        depth++;
+    }
+
+    private void finishStart() throws IOException {
+        if (inStart) {
+            if (inAttribute)
+                out.write(quoteChar);
+            out.write('>');
+            inStart = false;
+            inAttribute = false;
+            inAttributeValue = false;
+        }
+    }
+
+    /**
+     * Writes a start tag for the named element.  </p>
+     *
+     * @param  name  The name to be used in the start tag
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void start(String name) throws IOException {
+        start1(name);
+    }
+
+    /**
+     * Writes an attribute for the current element.  </p>
+     *
+     * @param  name  The attribute's name
+     *
+     * @param  value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void attribute(String name, String value) throws IOException {
+        attributeName(name);
+        attributeValue(value);
+    }
+
+    /**
+     * Writes an attribute (unquoted) for the current element.  </p>
+     *
+     * @param  name  The attribute's name
+     *
+     * @param  value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void attributeUnquoted(String name, String value)
+        throws IOException {
+        attributeName(name);
+        attributeValueUnquoted(value);
+    }
+
+    /**
+     * Writes an attribute for the current element.  </p>
+     *
+     * @param  prefix  The attribute's prefix
+     *
+     * @param  name  The attribute's name
+     *
+     * @param  value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void attribute(String prefix, String name, String value)
+        throws IOException {
+        attributeName(prefix, name);
+        attributeValue(value);
+    }
+
+    /**
+     * Writes an attribute (unquoted) for the current element.  </p>
+     *
+     * @param  prefix  The attribute's prefix
+     *
+     * @param  name  The attribute's name
+     *
+     * @param  value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void attributeUnquoted(String prefix, String name, String value)
+        throws IOException {
+        attributeName(prefix, name);
+        attributeValueUnquoted(value);
+    }
+
+    /**
+     * Writes an attribute name for the current element.  After invoking this
+     * method, invoke the {@link #attributeValue attributeValue} method to
+     * write the attribute value, or invoke the {@link #attributeValueToken
+     * attributeValueToken} method to write one or more space-separated value
+     * tokens.  </p>
+     *
+     * @param   name  The attribute's name
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     */
+    public void attributeName(String name) throws IOException {
+        if (!inStart)
+            throw new IllegalStateException();
+        if (inAttribute) {
+            out.write(quoteChar);
+            inAttribute = false;
+            inAttributeValue = false;
+        }
+        out.write(' ');
+        out.write(name);
+        out.write('=');
+        out.write(quoteChar);
+        inAttribute = true;
+    }
+
+    /**
+     * Writes an attribute name for the current element.  After invoking this
+     * method, invoke the {@link #attributeValue attributeValue} method to
+     * write the attribute value, or invoke the {@link #attributeValueToken
+     * attributeValueToken} method to write one or more space-separated value
+     * tokens.  </p>
+     *
+     * @param   prefix The attribute's prefix
+     * @param   name  The attribute's name
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #start start} nor {@link #attribute attribute}
+     */
+    public void attributeName(String prefix, String name) throws IOException {
+        if (!inStart)
+            throw new IllegalStateException();
+        if (inAttribute) {
+            out.write(quoteChar);
+            inAttribute = false;
+            inAttributeValue = false;
+        }
+        out.write(' ');
+        out.write(prefix);
+        out.write(':');
+        out.write(name);
+        out.write('=');
+        out.write(quoteChar);
+        inAttribute = true;
+    }
+
+    /**
+     * Writes a value for the current attribute.  </p>
+     *
+     * @param   value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was not
+     *          {@link #attributeName attributeName}
+     */
+    public void attributeValue(String value) throws IOException {
+        if (!inAttribute || inAttributeValue)
+            throw new IllegalStateException();
+        aquote(value);
+        out.write(quoteChar);
+        inAttribute = false;
+    }
+
+    /**
+     * Writes a value (unquoted) for the current attribute.  </p>
+     *
+     * @param   value  The attribute's value
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was not
+     *          {@link #attributeName attributeName}
+     */
+    public void attributeValueUnquoted(String value) throws IOException {
+        if (!inAttribute || inAttributeValue)
+            throw new IllegalStateException();
+        out.write(value, 0, value.length());
+        out.write(quoteChar);
+        inAttribute = false;
+    }
+
+    /**
+     * Writes one token of the current attribute's value.  Adjacent tokens will
+     * be separated by single space characters.  </p>
+     *
+     * @param   token  The token to be written
+     *
+     * @throws  IllegalStateException
+     *          If the previous method invoked upon this object was neither
+     *          {@link #attributeName attributeName} nor
+     *          {@link #attributeValueToken attributeValueToken}
+     */
+    public void attributeValueToken(String token) throws IOException {
+        if (!inAttribute)
+            throw new IllegalStateException();
+        if (inAttributeValue)
+            out.write(' ');
+        aquote(token);
+        inAttributeValue = true;
+    }
+
+    /**
+     * Writes an end tag for the named element.  </p>
+     *
+     * @param  name  The name to be used in the end tag
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void end(String name) throws IOException {
+        if (inStart) {
+            if (inAttribute)
+                out.write(quoteChar);
+            out.write("/>");
+            inStart = false;
+            inAttribute = false;
+            inAttributeValue = false;
+        } else {
+            out.write("</");
+            out.write(name);
+            out.write('>');
+        }
+        depth--;
+        writtenChars = false;
+    }
+
+    /**
+     * Writes some character data.  </p>
+     *
+     * @param  chars  The character data to be written
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void chars(String chars) throws IOException {
+        finishStart();
+        quote(chars);
+        writtenChars = true;
+    }
+
+    public void chars(CDATA chars) throws IOException {
+        finishStart();
+        nonQuote(chars.getText());
+        writtenChars = true;
+    }
+
+    /**
+     * Writes some character data, skipping quoting.  </p>
+     *
+     * @param  chars  The character data to be written
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void charsUnquoted(String chars) throws IOException {
+        finishStart();
+        out.write(chars, 0, chars.length());
+        writtenChars = true;
+    }
+
+    /**
+     * Writes some character data, skipping quoting.  </p>
+     *
+     * @param  buf   Buffer containing the character data to be written
+     * @param  off    The offset of the data to be written
+     * @param  len    The length of the data to be written
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void charsUnquoted(char[] buf, int off, int len)
+        throws IOException {
+        finishStart();
+        out.write(buf, off, len);
+        writtenChars = true;
+    }
+
+    /**
+     * Writes a leaf element with the given character content.  </p>
+     *
+     * @param  name  The name to be used in the start and end tags
+     *
+     * @param  chars  The character data to be written
+     *
+     * <p> This method writes a start tag with the given name, followed by the
+     * given character data, followed by an end tag.  If the <tt>chars</tt>
+     * parameter is <tt>null</tt> or the empty string then an empty tag is
+     * written.  </p>
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void leaf(String name, String chars) throws IOException {
+        start1(name);
+        if ((chars != null) && (chars.length() != 0))
+            chars(chars);
+        end(name);
+    }
+
+    public void inlineLeaf(String name, String chars) throws IOException {
+        start0(name);
+        if ((chars != null) && (chars.length() != 0))
+            chars(chars);
+        end(name);
+    }
+
+    /**
+     * Writes an empty leaf element.  </p>
+     *
+     * @param name name to be used in the empty-element tag
+     */
+    public void leaf(String name) throws IOException {
+        leaf(name, null);
+    }
+
+    public void inlineLeaf(String name) throws IOException {
+        inlineLeaf(name, null);
+    }
+
+    /**
+     * Flushes the writer.  </p>
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void flush() throws IOException {
+        if (depth != 0)
+            // throw new IllegalStateException("Nonzero depth");
+            // if (shouldPrettyprint)
+            out.newLine();
+        out.flush();
+    }
+
+    /**
+     * Flushes the writer and closes the underlying byte-output stream.  </p>
+     *
+     * @throws  IOException
+     *          If an I/O error occurs
+     */
+    public void close() throws IOException {
+        flush();
+        out.close();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/version.properties b/jaxws/src/share/classes/com/sun/tools/internal/ws/version.properties
new file mode 100644
index 0000000..b269810
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/version.properties
@@ -0,0 +1,3 @@
+build-id=b08
+build-version=JAX-WS RI 2.0_02-b08-fcs
+major-version=2.0_02
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/ActionConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/ActionConstants.java
new file mode 100644
index 0000000..a91f6f7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/ActionConstants.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wscompile;
+
+/**
+ * @author WS Development Team
+ */
+public interface ActionConstants {
+//    public static final String ACTION_SERVICE_INTERFACE_GENERATOR =
+//        "service.interface.generator";
+    public static final String ACTION_SERVICE_GENERATOR =
+        "service.generator";
+    public static final String ACTION_REMOTE_INTERFACE_GENERATOR  =
+        "remote.interface.impl.generator";
+    public static final String ACTION_REMOTE_INTERFACE_IMPL_GENERATOR  =
+        "remote.interface.impl.generator";
+    public static final String ACTION_JAXB_TYPE_GENERATOR =
+        "jaxb.type.generator";
+    public static final String ACTION_CUSTOM_EXCEPTION_GENERATOR =
+        "custom.exception.generator";
+    public static final String ACTION_WSDL_GENERATOR =
+        "wsdl.generator";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/CompileTool.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/CompileTool.java
new file mode 100644
index 0000000..9110e85
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/CompileTool.java
@@ -0,0 +1,967 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wscompile;
+
+import com.sun.mirror.apt.AnnotationProcessor;
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.apt.AnnotationProcessorFactory;
+import com.sun.mirror.declaration.AnnotationTypeDeclaration;
+import com.sun.tools.internal.ws.processor.Processor;
+import com.sun.tools.internal.ws.processor.ProcessorAction;
+import com.sun.tools.internal.ws.processor.ProcessorConstants;
+import com.sun.tools.internal.ws.processor.ProcessorNotificationListener;
+import com.sun.tools.internal.ws.processor.ProcessorOptions;
+import com.sun.tools.internal.ws.processor.config.ClassModelInfo;
+import com.sun.tools.internal.ws.processor.config.Configuration;
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+import com.sun.tools.internal.ws.processor.config.parser.Reader;
+import com.sun.tools.internal.ws.processor.generator.CustomExceptionGenerator;
+import com.sun.tools.internal.ws.processor.generator.SeiGenerator;
+import com.sun.tools.internal.ws.processor.model.Model;
+import com.sun.tools.internal.ws.processor.modeler.annotation.AnnotationProcessorContext;
+import com.sun.tools.internal.ws.processor.modeler.annotation.WebServiceAP;
+import com.sun.tools.internal.ws.processor.util.ClientProcessorEnvironment;
+import com.sun.tools.internal.ws.processor.util.GeneratedFileInfo;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironmentBase;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.tools.internal.ws.util.JavaCompilerHelper;
+import com.sun.tools.internal.ws.util.ToolBase;
+import com.sun.tools.internal.ws.util.ForkEntityResolver;
+import com.sun.tools.internal.ws.ToolVersion;
+import com.sun.xml.internal.ws.util.VersionUtil;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.wsdl.writer.WSDLGenerator;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.binding.soap.SOAPBindingImpl;
+
+
+import javax.xml.namespace.QName;
+import javax.xml.transform.Result;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.ws.BindingType;
+import javax.xml.ws.Holder;
+import javax.xml.ws.soap.SOAPBinding;
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.OutputStream;
+import java.net.URLClassLoader;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Properties;
+import java.util.Set;
+
+import org.xml.sax.EntityResolver;
+
+/**
+ *    This is the real implementation class for both WsGen and WsImport.
+ *
+ *    <P>If the program being executed is WsGen, the CompileTool acts as an
+ *    {@link com.sun.mirror.apt.AnnotationProcessorFactory AnnotationProcessorFactory}
+ *    and uses {@link com.sun.tools.internal.ws.processor.modeler.annotation.WebServiceAP
+ *    WebServiceAP} as the {@link com.sun.mirror.apt.AnnotationProcessor
+ *    AnnotationProcessor} for the APT framework.  In this case APT takes control
+ *    while processing the SEI passed to WsGen.  The APT framework then invokes the
+ *    WebServiceAP to process classes that contain javax.jws.* annotations.
+ *    WsGen uses the APT reflection library to process the SEI and to generate any
+ *    JAX-WS spec mandated Java beans.
+ *
+ *    <p>If the program being executed is WsImport, the CompileTool creates a
+ *    {@link com.sun.tools.internal.ws.processor.Processor  Processor} to help with the
+ *    processing.  First the {@link com.sun.tools.internal.ws.processor.Processor#runModeler()
+ *    Processor.runModeler()} method is called to create an instance of the
+ *    {@link com.sun.tools.internal.ws.processor.modeler.wsdl.WSDLModeler WSDLModeler} to
+ *    process the WSDL being imported, which intern processes the WSDL and creates
+ *    a {@link com.sun.tools.internal.ws.processor.model.Model Model} that is returned to the
+ *    Processor.  The CompileTool then registers a number of
+ *    {@link com.sun.tools.internal.ws.processor.ProcessorAction ProcessorActions} with the
+ *    Processor.  Some of these ProcessorActions include
+ *    the {@link com.sun.tools.internal.ws.processor.generator.CustomExceptionGenerator
+ *    CustomExceptionGenerator} to generate Exception classes,
+ *    the {@link com.sun.tools.internal.ws.processor.generator.JAXBTypeGenerator
+ *    JAXBTypeGenerator} to generate JAXB types,
+ *    the {@link com.sun.tools.internal.ws.processor.generator.ServiceGenerator
+ *    ServiceGenerator} to generate the Service interface, and
+ *    the {@link com.sun.tools.internal.ws.processor.generator.SeiGenerator
+ *    RemoteInterfaceGenerator} to generate the service endpoint interface.
+ *    The CompileTool then invokes the {@link com.sun.tools.internal.ws.processor.Processor#runActions()
+ *    Processor.runActions()} method to cause these ProcessorActions to run.
+ *    Once the ProcessorActions have been run, the CompileTool will invoke javac
+ *    to compile any classes generated by the  ProcessorActions.
+ *
+ * @author WS Development Team
+ *
+ */
+public class CompileTool extends ToolBase implements ProcessorNotificationListener,
+        AnnotationProcessorFactory {
+
+    public CompileTool(OutputStream out, String program) {
+        super(out, program);
+        listener = this;
+    }
+
+    protected boolean parseArguments(String[] args) {
+        for (int i = 0; i < args.length; i++) {
+            if (args[i].equals("")) {
+                args[i] = null;
+            } else if (args[i].equals("-g")) {
+                compilerDebug = true;
+                args[i] = null;
+            } /*else if (args[i].equals("-O")) {
+                compilerOptimize = true;
+                args[i] = null;
+            }*/ else if (args[i].equals("-verbose")) {
+                verbose = true;
+                args[i] = null;
+            } else if (args[i].equals("-b")) {
+                if(program.equals(WSGEN)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                if ((i + 1) < args.length) {
+                    args[i] = null;
+                    String file = args[++i];
+                    args[i] = null;
+                    bindingFiles.add(JAXWSUtils.absolutize(JAXWSUtils.getFileOrURLName(file)));
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", "-b"));
+                    usage();
+                    return false;
+                }
+            } else if (args[i].equals("-version")) {
+                report(ToolVersion.VERSION.BUILD_VERSION);
+                doNothing = true;
+                args[i] = null;
+                return true;
+            } else if (args[i].equals("-keep")) {
+                keepGenerated = true;
+                args[i] = null;
+            } else if(args[i].equals("-wsdllocation")){
+                if(program.equals(WSGEN)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                if ((i + 1) < args.length) {
+                    args[i]=null;
+                    wsdlLocation = args[++i];
+                    args[i]=null;
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", args[i]));
+                    usage();
+                    return false;
+                }
+            } else if(args[i].equals("-p")){
+                if(program.equals(WSGEN)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                if ((i + 1) < args.length) {
+                    args[i]=null;
+                    defaultPackage = args[++i];
+                    args[i]=null;
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", args[i]));
+                    usage();
+                    return false;
+                }
+            }else if(args[i].equals("-catalog")){
+                if(program.equals(WSGEN)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                if ((i + 1) < args.length) {
+                    args[i]=null;
+                    catalog = args[++i];
+                    args[i]=null;
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", args[i]));
+                    usage();
+                    return false;
+                }
+            }else if (args[i].equals(SERVICENAME_OPTION)) {
+                if(program.equals(WSIMPORT)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                if ((i + 1) < args.length) {
+                    args[i] = null;
+                    serviceName = QName.valueOf(args[++i]);
+                    if (serviceName.getNamespaceURI() == null || serviceName.getNamespaceURI().length() == 0) {
+                        onError(getMessage("wsgen.servicename.missing.namespace", args[i]));
+                        usage();
+                        return false;
+                    }
+                    if (serviceName.getLocalPart() == null || serviceName.getLocalPart().length() == 0) {
+                        onError(getMessage("wsgen.servicename.missing.localname", args[i]));
+                        usage();
+                        return false;
+                    }
+                    args[i] = null;
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", args[i]));
+                    usage();
+                    return false;
+                }
+            } else if (args[i].equals(PORTNAME_OPTION)) {
+                if(program.equals(WSIMPORT)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                if ((i + 1) < args.length) {
+                    args[i] = null;
+                    portName = QName.valueOf(args[++i]);
+                    if (portName.getNamespaceURI() == null || portName.getNamespaceURI().length() == 0) {
+                        onError(getMessage("wsgen.portname.missing.namespace", args[i]));
+                        usage();
+                        return false;
+                    }
+                    if (portName.getLocalPart() == null || portName.getLocalPart().length() == 0) {
+                        onError(getMessage("wsgen.portname.missing.localname", args[i]));
+                        usage();
+                        return false;
+                    }
+                    args[i] = null;
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", args[i]));
+                    usage();
+                    return false;
+                }
+            } else if (args[i].equals("-d")) {
+                if ((i + 1) < args.length) {
+                    if (destDir != null) {
+                        onError(getMessage("wscompile.duplicateOption", "-d"));
+                        usage();
+                        return false;
+                    }
+                    args[i] = null;
+                    destDir = new File(args[++i]);
+                    args[i] = null;
+                    if (!destDir.exists()) {
+                        onError(getMessage("wscompile.noSuchDirectory", destDir.getPath()));
+                        usage();
+                        return false;
+                    }
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", "-d"));
+                    usage();
+                    return false;
+                }
+            } else if (args[i].equals("-r")) {
+                if (program.equals(WSIMPORT)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                if ((i + 1) < args.length) {
+                    if (nonclassDestDir != null) {
+                        onError(getMessage("wscompile.duplicateOption", "-r"));
+                        usage();
+                        return false;
+                    }
+                    args[i] = null;
+                    nonclassDestDir = new File(args[++i]);
+                    args[i] = null;
+                    if (!nonclassDestDir.exists()) {
+                        onError(getMessage("wscompile.noSuchDirectory", nonclassDestDir.getPath()));
+                        usage();
+                        return false;
+                    }
+                } else {
+                onError(getMessage("wscompile.missingOptionArgument", "-r"));
+                    usage();
+                    return false;
+                }
+            } else if (args[i].equals("-s")) {
+                if ((i + 1) < args.length) {
+                    if (sourceDir != null) {
+                        onError(getMessage("wscompile.duplicateOption", "-s"));
+                        usage();
+                        return false;
+                    }
+                    args[i] = null;
+                    sourceDir = new File(args[++i]);
+                    args[i] = null;
+                    if (!sourceDir.exists()) {
+                        onError(getMessage("wscompile.noSuchDirectory", sourceDir.getPath()));
+                        usage();
+                        return false;
+                    }
+                    keepGenerated = true;
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", "-s"));
+                    usage();
+                    return false;
+                }
+            } else if (args[i].equals("-classpath") || args[i].equals("-cp")) {
+                if (program.equals(WSIMPORT)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                if ((i + 1) < args.length) {
+                    if (userClasspath != null) {
+                        onError(getMessage("wscompile.duplicateOption", args[i]));
+                        usage();
+                        return false;
+                    }
+                    args[i] = null;
+                    userClasspath = args[++i];
+                    args[i] = null;
+                } else {
+                    onError(getMessage("wscompile.missingOptionArgument", args[i]));
+                    usage();
+                    return false;
+                }
+
+            } else if (args[i].startsWith("-httpproxy:")) {
+                if(program.equals(WSGEN)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                String value = args[i].substring(11);
+                if (value.length() == 0) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                int index = value.indexOf(':');
+                if (index == -1) {
+                    System.setProperty("proxySet", TRUE);
+                    System.setProperty("proxyHost", value);
+                    System.setProperty("proxyPort", "8080");
+                } else {
+                    System.setProperty("proxySet", TRUE);
+                    System.setProperty("proxyHost", value.substring(0, index));
+                    System.setProperty("proxyPort", value.substring(index + 1));
+                }
+                args[i] = null;
+            } else if (args[i].startsWith("-wsdl")) {
+                if (program.equals(WSIMPORT)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                genWsdl = true;
+                String value = args[i].substring(5);
+                int index = value.indexOf(':');
+                if (index == 0) {
+                    value = value.substring(1);
+                    index = value.indexOf('/');
+                    if (index == -1) {
+                        protocol = value;
+                        transport = HTTP;
+                    } else {
+                        protocol = value.substring(0, index);
+                        transport = value.substring(index + 1);
+                    }
+                    if (!isValidProtocol(protocol)) {
+                        onError(getMessage("wsgen.invalid.protocol", protocol, VALID_PROTOCOLS));
+                    }
+                    protocolSet = true;
+                    if (!isValidTransport(transport)) {
+                        onError(getMessage("wsgen.invalid.transport", transport, VALID_TRANSPORTS));
+                    }
+                }
+                args[i] = null;
+            } else if (args[i].equals("-extension")) {
+                extensions = true;
+                args[i] = null;
+            } else if (args[i].startsWith("-help")) {
+                help();
+                return false;
+            } else if (args[i].equals("-Xdonotoverwrite")) {
+                if(program.equals(WSIMPORT)) {
+                    onError(getMessage("wscompile.invalidOption", args[i]));
+                    usage();
+                    return false;
+                }
+                doNotOverWrite = true;
+                args[i] = null;
+            }
+        }
+
+        for (String arg : args) {
+            if (arg != null) {
+                if (arg.startsWith("-")) {
+                    onError(getMessage("wscompile.invalidOption", arg));
+                    usage();
+                    return false;
+                }
+
+                // the input source could be a local file or a URL,get the
+                // abolutized URL string
+                String fileName = arg;
+                if (program.equals(WSGEN)) {
+                    if (!isValidWSGenClass(fileName))
+                        return false;
+                }
+                inputFiles.add(fileName);
+            }
+        }
+
+        if (inputFiles.isEmpty()) {
+            onError(getMessage(program+".missingFile"));
+            usage();
+            return false;
+        }
+        if (!extensions && hasExtensions())
+            return false;
+
+        // put jaxws and jaxb binding files
+        properties.put(ProcessorOptions.BINDING_FILES, bindingFiles);
+        if (!validateArguments()) {
+            usage();
+            return false;
+        }
+        return true;
+    }
+
+    protected boolean isValidWSGenClass(String className) {
+        Class clazz = getClass(className);
+        if (clazz == null) {
+            onError(getMessage("wsgen.class.not.found", className));
+            return false;
+        }
+        if (clazz.isEnum() || clazz.isInterface() ||
+            clazz.isPrimitive()) {
+            onError(getMessage("wsgen.class.must.be.implementation.class", className));
+            return false;
+        }
+        if (genWsdl) {
+            BindingImpl binding = (BindingImpl)BindingImpl.getBinding(null, clazz, null, false);
+            if (!(binding instanceof SOAPBinding)) {
+                onError(getMessage("wsgen.cannot.gen.wsdl.for.non.soap.binding",
+                        new Object[] {className, binding.getBindingId()}));
+                return false;
+            }
+            SOAPBindingImpl soapBinding = (SOAPBindingImpl)binding;
+            if ((soapBinding.getActualBindingId().equals(SOAPBinding.SOAP12HTTP_BINDING) ||
+                soapBinding.getActualBindingId().equals(SOAPBinding.SOAP12HTTP_MTOM_BINDING)) &&
+                    !(protocol.equals(X_SOAP12) && extensions)) {
+                onError(getMessage("wsgen.cannot.gen.wsdl.for.soap12.binding",
+                        new Object[] {className, binding.getBindingId()}));
+                return false;
+            }
+            if (soapBinding.getActualBindingId().equals(SOAPBindingImpl.X_SOAP12HTTP_BINDING) &&
+                !extensions) {
+                onError(getMessage("wsgen.cannot.gen.wsdl.for.xsoap12.binding.wo.extention",
+                        new Object[] {className, binding.getBindingId()}));
+                return false;
+            }
+        }
+        return true;
+    }
+
+    protected boolean validateArguments() {
+        if (!genWsdl) {
+            if (serviceName != null) {
+                onError(getMessage("wsgen.wsdl.arg.no.genwsdl", SERVICENAME_OPTION));
+                return false;
+            }
+            if (portName != null) {
+                onError(getMessage("wsgen.wsdl.arg.no.genwsdl", PORTNAME_OPTION));
+                return false;
+            }
+        }
+        return true;
+    }
+
+    protected boolean hasExtensions() {
+        if (protocol.equalsIgnoreCase(X_SOAP12)) {
+            onError(getMessage("wsgen.soap12.without.extension"));
+            return true;
+        }
+        return false;
+    }
+
+
+    static public boolean isValidProtocol(String protocol) {
+        return (protocol.equalsIgnoreCase(SOAP11) ||
+                protocol.equalsIgnoreCase(X_SOAP12));
+    }
+
+    static public boolean isValidTransport(String transport) {
+        return (transport.equalsIgnoreCase(HTTP));
+    }
+
+    protected void run() throws Exception {
+        if (doNothing) {
+            return;
+        }
+        try {
+            beforeHook();
+            if(entityResolver == null){
+                if(catalog != null && catalog.length() > 0)
+                    entityResolver = XmlUtil.createEntityResolver(JAXWSUtils.getFileOrURL(catalog));
+            }else if(catalog != null && catalog.length() > 0){
+                EntityResolver er = XmlUtil.createEntityResolver(JAXWSUtils.getFileOrURL(catalog));
+                entityResolver =  new ForkEntityResolver(er, entityResolver);
+            }
+            environment = createEnvironment();
+            configuration = createConfiguration();
+            setEnvironmentValues(environment);
+            if (configuration.getModelInfo() instanceof ClassModelInfo) {
+                buildModel(((ClassModelInfo) configuration.getModelInfo()).getClassName());
+            } else {
+                processor = new Processor(configuration, properties);
+                configuration.getModelInfo().setEntityResolver(entityResolver);
+                configuration.getModelInfo().setDefaultJavaPackage(defaultPackage);
+                processor.runModeler();
+                withModelHook();
+                registerProcessorActions(processor);
+                processor.runActions();
+                if (environment.getErrorCount() == 0) {
+                    compileGeneratedClasses();
+                }
+            }
+            afterHook();
+        } finally {
+            if (!keepGenerated) {
+                removeGeneratedFiles();
+            }
+            if (environment != null) {
+                environment.shutdown();
+            }
+        }
+    }
+
+    protected void setEnvironmentValues(ProcessorEnvironment env) {
+        int envFlags = env.getFlags();
+        envFlags |= ProcessorEnvironment.F_WARNINGS;
+        if (verbose) {
+            envFlags |= ProcessorEnvironment.F_VERBOSE;
+        }
+        env.setFlags(envFlags);
+    }
+
+    protected void initialize() {
+        super.initialize();
+        properties = new Properties();
+        actions = new HashMap<String,ProcessorAction>();
+        actions.put(ActionConstants.ACTION_SERVICE_GENERATOR,
+                new com.sun.tools.internal.ws.processor.generator.ServiceGenerator());
+        actions.put(ActionConstants.ACTION_REMOTE_INTERFACE_GENERATOR,
+                new SeiGenerator());
+        actions.put(ActionConstants.ACTION_CUSTOM_EXCEPTION_GENERATOR,
+                new CustomExceptionGenerator());
+        actions.put(ActionConstants.ACTION_JAXB_TYPE_GENERATOR,
+                new com.sun.tools.internal.ws.processor.generator.JAXBTypeGenerator());
+    }
+
+    public void removeGeneratedFiles() {
+        environment.deleteGeneratedFiles();
+    }
+
+    public void buildModel(String endpoint) {
+        context = new AnnotationProcessorContext();
+        webServiceAP = new WebServiceAP(this, environment, properties, context);
+
+        String classpath = environment.getClassPath();
+
+        String[] args = new String[8];
+        args[0] = "-d";
+        args[1] = destDir.getAbsolutePath();
+        args[2] = "-classpath";
+        args[3] = classpath;
+        args[4] = "-s";
+        args[5] = sourceDir.getAbsolutePath();
+        args[6] = "-XclassesAsDecls";
+        args[7] = endpoint;
+
+        int result = com.sun.tools.apt.Main.process(this, args);
+        if (result != 0) {
+            environment.error(getMessage("wscompile.compilationFailed"));
+            return;
+        }
+        if (genWsdl) {
+            String tmpPath = destDir.getAbsolutePath()+File.pathSeparator+classpath;
+            ClassLoader classLoader = new URLClassLoader(ProcessorEnvironmentBase.pathToURLs(tmpPath),
+                    this.getClass().getClassLoader());
+            Class<?> endpointClass = null;
+
+            try {
+                endpointClass = classLoader.loadClass(endpoint);
+            } catch (ClassNotFoundException e) {
+                // this should never happen
+                environment.error(getMessage("wsgen.class.not.found", endpoint));
+            }
+            String bindingID = getBindingID(protocol);
+            if (!protocolSet) {
+                BindingImpl binding = (BindingImpl)BindingImpl.getBinding(null,
+                                                    endpointClass, null, false);
+                bindingID = binding.getBindingId();
+            }
+            com.sun.xml.internal.ws.modeler.RuntimeModeler rtModeler =
+                    new com.sun.xml.internal.ws.modeler.RuntimeModeler(endpointClass, serviceName, bindingID);
+            rtModeler.setClassLoader(classLoader);
+            if (portName != null)
+                rtModeler.setPortName(portName);
+            com.sun.xml.internal.ws.model.RuntimeModel rtModel = rtModeler.buildRuntimeModel();
+            WSDLGenerator wsdlGenerator = new WSDLGenerator(rtModel,
+                    new com.sun.xml.internal.ws.wsdl.writer.WSDLOutputResolver() {
+                        public Result getWSDLOutput(String suggestedFilename) {
+                            File wsdlFile =
+                                new File(nonclassDestDir, suggestedFilename);
+
+                            Result result = new StreamResult();
+                            try {
+                                result = new StreamResult(new FileOutputStream(wsdlFile));
+                                result.setSystemId(wsdlFile.toString().replace('\\', '/'));
+                            } catch (FileNotFoundException e) {
+                                environment.error(getMessage("wsgen.could.not.create.file", wsdlFile.toString()));
+                            }
+                            return result;
+                        }
+                        public Result getSchemaOutput(String namespace, String suggestedFilename) {
+                            if (namespace.equals(""))
+                                return null;
+                            return getWSDLOutput(suggestedFilename);
+                        }
+                        public Result getAbstractWSDLOutput(Holder<String> filename) {
+                            return getWSDLOutput(filename.value);
+                        }
+                        public Result getSchemaOutput(String namespace, Holder<String> filename) {
+                            return getSchemaOutput(namespace, filename.value);
+                        }
+                    }, bindingID);
+            wsdlGenerator.doGeneration();
+        }
+    }
+
+    static public String getBindingID(String protocol) {
+        if (protocol.equals(SOAP11))
+            return SOAP11_ID;
+        if (protocol.equals(X_SOAP12))
+            return SOAP12_ID;
+        return null;
+    }
+
+    public void runProcessorActions() {
+        if (!(configuration.getModelInfo() instanceof ClassModelInfo)) {
+            onError(getMessage("wscompile.classmodelinfo.expected", new Object[] { configuration
+                    .getModelInfo() }));
+            return;
+        }
+        Model model = context.getSEIContext(
+                ((ClassModelInfo) configuration.getModelInfo()).getClassName()).getModel();
+        processor = new Processor(configuration, properties, model);
+        withModelHook();
+        registerProcessorActions(processor);
+        processor.runActions();
+       // TODO throw an error
+//        if (environment.getErrorCount() != 0) {
+//        }
+
+    }
+    /**
+     * @return the SourceVersion string
+     */
+    protected String getSourceVersion() {
+        if (targetVersion == null) {
+
+            /* no target specified, defaulting to the default version,
+             * which is the latest version
+             */
+            return VersionUtil.JAXWS_VERSION_DEFAULT;
+        }
+        return targetVersion;
+    }
+
+    protected void withModelHook() {
+    }
+
+    protected void afterHook() {
+    }
+
+    protected void compileGeneratedClasses() {
+        List<String> sourceFiles = new ArrayList<String>();
+
+        for (Iterator iter = environment.getGeneratedFiles(); iter.hasNext();) {
+            GeneratedFileInfo fileInfo = (GeneratedFileInfo) iter.next();
+            File f = fileInfo.getFile();
+            if (f.exists() && f.getName().endsWith(".java")) {
+                sourceFiles.add(f.getAbsolutePath());
+            }
+        }
+
+        if (sourceFiles.size() > 0) {
+            String classDir = destDir.getAbsolutePath();
+            String classpathString = createClasspathString();
+            String[] args = new String[4 + (compilerDebug ? 1 : 0)
+                    + (compilerOptimize ? 1 : 0) + sourceFiles.size()];
+            args[0] = "-d";
+            args[1] = classDir;
+            args[2] = "-classpath";
+            args[3] = classpathString;
+            int baseIndex = 4;
+            if (compilerDebug) {
+                args[baseIndex++] = "-g";
+            }
+            if (compilerOptimize) {
+                args[baseIndex++] = "-O";
+            }
+            for (int i = 0; i < sourceFiles.size(); ++i) {
+                args[baseIndex + i] = sourceFiles.get(i);
+            }
+
+            // ByteArrayOutputStream javacOutput = new ByteArrayOutputStream();
+            JavaCompilerHelper compilerHelper = new JavaCompilerHelper(out);
+            boolean result = compilerHelper.compile(args);
+            if (!result) {
+                environment.error(getMessage("wscompile.compilationFailed"));
+            }
+        }
+    }
+
+    protected ProcessorAction getAction(String name) {
+        return actions.get(name);
+    }
+
+    protected String createClasspathString() {
+        if (userClasspath == null) {
+            userClasspath = "";
+        }
+        return userClasspath + File.pathSeparator + System.getProperty("java.class.path");
+    }
+
+    protected void registerProcessorActions(Processor processor) {
+        register(processor);
+    }
+
+    protected void register(Processor processor) {
+        boolean genServiceInterface = false;
+        boolean genInterface = false;
+        boolean genCustomClasses = false;
+
+        if (configuration.getModelInfo() instanceof WSDLModelInfo) {
+            genInterface = true;
+            //genInterfaceTemplate = true;
+            genServiceInterface = true;
+            genCustomClasses = true;
+        }
+
+        if (genServiceInterface) {
+            processor.add(getAction(ActionConstants.ACTION_SERVICE_GENERATOR));
+        }
+
+        if (genCustomClasses) {
+            processor.add(getAction(ActionConstants.ACTION_JAXB_TYPE_GENERATOR));
+        }
+
+        if (genInterface) {
+            processor.add(getAction(ActionConstants.ACTION_CUSTOM_EXCEPTION_GENERATOR));
+            processor.add(getAction(ActionConstants.ACTION_REMOTE_INTERFACE_GENERATOR));
+        }
+    }
+
+    protected Configuration createConfiguration() throws Exception {
+        if (environment == null)
+            environment = createEnvironment();
+        Reader reader = new Reader(environment, properties);
+        return reader.parse(entityResolver, inputFiles);
+    }
+
+    protected void beforeHook() {
+        if (destDir == null) {
+            destDir = new File(".");
+        }
+        if (sourceDir == null) {
+            sourceDir = destDir;
+        }
+        if (nonclassDestDir == null) {
+            nonclassDestDir = destDir;
+        }
+
+        properties.setProperty(ProcessorOptions.SOURCE_DIRECTORY_PROPERTY, sourceDir
+                .getAbsolutePath());
+        properties.setProperty(ProcessorOptions.DESTINATION_DIRECTORY_PROPERTY, destDir
+                .getAbsolutePath());
+        properties.setProperty(ProcessorOptions.NONCLASS_DESTINATION_DIRECTORY_PROPERTY,
+                nonclassDestDir.getAbsolutePath());
+        properties.setProperty(ProcessorOptions.EXTENSION, (extensions ? "true" : "false"));
+        properties.setProperty(ProcessorOptions.PRINT_STACK_TRACE_PROPERTY,
+                (verbose ? TRUE : FALSE));
+        properties.setProperty(ProcessorOptions.PROTOCOL, protocol);
+        properties.setProperty(ProcessorOptions.TRANSPORT, transport);
+        properties.setProperty(ProcessorOptions.JAXWS_SOURCE_VERSION, getSourceVersion());
+        if(wsdlLocation != null)
+            properties.setProperty(ProcessorOptions.WSDL_LOCATION, wsdlLocation);
+        if(defaultPackage != null)
+            properties.setProperty(ProcessorOptions.DEFAULT_PACKAGE, defaultPackage);
+        properties.setProperty(ProcessorOptions.DONOT_OVERWRITE_CLASSES, (doNotOverWrite ? TRUE : FALSE));
+    }
+
+    protected String getGenericErrorMessage() {
+        return "wscompile.error";
+    }
+
+    protected String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.wscompile";
+    }
+
+    public Collection<String> supportedOptions() {
+        return supportedOptions;
+    }
+
+    public Collection<String> supportedAnnotationTypes() {
+        return supportedAnnotations;
+    }
+
+    public void onError(Localizable msg) {
+        report(getMessage("wscompile.error", localizer.localize(msg)));
+    }
+
+    public void onWarning(Localizable msg) {
+        report(getMessage("wscompile.warning", localizer.localize(msg)));
+    }
+
+    public void onInfo(Localizable msg) {
+        report(getMessage("wscompile.info", localizer.localize(msg)));
+    }
+
+    public AnnotationProcessor getProcessorFor(Set<AnnotationTypeDeclaration> atds,
+            AnnotationProcessorEnvironment apEnv) {
+        if (verbose)
+            apEnv.getMessager().printNotice("\tap round: " + ++round);
+        webServiceAP.init(apEnv);
+        return webServiceAP;
+    }
+
+    private Class getClass(String className) {
+        try {
+            ProcessorEnvironment env = createEnvironment();
+            return env.getClassLoader().loadClass(className);
+        } catch (ClassNotFoundException e) {
+            return null;
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        return null;
+    }
+
+    private ProcessorEnvironment createEnvironment() throws Exception {
+        String cpath = userClasspath + File.pathSeparator + System.getProperty("java.class.path");
+        ProcessorEnvironment env = new ClientProcessorEnvironment(System.out, cpath, listener);
+        return env;
+    }
+
+    protected void usage() {
+        help();
+        //report(getMessage(program+".usage", program));
+    }
+
+    protected void help() {
+        report(getMessage(program+".help", program));
+        report(getMessage(program+".usage.examples"));
+    }
+
+    public void setEntityResolver(EntityResolver entityResolver) {
+        this.entityResolver = entityResolver;
+    }
+
+    /*
+     * Processor doesn't examine any options.
+     */
+    static final Collection<String> supportedOptions = Collections
+            .unmodifiableSet(new HashSet<String>());
+
+    /*
+     * All annotation types are supported.
+     */
+    static Collection<String> supportedAnnotations;
+    static {
+        Collection<String> types = new HashSet<String>();
+        types.add("*");
+        types.add("javax.jws.*");
+        types.add("javax.jws.soap.*");
+        supportedAnnotations = Collections.unmodifiableCollection(types);
+    }
+
+    private AnnotationProcessorContext context;
+
+    private WebServiceAP webServiceAP;
+
+    private int round = 0;
+
+    // End AnnotationProcessorFactory stuff
+    // -----------------------------------------------------------------------------
+
+    protected Properties properties;
+    protected ProcessorEnvironment environment;
+    protected Configuration configuration;
+    protected ProcessorNotificationListener listener;
+    protected Processor processor;
+    protected Map<String,ProcessorAction> actions;
+    protected List<String> inputFiles = new ArrayList<String>();
+    protected File sourceDir;
+    protected File destDir;
+    protected File nonclassDestDir;
+    protected boolean doNothing = false;
+    protected boolean compilerDebug = false;
+    protected boolean compilerOptimize = false;
+    protected boolean verbose = false;
+    protected boolean keepGenerated = false;
+    protected boolean doNotOverWrite = false;
+    protected boolean extensions = false;
+    protected String userClasspath = null;
+    protected Set<String> bindingFiles = new HashSet<String>();
+    protected boolean genWsdl = false;
+    protected String protocol = SOAP11;
+    protected boolean protocolSet = false;
+    protected String transport = HTTP;
+    protected static final String SOAP11 = "soap1.1";
+    protected static final String X_SOAP12 = "Xsoap1.2";
+    protected static final String HTTP   = "http";
+    protected static final String WSIMPORT = "wsimport";
+    protected static final String WSGEN    = "wsgen";
+    protected static final String SOAP11_ID = javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_BINDING;
+    protected static final String SOAP12_ID = javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING;
+    protected static final String VALID_PROTOCOLS = SOAP11 +", "+X_SOAP12;
+    protected static final String VALID_TRANSPORTS = "http";
+    protected String  targetVersion = null;
+    protected String wsdlLocation;
+    protected String defaultPackage;
+    protected String catalog;
+    protected QName serviceName;
+    protected QName portName;
+    protected static final String PORTNAME_OPTION = "-portname";
+    protected static final String SERVICENAME_OPTION = "-servicename";
+    protected EntityResolver entityResolver;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/FilerCodeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/FilerCodeWriter.java
new file mode 100644
index 0000000..c6bbcca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/FilerCodeWriter.java
@@ -0,0 +1,71 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wscompile;
+
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import java.io.File;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.Writer;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+import java.io.BufferedOutputStream;
+
+import com.sun.mirror.apt.Filer;
+
+/**
+ * Writes all the source files using the specified Filer.
+ *
+ * @author WS Development Team
+ */
+public class FilerCodeWriter extends WSCodeWriter {
+
+    /** The Filer used to create files. */
+    private final Filer filer;
+
+    private Writer w;
+
+    public FilerCodeWriter(File outDir, ProcessorEnvironment env ) throws IOException {
+        super(outDir, env);
+        this.filer = env.getFiler();
+    }
+
+
+    public Writer openSource(JPackage pkg, String fileName) throws IOException {
+        String tmp = fileName.substring(0, fileName.length()-5);
+        w = filer.createSourceFile(pkg.name()+"."+tmp);
+        return w;
+    }
+
+
+    public void close() throws IOException {
+        super.close();
+        if (w != null)
+            w.close();
+        w = null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/WSCodeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/WSCodeWriter.java
new file mode 100644
index 0000000..0a116a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wscompile/WSCodeWriter.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wscompile;
+
+import java.io.File;
+import java.io.IOException;
+
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.writer.FileCodeWriter;
+import com.sun.tools.internal.ws.processor.util.GeneratedFileInfo;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+
+/**
+ * {@link FileCodeWriter} implementation that notifies
+ * JAX-WS about newly created files.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class WSCodeWriter extends FileCodeWriter {
+    private final ProcessorEnvironment env;
+
+    public WSCodeWriter( File outDir, ProcessorEnvironment _env ) throws IOException {
+        super(outDir);
+        this.env = _env;
+    }
+
+    protected File getFile(JPackage pkg, String fileName ) throws IOException {
+        File f = super.getFile(pkg, fileName);
+
+        // notify JAX-WS RI
+        GeneratedFileInfo fi = new GeneratedFileInfo();
+        fi.setType("JAXB"/*GeneratorConstants.FILE_TYPE_VALUETYPE*/);
+        fi.setFile(f);
+        env.addGeneratedFile(fi);
+        // we can't really tell the file type, for we don't know
+        // what this file is used for. Fortunately,
+        // FILE_TYPE doesn't seem to be used, so it doesn't really
+        // matter what we set.
+
+        return f;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Binding.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Binding.java
new file mode 100644
index 0000000..28b2f3b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Binding.java
@@ -0,0 +1,148 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Defining;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.GlobalEntity;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.QNameAction;
+
+/**
+ * Entity corresponding to the "binding" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Binding extends GlobalEntity implements Extensible {
+
+    public Binding(Defining defining) {
+        super(defining);
+        _operations = new ArrayList();
+        _helper = new ExtensibilityHelper();
+    }
+
+    public void add(BindingOperation operation) {
+        _operations.add(operation);
+    }
+
+    public Iterator operations() {
+        return _operations.iterator();
+    }
+
+    public QName getPortType() {
+        return _portType;
+    }
+
+    public void setPortType(QName n) {
+        _portType = n;
+    }
+
+    public PortType resolvePortType(AbstractDocument document) {
+        return (PortType) document.find(Kinds.PORT_TYPE, _portType);
+    }
+
+    public Kind getKind() {
+        return Kinds.BINDING;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_BINDING;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        for (Iterator iter = _operations.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        super.withAllQNamesDo(action);
+
+        if (_portType != null) {
+            action.perform(_portType);
+        }
+    }
+
+    public void withAllEntityReferencesDo(EntityReferenceAction action) {
+        super.withAllEntityReferencesDo(action);
+        if (_portType != null) {
+            action.perform(Kinds.PORT_TYPE, _portType);
+        }
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        //bug fix: 4947340, extensions should be the first element
+        _helper.accept(visitor);
+        for (Iterator iter = _operations.iterator(); iter.hasNext();) {
+            ((BindingOperation) iter.next()).accept(visitor);
+        }
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (getName() == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+        if (_portType == null) {
+            failValidation("validation.missingRequiredAttribute", "type");
+        }
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+    private QName _portType;
+    private List _operations;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingFault.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingFault.java
new file mode 100644
index 0000000..65c1ba9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingFault.java
@@ -0,0 +1,96 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * Entity corresponding to the "fault" child element of a binding operation.
+ *
+ * @author WS Development Team
+ */
+public class BindingFault extends Entity implements Extensible {
+
+    public BindingFault() {
+        _helper = new ExtensibilityHelper();
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_FAULT;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        _helper.accept(visitor);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (_name == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+    }
+
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+    private String _name;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingInput.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingInput.java
new file mode 100644
index 0000000..5aca957
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingInput.java
@@ -0,0 +1,91 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.Iterator;
+import javax.xml.namespace.QName;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+
+/**
+ * Entity corresponding to the "input" child element of a binding operation.
+ *
+ * @author WS Development Team
+ */
+public class BindingInput extends Entity implements Extensible {
+
+    public BindingInput() {
+        _helper = new ExtensibilityHelper();
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_INPUT;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        _helper.accept(visitor);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+    }
+
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+    private String _name;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingOperation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingOperation.java
new file mode 100644
index 0000000..272784b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingOperation.java
@@ -0,0 +1,203 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * Entity corresponding to the "operation" child element of a WSDL "binding" element.
+ *
+ * @author WS Development Team
+ */
+public class BindingOperation extends Entity implements Extensible {
+
+    public BindingOperation() {
+        _faults = new ArrayList();
+        _helper = new ExtensibilityHelper();
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public String getUniqueKey() {
+        if (_uniqueKey == null) {
+            StringBuffer sb = new StringBuffer();
+            sb.append(_name);
+            sb.append(' ');
+            if (_input != null) {
+                sb.append(_input.getName());
+            } else {
+                sb.append(_name);
+                if (_style == OperationStyle.REQUEST_RESPONSE) {
+                    sb.append("Request");
+                } else if (_style == OperationStyle.SOLICIT_RESPONSE) {
+                    sb.append("Response");
+                }
+            }
+            sb.append(' ');
+            if (_output != null) {
+                sb.append(_output.getName());
+            } else {
+                sb.append(_name);
+                if (_style == OperationStyle.SOLICIT_RESPONSE) {
+                    sb.append("Solicit");
+                } else if (_style == OperationStyle.REQUEST_RESPONSE) {
+                    sb.append("Response");
+                }
+            }
+            _uniqueKey = sb.toString();
+        }
+
+        return _uniqueKey;
+    }
+
+    public OperationStyle getStyle() {
+        return _style;
+    }
+
+    public void setStyle(OperationStyle s) {
+        _style = s;
+    }
+
+    public BindingInput getInput() {
+        return _input;
+    }
+
+    public void setInput(BindingInput i) {
+        _input = i;
+    }
+
+    public BindingOutput getOutput() {
+        return _output;
+    }
+
+    public void setOutput(BindingOutput o) {
+        _output = o;
+    }
+
+    public void addFault(BindingFault f) {
+        _faults.add(f);
+    }
+
+    public Iterator faults() {
+        return _faults.iterator();
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_OPERATION;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        if (_input != null) {
+            action.perform(_input);
+        }
+        if (_output != null) {
+            action.perform(_output);
+        }
+        for (Iterator iter = _faults.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        //bug fix: 4947340, extensions should be the first element
+        _helper.accept(visitor);
+        if (_input != null) {
+            _input.accept(visitor);
+        }
+        if (_output != null) {
+            _output.accept(visitor);
+        }
+        for (Iterator iter = _faults.iterator(); iter.hasNext();) {
+            ((BindingFault) iter.next()).accept(visitor);
+        }
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (_name == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+        if (_style == null) {
+            failValidation("validation.missingRequiredProperty", "style");
+        }
+
+        // verify operation style
+        if (_style == OperationStyle.ONE_WAY) {
+            if (_input == null) {
+                failValidation("validation.missingRequiredSubEntity", "input");
+            }
+            if (_output != null) {
+                failValidation("validation.invalidSubEntity", "output");
+            }
+            if (_faults != null && _faults.size() != 0) {
+                failValidation("validation.invalidSubEntity", "fault");
+            }
+        }
+    }
+
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+    private String _name;
+    private BindingInput _input;
+    private BindingOutput _output;
+    private List _faults;
+    private OperationStyle _style;
+    private String _uniqueKey;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingOutput.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingOutput.java
new file mode 100644
index 0000000..2bf4757
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/BindingOutput.java
@@ -0,0 +1,93 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * Entity corresponding to the "output" child element of a binding operation.
+ *
+ * @author WS Development Team
+ */
+public class BindingOutput extends Entity implements Extensible {
+
+    public BindingOutput() {
+        _helper = new ExtensibilityHelper();
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_OUTPUT;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        _helper.accept(visitor);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+    }
+
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+    private String _name;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Definitions.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Definitions.java
new file mode 100644
index 0000000..64d19df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Definitions.java
@@ -0,0 +1,221 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Defining;
+import com.sun.tools.internal.ws.wsdl.framework.DuplicateEntityException;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * Entity corresponding to the "definitions" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Definitions extends Entity implements Defining, Extensible {
+
+    public Definitions(AbstractDocument document) {
+        _document = document;
+        _bindings = new ArrayList();
+        _imports = new ArrayList();
+        _messages = new ArrayList();
+        _portTypes = new ArrayList();
+        _services = new ArrayList();
+        _importedNamespaces = new HashSet();
+        _helper = new ExtensibilityHelper();
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String s) {
+        _name = s;
+    }
+
+    public String getTargetNamespaceURI() {
+        return _targetNsURI;
+    }
+
+    public void setTargetNamespaceURI(String s) {
+        _targetNsURI = s;
+    }
+
+    public void setTypes(Types t) {
+        _types = t;
+    }
+
+    public Types getTypes() {
+        return _types;
+    }
+
+    public void add(Message m) {
+        _document.define(m);
+        _messages.add(m);
+    }
+
+    public void add(PortType p) {
+        _document.define(p);
+        _portTypes.add(p);
+    }
+
+    public void add(Binding b) {
+        _document.define(b);
+        _bindings.add(b);
+    }
+
+    public void add(Service s) {
+        _document.define(s);
+        _services.add(s);
+    }
+
+    public void addServiceOveride(Service s) {
+        _services.add(s);
+    }
+
+    public void add(Import i) {
+        _imports.add(i);
+        _importedNamespaces.add(i.getNamespace());
+    }
+
+    public Iterator imports() {
+        return _imports.iterator();
+    }
+
+    public Iterator messages() {
+        return _messages.iterator();
+    }
+
+    public Iterator portTypes() {
+        return _portTypes.iterator();
+    }
+
+    public Iterator bindings() {
+        return _bindings.iterator();
+    }
+
+    public Iterator<Service> services() {
+        return _services.iterator();
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_DEFINITIONS;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        if (_types != null) {
+            action.perform(_types);
+        }
+        for (Iterator iter = _messages.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        for (Iterator iter = _portTypes.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        for (Iterator iter = _bindings.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        for (Iterator iter = _services.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        for (Iterator iter = _imports.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+
+        for (Iterator iter = _imports.iterator(); iter.hasNext();) {
+            ((Import) iter.next()).accept(visitor);
+        }
+
+        if (_types != null) {
+            _types.accept(visitor);
+        }
+
+        for (Iterator iter = _messages.iterator(); iter.hasNext();) {
+            ((Message) iter.next()).accept(visitor);
+        }
+        for (Iterator iter = _portTypes.iterator(); iter.hasNext();) {
+            ((PortType) iter.next()).accept(visitor);
+        }
+        for (Iterator iter = _bindings.iterator(); iter.hasNext();) {
+            ((Binding) iter.next()).accept(visitor);
+        }
+        for (Iterator iter = _services.iterator(); iter.hasNext();) {
+            ((Service) iter.next()).accept(visitor);
+        }
+
+        _helper.accept(visitor);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+    }
+
+    private AbstractDocument _document;
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+    private String _name;
+    private String _targetNsURI;
+    private Types _types;
+    private List _messages;
+    private List _portTypes;
+    private List _bindings;
+    private List<Service> _services;
+    private List _imports;
+    private Set _importedNamespaces;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Documentation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Documentation.java
new file mode 100644
index 0000000..b49779f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Documentation.java
@@ -0,0 +1,52 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+/**
+ * Entity corresponding to the "documentation" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Documentation {
+
+    public Documentation(String s) {
+        content = s;
+    }
+
+    public String getContent() {
+        return content;
+    }
+
+    public void setContent(String s) {
+        content = s;
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    private String content;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Fault.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Fault.java
new file mode 100644
index 0000000..d280d89
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Fault.java
@@ -0,0 +1,129 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.QNameAction;
+
+/**
+ * Entity corresponding to the "fault" child element of a port type operation.
+ *
+ * @author WS Development Team
+ */
+public class Fault extends Entity implements Extensible{
+
+    public Fault() {
+        _helper = new ExtensibilityHelper();
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public QName getMessage() {
+        return _message;
+    }
+
+    public void setMessage(QName n) {
+        _message = n;
+    }
+
+    public Message resolveMessage(AbstractDocument document) {
+        return (Message) document.find(Kinds.MESSAGE, _message);
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_FAULT;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        if (_message != null) {
+            action.perform(_message);
+        }
+    }
+
+    public void withAllEntityReferencesDo(EntityReferenceAction action) {
+        super.withAllEntityReferencesDo(action);
+        if (_message != null) {
+            action.perform(Kinds.MESSAGE, _message);
+        }
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (_name == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+        if (_message == null) {
+            failValidation("validation.missingRequiredAttribute", "message");
+        }
+    }
+
+    private Documentation _documentation;
+    private String _name;
+    private QName _message;
+    private ExtensibilityHelper _helper;
+
+    /* (non-Javadoc)
+     * @see Extensible#addExtension(Extension)
+     */
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+
+    }
+
+    /* (non-Javadoc)
+     * @see Extensible#extensions()
+     */
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Import.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Import.java
new file mode 100644
index 0000000..349dd3f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Import.java
@@ -0,0 +1,86 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+
+/**
+ * Entity corresponding to the "import" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Import extends Entity{
+
+    public Import() {
+    }
+
+    public String getNamespace() {
+        return _namespace;
+    }
+
+    public void setNamespace(String s) {
+        _namespace = s;
+    }
+
+    public String getLocation() {
+        return _location;
+    }
+
+    public void setLocation(String s) {
+        _location = s;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_IMPORT;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    public void validateThis() {
+        if (_location == null) {
+            failValidation("validation.missingRequiredAttribute", "location");
+        }
+        if (_namespace == null) {
+            failValidation("validation.missingRequiredAttribute", "namespace");
+        }
+    }
+
+    private Documentation _documentation;
+    private String _location;
+    private String _namespace;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Input.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Input.java
new file mode 100644
index 0000000..ff98b99
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Input.java
@@ -0,0 +1,104 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceAction;
+import com.sun.tools.internal.ws.wsdl.framework.QNameAction;
+
+/**
+ * Entity corresponding to the "input" child element of a port type operation.
+ *
+ * @author WS Development Team
+ */
+public class Input extends Entity {
+
+    public Input() {
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public QName getMessage() {
+        return _message;
+    }
+
+    public void setMessage(QName n) {
+        _message = n;
+    }
+
+    public Message resolveMessage(AbstractDocument document) {
+        return (Message) document.find(Kinds.MESSAGE, _message);
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_INPUT;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        if (_message != null) {
+            action.perform(_message);
+        }
+    }
+
+    public void withAllEntityReferencesDo(EntityReferenceAction action) {
+        super.withAllEntityReferencesDo(action);
+        if (_message != null) {
+            action.perform(Kinds.MESSAGE, _message);
+        }
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (_message == null) {
+            failValidation("validation.missingRequiredAttribute", "message");
+        }
+    }
+
+    private Documentation _documentation;
+    private String _name;
+    private QName _message;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Kinds.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Kinds.java
new file mode 100644
index 0000000..8a4435a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Kinds.java
@@ -0,0 +1,44 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+
+/**
+ * Enumeration of the kind of entities that can be defined in a WSDL "definitions" element.
+ *
+ * @author WS Development Team
+ */
+public class Kinds {
+    public static final Kind BINDING = new Kind("wsdl:binding");
+    public static final Kind MESSAGE = new Kind("wsdl:message");
+    public static final Kind PORT = new Kind("wsdl:port");
+    public static final Kind PORT_TYPE = new Kind("wsdl:portType");
+    public static final Kind SERVICE = new Kind("wsdl:service");
+
+    private Kinds() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Message.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Message.java
new file mode 100644
index 0000000..0033122
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Message.java
@@ -0,0 +1,122 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Defining;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.GlobalEntity;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.ValidationException;
+
+/**
+ * Entity corresponding to the "message" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Message extends GlobalEntity {
+
+    public Message(Defining defining) {
+        super(defining);
+        _parts = new ArrayList<MessagePart>();
+        _partsByName = new HashMap<String, MessagePart>();
+    }
+
+    public void add(MessagePart part) {
+        if (_partsByName.get(part.getName()) != null)
+            throw new ValidationException(
+                "validation.duplicateName",
+                part.getName());
+        _partsByName.put(part.getName(), part);
+        _parts.add(part);
+    }
+
+    public Iterator<MessagePart> parts() {
+        return _parts.iterator();
+    }
+
+    public List<MessagePart> getParts(){
+        return _parts;
+    }
+
+    public MessagePart getPart(String name) {
+        return _partsByName.get(name);
+    }
+
+    public int numParts() {
+        return _parts.size();
+    }
+
+    public Kind getKind() {
+        return Kinds.MESSAGE;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_MESSAGE;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        super.withAllSubEntitiesDo(action);
+
+        for (Iterator iter = _parts.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        for (Iterator<MessagePart> iter = _parts.iterator(); iter.hasNext();) {
+            iter.next().accept(visitor);
+        }
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (getName() == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+    }
+
+    private Documentation _documentation;
+    private List<MessagePart> _parts;
+    private Map<String, MessagePart> _partsByName;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/MessagePart.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/MessagePart.java
new file mode 100644
index 0000000..665be32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/MessagePart.java
@@ -0,0 +1,156 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceAction;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.QNameAction;
+import com.sun.xml.internal.ws.model.Mode;
+
+/**
+ * Entity corresponding to a WSDL message part.
+ *
+ * @author WS Development Team
+ */
+public class MessagePart extends Entity {
+
+    public static final int SOAP_BODY_BINDING = 1;
+    public static final int SOAP_HEADER_BINDING = 2;
+    public static final int SOAP_HEADERFAULT_BINDING = 3;
+    public static final int SOAP_FAULT_BINDING = 4;
+    public static final int WSDL_MIME_BINDING = 5;
+    public static final int PART_NOT_BOUNDED = -1;
+
+    public MessagePart() {
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public QName getDescriptor() {
+        return _descriptor;
+    }
+
+    public void setDescriptor(QName n) {
+        _descriptor = n;
+    }
+
+    public Kind getDescriptorKind() {
+        return _descriptorKind;
+    }
+
+    public void setDescriptorKind(Kind k) {
+        _descriptorKind = k;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_PART;
+    }
+
+    public int getBindingExtensibilityElementKind(){
+        return _bindingKind;
+    }
+
+    public void setBindingExtensibilityElementKind(int kind) {
+        _bindingKind = kind;
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        if (_descriptor != null) {
+            action.perform(_descriptor);
+        }
+    }
+
+    public void withAllEntityReferencesDo(EntityReferenceAction action) {
+        super.withAllEntityReferencesDo(action);
+        if (_descriptor != null && _descriptorKind != null) {
+            action.perform(_descriptorKind, _descriptor);
+        }
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.visit(this);
+    }
+
+    public void validateThis() {
+        if (_descriptorKind == null || _descriptor == null) {
+            failValidation("validation.missingRequiredProperty", "descriptor");
+        }else if(_descriptor.getLocalPart().equals("")){
+            failValidation("validation.invalidElement", _descriptor.toString());
+        }
+    }
+
+    public void setMode(Mode mode){
+        this.mode = mode;
+    }
+
+    public Mode getMode(){
+        return mode;
+    }
+
+    public boolean isINOUT(){
+        if(mode!=null)
+            return (mode == Mode.INOUT);
+        return false;
+    }
+
+    public boolean isIN(){
+        if(mode!=null)
+            return (mode == Mode.IN);
+        return false;
+    }
+
+    public boolean isOUT(){
+        if(mode!=null)
+            return (mode == Mode.OUT);
+        return false;
+    }
+
+    public void setReturn(boolean ret){
+        isRet=ret;
+    }
+
+    public boolean isReturn(){
+        return isRet;
+    }
+
+
+    private boolean isRet;
+    private String _name;
+    private QName _descriptor;
+    private Kind _descriptorKind;
+    private int _bindingKind;
+
+    private Mode mode;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Operation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Operation.java
new file mode 100644
index 0000000..5219efa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Operation.java
@@ -0,0 +1,227 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * Entity corresponding to the "operation" child element of a "portType" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Operation extends Entity implements Extensible{
+
+    public Operation() {
+        _faults = new ArrayList();
+        _helper = new ExtensibilityHelper();
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public String getUniqueKey() {
+        if (_uniqueKey == null) {
+            StringBuffer sb = new StringBuffer();
+            sb.append(_name);
+            sb.append(' ');
+            if (_input != null) {
+                sb.append(_input.getName());
+            } else {
+                sb.append(_name);
+                if (_style == OperationStyle.REQUEST_RESPONSE) {
+                    sb.append("Request");
+                } else if (_style == OperationStyle.SOLICIT_RESPONSE) {
+                    sb.append("Response");
+                }
+            }
+            sb.append(' ');
+            if (_output != null) {
+                sb.append(_output.getName());
+            } else {
+                sb.append(_name);
+                if (_style == OperationStyle.SOLICIT_RESPONSE) {
+                    sb.append("Solicit");
+                } else if (_style == OperationStyle.REQUEST_RESPONSE) {
+                    sb.append("Response");
+                }
+            }
+            _uniqueKey = sb.toString();
+        }
+
+        return _uniqueKey;
+    }
+
+    public OperationStyle getStyle() {
+        return _style;
+    }
+
+    public void setStyle(OperationStyle s) {
+        _style = s;
+    }
+
+    public Input getInput() {
+        return _input;
+    }
+
+    public void setInput(Input i) {
+        _input = i;
+    }
+
+    public Output getOutput() {
+        return _output;
+    }
+
+    public void setOutput(Output o) {
+        _output = o;
+    }
+
+    public void addFault(Fault f) {
+        _faults.add(f);
+    }
+
+    public Iterator faults() {
+        return _faults.iterator();
+    }
+
+    public String getParameterOrder() {
+        return _parameterOrder;
+    }
+
+    public void setParameterOrder(String s) {
+        _parameterOrder = s;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_OPERATION;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        super.withAllSubEntitiesDo(action);
+
+        if (_input != null) {
+            action.perform(_input);
+        }
+        if (_output != null) {
+            action.perform(_output);
+        }
+        for (Iterator iter = _faults.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        if (_input != null) {
+            _input.accept(visitor);
+        }
+        if (_output != null) {
+            _output.accept(visitor);
+        }
+        for (Iterator iter = _faults.iterator(); iter.hasNext();) {
+            ((Fault) iter.next()).accept(visitor);
+        }
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (_name == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+        if (_style == null) {
+            failValidation("validation.missingRequiredProperty", "style");
+        }
+
+        // verify operation style
+        if (_style == OperationStyle.ONE_WAY) {
+            if (_input == null) {
+                failValidation("validation.missingRequiredSubEntity", "input");
+            }
+            if (_output != null) {
+                failValidation("validation.invalidSubEntity", "output");
+            }
+            if (_faults != null && _faults.size() != 0) {
+                failValidation("validation.invalidSubEntity", "fault");
+            }
+            if (_parameterOrder != null) {
+                failValidation("validation.invalidAttribute", "parameterOrder");
+            }
+        } else if (_style == OperationStyle.NOTIFICATION) {
+            if (_parameterOrder != null) {
+                failValidation("validation.invalidAttribute", "parameterOrder");
+            }
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see Extensible#addExtension(Extension)
+     */
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+
+    }
+
+    /* (non-Javadoc)
+     * @see Extensible#extensions()
+     */
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+
+    private Documentation _documentation;
+    private String _name;
+    private Input _input;
+    private Output _output;
+    private List _faults;
+    private OperationStyle _style;
+    private String _parameterOrder;
+    private String _uniqueKey;
+    private ExtensibilityHelper _helper;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/OperationStyle.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/OperationStyle.java
new file mode 100644
index 0000000..00cdab3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/OperationStyle.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+/**
+ * Enumeration of the supported WSDL operation styles.
+ *
+ * @author WS Development Team
+ */
+public final class OperationStyle {
+
+    public static final OperationStyle ONE_WAY = new OperationStyle();
+    public static final OperationStyle REQUEST_RESPONSE = new OperationStyle();
+    public static final OperationStyle SOLICIT_RESPONSE = new OperationStyle();
+    public static final OperationStyle NOTIFICATION = new OperationStyle();
+
+    private OperationStyle() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Output.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Output.java
new file mode 100644
index 0000000..8842227
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Output.java
@@ -0,0 +1,104 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceAction;
+import com.sun.tools.internal.ws.wsdl.framework.QNameAction;
+
+/**
+ * Entity corresponding to the "output" child element of a port type operation.
+ *
+ * @author WS Development Team
+ */
+public class Output extends Entity {
+
+    public Output() {
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public QName getMessage() {
+        return _message;
+    }
+
+    public void setMessage(QName n) {
+        _message = n;
+    }
+
+    public Message resolveMessage(AbstractDocument document) {
+        return (Message) document.find(Kinds.MESSAGE, _message);
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_OUTPUT;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        if (_message != null) {
+            action.perform(_message);
+        }
+    }
+
+    public void withAllEntityReferencesDo(EntityReferenceAction action) {
+        super.withAllEntityReferencesDo(action);
+        if (_message != null) {
+            action.perform(Kinds.MESSAGE, _message);
+        }
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (_message == null) {
+            failValidation("validation.missingRequiredAttribute", "message");
+        }
+    }
+
+    private Documentation _documentation;
+    private String _name;
+    private QName _message;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Port.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Port.java
new file mode 100644
index 0000000..b37a666
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Port.java
@@ -0,0 +1,137 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Defining;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.GlobalEntity;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.QNameAction;
+
+/**
+ * Entity corresponding to the "port" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Port extends GlobalEntity implements Extensible {
+
+    public Port(Defining defining) {
+        super(defining);
+        _helper = new ExtensibilityHelper();
+    }
+
+    public Service getService() {
+        return _service;
+    }
+
+    public void setService(Service s) {
+        _service = s;
+    }
+
+    public QName getBinding() {
+        return _binding;
+    }
+
+    public void setBinding(QName n) {
+        _binding = n;
+    }
+
+    public Binding resolveBinding(AbstractDocument document) {
+        return (Binding) document.find(Kinds.BINDING, _binding);
+    }
+
+    public Kind getKind() {
+        return Kinds.PORT;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_PORT;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        super.withAllQNamesDo(action);
+
+        if (_binding != null) {
+            action.perform(_binding);
+        }
+    }
+
+    public void withAllEntityReferencesDo(EntityReferenceAction action) {
+        super.withAllEntityReferencesDo(action);
+        if (_binding != null) {
+            action.perform(Kinds.BINDING, _binding);
+        }
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        _helper.accept(visitor);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (getName() == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+        if (_binding == null) {
+            failValidation("validation.missingRequiredAttribute", "binding");
+        }
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+    private Service _service;
+    private QName _binding;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/PortType.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/PortType.java
new file mode 100644
index 0000000..8d6deeb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/PortType.java
@@ -0,0 +1,144 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Defining;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.GlobalEntity;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.ValidationException;
+
+/**
+ * Entity corresponding to the "portType" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class PortType extends GlobalEntity implements Extensible{
+
+    public PortType(Defining defining) {
+        super(defining);
+        _operations = new ArrayList();
+        _operationKeys = new HashSet();
+        _helper = new ExtensibilityHelper();
+    }
+
+    public void add(Operation operation) {
+        String key = operation.getUniqueKey();
+        if (_operationKeys.contains(key))
+            throw new ValidationException(
+                "validation.ambiguousName",
+                operation.getName());
+        _operationKeys.add(key);
+        _operations.add(operation);
+    }
+
+    public Iterator operations() {
+        return _operations.iterator();
+    }
+
+    public Set getOperationsNamed(String s) {
+        Set result = new HashSet();
+        for (Iterator iter = _operations.iterator(); iter.hasNext();) {
+            Operation operation = (Operation) iter.next();
+            if (operation.getName().equals(s)) {
+                result.add(operation);
+            }
+        }
+        return result;
+    }
+
+    public Kind getKind() {
+        return Kinds.PORT_TYPE;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_PORT_TYPE;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        super.withAllSubEntitiesDo(action);
+
+        for (Iterator iter = _operations.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        _helper.accept(visitor);
+        for (Iterator iter = _operations.iterator(); iter.hasNext();) {
+            ((Operation) iter.next()).accept(visitor);
+        }
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (getName() == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see Extensible#addExtension(Extension)
+     */
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+
+    }
+
+    /* (non-Javadoc)
+     * @see Extensible#extensions()
+     */
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    private Documentation _documentation;
+    private List _operations;
+    private Set _operationKeys;
+    private ExtensibilityHelper _helper;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Service.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Service.java
new file mode 100644
index 0000000..87925c3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Service.java
@@ -0,0 +1,114 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Defining;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.GlobalEntity;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+
+/**
+ * Entity corresponding to the "service" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Service extends GlobalEntity implements Extensible {
+
+    public Service(Defining defining) {
+        super(defining);
+        _ports = new ArrayList();
+        _helper = new ExtensibilityHelper();
+    }
+
+    public void add(Port port) {
+        port.setService(this);
+        _ports.add(port);
+    }
+
+    public Iterator <Port> ports() {
+        return _ports.iterator();
+    }
+
+    public Kind getKind() {
+        return Kinds.SERVICE;
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_SERVICE;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        for (Iterator iter = _ports.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        for (Iterator iter = _ports.iterator(); iter.hasNext();) {
+            ((Port) iter.next()).accept(visitor);
+        }
+        _helper.accept(visitor);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (getName() == null) {
+            failValidation("validation.missingRequiredAttribute", "name");
+        }
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+    private List <Port> _ports;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Types.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Types.java
new file mode 100644
index 0000000..98762e0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/Types.java
@@ -0,0 +1,89 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensionVisitor;
+
+/**
+ * Entity corresponding to the "types" WSDL element.
+ *
+ * @author WS Development Team
+ */
+public class Types extends Entity implements Extensible {
+
+    public Types() {
+        _helper = new ExtensibilityHelper();
+    }
+
+    public QName getElementName() {
+        return WSDLConstants.QNAME_TYPES;
+    }
+
+    public Documentation getDocumentation() {
+        return _documentation;
+    }
+
+    public void setDocumentation(Documentation d) {
+        _documentation = d;
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        _helper.accept(visitor);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void accept(ExtensionVisitor visitor) throws Exception {
+        _helper.accept(visitor);
+    }
+
+    private ExtensibilityHelper _helper;
+    private Documentation _documentation;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLConstants.java
new file mode 100644
index 0000000..660933e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLConstants.java
@@ -0,0 +1,59 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Interface defining WSDL-related constants.
+ *
+ * @author WS Development Team
+ */
+public interface WSDLConstants {
+
+    // namespace URIs
+    public static String NS_XMLNS = "http://www.w3.org/2000/xmlns/";
+    public static String NS_WSDL = "http://schemas.xmlsoap.org/wsdl/";
+
+    // QNames
+    public static QName QNAME_BINDING = new QName(NS_WSDL, "binding");
+    public static QName QNAME_DEFINITIONS = new QName(NS_WSDL, "definitions");
+    public static QName QNAME_DOCUMENTATION =
+        new QName(NS_WSDL, "documentation");
+    public static QName QNAME_FAULT = new QName(NS_WSDL, "fault");
+    public static QName QNAME_IMPORT = new QName(NS_WSDL, "import");
+    public static QName QNAME_INPUT = new QName(NS_WSDL, "input");
+    public static QName QNAME_MESSAGE = new QName(NS_WSDL, "message");
+    public static QName QNAME_OPERATION = new QName(NS_WSDL, "operation");
+    public static QName QNAME_OUTPUT = new QName(NS_WSDL, "output");
+    public static QName QNAME_PART = new QName(NS_WSDL, "part");
+    public static QName QNAME_PORT = new QName(NS_WSDL, "port");
+    public static QName QNAME_PORT_TYPE = new QName(NS_WSDL, "portType");
+    public static QName QNAME_SERVICE = new QName(NS_WSDL, "service");
+    public static QName QNAME_TYPES = new QName(NS_WSDL, "types");
+
+    public static QName QNAME_ATTR_ARRAY_TYPE = new QName(NS_WSDL, "arrayType");
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocument.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocument.java
new file mode 100644
index 0000000..251cc3e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocument.java
@@ -0,0 +1,185 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceAction;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceValidator;
+import com.sun.tools.internal.ws.wsdl.framework.GloballyKnown;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.NoSuchEntityException;
+import com.sun.tools.internal.ws.wsdl.framework.ValidationException;
+
+/**
+ * A WSDL document.
+ *
+ * @author WS Development Team
+ */
+public class WSDLDocument extends AbstractDocument{
+
+    public WSDLDocument() {
+    }
+
+    public Definitions getDefinitions() {
+        return _definitions;
+    }
+
+    public void setDefinitions(Definitions d) {
+        _definitions = d;
+    }
+
+    public Set collectAllNamespaces() {
+        Set result = super.collectAllNamespaces();
+        if (_definitions.getTargetNamespaceURI() != null) {
+            result.add(_definitions.getTargetNamespaceURI());
+        }
+        return result;
+    }
+
+    public QName[] getAllServiceQNames() {
+
+        ArrayList serviceQNames = new ArrayList();
+
+        for (Iterator iter = getDefinitions().services(); iter.hasNext();) {
+            Service next = (Service) iter.next();
+            String targetNamespace = next.getDefining().getTargetNamespaceURI();
+            String localName = next.getName();
+            QName serviceQName = new QName(targetNamespace, localName);
+            serviceQNames.add(serviceQName);
+        }
+        return (QName[]) serviceQNames.toArray(new QName[serviceQNames.size()]);
+    }
+
+    public QName[] getAllPortQNames() {
+        ArrayList portQNames = new ArrayList();
+
+        for (Iterator iter = getDefinitions().services(); iter.hasNext();) {
+            Service next = (Service) iter.next();
+            //Iterator ports = next.ports();
+            for (Iterator piter = next.ports(); piter.hasNext();) {
+                // If it's a relative import
+                Port pnext = (Port) piter.next();
+                String targetNamespace =
+                    pnext.getDefining().getTargetNamespaceURI();
+                String localName = pnext.getName();
+                QName portQName = new QName(targetNamespace, localName);
+                portQNames.add(portQName);
+            }
+        }
+        return (QName[]) portQNames.toArray(new QName[portQNames.size()]);
+    }
+
+    public QName[] getPortQNames(String serviceNameLocalPart) {
+
+        ArrayList portQNames = new ArrayList();
+
+        for (Iterator iter = getDefinitions().services(); iter.hasNext();) {
+            Service next = (Service) iter.next();
+            if (next.getName().equals(serviceNameLocalPart)) {
+                for (Iterator piter = next.ports(); piter.hasNext();) {
+                    Port pnext = (Port) piter.next();
+                    String targetNamespace =
+                        pnext.getDefining().getTargetNamespaceURI();
+                    String localName = pnext.getName();
+                    QName portQName = new QName(targetNamespace, localName);
+                    portQNames.add(portQName);
+                }
+            }
+        }
+        return (QName[]) portQNames.toArray(new QName[portQNames.size()]);
+    }
+
+    public void accept(WSDLDocumentVisitor visitor) throws Exception {
+        _definitions.accept(visitor);
+    }
+
+    public void validate(EntityReferenceValidator validator) {
+        GloballyValidatingAction action =
+            new GloballyValidatingAction(this, validator);
+        withAllSubEntitiesDo(action);
+        if (action.getException() != null) {
+            throw action.getException();
+        }
+    }
+
+    protected Entity getRoot() {
+        return _definitions;
+    }
+
+    private Definitions _definitions;
+
+    private class GloballyValidatingAction
+        implements EntityAction, EntityReferenceAction {
+        public GloballyValidatingAction(
+            AbstractDocument document,
+            EntityReferenceValidator validator) {
+            _document = document;
+            _validator = validator;
+        }
+
+        public void perform(Entity entity) {
+            try {
+                entity.validateThis();
+                entity.withAllEntityReferencesDo(this);
+                entity.withAllSubEntitiesDo(this);
+            } catch (ValidationException e) {
+                if (_exception == null) {
+                    _exception = e;
+                }
+            }
+        }
+
+        public void perform(Kind kind, QName name) {
+            try {
+                GloballyKnown entity = _document.find(kind, name);
+            } catch (NoSuchEntityException e) {
+                // failed to resolve, check with the validator
+                if (_exception == null) {
+                    if (_validator == null
+                        || !_validator.isValid(kind, name)) {
+                        _exception = e;
+                    }
+                }
+            }
+        }
+
+        public ValidationException getException() {
+            return _exception;
+        }
+
+        private ValidationException _exception;
+        private AbstractDocument _document;
+        private EntityReferenceValidator _validator;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocumentVisitor.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocumentVisitor.java
new file mode 100644
index 0000000..99d7d9a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocumentVisitor.java
@@ -0,0 +1,70 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import com.sun.tools.internal.ws.wsdl.framework.ExtensionVisitor;
+
+/**
+ * A visitor for WSDL documents.
+ *
+ * @author WS Development Team
+ */
+public interface WSDLDocumentVisitor extends ExtensionVisitor {
+
+    public void preVisit(Definitions definitions) throws Exception;
+    public void postVisit(Definitions definitions) throws Exception;
+    public void visit(Import i) throws Exception;
+    public void preVisit(Types types) throws Exception;
+    public void postVisit(Types types) throws Exception;
+    public void preVisit(Message message) throws Exception;
+    public void postVisit(Message message) throws Exception;
+    public void visit(MessagePart part) throws Exception;
+    public void preVisit(PortType portType) throws Exception;
+    public void postVisit(PortType portType) throws Exception;
+    public void preVisit(Operation operation) throws Exception;
+    public void postVisit(Operation operation) throws Exception;
+    public void preVisit(Input input) throws Exception;
+    public void postVisit(Input input) throws Exception;
+    public void preVisit(Output output) throws Exception;
+    public void postVisit(Output output) throws Exception;
+    public void preVisit(Fault fault) throws Exception;
+    public void postVisit(Fault fault) throws Exception;
+    public void preVisit(Binding binding) throws Exception;
+    public void postVisit(Binding binding) throws Exception;
+    public void preVisit(BindingOperation operation) throws Exception;
+    public void postVisit(BindingOperation operation) throws Exception;
+    public void preVisit(BindingInput input) throws Exception;
+    public void postVisit(BindingInput input) throws Exception;
+    public void preVisit(BindingOutput output) throws Exception;
+    public void postVisit(BindingOutput output) throws Exception;
+    public void preVisit(BindingFault fault) throws Exception;
+    public void postVisit(BindingFault fault) throws Exception;
+    public void preVisit(Service service) throws Exception;
+    public void postVisit(Service service) throws Exception;
+    public void preVisit(Port port) throws Exception;
+    public void postVisit(Port port) throws Exception;
+    public void visit(Documentation documentation) throws Exception;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocumentVisitorBase.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocumentVisitorBase.java
new file mode 100644
index 0000000..f8cf2e5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/WSDLDocumentVisitorBase.java
@@ -0,0 +1,105 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document;
+
+import com.sun.tools.internal.ws.wsdl.framework.ExtensionVisitorBase;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class WSDLDocumentVisitorBase extends ExtensionVisitorBase {
+    public WSDLDocumentVisitorBase() {
+    }
+
+    public void preVisit(Definitions definitions) throws Exception {
+    }
+    public void postVisit(Definitions definitions) throws Exception {
+    }
+    public void visit(Import i) throws Exception {
+    }
+    public void preVisit(Types types) throws Exception {
+    }
+    public void postVisit(Types types) throws Exception {
+    }
+    public void preVisit(Message message) throws Exception {
+    }
+    public void postVisit(Message message) throws Exception {
+    }
+    public void visit(MessagePart part) throws Exception {
+    }
+    public void preVisit(PortType portType) throws Exception {
+    }
+    public void postVisit(PortType portType) throws Exception {
+    }
+    public void preVisit(Operation operation) throws Exception {
+    }
+    public void postVisit(Operation operation) throws Exception {
+    }
+    public void preVisit(Input input) throws Exception {
+    }
+    public void postVisit(Input input) throws Exception {
+    }
+    public void preVisit(Output output) throws Exception {
+    }
+    public void postVisit(Output output) throws Exception {
+    }
+    public void preVisit(Fault fault) throws Exception {
+    }
+    public void postVisit(Fault fault) throws Exception {
+    }
+    public void preVisit(Binding binding) throws Exception {
+    }
+    public void postVisit(Binding binding) throws Exception {
+    }
+    public void preVisit(BindingOperation operation) throws Exception {
+    }
+    public void postVisit(BindingOperation operation) throws Exception {
+    }
+    public void preVisit(BindingInput input) throws Exception {
+    }
+    public void postVisit(BindingInput input) throws Exception {
+    }
+    public void preVisit(BindingOutput output) throws Exception {
+    }
+    public void postVisit(BindingOutput output) throws Exception {
+    }
+    public void preVisit(BindingFault fault) throws Exception {
+    }
+    public void postVisit(BindingFault fault) throws Exception {
+    }
+    public void preVisit(Service service) throws Exception {
+    }
+    public void postVisit(Service service) throws Exception {
+    }
+    public void preVisit(Port port) throws Exception {
+    }
+    public void postVisit(Port port) throws Exception {
+    }
+    public void visit(Documentation documentation) throws Exception {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPAddress.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPAddress.java
new file mode 100644
index 0000000..693c53a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPAddress.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.http;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A HTTP address extension.
+ *
+ * @author WS Development Team
+ */
+public class HTTPAddress extends Extension {
+
+    public HTTPAddress() {
+    }
+
+    public QName getElementName() {
+        return HTTPConstants.QNAME_ADDRESS;
+    }
+
+    public String getLocation() {
+        return _location;
+    }
+
+    public void setLocation(String s) {
+        _location = s;
+    }
+
+    public void validateThis() {
+        if (_location == null) {
+            failValidation("validation.missingRequiredAttribute", "location");
+        }
+    }
+
+    private String _location;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPBinding.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPBinding.java
new file mode 100644
index 0000000..a81fad3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPBinding.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.http;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A HTTP binding extension.
+ *
+ * @author WS Development Team
+ */
+public class HTTPBinding extends Extension {
+
+    public HTTPBinding() {
+    }
+
+    public QName getElementName() {
+        return HTTPConstants.QNAME_BINDING;
+    }
+
+    public String getVerb() {
+        return _verb;
+    }
+
+    public void setVerb(String s) {
+        _verb = s;
+    }
+
+    public void validateThis() {
+        if (_verb == null) {
+            failValidation("validation.missingRequiredAttribute", "verb");
+        }
+    }
+
+    private String _verb;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPConstants.java
new file mode 100644
index 0000000..1ec64a2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPConstants.java
@@ -0,0 +1,48 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.http;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Interface defining HTTP-extension-related constants.
+ *
+ * @author WS Development Team
+ */
+public interface HTTPConstants {
+
+    // namespace URIs
+    public static String NS_WSDL_HTTP = "http://schemas.xmlsoap.org/wsdl/http/";
+
+    // QNames
+    public static QName QNAME_ADDRESS = new QName(NS_WSDL_HTTP, "address");
+    public static QName QNAME_BINDING = new QName(NS_WSDL_HTTP, "binding");
+    public static QName QNAME_OPERATION = new QName(NS_WSDL_HTTP, "operation");
+    public static QName QNAME_URL_ENCODED =
+        new QName(NS_WSDL_HTTP, "urlEncoded");
+    public static QName QNAME_URL_REPLACEMENT =
+        new QName(NS_WSDL_HTTP, "urlReplacement");
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPOperation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPOperation.java
new file mode 100644
index 0000000..a56297e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPOperation.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.http;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A HTTP operation extension.
+ *
+ * @author WS Development Team
+ */
+public class HTTPOperation extends Extension {
+
+    public HTTPOperation() {
+    }
+
+    public QName getElementName() {
+        return HTTPConstants.QNAME_OPERATION;
+    }
+
+    public String getLocation() {
+        return _location;
+    }
+
+    public void setLocation(String s) {
+        _location = s;
+    }
+
+    public void validateThis() {
+        if (_location == null) {
+            failValidation("validation.missingRequiredAttribute", "location");
+        }
+    }
+
+    private String _location;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPUrlEncoded.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPUrlEncoded.java
new file mode 100644
index 0000000..3e7e847
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPUrlEncoded.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.http;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A HTTP urlEncoded extension.
+ *
+ * @author WS Development Team
+ */
+public class HTTPUrlEncoded extends Extension {
+
+    public HTTPUrlEncoded() {}
+
+    public QName getElementName() {
+        return HTTPConstants.QNAME_URL_ENCODED;
+    }
+
+    public void validateThis() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPUrlReplacement.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPUrlReplacement.java
new file mode 100644
index 0000000..876a4e5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/http/HTTPUrlReplacement.java
@@ -0,0 +1,48 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.http;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A HTTP urlReplacement extension.
+ *
+ * @author WS Development Team
+ */
+public class HTTPUrlReplacement extends Extension {
+
+    public HTTPUrlReplacement() {
+    }
+
+    public QName getElementName() {
+        return HTTPConstants.QNAME_URL_REPLACEMENT;
+    }
+
+    public void validateThis() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/CustomName.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/CustomName.java
new file mode 100644
index 0000000..f5fa013
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/CustomName.java
@@ -0,0 +1,78 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.document.jaxws;
+
+
+/**
+ * @author Vivek Pandey
+ *
+ * To change the template for this generated type comment go to
+ * Window&gt;Preferences&gt;Java&gt;Code Generation&gt;Code and Comments
+ */
+public class CustomName {
+
+
+    /**
+     *
+     */
+    public CustomName() {
+    }
+
+    /**
+     *
+     */
+    public CustomName(String name, String javaDoc) {
+        this.name = name;
+        this.javaDoc = javaDoc;
+    }
+
+    /**
+     * @return Returns the javaDoc.
+     */
+    public String getJavaDoc() {
+        return javaDoc;
+    }
+    /**
+     * @param javaDoc The javaDoc to set.
+     */
+    public void setJavaDoc(String javaDoc) {
+        this.javaDoc = javaDoc;
+    }
+    /**
+     * @return Returns the name.
+     */
+    public String getName() {
+        return name;
+    }
+    /**
+     * @param name The name to set.
+     */
+    public void setName(String name) {
+        this.name = name;
+    }
+
+    private String javaDoc;
+    private String name;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/Exception.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/Exception.java
new file mode 100644
index 0000000..b741788
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/Exception.java
@@ -0,0 +1,54 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.document.jaxws;
+
+/**
+ * @author Vivek Pandey
+ *
+ * class representing jaxws:exception
+ *
+ */
+public class Exception {
+
+    public Exception(){}
+
+    public Exception(CustomName name){
+        this.className = name;
+    }
+
+    private CustomName className;
+    /**
+     * @return Returns the className.
+     */
+    public CustomName getClassName() {
+        return className;
+    }
+    /**
+     * @param className The className to set.
+     */
+    public void setClassName(CustomName className) {
+        this.className = className;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/JAXWSBinding.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/JAXWSBinding.java
new file mode 100644
index 0000000..a8f48f9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/JAXWSBinding.java
@@ -0,0 +1,338 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.document.jaxws;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.Element;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+
+/**
+ * @author Vivek Pandey
+ *
+ * To change the template for this generated type comment go to
+ * Window&gt;Preferences&gt;Java&gt;Code Generation&gt;Code and Comments
+ */
+public class JAXWSBinding extends Extension implements Extensible {
+
+    /**
+     *
+     */
+    public JAXWSBinding(){
+        super();
+        jaxbBindings = new HashSet<Element>();
+        // TODO Auto-generated constructor stub
+    }
+
+
+    /* (non-Javadoc)
+     * @see Entity#validateThis()
+     */
+    public void validateThis(){
+        // TODO Auto-generated method stub
+
+    }
+
+    /* (non-Javadoc)
+     * @see Elemental#getElementName()
+     */
+    public QName getElementName(){
+        // TODO Auto-generated method stub
+        return JAXWSBindingsConstants.JAXWS_BINDINGS;
+    }
+
+    /* (non-Javadoc)
+     * @see Extensible#addExtension(Extension)
+     */
+    public void addExtension(Extension e) {
+        // TODO Auto-generated method stub
+
+    }
+
+    /* (non-Javadoc)
+     * @see Extensible#extensions()
+     */
+    public Iterator extensions() {
+        // TODO Auto-generated method stub
+        return null;
+    }
+
+
+//    /**
+//     * @return Returns the enableAdditionalHeaderMapping.
+//     */
+//    public Boolean isEnableAdditionalHeaderMapping() {
+//        return enableAdditionalHeaderMapping;
+//    }
+//    /**
+//     * @param enableAdditionalHeaderMapping The enableAdditionalHeaderMapping to set.
+//     */
+//    public void setEnableAdditionalHeaderMapping(
+//            Boolean enableAdditionalHeaderMapping) {
+//        this.enableAdditionalHeaderMapping = enableAdditionalHeaderMapping;
+//    }
+    /**
+     * @return Returns the enableAsyncMapping.
+     */
+    public Boolean isEnableAsyncMapping() {
+        return enableAsyncMapping;
+    }
+    /**
+     * @param enableAsyncMapping The enableAsyncMapping to set.
+     */
+    public void setEnableAsyncMapping(Boolean enableAsyncMapping) {
+        this.enableAsyncMapping = enableAsyncMapping;
+    }
+    /**
+     * @return Returns the enableMimeContentMapping.
+     */
+    public Boolean isEnableMimeContentMapping() {
+        return enableMimeContentMapping;
+    }
+    /**
+     * @param enableMimeContentMapping The enableMimeContentMapping to set.
+     */
+    public void setEnableMimeContentMapping(Boolean enableMimeContentMapping) {
+        this.enableMimeContentMapping = enableMimeContentMapping;
+    }
+    /**
+     * @return Returns the enableWrapperStyle.
+     */
+    public Boolean isEnableWrapperStyle() {
+        return enableWrapperStyle;
+    }
+    /**
+     * @param enableWrapperStyle The enableWrapperStyle to set.
+     */
+    public void setEnableWrapperStyle(Boolean enableWrapperStyle) {
+        this.enableWrapperStyle = enableWrapperStyle;
+    }
+    /**
+     * @return Returns the jaxwsPackage.
+     */
+    public CustomName getJaxwsPackage() {
+        return jaxwsPackage;
+    }
+    /**
+     * @param jaxwsPackage The jaxwsPackage to set.
+     */
+    public void setJaxwsPackage(CustomName jaxwsPackage) {
+        this.jaxwsPackage = jaxwsPackage;
+    }
+    /**
+     * @return Returns the node.
+     */
+    public String getNode() {
+        return node;
+    }
+    /**
+     * @param node The node to set.
+     */
+    public void setNode(String node) {
+        this.node = node;
+    }
+    /**
+     * @return Returns the version.
+     */
+    public String getVersion() {
+        return version;
+    }
+    /**
+     * @param version The version to set.
+     */
+    public void setVersion(String version) {
+        this.version = version;
+    }
+
+    /**
+     * @return Returns the wsdlLocation.
+     */
+    public String getWsdlLocation() {
+        return wsdlLocation;
+    }
+
+    /**
+     * @param wsdlLocation The wsdlLocation to set.
+     */
+    public void setWsdlLocation(String wsdlLocation) {
+        this.wsdlLocation = wsdlLocation;
+    }
+
+    /**
+     * @return Returns the wsdlNamespace.
+     */
+    public String getWsdlNamespace() {
+        return wsdlNamespace;
+    }
+
+
+    /**
+     * @param wsdlNamespace The wsdlNamespace to set.
+     */
+    public void setWsdlNamespace(String wsdlNamespace) {
+        this.wsdlNamespace = wsdlNamespace;
+    }
+
+    /**
+     * @return Returns the jaxbBindings.
+     */
+    public Set<Element> getJaxbBindings() {
+        return jaxbBindings;
+    }
+
+    /**
+     * @param jaxbBinding The jaxbBindings to set.
+     */
+    public void addJaxbBindings(Element jaxbBinding) {
+        if(jaxbBindings == null)
+            return;
+        this.jaxbBindings.add(jaxbBinding);
+    }
+
+
+    /**
+     * @return the isProvider.
+     */
+    public Boolean isProvider() {
+        return isProvider;
+    }
+    /**
+     * @param isProvider The isProvider to set.
+     */
+    public void setProvider(Boolean isProvider) {
+        this.isProvider = isProvider;
+    }
+
+    /* (non-Javadoc)
+     * @see Entity#getProperty(java.lang.String)
+     */
+    public Object getProperty(String key) {
+        if(key.equals(JAXWSBindingsConstants.JAXB_BINDINGS))
+            return jaxbBindings;
+        return null;
+    }
+
+    /**
+     * @return Returns the methodName.
+     */
+    public CustomName getMethodName() {
+        return methodName;
+    }
+    /**
+     * @param methodName The methodName to set.
+     */
+    public void setMethodName(CustomName methodName) {
+        this.methodName = methodName;
+    }
+
+    /**
+     * @return Returns the parameter.
+     */
+    public Iterator<Parameter> parameters() {
+        return parameters.iterator();
+    }
+
+    /**
+     * @param parameter The parameter to set.
+     */
+    public void addParameter(Parameter parameter) {
+        if(parameters == null)
+            parameters = new ArrayList<Parameter>();
+        parameters.add(parameter);
+    }
+
+    public String getParameterName(String msgName, String wsdlPartName, QName element, boolean wrapperStyle){
+        if(msgName == null || wsdlPartName == null || element == null || parameters == null)
+            return null;
+        for(Parameter param : parameters){
+            if(param.getMessageName().equals(msgName) && param.getPart().equals(wsdlPartName)){
+                if(wrapperStyle && (param.getElement() != null)){
+                    if(param.getElement().equals(element))
+                        return param.getName();
+                }else if(!wrapperStyle){
+                    return param.getName();
+                }
+            }
+        }
+        return null;
+    }
+
+    /**
+     * @return Returns the className.
+     */
+    public CustomName getClassName() {
+        return className;
+    }
+    /**
+     * @param className The className to set.
+     */
+    public void setClassName(CustomName className) {
+        this.className = className;
+    }
+
+    /**
+     * @return Returns the exception.
+     */
+    public Exception getException() {
+        return exception;
+    }
+    /**
+     * @param exception The exception to set.
+     */
+    public void setException(Exception exception) {
+        this.exception = exception;
+    }
+
+    private String wsdlNamespace;
+    private String wsdlLocation;
+    private String node;
+    private String version;
+
+    private CustomName jaxwsPackage;
+    private List<Parameter> parameters;
+    private Boolean enableWrapperStyle;
+    private Boolean enableAsyncMapping;
+//    private Boolean enableAdditionalHeaderMapping;
+    private Boolean enableMimeContentMapping;
+    private Boolean isProvider;
+    private Exception exception;
+
+    private Set<Element> jaxbBindings;
+
+    // portType className
+    private CustomName className;
+
+    //portType Operation
+    private CustomName methodName;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/JAXWSBindingsConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/JAXWSBindingsConstants.java
new file mode 100644
index 0000000..4ada7db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/JAXWSBindingsConstants.java
@@ -0,0 +1,193 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.jaxws;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.parser.Constants;
+
+/**
+ * @author Vivek Pandey
+ *
+ */
+public interface JAXWSBindingsConstants {
+
+    public static String NS_JAXWS_BINDINGS = "http://java.sun.com/xml/ns/jaxws";
+    public static String NS_JAXB_BINDINGS = "http://java.sun.com/xml/ns/jaxb";
+
+    /**
+     * jaxws:bindings schema component
+     *
+     * <jaxws:bindings wsdlLocation="xs:anyURI"? node="xs:string"?
+     *      version="string"?> binding declarations...
+     * </jaxws:bindings>
+     *
+     * wsdlLocation="xs:anyURI"? node="xs:string"? version="string"?> binding
+     * declarations... </jaxws:bindings>
+     *
+     * <code>@wsdlLocation</code> A URI pointing to a WSDL file establishing the scope of the
+     *               contents of this binding declaration. It MUST NOT be
+     *               present if the binding declaration is used as an extension
+     *               inside a WSDL document or if there is an ancestor binding
+     *               declaration that contains this attribute.
+     *
+     * <code>@node</code> An XPath expression pointing to the element in the WSDL file in
+     *       scope that this binding declaration is attached to.
+     *
+     * <code>@version</code> A version identifier. It MAY only appear on jaxws:bindings
+     *          elements that don't have any jaxws:bindings ancestors (i.e. on
+     *          outermost binding declarations).
+     */
+    public static QName JAXWS_BINDINGS = new QName(NS_JAXWS_BINDINGS, "bindings");
+    public static String WSDL_LOCATION_ATTR = "wsdlLocation";
+    public static String NODE_ATTR = "node";
+    public static String VERSION_ATTR = "version";
+
+    /*
+     * <jaxws:package name="xs:string">? <jaxws:javadoc>xs:string
+     * </jaxws:javadoc> </jaxws:package>
+     */
+    public static QName PACKAGE = new QName(NS_JAXWS_BINDINGS, "package");
+    public static String NAME_ATTR = "name";
+    public static QName JAVADOC = new QName(NS_JAXWS_BINDINGS, "javadoc");
+
+    /*
+     * <jaxws:enableWrapperStyle>xs:boolean </jaxws:enableWrapperStyle>?
+     */
+    public static QName ENABLE_WRAPPER_STYLE = new QName(NS_JAXWS_BINDINGS, "enableWrapperStyle");
+
+    /*
+     * <jaxws:enableAsynchronousMapping>xs:boolean
+     *      </jaxws:enableAsynchronousMapping>?
+     */
+    public static QName ENABLE_ASYNC_MAPPING = new QName(NS_JAXWS_BINDINGS, "enableAsyncMapping");
+
+    /*
+     * <jaxws:enableAdditionalSOAPHeaderMapping>xs:boolean</jaxws:enableAdditionalSOAPHeaderMapping>?
+     */
+    public static QName ENABLE_ADDITIONAL_SOAPHEADER_MAPPING = new QName(NS_JAXWS_BINDINGS, "enableAdditionalSOAPHeaderMapping");
+
+    /*
+     * <jaxws:enableMIMEContent>xs:boolean</jaxws:enableMIMEContent>?
+     */
+    public static QName ENABLE_MIME_CONTENT = new QName(NS_JAXWS_BINDINGS, "enableMIMEContent");
+
+    /*
+     * <jaxwsc:provider>xs:boolean</jaxws:provider>?
+     */
+    public static QName PROVIDER = new QName(NS_JAXWS_BINDINGS, "provider");
+
+    /*
+     * PortType
+     *
+     * <jaxws:class name="xs:string">?
+     *  <jaxws:javadoc>xs:string</jaxws:javadoc>?
+     * </jaxws:class>
+     *
+     * <jaxws:enableWrapperStyle>
+     *  xs:boolean
+     * </jaxws:enableWrapperStyle>?
+     *
+     * <jaxws:enableAsynchronousMapping>
+     *  xs:boolean
+     * </jaxws:enableAsynchronousMapping>?
+     *
+     */
+
+    public static QName CLASS = new QName(NS_JAXWS_BINDINGS, "class");
+
+    /*
+     * PortType Operation
+     *
+     * <jaxws:method name="xs:string">?
+     *   <jaxws:javadoc>xs:string</jaxws:javadoc>?
+     * </jaxws:method>
+     *
+     * <jaxws:enableWrapperStyle>
+     *  xs:boolean
+     * </jaxws:enableWrapperStyle>?
+     *
+     * <jaxws:enableAsyncMapping>
+     *  xs:boolean
+     * </jaxws:enableAsyncMapping>?
+     *
+     * <jaxws:parameter part="xs:string"
+     *      childElementName="xs:QName"?
+     *      name="xs:string"/>*
+     */
+
+
+
+    public static QName METHOD = new QName(NS_JAXWS_BINDINGS, "method");
+    public static QName PARAMETER = new QName(NS_JAXWS_BINDINGS, "parameter");
+    public static String PART_ATTR = "part";
+    public static String ELEMENT_ATTR = "childElementName";
+
+    /*
+     * Binding
+     *
+     * <jaxws:enableAdditionalSOAPHeaderMapping>
+     *  xs:boolean
+     * </jaxws:enableAdditionalSOAPHeaderMapping>?
+     *
+     * <jaxws:enableMIMEContent>
+     *  xs:boolean
+     * </jaxws:enableMIMEContent>?
+     */
+
+    /*
+     * BindingOperation
+     *
+     * <jaxws:enableAdditionalSOAPHeaderMapping>
+     *  xs:boolean
+     * </jaxws:enableAdditionalSOAPHeaderMapping>?
+     *
+     * <jaxws:enableMIMEContent>
+     *  xs:boolean
+     * </jaxws:enableMIMEContent>?
+     *
+     * <jaxws:parameter part="xs:string"
+     *                  element="xs:QName"?
+     *                  name="xs:string"/>*
+     *
+     * <jaxws:exception part="xs:string">*
+     *  <jaxws:class name="xs:string">?
+     *      <jaxws:javadoc>xs:string</jaxws:javadoc>?
+     *  </jaxws:class>
+     * </jaxws:exception>
+     */
+
+    public static QName EXCEPTION = new QName(NS_JAXWS_BINDINGS, "exception");
+
+
+    /*
+     * jaxb:bindgs QName
+     */
+    public static QName JAXB_BINDINGS = new QName(NS_JAXB_BINDINGS, "bindings");
+    public static String JAXB_BINDING_VERSION = "1.0";
+    public static QName XSD_APPINFO = new QName(Constants.NS_XSD, "appinfo");
+    public static QName XSD_ANNOTATION = new QName(Constants.NS_XSD, "annotation");
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/Parameter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/Parameter.java
new file mode 100644
index 0000000..74588ea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/jaxws/Parameter.java
@@ -0,0 +1,102 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.document.jaxws;
+
+import javax.xml.namespace.QName;
+
+/**
+ * @author Vivek Pandey
+ *
+ * class representing jaxws:parameter
+ *
+ */
+public class Parameter {
+    private String part;
+    private QName element;
+    private String name;
+    private String messageName;
+
+    /**
+     * @param part
+     * @param element
+     * @param name
+     */
+    public Parameter(String msgName, String part, QName element, String name) {
+        this.part = part;
+        this.element = element;
+        this.name = name;
+        this.messageName = msgName;
+    }
+
+    public String getMessageName() {
+        return messageName;
+    }
+
+    public void setMessageName(String messageName) {
+        this.messageName = messageName;
+    }
+
+    /**
+     * @return Returns the element.
+     */
+    public QName getElement() {
+        return element;
+    }
+
+    /**
+     * @param element The element to set.
+     */
+    public void setElement(QName element) {
+        this.element = element;
+    }
+
+    /**
+     * @return Returns the name.
+     */
+    public String getName() {
+        return name;
+    }
+
+    /**
+     * @param name The name to set.
+     */
+    public void setName(String name) {
+        this.name = name;
+    }
+
+    /**
+     * @return Returns the part.
+     */
+    public String getPart() {
+        return part;
+    }
+
+    /**
+     * @param part The part to set.
+     */
+    public void setPart(String part) {
+        this.part = part;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEConstants.java
new file mode 100644
index 0000000..401dd80
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEConstants.java
@@ -0,0 +1,46 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.mime;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Interface defining MIME-extension-related constants.
+ *
+ * @author WS Development Team
+ */
+public interface MIMEConstants {
+
+    // namespace URIs
+    public static String NS_WSDL_MIME = "http://schemas.xmlsoap.org/wsdl/mime/";
+
+    // QNames
+    public static QName QNAME_CONTENT = new QName(NS_WSDL_MIME, "content");
+    public static QName QNAME_MULTIPART_RELATED =
+        new QName(NS_WSDL_MIME, "multipartRelated");
+    public static QName QNAME_PART = new QName(NS_WSDL_MIME, "part");
+    public static QName QNAME_MIME_XML = new QName(NS_WSDL_MIME, "mimeXml");
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEContent.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEContent.java
new file mode 100644
index 0000000..24e6fcf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEContent.java
@@ -0,0 +1,67 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.mime;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A MIME content extension.
+ *
+ * @author WS Development Team
+ */
+public class MIMEContent extends Extension {
+
+    public MIMEContent() {
+    }
+
+    public QName getElementName() {
+        return MIMEConstants.QNAME_CONTENT;
+    }
+
+    public String getPart() {
+        return _part;
+    }
+
+    public void setPart(String s) {
+        _part = s;
+    }
+
+    public String getType() {
+        return _type;
+    }
+
+    public void setType(String s) {
+        _type = s;
+    }
+
+    public void validateThis() {
+    }
+
+    private String _part;
+    private String _type;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEMultipartRelated.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEMultipartRelated.java
new file mode 100644
index 0000000..4d08777
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEMultipartRelated.java
@@ -0,0 +1,79 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.mime;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensionVisitor;
+
+/**
+ * A MIME multipartRelated extension.
+ *
+ * @author WS Development Team
+ */
+public class MIMEMultipartRelated extends Extension {
+
+    public MIMEMultipartRelated() {
+        _parts = new ArrayList<MIMEPart>();
+    }
+
+    public QName getElementName() {
+        return MIMEConstants.QNAME_MULTIPART_RELATED;
+    }
+
+    public void add(MIMEPart part) {
+        _parts.add(part);
+    }
+
+    public Iterator<MIMEPart> getParts() {
+        return _parts.iterator();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        super.withAllSubEntitiesDo(action);
+
+        for (Iterator iter = _parts.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+    }
+
+    public void accept(ExtensionVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+    }
+
+    private List<MIMEPart> _parts;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEPart.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEPart.java
new file mode 100644
index 0000000..7eecfe0e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEPart.java
@@ -0,0 +1,77 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.mime;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensibilityHelper;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A MIME part extension.
+ *
+ * @author WS Development Team
+ */
+public class MIMEPart extends Extension implements Extensible {
+
+    public MIMEPart() {
+        _helper = new ExtensibilityHelper();
+    }
+
+    public QName getElementName() {
+        return MIMEConstants.QNAME_PART;
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String s) {
+        _name = s;
+    }
+
+    public void addExtension(Extension e) {
+        _helper.addExtension(e);
+    }
+
+    public Iterator extensions() {
+        return _helper.extensions();
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        _helper.withAllSubEntitiesDo(action);
+    }
+
+    public void validateThis() {
+    }
+
+    private String _name;
+    private ExtensibilityHelper _helper;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEXml.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEXml.java
new file mode 100644
index 0000000..439597d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/mime/MIMEXml.java
@@ -0,0 +1,58 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.mime;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A MIME mimeXml extension.
+ *
+ * @author WS Development Team
+ */
+public class MIMEXml extends Extension {
+
+    public MIMEXml() {
+    }
+
+    public QName getElementName() {
+        return MIMEConstants.QNAME_MIME_XML;
+    }
+
+    public String getPart() {
+        return _part;
+    }
+
+    public void setPart(String s) {
+        _part = s;
+    }
+
+    public void validateThis() {
+    }
+
+    private String _part;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/BuiltInTypes.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/BuiltInTypes.java
new file mode 100644
index 0000000..56f97ed
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/BuiltInTypes.java
@@ -0,0 +1,86 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.schema;
+
+import javax.xml.namespace.QName;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface BuiltInTypes {
+    public QName STRING = SchemaConstants.QNAME_TYPE_STRING;
+    public QName NORMALIZED_STRING =
+        SchemaConstants.QNAME_TYPE_NORMALIZED_STRING;
+    public QName TOKEN = SchemaConstants.QNAME_TYPE_TOKEN;
+    public QName BYTE = SchemaConstants.QNAME_TYPE_BYTE;
+    public QName UNSIGNED_BYTE = SchemaConstants.QNAME_TYPE_UNSIGNED_BYTE;
+    public QName BASE64_BINARY = SchemaConstants.QNAME_TYPE_BASE64_BINARY;
+    public QName HEX_BINARY = SchemaConstants.QNAME_TYPE_HEX_BINARY;
+    public QName INTEGER = SchemaConstants.QNAME_TYPE_INTEGER;
+    public QName POSITIVE_INTEGER = SchemaConstants.QNAME_TYPE_POSITIVE_INTEGER;
+    public QName NEGATIVE_INTEGER = SchemaConstants.QNAME_TYPE_NEGATIVE_INTEGER;
+    public QName NON_NEGATIVE_INTEGER =
+        SchemaConstants.QNAME_TYPE_NON_NEGATIVE_INTEGER;
+    public QName NON_POSITIVE_INTEGER =
+        SchemaConstants.QNAME_TYPE_NON_POSITIVE_INTEGER;
+    public QName INT = SchemaConstants.QNAME_TYPE_INT;
+    public QName UNSIGNED_INT = SchemaConstants.QNAME_TYPE_UNSIGNED_INT;
+    public QName LONG = SchemaConstants.QNAME_TYPE_LONG;
+    public QName UNSIGNED_LONG = SchemaConstants.QNAME_TYPE_UNSIGNED_LONG;
+    public QName SHORT = SchemaConstants.QNAME_TYPE_SHORT;
+    public QName UNSIGNED_SHORT = SchemaConstants.QNAME_TYPE_UNSIGNED_SHORT;
+    public QName DECIMAL = SchemaConstants.QNAME_TYPE_DECIMAL;
+    public QName FLOAT = SchemaConstants.QNAME_TYPE_FLOAT;
+    public QName DOUBLE = SchemaConstants.QNAME_TYPE_DOUBLE;
+    public QName BOOLEAN = SchemaConstants.QNAME_TYPE_BOOLEAN;
+    public QName TIME = SchemaConstants.QNAME_TYPE_TIME;
+    public QName DATE_TIME = SchemaConstants.QNAME_TYPE_DATE_TIME;
+    public QName DURATION = SchemaConstants.QNAME_TYPE_DURATION;
+    public QName DATE = SchemaConstants.QNAME_TYPE_DATE;
+    public QName G_MONTH = SchemaConstants.QNAME_TYPE_G_MONTH;
+    public QName G_YEAR = SchemaConstants.QNAME_TYPE_G_YEAR;
+    public QName G_YEAR_MONTH = SchemaConstants.QNAME_TYPE_G_YEAR_MONTH;
+    public QName G_DAY = SchemaConstants.QNAME_TYPE_G_DAY;
+    public QName G_MONTH_DAY = SchemaConstants.QNAME_TYPE_G_MONTH_DAY;
+    public QName NAME = SchemaConstants.QNAME_TYPE_NAME;
+    public QName QNAME = SchemaConstants.QNAME_TYPE_QNAME;
+    public QName NCNAME = SchemaConstants.QNAME_TYPE_NCNAME;
+    public QName ANY_URI = SchemaConstants.QNAME_TYPE_ANY_URI;
+    public QName ID = SchemaConstants.QNAME_TYPE_ID;
+    public QName IDREF = SchemaConstants.QNAME_TYPE_IDREF;
+    public QName IDREFS = SchemaConstants.QNAME_TYPE_IDREFS;
+    public QName ENTITY = SchemaConstants.QNAME_TYPE_ENTITY;
+    public QName ENTITIES = SchemaConstants.QNAME_TYPE_ENTITIES;
+    public QName NOTATION = SchemaConstants.QNAME_TYPE_NOTATION;
+    public QName NMTOKEN = SchemaConstants.QNAME_TYPE_NMTOKEN;
+    public QName NMTOKENS = SchemaConstants.QNAME_TYPE_NMTOKENS;
+    public QName LANGUAGE = SchemaConstants.QNAME_TYPE_LANGUAGE;
+    public QName ANY_SIMPLE_URTYPE = SchemaConstants.QNAME_TYPE_SIMPLE_URTYPE;
+
+    //xsd:list
+    public QName LIST = SchemaConstants.QNAME_LIST;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/Schema.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/Schema.java
new file mode 100644
index 0000000..8f302bd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/Schema.java
@@ -0,0 +1,188 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.schema;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Defining;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.ValidationException;
+import com.sun.tools.internal.ws.wsdl.parser.Constants;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class Schema extends Extension implements Defining {
+
+    public Schema(AbstractDocument document) {
+        _document = document;
+        _nsPrefixes = new HashMap();
+        _definedEntities = new ArrayList();
+    }
+
+    public QName getElementName() {
+        return SchemaConstants.QNAME_SCHEMA;
+    }
+
+    public SchemaElement getContent() {
+        return _content;
+    }
+
+    public void setContent(SchemaElement entity) {
+        _content = entity;
+        _content.setSchema(this);
+    }
+
+    public void setTargetNamespaceURI(String uri) {
+        _targetNamespaceURI = uri;
+    }
+
+    public String getTargetNamespaceURI() {
+        return _targetNamespaceURI;
+    }
+
+    public void addPrefix(String prefix, String uri) {
+        _nsPrefixes.put(prefix, uri);
+    }
+
+    public String getURIForPrefix(String prefix) {
+        return (String) _nsPrefixes.get(prefix);
+    }
+
+    public Iterator prefixes() {
+        return _nsPrefixes.keySet().iterator();
+    }
+
+    public void defineAllEntities() {
+        if (_content == null) {
+            throw new ValidationException(
+                "validation.shouldNotHappen",
+                "missing schema content");
+        }
+
+        for (Iterator iter = _content.children(); iter.hasNext();) {
+            SchemaElement child = (SchemaElement) iter.next();
+            if (child.getQName().equals(SchemaConstants.QNAME_ATTRIBUTE)) {
+                QName name =
+                    new QName(
+                        _targetNamespaceURI,
+                        child.getValueOfMandatoryAttribute(
+                            Constants.ATTR_NAME));
+                defineEntity(child, SchemaKinds.XSD_ATTRIBUTE, name);
+            } else if (
+                child.getQName().equals(
+                    SchemaConstants.QNAME_ATTRIBUTE_GROUP)) {
+                QName name =
+                    new QName(
+                        _targetNamespaceURI,
+                        child.getValueOfMandatoryAttribute(
+                            Constants.ATTR_NAME));
+                defineEntity(child, SchemaKinds.XSD_ATTRIBUTE_GROUP, name);
+            } else if (
+                child.getQName().equals(SchemaConstants.QNAME_ELEMENT)) {
+                QName name =
+                    new QName(
+                        _targetNamespaceURI,
+                        child.getValueOfMandatoryAttribute(
+                            Constants.ATTR_NAME));
+                defineEntity(child, SchemaKinds.XSD_ELEMENT, name);
+            } else if (child.getQName().equals(SchemaConstants.QNAME_GROUP)) {
+                QName name =
+                    new QName(
+                        _targetNamespaceURI,
+                        child.getValueOfMandatoryAttribute(
+                            Constants.ATTR_NAME));
+                defineEntity(child, SchemaKinds.XSD_GROUP, name);
+            } else if (
+                child.getQName().equals(SchemaConstants.QNAME_COMPLEX_TYPE)) {
+                QName name =
+                    new QName(
+                        _targetNamespaceURI,
+                        child.getValueOfMandatoryAttribute(
+                            Constants.ATTR_NAME));
+                defineEntity(child, SchemaKinds.XSD_TYPE, name);
+            } else if (
+                child.getQName().equals(SchemaConstants.QNAME_SIMPLE_TYPE)) {
+                QName name =
+                    new QName(
+                        _targetNamespaceURI,
+                        child.getValueOfMandatoryAttribute(
+                            Constants.ATTR_NAME));
+                defineEntity(child, SchemaKinds.XSD_TYPE, name);
+            }
+        }
+    }
+
+    public void defineEntity(SchemaElement element, Kind kind, QName name) {
+        SchemaEntity entity = new SchemaEntity(this, element, kind, name);
+        _document.define(entity);
+        _definedEntities.add(entity);
+    }
+
+    public Iterator definedEntities() {
+        return _definedEntities.iterator();
+    }
+
+    public void validateThis() {
+        if (_content == null) {
+            throw new ValidationException(
+                "validation.shouldNotHappen",
+                "missing schema content");
+        }
+    }
+
+    public String asString(QName name) {
+        if (name.getNamespaceURI().equals("")) {
+            return name.getLocalPart();
+        } else {
+            // look for a prefix
+            for (Iterator iter = prefixes(); iter.hasNext();) {
+                String prefix = (String) iter.next();
+                if (prefix.equals(name.getNamespaceURI())) {
+                    return prefix + ":" + name.getLocalPart();
+                }
+            }
+
+            // not found
+            return null;
+        }
+    }
+
+    private AbstractDocument _document;
+    private String _targetNamespaceURI;
+    private SchemaElement _content;
+    private List _definedEntities;
+    private Map _nsPrefixes;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaAttribute.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaAttribute.java
new file mode 100644
index 0000000..5da73a6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaAttribute.java
@@ -0,0 +1,106 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.schema;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class SchemaAttribute {
+
+    public SchemaAttribute() {
+    }
+
+    public SchemaAttribute(String localName) {
+        _localName = localName;
+    }
+
+    public String getNamespaceURI() {
+        return _nsURI;
+    }
+
+    public void setNamespaceURI(String s) {
+        _nsURI = s;
+    }
+
+    public String getLocalName() {
+        return _localName;
+    }
+
+    public void setLocalName(String s) {
+        _localName = s;
+    }
+
+    public QName getQName() {
+        return new QName(_nsURI, _localName);
+    }
+
+    public String getValue() {
+        if (_qnameValue != null) {
+            if (_parent == null) {
+                throw new IllegalStateException();
+            } else {
+                return _parent.asString(_qnameValue);
+            }
+        } else {
+            return _value;
+        }
+    }
+
+    public String getValue(WriterContext context) {
+        if (_qnameValue != null) {
+            return context.getQNameString(_qnameValue);
+        } else {
+            return _value;
+        }
+    }
+
+    public void setValue(String s) {
+        _value = s;
+    }
+
+    public void setValue(QName name) {
+        _qnameValue = name;
+    }
+
+    public SchemaElement getParent() {
+        return _parent;
+    }
+
+    public void setParent(SchemaElement e) {
+        _parent = e;
+    }
+
+    private String _nsURI;
+    private String _localName;
+    private String _value;
+    private QName _qnameValue;
+    private SchemaElement _parent;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaConstants.java
new file mode 100644
index 0000000..381ae62
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaConstants.java
@@ -0,0 +1,151 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.schema;
+
+import javax.xml.namespace.QName;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface SchemaConstants {
+
+    // namespace URIs
+    public static String NS_XMLNS = "http://www.w3.org/2000/xmlns/";
+    public static String NS_XSD = "http://www.w3.org/2001/XMLSchema";
+    public static String NS_XSI = "http://www.w3.org/2001/XMLSchema-instance";
+
+    // QNames
+    public static QName QNAME_ALL = new QName(NS_XSD, "all");
+    public static QName QNAME_ANNOTATION = new QName(NS_XSD, "annotation");
+    public static QName QNAME_ANY = new QName(NS_XSD, "any");
+    public static QName QNAME_ANY_ATTRIBUTE = new QName(NS_XSD, "anyAttribute");
+    public static QName QNAME_ATTRIBUTE = new QName(NS_XSD, "attribute");
+    public static QName QNAME_ATTRIBUTE_GROUP =
+        new QName(NS_XSD, "attributeGroup");
+    public static QName QNAME_CHOICE = new QName(NS_XSD, "choice");
+    public static QName QNAME_COMPLEX_CONTENT =
+        new QName(NS_XSD, "complexContent");
+    public static QName QNAME_COMPLEX_TYPE = new QName(NS_XSD, "complexType");
+    public static QName QNAME_ELEMENT = new QName(NS_XSD, "element");
+    public static QName QNAME_ENUMERATION = new QName(NS_XSD, "enumeration");
+    public static QName QNAME_EXTENSION = new QName(NS_XSD, "extension");
+    public static QName QNAME_FIELD = new QName(NS_XSD, "field");
+    public static QName QNAME_FRACTION_DIGITS =
+        new QName(NS_XSD, "fractionDigits");
+    public static QName QNAME_GROUP = new QName(NS_XSD, "group");
+    public static QName QNAME_IMPORT = new QName(NS_XSD, "import");
+    public static QName QNAME_INCLUDE = new QName(NS_XSD, "include");
+    public static QName QNAME_KEY = new QName(NS_XSD, "key");
+    public static QName QNAME_KEYREF = new QName(NS_XSD, "keyref");
+    public static QName QNAME_LENGTH = new QName(NS_XSD, "length");
+    public static QName QNAME_LIST = new QName(NS_XSD, "list");
+    public static QName QNAME_MAX_EXCLUSIVE = new QName(NS_XSD, "maxExclusive");
+    public static QName QNAME_MAX_INCLUSIVE = new QName(NS_XSD, "maxInclusive");
+    public static QName QNAME_MAX_LENGTH = new QName(NS_XSD, "maxLength");
+    public static QName QNAME_MIN_EXCLUSIVE = new QName(NS_XSD, "minExclusive");
+    public static QName QNAME_MIN_INCLUSIVE = new QName(NS_XSD, "minInclusive");
+    public static QName QNAME_MIN_LENGTH = new QName(NS_XSD, "minLength");
+    public static QName QNAME_NOTATION = new QName(NS_XSD, "notation");
+    public static QName QNAME_RESTRICTION = new QName(NS_XSD, "restriction");
+    public static QName QNAME_PATTERN = new QName(NS_XSD, "pattern");
+    public static QName QNAME_PRECISION = new QName(NS_XSD, "precision");
+    public static QName QNAME_REDEFINE = new QName(NS_XSD, "redefine");
+    public static QName QNAME_SCALE = new QName(NS_XSD, "scale");
+    public static QName QNAME_SCHEMA = new QName(NS_XSD, "schema");
+    public static QName QNAME_SELECTOR = new QName(NS_XSD, "selector");
+    public static QName QNAME_SEQUENCE = new QName(NS_XSD, "sequence");
+    public static QName QNAME_SIMPLE_CONTENT =
+        new QName(NS_XSD, "simpleContent");
+    public static QName QNAME_SIMPLE_TYPE = new QName(NS_XSD, "simpleType");
+    public static QName QNAME_TOTAL_DIGITS = new QName(NS_XSD, "totalDigits");
+    public static QName QNAME_UNIQUE = new QName(NS_XSD, "unique");
+    public static QName QNAME_UNION = new QName(NS_XSD, "union");
+    public static QName QNAME_WHITE_SPACE = new QName(NS_XSD, "whiteSpace");
+
+    // QNames for built-in XSD types
+    public static QName QNAME_TYPE_STRING = new QName(NS_XSD, "string");
+    public static QName QNAME_TYPE_NORMALIZED_STRING =
+        new QName(NS_XSD, "normalizedString");
+    public static QName QNAME_TYPE_TOKEN = new QName(NS_XSD, "token");
+    public static QName QNAME_TYPE_BYTE = new QName(NS_XSD, "byte");
+    public static QName QNAME_TYPE_UNSIGNED_BYTE =
+        new QName(NS_XSD, "unsignedByte");
+    public static QName QNAME_TYPE_BASE64_BINARY =
+        new QName(NS_XSD, "base64Binary");
+    public static QName QNAME_TYPE_HEX_BINARY = new QName(NS_XSD, "hexBinary");
+    public static QName QNAME_TYPE_INTEGER = new QName(NS_XSD, "integer");
+    public static QName QNAME_TYPE_POSITIVE_INTEGER =
+        new QName(NS_XSD, "positiveInteger");
+    public static QName QNAME_TYPE_NEGATIVE_INTEGER =
+        new QName(NS_XSD, "negativeInteger");
+    public static QName QNAME_TYPE_NON_NEGATIVE_INTEGER =
+        new QName(NS_XSD, "nonNegativeInteger");
+    public static QName QNAME_TYPE_NON_POSITIVE_INTEGER =
+        new QName(NS_XSD, "nonPositiveInteger");
+    public static QName QNAME_TYPE_INT = new QName(NS_XSD, "int");
+    public static QName QNAME_TYPE_UNSIGNED_INT =
+        new QName(NS_XSD, "unsignedInt");
+    public static QName QNAME_TYPE_LONG = new QName(NS_XSD, "long");
+    public static QName QNAME_TYPE_UNSIGNED_LONG =
+        new QName(NS_XSD, "unsignedLong");
+    public static QName QNAME_TYPE_SHORT = new QName(NS_XSD, "short");
+    public static QName QNAME_TYPE_UNSIGNED_SHORT =
+        new QName(NS_XSD, "unsignedShort");
+    public static QName QNAME_TYPE_DECIMAL = new QName(NS_XSD, "decimal");
+    public static QName QNAME_TYPE_FLOAT = new QName(NS_XSD, "float");
+    public static QName QNAME_TYPE_DOUBLE = new QName(NS_XSD, "double");
+    public static QName QNAME_TYPE_BOOLEAN = new QName(NS_XSD, "boolean");
+    public static QName QNAME_TYPE_TIME = new QName(NS_XSD, "time");
+    public static QName QNAME_TYPE_DATE_TIME = new QName(NS_XSD, "dateTime");
+    public static QName QNAME_TYPE_DURATION = new QName(NS_XSD, "duration");
+    public static QName QNAME_TYPE_DATE = new QName(NS_XSD, "date");
+    public static QName QNAME_TYPE_G_MONTH = new QName(NS_XSD, "gMonth");
+    public static QName QNAME_TYPE_G_YEAR = new QName(NS_XSD, "gYear");
+    public static QName QNAME_TYPE_G_YEAR_MONTH =
+        new QName(NS_XSD, "gYearMonth");
+    public static QName QNAME_TYPE_G_DAY = new QName(NS_XSD, "gDay");
+    public static QName QNAME_TYPE_G_MONTH_DAY = new QName(NS_XSD, "gMonthDay");
+    public static QName QNAME_TYPE_NAME = new QName(NS_XSD, "Name");
+    public static QName QNAME_TYPE_QNAME = new QName(NS_XSD, "QName");
+    public static QName QNAME_TYPE_NCNAME = new QName(NS_XSD, "NCName");
+    public static QName QNAME_TYPE_ANY_URI = new QName(NS_XSD, "anyURI");
+    public static QName QNAME_TYPE_ID = new QName(NS_XSD, "ID");
+    public static QName QNAME_TYPE_IDREF = new QName(NS_XSD, "IDREF");
+    public static QName QNAME_TYPE_IDREFS = new QName(NS_XSD, "IDREFS");
+    public static QName QNAME_TYPE_ENTITY = new QName(NS_XSD, "ENTITY");
+    public static QName QNAME_TYPE_ENTITIES = new QName(NS_XSD, "ENTITIES");
+    public static QName QNAME_TYPE_NOTATION = new QName(NS_XSD, "NOTATION");
+    public static QName QNAME_TYPE_NMTOKEN = new QName(NS_XSD, "NMTOKEN");
+    public static QName QNAME_TYPE_NMTOKENS = new QName(NS_XSD, "NMTOKENS");
+
+    public static QName QNAME_TYPE_LANGUAGE = new QName(NS_XSD, "language");
+
+    // QNames for special types
+    public static QName QNAME_TYPE_URTYPE = new QName(NS_XSD, "anyType");
+    public static QName QNAME_TYPE_SIMPLE_URTYPE =
+        new QName(NS_XSD, "anySimpleType");
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaDocument.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaDocument.java
new file mode 100644
index 0000000..25d002e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaDocument.java
@@ -0,0 +1,126 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.schema;
+
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.AbstractDocument;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceAction;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceValidator;
+import com.sun.tools.internal.ws.wsdl.framework.GloballyKnown;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.NoSuchEntityException;
+import com.sun.tools.internal.ws.wsdl.framework.ValidationException;
+
+/**
+ * A XML Schema document.
+ *
+ * @author WS Development Team
+ */
+public class SchemaDocument extends AbstractDocument {
+
+    public SchemaDocument() {
+    }
+
+    public Schema getSchema() {
+        return _schema;
+    }
+
+    public void setSchema(Schema s) {
+        _schema = s;
+    }
+
+    public Set collectAllNamespaces() {
+        Set result = super.collectAllNamespaces();
+        if (_schema.getTargetNamespaceURI() != null) {
+            result.add(_schema.getTargetNamespaceURI());
+        }
+        return result;
+    }
+
+    public void validate(EntityReferenceValidator validator) {
+        GloballyValidatingAction action =
+            new GloballyValidatingAction(this, validator);
+        withAllSubEntitiesDo(action);
+        if (action.getException() != null) {
+            throw action.getException();
+        }
+    }
+
+    protected Entity getRoot() {
+        return _schema;
+    }
+
+    private Schema _schema;
+
+    private class GloballyValidatingAction
+        implements EntityAction, EntityReferenceAction {
+        public GloballyValidatingAction(
+            AbstractDocument document,
+            EntityReferenceValidator validator) {
+            _document = document;
+            _validator = validator;
+        }
+
+        public void perform(Entity entity) {
+            try {
+                entity.validateThis();
+                entity.withAllEntityReferencesDo(this);
+                entity.withAllSubEntitiesDo(this);
+            } catch (ValidationException e) {
+                if (_exception == null) {
+                    _exception = e;
+                }
+            }
+        }
+
+        public void perform(Kind kind, QName name) {
+            try {
+                GloballyKnown entity = _document.find(kind, name);
+            } catch (NoSuchEntityException e) {
+                // failed to resolve, check with the validator
+                if (_exception == null) {
+                    if (_validator == null
+                        || !_validator.isValid(kind, name)) {
+                        _exception = e;
+                    }
+                }
+            }
+        }
+
+        public ValidationException getException() {
+            return _exception;
+        }
+
+        private ValidationException _exception;
+        private AbstractDocument _document;
+        private EntityReferenceValidator _validator;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaElement.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaElement.java
new file mode 100644
index 0000000..1193405
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaElement.java
@@ -0,0 +1,347 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.schema;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.ValidationException;
+import com.sun.xml.internal.ws.util.NullIterator;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class SchemaElement {
+
+    public SchemaElement() {
+    }
+
+    public SchemaElement(String localName) {
+        _localName = localName;
+    }
+
+    public SchemaElement(QName name) {
+        _qname = name;
+        _localName = name.getLocalPart();
+        _nsURI = name.getNamespaceURI();
+    }
+
+    public String getNamespaceURI() {
+        return _nsURI;
+    }
+
+    public void setNamespaceURI(String s) {
+        _nsURI = s;
+    }
+
+    public String getLocalName() {
+        return _localName;
+    }
+
+    public void setLocalName(String s) {
+        _localName = s;
+    }
+
+    public QName getQName() {
+        if (_qname == null) {
+            _qname = new QName(_nsURI, _localName);
+        }
+        return _qname;
+    }
+
+    public SchemaElement getParent() {
+        return _parent;
+    }
+
+    public void setParent(SchemaElement e) {
+        _parent = e;
+    }
+
+    public SchemaElement getRoot() {
+        return _parent == null ? this : _parent.getRoot();
+    }
+
+    public Schema getSchema() {
+        return _parent == null ? _schema : _parent.getSchema();
+    }
+
+    public void setSchema(Schema s) {
+        _schema = s;
+    }
+
+    public void addChild(SchemaElement e) {
+        if (_children == null) {
+            _children = new ArrayList();
+        }
+
+        _children.add(e);
+        e.setParent(this);
+    }
+
+    public void insertChildAtTop(SchemaElement e) {
+        if (_children == null) {
+            _children = new ArrayList();
+        }
+
+        _children.add(0, e);
+        e.setParent(this);
+    }
+
+    public Iterator children() {
+        if (_children == null) {
+            return NullIterator.getInstance();
+        } else {
+            return _children.iterator();
+        }
+    }
+
+    public void addAttribute(SchemaAttribute a) {
+        if (_attributes == null) {
+            _attributes = new ArrayList();
+        }
+
+        _attributes.add(a);
+        a.setParent(this);
+        a.getValue();
+        // this is a hack to force namespace declarations to be added, if needed
+    }
+
+    public void addAttribute(String name, String value) {
+        SchemaAttribute attr = new SchemaAttribute();
+        attr.setLocalName(name);
+        attr.setValue(value);
+        addAttribute(attr);
+    }
+
+    public void addAttribute(String name, QName value) {
+        SchemaAttribute attr = new SchemaAttribute();
+        attr.setLocalName(name);
+        attr.setValue(value);
+        addAttribute(attr);
+    }
+
+    public Iterator attributes() {
+        if (_attributes == null) {
+            return NullIterator.getInstance();
+        } else {
+            return _attributes.iterator();
+        }
+    }
+
+    public SchemaAttribute getAttribute(String localName) {
+        if (_attributes != null) {
+            for (Iterator iter = _attributes.iterator(); iter.hasNext();) {
+                SchemaAttribute attr = (SchemaAttribute) iter.next();
+                if (localName.equals(attr.getLocalName())) {
+                    return attr;
+                }
+            }
+        }
+        return null;
+    }
+
+    public String getValueOfMandatoryAttribute(String localName) {
+        SchemaAttribute attr = getAttribute(localName);
+        if (attr == null) {
+            throw new ValidationException(
+                "validation.missingRequiredAttribute",
+                new Object[] { localName, _localName });
+        }
+        return attr.getValue();
+    }
+
+    public String getValueOfAttributeOrNull(String localName) {
+        SchemaAttribute attr = getAttribute(localName);
+        if (attr == null) {
+            return null;
+        } else {
+            return attr.getValue();
+        }
+    }
+
+    public boolean getValueOfBooleanAttributeOrDefault(
+        String localName,
+        boolean defaultValue) {
+        String stringValue = getValueOfAttributeOrNull(localName);
+        if (stringValue == null) {
+            return defaultValue;
+        }
+        if (stringValue.equals("true") || stringValue.equals("1")) {
+            return true;
+        } else if (stringValue.equals("false") || stringValue.equals("0")) {
+            return false;
+        } else {
+            throw new ValidationException(
+                "validation.invalidAttributeValue",
+                new Object[] { localName, stringValue });
+        }
+    }
+
+    public int getValueOfIntegerAttributeOrDefault(
+        String localName,
+        int defaultValue) {
+        String stringValue = getValueOfAttributeOrNull(localName);
+        if (stringValue == null) {
+            return defaultValue;
+        }
+        try {
+            return Integer.parseInt(stringValue);
+        } catch (NumberFormatException e) {
+            throw new ValidationException(
+                "validation.invalidAttributeValue",
+                new Object[] { localName, stringValue });
+        }
+    }
+
+    public QName getValueOfQNameAttributeOrNull(String localName) {
+        String stringValue = getValueOfAttributeOrNull(localName);
+        if (stringValue == null)
+            return null;
+
+        String prefix = XmlUtil.getPrefix(stringValue);
+        String uri =
+            (prefix == null ? getURIForPrefix("") : getURIForPrefix(prefix));
+        if (uri == null) {
+            throw new ValidationException(
+                "validation.invalidAttributeValue",
+                new Object[] { localName, stringValue });
+        }
+        return new QName(uri, XmlUtil.getLocalPart(stringValue));
+    }
+
+    public void addPrefix(String prefix, String uri) {
+        if (_nsPrefixes == null) {
+            _nsPrefixes = new HashMap();
+        }
+
+        _nsPrefixes.put(prefix, uri);
+    }
+
+    public String getURIForPrefix(String prefix) {
+        if (_nsPrefixes != null) {
+            String result = (String) _nsPrefixes.get(prefix);
+            if (result != null)
+                return result;
+        }
+        if (_parent != null) {
+            return _parent.getURIForPrefix(prefix);
+        }
+        if (_schema != null) {
+            return _schema.getURIForPrefix(prefix);
+        }
+        // give up
+        return null;
+    }
+
+    public boolean declaresPrefixes() {
+        return _nsPrefixes != null;
+    }
+
+    public Iterator prefixes() {
+        if (_nsPrefixes == null) {
+            return NullIterator.getInstance();
+        } else {
+            return _nsPrefixes.keySet().iterator();
+        }
+    }
+
+    public QName asQName(String s) {
+        String prefix = XmlUtil.getPrefix(s);
+        if (prefix == null) {
+            prefix = "";
+        }
+        String uri = getURIForPrefix(prefix);
+        if (uri == null) {
+            throw new ValidationException("validation.invalidPrefix", prefix);
+        }
+        String localPart = XmlUtil.getLocalPart(s);
+        return new QName(uri, localPart);
+    }
+
+    public String asString(QName name) {
+        if (name.getNamespaceURI().equals("")) {
+            return name.getLocalPart();
+        } else {
+            // look for a prefix
+            for (Iterator iter = prefixes(); iter.hasNext();) {
+                String prefix = (String) iter.next();
+                String uri = getURIForPrefix(prefix);
+                if (uri.equals(name.getNamespaceURI())) {
+                    if (prefix.equals("")) {
+                        return name.getLocalPart();
+                    } else {
+                        return prefix + ":" + name.getLocalPart();
+                    }
+                }
+            }
+
+            // not found
+            if (_parent != null) {
+                return _parent.asString(name);
+            }
+            if (_schema != null) {
+                String result = _schema.asString(name);
+                if (result != null) {
+                    return result;
+                }
+            }
+
+            // not found and no parent
+            String prefix = getNewPrefix();
+            addPrefix(prefix, name.getNamespaceURI());
+            return asString(name);
+        }
+    }
+
+    protected String getNewPrefix() {
+        String base = NEW_NS_PREFIX_BASE;
+        int count = 2;
+        String prefix = null;
+        for (boolean needNewOne = true; needNewOne; ++count) {
+            prefix = base + Integer.toString(count);
+            needNewOne = getURIForPrefix(prefix) != null;
+        }
+        return prefix;
+    }
+
+    private String _nsURI;
+    private String _localName;
+    private List _children;
+    private List _attributes;
+    private Map _nsPrefixes;
+    private SchemaElement _parent;
+    private QName _qname;
+    private Schema _schema;
+
+    private static final String NEW_NS_PREFIX_BASE = "ns";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaEntity.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaEntity.java
new file mode 100644
index 0000000..acfcb8a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaEntity.java
@@ -0,0 +1,84 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.schema;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Defining;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.GloballyKnown;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class SchemaEntity extends Entity implements GloballyKnown {
+
+    public SchemaEntity(
+        Schema parent,
+        SchemaElement element,
+        Kind kind,
+        QName name) {
+        _parent = parent;
+        _element = element;
+        _kind = kind;
+        _name = name;
+    }
+
+    public SchemaElement getElement() {
+        return _element;
+    }
+
+    public QName getElementName() {
+        return _element.getQName();
+    }
+
+    public String getName() {
+        return _name.getLocalPart();
+    }
+
+    public Kind getKind() {
+        return _kind;
+    }
+
+    public Schema getSchema() {
+        return _parent;
+    }
+
+    public Defining getDefining() {
+        return _parent;
+    }
+
+    public void validateThis() {
+        // do nothing
+    }
+
+    private Schema _parent;
+    private SchemaElement _element;
+    private Kind _kind;
+    private QName _name;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaKinds.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaKinds.java
new file mode 100644
index 0000000..e43a577
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/schema/SchemaKinds.java
@@ -0,0 +1,48 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.schema;
+
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class SchemaKinds {
+    public static final Kind XSD_ATTRIBUTE = new Kind("xsd:attribute");
+    public static final Kind XSD_ATTRIBUTE_GROUP =
+        new Kind("xsd:attributeGroup");
+    public static final Kind XSD_CONSTRAINT = new Kind("xsd:constraint");
+    public static final Kind XSD_ELEMENT = new Kind("xsd:element");
+    public static final Kind XSD_GROUP = new Kind("xsd:group");
+    public static final Kind XSD_IDENTITY_CONSTRAINT =
+        new Kind("xsd:identityConstraint");
+    public static final Kind XSD_NOTATION = new Kind("xsd:notation");
+    public static final Kind XSD_TYPE = new Kind("xsd:type");
+
+    private SchemaKinds() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAP12Binding.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAP12Binding.java
new file mode 100644
index 0000000..0cae486
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAP12Binding.java
@@ -0,0 +1,33 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+public class SOAP12Binding extends SOAPBinding{
+    @Override public QName getElementName() {
+        return SOAP12Constants.QNAME_BINDING;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAP12Constants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAP12Constants.java
new file mode 100644
index 0000000..e8738d4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAP12Constants.java
@@ -0,0 +1,238 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Interface defining SOAP1.2-related constants.
+ *
+ * @author WS Development Team
+ */
+public interface SOAP12Constants {
+
+    // namespace URIs
+    public static String NS_WSDL_SOAP = "http://schemas.xmlsoap.org/wsdl/soap12/";
+    public static String NS_SOAP_ENCODING =
+        "http://schemas.xmlsoap.org/soap/encoding/";
+
+    // other URIs
+    public static String URI_SOAP_TRANSPORT_HTTP =
+        "http://www.w3.org/2003/05/soap/bindings/HTTP/";
+    ;
+
+    // QNames
+    public static QName QNAME_ADDRESS = new QName(NS_WSDL_SOAP, "address");
+    public static QName QNAME_BINDING = new QName(NS_WSDL_SOAP, "binding");
+    public static QName QNAME_BODY = new QName(NS_WSDL_SOAP, "body");
+    public static QName QNAME_FAULT = new QName(NS_WSDL_SOAP, "fault");
+    public static QName QNAME_HEADER = new QName(NS_WSDL_SOAP, "header");
+    public static QName QNAME_HEADERFAULT =
+        new QName(NS_WSDL_SOAP, "headerfault");
+    public static QName QNAME_OPERATION = new QName(NS_WSDL_SOAP, "operation");
+
+    // SOAP encoding QNames
+    public static QName QNAME_TYPE_ARRAY = new QName(NS_SOAP_ENCODING, "Array");
+    public static QName QNAME_ATTR_GROUP_COMMON_ATTRIBUTES =
+        new QName(NS_SOAP_ENCODING, "commonAttributes");
+    public static QName QNAME_ATTR_ARRAY_TYPE =
+        new QName(NS_SOAP_ENCODING, "arrayType");
+    public static QName QNAME_ATTR_ITEM_TYPE =
+        new QName(NS_SOAP_ENCODING, "itemType");
+    public static QName QNAME_ATTR_ARRAY_SIZE =
+        new QName(NS_SOAP_ENCODING, "arraySize");
+    public static QName QNAME_ATTR_OFFSET =
+        new QName(NS_SOAP_ENCODING, "offset");
+    public static QName QNAME_ATTR_POSITION =
+        new QName(NS_SOAP_ENCODING, "position");
+
+    public static QName QNAME_TYPE_BASE64 =
+        new QName(NS_SOAP_ENCODING, "base64");
+
+    public static QName QNAME_ELEMENT_STRING =
+        new QName(NS_SOAP_ENCODING, "string");
+    public static QName QNAME_ELEMENT_NORMALIZED_STRING =
+        new QName(NS_SOAP_ENCODING, "normalizedString");
+    public static QName QNAME_ELEMENT_TOKEN =
+        new QName(NS_SOAP_ENCODING, "token");
+    public static QName QNAME_ELEMENT_BYTE =
+        new QName(NS_SOAP_ENCODING, "byte");
+    public static QName QNAME_ELEMENT_UNSIGNED_BYTE =
+        new QName(NS_SOAP_ENCODING, "unsignedByte");
+    public static QName QNAME_ELEMENT_BASE64_BINARY =
+        new QName(NS_SOAP_ENCODING, "base64Binary");
+    public static QName QNAME_ELEMENT_HEX_BINARY =
+        new QName(NS_SOAP_ENCODING, "hexBinary");
+    public static QName QNAME_ELEMENT_INTEGER =
+        new QName(NS_SOAP_ENCODING, "integer");
+    public static QName QNAME_ELEMENT_POSITIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "positiveInteger");
+    public static QName QNAME_ELEMENT_NEGATIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "negativeInteger");
+    public static QName QNAME_ELEMENT_NON_NEGATIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "nonNegativeInteger");
+    public static QName QNAME_ELEMENT_NON_POSITIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "nonPositiveInteger");
+    public static QName QNAME_ELEMENT_INT = new QName(NS_SOAP_ENCODING, "int");
+    public static QName QNAME_ELEMENT_UNSIGNED_INT =
+        new QName(NS_SOAP_ENCODING, "unsignedInt");
+    public static QName QNAME_ELEMENT_LONG =
+        new QName(NS_SOAP_ENCODING, "long");
+    public static QName QNAME_ELEMENT_UNSIGNED_LONG =
+        new QName(NS_SOAP_ENCODING, "unsignedLong");
+    public static QName QNAME_ELEMENT_SHORT =
+        new QName(NS_SOAP_ENCODING, "short");
+    public static QName QNAME_ELEMENT_UNSIGNED_SHORT =
+        new QName(NS_SOAP_ENCODING, "unsignedShort");
+    public static QName QNAME_ELEMENT_DECIMAL =
+        new QName(NS_SOAP_ENCODING, "decimal");
+    public static QName QNAME_ELEMENT_FLOAT =
+        new QName(NS_SOAP_ENCODING, "float");
+    public static QName QNAME_ELEMENT_DOUBLE =
+        new QName(NS_SOAP_ENCODING, "double");
+    public static QName QNAME_ELEMENT_BOOLEAN =
+        new QName(NS_SOAP_ENCODING, "boolean");
+    public static QName QNAME_ELEMENT_TIME =
+        new QName(NS_SOAP_ENCODING, "time");
+    public static QName QNAME_ELEMENT_DATE_TIME =
+        new QName(NS_SOAP_ENCODING, "dateTime");
+    public static QName QNAME_ELEMENT_DURATION =
+        new QName(NS_SOAP_ENCODING, "duration");
+    public static QName QNAME_ELEMENT_DATE =
+        new QName(NS_SOAP_ENCODING, "date");
+    public static QName QNAME_ELEMENT_G_MONTH =
+        new QName(NS_SOAP_ENCODING, "gMonth");
+    public static QName QNAME_ELEMENT_G_YEAR =
+        new QName(NS_SOAP_ENCODING, "gYear");
+    public static QName QNAME_ELEMENT_G_YEAR_MONTH =
+        new QName(NS_SOAP_ENCODING, "gYearMonth");
+    public static QName QNAME_ELEMENT_G_DAY =
+        new QName(NS_SOAP_ENCODING, "gDay");
+    public static QName QNAME_ELEMENT_G_MONTH_DAY =
+        new QName(NS_SOAP_ENCODING, "gMonthDay");
+    public static QName QNAME_ELEMENT_NAME =
+        new QName(NS_SOAP_ENCODING, "Name");
+    public static QName QNAME_ELEMENT_QNAME =
+        new QName(NS_SOAP_ENCODING, "QName");
+    public static QName QNAME_ELEMENT_NCNAME =
+        new QName(NS_SOAP_ENCODING, "NCName");
+    public static QName QNAME_ELEMENT_ANY_URI =
+        new QName(NS_SOAP_ENCODING, "anyURI");
+    public static QName QNAME_ELEMENT_ID = new QName(NS_SOAP_ENCODING, "ID");
+    public static QName QNAME_ELEMENT_IDREF =
+        new QName(NS_SOAP_ENCODING, "IDREF");
+    public static QName QNAME_ELEMENT_IDREFS =
+        new QName(NS_SOAP_ENCODING, "IDREFS");
+    public static QName QNAME_ELEMENT_ENTITY =
+        new QName(NS_SOAP_ENCODING, "ENTITY");
+    public static QName QNAME_ELEMENT_ENTITIES =
+        new QName(NS_SOAP_ENCODING, "ENTITIES");
+    public static QName QNAME_ELEMENT_NOTATION =
+        new QName(NS_SOAP_ENCODING, "NOTATION");
+    public static QName QNAME_ELEMENT_NMTOKEN =
+        new QName(NS_SOAP_ENCODING, "NMTOKEN");
+    public static QName QNAME_ELEMENT_NMTOKENS =
+        new QName(NS_SOAP_ENCODING, "NMTOKENS");
+
+    public static QName QNAME_TYPE_STRING =
+        new QName(NS_SOAP_ENCODING, "string");
+    public static QName QNAME_TYPE_NORMALIZED_STRING =
+        new QName(NS_SOAP_ENCODING, "normalizedString");
+    public static QName QNAME_TYPE_TOKEN = new QName(NS_SOAP_ENCODING, "token");
+    public static QName QNAME_TYPE_BYTE = new QName(NS_SOAP_ENCODING, "byte");
+    public static QName QNAME_TYPE_UNSIGNED_BYTE =
+        new QName(NS_SOAP_ENCODING, "unsignedByte");
+    public static QName QNAME_TYPE_BASE64_BINARY =
+        new QName(NS_SOAP_ENCODING, "base64Binary");
+    public static QName QNAME_TYPE_HEX_BINARY =
+        new QName(NS_SOAP_ENCODING, "hexBinary");
+    public static QName QNAME_TYPE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "integer");
+    public static QName QNAME_TYPE_POSITIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "positiveInteger");
+    public static QName QNAME_TYPE_NEGATIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "negativeInteger");
+    public static QName QNAME_TYPE_NON_NEGATIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "nonNegativeInteger");
+    public static QName QNAME_TYPE_NON_POSITIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "nonPositiveInteger");
+    public static QName QNAME_TYPE_INT = new QName(NS_SOAP_ENCODING, "int");
+    public static QName QNAME_TYPE_UNSIGNED_INT =
+        new QName(NS_SOAP_ENCODING, "unsignedInt");
+    public static QName QNAME_TYPE_LONG = new QName(NS_SOAP_ENCODING, "long");
+    public static QName QNAME_TYPE_UNSIGNED_LONG =
+        new QName(NS_SOAP_ENCODING, "unsignedLong");
+    public static QName QNAME_TYPE_SHORT = new QName(NS_SOAP_ENCODING, "short");
+    public static QName QNAME_TYPE_UNSIGNED_SHORT =
+        new QName(NS_SOAP_ENCODING, "unsignedShort");
+    public static QName QNAME_TYPE_DECIMAL =
+        new QName(NS_SOAP_ENCODING, "decimal");
+    public static QName QNAME_TYPE_FLOAT = new QName(NS_SOAP_ENCODING, "float");
+    public static QName QNAME_TYPE_DOUBLE =
+        new QName(NS_SOAP_ENCODING, "double");
+    public static QName QNAME_TYPE_BOOLEAN =
+        new QName(NS_SOAP_ENCODING, "boolean");
+    public static QName QNAME_TYPE_TIME = new QName(NS_SOAP_ENCODING, "time");
+    public static QName QNAME_TYPE_DATE_TIME =
+        new QName(NS_SOAP_ENCODING, "dateTime");
+    public static QName QNAME_TYPE_DURATION =
+        new QName(NS_SOAP_ENCODING, "duration");
+    public static QName QNAME_TYPE_DATE = new QName(NS_SOAP_ENCODING, "date");
+    public static QName QNAME_TYPE_G_MONTH =
+        new QName(NS_SOAP_ENCODING, "gMonth");
+    public static QName QNAME_TYPE_G_YEAR =
+        new QName(NS_SOAP_ENCODING, "gYear");
+    public static QName QNAME_TYPE_G_YEAR_MONTH =
+        new QName(NS_SOAP_ENCODING, "gYearMonth");
+    public static QName QNAME_TYPE_G_DAY = new QName(NS_SOAP_ENCODING, "gDay");
+    public static QName QNAME_TYPE_G_MONTH_DAY =
+        new QName(NS_SOAP_ENCODING, "gMonthDay");
+    public static QName QNAME_TYPE_NAME = new QName(NS_SOAP_ENCODING, "Name");
+    public static QName QNAME_TYPE_QNAME = new QName(NS_SOAP_ENCODING, "QName");
+    public static QName QNAME_TYPE_NCNAME =
+        new QName(NS_SOAP_ENCODING, "NCName");
+    public static QName QNAME_TYPE_ANY_URI =
+        new QName(NS_SOAP_ENCODING, "anyURI");
+    public static QName QNAME_TYPE_ID = new QName(NS_SOAP_ENCODING, "ID");
+    public static QName QNAME_TYPE_IDREF = new QName(NS_SOAP_ENCODING, "IDREF");
+    public static QName QNAME_TYPE_IDREFS =
+        new QName(NS_SOAP_ENCODING, "IDREFS");
+    public static QName QNAME_TYPE_ENTITY =
+        new QName(NS_SOAP_ENCODING, "ENTITY");
+    public static QName QNAME_TYPE_ENTITIES =
+        new QName(NS_SOAP_ENCODING, "ENTITIES");
+    public static QName QNAME_TYPE_NOTATION =
+        new QName(NS_SOAP_ENCODING, "NOTATION");
+    public static QName QNAME_TYPE_NMTOKEN =
+        new QName(NS_SOAP_ENCODING, "NMTOKEN");
+    public static QName QNAME_TYPE_NMTOKENS =
+        new QName(NS_SOAP_ENCODING, "NMTOKENS");
+    public static QName QNAME_TYPE_LANGUAGE =
+        new QName(NS_SOAP_ENCODING, "LANGUAGE");
+
+    // SOAP attributes with non-colonized names
+    public static QName QNAME_ATTR_ID = new QName("", "id");
+    public static QName QNAME_ATTR_HREF = new QName("", "ref");
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPAddress.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPAddress.java
new file mode 100644
index 0000000..95a2bfa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPAddress.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A SOAP address extension.
+ *
+ * @author WS Development Team
+ */
+public class SOAPAddress extends Extension {
+
+    public SOAPAddress() {
+    }
+
+    public QName getElementName() {
+        return SOAPConstants.QNAME_ADDRESS;
+    }
+
+    public String getLocation() {
+        return _location;
+    }
+
+    public void setLocation(String s) {
+        _location = s;
+    }
+
+    public void validateThis() {
+        if (_location == null) {
+            failValidation("validation.missingRequiredAttribute", "location");
+        }
+    }
+
+    private String _location;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPBinding.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPBinding.java
new file mode 100644
index 0000000..be2fe89
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPBinding.java
@@ -0,0 +1,76 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A SOAP binding extension.
+ *
+ * @author WS Development Team
+ */
+public class SOAPBinding extends Extension {
+
+    public SOAPBinding() {
+        _style = SOAPStyle.DOCUMENT;
+    }
+
+    public QName getElementName() {
+        return SOAPConstants.QNAME_BINDING;
+    }
+
+    public String getTransport() {
+        return _transport;
+    }
+
+    public void setTransport(String s) {
+        _transport = s;
+    }
+
+    public SOAPStyle getStyle() {
+        return _style;
+    }
+
+    public void setStyle(SOAPStyle s) {
+        _style = s;
+    }
+
+    public boolean isDocument() {
+        return _style == SOAPStyle.DOCUMENT;
+    }
+
+    public boolean isRPC() {
+        return _style == SOAPStyle.RPC;
+    }
+
+    public void validateThis() {
+    }
+
+    private String _transport;
+    private SOAPStyle _style;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPBody.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPBody.java
new file mode 100644
index 0000000..0bae750
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPBody.java
@@ -0,0 +1,93 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A SOAP body extension.
+ *
+ * @author WS Development Team
+ */
+public class SOAPBody extends Extension {
+
+    public SOAPBody() {
+    }
+
+    public QName getElementName() {
+        return SOAPConstants.QNAME_BODY;
+    }
+
+    public String getNamespace() {
+        return _namespace;
+    }
+
+    public void setNamespace(String s) {
+        _namespace = s;
+    }
+
+    public SOAPUse getUse() {
+        return _use;
+    }
+
+    public void setUse(SOAPUse u) {
+        _use = u;
+    }
+
+    public boolean isEncoded() {
+        return _use == SOAPUse.ENCODED;
+    }
+
+    public boolean isLiteral() {
+        return _use == SOAPUse.LITERAL;
+    }
+
+    public String getEncodingStyle() {
+        return _encodingStyle;
+    }
+
+    public void setEncodingStyle(String s) {
+        _encodingStyle = s;
+    }
+
+    public String getParts() {
+        return _parts;
+    }
+
+    public void setParts(String s) {
+        _parts = s;
+    }
+
+    public void validateThis() {
+    }
+
+    private String _encodingStyle;
+    private String _namespace;
+    private String _parts;
+    private SOAPUse _use=SOAPUse.LITERAL;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPConstants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPConstants.java
new file mode 100644
index 0000000..d8ac0cf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPConstants.java
@@ -0,0 +1,259 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+
+/**
+ * Interface defining SOAP-related constants.
+ *
+ * @author WS Development Team
+ */
+public interface SOAPConstants {
+
+    // namespace URIs
+    public static final String URI_ENVELOPE = SOAPNamespaceConstants.ENVELOPE;
+    public static final String NS_WSDL_SOAP =
+        "http://schemas.xmlsoap.org/wsdl/soap/";
+    public static final String NS_SOAP_ENCODING = "http://schemas.xmlsoap.org/soap/encoding/";
+
+    // other URIs
+    public final String URI_SOAP_TRANSPORT_HTTP =
+        "http://schemas.xmlsoap.org/soap/http";
+
+    // QNames
+    public static final QName QNAME_ADDRESS =
+        new QName(NS_WSDL_SOAP, "address");
+    public static final QName QNAME_BINDING =
+        new QName(NS_WSDL_SOAP, "binding");
+    public static final QName QNAME_BODY = new QName(NS_WSDL_SOAP, "body");
+    public static final QName QNAME_FAULT = new QName(NS_WSDL_SOAP, "fault");
+    public static final QName QNAME_HEADER = new QName(NS_WSDL_SOAP, "header");
+    public static final QName QNAME_HEADERFAULT =
+        new QName(NS_WSDL_SOAP, "headerfault");
+    public static final QName QNAME_OPERATION =
+        new QName(NS_WSDL_SOAP, "operation");
+    public static final QName QNAME_MUSTUNDERSTAND =
+        new QName(URI_ENVELOPE, "mustUnderstand");
+
+
+    // SOAP encoding QNames
+    public static final QName QNAME_TYPE_ARRAY =
+        new QName(NS_SOAP_ENCODING, "Array");
+    public static final QName QNAME_ATTR_GROUP_COMMON_ATTRIBUTES =
+        new QName(NS_SOAP_ENCODING, "commonAttributes");
+    public static final QName QNAME_ATTR_ARRAY_TYPE =
+        new QName(NS_SOAP_ENCODING, "arrayType");
+    public static final QName QNAME_ATTR_OFFSET =
+        new QName(NS_SOAP_ENCODING, "offset");
+    public static final QName QNAME_ATTR_POSITION =
+        new QName(NS_SOAP_ENCODING, "position");
+
+    public static final QName QNAME_TYPE_BASE64 =
+        new QName(NS_SOAP_ENCODING, "base64");
+
+    public static final QName QNAME_ELEMENT_STRING =
+        new QName(NS_SOAP_ENCODING, "string");
+    public static final QName QNAME_ELEMENT_NORMALIZED_STRING =
+        new QName(NS_SOAP_ENCODING, "normalizedString");
+    public static final QName QNAME_ELEMENT_TOKEN =
+        new QName(NS_SOAP_ENCODING, "token");
+    public static final QName QNAME_ELEMENT_BYTE =
+        new QName(NS_SOAP_ENCODING, "byte");
+    public static final QName QNAME_ELEMENT_UNSIGNED_BYTE =
+        new QName(NS_SOAP_ENCODING, "unsignedByte");
+    public static final QName QNAME_ELEMENT_BASE64_BINARY =
+        new QName(NS_SOAP_ENCODING, "base64Binary");
+    public static final QName QNAME_ELEMENT_HEX_BINARY =
+        new QName(NS_SOAP_ENCODING, "hexBinary");
+    public static final QName QNAME_ELEMENT_INTEGER =
+        new QName(NS_SOAP_ENCODING, "integer");
+    public static final QName QNAME_ELEMENT_POSITIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "positiveInteger");
+    public static final QName QNAME_ELEMENT_NEGATIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "negativeInteger");
+    public static final QName QNAME_ELEMENT_NON_NEGATIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "nonNegativeInteger");
+    public static final QName QNAME_ELEMENT_NON_POSITIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "nonPositiveInteger");
+    public static final QName QNAME_ELEMENT_INT =
+        new QName(NS_SOAP_ENCODING, "int");
+    public static final QName QNAME_ELEMENT_UNSIGNED_INT =
+        new QName(NS_SOAP_ENCODING, "unsignedInt");
+    public static final QName QNAME_ELEMENT_LONG =
+        new QName(NS_SOAP_ENCODING, "long");
+    public static final QName QNAME_ELEMENT_UNSIGNED_LONG =
+        new QName(NS_SOAP_ENCODING, "unsignedLong");
+    public static final QName QNAME_ELEMENT_SHORT =
+        new QName(NS_SOAP_ENCODING, "short");
+    public static final QName QNAME_ELEMENT_UNSIGNED_SHORT =
+        new QName(NS_SOAP_ENCODING, "unsignedShort");
+    public static final QName QNAME_ELEMENT_DECIMAL =
+        new QName(NS_SOAP_ENCODING, "decimal");
+    public static final QName QNAME_ELEMENT_FLOAT =
+        new QName(NS_SOAP_ENCODING, "float");
+    public static final QName QNAME_ELEMENT_DOUBLE =
+        new QName(NS_SOAP_ENCODING, "double");
+    public static final QName QNAME_ELEMENT_BOOLEAN =
+        new QName(NS_SOAP_ENCODING, "boolean");
+    public static final QName QNAME_ELEMENT_TIME =
+        new QName(NS_SOAP_ENCODING, "time");
+    public static final QName QNAME_ELEMENT_DATE_TIME =
+        new QName(NS_SOAP_ENCODING, "dateTime");
+    public static final QName QNAME_ELEMENT_DURATION =
+        new QName(NS_SOAP_ENCODING, "duration");
+    public static final QName QNAME_ELEMENT_DATE =
+        new QName(NS_SOAP_ENCODING, "date");
+    public static final QName QNAME_ELEMENT_G_MONTH =
+        new QName(NS_SOAP_ENCODING, "gMonth");
+    public static final QName QNAME_ELEMENT_G_YEAR =
+        new QName(NS_SOAP_ENCODING, "gYear");
+    public static final QName QNAME_ELEMENT_G_YEAR_MONTH =
+        new QName(NS_SOAP_ENCODING, "gYearMonth");
+    public static final QName QNAME_ELEMENT_G_DAY =
+        new QName(NS_SOAP_ENCODING, "gDay");
+    public static final QName QNAME_ELEMENT_G_MONTH_DAY =
+        new QName(NS_SOAP_ENCODING, "gMonthDay");
+    public static final QName QNAME_ELEMENT_NAME =
+        new QName(NS_SOAP_ENCODING, "Name");
+    public static final QName QNAME_ELEMENT_QNAME =
+        new QName(NS_SOAP_ENCODING, "QName");
+    public static final QName QNAME_ELEMENT_NCNAME =
+        new QName(NS_SOAP_ENCODING, "NCName");
+    public static final QName QNAME_ELEMENT_ANY_URI =
+        new QName(NS_SOAP_ENCODING, "anyURI");
+    public static final QName QNAME_ELEMENT_ID =
+        new QName(NS_SOAP_ENCODING, "ID");
+    public static final QName QNAME_ELEMENT_IDREF =
+        new QName(NS_SOAP_ENCODING, "IDREF");
+    public static final QName QNAME_ELEMENT_IDREFS =
+        new QName(NS_SOAP_ENCODING, "IDREFS");
+    public static final QName QNAME_ELEMENT_ENTITY =
+        new QName(NS_SOAP_ENCODING, "ENTITY");
+    public static final QName QNAME_ELEMENT_ENTITIES =
+        new QName(NS_SOAP_ENCODING, "ENTITIES");
+    public static final QName QNAME_ELEMENT_NOTATION =
+        new QName(NS_SOAP_ENCODING, "NOTATION");
+    public static final QName QNAME_ELEMENT_NMTOKEN =
+        new QName(NS_SOAP_ENCODING, "NMTOKEN");
+    public static final QName QNAME_ELEMENT_NMTOKENS =
+        new QName(NS_SOAP_ENCODING, "NMTOKENS");
+
+    public static final QName QNAME_TYPE_STRING =
+        new QName(NS_SOAP_ENCODING, "string");
+    public static final QName QNAME_TYPE_NORMALIZED_STRING =
+        new QName(NS_SOAP_ENCODING, "normalizedString");
+    public static final QName QNAME_TYPE_TOKEN =
+        new QName(NS_SOAP_ENCODING, "token");
+    public static final QName QNAME_TYPE_BYTE =
+        new QName(NS_SOAP_ENCODING, "byte");
+    public static final QName QNAME_TYPE_UNSIGNED_BYTE =
+        new QName(NS_SOAP_ENCODING, "unsignedByte");
+    public static final QName QNAME_TYPE_BASE64_BINARY =
+        new QName(NS_SOAP_ENCODING, "base64Binary");
+    public static final QName QNAME_TYPE_HEX_BINARY =
+        new QName(NS_SOAP_ENCODING, "hexBinary");
+    public static final QName QNAME_TYPE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "integer");
+    public static final QName QNAME_TYPE_POSITIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "positiveInteger");
+    public static final QName QNAME_TYPE_NEGATIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "negativeInteger");
+    public static final QName QNAME_TYPE_NON_NEGATIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "nonNegativeInteger");
+    public static final QName QNAME_TYPE_NON_POSITIVE_INTEGER =
+        new QName(NS_SOAP_ENCODING, "nonPositiveInteger");
+    public static final QName QNAME_TYPE_INT =
+        new QName(NS_SOAP_ENCODING, "int");
+    public static final QName QNAME_TYPE_UNSIGNED_INT =
+        new QName(NS_SOAP_ENCODING, "unsignedInt");
+    public static final QName QNAME_TYPE_LONG =
+        new QName(NS_SOAP_ENCODING, "long");
+    public static final QName QNAME_TYPE_UNSIGNED_LONG =
+        new QName(NS_SOAP_ENCODING, "unsignedLong");
+    public static final QName QNAME_TYPE_SHORT =
+        new QName(NS_SOAP_ENCODING, "short");
+    public static final QName QNAME_TYPE_UNSIGNED_SHORT =
+        new QName(NS_SOAP_ENCODING, "unsignedShort");
+    public static final QName QNAME_TYPE_DECIMAL =
+        new QName(NS_SOAP_ENCODING, "decimal");
+    public static final QName QNAME_TYPE_FLOAT =
+        new QName(NS_SOAP_ENCODING, "float");
+    public static final QName QNAME_TYPE_DOUBLE =
+        new QName(NS_SOAP_ENCODING, "double");
+    public static final QName QNAME_TYPE_BOOLEAN =
+        new QName(NS_SOAP_ENCODING, "boolean");
+    public static final QName QNAME_TYPE_TIME =
+        new QName(NS_SOAP_ENCODING, "time");
+    public static final QName QNAME_TYPE_DATE_TIME =
+        new QName(NS_SOAP_ENCODING, "dateTime");
+    public static final QName QNAME_TYPE_DURATION =
+        new QName(NS_SOAP_ENCODING, "duration");
+    public static final QName QNAME_TYPE_DATE =
+        new QName(NS_SOAP_ENCODING, "date");
+    public static final QName QNAME_TYPE_G_MONTH =
+        new QName(NS_SOAP_ENCODING, "gMonth");
+    public static final QName QNAME_TYPE_G_YEAR =
+        new QName(NS_SOAP_ENCODING, "gYear");
+    public static final QName QNAME_TYPE_G_YEAR_MONTH =
+        new QName(NS_SOAP_ENCODING, "gYearMonth");
+    public static final QName QNAME_TYPE_G_DAY =
+        new QName(NS_SOAP_ENCODING, "gDay");
+    public static final QName QNAME_TYPE_G_MONTH_DAY =
+        new QName(NS_SOAP_ENCODING, "gMonthDay");
+    public static final QName QNAME_TYPE_NAME =
+        new QName(NS_SOAP_ENCODING, "Name");
+    public static final QName QNAME_TYPE_QNAME =
+        new QName(NS_SOAP_ENCODING, "QName");
+    public static final QName QNAME_TYPE_NCNAME =
+        new QName(NS_SOAP_ENCODING, "NCName");
+    public static final QName QNAME_TYPE_ANY_URI =
+        new QName(NS_SOAP_ENCODING, "anyURI");
+    public static final QName QNAME_TYPE_ID = new QName(NS_SOAP_ENCODING, "ID");
+    public static final QName QNAME_TYPE_IDREF =
+        new QName(NS_SOAP_ENCODING, "IDREF");
+    public static final QName QNAME_TYPE_IDREFS =
+        new QName(NS_SOAP_ENCODING, "IDREFS");
+    public static final QName QNAME_TYPE_ENTITY =
+        new QName(NS_SOAP_ENCODING, "ENTITY");
+    public static final QName QNAME_TYPE_ENTITIES =
+        new QName(NS_SOAP_ENCODING, "ENTITIES");
+    public static final QName QNAME_TYPE_NOTATION =
+        new QName(NS_SOAP_ENCODING, "NOTATION");
+    public static final QName QNAME_TYPE_NMTOKEN =
+        new QName(NS_SOAP_ENCODING, "NMTOKEN");
+    public static final QName QNAME_TYPE_NMTOKENS =
+        new QName(NS_SOAP_ENCODING, "NMTOKENS");
+    public static final QName QNAME_TYPE_LANGUAGE =
+        new QName(NS_SOAP_ENCODING, "LANGUAGE");
+
+    // SOAP attributes with non-colonized names
+    public static final QName QNAME_ATTR_ID = new QName("", "id");
+    public static final QName QNAME_ATTR_HREF = new QName("", "href");
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPFault.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPFault.java
new file mode 100644
index 0000000..b12cf35
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPFault.java
@@ -0,0 +1,94 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A SOAP fault extension.
+ *
+ * @author WS Development Team
+ */
+public class SOAPFault extends Extension {
+
+    public SOAPFault() {
+        _use = SOAPUse.LITERAL;
+    }
+
+    public QName getElementName() {
+        return SOAPConstants.QNAME_FAULT;
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String s) {
+        _name = s;
+    }
+
+    public String getNamespace() {
+        return _namespace;
+    }
+
+    public void setNamespace(String s) {
+        _namespace = s;
+    }
+
+    public SOAPUse getUse() {
+        return _use;
+    }
+
+    public void setUse(SOAPUse u) {
+        _use = u;
+    }
+
+    public boolean isEncoded() {
+        return _use == SOAPUse.ENCODED;
+    }
+
+    public boolean isLiteral() {
+        return _use == SOAPUse.LITERAL;
+    }
+
+    public String getEncodingStyle() {
+        return _encodingStyle;
+    }
+
+    public void setEncodingStyle(String s) {
+        _encodingStyle = s;
+    }
+
+    public void validateThis() {
+    }
+
+    private String _name;
+    private String _encodingStyle;
+    private String _namespace;
+    private SOAPUse _use = SOAPUse.LITERAL;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPHeader.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPHeader.java
new file mode 100644
index 0000000..c75e758
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPHeader.java
@@ -0,0 +1,154 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.EntityAction;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ExtensionVisitor;
+import com.sun.tools.internal.ws.wsdl.framework.QNameAction;
+
+/**
+ * A SOAP header extension.
+ *
+ * @author WS Development Team
+ */
+public class SOAPHeader extends Extension {
+
+    public SOAPHeader() {
+        _faults = new ArrayList();
+    }
+
+    public void add(SOAPHeaderFault fault) {
+        _faults.add(fault);
+    }
+
+    public Iterator faults() {
+        return _faults.iterator();
+    }
+
+    public QName getElementName() {
+        return SOAPConstants.QNAME_HEADER;
+    }
+
+    public String getNamespace() {
+        return _namespace;
+    }
+
+    public void setNamespace(String s) {
+        _namespace = s;
+    }
+
+    public SOAPUse getUse() {
+        return _use;
+    }
+
+    public void setUse(SOAPUse u) {
+        _use = u;
+    }
+
+    public boolean isEncoded() {
+        return _use == SOAPUse.ENCODED;
+    }
+
+    public boolean isLiteral() {
+        return _use == SOAPUse.LITERAL;
+    }
+
+    public String getEncodingStyle() {
+        return _encodingStyle;
+    }
+
+    public void setEncodingStyle(String s) {
+        _encodingStyle = s;
+    }
+
+    public String getPart() {
+        return _part;
+    }
+
+    public void setMessage(QName message) {
+        _message = message;
+    }
+
+    public QName getMessage() {
+        return _message;
+    }
+
+    public void setPart(String s) {
+        _part = s;
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        super.withAllSubEntitiesDo(action);
+
+        for (Iterator iter = _faults.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        super.withAllQNamesDo(action);
+
+        if (_message != null) {
+            action.perform(_message);
+        }
+    }
+
+    public void accept(ExtensionVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        for (Iterator iter = _faults.iterator(); iter.hasNext();) {
+            ((SOAPHeaderFault) iter.next()).accept(visitor);
+        }
+        visitor.postVisit(this);
+    }
+
+    public void validateThis() {
+        if (_message == null) {
+            failValidation("validation.missingRequiredAttribute", "message");
+        }
+        if (_part == null) {
+            failValidation("validation.missingRequiredAttribute", "part");
+        }
+        // Fix for bug 4851427
+        //        if (_use == null) {
+        //            failValidation("validation.missingRequiredAttribute", "use");
+        //        }
+    }
+
+    private String _encodingStyle;
+    private String _namespace;
+    private String _part;
+    private QName _message;
+    private SOAPUse _use=SOAPUse.LITERAL;
+    private List _faults;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPHeaderFault.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPHeaderFault.java
new file mode 100644
index 0000000..fa0e1fc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPHeaderFault.java
@@ -0,0 +1,120 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.QNameAction;
+
+/**
+ * A SOAP header fault extension.
+ *
+ * @author WS Development Team
+ */
+public class SOAPHeaderFault extends Extension {
+
+    public SOAPHeaderFault() {
+    }
+
+    public QName getElementName() {
+        return SOAPConstants.QNAME_HEADERFAULT;
+    }
+
+    public String getNamespace() {
+        return _namespace;
+    }
+
+    public void setNamespace(String s) {
+        _namespace = s;
+    }
+
+    public SOAPUse getUse() {
+        return _use;
+    }
+
+    public void setUse(SOAPUse u) {
+        _use = u;
+    }
+
+    public boolean isEncoded() {
+        return _use == SOAPUse.ENCODED;
+    }
+
+    public boolean isLiteral() {
+        return _use == SOAPUse.LITERAL;
+    }
+
+    public String getEncodingStyle() {
+        return _encodingStyle;
+    }
+
+    public void setEncodingStyle(String s) {
+        _encodingStyle = s;
+    }
+
+    public String getPart() {
+        return _part;
+    }
+
+    public void setMessage(QName message) {
+        _message = message;
+    }
+
+    public QName getMessage() {
+        return _message;
+    }
+
+    public void setPart(String s) {
+        _part = s;
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        super.withAllQNamesDo(action);
+
+        if (_message != null) {
+            action.perform(_message);
+        }
+    }
+
+    public void validateThis() {
+        if (_message == null) {
+            failValidation("validation.missingRequiredAttribute", "message");
+        }
+        if (_part == null) {
+            failValidation("validation.missingRequiredAttribute", "part");
+        }
+        if (_use == null) {
+            failValidation("validation.missingRequiredAttribute", "use");
+        }
+    }
+
+    private String _encodingStyle;
+    private String _namespace;
+    private String _part;
+    private QName _message;
+    private SOAPUse _use=SOAPUse.LITERAL;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPOperation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPOperation.java
new file mode 100644
index 0000000..c519deb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPOperation.java
@@ -0,0 +1,75 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+
+/**
+ * A SOAP operation extension.
+ *
+ * @author WS Development Team
+ */
+public class SOAPOperation extends Extension {
+
+    public SOAPOperation() {
+    }
+
+    public QName getElementName() {
+        return SOAPConstants.QNAME_OPERATION;
+    }
+
+    public String getSOAPAction() {
+        return _soapAction;
+    }
+
+    public void setSOAPAction(String s) {
+        _soapAction = s;
+    }
+
+    public SOAPStyle getStyle() {
+        return _style;
+    }
+
+    public void setStyle(SOAPStyle s) {
+        _style = s;
+    }
+
+    public boolean isDocument() {
+        return _style == SOAPStyle.DOCUMENT;
+    }
+
+    public boolean isRPC() {
+        return _style == SOAPStyle.RPC;
+    }
+
+    public void validateThis() {
+    }
+
+    private String _soapAction;
+    private SOAPStyle _style;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPStyle.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPStyle.java
new file mode 100644
index 0000000..cd5d407
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPStyle.java
@@ -0,0 +1,40 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+/**
+ * A SOAP "style" enumeration.
+ *
+ * @author WS Development Team
+ */
+public final class SOAPStyle {
+
+    public static final SOAPStyle RPC = new SOAPStyle();
+    public static final SOAPStyle DOCUMENT = new SOAPStyle();
+
+    private SOAPStyle() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPUse.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPUse.java
new file mode 100644
index 0000000..b07e038
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/document/soap/SOAPUse.java
@@ -0,0 +1,40 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.document.soap;
+
+/**
+ * A SOAP "use" enumeration.
+ *
+ * @author WS Development Team
+ */
+public final class SOAPUse {
+
+    public static final SOAPUse LITERAL = new SOAPUse();
+    public static final SOAPUse ENCODED = new SOAPUse();
+
+    private SOAPUse() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/AbstractDocument.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/AbstractDocument.java
new file mode 100644
index 0000000..334aa00
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/AbstractDocument.java
@@ -0,0 +1,260 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+/**
+ * An abstract class for documents containing entities.
+ *
+ * @author WS Development Team
+ */
+public abstract class AbstractDocument {
+
+    protected AbstractDocument() {
+        _kinds = new HashMap();
+        _identifiables = new HashMap();
+        _importedEntities = new ArrayList();
+        _importedDocuments = new HashSet();
+        _includedEntities = new ArrayList();
+        _includedDocuments = new HashSet();
+    }
+
+    public String getSystemId() {
+        return _systemId;
+    }
+
+    public void setSystemId(String s) {
+        if (_systemId != null && !_systemId.equals(s)) {
+            // avoid redefinition of a system identifier
+            throw new IllegalArgumentException();
+        }
+
+        _systemId = s;
+        if (s != null) {
+            _importedDocuments.add(s);
+        }
+    }
+
+    public void addIncludedDocument(String systemId) {
+        _includedDocuments.add(systemId);
+    }
+
+    public boolean isIncludedDocument(String systemId) {
+        return _includedDocuments.contains(systemId);
+    }
+
+    public void addIncludedEntity(Entity entity) {
+        _includedEntities.add(entity);
+    }
+
+    public void addImportedDocument(String systemId) {
+        _importedDocuments.add(systemId);
+    }
+
+    public boolean isImportedDocument(String systemId) {
+        return _importedDocuments.contains(systemId);
+    }
+
+    public void addImportedEntity(Entity entity) {
+        _importedEntities.add(entity);
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        if (getRoot() != null) {
+            action.perform(getRoot());
+        }
+
+        for (Iterator iter = _importedEntities.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+
+        for (Iterator iter = _includedEntities.iterator(); iter.hasNext();) {
+            action.perform((Entity) iter.next());
+        }
+    }
+
+    public Map getMap(Kind k) {
+        Map m = (Map) _kinds.get(k.getName());
+        if (m == null) {
+            m = new HashMap();
+            _kinds.put(k.getName(), m);
+        }
+        return m;
+    }
+
+    public void define(GloballyKnown e) {
+        Map map = getMap(e.getKind());
+        if (e.getName() == null)
+            return;
+        QName name =
+            new QName(e.getDefining().getTargetNamespaceURI(), e.getName());
+
+        if (map.containsKey(name))
+            throw new DuplicateEntityException(e);
+        else
+            map.put(name, e);
+    }
+
+    public void undefine(GloballyKnown e) {
+        Map map = getMap(e.getKind());
+        if (e.getName() == null)
+            return;
+        QName name =
+            new QName(e.getDefining().getTargetNamespaceURI(), e.getName());
+
+        if (map.containsKey(name))
+            throw new NoSuchEntityException(name);
+        else
+            map.remove(name);
+    }
+
+    public GloballyKnown find(Kind k, QName name) {
+        Map map = getMap(k);
+        Object result = map.get(name);
+        if (result == null)
+            throw new NoSuchEntityException(name);
+        return (GloballyKnown) result;
+    }
+
+    public void defineID(Identifiable e) {
+        String id = e.getID();
+        if (id == null)
+            return;
+
+        if (_identifiables.containsKey(id))
+            throw new DuplicateEntityException(e);
+        else
+            _identifiables.put(id, e);
+    }
+
+    public void undefineID(Identifiable e) {
+        String id = e.getID();
+
+        if (id == null)
+            return;
+
+        if (_identifiables.containsKey(id))
+            throw new NoSuchEntityException(id);
+        else
+            _identifiables.remove(id);
+    }
+
+    public Identifiable findByID(String id) {
+        Object result = _identifiables.get(id);
+        if (result == null)
+            throw new NoSuchEntityException(id);
+        return (Identifiable) result;
+    }
+
+    public Set collectAllQNames() {
+        final Set result = new HashSet();
+        EntityAction action = new EntityAction() {
+            public void perform(Entity entity) {
+                entity.withAllQNamesDo(new QNameAction() {
+                    public void perform(QName name) {
+                        result.add(name);
+                    }
+                });
+                entity.withAllSubEntitiesDo(this);
+            }
+        };
+        withAllSubEntitiesDo(action);
+        return result;
+    }
+
+    public Set collectAllNamespaces() {
+        final Set result = new HashSet();
+
+        EntityAction action = new EntityAction() {
+            public void perform(Entity entity) {
+                entity.withAllQNamesDo(new QNameAction() {
+                    public void perform(QName name) {
+                        result.add(name.getNamespaceURI());
+                    }
+                });
+
+                entity.withAllSubEntitiesDo(this);
+            }
+        };
+        withAllSubEntitiesDo(action);
+        return result;
+    }
+
+    public void validateLocally() {
+        LocallyValidatingAction action = new LocallyValidatingAction();
+        withAllSubEntitiesDo(action);
+        if (action.getException() != null) {
+            throw action.getException();
+        }
+    }
+
+    public void validate() {
+        validate(null);
+    }
+
+    public abstract void validate(EntityReferenceValidator validator);
+
+    protected abstract Entity getRoot();
+
+    private Map _kinds;
+    private Map _identifiables;
+    private String _systemId;
+    private Set _importedDocuments;
+    private List _importedEntities;
+    private Set _includedDocuments;
+    private List _includedEntities;
+
+    private class LocallyValidatingAction implements EntityAction {
+        public LocallyValidatingAction() {
+        }
+
+        public void perform(Entity entity) {
+            try {
+                entity.validateThis();
+                entity.withAllSubEntitiesDo(this);
+            } catch (ValidationException e) {
+                if (_exception == null) {
+                    _exception = e;
+                }
+            }
+        }
+
+        public ValidationException getException() {
+            return _exception;
+        }
+
+        private ValidationException _exception;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Defining.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Defining.java
new file mode 100644
index 0000000..b61ad7c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Defining.java
@@ -0,0 +1,35 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * An interface implemented by entities that define target namespaces.
+ *
+ * @author WS Development Team
+ */
+public interface Defining extends Elemental {
+    public String getTargetNamespaceURI();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/DuplicateEntityException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/DuplicateEntityException.java
new file mode 100644
index 0000000..b2da2b7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/DuplicateEntityException.java
@@ -0,0 +1,58 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * An exception signalling that an entity with the given name/id has already been defined.
+ *
+ * @author WS Development Team
+ */
+public class DuplicateEntityException extends ValidationException {
+
+    public DuplicateEntityException(GloballyKnown entity) {
+        super(
+            "entity.duplicateWithType",
+                entity.getElementName().getLocalPart(),
+                entity.getName());
+    }
+
+    public DuplicateEntityException(Identifiable entity) {
+        super(
+            "entity.duplicateWithType",
+                entity.getElementName().getLocalPart(),
+                entity.getID());
+    }
+
+    public DuplicateEntityException(Entity entity, String name) {
+        super(
+            "entity.duplicateWithType",
+                entity.getElementName().getLocalPart(), name);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.wsdl";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Elemental.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Elemental.java
new file mode 100644
index 0000000..1ba0653
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Elemental.java
@@ -0,0 +1,37 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Interface implemented by classes that are mappable to XML elements.
+ *
+ * @author WS Development Team
+ */
+public interface Elemental {
+    public QName getElementName();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Entity.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Entity.java
new file mode 100644
index 0000000..c568122
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Entity.java
@@ -0,0 +1,90 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * An entity, typically corresponding to an XML element.
+ *
+ * @author WS Development Team
+ */
+public abstract class Entity implements Elemental {
+
+    public Entity() {
+    }
+
+    public Object getProperty(String key) {
+        if (_properties == null)
+            return null;
+        return _properties.get(key);
+    }
+
+    public void setProperty(String key, Object value) {
+        if (value == null) {
+            removeProperty(key);
+            return;
+        }
+
+        if (_properties == null) {
+            _properties = new HashMap();
+        }
+        _properties.put(key, value);
+    }
+
+    public void removeProperty(String key) {
+        if (_properties != null) {
+            _properties.remove(key);
+        }
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        // no-op by default
+    }
+
+    public void withAllQNamesDo(QNameAction action) {
+        action.perform(getElementName());
+    }
+
+    public void withAllEntityReferencesDo(EntityReferenceAction action) {
+        // no-op by default
+    }
+
+    public abstract void validateThis();
+
+    protected void failValidation(String key) {
+        throw new ValidationException(key, getElementName().getLocalPart());
+    }
+
+    protected void failValidation(String key, String arg) {
+        throw new ValidationException(
+            key,
+            new Object[] { arg, getElementName().getLocalPart()});
+    }
+
+    private Map _properties;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityAction.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityAction.java
new file mode 100644
index 0000000..0b1f948
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityAction.java
@@ -0,0 +1,35 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * An action operating on an entity.
+ *
+ * @author WS Development Team
+ */
+public interface EntityAction {
+    public void perform(Entity entity);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityReferenceAction.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityReferenceAction.java
new file mode 100644
index 0000000..715eaa1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityReferenceAction.java
@@ -0,0 +1,37 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import javax.xml.namespace.QName;
+
+/**
+ * An action operating on an entity reference composed of a kind and a QName.
+ *
+ * @author WS Development Team
+ */
+public interface EntityReferenceAction {
+    public void perform(Kind kind, QName name);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityReferenceValidator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityReferenceValidator.java
new file mode 100644
index 0000000..a09ce94
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/EntityReferenceValidator.java
@@ -0,0 +1,38 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import javax.xml.namespace.QName;
+
+/**
+ * An interface implemented by a class that is capable of validating
+ * a QName/Kind pair referring to an external entity.
+ *
+ * @author WS Development Team
+ */
+public interface EntityReferenceValidator {
+    public boolean isValid(Kind kind, QName name);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensibilityHelper.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensibilityHelper.java
new file mode 100644
index 0000000..71452cb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensibilityHelper.java
@@ -0,0 +1,87 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.NoSuchElementException;
+
+/**
+ * A helper class for extensible entities.
+ *
+ * @author WS Development Team
+ */
+public class ExtensibilityHelper {
+
+    public ExtensibilityHelper() {
+    }
+
+    public void addExtension(Extension e) {
+        if (_extensions == null) {
+            _extensions = new ArrayList();
+        }
+        _extensions.add(e);
+    }
+
+    public Iterator extensions() {
+        if (_extensions == null) {
+            return new Iterator() {
+                public boolean hasNext() {
+                    return false;
+                }
+
+                public Object next() {
+                    throw new NoSuchElementException();
+                }
+
+                public void remove() {
+                    throw new UnsupportedOperationException();
+                }
+            };
+        } else {
+            return _extensions.iterator();
+        }
+    }
+
+    public void withAllSubEntitiesDo(EntityAction action) {
+        if (_extensions != null) {
+            for (Iterator iter = _extensions.iterator(); iter.hasNext();) {
+                action.perform((Entity) iter.next());
+            }
+        }
+    }
+
+    public void accept(ExtensionVisitor visitor) throws Exception {
+        if (_extensions != null) {
+            for (Iterator iter = _extensions.iterator(); iter.hasNext();) {
+                ((Extension) iter.next()).accept(visitor);
+            }
+        }
+    }
+
+    private List _extensions;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Extensible.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Extensible.java
new file mode 100644
index 0000000..1a0a6be
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Extensible.java
@@ -0,0 +1,38 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import java.util.Iterator;
+
+/**
+ * An entity that can be extended.
+ *
+ * @author WS Development Team
+ */
+public interface Extensible extends Elemental {
+    public void addExtension(Extension e);
+    public Iterator extensions();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Extension.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Extension.java
new file mode 100644
index 0000000..2d3d643
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Extension.java
@@ -0,0 +1,52 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * An entity extending another entity.
+ *
+ * @author WS Development Team
+ */
+public abstract class Extension extends Entity {
+
+    public Extension() {
+    }
+
+    public Extensible getParent() {
+        return _parent;
+    }
+
+    public void setParent(Extensible parent) {
+        _parent = parent;
+    }
+
+    public void accept(ExtensionVisitor visitor) throws Exception {
+        visitor.preVisit(this);
+        visitor.postVisit(this);
+    }
+
+    private Extensible _parent;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensionVisitor.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensionVisitor.java
new file mode 100644
index 0000000..7676a78
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensionVisitor.java
@@ -0,0 +1,36 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * A visitor working on extension entities.
+ *
+ * @author WS Development Team
+ */
+public interface ExtensionVisitor {
+    public void preVisit(Extension extension) throws Exception;
+    public void postVisit(Extension extension) throws Exception;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensionVisitorBase.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensionVisitorBase.java
new file mode 100644
index 0000000..e570b71
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExtensionVisitorBase.java
@@ -0,0 +1,41 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * A base class for extension visitors.
+ *
+ * @author WS Development Team
+ */
+public class ExtensionVisitorBase implements ExtensionVisitor {
+    public ExtensionVisitorBase() {
+    }
+
+    public void preVisit(Extension extension) throws Exception {
+    }
+    public void postVisit(Extension extension) throws Exception {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExternalEntityReference.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExternalEntityReference.java
new file mode 100644
index 0000000..e4370a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ExternalEntityReference.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import javax.xml.namespace.QName;
+
+/**
+ * A reference to a globally known entity in a document.
+ *
+ * @author WS Development Team
+ */
+public class ExternalEntityReference {
+
+    public ExternalEntityReference(
+        AbstractDocument document,
+        Kind kind,
+        QName name) {
+        _document = document;
+        _kind = kind;
+        _name = name;
+    }
+
+    public AbstractDocument getDocument() {
+        return _document;
+    }
+
+    public Kind getKind() {
+        return _kind;
+    }
+
+    public QName getName() {
+        return _name;
+    }
+
+    public GloballyKnown resolve() {
+        return _document.find(_kind, _name);
+    }
+
+    private AbstractDocument _document;
+    private Kind _kind;
+    private QName _name;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/GlobalEntity.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/GlobalEntity.java
new file mode 100644
index 0000000..fda7291
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/GlobalEntity.java
@@ -0,0 +1,55 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * An entity that can be defined in a target namespace.
+ *
+ * @author WS Development Team
+ */
+public abstract class GlobalEntity extends Entity implements GloballyKnown {
+
+    public GlobalEntity(Defining defining) {
+        _defining = defining;
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    public void setName(String name) {
+        _name = name;
+    }
+
+    public abstract Kind getKind();
+
+    public Defining getDefining() {
+        return _defining;
+    }
+
+    private Defining _defining;
+    private String _name;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/GloballyKnown.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/GloballyKnown.java
new file mode 100644
index 0000000..b59dc23
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/GloballyKnown.java
@@ -0,0 +1,37 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * An interface implemented by entities which can be defined in a target namespace.
+ *
+ * @author WS Development Team
+ */
+public interface GloballyKnown extends Elemental {
+    public String getName();
+    public Kind getKind();
+    public Defining getDefining();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Identifiable.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Identifiable.java
new file mode 100644
index 0000000..0f70935
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Identifiable.java
@@ -0,0 +1,35 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * An interface implemented by entities which have an ID.
+ *
+ * @author WS Development Team
+ */
+public interface Identifiable extends Elemental {
+    public String getID();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Kind.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Kind.java
new file mode 100644
index 0000000..f20d0df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/Kind.java
@@ -0,0 +1,44 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ * A kind of entity.
+ *
+ * @author WS Development Team
+ */
+public final class Kind {
+
+    public Kind(String s) {
+        _name = s;
+    }
+
+    public String getName() {
+        return _name;
+    }
+
+    private String _name;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/NoSuchEntityException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/NoSuchEntityException.java
new file mode 100644
index 0000000..87ac0a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/NoSuchEntityException.java
@@ -0,0 +1,50 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import javax.xml.namespace.QName;
+
+/**
+ * An exception signalling that an entity with the given name/id does not exist.
+ *
+ * @author WS Development Team
+ */
+public class NoSuchEntityException extends ValidationException {
+
+    public NoSuchEntityException(QName name) {
+        super(
+            "entity.notFoundByQName",
+                name.getLocalPart(), name.getNamespaceURI());
+    }
+
+    public NoSuchEntityException(String id) {
+        super("entity.notFoundByID", id);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.wsdl";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParseException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParseException.java
new file mode 100644
index 0000000..5841e2c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParseException.java
@@ -0,0 +1,49 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * An exception signalling a parsing error.
+ *
+ * @author WS Development Team
+ */
+public class ParseException extends JAXWSExceptionBase {
+
+    public ParseException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ParseException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.wsdl";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParserContext.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParserContext.java
new file mode 100644
index 0000000..2781c08
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParserContext.java
@@ -0,0 +1,185 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Element;
+
+import com.sun.xml.internal.ws.util.NamespaceSupport;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+/**
+ * The context used by parser classes.
+ *
+ * @author WS Development Team
+ */
+public class ParserContext {
+
+    private final static String PREFIX_XMLNS = "xmlns";
+
+    public ParserContext(AbstractDocument doc, ArrayList listeners) {
+        _document = doc;
+        _listeners = listeners;
+        _nsSupport = new NamespaceSupport();
+        _wsdlLocation = new WSDLLocation();
+    }
+
+    public AbstractDocument getDocument() {
+        return _document;
+    }
+
+    public boolean getFollowImports() {
+        return _followImports;
+    }
+
+    public void setFollowImports(boolean b) {
+        _followImports = b;
+    }
+
+    public void push() {
+        _nsSupport.pushContext();
+    }
+
+    public void pop() {
+        _nsSupport.popContext();
+    }
+
+    public String getNamespaceURI(String prefix) {
+        return _nsSupport.getURI(prefix);
+    }
+
+    public Iterator getPrefixes() {
+        return _nsSupport.getPrefixes();
+    }
+
+    public String getDefaultNamespaceURI() {
+        return getNamespaceURI("");
+    }
+
+    public void registerNamespaces(Element e) {
+        for (Iterator iter = XmlUtil.getAllAttributes(e); iter.hasNext();) {
+            Attr a = (Attr) iter.next();
+            if (a.getName().equals(PREFIX_XMLNS)) {
+                // default namespace declaration
+                _nsSupport.declarePrefix("", a.getValue());
+            } else {
+                String prefix = XmlUtil.getPrefix(a.getName());
+                if (prefix != null && prefix.equals(PREFIX_XMLNS)) {
+                    String nsPrefix = XmlUtil.getLocalPart(a.getName());
+                    String uri = a.getValue();
+                    _nsSupport.declarePrefix(nsPrefix, uri);
+                }
+            }
+        }
+    }
+
+    public QName translateQualifiedName(String s) {
+        if (s == null)
+            return null;
+
+        String prefix = XmlUtil.getPrefix(s);
+        String uri = null;
+
+        if (prefix == null) {
+            uri = getDefaultNamespaceURI();
+        } else {
+            uri = getNamespaceURI(prefix);
+            if (uri == null) {
+                throw new ParseException(
+                    "parsing.unknownNamespacePrefix",
+                    prefix);
+            }
+        }
+
+        return new QName(uri, XmlUtil.getLocalPart(s));
+    }
+
+    public void fireIgnoringExtension(QName name, QName parent) {
+        List _targets = null;
+
+        synchronized (this) {
+            if (_listeners != null) {
+                _targets = (List) _listeners.clone();
+            }
+        }
+
+        if (_targets != null) {
+            for (Iterator iter = _targets.iterator(); iter.hasNext();) {
+                ParserListener l = (ParserListener) iter.next();
+                l.ignoringExtension(name, parent);
+            }
+        }
+    }
+
+    public void fireDoneParsingEntity(QName element, Entity entity) {
+        List _targets = null;
+
+        synchronized (this) {
+            if (_listeners != null) {
+                _targets = (List) _listeners.clone();
+            }
+        }
+
+        if (_targets != null) {
+            for (Iterator iter = _targets.iterator(); iter.hasNext();) {
+                ParserListener l = (ParserListener) iter.next();
+                l.doneParsingEntity(element, entity);
+            }
+        }
+    }
+
+    //bug fix: 4856674, WSDLLocation context maintainence
+    //and utility funcitons
+    public void pushWSDLLocation() {
+        _wsdlLocation.push();
+    }
+
+    public void popWSDLLocation() {
+        _wsdlLocation.pop();
+    }
+
+    public void setWSDLLocation(String loc) {
+        _wsdlLocation.setLocation(loc);
+    }
+
+    public String getWSDLLocation() {
+        return _wsdlLocation.getLocation();
+    }
+
+    private boolean _followImports;
+    private AbstractDocument _document;
+    private NamespaceSupport _nsSupport;
+    private ArrayList _listeners;
+    //bug fix:4856674
+    private WSDLLocation _wsdlLocation;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParserListener.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParserListener.java
new file mode 100644
index 0000000..b857bf0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ParserListener.java
@@ -0,0 +1,38 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import javax.xml.namespace.QName;
+
+/**
+ * A listener for parsing-related events.
+ *
+ * @author WS Development Team
+ */
+public interface ParserListener {
+    public void ignoringExtension(QName name, QName parent);
+    public void doneParsingEntity(QName element, Entity entity);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/QNameAction.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/QNameAction.java
new file mode 100644
index 0000000..1588cde
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/QNameAction.java
@@ -0,0 +1,37 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import javax.xml.namespace.QName;
+
+/**
+ * An action operating on a QName.
+ *
+ * @author WS Development Team
+ */
+public interface QNameAction {
+    public void perform(QName name);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ValidationException.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ValidationException.java
new file mode 100644
index 0000000..8b2d51f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/ValidationException.java
@@ -0,0 +1,49 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * An exception signalling that validation of an entity failed.
+ *
+ * @author WS Development Team
+ */
+public class ValidationException extends JAXWSExceptionBase {
+
+    public ValidationException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ValidationException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.tools.internal.ws.resources.wsdl";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/WSDLLocation.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/WSDLLocation.java
new file mode 100644
index 0000000..3e4c03e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/WSDLLocation.java
@@ -0,0 +1,101 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.framework;
+
+/**
+ *
+ * Maintains wsdl:location context. This is used with
+ * ParserContext, where one each WSDL being imported its location is pushed, this will be used
+ * latter to resolve relative imports of schema in SchemaParser.
+ *
+ * @author WS Development Team
+ */
+public class WSDLLocation {
+    WSDLLocation() {
+        reset();
+    }
+
+    public void push() {
+        int max = contexts.length;
+        idPos++;
+        if (idPos >= max) {
+            LocationContext newContexts[] = new LocationContext[max * 2];
+            System.arraycopy(contexts, 0, newContexts, 0, max);
+            max *= 2;
+            contexts = newContexts;
+        }
+        currentContext = contexts[idPos];
+        if (currentContext == null) {
+            contexts[idPos] = currentContext = new LocationContext();
+        }
+        if (idPos > 0) {
+            currentContext.setParent(contexts[idPos - 1]);
+        }
+
+    }
+
+    public void pop() {
+        idPos--;
+        if (idPos >= 0) {
+            currentContext = contexts[idPos];
+        }
+    }
+
+    public void reset() {
+        contexts = new LocationContext[32];
+        idPos = 0;
+        contexts[idPos] = currentContext = new LocationContext();
+    }
+
+    public String getLocation() {
+        return currentContext.getLocation();
+    }
+
+    public void setLocation(String loc) {
+        currentContext.setLocation(loc);
+    }
+
+    private LocationContext[] contexts;
+    private int idPos;
+    private LocationContext currentContext;
+
+    // LocationContext - inner class
+    private static class LocationContext {
+        void setLocation(String loc) {
+            location = loc;
+        }
+
+        String getLocation() {
+            return location;
+        }
+
+        void setParent(LocationContext parent) {
+            parentLocation = parent;
+        }
+
+        private String location;
+        private LocationContext parentLocation;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/WriterContext.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/WriterContext.java
new file mode 100644
index 0000000..cb5217d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/framework/WriterContext.java
@@ -0,0 +1,212 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.framework;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.ws.util.NamespaceSupport;
+import com.sun.tools.internal.ws.util.xml.PrettyPrintingXmlWriter;
+
+/**
+ * The context used by writer classes.
+ *
+ * @author WS Development Team
+ */
+public class WriterContext {
+
+    public WriterContext(OutputStream os) throws IOException {
+        _writer = new PrettyPrintingXmlWriter(os);
+        _nsSupport = new NamespaceSupport();
+        _newPrefixCount = 2;
+    }
+
+    public void flush() throws IOException {
+        _writer.flush();
+    }
+
+    public void close() throws IOException {
+        _writer.close();
+    }
+
+    public void push() {
+        if (_pendingNamespaceDeclarations != null) {
+            throw new IllegalStateException("prefix declarations are pending");
+        }
+        _nsSupport.pushContext();
+    }
+
+    public void pop() {
+        _nsSupport.popContext();
+        _pendingNamespaceDeclarations = null;
+    }
+
+    public String getNamespaceURI(String prefix) {
+        return _nsSupport.getURI(prefix);
+    }
+
+    public Iterator getPrefixes() {
+        return _nsSupport.getPrefixes();
+    }
+
+    public String getDefaultNamespaceURI() {
+        return getNamespaceURI("");
+    }
+
+    public void declarePrefix(String prefix, String uri) {
+        _nsSupport.declarePrefix(prefix, uri);
+        if (_pendingNamespaceDeclarations == null) {
+            _pendingNamespaceDeclarations = new ArrayList();
+        }
+        _pendingNamespaceDeclarations.add(new String[] { prefix, uri });
+    }
+
+    public String getPrefixFor(String uri) {
+        if ((getDefaultNamespaceURI() != null && getDefaultNamespaceURI().equals(uri))
+            || uri.equals("")) {
+            return "";
+        } else {
+            return _nsSupport.getPrefix(uri);
+        }
+    }
+
+    public String findNewPrefix(String base) {
+        return base + Integer.toString(_newPrefixCount++);
+    }
+
+    public String getTargetNamespaceURI() {
+        return _targetNamespaceURI;
+    }
+
+    public void setTargetNamespaceURI(String uri) {
+        _targetNamespaceURI = uri;
+    }
+
+    public void writeStartTag(QName name) throws IOException {
+        _writer.start(getQNameString(name));
+    }
+
+    public void writeEndTag(QName name) throws IOException {
+        _writer.end(getQNameString(name));
+    }
+
+    public void writeAttribute(String name, String value) throws IOException {
+        if (value != null) {
+            _writer.attribute(name, value);
+        }
+    }
+
+    public void writeAttribute(String name, QName value) throws IOException {
+        if (value != null) {
+            _writer.attribute(name, getQNameString(value));
+        }
+    }
+
+    public void writeAttribute(String name, boolean value) throws IOException {
+        writeAttribute(name, value ? "true" : "false");
+    }
+
+    public void writeAttribute(String name, Boolean value) throws IOException {
+        if (value != null) {
+            writeAttribute(name, value.booleanValue());
+        }
+    }
+
+    public void writeAttribute(String name, int value) throws IOException {
+        writeAttribute(name, Integer.toString(value));
+    }
+
+    public void writeAttribute(String name, Object value, Map valueToXmlMap)
+        throws IOException {
+        String actualValue = (String) valueToXmlMap.get(value);
+        writeAttribute(name, actualValue);
+    }
+
+    public void writeNamespaceDeclaration(String prefix, String uri)
+        throws IOException {
+        _writer.attribute(getNamespaceDeclarationAttributeName(prefix), uri);
+    }
+
+    public void writeAllPendingNamespaceDeclarations() throws IOException {
+        if (_pendingNamespaceDeclarations != null) {
+            for (Iterator iter = _pendingNamespaceDeclarations.iterator();
+                iter.hasNext();
+                ) {
+                String[] pair = (String[]) iter.next();
+                writeNamespaceDeclaration(pair[0], pair[1]);
+            }
+        }
+        _pendingNamespaceDeclarations = null;
+    }
+
+    private String getNamespaceDeclarationAttributeName(String prefix) {
+        if (prefix.equals("")) {
+            return "xmlns";
+        } else {
+            return "xmlns:" + prefix;
+        }
+    }
+
+    public void writeTag(QName name, String value) throws IOException {
+        _writer.leaf(getQNameString(name), value);
+    }
+
+    public String getQNameString(QName name) {
+        String nsURI = name.getNamespaceURI();
+        String prefix = getPrefixFor(nsURI);
+        if (prefix == null) {
+            throw new IllegalArgumentException();
+        } else if (prefix.equals("")) {
+            return name.getLocalPart();
+        } else {
+            return prefix + ":" + name.getLocalPart();
+        }
+    }
+
+    public String getQNameStringWithTargetNamespaceCheck(QName name) {
+        if (name.getNamespaceURI().equals(_targetNamespaceURI)) {
+            return name.getLocalPart();
+        } else {
+            return getQNameString(name);
+        }
+    }
+
+    public void writeChars(String chars) throws IOException {
+        _writer.chars(chars);
+    }
+
+    private PrettyPrintingXmlWriter _writer;
+    private NamespaceSupport _nsSupport;
+    private String _targetNamespaceURI;
+    private int _newPrefixCount;
+    private List _pendingNamespaceDeclarations;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Constants.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Constants.java
new file mode 100644
index 0000000..a59d0ab
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Constants.java
@@ -0,0 +1,145 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+/**
+ * An interface defining constants needed to read and write WSDL documents.
+ *
+ * @author WS Development Team
+ */
+public interface Constants {
+    // WSDL element tags
+    public static String TAG_BINDING = "binding";
+    public static String TAG_DEFINITIONS = "definitions";
+    public static String TAG_DOCUMENTATION = "documentation";
+    public static String TAG_MESSAGE = "message";
+    public static String TAG_PART = "part";
+    public static String TAG_PORT_TYPE = "portType";
+    public static String TAG_TYPES = "types";
+    public static String TAG_OPERATION = "operation";
+    public static String TAG_INPUT = "input";
+    public static String TAG_OUTPUT = "output";
+    public static String TAG_FAULT = "fault";
+    public static String TAG_SERVICE = "service";
+    public static String TAG_PORT = "port";
+    public static String TAG_ = "";
+
+    // WSDL attribute names
+    public static String ATTR_ELEMENT = "element";
+    public static String ATTR_NAME = "name";
+    public static String ATTR_REQUIRED = "required";
+    public static String ATTR_TARGET_NAMESPACE = "targetNamespace";
+    public static String ATTR_TYPE = "type";
+    public static String ATTR_MESSAGE = "message";
+    public static String ATTR_BINDING = "binding";
+    public static String ATTR_LOCATION = "location";
+    public static String ATTR_TRANSPORT = "transport";
+    public static String ATTR_STYLE = "style";
+    public static String ATTR_USE = "use";
+    public static String ATTR_NAMESPACE = "namespace";
+    public static String ATTR_ENCODING_STYLE = "encodingStyle";
+    public static String ATTR_PART = "part";
+    public static String ATTR_PARTS = "parts";
+    public static String ATTR_SOAP_ACTION = "soapAction";
+    public static String ATTR_PARAMETER_ORDER = "parameterOrder";
+    public static String ATTR_VERB = "verb";
+
+    // schema attribute names
+    public static String ATTR_ID = "id";
+    public static String ATTR_VERSION = "version";
+    public static String ATTR_ATTRIBUTE_FORM_DEFAULT = "attributeFormDefault";
+    public static String ATTR_BLOCK_DEFAULT = "blockDefault";
+    public static String ATTR_ELEMENT_FORM_DEFAULT = "elementFormDefault";
+    public static String ATTR_FINAL_DEFAULT = "finalDefault";
+    public static String ATTR_ABSTRACT = "abstract";
+    public static String ATTR_NILLABLE = "nillable";
+    public static String ATTR_DEFAULT = "default";
+    public static String ATTR_FIXED = "fixed";
+    public static String ATTR_FORM = "form";
+    public static String ATTR_BLOCK = "block";
+    public static String ATTR_FINAL = "final";
+    public static String ATTR_REF = "ref";
+    public static String ATTR_SUBSTITUTION_GROUP = "substitutionGroup";
+    public static String ATTR_MIN_OCCURS = "minOccurs";
+    public static String ATTR_MAX_OCCURS = "maxOccurs";
+    public static String ATTR_PROCESS_CONTENTS = "processContents";
+    public static String ATTR_MIXED = "mixed";
+    public static String ATTR_BASE = "base";
+    public static String ATTR_VALUE = "value";
+    public static String ATTR_XPATH = "xpath";
+    public static String ATTR_SCHEMA_LOCATION = "schemaLocation";
+    public static String ATTR_REFER = "refer";
+    public static String ATTR_ITEM_TYPE = "itemType";
+    public static String ATTR_PUBLIC = "public";
+    public static String ATTR_SYSTEM = "system";
+    public static String ATTR_MEMBER_TYPES = "memberTypes";
+    public static String ATTR_ = "";
+
+    // WSDL attribute values
+    public static String ATTRVALUE_RPC = "rpc";
+    public static String ATTRVALUE_DOCUMENT = "document";
+    public static String ATTRVALUE_LITERAL = "literal";
+    public static String ATTRVALUE_ENCODED = "encoded";
+
+    // schema attribute values
+    public static String ATTRVALUE_QUALIFIED = "qualified";
+    public static String ATTRVALUE_UNQUALIFIED = "unqualified";
+    public static String ATTRVALUE_ALL = "#all";
+    public static String ATTRVALUE_SUBSTITUTION = "substitution";
+    public static String ATTRVALUE_EXTENSION = "extension";
+    public static String ATTRVALUE_RESTRICTION = "restriction";
+    public static String ATTRVALUE_LIST = "list";
+    public static String ATTRVALUE_UNION = "union";
+    public static String ATTRVALUE_UNBOUNDED = "unbounded";
+    public static String ATTRVALUE_PROHIBITED = "prohibited";
+    public static String ATTRVALUE_OPTIONAL = "optional";
+    public static String ATTRVALUE_REQUIRED = "required";
+    public static String ATTRVALUE_LAX = "lax";
+    public static String ATTRVALUE_SKIP = "skip";
+    public static String ATTRVALUE_STRICT = "strict";
+    public static String ATTRVALUE_ANY = "##any";
+    public static String ATTRVALUE_LOCAL = "##local";
+    public static String ATTRVALUE_OTHER = "##other";
+    public static String ATTRVALUE_TARGET_NAMESPACE = "##targetNamespace";
+    public static String ATTRVALUE_ = "";
+
+    // namespace URIs
+    public static String NS_XML = "http://www.w3.org/XML/1998/namespace";
+    public static String NS_XMLNS = "http://www.w3.org/2000/xmlns/";
+    public static String NS_WSDL = "http://schemas.xmlsoap.org/wsdl/";
+    public static String NS_WSDL_SOAP = "http://schemas.xmlsoap.org/wsdl/soap/";
+    public static String NS_WSDL_SOAP12 = "http://schemas.xmlsoap.org/wsdl/soap12/";
+    public static String NS_WSDL_HTTP = "http://schemas.xmlsoap.org/wsdl/http/";
+    public static String NS_WSDL_MIME = "http://schemas.xmlsoap.org/wsdl/mime/";
+    public static String NS_XSD = "http://www.w3.org/2001/XMLSchema";
+    public static String NS_XSI = "http://www.w3.org/2001/XMLSchema-instance";
+    public static String NS_ = "";
+
+    // other constants
+    public static String XMLNS = "xmlns";
+    public static String TRUE = "true";
+    public static String FALSE = "false";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/ExtensionHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/ExtensionHandler.java
new file mode 100644
index 0000000..971940e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/ExtensionHandler.java
@@ -0,0 +1,66 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.IOException;
+import java.util.Map;
+
+import org.w3c.dom.Element;
+
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+
+/**
+ * A handler for extensions elements definined in one namespace.
+ *
+ * @author WS Development Team
+ */
+public abstract class ExtensionHandler {
+
+    protected ExtensionHandler() {
+    }
+
+    public abstract String getNamespaceURI();
+
+    public void setExtensionHandlers(Map m) {
+        _extensionHandlers = m;
+    }
+
+    public boolean doHandleExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        return false;
+    }
+
+    public void doHandleExtension(WriterContext context, Extension extension)
+        throws IOException {
+    }
+
+    protected Map _extensionHandlers;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/ExtensionHandlerBase.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/ExtensionHandlerBase.java
new file mode 100644
index 0000000..0e2ffa5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/ExtensionHandlerBase.java
@@ -0,0 +1,130 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import org.w3c.dom.Element;
+
+import com.sun.tools.internal.ws.wsdl.document.WSDLConstants;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEConstants;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+/**
+ * A base class for WSDL extension handlers.
+ *
+ * @author WS Development Team
+ */
+public abstract class ExtensionHandlerBase extends ExtensionHandler {
+
+    protected ExtensionHandlerBase() {
+    }
+
+    public boolean doHandleExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (parent.getElementName().equals(WSDLConstants.QNAME_DEFINITIONS)) {
+            return handleDefinitionsExtension(context, parent, e);
+        } else if (parent.getElementName().equals(WSDLConstants.QNAME_TYPES)) {
+            return handleTypesExtension(context, parent, e);
+        } else if (parent.getElementName().equals(WSDLConstants.QNAME_PORT_TYPE)) {
+            return handlePortTypeExtension(context, parent, e);
+        } else if (
+            parent.getElementName().equals(WSDLConstants.QNAME_BINDING)) {
+            return handleBindingExtension(context, parent, e);
+        } else if (
+            parent.getElementName().equals(WSDLConstants.QNAME_OPERATION)) {
+            return handleOperationExtension(context, parent, e);
+        } else if (parent.getElementName().equals(WSDLConstants.QNAME_INPUT)) {
+            return handleInputExtension(context, parent, e);
+        } else if (
+            parent.getElementName().equals(WSDLConstants.QNAME_OUTPUT)) {
+            return handleOutputExtension(context, parent, e);
+        } else if (parent.getElementName().equals(WSDLConstants.QNAME_FAULT)) {
+            return handleFaultExtension(context, parent, e);
+        } else if (
+            parent.getElementName().equals(WSDLConstants.QNAME_SERVICE)) {
+            return handleServiceExtension(context, parent, e);
+        } else if (parent.getElementName().equals(WSDLConstants.QNAME_PORT)) {
+            return handlePortExtension(context, parent, e);
+        } else if (parent.getElementName().equals(MIMEConstants.QNAME_PART)) {
+            return handleMIMEPartExtension(context, parent, e);
+        } else {
+            return false;
+        }
+    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     * @return true if the PortTypeExtension should be handled
+     */
+    protected abstract boolean handlePortTypeExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+
+    protected abstract boolean handleDefinitionsExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handleTypesExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handleBindingExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handleOperationExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handleInputExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handleOutputExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handleFaultExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handleServiceExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handlePortExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+    protected abstract boolean handleMIMEPartExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/HTTPExtensionHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/HTTPExtensionHandler.java
new file mode 100644
index 0000000..bce6c4c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/HTTPExtensionHandler.java
@@ -0,0 +1,268 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.IOException;
+
+import org.w3c.dom.Element;
+
+import com.sun.tools.internal.ws.wsdl.document.http.HTTPAddress;
+import com.sun.tools.internal.ws.wsdl.document.http.HTTPBinding;
+import com.sun.tools.internal.ws.wsdl.document.http.HTTPConstants;
+import com.sun.tools.internal.ws.wsdl.document.http.HTTPOperation;
+import com.sun.tools.internal.ws.wsdl.document.http.HTTPUrlEncoded;
+import com.sun.tools.internal.ws.wsdl.document.http.HTTPUrlReplacement;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+import com.sun.tools.internal.ws.util.xml.XmlUtil;
+
+/**
+ * The HTTP extension handler for WSDL.
+ *
+ * @author WS Development Team
+ */
+public class HTTPExtensionHandler extends ExtensionHandlerBase {
+
+    public HTTPExtensionHandler() {
+    }
+
+    public String getNamespaceURI() {
+        return Constants.NS_WSDL_HTTP;
+    }
+
+    protected boolean handleDefinitionsExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected boolean handleTypesExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected boolean handleBindingExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, HTTPConstants.QNAME_BINDING)) {
+            context.push();
+            context.registerNamespaces(e);
+
+            HTTPBinding binding = new HTTPBinding();
+
+            String verb = Util.getRequiredAttribute(e, Constants.ATTR_VERB);
+            binding.setVerb(verb);
+
+            parent.addExtension(binding);
+            context.pop();
+            context.fireDoneParsingEntity(HTTPConstants.QNAME_BINDING, binding);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleOperationExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, HTTPConstants.QNAME_OPERATION)) {
+            context.push();
+            context.registerNamespaces(e);
+
+            HTTPOperation operation = new HTTPOperation();
+
+            String location =
+                Util.getRequiredAttribute(e, Constants.ATTR_LOCATION);
+            operation.setLocation(location);
+
+            parent.addExtension(operation);
+            context.pop();
+            context.fireDoneParsingEntity(
+                HTTPConstants.QNAME_OPERATION,
+                operation);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleInputExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, HTTPConstants.QNAME_URL_ENCODED)) {
+            parent.addExtension(new HTTPUrlEncoded());
+            return true;
+        } else if (
+            XmlUtil.matchesTagNS(e, HTTPConstants.QNAME_URL_REPLACEMENT)) {
+            parent.addExtension(new HTTPUrlReplacement());
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleOutputExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected boolean handleFaultExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected boolean handleServiceExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected boolean handlePortExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, HTTPConstants.QNAME_ADDRESS)) {
+            context.push();
+            context.registerNamespaces(e);
+
+            HTTPAddress address = new HTTPAddress();
+
+            String location =
+                Util.getRequiredAttribute(e, Constants.ATTR_LOCATION);
+            address.setLocation(location);
+
+            parent.addExtension(address);
+            context.pop();
+            context.fireDoneParsingEntity(HTTPConstants.QNAME_ADDRESS, address);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleMIMEPartExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    public void doHandleExtension(WriterContext context, Extension extension)
+        throws IOException {
+        if (extension instanceof HTTPAddress) {
+            HTTPAddress address = (HTTPAddress) extension;
+            context.writeStartTag(address.getElementName());
+            context.writeAttribute(
+                Constants.ATTR_LOCATION,
+                address.getLocation());
+            context.writeEndTag(address.getElementName());
+        } else if (extension instanceof HTTPBinding) {
+            HTTPBinding binding = (HTTPBinding) extension;
+            context.writeStartTag(binding.getElementName());
+            context.writeAttribute(Constants.ATTR_VERB, binding.getVerb());
+            context.writeEndTag(binding.getElementName());
+        } else if (extension instanceof HTTPOperation) {
+            HTTPOperation operation = (HTTPOperation) extension;
+            context.writeStartTag(operation.getElementName());
+            context.writeAttribute(
+                Constants.ATTR_LOCATION,
+                operation.getLocation());
+            context.writeEndTag(operation.getElementName());
+        } else if (extension instanceof HTTPUrlEncoded) {
+            context.writeStartTag(extension.getElementName());
+            context.writeEndTag(extension.getElementName());
+        } else if (extension instanceof HTTPUrlReplacement) {
+            context.writeStartTag(extension.getElementName());
+            context.writeEndTag(extension.getElementName());
+        } else {
+            throw new IllegalArgumentException();
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handlePortTypeExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handlePortTypeExtension(ParserContext context, Extensible parent, Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Internalizer.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Internalizer.java
new file mode 100644
index 0000000..bf85b29
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Internalizer.java
@@ -0,0 +1,538 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.net.URLDecoder;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Set;
+import java.io.UnsupportedEncodingException;
+
+import javax.xml.namespace.QName;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.xpath.XPath;
+import javax.xml.xpath.XPathConstants;
+import javax.xml.xpath.XPathExpressionException;
+import javax.xml.xpath.XPathFactory;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+
+import com.sun.tools.internal.xjc.util.DOMUtils;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.JAXWSBindingsConstants;
+import com.sun.tools.internal.ws.util.xml.XmlUtil;
+
+
+/**
+ * Internalizes external binding declarations.
+ * @author Vivek Pandey
+ */
+public class Internalizer {
+    private Map<String, Document> wsdlDocuments;
+    private Map<String, Document> jaxwsBindings;
+    private static final XPathFactory xpf = XPathFactory.newInstance();
+    private final XPath xpath = xpf.newXPath();
+    private final  LocalizableMessageFactory messageFactory = new LocalizableMessageFactory("com.sun.tools.internal.ws.resources.wsdl");;
+    private ProcessorEnvironment env;
+    public  void transform(Map<String, Document> jaxwsBindings, Map<String, Document> wsdlDocuments, ProcessorEnvironment env) {
+        if(jaxwsBindings == null)
+            return;
+        this.env = env;
+        this.wsdlDocuments = wsdlDocuments;
+        this.jaxwsBindings = jaxwsBindings;
+        Map targetNodes = new HashMap<Element, Node>();
+
+        // identify target nodes for all <JAXWS:bindings>
+        for(Map.Entry<String, Document> jaxwsBinding : jaxwsBindings.entrySet()) {
+            Element e = jaxwsBinding.getValue().getDocumentElement();
+            // initially, the inherited context is itself
+            buildTargetNodeMap( e, e, targetNodes );
+        }
+
+        // then move them to their respective positions.
+        for(Map.Entry<String, Document> jaxwsBinding : jaxwsBindings.entrySet()) {
+            Element e = jaxwsBinding.getValue().getDocumentElement();
+            move( e, targetNodes );
+        }
+
+    }
+
+    /**
+     * Validates attributes of a &lt;JAXWS:bindings> element.
+     */
+    private void validate( Element bindings ) {
+        NamedNodeMap atts = bindings.getAttributes();
+        for( int i=0; i<atts.getLength(); i++ ) {
+            Attr a = (Attr)atts.item(i);
+            if( a.getNamespaceURI()!=null )
+                continue;   // all foreign namespace OK.
+            if( a.getLocalName().equals("node") )
+                continue;
+            if( a.getLocalName().equals("wsdlLocation"))
+                continue;
+
+            // TODO: flag error for this undefined attribute
+        }
+    }
+
+    /**
+     * Gets the DOM tree associated with the specified system ID,
+     * or null if none is found.
+     */
+    public Document get( String systemId ) {
+        Document doc = wsdlDocuments.get(systemId);
+
+        if( doc==null && systemId.startsWith("file:/") && !systemId.startsWith("file://") ) {
+            // As of JDK1.4, java.net.URL.toExternal method returns URLs like
+            // "file:/abc/def/ghi" which is an incorrect file protocol URL according to RFC1738.
+            // Some other correctly functioning parts return the correct URLs ("file:///abc/def/ghi"),
+            // and this descripancy breaks DOM look up by system ID.
+
+            // this extra check solves this problem.
+            doc = wsdlDocuments.get( "file://"+systemId.substring(5) );
+        }
+
+        if( doc==null && systemId.startsWith("file:") ) {
+            // on Windows, filenames are case insensitive.
+            // perform case-insensitive search for improved user experience
+            String systemPath = getPath(systemId);
+            for (String key : wsdlDocuments.keySet()) {
+                if(key.startsWith("file:") && getPath(key).equalsIgnoreCase(systemPath)) {
+                    doc = wsdlDocuments.get(key);
+                    break;
+                }
+            }
+        }
+        return doc;
+    }
+
+    /**
+     * Strips off the leading 'file:///' portion from an URL.
+     */
+    private String getPath(String key) {
+        key = key.substring(5); // skip 'file:'
+        while(key.length()>0 && key.charAt(0)=='/')
+            key = key.substring(1);
+        return key;
+    }
+
+    /**
+     * Determines the target node of the "bindings" element
+     * by using the inherited target node, then put
+     * the result into the "result" map.
+     */
+    private void buildTargetNodeMap( Element bindings, Node inheritedTarget, Map<Element, Node> result ) {
+        // start by the inherited target
+        Node target = inheritedTarget;
+
+        validate(bindings); // validate this node
+
+        // look for @wsdlLocation
+        if( bindings.getAttributeNode("wsdlLocation")!=null ) {
+            String wsdlLocation = bindings.getAttribute("wsdlLocation");
+
+            try {
+                // absolutize this URI.
+                // TODO: use the URI class
+                // TODO: honor xml:base
+                wsdlLocation = new URL(new URL(getSystemId(bindings.getOwnerDocument())),
+                        wsdlLocation ).toExternalForm();
+            } catch( MalformedURLException e ) {
+                wsdlLocation = JAXWSUtils.absolutize(JAXWSUtils.getFileOrURLName(wsdlLocation));
+            }
+
+            target = get(wsdlLocation);
+            if(target==null) {
+                error("internalizer.targetNotFound", new Object[]{wsdlLocation});
+                return; // abort processing this <JAXWS:bindings>
+            }
+        }
+
+        boolean hasNode = true;
+        if(isJAXWSBindings(bindings) && bindings.getAttributeNode("node")!=null ) {
+            target = evaluateXPathNode(target, bindings.getAttribute("node"), new NamespaceContextImpl(bindings));
+        }else if(isJAXWSBindings(bindings) && (bindings.getAttributeNode("node")==null) && !isTopLevelBinding(bindings)) {
+            hasNode = false;
+        }else if(isGlobalBinding(bindings) && !isWSDLDefinition(target) && isTopLevelBinding(bindings.getParentNode())){
+            target = getWSDLDefintionNode(target);
+        }
+
+        //if target is null it means the xpath evaluation has some problem,
+        // just return
+        if(target == null)
+            return;
+
+        // update the result map
+        if(hasNode)
+            result.put( bindings, target );
+
+        // look for child <JAXWS:bindings> and process them recursively
+        Element[] children = getChildElements( bindings, JAXWSBindingsConstants.NS_JAXWS_BINDINGS);
+        for( int i=0; i<children.length; i++ )
+            buildTargetNodeMap( children[i], target, result );
+    }
+
+    private Node getWSDLDefintionNode(Node target){
+        return evaluateXPathNode(target, "wsdl:definitions",
+            new javax.xml.namespace.NamespaceContext(){
+                public String getNamespaceURI(String prefix){
+                    return "http://schemas.xmlsoap.org/wsdl/";
+                }
+                public String getPrefix(String nsURI){
+                    throw new UnsupportedOperationException();
+                }
+                public Iterator getPrefixes(String namespaceURI) {
+                    throw new UnsupportedOperationException();
+                }});
+    }
+
+    private boolean isWSDLDefinition(Node target){
+        if(target == null)
+            return false;
+        String localName = target.getLocalName();
+        String nsURI = target.getNamespaceURI();
+        if(((localName != null) && localName.equals("definitions")) &&
+            (nsURI != null && nsURI.equals("http://schemas.xmlsoap.org/wsdl/")))
+            return true;
+        return false;
+
+    }
+
+    private boolean isTopLevelBinding(Node node){
+        if(node instanceof Document)
+            node = ((Document)node).getDocumentElement();
+        return ((node != null) && (((Element)node).getAttributeNode("wsdlLocation") != null));
+    }
+
+    private boolean isJAXWSBindings(Node bindings){
+        return (bindings.getNamespaceURI().equals(JAXWSBindingsConstants.NS_JAXWS_BINDINGS) && bindings.getLocalName().equals("bindings"));
+    }
+
+    private boolean isGlobalBinding(Node bindings){
+        if((bindings.getNamespaceURI() == null)){
+            warn("invalid.customization.namespace", new Object[]{bindings.getLocalName()});
+            return false;
+        }
+        return  (bindings.getNamespaceURI().equals(JAXWSBindingsConstants.NS_JAXWS_BINDINGS) &&
+                (bindings.getLocalName().equals("package") ||
+                bindings.getLocalName().equals("enableAsyncMapping") ||
+                bindings.getLocalName().equals("enableAdditionalSOAPHeaderMapping") ||
+                bindings.getLocalName().equals("enableWrapperStyle") ||
+                bindings.getLocalName().equals("enableMIMEContent")));
+    }
+
+    private static Element[] getChildElements(Element parent, String nsUri) {
+        ArrayList a = new ArrayList();
+        NodeList children = parent.getChildNodes();
+        for( int i=0; i<children.getLength(); i++ ) {
+            Node item = children.item(i);
+            if(!(item instanceof Element ))     continue;
+
+            if(nsUri.equals(item.getNamespaceURI()))
+                a.add(item);
+        }
+        return (Element[]) a.toArray(new Element[a.size()]);
+    }
+
+    private Node evaluateXPathNode(Node target, String expression, NamespaceContext namespaceContext) {
+        NodeList nlst;
+        try {
+            xpath.setNamespaceContext(namespaceContext);
+            nlst = (NodeList)xpath.evaluate(expression, target, XPathConstants.NODESET);
+        } catch (XPathExpressionException e) {
+            error("internalizer.XPathEvaluationError", new Object[]{e.getMessage()});
+            if(env.verbose())
+                e.printStackTrace();
+            return null; // abort processing this <jaxb:bindings>
+        }
+
+        if( nlst.getLength()==0 ) {
+            error("internalizer.XPathEvaluatesToNoTarget", new Object[]{expression});
+            return null; // abort
+        }
+
+        if( nlst.getLength()!=1 ) {
+            error("internalizer.XPathEvaulatesToTooManyTargets", new Object[]{expression, nlst.getLength()});
+            return null; // abort
+        }
+
+        Node rnode = nlst.item(0);
+        if(!(rnode instanceof Element )) {
+            error("internalizer.XPathEvaluatesToNonElement", new Object[]{expression});
+            return null; // abort
+        }
+        return (Element)rnode;
+    }
+
+    /**
+     * Moves JAXWS customizations under their respective target nodes.
+     */
+    private void move( Element bindings, Map<Element, Node> targetNodes ) {
+        Node target = targetNodes.get(bindings);
+        if(target==null)
+            // this must be the result of an error on the external binding.
+            // recover from the error by ignoring this node
+            return;
+
+        Element[] children = DOMUtils.getChildElements(bindings);
+
+        for (Element item : children) {
+            if ("bindings".equals(item.getLocalName())){
+            // process child <jaxws:bindings> recursively
+                move(item, targetNodes);
+            }else if(isGlobalBinding(item)){
+                target = targetNodes.get(item);
+                moveUnder(item,(Element)target);
+            }else {
+                if (!(target instanceof Element)) {
+                    return; // abort
+                }
+                // move this node under the target
+                moveUnder(item,(Element)target);
+            }
+        }
+    }
+
+    private boolean isJAXBBindingElement(Element e){
+        if((e.getNamespaceURI() != null ) && e.getNamespaceURI().equals(JAXWSBindingsConstants.NS_JAXB_BINDINGS))
+            return true;
+        return false;
+    }
+
+    private boolean isJAXWSBindingElement(Element e){
+        if((e.getNamespaceURI() != null ) && e.getNamespaceURI().equals(JAXWSBindingsConstants.NS_JAXWS_BINDINGS))
+            return true;
+        return false;
+    }
+
+    /**
+     * Moves the "decl" node under the "target" node.
+     *
+     * @param decl
+     *      A JAXWS customization element (e.g., &lt;JAXWS:class>)
+     *
+     * @param target
+     *      XML wsdl element under which the declaration should move.
+     *      For example, &lt;xs:element>
+     */
+    private void moveUnder( Element decl, Element target ) {
+
+        //if there is @node on decl and has a child element jaxb:bindings, move it under the target
+        //Element jaxb = getJAXBBindingElement(decl);
+        if(isJAXBBindingElement(decl)){
+            //add jaxb namespace declaration
+            if(!target.hasAttributeNS(Constants.NS_XMLNS, "jaxb")){
+                target.setAttributeNS(Constants.NS_XMLNS, "xmlns:jaxb", JAXWSBindingsConstants.NS_JAXB_BINDINGS);
+            }
+
+            //add jaxb:bindings version info. Lets put it to 1.0, may need to change latter
+            if(!target.hasAttributeNS(JAXWSBindingsConstants.NS_JAXB_BINDINGS, "version")){
+                target.setAttributeNS(JAXWSBindingsConstants.NS_JAXB_BINDINGS, "jaxb:version", JAXWSBindingsConstants.JAXB_BINDING_VERSION);
+            }
+
+            //insert xs:annotation/xs:appinfo where in jaxb:binding will be put
+            target = refineSchemaTarget(target);
+            copyInscopeNSAttributes(decl);
+        }else if(isJAXWSBindingElement(decl)){
+            //add jaxb namespace declaration
+            if(!target.hasAttributeNS(Constants.NS_XMLNS, "JAXWS")){
+                target.setAttributeNS(Constants.NS_XMLNS, "xmlns:JAXWS", JAXWSBindingsConstants.NS_JAXWS_BINDINGS);
+            }
+
+            //insert xs:annotation/xs:appinfo where in jaxb:binding will be put
+            target = refineWSDLTarget(target);
+            copyInscopeNSAttributes(decl);
+        }else{
+            return;
+        }
+
+        // finally move the declaration to the target node.
+        if( target.getOwnerDocument()!=decl.getOwnerDocument() ) {
+            // if they belong to different DOM documents, we need to clone them
+            Element original = decl;
+            decl = (Element)target.getOwnerDocument().importNode(decl,true);
+
+        }
+
+        target.appendChild( decl );
+    }
+
+    /**
+     *  Copy in-scope namespace declarations of the decl node
+     *  to the decl node itself so that this move won't change
+     *  the in-scope namespace bindings.
+     */
+    private void copyInscopeNSAttributes(Element e){
+        Element p = e;
+        Set inscopes = new HashSet();
+        while(true) {
+            NamedNodeMap atts = p.getAttributes();
+            for( int i=0; i<atts.getLength(); i++ ) {
+                Attr a = (Attr)atts.item(i);
+                if( Constants.NS_XMLNS.equals(a.getNamespaceURI()) ) {
+                    String prefix;
+                    if( a.getName().indexOf(':')==-1 )  prefix = "";
+                    else                                prefix = a.getLocalName();
+
+                    if( inscopes.add(prefix) && p!=e ) {
+                        // if this is the first time we see this namespace bindings,
+                        // copy the declaration.
+                        // if p==decl, there's no need to. Note that
+                        // we want to add prefix to inscopes even if p==Decl
+
+                        e.setAttributeNodeNS( (Attr)a.cloneNode(true) );
+                    }
+                }
+            }
+
+            if( p.getParentNode() instanceof Document )
+                break;
+
+            p = (Element)p.getParentNode();
+        }
+
+        if( !inscopes.contains("") ) {
+            // if the default namespace was undeclared in the context of decl,
+            // it must be explicitly set to "" since the new environment might
+            // have a different default namespace URI.
+            e.setAttributeNS(Constants.NS_XMLNS,"xmlns","");
+        }
+    }
+
+    public Element refineSchemaTarget(Element target) {
+        // look for existing xs:annotation
+        Element annotation = DOMUtils.getFirstChildElement(target, Constants.NS_XSD, "annotation");
+        if(annotation==null)
+            // none exists. need to make one
+            annotation = insertXMLSchemaElement( target, "annotation" );
+
+        // then look for appinfo
+        Element appinfo = DOMUtils.getFirstChildElement(annotation, Constants.NS_XSD, "appinfo" );
+        if(appinfo==null)
+            // none exists. need to make one
+            appinfo = insertXMLSchemaElement( annotation, "appinfo" );
+
+        return appinfo;
+    }
+
+    public Element refineWSDLTarget(Element target) {
+        // look for existing xs:annotation
+        Element JAXWSBindings = DOMUtils.getFirstChildElement(target, JAXWSBindingsConstants.NS_JAXWS_BINDINGS, "bindings");
+        if(JAXWSBindings==null)
+            // none exists. need to make one
+            JAXWSBindings = insertJAXWSBindingsElement(target, "bindings" );
+        return JAXWSBindings;
+    }
+
+    /**
+     * Creates a new XML Schema element of the given local name
+     * and insert it as the first child of the given parent node.
+     *
+     * @return
+     *      Newly create element.
+     */
+    private Element insertXMLSchemaElement( Element parent, String localName ) {
+        // use the same prefix as the parent node to avoid modifying
+        // the namespace binding.
+        String qname = parent.getTagName();
+        int idx = qname.indexOf(':');
+        if(idx==-1)     qname = localName;
+        else            qname = qname.substring(0,idx+1)+localName;
+
+        Element child = parent.getOwnerDocument().createElementNS( Constants.NS_XSD, qname );
+
+        NodeList children = parent.getChildNodes();
+
+        if( children.getLength()==0 )
+            parent.appendChild(child);
+        else
+            parent.insertBefore( child, children.item(0) );
+
+        return child;
+    }
+
+    private Element insertJAXWSBindingsElement( Element parent, String localName ) {
+        String qname = "JAXWS:"+localName;
+
+        Element child = parent.getOwnerDocument().createElementNS(JAXWSBindingsConstants.NS_JAXWS_BINDINGS, qname );
+
+        NodeList children = parent.getChildNodes();
+
+        if( children.getLength()==0 )
+            parent.appendChild(child);
+        else
+            parent.insertBefore( child, children.item(0) );
+
+        return child;
+    }
+
+    private String getSystemId(Document doc){
+        for(Map.Entry<String, Document> e:jaxwsBindings.entrySet()){
+            if (e.getValue() == doc)
+                return e.getKey();
+        }
+        return null;
+    }
+
+    protected void warn(Localizable msg) {
+        env.warn(msg);
+    }
+
+
+    protected void error(String key, Object[] args) {
+        env.error(messageFactory.getMessage(key, args));
+    }
+
+    protected void warn(String key) {
+        env.warn(messageFactory.getMessage(key));
+    }
+
+    protected void warn(String key, Object[] args) {
+        env.warn(messageFactory.getMessage(key, args));
+    }
+
+    protected void info(String key) {
+        env.info(messageFactory.getMessage(key));
+    }
+
+    protected void info(String key, String arg) {
+        env.info(messageFactory.getMessage(key, arg));
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/JAXWSBindingExtensionHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/JAXWSBindingExtensionHandler.java
new file mode 100644
index 0000000..775a2e8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/JAXWSBindingExtensionHandler.java
@@ -0,0 +1,755 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.util.Iterator;
+import java.io.IOException;
+
+import javax.xml.namespace.QName;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.xpath.XPathFactory;
+import javax.xml.xpath.XPath;
+import javax.xml.xpath.XPathConstants;
+import javax.xml.xpath.XPathExpressionException;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+
+import com.sun.tools.internal.ws.wsdl.document.*;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.CustomName;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.JAXWSBinding;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.JAXWSBindingsConstants;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.Parameter;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaKinds;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+import com.sun.tools.internal.ws.util.xml.XmlUtil;
+
+
+/**
+ * @author Vivek Pandey
+ *
+ * jaxws:bindings exension handler.
+ *
+ */
+public class JAXWSBindingExtensionHandler extends ExtensionHandlerBase {
+
+    private static final XPathFactory xpf = XPathFactory.newInstance();
+    private final XPath xpath = xpf.newXPath();
+
+    /**
+     *
+     */
+    public JAXWSBindingExtensionHandler() {
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandler#getNamespaceURI()
+     */
+    public String getNamespaceURI() {
+        return JAXWSBindingsConstants.NS_JAXWS_BINDINGS;
+    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     */
+    private boolean parseGlobalJAXWSBindings(ParserContext context, Extensible parent, Element e) {
+        context.push();
+        context.registerNamespaces(e);
+
+        JAXWSBinding jaxwsBinding =  getJAXWSExtension(parent);
+        if(jaxwsBinding == null)
+            jaxwsBinding = new JAXWSBinding();
+        String attr = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.WSDL_LOCATION_ATTR);
+        if (attr != null) {
+            jaxwsBinding.setWsdlLocation(attr);
+        }
+
+        attr = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.NODE_ATTR);
+        if (attr != null) {
+            jaxwsBinding.setNode(attr);
+        }
+
+        attr = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.VERSION_ATTR);
+        if (attr != null) {
+            jaxwsBinding.setVersion(attr);
+        }
+
+        for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.PACKAGE)){
+                parsePackage(context, jaxwsBinding, e2);
+                if((jaxwsBinding.getJaxwsPackage() != null) && (jaxwsBinding.getJaxwsPackage().getJavaDoc() != null)){
+                    ((Definitions)parent).setDocumentation(new Documentation(jaxwsBinding.getJaxwsPackage().getJavaDoc()));
+                }
+            }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_WRAPPER_STYLE)){
+                parseWrapperStyle(context, jaxwsBinding, e2);
+            }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_ASYNC_MAPPING)){
+                parseAsynMapping(context, jaxwsBinding, e2);
+            }
+//            else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_ADDITIONAL_SOAPHEADER_MAPPING)){
+//                parseAdditionalSOAPHeaderMapping(context, jaxwsBinding, e2);
+//            }
+            else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_MIME_CONTENT)){
+                parseMimeContent(context, jaxwsBinding, e2);
+            }else{
+                Util.fail(
+                    "parsing.invalidExtensionElement",
+                    e2.getTagName(),
+                    e2.getNamespaceURI());
+                return false;
+            }
+        }
+        parent.addExtension(jaxwsBinding);
+        context.pop();
+        context.fireDoneParsingEntity(
+                JAXWSBindingsConstants.JAXWS_BINDINGS,
+                jaxwsBinding);
+        return true;
+    }
+
+    private static JAXWSBinding getJAXWSExtension(Extensible extensible) {
+        for (Iterator iter = extensible.extensions(); iter.hasNext();) {
+            Extension extension = (Extension)iter.next();
+            if (extension.getClass().equals(JAXWSBinding.class)) {
+                return (JAXWSBinding)extension;
+            }
+        }
+
+        return null;
+    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     */
+    private void parseProvider(ParserContext context, Extensible parent, Element e) {
+        String val = e.getTextContent();
+        if(val == null)
+            return;
+        if(val.equals("false") || val.equals("0")){
+            ((JAXWSBinding)parent).setProvider(Boolean.FALSE);
+        }else if(val.equals("true") || val.equals("1")){
+            ((JAXWSBinding)parent).setProvider(Boolean.TRUE);
+        }
+
+    }
+
+    /**
+     *
+     * @param context
+     * @param parent
+     * @param e
+     */
+    private void parseJAXBBindings(ParserContext context, Extensible parent, Element e) {
+        JAXWSBinding binding = (JAXWSBinding)parent;
+        binding.addJaxbBindings(e);
+    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     */
+    private void parsePackage(ParserContext context, Extensible parent, Element e) {
+        //System.out.println("In handlePackageExtension: " + e.getNodeName());
+        String packageName = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.NAME_ATTR);
+        JAXWSBinding binding = (JAXWSBinding)parent;
+        binding.setJaxwsPackage(new CustomName(packageName, getJavaDoc(e)));
+    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     */
+    private void parseWrapperStyle(ParserContext context, Extensible parent, Element e) {
+        //System.out.println("In handleWrapperStyleExtension: " + e.getNodeName());
+        String val = e.getTextContent();
+        if(val == null)
+            return;
+        if(val.equals("false") || val.equals("0")){
+            ((JAXWSBinding)parent).setEnableWrapperStyle(Boolean.FALSE);
+        }else if(val.equals("true") || val.equals("1")){
+            ((JAXWSBinding)parent).setEnableWrapperStyle(Boolean.TRUE);
+        }
+    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     */
+//    private void parseAdditionalSOAPHeaderMapping(ParserContext context, Extensible parent, Element e) {
+//        //System.out.println("In handleAdditionalSOAPHeaderExtension: " + e.getNodeName());
+//        String val = e.getTextContent();
+//        if(val == null)
+//            return;
+//        if(val.equals("false") || val.equals("0")){
+//            ((JAXWSBinding)parent).setEnableAdditionalHeaderMapping(Boolean.FALSE);
+//        }else if(val.equals("true") || val.equals("1")){
+//            ((JAXWSBinding)parent).setEnableAdditionalHeaderMapping(Boolean.TRUE);
+//        }
+//    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     */
+    private void parseAsynMapping(ParserContext context, Extensible parent, Element e) {
+        //System.out.println("In handleAsynMappingExtension: " + e.getNodeName());
+        String val = e.getTextContent();
+        if(val == null)
+            return;
+        if(val.equals("false") || val.equals("0")){
+            ((JAXWSBinding)parent).setEnableAsyncMapping(Boolean.FALSE);
+        }else if(val.equals("true") || val.equals("1")){
+            ((JAXWSBinding)parent).setEnableAsyncMapping(Boolean.TRUE);
+        }
+    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     */
+    private void parseMimeContent(ParserContext context, Extensible parent, Element e) {
+        //System.out.println("In handleMimeContentExtension: " + e.getNodeName());
+        String val = e.getTextContent();
+        if(val == null)
+            return;
+        if(val.equals("false") || val.equals("0")){
+            ((JAXWSBinding)parent).setEnableMimeContentMapping(Boolean.FALSE);
+        }else if(val.equals("true") || val.equals("1")){
+            ((JAXWSBinding)parent).setEnableMimeContentMapping(Boolean.TRUE);
+        }
+    }
+
+    /**
+     * @param context
+     * @param jaxwsBinding
+     * @param e
+     */
+    private void parseMethod(ParserContext context, JAXWSBinding jaxwsBinding, Element e) {
+        String methodName = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.NAME_ATTR);
+        String javaDoc = getJavaDoc(e);
+        CustomName name = new CustomName(methodName, javaDoc);
+        jaxwsBinding.setMethodName(name);
+    }
+
+    /**
+     * @param context
+     * @param jaxwsBinding
+     * @param e
+     */
+    private void parseParameter(ParserContext context, JAXWSBinding jaxwsBinding, Element e) {
+        String part = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.PART_ATTR);
+        Element msgPartElm = evaluateXPathNode(e.getOwnerDocument(), part, new NamespaceContextImpl(e));
+        Node msgElm = msgPartElm.getParentNode();
+        //MessagePart msgPart = new MessagePart();
+
+        String partName = XmlUtil.getAttributeOrNull(msgPartElm, "name");
+        String msgName = XmlUtil.getAttributeOrNull((Element)msgElm, "name");
+        if((partName == null) || (msgName == null))
+            return;
+
+        String val = XmlUtil.getAttributeOrNull(msgPartElm, "element");
+
+        String element = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.ELEMENT_ATTR);
+        String name = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.NAME_ATTR);
+
+        QName elementName = null;
+        if(element != null){
+            String uri = e.lookupNamespaceURI(XmlUtil.getPrefix(element));
+            elementName = (uri == null)?null:new QName(uri, XmlUtil.getLocalPart(element));
+        }
+
+        jaxwsBinding.addParameter(new Parameter(msgName, partName, elementName, name));
+    }
+
+    private Element evaluateXPathNode(Node target, String expression, NamespaceContext namespaceContext) {
+        NodeList nlst;
+        try {
+            xpath.setNamespaceContext(namespaceContext);
+            nlst = (NodeList)xpath.evaluate(expression, target, XPathConstants.NODESET);
+        } catch (XPathExpressionException e) {
+            Util.fail("internalizer.XPathEvaluationError", e.getMessage());
+            return null; // abort processing this <jaxb:bindings>
+        }
+
+        if( nlst.getLength()==0 ) {
+            Util.fail("internalizer.XPathEvaluatesToNoTarget", new Object[]{expression});
+            return null; // abort
+        }
+
+        if( nlst.getLength()!=1 ) {
+            Util.fail("internalizer.XPathEvaulatesToTooManyTargets", new Object[]{expression, nlst.getLength()});
+            return null; // abort
+        }
+
+        Node rnode = nlst.item(0);
+        if(!(rnode instanceof Element )) {
+            Util.fail("internalizer.XPathEvaluatesToNonElement", new Object[]{expression});
+            return null; // abort
+        }
+        return (Element)rnode;
+    }
+
+    /**
+     * @param context
+     * @param jaxwsBinding
+     * @param e
+     */
+    private void parseClass(ParserContext context, JAXWSBinding jaxwsBinding, Element e) {
+        String className = XmlUtil.getAttributeOrNull(e, JAXWSBindingsConstants.NAME_ATTR);
+        String javaDoc = getJavaDoc(e);
+        jaxwsBinding.setClassName(new CustomName(className, javaDoc));
+    }
+
+
+    /**
+     * @param context
+     * @param jaxwsBinding
+     * @param e
+     */
+    private void parseException(ParserContext context, JAXWSBinding jaxwsBinding, Element e) {
+        for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+            if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.CLASS)){
+                String className = XmlUtil.getAttributeOrNull(e2, JAXWSBindingsConstants.NAME_ATTR);
+                String javaDoc = getJavaDoc(e2);
+                jaxwsBinding.setException(new com.sun.tools.internal.ws.wsdl.document.jaxws.Exception(new CustomName(className, javaDoc)));
+            }
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleDefinitionsExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleDefinitionsExtension(ParserContext context, Extensible parent, Element e) {
+        return parseGlobalJAXWSBindings(context, parent, e);
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleTypesExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleTypesExtension(ParserContext context, Extensible parent, Element e) {
+        // TODO Auto-generated method stub
+        return false;
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handlePortTypeExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handlePortTypeExtension(ParserContext context, Extensible parent, Element e) {
+        if(XmlUtil.matchesTagNS(e, JAXWSBindingsConstants.JAXWS_BINDINGS)){
+            context.push();
+            context.registerNamespaces(e);
+            JAXWSBinding jaxwsBinding = new JAXWSBinding();
+
+            for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+                Element e2 = Util.nextElement(iter);
+                if (e2 == null)
+                    break;
+
+                if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_WRAPPER_STYLE)){
+                    parseWrapperStyle(context, jaxwsBinding, e2);
+                }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_ASYNC_MAPPING)){
+                    parseAsynMapping(context, jaxwsBinding, e2);
+                }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.CLASS)){
+                    parseClass(context, jaxwsBinding, e2);
+                    if((jaxwsBinding.getClassName() != null) && (jaxwsBinding.getClassName().getJavaDoc() != null)){
+                        ((PortType)parent).setDocumentation(new Documentation(jaxwsBinding.getClassName().getJavaDoc()));
+                    }
+                }else{
+                    Util.fail(
+                        "parsing.invalidExtensionElement",
+                        e2.getTagName(),
+                        e2.getNamespaceURI());
+                    return false;
+                }
+            }
+            parent.addExtension(jaxwsBinding);
+            context.pop();
+            context.fireDoneParsingEntity(
+                    JAXWSBindingsConstants.JAXWS_BINDINGS,
+                    jaxwsBinding);
+            return true;
+        }else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false;
+        }
+    }
+
+
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleOperationExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleOperationExtension(ParserContext context, Extensible parent, Element e) {
+        if(XmlUtil.matchesTagNS(e, JAXWSBindingsConstants.JAXWS_BINDINGS)){
+            if(parent instanceof Operation){
+                return handlePortTypeOperation(context, (Operation)parent, e);
+            }else if(parent instanceof BindingOperation){
+                return handleBindingOperation(context, (BindingOperation)parent, e);
+            }
+        }else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false;
+        }
+        return false;
+    }
+
+    /**
+     * @param context
+     * @param operation
+     * @param e
+     * @return
+     */
+    private boolean handleBindingOperation(ParserContext context, BindingOperation operation, Element e) {
+        if(XmlUtil.matchesTagNS(e, JAXWSBindingsConstants.JAXWS_BINDINGS)){
+            context.push();
+            context.registerNamespaces(e);
+            JAXWSBinding jaxwsBinding = new JAXWSBinding();
+
+            for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+                Element e2 = Util.nextElement(iter);
+                if (e2 == null)
+                    break;
+
+//                if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_ADDITIONAL_SOAPHEADER_MAPPING)){
+//                    parseAdditionalSOAPHeaderMapping(context, jaxwsBinding, e2);
+//                }else
+                if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_MIME_CONTENT)){
+                    parseMimeContent(context, jaxwsBinding, e2);
+                }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.PARAMETER)){
+                    parseParameter(context, jaxwsBinding, e2);
+                }else{
+                    Util.fail(
+                        "parsing.invalidExtensionElement",
+                        e2.getTagName(),
+                        e2.getNamespaceURI());
+                    return false;
+                }
+            }
+            operation.addExtension(jaxwsBinding);
+            context.pop();
+            context.fireDoneParsingEntity(
+                    JAXWSBindingsConstants.JAXWS_BINDINGS,
+                    jaxwsBinding);
+            return true;
+        }else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false;
+        }
+    }
+
+    /**
+     * @param context
+     * @param parent
+     * @param e
+     * @return
+     */
+    private boolean handlePortTypeOperation(ParserContext context, Operation parent, Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        JAXWSBinding jaxwsBinding = new JAXWSBinding();
+
+        for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_WRAPPER_STYLE)){
+                parseWrapperStyle(context, jaxwsBinding, e2);
+            }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_ASYNC_MAPPING)){
+                parseAsynMapping(context, jaxwsBinding, e2);
+            }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.METHOD)){
+                parseMethod(context, jaxwsBinding, e2);
+                if((jaxwsBinding.getMethodName() != null) && (jaxwsBinding.getMethodName().getJavaDoc() != null)){
+                    parent.setDocumentation(new Documentation(jaxwsBinding.getMethodName().getJavaDoc()));
+                }
+            }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.PARAMETER)){
+                parseParameter(context, jaxwsBinding, e2);
+            }else{
+                Util.fail(
+                    "parsing.invalidExtensionElement",
+                    e2.getTagName(),
+                    e2.getNamespaceURI());
+                return false;
+            }
+        }
+        parent.addExtension(jaxwsBinding);
+        context.pop();
+        context.fireDoneParsingEntity(
+                JAXWSBindingsConstants.JAXWS_BINDINGS,
+                jaxwsBinding);
+        return true;
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleBindingExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleBindingExtension(ParserContext context, Extensible parent, Element e) {
+        if(XmlUtil.matchesTagNS(e, JAXWSBindingsConstants.JAXWS_BINDINGS)){
+            context.push();
+            context.registerNamespaces(e);
+            JAXWSBinding jaxwsBinding = new JAXWSBinding();
+
+            for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+                Element e2 = Util.nextElement(iter);
+                if (e2 == null)
+                    break;
+
+//                if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_ADDITIONAL_SOAPHEADER_MAPPING)){
+//                    parseAdditionalSOAPHeaderMapping(context, jaxwsBinding, e2);
+//                }else
+                if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.ENABLE_MIME_CONTENT)){
+                    parseMimeContent(context, jaxwsBinding, e2);
+                }else{
+                    Util.fail(
+                        "parsing.invalidExtensionElement",
+                        e2.getTagName(),
+                        e2.getNamespaceURI());
+                    return false;
+                }
+            }
+            parent.addExtension(jaxwsBinding);
+            context.pop();
+            context.fireDoneParsingEntity(
+                    JAXWSBindingsConstants.JAXWS_BINDINGS,
+                    jaxwsBinding);
+            return true;
+        }else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false;
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleInputExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleInputExtension(ParserContext context, Extensible parent, Element e) {
+        // TODO Auto-generated method stub
+        return false;
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleOutputExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleOutputExtension(ParserContext context, Extensible parent, Element e) {
+        // TODO Auto-generated method stub
+        return false;
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleFaultExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleFaultExtension(ParserContext context, Extensible parent, Element e) {
+        if(XmlUtil.matchesTagNS(e, JAXWSBindingsConstants.JAXWS_BINDINGS)){
+            context.push();
+            context.registerNamespaces(e);
+            JAXWSBinding jaxwsBinding = new JAXWSBinding();
+
+            for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+                Element e2 = Util.nextElement(iter);
+                if (e2 == null)
+                    break;
+                if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.CLASS)){
+                    parseClass(context, jaxwsBinding, e2);
+                    if((jaxwsBinding.getClassName() != null) && (jaxwsBinding.getClassName().getJavaDoc() != null)){
+                        ((Fault)parent).setDocumentation(new Documentation(jaxwsBinding.getClassName().getJavaDoc()));
+                    }
+                }else{
+                    Util.fail(
+                        "parsing.invalidExtensionElement",
+                        e2.getTagName(),
+                        e2.getNamespaceURI());
+                    return false;
+                }
+            }
+            parent.addExtension(jaxwsBinding);
+            context.pop();
+            context.fireDoneParsingEntity(
+                    JAXWSBindingsConstants.JAXWS_BINDINGS,
+                    jaxwsBinding);
+            return true;
+        }else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false;
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleServiceExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleServiceExtension(ParserContext context, Extensible parent, Element e) {
+        if(XmlUtil.matchesTagNS(e, JAXWSBindingsConstants.JAXWS_BINDINGS)){
+            context.push();
+            context.registerNamespaces(e);
+            JAXWSBinding jaxwsBinding = new JAXWSBinding();
+
+            for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+                Element e2 = Util.nextElement(iter);
+                if (e2 == null)
+                    break;
+                if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.CLASS)){
+                    parseClass(context, jaxwsBinding, e2);
+                    if((jaxwsBinding.getClassName() != null) && (jaxwsBinding.getClassName().getJavaDoc() != null)){
+                        ((Service)parent).setDocumentation(new Documentation(jaxwsBinding.getClassName().getJavaDoc()));
+                    }
+                }else{
+                    Util.fail(
+                        "parsing.invalidExtensionElement",
+                        e2.getTagName(),
+                        e2.getNamespaceURI());
+                    return false;
+                }
+            }
+            parent.addExtension(jaxwsBinding);
+            context.pop();
+            context.fireDoneParsingEntity(
+                    JAXWSBindingsConstants.JAXWS_BINDINGS,
+                    jaxwsBinding);
+            return true;
+        }else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false;
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handlePortExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handlePortExtension(ParserContext context, Extensible parent, Element e) {
+        if(XmlUtil.matchesTagNS(e, JAXWSBindingsConstants.JAXWS_BINDINGS)){
+            context.push();
+            context.registerNamespaces(e);
+            JAXWSBinding jaxwsBinding = new JAXWSBinding();
+
+            for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+                Element e2 = Util.nextElement(iter);
+                if (e2 == null)
+                    break;
+
+                if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.PROVIDER)){
+                    parseProvider(context, jaxwsBinding, e2);
+                }else if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.METHOD)){
+                    parseMethod(context, jaxwsBinding, e2);
+                    if((jaxwsBinding.getMethodName() != null) && (jaxwsBinding.getMethodName().getJavaDoc() != null)){
+                        ((Port)parent).setDocumentation(new Documentation(jaxwsBinding.getMethodName().getJavaDoc()));
+                    }
+                }else{
+                    Util.fail(
+                        "parsing.invalidExtensionElement",
+                        e2.getTagName(),
+                        e2.getNamespaceURI());
+                    return false;
+                }
+            }
+            parent.addExtension(jaxwsBinding);
+            context.pop();
+            context.fireDoneParsingEntity(
+                    JAXWSBindingsConstants.JAXWS_BINDINGS,
+                    jaxwsBinding);
+            return true;
+        }else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false;
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handleMIMEPartExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handleMIMEPartExtension(ParserContext context, Extensible parent, Element e) {
+        // TODO Auto-generated method stub
+        return false;
+    }
+
+    private String getJavaDoc(Element e){
+        for(Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();){
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+            if(XmlUtil.matchesTagNS(e2, JAXWSBindingsConstants.JAVADOC)){
+                return XmlUtil.getTextForNode(e2);
+            }
+        }
+        return null;
+    }
+
+    public void doHandleExtension(WriterContext context, Extension extension)
+        throws IOException {
+        //System.out.println("JAXWSBindingExtensionHandler doHandleExtension: "+extension);
+        // NOTE - this ugliness can be avoided by moving all the XML parsing/writing code
+        // into the document classes themselves
+        if (extension instanceof JAXWSBinding) {
+            JAXWSBinding binding = (JAXWSBinding) extension;
+            System.out.println("binding.getElementName: "+binding.getElementName());
+            context.writeStartTag(binding.getElementName());
+            context.writeStartTag(JAXWSBindingsConstants.ENABLE_WRAPPER_STYLE);
+            context.writeChars(binding.isEnableWrapperStyle().toString());
+            context.writeEndTag(JAXWSBindingsConstants.ENABLE_WRAPPER_STYLE);
+            context.writeEndTag(binding.getElementName());
+        } else {
+            throw new IllegalArgumentException();
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/MIMEExtensionHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/MIMEExtensionHandler.java
new file mode 100644
index 0000000..fb8ea75
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/MIMEExtensionHandler.java
@@ -0,0 +1,274 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.IOException;
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.Element;
+
+import com.sun.tools.internal.ws.wsdl.document.WSDLConstants;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEConstants;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEContent;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEMultipartRelated;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEPart;
+import com.sun.tools.internal.ws.wsdl.document.mime.MIMEXml;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+import com.sun.tools.internal.ws.util.xml.XmlUtil;
+
+/**
+ * The MIME extension handler for WSDL.
+ *
+ * @author WS Development Team
+ */
+public class MIMEExtensionHandler extends ExtensionHandler {
+
+    public MIMEExtensionHandler() {
+    }
+
+    public String getNamespaceURI() {
+        return Constants.NS_WSDL_MIME;
+    }
+
+    public boolean doHandleExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (parent.getElementName().equals(WSDLConstants.QNAME_OUTPUT)) {
+            return handleInputOutputExtension(context, parent, e);
+        } else if (parent.getElementName().equals(WSDLConstants.QNAME_INPUT)) {
+            return handleInputOutputExtension(context, parent, e);
+        } else if (parent.getElementName().equals(MIMEConstants.QNAME_PART)) {
+            return handleMIMEPartExtension(context, parent, e);
+        } else {
+            context.fireIgnoringExtension(
+                new QName(e.getNamespaceURI(), e.getLocalName()),
+                parent.getElementName());
+            return false;
+        }
+    }
+
+    protected boolean handleInputOutputExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, MIMEConstants.QNAME_MULTIPART_RELATED)) {
+            context.push();
+            context.registerNamespaces(e);
+
+            MIMEMultipartRelated mpr = new MIMEMultipartRelated();
+
+            for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+                Element e2 = Util.nextElement(iter);
+                if (e2 == null)
+                    break;
+
+                if (XmlUtil.matchesTagNS(e2, MIMEConstants.QNAME_PART)) {
+                    context.push();
+                    context.registerNamespaces(e2);
+
+                    MIMEPart part = new MIMEPart();
+
+                    String name =
+                        XmlUtil.getAttributeOrNull(e2, Constants.ATTR_NAME);
+                    if (name != null) {
+                        part.setName(name);
+                    }
+
+                    for (Iterator iter2 = XmlUtil.getAllChildren(e2);
+                        iter2.hasNext();
+                        ) {
+                        Element e3 = Util.nextElement(iter2);
+                        if (e3 == null)
+                            break;
+
+                        ExtensionHandler h =
+                            (ExtensionHandler) _extensionHandlers.get(
+                                e3.getNamespaceURI());
+                        boolean handled = false;
+                        if (h != null) {
+                            handled = h.doHandleExtension(context, part, e3);
+                        }
+
+                        if (!handled) {
+                            String required =
+                                XmlUtil.getAttributeNSOrNull(
+                                    e3,
+                                    Constants.ATTR_REQUIRED,
+                                    Constants.NS_WSDL);
+                            if (required != null
+                                && required.equals(Constants.TRUE)) {
+                                Util.fail(
+                                    "parsing.requiredExtensibilityElement",
+                                    e3.getTagName(),
+                                    e3.getNamespaceURI());
+                            } else {
+                                context.fireIgnoringExtension(
+                                    new QName(
+                                        e3.getNamespaceURI(),
+                                        e3.getLocalName()),
+                                    part.getElementName());
+                            }
+                        }
+                    }
+
+                    mpr.add(part);
+                    context.pop();
+                    context.fireDoneParsingEntity(
+                        MIMEConstants.QNAME_PART,
+                        part);
+                } else {
+                    Util.fail(
+                        "parsing.invalidElement",
+                        e2.getTagName(),
+                        e2.getNamespaceURI());
+                }
+            }
+
+            parent.addExtension(mpr);
+            context.pop();
+            context.fireDoneParsingEntity(
+                MIMEConstants.QNAME_MULTIPART_RELATED,
+                mpr);
+            return true;
+        } else if (XmlUtil.matchesTagNS(e, MIMEConstants.QNAME_CONTENT)) {
+            MIMEContent content = parseMIMEContent(context, e);
+            parent.addExtension(content);
+            return true;
+        } else if (XmlUtil.matchesTagNS(e, MIMEConstants.QNAME_MIME_XML)) {
+            MIMEXml mimeXml = parseMIMEXml(context, e);
+            parent.addExtension(mimeXml);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleMIMEPartExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, MIMEConstants.QNAME_CONTENT)) {
+            MIMEContent content = parseMIMEContent(context, e);
+            parent.addExtension(content);
+            return true;
+        } else if (XmlUtil.matchesTagNS(e, MIMEConstants.QNAME_MIME_XML)) {
+            MIMEXml mimeXml = parseMIMEXml(context, e);
+            parent.addExtension(mimeXml);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected MIMEContent parseMIMEContent(ParserContext context, Element e) {
+        context.push();
+        context.registerNamespaces(e);
+
+        MIMEContent content = new MIMEContent();
+
+        String part = XmlUtil.getAttributeOrNull(e, Constants.ATTR_PART);
+        if (part != null) {
+            content.setPart(part);
+        }
+
+        String type = XmlUtil.getAttributeOrNull(e, Constants.ATTR_TYPE);
+        if (type != null) {
+            content.setType(type);
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(MIMEConstants.QNAME_CONTENT, content);
+        return content;
+    }
+
+    protected MIMEXml parseMIMEXml(ParserContext context, Element e) {
+        context.push();
+        context.registerNamespaces(e);
+
+        MIMEXml mimeXml = new MIMEXml();
+
+        String part = XmlUtil.getAttributeOrNull(e, Constants.ATTR_PART);
+        if (part != null) {
+            mimeXml.setPart(part);
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(MIMEConstants.QNAME_MIME_XML, mimeXml);
+        return mimeXml;
+    }
+
+    public void doHandleExtension(WriterContext context, Extension extension)
+        throws IOException {
+        // NOTE - this ugliness can be avoided by moving all the XML parsing/writing code
+        // into the document classes themselves
+        if (extension instanceof MIMEContent) {
+            MIMEContent content = (MIMEContent) extension;
+            context.writeStartTag(content.getElementName());
+            context.writeAttribute(Constants.ATTR_PART, content.getPart());
+            context.writeAttribute(Constants.ATTR_TYPE, content.getType());
+            context.writeEndTag(content.getElementName());
+        } else if (extension instanceof MIMEXml) {
+            MIMEXml mimeXml = (MIMEXml) extension;
+            context.writeStartTag(mimeXml.getElementName());
+            context.writeAttribute(Constants.ATTR_PART, mimeXml.getPart());
+            context.writeEndTag(mimeXml.getElementName());
+        } else if (extension instanceof MIMEMultipartRelated) {
+            MIMEMultipartRelated mpr = (MIMEMultipartRelated) extension;
+            context.writeStartTag(mpr.getElementName());
+            for (Iterator iter = mpr.getParts(); iter.hasNext();) {
+                MIMEPart part = (MIMEPart) iter.next();
+                context.writeStartTag(part.getElementName());
+                for (Iterator iter2 = part.extensions(); iter2.hasNext();) {
+                    Extension e = (Extension) iter2.next();
+                    ExtensionHandler h =
+                        (ExtensionHandler) _extensionHandlers.get(
+                            e.getElementName().getNamespaceURI());
+                    if (h != null) {
+                        h.doHandleExtension(context, e);
+                    }
+                }
+                context.writeEndTag(part.getElementName());
+            }
+            context.writeEndTag(mpr.getElementName());
+        } else {
+            throw new IllegalArgumentException();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/NamespaceContextImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/NamespaceContextImpl.java
new file mode 100644
index 0000000..e6f2485
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/NamespaceContextImpl.java
@@ -0,0 +1,99 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.NamespaceContext;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+
+public class NamespaceContextImpl implements NamespaceContext {
+
+    private final Element e;
+
+    public NamespaceContextImpl(Element e) {
+        this.e = e;
+    }
+
+    /*
+     * Copyright 1999-2004 The Apache Software Foundation.
+     *     */
+    public String getNamespaceURI(String prefix) {
+        Node parent = e;
+        String namespace = null;
+
+        if (prefix.equals("xml")) {
+            namespace = WellKnownNamespace.XML_NAMESPACE_URI;
+        } else {
+            int type;
+
+            while ((null != parent) && (null == namespace)
+                    && (((type = parent.getNodeType()) == Node.ELEMENT_NODE)
+                    || (type == Node.ENTITY_REFERENCE_NODE))) {
+                if (type == Node.ELEMENT_NODE) {
+                    if (parent.getNodeName().indexOf(prefix + ':') == 0)
+                        return parent.getNamespaceURI();
+                    NamedNodeMap nnm = parent.getAttributes();
+
+                    for (int i = 0; i < nnm.getLength(); i++) {
+                        Node attr = nnm.item(i);
+                        String aname = attr.getNodeName();
+                        boolean isPrefix = aname.startsWith("xmlns:");
+
+                        if (isPrefix || aname.equals("xmlns")) {
+                            int index = aname.indexOf(':');
+                            String p = isPrefix ? aname.substring(index + 1) : "";
+
+                            if (p.equals(prefix)) {
+                                namespace = attr.getNodeValue();
+
+                                break;
+                            }
+                        }
+                    }
+                }
+
+                parent = parent.getParentNode();
+            }
+        }
+
+        return namespace;
+    }
+
+    public String getPrefix(String namespaceURI) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Iterator getPrefixes(String namespaceURI) {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAP12ExtensionHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAP12ExtensionHandler.java
new file mode 100644
index 0000000..f86bd41
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAP12ExtensionHandler.java
@@ -0,0 +1,103 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAP12Constants;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPBinding;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAP12Binding;
+
+
+public class SOAP12ExtensionHandler extends SOAPExtensionHandler {
+
+    /*
+     * @see SOAPExtensionHandler#getNamespaceURI()
+     */
+    @Override
+    public String getNamespaceURI() {
+        return Constants.NS_WSDL_SOAP12;
+    }
+
+    /*
+     * @see SOAPExtensionHandler#getAddressQName()
+     */
+    @Override
+    protected QName getAddressQName() {
+        return SOAP12Constants.QNAME_ADDRESS;
+    }
+
+    /*
+     * @see SOAPExtensionHandler#getBindingQName()
+     */
+    @Override
+    protected QName getBindingQName() {
+        return SOAP12Constants.QNAME_BINDING;
+    }
+
+    @Override protected SOAPBinding getSOAPBinding() {
+        return new SOAP12Binding();
+    }
+
+    /*
+     * @see SOAPExtensionHandler#getBodyQName()
+     */
+    @Override
+    protected QName getBodyQName() {
+        return SOAP12Constants.QNAME_BODY;
+    }
+
+    /*
+     * @see SOAPExtensionHandler#getFaultQName()
+     */
+    @Override
+    protected QName getFaultQName() {
+        return SOAP12Constants.QNAME_FAULT;
+    }
+
+    /*
+     * @see SOAPExtensionHandler#getHeaderfaultQName()
+     */
+    @Override
+    protected QName getHeaderfaultQName() {
+        return SOAP12Constants.QNAME_HEADERFAULT;
+    }
+
+    /*
+     * @see SOAPExtensionHandler#getHeaderQName()
+     */
+    @Override
+    protected QName getHeaderQName() {
+        return SOAP12Constants.QNAME_HEADER;
+    }
+
+    /*
+     * @see SOAPExtensionHandler#getOperationQName()
+     */
+    @Override
+    protected QName getOperationQName() {
+        return SOAP12Constants.QNAME_OPERATION;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAPEntityReferenceValidator.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAPEntityReferenceValidator.java
new file mode 100644
index 0000000..0482002
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAPEntityReferenceValidator.java
@@ -0,0 +1,218 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaConstants;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaKinds;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPConstants;
+import com.sun.tools.internal.ws.wsdl.framework.EntityReferenceValidator;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+
+/**
+ * An interface implemented by a class that is capable of validating
+ * a QName/Kind pair referring to an external entity.
+ *
+ * @author WS Development Team
+ */
+public class SOAPEntityReferenceValidator implements EntityReferenceValidator {
+    public SOAPEntityReferenceValidator() {
+    }
+
+    public boolean isValid(Kind kind, QName name) {
+
+        // just let all "xml:" QNames through
+        if (name.getNamespaceURI().equals(Constants.NS_XML))
+            return true;
+
+        if (kind == SchemaKinds.XSD_TYPE) {
+            return _validTypes.contains(name);
+        } else if (kind == SchemaKinds.XSD_ELEMENT) {
+            return _validElements.contains(name);
+        } else if (kind == SchemaKinds.XSD_ATTRIBUTE) {
+            return _validAttributes.contains(name);
+        } else {
+            // no luck
+            return false;
+        }
+    }
+
+    private static final Set _validTypes;
+    private static final Set _validElements;
+    private static final Set _validAttributes;
+
+    static {
+        // add all XML Schema and SOAP types
+        _validTypes = new HashSet();
+        _validTypes.add(SOAPConstants.QNAME_TYPE_ARRAY);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_STRING);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NORMALIZED_STRING);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_TOKEN);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_BYTE);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_UNSIGNED_BYTE);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_BASE64_BINARY);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_HEX_BINARY);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_INTEGER);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_POSITIVE_INTEGER);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NEGATIVE_INTEGER);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NON_NEGATIVE_INTEGER);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NON_POSITIVE_INTEGER);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_INT);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_UNSIGNED_INT);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_LONG);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_UNSIGNED_LONG);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_SHORT);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_UNSIGNED_SHORT);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_DECIMAL);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_FLOAT);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_DOUBLE);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_BOOLEAN);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_TIME);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_DATE_TIME);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_DURATION);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_DATE);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_G_MONTH);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_G_YEAR);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_G_YEAR_MONTH);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_G_DAY);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_G_MONTH_DAY);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NAME);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_QNAME);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NCNAME);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_ANY_URI);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_ID);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_IDREF);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_IDREFS);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_ENTITY);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_ENTITIES);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NOTATION);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NMTOKEN);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_NMTOKENS);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_URTYPE);
+        _validTypes.add(SchemaConstants.QNAME_TYPE_SIMPLE_URTYPE);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_STRING);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NORMALIZED_STRING);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_TOKEN);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_BYTE);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_UNSIGNED_BYTE);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_BASE64_BINARY);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_HEX_BINARY);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_INTEGER);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_POSITIVE_INTEGER);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NEGATIVE_INTEGER);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NON_NEGATIVE_INTEGER);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NON_POSITIVE_INTEGER);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_INT);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_UNSIGNED_INT);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_LONG);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_UNSIGNED_LONG);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_SHORT);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_UNSIGNED_SHORT);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_DECIMAL);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_FLOAT);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_DOUBLE);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_BOOLEAN);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_TIME);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_DATE_TIME);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_DURATION);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_DATE);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_G_MONTH);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_G_YEAR);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_G_YEAR_MONTH);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_G_DAY);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_G_MONTH_DAY);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NAME);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_QNAME);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NCNAME);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_ANY_URI);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_ID);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_IDREF);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_IDREFS);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_ENTITY);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_ENTITIES);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NOTATION);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NMTOKEN);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_NMTOKENS);
+        _validTypes.add(SOAPConstants.QNAME_TYPE_BASE64);
+        // New types 12/3/02
+        _validTypes.add(SchemaConstants.QNAME_TYPE_LANGUAGE);
+
+        // add all SOAP encoding elements
+        _validElements = new HashSet();
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_STRING);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NORMALIZED_STRING);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_TOKEN);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_BYTE);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_UNSIGNED_BYTE);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_BASE64_BINARY);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_HEX_BINARY);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_INTEGER);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_POSITIVE_INTEGER);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NEGATIVE_INTEGER);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NON_NEGATIVE_INTEGER);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NON_POSITIVE_INTEGER);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_INT);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_UNSIGNED_INT);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_LONG);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_UNSIGNED_LONG);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_SHORT);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_UNSIGNED_SHORT);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_DECIMAL);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_FLOAT);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_DOUBLE);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_BOOLEAN);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_TIME);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_DATE_TIME);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_DURATION);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_DATE);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_G_MONTH);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_G_YEAR);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_G_YEAR_MONTH);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_G_DAY);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_G_MONTH_DAY);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NAME);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_QNAME);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NCNAME);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_ANY_URI);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_ID);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_IDREF);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_IDREFS);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_ENTITY);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_ENTITIES);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NOTATION);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NMTOKEN);
+        _validElements.add(SOAPConstants.QNAME_ELEMENT_NMTOKENS);
+
+        _validAttributes = new HashSet();
+        _validAttributes.add(SOAPConstants.QNAME_ATTR_ARRAY_TYPE);
+        _validAttributes.add(SOAPConstants.QNAME_ATTR_OFFSET);
+        _validAttributes.add(SOAPConstants.QNAME_ATTR_POSITION);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAPExtensionHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAPExtensionHandler.java
new file mode 100644
index 0000000..de19bb1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SOAPExtensionHandler.java
@@ -0,0 +1,614 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.IOException;
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.Element;
+
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPAddress;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPBinding;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPBody;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPConstants;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPFault;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPHeader;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPHeaderFault;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPOperation;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPStyle;
+import com.sun.tools.internal.ws.wsdl.document.soap.SOAPUse;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+import com.sun.tools.internal.ws.util.xml.XmlUtil;
+
+/**
+ * The SOAP extension handler for WSDL.
+ *
+ * @author WS Development Team
+ */
+public class SOAPExtensionHandler extends ExtensionHandlerBase {
+
+    public SOAPExtensionHandler() {
+    }
+
+    public String getNamespaceURI() {
+        return Constants.NS_WSDL_SOAP;
+    }
+
+    protected boolean handleDefinitionsExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected boolean handleTypesExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected SOAPBinding getSOAPBinding(){
+        return new SOAPBinding();
+    }
+
+    protected boolean handleBindingExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, getBindingQName())) {
+            context.push();
+            context.registerNamespaces(e);
+
+            SOAPBinding binding = getSOAPBinding();
+
+            // NOTE - the "transport" attribute is required according to section 3.3 of the WSDL 1.1 spec,
+            // but optional according to the schema in appendix A 4.2 of the same document!
+            String transport =
+                Util.getRequiredAttribute(e, Constants.ATTR_TRANSPORT);
+            binding.setTransport(transport);
+
+            String style = XmlUtil.getAttributeOrNull(e, Constants.ATTR_STYLE);
+            if (style != null) {
+                if (style.equals(Constants.ATTRVALUE_RPC)) {
+                    binding.setStyle(SOAPStyle.RPC);
+                } else if (style.equals(Constants.ATTRVALUE_DOCUMENT)) {
+                    binding.setStyle(SOAPStyle.DOCUMENT);
+                } else {
+                    Util.fail(
+                        "parsing.invalidAttributeValue",
+                        Constants.ATTR_STYLE,
+                        style);
+                }
+            }
+            parent.addExtension(binding);
+            context.pop();
+            context.fireDoneParsingEntity(getBindingQName(), binding);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleOperationExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, getOperationQName())) {
+            context.push();
+            context.registerNamespaces(e);
+
+            SOAPOperation operation = new SOAPOperation();
+
+            String soapAction =
+                XmlUtil.getAttributeOrNull(e, Constants.ATTR_SOAP_ACTION);
+            if (soapAction != null) {
+                operation.setSOAPAction(soapAction);
+            }
+
+            String style = XmlUtil.getAttributeOrNull(e, Constants.ATTR_STYLE);
+            if (style != null) {
+                if (style.equals(Constants.ATTRVALUE_RPC)) {
+                    operation.setStyle(SOAPStyle.RPC);
+                } else if (style.equals(Constants.ATTRVALUE_DOCUMENT)) {
+                    operation.setStyle(SOAPStyle.DOCUMENT);
+                } else {
+                    Util.fail(
+                        "parsing.invalidAttributeValue",
+                        Constants.ATTR_STYLE,
+                        style);
+                }
+            }
+            parent.addExtension(operation);
+            context.pop();
+            context.fireDoneParsingEntity(
+                getOperationQName(),
+                operation);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleInputExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        return handleInputOutputExtension(context, parent, e);
+    }
+    protected boolean handleOutputExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        return handleInputOutputExtension(context, parent, e);
+    }
+
+    protected boolean handleMIMEPartExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        return handleInputOutputExtension(context, parent, e);
+    }
+
+    protected boolean handleInputOutputExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, getBodyQName())) {
+            context.push();
+            context.registerNamespaces(e);
+
+            SOAPBody body = new SOAPBody();
+
+            String use = XmlUtil.getAttributeOrNull(e, Constants.ATTR_USE);
+            if (use != null) {
+                if (use.equals(Constants.ATTRVALUE_LITERAL)) {
+                    body.setUse(SOAPUse.LITERAL);
+                } else if (use.equals(Constants.ATTRVALUE_ENCODED)) {
+                    body.setUse(SOAPUse.ENCODED);
+                } else {
+                    Util.fail(
+                        "parsing.invalidAttributeValue",
+                        Constants.ATTR_USE,
+                        use);
+                }
+            }
+
+            String namespace =
+                XmlUtil.getAttributeOrNull(e, Constants.ATTR_NAMESPACE);
+            if (namespace != null) {
+                body.setNamespace(namespace);
+            }
+
+            String encodingStyle =
+                XmlUtil.getAttributeOrNull(e, Constants.ATTR_ENCODING_STYLE);
+            if (encodingStyle != null) {
+                body.setEncodingStyle(encodingStyle);
+            }
+
+            String parts = XmlUtil.getAttributeOrNull(e, Constants.ATTR_PARTS);
+            if (parts != null) {
+                body.setParts(parts);
+            }
+
+            parent.addExtension(body);
+            context.pop();
+            context.fireDoneParsingEntity(getBodyQName(), body);
+            return true;
+        } else if (XmlUtil.matchesTagNS(e, getHeaderQName())) {
+            context.push();
+            context.registerNamespaces(e);
+
+            SOAPHeader header = new SOAPHeader();
+
+            String use = XmlUtil.getAttributeOrNull(e, Constants.ATTR_USE);
+            if (use != null) {
+                if (use.equals(Constants.ATTRVALUE_LITERAL)) {
+                    header.setUse(SOAPUse.LITERAL);
+                } else if (use.equals(Constants.ATTRVALUE_ENCODED)) {
+                    header.setUse(SOAPUse.ENCODED);
+                } else {
+                    Util.fail(
+                        "parsing.invalidAttributeValue",
+                        Constants.ATTR_USE,
+                        use);
+                }
+            }
+
+            String namespace =
+                XmlUtil.getAttributeOrNull(e, Constants.ATTR_NAMESPACE);
+            if (namespace != null) {
+                header.setNamespace(namespace);
+            }
+
+            String encodingStyle =
+                XmlUtil.getAttributeOrNull(e, Constants.ATTR_ENCODING_STYLE);
+            if (encodingStyle != null) {
+                header.setEncodingStyle(encodingStyle);
+            }
+
+            String part = XmlUtil.getAttributeOrNull(e, Constants.ATTR_PART);
+            if (part != null) {
+                header.setPart(part);
+            }
+
+            String messageAttr =
+                XmlUtil.getAttributeOrNull(e, Constants.ATTR_MESSAGE);
+            if (messageAttr != null) {
+                header.setMessage(context.translateQualifiedName(messageAttr));
+            }
+
+            for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+                Element e2 = Util.nextElement(iter);
+                if (e2 == null)
+                    break;
+
+                if (XmlUtil
+                    .matchesTagNS(e2, getHeaderfaultQName())) {
+                    context.push();
+                    context.registerNamespaces(e);
+
+                    SOAPHeaderFault headerfault = new SOAPHeaderFault();
+
+                    String use2 =
+                        XmlUtil.getAttributeOrNull(e2, Constants.ATTR_USE);
+                    if (use2 != null) {
+                        if (use2.equals(Constants.ATTRVALUE_LITERAL)) {
+                            headerfault.setUse(SOAPUse.LITERAL);
+                        } else if (use.equals(Constants.ATTRVALUE_ENCODED)) {
+                            headerfault.setUse(SOAPUse.ENCODED);
+                        } else {
+                            Util.fail(
+                                "parsing.invalidAttributeValue",
+                                Constants.ATTR_USE,
+                                use2);
+                        }
+                    }
+
+                    String namespace2 =
+                        XmlUtil.getAttributeOrNull(
+                            e2,
+                            Constants.ATTR_NAMESPACE);
+                    if (namespace2 != null) {
+                        headerfault.setNamespace(namespace2);
+                    }
+
+                    String encodingStyle2 =
+                        XmlUtil.getAttributeOrNull(
+                            e2,
+                            Constants.ATTR_ENCODING_STYLE);
+                    if (encodingStyle2 != null) {
+                        headerfault.setEncodingStyle(encodingStyle2);
+                    }
+
+                    String part2 =
+                        XmlUtil.getAttributeOrNull(e2, Constants.ATTR_PART);
+                    if (part2 != null) {
+                        headerfault.setPart(part2);
+                    }
+
+                    String messageAttr2 =
+                        XmlUtil.getAttributeOrNull(e2, Constants.ATTR_MESSAGE);
+                    if (messageAttr2 != null) {
+                        headerfault.setMessage(
+                            context.translateQualifiedName(messageAttr2));
+                    }
+
+                    header.add(headerfault);
+                    context.pop();
+                } else {
+                    Util.fail(
+                        "parsing.invalidElement",
+                        e2.getTagName(),
+                        e2.getNamespaceURI());
+                }
+            }
+
+            parent.addExtension(header);
+            context.pop();
+            context.fireDoneParsingEntity(getHeaderQName(), header);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleFaultExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, getFaultQName())) {
+            context.push();
+            context.registerNamespaces(e);
+
+            SOAPFault fault = new SOAPFault();
+
+            String name = XmlUtil.getAttributeOrNull(e, Constants.ATTR_NAME);
+            if (name != null) {
+                fault.setName(name);
+            }
+
+            String use = XmlUtil.getAttributeOrNull(e, Constants.ATTR_USE);
+            if (use != null) {
+                if (use.equals(Constants.ATTRVALUE_LITERAL)) {
+                    fault.setUse(SOAPUse.LITERAL);
+                } else if (use.equals(Constants.ATTRVALUE_ENCODED)) {
+                    fault.setUse(SOAPUse.ENCODED);
+                } else {
+                    Util.fail(
+                        "parsing.invalidAttributeValue",
+                        Constants.ATTR_USE,
+                        use);
+                }
+            }
+
+            String namespace =
+                XmlUtil.getAttributeOrNull(e, Constants.ATTR_NAMESPACE);
+            if (namespace != null) {
+                fault.setNamespace(namespace);
+            }
+
+            String encodingStyle =
+                XmlUtil.getAttributeOrNull(e, Constants.ATTR_ENCODING_STYLE);
+            if (encodingStyle != null) {
+                fault.setEncodingStyle(encodingStyle);
+            }
+
+            parent.addExtension(fault);
+            context.pop();
+            context.fireDoneParsingEntity(getFaultQName(), fault);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    protected boolean handleServiceExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected boolean handlePortExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, getAddressQName())) {
+            context.push();
+            context.registerNamespaces(e);
+
+            SOAPAddress address = new SOAPAddress();
+
+            String location =
+                Util.getRequiredAttribute(e, Constants.ATTR_LOCATION);
+            address.setLocation(location);
+
+            parent.addExtension(address);
+            context.pop();
+            context.fireDoneParsingEntity(getAddressQName(), address);
+            return true;
+        } else {
+            Util.fail(
+                "parsing.invalidExtensionElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+            return false; // keep compiler happy
+        }
+    }
+
+    public void doHandleExtension(WriterContext context, Extension extension)
+        throws IOException {
+        // NOTE - this ugliness can be avoided by moving all the XML parsing/writing code
+        // into the document classes themselves
+        if (extension instanceof SOAPAddress) {
+            SOAPAddress address = (SOAPAddress) extension;
+            context.writeStartTag(address.getElementName());
+            context.writeAttribute(
+                Constants.ATTR_LOCATION,
+                address.getLocation());
+            context.writeEndTag(address.getElementName());
+        } else if (extension instanceof SOAPBinding) {
+            SOAPBinding binding = (SOAPBinding) extension;
+            context.writeStartTag(binding.getElementName());
+            context.writeAttribute(
+                Constants.ATTR_TRANSPORT,
+                binding.getTransport());
+            String style =
+                (binding.getStyle() == null
+                    ? null
+                    : (binding.getStyle() == SOAPStyle.DOCUMENT
+                        ? Constants.ATTRVALUE_DOCUMENT
+                        : Constants.ATTRVALUE_RPC));
+            context.writeAttribute(Constants.ATTR_STYLE, style);
+            context.writeEndTag(binding.getElementName());
+        } else if (extension instanceof SOAPBody) {
+            SOAPBody body = (SOAPBody) extension;
+            context.writeStartTag(body.getElementName());
+            context.writeAttribute(
+                Constants.ATTR_ENCODING_STYLE,
+                body.getEncodingStyle());
+            context.writeAttribute(Constants.ATTR_PARTS, body.getParts());
+            String use =
+                (body.getUse() == null
+                    ? null
+                    : (body.getUse() == SOAPUse.LITERAL
+                        ? Constants.ATTRVALUE_LITERAL
+                        : Constants.ATTRVALUE_ENCODED));
+            context.writeAttribute(Constants.ATTR_USE, use);
+            context.writeAttribute(
+                Constants.ATTR_NAMESPACE,
+                body.getNamespace());
+            context.writeEndTag(body.getElementName());
+        } else if (extension instanceof SOAPFault) {
+            SOAPFault fault = (SOAPFault) extension;
+            context.writeStartTag(fault.getElementName());
+            context.writeAttribute(Constants.ATTR_NAME, fault.getName());
+            context.writeAttribute(
+                Constants.ATTR_ENCODING_STYLE,
+                fault.getEncodingStyle());
+            String use =
+                (fault.getUse() == null
+                    ? null
+                    : (fault.getUse() == SOAPUse.LITERAL
+                        ? Constants.ATTRVALUE_LITERAL
+                        : Constants.ATTRVALUE_ENCODED));
+            context.writeAttribute(Constants.ATTR_USE, use);
+            context.writeAttribute(
+                Constants.ATTR_NAMESPACE,
+                fault.getNamespace());
+            context.writeEndTag(fault.getElementName());
+        } else if (extension instanceof SOAPHeader) {
+            SOAPHeader header = (SOAPHeader) extension;
+            context.writeStartTag(header.getElementName());
+            context.writeAttribute(Constants.ATTR_MESSAGE, header.getMessage());
+            context.writeAttribute(Constants.ATTR_PART, header.getPart());
+            context.writeAttribute(
+                Constants.ATTR_ENCODING_STYLE,
+                header.getEncodingStyle());
+            String use =
+                (header.getUse() == null
+                    ? null
+                    : (header.getUse() == SOAPUse.LITERAL
+                        ? Constants.ATTRVALUE_LITERAL
+                        : Constants.ATTRVALUE_ENCODED));
+            context.writeAttribute(Constants.ATTR_USE, use);
+            context.writeAttribute(
+                Constants.ATTR_NAMESPACE,
+                header.getNamespace());
+            context.writeEndTag(header.getElementName());
+        } else if (extension instanceof SOAPHeaderFault) {
+            SOAPHeaderFault headerfault = (SOAPHeaderFault) extension;
+            context.writeStartTag(headerfault.getElementName());
+            context.writeAttribute(
+                Constants.ATTR_MESSAGE,
+                headerfault.getMessage());
+            context.writeAttribute(Constants.ATTR_PART, headerfault.getPart());
+            context.writeAttribute(
+                Constants.ATTR_ENCODING_STYLE,
+                headerfault.getEncodingStyle());
+            String use =
+                (headerfault.getUse() == null
+                    ? null
+                    : (headerfault.getUse() == SOAPUse.LITERAL
+                        ? Constants.ATTRVALUE_LITERAL
+                        : Constants.ATTRVALUE_ENCODED));
+            context.writeAttribute(Constants.ATTR_USE, use);
+            context.writeAttribute(
+                Constants.ATTR_NAMESPACE,
+                headerfault.getNamespace());
+            context.writeEndTag(headerfault.getElementName());
+        } else if (extension instanceof SOAPOperation) {
+            SOAPOperation operation = (SOAPOperation) extension;
+            context.writeStartTag(operation.getElementName());
+            context.writeAttribute(
+                Constants.ATTR_SOAP_ACTION,
+                operation.getSOAPAction());
+            String style =
+                (operation.getStyle() == null
+                    ? null
+                    : (operation.isDocument()
+                        ? Constants.ATTRVALUE_DOCUMENT
+                        : Constants.ATTRVALUE_RPC));
+            context.writeAttribute(Constants.ATTR_STYLE, style);
+            context.writeEndTag(operation.getElementName());
+        } else {
+            throw new IllegalArgumentException();
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see ExtensionHandlerBase#handlePortTypeExtension(ParserContext, Extensible, org.w3c.dom.Element)
+     */
+    protected boolean handlePortTypeExtension(ParserContext context, Extensible parent, Element e) {
+        Util.fail(
+            "parsing.invalidExtensionElement",
+            e.getTagName(),
+            e.getNamespaceURI());
+        return false; // keep compiler happy
+    }
+
+    protected QName getBodyQName(){
+        return SOAPConstants.QNAME_BODY;
+    }
+
+    protected QName getHeaderQName(){
+        return SOAPConstants.QNAME_HEADER;
+    }
+
+    protected QName getHeaderfaultQName(){
+        return SOAPConstants.QNAME_HEADERFAULT;
+    }
+
+    protected QName getOperationQName(){
+        return SOAPConstants.QNAME_OPERATION;
+    }
+
+    protected QName getFaultQName(){
+        return SOAPConstants.QNAME_FAULT;
+    }
+
+    protected QName getAddressQName(){
+        return SOAPConstants.QNAME_ADDRESS;
+    }
+
+    protected QName getBindingQName(){
+        return SOAPConstants.QNAME_BINDING;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaExtensionHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaExtensionHandler.java
new file mode 100644
index 0000000..6edcb67
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaExtensionHandler.java
@@ -0,0 +1,77 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.IOException;
+
+import org.w3c.dom.Element;
+
+import com.sun.tools.internal.ws.wsdl.document.schema.Schema;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaConstants;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+import com.sun.tools.internal.ws.util.xml.XmlUtil;
+
+/**
+ * The XML Schema extension handler for WSDL.
+ *
+ * @author WS Development Team
+ */
+public class SchemaExtensionHandler extends ExtensionHandler {
+
+    public SchemaExtensionHandler() {
+    }
+
+    public String getNamespaceURI() {
+        return Constants.NS_XSD;
+    }
+
+    public boolean doHandleExtension(
+        ParserContext context,
+        Extensible parent,
+        Element e) {
+        if (XmlUtil.matchesTagNS(e, SchemaConstants.QNAME_SCHEMA)) {
+            SchemaParser parser = new SchemaParser();
+            parent.addExtension(parser.parseSchema(context, e, null));
+            return true;
+        } else {
+            return false;
+        }
+    }
+
+    public void doHandleExtension(WriterContext context, Extension extension)
+        throws IOException {
+        if (extension instanceof Schema) {
+            SchemaWriter writer = new SchemaWriter();
+            writer.writeSchema(context, (Schema) extension);
+        } else {
+            // unknown extension
+            throw new IllegalArgumentException();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaParser.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaParser.java
new file mode 100644
index 0000000..cbf991b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaParser.java
@@ -0,0 +1,353 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.IOException;
+import java.util.Iterator;
+
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.FactoryConfigurationError;
+import javax.xml.parsers.ParserConfigurationException;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+import com.sun.xml.internal.ws.util.xml.NamedNodeMapIterator;
+import com.sun.tools.internal.ws.util.xml.NullEntityResolver;
+import com.sun.tools.internal.ws.wsdl.document.schema.Schema;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaAttribute;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaConstants;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaDocument;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaElement;
+import com.sun.tools.internal.ws.wsdl.framework.ParseException;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+import com.sun.tools.internal.ws.wsdl.framework.ValidationException;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+/**
+ * A parser for XML Schema, including the fragments found inside a WSDL document.
+ *
+ * @author WS Development Team
+ */
+public class SchemaParser {
+
+    public SchemaParser() {
+    }
+
+    public boolean getFollowImports() {
+        return _followImports;
+    }
+
+    public void setFollowImports(boolean b) {
+        _followImports = b;
+    }
+
+    public SchemaDocument parse(InputSource source) {
+        SchemaDocument schemaDocument = new SchemaDocument();
+        schemaDocument.setSystemId(source.getSystemId());
+        ParserContext context = new ParserContext(schemaDocument, null);
+        context.setFollowImports(_followImports);
+        schemaDocument.setSchema(parseSchema(context, source, null));
+        return schemaDocument;
+    }
+
+    public Schema parseSchema(
+        ParserContext context,
+        InputSource source,
+        String expectedTargetNamespaceURI) {
+        Schema schema =
+            parseSchemaNoImport(context, source, expectedTargetNamespaceURI);
+        schema.defineAllEntities();
+        processImports(context, source, schema);
+        return schema;
+    }
+
+    public Schema parseSchema(
+        ParserContext context,
+        Element e,
+        String expectedTargetNamespaceURI) {
+        Schema schema =
+            parseSchemaNoImport(context, e, expectedTargetNamespaceURI);
+        schema.defineAllEntities();
+        processImports(context, null, schema);
+        return schema;
+    }
+
+    protected void processImports(
+        ParserContext context,
+        InputSource source,
+        Schema schema) {
+        for (Iterator iter = schema.getContent().children(); iter.hasNext();) {
+            SchemaElement child = (SchemaElement) iter.next();
+            if (child.getQName().equals(SchemaConstants.QNAME_IMPORT)) {
+                String location =
+                    child.getValueOfAttributeOrNull(
+                        Constants.ATTR_SCHEMA_LOCATION);
+                String namespace =
+                    child.getValueOfAttributeOrNull(Constants.ATTR_NAMESPACE);
+                //bug fix: 4857762, add adjustedLocation to teh importDocuments and ignore if it
+                //exists, to avoid duplicates
+                if (location != null) {
+                    String adjustedLocation = null;
+                    if (source != null && source.getSystemId() != null) {
+                        adjustedLocation =
+                            Util.processSystemIdWithBase(
+                                source.getSystemId(),
+                                location);
+                    }
+                    //bug fix: 4856674
+                    if (adjustedLocation == null) {
+                        adjustedLocation =
+                            context.getWSDLLocation() == null
+                                ? location
+                                : Util.processSystemIdWithBase(
+                                    context.getWSDLLocation(),
+                                    location);
+                    }
+                    if (!context
+                        .getDocument()
+                        .isImportedDocument(adjustedLocation)) {
+                        context.getDocument().addImportedEntity(
+                            parseSchema(
+                                context,
+                                new InputSource(adjustedLocation),
+                                namespace));
+                        context.getDocument().addImportedDocument(
+                            adjustedLocation);
+                    }
+                }
+            } else if (
+                child.getQName().equals(SchemaConstants.QNAME_INCLUDE)
+                    && (schema.getTargetNamespaceURI() != null)) {
+                String location =
+                    child.getValueOfAttributeOrNull(
+                        Constants.ATTR_SCHEMA_LOCATION);
+                if (location != null
+                    && !context.getDocument().isIncludedDocument(location)) {
+                    context.getDocument().addIncludedDocument(location);
+                    String adjustedLocation = null;
+                    if (source != null && source.getSystemId() != null) {
+                        adjustedLocation =
+                            Util.processSystemIdWithBase(
+                                source.getSystemId(),
+                                location);
+                    }
+                    if (adjustedLocation == null) {
+                        adjustedLocation =
+                            context.getDocument().getSystemId() == null
+                                ? location
+                                : Util.processSystemIdWithBase(
+                                    context.getDocument().getSystemId(),
+                                    location);
+                    }
+                    context.getDocument().addIncludedEntity(
+                        parseSchema(
+                            context,
+                            new InputSource(adjustedLocation),
+                            schema.getTargetNamespaceURI()));
+                }
+            } else if (
+                child.getQName().equals(SchemaConstants.QNAME_REDEFINE)) {
+                // not supported
+                Util.fail("validation.unsupportedSchemaFeature", "redefine");
+            }
+        }
+    }
+
+    protected Schema parseSchemaNoImport(
+        ParserContext context,
+        InputSource source,
+        String expectedTargetNamespaceURI) {
+        try {
+            DocumentBuilderFactory builderFactory =
+                DocumentBuilderFactory.newInstance();
+            builderFactory.setNamespaceAware(true);
+            builderFactory.setValidating(false);
+            DocumentBuilder builder = builderFactory.newDocumentBuilder();
+            builder.setErrorHandler(new ErrorHandler() {
+                public void error(SAXParseException e)
+                    throws SAXParseException {
+                    throw e;
+                }
+                public void fatalError(SAXParseException e)
+                    throws SAXParseException {
+                    throw e;
+                }
+                public void warning(SAXParseException err)
+                    throws SAXParseException {
+                    // do nothing
+                }
+            });
+            builder.setEntityResolver(new NullEntityResolver());
+
+            try {
+                Document document = builder.parse(source);
+                return parseSchemaNoImport(
+                    context,
+                    document,
+                    expectedTargetNamespaceURI);
+            } catch (IOException e) {
+                throw new ParseException(
+                    "parsing.ioException",e);
+            } catch (SAXException e) {
+                throw new ParseException(
+                    "parsing.saxException",e);
+            }
+        } catch (ParserConfigurationException e) {
+            throw new ParseException(
+                "parsing.parserConfigException",e);
+        } catch (FactoryConfigurationError e) {
+            throw new ParseException(
+                "parsing.factoryConfigException",e);
+        }
+    }
+
+    protected Schema parseSchemaNoImport(
+        ParserContext context,
+        Document doc,
+        String expectedTargetNamespaceURI) {
+        Element root = doc.getDocumentElement();
+        Util.verifyTagNSRootElement(root, SchemaConstants.QNAME_SCHEMA);
+        return parseSchemaNoImport(context, root, expectedTargetNamespaceURI);
+    }
+
+    protected Schema parseSchemaNoImport(
+        ParserContext context,
+        Element e,
+        String expectedTargetNamespaceURI) {
+        Schema schema = new Schema(context.getDocument());
+        String targetNamespaceURI =
+            XmlUtil.getAttributeOrNull(e, Constants.ATTR_TARGET_NAMESPACE);
+        //bug 4849754 fix, in both the case of xsd:include and xsd:import this should work
+        if (targetNamespaceURI != null
+            && expectedTargetNamespaceURI != null
+            && !expectedTargetNamespaceURI.equals(targetNamespaceURI)) {
+            throw new ValidationException(
+                "validation.incorrectTargetNamespace",
+                new Object[] {
+                    targetNamespaceURI,
+                    expectedTargetNamespaceURI });
+        }
+        if (targetNamespaceURI == null)
+            schema.setTargetNamespaceURI(expectedTargetNamespaceURI);
+        else
+            schema.setTargetNamespaceURI(targetNamespaceURI);
+
+        // snapshot the current prefixes
+        for (Iterator iter = context.getPrefixes(); iter.hasNext();) {
+            String prefix = (String) iter.next();
+            String nsURI = context.getNamespaceURI(prefix);
+            if (nsURI == null) {
+                // should not happen
+                throw new ParseException("parsing.shouldNotHappen");
+            }
+            schema.addPrefix(prefix, nsURI);
+        }
+
+        context.push();
+        context.registerNamespaces(e);
+
+        // just internalize the XML fragment
+        SchemaElement schemaElement =
+            new SchemaElement(SchemaConstants.QNAME_SCHEMA);
+
+        copyNamespaceDeclarations(schemaElement, e);
+        copyAttributesNoNs(schemaElement, e);
+        copyElementContent(schemaElement, e);
+
+        schema.setContent(schemaElement);
+        schemaElement.setSchema(schema);
+
+        context.pop();
+        context.fireDoneParsingEntity(SchemaConstants.QNAME_SCHEMA, schema);
+        return schema;
+    }
+
+    protected void copyAttributesNoNs(SchemaElement target, Element source) {
+        for (Iterator iter = new NamedNodeMapIterator(source.getAttributes());
+            iter.hasNext();
+            ) {
+            Attr attr = (Attr) iter.next();
+            if (attr.getName().equals(PREFIX_XMLNS)
+                || attr.getName().startsWith(PREFIX_XMLNS_COLON)) {
+                continue;
+            }
+
+            SchemaAttribute attribute =
+                new SchemaAttribute(attr.getLocalName());
+            attribute.setNamespaceURI(attr.getNamespaceURI());
+            attribute.setValue(attr.getValue());
+            target.addAttribute(attribute);
+        }
+    }
+
+    protected void copyNamespaceDeclarations(
+        SchemaElement target,
+        Element source) {
+        for (Iterator iter = new NamedNodeMapIterator(source.getAttributes());
+            iter.hasNext();
+            ) {
+            Attr attr = (Attr) iter.next();
+            if (attr.getName().equals(PREFIX_XMLNS)) {
+                // default namespace declaration
+                target.addPrefix("", attr.getValue());
+            } else {
+                String prefix = XmlUtil.getPrefix(attr.getName());
+                if (prefix != null && prefix.equals(PREFIX_XMLNS)) {
+                    String nsPrefix = XmlUtil.getLocalPart(attr.getName());
+                    String uri = attr.getValue();
+                    target.addPrefix(nsPrefix, uri);
+                }
+            }
+        }
+    }
+
+    protected void copyElementContent(SchemaElement target, Element source) {
+        for (Iterator iter = XmlUtil.getAllChildren(source); iter.hasNext();) {
+            Element e2 = Util.nextElementIgnoringCharacterContent(iter);
+            if (e2 == null)
+                break;
+            SchemaElement newElement = new SchemaElement(e2.getLocalName());
+            newElement.setNamespaceURI(e2.getNamespaceURI());
+            copyNamespaceDeclarations(newElement, e2);
+            copyAttributesNoNs(newElement, e2);
+            copyElementContent(newElement, e2);
+            target.addChild(newElement);
+            newElement.setParent(target);
+        }
+    }
+
+    private boolean _followImports;
+
+    private final static String PREFIX_XMLNS = "xmlns";
+    private final static String PREFIX_XMLNS_COLON = "xmlns:";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaWriter.java
new file mode 100644
index 0000000..0bd91bd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/SchemaWriter.java
@@ -0,0 +1,158 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.document.schema.Schema;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaAttribute;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaDocument;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaElement;
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+
+/**
+ * A writer for XML Schema fragments within a WSDL document.
+ *
+ * @author WS Development Team
+ */
+public class SchemaWriter {
+
+    public SchemaWriter() {
+    }
+
+    public void write(SchemaDocument document, OutputStream os)
+        throws IOException {
+        WriterContext context = new WriterContext(os);
+        writeSchema(context, document.getSchema());
+        context.flush();
+    }
+
+    public void writeSchema(WriterContext context, Schema schema)
+        throws IOException {
+        context.push();
+        try {
+            writeTopSchemaElement(context, schema);
+        } catch (Exception e) {
+        } finally {
+            context.pop();
+        }
+    }
+
+    protected void writeTopSchemaElement(WriterContext context, Schema schema)
+        throws IOException {
+        SchemaElement schemaElement = schema.getContent();
+        QName name = schemaElement.getQName();
+
+        // make sure that all namespaces we expect are actually declared
+        for (Iterator iter = schema.prefixes(); iter.hasNext();) {
+            String prefix = (String) iter.next();
+            String expectedURI = schema.getURIForPrefix(prefix);
+            if (!expectedURI.equals(context.getNamespaceURI(prefix))) {
+                context.declarePrefix(prefix, expectedURI);
+            }
+        }
+
+        for (Iterator iter = schemaElement.prefixes(); iter.hasNext();) {
+            String prefix = (String) iter.next();
+            String uri = schemaElement.getURIForPrefix(prefix);
+            context.declarePrefix(prefix, uri);
+        }
+
+        context.writeStartTag(name);
+
+        for (Iterator iter = schemaElement.attributes(); iter.hasNext();) {
+            SchemaAttribute attribute = (SchemaAttribute) iter.next();
+            if (attribute.getNamespaceURI() == null) {
+                context.writeAttribute(
+                    attribute.getLocalName(),
+                    attribute.getValue(context));
+            } else {
+                context.writeAttribute(
+                    context.getQNameString(attribute.getQName()),
+                    attribute.getValue(context));
+            }
+        }
+
+        context.writeAllPendingNamespaceDeclarations();
+
+        for (Iterator iter = schemaElement.children(); iter.hasNext();) {
+            SchemaElement child = (SchemaElement) iter.next();
+            writeSchemaElement(context, child);
+        }
+
+        context.writeEndTag(name);
+    }
+
+    protected void writeSchemaElement(
+        WriterContext context,
+        SchemaElement schemaElement)
+        throws IOException {
+        QName name = schemaElement.getQName();
+
+        if (schemaElement.declaresPrefixes()) {
+            context.push();
+        }
+
+        context.writeStartTag(name);
+
+        if (schemaElement.declaresPrefixes()) {
+            for (Iterator iter = schemaElement.prefixes(); iter.hasNext();) {
+                String prefix = (String) iter.next();
+                String uri = schemaElement.getURIForPrefix(prefix);
+                context.writeNamespaceDeclaration(prefix, uri);
+                context.declarePrefix(prefix, uri);
+            }
+        }
+
+        for (Iterator iter = schemaElement.attributes(); iter.hasNext();) {
+            SchemaAttribute attribute = (SchemaAttribute) iter.next();
+            if (attribute.getNamespaceURI() == null) {
+                context.writeAttribute(
+                    attribute.getLocalName(),
+                    attribute.getValue(context));
+            } else {
+                context.writeAttribute(
+                    context.getQNameString(attribute.getQName()),
+                    attribute.getValue(context));
+            }
+        }
+
+        for (Iterator iter = schemaElement.children(); iter.hasNext();) {
+            SchemaElement child = (SchemaElement) iter.next();
+            writeSchemaElement(context, child);
+        }
+
+        context.writeEndTag(name);
+
+        if (schemaElement.declaresPrefixes()) {
+            context.pop();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Util.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Util.java
new file mode 100644
index 0000000..448eb34
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/Util.java
@@ -0,0 +1,178 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.File;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.Comment;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.w3c.dom.Text;
+
+import com.sun.tools.internal.ws.wsdl.framework.ParseException;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+/**2
+ * Defines various utility methods.
+ *
+ * @author WS Development Team
+ */
+public class Util {
+
+    public static String getRequiredAttribute(Element element, String name) {
+        String result = XmlUtil.getAttributeOrNull(element, name);
+        if (result == null)
+            fail(
+                "parsing.missingRequiredAttribute",
+                element.getTagName(),
+                name);
+        return result;
+    }
+
+    public static void verifyTag(Element element, String tag) {
+        if (!element.getLocalName().equals(tag))
+            fail("parsing.invalidTag", element.getTagName(), tag);
+    }
+
+    public static void verifyTagNS(Element element, String tag, String nsURI) {
+        if (!element.getLocalName().equals(tag)
+            || (element.getNamespaceURI() != null
+                && !element.getNamespaceURI().equals(nsURI)))
+            fail(
+                "parsing.invalidTagNS",
+                new Object[] {
+                    element.getTagName(),
+                    element.getNamespaceURI(),
+                    tag,
+                    nsURI });
+    }
+
+    public static void verifyTagNS(Element element, QName name) {
+        if (!element.getLocalName().equals(name.getLocalPart())
+            || (element.getNamespaceURI() != null
+                && !element.getNamespaceURI().equals(name.getNamespaceURI())))
+            fail(
+                "parsing.invalidTagNS",
+                new Object[] {
+                    element.getTagName(),
+                    element.getNamespaceURI(),
+                    name.getLocalPart(),
+                    name.getNamespaceURI()});
+    }
+
+    public static void verifyTagNSRootElement(Element element, QName name) {
+        if (!element.getLocalName().equals(name.getLocalPart())
+            || (element.getNamespaceURI() != null
+                && !element.getNamespaceURI().equals(name.getNamespaceURI())))
+            fail(
+                "parsing.incorrectRootElement",
+                new Object[] {
+                    element.getTagName(),
+                    element.getNamespaceURI(),
+                    name.getLocalPart(),
+                    name.getNamespaceURI()});
+    }
+
+    public static Element nextElementIgnoringCharacterContent(Iterator iter) {
+        while (iter.hasNext()) {
+            Node n = (Node) iter.next();
+            if (n instanceof Text)
+                continue;
+            if (n instanceof Comment)
+                continue;
+            if (!(n instanceof Element))
+                fail("parsing.elementExpected");
+            return (Element) n;
+        }
+
+        return null;
+    }
+
+    public static Element nextElement(Iterator iter) {
+        while (iter.hasNext()) {
+            Node n = (Node) iter.next();
+            if (n instanceof Text) {
+                Text t = (Text) n;
+                if (t.getData().trim().length() == 0)
+                    continue;
+                fail("parsing.nonWhitespaceTextFound", t.getData().trim());
+            }
+            if (n instanceof Comment)
+                continue;
+            if (!(n instanceof Element))
+                fail("parsing.elementExpected");
+            return (Element) n;
+        }
+
+        return null;
+    }
+
+    public static String processSystemIdWithBase(
+        String baseSystemId,
+        String systemId) {
+        try {
+            URL base = null;
+            try {
+                base = new URL(baseSystemId);
+            } catch (MalformedURLException e) {
+                base = new File(baseSystemId).toURL();
+            }
+
+            try {
+                URL url = new URL(base, systemId);
+                return url.toString();
+            } catch (MalformedURLException e) {
+                fail("parsing.invalidURI", systemId);
+            }
+
+        } catch (MalformedURLException e) {
+            fail("parsing.invalidURI", baseSystemId);
+        }
+
+        return null; // keep compiler happy
+    }
+
+    public static void fail(String key) {
+        throw new ParseException(key);
+    }
+
+    public static void fail(String key, String arg) {
+        throw new ParseException(key, arg);
+    }
+
+    public static void fail(String key, String arg1, String arg2) {
+        throw new ParseException(key, new Object[] { arg1, arg2 });
+    }
+
+    public static void fail(String key, Object[] args) {
+        throw new ParseException(key, args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/WSDLParser.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/WSDLParser.java
new file mode 100644
index 0000000..93d3cf9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/WSDLParser.java
@@ -0,0 +1,1409 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.BufferedInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.FactoryConfigurationError;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.transform.dom.DOMSource;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.EntityResolver;
+
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.xml.internal.ws.util.localization.Localizer;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.tools.internal.ws.util.xml.NullEntityResolver;
+import com.sun.tools.internal.ws.wsdl.document.Binding;
+import com.sun.tools.internal.ws.wsdl.document.BindingFault;
+import com.sun.tools.internal.ws.wsdl.document.BindingInput;
+import com.sun.tools.internal.ws.wsdl.document.BindingOperation;
+import com.sun.tools.internal.ws.wsdl.document.BindingOutput;
+import com.sun.tools.internal.ws.wsdl.document.Definitions;
+import com.sun.tools.internal.ws.wsdl.document.Documentation;
+import com.sun.tools.internal.ws.wsdl.document.Fault;
+import com.sun.tools.internal.ws.wsdl.document.Import;
+import com.sun.tools.internal.ws.wsdl.document.Input;
+import com.sun.tools.internal.ws.wsdl.document.Message;
+import com.sun.tools.internal.ws.wsdl.document.MessagePart;
+import com.sun.tools.internal.ws.wsdl.document.Operation;
+import com.sun.tools.internal.ws.wsdl.document.OperationStyle;
+import com.sun.tools.internal.ws.wsdl.document.Output;
+import com.sun.tools.internal.ws.wsdl.document.Port;
+import com.sun.tools.internal.ws.wsdl.document.PortType;
+import com.sun.tools.internal.ws.wsdl.document.Service;
+import com.sun.tools.internal.ws.wsdl.document.Types;
+import com.sun.tools.internal.ws.wsdl.document.WSDLConstants;
+import com.sun.tools.internal.ws.wsdl.document.WSDLDocument;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaConstants;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaKinds;
+import com.sun.tools.internal.ws.wsdl.framework.Entity;
+import com.sun.tools.internal.ws.wsdl.framework.Extensible;
+import com.sun.tools.internal.ws.wsdl.framework.ParseException;
+import com.sun.tools.internal.ws.wsdl.framework.ParserContext;
+import com.sun.tools.internal.ws.wsdl.framework.ParserListener;
+import com.sun.tools.internal.ws.util.xml.XmlUtil;
+import com.sun.tools.internal.ws.processor.util.ProcessorEnvironment;
+import com.sun.tools.internal.ws.processor.config.WSDLModelInfo;
+
+/**
+ * A parser for WSDL documents.
+ *
+ * @author WS Development Team
+ */
+public class WSDLParser {
+    private WSDLModelInfo modelInfo;
+    private EntityResolver entityResolver;
+    //all the wsdl:import system Ids
+    private final Set<String> imports = new HashSet<String>();
+    //Map which holds wsdl Document(s) for a given SystemId
+    private final Map<String, Document> wsdlDocuments = new HashMap<String, Document>();
+
+    private WSDLParser() {
+        _extensionHandlers = new HashMap();
+        hSet = new HashSet();
+
+        // register handlers for default extensions
+        register(new SOAPExtensionHandler());
+        register(new HTTPExtensionHandler());
+        register(new MIMEExtensionHandler());
+        register(new SchemaExtensionHandler());
+        register(new JAXWSBindingExtensionHandler());
+        register(new SOAP12ExtensionHandler());
+    }
+
+    public WSDLParser(WSDLModelInfo modelInfo) {
+        this();
+        assert(modelInfo != null);
+        this.modelInfo = modelInfo;
+        this.entityResolver = modelInfo.getEntityResolver();
+    }
+
+    public void register(ExtensionHandler h) {
+        _extensionHandlers.put(h.getNamespaceURI(), h);
+        h.setExtensionHandlers(_extensionHandlers);
+    }
+
+    public void unregister(ExtensionHandler h) {
+        _extensionHandlers.put(h.getNamespaceURI(), null);
+        h.setExtensionHandlers(null);
+    }
+
+    public void unregister(String uri) {
+        _extensionHandlers.put(uri, null);
+    }
+
+    public boolean getFollowImports() {
+        return _followImports;
+    }
+
+    public void setFollowImports(boolean b) {
+        _followImports = b;
+    }
+
+    public void addParserListener(ParserListener l) {
+        if (_listeners == null) {
+            _listeners = new ArrayList();
+        }
+        _listeners.add(l);
+    }
+
+    public void removeParserListener(ParserListener l) {
+        if (_listeners == null) {
+            return;
+        }
+        _listeners.remove(l);
+    }
+
+//    public WSDLDocument parse(InputSource source) {
+//        _messageFactory =
+//            new LocalizableMessageFactory("com.sun.tools.internal.ws.resources.wsdl");
+//        _localizer = new Localizer();
+//
+//        WSDLDocument document = new WSDLDocument();
+//        document.setSystemId(source.getSystemId());
+//        ParserContext context = new ParserContext(document, _listeners);
+//        context.setFollowImports(_followImports);
+//        document.setDefinitions(parseDefinitions(context, source, null));
+//        return document;
+//    }
+
+    public WSDLDocument parse(){
+        String location = modelInfo.getLocation();
+        assert(location != null);
+        _messageFactory =
+            new LocalizableMessageFactory("com.sun.tools.internal.ws.resources.wsdl");
+        _localizer = new Localizer();
+
+        WSDLDocument document = new WSDLDocument();
+        InputSource source = null;
+        String wsdlLoc = JAXWSUtils.absolutize(JAXWSUtils.getFileOrURLName(location));
+        if(entityResolver != null){
+            try {
+                source = entityResolver.resolveEntity(null, wsdlLoc);
+            } catch (SAXException e) {
+                if (source.getSystemId() != null) {
+                    throw new ParseException(
+                        "parsing.saxExceptionWithSystemId",
+                        source.getSystemId(),e);
+                } else {
+                    throw new ParseException("parsing.saxException",e);
+                }
+            } catch (IOException e) {
+                if (source.getSystemId() != null) {
+                    throw new ParseException(
+                        "parsing.ioExceptionWithSystemId",
+                        source.getSystemId(),e);
+                } else {
+                    throw new ParseException("parsing.ioException",e);
+                }
+            }
+        }
+        if(source == null){
+            //default resolution
+            source = new InputSource(wsdlLoc);
+        }
+        document.setSystemId(wsdlLoc);
+        ParserContext context = new ParserContext(document, _listeners);
+        context.setFollowImports(_followImports);
+        document.setDefinitions(parseDefinitions(context, source, null));
+        return document;
+    }
+
+    protected Definitions parseDefinitions(ParserContext context,
+            InputSource source, String expectedTargetNamespaceURI) {
+        context.pushWSDLLocation();
+        context.setWSDLLocation(context.getDocument().getSystemId());
+        String sysId = context.getDocument().getSystemId();
+        buildDocumentFromWSDL(sysId, source, expectedTargetNamespaceURI);
+        Document root = wsdlDocuments.get(sysId);
+
+        //Internalizer.transform takes Set of jaxws:bindings elements, this is to allow multiple external
+        //bindings to be transformed.
+        new Internalizer().transform(modelInfo.getJAXWSBindings(), wsdlDocuments,
+                (ProcessorEnvironment)modelInfo.getParent().getEnvironment());
+
+        //print the wsdl
+//        try{
+//            dump(System.out);
+//        }catch(IOException e){
+//            e.printStackTrace();
+//        }
+
+        Definitions definitions = parseDefinitionsNoImport(context, root, expectedTargetNamespaceURI);
+        processImports(context, source, definitions);
+        context.popWSDLLocation();
+        return definitions;
+    }
+
+    /**
+     * @param systemId
+     * @param source
+     * @param expectedTargetNamespaceURI
+     */
+    private void buildDocumentFromWSDL(String systemId, InputSource source, String expectedTargetNamespaceURI) {
+        try {
+            DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
+            builderFactory.setNamespaceAware(true);
+            builderFactory.setValidating(false);
+            DocumentBuilder builder = builderFactory.newDocumentBuilder();
+            builder.setErrorHandler(new ErrorHandler() {
+                public void error(SAXParseException e)
+                    throws SAXParseException {
+                    throw e;
+                }
+
+                public void fatalError(SAXParseException e)
+                    throws SAXParseException {
+                    throw e;
+                }
+
+                public void warning(SAXParseException err)
+                    throws SAXParseException {
+                    // do nothing
+                }
+            });
+            if(entityResolver != null)
+                builder.setEntityResolver(entityResolver);
+            else
+                builder.setEntityResolver(new NullEntityResolver());
+
+            try {
+                Document document = builder.parse(source);
+                wsdlDocuments.put(systemId, document);
+                Element e = document.getDocumentElement();
+                Util.verifyTagNSRootElement(e, WSDLConstants.QNAME_DEFINITIONS);
+                String name = XmlUtil.getAttributeOrNull(e, Constants.ATTR_NAME);
+
+                String _targetNamespaceURI =
+                    XmlUtil.getAttributeOrNull(e, Constants.ATTR_TARGET_NAMESPACE);
+
+                if (expectedTargetNamespaceURI != null
+                    && !expectedTargetNamespaceURI.equals(_targetNamespaceURI)){
+                    //TODO: throw an exception???
+                }
+
+                for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+                    Element e2 = Util.nextElement(iter);
+                    if (e2 == null)
+                        break;
+
+                    //check to see if it has imports
+                    if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_IMPORT)){
+                        String namespace = Util.getRequiredAttribute(e2, Constants.ATTR_NAMESPACE);
+                        String location = Util.getRequiredAttribute(e2, Constants.ATTR_LOCATION);
+                        location = getAdjustedLocation(source, location);
+                        if(location != null && !location.equals("")){
+                            if(!imports.contains(location)){
+                                imports.add(location);
+                                InputSource impSource = null;
+                                if(entityResolver != null){
+                                    impSource = entityResolver.resolveEntity(null, location);
+                                }
+
+                                if(impSource==null)
+                                    impSource = new InputSource(location);  // default resolution{
+
+                                buildDocumentFromWSDL(location, impSource, namespace);
+                            }
+                        }
+                    }
+                }
+            } catch (IOException e) {
+                if (source.getSystemId() != null) {
+                    throw new ParseException(
+                        "parsing.ioExceptionWithSystemId",
+                        source.getSystemId(),e);
+                } else {
+                    throw new ParseException("parsing.ioException",e);
+                }
+            } catch (SAXException e) {
+                if (source.getSystemId() != null) {
+                    throw new ParseException(
+                        "parsing.saxExceptionWithSystemId",
+                        source.getSystemId(),e);
+                } else {
+                    throw new ParseException("parsing.saxException",e);
+                }
+            }
+        } catch (ParserConfigurationException e) {
+            throw new ParseException(
+                "parsing.parserConfigException",e);
+        } catch (FactoryConfigurationError e) {
+            throw new ParseException(
+                "parsing.factoryConfigException",e);
+        }
+    }
+
+    private String getAdjustedLocation(InputSource source, String location) {
+        return source.getSystemId() == null
+            ? location
+            : Util.processSystemIdWithBase(
+                source.getSystemId(),
+                location);
+    }
+
+    /**
+     * Dumps the contents of the forest to the specified stream.
+     *
+     * This is a debug method. As such, error handling is sloppy.
+     */
+    public void dump( OutputStream out ) throws IOException {
+        try {
+            // create identity transformer
+            Transformer it = XmlUtil.newTransformer();
+
+            for( Iterator itr=wsdlDocuments.entrySet().iterator(); itr.hasNext(); ) {
+                Map.Entry e = (Map.Entry)itr.next();
+
+                out.write( ("---<< "+e.getKey()+"\n").getBytes() );
+
+                it.transform( new DOMSource((Document)e.getValue()), new StreamResult(out) );
+
+                out.write( "\n\n\n".getBytes() );
+            }
+        } catch( TransformerException e ) {
+            e.printStackTrace();
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see WSDLParser#processImports(ParserContext, org.xml.sax.InputSource, Definitions)
+     */
+    protected void processImports(ParserContext context, InputSource source, Definitions definitions) {
+        for(String location : imports){
+            if (!context.getDocument().isImportedDocument(location)){
+                Definitions importedDefinitions = parseDefinitionsNoImport(context,
+                        wsdlDocuments.get(location), location);
+                if(importedDefinitions == null)
+                    continue;
+                context.getDocument().addImportedEntity(importedDefinitions);
+                context.getDocument().addImportedDocument(location);
+            }
+        }
+    }
+
+    protected Definitions parseDefinitionsNoImport(
+        ParserContext context,
+        InputSource source,
+        String expectedTargetNamespaceURI) {
+        try {
+            DocumentBuilderFactory builderFactory =
+                DocumentBuilderFactory.newInstance();
+            builderFactory.setNamespaceAware(true);
+            builderFactory.setValidating(false);
+            DocumentBuilder builder = builderFactory.newDocumentBuilder();
+            builder.setErrorHandler(new ErrorHandler() {
+                public void error(SAXParseException e)
+                    throws SAXParseException {
+                    throw e;
+                }
+
+                public void fatalError(SAXParseException e)
+                    throws SAXParseException {
+                    throw e;
+                }
+
+                public void warning(SAXParseException err)
+                    throws SAXParseException {
+                    // do nothing
+                }
+            });
+            builder.setEntityResolver(new NullEntityResolver());
+
+            try {
+                Document document = builder.parse(source);
+                return parseDefinitionsNoImport(
+                    context,
+                    document,
+                    expectedTargetNamespaceURI);
+            } catch (IOException e) {
+                if (source.getSystemId() != null) {
+                    throw new ParseException(
+                        "parsing.ioExceptionWithSystemId",
+                        source.getSystemId(),e);
+                } else {
+                    throw new ParseException("parsing.ioException",e);
+                }
+            } catch (SAXException e) {
+                if (source.getSystemId() != null) {
+                    throw new ParseException(
+                        "parsing.saxExceptionWithSystemId",
+                        source.getSystemId(),
+                        e);
+                } else {
+                    throw new ParseException("parsing.saxException",e);
+                }
+            }
+        } catch (ParserConfigurationException e) {
+            throw new ParseException("parsing.parserConfigException",e);
+        } catch (FactoryConfigurationError e) {
+            throw new ParseException("parsing.factoryConfigException",e);
+        }
+    }
+
+    protected Definitions parseDefinitionsNoImport(
+        ParserContext context,
+        Document doc,
+        String expectedTargetNamespaceURI) {
+        _targetNamespaceURI = null;
+        Element root = doc.getDocumentElement();
+        Util.verifyTagNSRootElement(root, WSDLConstants.QNAME_DEFINITIONS);
+        return parseDefinitionsNoImport(
+            context,
+            root,
+            expectedTargetNamespaceURI);
+    }
+
+    protected Definitions parseDefinitionsNoImport(
+        ParserContext context,
+        Element e,
+        String expectedTargetNamespaceURI) {
+        context.push();
+        context.registerNamespaces(e);
+
+        Definitions definitions = new Definitions(context.getDocument());
+        String name = XmlUtil.getAttributeOrNull(e, Constants.ATTR_NAME);
+        definitions.setName(name);
+
+        _targetNamespaceURI =
+            XmlUtil.getAttributeOrNull(e, Constants.ATTR_TARGET_NAMESPACE);
+
+        definitions.setTargetNamespaceURI(_targetNamespaceURI);
+
+        boolean gotDocumentation = false;
+        boolean gotTypes = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                if(definitions.getDocumentation() == null)
+                    definitions.setDocumentation(getDocumentationFor(e2));
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_TYPES)) {
+                if (gotTypes) {
+                    Util.fail(
+                        "parsing.onlyOneTypesAllowed",
+                        Constants.TAG_DEFINITIONS);
+                }
+                //add all the wsdl:type elements to latter make a list of all the schema elements
+                // that will be needed to create jaxb model
+                addSchemaElements(e2);
+
+                //definitions.setTypes(parseTypes(context, definitions, e2));
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_MESSAGE)) {
+                Message message = parseMessage(context, definitions, e2);
+                definitions.add(message);
+            } else if (
+                XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_PORT_TYPE)) {
+                PortType portType = parsePortType(context, definitions, e2);
+                definitions.add(portType);
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_BINDING)) {
+                Binding binding = parseBinding(context, definitions, e2);
+                definitions.add(binding);
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_SERVICE)) {
+                Service service = parseService(context, definitions, e2);
+                definitions.add(service);
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_IMPORT)) {
+                definitions.add(parseImport(context, definitions, e2));
+            } else if (
+                (_useWSIBasicProfile)
+                    && (XmlUtil.matchesTagNS(e2, SchemaConstants.QNAME_IMPORT))) {
+                warn("warning.wsi.r2003");
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e2);
+                if (!handleExtension(context, definitions, e2)) {
+                    checkNotWsdlRequired(e2);
+                }
+            }
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(
+            WSDLConstants.QNAME_DEFINITIONS,
+            definitions);
+        return definitions;
+    }
+
+    protected Message parseMessage(
+        ParserContext context,
+        Definitions definitions,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        Message message = new Message(definitions);
+        String name = Util.getRequiredAttribute(e, Constants.ATTR_NAME);
+        message.setName(name);
+
+        boolean gotDocumentation = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                message.setDocumentation(getDocumentationFor(e2));
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_PART)) {
+                MessagePart part = parseMessagePart(context, e2);
+                message.add(part);
+            } else {
+                Util.fail(
+                    "parsing.invalidElement",
+                    e2.getTagName(),
+                    e2.getNamespaceURI());
+            }
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_MESSAGE, message);
+        return message;
+    }
+
+    protected MessagePart parseMessagePart(ParserContext context, Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        MessagePart part = new MessagePart();
+        String partName = Util.getRequiredAttribute(e, Constants.ATTR_NAME);
+        part.setName(partName);
+
+        String elementAttr =
+            XmlUtil.getAttributeOrNull(e, Constants.ATTR_ELEMENT);
+        String typeAttr = XmlUtil.getAttributeOrNull(e, Constants.ATTR_TYPE);
+
+        if (elementAttr != null) {
+            if (typeAttr != null) {
+                Util.fail("parsing.onlyOneOfElementOrTypeRequired", partName);
+            }
+
+            part.setDescriptor(context.translateQualifiedName(elementAttr));
+            part.setDescriptorKind(SchemaKinds.XSD_ELEMENT);
+        } else if (typeAttr != null) {
+            part.setDescriptor(context.translateQualifiedName(typeAttr));
+            part.setDescriptorKind(SchemaKinds.XSD_TYPE);
+        } else {
+            // XXX-NOTE - this is wrong; for extensibility purposes,
+            // any attribute can be specified on a <part> element, so
+            // we need to put an extensibility hook here
+            Util.fail("parsing.elementOrTypeRequired", partName);
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_PART, part);
+        return part;
+    }
+
+    protected PortType parsePortType(
+        ParserContext context,
+        Definitions definitions,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        PortType portType = new PortType(definitions);
+        String name = Util.getRequiredAttribute(e, Constants.ATTR_NAME);
+        portType.setName(name);
+
+        boolean gotDocumentation = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                if(portType.getDocumentation() == null)
+                    portType.setDocumentation(getDocumentationFor(e2));
+            } else if (
+                XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_OPERATION)) {
+                Operation op = parsePortTypeOperation(context, e2);
+                portType.add(op);
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e2);
+                if (!handleExtension(context, portType, e2)) {
+                    checkNotWsdlRequired(e2);
+                }
+            }/*else {
+                Util.fail(
+                    "parsing.invalidElement",
+                    e2.getTagName(),
+                    e2.getNamespaceURI());
+            }*/
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_PORT_TYPE, portType);
+        return portType;
+    }
+
+    protected Operation parsePortTypeOperation(
+        ParserContext context,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+
+        Operation operation = new Operation();
+        String name = Util.getRequiredAttribute(e, Constants.ATTR_NAME);
+        operation.setName(name);
+        String parameterOrderAttr =
+            XmlUtil.getAttributeOrNull(e, Constants.ATTR_PARAMETER_ORDER);
+        operation.setParameterOrder(parameterOrderAttr);
+
+        boolean gotDocumentation = false;
+
+        boolean gotInput = false;
+        boolean gotOutput = false;
+        boolean gotFault = false;
+        boolean inputBeforeOutput = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                if(operation.getDocumentation() == null)
+                    operation.setDocumentation(getDocumentationFor(e2));
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_INPUT)) {
+                if (gotInput) {
+                    Util.fail(
+                        "parsing.tooManyElements",
+                        new Object[] {
+                            Constants.TAG_INPUT,
+                            Constants.TAG_OPERATION,
+                            name });
+                }
+
+                context.push();
+                context.registerNamespaces(e2);
+                Input input = new Input();
+                String messageAttr =
+                    Util.getRequiredAttribute(e2, Constants.ATTR_MESSAGE);
+                input.setMessage(context.translateQualifiedName(messageAttr));
+                String nameAttr =
+                    XmlUtil.getAttributeOrNull(e2, Constants.ATTR_NAME);
+                input.setName(nameAttr);
+                operation.setInput(input);
+                gotInput = true;
+                if (gotOutput) {
+                    inputBeforeOutput = false;
+                }
+
+                // verify that there is at most one child element and it is a documentation element
+                boolean gotDocumentation2 = false;
+                for (Iterator iter2 = XmlUtil.getAllChildren(e2);
+                    iter2.hasNext();
+                    ) {
+                    Element e3 = Util.nextElement(iter2);
+                    if (e3 == null)
+                        break;
+
+                    if (XmlUtil
+                        .matchesTagNS(e3, WSDLConstants.QNAME_DOCUMENTATION)) {
+                        if (gotDocumentation2) {
+                            Util.fail(
+                                "parsing.onlyOneDocumentationAllowed",
+                                e.getLocalName());
+                        }
+                        gotDocumentation2 = true;
+                        input.setDocumentation(getDocumentationFor(e3));
+                    } else {
+                        Util.fail(
+                            "parsing.invalidElement",
+                            e3.getTagName(),
+                            e3.getNamespaceURI());
+                    }
+                }
+                context.pop();
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_OUTPUT)) {
+                if (gotOutput) {
+                    Util.fail(
+                        "parsing.tooManyElements",
+                        new Object[] {
+                            Constants.TAG_OUTPUT,
+                            Constants.TAG_OPERATION,
+                            name });
+                }
+
+                context.push();
+                context.registerNamespaces(e2);
+                Output output = new Output();
+                String messageAttr =
+                    Util.getRequiredAttribute(e2, Constants.ATTR_MESSAGE);
+                output.setMessage(context.translateQualifiedName(messageAttr));
+                String nameAttr =
+                    XmlUtil.getAttributeOrNull(e2, Constants.ATTR_NAME);
+                output.setName(nameAttr);
+                operation.setOutput(output);
+                gotOutput = true;
+                if (gotInput) {
+                    inputBeforeOutput = true;
+                }
+
+                // verify that there is at most one child element and it is a documentation element
+                boolean gotDocumentation2 = false;
+                for (Iterator iter2 = XmlUtil.getAllChildren(e2);
+                    iter2.hasNext();
+                    ) {
+                    Element e3 = Util.nextElement(iter2);
+                    if (e3 == null)
+                        break;
+
+                    if (XmlUtil
+                        .matchesTagNS(e3, WSDLConstants.QNAME_DOCUMENTATION)) {
+                        if (gotDocumentation2) {
+                            Util.fail(
+                                "parsing.onlyOneDocumentationAllowed",
+                                e.getLocalName());
+                        }
+                        gotDocumentation2 = true;
+                        output.setDocumentation(getDocumentationFor(e3));
+                    } else {
+                        Util.fail(
+                            "parsing.invalidElement",
+                            e3.getTagName(),
+                            e3.getNamespaceURI());
+                    }
+                }
+                context.pop();
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_FAULT)) {
+                context.push();
+                context.registerNamespaces(e2);
+                Fault fault = new Fault();
+                String messageAttr =
+                    Util.getRequiredAttribute(e2, Constants.ATTR_MESSAGE);
+                fault.setMessage(context.translateQualifiedName(messageAttr));
+                String nameAttr =
+                    XmlUtil.getAttributeOrNull(e2, Constants.ATTR_NAME);
+                fault.setName(nameAttr);
+                operation.addFault(fault);
+                gotFault = true;
+
+                // verify that there is at most one child element and it is a documentation element
+                boolean gotDocumentation2 = false;
+                for (Iterator iter2 = XmlUtil.getAllChildren(e2);
+                    iter2.hasNext();
+                    ) {
+                    Element e3 = Util.nextElement(iter2);
+                    if (e3 == null)
+                        break;
+
+                    if (XmlUtil
+                        .matchesTagNS(e3, WSDLConstants.QNAME_DOCUMENTATION)) {
+                        if (gotDocumentation2) {
+                            Util.fail(
+                                "parsing.onlyOneDocumentationAllowed",
+                                e.getLocalName());
+                        }
+                        gotDocumentation2 = true;
+                        if(fault.getDocumentation() == null)
+                            fault.setDocumentation(getDocumentationFor(e3));
+                    } else {
+                        // possible extensibility element -- must live outside the WSDL namespace
+                        checkNotWsdlElement(e3);
+                        if (!handleExtension(context, fault, e3)) {
+                            checkNotWsdlRequired(e3);
+                        }
+                    }/*else {
+                        Util.fail(
+                            "parsing.invalidElement",
+                            e3.getTagName(),
+                            e3.getNamespaceURI());
+                    }*/
+                }
+                context.pop();
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e2);
+                if (!handleExtension(context, operation, e2)) {
+                    checkNotWsdlRequired(e2);
+                }
+            }/*else {
+                Util.fail(
+                    "parsing.invalidElement",
+                    e2.getTagName(),
+                    e2.getNamespaceURI());
+            }*/
+        }
+
+        if (gotInput && !gotOutput && !gotFault) {
+            operation.setStyle(OperationStyle.ONE_WAY);
+        } else if (gotInput && gotOutput && inputBeforeOutput) {
+            operation.setStyle(OperationStyle.REQUEST_RESPONSE);
+        } else if (gotInput && gotOutput && !inputBeforeOutput) {
+            operation.setStyle(OperationStyle.SOLICIT_RESPONSE);
+        } else if (gotOutput && !gotInput && !gotFault) {
+            operation.setStyle(OperationStyle.NOTIFICATION);
+        } else {
+            Util.fail("parsing.invalidOperationStyle", name);
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_OPERATION, operation);
+        return operation;
+    }
+
+    protected Binding parseBinding(
+        ParserContext context,
+        Definitions definitions,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        Binding binding = new Binding(definitions);
+        String name = Util.getRequiredAttribute(e, Constants.ATTR_NAME);
+        binding.setName(name);
+        String typeAttr = Util.getRequiredAttribute(e, Constants.ATTR_TYPE);
+        binding.setPortType(context.translateQualifiedName(typeAttr));
+
+        boolean gotDocumentation = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                binding.setDocumentation(getDocumentationFor(e2));
+            } else if (
+                XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_OPERATION)) {
+                BindingOperation op = parseBindingOperation(context, e2);
+                binding.add(op);
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e2);
+                if (!handleExtension(context, binding, e2)) {
+                    checkNotWsdlRequired(e2);
+                }
+            }
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_BINDING, binding);
+        return binding;
+    }
+
+    protected BindingOperation parseBindingOperation(
+        ParserContext context,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        BindingOperation operation = new BindingOperation();
+        String name = Util.getRequiredAttribute(e, Constants.ATTR_NAME);
+        operation.setName(name);
+
+        boolean gotDocumentation = false;
+
+        boolean gotInput = false;
+        boolean gotOutput = false;
+        boolean gotFault = false;
+        boolean inputBeforeOutput = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                operation.setDocumentation(getDocumentationFor(e2));
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_INPUT)) {
+                if (gotInput) {
+                    Util.fail(
+                        "parsing.tooManyElements",
+                        new Object[] {
+                            Constants.TAG_INPUT,
+                            Constants.TAG_OPERATION,
+                            name });
+                }
+
+                /* Here we check for the use scenario */
+                Iterator itere2 = XmlUtil.getAllChildren(e2);
+                Element ee = Util.nextElement(itere2);
+                if (hSet.isEmpty()) {
+                    hSet.add(ee.getAttribute("use"));
+                } else {
+                    /* this codition will happen when the wsdl used has a mixture of
+                       literal and encoded style */
+                    if (!hSet.contains(ee.getAttribute("use"))
+                        && (ee.getAttribute("use") != "")) {
+                        hSet.add(ee.getAttribute("use"));
+                    }
+                }
+
+                context.push();
+                context.registerNamespaces(e2);
+                BindingInput input = new BindingInput();
+                String nameAttr =
+                    XmlUtil.getAttributeOrNull(e2, Constants.ATTR_NAME);
+                input.setName(nameAttr);
+                operation.setInput(input);
+                gotInput = true;
+                if (gotOutput) {
+                    inputBeforeOutput = false;
+                }
+
+                // verify that there is at most one child element and it is a documentation element
+                boolean gotDocumentation2 = false;
+                for (Iterator iter2 = XmlUtil.getAllChildren(e2);
+                    iter2.hasNext();
+                    ) {
+                    Element e3 = Util.nextElement(iter2);
+                    if (e3 == null)
+                        break;
+
+                    if (XmlUtil
+                        .matchesTagNS(e3, WSDLConstants.QNAME_DOCUMENTATION)) {
+                        if (gotDocumentation2) {
+                            Util.fail(
+                                "parsing.onlyOneDocumentationAllowed",
+                                e.getLocalName());
+                        }
+                        gotDocumentation2 = true;
+                        input.setDocumentation(getDocumentationFor(e3));
+                    } else {
+                        // possible extensibility element -- must live outside the WSDL namespace
+                        checkNotWsdlElement(e3);
+                        if (!handleExtension(context, input, e3)) {
+                            checkNotWsdlRequired(e3);
+                        }
+                    }
+                }
+                context.pop();
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_OUTPUT)) {
+                if (gotOutput) {
+                    Util.fail(
+                        "parsing.tooManyElements",
+                        new Object[] {
+                            Constants.TAG_OUTPUT,
+                            Constants.TAG_OPERATION,
+                            name });
+                }
+
+                context.push();
+                context.registerNamespaces(e2);
+                BindingOutput output = new BindingOutput();
+                String nameAttr =
+                    XmlUtil.getAttributeOrNull(e2, Constants.ATTR_NAME);
+                output.setName(nameAttr);
+                operation.setOutput(output);
+                gotOutput = true;
+                if (gotInput) {
+                    inputBeforeOutput = true;
+                }
+
+                // verify that there is at most one child element and it is a documentation element
+                boolean gotDocumentation2 = false;
+                for (Iterator iter2 = XmlUtil.getAllChildren(e2);
+                    iter2.hasNext();
+                    ) {
+
+                    Element e3 = Util.nextElement(iter2);
+                    if (e3 == null)
+                        break;
+
+                    if (XmlUtil
+                        .matchesTagNS(e3, WSDLConstants.QNAME_DOCUMENTATION)) {
+                        if (gotDocumentation2) {
+                            Util.fail(
+                                "parsing.onlyOneDocumentationAllowed",
+                                e.getLocalName());
+                        }
+                        gotDocumentation2 = true;
+                        output.setDocumentation(getDocumentationFor(e3));
+                    } else {
+                        // possible extensibility element -- must live outside the WSDL namespace
+                        checkNotWsdlElement(e3);
+                        if (!handleExtension(context, output, e3)) {
+                            checkNotWsdlRequired(e3);
+                        }
+                    }
+                }
+                context.pop();
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_FAULT)) {
+                context.push();
+                context.registerNamespaces(e2);
+                BindingFault fault = new BindingFault();
+                String nameAttr =
+                    Util.getRequiredAttribute(e2, Constants.ATTR_NAME);
+                fault.setName(nameAttr);
+                operation.addFault(fault);
+                gotFault = true;
+
+                // verify that there is at most one child element and it is a documentation element
+                boolean gotDocumentation2 = false;
+                for (Iterator iter2 = XmlUtil.getAllChildren(e2);
+                    iter2.hasNext();
+                    ) {
+                    Element e3 = Util.nextElement(iter2);
+                    if (e3 == null)
+                        break;
+
+                    if (XmlUtil
+                        .matchesTagNS(e3, WSDLConstants.QNAME_DOCUMENTATION)) {
+                        if (gotDocumentation2) {
+                            Util.fail(
+                                "parsing.onlyOneDocumentationAllowed",
+                                e.getLocalName());
+                        }
+                        gotDocumentation2 = true;
+                        if(fault.getDocumentation() == null)
+                            fault.setDocumentation(getDocumentationFor(e3));
+                    } else {
+                        // possible extensibility element -- must live outside the WSDL namespace
+                        checkNotWsdlElement(e3);
+                        if (!handleExtension(context, fault, e3)) {
+                            checkNotWsdlRequired(e3);
+                        }
+                    }
+                }
+                context.pop();
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e2);
+                if (!handleExtension(context, operation, e2)) {
+                    checkNotWsdlRequired(e2);
+                }
+            }
+        }
+
+        if (gotInput && !gotOutput && !gotFault) {
+            operation.setStyle(OperationStyle.ONE_WAY);
+        } else if (gotInput && gotOutput && inputBeforeOutput) {
+            operation.setStyle(OperationStyle.REQUEST_RESPONSE);
+        } else if (gotInput && gotOutput && !inputBeforeOutput) {
+            operation.setStyle(OperationStyle.SOLICIT_RESPONSE);
+        } else if (gotOutput && !gotInput && !gotFault) {
+            operation.setStyle(OperationStyle.NOTIFICATION);
+        } else {
+            Util.fail("parsing.invalidOperationStyle", name);
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_OPERATION, operation);
+        return operation;
+    }
+
+    protected Import parseImport(
+        ParserContext context,
+        Definitions definitions,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        Import anImport = new Import();
+        String namespace =
+            Util.getRequiredAttribute(e, Constants.ATTR_NAMESPACE);
+        anImport.setNamespace(namespace);
+        String location = Util.getRequiredAttribute(e, Constants.ATTR_LOCATION);
+        anImport.setLocation(location);
+
+        // according to the schema in the WSDL 1.1 spec, an import can have a documentation element
+        boolean gotDocumentation = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                anImport.setDocumentation(getDocumentationFor(e2));
+            } else {
+                Util.fail(
+                    "parsing.invalidElement",
+                    e2.getTagName(),
+                    e2.getNamespaceURI());
+            }
+        }
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_IMPORT, anImport);
+        return anImport;
+    }
+
+    protected Service parseService(
+        ParserContext context,
+        Definitions definitions,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        Service service = new Service(definitions);
+        String name = Util.getRequiredAttribute(e, Constants.ATTR_NAME);
+        service.setName(name);
+
+        boolean gotDocumentation = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                if(service.getDocumentation() == null)
+                    service.setDocumentation(getDocumentationFor(e2));
+            } else if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_PORT)) {
+                Port port = parsePort(context, definitions, e2);
+                service.add(port);
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e2);
+                if (!handleExtension(context, service, e2)) {
+                    checkNotWsdlRequired(e2);
+                }
+            }
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_SERVICE, service);
+        return service;
+    }
+
+    protected Port parsePort(
+        ParserContext context,
+        Definitions definitions,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+
+        Port port = new Port(definitions);
+        String name = Util.getRequiredAttribute(e, Constants.ATTR_NAME);
+        port.setName(name);
+
+        String bindingAttr =
+            Util.getRequiredAttribute(e, Constants.ATTR_BINDING);
+        port.setBinding(context.translateQualifiedName(bindingAttr));
+
+        boolean gotDocumentation = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                if(port.getDocumentation() == null)
+                    port.setDocumentation(getDocumentationFor(e2));
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e2);
+                if (!handleExtension(context, port, e2)) {
+                    checkNotWsdlRequired(e2);
+                }
+            }
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_PORT, port);
+        return port;
+    }
+
+    protected Types parseTypes(
+        ParserContext context,
+        Definitions definitions,
+        Element e) {
+        context.push();
+        context.registerNamespaces(e);
+        Types types = new Types();
+
+        boolean gotDocumentation = false;
+
+        for (Iterator iter = XmlUtil.getAllChildren(e); iter.hasNext();) {
+            Element e2 = Util.nextElement(iter);
+            if (e2 == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e2, WSDLConstants.QNAME_DOCUMENTATION)) {
+                if (gotDocumentation) {
+                    Util.fail(
+                        "parsing.onlyOneDocumentationAllowed",
+                        e.getLocalName());
+                }
+                gotDocumentation = true;
+                types.setDocumentation(getDocumentationFor(e2));
+            } //bug fix 4854004
+            else if (
+                (_useWSIBasicProfile)
+                    && (XmlUtil.matchesTagNS(e2, SchemaConstants.QNAME_IMPORT))) {
+                warn("warning.wsi.r2003");
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e2);
+                try {
+                    if (!handleExtension(context, types, e2)) {
+                        checkNotWsdlRequired(e2);
+                    }
+                } catch (ParseException pe) {
+                    if (pe.getKey().equals("parsing.incorrectRootElement")) {
+                        if (_useWSIBasicProfile) {
+                            warn("warning.wsi.r2004");
+                        }
+                        throw pe;
+                    }
+                }
+            }
+        }
+
+        context.pop();
+        context.fireDoneParsingEntity(WSDLConstants.QNAME_TYPES, types);
+        return types;
+    }
+
+    private List _elements = new ArrayList();
+
+    public void addSchemaElements(Element typesElement){
+        for (Iterator iter = XmlUtil.getAllChildren(typesElement); iter.hasNext();) {
+            Element e = Util.nextElement(iter);
+            if (e == null)
+                break;
+
+            if (XmlUtil.matchesTagNS(e, SchemaConstants.QNAME_SCHEMA)) {
+                _elements.add(e);
+            } else {
+                // possible extensibility element -- must live outside the WSDL namespace
+                checkNotWsdlElement(e);
+            }
+        }
+    }
+
+    public List getSchemaElements(){
+        return _elements;
+    }
+
+    protected boolean handleExtension(
+        ParserContext context,
+        Extensible entity,
+        Element e) {
+        ExtensionHandler h =
+            (ExtensionHandler) _extensionHandlers.get(e.getNamespaceURI());
+        if (h == null) {
+            context.fireIgnoringExtension(
+                new QName(e.getNamespaceURI(), e.getLocalName()),
+                ((Entity) entity).getElementName());
+            return false;
+        } else {
+            return h.doHandleExtension(context, entity, e);
+        }
+    }
+
+    protected void checkNotWsdlElement(Element e) {
+        // possible extensibility element -- must live outside the WSDL namespace
+        if (e.getNamespaceURI().equals(Constants.NS_WSDL))
+            Util.fail("parsing.invalidWsdlElement", e.getTagName());
+    }
+
+    protected void checkNotWsdlRequired(Element e) {
+        // check the wsdl:required attribute, fail if set to "true"
+        String required =
+            XmlUtil.getAttributeNSOrNull(
+                e,
+                Constants.ATTR_REQUIRED,
+                Constants.NS_WSDL);
+        if (required != null && required.equals(Constants.TRUE)) {
+            Util.fail(
+                "parsing.requiredExtensibilityElement",
+                e.getTagName(),
+                e.getNamespaceURI());
+        }
+    }
+
+    protected Documentation getDocumentationFor(Element e) {
+        String s = XmlUtil.getTextForNode(e);
+        if (s == null) {
+            return null;
+        } else {
+            return new Documentation(s);
+        }
+    }
+
+    protected void error(String key) {
+        System.err.println(
+            _localizer.localize(_messageFactory.getMessage(key)));
+    }
+
+    public HashSet getUse() {
+        return hSet;
+    }
+
+    protected void warn(String key) {
+        System.err.println(
+            _localizer.localize(_messageFactory.getMessage(key)));
+    }
+
+    protected void warn(String key, String arg) {
+        System.err.println(
+            _localizer.localize(_messageFactory.getMessage(key, arg)));
+    }
+
+    protected void warn(String key, Object[] args) {
+        System.err.println(
+            _localizer.localize(_messageFactory.getMessage(key, args)));
+    }
+
+    private boolean _followImports;
+    private String _targetNamespaceURI;
+    private Map _extensionHandlers;
+    private ArrayList _listeners;
+    private boolean _useWSIBasicProfile = true;
+    private LocalizableMessageFactory _messageFactory = null;
+    private Localizer _localizer;
+    private HashSet hSet = null;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/WSDLWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/WSDLWriter.java
new file mode 100644
index 0000000..e169c88
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/ws/wsdl/parser/WSDLWriter.java
@@ -0,0 +1,371 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.ws.wsdl.parser;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.ws.wsdl.document.Binding;
+import com.sun.tools.internal.ws.wsdl.document.BindingFault;
+import com.sun.tools.internal.ws.wsdl.document.BindingInput;
+import com.sun.tools.internal.ws.wsdl.document.BindingOperation;
+import com.sun.tools.internal.ws.wsdl.document.BindingOutput;
+import com.sun.tools.internal.ws.wsdl.document.Definitions;
+import com.sun.tools.internal.ws.wsdl.document.Documentation;
+import com.sun.tools.internal.ws.wsdl.document.Fault;
+import com.sun.tools.internal.ws.wsdl.document.Import;
+import com.sun.tools.internal.ws.wsdl.document.Input;
+import com.sun.tools.internal.ws.wsdl.document.Message;
+import com.sun.tools.internal.ws.wsdl.document.MessagePart;
+import com.sun.tools.internal.ws.wsdl.document.Operation;
+import com.sun.tools.internal.ws.wsdl.document.Output;
+import com.sun.tools.internal.ws.wsdl.document.Port;
+import com.sun.tools.internal.ws.wsdl.document.PortType;
+import com.sun.tools.internal.ws.wsdl.document.Service;
+import com.sun.tools.internal.ws.wsdl.document.Types;
+import com.sun.tools.internal.ws.wsdl.document.WSDLConstants;
+import com.sun.tools.internal.ws.wsdl.document.WSDLDocument;
+import com.sun.tools.internal.ws.wsdl.document.WSDLDocumentVisitor;
+import com.sun.tools.internal.ws.wsdl.document.schema.SchemaKinds;
+import com.sun.tools.internal.ws.wsdl.document.jaxws.JAXWSBindingsConstants;
+import com.sun.tools.internal.ws.wsdl.framework.Extension;
+import com.sun.tools.internal.ws.wsdl.framework.Kind;
+import com.sun.tools.internal.ws.wsdl.framework.WriterContext;
+
+/**
+ * A writer for WSDL documents.
+ *
+ * @author WS Development Team
+ */
+public class WSDLWriter {
+
+    public WSDLWriter() throws IOException {
+        _extensionHandlers = new HashMap();
+
+        // register handlers for default extensions
+        register(new SOAPExtensionHandler());
+        register(new HTTPExtensionHandler());
+        register(new MIMEExtensionHandler());
+        register(new SchemaExtensionHandler());
+        register(new JAXWSBindingExtensionHandler());
+    }
+
+    public void register(ExtensionHandler h) {
+        _extensionHandlers.put(h.getNamespaceURI(), h);
+        h.setExtensionHandlers(_extensionHandlers);
+    }
+
+    public void unregister(ExtensionHandler h) {
+        _extensionHandlers.put(h.getNamespaceURI(), null);
+        h.setExtensionHandlers(null);
+    }
+
+    public void unregister(String uri) {
+        _extensionHandlers.put(uri, null);
+    }
+
+    public void write(final WSDLDocument document, OutputStream os)
+        throws IOException {
+        final WriterContext context = new WriterContext(os);
+        try {
+            document.accept(new WSDLDocumentVisitor() {
+                public void preVisit(Definitions definitions)
+                    throws Exception {
+                    context.push();
+                    initializePrefixes(context, document);
+                    context.writeStartTag(definitions.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        definitions.getName());
+                    context.writeAttribute(
+                        Constants.ATTR_TARGET_NAMESPACE,
+                        definitions.getTargetNamespaceURI());
+                    context.writeAllPendingNamespaceDeclarations();
+                }
+                public void postVisit(Definitions definitions)
+                    throws Exception {
+                    context.writeEndTag(definitions.getElementName());
+                    context.pop();
+                }
+                public void visit(Import i) throws Exception {
+                    context.writeStartTag(i.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAMESPACE,
+                        i.getNamespace());
+                    context.writeAttribute(
+                        Constants.ATTR_LOCATION,
+                        i.getLocation());
+                    context.writeEndTag(i.getElementName());
+                }
+                public void preVisit(Types types) throws Exception {
+                    context.writeStartTag(types.getElementName());
+                }
+                public void postVisit(Types types) throws Exception {
+                    context.writeEndTag(types.getElementName());
+                }
+                public void preVisit(Message message) throws Exception {
+                    context.writeStartTag(message.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        message.getName());
+                }
+                public void postVisit(Message message) throws Exception {
+                    context.writeEndTag(message.getElementName());
+                }
+                public void visit(MessagePart part) throws Exception {
+                    context.writeStartTag(part.getElementName());
+                    context.writeAttribute(Constants.ATTR_NAME, part.getName());
+
+                    QName dname = part.getDescriptor();
+                    Kind dkind = part.getDescriptorKind();
+                    if (dname != null && dkind != null) {
+                        if (dkind.equals(SchemaKinds.XSD_ELEMENT)) {
+                            context.writeAttribute(
+                                Constants.ATTR_ELEMENT,
+                                dname);
+                        } else if (dkind.equals(SchemaKinds.XSD_TYPE)) {
+                            context.writeAttribute(Constants.ATTR_TYPE, dname);
+                        } else {
+                            // TODO - add support for attribute extensions here
+                        }
+                    }
+                    context.writeEndTag(part.getElementName());
+                }
+                public void preVisit(PortType portType) throws Exception {
+                    context.writeStartTag(portType.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        portType.getName());
+                }
+                public void postVisit(PortType portType) throws Exception {
+                    context.writeEndTag(portType.getElementName());
+                }
+                public void preVisit(Operation operation) throws Exception {
+                    context.writeStartTag(operation.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        operation.getName());
+                    //bug fix: 4947340, parameterOder="" should not be generated
+                    if(operation.getParameterOrder() != null &&
+                        operation.getParameterOrder().length() > 0) {
+                        context.writeAttribute(
+                            Constants.ATTR_PARAMETER_ORDER,
+                            operation.getParameterOrder());
+                    }
+                }
+                public void postVisit(Operation operation) throws Exception {
+                    context.writeEndTag(operation.getElementName());
+                }
+                public void preVisit(Input input) throws Exception {
+                    context.writeStartTag(input.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        input.getName());
+                    context.writeAttribute(
+                        Constants.ATTR_MESSAGE,
+                        input.getMessage());
+                }
+                public void postVisit(Input input) throws Exception {
+                    context.writeEndTag(input.getElementName());
+                }
+                public void preVisit(Output output) throws Exception {
+                    context.writeStartTag(output.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        output.getName());
+                    context.writeAttribute(
+                        Constants.ATTR_MESSAGE,
+                        output.getMessage());
+                }
+                public void postVisit(Output output) throws Exception {
+                    context.writeEndTag(output.getElementName());
+                }
+                public void preVisit(Fault fault) throws Exception {
+                    context.writeStartTag(fault.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        fault.getName());
+                    context.writeAttribute(
+                        Constants.ATTR_MESSAGE,
+                        fault.getMessage());
+                }
+                public void postVisit(Fault fault) throws Exception {
+                    context.writeEndTag(fault.getElementName());
+                }
+                public void preVisit(Binding binding) throws Exception {
+                    context.writeStartTag(binding.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        binding.getName());
+                    context.writeAttribute(
+                        Constants.ATTR_TYPE,
+                        binding.getPortType());
+                }
+                public void postVisit(Binding binding) throws Exception {
+                    context.writeEndTag(binding.getElementName());
+                }
+
+                public void preVisit(BindingOperation operation)
+                    throws Exception {
+                    context.writeStartTag(operation.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        operation.getName());
+                }
+                public void postVisit(BindingOperation operation)
+                    throws Exception {
+                    context.writeEndTag(operation.getElementName());
+                }
+                public void preVisit(BindingInput input) throws Exception {
+                    context.writeStartTag(input.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        input.getName());
+                }
+                public void postVisit(BindingInput input) throws Exception {
+                    context.writeEndTag(input.getElementName());
+                }
+                public void preVisit(BindingOutput output) throws Exception {
+                    context.writeStartTag(output.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        output.getName());
+                }
+                public void postVisit(BindingOutput output) throws Exception {
+                    context.writeEndTag(output.getElementName());
+                }
+                public void preVisit(BindingFault fault) throws Exception {
+                    context.writeStartTag(fault.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        fault.getName());
+                }
+                public void postVisit(BindingFault fault) throws Exception {
+                    context.writeEndTag(fault.getElementName());
+                }
+
+                public void preVisit(Service service) throws Exception {
+                    context.writeStartTag(service.getElementName());
+                    context.writeAttribute(
+                        Constants.ATTR_NAME,
+                        service.getName());
+                }
+                public void postVisit(Service service) throws Exception {
+                    context.writeEndTag(service.getElementName());
+                }
+                public void preVisit(Port port) throws Exception {
+                    context.writeStartTag(port.getElementName());
+                    context.writeAttribute(Constants.ATTR_NAME, port.getName());
+                    context.writeAttribute(
+                        Constants.ATTR_BINDING,
+                        port.getBinding());
+                }
+                public void postVisit(Port port) throws Exception {
+                    context.writeEndTag(port.getElementName());
+                }
+                public void preVisit(Extension extension) throws Exception {
+                    ExtensionHandler h =
+                        (ExtensionHandler) _extensionHandlers.get(
+                            extension.getElementName().getNamespaceURI());
+                    h.doHandleExtension(context, extension);
+                }
+                public void postVisit(Extension extension) throws Exception {
+                }
+                public void visit(Documentation documentation)
+                    throws Exception {
+                    context.writeTag(WSDLConstants.QNAME_DOCUMENTATION, null);
+                }
+            });
+            context.flush();
+        } catch (Exception e) {
+            if (e instanceof IOException) {
+                throw (IOException) e;
+            } else if (e instanceof RuntimeException) {
+                throw (RuntimeException) e;
+            } else {
+                // entirely unexpected exception
+                throw new IllegalStateException();
+            }
+        }
+    }
+
+    private void initializePrefixes(
+        WriterContext context,
+        WSDLDocument document)
+        throws IOException {
+        // deal with the target namespace first
+        String tnsURI = document.getDefinitions().getTargetNamespaceURI();
+        if (tnsURI != null) {
+            context.setTargetNamespaceURI(tnsURI);
+            context.declarePrefix(TARGET_NAMESPACE_PREFIX, tnsURI);
+        }
+
+        // then with the WSDL namespace
+//        context.declarePrefix(_commonPrefixes.get(Constants.NS_WSDL), Constants.NS_WSDL);
+        context.declarePrefix("", Constants.NS_WSDL);
+
+        // then with all other namespaces
+        Set namespaces = document.collectAllNamespaces();
+        for (Iterator iter = namespaces.iterator(); iter.hasNext();) {
+            String nsURI = (String) iter.next();
+            if (context.getPrefixFor(nsURI) != null)
+                continue;
+
+            String prefix = (String) _commonPrefixes.get(nsURI);
+            if (prefix == null) {
+                // create a new prefix for it
+                prefix = context.findNewPrefix(NEW_NAMESPACE_PREFIX_BASE);
+            }
+            context.declarePrefix(prefix, nsURI);
+        }
+    }
+
+    private Map _extensionHandlers;
+
+    ////////
+
+    private static Map<String, String> _commonPrefixes;
+
+    static {
+        _commonPrefixes = new HashMap<String, String>();
+        _commonPrefixes.put(Constants.NS_WSDL, "wsdl");
+        _commonPrefixes.put(Constants.NS_WSDL_SOAP, "soap");
+        _commonPrefixes.put(Constants.NS_WSDL_HTTP, "http");
+        _commonPrefixes.put(Constants.NS_WSDL_MIME, "mime");
+        _commonPrefixes.put(Constants.NS_XSD, "xsd");
+        _commonPrefixes.put(Constants.NS_XSI, "xsi");
+        _commonPrefixes.put(JAXWSBindingsConstants.NS_JAXWS_BINDINGS, "jaxws");
+    }
+
+    private final static String TARGET_NAMESPACE_PREFIX = "tns";
+    private final static String NEW_NAMESPACE_PREFIX_BASE = "ns";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/AbortException.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/AbortException.java
new file mode 100644
index 0000000..97acb1f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/AbortException.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Use is subject to the license terms.
+ */
+package com.sun.tools.internal.xjc;
+
+
+/**
+ * Signals the abortion of the compilation.
+ * <p>
+ * This exception should be only thrown from {@link ErrorReceiver}
+ * for the consistent error handling.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class AbortException extends RuntimeException {
+    public AbortException() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/BadCommandLineException.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/BadCommandLineException.java
new file mode 100644
index 0000000..8ff4cae
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/BadCommandLineException.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import com.sun.istack.internal.Nullable;
+
+/**
+ * Signals a bad command line argument.
+ */
+public class BadCommandLineException extends Exception {
+    private Options options;
+
+    public BadCommandLineException(String msg) {
+        super(msg);
+    }
+
+    public BadCommandLineException(String message, Throwable cause) {
+        super(message, cause);
+    }
+
+    public BadCommandLineException() {
+        this(null);
+    }
+
+    public void initOptions(Options opt) {
+        assert this.options==null;
+        this.options = opt;
+    }
+
+    /**
+     * Gets the partly parsed option object, if any.
+     */
+    public @Nullable Options getOptions() {
+        return options;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/ConsoleErrorReporter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/ConsoleErrorReporter.java
new file mode 100644
index 0000000..c204f2c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/ConsoleErrorReporter.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.io.OutputStream;
+import java.io.PrintStream;
+
+import org.xml.sax.SAXParseException;
+
+/**
+ * {@link ErrorReceiver} that prints to a {@link PrintStream}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ConsoleErrorReporter extends ErrorReceiver {
+
+    /**
+     * Errors, warnings are sent to this output.
+     */
+    private PrintStream output;
+
+    private boolean hadError = false;
+
+    public ConsoleErrorReporter( PrintStream out) {
+        this.output = out;
+    }
+    public ConsoleErrorReporter( OutputStream out ) {
+        this(new PrintStream(out));
+    }
+    public ConsoleErrorReporter() { this(System.out); }
+
+    public void warning(SAXParseException e) {
+        print(Messages.WARNING_MSG,e);
+    }
+
+    public void error(SAXParseException e) {
+        hadError = true;
+        print(Messages.ERROR_MSG,e);
+    }
+
+    public void fatalError(SAXParseException e) {
+        hadError = true;
+        print(Messages.ERROR_MSG,e);
+    }
+
+    public void info(SAXParseException e) {
+        print(Messages.INFO_MSG,e);
+    }
+
+    public boolean hadError() {
+        return hadError;
+    }
+
+    private void print( String resource, SAXParseException e ) {
+        output.println(Messages.format(resource,e.getMessage()));
+        output.println(getLocationString(e));
+        output.println();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/Driver.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Driver.java
new file mode 100644
index 0000000..fb5a342
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Driver.java
@@ -0,0 +1,488 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.PrintStream;
+import java.util.Iterator;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.writer.ZipCodeWriter;
+import com.sun.istack.internal.Nullable;
+import com.sun.tools.internal.xjc.generator.bean.BeanGenerator;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.tools.internal.xjc.reader.gbind.Expression;
+import com.sun.tools.internal.xjc.reader.gbind.Graph;
+import com.sun.tools.internal.xjc.reader.internalizer.DOMForest;
+import com.sun.tools.internal.xjc.reader.xmlschema.ExpressionBuilder;
+import com.sun.tools.internal.xjc.reader.xmlschema.parser.XMLSchemaInternalizationLogic;
+import com.sun.tools.internal.xjc.util.ErrorReceiverFilter;
+import com.sun.tools.internal.xjc.util.NullStream;
+import com.sun.tools.internal.xjc.util.Util;
+import com.sun.tools.internal.xjc.writer.SignatureWriter;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+
+/**
+ * CUI of XJC.
+ */
+public class Driver {
+
+    public static void main(final String[] args) throws Exception {
+        // use the platform default proxy if available.
+        // see sun.net.spi.DefaultProxySelector for details.
+        try {
+            System.setProperty("java.net.useSystemProxies","true");
+        } catch (SecurityException e) {
+            // failing to set this property isn't fatal
+        }
+
+        if( Util.getSystemProperty(Driver.class,"noThreadSwap")!=null )
+            _main(args);    // for the ease of debugging
+
+        // run all the work in another thread so that the -Xss option
+        // will take effect when compiling a large schema. See
+        // http://developer.java.sun.com/developer/bugParade/bugs/4362291.html
+        final Throwable[] ex = new Throwable[1];
+
+        Thread th = new Thread() {
+            public void run() {
+                try {
+                    _main(args);
+                } catch( Throwable e ) {
+                    ex[0]=e;
+                }
+            }
+        };
+        th.start();
+        th.join();
+
+        if(ex[0]!=null) {
+            // re-throw
+            if( ex[0] instanceof Exception )
+                throw (Exception)ex[0];
+            else
+                throw (Error)ex[0];
+        }
+    }
+
+    private static void _main( String[] args ) throws Exception {
+        try {
+            System.exit(run( args, System.err, System.out ));
+        } catch (BadCommandLineException e) {
+            // there was an error in the command line.
+            // print usage and abort.
+            if(e.getMessage()!=null) {
+                System.out.println(e.getMessage());
+                System.out.println();
+            }
+
+            usage(e.getOptions(),false);
+            System.exit(-1);
+        }
+    }
+
+
+
+    /**
+     * Performs schema compilation and prints the status/error into the
+     * specified PrintStream.
+     *
+     * <p>
+     * This method could be used to trigger XJC from other tools,
+     * such as Ant or IDE.
+     *
+     * @param    args
+     *      specified command line parameters. If there is an error
+     *      in the parameters, {@link BadCommandLineException} will
+     *      be thrown.
+     * @param    status
+     *      Status report of the compilation will be sent to this object.
+     *      Useful to update users so that they will know something is happening.
+     *      Only ignorable messages should be sent to this stream.
+     *
+     *      This parameter can be null to suppress messages.
+     *
+     * @param    out
+     *      Various non-ignorable output (error messages, etc)
+     *      will go to this stream.
+     *
+     * @return
+     *      If the compiler runs successfully, this method returns 0.
+     *      All non-zero values indicate an error. The error message
+     *      will be sent to the specified PrintStream.
+     */
+    public static int run(String[] args, final PrintStream status, final PrintStream out)
+        throws Exception {
+
+        class Listener extends XJCListener {
+            ConsoleErrorReporter cer = new ConsoleErrorReporter(out==null?new PrintStream(new NullStream()):out);
+
+            public void generatedFile(String fileName, int count, int total) {
+                message(fileName);
+            }
+            public void message(String msg) {
+                if(status!=null)
+                    status.println(msg);
+            }
+
+            public void error(SAXParseException exception) {
+                cer.error(exception);
+            }
+
+            public void fatalError(SAXParseException exception) {
+                cer.fatalError(exception);
+            }
+
+            public void warning(SAXParseException exception) {
+                cer.warning(exception);
+            }
+
+            public void info(SAXParseException exception) {
+                cer.info(exception);
+            }
+        }
+
+        return run(args,new Listener());
+    }
+
+    /**
+     * Performs schema compilation and prints the status/error into the
+     * specified PrintStream.
+     *
+     * <p>
+     * This method could be used to trigger XJC from other tools,
+     * such as Ant or IDE.
+     *
+     * @param    args
+     *        specified command line parameters. If there is an error
+     *        in the parameters, {@link BadCommandLineException} will
+     *        be thrown.
+     * @param    listener
+     *      Receives messages from XJC reporting progress/errors.
+     *
+     * @return
+     *      If the compiler runs successfully, this method returns 0.
+     *      All non-zero values indicate an error. The error message
+     *      will be sent to the specified PrintStream.
+     */
+    public static int run(String[] args, XJCListener listener) throws BadCommandLineException {
+
+        // recognize those special options before we start parsing options.
+        for (String arg : args) {
+            if (arg.equals("-version")) {
+                listener.message(Messages.format(Messages.VERSION));
+                return -1;
+            }
+        }
+
+        final OptionsEx opt = new OptionsEx();
+        opt.setSchemaLanguage(Language.XMLSCHEMA);  // disable auto-guessing
+        try {
+            opt.parseArguments(args);
+        } catch (WeAreDone _) {
+            return -1;
+        } catch(BadCommandLineException e) {
+            e.initOptions(opt);
+            throw e;
+        }
+
+        // display a warning if the user specified the default package
+        // this should work, but is generally a bad idea
+        if(opt.defaultPackage != null && opt.defaultPackage.length()==0) {
+            listener.message(Messages.format(Messages.WARNING_MSG, Messages.format(Messages.DEFAULT_PACKAGE_WARNING)));
+        }
+
+
+        // set up the context class loader so that the user-specified classes
+        // can be loaded from there
+        final ClassLoader contextClassLoader = Thread.currentThread().getContextClassLoader();
+        Thread.currentThread().setContextClassLoader(
+            opt.getUserClassLoader(contextClassLoader));
+
+        // parse a grammar file
+        //-----------------------------------------
+        try {
+            if( !opt.quiet ) {
+                listener.message(Messages.format(Messages.PARSING_SCHEMA));
+            }
+
+            ErrorReceiver receiver = new ErrorReceiverFilter(listener) {
+                public void info(SAXParseException exception) {
+                    if(opt.verbose)
+                        super.info(exception);
+                }
+                public void warning(SAXParseException exception) {
+                    if(!opt.quiet)
+                        super.warning(exception);
+                }
+            };
+
+            if( opt.mode==Mode.FOREST ) {
+                // dump DOM forest and quit
+                ModelLoader loader  = new ModelLoader( opt, new JCodeModel(), receiver );
+                try {
+                    DOMForest forest = loader.buildDOMForest(new XMLSchemaInternalizationLogic());
+                    forest.dump(System.out);
+                    return 0;
+                } catch (SAXException e) {
+                    // the error should have already been reported
+                } catch (IOException e) {
+                    receiver.error(e);
+                }
+
+                return -1;
+            }
+
+            if( opt.mode==Mode.GBIND ) {
+                try {
+                    XSSchemaSet xss = new ModelLoader(opt, new JCodeModel(), receiver).loadXMLSchema();
+                    Iterator<XSComplexType> it = xss.iterateComplexTypes();
+                    while (it.hasNext()) {
+                        XSComplexType ct =  it.next();
+                        XSParticle p = ct.getContentType().asParticle();
+                        if(p==null)     continue;
+
+                        Expression tree = ExpressionBuilder.createTree(p);
+                        System.out.println("Graph for "+ct.getName());
+                        System.out.println(tree.toString());
+                        Graph g = new Graph(tree);
+                        System.out.println(g.toString());
+                        System.out.println();
+                    }
+                    return 0;
+                } catch (SAXException e) {
+                    // the error should have already been reported
+                }
+                return -1;
+            }
+
+            Model model = ModelLoader.load( opt, new JCodeModel(), receiver );
+
+            if (model == null) {
+                listener.message(Messages.format(Messages.PARSE_FAILED));
+                return -1;
+            }
+
+            if( !opt.quiet ) {
+                listener.message(Messages.format(Messages.COMPILING_SCHEMA));
+            }
+
+            switch (opt.mode) {
+            case SIGNATURE :
+                try {
+                    SignatureWriter.write(
+                        BeanGenerator.generate(model,receiver),
+                        new OutputStreamWriter(System.out));
+                    return 0;
+                } catch (IOException e) {
+                    receiver.error(e);
+                    return -1;
+                }
+
+            case CODE :
+            case DRYRUN :
+            case ZIP :
+                {
+                    // generate actual code
+                    receiver.debug("generating code");
+                    {// don't want to hold outline in memory for too long.
+                        Outline outline = model.generateCode(opt,receiver);
+                        if(outline==null) {
+                            listener.message(
+                                Messages.format(Messages.FAILED_TO_GENERATE_CODE));
+                            return -1;
+                        }
+
+                        listener.compiled(outline);
+                    }
+
+                    if( opt.mode == Mode.DRYRUN )
+                        break;  // enough
+
+                    // then print them out
+                    try {
+                        CodeWriter cw;
+                        if( opt.mode==Mode.ZIP ) {
+                            OutputStream os;
+                            if(opt.targetDir.getPath().equals("."))
+                                os = System.out;
+                            else
+                                os = new FileOutputStream(opt.targetDir);
+
+                            cw = opt.createCodeWriter(new ZipCodeWriter(os));
+                        } else
+                            cw = opt.createCodeWriter();
+
+                        if( !opt.quiet ) {
+                            cw = new ProgressCodeWriter(cw,listener, model.codeModel.countArtifacts());
+                        }
+                        model.codeModel.build(cw);
+                    } catch (IOException e) {
+                        receiver.error(e);
+                        return -1;
+                    }
+
+                    break;
+                }
+            default :
+                assert false;
+            }
+
+            return 0;
+        } catch( StackOverflowError e ) {
+            if(opt.verbose)
+                // in the debug mode, propagate the error so that
+                // the full stack trace will be dumped to the screen.
+                throw e;
+            else {
+                // otherwise just print a suggested workaround and
+                // quit without filling the user's screen
+                listener.message(Messages.format(Messages.STACK_OVERFLOW));
+                return -1;
+            }
+        }
+    }
+
+    public static String getBuildID() {
+        return Messages.format(Messages.BUILD_ID);
+    }
+
+
+    /**
+     * Operation mode.
+     */
+    private static enum Mode {
+        // normal mode. compile the code
+        CODE,
+
+        // dump the signature of the generated code
+        SIGNATURE,
+
+        // dump DOMForest
+        FOREST,
+
+        // same as CODE but don't produce any Java source code
+        DRYRUN,
+
+        // same as CODE but pack all the outputs into a zip and dumps to stdout
+        ZIP,
+
+        // testing a new binding mode
+        GBIND
+    }
+
+
+    /**
+     * Command-line arguments processor.
+     *
+     * <p>
+     * This class contains options that only make sense
+     * for the command line interface.
+     */
+    static class OptionsEx extends Options
+    {
+        /** Operation mode. */
+        protected Mode mode = Mode.CODE;
+
+        /** A switch that determines the behavior in the BGM mode. */
+        public boolean noNS = false;
+
+        /** Parse XJC-specific options. */
+        protected int parseArgument(String[] args, int i) throws BadCommandLineException {
+            if (args[i].equals("-noNS")) {
+                noNS = true;
+                return 1;
+            }
+            if (args[i].equals("-mode")) {
+                i++;
+                if (i == args.length)
+                    throw new BadCommandLineException(
+                        Messages.format(Messages.MISSING_MODE_OPERAND));
+
+                String mstr = args[i].toLowerCase();
+
+                for( Mode m : Mode.values() ) {
+                    if(m.name().toLowerCase().startsWith(mstr) && mstr.length()>2) {
+                        mode = m;
+                        return 2;
+                    }
+                }
+
+                throw new BadCommandLineException(
+                    Messages.format(Messages.UNRECOGNIZED_MODE, args[i]));
+            }
+            if (args[i].equals("-help")) {
+                usage(this,false);
+                throw new WeAreDone();
+            }
+            if (args[i].equals("-private")) {
+                usage(this,true);
+                throw new WeAreDone();
+            }
+
+            return super.parseArgument(args, i);
+        }
+    }
+
+    /**
+     * Used to signal that we've finished processing.
+     */
+    private static final class WeAreDone extends BadCommandLineException {}
+
+
+    /**
+     * Prints the usage screen and exits the process.
+     *
+     * @param opts
+     *      If the parsing of options have started, set a partly populated
+     *      {@link Options} object.
+     */
+    protected static void usage( @Nullable Options opts, boolean privateUsage ) {
+        if( privateUsage ) {
+            System.out.println(Messages.format(Messages.DRIVER_PRIVATE_USAGE));
+        } else {
+            System.out.println(Messages.format(Messages.DRIVER_PUBLIC_USAGE));
+        }
+
+        if( opts!=null && opts.getAllPlugins().size()!=0 ) {
+            System.out.println(Messages.format(Messages.ADDON_USAGE));
+            for (Plugin p : opts.getAllPlugins()) {
+                System.out.println(p.getUsage());
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/ErrorReceiver.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/ErrorReceiver.java
new file mode 100644
index 0000000..b602829
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/ErrorReceiver.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Use is subject to the license terms.
+ */
+package com.sun.tools.internal.xjc;
+
+import com.sun.tools.internal.xjc.api.ErrorListener;
+import com.sun.istack.internal.SAXParseException2;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Implemented by the driver of the compiler engine to handle
+ * errors found during the compiliation.
+ *
+ * <p>
+ * This class implements {@link ErrorHandler} so it can be
+ * passed to anywhere where {@link ErrorHandler} is expected.
+ *
+ * <p>
+ * However, to make the error handling easy (and make it work
+ * with visitor patterns nicely),
+ * none of the methods on thi class throws {@link org.xml.sax.SAXException}.
+ * Instead, when the compilation needs to be aborted,
+ * it throws {@link AbortException}, which is unchecked.
+ *
+ * <p>
+ * This also implements the externally visible {@link ErrorListener}
+ * so that we can reuse our internal implementation for testing and such.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class ErrorReceiver  implements ErrorHandler, ErrorListener {
+
+//
+//
+// convenience methods for callers
+//
+//
+    /**
+     * @param loc
+     *      can be null if the location is unknown
+     */
+    public final void error( Locator loc, String msg ) {
+        error( new SAXParseException2(msg,loc) );
+    }
+
+    public final void error( Locator loc, String msg, Exception e ) {
+        error( new SAXParseException2(msg,loc,e) );
+    }
+
+    public final void error( String msg, Exception e ) {
+        error( new SAXParseException2(msg,null,e) );
+    }
+
+    public void error(Exception e) {
+        error(e.getMessage(),e);
+    }
+
+    /**
+     * @param loc
+     *      can be null if the location is unknown
+     */
+    public final void warning( Locator loc, String msg ) {
+        warning( new SAXParseException(msg,loc) );
+    }
+
+//
+//
+// ErrorHandler implementation, but can't throw SAXException
+//
+//
+    public abstract void error(SAXParseException exception) throws AbortException;
+    public abstract void fatalError(SAXParseException exception) throws AbortException;
+    public abstract void warning(SAXParseException exception) throws AbortException;
+
+    /**
+     * Reports verbose messages to users.
+     *
+     * This method can be used to report additional non-essential
+     * messages. The implementation usually discards them
+     * unless some specific debug option is turned on.
+     */
+    public abstract void info(SAXParseException exception) /*REVISIT:throws AbortException*/;
+
+    /**
+     * Reports a debug message to users.
+     *
+     * @see #info(SAXParseException)
+     */
+    public final void debug( String msg ) {
+        info( new SAXParseException(msg,null) );
+    }
+
+//
+//
+// convenience methods for derived classes
+//
+//
+
+  /**
+   * Returns the human readable string representation of the
+   * {@link org.xml.sax.Locator} part of the specified
+   * {@link SAXParseException}.
+   *
+   * @return  non-null valid object.
+   */
+  protected final String getLocationString( SAXParseException e ) {
+      if(e.getLineNumber()!=-1 || e.getSystemId()!=null) {
+          int line = e.getLineNumber();
+          return Messages.format( Messages.LINE_X_OF_Y,
+              line==-1?"?":Integer.toString( line ),
+              getShortName( e.getSystemId() ) );
+      } else {
+          return Messages.format( Messages.UNKNOWN_LOCATION );
+      }
+  }
+
+  /** Computes a short name of a given URL for display. */
+  private String getShortName( String url ) {
+      if(url==null)
+          return Messages.format( Messages.UNKNOWN_FILE );
+
+// sometimes the user deals with a set of schems that reference each other
+// in a complicated way, and end up importing two versions of the same schema.
+// just printing the file name makes it very difficult to recognize of this problem.
+// so I decided to change it back to print the full URL.
+
+//      int idx;
+//
+//      // system Id can be URL, so we can't use File.separator
+//      idx = url.lastIndexOf('/');
+//      if(idx!=-1)     return url.substring(idx+1);
+//      idx = url.lastIndexOf('\\');
+//      if(idx!=-1)     return url.substring(idx+1);
+
+      return url;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/Language.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Language.java
new file mode 100644
index 0000000..36444ee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Language.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+/**
+ * Type of the schema language.
+ */
+public enum Language {
+    DTD,
+    XMLSCHEMA,
+    RELAXNG,
+    RELAXNG_COMPACT,
+    WSDL
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/MessageBundle.properties
new file mode 100644
index 0000000..37f55bd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/MessageBundle.properties
@@ -0,0 +1,221 @@
+ConsoleErrorReporter.UnknownLocation = \
+	unknown location
+	
+ConsoleErrorReporter.LineXOfY = \
+	\ \ line {0} of {1}
+
+ConsoleErrorReporter.UnknownFile = \
+	unknown file
+	
+Driver.Private.Usage = \
+Usage: xjc [-options ...] <schema file/URL/dir> ... [-b <bindinfo>] ...\n\
+Options:\n\
+\ \ -debug             :  run in the debug mode\n\
+\ \ -nv                :  do not perform strict validation of the input schema(s)\n\
+\ \ -extension         :  allow vendor extensions - do not strictly follow the\n\
+\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ Compatibility Rules and App E.2 from the JAXB Spec\n\
+\ \ -mode <mode>       :  run XJC in other running mode\n\
+\ \ -b <file/dir>      :  specify external bindings files (each <file> must have its own -b)\n\
+\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ If a directory is given, **/*.xjb is searched\n\
+\ \ -d <dir>           :  generated files will go into this directory\n\
+\ \ -httpproxy <proxy> :  set HTTP/HTTPS proxy. Format is [user[:password]@]proxyHost:proxyPort\n\
+\ \ -httpproxyfile <f> :  Works like -httpproxy but takes the argument in a file to protect password \n\
+\ \ -classpath <arg>   :  specify where to find user class files\n\
+\ \ -catalog <file>    :  specify catalog files to resolve external entity references\n\
+\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ support TR9401, XCatalog, and OASIS XML Catalog format.\n\
+\ \ -readOnly          :  generated files will be in read-only mode\n\
+\ \ -npa               :  suppress generation of package level annotations (**/package-info.java)\n\
+\ \ -no-header         :  suppress generation of a file header with timestamp\n\
+\ \ -private           :  display this help message\n\
+\ \ -xmlschema         :  treat input as W3C XML Schema (default)\n\
+\ \ -relaxng           :  treat input as RELAX NG (experimental,unsupported)\n\
+\ \ -relaxng-compact   :  treat input as RELAX NG compact syntax (experimental,unsupported)\n\
+\ \ -dtd               :  treat input as XML DTD (experimental,unsupported)\n\
+\ \ -wsdl              :  treat input as WSDL and compile schemas inside it (experimental,unsupported)\n\
+\ \ -version           :  display version information\n\
+\ \ -verbose           :  be extra verbose\n\
+\ \ -quiet             :  suppress compiler output\n\
+Mode:\n\
+\ \ code         :  generate Java source code (default)\n\
+\ \ dryrun       :  compile the schema in memory, but don't generate the Java source\n\
+\ \ zip          :  generate Java source code into a zip file specified by the -d option\n\
+\ \ sig          :  dump the signatures of the generated code\n\
+\ \ forest       :  dump transformed DOM forest\n\
+Options in Code mode:\n\
+\ \ -p <pkg>     :  specifies the target package\n
+
+Driver.Public.Usage = \
+Usage: xjc [-options ...] <schema file/URL/dir> ... [-b <bindinfo>] ...\n\
+Options:\n\
+\ \ -nv                :  do not perform strict validation of the input schema(s)\n\
+\ \ -extension         :  allow vendor extensions - do not strictly follow the\n\
+\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ Compatibility Rules and App E.2 from the JAXB Spec\n\
+\ \ -b <file/dir>      :  specify external bindings files (each <file> must have its own -b)\n\
+\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ If a directory is given, **/*.xjb is searched\n\
+\ \ -d <dir>           :  generated files will go into this directory\n\
+\ \ -p <pkg>           :  specifies the target package\n\
+\ \ -httpproxy <proxy> :  set HTTP/HTTPS proxy. Format is [user[:password]@]proxyHost:proxyPort\n\
+\ \ -httpproxyfile <f> :  Works like -httpproxy but takes the argument in a file to protect password \n\
+\ \ -classpath <arg>   :  specify where to find user class files\n\
+\ \ -catalog <file>    :  specify catalog files to resolve external entity references\n\
+\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ support TR9401, XCatalog, and OASIS XML Catalog format.\n\
+\ \ -readOnly          :  generated files will be in read-only mode\n\
+\ \ -npa               :  suppress generation of package level annotations (**/package-info.java)\n\
+\ \ -no-header         :  suppress generation of a file header with timestamp\n\
+\ \ -xmlschema         :  treat input as W3C XML Schema (default)\n\
+\ \ -relaxng           :  treat input as RELAX NG (experimental,unsupported)\n\
+\ \ -relaxng-compact   :  treat input as RELAX NG compact syntax (experimental,unsupported)\n\
+\ \ -dtd               :  treat input as XML DTD (experimental,unsupported)\n\
+\ \ -wsdl              :  treat input as WSDL and compile schemas inside it (experimental,unsupported)\n\
+\ \ -verbose           :  be extra verbose\n\
+\ \ -quiet             :  suppress compiler output\n\
+\ \ -help              :  display this help message\n\
+\ \ -version           :  display version information\n\
+
+Driver.AddonUsage = \nExtensions:
+
+Driver.ExperimentalLanguageWarning = \
+	Are you trying to compile {0}? Support for {0} is experimental. \
+	You may enable it by using the {1} option.
+
+Driver.MissingCatalog = \
+	the -catalog option is missing a file name
+
+Driver.MissingClassPath = \
+	the -classpath option is missing a directory/jarfile name
+
+Driver.MissingDir = \
+	the -d option is missing a directory name
+
+Driver.NonExistentDir = \
+    cowardly refuses to write to a non-existent directory "{0}"
+	
+Driver.MissingFileName = \
+	the -b option is missing a file name
+	
+Driver.MissingPackageName = \
+	the -p option is missing a package name
+	
+Driver.MissingRuntimePackageName = \
+	the -use-runtime option is missing a package name
+	
+Driver.MissingModeOperand = \
+	the -mode option is missing an operand
+	
+Driver.MissingCompatibilityOperand = \
+	the -compatibility option is missing an operand
+
+Driver.MissingProxyHost = \
+	either the -host option is missing an operand \n\
+        or -port was specified but not -host
+	
+Driver.MissingProxyPort = \
+	either the -port option is missing an operand \n\
+        or -host was specified but not -port
+
+Driver.MISSING_PROXY = \
+    the -httpproxy option is missing an operand
+
+Driver.MISSING_PROXYFILE = \
+    the -httpproxyfile option is missing an operand
+
+Driver.NO_SUCH_FILE = \
+    No such file: {0}
+
+Driver.ILLEGAL_PROXY = \
+    "{0}" is not a valid proxy format. The format is [user[:password]@]proxyHost:proxyPort
+
+Driver.UnrecognizedMode = \
+	unrecognized mode {0}
+
+Driver.UnrecognizedParameter = \
+	unrecognized parameter {0}
+	
+Driver.MissingGrammar = \
+	grammar is not specified
+
+Driver.NotABindingFile = \
+	not an external binding file. The root element must be '{'http://java.sun.com/xml/ns/jaxb'}'bindings but it is '{'{0}'}'{1}
+		
+Driver.ParsingSchema = \
+	parsing a schema...
+	
+Driver.ParseFailed = \
+	Failed to parse a schema.
+
+Driver.StackOverflow = \
+	Stack overflow. Either you are compiling a large schema that requires more resource, or \
+	XJC has a bug. First, please extend the stack size by using the -Xss JVM option. If this \
+	doesn'''t solve the problem, please use the -debug option to obtain the stack trace and \
+	contact Sun. 
+		
+Driver.CompilingSchema = \
+	compiling a schema...
+
+Driver.FailedToGenerateCode = \
+	Failed to produce code.
+
+# DO NOT localize the JAXB 2.0 in JDK 1.6 string - it is a token for an ant <replaceFilter>	
+Driver.FilePrologComment = \
+	This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, vJAXB 2.0 in JDK 1.6 \n\
+	See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a> \n\
+	Any modifications to this file will be lost upon recompilation of the source schema. \n\
+	Generated on: {0} \n
+
+Driver.Version = \
+	xjc version "JAXB 2.0 in JDK 1.6" \n\
+	JavaTM Architecture for XML Binding(JAXB) Reference Implementation, (build JAXB 2.0 in JDK 1.6)	
+
+Driver.BuildID = JAXB 2.0 in JDK 1.6
+	
+# see java.text.SimpleDateFormat for format syntax
+Driver.DateFormat = \
+	yyyy.MM.dd
+
+# see java.text.SimpleDateFormat for format syntax
+Driver.TimeFormat = \
+	hh:mm:ss a z
+
+# as in: "generated on <date> at <time>"	
+Driver.At = \
+	at
+
+Driver.ErrorMessage = \
+	[ERROR] {0}
+
+Driver.WarningMessage = \
+	[WARNING] {0}
+
+Driver.InfoMessage = \
+	[INFO] {0}
+
+ModelLoader.TooManySchema = \
+	Too many schema files for this schema language. Compile one file at a time.
+
+ModelLoader.BindingFileNotSupportedForRNC = \
+    External binding files are not supported for the RELAX NG compact syntax.
+
+Driver.MissingVersion = \
+	the -source option is missing the version value
+
+Driver.DefaultVersion = \
+	Defaulting the version to JAXB 2.0
+
+Driver.DefaultPackageWarning = \
+    Default Java package specified.  You will not be able to access the generated code from classes in any other package.
+
+Driver.NotAValidFileName = \
+    "{0}" is not a valid file name: {1}
+
+Driver.FailedToParse = \
+    Failed to parse "{0}": {1}
+
+Driver.NotAFileNorURL = \
+    "{0}" is neither a file name nor an URL
+
+FIELD_RENDERER_CONFLICT = \
+    "-{0}" and "-{1}" are mutually exclusive since both affect the code generation 
+
+NAME_CONVERTER_CONFLICT - \
+    "-{0}" and "-{1}" are mutually exclusive since both affect the code generation
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Messages.java
new file mode 100644
index 0000000..ea3268f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Messages.java
@@ -0,0 +1,194 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getPackage().getName() +".MessageBundle").getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+//
+//
+// Message resources
+//
+//
+    static final String UNKNOWN_LOCATION = // 0 args
+        "ConsoleErrorReporter.UnknownLocation";
+
+    static final String LINE_X_OF_Y = // 2 args
+        "ConsoleErrorReporter.LineXOfY";
+
+    static final String UNKNOWN_FILE = // 0 args
+        "ConsoleErrorReporter.UnknownFile";
+
+    static final String DRIVER_PUBLIC_USAGE = // 0 args
+        "Driver.Public.Usage";
+
+    static final String DRIVER_PRIVATE_USAGE = // 0 args
+        "Driver.Private.Usage";
+
+    static final String ADDON_USAGE = // 0 args
+        "Driver.AddonUsage";
+
+    static final String EXPERIMENTAL_LANGUAGE_WARNING = // 2 arg
+        "Driver.ExperimentalLanguageWarning";
+
+    static final String MISSING_CLASSPATH = // 0 args
+        "Driver.MissingClassPath";
+
+    static final String MISSING_DIR = // 0 args
+        "Driver.MissingDir";
+
+    static final String NON_EXISTENT_DIR = // 1 arg
+        "Driver.NonExistentDir";
+
+    static final String MISSING_FILENAME = // 0 args
+        "Driver.MissingFileName";
+
+    static final String MISSING_PACKAGENAME = // 0 args
+        "Driver.MissingPackageName";
+
+    static final String MISSING_RUNTIME_PACKAGENAME = // 0 args
+        "Driver.MissingRuntimePackageName";
+
+    static final String MISSING_MODE_OPERAND = // 0 args
+        "Driver.MissingModeOperand";
+
+    static final String MISSING_CATALOG = // 0 args
+        "Driver.MissingCatalog";
+
+    static final String MISSING_COMPATIBILITY_OPERAND = // 0 args
+        "Driver.MissingCompatibilityOperand";
+
+    static final String MISSING_PROXY = // 0 args
+        "Driver.MISSING_PROXY";
+
+    static final String MISSING_PROXYFILE = // 0 args
+        "Driver.MISSING_PROXYFILE";
+
+    static final String NO_SUCH_FILE = // 1 arg
+        "Driver.NO_SUCH_FILE";
+
+    static final String ILLEGAL_PROXY = // 1 arg
+        "Driver.ILLEGAL_PROXY";
+
+    static final String MISSING_PROXYHOST = // 0 args
+        "Driver.MissingProxyHost";
+
+    static final String MISSING_PROXYPORT = // 0 args
+        "Driver.MissingProxyPort";
+
+    static final String STACK_OVERFLOW = // 0 arg
+        "Driver.StackOverflow";
+
+    static final String UNRECOGNIZED_MODE = // 1 arg
+        "Driver.UnrecognizedMode";
+
+    static final String UNRECOGNIZED_PARAMETER = // 1 arg
+        "Driver.UnrecognizedParameter";
+
+    static final String MISSING_GRAMMAR = // 0 args
+        "Driver.MissingGrammar";
+
+    static final String PARSING_SCHEMA = // 0 args
+        "Driver.ParsingSchema";
+
+    static final String PARSE_FAILED = // 0 args
+        "Driver.ParseFailed";
+
+    static final String COMPILING_SCHEMA = // 0 args
+        "Driver.CompilingSchema";
+
+    static final String FAILED_TO_GENERATE_CODE = // 0 args
+        "Driver.FailedToGenerateCode";
+
+    static final String FILE_PROLOG_COMMENT = // 1 arg
+        "Driver.FilePrologComment";
+
+    static final String DATE_FORMAT = // 0 args
+        "Driver.DateFormat";
+
+    static final String TIME_FORMAT = // 0 args
+        "Driver.TimeFormat";
+
+    static final String AT = // 0 args
+        "Driver.At";
+
+    static final String VERSION = // 0 args
+        "Driver.Version";
+
+    static final String BUILD_ID = // 0 args
+        "Driver.BuildID";
+
+    static final String ERROR_MSG = // 1:arg
+        "Driver.ErrorMessage";
+
+    static final String WARNING_MSG = // 1:arg
+        "Driver.WarningMessage";
+
+    static final String INFO_MSG = // 1:arg
+        "Driver.InfoMessage";
+
+    static final String ERR_NOT_A_BINDING_FILE = // 2 arg
+        "Driver.NotABindingFile";
+
+    static final String ERR_TOO_MANY_SCHEMA = // 0 args
+        "ModelLoader.TooManySchema";
+
+    static final String ERR_BINDING_FILE_NOT_SUPPORTED_FOR_RNC = // 0 args
+        "ModelLoader.BindingFileNotSupportedForRNC";
+
+     static final String MISSING_VERSION = // 0 args
+        "Driver.MissingVersion";
+
+    static final String DEFAULT_VERSION = // 0 args
+        "Driver.DefaultVersion";
+
+    static final String DEFAULT_PACKAGE_WARNING = // 0 args
+        "Driver.DefaultPackageWarning";
+
+    static final String NOT_A_VALID_FILENAME = // 2 args
+        "Driver.NotAValidFileName";
+    static final String FAILED_TO_PARSE = // 2 args
+        "Driver.FailedToParse";
+    static final String NOT_A_FILE_NOR_URL = // 1 arg
+        "Driver.NotAFileNorURL";
+
+    static final String FIELD_RENDERER_CONFLICT = // 2 args
+        "FIELD_RENDERER_CONFLICT";
+
+    static final String NAME_CONVERTER_CONFLICT = // 2 args
+            "NAME_CONVERTER_CONFLICT";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/ModelLoader.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/ModelLoader.java
new file mode 100644
index 0000000..5c84f6a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/ModelLoader.java
@@ -0,0 +1,562 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.io.IOException;
+import java.io.StringReader;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.reader.ExtensionBindingChecker;
+import com.sun.tools.internal.xjc.reader.dtd.TDTDReader;
+import com.sun.tools.internal.xjc.reader.internalizer.DOMForest;
+import com.sun.tools.internal.xjc.reader.internalizer.DOMForestScanner;
+import com.sun.tools.internal.xjc.reader.internalizer.InternalizationLogic;
+import com.sun.tools.internal.xjc.reader.internalizer.VersionChecker;
+import com.sun.tools.internal.xjc.reader.relaxng.RELAXNGCompiler;
+import com.sun.tools.internal.xjc.reader.relaxng.RELAXNGInternalizationLogic;
+import com.sun.tools.internal.xjc.reader.xmlschema.BGMBuilder;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.AnnotationParserFactoryImpl;
+import com.sun.tools.internal.xjc.reader.xmlschema.parser.CustomizationContextChecker;
+import com.sun.tools.internal.xjc.reader.xmlschema.parser.IncorrectNamespaceURIChecker;
+import com.sun.tools.internal.xjc.reader.xmlschema.parser.SchemaConstraintChecker;
+import com.sun.tools.internal.xjc.reader.xmlschema.parser.XMLSchemaInternalizationLogic;
+import com.sun.tools.internal.xjc.util.ErrorReceiverFilter;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.parser.JAXPParser;
+import com.sun.xml.internal.xsom.parser.XMLParser;
+import com.sun.xml.internal.xsom.parser.XSOMParser;
+
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.util.CheckingSchemaBuilder;
+import com.sun.xml.internal.rngom.digested.DPattern;
+import com.sun.xml.internal.rngom.digested.DSchemaBuilderImpl;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import com.sun.xml.internal.rngom.parse.compact.CompactParseable;
+import com.sun.xml.internal.rngom.parse.xml.SAXParseable;
+import com.sun.xml.internal.rngom.xml.sax.XMLReaderCreator;
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.NodeList;
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.XMLFilter;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * Builds a {@link Model} object.
+ *
+ * This is an utility class that makes it easy to load a grammar object
+ * from various sources.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class ModelLoader {
+
+    private final Options opt;
+    private final ErrorReceiverFilter errorReceiver;
+    private final JCodeModel codeModel;
+
+    /**
+     * A convenience method to load schemas into a {@link Model}.
+     */
+    public static Model load( Options opt, JCodeModel codeModel, ErrorReceiver er ) {
+        return new ModelLoader(opt,codeModel,er).load();
+    }
+
+
+    public ModelLoader(Options _opt, JCodeModel _codeModel, ErrorReceiver er) {
+        this.opt = _opt;
+        this.codeModel = _codeModel;
+        this.errorReceiver = new ErrorReceiverFilter(er);
+    }
+
+    private Model load() {
+        Model grammar;
+
+        if(!sanityCheck())
+            return null;
+
+
+        try {
+            switch (opt.getSchemaLanguage()) {
+            case DTD :
+                // TODO: make sure that bindFiles,size()<=1
+                InputSource bindFile = null;
+                if (opt.getBindFiles().length > 0)
+                    bindFile = opt.getBindFiles()[0];
+                // if there is no binding file, make a dummy one.
+                if (bindFile == null) {
+                    // if no binding information is specified, provide a default
+                    bindFile =
+                        new InputSource(
+                            new StringReader(
+                                "<?xml version='1.0'?><xml-java-binding-schema><options package='"
+                                    + (opt.defaultPackage==null?"generated":opt.defaultPackage)
+                                    + "'/></xml-java-binding-schema>"));
+                }
+
+                checkTooManySchemaErrors();
+                grammar = loadDTD(opt.getGrammars()[0], bindFile );
+                break;
+
+            case RELAXNG :
+                checkTooManySchemaErrors();
+                grammar = loadRELAXNG();
+                break;
+
+            case RELAXNG_COMPACT :
+                checkTooManySchemaErrors();
+                grammar = loadRELAXNGCompact();
+                break;
+
+            case WSDL:
+                grammar = annotateXMLSchema( loadWSDL() );
+                break;
+
+            case XMLSCHEMA:
+                grammar = annotateXMLSchema( loadXMLSchema() );
+                break;
+
+            default :
+                throw new AssertionError(); // assertion failed
+            }
+
+            if (errorReceiver.hadError()) {
+                grammar = null;
+            } else {
+                grammar.setPackageLevelAnnotations(opt.packageLevelAnnotations);
+            }
+
+            return grammar;
+
+        } catch (SAXException e) {
+            // parsing error in the input document.
+            // this error must have been reported to the user vis error handler
+            // so don't print it again.
+            if (opt.verbose) {
+                // however, a bug in XJC might throw unexpected SAXException.
+                // thus when one is debugging, it is useful to print what went
+                // wrong.
+                if (e.getException() != null)
+                    e.getException().printStackTrace();
+                else
+                    e.printStackTrace();
+            }
+            return null;
+        }
+    }
+
+
+
+    /**
+     * Do some extra checking and return false if the compilation
+     * should abort.
+     */
+    private boolean sanityCheck() {
+        if( opt.getSchemaLanguage()==Language.XMLSCHEMA ) {
+            Language guess = opt.guessSchemaLanguage();
+
+            String[] msg = null;
+            switch(guess) {
+            case DTD:
+                msg = new String[]{"DTD","-dtd"};
+                break;
+            case RELAXNG:
+                msg = new String[]{"RELAX NG","-relaxng"};
+                break;
+            case RELAXNG_COMPACT:
+                msg = new String[]{"RELAX NG compact syntax","-relaxng-compact"};
+                break;
+            case WSDL:
+                msg = new String[]{"WSDL","-wsdl"};
+                break;
+            }
+            if( msg!=null )
+                errorReceiver.warning( null,
+                    Messages.format(
+                    Messages.EXPERIMENTAL_LANGUAGE_WARNING,
+                    msg[0], msg[1] ));
+        }
+        return true;
+    }
+
+
+    /**
+     * {@link XMLParser} implementation that adds additional processors into the chain.
+     *
+     * <p>
+     * This parser will parse a DOM forest as:
+     * DOMForestParser -->
+     *   ExtensionBindingChecker -->
+     *     ProhibitedFeatureFilter -->
+     *       XSOMParser
+     */
+    private class XMLSchemaParser implements XMLParser {
+        private final XMLParser baseParser;
+
+        private XMLSchemaParser(XMLParser baseParser) {
+            this.baseParser = baseParser;
+        }
+
+        public void parse(InputSource source, ContentHandler handler,
+            ErrorHandler errorHandler, EntityResolver entityResolver ) throws SAXException, IOException {
+            // set up the chain of handlers.
+            handler = wrapBy( new ExtensionBindingChecker(WellKnownNamespace.XML_SCHEMA,opt,errorReceiver), handler );
+            handler = wrapBy( new IncorrectNamespaceURIChecker(errorReceiver), handler );
+            handler = wrapBy( new CustomizationContextChecker(errorReceiver), handler );
+//          handler = wrapBy( new VersionChecker(controller), handler );
+
+            baseParser.parse( source, handler, errorHandler, entityResolver );
+        }
+        /**
+         * Wraps the specified content handler by a filter.
+         * It is little awkward to use a helper implementation class like XMLFilterImpl
+         * as the method parameter, but this simplifies the code.
+         */
+        private ContentHandler wrapBy( XMLFilterImpl filter, ContentHandler handler ) {
+            filter.setContentHandler(handler);
+            return filter;
+        }
+    }
+
+
+
+
+
+    private void checkTooManySchemaErrors() {
+        if( opt.getGrammars().length!=1 )
+            errorReceiver.error(null,Messages.format(Messages.ERR_TOO_MANY_SCHEMA));
+    }
+
+    /**
+     * Parses a DTD file into an annotated grammar.
+     *
+     * @param   source
+     *      DTD file
+     * @param   bindFile
+     *      External binding file.
+     */
+    private Model loadDTD( InputSource source, InputSource bindFile) {
+
+        // parse the schema as a DTD.
+        return TDTDReader.parse(
+            source,
+            bindFile,
+            errorReceiver,
+            opt);
+    }
+
+    /**
+     * Builds DOMForest and performs the internalization.
+     *
+     * @throws SAXException
+     *      when a fatal happe
+     */
+    public DOMForest buildDOMForest( InternalizationLogic logic )
+        throws SAXException {
+
+        // parse into DOM forest
+        DOMForest forest = new DOMForest(logic);
+
+        forest.setErrorHandler(errorReceiver);
+        if(opt.entityResolver!=null)
+        forest.setEntityResolver(opt.entityResolver);
+
+        // parse source grammars
+        for (InputSource value : opt.getGrammars())
+            forest.parse(value, true);
+
+        // parse external binding files
+        for (InputSource value : opt.getBindFiles()) {
+            Document dom = forest.parse(value, true);
+            if(dom==null)       continue;   // error must have been reported
+            Element root = dom.getDocumentElement();
+            // TODO: it somehow doesn't feel right to do a validation in the Driver class.
+            // think about moving it to somewhere else.
+            if (!fixNull(root.getNamespaceURI()).equals(Const.JAXB_NSURI)
+                    || !root.getLocalName().equals("bindings"))
+                errorReceiver.error(new SAXParseException(Messages.format(Messages.ERR_NOT_A_BINDING_FILE,
+                        root.getNamespaceURI(),
+                        root.getLocalName()),
+                        null,
+                        value.getSystemId(),
+                        -1, -1));
+        }
+
+        forest.transform();
+
+        return forest;
+    }
+
+    private String fixNull(String s) {
+        if(s==null) return "";
+        else        return s;
+    }
+
+    /**
+     * Parses a set of XML Schema files into an annotated grammar.
+     */
+    public XSSchemaSet loadXMLSchema() throws SAXException {
+
+        if( opt.strictCheck && !SchemaConstraintChecker.check(opt.getGrammars(),errorReceiver,opt.entityResolver)) {
+            // schema error. error should have been reported
+            return null;
+        }
+
+        if(opt.getBindFiles().length==0) {
+            // no external binding. try the speculative no DOMForest execution,
+            // which is faster if the speculation succeeds.
+            try {
+                return createXSOMSpeculative();
+            } catch( SpeculationFailure _ ) {
+                // failed. go the slow way
+            }
+        }
+
+        // the default slower way is to parse everything into DOM first.
+        // so that we can take external annotations into account.
+        DOMForest forest = buildDOMForest( new XMLSchemaInternalizationLogic() );
+        return createXSOM(forest);
+    }
+
+    /**
+     * Parses a set of schemas inside a WSDL file.
+     *
+     * A WSDL file may contain multiple &lt;xsd:schema> elements.
+     */
+    private XSSchemaSet loadWSDL()
+        throws SAXException {
+
+
+        // build DOMForest just like we handle XML Schema
+        DOMForest forest = buildDOMForest( new XMLSchemaInternalizationLogic() );
+
+        DOMForestScanner scanner = new DOMForestScanner(forest);
+
+        XSOMParser xsomParser = createXSOMParser( forest );
+
+        // find <xsd:schema>s and parse them individually
+        for( InputSource grammar : opt.getGrammars() ) {
+            Document wsdlDom = forest.get( grammar.getSystemId() );
+
+            NodeList schemas = wsdlDom.getElementsByTagNameNS(WellKnownNamespace.XML_SCHEMA,"schema");
+            for( int i=0; i<schemas.getLength(); i++ )
+                scanner.scan( (Element)schemas.item(i), xsomParser.getParserHandler() );
+        }
+        return xsomParser.getResult();
+    }
+
+    /**
+     * Annotates the obtained schema set.
+     *
+     * @return
+     *      null if an error happens. In that case, the error messages
+     *      will be properly reported to the controller by this method.
+     */
+    public Model annotateXMLSchema(XSSchemaSet xs) {
+        if (xs == null)
+            return null;
+        return BGMBuilder.build(xs, codeModel, errorReceiver, opt);
+    }
+
+    public XSOMParser createXSOMParser(XMLParser parser) {
+        // set up other parameters to XSOMParser
+        XSOMParser reader = new XSOMParser(new XMLSchemaParser(parser));
+        reader.setAnnotationParser(new AnnotationParserFactoryImpl(opt));
+        reader.setErrorHandler(errorReceiver);
+        reader.setEntityResolver(opt.entityResolver);
+        return reader;
+    }
+
+    public XSOMParser createXSOMParser(final DOMForest forest) {
+        XSOMParser p = createXSOMParser(forest.createParser());
+        p.setEntityResolver(new EntityResolver() {
+            public InputSource resolveEntity(String publicId, String systemId) throws SAXException, IOException {
+                // DOMForest only parses documents that are rearchable through systemIds,
+                // and it won't pick up references like <xs:import namespace="..." /> without
+                // @schemaLocation. So we still need to use an entity resolver here to resolve
+                // these references, yet we don't want to just run them blindly, since if we do that
+                // DOMForestParser always get the translated system ID when catalog is used
+                // (where DOMForest records trees with their original system IDs.)
+                if(systemId!=null && forest.get(systemId)!=null)
+                    return new InputSource(systemId);
+                if(opt.entityResolver!=null)
+                    return opt.entityResolver.resolveEntity(publicId,systemId);
+
+                return null;
+            }
+        });
+        return p;
+    }
+
+
+    private static final class SpeculationFailure extends Error {}
+
+    private static final class SpeculationChecker extends XMLFilterImpl {
+        public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
+            if(localName.equals("bindings") && uri.equals(Const.JAXB_NSURI))
+                throw new SpeculationFailure();
+            super.startElement(uri,localName,qName,attributes);
+        }
+    }
+
+    /**
+     * Parses schemas directly into XSOM by assuming that there's
+     * no external annotations.
+     * <p>
+     * When an external annotation is found, a {@link SpeculationFailure} is thrown,
+     * and we will do it all over again by using the slow way.
+     */
+    private XSSchemaSet createXSOMSpeculative() throws SAXException, SpeculationFailure {
+
+        // check if the schema contains external binding files. If so, speculation is a failure.
+
+        XMLParser parser = new XMLParser() {
+            private final JAXPParser base = new JAXPParser();
+
+            public void parse(InputSource source, ContentHandler handler,
+                ErrorHandler errorHandler, EntityResolver entityResolver ) throws SAXException, IOException {
+                // set up the chain of handlers.
+                handler = wrapBy( new SpeculationChecker(), handler );
+                handler = wrapBy( new VersionChecker(null,errorReceiver,entityResolver), handler );
+
+                base.parse( source, handler, errorHandler, entityResolver );
+            }
+            /**
+             * Wraps the specified content handler by a filter.
+             * It is little awkward to use a helper implementation class like XMLFilterImpl
+             * as the method parameter, but this simplifies the code.
+             */
+            private ContentHandler wrapBy( XMLFilterImpl filter, ContentHandler handler ) {
+                filter.setContentHandler(handler);
+                return filter;
+            }
+        };
+
+        XSOMParser reader = createXSOMParser(parser);
+
+        // parse source grammars
+        for (InputSource value : opt.getGrammars())
+            reader.parse(value);
+
+        return reader.getResult();
+    }
+
+    /**
+     * Parses a {@link DOMForest} into a {@link XSSchemaSet}.
+     */
+    public XSSchemaSet createXSOM(DOMForest forest) throws SAXException {
+        // set up other parameters to XSOMParser
+        XSOMParser reader = createXSOMParser(forest);
+
+        // re-parse the transformed schemas
+        for (String systemId : forest.getRootDocuments()) {
+            Document dom = forest.get(systemId);
+            if (!dom.getDocumentElement().getNamespaceURI().equals(Const.JAXB_NSURI))
+                reader.parse(systemId);
+        }
+
+        return reader.getResult();
+    }
+
+    /**
+     * Parses a RELAX NG grammar into an annotated grammar.
+     */
+    private Model loadRELAXNG() throws SAXException {
+
+        // build DOM forest
+        final DOMForest forest = buildDOMForest( new RELAXNGInternalizationLogic() );
+
+        // use JAXP masquerading to validate the input document.
+        // DOMForest -> ExtensionBindingChecker -> RNGOM
+
+        XMLReaderCreator xrc = new XMLReaderCreator() {
+            public XMLReader createXMLReader() {
+
+                // foreset parser cannot change the receivers while it's working,
+                // so we need to have one XMLFilter that works as a buffer
+                XMLFilter buffer = new XMLFilterImpl() {
+                    public void parse(InputSource source) throws IOException, SAXException {
+                        forest.createParser().parse( source, this, this, this );
+                    }
+                };
+
+                XMLFilter f = new ExtensionBindingChecker(Const.RELAXNG_URI,opt,errorReceiver);
+                f.setParent(buffer);
+
+                f.setEntityResolver(opt.entityResolver);
+
+                return f;
+            }
+        };
+
+        Parseable p = new SAXParseable( opt.getGrammars()[0], errorReceiver, xrc );
+
+        return loadRELAXNG(p);
+
+    }
+
+    /**
+     * Loads RELAX NG compact syntax
+     */
+    private Model loadRELAXNGCompact() {
+        if(opt.getBindFiles().length>0)
+            errorReceiver.error(new SAXParseException(
+                Messages.format(Messages.ERR_BINDING_FILE_NOT_SUPPORTED_FOR_RNC),null));
+
+        // TODO: entity resolver?
+        Parseable p = new CompactParseable( opt.getGrammars()[0], errorReceiver );
+
+        return loadRELAXNG(p);
+
+    }
+
+    /**
+     * Common part between the XML syntax and the compact syntax.
+     */
+    private Model loadRELAXNG(Parseable p) {
+        SchemaBuilder sb = new CheckingSchemaBuilder(new DSchemaBuilderImpl(),errorReceiver);
+
+        try {
+            DPattern out = (DPattern)p.parse(sb);
+            return RELAXNGCompiler.build(out,codeModel,opt);
+        } catch (IllegalSchemaException e) {
+            errorReceiver.error(e.getMessage(),e);
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/Options.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Options.java
new file mode 100644
index 0000000..b741be4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Options.java
@@ -0,0 +1,869 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.io.BufferedReader;
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.IOException;
+import java.io.InputStreamReader;
+import java.lang.reflect.Array;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.net.URLClassLoader;
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.Enumeration;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.writer.FileCodeWriter;
+import com.sun.codemodel.internal.writer.PrologCodeWriter;
+import com.sun.org.apache.xml.internal.resolver.CatalogManager;
+import com.sun.org.apache.xml.internal.resolver.tools.CatalogResolver;
+import com.sun.tools.internal.xjc.api.ClassNameAllocator;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRendererFactory;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.reader.Util;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+
+/**
+ * Global options.
+ *
+ * <p>
+ * This class stores invocation configuration for XJC.
+ * The configuration in this class shoule be abstract enough so that
+ * it could be parsed from both command-line or Ant.
+ */
+public class Options
+{
+    /** If "-debug" is specified. */
+    public boolean debugMode;
+
+    /** If the "-verbose" option is specified. */
+    public boolean verbose;
+
+    /** If the "-quiet" option is specified. */
+    public boolean quiet;
+
+    /** If the -readOnly option is specified. */
+    public boolean readOnly;
+
+    /** No file header comment (to be more friendly with diff.) */
+    public boolean noFileHeader;
+
+    /**
+     * Check the source schemas with extra scrutiny.
+     * The exact meaning depends on the schema language.
+     */
+    public boolean strictCheck =true;
+
+    /**
+     * If -explicit-annotation option is specified.
+     * <p>
+     * This generates code that works around issues specific to 1.4 runtime.
+     */
+    public boolean runtime14 = false;
+
+    /**
+     * strictly follow the compatibility rules and reject schemas that
+     * contain features from App. E.2, use vendor binding extensions
+     */
+    public static final int STRICT = 1;
+    /**
+     * loosely follow the compatibility rules and allow the use of vendor
+     * binding extensions
+     */
+    public static final int EXTENSION = 2;
+
+    /**
+     * this switch determines how carefully the compiler will follow
+     * the compatibility rules in the spec. Either <code>STRICT</code>
+     * or <code>EXTENSION</code>.
+     */
+    public int compatibilityMode = STRICT;
+
+    /** Target direcoty when producing files. */
+    public File targetDir = new File(".");
+
+    /**
+     * Actually stores {@link CatalogResolver}, but the field
+     * type is made to {@link EntityResolver} so that XJC can be
+     * used even if resolver.jar is not available in the classpath.
+     */
+    public EntityResolver entityResolver = null;
+
+    /**
+     * Type of input schema language. One of the <code>SCHEMA_XXX</code>
+     * constants.
+     */
+    private Language schemaLanguage = null;
+
+    /**
+     * The -p option that should control the default Java package that
+     * will contain the generated code. Null if unspecified.
+     */
+    public String defaultPackage = null;
+
+    /**
+     * Similar to the -p option, but this one works with a lower priority,
+     * and customizations overrides this. Used by JAX-RPC.
+     */
+    public String defaultPackage2 = null;
+
+    /**
+     * Input schema files as a list of {@link InputSource}s.
+     */
+    private final List<InputSource> grammars = new ArrayList<InputSource>();
+
+    private final List<InputSource> bindFiles = new ArrayList<InputSource>();
+
+    // Proxy setting.
+    private String proxyHost = null;
+    private String proxyPort = null;
+    private String proxyUser = null;
+    private String proxyPassword = null;
+
+    /**
+     * {@link Plugin}s that are enabled in this compilation.
+     */
+    public final List<Plugin> activePlugins = new ArrayList<Plugin>();
+
+    /**
+     * All discovered {@link Plugin}s.
+     * This is lazily parsed, so that we can take '-cp' option into account.
+     *
+     * @see #getAllPlugins()
+     */
+    private List<Plugin> allPlugins;
+
+    /**
+     * Set of URIs that plug-ins recognize as extension bindings.
+     */
+    public final Set<String> pluginURIs = new HashSet<String>();
+
+    /**
+     * This allocator has the final say on deciding the class name.
+     */
+    public ClassNameAllocator classNameAllocator;
+
+    /**
+     * This switch controls whether or not xjc will generate package level annotations
+     */
+    public boolean packageLevelAnnotations = true;
+
+    /**
+     * This {@link FieldRendererFactory} determines how the fields are generated.
+     */
+    private FieldRendererFactory fieldRendererFactory = new FieldRendererFactory();
+    /**
+     * Used to detect if two {@link Plugin}s try to overwrite {@link #fieldRendererFactory}.
+     */
+    private Plugin fieldRendererFactoryOwner = null;
+
+    /**
+     * If this is non-null, we use this {@link NameConverter} over the one
+     * given in the schema/binding.
+     */
+    private NameConverter nameConverter = null;
+    /**
+     * Used to detect if two {@link Plugin}s try to overwrite {@link #nameConverter}.
+     */
+    private Plugin nameConverterOwner = null;
+
+    /**
+     * Gets the active {@link FieldRendererFactory} that shall be used to build {@link Model}.
+     *
+     * @return always non-null.
+     */
+    public FieldRendererFactory getFieldRendererFactory() {
+        return fieldRendererFactory;
+    }
+
+    /**
+     * Sets the {@link FieldRendererFactory}.
+     *
+     * <p>
+     * This method is for plugins to call to set a custom {@link FieldRendererFactory}.
+     *
+     * @param frf
+     *      The {@link FieldRendererFactory} to be installed. Must not be null.
+     * @param owner
+     *      Identifies the plugin that owns this {@link FieldRendererFactory}.
+     *      When two {@link Plugin}s try to call this method, this allows XJC
+     *      to report it as a user-friendly error message.
+     *
+     * @throws BadCommandLineException
+     *      If a conflit happens, this exception carries a user-friendly error
+     *      message, indicating a conflict.
+     */
+    public void setFieldRendererFactory(FieldRendererFactory frf, Plugin owner) throws BadCommandLineException {
+        // since this method is for plugins, make it bit more fool-proof than usual
+        if(frf==null)
+            throw new IllegalArgumentException();
+        if(fieldRendererFactoryOwner!=null) {
+            throw new BadCommandLineException(
+                Messages.format(Messages.FIELD_RENDERER_CONFLICT,
+                    fieldRendererFactoryOwner.getOptionName(),
+                    owner.getOptionName() ));
+        }
+        this.fieldRendererFactoryOwner = owner;
+        this.fieldRendererFactory = frf;
+    }
+
+
+    /**
+     * Gets the active {@link NameConverter} that shall be used to build {@link Model}.
+     *
+     * @return can be null, in which case it's up to the binding.
+     */
+    public NameConverter getNameConverter() {
+        return nameConverter;
+    }
+
+    /**
+     * Sets the {@link NameConverter}.
+     *
+     * <p>
+     * This method is for plugins to call to set a custom {@link NameConverter}.
+     *
+     * @param nc
+     *      The {@link NameConverter} to be installed. Must not be null.
+     * @param owner
+     *      Identifies the plugin that owns this {@link NameConverter}.
+     *      When two {@link Plugin}s try to call this method, this allows XJC
+     *      to report it as a user-friendly error message.
+     *
+     * @throws BadCommandLineException
+     *      If a conflit happens, this exception carries a user-friendly error
+     *      message, indicating a conflict.
+     */
+    public void setNameConverter(NameConverter nc, Plugin owner) throws BadCommandLineException {
+        // since this method is for plugins, make it bit more fool-proof than usual
+        if(nc==null)
+            throw new IllegalArgumentException();
+        if(nameConverter!=null) {
+            throw new BadCommandLineException(
+                Messages.format(Messages.NAME_CONVERTER_CONFLICT,
+                    nameConverterOwner.getOptionName(),
+                    owner.getOptionName() ));
+        }
+        this.nameConverterOwner = owner;
+        this.nameConverter = nc;
+    }
+
+    /**
+     * Gets all the {@link Plugin}s discovered so far.
+     *
+     * <p>
+     * A plugins are enumerated when this method is called for the first time,
+     * by taking {@link #classpaths} into account. That means
+     * "-cp plugin.jar" has to come before you specify options to enable it.
+     */
+    public List<Plugin> getAllPlugins() {
+        if(allPlugins==null) {
+            allPlugins = new ArrayList<Plugin>();
+            ClassLoader ucl = getUserClassLoader(getClass().getClassLoader());
+            for( Plugin aug : findServices(Plugin.class,ucl) )
+                allPlugins.add(aug);
+        }
+
+        return allPlugins;
+    }
+
+    public Language getSchemaLanguage() {
+        if( schemaLanguage==null)
+            schemaLanguage = guessSchemaLanguage();
+        return schemaLanguage;
+    }
+    public void setSchemaLanguage(Language _schemaLanguage) {
+        this.schemaLanguage = _schemaLanguage;
+    }
+
+    /** Input schema files. */
+    public InputSource[] getGrammars() {
+        return grammars.toArray(new InputSource[grammars.size()]);
+    }
+
+    /**
+     * Adds a new input schema.
+     */
+    public void addGrammar( InputSource is ) {
+        grammars.add(absolutize(is));
+    }
+
+    private InputSource fileToInputSource( File source ) {
+        try {
+            String url = source.toURL().toExternalForm();
+            return new InputSource(Util.escapeSpace(url));
+        } catch (MalformedURLException e) {
+            return new InputSource(source.getPath());
+        }
+    }
+
+    public void addGrammar( File source ) {
+        addGrammar(fileToInputSource(source));
+    }
+
+    /**
+     * Recursively scan directories and add all XSD files in it.
+     */
+    public void addGrammarRecursive( File dir ) {
+        addRecursive(dir,".xsd",grammars);
+    }
+
+    private  void addRecursive( File dir, String suffix, List<InputSource> result ) {
+        File[] files = dir.listFiles();
+        if(files==null)     return; // work defensively
+
+        for( File f : files ) {
+            if(f.isDirectory())
+                addRecursive(f,suffix,result);
+            else
+            if(f.getPath().endsWith(suffix))
+                result.add(absolutize(fileToInputSource(f)));
+        }
+    }
+
+
+    private InputSource absolutize(InputSource is) {
+        // absolutize all the system IDs in the input,
+        // so that we can map system IDs to DOM trees.
+        try {
+            URL baseURL = new File(".").getCanonicalFile().toURL();
+            is.setSystemId( new URL(baseURL,is.getSystemId()).toExternalForm() );
+        } catch( IOException e ) {
+            // ignore
+        }
+        return is;
+    }
+
+
+    /** Input external binding files. */
+    public InputSource[] getBindFiles() {
+        return bindFiles.toArray(new InputSource[bindFiles.size()]);
+    }
+
+    /**
+     * Adds a new input schema.
+     */
+    public void addBindFile( InputSource is ) {
+        bindFiles.add(absolutize(is));
+    }
+
+    /**
+     * Recursively scan directories and add all ".xjb" files in it.
+     */
+    public void addBindFileRecursive( File dir ) {
+        addRecursive(dir,".xjb",bindFiles);
+    }
+
+    public final List<URL> classpaths = new ArrayList<URL>();
+    /**
+     * Gets a classLoader that can load classes specified via the
+     * -classpath option.
+     */
+    public URLClassLoader getUserClassLoader( ClassLoader parent ) {
+        return new URLClassLoader(
+                classpaths.toArray(new URL[classpaths.size()]),parent);
+    }
+
+
+    /**
+     * Parses an option <code>args[i]</code> and return
+     * the number of tokens consumed.
+     *
+     * @return
+     *      0 if the argument is not understood. Returning 0
+     *      will let the caller report an error.
+     * @exception BadCommandLineException
+     *      If the callee wants to provide a custom message for an error.
+     */
+    protected int parseArgument( String[] args, int i ) throws BadCommandLineException {
+        if (args[i].equals("-classpath") || args[i].equals("-cp")) {
+            if (i == args.length - 1)
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_CLASSPATH));
+            File file = new File(args[++i]);
+            try {
+                classpaths.add(file.toURL());
+            } catch (MalformedURLException e) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.NOT_A_VALID_FILENAME,file),e);
+            }
+            return 2;
+        }
+        if (args[i].equals("-d")) {
+            if (i == args.length - 1)
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_DIR));
+            targetDir = new File(args[++i]);
+            if( !targetDir.exists() )
+                throw new BadCommandLineException(
+                    Messages.format(Messages.NON_EXISTENT_DIR,targetDir));
+            return 2;
+        }
+        if (args[i].equals("-readOnly")) {
+            readOnly = true;
+            return 1;
+        }
+        if (args[i].equals("-p")) {
+            if (i == args.length - 1)
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_PACKAGENAME));
+            defaultPackage = args[++i];
+            if(defaultPackage.length()==0) { // user specified default package
+                // there won't be any package to annotate, so disable them
+                // automatically as a usability feature
+                packageLevelAnnotations = false;
+            }
+            return 2;
+        }
+        if (args[i].equals("-debug")) {
+            debugMode = true;
+            verbose = true;
+            return 1;
+        }
+        if (args[i].equals("-nv")) {
+            strictCheck = false;
+            return 1;
+        }
+        if( args[i].equals("-npa")) {
+            packageLevelAnnotations = false;
+            return 1;
+        }
+        if( args[i].equals("-no-header")) {
+            noFileHeader = true;
+            return 1;
+        }
+        if (args[i].equals("-verbose")) {
+            verbose = true;
+            return 1;
+        }
+        if (args[i].equals("-quiet")) {
+            quiet = true;
+            return 1;
+        }
+        if (args[i].equals("-XexplicitAnnotation")) {
+            runtime14 = true;
+            return 1;
+        }
+        if (args[i].equals("-b")) {
+            if (i==args.length-1 || args[i + 1].startsWith("-"))
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_FILENAME));
+
+            addFile(args[i + 1],bindFiles,".xjb");
+            return 2;
+        }
+        if (args[i].equals("-dtd")) {
+            schemaLanguage = Language.DTD;
+            return 1;
+        }
+        if (args[i].equals("-relaxng")) {
+            schemaLanguage = Language.RELAXNG;
+            return 1;
+        }
+        if (args[i].equals("-relaxng-compact")) {
+            schemaLanguage = Language.RELAXNG_COMPACT;
+            return 1;
+        }
+        if (args[i].equals("-xmlschema")) {
+            schemaLanguage = Language.XMLSCHEMA;
+            return 1;
+        }
+        if (args[i].equals("-wsdl")) {
+            schemaLanguage = Language.WSDL;
+            return 1;
+        }
+        if (args[i].equals("-extension")) {
+            compatibilityMode = EXTENSION;
+            return 1;
+        }
+        if (args[i].equals("-httpproxyfile")) {
+            if (i == args.length - 1 || args[i + 1].startsWith("-")) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_PROXYFILE));
+            }
+
+            File file = new File(args[++i]);
+            if(!file.exists()) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.NO_SUCH_FILE,file));
+            }
+
+            try {
+                BufferedReader in = new BufferedReader(new InputStreamReader(new FileInputStream(file),"UTF-8"));
+                parseProxy(in.readLine());
+                in.close();
+            } catch (IOException e) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.FAILED_TO_PARSE,file,e.getMessage()),e);
+            }
+
+            return 2;
+        }
+        if (args[i].equals("-httpproxy")) {
+            if (i == args.length - 1 || args[i + 1].startsWith("-")) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_PROXY));
+            }
+
+            parseProxy(args[++i]);
+            return 2;
+        }
+        if (args[i].equals("-host")) {
+            // legacy option. we use -httpproxy for more control
+            if (i == args.length - 1 || args[i + 1].startsWith("-")) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_PROXYHOST));
+            }
+            proxyHost = args[++i];
+            return 2;
+        }
+        if (args[i].equals("-port")) {
+            // legacy option. we use -httpproxy for more control
+            if (i == args.length - 1 || args[i + 1].startsWith("-")) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_PROXYPORT));
+            }
+            proxyPort = args[++i];
+            return 2;
+        }
+        if( args[i].equals("-catalog") ) {
+            // use Sun's "XML Entity and URI Resolvers" by Norman Walsh
+            // to resolve external entities.
+            // http://www.sun.com/xml/developers/resolver/
+            if (i == args.length - 1)
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_CATALOG));
+
+            File catalogFile = new File(args[++i]);
+            try {
+                addCatalog(catalogFile);
+            } catch (IOException e) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.FAILED_TO_PARSE,catalogFile,e.getMessage()),e);
+            }
+            return 2;
+        }
+        if (args[i].equals("-source")) {
+            if (i == args.length - 1)
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_VERSION));
+            String version = args[++i];
+            //For source 1.0 the 1.0 Driver is loaded
+            //Hence anything other than 2.0 is defaulted to
+            //2.0
+            if( !version.equals("2.0") )
+                throw new BadCommandLineException(
+                    Messages.format(Messages.DEFAULT_VERSION));
+            return 2;
+        }
+        if( args[i].equals("-Xtest-class-name-allocator") ) {
+            classNameAllocator = new ClassNameAllocator() {
+                public String assignClassName(String packageName, String className) {
+                    System.out.printf("assignClassName(%s,%s)\n",packageName,className);
+                    return className+"_Type";
+                }
+            };
+            return 1;
+        }
+
+        // see if this is one of the extensions
+        for( Plugin plugin : getAllPlugins() ) {
+            if( ('-'+plugin.getOptionName()).equals(args[i]) ) {
+                activePlugins.add(plugin);
+                plugin.onActivated(this);
+                pluginURIs.addAll(plugin.getCustomizationURIs());
+                return 1;
+            }
+
+            try {
+                int r = plugin.parseArgument(this,args,i);
+                if(r!=0)    return r;
+            } catch (IOException e) {
+                throw new BadCommandLineException(e.getMessage(),e);
+            }
+        }
+
+        return 0;   // unrecognized
+    }
+
+    private void parseProxy(String text) throws BadCommandLineException {
+        // syntax is [user[:password]@]proxyHost:proxyPort
+        String token = "([^@:]+)";
+        Pattern p = Pattern.compile("(?:"+token+"(?:\\:"+token+")?\\@)?"+token+"(?:\\:"+token+")");
+
+        Matcher matcher = p.matcher(text);
+        if(!matcher.matches())
+            throw new BadCommandLineException(Messages.format(Messages.ILLEGAL_PROXY,text));
+
+        proxyUser = matcher.group(1);
+        proxyPassword = matcher.group(2);
+        proxyHost = matcher.group(3);
+        proxyPort = matcher.group(4);
+        try {
+            Integer.valueOf(proxyPort);
+        } catch (NumberFormatException e) {
+            throw new BadCommandLineException(Messages.format(Messages.ILLEGAL_PROXY,text));
+        }
+    }
+
+    /**
+     * Parses a token to a file (or a set of files)
+     * and add them as {@link InputSource} to the specified list.
+     *
+     * @param suffix
+     *      If the given token is a directory name, we do a recusive search
+     *      and find all files that have the given suffix.
+     */
+    private void addFile(String name, List<InputSource> target, String suffix) throws BadCommandLineException {
+        Object src;
+        try {
+            src = Util.getFileOrURL(name);
+        } catch (IOException e) {
+            throw new BadCommandLineException(
+                Messages.format(Messages.NOT_A_FILE_NOR_URL,name));
+        }
+        if(src instanceof URL) {
+            target.add(absolutize(new InputSource(Util.escapeSpace(((URL)src).toExternalForm()))));
+        } else {
+            File fsrc = (File)src;
+            if(fsrc.isDirectory()) {
+                addRecursive(fsrc,suffix,target);
+            } else {
+                target.add(absolutize(fileToInputSource(fsrc)));
+            }
+        }
+    }
+
+    /**
+     * Adds a new catalog file.
+     */
+    public void addCatalog(File catalogFile) throws IOException {
+        if(entityResolver==null) {
+            CatalogManager.getStaticManager().setIgnoreMissingProperties(true);
+            entityResolver = new CatalogResolver(true);
+        }
+        ((CatalogResolver)entityResolver).getCatalog().parseCatalog(catalogFile.getPath());
+    }
+
+    /**
+     * Parses arguments and fill fields of this object.
+     *
+     * @exception BadCommandLineException
+     *      thrown when there's a problem in the command-line arguments
+     */
+    public void parseArguments( String[] args ) throws BadCommandLineException {
+
+        for (int i = 0; i < args.length; i++) {
+            if(args[i].length()==0)
+                throw new BadCommandLineException();
+            if (args[i].charAt(0) == '-') {
+                int j = parseArgument(args,i);
+                if(j==0)
+                    throw new BadCommandLineException(
+                        Messages.format(Messages.UNRECOGNIZED_PARAMETER, args[i]));
+                i += (j-1);
+            } else {
+                addFile(args[i],grammars,".xsd");
+            }
+        }
+
+        // configure proxy
+        if (proxyHost != null || proxyPort != null) {
+            if (proxyHost != null && proxyPort != null) {
+                System.setProperty("http.proxyHost", proxyHost);
+                System.setProperty("http.proxyPort", proxyPort);
+                System.setProperty("https.proxyHost", proxyHost);
+                System.setProperty("https.proxyPort", proxyPort);
+            } else if (proxyHost == null) {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_PROXYHOST));
+            } else {
+                throw new BadCommandLineException(
+                    Messages.format(Messages.MISSING_PROXYPORT));
+            }
+            if(proxyUser!=null)
+                System.setProperty("http.proxyUser", proxyUser);
+            if(proxyPassword!=null)
+                System.setProperty("http.proxyPassword", proxyPassword);
+
+        }
+
+        if (grammars.size() == 0)
+            throw new BadCommandLineException(
+                Messages.format(Messages.MISSING_GRAMMAR));
+
+        if( schemaLanguage==null )
+            schemaLanguage = guessSchemaLanguage();
+    }
+
+
+    /**
+     * Guesses the schema language.
+     */
+    public Language guessSchemaLanguage() {
+        // otherwise, use the file extension.
+        // not a good solution, but very easy.
+        String name = grammars.get(0).getSystemId().toLowerCase();
+
+        if (name.endsWith(".rng"))
+            return Language.RELAXNG;
+        if (name.endsWith(".rnc"))
+            return Language.RELAXNG_COMPACT;
+        if (name.endsWith(".dtd"))
+            return Language.DTD;
+        if (name.endsWith(".wsdl"))
+            return Language.WSDL;
+
+        // by default, assume XML Schema
+        return Language.XMLSCHEMA;
+    }
+
+    /**
+     * Creates a configured CodeWriter that produces files into the specified directory.
+     */
+    public CodeWriter createCodeWriter() throws IOException {
+        return createCodeWriter(new FileCodeWriter( targetDir, readOnly ));
+    }
+
+    /**
+     * Creates a configured CodeWriter that produces files into the specified directory.
+     */
+    public CodeWriter createCodeWriter( CodeWriter core ) {
+        if(noFileHeader)
+            return core;
+
+        // generate format syntax: <date> 'at' <time>
+        String format =
+            Messages.format(Messages.DATE_FORMAT)
+                + " '"
+                + Messages.format(Messages.AT)
+                + "' "
+                + Messages.format(Messages.TIME_FORMAT);
+        SimpleDateFormat dateFormat = new SimpleDateFormat(format);
+
+        return new PrologCodeWriter( core,
+                Messages.format(
+                    Messages.FILE_PROLOG_COMMENT,
+                    dateFormat.format(new Date())) );
+    }
+
+
+
+
+    /**
+     * Looks for all "META-INF/services/[className]" files and
+     * create one instance for each class name found inside this file.
+     */
+    private static <T> T[] findServices( Class<T> clazz, ClassLoader classLoader ) {
+        // if true, print debug output
+        final boolean debug = com.sun.tools.internal.xjc.util.Util.getSystemProperty(Options.class,"findServices")!=null;
+
+        String serviceId = "META-INF/services/" + clazz.getName();
+
+        // used to avoid creating the same instance twice
+        Set<String> classNames = new HashSet<String>();
+
+        if(debug) {
+            System.out.println("Looking for "+serviceId+" for add-ons");
+        }
+
+        // try to find services in CLASSPATH
+        try {
+            Enumeration<URL> e = classLoader.getResources(serviceId);
+            if(e==null) return (T[])Array.newInstance(clazz,0);
+
+            ArrayList<T> a = new ArrayList<T>();
+            while(e.hasMoreElements()) {
+                URL url = e.nextElement();
+                BufferedReader reader=null;
+
+                if(debug) {
+                    System.out.println("Checking "+url+" for an add-on");
+                }
+
+                try {
+                    reader = new BufferedReader(new InputStreamReader(url.openStream()));
+                    String impl;
+                    while((impl = reader.readLine())!=null ) {
+                        // try to instanciate the object
+                        impl = impl.trim();
+                        if(classNames.add(impl)) {
+                            Class implClass = classLoader.loadClass(impl);
+                            if(!clazz.isAssignableFrom(implClass)) {
+                                if(debug) {
+                                    System.out.println(impl+" is not a subclass of "+clazz+". Skipping");
+                                }
+                                continue;
+                            }
+                            if(debug) {
+                                System.out.println("Attempting to instanciate "+impl);
+                            }
+                            a.add(clazz.cast(implClass.newInstance()));
+                        }
+                    }
+                    reader.close();
+                } catch( Exception ex ) {
+                    // let it go.
+                    if(debug) {
+                        ex.printStackTrace(System.out);
+                    }
+                    if( reader!=null ) {
+                        try {
+                            reader.close();
+                        } catch( IOException ex2 ) {
+                            // ignore
+                        }
+                    }
+                }
+            }
+
+            return a.toArray((T[])Array.newInstance(clazz,a.size()));
+        } catch( Throwable e ) {
+            // ignore any error
+            if(debug) {
+                e.printStackTrace(System.out);
+            }
+            return (T[])Array.newInstance(clazz,0);
+        }
+    }
+
+    // this is a convenient place to expose the build version to xjc plugins
+    public static String getBuildID() {
+        return Messages.format(Messages.BUILD_ID);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/Plugin.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Plugin.java
new file mode 100644
index 0000000..82d21d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/Plugin.java
@@ -0,0 +1,233 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.io.IOException;
+import java.util.Collections;
+import java.util.List;
+
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRendererFactory;
+import com.sun.tools.internal.xjc.model.CPluginCustomization;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+import org.xml.sax.ErrorHandler;
+
+/**
+ * Add-on that works on the generated source code.
+ *
+ * <p>
+ * This add-on will be called after the default bean generation
+ * has finished.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ *
+ * @since
+ *      JAXB RI 2.0 EA
+ */
+public abstract class Plugin {
+
+    /**
+     * Gets the option name to turn on this add-on.
+     *
+     * <p>
+     * For example, if "abc" is returned, "-abc" will
+     * turn on this plugin. A plugin needs to be turned
+     * on explicitly, or else no other methods of {@link Plugin}
+     * will be invoked.
+     */
+    public abstract String getOptionName();
+
+    /**
+     * Gets the description of this add-on. Used to generate
+     * a usage screen.
+     *
+     * @return
+     *      localized description message. should be terminated by \n.
+     */
+    public abstract String getUsage();
+
+    /**
+     * Parses an option <code>args[i]</code> and augment
+     * the <code>opt</code> object appropriately, then return
+     * the number of tokens consumed.
+     *
+     * <p>
+     * The callee doesn't need to recognize the option that the
+     * getOptionName method returns.
+     *
+     * <p>
+     * Once a plugin is activated, this method is called
+     * for options that XJC didn't recognize. This allows
+     * a plugin to define additional options to customize
+     * its behavior.
+     *
+     * <p>
+     * Since options can appear in no particular order,
+     * XJC allows sub-options of a plugin to show up before
+     * the option that activates a plugin (one that's returned
+     * by {@link #getOptionName().)
+     *
+     * But nevertheless a {@link Plugin} needs to be activated
+     * to participate in further processing.
+     *
+     * @return
+     *      0 if the argument is not understood.
+     *      Otherwise return the number of tokens that are
+     *      consumed, including the option itself.
+     *      (so if you have an option like "-foo 3", return 2.)
+     * @exception BadCommandLineException
+     *      If the option was recognized but there's an error.
+     *      This halts the argument parsing process and causes
+     *      XJC to abort, reporting an error.
+     */
+    public int parseArgument( Options opt, String[] args, int i ) throws BadCommandLineException, IOException {
+        return 0;
+    }
+
+    /**
+     * Returns the list of namespace URIs that are supported by this plug-in
+     * as schema annotations.
+     *
+     * <p>
+     * If a plug-in returns a non-empty list, the JAXB RI will recognize
+     * these namespace URIs as vendor extensions
+     * (much like "http://java.sun.com/xml/ns/jaxb/xjc"). This allows users
+     * to write those annotations inside a schema, or in external binding files,
+     * and later plug-ins can access those annotations as DOM nodes.
+     *
+     * <p>
+     * See <a href="http://java.sun.com/webservices/docs/1.5/jaxb/vendorCustomizations.html">
+     * http://java.sun.com/webservices/docs/1.5/jaxb/vendorCustomizations.html</a>
+     * for the syntax that users need to use to enable extension URIs.
+     *
+     * @return
+     *      can be empty, be never be null.
+     */
+    public List<String> getCustomizationURIs() {
+        return Collections.emptyList();
+    }
+
+    /**
+     * Checks if the given tag name is a valid tag name for the customization element in this plug-in.
+     *
+     * <p>
+     * This method is invoked by XJC to determine if the user-specified customization element
+     * is really a customization or not. This information is used to pick the proper error message.
+     *
+     * <p>
+     * A plug-in is still encouraged to do the validation of the customization element in the
+     * {@link #run} method before using any {@link CPluginCustomization}, to make sure that it
+     * has proper child elements and attributes.
+     *
+     * @param nsUri
+     *      the namespace URI of the element. Never null.
+     * @param localName
+     *      the local name of the element. Never null.
+     */
+    public boolean isCustomizationTagName(String nsUri,String localName) {
+        return false;
+    }
+
+    /**
+     * Notifies a plugin that it's activated.
+     *
+     * <p>
+     * This method is called when a plugin is activated
+     * through the command line option (as specified by {@link #getOptionName()}.
+     *
+     * <p>
+     * This is a good opportunity to use
+     * {@link Options#setFieldRendererFactory(FieldRendererFactory, Plugin)}
+     * if a plugin so desires.
+     *
+     * <p>
+     * Noop by default.
+     *
+     * @since JAXB 2.0 EA4
+     */
+    public void onActivated(Options opts) throws BadCommandLineException {
+        // noop
+    }
+
+    /**
+     * Performs the post-processing of the {@link Model}.
+     *
+     * <p>
+     * This method is invoked after XJC has internally finished
+     * the model construction. This is a chance for a plugin to
+     * affect the way code generation is performed.
+     *
+     * <p>
+     * Compared to the {@link #run(Outline, Options, ErrorHandler)}
+     * method, this method allows a plugin to work at the higher level
+     * conceptually closer to the abstract JAXB model, as opposed to
+     * Java syntax level.
+     *
+     * <p>
+     * Note that this method is invoked only when a {@link Plugin}
+     * is activated.
+     *
+     * @param model
+     *      The object that represents the classes/properties to
+     *      be generated.
+     *
+     * @param errorHandler
+     *      Errors should be reported to this handler.
+     *
+     * @since JAXB 2.0.2
+     */
+    public void postProcessModel(Model model, ErrorHandler errorHandler) {
+        // noop
+    }
+
+    /**
+     * Run the add-on.
+     *
+     * <p>
+     * This method is invoked after XJC has internally finished
+     * the code generation. Plugins can tweak some of the generated
+     * code (or add more code) by using {@link Outline} and {@link Options}.
+     *
+     * <p>
+     * Note that this method is invoked only when a {@link Plugin}
+     * is activated.
+     *
+     * @param outline
+     *      This object allows access to various generated code.
+     *
+     * @param errorHandler
+     *      Errors should be reported to this handler.
+     *
+     * @return
+     *      If the add-on executes successfully, return true.
+     *      If it detects some errors but those are reported and
+     *      recovered gracefully, return false.
+     */
+    public abstract boolean run(
+        Outline outline, Options opt, ErrorHandler errorHandler );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/ProgressCodeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/ProgressCodeWriter.java
new file mode 100644
index 0000000..b0dc87c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/ProgressCodeWriter.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.Writer;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.writer.FilterCodeWriter;
+
+/**
+ * {@link CodeWriter} that reports progress to {@link XJCListener}.
+ */
+final class ProgressCodeWriter extends FilterCodeWriter {
+
+    private int current;
+    private final int totalFileCount;
+
+    public ProgressCodeWriter( CodeWriter output, XJCListener progress, int totalFileCount ) {
+        super(output);
+        this.progress = progress;
+        this.totalFileCount = totalFileCount;
+        if(progress==null)
+            throw new IllegalArgumentException();
+    }
+
+    private final XJCListener progress;
+
+    public Writer openSource(JPackage pkg, String fileName) throws IOException {
+        report(pkg,fileName);
+        return super.openSource(pkg, fileName);
+    }
+
+    public OutputStream openBinary(JPackage pkg, String fileName) throws IOException {
+        report(pkg,fileName);
+        return super.openBinary(pkg,fileName);
+    }
+
+    private void report(JPackage pkg, String fileName) {
+        String name = pkg.name().replace('.', File.separatorChar);
+        if(name.length()!=0)    name +=     File.separatorChar;
+        name += fileName;
+
+        progress.generatedFile(name,current++,totalFileCount);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/SchemaCache.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/SchemaCache.java
new file mode 100644
index 0000000..c419344
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/SchemaCache.java
@@ -0,0 +1,120 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.net.URL;
+
+import javax.xml.validation.Schema;
+import javax.xml.validation.SchemaFactory;
+import javax.xml.validation.ValidatorHandler;
+
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Wraps a JAXP {@link Schema} object and lazily instanciate it.
+ *
+ * Also fix bug 6246922.
+ *
+ * This object is thread-safe. There should be only one instance of
+ * this for the whole VM.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class SchemaCache {
+
+    private Schema schema;
+
+    private final URL source;
+
+    public SchemaCache(URL source) {
+        this.source = source;
+    }
+
+    public ValidatorHandler newValidator() {
+        synchronized(this) {
+            if(schema==null) {
+                try {
+                    schema = SchemaFactory.newInstance(WellKnownNamespace.XML_SCHEMA).newSchema(source);
+                } catch (SAXException e) {
+                    // we make sure that the schema is correct before we ship.
+                    throw new AssertionError(e);
+                }
+            }
+        }
+
+        ValidatorHandler handler = schema.newValidatorHandler();
+        fixValidatorBug6246922(handler);
+
+        return handler;
+    }
+
+
+    /**
+     * Fix the bug 6246922 if we are running inside Tiger.
+     */
+    private void fixValidatorBug6246922(ValidatorHandler handler) {
+        try {
+            Field f = handler.getClass().getDeclaredField("errorReporter");
+            f.setAccessible(true);
+            Object errorReporter = f.get(handler);
+
+            Method get = errorReporter.getClass().getDeclaredMethod("getMessageFormatter",String.class);
+            Object currentFormatter = get.invoke(errorReporter,"http://www.w3.org/TR/xml-schema-1");
+            if(currentFormatter!=null)
+                return;
+
+            // otherwise attempt to set
+            Method put = null;
+            for( Method m : errorReporter.getClass().getDeclaredMethods() ) {
+                if(m.getName().equals("putMessageFormatter")) {
+                    put = m;
+                    break;
+                }
+            }
+            if(put==null)       return; // unable to find the putMessageFormatter
+
+            ClassLoader cl = errorReporter.getClass().getClassLoader();
+            String className = "com.sun.org.apache.xerces.internal.impl.xs.XSMessageFormatter";
+            Class xsformatter;
+            if(cl==null) {
+                xsformatter = Class.forName(className);
+            } else {
+                xsformatter = cl.loadClass(className);
+            }
+
+            put.invoke(errorReporter,"http://www.w3.org/TR/xml-schema-1",xsformatter.newInstance());
+        } catch( Throwable t ) {
+            // this code is heavily relying on an implementation detail of JAXP RI,
+            // so any error is likely because of the incompatible change in it.
+            // don't die if that happens. Just continue. The worst case is a illegible
+            // error messages, which are much better than not compiling schemas at all.
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/XJCListener.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/XJCListener.java
new file mode 100644
index 0000000..9df0cd3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/XJCListener.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc;
+
+import java.io.PrintStream;
+
+import com.sun.tools.internal.xjc.api.ErrorListener;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * Call-back interface that can be implemented by the caller of {@link Driver}
+ * to receive output from XJC.
+ *
+ * <p>
+ * Most of the messages XJC produce once the real work starts is structured
+ * as (message,source). Those outputs will be reported to various methods on
+ * {@link ErrorListener}, which is inherited by this interface.
+ *
+ * <p>
+ * The other messages (such as the usage screen when there was an error in
+ * the command line option) will go to the {@link #message(String)} method.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB 2.0 EA
+ */
+public abstract class XJCListener implements ErrorListener {
+
+    /**
+     * @deprecated
+     *      Override {@link #generatedFile(String, int, int)}.
+     *      Deprecated in 2.0.1.
+     */
+    public void generatedFile(String fileName) {}
+
+    /**
+     * Called for each file generated by XJC.
+     *
+     * <p>
+     * XJC may generate not only source files but also resources files.
+     * The file name includes the path portions that correspond with the package name.
+     *
+     * <p>
+     * When generating files into a directory, file names will be relative to the
+     * output directory. When generating files into a zip file, file names will be
+     * those in the zip file.
+     *
+     * @param fileName
+     *      file names like "org/acme/foo/Foo.java" or "org/acme/foo/jaxb.properties".
+     *
+     * @since 2.0.1
+     */
+    public void generatedFile(String fileName, int current, int total ) {
+        generatedFile(fileName);    // backward compatibility
+    }
+
+    /**
+     * Other miscellenous messages that do not have structures
+     * will be reported through this method.
+     *
+     * This method is used like {@link PrintStream#println(String)}.
+     * The callee is expected to add '\n'.
+     */
+    public void message(String msg) {}
+
+    /**
+     * Called after the schema is compiled and the code generation strategy is determined,
+     * but before any code is actually generated as files.
+     *
+     * @param outline
+     *      never null. this is the root object that represents the code generation strategy.
+     */
+    public void compiled(Outline outline) {}
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/at_generated/PluginImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/at_generated/PluginImpl.java
new file mode 100644
index 0000000..6b72ddc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/at_generated/PluginImpl.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.addon.at_generated;
+
+import java.text.SimpleDateFormat;
+import java.util.Date;
+
+import com.sun.codemodel.internal.JAnnotatable;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.tools.internal.xjc.Driver;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+import com.sun.tools.internal.xjc.outline.EnumOutline;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+import org.xml.sax.ErrorHandler;
+
+/**
+ * {@link Plugin} that marks the generated code by using JSR-250's '@Generated'.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class PluginImpl extends Plugin {
+
+    public String getOptionName() {
+        return "mark-generated";
+    }
+
+    public String getUsage() {
+        return "  -mark-generated    :  mark the generated code as @javax.annotation.Generated";
+    }
+
+    private JClass annotation;
+
+    public boolean run( Outline model, Options opt, ErrorHandler errorHandler ) {
+        // we want this to work without requiring JSR-250 jar.
+        annotation = model.getCodeModel().ref("javax.annotation.Generated");
+
+        for( ClassOutline co : model.getClasses() )
+            augument(co);
+        for( EnumOutline eo : model.getEnums() )
+            augument(eo);
+
+        //TODO: process generated ObjectFactory classes?
+
+        return true;
+    }
+
+    private void augument(EnumOutline eo) {
+        annotate(eo.clazz);
+    }
+
+    /**
+     * Adds "@Generated" to the classes, methods, and fields.
+     */
+    private void augument(ClassOutline co) {
+        annotate(co.implClass);
+        for (JMethod m : co.implClass.methods())
+            annotate(m);
+        for (JFieldVar f : co.implClass.fields().values())
+            annotate(f);
+    }
+
+    private void annotate(JAnnotatable m) {
+        m.annotate(annotation)
+                .param("value",Driver.class.getName())
+                .param("date", getISO8601Date())
+                .param("comment", "JAXB RI v" + Options.getBuildID());
+    }
+
+    // cache the timestamp so that all the @Generated annotations match
+    private String date = null;
+
+    /**
+     * calculate the date value in ISO8601 format for the @Generated annotation
+     * @return the date value
+     */
+    private String getISO8601Date() {
+        if(date==null) {
+            StringBuffer tstamp = new StringBuffer();
+            tstamp.append((new SimpleDateFormat("yyyy-MM-dd'T'hh:mm:ssZ")).format(new Date()));
+            // hack to get ISO 8601 style timezone - is there a better way that doesn't require
+            // a bunch of timezone offset calculations?
+            tstamp.insert(tstamp.length()-2, ':');
+            date = tstamp.toString();
+        }
+        return date;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/code_injector/Const.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/code_injector/Const.java
new file mode 100644
index 0000000..f7ec985
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/code_injector/Const.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.addon.code_injector;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class Const {
+    /**
+     * Customization namespace URI.
+     */
+    public static final String NS = "http://jaxb.dev.java.net/plugin/code-injector";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/code_injector/PluginImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/code_injector/PluginImpl.java
new file mode 100644
index 0000000..999c190
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/code_injector/PluginImpl.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.addon.code_injector;
+
+import java.util.Collections;
+import java.util.List;
+
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.tools.internal.xjc.model.CPluginCustomization;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.tools.internal.xjc.util.DOMUtils;
+
+import org.xml.sax.ErrorHandler;
+
+/**
+ * Entry point of a plugin.
+ *
+ * See the javadoc of {@link Plugin} for what those methods mean.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class PluginImpl extends Plugin {
+    public String getOptionName() {
+        return "Xinject-code";
+    }
+
+    public List<String> getCustomizationURIs() {
+        return Collections.singletonList(Const.NS);
+    }
+
+    public boolean isCustomizationTagName(String nsUri, String localName) {
+        return nsUri.equals(Const.NS) && localName.equals("code");
+    }
+
+    public String getUsage() {
+        return "  -Xinject-code      :  inject specified Java code fragments into the generated code";
+    }
+
+    // meat of the processing
+    public boolean run(Outline model, Options opt, ErrorHandler errorHandler) {
+        for( ClassOutline co : model.getClasses() ) {
+            CPluginCustomization c = co.target.getCustomizations().find(Const.NS,"code");
+            if(c==null)
+                continue;   // no customization --- nothing to inject here
+
+            c.markAsAcknowledged();
+            // TODO: ideally you should validate this DOM element to make sure
+            // that there's no typo/etc. JAXP 1.3 can do this very easily.
+            String codeFragment = DOMUtils.getElementText(c.element);
+
+            // inject the specified code fragment into the implementation class.
+            co.implClass.direct(codeFragment);
+        }
+
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/locator/SourceLocationAddOn.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/locator/SourceLocationAddOn.java
new file mode 100644
index 0000000..b352284
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/locator/SourceLocationAddOn.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.addon.locator;
+
+import java.io.IOException;
+
+import javax.xml.bind.annotation.XmlTransient;
+
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.BadCommandLineException;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.Locatable;
+import com.sun.xml.internal.bind.annotation.XmlLocation;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+
+/**
+ * Generates JAXB objects that implement {@link Locatable}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class SourceLocationAddOn extends Plugin {
+
+    public String getOptionName() {
+        return "Xlocator";
+    }
+
+    public String getUsage() {
+        return "  -Xlocator          :  enable source location support for generated code";
+    }
+
+    public int parseArgument(Options opt, String[] args, int i) throws BadCommandLineException, IOException {
+        return 0;   // no option recognized
+    }
+
+    private static final String fieldName = "locator";
+
+    public boolean run(
+        Outline outline,
+        Options opt,
+        ErrorHandler errorHandler ) {
+
+        for( ClassOutline ci : outline.getClasses() ) {
+            JDefinedClass impl = ci.implClass;
+            if (ci.getSuperClass() == null) {
+                JVar $loc = impl.field(JMod.PROTECTED, Locator.class, fieldName);
+                $loc.annotate(XmlLocation.class);
+                $loc.annotate(XmlTransient.class);
+
+                impl._implements(Locatable.class);
+
+                impl.method(JMod.PUBLIC, Locator.class, "sourceLocation").body()._return($loc);
+            }
+        }
+
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/sync/SynchronizedMethodAddOn.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/sync/SynchronizedMethodAddOn.java
new file mode 100644
index 0000000..100ccb0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/addon/sync/SynchronizedMethodAddOn.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.addon.sync;
+
+import java.io.IOException;
+
+import com.sun.codemodel.internal.JMethod;
+import com.sun.tools.internal.xjc.BadCommandLineException;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+import org.xml.sax.ErrorHandler;
+
+/**
+ * Generates synchronized methods.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class SynchronizedMethodAddOn extends Plugin {
+
+    public String getOptionName() {
+        return "Xsync-methods";
+    }
+
+    public String getUsage() {
+        return "  -Xsync-methods     :  generate accessor methods with the 'synchronized' keyword";
+    }
+
+    public int parseArgument(Options opt, String[] args, int i) throws BadCommandLineException, IOException {
+        return 0;   // no option recognized
+    }
+
+    public boolean run( Outline model, Options opt, ErrorHandler errorHandler ) {
+
+        for( ClassOutline co : model.getClasses() )
+            augument(co);
+
+        return true;
+    }
+
+    /**
+     * Adds "synchoronized" to all the methods.
+     */
+    private void augument(ClassOutline co) {
+        for (JMethod m : co.implClass.methods())
+            m.getMods().setSynchronized(true);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/ClassNameAllocator.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/ClassNameAllocator.java
new file mode 100644
index 0000000..cad2d41
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/ClassNameAllocator.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+/**
+ * Callback interface that allows the driver of the XJC API
+ * to rename JAXB-generated classes/interfaces/enums.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface ClassNameAllocator {
+    /**
+     * Hook that allows the client of the XJC API to rename some of the JAXB-generated classes.
+     *
+     * <p>
+     * When registered, this calllbcak is consulted for every package-level
+     * classes/interfaces/enums (hereafter, simply "classes")
+     * that the JAXB RI generates. Note that
+     * the JAXB RI does not use this allocator for nested/inner classes.
+     *
+     * <p>
+     * If the allocator chooses to rename some classes. It is
+     * the allocator's responsibility to find unique names.
+     * If the returned name collides with other classes, the JAXB RI will
+     * report errors.
+     *
+     * @param packageName
+     *      The package name, such as "" or "foo.bar". Never be null.
+     * @param className
+     *      The short name of the proposed class name. Such as
+     *      "Foo" or "Bar". Never be null, never be empty.
+     *      Always a valid Java identifier.
+     *
+     * @return
+     *      The short name of the class name that should be used.
+     *      The class will be generated into the same package with this name.
+     *      The return value must be a valid Java identifier. May not be null.
+     */
+    String assignClassName( String packageName, String className );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/ErrorListener.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/ErrorListener.java
new file mode 100644
index 0000000..a83d313
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/ErrorListener.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Implemented by the driver of the compiler engine to handle
+ * errors found during the compiliation.
+ *
+ * <p>
+ * This class implements {@link ErrorHandler} so it can be
+ * passed to anywhere where {@link ErrorHandler} is expected.
+ *
+ * <p>
+ * However, to make the error handling easy (and make it work
+ * with visitor patterns nicely), this interface is not allowed
+ * to abort the processing. It merely receives errors.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface ErrorListener extends ErrorHandler {
+    void error(SAXParseException exception);
+    void fatalError(SAXParseException exception);
+    void warning(SAXParseException exception);
+    /**
+     * Used to report possibly verbose information that
+     * can be safely ignored.
+     */
+    void info(SAXParseException exception);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/J2SJAXBModel.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/J2SJAXBModel.java
new file mode 100644
index 0000000..2fa0154
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/J2SJAXBModel.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import java.io.IOException;
+
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.namespace.QName;
+
+/**
+ * {@link JAXBModel} that exposes additional information available
+ * only for the java->schema direction.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface J2SJAXBModel extends JAXBModel {
+    /**
+     * Returns the name of the XML Type bound to the
+     * specified Java type.
+     *
+     * @param javaType
+     *      must not be null. This must be one of the {@link Reference}s specified
+     *      in the {@link JavaCompiler#bind} method.
+     *
+     * @return
+     *      null if it is not a part of the input to {@link JavaCompiler#bind}.
+     *
+     * @throws IllegalArgumentException
+     *      if the parameter is null
+     */
+    QName getXmlTypeName(Reference javaType);
+
+    /**
+     * Generates the schema documents from the model.
+     *
+     * <p>
+     * The caller can use the additionalElementDecls parameter to
+     * add element declarations to the generate schema.
+     * For example, if the JAX-RPC passes in the following entry:
+     *
+     * {foo}bar -> DeclaredType for java.lang.String
+     *
+     * then JAXB generates the following element declaration (in the schema
+     * document for the namespace "foo")"
+     *
+     * &lt;xs:element name="bar" type="xs:string" />
+     *
+     * This can be used for generating schema components necessary for WSDL.
+     *
+     * @param outputResolver
+     *      this object controls the output to which schemas
+     *      will be sent.
+     *
+     * @throws IOException
+     *      if {@link SchemaOutputResolver} throws an {@link IOException}.
+     */
+    void generateSchema(SchemaOutputResolver outputResolver, ErrorListener errorListener) throws IOException;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/JAXBModel.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/JAXBModel.java
new file mode 100644
index 0000000..c586246
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/JAXBModel.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import java.util.List;
+
+import javax.xml.bind.JAXBContext;
+
+/**
+ * The in-memory representation of the JAXB binding.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface JAXBModel {
+
+    /**
+     * Returns a list of fully-qualified class names, which should
+     * be used at the runtime to create a new {@link JAXBContext}.
+     *
+     * <p>
+     * Until the JAXB team fixes the bootstrapping issue, we have
+     * two bootstrapping methods. This one is to use a list of class names
+     * to call {@link JAXBContext#newInstance(Class[])} method. If
+     * this method returns non-null, the caller is expected to use
+     * that method. <b>This is meant to be a temporary workaround.</b>
+     *
+     * @return
+     *      non-null read-only list.
+     *
+     * @deprecated
+     *      this method is provided for now to allow gradual migration for JAX-RPC.
+     */
+    List<String> getClassList();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/JavaCompiler.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/JavaCompiler.java
new file mode 100644
index 0000000..a5840c2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/JavaCompiler.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import java.util.Collection;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+
+
+/**
+ * Java-to-Schema compiler.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface JavaCompiler {
+
+    /**
+     * Compiles the given annotated Java source code.
+     *
+     * <p>
+     * This operation takes a set of "root types", then compute the list of
+     * all the types that need to be bound by forming a transitive reflexive
+     * closure of types that are referenced by the root types.
+     *
+     * <p>
+     * Errors will be sent to {@link AnnotationProcessorEnvironment#getMessager()}.
+     *
+     * @param rootTypes
+     *      The list of types that needs to be bound to XML.
+     *      "root references" from JAX-RPC to JAXB is always in the form of (type,annotations) pair.
+     *
+     * @param additionalElementDecls
+     *      Add element declarations for the specified element names to
+     *      the XML types mapped from the corresponding {@link Reference}s.
+     *      Those {@link Reference}s must be included in the <tt>rootTypes</tt> parameter.
+     *      In this map, a {@link Reference} can be null, in which case the element name is
+     *      declared to have an empty complex type.
+     *      (&lt;xs:element name='foo'>&lt;xs:complexType/>&lt;/xs:element>)
+     *      This parameter can be null, in which case the method behaves as if the empty map is given.
+     *
+     * @param defaultNamespaceRemap
+     *      If not-null, all the uses of the empty default namespace ("") will
+     *      be replaced by this namespace URI.
+     *
+     * @param source
+     *      The caller supplied view to the annotated source code that JAXB is going to process.
+     *
+     * @return
+     *      Non-null if no error was reported. Otherwise null.
+     */
+    J2SJAXBModel bind(
+            Collection<Reference> rootTypes,
+            Map<QName, Reference> additionalElementDecls,
+            String defaultNamespaceRemap,
+            AnnotationProcessorEnvironment source );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Mapping.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Mapping.java
new file mode 100644
index 0000000..14db890
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Mapping.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+/**
+ * JAXB-induced mapping between a Java class
+ * and an XML element declaration. A part of the compiler artifacts.
+ *
+ * <p>
+ * To be precise, this is a mapping between two Java classes and an
+ * XML element declaration. There's one Java class/interface that
+ * represents the element, and there's another Java class/interface that
+ * represents the type of the element.
+ *
+ * The former is called "element representation" and the latter is called
+ * "type representation".
+ *
+ * <p>
+ * The {@link Mapping} interface provides operation that lets the caller
+ * convert an instance of the element representation to that of the
+ * type representation or vice versa.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface Mapping {
+    /**
+     * Name of the XML element.
+     *
+     * @return
+     *      never be null.
+     */
+    QName getElement();
+
+    /**
+     * Returns the fully-qualified name of the java class for the type of this element.
+     *
+     * TODO: does this method returns the name of the wrapper bean when it's qualified
+     * for the wrapper style? Seems no (consider &lt;xs:element name='foo' type='xs:long' />),
+     * but then how does JAX-RPC captures that bean?
+     *
+     * @return
+     *      never be null.
+     */
+    TypeAndAnnotation getType();
+
+    /**
+     * If this element is a so-called "wrapper-style" element,
+     * obtains its member information.
+     *
+     * <p>
+     * The notion of the wrapper style should be defined by the JAXB spec,
+     * and ideally it should differ from that of the JAX-RPC only at
+     * the point where the JAX-RPC imposes additional restriction
+     * on the element name.
+     *
+     * <p>
+     * As of this writing the JAXB spec doesn't define "the wrapper style"
+     * and as such the exact definition of what XJC thinks
+     * "the wrapper style" isn't spec-ed.
+     *
+     * <p>
+     * Ths returned list includes {@link Property} defined not just
+     * in this class but in all its base classes.
+     *
+     * @return
+     *      null if this isn't a wrapper-style element.
+     *      Otherwise list of {@link Property}s. The order signifies
+     *      the order they appeared inside a schema.
+     */
+    List<? extends Property> getWrapperStyleDrilldown();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Property.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Property.java
new file mode 100644
index 0000000..23d2512
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Property.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JType;
+
+/**
+ * Represents a property of a wrapper-style element.
+ *
+ * <p>
+ * Carrys information about one property of a wrapper-style
+ * element. This interface is solely intended for the use by
+ * the JAX-RPC and otherwise the use is discouraged.
+ *
+ * <p>
+ * REVISIT: use CodeModel.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ * @see Mapping
+ */
+public interface Property {
+    /**
+     * The name of the property.
+     *
+     * <p>
+     * This method returns a valid identifier suitable for
+     * the use as a variable name.
+     *
+     * @return
+     *      always non-null. Camel-style name like "foo" or "barAndZot".
+     *      Note that it may contain non-ASCII characters (CJK, etc.)
+     *      The caller is responsible for proper escaping if it
+     *      wants to print this as a variable name.
+     */
+    String name();
+
+    /**
+     * The Java type of the property.
+     *
+     * @return
+     *      always non-null.
+     *      {@link JType} is a representation of a Java type in a codeModel.
+     *      If you just need the fully-qualified class name, call {@link JType#fullName()}.
+     */
+    JType type();
+
+    /**
+     * Name of the XML element that corresponds to the property.
+     *
+     * <p>
+     * Each child of a wrapper style element corresponds with an
+     * element, and this method returns that name.
+     *
+     * @return
+     *      always non-null valid {@link QName}.
+     */
+    QName elementName();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Reference.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Reference.java
new file mode 100644
index 0000000..b5e6325
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/Reference.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.declaration.Declaration;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.ParameterDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.util.SourcePosition;
+
+/**
+ * Reference to a JAXB type (from JAX-RPC.)
+ *
+ * <p>
+ * A reference is a Java type (represented as a {@link TypeMirror})
+ * and a set of annotations (represented as a {@link Declaration}).
+ * Together they describe a root reference to a JAXB type binding.
+ *
+ * <p>
+ * Those two values can be supplied independently, or you can use
+ * other convenience constructors to supply two values at once.
+ *
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Reference {
+    /**
+     * The JAXB type being referenced. Must not be null.
+     */
+    public final TypeMirror type;
+    /**
+     * The declaration from which annotations for the {@link #type} is read.
+     * Must not be null.
+     */
+    public final Declaration annotations;
+
+    /**
+     * Creates a reference from the return type of the method
+     * and annotations on the method.
+     */
+    public Reference(MethodDeclaration method) {
+        this(method.getReturnType(),method);
+    }
+
+    /**
+     * Creates a reference from the parameter type
+     * and annotations on the parameter.
+     */
+    public Reference(ParameterDeclaration param) {
+        this(param.getType(),param);
+    }
+
+    /**
+     * Creates a reference from a class declaration and its annotations.
+     */
+    public Reference(TypeDeclaration type,AnnotationProcessorEnvironment env) {
+        this(env.getTypeUtils().getDeclaredType(type),type);
+    }
+
+    /**
+     * Creates a reference by providing two values independently.
+     */
+    public Reference(TypeMirror type, Declaration annotations) {
+        if(type==null || annotations==null)
+            throw new IllegalArgumentException();
+        this.type = type;
+        this.annotations = annotations;
+    }
+
+    /**
+     * Gets the source location that can be used to report error messages regarding
+     * this reference.
+     */
+    public SourcePosition getPosition() {
+        return annotations.getPosition();
+    }
+
+    public boolean equals(Object o) {
+        if (this == o) return true;
+        if (!(o instanceof Reference)) return false;
+
+        final Reference that = (Reference) o;
+
+        return annotations.equals(that.annotations) && type.equals(that.type);
+    }
+
+    public int hashCode() {
+        return 29 * type.hashCode() + annotations.hashCode();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/S2JJAXBModel.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/S2JJAXBModel.java
new file mode 100644
index 0000000..b84f89b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/S2JJAXBModel.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import java.util.Collection;
+
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.Plugin;
+
+/**
+ * {@link JAXBModel} that exposes additional information available
+ * only for the schema->java direction.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface S2JJAXBModel extends JAXBModel {
+
+    /**
+     * Gets a {@link Mapping} object for the given global element.
+     *
+     * @return
+     *      null if the element name is not a defined global element in the schema.
+     */
+    Mapping get( QName elementName );
+
+    /**
+     * Gets a read-only view of all the {@link Mapping}s.
+     */
+    Collection<? extends Mapping> getMappings();
+
+    /**
+     * Returns the fully-qualified name of the Java type that is bound to the
+     * specified XML type.
+     *
+     * @param xmlTypeName
+     *      must not be null.
+     * @return
+     *      null if the XML type is not bound to any Java type.
+     */
+    TypeAndAnnotation getJavaType(QName xmlTypeName);
+
+    /**
+     * Generates artifacts.
+     *
+     * <p>
+     * TODO: if JAXB supports various modes of code generations
+     * (such as public interface only or implementation only or
+     * etc), we should define bit flags to control those.
+     *
+     * <p>
+     * This operation is only supported for a model built from a schema.
+     *
+     * @param extensions
+     *      The JAXB RI extensions to run. This can be null or empty
+     *      array if the caller wishes not to run any extension.
+     *      <br>
+     *
+     *      Those specified extensions
+     *      will participate in the code generation. Specifying an extension
+     *      in this list has the same effect of turning that extension on
+     *      via command line.
+     *      <br>
+     *
+     *      It is the caller's responsibility to configure each augmenter
+     *      properly by using {@link Plugin#parseArgument(Options, String[], int)}.
+     *
+     * @return
+     *      object filled with the generated code. Use
+     *      {@link JCodeModel#build(CodeWriter)} to write them
+     *      to a disk.
+     */
+    JCodeModel generateCode( Plugin[] extensions, ErrorListener errorListener );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/SchemaCompiler.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/SchemaCompiler.java
new file mode 100644
index 0000000..53b8b8f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/SchemaCompiler.java
@@ -0,0 +1,233 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.tools.internal.xjc.Options;
+
+import org.w3c.dom.Element;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+
+/**
+ * Schema-to-Java compiler.
+ *
+ * <p>
+ * The caller can parse multiple schema documents,
+ * JAXB external binding files (or potentially WSDL
+ * and JSR-109.next mapping files in the future).
+ *
+ * <p>
+ * All the errors found during this process will be sent
+ * to the registered {@link ErrorListener}.
+ *
+ * <p>
+ * Once all the documents are parsed, call the {@link #bind()}
+ * method to get the compiled {@link JAXBModel} object.
+ *
+ *
+ * <h2>Tips: namespace URI -> package customization</h2>
+ * <p>
+ * The caller can feed the following synthesized schema
+ * to achive the namespace URI -> Java package customization:
+ * <pre><xmp>
+ * <schema targetNamespace="xml.namespace.uri"
+ *   xmlns="http://www.w3.org/2001/XMLSchema"
+ *   xmlns:jaxb="http://java.sun.com/xml/ns/jaxb"
+ *   jaxb:version="1.0">
+ *   <annotation><appinfo>
+ *     <jaxb:schemaBindings>
+ *       <jaxb:package name="java.package.name"/>
+ *     </jaxb:schemaBindings>
+ *   </appinfo></annotation>
+ * </schema>
+ * </xmp></pre>
+ * Feed this synthesized schema document for each namespace URI
+ * you need to map.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface SchemaCompiler {
+    /**
+     * Parses schemas or external bindings
+     * through SAX events by feeding events into
+     * SAX {@link ContentHandler}.
+     *
+     * @param systemId
+     *      The system ID of the document to be read in.
+     *
+     * @see #parseSchema(String, XMLStreamReader)
+     */
+    ContentHandler getParserHandler( String systemId );
+
+    /**
+     * Parses a schema or an external binding file
+     * from an external source.
+     *
+     * @param source
+     *      Its system Id must be set to an absolute URI.
+     */
+    void parseSchema( InputSource source );
+
+    /**
+     * Parses a schema or an external binding file
+     * from the specified DOM element.
+     *
+     * <p>
+     * The given DOM element is treated as if it's the root of a
+     * virtual document.
+     *
+     * <p>
+     * XJC will not be able to print location information for
+     * errors found in this document, since DOM doesn't have them.
+     * For this reason, use of this method is strongly discouraged.
+     *
+     * @param systemId
+     *      We need an absolute system ID that uniquely designates the virtual
+     *      document. This should be different from the system ID of
+     *      the document which contains this element.
+     *      <p>
+     *      One way to do that is by adding a fragment identifier
+     *      to the system ID of the document. For example, if the document
+     *      is "foo.wsdl" and you are passing in its types section, you
+     *      can use an unique identifier like "foo.wsdl#types"
+     */
+    void parseSchema( String systemId, Element element );
+
+    /**
+     * Parses a schema or an external binding file
+     * from the given source.
+     *
+     * <p>
+     * A stream reader must be pointing at the element or
+     * at the start of the document.
+     * XML is parsed until the corresponding end tag, then the
+     * sub tree is processed as a schema document.
+     *
+     * <p>
+     * When this method returns successfully, the parser is at
+     * the next token of the end element.
+     *
+     * @param systemId
+     *      The absolute system ID of the document that is being parsed.
+     *      This information is necessary to avoid double-inclusion
+     *      and etc.
+     *
+     *      Note that {@link XMLStreamReader#getLocation()} only
+     *      returns the system ID of the entity it is parsing, not
+     *      necessarily the system ID of the document itself.
+     *
+     * @throws XMLStreamException
+     *      If an error happens while parsing a document.
+     *      Note that not only the parser but also the XJC itself
+     *      may throw this error (as a result of the additional validation
+     *      for example.)
+     */
+    void parseSchema( String systemId, XMLStreamReader reader ) throws XMLStreamException;
+
+    void setErrorListener( ErrorListener errorListener );
+    void setEntityResolver( EntityResolver entityResolver );
+
+
+    /**
+     * Sets the default Java package name into which the generated code will be placed.
+     *
+     * <p>
+     * Customizations in the binding files/schemas will have precedence over this setting.
+     * Set to null to use the default package name computation algorithm as specified by
+     * the JAXB spec (which is the default behavior.)
+     *
+     * <p>
+     * Initially this parameter is set to null.
+     *
+     * @param packageName
+     *      Java pckage name such as "org.foo.bar". Use "" to represent the root package,
+     *      and null to defer to the default computation algorithm.
+     *
+     * @see #forcePackageName(String)
+     */
+    void setDefaultPackageName( String packageName );
+
+    /**
+     * Forces all the JAXB-generated classes to go into the specific package.
+     *
+     * <p>
+     * This setting takes precedence over the {@link #setDefaultPackageName(String)}
+     * or any of the customization found in the JAXB binding files. This method
+     * is designed to implement the semantics of the command-line '-p' option.
+     *
+     * <p>
+     * This somewhat ugly semantics actually have a long history now and too late
+     * to change.
+     *
+     * @see #setDefaultPackageName(String)
+     */
+    void forcePackageName( String packageName );
+
+    /**
+     * Sets the {@link ClassNameAllocator} to be used for the binding operation.
+     *
+     * <p>
+     * This mechanism would allow the caller to participate in the binding operation.
+     *
+     * @see ClassNameAllocator
+     */
+    void setClassNameAllocator( ClassNameAllocator allocator );
+
+    /**
+     * Obtains the compiled schema object model.
+     *
+     * Once this method is called, no other method should be
+     * invoked on the {@link SchemaCompiler}.
+     *
+     * @return
+     *      null if the compilation fails. The errors should have been
+     *      delivered to the registered error handler in such a case.
+     */
+    S2JJAXBModel bind();
+
+    /**
+     * Allows the calling code to tweak more schema compilation details.
+     *
+     * <p>
+     * The caller can use this method to obtain an {@link Options} instance,
+     * then tweak settings on it. The updated settings will be used when the
+     * {@link #bind()} method is invoked.
+     *
+     * @since 2.0.2
+     * @deprecated
+     *      This method is not really "deprecated" (in the sense of being removed
+     *      from future versions), but the JAXB team is not committed to evolve
+     *      {@link Options} class in the compatible fashion. So please don't
+     *      use this method unless you know what you're doing.
+     */
+    @NotNull Options getOptions();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/TypeAndAnnotation.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/TypeAndAnnotation.java
new file mode 100644
index 0000000..660f610
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/TypeAndAnnotation.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import com.sun.codemodel.internal.JAnnotatable;
+import com.sun.codemodel.internal.JType;
+
+/**
+ * Java type and associated JAXB annotations.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface TypeAndAnnotation {
+    /**
+     * Returns the Java type.
+     *
+     * <p>
+     * {@link JType} is a representation of a Java type in a codeModel.
+     * If you just need the fully-qualified class name, call {@link JType#fullName()}.
+     *
+     * @return
+     *      never be null.
+     */
+    JType getTypeClass();
+
+    /**
+     * Annotates the given program element by additional JAXB annotations that need to be there
+     * at the point of reference.
+     */
+    void annotate( JAnnotatable programElement );
+
+    /**
+     * Two {@link TypeAndAnnotation} are equal if they
+     * has the same type and annotations.
+     */
+    boolean equals(Object o);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/XJC.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/XJC.java
new file mode 100644
index 0000000..2f9e5b9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/XJC.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api;
+
+import com.sun.tools.internal.xjc.api.impl.j2s.JavaCompilerImpl;
+import com.sun.tools.internal.xjc.api.impl.s2j.SchemaCompilerImpl;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+
+/**
+ * Entry point to the programatic API to access
+ * schema compiler (XJC) and schema generator (schemagen).
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class XJC {
+    /**
+     * Gets a fresh {@link JavaCompiler}.
+     *
+     * @return
+     *      always return non-null object.
+     */
+    public static JavaCompiler createJavaCompiler() {
+        return new JavaCompilerImpl();
+    }
+
+    /**
+     * Gets a fresh {@link SchemaCompiler}.
+     *
+     * @return
+     *      always return non-null object.
+     */
+    public static SchemaCompiler createSchemaCompiler() {
+        return new SchemaCompilerImpl();
+    }
+
+    /**
+     * Computes the namespace URI -> package name conversion
+     * as specified by the JAXB spec.
+     *
+     * @param namespaceUri
+     *      Namespace URI. Can be empty, but must not be null.
+     * @return
+     *      A Java package name (e.g., "foo.bar"). "" to represent the root package.
+     *      This method returns null if the method fails to derive the package name
+     *      (there are certain namespace URIs with which this algorithm does not
+     *      work --- such as ":::" as the URI.)
+     */
+    public static String getDefaultPackageName( String namespaceUri ) {
+        if(namespaceUri==null)   throw new IllegalArgumentException();
+        return NameConverter.standard.toPackageName( namespaceUri );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/JAXBModelImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/JAXBModelImpl.java
new file mode 100644
index 0000000..93be90b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/JAXBModelImpl.java
@@ -0,0 +1,180 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.j2s;
+
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.bind.annotation.XmlList;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+
+import com.sun.mirror.declaration.FieldDeclaration;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.mirror.type.PrimitiveType;
+import com.sun.tools.internal.xjc.api.ErrorListener;
+import com.sun.tools.internal.xjc.api.J2SJAXBModel;
+import com.sun.tools.internal.xjc.api.Reference;
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.core.ArrayInfo;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.bind.v2.model.core.ElementInfo;
+import com.sun.xml.internal.bind.v2.model.core.EnumLeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.Ref;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.schemagen.XmlSchemaGenerator;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class JAXBModelImpl implements J2SJAXBModel {
+
+    private final Map<QName,Reference> additionalElementDecls;
+
+    private final List<String> classList = new ArrayList<String>();
+
+    private final TypeInfoSet<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration> types;
+
+    private final AnnotationReader<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration> reader;
+
+    /**
+     * Look up table from an externally visible {@link Reference} object
+     * to our internal format.
+     */
+    private final Map<Reference,NonElement<TypeMirror,TypeDeclaration>> refMap =
+        new HashMap<Reference, NonElement<TypeMirror,TypeDeclaration>>();
+
+    public JAXBModelImpl(TypeInfoSet<TypeMirror, TypeDeclaration, FieldDeclaration, MethodDeclaration> types,
+                         AnnotationReader<TypeMirror, TypeDeclaration, FieldDeclaration, MethodDeclaration> reader,
+                         Collection<Reference> rootClasses,
+                         Map<QName, Reference> additionalElementDecls) {
+        this.types = types;
+        this.reader = reader;
+        this.additionalElementDecls = additionalElementDecls;
+
+        Navigator<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration> navigator = types.getNavigator();
+
+        for( ClassInfo<TypeMirror,TypeDeclaration> i : types.beans().values() ) {
+            classList.add(i.getName());
+        }
+
+        for(ArrayInfo<TypeMirror,TypeDeclaration> a : types.arrays().values()) {
+            String javaName = navigator.getTypeName(a.getType());
+            classList.add(javaName);
+        }
+
+        for( EnumLeafInfo<TypeMirror,TypeDeclaration> l : types.enums().values() ) {
+            QName tn = l.getTypeName();
+            if(tn!=null) {
+                String javaName = navigator.getTypeName(l.getType());
+                classList.add(javaName);
+            }
+        }
+
+        for (Reference ref : rootClasses)
+            refMap.put(ref,getXmlType(ref));
+
+        // check for collision between "additional" ones and the ones given to JAXB
+        // and eliminate duplication
+        Iterator<Map.Entry<QName, Reference>> itr = additionalElementDecls.entrySet().iterator();
+        while(itr.hasNext()) {
+            Map.Entry<QName, Reference> entry = itr.next();
+            if(entry.getValue()==null)      continue;
+
+            NonElement<TypeMirror,TypeDeclaration> xt = getXmlType(entry.getValue());
+
+            assert xt!=null;
+            refMap.put(entry.getValue(),xt);
+            if(xt instanceof ClassInfo) {
+                ClassInfo<TypeMirror,TypeDeclaration> xct = (ClassInfo<TypeMirror,TypeDeclaration>) xt;
+                Element<TypeMirror,TypeDeclaration> elem = xct.asElement();
+                if(elem!=null && elem.getElementName().equals(entry.getKey())) {
+                    itr.remove();
+                    continue;
+                }
+            }
+            ElementInfo<TypeMirror,TypeDeclaration> ei = types.getElementInfo(null,entry.getKey());
+            if(ei!=null && ei.getContentType()==xt)
+                itr.remove();
+        }
+    }
+
+    public List<String> getClassList() {
+        return classList;
+    }
+
+    public QName getXmlTypeName(Reference javaType) {
+        NonElement<TypeMirror,TypeDeclaration> ti = refMap.get(javaType);
+
+        if(ti!=null)
+            return ti.getTypeName();
+
+        return null;
+    }
+
+    private NonElement<TypeMirror,TypeDeclaration> getXmlType(Reference r) {
+        if(r==null)
+            throw new IllegalArgumentException();
+
+        XmlJavaTypeAdapter xjta = r.annotations.getAnnotation(XmlJavaTypeAdapter.class);
+        XmlList xl = r.annotations.getAnnotation(XmlList.class);
+
+        Ref<TypeMirror, TypeDeclaration> ref = new Ref<TypeMirror, TypeDeclaration>(
+            reader,types.getNavigator(),r.type,xjta,xl);
+
+        return types.getTypeInfo(ref);
+    }
+
+    public void generateSchema(SchemaOutputResolver outputResolver, ErrorListener errorListener) throws IOException {
+        XmlSchemaGenerator<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration> xsdgen
+            = new XmlSchemaGenerator<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration>( types.getNavigator(), types );
+
+        for (Map.Entry<QName,Reference> e : additionalElementDecls.entrySet()) {
+            Reference value = e.getValue();
+            if(value!=null) {
+                NonElement<TypeMirror, TypeDeclaration> typeInfo = refMap.get(value);
+                if(typeInfo==null)
+                    throw new IllegalArgumentException(e.getValue()+" was not specified to JavaCompiler.bind");
+                xsdgen.add(e.getKey(),!(value.type instanceof PrimitiveType),typeInfo);
+            } else {
+                xsdgen.add(e.getKey(),false,null);
+            }
+        }
+
+        xsdgen.write(outputResolver);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/JavaCompilerImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/JavaCompilerImpl.java
new file mode 100644
index 0000000..4c91985
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/JavaCompilerImpl.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.j2s;
+
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.bind.annotation.XmlList;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+
+import com.sun.mirror.apt.AnnotationProcessorEnvironment;
+import com.sun.mirror.apt.Messager;
+import com.sun.mirror.declaration.FieldDeclaration;
+import com.sun.mirror.declaration.MethodDeclaration;
+import com.sun.mirror.declaration.TypeDeclaration;
+import com.sun.mirror.type.TypeMirror;
+import com.sun.tools.internal.jxc.apt.InlineAnnotationReaderImpl;
+import com.sun.tools.internal.jxc.model.nav.APTNavigator;
+import com.sun.tools.internal.xjc.api.J2SJAXBModel;
+import com.sun.tools.internal.xjc.api.JavaCompiler;
+import com.sun.tools.internal.xjc.api.Reference;
+import com.sun.xml.internal.bind.v2.model.core.ErrorHandler;
+import com.sun.xml.internal.bind.v2.model.core.Ref;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.impl.ModelBuilder;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class JavaCompilerImpl implements JavaCompiler {
+    public J2SJAXBModel bind(
+        Collection<Reference> rootClasses,
+        Map<QName,Reference> additionalElementDecls,
+        String defaultNamespaceRemap,
+        AnnotationProcessorEnvironment env) {
+
+        ModelBuilder<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration> builder =
+            new ModelBuilder<TypeMirror,TypeDeclaration,FieldDeclaration,MethodDeclaration>(
+                InlineAnnotationReaderImpl.theInstance,
+                new APTNavigator(env),
+                defaultNamespaceRemap
+            );
+
+        builder.setErrorHandler(new ErrorHandlerImpl(env.getMessager()));
+
+        for( Reference ref : rootClasses ) {
+            TypeMirror t = ref.type;
+
+            XmlJavaTypeAdapter xjta = ref.annotations.getAnnotation(XmlJavaTypeAdapter.class);
+            XmlList xl = ref.annotations.getAnnotation(XmlList.class);
+
+            builder.getTypeInfo(new Ref<TypeMirror,TypeDeclaration>(builder,t,xjta,xl));
+        }
+
+        TypeInfoSet r = builder.link();
+        if(r==null)     return null;
+
+        if(additionalElementDecls==null)
+            additionalElementDecls = Collections.emptyMap();
+        else {
+            // fool proof check
+            for (Map.Entry<QName, ? extends Reference> e : additionalElementDecls.entrySet()) {
+                if(e.getKey()==null)
+                    throw new IllegalArgumentException("nulls in additionalElementDecls");
+            }
+        }
+        return new JAXBModelImpl(r,builder.reader,rootClasses,new HashMap(additionalElementDecls));
+    }
+
+    private static final class ErrorHandlerImpl implements ErrorHandler {
+        private final Messager messager;
+
+        public ErrorHandlerImpl(Messager messager) {
+            this.messager = messager;
+        }
+
+        public void error(IllegalAnnotationException e) {
+            messager.printError(e.toString());
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/Messages.java
new file mode 100644
index 0000000..9bcad5e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/Messages.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.j2s;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+enum Messages {
+    ;
+
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/Messages.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/Messages.properties
new file mode 100644
index 0000000..8d1c8b6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/j2s/Messages.properties
@@ -0,0 +1 @@
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/AbstractMappingImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/AbstractMappingImpl.java
new file mode 100644
index 0000000..33dd373
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/AbstractMappingImpl.java
@@ -0,0 +1,156 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.api.Mapping;
+import com.sun.tools.internal.xjc.api.Property;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.ReferencePropertyInfo;
+
+/**
+ * Partial common implementation between {@link ElementMappingImpl} and {@link BeanMappingImpl}
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class AbstractMappingImpl<InfoT extends CElement> implements Mapping {
+
+    protected final JAXBModelImpl parent;
+    protected final InfoT clazz;
+
+    /**
+     * Lazily computed.
+     *
+     * @see #getWrapperStyleDrilldown()
+     */
+    private List<Property> drilldown = null;
+    private boolean drilldownComputed = false;
+
+    protected AbstractMappingImpl(JAXBModelImpl parent, InfoT clazz) {
+        this.parent = parent;
+        this.clazz = clazz;
+    }
+
+    public final QName getElement() {
+        return clazz.getElementName();
+    }
+
+    public final String getClazz() {
+        return clazz.getType().fullName();
+    }
+
+    public final List<? extends Property> getWrapperStyleDrilldown() {
+        if(!drilldownComputed) {
+            drilldownComputed = true;
+            drilldown = calcDrilldown();
+        }
+        return drilldown;
+    }
+
+    protected abstract List<Property> calcDrilldown();
+
+
+    /**
+     * Derived classes can use this method to implement {@link #calcDrilldown}.
+     */
+    protected List<Property> buildDrilldown(CClassInfo typeBean) {
+        List<Property> result;
+
+        CClassInfo bc = typeBean.getBaseClass();
+        if(bc!=null) {
+            result = buildDrilldown(bc);
+            if(result==null)
+                return null;        // aborted
+        } else
+            result = new ArrayList<Property>();
+
+        for( CPropertyInfo p : typeBean.getProperties() ) {
+            if (p instanceof CElementPropertyInfo) {
+                CElementPropertyInfo ep = (CElementPropertyInfo) p;
+// wrong. A+,B,C is eligible for drill-down.
+//                if(ep.isCollection())
+//                    // content model like A+,B,C is not eligible
+//                    return null;
+
+                List<? extends CTypeRef> ref = ep.getTypes();
+                if(ref.size()!=1)
+                    // content model like (A|B),C is not eligible
+                    return null;
+
+                result.add(createPropertyImpl(ep,ref.get(0).getTagName()));
+            } else
+            if (p instanceof ReferencePropertyInfo) {
+                CReferencePropertyInfo rp = (CReferencePropertyInfo) p;
+
+                Collection<CElement> elements = rp.getElements();
+                if(elements.size()!=1)
+                    return null;
+
+                CElement ref = elements.iterator().next();
+                if(ref instanceof ClassInfo) {
+                    result.add(createPropertyImpl(rp,ref.getElementName()));
+                } else {
+                    CElementInfo eref = (CElementInfo)ref;
+                    if(!eref.getSubstitutionMembers().isEmpty())
+                        return null;    // elements with a substitution group isn't qualified for the wrapper style
+
+                    // JAX-WS doesn't want to see JAXBElement, so we have to hide it for them.
+                    ElementAdapter fr;
+                    if(rp.isCollection())
+                        fr = new ElementCollectionAdapter(parent.outline.getField(rp), eref);
+                    else
+                        fr = new ElementSingleAdapter(parent.outline.getField(rp), eref);
+
+                    result.add(new PropertyImpl(this,
+                        fr, eref.getElementName()));
+                }
+            } else
+                // to be eligible for the wrapper style, only elements are allowed.
+                // according to the JAX-RPC spec 2.3.1.2, element refs are disallowed
+                return null;
+
+        }
+
+        return result;
+    }
+
+    private Property createPropertyImpl(CPropertyInfo p, QName tagName) {
+        return new PropertyImpl(this,
+            parent.outline.getField(p),tagName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/BeanMappingImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/BeanMappingImpl.java
new file mode 100644
index 0000000..78fe662
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/BeanMappingImpl.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import java.util.List;
+
+import com.sun.tools.internal.xjc.api.Mapping;
+import com.sun.tools.internal.xjc.api.Property;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+
+/**
+ * Partial implementation of {@link Mapping}
+ * for bean classes.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class BeanMappingImpl extends AbstractMappingImpl<CClassInfo> {
+
+    private final TypeAndAnnotationImpl taa = new TypeAndAnnotationImpl(parent.outline,clazz);
+
+    BeanMappingImpl(JAXBModelImpl parent, CClassInfo classInfo) {
+        super(parent,classInfo);
+        assert classInfo.isElement();
+    }
+
+    public TypeAndAnnotation getType() {
+        return taa;
+    }
+
+    public final String getTypeClass() {
+        return getClazz();
+    }
+
+    public List<Property> calcDrilldown() {
+        if(!clazz.isOrdered())
+            return null;    // all is not eligible for the wrapper style
+        return buildDrilldown(clazz);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/DowngradingErrorHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/DowngradingErrorHandler.java
new file mode 100644
index 0000000..2b5424e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/DowngradingErrorHandler.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+/**
+ * {@link ErrorHandler} that reports all errors as warnings.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class DowngradingErrorHandler implements ErrorHandler {
+    private final ErrorHandler core;
+
+    public DowngradingErrorHandler(ErrorHandler core) {
+        this.core = core;
+    }
+
+    public void warning(SAXParseException exception) throws SAXException {
+        core.warning(exception);
+    }
+
+    public void error(SAXParseException exception) throws SAXException {
+        core.warning(exception);
+    }
+
+    public void fatalError(SAXParseException exception) throws SAXException {
+        core.warning(exception);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementAdapter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementAdapter.java
new file mode 100644
index 0000000..b06930c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementAdapter.java
@@ -0,0 +1,131 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JVar;
+import com.sun.codemodel.internal.JConditional;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JInvocation;
+
+/**
+ * {@link FieldOutline} that wraps another {@link FieldOutline}
+ * and allows JAX-WS to access values without using about
+ * {@link JAXBElement}.
+ *
+ * <p>
+ * That means if a value is requested, we unwrap JAXBElement
+ * and give it to them. If a value is set, we wrap that into
+ * JAXBElement, etc.
+ *
+ * <p>
+ * This can be used only with {@link CReferencePropertyInfo}
+ * (or else it won't be {@link JAXBElement),
+ * with one {@link CElementInfo} (or else we can't infer the tag name.)
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class ElementAdapter implements FieldOutline {
+    protected final FieldOutline core;
+
+    /**
+     * The only one {@link CElementInfo} that can be in the property.
+     */
+    protected final CElementInfo ei;
+
+    public ElementAdapter(FieldOutline core, CElementInfo ei) {
+        this.core = core;
+        this.ei = ei;
+    }
+
+    public ClassOutline parent() {
+        return core.parent();
+    }
+
+    public CPropertyInfo getPropertyInfo() {
+        return core.getPropertyInfo();
+    }
+
+    protected final Outline outline() {
+        return core.parent().parent();
+    }
+
+    protected final JCodeModel codeModel() {
+        return outline().getCodeModel();
+    }
+
+    protected abstract class FieldAccessorImpl implements FieldAccessor {
+        final FieldAccessor acc;
+
+        public FieldAccessorImpl(JExpression target) {
+            acc = core.create(target);
+        }
+
+        public void unsetValues(JBlock body) {
+            acc.unsetValues(body);
+        }
+
+        public JExpression hasSetValue() {
+            return acc.hasSetValue();
+        }
+
+        public FieldOutline owner() {
+            return ElementAdapter.this;
+        }
+
+        public CPropertyInfo getPropertyInfo() {
+            return core.getPropertyInfo();
+        }
+
+        /**
+         * Wraps a type value into a {@link JAXBElement}.
+         */
+        protected final JInvocation createJAXBElement(JExpression $var) {
+            JCodeModel cm = codeModel();
+
+            return JExpr._new(cm.ref(JAXBElement.class))
+                .arg(JExpr._new(cm.ref(QName.class))
+                    .arg(ei.getElementName().getNamespaceURI())
+                    .arg(ei.getElementName().getLocalPart()))
+                .arg(getRawType().boxify().erasure().dotclass())
+                .arg($var);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementCollectionAdapter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementCollectionAdapter.java
new file mode 100644
index 0000000..73ad223
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementCollectionAdapter.java
@@ -0,0 +1,118 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import javax.xml.bind.JAXBElement;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JConditional;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JForEach;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import static com.sun.tools.internal.xjc.outline.Aspect.EXPOSED;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+/**
+ * {@link ElementAdapter} that works with a collection
+ * of {@link JAXBElement}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ElementCollectionAdapter extends ElementAdapter {
+    public ElementCollectionAdapter(FieldOutline core, CElementInfo ei) {
+        super(core, ei);
+    }
+
+    public JType getRawType() {
+        return codeModel().ref(List.class).narrow(itemType().boxify());
+    }
+
+    private JType itemType() {
+        return ei.getContentInMemoryType().toType(outline(), EXPOSED);
+    }
+
+    public FieldAccessor create(JExpression targetObject) {
+        return new FieldAccessorImpl(targetObject);
+    }
+
+    final class FieldAccessorImpl extends ElementAdapter.FieldAccessorImpl {
+        public FieldAccessorImpl(JExpression target) {
+            super(target);
+        }
+
+        public void toRawValue(JBlock block, JVar $var) {
+            JCodeModel cm = outline().getCodeModel();
+            JClass elementType = ei.toType(outline(),EXPOSED).boxify();
+
+            // [RESULT]
+            // $var = new ArrayList();
+            // for( JAXBElement e : [core.toRawValue] ) {
+            //   if(e==null)
+            //     $var.add(null);
+            //   else
+            //     $var.add(e.getValue());
+            // }
+
+            block.assign($var,JExpr._new(cm.ref(ArrayList.class).narrow(itemType().boxify())));
+            JVar $col = block.decl(core.getRawType(), "col" + hashCode());
+            acc.toRawValue(block,$col);
+            JForEach loop = block.forEach(elementType, "v" + hashCode()/*unique string handling*/, $col);
+
+            JConditional cond = loop.body()._if(loop.var().eq(JExpr._null()));
+            cond._then().invoke($var,"add").arg(JExpr._null());
+            cond._else().invoke($var,"add").arg(loop.var().invoke("getValue"));
+        }
+
+        public void fromRawValue(JBlock block, String uniqueName, JExpression $var) {
+            JCodeModel cm = outline().getCodeModel();
+            JClass elementType = ei.toType(outline(),EXPOSED).boxify();
+
+            // [RESULT]
+            // $t = new ArrayList();
+            // for( Type e : $var ) {
+            //     $var.add(new JAXBElement(e));
+            // }
+            // [core.fromRawValue]
+
+            JClass col = cm.ref(ArrayList.class).narrow(elementType);
+            JVar $t = block.decl(col,uniqueName+"_col",JExpr._new(col));
+
+            JForEach loop = block.forEach(itemType(), uniqueName+"_i", $t);
+            loop.body().invoke($var,"add").arg(createJAXBElement(loop.var()));
+
+            acc.fromRawValue(block, uniqueName, $t);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementMappingImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementMappingImpl.java
new file mode 100644
index 0000000..27d6f37
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementMappingImpl.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import java.util.List;
+
+import com.sun.tools.internal.xjc.api.Property;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.xjc.model.CAdapter;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.model.TypeUseFactory;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class ElementMappingImpl extends AbstractMappingImpl<CElementInfo> {
+
+    private final TypeAndAnnotation taa;
+
+    protected ElementMappingImpl(JAXBModelImpl parent, CElementInfo elementInfo) {
+        super(parent,elementInfo);
+
+        TypeUse t = clazz.getContentType();
+        if(clazz.getProperty().isCollection())
+            t = TypeUseFactory.makeCollection(t);
+        CAdapter a = clazz.getProperty().getAdapter();
+        if(a!=null)
+            t = TypeUseFactory.adapt(t,a);
+        taa = new TypeAndAnnotationImpl(parent.outline,t);
+    }
+
+    public TypeAndAnnotation getType() {
+        return taa;
+    }
+
+    public final List<Property> calcDrilldown() {
+        CElementPropertyInfo p = clazz.getProperty();
+
+        if(p.getAdapter()!=null)
+            return null;    // if adapted, avoid drill down
+
+        if(p.isCollection())
+        // things like <xs:element name="foo" type="xs:NMTOKENS" /> is not eligible.
+            return null;
+
+        CTypeInfo typeClass = p.ref().get(0);
+
+        if(!(typeClass instanceof CClassInfo))
+            // things like <xs:element name="foo" type="xs:string" /> is not eligible.
+            return null;
+
+        CClassInfo ci = (CClassInfo)typeClass;
+
+        // if the type is abstract we can't use it.
+        if(ci.isAbstract())
+            return null;
+
+        // the 'all' compositor doesn't qualify
+        if(!ci.isOrdered())
+            return null;
+
+        return buildDrilldown(ci);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementSingleAdapter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementSingleAdapter.java
new file mode 100644
index 0000000..f1c5844
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/ElementSingleAdapter.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JVar;
+import com.sun.codemodel.internal.JConditional;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JInvocation;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+
+/**
+ * {@link ElementAdapter} that works with a single {@link JAXBElement}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ElementSingleAdapter extends ElementAdapter {
+    public ElementSingleAdapter(FieldOutline core, CElementInfo ei) {
+        super(core, ei);
+    }
+
+    public JType getRawType() {
+        return ei.getContentInMemoryType().toType(outline(), Aspect.EXPOSED);
+    }
+
+    public FieldAccessor create(JExpression targetObject) {
+        return new FieldAccessorImpl(targetObject);
+    }
+
+    final class FieldAccessorImpl extends ElementAdapter.FieldAccessorImpl {
+        public FieldAccessorImpl(JExpression target) {
+            super(target);
+        }
+
+        public void toRawValue(JBlock block, JVar $var) {
+            // [RESULT]
+            // if([core.hasSetValue])
+            //   $var = [core.toRawValue].getValue();
+            // else
+            //   $var = null;
+
+            JConditional cond = block._if(acc.hasSetValue());
+            JVar $v = cond._then().decl(core.getRawType(), "v" + hashCode());// TODO: unique value control
+            acc.toRawValue(cond._then(),$v);
+            cond._then().assign($var,$v.invoke("getValue"));
+            cond._else().assign($var, JExpr._null());
+        }
+
+        public void fromRawValue(JBlock block, String uniqueName, JExpression $var) {
+            // [RESULT]
+            // [core.fromRawValue](new JAXBElement(tagName, TYPE, $var));
+
+            acc.fromRawValue(block,uniqueName, createJAXBElement($var));
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/JAXBModelImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/JAXBModelImpl.java
new file mode 100644
index 0000000..db33507
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/JAXBModelImpl.java
@@ -0,0 +1,110 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.tools.internal.xjc.api.ErrorListener;
+import com.sun.tools.internal.xjc.api.JAXBModel;
+import com.sun.tools.internal.xjc.api.Mapping;
+import com.sun.tools.internal.xjc.api.S2JJAXBModel;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.tools.internal.xjc.outline.PackageOutline;
+
+/**
+ * {@link JAXBModel} implementation.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class JAXBModelImpl implements S2JJAXBModel {
+    /*package*/ final Outline outline;
+
+    /**
+     * All the known classes.
+     */
+    private final Model model;
+
+    private final Map<QName,Mapping> byXmlName = new HashMap<QName,Mapping>();
+
+    JAXBModelImpl(Outline outline) {
+        this.model = outline.getModel();
+        this.outline = outline;
+
+        for (CClassInfo ci : model.beans().values()) {
+            if(!ci.isElement())
+                continue;
+            byXmlName.put(ci.getElementName(),new BeanMappingImpl(this,ci));
+        }
+        for (CElementInfo ei : model.getElementMappings(null).values()) {
+            byXmlName.put(ei.getElementName(),new ElementMappingImpl(this,ei));
+        }
+    }
+
+    public JCodeModel generateCode(Plugin[] extensions,ErrorListener errorListener) {
+        // we no longer do any code generation
+        return outline.getCodeModel();
+    }
+
+
+    public final Mapping get(QName elementName) {
+        return byXmlName.get(elementName);
+    }
+
+    public final Collection<? extends Mapping> getMappings() {
+        return byXmlName.values();
+    }
+
+    public TypeAndAnnotation getJavaType(QName xmlTypeName) {
+        // TODO: primitive type handling?
+        TypeUse use = model.typeUses().get(xmlTypeName);
+        if(use==null)   return null;
+
+        return new TypeAndAnnotationImpl(outline,use);
+    }
+
+    public final List<String> getClassList() {
+        List<String> classList = new ArrayList<String>();
+
+        // list up root classes
+        for( PackageOutline p : outline.getAllPackageContexts() )
+            classList.add( p.objectFactory().fullName() );
+        return classList;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/PropertyImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/PropertyImpl.java
new file mode 100644
index 0000000..d4da9e6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/PropertyImpl.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.api.Mapping;
+import com.sun.tools.internal.xjc.api.Property;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public /*for BSH*/ final class PropertyImpl implements Property {
+    protected final FieldOutline fr;
+    protected final QName elementName;
+    protected final Mapping parent;
+    protected final JCodeModel codeModel;
+
+    PropertyImpl( Mapping parent, FieldOutline fr, QName elementName ) {
+        this.parent = parent;
+        this.fr = fr;
+        this.elementName = elementName;
+        this.codeModel = fr.getRawType().owner();
+    }
+
+    public final String name() {
+        return fr.getPropertyInfo().getName(false);
+    }
+
+    public final QName elementName() {
+        return elementName;
+    }
+
+    public final JType type() {
+        return fr.getRawType();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/SchemaCompilerImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/SchemaCompilerImpl.java
new file mode 100644
index 0000000..76cd416
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/SchemaCompilerImpl.java
@@ -0,0 +1,279 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import java.net.MalformedURLException;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.net.URL;
+
+import javax.xml.XMLConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.validation.SchemaFactory;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.istack.internal.NotNull;
+import com.sun.istack.internal.SAXParseException2;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.ModelLoader;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.api.ClassNameAllocator;
+import com.sun.tools.internal.xjc.api.ErrorListener;
+import com.sun.tools.internal.xjc.api.SchemaCompiler;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.tools.internal.xjc.reader.internalizer.DOMForest;
+import com.sun.tools.internal.xjc.reader.xmlschema.parser.XMLSchemaInternalizationLogic;
+import com.sun.xml.internal.bind.unmarshaller.DOMScanner;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+
+import org.w3c.dom.Element;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.LocatorImpl;
+
+/**
+ * {@link SchemaCompiler} implementation.
+ *
+ * This class builds a {@link DOMForest} until the {@link #bind()} method,
+ * then this method does the rest of the hard work.
+ *
+ * @see ModelLoader
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class SchemaCompilerImpl extends ErrorReceiver implements SchemaCompiler {
+
+    /**
+     * User-specified error receiver.
+     * This field can be null, in which case errors need to be discarded.
+     */
+    private ErrorListener errorListener;
+
+    protected final Options opts = new Options();
+
+    protected final DOMForest forest;
+
+    /**
+     * Set to true once an error is found.
+     */
+    private boolean hadError;
+
+    public SchemaCompilerImpl() {
+        forest = new DOMForest(new XMLSchemaInternalizationLogic());
+        opts.compatibilityMode = Options.EXTENSION;
+        forest.setErrorHandler(this);
+
+        if(System.getProperty("xjc-api.test")!=null) {
+            opts.debugMode = true;
+            opts.verbose = true;
+        }
+    }
+
+    @NotNull
+    public Options getOptions() {
+        return opts;
+    }
+
+    public ContentHandler getParserHandler( String systemId ) {
+        return forest.getParserHandler(systemId,true);
+    }
+
+    public void parseSchema( String systemId, Element element ) {
+        checkAbsoluteness(systemId);
+        try {
+            DOMScanner scanner = new DOMScanner();
+
+            // use a locator that sets the system ID correctly
+            // so that we can resolve relative URLs in most of the case.
+            // it still doesn't handle xml:base and XInclude and all those things
+            // correctly. There's just no way to make all those things work with DOM!
+            LocatorImpl loc = new LocatorImpl();
+            loc.setSystemId(systemId);
+            scanner.setLocator(loc);
+
+            scanner.setContentHandler(getParserHandler(systemId));
+            scanner.scan(element);
+        } catch (SAXException e) {
+            // since parsing DOM shouldn't cause a SAX exception
+            // and our handler will never throw it, it's not clear
+            // if this will ever happen.
+            fatalError(new SAXParseException2(
+                e.getMessage(), null, systemId,-1,-1, e));
+        }
+    }
+
+    public void parseSchema(InputSource source) {
+        checkAbsoluteness(source.getSystemId());
+        try {
+            forest.parse(source,true);
+        } catch (SAXException e) {
+            // parsers are required to report an error to ErrorHandler,
+            // so we should never see this error.
+            e.printStackTrace();
+        }
+    }
+
+    public void parseSchema(String systemId, XMLStreamReader reader) throws XMLStreamException {
+        checkAbsoluteness(systemId);
+        forest.parse(systemId,reader,true);
+    }
+
+    /**
+     * Checks if the system ID is absolute.
+     */
+    private void checkAbsoluteness(String systemId) {
+        // we need to be able to handle system IDs like "urn:foo", which java.net.URL can't process,
+        // but OTOH we also need to be able to process system IDs like "file://a b c/def.xsd",
+        // which java.net.URI can't process. So for now, let's fail only if both of them fail.
+        // eventually we need a proper URI class that works for us.
+        try {
+            new URL(systemId);
+        } catch( MalformedURLException _ ) {
+            try {
+                new URI(systemId);
+            } catch (URISyntaxException e ) {
+                throw new IllegalArgumentException("system ID '"+systemId+"' isn't absolute",e);
+            }
+        }
+    }
+
+    public void setEntityResolver(EntityResolver entityResolver) {
+        forest.setEntityResolver(entityResolver);
+        opts.entityResolver = entityResolver;
+    }
+
+    public void setDefaultPackageName(String packageName) {
+        opts.defaultPackage2 = packageName;
+    }
+
+    public void forcePackageName(String packageName) {
+        opts.defaultPackage = packageName;
+    }
+
+    public void setClassNameAllocator(ClassNameAllocator allocator) {
+        opts.classNameAllocator = allocator;
+    }
+
+
+    public JAXBModelImpl bind() {
+        // this has been problematic. turn it off.
+//        if(!forest.checkSchemaCorrectness(this))
+//            return null;
+
+        // internalization
+        forest.transform();
+
+        if(!NO_CORRECTNESS_CHECK) {
+            // correctness check
+            SchemaFactory sf = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
+            sf.setErrorHandler(new DowngradingErrorHandler(this));
+            forest.weakSchemaCorrectnessCheck(sf);
+            if(hadError)
+                return null;    // error in the correctness check. abort now
+        }
+
+        JCodeModel codeModel = new JCodeModel();
+
+        ModelLoader gl = new ModelLoader(opts,codeModel,this);
+
+        try {
+            XSSchemaSet result = gl.createXSOM(forest);
+            if(result==null)
+                return null;
+
+
+            // we need info about each field, so we go ahead and generate the
+            // skeleton at this point.
+            // REVISIT: we should separate FieldRenderer and FieldAccessor
+            // so that accessors can be used before we build the code.
+            Model model = gl.annotateXMLSchema(result);
+            if(model==null)   return null;
+
+            if(hadError)        return null;    // if we have any error by now, abort
+
+            Outline context = model.generateCode(opts,this);
+            if(context==null)   return null;
+
+            if(hadError)        return null;
+
+            return new JAXBModelImpl(context);
+        } catch( SAXException e ) {
+            // since XSOM uses our parser that scans DOM,
+            // no parser error is possible.
+            // all the other errors will be directed to ErrorReceiver
+            // before it's thrown, so when the exception is thrown
+            // the error should have already been reported.
+
+            // thus ignore.
+            return null;
+        }
+    }
+
+    public void setErrorListener(ErrorListener errorListener) {
+        this.errorListener = errorListener;
+    }
+
+
+    public void info(SAXParseException exception) {
+        if(errorListener!=null)
+            errorListener.info(exception);
+    }
+    public void warning(SAXParseException exception) {
+        if(errorListener!=null)
+            errorListener.warning(exception);
+    }
+    public void error(SAXParseException exception) {
+        hadError = true;
+        if(errorListener!=null)
+            errorListener.error(exception);
+    }
+    public void fatalError(SAXParseException exception) {
+        hadError = true;
+        if(errorListener!=null)
+            errorListener.fatalError(exception);
+    }
+
+    /**
+     * We use JAXP 1.3 to do a schema correctness check, but we know
+     * it doesn't always work. So in case some people hit the problem,
+     * this switch is here so that they can turn it off as a workaround.
+     */
+    private static boolean NO_CORRECTNESS_CHECK = false;
+
+    static {
+        try {
+            NO_CORRECTNESS_CHECK = Boolean.getBoolean(SchemaCompilerImpl.class+".noCorrectnessCheck");
+        } catch( Throwable t) {
+            // ignore
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/TypeAndAnnotationImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/TypeAndAnnotationImpl.java
new file mode 100644
index 0000000..f1baf82
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/TypeAndAnnotationImpl.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.impl.s2j;
+
+import javax.xml.bind.annotation.XmlAttachmentRef;
+import javax.xml.bind.annotation.XmlList;
+
+import com.sun.codemodel.internal.JAnnotatable;
+import com.sun.codemodel.internal.JPrimitiveType;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.api.TypeAndAnnotation;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlJavaTypeAdapterWriter;
+import com.sun.tools.internal.xjc.model.CAdapter;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import static com.sun.tools.internal.xjc.outline.Aspect.EXPOSED;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.runtime.SwaRefAdapter;
+
+/**
+ * {@link TypeAndAnnotation} implementation.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class TypeAndAnnotationImpl implements TypeAndAnnotation {
+    private final TypeUse typeUse;
+    private final Outline outline;
+
+    public TypeAndAnnotationImpl(Outline outline, TypeUse typeUse) {
+        this.typeUse = typeUse;
+        this.outline = outline;
+    }
+
+    public JType getTypeClass() {
+        CAdapter a = typeUse.getAdapterUse();
+        NType nt;
+        if(a!=null)
+            nt = a.customType;
+        else
+            nt = typeUse.getInfo().getType();
+
+        JType jt = nt.toType(outline,EXPOSED);
+
+        JPrimitiveType prim = jt.boxify().getPrimitiveType();
+        if(!typeUse.isCollection() && prim!=null)
+            jt = prim;
+
+        if(typeUse.isCollection())
+            jt = jt.array();
+
+        return jt;
+    }
+
+    public void annotate(JAnnotatable programElement) {
+        if(typeUse.getAdapterUse()==null && !typeUse.isCollection())
+            return; // nothing
+
+        CAdapter adapterUse = typeUse.getAdapterUse();
+        if(adapterUse!=null) {
+            // ugly, ugly hack
+            if(adapterUse.getAdapterIfKnown()== SwaRefAdapter.class) {
+                programElement.annotate(XmlAttachmentRef.class);
+            } else {
+                // [RESULT]
+                // @XmlJavaTypeAdapter( Foo.class )
+                programElement.annotate2(XmlJavaTypeAdapterWriter.class).value(
+                    adapterUse.adapterType.toType(outline,EXPOSED));
+            }
+        }
+        if(typeUse.isCollection())
+            programElement.annotate(XmlList.class);
+    }
+
+    public String toString() {
+        StringBuilder builder = new StringBuilder();
+        // TODO: support annotations
+        builder.append(getTypeClass());
+        return builder.toString();
+    }
+
+    public boolean equals(Object o) {
+        if (!(o instanceof TypeAndAnnotationImpl)) return false;
+        TypeAndAnnotationImpl that = (TypeAndAnnotationImpl) o;
+        return this.typeUse==that.typeUse;
+    }
+
+    public int hashCode() {
+        return typeUse.hashCode();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/package.html
new file mode 100644
index 0000000..1b17d19
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/impl/s2j/package.html
@@ -0,0 +1,3 @@
+<html><body>
+implementation of the XJC API for schema to java.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/package.html
new file mode 100644
index 0000000..4ffeb74
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/package.html
@@ -0,0 +1,37 @@
+<html><body>
+API for programatic invocation of XJC and schemagen.
+
+<p>
+This package provides a way to invoke XJC from within another program.
+The primarily target of this API is the JAX-WS RI, but we hope that
+this API would be useful for other integration purposes as well.
+
+<h2>Getting Started: Using XJC</h2>
+<p>
+To invoke XJC, a typical client would do something like this:
+<pre>
+    SchemaCompiler sc = XJC.createSchemaCompiler();
+    sc.parseSchema(new InputSource(schema1Url.toExternalForm()));
+    sc.parseSchema(new InputSource(schema2Url.toExternalForm()));
+    ...
+    S2JModel model = sc.bind();
+</pre>
+<p>
+The bind operation causes XJC to do the bulk of the work, such as
+figuring out what classes to generate, what methods/fields to generate, etc.
+The obtained model contains useful introspective information about
+how the binding was performed (such as relationship between XML types
+and generated Java classes)
+
+<p>
+Once the model is obtained, generate the code into the file system as follows:
+<pre>
+    JCodeModel cm = model.generateCode( null, ... );
+    cm.build(new FileCodeWriter(outputDir));
+</pre>
+
+
+<h2>Implementation Note</h2>
+<p>
+This package shouldn't contain any implementation code.
+</body></html> 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/APTClassLoader.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/APTClassLoader.java
new file mode 100644
index 0000000..4ddff33
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/APTClassLoader.java
@@ -0,0 +1,145 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.util;
+
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.File;
+import java.net.URL;
+import java.net.URLClassLoader;
+import java.net.MalformedURLException;
+
+/**
+ * {@link ClassLoader} that loads APT and specified classes
+ * both into the same classloader, so that they can reference each other.
+ *
+ * @author Bhakti Mehta
+ * @since 2.0 beta
+ */
+public final class APTClassLoader extends URLClassLoader {
+    /**
+     * List of package prefixes we want to mask the
+     * parent classLoader from loading
+     */
+    private final String[] packagePrefixes;
+
+    /**
+     *
+     * @param packagePrefixes
+     *      The package prefixes that are forced to resolve within this class loader.
+     * @param parent
+     *      The parent class loader to delegate to.
+     */
+    public APTClassLoader(ClassLoader parent, String[] packagePrefixes) throws ToolsJarNotFoundException {
+        super(getToolsJar(parent),parent);
+        if(getURLs().length==0)
+            // if tools.jar was found in our classloader, no need to create
+            // a parallel classes
+            this.packagePrefixes = new String[0];
+        else
+            this.packagePrefixes = packagePrefixes;
+    }
+
+    public Class loadClass(String className) throws ClassNotFoundException {
+        for( String prefix : packagePrefixes ) {
+            if (className.startsWith(prefix) ) {
+                // we need to load those classes in this class loader
+                // without delegation.
+                return findClass(className);
+            }
+        }
+
+        return super.loadClass(className);
+
+    }
+
+    protected Class findClass(String name) throws ClassNotFoundException {
+
+        StringBuilder sb = new StringBuilder(name.length() + 6);
+        sb.append(name.replace('.','/')).append(".class");
+
+        InputStream is = getResourceAsStream(sb.toString());
+        if (is==null)
+            throw new ClassNotFoundException("Class not found" + sb);
+
+        try {
+            ByteArrayOutputStream baos = new ByteArrayOutputStream();
+            byte[] buf = new byte[1024];
+            int len;
+            while((len=is.read(buf))>=0)
+                baos.write(buf,0,len);
+
+            buf = baos.toByteArray();
+
+            // define package if not defined yet
+            int i = name.lastIndexOf('.');
+            if (i != -1) {
+                String pkgname = name.substring(0, i);
+                Package pkg = getPackage(pkgname);
+                if(pkg==null)
+                    definePackage(pkgname, null, null, null, null, null, null, null);
+            }
+
+            return defineClass(name,buf,0,buf.length);
+        } catch (IOException e) {
+            throw new ClassNotFoundException(name,e);
+        }
+    }
+
+    /**
+     * Returns a class loader that can load classes from JDK tools.jar.
+     * @param parent
+     */
+    private static URL[] getToolsJar(ClassLoader parent) throws ToolsJarNotFoundException {
+
+        try {
+            parent.loadClass("com.sun.tools.javac.Main");
+            parent.loadClass("com.sun.tools.apt.Main");
+            return new URL[0];
+            // we can already load them in the parent class loader.
+            // so no need to look for tools.jar.
+            // this happens when we are run inside IDE/Ant, or
+            // in Mac OS.
+        } catch (ClassNotFoundException e) {
+            // otherwise try to find tools.jar
+        }
+
+        File jreHome = new File(System.getProperty("java.home"));
+        File toolsJar = new File( jreHome.getParent(), "lib/tools.jar" );
+
+        if (!toolsJar.exists()) {
+            throw new ToolsJarNotFoundException(toolsJar);
+        }
+
+        try {
+            return new URL[]{toolsJar.toURL()};
+        } catch (MalformedURLException e) {
+            // impossible
+            throw new AssertionError(e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/FilerCodeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/FilerCodeWriter.java
new file mode 100644
index 0000000..0c9268b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/FilerCodeWriter.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.util;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.Writer;
+
+import com.sun.codemodel.internal.CodeWriter;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.mirror.apt.Filer;
+
+import static com.sun.mirror.apt.Filer.Location.CLASS_TREE;
+import static com.sun.mirror.apt.Filer.Location.SOURCE_TREE;
+
+/**
+ * {@link CodeWriter} that generates source code to {@link Filer}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class FilerCodeWriter extends CodeWriter {
+
+    private final Filer filer;
+
+    public FilerCodeWriter(Filer filer) {
+        this.filer = filer;
+    }
+
+    public OutputStream openBinary(JPackage pkg, String fileName) throws IOException {
+        Filer.Location loc;
+        if(fileName.endsWith(".java")) {
+            // APT doesn't do the proper Unicode escaping on Java source files,
+            // so we can't rely on Filer.createSourceFile.
+            loc = SOURCE_TREE;
+        } else {
+            // put non-Java files directly to the output folder
+            loc = CLASS_TREE;
+        }
+        return filer.createBinaryFile(loc,pkg.name(),new File(fileName));
+    }
+
+    public Writer openSource(JPackage pkg, String fileName) throws IOException {
+        String name;
+        if(pkg.isUnnamed())
+            name = fileName;
+        else
+            name = pkg.name()+'.'+fileName;
+
+        name = name.substring(0,name.length()-5);   // strip ".java"
+
+        return filer.createSourceFile(name);
+    }
+
+    public void close() {
+        ; // noop
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/Messages.java
new file mode 100644
index 0000000..ecedc62
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/Messages.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.util;
+
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources
+ */
+enum Messages {
+    TOOLS_JAR_NOT_FOUND,     // 1 arg
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/Messages.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/Messages.properties
new file mode 100644
index 0000000..ed10953
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/Messages.properties
@@ -0,0 +1,4 @@
+TOOLS_JAR_NOT_FOUND = \
+    JDK''s tools.jar was not found in {0}. Usually this means you are running JRE, not JDK. Please use the java command in JDK 5.0 or later (not JRE.)
+ 
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/ToolsJarNotFoundException.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/ToolsJarNotFoundException.java
new file mode 100644
index 0000000..c48a69d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/ToolsJarNotFoundException.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.api.util;
+
+import java.io.File;
+
+/**
+ * Signals an error when tools.jar was not found.
+ *
+ * Simply print out the message obtained by {@link #getMessage()}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ToolsJarNotFoundException extends Exception {
+    /**
+     * Location where we expected to find tools.jar
+     */
+    public final File toolsJar;
+
+    public ToolsJarNotFoundException(File toolsJar) {
+        super(calcMessage(toolsJar));
+        this.toolsJar = toolsJar;
+    }
+
+    private static String calcMessage(File toolsJar) {
+        return Messages.TOOLS_JAR_NOT_FOUND.format(toolsJar.getPath());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/package.html
new file mode 100644
index 0000000..3bd340f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/api/util/package.html
@@ -0,0 +1,3 @@
+<html><body>
+  Utility code shared between JAXB and JAX-WS
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/ri/XmlIsSetWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/ri/XmlIsSetWriter.java
new file mode 100644
index 0000000..1f6e652
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/ri/XmlIsSetWriter.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.ri;
+
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.xml.internal.bind.annotation.XmlIsSet;
+
+public interface XmlIsSetWriter
+    extends JAnnotationWriter<XmlIsSet>
+{
+
+
+    XmlIsSetWriter value(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/ri/XmlLocationWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/ri/XmlLocationWriter.java
new file mode 100644
index 0000000..6cbcd87
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/ri/XmlLocationWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.ri;
+
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.xml.internal.bind.annotation.XmlLocation;
+
+public interface XmlLocationWriter
+    extends JAnnotationWriter<XmlLocation>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAccessorOrderWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAccessorOrderWriter.java
new file mode 100644
index 0000000..bc234d0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAccessorOrderWriter.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlAccessOrder;
+import javax.xml.bind.annotation.XmlAccessorOrder;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlAccessorOrderWriter
+    extends JAnnotationWriter<XmlAccessorOrder>
+{
+
+
+    XmlAccessorOrderWriter value(XmlAccessOrder value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAccessorTypeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAccessorTypeWriter.java
new file mode 100644
index 0000000..e35e2b5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAccessorTypeWriter.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlAccessorTypeWriter
+    extends JAnnotationWriter<XmlAccessorType>
+{
+
+
+    XmlAccessorTypeWriter value(XmlAccessType value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAnyAttributeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAnyAttributeWriter.java
new file mode 100644
index 0000000..dbdba1a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAnyAttributeWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlAnyAttribute;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlAnyAttributeWriter
+    extends JAnnotationWriter<XmlAnyAttribute>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAnyElementWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAnyElementWriter.java
new file mode 100644
index 0000000..c6c39f7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAnyElementWriter.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlAnyElement;
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.codemodel.internal.JType;
+
+public interface XmlAnyElementWriter
+    extends JAnnotationWriter<XmlAnyElement>
+{
+
+
+    XmlAnyElementWriter value(Class value);
+
+    XmlAnyElementWriter value(JType value);
+
+    XmlAnyElementWriter lax(boolean value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAttachmentRefWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAttachmentRefWriter.java
new file mode 100644
index 0000000..fb91383
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAttachmentRefWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlAttachmentRef;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlAttachmentRefWriter
+    extends JAnnotationWriter<XmlAttachmentRef>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAttributeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAttributeWriter.java
new file mode 100644
index 0000000..31a18cd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlAttributeWriter.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlAttributeWriter
+    extends JAnnotationWriter<XmlAttribute>
+{
+
+
+    XmlAttributeWriter name(String value);
+
+    XmlAttributeWriter namespace(String value);
+
+    XmlAttributeWriter required(boolean value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementDeclWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementDeclWriter.java
new file mode 100644
index 0000000..dc68744
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementDeclWriter.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlElementDecl;
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.codemodel.internal.JType;
+
+public interface XmlElementDeclWriter
+    extends JAnnotationWriter<XmlElementDecl>
+{
+
+
+    XmlElementDeclWriter name(String value);
+
+    XmlElementDeclWriter namespace(String value);
+
+    XmlElementDeclWriter defaultValue(String value);
+
+    XmlElementDeclWriter scope(Class value);
+
+    XmlElementDeclWriter scope(JType value);
+
+    XmlElementDeclWriter substitutionHeadNamespace(String value);
+
+    XmlElementDeclWriter substitutionHeadName(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementRefWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementRefWriter.java
new file mode 100644
index 0000000..0cf5ace
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementRefWriter.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlElementRef;
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.codemodel.internal.JType;
+
+public interface XmlElementRefWriter
+    extends JAnnotationWriter<XmlElementRef>
+{
+
+
+    XmlElementRefWriter name(String value);
+
+    XmlElementRefWriter type(Class value);
+
+    XmlElementRefWriter type(JType value);
+
+    XmlElementRefWriter namespace(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementRefsWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementRefsWriter.java
new file mode 100644
index 0000000..1ad6aee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementRefsWriter.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlElementRefs;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlElementRefsWriter
+    extends JAnnotationWriter<XmlElementRefs>
+{
+
+
+    XmlElementRefWriter value();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementWrapperWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementWrapperWriter.java
new file mode 100644
index 0000000..c2341ff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementWrapperWriter.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlElementWrapper;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlElementWrapperWriter
+    extends JAnnotationWriter<XmlElementWrapper>
+{
+
+
+    XmlElementWrapperWriter name(String value);
+
+    XmlElementWrapperWriter namespace(String value);
+
+    XmlElementWrapperWriter nillable(boolean value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementWriter.java
new file mode 100644
index 0000000..714f807
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementWriter.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlElement;
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.codemodel.internal.JType;
+
+public interface XmlElementWriter
+    extends JAnnotationWriter<XmlElement>
+{
+
+
+    XmlElementWriter name(String value);
+
+    XmlElementWriter type(Class value);
+
+    XmlElementWriter type(JType value);
+
+    XmlElementWriter namespace(String value);
+
+    XmlElementWriter defaultValue(String value);
+
+    XmlElementWriter required(boolean value);
+
+    XmlElementWriter nillable(boolean value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementsWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementsWriter.java
new file mode 100644
index 0000000..0707c54
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlElementsWriter.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlElements;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlElementsWriter
+    extends JAnnotationWriter<XmlElements>
+{
+
+
+    XmlElementWriter value();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlEnumValueWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlEnumValueWriter.java
new file mode 100644
index 0000000..8025105
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlEnumValueWriter.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlEnumValue;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlEnumValueWriter
+    extends JAnnotationWriter<XmlEnumValue>
+{
+
+
+    XmlEnumValueWriter value(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlEnumWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlEnumWriter.java
new file mode 100644
index 0000000..60422ec
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlEnumWriter.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlEnum;
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.codemodel.internal.JType;
+
+public interface XmlEnumWriter
+    extends JAnnotationWriter<XmlEnum>
+{
+
+
+    XmlEnumWriter value(Class value);
+
+    XmlEnumWriter value(JType value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlIDREFWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlIDREFWriter.java
new file mode 100644
index 0000000..b768d9f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlIDREFWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlIDREF;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlIDREFWriter
+    extends JAnnotationWriter<XmlIDREF>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlIDWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlIDWriter.java
new file mode 100644
index 0000000..367633b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlIDWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlID;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlIDWriter
+    extends JAnnotationWriter<XmlID>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlInlineBinaryDataWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlInlineBinaryDataWriter.java
new file mode 100644
index 0000000..7f5cb4a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlInlineBinaryDataWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlInlineBinaryData;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlInlineBinaryDataWriter
+    extends JAnnotationWriter<XmlInlineBinaryData>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlJavaTypeAdapterWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlJavaTypeAdapterWriter.java
new file mode 100644
index 0000000..3fa1c9f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlJavaTypeAdapterWriter.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.codemodel.internal.JType;
+
+public interface XmlJavaTypeAdapterWriter
+    extends JAnnotationWriter<XmlJavaTypeAdapter>
+{
+
+
+    XmlJavaTypeAdapterWriter value(Class value);
+
+    XmlJavaTypeAdapterWriter value(JType value);
+
+    XmlJavaTypeAdapterWriter type(Class value);
+
+    XmlJavaTypeAdapterWriter type(JType value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlListWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlListWriter.java
new file mode 100644
index 0000000..9427b61
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlListWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlList;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlListWriter
+    extends JAnnotationWriter<XmlList>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlMimeTypeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlMimeTypeWriter.java
new file mode 100644
index 0000000..8cc20db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlMimeTypeWriter.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlMimeType;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlMimeTypeWriter
+    extends JAnnotationWriter<XmlMimeType>
+{
+
+
+    XmlMimeTypeWriter value(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlMixedWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlMixedWriter.java
new file mode 100644
index 0000000..ec2f889
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlMixedWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlMixed;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlMixedWriter
+    extends JAnnotationWriter<XmlMixed>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlNsWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlNsWriter.java
new file mode 100644
index 0000000..a034b11
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlNsWriter.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlNs;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlNsWriter
+    extends JAnnotationWriter<XmlNs>
+{
+
+
+    XmlNsWriter prefix(String value);
+
+    XmlNsWriter namespaceURI(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlRegistryWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlRegistryWriter.java
new file mode 100644
index 0000000..3751af0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlRegistryWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlRegistry;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlRegistryWriter
+    extends JAnnotationWriter<XmlRegistry>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlRootElementWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlRootElementWriter.java
new file mode 100644
index 0000000..c2e123b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlRootElementWriter.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlRootElement;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlRootElementWriter
+    extends JAnnotationWriter<XmlRootElement>
+{
+
+
+    XmlRootElementWriter name(String value);
+
+    XmlRootElementWriter namespace(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaTypeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaTypeWriter.java
new file mode 100644
index 0000000..04a2bd9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaTypeWriter.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlSchemaType;
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.codemodel.internal.JType;
+
+public interface XmlSchemaTypeWriter
+    extends JAnnotationWriter<XmlSchemaType>
+{
+
+
+    XmlSchemaTypeWriter name(String value);
+
+    XmlSchemaTypeWriter type(Class value);
+
+    XmlSchemaTypeWriter type(JType value);
+
+    XmlSchemaTypeWriter namespace(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaTypesWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaTypesWriter.java
new file mode 100644
index 0000000..2d6fbd7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaTypesWriter.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlSchemaTypes;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlSchemaTypesWriter
+    extends JAnnotationWriter<XmlSchemaTypes>
+{
+
+
+    XmlSchemaTypeWriter value();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaWriter.java
new file mode 100644
index 0000000..f52b536
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlSchemaWriter.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.bind.annotation.XmlSchema;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlSchemaWriter
+    extends JAnnotationWriter<XmlSchema>
+{
+
+
+    XmlSchemaWriter namespace(String value);
+
+    XmlNsWriter xmlns();
+
+    XmlSchemaWriter elementFormDefault(XmlNsForm value);
+
+    XmlSchemaWriter attributeFormDefault(XmlNsForm value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlTransientWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlTransientWriter.java
new file mode 100644
index 0000000..1f2c67a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlTransientWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlTransient;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlTransientWriter
+    extends JAnnotationWriter<XmlTransient>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlTypeWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlTypeWriter.java
new file mode 100644
index 0000000..2f04dbc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlTypeWriter.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlType;
+import com.sun.codemodel.internal.JAnnotationWriter;
+import com.sun.codemodel.internal.JType;
+
+public interface XmlTypeWriter
+    extends JAnnotationWriter<XmlType>
+{
+
+
+    XmlTypeWriter name(String value);
+
+    XmlTypeWriter namespace(String value);
+
+    XmlTypeWriter propOrder(String value);
+
+    XmlTypeWriter factoryClass(Class value);
+
+    XmlTypeWriter factoryClass(JType value);
+
+    XmlTypeWriter factoryMethod(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlValueWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlValueWriter.java
new file mode 100644
index 0000000..9aaf50e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/annotation/spec/XmlValueWriter.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.generator.annotation.spec;
+
+import javax.xml.bind.annotation.XmlValue;
+import com.sun.codemodel.internal.JAnnotationWriter;
+
+public interface XmlValueWriter
+    extends JAnnotationWriter<XmlValue>
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/BeanGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/BeanGenerator.java
new file mode 100644
index 0000000..297063b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/BeanGenerator.java
@@ -0,0 +1,753 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import java.io.Serializable;
+import java.net.URL;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeSet;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.annotation.XmlAttachmentRef;
+import javax.xml.bind.annotation.XmlID;
+import javax.xml.bind.annotation.XmlIDREF;
+import javax.xml.bind.annotation.XmlMimeType;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.ClassType;
+import com.sun.codemodel.internal.JAnnotatable;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JClassAlreadyExistsException;
+import com.sun.codemodel.internal.JClassContainer;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JEnumConstant;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JForEach;
+import com.sun.codemodel.internal.JInvocation;
+import com.sun.codemodel.internal.JJavaName;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.codemodel.internal.fmt.JStaticJavaFile;
+import com.sun.tools.internal.xjc.AbortException;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlAnyAttributeWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlEnumValueWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlEnumWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlJavaTypeAdapterWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlMimeTypeWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlRootElementWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlTypeWriter;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRenderer;
+import com.sun.tools.internal.xjc.model.CAdapter;
+import com.sun.tools.internal.xjc.model.CAttributePropertyInfo;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CClassInfoParent;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CEnumConstant;
+import com.sun.tools.internal.xjc.model.CEnumLeafInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+import com.sun.tools.internal.xjc.outline.EnumConstantOutline;
+import com.sun.tools.internal.xjc.outline.EnumOutline;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.tools.internal.xjc.outline.PackageOutline;
+import com.sun.tools.internal.xjc.util.CodeModelClassFactory;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.SwaRefAdapter;
+import com.sun.xml.internal.xsom.XmlString;
+
+/**
+ * Generates fields and accessors.
+ */
+public final class BeanGenerator implements Outline
+{
+    /** Simplifies class/interface creation and collision detection. */
+    private final CodeModelClassFactory codeModelClassFactory;
+
+    private final ErrorReceiver errorReceiver;
+
+    /** all {@link PackageOutline}s keyed by their {@link PackageOutline#_package}. */
+    private final Map<JPackage,PackageOutlineImpl> packageContexts = new HashMap<JPackage,PackageOutlineImpl>();
+
+    /** all {@link ClassOutline}s keyed by their {@link ClassOutline#target}. */
+    private final Map<CClassInfo,ClassOutlineImpl> classes = new HashMap<CClassInfo,ClassOutlineImpl>();
+
+    /** all {@link EnumOutline}s keyed by their {@link EnumOutline#target}. */
+    private final Map<CEnumLeafInfo,EnumOutline> enums = new HashMap<CEnumLeafInfo,EnumOutline>();
+
+    /**
+     * Generated runtime classes.
+     */
+    private final Map<Class,JClass> generatedRuntime = new HashMap<Class, JClass>();
+
+    /** the model object which we are processing. */
+    private final Model model;
+
+    private final JCodeModel codeModel;
+
+    /**
+     * for each property, the information about the generated field.
+     */
+    private final Map<CPropertyInfo,FieldOutline> fields = new HashMap<CPropertyInfo,FieldOutline>();
+
+    /**
+     * elements that generate classes to the generated classes.
+     */
+    /*package*/ final Map<CElementInfo,ElementOutlineImpl> elements = new HashMap<CElementInfo,ElementOutlineImpl>();
+
+
+
+    /**
+     * Generates beans into code model according to the BGM,
+     * and produces the reflection model.
+     *
+     * @param _errorReceiver
+     *      This object will receive all the errors discovered
+     *      during the back-end stage.
+     *
+     * @return
+     *      returns a {@link Outline} which will in turn
+     *      be used to further generate marshaller/unmarshaller,
+     *      or null if the processing fails (errors should have been
+     *      reported to the error recevier.)
+     */
+    public static Outline generate(Model model, ErrorReceiver _errorReceiver) {
+
+        try {
+            return new BeanGenerator(model, _errorReceiver);
+        } catch( AbortException e ) {
+            return null;
+        }
+    }
+
+
+    private BeanGenerator(Model _model, ErrorReceiver _errorReceiver) {
+
+        this.model = _model;
+        this.codeModel = model.codeModel;
+        this.errorReceiver = _errorReceiver;
+        this.codeModelClassFactory = new CodeModelClassFactory(errorReceiver);
+
+        // build enum classes
+        for( CEnumLeafInfo p : model.enums().values() )
+            enums.put( p, generateEnum(p) );
+
+        JPackage[] packages = getUsedPackages(Aspect.EXPOSED);
+
+        // generates per-package code and remember the results as contexts.
+        for( JPackage pkg : packages )
+            getPackageContext(pkg);
+
+        // create the class definitions for all the beans first.
+        // this should also fill in PackageContext#getClasses
+        for( CClassInfo bean : model.beans().values() )
+            getClazz(bean);
+
+        // compute the package-level setting
+        for (PackageOutlineImpl p : packageContexts.values())
+            p.calcDefaultValues();
+
+        JClass OBJECT = codeModel.ref(Object.class);
+
+        // inheritance relationship needs to be set before we generate fields, or otherwise
+        // we'll fail to compute the correct type signature (namely the common base type computation)
+        for( ClassOutlineImpl cc : getClasses() ) {
+
+            // setup inheritance between implementation hierarchy.
+            CClassInfo superClass = cc.target.getBaseClass();
+            if(superClass!=null) {
+                // use the specified super class
+                model.strategy._extends(cc,getClazz(superClass));
+            } else {
+                // use the default one, if any
+                if( model.rootClass!=null && cc.implClass._extends().equals(OBJECT) )
+                    cc.implClass._extends(model.rootClass);
+                if( model.rootInterface!=null)
+                    cc.ref._implements(model.rootInterface);
+            }
+        }
+
+        // fill in implementation classes
+        for( ClassOutlineImpl co : getClasses() )
+            generateClassBody(co);
+
+        // create factories for the impl-less elements
+        for( CElementInfo ei : model.getAllElements())
+            getPackageContext(ei._package()).objectFactoryGenerator().populate(ei);
+
+        if(model.options.debugMode)
+            generateClassList();
+    }
+
+    /**
+     * Generates a class that knows how to create an instance of JAXBContext
+     *
+     * <p>
+     * This is used in the debug mode so that a new properly configured
+     * {@link JAXBContext} object can be used.
+     */
+    private void generateClassList() {
+        try {
+            JDefinedClass jc = codeModel.rootPackage()._class("JAXBDebug");
+            JMethod m = jc.method(JMod.PUBLIC|JMod.STATIC,JAXBContext.class,"createContext");
+            JVar $classLoader = m.param(ClassLoader.class,"classLoader");
+            m._throws(JAXBException.class);
+            JInvocation inv = codeModel.ref(JAXBContext.class).staticInvoke("newInstance");
+            m.body()._return(inv);
+
+            switch(model.strategy) {
+            case INTF_AND_IMPL:
+                {
+                    StringBuilder buf = new StringBuilder();
+                    for( PackageOutlineImpl po : packageContexts.values() ) {
+                        if(buf.length()>0)  buf.append(':');
+                        buf.append(po._package().name());
+                    }
+                    inv.arg(buf.toString()).arg($classLoader);
+                    break;
+                }
+            case BEAN_ONLY:
+                for( ClassOutlineImpl cc : getClasses() )
+                    inv.arg(cc.implRef.dotclass());
+                for( PackageOutlineImpl po : packageContexts.values() )
+                    inv.arg(po.objectFactory().dotclass());
+                break;
+            default:
+                throw new IllegalStateException();
+            }
+        } catch (JClassAlreadyExistsException e) {
+            e.printStackTrace();
+            // after all, we are in the debug mode. a little sloppiness is OK.
+            // this error is not fatal. just continue.
+        }
+    }
+
+
+    public Model getModel() {
+        return model;
+    }
+
+    public JCodeModel getCodeModel() {
+        return codeModel;
+    }
+
+    public JClassContainer getContainer(CClassInfoParent parent, Aspect aspect) {
+        CClassInfoParent.Visitor<JClassContainer> v;
+        switch(aspect) {
+        case EXPOSED:
+            v = exposedContainerBuilder;
+            break;
+        case IMPLEMENTATION:
+            v = implContainerBuilder;
+            break;
+        default:
+            assert false;
+            throw new IllegalStateException();
+        }
+        return parent.accept(v);
+    }
+
+    public final JType resolve(CTypeRef ref,Aspect a) {
+        return ref.getTarget().getType().toType(this,a);
+    }
+
+    private final CClassInfoParent.Visitor<JClassContainer> exposedContainerBuilder =
+        new CClassInfoParent.Visitor<JClassContainer>() {
+        public JClassContainer onBean(CClassInfo bean) {
+            return getClazz(bean).ref;
+        }
+
+        public JClassContainer onElement(CElementInfo element) {
+            // hmm...
+            return getElement(element).implClass;
+        }
+
+        public JClassContainer onPackage(JPackage pkg) {
+            return model.strategy.getPackage(pkg,Aspect.EXPOSED);
+        }
+    };
+
+    private final CClassInfoParent.Visitor<JClassContainer> implContainerBuilder =
+        new CClassInfoParent.Visitor<JClassContainer>() {
+        public JClassContainer onBean(CClassInfo bean) {
+            return getClazz(bean).implClass;
+        }
+
+        public JClassContainer onElement(CElementInfo element) {
+            return getElement(element).implClass;
+        }
+
+        public JClassContainer onPackage(JPackage pkg) {
+            return model.strategy.getPackage(pkg,Aspect.IMPLEMENTATION);
+        }
+    };
+
+
+    /**
+     * Returns all <i>used</i> JPackages.
+     *
+     * A JPackage is considered as "used" if a ClassItem or
+     * a InterfaceItem resides in that package.
+     *
+     * This value is dynamically calculated every time because
+     * one can freely remove ClassItem/InterfaceItem.
+     *
+     * @return
+     *         Given the same input, the order of packages in the array
+     *         is always the same regardless of the environment.
+     */
+    public final JPackage[] getUsedPackages( Aspect aspect ) {
+        Set<JPackage> s = new TreeSet<JPackage>();
+
+        for( CClassInfo bean : model.beans().values() ) {
+            JClassContainer cont = getContainer(bean.parent(),aspect);
+            if(cont.isPackage())
+                s.add( (JPackage)cont );
+        }
+
+        for( CElementInfo e : model.getElementMappings(null).values() ) {
+            // at the first glance you might think we should be iterating all elements,
+            // not just global ones, but if you think about it, local ones live inside
+            // another class, so those packages are already enumerated when we were
+            // walking over CClassInfos.
+            s.add( e._package() );
+        }
+
+        return s.toArray(new JPackage[s.size()]);
+    }
+
+    public ErrorReceiver getErrorReceiver() { return errorReceiver; }
+
+    public CodeModelClassFactory getClassFactory() { return codeModelClassFactory; }
+
+    public PackageOutlineImpl getPackageContext( JPackage p ) {
+        PackageOutlineImpl r = packageContexts.get(p);
+        if(r==null) {
+            r=new PackageOutlineImpl(this,model,p);
+            packageContexts.put(p,r);
+        }
+        return r;
+    }
+
+    /**
+     * Generates the minimum {@link JDefinedClass} skeleton
+     * without filling in its body.
+     */
+    private ClassOutlineImpl generateClassDef(CClassInfo bean) {
+        ImplStructureStrategy.Result r = model.strategy.createClasses(this,bean);
+        JClass implRef;
+
+        if( bean.getUserSpecifiedImplClass()!=null ) {
+            // create a place holder for a user-specified class.
+            JDefinedClass usr;
+            try {
+                usr = codeModel._class(bean.getUserSpecifiedImplClass());
+                // but hide that file so that it won't be generated.
+                usr.hide();
+            } catch( JClassAlreadyExistsException e ) {
+                // it's OK for this to collide.
+                usr = e.getExistingClass();
+            }
+            usr._extends(r.implementation);
+            implRef = usr;
+        } else
+                implRef = r.implementation;
+
+        return new ClassOutlineImpl(this,bean,r.exposed,r.implementation,implRef);
+    }
+
+
+    public Collection<ClassOutlineImpl> getClasses() {
+        // make sure that classes are fully populated
+        assert model.beans().size()==classes.size();
+        return classes.values();
+    }
+
+    public ClassOutlineImpl getClazz( CClassInfo bean ) {
+        ClassOutlineImpl r = classes.get(bean);
+        if(r==null)
+            classes.put( bean, r=generateClassDef(bean) );
+        return r;
+    }
+
+    public ElementOutlineImpl getElement(CElementInfo ei) {
+        ElementOutlineImpl def = elements.get(ei);
+        if(def==null && ei.hasClass()) {
+            // create one. in the constructor it adds itself to the elements.
+            def = new ElementOutlineImpl(this,ei);
+        }
+        return def;
+    }
+
+    public EnumOutline getEnum(CEnumLeafInfo eli) {
+        return enums.get(eli);
+    }
+
+    public Collection<EnumOutline> getEnums() {
+        return enums.values();
+    }
+
+    public Iterable<? extends PackageOutline> getAllPackageContexts() {
+        return packageContexts.values();
+    }
+
+    public FieldOutline getField( CPropertyInfo prop ) {
+        return fields.get(prop);
+    }
+
+    /**
+     * Generates the body of a class.
+     *
+     */
+    private void generateClassBody( ClassOutlineImpl cc ) {
+        CClassInfo target = cc.target;
+
+
+        // if serialization support is turned on, generate
+        // [RESULT]
+        // class ... implements Serializable {
+        //     private static final long serialVersionUID = <id>;
+        //     ....
+        // }
+        if( model.serializable ) {
+            cc.implClass._implements(Serializable.class);
+            if( model.serialVersionUID!=null ) {
+                cc.implClass.field(
+                    JMod.PRIVATE|JMod.STATIC|JMod.FINAL,
+                    codeModel.LONG,
+                    "serialVersionUID",
+                    JExpr.lit(model.serialVersionUID));
+            }
+        }
+
+        // used to simplify the generated annotations
+        String mostUsedNamespaceURI = cc._package().getMostUsedNamespaceURI();
+
+        // [RESULT]
+        // @XmlType(name="foo", targetNamespace="bar://baz")
+        XmlTypeWriter xtw = cc.implClass.annotate2(XmlTypeWriter.class);
+        QName typeName = cc.target.getTypeName();
+        if(typeName==null) {
+            xtw.name("");
+        } else {
+            xtw.name(typeName.getLocalPart());
+            final String typeNameURI = typeName.getNamespaceURI();
+            if(!typeNameURI.equals(mostUsedNamespaceURI)) // only generate if necessary
+                xtw.namespace(typeNameURI);
+        }
+
+
+        if(target.isElement()) {
+            String namespaceURI = target.getElementName().getNamespaceURI();
+            String localPart = target.getElementName().getLocalPart();
+
+            // [RESULT]
+            // @XmlRootElement(name="foo", targetNamespace="bar://baz")
+            XmlRootElementWriter xrew = cc.implClass.annotate2(XmlRootElementWriter.class);
+            xrew.name(localPart);
+            if(!namespaceURI.equals(mostUsedNamespaceURI)) // only generate if necessary
+                xrew.namespace(namespaceURI);
+        }
+
+        if(target.isOrdered()) {
+            for(CPropertyInfo p : target.getProperties() ) {
+                if( ! (p instanceof CAttributePropertyInfo )) {
+                    xtw.propOrder(p.getName(false));
+                }
+            }
+        } else {
+            // produce empty array
+            xtw.getAnnotationUse().paramArray("propOrder");
+        }
+
+        for( CPropertyInfo prop : target.getProperties() ) {
+            generateFieldDecl(cc,prop);
+        }
+
+        if( target.declaresAttributeWildcard() ) {
+            generateAttributeWildcard(cc);
+        }
+
+        // generate some class level javadoc
+        cc.ref.javadoc().append(target.javadoc);
+
+        cc._package().objectFactoryGenerator().populate(cc);
+    }
+
+    /**
+     * Generates an attribute wildcard property on a class.
+     */
+    private void generateAttributeWildcard( ClassOutlineImpl cc ) {
+        String FIELD_NAME = "otherAttributes";
+        String METHOD_SEED = model.getNameConverter().toClassName(FIELD_NAME);
+
+        JClass mapType = codeModel.ref(Map.class).narrow(QName.class,String.class);
+        JClass mapImpl = codeModel.ref(HashMap.class).narrow(QName.class,String.class);
+
+        // [RESULT]
+        // Map<QName,String> m = new HashMap<QName,String>();
+        JFieldVar $ref = cc.implClass.field(JMod.PRIVATE,
+                mapType, FIELD_NAME, JExpr._new(mapImpl) );
+        $ref.annotate2(XmlAnyAttributeWriter.class);
+
+        MethodWriter writer = cc.createMethodWriter();
+
+        JMethod $get = writer.declareMethod( mapType, "get"+METHOD_SEED );
+        $get.javadoc().append(
+            "Gets a map that contains attributes that aren't bound to any typed property on this class.\n\n" +
+            "<p>\n" +
+            "the map is keyed by the name of the attribute and \n" +
+            "the value is the string value of the attribute.\n" +
+            "\n" +
+            "the map returned by this method is live, and you can add new attribute\n" +
+            "by updating the map directly. Because of this design, there's no setter.\n");
+        $get.javadoc().addReturn().append("always non-null");
+
+        $get.body()._return($ref);
+    }
+
+
+
+    private EnumOutline generateEnum(CEnumLeafInfo e) {
+        JDefinedClass type;
+
+        // since constant values are never null, no point in using the boxed types.
+        JType baseExposedType = e.base.toType(this,Aspect.EXPOSED).unboxify();
+        JType baseImplType = e.base.toType(this,Aspect.IMPLEMENTATION).unboxify();
+
+
+        type = getClassFactory().createClass(
+            getContainer(e.parent,Aspect.EXPOSED),e.shortName,e.getLocator(), ClassType.ENUM);
+        type.javadoc().append(e.javadoc);
+
+        XmlEnumWriter xew = type.annotate2(XmlEnumWriter.class);
+        xew.value(baseExposedType);
+
+        JCodeModel codeModel = model.codeModel;
+
+        EnumOutline enumOutline = new EnumOutline(e, type) {};
+
+        boolean needsValue = e.needsValueField();
+
+        // for each member <m>,
+        // [RESULT]
+        //    <EnumName>(<deserializer of m>(<value>));
+
+        Set<String> enumFieldNames = new HashSet<String>();    // record generated field names to detect collision
+
+        for( CEnumConstant mem : e.members ) {
+            String constName = mem.getName();
+
+            if(!JJavaName.isJavaIdentifier(constName)) {
+                // didn't produce a name.
+                getErrorReceiver().error( e.getLocator(),
+                    Messages.ERR_UNUSABLE_NAME.format(mem.getLexicalValue(), constName ) );
+            }
+
+            if( !enumFieldNames.add(constName) )
+                getErrorReceiver().error( e.getLocator(), Messages.ERR_NAME_COLLISION.format(constName));
+
+            // [RESULT]
+            // <Const>(...)
+            // ASSUMPTION: datatype is outline-independent
+            JEnumConstant constRef = type.enumConstant(constName);
+            if(needsValue)
+                constRef.arg(e.base.createConstant(this, new XmlString(mem.getLexicalValue())));
+
+            if(!mem.getLexicalValue().equals(constName))
+                constRef.annotate2(XmlEnumValueWriter.class).value(mem.getLexicalValue());
+
+            // set javadoc
+            if( mem.javadoc!=null )
+                constRef.javadoc().append(mem.javadoc);
+
+            enumOutline.constants.add(new EnumConstantOutline(mem,constRef){});
+        }
+
+
+        if(needsValue) {
+            // [RESULT]
+            // final <valueType> value;
+            JFieldVar $value = type.field( JMod.PRIVATE|JMod.FINAL, baseExposedType, "value" );
+
+            // [RESULT]
+            // public <valuetype> value() { return value; }
+            type.method(JMod.PUBLIC, baseExposedType, "value" ).body()._return($value);
+
+            // [RESULT]
+            // <constructor>(<valueType> v) {
+            //     this.value=v;
+            // }
+            {
+                JMethod m = type.constructor(0);
+                m.body().assign( $value,    m.param( baseImplType, "v" ) );
+            }
+
+            // [RESULT]
+            // public static <Const> fromValue(<valueType> v) {
+            //   for( <Const> c : <Const>.values() ) {
+            //       if(c.value == v)   // or equals
+            //           return c;
+            //   }
+            //   throw new IllegalArgumentException(...);
+            // }
+            {
+                JMethod m = type.method(JMod.PUBLIC|JMod.STATIC , type, "fromValue" );
+                JVar $v = m.param(baseExposedType,"v");
+                JForEach fe = m.body().forEach(type,"c", type.staticInvoke("values") );
+                JExpression eq;
+                if(baseExposedType.isPrimitive())
+                    eq = fe.var().ref($value).eq($v);
+                else
+                    eq = fe.var().ref($value).invoke("equals").arg($v);
+
+                fe.body()._if(eq)._then()._return(fe.var());
+
+                JInvocation ex = JExpr._new(codeModel.ref(IllegalArgumentException.class));
+
+                if(baseExposedType.isPrimitive()) {
+                    m.body()._throw(ex.arg(codeModel.ref(String.class).staticInvoke("valueOf").arg($v)));
+                } else {
+                    m.body()._throw(ex.arg($v.invoke("toString")));
+                }
+            }
+        } else {
+            // [RESULT]
+            // public String value() { return name(); }
+            type.method(JMod.PUBLIC, String.class, "value" ).body()._return(JExpr.invoke("name"));
+
+            // [RESULT]
+            // public <Const> fromValue(String v) { return valueOf(v); }
+            JMethod m = type.method(JMod.PUBLIC|JMod.STATIC, type, "fromValue" );
+            m.body()._return( JExpr.invoke("valueOf").arg(m.param(String.class,"v")));
+        }
+
+        return enumOutline;
+    }
+
+
+
+
+    /**
+     * Determines the FieldRenderer used for the given FieldUse,
+     * then generates the field declaration and accessor methods.
+     *
+     * The <code>fields</code> map will be updated with the newly
+     * created FieldRenderer.
+     */
+    private FieldOutline generateFieldDecl( ClassOutlineImpl cc, CPropertyInfo prop ) {
+        FieldRenderer fr = prop.realization;
+        if(fr==null)
+            // none is specified. use the default factory
+            fr = model.options.getFieldRendererFactory().getDefault();
+
+        FieldOutline field = fr.generate(cc,prop);
+        fields.put(prop,field);
+
+
+        return field;
+    }
+
+    /**
+     * Generates {@link XmlJavaTypeAdapter} from {@link PropertyInfo} if necessary.
+     * Also generates other per-property annotations
+     * (such as {@link XmlID}, {@link XmlIDREF}, and {@link XmlMimeType} if necessary.
+     */
+    public final void generateAdapterIfNecessary(CPropertyInfo prop, JAnnotatable field) {
+        CAdapter adapter = prop.getAdapter();
+        if (adapter != null ) {
+            if(adapter.getAdapterIfKnown()==SwaRefAdapter.class) {
+                field.annotate(XmlAttachmentRef.class);
+            } else {
+                // [RESULT]
+                // @XmlJavaTypeAdapter( Foo.class )
+                XmlJavaTypeAdapterWriter xjtw = field.annotate2(XmlJavaTypeAdapterWriter.class);
+                xjtw.value(adapter.adapterType.toType(this,Aspect.EXPOSED));
+            }
+        }
+
+        switch(prop.id()) {
+        case ID:
+            field.annotate(XmlID.class);
+            break;
+        case IDREF:
+            field.annotate(XmlIDREF.class);
+            break;
+        }
+
+        if(prop.getExpectedMimeType()!=null)
+            field.annotate2(XmlMimeTypeWriter.class).value(prop.getExpectedMimeType().toString());
+    }
+
+    public final JClass addRuntime(Class clazz) {
+        JClass g = generatedRuntime.get(clazz);
+        if(g==null) {
+            // put code into a separate package to avoid name conflicts.
+            JPackage implPkg = getUsedPackages(Aspect.IMPLEMENTATION)[0].subPackage("runtime");
+            g = generateStaticClass(clazz,implPkg);
+            generatedRuntime.put(clazz,g);
+        }
+        return g;
+    }
+
+    public JClass generateStaticClass(Class src, JPackage out) {
+        String shortName = getShortName(src.getName());
+
+        // some people didn't like our jars to contain files with .java extension,
+        // so when we build jars, we'' use ".java_". But when we run from the workspace,
+        // we want the original source code to be used, so we check both here.
+        // see bug 6211503.
+        URL res = src.getResource(shortName+".java");
+        if(res==null)
+            res = src.getResource(shortName+".java_");
+        if(res==null)
+            throw new InternalError("Unable to load source code of "+src.getName()+" as a resource");
+
+        JStaticJavaFile sjf = new JStaticJavaFile(out,shortName, res, null );
+        out.addResourceFile(sjf);
+        return sjf.getJClass();
+    }
+
+    private String getShortName( String name ) {
+        return name.substring(name.lastIndexOf('.')+1);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ClassOutlineImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ClassOutlineImpl.java
new file mode 100644
index 0000000..b839331
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ClassOutlineImpl.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+
+/**
+ * {@link ClassOutline} enhanced with schema2java specific
+ * information.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class ClassOutlineImpl extends ClassOutline {
+    private final BeanGenerator _parent;
+
+
+    public MethodWriter createMethodWriter() {
+        return _parent.getModel().strategy.createMethodWriter(this);
+    }
+
+    /**
+     * Gets {@link #_package} as {@link PackageOutlineImpl},
+     * since it's guaranteed to be of that type.
+     */
+    public PackageOutlineImpl _package() {
+        return (PackageOutlineImpl)super._package();
+    }
+
+    ClassOutlineImpl( BeanGenerator _parent,
+        CClassInfo _target, JDefinedClass exposedClass, JDefinedClass _implClass, JClass _implRef ) {
+        super(_target,exposedClass,_implRef,_implClass);
+        this._parent = _parent;
+        _package().classes.add(this);
+    }
+
+    public BeanGenerator parent() {
+        return _parent;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/DualObjectFactoryGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/DualObjectFactoryGenerator.java
new file mode 100644
index 0000000..bd5d54e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/DualObjectFactoryGenerator.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.xml.internal.bind.v2.ContextFactory;
+
+/**
+ * {@link ObjectFactoryGenerator} used when we generate
+ * interfaces and implementations in separate packages.
+ *
+ * <p>
+ * {@link #publicOFG} and {@link #privateOFG} gives you access to
+ * {@code ObjectFactory}s in both packages, if you need to.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class DualObjectFactoryGenerator extends ObjectFactoryGenerator {
+    public final ObjectFactoryGenerator publicOFG;
+    public final ObjectFactoryGenerator privateOFG;
+
+    DualObjectFactoryGenerator(BeanGenerator outline, Model model, JPackage targetPackage) {
+        this.publicOFG = new PublicObjectFactoryGenerator(outline,model,targetPackage);
+        this.privateOFG = new PrivateObjectFactoryGenerator(outline,model,targetPackage);
+
+        // put the marker so that we can detect missing jaxb.properties
+        publicOFG.getObjectFactory().field(JMod.PRIVATE|JMod.STATIC|JMod.FINAL,
+                Void.class, ContextFactory.USE_JAXB_PROPERTIES, JExpr._null());
+    }
+
+    void populate(CElementInfo ei) {
+        publicOFG.populate(ei);
+        privateOFG.populate(ei);
+    }
+
+    void populate(ClassOutlineImpl cc) {
+        publicOFG.populate(cc);
+        privateOFG.populate(cc);
+    }
+
+    /**
+     * Returns the private version (which is what gets used at runtime.)
+     */
+    public JDefinedClass getObjectFactory() {
+        return privateOFG.getObjectFactory();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ElementOutlineImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ElementOutlineImpl.java
new file mode 100644
index 0000000..c664535
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ElementOutlineImpl.java
@@ -0,0 +1,93 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JInvocation;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.ElementOutline;
+
+/**
+ * {@link ElementOutline} implementation.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ElementOutlineImpl extends ElementOutline {
+    private final BeanGenerator parent;
+
+    public BeanGenerator parent() {
+        return parent;
+    }
+
+    /*package*/ ElementOutlineImpl(BeanGenerator parent, CElementInfo ei) {
+        super(ei,
+              parent.getClassFactory().createClass(
+                      parent.getContainer( ei.parent, Aspect.EXPOSED ), ei.shortName(), ei.getLocator() ));
+        this.parent = parent;
+        parent.elements.put(ei,this);
+
+        JCodeModel cm = parent.getCodeModel();
+
+        implClass._extends(
+            cm.ref(JAXBElement.class).narrow(
+                target.getContentInMemoryType().toType(parent,Aspect.EXPOSED).boxify()));
+
+        if(ei.hasClass()) {
+            JType implType = ei.getContentInMemoryType().toType(parent,Aspect.IMPLEMENTATION);
+            JExpression declaredType = JExpr.cast(cm.ref(Class.class),implType.boxify().dotclass()); // why do we have to cast?
+            JClass scope=null;
+            if(ei.getScope()!=null)
+                scope = parent.getClazz(ei.getScope()).implRef;
+            JExpression scopeClass = scope==null?JExpr._null():scope.dotclass();
+
+            // take this opportunity to generate a constructor in the element class
+            JMethod cons = implClass.constructor(JMod.PUBLIC);
+            cons.body().invoke("super")
+                .arg(implClass.field(JMod.PROTECTED|JMod.FINAL|JMod.STATIC,QName.class,"NAME",createQName(cm,ei.getElementName())))
+                .arg(declaredType)
+                .arg(scopeClass)
+                .arg(cons.param(implType,"value"));
+
+        }
+    }
+
+    /**
+     * Generates an expression that evaluates to "new QName(...)"
+     */
+    private JInvocation createQName(JCodeModel codeModel,QName name) {
+        return JExpr._new(codeModel.ref(QName.class)).arg(name.getNamespaceURI()).arg(name.getLocalPart());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ImplStructureStrategy.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ImplStructureStrategy.java
new file mode 100644
index 0000000..32562e4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ImplStructureStrategy.java
@@ -0,0 +1,216 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Use is subject to the license terms.
+ */
+package com.sun.tools.internal.xjc.generator.bean;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlEnum;
+import javax.xml.bind.annotation.XmlEnumValue;
+
+import com.sun.codemodel.internal.JClassContainer;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JDocComment;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlAccessorTypeWriter;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * Decides how a bean token is mapped to the generated classes.
+ *
+ * <p>
+ * The actual implementations of this interface is tightly coupled with
+ * the backend, but the front-end gets to choose which strategy to be used.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+@XmlEnum(Boolean.class)
+public enum ImplStructureStrategy {
+    /**
+     * Generates beans only. The simplest code generation.
+     */
+    @XmlEnumValue("true")
+    BEAN_ONLY() {
+        protected Result createClasses(Outline outline, CClassInfo bean) {
+            JClassContainer parent = outline.getContainer( bean.parent(), Aspect.EXPOSED );
+
+            JDefinedClass impl = outline.getClassFactory().createClass(
+                parent,
+                JMod.PUBLIC|(parent.isPackage()?0:JMod.STATIC)|(bean.isAbstract()?JMod.ABSTRACT:0),
+                bean.shortName, bean.getLocator() );
+            impl.annotate2(XmlAccessorTypeWriter.class).value(XmlAccessType.FIELD);
+
+            return new Result(impl,impl);
+        }
+
+        protected JPackage getPackage(JPackage pkg, Aspect a) {
+            return pkg;
+        }
+
+        protected MethodWriter createMethodWriter(final ClassOutlineImpl target) {
+            assert target.ref==target.implClass;
+
+            return new MethodWriter(target) {
+                private final JDefinedClass impl = target.implClass;
+
+                private JMethod implMethod;
+
+                public JVar addParameter(JType type, String name) {
+                    return implMethod.param(type,name);
+                }
+
+                public JMethod declareMethod(JType returnType, String methodName) {
+                    implMethod = impl.method( JMod.PUBLIC, returnType, methodName );
+                    return implMethod;
+                }
+
+                public JDocComment javadoc() {
+                    return implMethod.javadoc();
+                }
+            };
+        }
+
+        protected void _extends(ClassOutlineImpl derived, ClassOutlineImpl base) {
+            derived.implClass._extends(base.implRef);
+        }
+    },
+
+    /**
+     * Generates the interfaces to describe beans (content interfaces)
+     * and then the beans themselves in a hidden impl package.
+     *
+     * Similar to JAXB 1.0.
+     */
+    @XmlEnumValue("false")
+    INTF_AND_IMPL() {
+        protected Result createClasses( Outline outline, CClassInfo bean ) {
+            JClassContainer parent = outline.getContainer( bean.parent(), Aspect.EXPOSED );
+
+            JDefinedClass intf = outline.getClassFactory().createInterface(
+                parent, bean.shortName, bean.getLocator() );
+
+            parent = outline.getContainer(bean.parent(), Aspect.IMPLEMENTATION);
+            JDefinedClass impl = outline.getClassFactory().createClass(
+                parent,
+                JMod.PUBLIC|(parent.isPackage()?0:JMod.STATIC)|(bean.isAbstract()?JMod.ABSTRACT:0),
+                bean.shortName+"Impl", bean.getLocator() );
+            impl.annotate2(XmlAccessorTypeWriter.class).value(XmlAccessType.FIELD);
+
+            impl._implements(intf);
+
+            return new Result(intf,impl);
+        }
+
+        protected JPackage getPackage(JPackage pkg, Aspect a) {
+            switch(a) {
+            case EXPOSED:
+                return pkg;
+            case IMPLEMENTATION:
+                return pkg.subPackage("impl");
+            default:
+                assert false;
+                throw new IllegalStateException();
+            }
+        }
+
+        protected MethodWriter createMethodWriter(final ClassOutlineImpl target) {
+            return new MethodWriter(target) {
+                private final JDefinedClass intf = target.ref;
+                private final JDefinedClass impl = target.implClass;
+
+                private JMethod intfMethod;
+                private JMethod implMethod;
+
+                public JVar addParameter(JType type, String name) {
+                    // TODO: do we still need to deal with the case where intf is null?
+                    if(intf!=null)
+                        intfMethod.param(type,name);
+                    return implMethod.param(type,name);
+                }
+
+                public JMethod declareMethod(JType returnType, String methodName) {
+                    if(intf!=null)
+                        intfMethod = intf.method( 0, returnType, methodName );
+                    implMethod = impl.method( JMod.PUBLIC, returnType, methodName );
+                    return implMethod;
+                }
+
+                public JDocComment javadoc() {
+                    if(intf!=null)
+                        return intfMethod.javadoc();
+                    else
+                        return implMethod.javadoc();
+                }
+            };
+        }
+
+        protected void _extends(ClassOutlineImpl derived, ClassOutlineImpl base) {
+            derived.implClass._extends(base.implRef);
+            derived.ref._implements(base.ref);
+        }
+    };
+
+
+    /**
+     * Creates class(es) for the given bean.
+     */
+    protected abstract Result createClasses( Outline outline, CClassInfo bean );
+
+    /**
+     * Gets the specified aspect of the given package.
+     */
+    protected abstract JPackage getPackage( JPackage pkg, Aspect a );
+
+    protected abstract MethodWriter createMethodWriter( ClassOutlineImpl target );
+
+    /**
+     * Sets up an inheritance relationship.
+     */
+    protected abstract void _extends( ClassOutlineImpl derived, ClassOutlineImpl base );
+
+    public static final class Result {
+        /**
+         * Corresponds to {@link Aspect#EXPOSED}
+         */
+        public final JDefinedClass exposed;
+        /**
+         * Corresponds to {@link Aspect#IMPLEMENTATION}
+         */
+        public final JDefinedClass implementation;
+
+        public Result(JDefinedClass exposed, JDefinedClass implementation) {
+            this.exposed = exposed;
+            this.implementation = implementation;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/MessageBundle.properties
new file mode 100644
index 0000000..1faab35
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/MessageBundle.properties
@@ -0,0 +1,19 @@
+METHOD_COLLISION = \
+	The "{0}" method is defined on both "{1}" and "{2}" and is causing a collision.
+
+ERR_UNUSABLE_NAME = \
+	Cannot derive a valid Java identifier from "{0}". Specify a customization to change the name.
+
+ERR_NAME_COLLISION = \
+	Type-safe enum has more than one values that share the same name "{0}". \
+	Use a typesafeEnumMemberName customization to resolve this conflict.
+
+ILLEGAL_CONSTRUCTOR_PARAM = \
+    Illegal constructor parameter {0}
+
+OBJECT_FACTORY_CONFLICT = \
+    Two declarations cause a collision in the ObjectFactory class.
+
+OBJECT_FACTORY_CONFLICT_RELATED = \
+    (Related to above error) This is the other declaration.   
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/Messages.java
new file mode 100644
index 0000000..e0ebad2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/Messages.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+enum Messages {
+    // AnnotationParser
+    METHOD_COLLISION, // 3 args
+    ERR_UNUSABLE_NAME, // 2 args
+    ERR_NAME_COLLISION, // 1 arg
+    ILLEGAL_CONSTRUCTOR_PARAM, // 1 arg
+    OBJECT_FACTORY_CONFLICT,    // 1 arg
+    OBJECT_FACTORY_CONFLICT_RELATED,
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getPackage().getName() + ".MessageBundle");
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/MethodWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/MethodWriter.java
new file mode 100644
index 0000000..20f2947
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/MethodWriter.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Use is subject to the license terms.
+ */
+package com.sun.tools.internal.xjc.generator.bean;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDocComment;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+
+/**
+ * The back-end may or may not generate the content interface
+ * separately from the implementation class. If so, a method
+ * needs to be declared on both the interface and the implementation class.
+ * <p>
+ * This class hides those details and allow callers to declare
+ * methods just once.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class MethodWriter {
+    protected final JCodeModel codeModel;
+
+    protected MethodWriter(ClassOutline context) {
+        this.codeModel = context.parent().getCodeModel();
+    }
+
+    /**
+     * Declares a method in both the interface and the implementation.
+     *
+     * @return
+     *      JMethod object that represents a newly declared method
+     *      on the implementation class.
+     */
+    public abstract JMethod declareMethod( JType returnType, String methodName );
+
+    public final JMethod declareMethod( Class returnType, String methodName ) {
+        return declareMethod( codeModel.ref(returnType), methodName );
+    }
+
+    /**
+     * To generate javadoc for the previously declared method, use this method
+     * to obtain a {@link JDocComment} object. This may return a value
+     * different from declareMethod().javadoc().
+     */
+    public abstract JDocComment javadoc();
+
+
+    /**
+     * Adds a parameter to the previously declared method.
+     *
+     * @return
+     *      JVar object that represents a newly added parameter
+     *      on the implementation class.
+     */
+    public abstract JVar addParameter( JType type, String name );
+
+    public final JVar addParameter( Class type, String name ) {
+        return addParameter( codeModel.ref(type), name );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ObjectFactoryGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ObjectFactoryGenerator.java
new file mode 100644
index 0000000..670e456
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ObjectFactoryGenerator.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+
+/**
+ * Generates <code>ObjectFactory</code> then wraps it and provides
+ * access to it.
+ *
+ * <p>
+ * The ObjectFactory contains
+ * factory methods for each schema derived content class
+ *
+ * @author
+ *      Ryan Shoemaker
+ */
+public abstract class ObjectFactoryGenerator {
+    /**
+     * Adds code for the given {@link CElementInfo} to ObjectFactory.
+     */
+    abstract void populate( CElementInfo ei );
+
+    /**
+     * Adds code that is relevant to a given {@link ClassOutlineImpl} to
+     * ObjectFactory.
+     */
+    abstract void populate( ClassOutlineImpl cc );
+
+    /**
+     * Returns a reference to the generated (public) ObjectFactory
+     */
+    public abstract JDefinedClass getObjectFactory();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ObjectFactoryGeneratorImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ObjectFactoryGeneratorImpl.java
new file mode 100644
index 0000000..fed8992
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/ObjectFactoryGeneratorImpl.java
@@ -0,0 +1,380 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JInvocation;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlElementDeclWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlRegistryWriter;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.Constructor;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+import com.sun.xml.internal.bind.v2.TODO;
+
+/**
+ * Generates <code>ObjectFactory</code> then wraps it and provides
+ * access to it.
+ *
+ * <p>
+ * The ObjectFactory contains
+ * factory methods for each schema derived content class
+ *
+ * @author
+ *      Ryan Shoemaker
+ */
+abstract class ObjectFactoryGeneratorImpl extends ObjectFactoryGenerator {
+
+    private final BeanGenerator outline;
+    private final Model model;
+    private final JCodeModel codeModel;
+    /**
+     * Ref to {@link Class}.
+     */
+    private final JClass classRef;
+
+    /**
+     * Reference to the generated ObjectFactory class.
+     */
+    private final JDefinedClass objectFactory;
+
+    /** map of qname to the QName constant field. */
+    private final HashMap<QName,JFieldVar> qnameMap = new HashMap<QName,JFieldVar>();
+
+    /**
+     * Names of the element factory methods that are created.
+     * Used to detect collisions.
+     *
+     * The value is used for reporting error locations.
+     */
+    private final Map<String,CElementInfo> elementFactoryNames = new HashMap<String,CElementInfo>();
+
+    /**
+     * Names of the value factory methods that are created.
+     * Used to detect collisions.
+     *
+     * The value is used for reporting error locations.
+     */
+    private final Map<String,ClassOutlineImpl> valueFactoryNames = new HashMap<String,ClassOutlineImpl>();
+
+    /**
+     * Returns a reference to the generated (public) ObjectFactory
+     */
+    public JDefinedClass getObjectFactory() {
+        return objectFactory;
+    }
+
+
+
+
+    public ObjectFactoryGeneratorImpl( BeanGenerator outline, Model model, JPackage targetPackage ) {
+        this.outline = outline;
+        this.model = model;
+        this.codeModel = this.model.codeModel;
+        this.classRef = codeModel.ref(Class.class);
+
+        // create the ObjectFactory class skeleton
+        objectFactory = this.outline.getClassFactory().createClass(
+                targetPackage, "ObjectFactory", null );
+        objectFactory.annotate2(XmlRegistryWriter.class);
+
+        // generate the default constructor
+        //
+        // m1 result:
+        //        public ObjectFactory() {}
+        JMethod m1 = objectFactory.constructor(JMod.PUBLIC);
+        m1.javadoc().append("Create a new ObjectFactory that can be used to " +
+                         "create new instances of schema derived classes " +
+                         "for package: " + targetPackage.name());
+
+        // add some class javadoc
+        objectFactory.javadoc().append(
+            "This object contains factory methods for each \n" +
+            "Java content interface and Java element interface \n" +
+            "generated in the " + targetPackage.name() + " package. \n" +
+            "<p>An ObjectFactory allows you to programatically \n" +
+            "construct new instances of the Java representation \n" +
+            "for XML content. The Java representation of XML \n" +
+            "content can consist of schema derived interfaces \n" +
+            "and classes representing the binding of schema \n" +
+            "type definitions, element declarations and model \n" +
+            "groups.  Factory methods for each of these are \n" +
+            "provided in this class." );
+
+    }
+
+    /**
+     * Adds code for the given {@link CElementInfo} to ObjectFactory.
+     */
+    protected final void populate( CElementInfo ei, Aspect impl, Aspect exposed ) {
+        JType exposedElementType = ei.toType(outline,exposed);
+        JType exposedType = ei.getContentInMemoryType().toType(outline,exposed);
+        JType implType = ei.getContentInMemoryType().toType(outline,impl);
+        String namespaceURI = ei.getElementName().getNamespaceURI();
+        String localPart = ei.getElementName().getLocalPart();
+
+        JClass scope=null;
+        if(ei.getScope()!=null)
+            scope = outline.getClazz(ei.getScope()).implRef;
+
+
+        JMethod m;
+
+        if(ei.isAbstract()) {
+            // TODO: see the "Abstract elements and mighty IXmlElement" e-mail
+            // that I sent to jaxb-tech
+            TODO.checkSpec();
+        }
+
+        {// collision check
+            CElementInfo existing = elementFactoryNames.put(ei.getSqueezedName(),ei);
+            if( existing!=null ) {
+                outline.getErrorReceiver().error(existing.getLocator(),
+                    Messages.OBJECT_FACTORY_CONFLICT.format(ei.getSqueezedName()));
+                outline.getErrorReceiver().error(ei.getLocator(),
+                    Messages.OBJECT_FACTORY_CONFLICT_RELATED.format());
+                return;
+            }
+        }
+
+        // no arg constructor
+        // [RESULT] if the element doesn't have its own class, something like:
+        //
+        //        @XmlElementMapping(uri = "", name = "foo")
+        //        public JAXBElement<Foo> createFoo( Foo value ) {
+        //            return new JAXBElement<Foo>(
+        //                new QName("","foo"),(Class)FooImpl.class,scope,(FooImpl)value);
+        //        }
+        //        NOTE: when we generate value classes Foo==FooImpl
+        //
+        // [RESULT] otherwise
+        //
+        //        @XmlElementMapping(uri = "", name = "foo")
+        //        public Foo createFoo( FooType value ) {
+        //            return new Foo((FooTypeImpl)value);
+        //        }
+        //        NOTE: when we generate value classes FooType==FooTypeImpl
+        //
+        // to deal with
+        //  new JAXBElement<List<String>>( ..., List.class, ... );
+        // we sometimes have to produce (Class)List.class instead of just List.class
+
+        m = objectFactory.method( JMod.PUBLIC, exposedElementType, "create" + ei.getSqueezedName() );
+        JVar $value = m.param(exposedType,"value");
+
+        JExpression declaredType;
+        if(implType.boxify().isParameterized() || !exposedType.equals(implType))
+            declaredType = JExpr.cast(classRef,implType.boxify().dotclass());
+        else
+            declaredType = implType.boxify().dotclass();
+        JExpression scopeClass = scope==null?JExpr._null():scope.dotclass();
+
+        // build up the return extpression
+        JInvocation exp = JExpr._new(exposedElementType);
+        if(!ei.hasClass()) {
+            exp.arg(getQNameInvocation(ei));
+            exp.arg(declaredType);
+            exp.arg(scopeClass);
+        }
+        if(implType==exposedType)
+            exp.arg($value);
+        else
+            exp.arg(JExpr.cast(implType,$value));
+
+        m.body()._return( exp );
+
+        m.javadoc()
+            .append("Create an instance of ")
+            .append(exposedElementType)
+            .append("}");
+
+        XmlElementDeclWriter xemw = m.annotate2(XmlElementDeclWriter.class);
+        xemw.namespace(namespaceURI).name(localPart);
+        if(scope!=null)
+            xemw.scope(scope);
+
+        if(ei.getSubstitutionHead()!=null) {
+            QName n = ei.getSubstitutionHead().getElementName();
+            xemw.substitutionHeadNamespace(n.getNamespaceURI());
+            xemw.substitutionHeadName(n.getLocalPart());
+        }
+
+        if(ei.getDefaultValue()!=null)
+            xemw.defaultValue(ei.getDefaultValue());
+
+        // if the element is adapter, put that annotation on the factory method
+        outline.generateAdapterIfNecessary(ei.getProperty(),m);
+    }
+
+    /**
+     * return a JFieldVar that represents the QName field for the given information.
+     *
+     * if it doesn't exist, create a static field in the class and store a new JFieldVar.
+     */
+    private JExpression getQNameInvocation(CElementInfo ei) {
+        QName name = ei.getElementName();
+        if(qnameMap.containsKey(name)) {
+            return qnameMap.get(name);
+        }
+
+        if(qnameMap.size()>1024)
+            // stop gap measure to avoid 'code too large' error in javac.
+            return createQName(name);
+
+        // [RESULT]
+        // private static final QName _XYZ_NAME = new QName("uri", "local");
+        JFieldVar qnameField = objectFactory.field(
+            JMod.PRIVATE | JMod.STATIC | JMod.FINAL,
+            QName.class,
+            '_' + ei.getSqueezedName() + "_QNAME", createQName(name));
+
+        qnameMap.put(name, qnameField);
+
+        return qnameField;
+    }
+
+    /**
+     * Generates an expression that evaluates to "new QName(...)"
+     */
+    private JInvocation createQName(QName name) {
+        return JExpr._new(codeModel.ref(QName.class)).arg(name.getNamespaceURI()).arg(name.getLocalPart());
+    }
+
+    protected final void populate( ClassOutlineImpl cc, JClass sigType ) {
+        // add static factory method for this class to JAXBContext.
+        //
+        // generate methods like:
+        //     public static final SIGTYPE createFoo() {
+        //         return new FooImpl();
+        //     }
+
+        if(!cc.target.isAbstract()) {
+            JMethod m = objectFactory.method(
+                JMod.PUBLIC, sigType, "create" + cc.target.getSqueezedName() );
+            m.body()._return( JExpr._new(cc.implRef) );
+
+            // add some jdoc to avoid javadoc warnings in jdk1.4
+            m.javadoc()
+                .append("Create an instance of ")
+                .append(cc.ref);
+        }
+
+
+        // add static factory methods for all the other constructors.
+        Collection<? extends Constructor> consl = cc.target.getConstructors();
+        if(consl.size()!=0) {
+            // if we are going to add constructors with parameters,
+            // first we need to have a default constructor.
+            cc.implClass.constructor(JMod.PUBLIC);
+        }
+
+        {// collision check
+            String name = cc.target.getSqueezedName();
+            ClassOutlineImpl existing = valueFactoryNames.put(name,cc);
+            if( existing!=null ) {
+                outline.getErrorReceiver().error(existing.target.getLocator(),
+                    Messages.OBJECT_FACTORY_CONFLICT.format(name));
+                outline.getErrorReceiver().error(cc.target.getLocator(),
+                    Messages.OBJECT_FACTORY_CONFLICT_RELATED.format());
+                return;
+            }
+        }
+
+        for( Constructor cons : consl ) {
+            // method on ObjectFactory
+            // [RESULT]
+            // Foo createFoo( T1 a, T2 b, T3 c, ... ) throws JAXBException {
+            //    return new FooImpl(a,b,c,...);
+            // }
+            JMethod m = objectFactory.method( JMod.PUBLIC,
+                cc.ref, "create" + cc.target.getSqueezedName() );
+            JInvocation inv = JExpr._new(cc.implRef);
+            m.body()._return(inv);
+
+            // let's not throw this exception.
+            // m._throws(codeModel.ref(JAXBException.class));
+
+            // add some jdoc to avoid javadoc warnings in jdk1.4
+            m.javadoc()
+                .append( "Create an instance of " )
+                .append( cc.ref )
+                .addThrows(JAXBException.class).append("if an error occurs");
+
+            // constructor
+            // [RESULT]
+            // FooImpl( T1 a, T2 b, T3 c, ... ) {
+            // }
+            JMethod c = cc.implClass.constructor(JMod.PUBLIC);
+
+            for( String fieldName : cons.fields ) {
+                CPropertyInfo field = cc.target.getProperty(fieldName);
+                if(field==null) {
+                    outline.getErrorReceiver().error(cc.target.getLocator(),
+                        Messages.ILLEGAL_CONSTRUCTOR_PARAM.format(fieldName));
+                    continue;
+                }
+
+                fieldName = camelize(fieldName);
+
+                FieldOutline fo = outline.getField(field);
+                FieldAccessor accessor = fo.create(JExpr._this());
+
+                // declare a parameter on this factory method and set
+                // it to the field
+                inv.arg(m.param( fo.getRawType(), fieldName ));
+
+                JVar $var = c.param( fo.getRawType(), fieldName );
+                accessor.fromRawValue(c.body(),'_'+fieldName,$var);
+            }
+        }
+    }
+
+
+    /** Change the first character to the lower case. */
+    private static String camelize( String s ) {
+        return Character.toLowerCase(s.charAt(0)) + s.substring(1);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PackageOutlineImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PackageOutlineImpl.java
new file mode 100644
index 0000000..6c2cc76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PackageOutlineImpl.java
@@ -0,0 +1,252 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.bind.annotation.XmlSchema;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlSchemaWriter;
+import com.sun.tools.internal.xjc.model.CAttributePropertyInfo;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CPropertyVisitor;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.tools.internal.xjc.model.CValuePropertyInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.outline.PackageOutline;
+
+/**
+ * {@link PackageOutline} enhanced with schema2java specific
+ * information.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class PackageOutlineImpl implements PackageOutline {
+    private final Model _model;
+    private final JPackage _package;
+    private final ObjectFactoryGenerator objectFactoryGenerator;
+
+    /*package*/ final Set<ClassOutlineImpl> classes = new HashSet<ClassOutlineImpl>();
+    private final Set<ClassOutlineImpl> classesView = Collections.unmodifiableSet(classes);
+
+    private String mostUsedNamespaceURI;
+    private XmlNsForm elementFormDefault;
+
+    /**
+     * The namespace URI most commonly used in classes in this package.
+     * This should be used as the namespace URI for {@link XmlSchema#namespace()}.
+     *
+     * <p>
+     * Null if no default
+     *
+     * @see #calcDefaultValues().
+     */
+    public String getMostUsedNamespaceURI() {
+        return mostUsedNamespaceURI;
+    }
+
+    /**
+     * The element form default for this package.
+     * <p>
+     * The value is computed by examining what would yield the smallest generated code.
+     */
+    public XmlNsForm getElementFormDefault() {
+        assert elementFormDefault!=null;
+        return elementFormDefault;
+    }
+
+    public JPackage _package() {
+        return _package;
+    }
+
+    public ObjectFactoryGenerator objectFactoryGenerator() {
+        return objectFactoryGenerator;
+    }
+
+    public Set<ClassOutlineImpl> getClasses() {
+        return classesView;
+    }
+
+    public JDefinedClass objectFactory() {
+        return objectFactoryGenerator.getObjectFactory();
+    }
+
+    protected PackageOutlineImpl( BeanGenerator outline, Model model, JPackage _pkg ) {
+        this._model = model;
+        this._package = _pkg;
+        switch(model.strategy) {
+        case BEAN_ONLY:
+            objectFactoryGenerator = new PublicObjectFactoryGenerator(outline,model,_pkg);
+            break;
+        case INTF_AND_IMPL:
+            objectFactoryGenerator = new DualObjectFactoryGenerator(outline,model,_pkg);
+            break;
+        default:
+            throw new IllegalStateException();
+        }
+    }
+
+    /**
+     * Compute the most common namespace URI in this package
+     * (to put into {@link XmlSchema#namespace()} and what value
+     * we should put into {@link XmlSchema#elementFormDefault()}.
+     *
+     * This method is called after {@link #classes} field is filled up.
+     */
+    public void calcDefaultValues() {
+        // short-circuit if xjc was told not to generate package level annotations in
+        // package-info.java
+        if(!_model.isPackageLevelAnnotations()) {
+            mostUsedNamespaceURI = "";
+            elementFormDefault = XmlNsForm.UNQUALIFIED;
+            return;
+        }
+
+        // used to visit properties
+        CPropertyVisitor<Void> propVisitor = new CPropertyVisitor<Void>() {
+            public Void onElement(CElementPropertyInfo p) {
+                for (CTypeRef tr : p.getTypes()) {
+                    countURI(propUriCountMap, tr.getTagName());
+                }
+                return null;
+            }
+
+            public Void onReference(CReferencePropertyInfo p) {
+                for (CElement e : p.getElements()) {
+                    countURI(propUriCountMap, e.getElementName());
+                }
+                return null;
+            }
+
+            public Void onAttribute(CAttributePropertyInfo p) {
+                return null;
+            }
+
+            public Void onValue(CValuePropertyInfo p) {
+                return null;
+            }
+        };
+
+
+        for (ClassOutlineImpl co : classes) {
+            CClassInfo ci = co.target;
+            countURI(uriCountMap, ci.getTypeName());
+            countURI(uriCountMap, ci.getElementName());
+
+            for( CPropertyInfo p : ci.getProperties() )
+                p.accept(propVisitor);
+        }
+        mostUsedNamespaceURI = getMostUsedURI(uriCountMap);
+        elementFormDefault = getFormDefault();
+
+        // generate package-info.java
+        // we won't get this far if the user specified -npa
+        if(!mostUsedNamespaceURI.equals("") || elementFormDefault==XmlNsForm.QUALIFIED) {
+            XmlSchemaWriter w = _package.annotate2(XmlSchemaWriter.class);
+            if(!mostUsedNamespaceURI.equals(""))
+                w.namespace(mostUsedNamespaceURI);
+            if(elementFormDefault==XmlNsForm.QUALIFIED)
+                w.elementFormDefault(elementFormDefault);
+        }
+    }
+
+    // Map to keep track of how often each type or element uri is used in this package
+    // mostly used to calculate mostUsedNamespaceURI
+    private HashMap<String, Integer> uriCountMap = new HashMap<String, Integer>();
+
+    // Map to keep track of how often each property uri is used in this package
+    // used to calculate elementFormDefault
+    private HashMap<String, Integer> propUriCountMap = new HashMap<String, Integer>();
+
+    /**
+     * pull the uri out of the specified QName and keep track of it in the
+     * specified hash map
+     *
+     * @param qname
+     */
+    private void countURI(HashMap<String, Integer> map, QName qname) {
+        if (qname == null) return;
+
+        String uri = qname.getNamespaceURI();
+
+        if (map.containsKey(uri)) {
+            map.put(uri, map.get(uri) + 1);
+        } else {
+            map.put(uri, 1);
+        }
+    }
+
+    /**
+     * Iterate through the hash map looking for the namespace used
+     * most frequently.  Ties are arbitrarily broken by the order
+     * in which the map keys are iterated over.
+     */
+    private String getMostUsedURI(HashMap<String, Integer> map) {
+        String mostPopular = null;
+        int count = 0;
+
+        for (Map.Entry<String,Integer> e : map.entrySet()) {
+            String uri = e.getKey();
+            int uriCount = e.getValue();
+            if (mostPopular == null) {
+                mostPopular = uri;
+                count = uriCount;
+            } else {
+                if (uriCount > count) {
+                    mostPopular = uri;
+                    count = uriCount;
+                }
+            }
+        }
+
+        if (mostPopular == null) return "";
+        return mostPopular;
+    }
+
+    /**
+     * Calculate the element form defaulting.
+     *
+     * Compare the most frequently used property URI to the most frequently used
+     * element/type URI.  If they match, then return QUALIFIED
+     */
+    private XmlNsForm getFormDefault() {
+        if (getMostUsedURI(propUriCountMap).equals("")) return XmlNsForm.UNQUALIFIED;
+        else return XmlNsForm.QUALIFIED;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PrivateObjectFactoryGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PrivateObjectFactoryGenerator.java
new file mode 100644
index 0000000..6f0584c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PrivateObjectFactoryGenerator.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import javax.xml.bind.JAXBContext;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.fmt.JPropertyFile;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.runtime.JAXBContextFactory;
+
+/**
+ * Generates private ObjectFactory.
+ *
+ * <p>
+ * This class also puts a copy of {@link JAXBContextFactory}
+ * to the impl package.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class PrivateObjectFactoryGenerator extends ObjectFactoryGeneratorImpl {
+    public PrivateObjectFactoryGenerator(BeanGenerator outline, Model model, JPackage targetPackage) {
+        super(outline, model, targetPackage.subPackage("impl"));
+
+        JPackage implPkg = targetPackage.subPackage("impl");
+
+        // put JAXBContextFactory into the impl package
+        JClass factory = outline.generateStaticClass(JAXBContextFactory.class,implPkg);
+
+        // and then put jaxb.properties to point to it
+        JPropertyFile jaxbProperties = new JPropertyFile("jaxb.properties");
+        targetPackage.addResourceFile(jaxbProperties);
+        jaxbProperties.add(
+            JAXBContext.JAXB_CONTEXT_FACTORY,
+            factory.fullName());
+    }
+
+    void populate(CElementInfo ei) {
+        populate(ei,Aspect.IMPLEMENTATION,Aspect.IMPLEMENTATION);
+    }
+
+    void populate(ClassOutlineImpl cc) {
+        populate(cc,cc.implRef);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PublicObjectFactoryGenerator.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PublicObjectFactoryGenerator.java
new file mode 100644
index 0000000..2f75af8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/PublicObjectFactoryGenerator.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean;
+
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.outline.Aspect;
+
+/**
+ * Generates public ObjectFactory.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class PublicObjectFactoryGenerator extends ObjectFactoryGeneratorImpl {
+    public PublicObjectFactoryGenerator(BeanGenerator outline, Model model, JPackage targetPackage) {
+        super(outline, model, targetPackage);
+    }
+
+    void populate(CElementInfo ei) {
+        populate(ei,Aspect.IMPLEMENTATION,Aspect.EXPOSED);
+    }
+
+    void populate(ClassOutlineImpl cc) {
+        populate(cc,cc.ref);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractField.java
new file mode 100644
index 0000000..21c8e50
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractField.java
@@ -0,0 +1,459 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.List;
+
+import javax.xml.bind.annotation.W3CDomHandler;
+import javax.xml.bind.annotation.XmlList;
+import javax.xml.bind.annotation.XmlMixed;
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.bind.annotation.XmlValue;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JAnnotatable;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlAnyElementWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlAttributeWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlElementRefWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlElementRefsWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlElementWriter;
+import com.sun.tools.internal.xjc.generator.annotation.spec.XmlElementsWriter;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CAttributePropertyInfo;
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.tools.internal.xjc.model.CValuePropertyInfo;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import static com.sun.tools.internal.xjc.outline.Aspect.IMPLEMENTATION;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+import com.sun.tools.internal.xjc.reader.TypeUtil;
+import com.sun.xml.internal.bind.v2.TODO;
+
+/**
+ * Useful base class for implementing {@link FieldOutline}.
+ *
+ * <p>
+ * This class just provides a few utility methods and keep some
+ * important variables so that they can be readily accessed any time.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+abstract class AbstractField implements FieldOutline {
+
+    protected final ClassOutlineImpl outline;
+
+    protected final CPropertyInfo prop;
+
+    protected final JCodeModel codeModel;
+
+    /**
+     * The type of this field, which can hold all the possible types.
+     */
+    protected final JType implType;
+
+    /**
+     * The publicly visible type of this field.
+     * If we are generating value classes implType==exposedType.
+     */
+    protected final JType exposedType;
+
+    protected AbstractField( ClassOutlineImpl outline, CPropertyInfo prop ) {
+        this.outline = outline;
+        this.prop = prop;
+        this.codeModel = outline.parent().getCodeModel();
+        this.implType = getType(IMPLEMENTATION);
+        this.exposedType = getType(Aspect.EXPOSED);
+    }
+
+    public final ClassOutline parent() {
+        return outline;
+    }
+
+    public final CPropertyInfo getPropertyInfo() {
+        return prop;
+    }
+
+
+    /**
+     * Annotate the field according to the recipes given as {@link CPropertyInfo}.
+     */
+    protected void annotate( JAnnotatable field ) {
+
+        assert(field!=null);
+
+        /*
+        TODO: consider moving this logic to somewhere else
+        so that it can be better shared, for how a field gets
+        annotated doesn't really depend on how we generate accessors.
+
+        so perhaps we should separate those two.
+        */
+
+        // TODO: consider a visitor
+        if (prop instanceof CAttributePropertyInfo) {
+            annotateAttribute(field);
+        } else if (prop instanceof CElementPropertyInfo) {
+            annotateElement(field);
+        } else if (prop instanceof CValuePropertyInfo) {
+            field.annotate(XmlValue.class);
+        } else if (prop instanceof CReferencePropertyInfo) {
+            annotateReference(field);
+        }
+
+        outline.parent().generateAdapterIfNecessary(prop,field);
+    }
+
+    private void annotateReference(JAnnotatable field) {
+        CReferencePropertyInfo rp = (CReferencePropertyInfo) prop;
+
+        TODO.prototype();
+        // this is just a quick hack to get the basic test working
+
+        Collection<CElement> elements = rp.getElements();
+
+        XmlElementRefWriter refw;
+        if(elements.size()==1) {
+            refw = field.annotate2(XmlElementRefWriter.class);
+            CElement e = elements.iterator().next();
+            refw.name(e.getElementName().getLocalPart())
+                .namespace(e.getElementName().getNamespaceURI())
+                .type(e.getType().toType(outline.parent(),IMPLEMENTATION));
+        } else
+        if(elements.size()>1) {
+            XmlElementRefsWriter refsw = field.annotate2(XmlElementRefsWriter.class);
+            for( CElement e : elements ) {
+                refw = refsw.value();
+                refw.name(e.getElementName().getLocalPart())
+                    .namespace(e.getElementName().getNamespaceURI())
+                    .type(e.getType().toType(outline.parent(),IMPLEMENTATION));
+            }
+        }
+
+        if(rp.isMixed())
+            field.annotate(XmlMixed.class);
+
+        NClass dh = rp.getDOMHandler();
+        if(dh!=null) {
+            XmlAnyElementWriter xaew = field.annotate2(XmlAnyElementWriter.class);
+            xaew.lax(rp.getWildcard().allowTypedObject);
+
+            final JClass value = dh.toType(outline.parent(),IMPLEMENTATION);
+            if(!value.equals(codeModel.ref(W3CDomHandler.class))) {
+                xaew.value(value);
+            }
+        }
+
+    }
+
+    /**
+     * Annotate the element property 'field'
+     */
+    private void annotateElement(JAnnotatable field) {
+        CElementPropertyInfo ep = (CElementPropertyInfo) prop;
+        List<CTypeRef> types = ep.getTypes();
+
+        if(ep.isValueList()) {
+            field.annotate(XmlList.class);
+        }
+
+        assert ep.getXmlName()==null;
+//        if( eName!=null ) { // wrapper
+//            XmlElementWrapperWriter xcw = field.annotate2(XmlElementWrapperWriter.class);
+//            xcw.name(eName.getLocalPart())
+//               .namespace(eName.getNamespaceURI());
+//        }
+
+        if (types.size() == 1) {
+            CTypeRef t = types.get(0);
+            writeXmlElementAnnotation(field, t, resolve(t,IMPLEMENTATION), false);
+        } else {
+            for (CTypeRef t : types) {
+                // generate @XmlElements
+                writeXmlElementAnnotation(field, t, resolve(t,IMPLEMENTATION), true);
+            }
+            xesw = null;
+        }
+    }
+
+    /**
+     * Generate the simplest XmlElement annotation possible taking all semantic optimizations
+     * into account.  This method is essentially equivalent to:
+     *
+     *     xew.name(ctype.getTagName().getLocalPart())
+     *        .namespace(ctype.getTagName().getNamespaceURI())
+     *        .type(jtype)
+     *        .defaultValue(ctype.getDefaultValue());
+     *
+     * @param field
+     * @param ctype
+     * @param jtype
+     * @param checkWrapper true if the method might need to generate XmlElements
+     */
+    private void writeXmlElementAnnotation( JAnnotatable field, CTypeRef ctype, JType jtype,
+                                            boolean checkWrapper ) {
+
+        // lazily create - we don't know if we need to generate anything yet
+        XmlElementWriter xew = null;
+
+        // these values are used to determine how to optimize the generated annotation
+        XmlNsForm formDefault = parent()._package().getElementFormDefault();
+        String mostUsedURI = parent()._package().getMostUsedNamespaceURI();
+        String propName = prop.getName(false);
+
+        // generate the name property?
+        String generatedName = ctype.getTagName().getLocalPart();
+        if(!generatedName.equals(propName)) {
+            if(xew == null) xew = getXew(checkWrapper, field);
+            xew.name(generatedName);
+        }
+
+        // generate the namespace property?
+        String generatedNS = ctype.getTagName().getNamespaceURI();
+        if (((formDefault == XmlNsForm.QUALIFIED) && !generatedNS.equals(mostUsedURI)) ||
+                ((formDefault == XmlNsForm.UNQUALIFIED) && !generatedNS.equals(""))) {
+            if(xew == null) xew = getXew(checkWrapper, field);
+            xew.namespace(generatedNS);
+        }
+
+        // generate the required() property?
+        CElementPropertyInfo ep = (CElementPropertyInfo) prop;
+        if(ep.isRequired() && exposedType.isReference()) {
+            if(xew == null) xew = getXew(checkWrapper, field);
+            xew.required(true);
+        }
+
+        // generate the type property?
+
+        // I'm not too sure if this is the right place to handle this, but
+        // if the schema definition is requiring this element, we should point to a primitive type,
+        // not wrapper type (to correctly carry forward the required semantics.)
+        // if it's a collection, we can't use a primitive, however.
+        if(ep.isRequired() && !prop.isCollection())
+            jtype = jtype.unboxify();
+
+        // when generating code for 1.4, the runtime can't infer that ArrayList<Foo> derives
+        // from Collection<Foo> (because List isn't parameterized), so always expclitly
+        // generate @XmlElement(type=...)
+        if( !jtype.equals(exposedType) || (parent().parent().getModel().options.runtime14 && prop.isCollection())) {
+            if(xew == null) xew = getXew(checkWrapper, field);
+            xew.type(jtype);
+        }
+
+        // generate defaultValue property?
+        final String defaultValue = ctype.getDefaultValue();
+        if (defaultValue!=null) {
+            if(xew == null) xew = getXew(checkWrapper, field);
+            xew.defaultValue(defaultValue);
+        }
+
+        // generate the nillable property?
+        if (ctype.isNillable()) {
+            if(xew == null) xew = getXew(checkWrapper, field);
+            xew.nillable(true);
+        }
+    }
+
+    // ugly hack to lazily create
+    private XmlElementsWriter xesw = null;
+
+    private XmlElementWriter getXew(boolean checkWrapper, JAnnotatable field) {
+        XmlElementWriter xew;
+        if(checkWrapper) {
+            if(xesw==null) {
+                xesw = field.annotate2(XmlElementsWriter.class);
+            }
+            xew = xesw.value();
+        } else {
+            xew = field.annotate2(XmlElementWriter.class);
+        }
+        return xew;
+    }
+
+    /**
+     * Annotate the attribute property 'field'
+     */
+    private void annotateAttribute(JAnnotatable field) {
+        CAttributePropertyInfo ap = (CAttributePropertyInfo) prop;
+        QName attName = ap.getXmlName();
+
+        // [RESULT]
+        // @XmlAttribute(name="foo", required=true, namespace="bar://baz")
+        XmlAttributeWriter xaw = field.annotate2(XmlAttributeWriter.class);
+
+        final String generatedName = attName.getLocalPart();
+        final String generatedNS = attName.getNamespaceURI();
+
+        // generate name property?
+        if(!generatedName.equals(ap.getName(false))) {
+            xaw.name(generatedName);
+        }
+
+        // generate namespace property?
+        if(!generatedNS.equals("")) { // assume attributeFormDefault == unqualified
+            xaw.namespace(generatedNS);
+        }
+
+        // generate required property?
+        if(ap.isRequired()) {
+            xaw.required(true);
+        }
+    }
+
+    /**
+     * Useful base class for implementing {@link FieldAccessor}.
+     */
+    protected abstract class Accessor implements FieldAccessor {
+
+        /**
+         * Evaluates to the target object this accessor should access.
+         */
+        protected final JExpression $target;
+
+        protected Accessor( JExpression $target ) {
+            this.$target = $target;
+        }
+
+        public final FieldOutline owner() {
+            return AbstractField.this;
+        }
+
+        public final CPropertyInfo getPropertyInfo() {
+            return prop;
+        }
+    }
+
+
+//
+//
+//     utility methods
+//
+//
+
+    /**
+     * Generates the field declaration.
+     */
+    protected final JFieldVar generateField( JType type ) {
+        return outline.implClass.field( JMod.PROTECTED, type, prop.getName(false) );
+    }
+
+    /**
+     * Case from {@link #exposedType} to {@link #implType} if necessary.
+     */
+    protected final JExpression castToImplType( JExpression exp ) {
+        if(implType==exposedType)
+            return exp;
+        else
+            return JExpr.cast(implType,exp);
+    }
+
+    /**
+     * Compute the type of a {@link CPropertyInfo}
+     * @param aspect
+     */
+    protected JType getType(final Aspect aspect) {
+        if(prop.getAdapter()!=null)
+            return prop.getAdapter().customType.toType(outline.parent(),aspect);
+
+        final class TypeList extends ArrayList<JType> {
+            void add( CTypeInfo t ) {
+                add( t.getType().toType(outline.parent(),aspect) );
+                if(t instanceof CElementInfo) {
+                    // UGLY. element substitution is implemented in a way that
+                    // the derived elements are not assignable to base elements.
+                    // so when we compute the signature, we have to take derived types
+                    // into account
+                    add( ((CElementInfo)t).getSubstitutionMembers());
+                }
+            }
+
+            void add( Collection<? extends CTypeInfo> col ) {
+                for (CTypeInfo typeInfo : col)
+                    add(typeInfo);
+            }
+        }
+        TypeList r = new TypeList();
+        r.add(prop.ref());
+
+        JType t;
+        if(prop.baseType!=null)
+            t = prop.baseType;
+        else
+            t = TypeUtil.getCommonBaseType(codeModel,r);
+
+        // if item type is unboxable, convert t=Integer -> t=int
+        // the in-memory data structure can't have primitives directly,
+        // but this guarantees that items cannot legal hold null,
+        // which helps us improve the boundary signature between our
+        // data structure and user code
+        if(prop.isUnboxable())
+            t = t.unboxify();
+        return t;
+    }
+
+    /**
+     * Returns contents to be added to javadoc.
+     */
+    protected final List<Object> listPossibleTypes( CPropertyInfo prop ) {
+        List<Object> r = new ArrayList<Object>();
+        for( CTypeInfo tt : prop.ref() ) {
+            JType t = tt.getType().toType(outline.parent(),Aspect.EXPOSED);
+            if( t.isPrimitive() || t.isArray() )
+                r.add(t.fullName());
+            else {
+                r.add(t);
+                r.add("\n");
+            }
+        }
+
+        return r;
+    }
+
+    /**
+     * return the Java type for the given type reference in the model.
+     */
+    private JType resolve(CTypeRef typeRef,Aspect a) {
+        return outline.parent().resolve(typeRef,a);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractFieldWithVar.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractFieldWithVar.java
new file mode 100644
index 0000000..0e16b82
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractFieldWithVar.java
@@ -0,0 +1,109 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JFieldRef;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+
+/**
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+abstract class AbstractFieldWithVar extends AbstractField {
+
+    /**
+     * Field declaration of the actual list object that we use
+     * to store data.
+     */
+    private JFieldVar field;
+
+    /**
+     * Invoke {@link #createField()} after calling the
+     * constructor.
+     */
+    AbstractFieldWithVar( ClassOutlineImpl outline, CPropertyInfo prop ) {
+        super(outline,prop);
+    }
+
+    protected final void createField() {
+        field = outline.implClass.field( JMod.PROTECTED,
+            getFieldType(), prop.getName(false) );
+
+        annotate(field);
+    }
+
+    /**
+     * Gets the name of the getter method.
+     *
+     * <p>
+     * This encapsulation is necessary because sometimes we use
+     * {@code isXXXX} as the method name.
+     */
+    protected String getGetterMethod() {
+        return (getFieldType().boxify().getPrimitiveType()==codeModel.BOOLEAN?"is":"get")+prop.getName(true);
+    }
+
+    /**
+     * Returns the type used to store the value of the field in memory.
+     */
+    protected abstract JType getFieldType();
+
+    protected JFieldVar ref() { return field; }
+
+    public final JType getRawType() {
+        return exposedType;
+    }
+
+    protected abstract class Accessor extends AbstractField.Accessor {
+
+        protected Accessor(JExpression $target) {
+            super($target);
+            this.$ref = $target.ref(AbstractFieldWithVar.this.ref());
+        }
+
+        /**
+         * Reference to the field bound by the target object.
+         */
+        protected final JFieldRef $ref;
+
+        public final void toRawValue(JBlock block, JVar $var) {
+            block.assign($var,$target.invoke(getGetterMethod()));
+        }
+
+        public final void fromRawValue(JBlock block, String uniqueName, JExpression $var) {
+            block.invoke($target,("set"+prop.getName(true))).arg($var);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractListField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractListField.java
new file mode 100644
index 0000000..086eb42
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/AbstractListField.java
@@ -0,0 +1,225 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import java.util.List;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JFieldRef;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JOp;
+import com.sun.codemodel.internal.JPrimitiveType;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+
+/**
+ * Common code for property renderer that generates a List as
+ * its underlying data structure.
+ *
+ * <p>
+ * For performance reaons, the actual list object used to store
+ * data is lazily created.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+abstract class AbstractListField extends AbstractField {
+    /** The field that stores the list. */
+    protected JFieldVar field;
+
+    /**
+     * a method that lazily initializes a List.
+     * Lazily created.
+     *
+     * [RESULT]
+     * List _getFoo() {
+     *   if(field==null)
+     *     field = create new list;
+     *   return field;
+     * }
+     */
+    private JMethod internalGetter;
+
+    /**
+     * If this collection property is a collection of a primitive type,
+     * this variable refers to that primitive type.
+     * Otherwise null.
+     */
+    protected final JPrimitiveType primitiveType;
+
+    protected final JClass listT = codeModel.ref(List.class).narrow(exposedType.boxify());
+
+    /**
+     * True to create a new instance of List eagerly in the constructor.
+     * False otherwise.
+     *
+     * <p>
+     * Setting it to true makes the generated code slower (as more list instances need to be
+     * allocated), but it works correctly if the user specifies the custom type of a list.
+     */
+    private final boolean eagerInstanciation;
+
+    /**
+     * Call {@link #generate()} method right after this.
+     */
+    protected AbstractListField(ClassOutlineImpl outline, CPropertyInfo prop, boolean eagerInstanciation) {
+        super(outline,prop);
+        this.eagerInstanciation = eagerInstanciation;
+
+        if( implType instanceof JPrimitiveType ) {
+            // primitive types don't have this tricky distinction
+            assert implType==exposedType;
+            primitiveType = (JPrimitiveType)implType;
+        } else
+            primitiveType = null;
+    }
+
+    protected final void generate() {
+
+        // for the collectionType customization to take effect, the field needs to be strongly typed,
+        // not just List<Foo>.
+        field = outline.implClass.field( JMod.PROTECTED, listT, prop.getName(false) );
+        if(eagerInstanciation)
+            field.init(newCoreList());
+
+        annotate(field);
+
+        // generate the rest of accessors
+        generateAccessors();
+    }
+
+    private void generateInternalGetter() {
+        internalGetter = outline.implClass.method(JMod.PROTECTED,listT,"_get"+prop.getName(true));
+        if(!eagerInstanciation) {
+            // if eagerly instanciated, the field can't be null
+            fixNullRef(internalGetter.body());
+        }
+        internalGetter.body()._return(field);
+    }
+
+    /**
+     * Generates statement(s) so that the successive {@link Accessor#ref(boolean)} with
+     * true will always return a non-null list.
+     *
+     * This is useful to avoid generating redundant internal getter.
+     */
+    protected final void fixNullRef(JBlock block) {
+        block._if(field.eq(JExpr._null()))._then()
+            .assign(field,newCoreList());
+    }
+
+    public final JType getRawType() {
+        return codeModel.ref(List.class).narrow(exposedType.boxify());
+    }
+
+    private JExpression newCoreList() {
+        return JExpr._new(getCoreListType());
+    }
+
+    /**
+     * Concrete class that implements the List interface.
+     * Used as the actual data storage.
+     */
+    protected abstract JClass getCoreListType();
+
+
+    /** Generates accessor methods. */
+    protected abstract void generateAccessors();
+
+
+
+    /**
+     *
+     *
+     * @author
+     *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+     */
+    protected abstract class Accessor extends AbstractField.Accessor {
+
+        /**
+         * Reference to the {@link AbstractListField#field}
+         * of the target object.
+         */
+        protected final JFieldRef field;
+
+        protected Accessor( JExpression $target ) {
+            super($target);
+            field = $target.ref(AbstractListField.this.field);
+        }
+
+
+        protected final JExpression unbox( JExpression exp ) {
+            if(primitiveType==null) return exp;
+            else                    return primitiveType.unwrap(exp);
+        }
+        protected final JExpression box( JExpression exp ) {
+            if(primitiveType==null) return exp;
+            else                    return primitiveType.wrap(exp);
+        }
+
+        /**
+         * Returns a reference to the List field that stores the data.
+         * <p>
+         * Using this method hides the fact that the list is lazily
+         * created.
+         *
+         * @param canBeNull
+         *      if true, the returned expression may be null (this is
+         *      when the list is still not constructed.) This could be
+         *      useful when the caller can deal with null more efficiently.
+         *      When the list is null, it should be treated as if the list
+         *      is empty.
+         *
+         *      if false, the returned expression will never be null.
+         *      This is the behavior users would see.
+         */
+        protected final JExpression ref(boolean canBeNull) {
+            if(canBeNull)
+                return field;
+            if(internalGetter==null)
+                generateInternalGetter();
+            return $target.invoke(internalGetter);
+        }
+
+        public JExpression count() {
+            return JOp.cond( field.eq(JExpr._null()), JExpr.lit(0), field.invoke("size") );
+        }
+
+        public void unsetValues( JBlock body ) {
+            body.assign(field,JExpr._null());
+        }
+        public JExpression hasSetValue() {
+            return field.ne(JExpr._null()).cand(field.invoke("isEmpty").not());
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ArrayField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ArrayField.java
new file mode 100644
index 0000000..095040b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ArrayField.java
@@ -0,0 +1,208 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JForLoop;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JOp;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.generator.bean.MethodWriter;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+
+/**
+ * Realizes a property as an "indexed property"
+ * as specified in the JAXB spec.
+ *
+ * <p>
+ * We will generate the following set of methods:
+ * <pre>
+ * T[] getX();
+ * T getX( int idx );
+ * void setX(T[] values);
+ * void setX( int idx, T value );
+ * </pre>
+ *
+ * We still use List as our back storage.
+ * This renderer also handles boxing/unboxing if
+ * T is a boxed type.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class ArrayField extends AbstractListField {
+
+    class Accessor extends AbstractListField.Accessor {
+        protected Accessor( JExpression $target ) {
+            super($target);
+        }
+
+        public void toRawValue(JBlock block, JVar $var) {
+            block.assign($var,codeModel.ref(Arrays.class).staticInvoke("asList").arg($target.invoke($getAll)));
+        }
+
+        public void fromRawValue(JBlock block, String uniqueName, JExpression $var) {
+            block.invoke($target,$setAll).arg($var.invoke("toArray").arg(JExpr.newArray(exposedType,$var.invoke("size"))));
+        }
+    }
+
+    private JMethod $setAll;
+
+    private JMethod $getAll;
+
+    ArrayField(ClassOutlineImpl context, CPropertyInfo prop) {
+        super(context,prop,false);
+        generate();
+    }
+
+    public void generateAccessors() {
+
+        MethodWriter writer = outline.createMethodWriter();
+        Accessor acc = create(JExpr._this());
+
+        JVar $idx,$value; JBlock body;
+        JType arrayType = exposedType.array();
+
+        // [RESULT] T[] getX() {
+        //     if( <var>==null )    return new T[0];
+        //     return (T[]) <var>.toArray(new T[<var>.size()]);
+        // }
+        $getAll = writer.declareMethod( exposedType.array(),"get"+prop.getName(true));
+        writer.javadoc().append(prop.javadoc);
+        body = $getAll.body();
+
+        body._if( acc.ref(true).eq(JExpr._null()) )._then()
+            ._return(JExpr.newArray(exposedType,0));
+
+        if(primitiveType==null) {
+            body._return(JExpr.cast(arrayType,
+                acc.ref(true).invoke("toArray").arg( JExpr.newArray(implType,acc.ref(true).invoke("size")) )));
+        } else {
+            // need to copy them manually to unbox values
+            // [RESULT]
+            // T[] r = new T[<ref>.size()];
+            // for( int i=0; i<r.length; i++ )
+            //     r[i] = unbox(<ref>.get(i));
+            JVar $r = body.decl(exposedType.array(),"r",JExpr.newArray(exposedType, acc.ref(true).invoke("size")));
+            JForLoop loop = body._for();
+            JVar $i = loop.init(codeModel.INT,"__i",JExpr.lit(0));
+            loop.test($i.lt($r.ref("length")));
+            loop.update($i.incr());
+            loop.body().assign( $r.component($i),
+                primitiveType.unwrap(acc.ref(true).invoke("get").arg($i)) );
+            body._return($r);
+        }
+
+        List<Object> returnTypes = listPossibleTypes(prop);
+        writer.javadoc().addReturn().append("array of\n").append(returnTypes);
+
+        // [RESULT]
+        // ET getX(int idx) {
+        //     if( <var>==null )    throw new IndexOutOfBoundsException();
+        //     return unbox(<var>.get(idx));
+        // }
+        JMethod $get = writer.declareMethod(exposedType,"get"+prop.getName(true));
+        $idx = writer.addParameter(codeModel.INT,"idx");
+
+        $get.body()._if(acc.ref(true).eq(JExpr._null()))._then()
+            ._throw(JExpr._new(codeModel.ref(IndexOutOfBoundsException.class)));
+
+        writer.javadoc().append(prop.javadoc);
+        $get.body()._return(acc.unbox(acc.ref(true).invoke("get").arg($idx) ));
+
+        writer.javadoc().addReturn().append("one of\n").append(returnTypes);
+
+
+        // [RESULT] int getXLength() {
+        //     if( <var>==null )    throw new IndexOutOfBoundsException();
+        //     return <ref>.size();
+        // }
+        JMethod $getLength = writer.declareMethod(codeModel.INT,"get"+prop.getName(true)+"Length");
+        $getLength.body()._if(acc.ref(true).eq(JExpr._null()))._then()
+                ._return(JExpr.lit(0));
+        $getLength.body()._return(acc.ref(true).invoke("size"));
+
+
+        // [RESULT] void setX(ET[] values) {
+        //     clear();
+        //     int len = values.length;
+        //     for( int i=0; i<len; i++ )
+        //         <ref>.add(values[i]);
+        // }
+        $setAll = writer.declareMethod(
+            codeModel.VOID,
+            "set"+prop.getName(true));
+
+        writer.javadoc().append(prop.javadoc);
+
+        $value = writer.addParameter(exposedType.array(),"values");
+        $setAll.body().invoke(acc.ref(false),"clear");
+        JVar $len = $setAll.body().decl(codeModel.INT,"len", $value.ref("length"));
+        JForLoop _for = $setAll.body()._for();
+        JVar $i = _for.init( codeModel.INT, "i", JExpr.lit(0) );
+        _for.test( JOp.lt($i,$len) );
+        _for.update( $i.incr() );
+        _for.body().invoke(acc.ref(true),"add").arg(castToImplType(acc.box($value.component($i))));
+
+        writer.javadoc().addParam($value)
+            .append("allowed objects are\n")
+            .append(returnTypes);
+
+        // [RESULT] ET setX(int,ET)
+        JMethod $set = writer.declareMethod(
+            exposedType,
+            "set"+prop.getName(true));
+        $idx = writer.addParameter( codeModel.INT, "idx" );
+        $value = writer.addParameter( exposedType, "value" );
+
+        writer.javadoc().append(prop.javadoc);
+
+        body = $set.body();
+        body._return( acc.unbox(
+            acc.ref(true).invoke("set").arg($idx).arg(castToImplType(acc.box($value)))));
+
+        writer.javadoc().addParam($value)
+            .append("allowed object is\n")
+            .append(returnTypes);
+    }
+
+    protected JClass getCoreListType() {
+        return codeModel.ref(ArrayList.class).narrow(exposedType.boxify());
+    }
+
+    public Accessor create(JExpression targetObject) {
+        return new Accessor(targetObject);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ConstField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ConstField.java
new file mode 100644
index 0000000..8cc1892
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ConstField.java
@@ -0,0 +1,110 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JFieldVar;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JPrimitiveType;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+
+/**
+ * Realizes a property as a "public static final" property on the interface.
+ * This class can handle both boxed/unboxed types and both
+ * single/colllection.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class ConstField extends AbstractField {
+//    /**
+//     * Number of items in this property, when
+//     * {@link #isCollection}==true.
+//     */
+//    private final int count=1;
+
+    /** Generated constant property on the interface. */
+    private final JFieldVar $ref;
+
+    ConstField( ClassOutlineImpl outline, CPropertyInfo prop ) {
+        super(outline,prop);
+
+        // we only support value constraints for a single-value property.
+        assert !prop.isCollection();
+
+        JPrimitiveType ptype = implType.boxify().getPrimitiveType();
+
+        // generate the constant
+        JExpression defaultValue = null;
+        if(prop.defaultValue!=null)
+            defaultValue = prop.defaultValue.compute(outline.parent());
+
+        $ref = outline.ref.field(JMod.PUBLIC|JMod.STATIC|JMod.FINAL,
+            ptype!=null?ptype:implType, prop.getName(true), defaultValue );
+        $ref.javadoc().append(prop.javadoc);
+
+        annotate($ref);
+    }
+
+    public JType getRawType() {
+//        if( isCollection )      return getInfo().array();
+        return exposedType;
+    }
+
+
+    public FieldAccessor create(JExpression target) {
+        return new Accessor(target);
+    }
+
+    private class Accessor extends AbstractField.Accessor {
+
+        Accessor( JExpression $target ) {
+            super($target);
+        }
+
+        public void unsetValues( JBlock body ) {
+            ;   // can't unset values
+        }
+        public JExpression hasSetValue() {
+            return null;    // can't generate the isSet/unset methods
+        }
+        public void toRawValue(JBlock block, JVar $var) {
+            // TODO: rethink abstraction. Those constant fields
+            // don't have "access" to them.
+            throw new UnsupportedOperationException();
+        }
+
+        public void fromRawValue(JBlock block, String uniqueName, JExpression $var) {
+            throw new UnsupportedOperationException();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ConstFieldRenderer.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ConstFieldRenderer.java
new file mode 100644
index 0000000..1a4aa02
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/ConstFieldRenderer.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+/**
+ * {@link FieldRenderer} for possibly constant field.
+ *
+ * <p>
+ * Since we don't know if the constant can be actually generated until
+ * we get to the codemodel building phase, this renderer lazily
+ * determines if it wants to generate a constant field or a normal property.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ConstFieldRenderer implements FieldRenderer {
+
+    private final FieldRenderer fallback;
+
+    protected ConstFieldRenderer(FieldRenderer fallback) {
+        this.fallback = fallback;
+    }
+
+    public FieldOutline generate(ClassOutlineImpl outline, CPropertyInfo prop) {
+        if(prop.defaultValue.compute(outline.parent())==null)
+            return fallback.generate(outline,prop);
+        else
+            return new ConstField(outline,prop);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/DefaultFieldRenderer.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/DefaultFieldRenderer.java
new file mode 100644
index 0000000..c756faf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/DefaultFieldRenderer.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import java.util.ArrayList;
+
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+/**
+ * Default implementation of the FieldRendererFactory
+ * that faithfully implements the semantics demanded by the JAXB spec.
+ *
+ * <p>
+ * This class is just a facade --- it just determines which
+ * {@link FieldRenderer} to use and just delegate the work.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class DefaultFieldRenderer implements FieldRenderer {
+
+    private final FieldRendererFactory frf;
+
+    /**
+     * Use {@link FieldRendererFactory#getDefault()}.
+     */
+    DefaultFieldRenderer(FieldRendererFactory frf) {
+        this.frf = frf;
+    }
+
+    public DefaultFieldRenderer(FieldRendererFactory frf, FieldRenderer defaultCollectionFieldRenderer ) {
+        this.frf = frf;
+        this.defaultCollectionFieldRenderer = defaultCollectionFieldRenderer;
+    }
+
+    private FieldRenderer defaultCollectionFieldRenderer;
+
+
+    public FieldOutline generate(ClassOutlineImpl outline, CPropertyInfo prop) {
+        return decideRenderer(outline,prop).generate(outline,prop);
+    }
+
+    private FieldRenderer decideRenderer(ClassOutlineImpl outline,CPropertyInfo prop) {
+        if(!prop.isCollection()) {
+            // non-collection field
+
+            // TODO: check for bidning info for optionalPrimitiveType=boxed or
+            // noHasMethod=false and noDeletedMethod=false
+            if(prop.isUnboxable())
+                // this one uses a primitive type as much as possible
+                return frf.getRequiredUnboxed();
+            else
+                // otherwise use the default non-collection field
+                return frf.getSingle();
+        }
+
+        if( defaultCollectionFieldRenderer==null ) {
+            return frf.getList(outline.parent().getCodeModel().ref(ArrayList.class));
+        }
+
+        // this field is a collection field.
+        // use untyped list as the default. This is consistent
+        // to the JAXB spec.
+        return defaultCollectionFieldRenderer;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/FieldRenderer.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/FieldRenderer.java
new file mode 100644
index 0000000..7f13459
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/FieldRenderer.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+
+/**
+ * Abstract model of one field in a generated class.
+ *
+ * <p>
+ * Responsible for "realizing" a Java property by actually generating
+ * members(s) to store the property value and a set of methods
+ * to manipulate them.
+ *
+ * <p>
+ * Objects that implement this interface also encapsulates the
+ * <b>internal</b> access to the field.
+ *
+ * <p>
+ * For discussion of the model this interface is representing, see
+ * the "field meta model" design document.
+ *
+ * REVISIT:
+ *  refactor this to two interfaces that provide
+ *  (1) internal access and (2) external access.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface FieldRenderer {
+    /**
+     * Generates accesssors and fields for the given implementation
+     * class, then return {@link FieldOutline} for accessing
+     * the generated field.
+     */
+    public FieldOutline generate( ClassOutlineImpl context, CPropertyInfo prop );
+
+//    //
+//    // field renderers
+//    //
+//    public static final FieldRenderer DEFAULT
+//        = new DefaultFieldRenderer();
+//
+//    public static final FieldRenderer ARRAY
+//        = new GenericFieldRenderer(ArrayField.class);
+//
+//    public static final FieldRenderer REQUIRED_UNBOXED
+//        = new GenericFieldRenderer(UnboxedField.class);
+//
+//    public static final FieldRenderer SINGLE
+//        = new GenericFieldRenderer(SingleField.class);
+//
+//    public static final FieldRenderer SINGLE_PRIMITIVE_ACCESS
+//        = new GenericFieldRenderer(SinglePrimitiveAccessField.class);
+//
+//    public static final FieldRenderer JAXB_DEFAULT
+//        = new DefaultFieldRenderer();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/FieldRendererFactory.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/FieldRendererFactory.java
new file mode 100644
index 0000000..cd7423d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/FieldRendererFactory.java
@@ -0,0 +1,89 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.tools.internal.xjc.Options;
+import com.sun.codemodel.internal.JClass;
+
+/**
+ * Factory for {@link FieldRenderer}.
+ *
+ * <p>
+ * This class can be overridden by a plugin to change the code generation
+ * behavior of XJC. Note that such changes aren't composable; for a given
+ * schema compilation, only one instance of {@link FieldRendererFactory} is
+ * used.
+ *
+ * <p>
+ * See {@link Options#fieldRendererFactory}
+ *
+ * <p>
+ * To be more precise, since {@link FieldRenderer} is just a strategy pattern
+ * and by itself is stateless, the "factory methods" don't necessarily need
+ * to create new instances of {@link FieldRenderer} --- it can just return
+ * a set of pre-created instances.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldRendererFactory {
+
+    public FieldRenderer getDefault() {
+        return DEFAULT;
+    }
+    public FieldRenderer getArray() {
+        return ARRAY;
+    }
+    public FieldRenderer getRequiredUnboxed() {
+        return REQUIRED_UNBOXED;
+    }
+    public FieldRenderer getSingle() {
+        return SINGLE;
+    }
+    public FieldRenderer getSinglePrimitiveAccess() {
+        return SINGLE_PRIMITIVE_ACCESS;
+    }
+    public FieldRenderer getList(JClass coreList) {
+        return new UntypedListFieldRenderer(coreList);
+    }
+    public FieldRenderer getConst(FieldRenderer fallback) {
+        return new ConstFieldRenderer(fallback);
+    }
+
+    private final FieldRenderer DEFAULT
+        = new DefaultFieldRenderer(this);
+
+    private static final FieldRenderer ARRAY
+        = new GenericFieldRenderer(ArrayField.class);
+
+    private static final FieldRenderer REQUIRED_UNBOXED
+        = new GenericFieldRenderer(UnboxedField.class);
+
+    private static final FieldRenderer SINGLE
+        = new GenericFieldRenderer(SingleField.class);
+
+    private static final FieldRenderer SINGLE_PRIMITIVE_ACCESS
+        = new GenericFieldRenderer(SinglePrimitiveAccessField.class);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/GenericFieldRenderer.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/GenericFieldRenderer.java
new file mode 100644
index 0000000..1888eb8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/GenericFieldRenderer.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import java.lang.reflect.Constructor;
+import java.lang.reflect.InvocationTargetException;
+
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+/**
+ * Creates
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class GenericFieldRenderer implements FieldRenderer {
+    private Constructor constructor;
+
+    public GenericFieldRenderer( Class fieldClass ) {
+        try {
+            constructor = fieldClass.getDeclaredConstructor(new Class[]{ClassOutlineImpl.class,CPropertyInfo.class});
+        } catch (NoSuchMethodException e) {
+            throw new NoSuchMethodError(e.getMessage());
+        }
+    }
+
+    public FieldOutline generate(ClassOutlineImpl context, CPropertyInfo prop) {
+        try {
+            return (FieldOutline)constructor.newInstance(new Object[]{context,prop});
+        } catch (InstantiationException e) {
+            throw new InstantiationError(e.getMessage());
+        } catch (IllegalAccessException e) {
+            throw new IllegalAccessError(e.getMessage());
+        } catch (InvocationTargetException e) {
+            Throwable t = e.getTargetException();
+            if(t instanceof RuntimeException)
+                throw (RuntimeException)t;
+            if(t instanceof Error)
+                throw (Error)t;
+
+            // impossible
+            throw new AssertionError(t);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/IsSetField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/IsSetField.java
new file mode 100644
index 0000000..1630594
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/IsSetField.java
@@ -0,0 +1,123 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.generator.bean.MethodWriter;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+/**
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class IsSetField extends AbstractField {
+
+    private final FieldOutline core;
+
+    private final boolean generateUnSetMethod;
+    private final boolean generateIsSetMethod;
+
+    protected IsSetField( ClassOutlineImpl outline, CPropertyInfo prop,
+            FieldOutline core, boolean unsetMethod, boolean issetMethod ) {
+        super(outline,prop);
+        this.core = core;
+        this.generateIsSetMethod = issetMethod;
+        this.generateUnSetMethod = unsetMethod;
+
+        generate(outline,prop);
+    }
+
+
+    private void generate( ClassOutlineImpl outline, CPropertyInfo prop ) {
+        // add isSetXXX and unsetXXX.
+        MethodWriter writer = outline.createMethodWriter();
+
+        JCodeModel codeModel = outline.parent().getCodeModel();
+
+        FieldAccessor acc = core.create(JExpr._this());
+
+        if( generateIsSetMethod ) {
+            // [RESULT] boolean isSetXXX()
+            JExpression hasSetValue = acc.hasSetValue();
+            if( hasSetValue==null ) {
+                // this field renderer doesn't support the isSet/unset methods generation.
+                // issue an error
+                throw new UnsupportedOperationException();
+            }
+            writer.declareMethod(codeModel.BOOLEAN,"isSet"+this.prop.getName(true))
+                .body()._return( hasSetValue );
+        }
+
+        if( generateUnSetMethod ) {
+            // [RESULT] void unsetXXX()
+            acc.unsetValues(
+                writer.declareMethod(codeModel.VOID,"unset"+this.prop.getName(true)).body() );
+        }
+    }
+
+    public JType getRawType() {
+        return core.getRawType();
+    }
+
+    public FieldAccessor create(JExpression targetObject) {
+        return new Accessor(targetObject);
+    }
+
+    private class Accessor extends AbstractField.Accessor {
+
+        private final FieldAccessor core;
+
+        Accessor( JExpression $target ) {
+            super($target);
+            this.core = IsSetField.this.core.create($target);
+        }
+
+
+        public void unsetValues( JBlock body ) {
+            core.unsetValues(body);
+        }
+        public JExpression hasSetValue() {
+            return core.hasSetValue();
+        }
+        public void toRawValue(JBlock block, JVar $var) {
+            core.toRawValue(block,$var);
+        }
+
+        public void fromRawValue(JBlock block, String uniqueName, JExpression $var) {
+            core.fromRawValue(block,uniqueName,$var);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/IsSetFieldRenderer.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/IsSetFieldRenderer.java
new file mode 100644
index 0000000..8cd0d4c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/IsSetFieldRenderer.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+/**
+ * FieldRenderer that wraps another field generator
+ * and produces isSetXXX unsetXXX methods.
+ *
+ * <p>
+ * This follows the decorator design pattern so that
+ * the caller of FieldRenderer can forget about details
+ * of the method generation.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class IsSetFieldRenderer implements FieldRenderer {
+    private final FieldRenderer core;
+    private final boolean generateUnSetMethod;
+    private final boolean generateIsSetMethod;
+
+    public IsSetFieldRenderer(
+        FieldRenderer core,
+        boolean generateUnSetMethod, boolean generateIsSetMethod ) {
+
+        this.core = core;
+        this.generateUnSetMethod = generateUnSetMethod;
+        this.generateIsSetMethod = generateIsSetMethod;
+    }
+
+    public FieldOutline generate(ClassOutlineImpl context, CPropertyInfo prop) {
+        return new IsSetField(context,prop,
+            core.generate(context,prop),
+            generateUnSetMethod,generateIsSetMethod);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/MessageBundle.properties
new file mode 100644
index 0000000..a77b6a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/MessageBundle.properties
@@ -0,0 +1,6 @@
+DEFAULT_SETTER_JAVADOC = \
+        Sets the value of the {0} property.
+
+DEFAULT_GETTER_JAVADOC = \
+        Gets the value of the {0} property.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/Messages.java
new file mode 100644
index 0000000..e654ef6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/Messages.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources
+ */
+enum Messages {
+    DEFAULT_GETTER_JAVADOC,     // 1 arg
+    DEFAULT_SETTER_JAVADOC,     // 1 arg
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName().substring(0, Messages.class.getName().lastIndexOf('.'))+ ".MessageBundle");
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/SingleField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/SingleField.java
new file mode 100644
index 0000000..99b7c91
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/SingleField.java
@@ -0,0 +1,164 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import java.util.List;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JConditional;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.generator.bean.MethodWriter;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+
+/**
+ * Realizes a property through one getter and one setter.
+ * This renders:
+ *
+ * <pre>
+ * T' field;
+ * T getXXX() { ... }
+ * void setXXX(T value) { ... }
+ * </pre>
+ *
+ * <p>
+ * Normally T'=T, but under some tricky circumstances they could be different
+ * (like T'=Integer, T=int.)
+ *
+ * This realization is only applicable to fields with (1,1)
+ * or (0,1) multiplicity.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class SingleField extends AbstractFieldWithVar {
+
+    protected SingleField(ClassOutlineImpl context, CPropertyInfo prop) {
+        this(context,prop,false);
+    }
+
+    /**
+     *
+     * @param forcePrimitiveAccess
+     *      forces the setter/getter to expose the primitive type.
+     *      it's a pointless customization, but it's nevertheless in the spec.
+     */
+    protected SingleField(ClassOutlineImpl context, CPropertyInfo prop, boolean forcePrimitiveAccess ) {
+        super(context, prop);
+        assert !exposedType.isPrimitive() && !implType.isPrimitive();
+
+        createField();
+
+        MethodWriter writer = context.createMethodWriter();
+        NameConverter nc = context.parent().getModel().getNameConverter();
+
+        // [RESULT]
+        // Type getXXX() {
+        // #ifdef default value
+        //     if(value==null)
+        //         return defaultValue;
+        // #endif
+        //     return value;
+        // }
+        JExpression defaultValue = null;
+        if(prop.defaultValue!=null)
+            defaultValue = prop.defaultValue.compute(outline.parent());
+
+        // if Type is a wrapper and we have a default value,
+        // we can use the primitive type.
+        JType getterType;
+        if(defaultValue!=null || forcePrimitiveAccess)
+            getterType = exposedType.unboxify();
+        else
+            getterType = exposedType;
+
+        JMethod $get = writer.declareMethod( getterType,getGetterMethod() );
+        String javadoc = prop.javadoc;
+        if(javadoc.length()==0)
+            javadoc = Messages.DEFAULT_GETTER_JAVADOC.format(nc.toVariableName(prop.getName(true)));
+        writer.javadoc().append(javadoc);
+
+
+        if(defaultValue==null) {
+            $get.body()._return(ref());
+        } else {
+            JConditional cond = $get.body()._if(ref().eq(JExpr._null()));
+            cond._then()._return(defaultValue);
+            cond._else()._return(ref());
+        }
+
+        List<Object> possibleTypes = listPossibleTypes(prop);
+        writer.javadoc().addReturn()
+            .append("possible object is\n")
+            .append(possibleTypes);
+
+        // [RESULT]
+        // void setXXX(Type newVal) {
+        //     this.value = newVal;
+        // }
+        JMethod $set = writer.declareMethod( codeModel.VOID, "set"+prop.getName(true) );
+        JType setterType = exposedType;
+        if(forcePrimitiveAccess)    setterType = setterType.unboxify();
+        JVar $value = writer.addParameter( setterType, "value" );
+        JBlock body = $set.body();
+        body.assign(JExpr._this().ref(ref()),castToImplType($value));
+
+        javadoc = prop.javadoc;
+        if(javadoc.length()==0)
+            javadoc = Messages.DEFAULT_SETTER_JAVADOC.format(nc.toVariableName(prop.getName(true)));
+        writer.javadoc().append(javadoc);
+        writer.javadoc().addParam($value)
+            .append("allowed object is\n")
+            .append(possibleTypes);
+    }
+
+    public final JType getFieldType() {
+        return implType;
+    }
+
+    public FieldAccessor create(JExpression targetObject) {
+        return new Accessor(targetObject);
+    }
+
+    protected class Accessor extends AbstractFieldWithVar.Accessor {
+        protected Accessor(JExpression $target) {
+            super($target);
+        }
+
+        public void unsetValues( JBlock body ) {
+            body.assign( $ref, JExpr._null() );
+        }
+        public JExpression hasSetValue() {
+            return $ref.ne( JExpr._null() );
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/SinglePrimitiveAccessField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/SinglePrimitiveAccessField.java
new file mode 100644
index 0000000..ef470b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/SinglePrimitiveAccessField.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+
+/**
+ * {@link SingleField} that forces the primitive accessor type.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class SinglePrimitiveAccessField extends SingleField {
+    protected SinglePrimitiveAccessField(ClassOutlineImpl context, CPropertyInfo prop) {
+        super(context, prop,true);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UnboxedField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UnboxedField.java
new file mode 100644
index 0000000..8fa55da
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UnboxedField.java
@@ -0,0 +1,123 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JPrimitiveType;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.generator.bean.MethodWriter;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.FieldAccessor;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+
+/**
+ * A required primitive property.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class UnboxedField extends AbstractFieldWithVar {
+
+    /**
+     * The primitive version of {@link #implType} and {@link #exposedType}.
+     */
+    private final JPrimitiveType ptype;
+
+
+    protected UnboxedField( ClassOutlineImpl outline, CPropertyInfo prop ) {
+        super(outline,prop);
+        // primitive types don't have this distintion
+        assert implType==exposedType;
+
+        ptype = (JPrimitiveType) implType;
+        assert ptype!=null;
+
+        createField();
+
+        // apparently a required attribute can be still defaulted.
+        // so this assertion is incorrect.
+        // assert prop.defaultValue==null;
+
+        MethodWriter writer = outline.createMethodWriter();
+        NameConverter nc = outline.parent().getModel().getNameConverter();
+
+        JBlock body;
+
+        // [RESULT]
+        // Type getXXX() {
+        //     return value;
+        // }
+        JMethod $get = writer.declareMethod( ptype, getGetterMethod() );
+        String javadoc = prop.javadoc;
+        if(javadoc.length()==0)
+            javadoc = Messages.DEFAULT_GETTER_JAVADOC.format(nc.toVariableName(prop.getName(true)));
+        writer.javadoc().append(javadoc);
+
+        $get.body()._return(ref());
+
+
+        // [RESULT]
+        // void setXXX( Type value ) {
+        //     this.value = value;
+        // }
+        JMethod $set = writer.declareMethod( codeModel.VOID, "set"+prop.getName(true) );
+        JVar $value = writer.addParameter( ptype, "value" );
+        body = $set.body();
+        body.assign(JExpr._this().ref(ref()),$value);
+        javadoc = prop.javadoc;
+        if(javadoc.length()==0)
+            javadoc = Messages.DEFAULT_SETTER_JAVADOC.format(nc.toVariableName(prop.getName(true)));
+        writer.javadoc().append(javadoc);
+
+    }
+
+    protected JType getType(Aspect aspect) {
+        return super.getType(aspect).boxify().getPrimitiveType();
+    }
+
+    protected JType getFieldType() {
+        return ptype;
+    }
+
+    public FieldAccessor create(JExpression targetObject) {
+        return new Accessor(targetObject) {
+
+            public void unsetValues( JBlock body ) {
+                // you can't unset a value
+            }
+
+            public JExpression hasSetValue() {
+                return JExpr.TRUE;
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UntypedListField.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UntypedListField.java
new file mode 100644
index 0000000..0c8c856
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UntypedListField.java
@@ -0,0 +1,167 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.generator.bean.MethodWriter;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+
+/**
+ * Realizes a property as an untyped {@link List}.
+ *
+ * <pre>
+ * List getXXX();
+ * </pre>
+ *
+ * <h2>Default value handling</h2>
+ * <p>
+ * Since unmarshaller just adds new values into the storage,
+ * we can't fill the storage by default values at the time of
+ * instanciation. (or oherwise values found in the document will
+ * be appended to default values, where it should overwrite them.)
+ * <p>
+ * Therefore, when the object is created, the storage will be empty.
+ * When the getXXX method is called, we'll check if the storage is
+ * modified in anyway. If it is modified, it must mean that the values
+ * are found in the document, so we just return it.
+ *
+ * Otherwise we will fill in default values and return it to the user.
+ *
+ * <p>
+ * When a list has default values, its dirty flag is set to true.
+ * Marshaller will check this and treat it appropriately.
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class UntypedListField extends AbstractListField {
+
+    /**
+     * A concrete class that implements the List interface.
+     * An instance of this class will be used to store data
+     * for this field.
+     */
+    private final JClass coreList;
+
+
+    /** List getFIELD() method. */
+    private JMethod $get;
+
+    /**
+     * @param coreList
+     *      A concrete class that implements the List interface.
+     *      An instance of this class will be used to store data
+     *      for this field.
+     */
+    protected UntypedListField(ClassOutlineImpl context, CPropertyInfo prop, JClass coreList) {
+        // the JAXB runtime picks ArrayList if the signature is List,
+        // so don't do eager allocation if it's ArrayList.
+        // otherwise we need to do eager allocation so that the collection type specified by the user
+        // will be used.
+        super(context, prop, !coreList.fullName().equals("java.util.ArrayList"));
+        this.coreList = coreList.narrow(exposedType.boxify());
+        generate();
+    }
+
+    protected final JClass getCoreListType() {
+        return coreList;
+    }
+
+    @Override
+    public void generateAccessors() {
+        final MethodWriter writer = outline.createMethodWriter();
+        final Accessor acc = create(JExpr._this());
+
+        // [RESULT]
+        // List getXXX() {
+        //     return <ref>;
+        // }
+        $get = writer.declareMethod(listT,"get"+prop.getName(true));
+        writer.javadoc().append(prop.javadoc);
+        JBlock block = $get.body();
+        fixNullRef(block);  // avoid using an internal getter
+        block._return(acc.ref(true));
+
+        String pname = NameConverter.standard.toVariableName(prop.getName(true));
+        writer.javadoc().append(
+            "Gets the value of the "+pname+" property.\n\n"+
+            "<p>\n" +
+            "This accessor method returns a reference to the live list,\n" +
+            "not a snapshot. Therefore any modification you make to the\n" +
+            "returned list will be present inside the JAXB object.\n" +
+            "This is why there is not a <CODE>set</CODE> method for the " +pname+ " property.\n" +
+            "\n"+
+            "<p>\n" +
+            "For example, to add a new item, do as follows:\n"+
+            "<pre>\n"+
+            "   get"+prop.getName(true)+"().add(newItem);\n"+
+            "</pre>\n"+
+            "\n\n"
+        );
+
+        writer.javadoc().append(
+            "<p>\n" +
+            "Objects of the following type(s) are allowed in the list\n")
+            .append(listPossibleTypes(prop));
+    }
+
+    public Accessor create(JExpression targetObject) {
+        return new Accessor(targetObject);
+    }
+
+    class Accessor extends AbstractListField.Accessor {
+        protected Accessor( JExpression $target ) {
+            super($target);
+        }
+
+        public void toRawValue(JBlock block, JVar $var) {
+            // [RESULT]
+            // $<var>.addAll(bean.getLIST());
+            // list.toArray( array );
+            block.assign($var,JExpr._new(codeModel.ref(ArrayList.class).narrow(exposedType.boxify())).arg(
+                $target.invoke($get)
+            ));
+        }
+
+        public void fromRawValue(JBlock block, String uniqueName, JExpression $var) {
+            // [RESULT]
+            // bean.getLIST().addAll($<var>);
+            JVar $list = block.decl(listT,uniqueName+'l',$target.invoke($get));
+            block.invoke($list,"addAll").arg($var);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UntypedListFieldRenderer.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UntypedListFieldRenderer.java
new file mode 100644
index 0000000..bf2a24d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/UntypedListFieldRenderer.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.bean.field;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.tools.internal.xjc.generator.bean.ClassOutlineImpl;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+
+/**
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class UntypedListFieldRenderer implements FieldRenderer {
+
+    private JClass coreList;
+
+    protected UntypedListFieldRenderer( JClass coreList ) {
+        this.coreList = coreList;
+    }
+
+    public FieldOutline generate(ClassOutlineImpl context, CPropertyInfo prop) {
+        return new UntypedListField(context,prop,coreList);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/package.html
new file mode 100644
index 0000000..d8eed5a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/bean/field/package.html
@@ -0,0 +1,5 @@
+<body><p>
+FieldRenderer and its implementation classes.
+Unless you are deriving from these classes to define your own custom renderer,
+you shouldn't be using these classes directly. Use the outline package.
+</p></body>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/package-info.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/package-info.java
new file mode 100644
index 0000000..a3d1e56
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/package-info.java
@@ -0,0 +1,32 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * <h1>Code Generator</h1>.
+ *
+ * This package hosts code for generating CodeModel AST from {@link com.sun.tools.internal.xjc.model Model}
+ * classes.
+ */
+package com.sun.tools.internal.xjc.generator;
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/BlockReference.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/BlockReference.java
new file mode 100644
index 0000000..ec192b5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/BlockReference.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.util;
+
+import com.sun.codemodel.internal.JBlock;
+
+/**
+ * Holds a reference to a {@link JBlock} object.
+ *
+ * <p>
+ * This interface is usually used when one wants to create
+ * a new JBlock object lazily.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface BlockReference {
+    /**
+     * @param create
+     *      If false, the method will return null if the block is
+     *      not yet created.
+     */
+    JBlock get(boolean create);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/ExistingBlockReference.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/ExistingBlockReference.java
new file mode 100644
index 0000000..73c2fcd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/ExistingBlockReference.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.util;
+
+import com.sun.codemodel.internal.JBlock;
+
+/**
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ExistingBlockReference implements BlockReference {
+    private final JBlock block;
+
+    public ExistingBlockReference( JBlock _block ) {
+        this.block = _block;
+    }
+
+    public JBlock get(boolean create) {
+        return block;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/LazyBlockReference.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/LazyBlockReference.java
new file mode 100644
index 0000000..a71fd23
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/LazyBlockReference.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.util;
+
+import com.sun.codemodel.internal.JBlock;
+
+/**
+ * Lazy block reference.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class LazyBlockReference implements BlockReference {
+
+    private JBlock block = null;
+
+    /**
+     * Called when a block needs to be created.
+     * Only called once in the whole life time of this object.
+     */
+    protected abstract JBlock create();
+
+    public JBlock get(boolean create) {
+        if(!create)     return block;
+        if(block==null)
+            block = create();
+        return block;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/WhitespaceNormalizer.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/WhitespaceNormalizer.java
new file mode 100644
index 0000000..aab57e8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/generator/util/WhitespaceNormalizer.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.generator.util;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JStringLiteral;
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+
+/**
+ * Generates code that performs the whitespace normalization.
+ */
+public abstract class WhitespaceNormalizer
+{
+    /**
+     * Generates the expression that normalizes
+     * the given expression (which evaluates to java.lang.String).
+     *
+     * @param codeModel
+     *      The owner code model object under which a new expression
+     *      will be created.
+     */
+    public abstract JExpression generate( JCodeModel codeModel, JExpression literal );
+
+    /**
+     * Parses "preserve","replace" or "collapse" into
+     * the corresponding WhitespaceNormalizer object.
+     *
+     * @param method
+     *      Either "preserve", "replace", or "collapse"
+     *
+     * @exception    IllegalArgumentException
+     *        when the specified method is invalid.
+     */
+    public static WhitespaceNormalizer parse( String method ) {
+        if( method.equals("preserve") )
+            return PRESERVE;
+
+        if( method.equals("replace") )
+            return REPLACE;
+
+        if( method.equals("collapse") )
+            return COLLAPSE;
+
+        throw new IllegalArgumentException(method);
+    }
+
+    public static final WhitespaceNormalizer PRESERVE = new WhitespaceNormalizer() {
+        public JExpression generate( JCodeModel codeModel, JExpression literal ) {
+            return literal;
+        }
+    };
+
+    public static final WhitespaceNormalizer REPLACE = new WhitespaceNormalizer() {
+        public JExpression generate( JCodeModel codeModel, JExpression literal ) {
+            // WhitespaceProcessor.replace(<literal>);
+            if( literal instanceof JStringLiteral )
+                // optimize
+                return JExpr.lit( WhiteSpaceProcessor.replace(((JStringLiteral)literal).str) );
+            else
+                return codeModel.ref(WhiteSpaceProcessor.class)
+                    .staticInvoke("replace").arg(literal);
+        }
+    };
+
+    public static final WhitespaceNormalizer COLLAPSE = new WhitespaceNormalizer() {
+        public JExpression generate( JCodeModel codeModel, JExpression literal ) {
+            // WhitespaceProcessor.replace(<literal>);
+            if( literal instanceof JStringLiteral )
+                // optimize
+                return JExpr.lit( WhiteSpaceProcessor.collapse(((JStringLiteral)literal).str) );
+            else
+                return codeModel.ref(WhiteSpaceProcessor.class)
+                    .staticInvoke("collapse").arg(literal);
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/AbstractCTypeInfoImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/AbstractCTypeInfoImpl.java
new file mode 100644
index 0000000..baa2db4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/AbstractCTypeInfoImpl.java
@@ -0,0 +1,116 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import javax.activation.MimeType;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XmlString;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * Partial implementation of {@link CTypeInfo}.
+ *
+ * <p>
+ * The inheritance of {@link TypeUse} by {@link CTypeInfo}
+ * isn't a normal inheritance (see {@link CTypeInfo} for more.)
+ * This class implments methods on {@link TypeUse} for {@link CTypeInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class AbstractCTypeInfoImpl implements CTypeInfo {
+
+    private final CCustomizations customizations;
+
+    private final XSComponent source;
+
+    protected AbstractCTypeInfoImpl(Model model, XSComponent source, CCustomizations customizations) {
+        if(customizations==null)
+            customizations = CCustomizations.EMPTY;
+        else
+            customizations.setParent(model,this);
+        this.customizations = customizations;
+        this.source = source;
+    }
+
+    public final boolean isCollection() {
+        return false;
+    }
+
+    public final CAdapter getAdapterUse() {
+        return null;
+    }
+
+    public final CTypeInfo getInfo() {
+        return this;
+    }
+
+    public final ID idUse() {
+        return ID.NONE;
+    }
+
+    public final XSComponent getSchemaComponent() {
+        return source;
+    }
+
+    /**
+     * @deprecated
+     *      why are you calling an unimplemented method?
+     */
+    public final boolean canBeReferencedByIDREF() {
+        // we aren't doing any error check in XJC, so no point in implementing this method.
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * No default {@link MimeType}.
+     */
+    public MimeType getExpectedMimeType() {
+        return null;
+    }
+
+    public CCustomizations getCustomizations() {
+        return customizations;
+    }
+
+    // this is just a convenient default
+    public JExpression createConstant(Outline outline, XmlString lexical) {
+        return null;
+    }
+
+    public final Locatable getUpstream() {
+        throw new UnsupportedOperationException();
+    }
+
+    public final Location getLocation() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CAdapter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CAdapter.java
new file mode 100644
index 0000000..21639e0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CAdapter.java
@@ -0,0 +1,119 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import javax.xml.bind.annotation.adapters.CollapsedStringAdapter;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.tools.internal.xjc.model.nav.EagerNClass;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.model.nav.NavigatorImpl;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+
+/**
+ * Extended {@link Adapter} for use within XJC.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CAdapter extends Adapter<NType,NClass> {
+
+    /**
+     * If non-null, the same as {@link #adapterType} but more conveniently typed.
+     */
+    private JClass adapterClass1;
+
+    /**
+     * If non-null, the same as {@link #adapterType} but more conveniently typed.
+     */
+    private Class<? extends XmlAdapter> adapterClass2;
+
+    /**
+     * When the adapter class is statically known to us.
+     *
+     * @param copy
+     *      true to copy the adapter class into the user package,
+     *      or otherwise just refer to the class specified via the
+     *      adapter parameter.
+     */
+    public CAdapter(Class<? extends XmlAdapter> adapter, boolean copy) {
+        super(getRef(adapter,copy),NavigatorImpl.theInstance);
+        this.adapterClass1 = null;
+        this.adapterClass2 = adapter;
+    }
+
+    static NClass getRef( final Class<? extends XmlAdapter> adapter, boolean copy ) {
+        if(copy) {
+            // TODO: this is a hack. the code generation should be defered until
+            // the backend. (right now constant generation happens in the front-end)
+            return new EagerNClass(adapter) {
+                @Override
+                public JClass toType(Outline o, Aspect aspect) {
+                    return o.addRuntime(adapter);
+                }
+                public String fullName() {
+                    // TODO: implement this method later
+                    throw new UnsupportedOperationException();
+                }
+            };
+        } else {
+            return NavigatorImpl.theInstance.ref(adapter);
+        }
+    }
+
+    public CAdapter(JClass adapter) {
+        super( NavigatorImpl.theInstance.ref(adapter), NavigatorImpl.theInstance);
+        this.adapterClass1 = adapter;
+        this.adapterClass2 = null;
+    }
+
+    public JClass getAdapterClass(Outline o) {
+        if(adapterClass1==null)
+            adapterClass1 = o.getCodeModel().ref(adapterClass2);
+        return adapterType.toType(o, Aspect.EXPOSED);
+    }
+
+    /**
+     * Returns true if the adapter is for whitespace normalization.
+     * Such an adapter can be ignored when producing a list.
+     */
+    public boolean isWhitespaceAdapter() {
+        return adapterClass2==CollapsedStringAdapter.class || adapterClass2==NormalizedStringAdapter.class;
+    }
+
+    /**
+     * Returns the adapter class if the adapter type is statically known to XJC.
+     * <p>
+     * This method is mostly for enabling certain optimized code generation.
+     */
+    public Class<? extends XmlAdapter> getAdapterIfKnown() {
+        return adapterClass2;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CArrayInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CArrayInfo.java
new file mode 100644
index 0000000..f3b26fa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CArrayInfo.java
@@ -0,0 +1,89 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.core.ArrayInfo;
+import com.sun.xml.internal.bind.v2.model.impl.ArrayInfoImpl;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * TODO: Because s2j doesn't generate the array binding, this is unnecessary.
+ * @author Kohsuke Kawaguchi
+ */
+public final class CArrayInfo extends AbstractCTypeInfoImpl implements ArrayInfo<NType,NClass>, CNonElement, NType {
+
+    private final CNonElement itemType;
+
+    private final QName typeName;
+
+    public CArrayInfo(Model model,CNonElement itemType, XSComponent source, CCustomizations customizations) {
+        super(model,source,customizations);
+        this.itemType = itemType;
+        assert itemType.getTypeName()!=null;
+        this.typeName = ArrayInfoImpl.calcArrayTypeName(itemType.getTypeName());
+    }
+
+    public CNonElement getItemType() {
+        return itemType;
+    }
+
+    public QName getTypeName() {
+        return typeName;
+    }
+
+    public boolean isSimpleType() {
+        return false;
+    }
+
+    public JType toType(Outline o, Aspect aspect) {
+        return itemType.toType(o,aspect).array();
+    }
+
+    public NType getType() {
+        return this;
+    }
+
+    public boolean isBoxedType() {
+        return false;
+    }
+
+    public String fullName() {
+        return itemType.getType().fullName()+"[]";
+    }
+
+    public Locator getLocator() {
+        return Model.EMPTY_LOCATOR;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CAttributePropertyInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CAttributePropertyInfo.java
new file mode 100644
index 0000000..814002d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CAttributePropertyInfo.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.xml.internal.bind.v2.model.core.AttributePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * {@link AttributePropertyInfo} for the compiler.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CAttributePropertyInfo extends CSingleTypePropertyInfo implements AttributePropertyInfo<NType,NClass> {
+
+    private final QName attName;
+    private final boolean isRequired;
+
+    public CAttributePropertyInfo(String name, XSComponent source, CCustomizations customizations,
+                                  Locator locator, QName attName, TypeUse type, boolean required ) {
+        super(name, type, source, customizations, locator);
+        isRequired = required;
+        this.attName = attName;
+    }
+
+    public boolean isRequired() {
+        return isRequired;
+    }
+
+    public QName getXmlName() {
+        return attName;
+    }
+
+    /**
+     * An optional attribute can never be unboxable,
+     * for we need null to represent the absence.
+     */
+    public boolean isUnboxable() {
+        if(!isRequired) return false;
+        return super.isUnboxable();
+    }
+
+    @Override
+    public boolean isOptionalPrimitive() {
+        return !isRequired && super.isUnboxable();
+    }
+
+    public <V> V accept(CPropertyVisitor<V> visitor) {
+        return visitor.onAttribute(this);
+    }
+
+    public final PropertyKind kind() {
+        return  PropertyKind.ATTRIBUTE;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CBuiltinLeafInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CBuiltinLeafInfo.java
new file mode 100644
index 0000000..f10ae64
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CBuiltinLeafInfo.java
@@ -0,0 +1,320 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.awt.*;
+import java.math.BigDecimal;
+import java.math.BigInteger;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.activation.DataHandler;
+import javax.activation.MimeType;
+import javax.xml.bind.DatatypeConverter;
+import javax.xml.bind.annotation.XmlIDREF;
+import javax.xml.bind.annotation.adapters.CollapsedStringAdapter;
+import javax.xml.bind.annotation.adapters.HexBinaryAdapter;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.datatype.Duration;
+import javax.xml.datatype.XMLGregorianCalendar;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Source;
+
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.model.nav.NavigatorImpl;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.tools.internal.xjc.runtime.ZeroOneBooleanAdapter;
+import com.sun.tools.internal.xjc.util.NamespaceContextAdapter;
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.impl.BuiltinLeafInfoImpl;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XmlString;
+
+import org.xml.sax.Locator;
+
+/**
+ * Encapsulates the default handling for leaf classes (which are bound
+ * to text in XML.) In particular this class knows how to convert
+ * the lexical value into the Java class according to this default rule.
+ *
+ * <p>
+ * This represents the spec-defined default handling for the Java
+ * type ({@link #getType()}.
+ *
+ * <p>
+ * For those Java classes (such as {@link String} or {@link Boolean})
+ * where the spec designates a specific default handling, there are
+ * constants in this class (such as {@link #STRING} or {@link #BOOLEAN}.)
+ *
+ * <p>
+ * The generated type-safe enum classes are also a leaf class,
+ * and as such there are {@link CEnumLeafInfo} that represents it
+ * as {@link CBuiltinLeafInfo}.
+ *
+ * <p>
+ * This class represents the <b>default handling</b>, and therefore
+ * we can only have one instance per one {@link NType}. Handling of
+ * other XML Schema types (such as xs:token) are represented as
+ * a general {@link TypeUse} objects.
+ *
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class CBuiltinLeafInfo extends BuiltinLeafInfoImpl<NType,NClass> implements CNonElement {
+
+    private final ID id;
+
+    // no derived class other than the spec-defined ones. definitely not for enum.
+    private CBuiltinLeafInfo(NType typeToken, QName typeName, ID id) {
+        super(typeToken,typeName);
+        this.id = id;
+    }
+
+    /**
+     * Gets the code model representation of this type.
+     */
+    public JType toType(Outline o, Aspect aspect) {
+        return getType().toType(o,aspect);
+    }
+
+    /**
+     * Since {@link CBuiltinLeafInfo} represents a default binding,
+     * it is never a collection.
+     */
+    public final boolean isCollection() {
+        return false;
+    }
+
+    public ID idUse() {
+        return id;
+    }
+
+    /**
+     * {@link CBuiltinLeafInfo} never has a default associated MIME type.
+     */
+    public MimeType getExpectedMimeType() {
+        return null;
+    }
+
+    /**
+     * By definition, a default handling doesn't need any adapter.
+     */
+    public final CAdapter getAdapterUse() {
+        return null;
+    }
+
+    public final CBuiltinLeafInfo getInfo() {
+        return this;
+    }
+
+    public Locator getLocator() {
+        return Model.EMPTY_LOCATOR;
+    }
+
+    public final XSComponent getSchemaComponent() {
+        throw new UnsupportedOperationException("TODO. If you hit this, let us know.");
+    }
+
+    /**
+     * Creates a {@link TypeUse} that represents a collection of this {@link CBuiltinLeafInfo}.
+     */
+    public final TypeUse makeCollection() {
+        return TypeUseFactory.makeCollection(this);
+    }
+
+    /**
+     * Creates a {@link TypeUse} that represents an adapted use of this {@link CBuiltinLeafInfo}.
+     */
+    public final TypeUse makeAdapted( Class<? extends XmlAdapter> adapter, boolean copy ) {
+        return TypeUseFactory.adapt(this,adapter,copy);
+    }
+
+    /**
+     * Creates a {@link TypeUse} that represents a MIME-type assocaited version of this {@link CBuiltinLeafInfo}.
+     */
+    public final TypeUse makeMimeTyped( MimeType mt ) {
+        return TypeUseFactory.makeMimeTyped(this,mt);
+    }
+
+    /**
+     * {@link CBuiltinLeafInfo} for Java classes that have
+     * the spec defined built-in binding semantics.
+     */
+    private static abstract class Builtin extends CBuiltinLeafInfo {
+        protected Builtin(Class c, String typeName) {
+            this(c,typeName,com.sun.xml.internal.bind.v2.model.core.ID.NONE);
+        }
+        protected Builtin(Class c, String typeName, ID id) {
+            super(NavigatorImpl.theInstance.ref(c), new QName(WellKnownNamespace.XML_SCHEMA,typeName),id);
+            LEAVES.put(getType(),this);
+        }
+
+        /**
+         * No vendor customization in the built-in classes.
+         */
+        public CCustomizations getCustomizations() {
+            return CCustomizations.EMPTY;
+        }
+    }
+
+    private static final class NoConstantBuiltin extends Builtin {
+        public NoConstantBuiltin(Class c, String typeName) {
+            super(c, typeName);
+        }
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return null;
+        }
+    }
+
+    /**
+     * All built-in leaves.
+     */
+    public static final Map<NType,CBuiltinLeafInfo> LEAVES = new HashMap<NType,CBuiltinLeafInfo>();
+
+
+    public static final CBuiltinLeafInfo ANYTYPE = new NoConstantBuiltin(Object.class,"anyType");
+    public static final CBuiltinLeafInfo STRING = new Builtin(String.class,"string") {
+            public JExpression createConstant(Outline outline, XmlString lexical) {
+                return JExpr.lit(lexical.value);
+            }
+    };
+    public static final CBuiltinLeafInfo BOOLEAN = new Builtin(Boolean.class,"boolean") {
+            public JExpression createConstant(Outline outline, XmlString lexical) {
+                return JExpr.lit(DatatypeConverterImpl._parseBoolean(lexical.value));
+            }
+    };
+    public static final CBuiltinLeafInfo INT = new Builtin(Integer.class,"int") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return JExpr.lit(DatatypeConverterImpl._parseInt(lexical.value));
+        }
+    };
+    public static final CBuiltinLeafInfo LONG = new Builtin(Long.class,"long") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return JExpr.lit(DatatypeConverterImpl._parseLong(lexical.value));
+        }
+    };
+    public static final CBuiltinLeafInfo BYTE = new Builtin(Byte.class,"byte") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return JExpr.cast(
+                    outline.getCodeModel().BYTE,
+                    JExpr.lit(DatatypeConverterImpl._parseByte(lexical.value)));
+        }
+    };
+    public static final CBuiltinLeafInfo SHORT = new Builtin(Short.class,"short") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return JExpr.cast(
+                    outline.getCodeModel().SHORT,
+                    JExpr.lit(DatatypeConverterImpl._parseShort(lexical.value)));
+        }
+    };
+    public static final CBuiltinLeafInfo FLOAT = new Builtin(Float.class,"float") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return JExpr.lit(DatatypeConverterImpl._parseFloat(lexical.value));
+        }
+    };
+    public static final CBuiltinLeafInfo DOUBLE = new Builtin(Double.class,"double") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return JExpr.lit(DatatypeConverterImpl._parseDouble(lexical.value));
+        }
+    };
+    public static final CBuiltinLeafInfo QNAME = new Builtin(QName.class,"QName") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            QName qn = DatatypeConverterImpl._parseQName(lexical.value,new NamespaceContextAdapter(lexical));
+            return JExpr._new(outline.getCodeModel().ref(QName.class))
+                .arg(qn.getNamespaceURI())
+                .arg(qn.getLocalPart())
+                .arg(qn.getPrefix());
+        }
+    };
+    // XMLGregorianCalendar is mutable, so we can't support default values anyhow.
+    public static final CBuiltinLeafInfo CALENDAR = new NoConstantBuiltin(XMLGregorianCalendar.class,"dateTime");
+    public static final CBuiltinLeafInfo DURATION = new NoConstantBuiltin(Duration.class,"duration");
+
+    public static final CBuiltinLeafInfo BIG_INTEGER = new Builtin(BigInteger.class,"integer") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return JExpr._new(outline.getCodeModel().ref(BigInteger.class)).arg(lexical.value.trim());
+        }
+    };
+
+    public static final CBuiltinLeafInfo BIG_DECIMAL = new Builtin(BigDecimal.class,"decimal") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return JExpr._new(outline.getCodeModel().ref(BigDecimal.class)).arg(lexical.value.trim());
+        }
+    };
+
+    public static final CBuiltinLeafInfo BASE64_BYTE_ARRAY = new Builtin(byte[].class,"base64Binary") {
+        public JExpression createConstant(Outline outline, XmlString lexical) {
+            return outline.getCodeModel().ref(DatatypeConverter.class).staticInvoke("parseBase64Binary").arg(lexical.value);
+        }
+    };
+
+    public static final CBuiltinLeafInfo DATA_HANDLER = new NoConstantBuiltin(DataHandler.class,"base64Binary");
+    public static final CBuiltinLeafInfo IMAGE = new NoConstantBuiltin(Image.class,"base64Binary");
+    public static final CBuiltinLeafInfo XML_SOURCE = new NoConstantBuiltin(Source.class,"base64Binary");
+
+    public static final TypeUse HEXBIN_BYTE_ARRAY =
+        STRING.makeAdapted(HexBinaryAdapter.class,false);
+
+
+    // TODO: not sure if they should belong here,
+    // but I couldn't find other places that fit.
+    public static final TypeUse TOKEN =
+            STRING.makeAdapted(CollapsedStringAdapter.class,false);
+
+    public static final TypeUse NORMALIZED_STRING =
+            STRING.makeAdapted(NormalizedStringAdapter.class,false);
+
+    public static final TypeUse ID = TypeUseFactory.makeID(TOKEN,com.sun.xml.internal.bind.v2.model.core.ID.ID);
+
+    /**
+     * boolean restricted to 0 or 1.
+     */
+    public static final TypeUse BOOLEAN_ZERO_OR_ONE =
+            STRING.makeAdapted(ZeroOneBooleanAdapter.class,true);
+
+    /**
+     * IDREF.
+     *
+     * IDREF is has a whitespace normalization semantics of token, but
+     * we don't want {@link XmlJavaTypeAdapter} and {@link XmlIDREF} to interact.
+     */
+    public static final TypeUse IDREF = TypeUseFactory.makeID(ANYTYPE,com.sun.xml.internal.bind.v2.model.core.ID.IDREF);
+
+    /**
+     * For all list of strings, such as NMTOKENS, ENTITIES.
+     */
+    public static final TypeUse STRING_LIST =
+            STRING.makeCollection();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CClassInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CClassInfo.java
new file mode 100644
index 0000000..73b1e56
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CClassInfo.java
@@ -0,0 +1,414 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlID;
+import javax.xml.bind.annotation.XmlIDREF;
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * Mutable {@link ClassInfo} represenatation.
+ *
+ * <p>
+ * Schema parsers build these objects.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CClassInfo extends AbstractCTypeInfoImpl implements ClassInfo<NType,NClass>, CClassInfoParent, CElement, CNonElement, NClass, CTypeInfo {
+
+    @XmlIDREF
+    private CClassInfo baseClass;
+
+    /**
+     * @see #getTypeName()
+     */
+    private final QName typeName;
+    /**
+     * Can be null.
+     */
+    private final QName elementName;
+
+    private boolean isOrdered = true;
+
+    private final List<CPropertyInfo> properties = new ArrayList<CPropertyInfo>();
+
+    /**
+     * TODO: revisit this design.
+     * we should at least do a basic encapsulation to avoid careless
+     * mistakes. Maybe we should even differ the javadoc generation
+     * by queueing runners.
+     */
+    public String javadoc;
+
+    @XmlIDREF
+    private final CClassInfoParent parent;
+
+    /**
+     * short name.
+     */
+    public final String shortName;
+
+    /**
+     * The location in the source file where this class was declared.
+     */
+    @XmlTransient
+    private final Locator location;
+
+    private boolean isAbstract;
+
+    /**
+     * Optional user-specified implementation override class.
+     */
+    private String implClass;
+
+    /**
+     * The {@link Model} object to which this bean belongs.
+     */
+    public final Model model;
+
+    /**
+     * @see #hasAttributeWildcard()
+     */
+    private boolean hasAttributeWildcard;
+
+
+    public CClassInfo(Model model,JPackage pkg, String shortName, Locator location, QName typeName, QName elementName, XSComponent source, CCustomizations customizations) {
+        this(model,model.getPackage(pkg),shortName,location,typeName,elementName,source,customizations);
+    }
+
+    public CClassInfo(Model model,CClassInfoParent p, String shortName, Locator location, QName typeName, QName elementName, XSComponent source, CCustomizations customizations) {
+        super(model,source,customizations);
+        this.model = model;
+        this.parent = p;
+        this.shortName = model.allocator.assignClassName(parent,shortName);
+        this.location = location;
+        this.typeName = typeName;
+        this.elementName = elementName;
+
+        model.add(this);
+    }
+
+    public CClassInfo(Model model,JCodeModel cm, String fullName, Locator location, QName typeName, QName elementName, XSComponent source, CCustomizations customizations) {
+        super(model,source,customizations);
+        this.model = model;
+        int idx = fullName.indexOf('.');
+        if(idx<0) {
+            this.parent = model.getPackage(cm.rootPackage());
+            this.shortName = model.allocator.assignClassName(parent,fullName);
+        } else {
+            this.parent = model.getPackage(cm._package(fullName.substring(0,idx)));
+            this.shortName = model.allocator.assignClassName(parent,fullName.substring(idx+1));
+        }
+        this.location = location;
+        this.typeName = typeName;
+        this.elementName = elementName;
+
+        model.add(this);
+    }
+
+    public Locator getLocator() {
+        return location;
+    }
+
+    public boolean hasAttributeWildcard() {
+        return hasAttributeWildcard;
+    }
+
+    public void hasAttributeWildcard(boolean hasAttributeWildcard) {
+        this.hasAttributeWildcard = hasAttributeWildcard;
+    }
+
+    public boolean hasSubClasses() {
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * Returns true iff a new attribute wildcard property needs to be
+     * declared on this class.
+     */
+    public boolean declaresAttributeWildcard() {
+        return hasAttributeWildcard && !inheritsAttributeWildcard();
+    }
+
+    /**
+     * Returns true iff this class inherits a wildcard attribute property
+     * from its ancestor classes.
+     */
+    public boolean inheritsAttributeWildcard() {
+        for( CClassInfo c=getBaseClass(); c!=null; c=c.getBaseClass() ) {
+            if(hasAttributeWildcard)
+                return true;
+        }
+        return false;
+    }
+
+
+    public NClass getClazz() {
+        return this;
+    }
+
+    public CClassInfo getScope() {
+        return null;
+    }
+
+    @XmlID
+    public String getName() {
+        return fullName();
+    }
+
+    /**
+     * Returns the "squeezed name" of this bean token.
+     * <p>
+     * The squeezed name of a bean is the concatenation of
+     * the names of its outer classes and itself.
+     * <p>
+     * Thus if the bean is "org.acme.foo.Bean", then the squeezed name is "Bean",
+     * if the bean is "org.acme.foo.Outer1.Outer2.Bean", then "Outer1Outer2Bean".
+     * <p>
+     * This is used by the code generator
+     */
+    @XmlElement
+    public String getSqueezedName() {
+        return calcSqueezedName.onBean(this);
+    }
+
+    private static final CClassInfoParent.Visitor<String> calcSqueezedName = new Visitor<String>() {
+        public String onBean(CClassInfo bean) {
+            return bean.parent.accept(this)+bean.shortName;
+        }
+
+        public String onElement(CElementInfo element) {
+            return element.parent.accept(this)+element.shortName();
+        }
+
+        public String onPackage(JPackage pkg) {
+            return "";
+        }
+    };
+
+    /**
+     * Returns a mutable list.
+     */
+    public List<CPropertyInfo> getProperties() {
+        return properties;
+    }
+
+    /**
+     * Gets a propery by name.
+     *
+     * TODO: consider moving this up to {@link ClassInfo}
+     */
+    public CPropertyInfo getProperty(String name) {
+        // TODO: does this method need to be fast?
+        for( CPropertyInfo p : properties )
+            if(p.getName(false).equals(name))
+                return p;
+        return null;
+    }
+
+    public boolean hasProperties() {
+        return !getProperties().isEmpty();
+    }
+
+    public boolean isElement() {
+        return elementName!=null;
+    }
+
+    public Element<NType,NClass> asElement() {
+        if(isElement())
+            return this;
+        else
+            return null;
+    }
+
+    public boolean isOrdered() {
+        return isOrdered;
+    }
+
+    /**
+     * @deprecated
+     *      if you are calling this method directly, you must be doing something wrong.
+     */
+    public boolean isFinal() {
+        return false;
+    }
+
+    public void setOrdered(boolean value) {
+        isOrdered = value;
+    }
+
+    public QName getElementName() {
+        return elementName;
+    }
+
+    public QName getTypeName() {
+        return typeName;
+    }
+
+    public boolean isSimpleType() {
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * Returns the FQCN of this bean.
+     */
+    public String fullName() {
+        String r = parent.fullName();
+        if(r.length()==0)   return shortName;
+        else                return r+'.'+shortName;
+    }
+
+    public CClassInfoParent parent() {
+        return parent;
+    }
+
+    public void setUserSpecifiedImplClass(String implClass) {
+        assert this.implClass==null;
+        assert implClass!=null;
+        this.implClass = implClass;
+    }
+
+    public String getUserSpecifiedImplClass() {
+        return implClass;
+    }
+
+
+    /**
+     * Adds a new property.
+     */
+    public void addProperty(CPropertyInfo prop) {
+        if(prop.ref().isEmpty())
+            // this property isn't contributing anything
+            // this happens when you try to map an empty sequence to a property
+            return;
+        prop.setParent(this);
+        properties.add(prop);
+    }
+
+    public void setBaseClass(CClassInfo base) {
+        assert baseClass==null;
+        assert base!=null;
+        baseClass = base;
+    }
+
+    public CClassInfo getBaseClass() {
+        return baseClass;
+    }
+
+    public CClassInfo getSubstitutionHead() {
+        CClassInfo c=baseClass;
+        while(c!=null && !c.isElement())
+            c=c.baseClass;
+        return c;
+    }
+
+
+    /**
+     * Interfaces to be implemented.
+     * Lazily constructed.
+     */
+    private Set<JClass> _implements = null;
+
+    public void _implements(JClass c) {
+        if(_implements==null)
+            _implements = new HashSet<JClass>();
+        _implements.add(c);
+    }
+
+
+    /** Constructor declarations. array of {@link Constructor}s. */
+    private final List<Constructor> constructors = new ArrayList<Constructor>(1);
+
+    /** Creates a new constructor declaration and adds it. */
+    public void addConstructor( String... fieldNames ) {
+        constructors.add(new Constructor(fieldNames));
+    }
+
+    /** list all constructor declarations. */
+    public Collection<? extends Constructor> getConstructors() {
+        return constructors;
+    }
+
+    public final <T> T accept(Visitor<T> visitor) {
+        return visitor.onBean(this);
+    }
+
+    public JPackage getOwnerPackage() {
+        return parent.getOwnerPackage();
+    }
+
+    public final NClass getType() {
+        return this;
+    }
+
+    public final JClass toType(Outline o, Aspect aspect) {
+        switch(aspect) {
+        case IMPLEMENTATION:
+            return o.getClazz(this).implRef;
+        case EXPOSED:
+            return o.getClazz(this).ref;
+        default:
+            throw new IllegalStateException();
+        }
+    }
+
+    public boolean isBoxedType() {
+        return false;
+    }
+
+    public String toString() {
+        return fullName();
+    }
+
+    public void setAbstract() {
+        isAbstract = true;
+    }
+
+    public boolean isAbstract() {
+        return isAbstract;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CClassInfoParent.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CClassInfoParent.java
new file mode 100644
index 0000000..72093e6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CClassInfoParent.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.codemodel.internal.JPackage;
+
+/**
+ * Parent of a {@link CClassInfo}/{@link CElementInfo}.
+ *
+ * TODO: rename
+ *
+ * Either {@link CClassInfo} or {@link CClassInfoParent.Package}.
+ */
+public interface CClassInfoParent {
+    /**
+     * Returns the fully-qualified name.
+     */
+    String fullName();
+
+    <T> T accept( Visitor<T> visitor );
+
+    /**
+     * Gets the nearest {@link JPackage}.
+     */
+    JPackage getOwnerPackage();
+
+    /**
+     * Visitor of {@link CClassInfoParent}
+     */
+    public static interface Visitor<T> {
+        T onBean( CClassInfo bean );
+        T onPackage( JPackage pkg );
+        T onElement( CElementInfo element );
+    }
+
+    /**
+     * {@link JPackage} as a {@link CClassInfoParent}.
+     *
+     * Use {@link Model#getPackage} to obtain an instance.
+     */
+    public static final class Package implements CClassInfoParent {
+        public final JPackage pkg;
+
+        public Package(JPackage pkg) {
+            this.pkg = pkg;
+        }
+
+        public String fullName() {
+            return pkg.name();
+        }
+
+        public <T> T accept(Visitor<T> visitor) {
+            return visitor.onPackage(pkg);
+        }
+
+        public JPackage getOwnerPackage() {
+            return pkg;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CCustomizable.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CCustomizable.java
new file mode 100644
index 0000000..3e6160d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CCustomizable.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * Implemented by model components that can have customizations contributed by {@link Plugin}s.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface CCustomizable {
+    /**
+     * Gets the list of customizations attached to this model component.
+     *
+     * @return
+     *      can be an empty list but never be null. The returned list is read-only.
+     *      Do not modify.
+     *
+     * @see Plugin#getCustomizationURIs()
+     */
+    CCustomizations getCustomizations();
+
+    /**
+     * Gets the source location in the schema from which this model component is created.
+     *
+     * @return never null.
+     */
+    Locator getLocator();
+
+    /**
+     * If this model object is built from XML Schema,
+     * this property returns a schema component from which the model is built.
+     *
+     * @return
+     *      null if the model is built from sources other than XML Schema
+     *      (such as DTD.)
+     */
+    XSComponent getSchemaComponent();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CCustomizations.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CCustomizations.java
new file mode 100644
index 0000000..83c255f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CCustomizations.java
@@ -0,0 +1,144 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.ArrayList;
+import java.util.Collection;
+
+import com.sun.tools.internal.xjc.Plugin;
+
+/**
+ * Represents the list of {@link CPluginCustomization}s attached to a JAXB model component.
+ *
+ * <p>
+ * When {@link Plugin}s register the customization namespace URIs through {@link Plugin#getCustomizationURIs()},
+ * XJC will treat those URIs just like XJC's own extension "http://java.sun.com/xml/ns/xjc" and make them
+ * available as DOM nodes through {@link CPluginCustomization}. A {@link Plugin} can then access
+ * this information to change its behavior.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CCustomizations extends ArrayList<CPluginCustomization> {
+
+    /**
+     * All {@link CCustomizations} used by a {@link Model} form a single linked list
+     * so that we can look for unacknowledged customizations later.
+     *
+     * @see CPluginCustomization#markAsAcknowledged()
+     * @see #setParent(Model,CCustomizable)
+     */
+    /*package*/ CCustomizations next;
+
+    /**
+     * The owner model component that carries these customizations.
+     */
+    private CCustomizable owner;
+
+    public CCustomizations() {
+    }
+
+    public CCustomizations(Collection<? extends CPluginCustomization> cPluginCustomizations) {
+        super(cPluginCustomizations);
+    }
+
+    /*package*/ void setParent(Model model,CCustomizable owner) {
+        if(this.owner!=null)     return;
+
+//        // loop check
+//        for( CCustomizations c = model.customizations; c!=null; c=c.next )
+//            assert c!=this;
+
+        this.next = model.customizations;
+        model.customizations = this;
+        assert owner!=null;
+        this.owner = owner;
+    }
+
+    /**
+     * Gets the model component that carries this customization.
+     *
+     * @return never null.
+     */
+    public CCustomizable getOwner() {
+        assert owner!=null;
+        return owner;
+    }
+
+    /**
+     * Finds the first {@link CPluginCustomization} that belongs to the given namespace URI.
+     * @return null if not found
+     */
+    public CPluginCustomization find( String nsUri ) {
+        for (CPluginCustomization p : this) {
+            if(fixNull(p.element.getNamespaceURI()).equals(nsUri))
+                return p;
+        }
+        return null;
+    }
+
+    /**
+     * Finds the first {@link CPluginCustomization} that belongs to the given namespace URI and the local name.
+     * @return null if not found
+     */
+    public CPluginCustomization find( String nsUri, String localName ) {
+        for (CPluginCustomization p : this) {
+            if(fixNull(p.element.getNamespaceURI()).equals(nsUri)
+            && fixNull(p.element.getLocalName()).equals(localName))
+                return p;
+        }
+        return null;
+    }
+
+    private String fixNull(String s) {
+        if(s==null) return "";
+        else        return s;
+    }
+
+    /**
+     * Convenient singleton instance that represents an empty {@link CCustomizations}.
+     */
+    public static final CCustomizations EMPTY = new CCustomizations();
+
+    /**
+     * Merges two {@link CCustomizations} objects into one.
+     */
+    public static CCustomizations merge(CCustomizations lhs, CCustomizations rhs) {
+        if(lhs==null || lhs.isEmpty())   return rhs;
+        if(rhs==null || rhs.isEmpty())   return lhs;
+
+        CCustomizations r = new CCustomizations(lhs);
+        r.addAll(rhs);
+        return r;
+    }
+
+    public boolean equals(Object o) {
+        return this==o;
+    }
+
+    public int hashCode() {
+        return System.identityHashCode(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CDefaultValue.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CDefaultValue.java
new file mode 100644
index 0000000..6a3b077
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CDefaultValue.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.codemodel.internal.JExpression;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.xsom.XmlString;
+
+/**
+ * Object that computes the default value expression lazily.
+ *
+ * The computation is done lazily because often the default value
+ * needs to refer to things (such as enum classes) that are only generated
+ * after some of the outline is built.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class CDefaultValue {
+    public abstract JExpression compute(Outline outline);
+
+    /**
+     * Creates a new {@link CDefaultValue} that computes the default value
+     * by applying a lexical representation to a {@link TypeUse}.
+     */
+    public static CDefaultValue create(final TypeUse typeUse, final XmlString defaultValue) {
+        return new CDefaultValue() {
+            public JExpression compute(Outline outline) {
+                return typeUse.createConstant(outline,defaultValue);
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElement.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElement.java
new file mode 100644
index 0000000..8d9a30a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElement.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+
+/**
+ * Either {@link CElementInfo} or {@link CClassInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface CElement extends CTypeInfo, Element<NType,NClass>, CClassInfoParent {
+    /**
+     * Marks this element as an abstract element.
+     */
+    void setAbstract();
+
+    /**
+     * Returns true iff this element is an abstract element.
+     */
+    boolean isAbstract();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElementInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElementInfo.java
new file mode 100644
index 0000000..9b346fe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElementInfo.java
@@ -0,0 +1,300 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.model.nav.NavigatorImpl;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.core.ElementInfo;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XmlString;
+
+import org.xml.sax.Locator;
+
+import static com.sun.tools.internal.xjc.model.CElementPropertyInfo.CollectionMode.REPEATED_VALUE;
+import static com.sun.tools.internal.xjc.model.CElementPropertyInfo.CollectionMode.NOT_REPEATED;
+
+/**
+ * {@link ElementInfo} implementation for the compile-time model.
+ *
+ * <p>
+ * As an NType, it represents the Java representation of this element
+ * (either JAXBElement&lt;T> or Foo).
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CElementInfo extends AbstractCTypeInfoImpl
+    implements ElementInfo<NType,NClass>, CElement, CTypeInfo, NType, CClassInfoParent {
+
+    private final QName tagName;
+
+    /**
+     * Represents {@code JAXBElement&lt;ContentType>}.
+     */
+    private NType type;
+
+    /**
+     * If this element produces its own class, the short name of that class.
+     * Otherwise null.
+     */
+    private String className;
+
+    /**
+     * If this element is global, the element info is considered to be
+     * package-level, and this points to the package in which this element
+     * lives in.
+     *
+     * <p>
+     * For local elements, this points to the parent {@link CClassInfo}.
+     */
+    public final CClassInfoParent parent;
+
+    /**
+     * The location in the source file where this class was declared.
+     */
+    @XmlTransient
+    private final Locator location;
+
+    private boolean isAbstract;
+
+    private CElementInfo substitutionHead;
+
+    /**
+     * Lazily computed.
+     */
+    private Set<CElementInfo> substitutionMembers;
+
+    /**
+     * {@link Model} that owns this object.
+     */
+    private final Model model;
+
+    private CElementPropertyInfo property;
+
+    /**
+     * Creates an element in the given parent.
+     *
+     * <p>
+     * When using this construction, {@link #initContentType(TypeUse, XSComponent, XmlString)}
+     * must not be invoked.
+     */
+    public CElementInfo(Model model,QName tagName, CClassInfoParent parent, TypeUse contentType, XmlString defaultValue, XSComponent source, CCustomizations customizations, Locator location ) {
+        super(model,source,customizations);
+        this.tagName = tagName;
+        this.model = model;
+        this.parent = parent;
+        this.location = location;
+        if(contentType!=null)
+            initContentType(contentType, source, defaultValue);
+
+        model.add(this);
+    }
+
+    /**
+     * Creates an element with a class in the given parent.
+     *
+     * <p>
+     * When using this construction, the caller must use
+     * {@link #initContentType(TypeUse, XSComponent, XmlString)} to fill in the content type
+     * later.
+     *
+     * This is to avoid a circular model construction dependency between buidling a type
+     * inside an element and element itself. To build a content type, you need to have
+     * {@link CElementInfo} for a parent, so we can't take it as a constructor parameter.
+     */
+    public CElementInfo(Model model,QName tagName, CClassInfoParent parent, String className, CCustomizations customizations, Locator location ) {
+        this(model,tagName,parent,null,null,null,customizations,location);
+        this.className = className;
+    }
+
+    public void initContentType(TypeUse contentType, XSComponent source, XmlString defaultValue) {
+        assert this.property==null; // must not be called twice
+
+        this.property = new CElementPropertyInfo("Value",
+                contentType.isCollection()?REPEATED_VALUE:NOT_REPEATED,
+                contentType.idUse(),
+                contentType.getExpectedMimeType(),
+                source,null,location,true);
+        this.property.setAdapter(contentType.getAdapterUse());
+        property.getTypes().add(new CTypeRef((CNonElement)contentType.getInfo(),tagName,true,defaultValue));
+        this.type = NavigatorImpl.createParameterizedType(
+            NavigatorImpl.theInstance.ref(JAXBElement.class),
+            getContentInMemoryType() );
+    }
+
+    public final String getDefaultValue() {
+        return getProperty().getTypes().get(0).getDefaultValue();
+    }
+
+    public final JPackage _package() {
+        return parent.getOwnerPackage();
+    }
+
+    public CNonElement getContentType() {
+        return getProperty().ref().get(0);
+    }
+
+    public NType getContentInMemoryType() {
+        if(getProperty().getAdapter()==null) {
+            NType itemType = getContentType().getType();
+            if(!property.isCollection())
+                return itemType;
+
+            return NavigatorImpl.createParameterizedType(List.class,itemType);
+        } else {
+            return getProperty().getAdapter().customType;
+        }
+    }
+
+    public CElementPropertyInfo getProperty() {
+        return property;
+    }
+
+    public CClassInfo getScope() {
+        if(parent instanceof CClassInfo)
+            return (CClassInfo)parent;
+        return null;
+    }
+
+    /**
+     * @deprecated why are you calling a method that returns this?
+     */
+    public NType getType() {
+        return this;
+    }
+
+    public QName getElementName() {
+        return tagName;
+    }
+
+    public JType toType(Outline o, Aspect aspect) {
+        if(className==null)
+            return type.toType(o,aspect);
+        else
+            return o.getElement(this).implClass;
+    }
+
+    /**
+     * Returns the "squeezed name" of this element.
+     *
+     * @see CClassInfo#getSqueezedName()
+     */
+    @XmlElement
+    public String getSqueezedName() {
+        StringBuilder b = new StringBuilder();
+        CClassInfo s = getScope();
+        if(s!=null)
+            b.append(s.getSqueezedName());
+        if(className!=null)
+            b.append(className);
+        else
+            b.append( model.getNameConverter().toClassName(tagName.getLocalPart()));
+        return b.toString();
+    }
+
+    public void setAbstract() {
+        isAbstract = true;
+    }
+
+    public boolean isAbstract() {
+        return isAbstract;
+    }
+
+    public CElementInfo getSubstitutionHead() {
+        return substitutionHead;
+    }
+
+    public Collection<CElementInfo> getSubstitutionMembers() {
+        if(substitutionMembers==null)
+            return Collections.emptyList();
+        else
+            return substitutionMembers;
+    }
+
+    public void setSubstitutionHead(CElementInfo substitutionHead) {
+        // don't set it twice
+        assert this.substitutionHead==null;
+        assert substitutionHead!=null;
+        this.substitutionHead = substitutionHead;
+
+        if(substitutionHead.substitutionMembers==null)
+            substitutionHead.substitutionMembers = new HashSet<CElementInfo>();
+        substitutionHead.substitutionMembers.add(this);
+    }
+
+    public boolean isBoxedType() {
+        return false;
+    }
+
+    public String fullName() {
+        if(className==null)
+            return type.fullName();
+        else {
+            String r = parent.fullName();
+            if(r.length()==0)   return className;
+            else                return r+'.'+className;
+        }
+    }
+
+    public <T> T accept(Visitor<T> visitor) {
+        return visitor.onElement(this);
+    }
+
+    public JPackage getOwnerPackage() {
+        return parent.getOwnerPackage();
+    }
+
+    public String shortName() {
+        return className;
+    }
+
+    /**
+     * True if this element has its own class
+     * (as opposed to be represented as an instance of {@link JAXBElement}.
+     */
+    public boolean hasClass() {
+        return className!=null;
+    }
+
+    public Locator getLocator() {
+        return location;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElementPropertyInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElementPropertyInfo.java
new file mode 100644
index 0000000..a9dd6df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CElementPropertyInfo.java
@@ -0,0 +1,184 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.AbstractList;
+import java.util.ArrayList;
+import java.util.List;
+
+import javax.activation.MimeType;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.reader.RawTypeSet;
+import com.sun.xml.internal.bind.v2.model.core.ElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * {@link ElementPropertyInfo} for the compiler.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CElementPropertyInfo extends CPropertyInfo implements ElementPropertyInfo<NType,NClass> {
+
+    /**
+     * True if this property can never be absent legally.
+     */
+    private final boolean required;
+
+    private final MimeType expectedMimeType;
+    /**
+     *
+     * <p>
+     * Currently, this is set inside {@link RawTypeSet} in a very ugly way.
+     */
+    private CAdapter adapter;
+
+    private final boolean isValueList;
+
+    private ID id;
+
+
+    /**
+     * List of referenced types.
+     */
+    private final List<CTypeRef> types = new ArrayList<CTypeRef>();
+
+    private final List<CNonElement> ref = new AbstractList<CNonElement>() {
+        public CNonElement get(int index) {
+            return getTypes().get(index).getTarget();
+        }
+        public int size() {
+            return getTypes().size();
+        }
+    };
+
+    // TODO: shouldn't they get id and expectedMimeType from TypeUses of CTypeRef?
+    public CElementPropertyInfo(String name, CollectionMode collection, ID id, MimeType expectedMimeType, XSComponent source,
+                                CCustomizations customizations, Locator locator, boolean required) {
+        super(name, collection.col, source, customizations, locator);
+        this.required = required;
+        this.id = id;
+        this.expectedMimeType = expectedMimeType;
+        this.isValueList = collection.val;
+    }
+
+    public ID id() {
+        return id;
+    }
+
+    public List<CTypeRef> getTypes() {
+        return types;
+    }
+
+    public List<CNonElement> ref() {
+        return ref;
+    }
+
+    /**
+     * XJC never uses the wrapper element. Always return null.
+     */
+    @Deprecated
+    public QName getXmlName() {
+        return null;
+    }
+
+    public boolean isCollectionNillable() {
+        // in XJC, we never recognize a nillable collection pattern, so this is always false.
+        return false;
+    }
+
+    public boolean isRequired() {
+        return required;
+    }
+
+    public boolean isValueList() {
+        return isValueList;
+    }
+
+    public boolean isUnboxable() {
+        if(!isCollection() && !required)
+            // if the property can be legally absent, it's not unboxable
+            return false;
+        // we need to have null to represent the absence of value. not unboxable.
+        for (CTypeRef t : getTypes()) {
+            if(t.isNillable())
+                return false;
+        }
+        return super.isUnboxable();
+    }
+
+    @Override
+    public boolean isOptionalPrimitive() {
+        // we need to have null to represent the absence of value. not unboxable.
+        for (CTypeRef t : getTypes()) {
+            if(t.isNillable())
+                return false;
+        }
+        return !isCollection() && !required && super.isUnboxable();
+    }
+
+    public <V> V accept(CPropertyVisitor<V> visitor) {
+        return visitor.onElement(this);
+    }
+
+    public CAdapter getAdapter() {
+        return adapter;
+    }
+
+    public void setAdapter(CAdapter a) {
+        assert adapter==null;
+        adapter = a;
+    }
+
+    public final PropertyKind kind() {
+        return PropertyKind.ELEMENT;
+    }
+
+    public MimeType getExpectedMimeType() {
+        return expectedMimeType;
+    }
+
+    public static enum CollectionMode {
+        NOT_REPEATED(false,false),
+        REPEATED_ELEMENT(true,false),
+        REPEATED_VALUE(true,true);
+
+        private final boolean col,val;
+
+        CollectionMode(boolean col,boolean val) {
+            this.col = col;
+            this.val = val;
+        }
+
+        public boolean isRepeated() { return col; }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CEnumConstant.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CEnumConstant.java
new file mode 100644
index 0000000..ea788cd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CEnumConstant.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.xml.internal.bind.v2.model.core.EnumConstant;
+
+import org.xml.sax.Locator;
+
+/**
+ * Enumeration constant.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CEnumConstant implements EnumConstant<NType,NClass> {
+    /** Name of the constant. */
+    public final String name;
+    /** Javadoc comment. Can be null. */
+    public final String javadoc;
+    /** Lexical representation of this enum constant. Always non-null. */
+    private final String lexical;
+
+    private CEnumLeafInfo parent;
+
+    private final Locator locator;
+
+    /**
+     * @param name
+     */
+    public CEnumConstant(String name, String javadoc, String lexical, Locator loc) {
+        assert name!=null;
+        this.name = name;
+        this.javadoc = javadoc;
+        this.lexical = lexical;
+        this.locator = loc;
+    }
+
+    public CEnumLeafInfo getEnclosingClass() {
+        return parent;
+    }
+
+    /*package*/ void setParent(CEnumLeafInfo parent) {
+        this.parent = parent;
+    }
+
+    public String getLexicalValue() {
+        return lexical;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public Locator getLocator() {
+        return locator;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CEnumLeafInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CEnumLeafInfo.java
new file mode 100644
index 0000000..0a8d010
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CEnumLeafInfo.java
@@ -0,0 +1,274 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.Collection;
+
+import javax.activation.MimeType;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.EnumLeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XmlString;
+
+import org.xml.sax.Locator;
+
+/**
+ * Transducer that converts a string into an "enumeration class."
+ *
+ * The structure of the generated class needs to precisely
+ * follow the JAXB spec.
+ *
+ * @author
+ *    <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public final class CEnumLeafInfo implements EnumLeafInfo<NType,NClass>, NClass, CNonElement
+{
+    /**
+     * The {@link Model} object to which this bean belongs.
+     */
+    public final Model model;
+
+    /**
+     * The parent into which the enum class should be generated.
+     */
+    public final CClassInfoParent parent;
+
+    /**
+     * Short name of the generated type-safe enum.
+     */
+    public final String shortName;
+
+    private final QName typeName;
+
+    private final XSComponent source;
+
+    /**
+     * Represents the underlying type of this enumeration
+     * and its conversion.
+     *
+     * <p>
+     * To parse XML into a constant, we use the base type
+     * to do lexical -> value, then use a map to pick up the right one.
+     *
+     * <p>
+     * Hence this also represents the type of the Java value.
+     * For example, if this is an enumeration of xs:int,
+     * then this field will be Java int.
+     */
+    public final CNonElement base;
+
+
+    /**
+     * List of enum members.
+     */
+    public final Collection<CEnumConstant> members;
+
+    private final CCustomizations customizations;
+
+    /**
+     * @see #getLocator()
+     */
+    private final Locator sourceLocator;
+
+    public String javadoc;
+
+    public CEnumLeafInfo(Model model,
+                         QName typeName,
+                         CClassInfoParent container,
+                         String shortName,
+                         CNonElement base,
+                         Collection<CEnumConstant> _members,
+                         XSComponent source,
+                         CCustomizations customizations,
+                         Locator _sourceLocator) {
+        this.model = model;
+        this.parent = container;
+        this.shortName = shortName;
+        this.base = base;
+        this.members = _members;
+        this.source = source;
+        if(customizations==null)
+            customizations = CCustomizations.EMPTY;
+        this.customizations = customizations;
+        this.sourceLocator = _sourceLocator;
+        this.typeName = typeName;
+
+        for( CEnumConstant mem : members )
+            mem.setParent(this);
+
+        model.add(this);
+
+        // TODO: can we take advantage of the fact that enum can be XmlRootElement?
+    }
+
+    /**
+     * Source line information that points to the place
+     * where this type-safe enum is defined.
+     * Used to report error messages.
+     */
+    public Locator getLocator() {
+        return sourceLocator;
+    }
+
+    public QName getTypeName() {
+        return typeName;
+    }
+
+    public NType getType() {
+        return this;
+    }
+
+    /**
+     * @deprecated
+     *      why are you calling the method whose return value is known?
+     */
+    public boolean canBeReferencedByIDREF() {
+        return false;
+    }
+
+    public boolean isElement() {
+        return false;
+    }
+
+    public QName getElementName() {
+        return null;
+    }
+
+    public Element<NType,NClass> asElement() {
+        return null;
+    }
+
+    public NClass getClazz() {
+        return this;
+    }
+
+    public XSComponent getSchemaComponent() {
+        return source;
+    }
+
+    public JClass toType(Outline o, Aspect aspect) {
+        return o.getEnum(this).clazz;
+    }
+
+    public boolean isAbstract() {
+        return false;
+    }
+
+    public boolean isBoxedType() {
+        return false;
+    }
+
+    public String fullName() {
+        return parent.fullName()+'.'+shortName;
+    }
+
+    public boolean isPrimitive() {
+        return false;
+    }
+
+    public boolean isSimpleType() {
+        return true;
+    }
+
+
+    /**
+     * The spec says the value field in the enum class will be generated
+     * only under certain circumstances.
+     *
+     * @return
+     *      true if the generated enum class should have the value field.
+     */
+    public boolean needsValueField() {
+        for (CEnumConstant cec : members) {
+            if(!cec.getName().equals(cec.getLexicalValue()))
+                return true;
+        }
+        return false;
+    }
+
+    public JExpression createConstant(Outline outline, XmlString literal) {
+        // correctly identifying which constant it maps to is hard, so
+        // here I'm cheating
+        JClass type = toType(outline,Aspect.EXPOSED);
+        for (CEnumConstant mem : members) {
+            if(mem.getLexicalValue().equals(literal.value))
+                return type.staticRef(mem.getName());
+        }
+        return null;
+    }
+
+    public boolean isCollection() {
+        return false;
+    }
+
+    public CAdapter getAdapterUse() {
+        return null;
+    }
+
+    public CTypeInfo getInfo() {
+        return this;
+    }
+
+    public ID idUse() {
+        return ID.NONE;
+    }
+
+    public MimeType getExpectedMimeType() {
+        return null;
+    }
+
+    public Collection<CEnumConstant> getConstants() {
+        return members;
+    }
+
+    public NonElement<NType,NClass> getBaseType() {
+        return base;
+    }
+
+    public CCustomizations getCustomizations() {
+        return customizations;
+    }
+
+    public Locatable getUpstream() {
+        throw new UnsupportedOperationException();
+    }
+
+    public Location getLocation() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CNonElement.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CNonElement.java
new file mode 100644
index 0000000..a8856ab
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CNonElement.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface CNonElement extends NonElement<NType,NClass>, CTypeInfo {
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPluginCustomization.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPluginCustomization.java
new file mode 100644
index 0000000..6858f69
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPluginCustomization.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.tools.internal.xjc.Plugin;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+
+/**
+ * Vendor extension customization contributed from {@link Plugin}s.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class CPluginCustomization {
+    /**
+     * The annotation found in a schema (or in an external binding file.)
+     *
+     * Always non-null.
+     */
+    public final Element element;
+
+    /**
+     * The source location where this customization is placed.
+     *
+     * <p>
+     * When an error is found in this customization, this information
+     * should be used to point the user to the source of the problem.
+     *
+     * Always non-nul.
+     */
+    public final Locator locator;
+
+    private boolean acknowledged;
+
+    /**
+     * When a {@link Plugin} "uses" this annotation, call this method
+     * to mark it.
+     *
+     * <p>
+     * {@link CPluginCustomization}s that are not marked will be
+     * reporeted as an error to users. This allows us to catch
+     * customizations that are not used by anybody.
+     */
+    public void markAsAcknowledged() {
+        acknowledged = true;
+    }
+
+    public CPluginCustomization(Element element, Locator locator) {
+        this.element = element;
+        this.locator = locator;
+    }
+
+    public boolean isAcknowledged() {
+        return acknowledged;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPropertyInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPropertyInfo.java
new file mode 100644
index 0000000..5577dae
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPropertyInfo.java
@@ -0,0 +1,285 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.Collection;
+
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JJavaName;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRenderer;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.RuntimeUtil;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class CPropertyInfo implements PropertyInfo<NType,NClass>, CCustomizable {
+
+    @XmlTransient
+    private CClassInfo parent;
+    private String privateName;
+    private String publicName;
+    private final boolean isCollection;
+
+    @XmlTransient
+    public final Locator locator;
+
+    /**
+     * @see #getSchemaComponent()
+     */
+    private final XSComponent source;
+
+    /**
+     * If the base type of the property is overriden,
+     * this field is set to non-null.
+     */
+    public JType baseType;
+
+    /**
+     * Javadoc for this property. Must not be null.
+     */
+    public String javadoc="";
+
+    /**
+     * Specifies how the field is generated by the backedn.
+     */
+    @XmlJavaTypeAdapter(RuntimeUtil.ToStringAdapter.class)
+    public FieldRenderer realization;
+
+    /**
+     * If non-null, keeps the default value in Java representation.
+     *
+     * If {@link #isCollection} is true, this field is always null,
+     * for we don't handle default values for a list.
+     */
+    public CDefaultValue defaultValue;
+
+    private final CCustomizations customizations;
+    /**
+     * @see #getSchemaType()
+     */
+    public QName schemaType;
+
+    protected CPropertyInfo(String name, boolean collection, XSComponent source,
+                            CCustomizations customizations, Locator locator) {
+        this.publicName = name;
+        String n = NameConverter.standard.toVariableName(name);
+        if(!JJavaName.isJavaIdentifier(n))
+            n = '_'+n;  // avoid colliding with the reserved names like 'abstract'.
+        this.privateName = n;
+
+        this.isCollection = collection;
+        this.locator = locator;
+        if(customizations==null)
+            this.customizations = CCustomizations.EMPTY;
+        else
+            this.customizations = customizations;
+        this.source = source;
+    }
+
+    // called from CClassInfo when added
+    final void setParent( CClassInfo parent ) {
+        assert this.parent==null;
+        assert parent!=null;
+        this.parent = parent;
+        customizations.setParent(parent.model,this);
+    }
+
+    public CTypeInfo parent() {
+        return parent;
+    }
+
+    public Locator getLocator() {
+        return locator;
+    }
+
+    /**
+     * If this model object is built from XML Schema,
+     * this property returns a schema component from which the model is built.
+     *
+     * @return
+     *      null if the model is built from sources other than XML Schema
+     *      (such as DTD.)
+     */
+    public final XSComponent getSchemaComponent() {
+        return source;
+    }
+
+    public abstract CAdapter getAdapter();
+
+    /**
+     * Name of the property.
+     *
+     * <p>
+     * This method is implemented to follow the contract of
+     * {@link PropertyInfo#getName()}, and therefore it always
+     * returns the name of the annotated field.
+     * <p>
+     * This name is normally not useful for the rest of XJC,
+     * which usually wants to access the "public name" of the property.
+     * A "public name" of the property is a name like "FooBar" which
+     * is used as a seed for generating the accessor methods.
+     * This is the name controlled by the schema customization via users.
+     *
+     * <p>
+     * If the caller is calling this method statically, it's usually
+     * the sign of a mistake. Use {@link #getName(boolean)} method instead,
+     * which forces you to think about which name you want to get.
+     *
+     * @deprecated
+     *      marked as deprecated so that we can spot the use of this method.
+     *
+     * @see #getName(boolean)
+     */
+    public String getName() {
+        return getName(false);
+    }
+
+    /**
+     * Gets the name of the property.
+     *
+     * @param isPublic
+     *      if true, this method returns a name like "FooBar", which
+     *      should be used as a seed for generating user-visible names
+     *      (such as accessors like "getFooBar".)
+     *
+     *      <p>
+     *      if false, this method returns the "name of the property"
+     *      as defined in the j2s side of the spec. This name is usually
+     *      something like "fooBar", which often corresponds to the XML
+     *      element/attribute name of this property (for taking advantage
+     *      of annotation defaulting as much as possible)
+     */
+    public String getName(boolean isPublic) {
+        return isPublic?publicName:privateName;
+    }
+
+    /**
+     * Overrides the name of the property.
+     *
+     * This method can be used from {@link Plugin#postProcessModel(Model, ErrorHandler)}.
+     * But the caller should do so with the understanding that this is inherently
+     * dangerous method.
+     */
+    public void setName(boolean isPublic, String newName) {
+        if(isPublic)
+            publicName = newName;
+        else
+            privateName = newName;
+    }
+
+    public String displayName() {
+        return parent.toString()+'#'+getName(false);
+    }
+
+    public boolean isCollection() {
+        return isCollection;
+    }
+
+
+    public abstract Collection<? extends CTypeInfo> ref();
+
+    /**
+     * Returns true if this property is "unboxable".
+     *
+     * <p>
+     * In general, a property often has to be capable of representing null
+     * to indicate the absence of the value. This requires properties
+     * to be generated as <tt>@XmlElement Float f</tt>, not as
+     * <tt>@XmlElement float f;</tt>. But this is slow.
+     *
+     * <p>
+     * Fortunately, there are cases where we know that the property can
+     * never legally be absent. When this condition holds we can generate
+     * the optimized "unboxed form".
+     *
+     * <p>
+     * The exact such conditions depend
+     * on the kind of properties, so refer to the implementation code
+     * for the details.
+     *
+     * <p>
+     * This method returns true when the property can be generated
+     * as "unboxed form", false otherwise.
+     *
+     * <p>
+     * When this property is a collection, this method returns true
+     * if items in the collection is unboxable. Obviously, the collection
+     * itself is always a reference type.
+     */
+    public boolean isUnboxable() {
+        Collection<? extends CTypeInfo> ts = ref();
+        if(ts.size()!=1)
+            // if the property is heterogeneous, no way.
+            // ts.size()==0 is a special case that can happen for wildcards.
+            return false;
+
+        if(baseType!=null && (baseType instanceof JClass))
+            return false;
+
+        CTypeInfo t = ts.iterator().next();
+        // only a primitive type is eligible.
+        return t.getType().isBoxedType();
+    }
+
+    /**
+     * Returns true if this property needs to represent null
+     * just for the purpose of representing an absence of the property.
+     */
+    public boolean isOptionalPrimitive() {
+        return false;
+    }
+
+    public CCustomizations getCustomizations() {
+        return customizations;
+    }
+
+    public QName getSchemaType() {
+        return schemaType;
+    }
+
+    /**
+     * @deprecated if you are calling this method directly, there's something wrong.
+     */
+    public boolean inlineBinaryData() {
+        return false;
+    }
+
+    public abstract <V> V accept( CPropertyVisitor<V> visitor );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPropertyVisitor.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPropertyVisitor.java
new file mode 100644
index 0000000..8e5c9d6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CPropertyVisitor.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+/**
+ * Visitor for {@link CPropertyInfo}.
+ *
+ * Ideally it should be defined on the runtime core model, but the runtime is on diet.
+ * Hence it's defined here.
+ *
+ * @see CPropertyInfo#accept(CPropertyVisitor)
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface CPropertyVisitor<V> {
+    V onElement( CElementPropertyInfo p );
+    V onAttribute( CAttributePropertyInfo p );
+    V onValue( CValuePropertyInfo p );
+    V onReference( CReferencePropertyInfo p );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CReferencePropertyInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CReferencePropertyInfo.java
new file mode 100644
index 0000000..ae686bc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CReferencePropertyInfo.java
@@ -0,0 +1,190 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.Set;
+
+import javax.activation.MimeType;
+import javax.xml.bind.annotation.W3CDomHandler;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.model.nav.NavigatorImpl;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.ReferencePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * {@link ReferencePropertyInfo} for the compiler.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CReferencePropertyInfo extends CPropertyInfo implements ReferencePropertyInfo<NType,NClass> {
+
+    /**
+     * List of referenced elements.
+     */
+    private final Set<CElement> elements = new HashSet<CElement>();
+
+    private final boolean isMixed;
+    private WildcardMode wildcard;
+
+    public CReferencePropertyInfo(String name, boolean collection, boolean isMixed, XSComponent source,
+                                  CCustomizations customizations, Locator locator) {
+        super(name, collection||isMixed, source, customizations, locator );
+        this.isMixed = isMixed;
+    }
+
+    public Set<? extends CTypeInfo> ref() {
+//        if(wildcard==null && !isMixed())
+//            return getElements();
+
+        // ugly hack to get the signature right for substitution groups
+        // when a class is generated for elements,they don't form a nice type hierarchy,
+        // so the Java types of the substitution members need to be taken into account
+        // when computing the signature
+
+        final class RefList extends HashSet<CTypeInfo> {
+            RefList() {
+                super(elements.size());
+                addAll(elements);
+            }
+            @Override
+            public boolean addAll( Collection<? extends CTypeInfo> col ) {
+                boolean r = false;
+                for (CTypeInfo e : col) {
+                    if(e instanceof CElementInfo) {
+                        // UGLY. element substitution is implemented in a way that
+                        // the derived elements are not assignable to base elements.
+                        // so when we compute the signature, we have to take derived types
+                        // into account
+                        r |= addAll( ((CElementInfo)e).getSubstitutionMembers());
+                    }
+                    r |= add(e);
+                }
+                return r;
+            }
+        }
+
+        RefList r = new RefList();
+        if(wildcard!=null) {
+            if(wildcard.allowDom)
+                r.add(CWildcardTypeInfo.INSTANCE);
+            if(wildcard.allowTypedObject)
+                // we aren't really adding an AnyType.
+                // this is a kind of hack to generate Object as a signature
+                r.add(CBuiltinLeafInfo.ANYTYPE);
+        }
+        if(isMixed())
+            r.add(CBuiltinLeafInfo.STRING);
+
+
+        return r;
+    }
+
+    public Set<CElement> getElements() {
+        return elements;
+    }
+
+    public boolean isMixed() {
+        return isMixed;
+    }
+
+    /**
+     * We'll never use a wrapper element in XJC. Always return null.
+     */
+    @Deprecated
+    public QName getXmlName() {
+        return null;
+    }
+
+    /**
+     * Reference properties refer to elements, and none of the Java primitive type
+     * maps to an element. Thus a reference property is always unboxable.
+     */
+    @Override
+    public boolean isUnboxable() {
+        return false;
+    }
+
+    // the same as above
+    @Override
+    public boolean isOptionalPrimitive() {
+        return false;
+    }
+
+    public <V> V accept(CPropertyVisitor<V> visitor) {
+        return visitor.onReference(this);
+    }
+
+    public CAdapter getAdapter() {
+        return null;
+    }
+
+    public final PropertyKind kind() {
+        return PropertyKind.REFERENCE;
+    }
+
+    /**
+     * A reference property can never be ID/IDREF because they always point to
+     * other element classes.
+     */
+    public ID id() {
+        return ID.NONE;
+    }
+
+    public WildcardMode getWildcard() {
+        return wildcard;
+    }
+
+    public void setWildcard(WildcardMode mode) {
+        this.wildcard = mode;
+    }
+
+    public NClass getDOMHandler() {
+        // TODO: support other DOM handlers
+        if(getWildcard()!=null)
+            return NavigatorImpl.create(W3CDomHandler.class);
+        else
+            return null;
+    }
+
+    public MimeType getExpectedMimeType() {
+        return null;
+    }
+
+    public boolean isCollectionNillable() {
+        // in XJC, we never recognize a nillable collection pattern, so this is always false.
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CSingleTypePropertyInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CSingleTypePropertyInfo.java
new file mode 100644
index 0000000..e8bf710
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CSingleTypePropertyInfo.java
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.Collections;
+import java.util.List;
+
+import javax.activation.MimeType;
+
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class CSingleTypePropertyInfo extends CPropertyInfo {
+    protected final TypeUse type;
+
+    protected CSingleTypePropertyInfo(String name, TypeUse type, XSComponent source, CCustomizations customizations, Locator locator) {
+        super(name, type.isCollection(), source, customizations, locator);
+        this.type = type;
+    }
+
+    public final ID id() {
+        return type.idUse();
+    }
+
+    public final MimeType getExpectedMimeType() {
+        return type.getExpectedMimeType();
+    }
+
+    public final List<? extends CTypeInfo> ref() {
+        return Collections.singletonList(getTarget());
+    }
+
+    public final CNonElement getTarget() {
+        CNonElement r = (CNonElement)type.getInfo();
+        assert r!=null;
+        return r;
+    }
+
+    public final CAdapter getAdapter() {
+        return type.getAdapterUse();
+    }
+
+    public final CSingleTypePropertyInfo getSource() {
+        return this;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CTypeInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CTypeInfo.java
new file mode 100644
index 0000000..ba9dc24
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CTypeInfo.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.xsom.XmlString;
+
+/**
+ * {@link TypeInfo} at the compile-time.
+ * Either {@link CClassInfo}, {@link CBuiltinLeafInfo}, or {@link CElementInfo}.
+ *
+ * <p>
+ * This interface implements {@link TypeUse} so that a {@link CTypeInfo}
+ * instance can be used as a {@link TypeUse} instance.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface CTypeInfo extends TypeInfo<NType,NClass>, TypeUse, CCustomizable {
+
+    /**
+     * Returns the {@link JClass} that represents the class being bound,
+     * under the given {@link Outline}.
+     *
+     * @see NType#toType(Outline, Aspect)
+     */
+    JType toType(Outline o, Aspect aspect);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CTypeRef.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CTypeRef.java
new file mode 100644
index 0000000..a9e7c66
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CTypeRef.java
@@ -0,0 +1,103 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeRef;
+import com.sun.xml.internal.bind.v2.runtime.RuntimeUtil;
+import com.sun.xml.internal.xsom.XmlString;
+
+/**
+ * {@link TypeRef} for XJC.
+ *
+ * TODO: do we need the source schema component support here?
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CTypeRef implements TypeRef<NType,NClass> {
+    /**
+     * In-memory type.
+     *
+     * This is the type used when
+     */
+    @XmlJavaTypeAdapter(RuntimeUtil.ToStringAdapter.class)
+    private final CNonElement type;
+
+    private final QName elementName;
+
+    private final boolean nillable;
+    public final XmlString defaultValue;
+
+    public CTypeRef(CNonElement type, QName elementName, boolean nillable, XmlString defaultValue) {
+        assert type!=null;
+        assert elementName!=null;
+
+        this.type = type;
+        this.elementName = elementName;
+        this.nillable = nillable;
+        this.defaultValue = defaultValue;
+    }
+
+    public CNonElement getTarget() {
+        return type;
+    }
+
+    public QName getTagName() {
+        return elementName;
+    }
+
+    public boolean isNillable() {
+        return nillable;
+    }
+
+    /**
+     * Inside XJC, use {@link #defaultValue} that has context information.
+     * This method is to override the one defined in the runtime model.
+     *
+     * @see #defaultValue
+     */
+    public String getDefaultValue() {
+        if(defaultValue!=null)
+            return defaultValue.value;
+        else
+            return null;
+    }
+
+    public boolean isLeaf() {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public PropertyInfo<NType, NClass> getSource() {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CValuePropertyInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CValuePropertyInfo.java
new file mode 100644
index 0000000..316225d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CValuePropertyInfo.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.ValuePropertyInfo;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * {@link ValuePropertyInfo} implementation for XJC.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CValuePropertyInfo extends CSingleTypePropertyInfo implements ValuePropertyInfo<NType,NClass> {
+    public CValuePropertyInfo(String name, XSComponent source, CCustomizations customizations, Locator locator, TypeUse type) {
+        super(name, type, source, customizations, locator);
+    }
+
+    public final PropertyKind kind() {
+        return  PropertyKind.VALUE;
+    }
+
+    public <V> V accept(CPropertyVisitor<V> visitor) {
+        return visitor.onValue(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CWildcardTypeInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CWildcardTypeInfo.java
new file mode 100644
index 0000000..793797f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/CWildcardTypeInfo.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.model.nav.NavigatorImpl;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.core.WildcardTypeInfo;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+
+/**
+ * {@link CTypeInfo} for the DOM node.
+ *
+ * TODO: support other DOM models.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CWildcardTypeInfo extends AbstractCTypeInfoImpl implements WildcardTypeInfo<NType,NClass> {
+    private CWildcardTypeInfo() {
+        super(null,null,null);
+    }
+
+    public static final CWildcardTypeInfo INSTANCE = new CWildcardTypeInfo();
+
+    public JType toType(Outline o, Aspect aspect) {
+        return o.getCodeModel().ref(Element.class);
+    }
+
+    public NType getType() {
+        return NavigatorImpl.create(Element.class);
+    }
+
+    public Locator getLocator() {
+        return Model.EMPTY_LOCATOR;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/ClassNameAllocatorWrapper.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/ClassNameAllocatorWrapper.java
new file mode 100644
index 0000000..4fc6936
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/ClassNameAllocatorWrapper.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.api.ClassNameAllocator;
+
+/**
+ * Wraps {@link ClassNameAllocator} and provides convenience.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ClassNameAllocatorWrapper implements ClassNameAllocator {
+    private final ClassNameAllocator core;
+
+    ClassNameAllocatorWrapper(ClassNameAllocator core) {
+        if(core==null)
+            core = new ClassNameAllocator() {
+                public String assignClassName(String packageName, String className) {
+                    return className;
+                }
+            };
+        this.core = core;
+    }
+
+    public String assignClassName(String packageName, String className) {
+        return core.assignClassName(packageName,className);
+    }
+
+    public String assignClassName(JPackage pkg, String className) {
+        return core.assignClassName(pkg.name(),className);
+    }
+
+    public String assignClassName(CClassInfoParent parent, String className) {
+        if (parent instanceof CClassInfoParent.Package) {
+            CClassInfoParent.Package p = (CClassInfoParent.Package) parent;
+            return assignClassName(p.pkg,className);
+        }
+        // not a package-level class
+        return className;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Constructor.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Constructor.java
new file mode 100644
index 0000000..1b139a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Constructor.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+/**
+ * Constructor declaration.
+ *
+ * <p>
+ * a constructor declaration consists of a set of fields to be initialized.
+ * For example, if a class is defined as:
+ *
+ * <pre>
+ * Class: Foo
+ *   Field: String a
+ *   Field: int b
+ *   Field: BigInteger c
+ * </pre>
+ *
+ * Then a constructor declaration of {"a","c"} will conceptually
+ * generate the following consturctor:
+ *
+ * <pre>
+ * Foo( String _a, BigInteger _c ) {
+ *   a=_a; c=_c;
+ * }
+ * </pre>
+ *
+ * (Only conceptually, because Foo will likely to become an interface
+ * so we can't simply generate a constructor like this.)
+ *
+ * @author
+ *    <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public class Constructor
+{
+    // Since Constructor is typically built when there is no FieldItem
+    // nor FieldUse, we need to rely on Strings.
+    public Constructor( String[] _fields ) { this.fields = _fields; }
+
+    /** array of field names to be initialized. */
+    public final String[] fields;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Model.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Model.java
new file mode 100644
index 0000000..f9d3062
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Model.java
@@ -0,0 +1,437 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.LinkedHashMap;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Result;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.tools.internal.xjc.api.ClassNameAllocator;
+import com.sun.tools.internal.xjc.generator.bean.BeanGenerator;
+import com.sun.tools.internal.xjc.generator.bean.ImplStructureStrategy;
+import com.sun.tools.internal.xjc.model.nav.NClass;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.model.nav.NavigatorImpl;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.tools.internal.xjc.reader.xmlschema.Messages;
+import com.sun.tools.internal.xjc.util.ErrorReceiverFilter;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.bind.v2.model.core.Ref;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.util.FlattenIterator;
+
+import org.xml.sax.Locator;
+import org.xml.sax.helpers.LocatorImpl;
+
+/**
+ * Root of the object model that represents the code that needs to be generated.
+ *
+ * <p>
+ * A {@link Model} is a schema language neutral representation of the
+ * result of a scehma parsing. The back-end then works against this model
+ * to turn this into a series of Java source code.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Model implements TypeInfoSet<NType,NClass,Void,Void> {
+
+    /**
+     * Generated beans.
+     */
+    private final Map<NClass,CClassInfo> beans = new LinkedHashMap<NClass,CClassInfo>();
+
+    /**
+     * Generated enums.
+     */
+    private final Map<NClass,CEnumLeafInfo> enums = new LinkedHashMap<NClass,CEnumLeafInfo>();
+
+    /**
+     * The element mappings.
+     */
+    private final Map<NClass/*scope*/,Map<QName,CElementInfo>> elementMappings =
+        new HashMap<NClass,Map<QName,CElementInfo>>();
+
+    private final Iterable<? extends CElementInfo> allElements =
+        new Iterable<CElementInfo>() {
+            public Iterator<CElementInfo> iterator() {
+                return new FlattenIterator<CElementInfo>(elementMappings.values());
+            }
+        };
+
+    /**
+     * {@link TypeUse}s for all named types.
+     * <p>
+     * I really don't want to promote the notion of a 'type' in any place except in the XML Schema code,
+     * but this needs to be exposed for JAX-RPC. A reference to a named XML type will be converted into
+     * a reference to a Java type with annotations.
+     */
+    private final Map<QName,TypeUse> typeUses = new LinkedHashMap<QName, TypeUse>();
+
+    /**
+     * {@link NameConverter} to be used.
+     */
+    private NameConverter nameConverter;
+
+    /**
+     * Single linked list that connects all {@link CCustomizations} that belong to this model.
+     *
+     * @see CCustomizations#next
+     */
+    /*package*/ CCustomizations customizations;
+
+    /**
+     * This field controls the generation of package level annotations for s2j
+     */
+    private boolean packageLevelAnnotations = true;
+
+    /**
+     * @param nc
+     *      Usually this should be set in the constructor, but we do allow this parameter
+     *      to be initially null, and then set later.
+     */
+    public Model( Options opts, JCodeModel cm, NameConverter nc, ClassNameAllocator allocator ) {
+        this.options = opts;
+        this.codeModel = cm;
+        this.nameConverter = nc;
+        this.defaultSymbolSpace = new SymbolSpace(codeModel);
+        defaultSymbolSpace.setType(codeModel.ref(Object.class));
+
+        elementMappings.put(null,new HashMap<QName,CElementInfo>());
+
+        this.allocator = new ClassNameAllocatorWrapper(allocator);
+    }
+
+    public void setNameConverter(NameConverter nameConverter) {
+        assert this.nameConverter==null;
+        assert nameConverter!=null;
+        this.nameConverter = nameConverter;
+    }
+
+    /**
+     * Gets the name converter that shall be used to parse XML names into Java names.
+     */
+    public final NameConverter getNameConverter() {
+        return nameConverter;
+    }
+
+    public boolean isPackageLevelAnnotations() {
+        return packageLevelAnnotations;
+    }
+
+    public void setPackageLevelAnnotations(boolean packageLevelAnnotations) {
+        this.packageLevelAnnotations = packageLevelAnnotations;
+    }
+
+    /**
+     * This model uses this code model exclusively.
+     */
+    @XmlTransient
+    public final JCodeModel codeModel;
+
+    /**
+     * Command-line options used for building this model.
+     */
+    public final Options options;
+
+    /**
+     * True to generate serializable classes.
+     */
+    @XmlAttribute
+    public boolean serializable;
+
+    /**
+     * serial version UID to be generated.
+     *
+     * null if not to generate serialVersionUID field.
+     */
+    @XmlAttribute
+    public Long serialVersionUID;
+
+    /**
+     * If non-null, all the generated classes should eventually derive from this class.
+     */
+    @XmlTransient
+    public JClass rootClass;
+
+    /**
+     * If non-null, all the generated interfaces should eventually derive from this interface.
+     */
+    @XmlTransient
+    public JClass rootInterface;
+
+    /**
+     * Specifies the code generation strategy.
+     * Must not be null.
+     */
+    public ImplStructureStrategy strategy = ImplStructureStrategy.BEAN_ONLY;
+
+    /**
+     * This allocator has the final say on deciding the class name.
+     * Must not be null.
+     *
+     * <p>
+     * Model classes are responsible for using the allocator.
+     * This allocator interaction should be transparent to the user/builder
+     * of the model.
+     */
+    /*package*/ final ClassNameAllocatorWrapper allocator;
+
+    /**
+     * Default ID/IDREF symbol space. Any ID/IDREF without explicit
+     * reference to a symbol space is assumed to use this default
+     * symbol space.
+     */
+    @XmlTransient
+    public final SymbolSpace defaultSymbolSpace;
+
+    /** All the defined {@link SymbolSpace}s keyed by their name. */
+    private final Map<String,SymbolSpace> symbolSpaces = new HashMap<String,SymbolSpace>();
+
+    public SymbolSpace getSymbolSpace( String name ) {
+        SymbolSpace ss = symbolSpaces.get(name);
+        if(ss==null)
+            symbolSpaces.put(name,ss=new SymbolSpace(codeModel));
+        return ss;
+    }
+
+    /**
+     * Fully-generate the source code into the given model.
+     *
+     * @return
+     *      null if there was any errors. Otherwise it returns a valid
+     *      {@link Outline} object, which captures how the model objects
+     *      are mapped to the generated source code.
+     *      <p>
+     *      Add-ons can use those information to further augment the generated
+     *      source code.
+     */
+    public Outline generateCode(Options opt,ErrorReceiver receiver) {
+        ErrorReceiverFilter ehf = new ErrorReceiverFilter(receiver);
+
+        // run extensions
+        for( Plugin ma : opt.activePlugins )
+            ma.postProcessModel(this,ehf);
+
+        Outline o = BeanGenerator.generate(this, ehf);
+
+        // run extensions
+        for( Plugin ma : opt.activePlugins )
+            ma.run(o,opt,ehf);
+
+        // check for unused plug-in customizations.
+        // these can be only checked after the plug-ins run, so it's here.
+        // the JAXB bindings are checked by XMLSchema's builder.
+        Set<CCustomizations> check = new HashSet<CCustomizations>();
+        for( CCustomizations c=customizations; c!=null; c=c.next ) {
+            if(!check.add(c)) {
+                throw new AssertionError(); // detect a loop
+            }
+            for (CPluginCustomization p : c) {
+                if(!p.isAcknowledged()) {
+                    ehf.error(
+                        p.locator,
+                        Messages.format(
+                            Messages.ERR_UNACKNOWLEDGED_CUSTOMIZATION,
+                            p.element.getNodeName()
+                        ));
+                    ehf.error(
+                        c.getOwner().getLocator(),
+                        Messages.format(
+                            Messages.ERR_UNACKNOWLEDGED_CUSTOMIZATION_LOCATION));
+                }
+            }
+        }
+
+        if(ehf.hadError())
+            o = null;
+        return o;
+    }
+
+    /**
+     * Represents the "top-level binding".
+     *
+     * <p>
+     * This is used to support the use of a schema inside WSDL.
+     * For XML Schema, the top-level binding is a map from
+     * global element declarations to its representation class.
+     *
+     * <p>
+     * For other schema languages, it should follow the appendicies in
+     * WSDL (but in practice no one would use WSDL with a schema language
+     * other than XML Schema, so it doesn't really matter.)
+     *
+     * <p>
+     * This needs to be filled by the front-end.
+     */
+    public final Map<QName,CClassInfo> createTopLevelBindings() {
+        Map<QName,CClassInfo> r = new HashMap<QName,CClassInfo>();
+        for( CClassInfo b : beans().values() ) {
+            if(b.isElement())
+                r.put(b.getElementName(),b);
+        }
+        return r;
+    }
+
+    public Navigator<NType,NClass,Void,Void> getNavigator() {
+        return NavigatorImpl.theInstance;
+    }
+
+    public CNonElement getTypeInfo(NType type) {
+        CBuiltinLeafInfo leaf = CBuiltinLeafInfo.LEAVES.get(type);
+        if(leaf!=null)      return leaf;
+
+        return getClassInfo(getNavigator().asDecl(type));
+    }
+
+    public CBuiltinLeafInfo getAnyTypeInfo() {
+        return CBuiltinLeafInfo.ANYTYPE;
+    }
+
+    public CNonElement getTypeInfo(Ref<NType,NClass> ref) {
+        // TODO: handle XmlValueList
+        assert !ref.valueList;
+        return getTypeInfo(ref.type);
+    }
+
+    public Map<NClass,CClassInfo> beans() {
+        return beans;
+    }
+
+    public Map<NClass,CEnumLeafInfo> enums() {
+        return enums;
+    }
+
+    public Map<QName,TypeUse> typeUses() {
+        return typeUses;
+    }
+
+    /**
+     * No array mapping generation for XJC.
+     */
+    public Map<NType, ? extends CArrayInfo> arrays() {
+        return Collections.emptyMap();
+    }
+
+    public Map<NType, ? extends CBuiltinLeafInfo> builtins() {
+        return CBuiltinLeafInfo.LEAVES;
+    }
+
+    public CClassInfo getClassInfo(NClass t) {
+        return beans.get(t);
+    }
+
+    public CElementInfo getElementInfo(NClass scope,QName name) {
+        Map<QName,CElementInfo> m = elementMappings.get(scope);
+        if(m!=null) {
+            CElementInfo r = m.get(name);
+            if(r!=null)     return r;
+        }
+        return elementMappings.get(null).get(name);
+    }
+
+    public Map<QName,CElementInfo> getElementMappings(NClass scope) {
+        return elementMappings.get(scope);
+    }
+
+    public Iterable<? extends CElementInfo> getAllElements() {
+        return allElements;
+    }
+
+    /**
+     * Not implemented in the compile-time model.
+     */
+    public Map<String, String> getXmlNs(String namespaceUri) {
+        return Collections.emptyMap();
+    }
+
+    public XmlNsForm getElementFormDefault(String nsUri) {
+        throw new UnsupportedOperationException();
+    }
+
+    public XmlNsForm getAttributeFormDefault(String nsUri) {
+        throw new UnsupportedOperationException();
+    }
+
+    public void dump(Result out) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    /*package*/ void add( CEnumLeafInfo e ) {
+        enums.put( e.getClazz(), e );
+    }
+
+    /*package*/ void add( CClassInfo ci ) {
+        beans.put( ci.getClazz(), ci );
+    }
+
+    /*package*/ void add( CElementInfo ei ) {
+        NClass clazz = null;
+        if(ei.getScope()!=null)
+            clazz = ei.getScope().getClazz();
+
+        Map<QName,CElementInfo> m = elementMappings.get(clazz);
+        if(m==null)
+            elementMappings.put(clazz,m=new HashMap<QName,CElementInfo>());
+        m.put(ei.getElementName(),ei);
+    }
+
+
+    private final Map<JPackage,CClassInfoParent.Package> cache = new HashMap<JPackage,CClassInfoParent.Package>();
+
+    public CClassInfoParent.Package getPackage(JPackage pkg) {
+        CClassInfoParent.Package r = cache.get(pkg);
+        if(r==null)
+            cache.put(pkg,r=new CClassInfoParent.Package(pkg));
+        return r;
+    }
+
+    /*package*/ static final Locator EMPTY_LOCATOR;
+
+    static {
+        LocatorImpl l = new LocatorImpl();
+        l.setColumnNumber(-1);
+        l.setLineNumber(-1);
+        EMPTY_LOCATOR = l;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Multiplicity.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Multiplicity.java
new file mode 100644
index 0000000..4cdbd4b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Multiplicity.java
@@ -0,0 +1,195 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+
+
+/**
+ * represents a possible number of occurence.
+ *
+ * Usually, denoted by a pair of integers like (1,1) or (5,10).
+ * A special value "unbounded" is allowed as the upper bound.
+ *
+ * <p>
+ * For example, (0,unbounded) corresponds to the '*' occurence of DTD.
+ * (0,1) corresponds to the '?' occurence of DTD.
+ *
+ * @author
+ *    <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public final class Multiplicity {
+    public final int min;
+    public final Integer max;    // null is used to represent "unbounded".
+
+    public static Multiplicity create( int min, Integer max ) {
+        if(min==0 && max==null) return STAR;
+        if(min==1 && max==null) return PLUS;
+        if(max!=null) {
+            if(min==0 && max==0)    return ZERO;
+            if(min==0 && max==1)    return OPTIONAL;
+            if(min==1 && max==1)    return ONE;
+        }
+        return new Multiplicity(min,max);
+    }
+
+    private Multiplicity( int min, Integer max ) {
+        this.min = min; this.max = max;
+    }
+
+    public boolean equals(Object o) {
+        if (!(o instanceof Multiplicity)) return false;
+
+        Multiplicity that = (Multiplicity) o;
+
+        if (this.min != that.min) return false;
+        if (this.max != null ? !this.max.equals(that.max) : that.max != null) return false;
+
+        return true;
+    }
+
+    public int hashCode() {
+        int result;
+        result = min;
+        result = 29 * result + (max != null ? max.hashCode() : 0);
+        return result;
+    }
+
+    /** returns true if the multiplicity is (1,1). */
+    public boolean isUnique() {
+        if(max==null)    return false;
+        return min==1 && max==1;
+    }
+
+    /** returns true if the multiplicity is (0,1) */
+    public boolean isOptional() {
+        if(max==null) return false;
+        return min==0 && max==1;
+    }
+
+    /** returns true if the multiplicity is (0,1) or (1,1). */
+    public boolean isAtMostOnce() {
+        if(max==null)    return false;
+        return max<=1;
+    }
+
+    /** returns true if the multiplicity is (0,0). */
+    public boolean isZero() {
+        if(max==null)    return false;
+        return max==0;
+    }
+
+    /**
+     * Returns true if the multiplicity represented by this object
+     * completely includes the multiplicity represented by the
+     * other object. For example, we say [1,3] includes [1,2] but
+     * [2,4] doesn't include [1,3].
+     */
+    public boolean includes( Multiplicity rhs ) {
+        if( rhs.min<min )   return false;
+        if( max==null )     return true;
+        if( rhs.max==null ) return false;
+        return rhs.max <= max;
+    }
+
+    /**
+     * Returns the string representation of the 'max' property.
+     * Either a number or a token "unbounded".
+     */
+    public String getMaxString() {
+        if(max==null)       return "unbounded";
+        else                return max.toString();
+    }
+
+    /** gets the string representation.
+     * mainly debug purpose.
+     */
+    public String toString() {
+        return "("+min+','+getMaxString()+')';
+    }
+
+    /** the constant representing the (0,0) multiplicity. */
+    public static final Multiplicity ZERO = new Multiplicity(0,0);
+
+    /** the constant representing the (1,1) multiplicity. */
+    public static final Multiplicity ONE = new Multiplicity(1,1);
+
+    /** the constant representing the (0,1) multiplicity. */
+    public static final Multiplicity OPTIONAL = new Multiplicity(0,1);
+
+    /** the constant representing the (0,unbounded) multiplicity. */
+    public static final Multiplicity STAR = new Multiplicity(0,null);
+
+    /** the constant representing the (1,unbounded) multiplicity. */
+    public static final Multiplicity PLUS = new Multiplicity(1,null);
+
+// arithmetic methods
+//============================
+    public static Multiplicity choice( Multiplicity lhs, Multiplicity rhs ) {
+        return create(
+            Math.min(lhs.min,rhs.min),
+            (lhs.max==null||rhs.max==null)?
+                null:
+                (Integer)Math.max(lhs.max, rhs.max) );
+    }
+    public static Multiplicity group( Multiplicity lhs, Multiplicity rhs ) {
+        return create( lhs.min+rhs.min,
+            (lhs.max==null||rhs.max==null)?
+                null:
+                (Integer)(lhs.max + rhs.max) );
+    }
+    public static Multiplicity multiply( Multiplicity lhs, Multiplicity rhs ) {
+        int min = lhs.min*rhs.min;
+        Integer max;
+        if(isZero(lhs.max) || isZero(rhs.max))
+            max = 0;
+        else
+        if(lhs.max==null || rhs.max==null)
+            max = null;
+        else
+            max = lhs.max*rhs.max;
+        return create(min,max);
+    }
+
+    private static boolean isZero(Integer i) {
+        return i!=null && i==0;
+    }
+
+    public static Multiplicity oneOrMore( Multiplicity c ) {
+        if(c.max==null)  return c; // (x,*) => (x,*)
+        if(c.max==0 )    return c; // (0,0) => (0,0)
+        else        return create( c.min, null );    // (x,y) => (x,*)
+    }
+
+    public Multiplicity makeOptional() {
+        if(min==0)    return this;
+        return create(0,max);
+    }
+
+    public Multiplicity makeRepeated() {
+        if(max==null || max==0)  return this;   // (0,0)* = (0,0)  and (n,unbounded)* = (n,unbounded)
+        return create(min,null);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Populatable.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Populatable.java
new file mode 100644
index 0000000..16a3572
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/Populatable.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * Mark model components which does additional code generation.
+ *
+ * TODO: currently this is only used for enum xducers. Think about a way
+ * to generalize this.
+ *
+ * TODO: is this a sensible abstraction? Who's responsible for registering
+ * populatable components to the model? Isn't it better if the back end
+ * just gives every component a chance to build it automatically?
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Populatable {
+    public void populate( Model model, Outline context );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/SymbolSpace.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/SymbolSpace.java
new file mode 100644
index 0000000..40f41c2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/SymbolSpace.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JType;
+
+/**
+ * Symbol space for ID/IDREF.
+ *
+ * In XJC, the whole ID space is considered to be splitted into
+ * one or more "symbol space". For an IDREF to match an ID, we impose
+ * additional restriction to the one stated in the XML rec.
+ *
+ * <p>
+ * That is, XJC'll require that the IDREF belongs to the same symbol
+ * space as the ID. Having this concept allows us to assign more
+ * specific type to IDREF.
+ *
+ * <p>
+ * See the design document for detail.
+ *
+ * @author
+ *    <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public class SymbolSpace
+{
+    private JType type;
+    private final JCodeModel codeModel;
+
+    public SymbolSpace( JCodeModel _codeModel ) {
+        this.codeModel = _codeModel;
+    }
+
+    /**
+     * Gets the Java type of this symbol space.
+     *
+     * <p>
+     * A symbol space is said to have a Java type X if all classes
+     * pointed by IDs belonging to this symbol space are assignable
+     * to X.
+     */
+    public JType getType() {
+        if(type==null)  return codeModel.ref(Object.class);
+        return type;
+    }
+
+    public void setType( JType _type ) {
+        if( this.type==null )
+            this.type = _type;
+    }
+
+    public String toString() {
+        if(type==null)  return "undetermined";
+        else            return type.name();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUse.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUse.java
new file mode 100644
index 0000000..9fae4ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUse.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import javax.activation.MimeType;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.xsom.XmlString;
+
+/**
+ * Information about how another type is referenced.
+ *
+ * <p>
+ * In practice it is often easier to use {@link CTypeInfo}
+ * instead of {@link NType}, so this interface defines {@link #getInfo()}.
+ *
+ * @author Kohsuke Kawaguchi
+ * @see TypeUseImpl
+ */
+public interface TypeUse {
+    /**
+     * If the use can hold multiple values of the specified type.
+     */
+    boolean isCollection();
+
+    /**
+     * If this type use is adapting the type, returns the adapter.
+     * Otherwise return null.
+     */
+    CAdapter getAdapterUse();
+
+    /**
+     * Individual item type.
+     */
+    CTypeInfo getInfo();
+
+    /**
+     * Whether the referenced type (individual item type in case of collection)
+     * is ID/IDREF.
+     *
+     * <p>
+     * ID is a property of a relationship. When a bean Foo has an ID property
+     * called 'bar' whose type is String, Foo isn't an ID, String isn't an ID,
+     * but this relationship is an ID (in the sense that Foo uses this String
+     * as an ID.)
+     *
+     * <p>
+     * The same thing can be said with IDREF. When Foo refers to Bar by means of
+     * IDREF, neither Foo nor Bar is IDREF.
+     *
+     * <p>
+     * That's why we have this method in {@link TypeUse}.
+     */
+    ID idUse();
+
+    /**
+     * A {@link TypeUse} can have an associated MIME type.
+     */
+    MimeType getExpectedMimeType();
+
+    /**
+     * Creates a constant for the given lexical value.
+     *
+     * <p>
+     * For example, to create a constant 1 for <tt>xs:int</tt>, you'd do:
+     * <pre>
+     * CBuiltinLeafInfo.INT.createConstant( codeModel, "1", null );
+     * </pre>
+     *
+     * <p>
+     * This method is invoked at the backend as a part of the code generation process.
+     *
+     * @throws IllegalStateException
+     *      if the type isn't bound to a text in XML.
+     *
+     * @return null
+     *      if the constant cannot be created for this {@link TypeUse}
+     *      (such as when it's a collection)
+     */
+    JExpression createConstant(Outline outline, XmlString lexical);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUseFactory.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUseFactory.java
new file mode 100644
index 0000000..72b1c02
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUseFactory.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import javax.activation.MimeType;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+
+/**
+ * Factory methods to create a new {@link TypeUse} from an existing one.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class TypeUseFactory {
+    private TypeUseFactory() {}
+
+    public static TypeUse makeID( TypeUse t, ID id ) {
+        if(t.idUse()!=ID.NONE)
+            // I don't think we let users tweak the idness, so
+            // this error must indicate an inconsistency within the RI/spec.
+            throw new IllegalStateException();
+        return new TypeUseImpl( t.getInfo(), t.isCollection(), id, t.getExpectedMimeType(), t.getAdapterUse() );
+    }
+
+    public static TypeUse makeMimeTyped( TypeUse t, MimeType mt ) {
+        if(t.getExpectedMimeType()!=null)
+            // I don't think we let users tweak the idness, so
+            // this error must indicate an inconsistency within the RI/spec.
+            throw new IllegalStateException();
+        return new TypeUseImpl( t.getInfo(), t.isCollection(), t.idUse(), mt, t.getAdapterUse() );
+    }
+
+    public static TypeUse makeCollection( TypeUse t ) {
+        if(t.isCollection())    return t;
+        CAdapter au = t.getAdapterUse();
+        if(au!=null && !au.isWhitespaceAdapter()) {
+            // we can't process this right now.
+            // for now bind to a weaker type
+            TODO.checkSpec();
+            return CBuiltinLeafInfo.STRING_LIST;
+        }
+        return new TypeUseImpl( t.getInfo(), true, t.idUse(), t.getExpectedMimeType(), null );
+    }
+
+    public static TypeUse adapt(TypeUse t, CAdapter adapter) {
+        assert t.getAdapterUse()==null;    // TODO: we don't know how to handle double adapters yet.
+        return new TypeUseImpl(t.getInfo(),t.isCollection(),t.idUse(),t.getExpectedMimeType(),adapter);
+    }
+
+    /**
+     * Creates a new adapter {@link TypeUse} by using the existing {@link Adapter} class.
+     */
+    public static TypeUse adapt( TypeUse t, Class<? extends XmlAdapter> adapter, boolean copy ) {
+        return adapt( t, new CAdapter(adapter,copy) );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUseImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUseImpl.java
new file mode 100644
index 0000000..6e95644
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/TypeUseImpl.java
@@ -0,0 +1,129 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model;
+
+import javax.activation.MimeType;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JStringLiteral;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.xsom.XmlString;
+
+
+/**
+ * General-purpose {@link TypeUse} implementation.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class TypeUseImpl implements TypeUse {
+    private final CTypeInfo coreType;
+    private final boolean collection;
+    private final CAdapter adapter;
+    private final ID id;
+    private final MimeType expectedMimeType;
+
+
+    public TypeUseImpl(CTypeInfo itemType, boolean collection, ID id, MimeType expectedMimeType, CAdapter adapter) {
+        this.coreType = itemType;
+        this.collection = collection;
+        this.id = id;
+        this.expectedMimeType = expectedMimeType;
+        this.adapter = adapter;
+    }
+
+    public boolean isCollection() {
+        return collection;
+    }
+
+    public CTypeInfo getInfo() {
+        return coreType;
+    }
+
+    public CAdapter getAdapterUse() {
+        return adapter;
+    }
+
+    public ID idUse() {
+        return id;
+    }
+
+    public MimeType getExpectedMimeType() {
+        return expectedMimeType;
+    }
+
+    public boolean equals(Object o) {
+        if (this == o) return true;
+        if (!(o instanceof TypeUseImpl)) return false;
+
+        final TypeUseImpl that = (TypeUseImpl) o;
+
+        if (collection != that.collection) return false;
+        if (this.id != that.id ) return false;
+        if (adapter != null ? !adapter.equals(that.adapter) : that.adapter != null) return false;
+        if (coreType != null ? !coreType.equals(that.coreType) : that.coreType != null) return false;
+
+        return true;
+    }
+
+    public int hashCode() {
+        int result;
+        result = (coreType != null ? coreType.hashCode() : 0);
+        result = 29 * result + (collection ? 1 : 0);
+        result = 29 * result + (adapter != null ? adapter.hashCode() : 0);
+        return result;
+    }
+
+
+    public JExpression createConstant(Outline outline, XmlString lexical) {
+        if(isCollection())  return null;
+
+        if(adapter==null)     return coreType.createConstant(outline, lexical);
+
+        // [RESULT] new Adapter().unmarshal(CONSTANT);
+        JExpression cons = coreType.createConstant(outline, lexical);
+        Class<? extends XmlAdapter> atype = adapter.getAdapterIfKnown();
+
+        // try to run the adapter now rather than later.
+        if(cons instanceof JStringLiteral && atype!=null) {
+            JStringLiteral scons = (JStringLiteral) cons;
+            XmlAdapter a = ClassFactory.create(atype);
+            try {
+                Object value = a.unmarshal(scons.str);
+                if(value instanceof String) {
+                    return JExpr.lit((String)value);
+                }
+            } catch (Exception e) {
+                // assume that we can't eagerly bind this
+            }
+        }
+
+        return JExpr._new(adapter.getAdapterClass(outline)).invoke("unmarshal").arg(cons);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/EagerNClass.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/EagerNClass.java
new file mode 100644
index 0000000..0603f4e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/EagerNClass.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model.nav;
+
+import java.lang.reflect.Modifier;
+import java.util.HashSet;
+import java.util.Set;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class EagerNClass extends EagerNType implements NClass {
+    /*package*/ final Class c;
+
+    public EagerNClass(Class type) {
+        super(type);
+        this.c = type;
+    }
+
+    @Override
+    public boolean isBoxedType() {
+        return boxedTypes.contains(c);
+    }
+
+    @Override
+    public JClass toType(Outline o, Aspect aspect) {
+        return o.getCodeModel().ref(c);
+    }
+
+    public boolean isAbstract() {
+        return Modifier.isAbstract(c.getModifiers());
+    }
+
+    private static final Set<Class> boxedTypes = new HashSet<Class>();
+
+    static {
+        boxedTypes.add(Boolean.class);
+        boxedTypes.add(Character.class);
+        boxedTypes.add(Byte.class);
+        boxedTypes.add(Short.class);
+        boxedTypes.add(Integer.class);
+        boxedTypes.add(Long.class);
+        boxedTypes.add(Float.class);
+        boxedTypes.add(Double.class);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/EagerNType.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/EagerNType.java
new file mode 100644
index 0000000..2ad35ea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/EagerNType.java
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model.nav;
+
+import java.lang.reflect.Type;
+
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class EagerNType implements NType {
+    /*package*/ final Type t;
+
+    public EagerNType(Type type) {
+        this.t = type;
+        assert t!=null;
+    }
+
+    public JType toType(Outline o, Aspect aspect) {
+        try {
+            return o.getCodeModel().parseType(t.toString());
+        } catch (ClassNotFoundException e) {
+            throw new NoClassDefFoundError(e.getMessage());
+        }
+    }
+
+    public boolean equals(Object o) {
+        if (this == o) return true;
+        if (!(o instanceof EagerNType)) return false;
+
+        final EagerNType eagerNType = (EagerNType) o;
+
+        return t.equals(eagerNType.t);
+    }
+
+    public boolean isBoxedType() {
+        return false;
+    }
+
+    public int hashCode() {
+        return t.hashCode();
+    }
+
+    public String fullName() {
+        return Navigator.REFLECTION.getTypeName(t);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NClass.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NClass.java
new file mode 100644
index 0000000..30cfff6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NClass.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model.nav;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface NClass extends NType {
+    JClass toType(Outline o, Aspect aspect);
+
+    boolean isAbstract();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NClassByJClass.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NClassByJClass.java
new file mode 100644
index 0000000..65cb951
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NClassByJClass.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model.nav;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class NClassByJClass implements NClass {
+    /*package*/ final JClass clazz;
+
+    NClassByJClass(JClass clazz) {
+        this.clazz = clazz;
+    }
+
+    public JClass toType(Outline o, Aspect aspect) {
+        return clazz;
+    }
+
+    public boolean isAbstract() {
+        return clazz.isAbstract();
+    }
+
+    public boolean isBoxedType() {
+        return clazz.getPrimitiveType()!=null;
+    }
+
+    public String fullName() {
+        return clazz.fullName();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NParameterizedType.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NParameterizedType.java
new file mode 100644
index 0000000..1ba875c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NParameterizedType.java
@@ -0,0 +1,78 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model.nav;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * Parameterized type.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class NParameterizedType implements NClass {
+
+    final NClass rawType;
+    final NType[] args;
+
+    NParameterizedType(NClass rawType, NType[] args) {
+        this.rawType = rawType;
+        this.args = args;
+        assert args.length>0;
+    }
+
+    public JClass toType(Outline o, Aspect aspect) {
+        JClass r = rawType.toType(o,aspect);
+
+        for( NType arg : args )
+            r = r.narrow(arg.toType(o,aspect).boxify());
+
+        return r;
+    }
+
+    public boolean isAbstract() {
+        return rawType.isAbstract();
+    }
+
+    public boolean isBoxedType() {
+        return false;
+    }
+
+
+    public String fullName() {
+        StringBuilder buf = new StringBuilder();
+        buf.append(rawType.fullName());
+        buf.append('<');
+        for( int i=0; i<args.length; i++ ) {
+            if(i!=0)
+                buf.append(',');
+            buf.append(args[i].fullName());
+        }
+        buf.append('>');
+        return buf.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NType.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NType.java
new file mode 100644
index 0000000..095d242
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NType.java
@@ -0,0 +1,77 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model.nav;
+
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.outline.Aspect;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * A type.
+ *
+ * See the package documentaion for details.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface NType {
+    /**
+     * Returns the representation of this type in code model.
+     * <p>
+     * This operation requires the whole model to be built,
+     * and hence it takes {@link Outline}.
+     * <p>
+     * Under some code generation strategy, some bean classes
+     * are considered implementation specific (such as impl.FooImpl class)
+     * These classes always have accompanying "exposed" type (such as
+     * the Foo interface).
+     * <p>
+     * For such Jekyll and Hyde type, the aspect parameter determines
+     * which personality is returned.
+     *
+     * @param aspect
+     *      If {@link Aspect#IMPLEMENTATION}, this method returns the
+     *      implementation specific class that this type represents.
+     *      If {@link Aspect#EXPOSED}, this method returns the
+     *      publicly exposed type that this type represents.
+     *
+     *      For ordinary classes, the aspect parameter is meaningless.
+     *
+     */
+    JType toType(Outline o, Aspect aspect);
+
+    /**
+     * Returns true iff this type represents a class that has a unboxed form.
+     *
+     * For example, for {@link String} this is false, but for {@link Integer}
+     * this is true.
+     */
+    boolean isBoxedType();
+
+    /**
+     * Human readable name of this type.
+     */
+    String fullName();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NavigatorImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NavigatorImpl.java
new file mode 100644
index 0000000..b968b7d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/NavigatorImpl.java
@@ -0,0 +1,322 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.model.nav;
+
+import java.lang.reflect.Type;
+import java.util.Collection;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link Navigator} implementation for XJC.
+ *
+ * Most of the Navigator methods are used for parsing the model, which doesn't happen
+ * in XJC. So Most of the methods aren't really implemented. Implementations should
+ * be filled in as needed.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class NavigatorImpl implements Navigator<NType,NClass,Void,Void> {
+    public static final NavigatorImpl theInstance = new NavigatorImpl();
+
+    private NavigatorImpl() {
+    }
+
+    public NClass getSuperClass(NClass nClass) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NType getBaseClass(NType nt, NClass base) {
+        if(nt instanceof EagerNType) {
+            EagerNType ent = (EagerNType) nt;
+            if (base instanceof EagerNClass) {
+                EagerNClass enc = (EagerNClass) base;
+                return create(REFLECTION.getBaseClass(ent.t, enc.c));
+            }
+            // lazy class can never be a base type of an eager type
+            return null;
+        }
+        if (nt instanceof NClassByJClass) {
+            NClassByJClass nnt = (NClassByJClass) nt;
+            if (base instanceof EagerNClass) {
+                EagerNClass enc = (EagerNClass) base;
+                return ref(nnt.clazz.getBaseClass(enc.c));
+            }
+        }
+
+        throw new UnsupportedOperationException();
+    }
+
+    public String getClassName(NClass nClass) {
+        throw new UnsupportedOperationException();
+    }
+
+    public String getTypeName(NType type) {
+        return type.fullName();
+    }
+
+    public String getClassShortName(NClass nClass) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Collection<? extends Void> getDeclaredFields(NClass nClass) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Void getDeclaredField(NClass clazz, String fieldName) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Collection<? extends Void> getDeclaredMethods(NClass nClass) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NClass getDeclaringClassForField(Void aVoid) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NClass getDeclaringClassForMethod(Void aVoid) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NType getFieldType(Void aVoid) {
+        throw new UnsupportedOperationException();
+    }
+
+    public String getFieldName(Void aVoid) {
+        throw new UnsupportedOperationException();
+    }
+
+    public String getMethodName(Void aVoid) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NType getReturnType(Void aVoid) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NType[] getMethodParameters(Void aVoid) {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isStaticMethod(Void aVoid) {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isSubClassOf(NType sub, NType sup) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NClass ref(Class c) {
+        return create(c);
+    }
+
+    public NClass ref(JClass c) {
+        if(c==null)     return null;
+        return new NClassByJClass(c);
+    }
+
+    public NType use(NClass nc) {
+        return nc;
+    }
+
+    public NClass asDecl(NType nt) {
+        if(nt instanceof NClass)
+            return (NClass)nt;
+        else
+            return null;
+    }
+
+    public NClass asDecl(Class c) {
+        return ref(c);
+    }
+
+    public boolean isArray(NType nType) {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isArrayButNotByteArray(NType t) {
+        throw new UnsupportedOperationException();
+    }
+
+
+    public NType getComponentType(NType nType) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NType getTypeArgument(NType nt, int i) {
+        if (nt instanceof EagerNType) {
+            EagerNType ent = (EagerNType) nt;
+            return create(REFLECTION.getTypeArgument(ent.t,i));
+        }
+        if (nt instanceof NClassByJClass) {
+            NClassByJClass nnt = (NClassByJClass) nt;
+            return ref(nnt.clazz.getTypeParameters().get(i));
+        }
+
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isParameterizedType(NType nt) {
+        if (nt instanceof EagerNType) {
+            EagerNType ent = (EagerNType) nt;
+            return REFLECTION.isParameterizedType(ent.t);
+        }
+        if (nt instanceof NClassByJClass) {
+            NClassByJClass nnt = (NClassByJClass) nt;
+            return nnt.clazz.isParameterized();
+        }
+
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isPrimitive(NType type) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NType getPrimitive(Class primitiveType) {
+        return create(primitiveType);
+    }
+
+
+    public static final NType create(Type t) {
+        if(t==null)     return null;
+        if(t instanceof Class)
+            return create((Class)t);
+
+        return new EagerNType(t);
+    }
+
+    public static NClass create( Class c ) {
+        if(c==null)     return null;
+        return new EagerNClass(c);
+    }
+
+    /**
+     * Creates a {@link NType} representation for a parameterized type
+     * {@code RawType&lt;ParamType1,ParamType2,...> }.
+     */
+    public static NType createParameterizedType( NClass rawType, NType... args ) {
+        return new NParameterizedType(rawType,args);
+    }
+
+    public static NType createParameterizedType( Class rawType, NType... args ) {
+        return new NParameterizedType(create(rawType),args);
+    }
+
+    public Location getClassLocation(final NClass c) {
+        // not really needed for XJC but doesn't hurt to have one
+        return new Location() {
+            public String toString() {
+                return c.fullName();
+            }
+        };
+    }
+
+    public Location getFieldLocation(Void _) {
+        throw new IllegalStateException();
+    }
+
+    public Location getMethodLocation(Void _) {
+        throw new IllegalStateException();
+    }
+
+    public boolean hasDefaultConstructor(NClass nClass) {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isStaticField(Void aVoid) {
+        throw new IllegalStateException();
+    }
+
+    public boolean isPublicMethod(Void aVoid) {
+        throw new IllegalStateException();
+    }
+
+    public boolean isPublicField(Void aVoid) {
+        throw new IllegalStateException();
+    }
+
+    public boolean isEnum(NClass c) {
+        return isSubClassOf(c,create(Enum.class));
+    }
+
+    public <T> NType erasure(NType type) {
+        if(type instanceof NParameterizedType) {
+            NParameterizedType pt = (NParameterizedType) type;
+            return pt.rawType;
+        }
+        return type;
+    }
+
+    public boolean isAbstract(NClass clazz) {
+        return clazz.isAbstract();
+    }
+
+    /**
+     * @deprecated
+     *      no class generated by XJC is final.
+     */
+    public boolean isFinal(NClass clazz) {
+        return false;
+    }
+
+    public Void[] getEnumConstants(NClass clazz) {
+        throw new UnsupportedOperationException();
+    }
+
+    public NType getVoidType() {
+        return ref(void.class);
+    }
+
+    public String getPackageName(NClass clazz) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public NClass findClass(String className, NClass referencePoint) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isBridgeMethod(Void method) {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isOverriding(Void method) {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isInterface(NClass clazz) {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean isTransient(Void f) {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/package.html
new file mode 100644
index 0000000..8812e8e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/nav/package.html
@@ -0,0 +1,15 @@
+<html><body>
+  <p>
+    Compile-time representation of Java type system.
+
+  <p>
+    These classes are used as TypeT and ClassDeclT of the model parameterization.
+    This implementaion is designed to be capable of representing pre-existing classes
+    (such as java.lang.String) as well as the generated classes (represented as JDefinedClass.)
+
+  <h2>Handling of Primitive Types</h2>
+  <p>
+    Primitive types have two forms (int and Integer), and this complicates the binding process.
+    For this reason, inside the front end, we always use the boxed types. We'll use the unboxed
+    form only in the back end when we know the field doesn't need to represent the null value.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/package-info.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/package-info.java
new file mode 100644
index 0000000..87be018
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/model/package-info.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * Implementation of the {@link com.sun.xml.internal.bind.v2.model.core} package for XJC.
+ *
+ * <p>
+ * This model is the recipes for the code generation.
+ * It captures the essence of the JAXB-bound beans,
+ * so that the actual Java code can be generated from this object model
+ * mechanically without knowing anything about how the model was built.
+ *
+ * <p>
+ * Most of the classes/interfaces in this package has one-to-one relationship
+ * with the parameterized core model in the {@link com.sun.xml.internal.bind.v2.model.core} package.
+ * Refer to the core model for better documentation.
+ *
+ * <p>
+ * The model for XJC also exposes a few additional information on top of the core model.
+ * Those are defined in this package. This includes such information as:
+ *
+ * <dl>
+ *  <dt>Source location information
+ *  <dd>{@link Locator} object that can be used to tell where the model components
+ *      are created from in terms of the source file. Useful for error reporting.
+ *
+ *  <dt>Source schema component
+ *  <dd>{@link XSComponent} object from which the model components are created from.
+ *      See {@link CCustomizable#getSchemaComponent()} for example.
+ *
+ *  <dt>Plugin customizations
+ *  <dd>See {@link CCustomizable}.
+ * </dl>
+ */
+package com.sun.tools.internal.xjc.model;
+
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/Aspect.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/Aspect.java
new file mode 100644
index 0000000..a257a3a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/Aspect.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.outline;
+
+import com.sun.tools.internal.xjc.generator.bean.ImplStructureStrategy;
+
+/**
+ * Sometimes a single JAXB-generated bean spans across multiple Java classes/interfaces.
+ * We call them "aspects of a bean".
+ *
+ * <p>
+ * This is an enumeration of all possible aspects.
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * TODO: move this to the model package
+ */
+public enum Aspect {
+    /**
+     * The exposed part of the bean.
+     * <p>
+     * This corresponds to the content interface when we are geneting one.
+     * This would be the same as the {@link #IMPLEMENTATION} when we are
+     * just generating beans.
+     *
+     * <p>
+     * This could be an interface, or it could be a class.
+     *
+     * We don't have any other {@link ImplStructureStrategy} at this point,
+     * but generally you can't assume anything about where this could be
+     * or whether that's equal to {@link #IMPLEMENTATION}.
+     */
+    EXPOSED,
+    /**
+     * The part of the bean that holds all the implementations.
+     *
+     * <p>
+     * This is always a class, never an interface.
+     */
+    IMPLEMENTATION
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/ClassOutline.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/ClassOutline.java
new file mode 100644
index 0000000..ac93ebf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/ClassOutline.java
@@ -0,0 +1,124 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Use is subject to the license terms.
+ */
+package com.sun.tools.internal.xjc.outline;
+
+import java.util.List;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+
+/**
+ * Outline object that provides per-{@link CClassInfo} information
+ * for filling in methods/fields for a bean.
+ *
+ * This interface is accessible from {@link Outline}
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class ClassOutline {
+
+    /**
+     * A {@link Outline} that encloses all the class outlines.
+     */
+    public abstract Outline parent();
+
+    /**
+     * {@link PackageOutline} that contains this class.
+     */
+    public PackageOutline _package() {
+        return parent().getPackageContext(ref._package());
+    }
+
+    /**
+     * This {@link ClassOutline} holds information about this {@link CClassInfo}.
+     */
+    public final CClassInfo target;
+
+    /**
+     * The exposed aspect of the a bean.
+     *
+     * implClass is always assignable to this type.
+     * <p>
+     * Usually this is the public content interface, but
+     * it could be the same as the implClass.
+     */
+    public final JDefinedClass ref;
+
+    /**
+     * The implementation aspect of a bean.
+     * The actual place where fields/methods should be generated into.
+     */
+    public final JDefinedClass implClass;
+
+    /**
+     * The implementation class that shall be used for reference.
+     * <p>
+     * Usually this field holds the same value as the impl method,
+     * but sometimes it holds the user-specified implementation class
+     * when it is specified.
+     * <p>
+     * This is the type that needs to be used for generating fields.
+     */
+    public final JClass implRef;
+
+
+
+
+    protected ClassOutline( CClassInfo _target, JDefinedClass exposedClass, JClass implRef, JDefinedClass _implClass) {
+        this.target = _target;
+        this.ref = exposedClass;
+        this.implRef = implRef;
+        this.implClass = _implClass;
+    }
+
+    /**
+     * Gets all the {@link FieldOutline}s newly declared
+     * in this class.
+     */
+    public final FieldOutline[] getDeclaredFields() {
+        List<CPropertyInfo> props = target.getProperties();
+        FieldOutline[] fr = new FieldOutline[props.size()];
+        for( int i=0; i<fr.length; i++ )
+            fr[i] = parent().getField(props.get(i));
+        return fr;
+    }
+
+    /**
+     * Returns the super class of this class, if it has the
+     * super class and it is also a JAXB-bound class.
+     * Otherwise null.
+     */
+    public final ClassOutline getSuperClass() {
+        CClassInfo s = target.getBaseClass();
+        if(s==null)     return null;
+        return parent().getClazz(s);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/ElementOutline.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/ElementOutline.java
new file mode 100644
index 0000000..c2c95d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/ElementOutline.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.outline;
+
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+
+/**
+ * Outline object that provides per-{@link CElementInfo} information
+ * for filling in methods/fields for a bean.
+ *
+ * This interface is accessible from {@link Outline}. This object is
+ * not created for all {@link CElementInfo}s.
+ * It is only for those {@link CElementInfo} that has a class.
+ * (IOW, {@link CElementInfo#hasClass()}
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class ElementOutline {
+
+    /**
+     * A {@link Outline} that encloses all the class outlines.
+     */
+    public abstract Outline parent();
+
+    /**
+     * {@link PackageOutline} that contains this class.
+     */
+    public PackageOutline _package() {
+        return parent().getPackageContext(implClass._package());
+    }
+
+    /**
+     * This {@link ElementOutline} holds information about this {@link CElementInfo}.
+     */
+    public final CElementInfo target;
+
+    /**
+     * The implementation aspect of a bean.
+     * The actual place where fields/methods should be generated into.
+     */
+    public final JDefinedClass implClass;
+
+
+    protected ElementOutline(CElementInfo target, JDefinedClass implClass) {
+        this.target = target;
+        this.implClass = implClass;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/EnumConstantOutline.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/EnumConstantOutline.java
new file mode 100644
index 0000000..bdc52c4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/EnumConstantOutline.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.outline;
+
+import com.sun.codemodel.internal.JEnumConstant;
+import com.sun.tools.internal.xjc.generator.bean.BeanGenerator;
+import com.sun.tools.internal.xjc.model.CEnumConstant;
+import com.sun.tools.internal.xjc.model.CEnumLeafInfo;
+
+/**
+ * Outline object that provides per-{@link CEnumConstant} information.
+ *
+ * This object can be obtained from {@link EnumOutline}
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class EnumConstantOutline {
+    /**
+     * This {@link EnumOutline} holds information about this {@link CEnumLeafInfo}.
+     */
+    public final CEnumConstant target;
+
+    /**
+     * The generated enum constant.
+     */
+    public final JEnumConstant constRef;
+
+    /**
+     * Reserved for {@link BeanGenerator}.
+     */
+    protected EnumConstantOutline(CEnumConstant target, JEnumConstant constRef) {
+        this.target = target;
+        this.constRef = constRef;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/EnumOutline.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/EnumOutline.java
new file mode 100644
index 0000000..4224294
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/EnumOutline.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.outline;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.tools.internal.xjc.model.CEnumLeafInfo;
+
+/**
+ * Outline object that provides per-{@link CEnumLeafInfo} information
+ * for filling in methods/fields for a bean.
+ *
+ * This object can be obtained from {@link Outline}
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class EnumOutline {
+
+    /**
+     * This {@link EnumOutline} holds information about this {@link CEnumLeafInfo}.
+     */
+    public final CEnumLeafInfo target;
+
+    /**
+     * The generated enum class.
+     */
+    public final JDefinedClass clazz;
+
+    /**
+     * Constants.
+     */
+    public final List<EnumConstantOutline> constants = new ArrayList<EnumConstantOutline>();
+
+    protected EnumOutline(CEnumLeafInfo target, JDefinedClass clazz) {
+        this.target = target;
+        this.clazz = clazz;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/FieldAccessor.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/FieldAccessor.java
new file mode 100644
index 0000000..db24049
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/FieldAccessor.java
@@ -0,0 +1,104 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.outline;
+
+import com.sun.codemodel.internal.JBlock;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+
+/**
+ * Encapsulates the access on a field.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface FieldAccessor {
+
+    /**
+     * Dumps everything in this field into the given variable.
+     *
+     * <p>
+     * This generates code that accesses the field from outside.
+     *
+     * @param block
+     *      The code will be generated into this block.
+     * @param $var
+     *      Variable whose type is {@link FieldOutline#getRawType()}
+     */
+    void toRawValue( JBlock block, JVar $var );
+
+    /**
+     * Sets the value of the field from the specified expression.
+     *
+     * <p>
+     * This generates code that accesses the field from outside.
+     *
+     * @param block
+     *      The code will be generated into this block.
+     * @param uniqueName
+     *      Identifier that the caller guarantees to be unique in
+     *      the given block. When the callee needs to produce additional
+     *      variables, it can do so by adding suffixes to this unique
+     *      name. For example, if the uniqueName is "abc", then the
+     *      caller guarantees that any identifier "abc.*" is unused
+     *      in this block.
+     * @param $var
+     *      The expression that evaluates to a value of the type
+     *      {@link FieldOutline#getRawType()}.
+     */
+    void fromRawValue( JBlock block, String uniqueName, JExpression $var );
+
+    /**
+     * Generates a code fragment to remove any "set" value
+     * and move this field to the "unset" state.
+     *
+     * @param body
+     *      The code will be appended at the end of this block.
+     */
+    void unsetValues( JBlock body );
+
+    /**
+     * Return an expression that evaluates to true only when
+     * this field has a set value(s).
+     *
+     * @return null
+     *      if the isSetXXX/unsetXXX method does not make sense
+     *      for the given field.
+     */
+    JExpression hasSetValue();
+
+    /**
+     * Gets the {@link FieldOutline} from which
+     * this object is created.
+     */
+    FieldOutline owner();
+
+    /**
+     * Short for <tt>owner().getPropertyInfo()</tt>
+     */
+    CPropertyInfo getPropertyInfo();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/FieldOutline.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/FieldOutline.java
new file mode 100644
index 0000000..d326d96
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/FieldOutline.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.outline;
+
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+
+/**
+ * Representation of a field of {@link ClassOutline}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface FieldOutline {
+
+    /**
+     * Gets the enclosing {@link ClassOutline}.
+     */
+    ClassOutline parent();
+
+    /** Gets the corresponding model object. */
+    CPropertyInfo getPropertyInfo();
+
+    /**
+     * Gets the type of the "raw value".
+     *
+     * <p>
+     * This type can represent the entire value of this field.
+     * For fields that can carry multiple values, this is an array.
+     *
+     * <p>
+     * This type allows the client of the outline to generate code
+     * to set/get values from a property.
+     */
+    JType getRawType();
+
+    /**
+     * Creates a new {@link FieldAccessor} of this field
+     * for the specified object.
+     *
+     * @param targetObject
+     *      Evaluates to an object, and the field on this object
+     *      will be accessed.
+     */
+    FieldAccessor create( JExpression targetObject );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/Outline.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/Outline.java
new file mode 100644
index 0000000..7145bb6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/Outline.java
@@ -0,0 +1,133 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.outline;
+
+import java.util.Collection;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JClassContainer;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CClassInfoParent;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CEnumLeafInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.util.CodeModelClassFactory;
+
+/**
+ * Root of the outline. Captures which code is generated for which model component.
+ *
+ * <p>
+ * This object also provides access to varioues utilities, such as
+ * error reporting etc, for the convenience of code that builds the outline.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Outline
+{
+    /**
+     * This outline is for this model.
+     */
+    Model getModel();
+
+    /**
+     * Short for {@code getModel().codeModel}.
+     */
+    JCodeModel getCodeModel();
+
+    /** Gets the object that wraps the generated field for a given {@link CPropertyInfo}. */
+    FieldOutline getField( CPropertyInfo fu );
+
+    /**
+     * Gets per-package context information.
+     *
+     * This method works for every visible package
+     * (those packages which are supposed to be used by client applications.)
+     *
+     * @return
+     *      If this grammar doesn't produce anything in the specified
+     *      package, return null.
+     */
+    PackageOutline getPackageContext( JPackage _Package );
+
+    /**
+     * Returns all the {@link ClassOutline}s known to this object.
+     */
+    Collection<? extends ClassOutline> getClasses();
+
+    /**
+     * Obtains per-class context information.
+     */
+    ClassOutline getClazz( CClassInfo clazz );
+
+    /**
+     * If the {@link CElementInfo} generates a class,
+     * returns such a class. Otherwise return null.
+     */
+    ElementOutline getElement(CElementInfo ei);
+
+    EnumOutline getEnum(CEnumLeafInfo eli);
+
+    /**
+     * Gets all the {@link EnumOutline}s.
+     */
+    Collection<EnumOutline> getEnums();
+
+    /** Gets all package-wise contexts at once. */
+    Iterable<? extends PackageOutline> getAllPackageContexts();
+
+    /**
+     * Gets a reference to
+     * <code>new CodeModelClassFactory(getErrorHandler())</code>.
+     */
+    CodeModelClassFactory getClassFactory();
+
+    /**
+     * Any error during the back-end proccessing should be
+     * sent to this object.
+     */
+    ErrorReceiver getErrorReceiver();
+
+    JClassContainer getContainer(CClassInfoParent parent, Aspect aspect );
+
+    /**
+     * Resolves a type reference to the actual (possibly generated) type.
+     *
+     * Short for {@code resolve(ref.getType(),aspect)}.
+     */
+    JType resolve(CTypeRef ref,Aspect aspect);
+
+    /**
+     * Copies the specified class into the user's package and returns
+     * a reference to it.
+     */
+    JClass addRuntime(Class clazz);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/PackageOutline.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/PackageOutline.java
new file mode 100644
index 0000000..1dfd4d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/PackageOutline.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.outline;
+
+import java.util.Set;
+
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.bind.annotation.XmlSchema;
+
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.generator.bean.ObjectFactoryGenerator;
+
+/**
+ * Outline object that provides per-package information.
+ *
+ * This interface is accessible from {@link Outline}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface PackageOutline {
+
+    /**
+     * The exposed package this context is representing.
+     *
+     * <p>
+     * An exposed package is a package visible to users, a package
+     * supposed to be used by client applications. Sometime
+     * we have another parallel package that's not visible to users.
+     */
+    JPackage _package();
+
+    /**
+     * Generated ObjectFactory from package.
+     *
+     * This method allows a caller to obtain a reference to such
+     * ObjectFactory from its package.
+     *
+     * Must not be null.
+     */
+    JDefinedClass objectFactory();
+
+    /**
+     * Generates an ObjectFactory class for this package.
+     */
+    ObjectFactoryGenerator objectFactoryGenerator();
+
+    /**
+     * Gets {@link ClassOutline}s whose {@link ClassOutline#_package()}
+     * points to this object.
+     *
+     * @return can be empty but never null.
+     */
+    Set<? extends ClassOutline> getClasses();
+
+    /**
+     * The namespace URI most commonly used in classes in this package.
+     * This should be used as the namespace URI for {@link XmlSchema#namespace()}.
+     *
+     * <p>
+     * Null if no default
+     */
+    public String getMostUsedNamespaceURI();
+
+    /**
+     * The element form default for this package.
+     * <p>
+     * The value is computed by examining what would yield the smallest generated code.
+     */
+    public XmlNsForm getElementFormDefault();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/package.html
new file mode 100644
index 0000000..0f20e33
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/outline/package.html
@@ -0,0 +1,9 @@
+<html><body>
+  Provides the outline of the generated Java source code so that
+  additional processings (such as adding more annotations) can be
+  done on the generated code.
+
+  <p>
+  Code generation phase builds an outline little by little, while
+  each step is using the outline built by the prior steps.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/package-info.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/package-info.java
new file mode 100644
index 0000000..04dbd8b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/package-info.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * <h1>Schema to Java compiler</h1>.
+ *
+ * <p>
+ * This module contains the code that implements the schema compiler 'XJC'.
+ *
+ *
+ * <h2>XJC Architecture Diagram</h2>
+ * {@DotDiagram
+     digraph G {
+         rankdir=TB;
+
+         // data
+         node [shape=box]; // style=filled,color=lightpink];
+         schema -> "DOM forest" [label="DOMForest.parse()"];
+         "DOM forest" -> "schema OM" [label="SOM specific parser"];
+         "schema OM" -> model [label="language specific builder"];
+
+         model -> codeModel [label="BeanGenerator.generate()"];
+         codeModel -> "Java source files" [label="JCodeModel.build()"];
+         model -> outline [label="BeanGenerator.generate()"];
+
+         edge [style=dotted,label="associate"]
+         outline -> codeModel;
+         outline -> model;
+       }
+ * }
+ *
+ * <h2>Overview</h2>
+ * <p>
+ * XJC consists of the following major components.
+ * <dl>
+ *  <dt>{@link com.sun.tools.internal.xjc.reader Schema reader}
+ *  <dd>
+ *   Schema readers read XML Schema documents (or DTD, RELAX NG, ...)
+ *   and builds a model.
+ *
+ *  <dt>{@link com.sun.tools.internal.xjc.model Model}
+ *  <dd>
+ *   Model represents the 'blueprint' of the code to be generated.
+ *   Model talks in terms of higher level constructs like 'class' and 'property'
+ *   without getting too much into the details of the Java source code.
+ *
+ *  <dt>{@link com.sun.tools.internal.xjc.generator Code generator}
+ *  <dd>
+ *   Code generators use a model as an input and builds Java code AST
+ *   into CodeModel. It also produces an {@link com.sun.tools.internal.xjc.outline.Outline} which captures
+ *   this work.
+ *
+ *  <dt>{@link com.sun.tools.internal.xjc.outline.Outline Outline}
+ *  <dd>
+ *   Outline can be thought as a series of links between a model
+ *   and CodeModel.
+ * </dl>
+ *
+ * {@DotDiagram
+ *   digraph G {
+ *      rankdir = LR;
+ *      schema -> reader -> model -> backend -> outline;
+ *   }
+ * }
+ *
+ * @ArchitectureDocument
+ */
+package com.sun.tools.internal.xjc;
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Const.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Const.java
new file mode 100644
index 0000000..dc0e83f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Const.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader;
+
+
+
+
+/**
+ * Useful constant values.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class Const {
+
+    /** XML namespace URI. */
+    public final static String XMLNS_URI =
+        "http://www.w3.org/2000/xmlns/";
+
+    /** JAXB customization URI. */
+    public final static String JAXB_NSURI =
+        "http://java.sun.com/xml/ns/jaxb";
+
+    /** XJC vendor extension namespace URI. */
+    public final static String XJC_EXTENSION_URI =
+        "http://java.sun.com/xml/ns/jaxb/xjc";
+
+    /** RELAX NG namespace URI. */
+    public static final String RELAXNG_URI =
+        "http://relaxng.org/ns/structure/1.0";
+
+    /** URI to represent DTD. */
+    public static final String DTD = "DTD";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/ExtensionBindingChecker.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/ExtensionBindingChecker.java
new file mode 100644
index 0000000..1cbaac4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/ExtensionBindingChecker.java
@@ -0,0 +1,321 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader;
+
+import java.util.HashSet;
+import java.util.Set;
+import java.util.StringTokenizer;
+
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.Plugin;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.DefaultHandler;
+import org.xml.sax.helpers.NamespaceSupport;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * This filter checks jaxb:extensionBindingPrefix and
+ * pass/filter extension bindings.
+ *
+ * <p>
+ * This filter also remembers enabled extension namespaces
+ * and filters out any extension namespaces that doesn't belong
+ * to those. The net effect is that disabled customizations
+ * will never pass through this filter.
+ *
+ * <p>
+ * Note that we can't just filter out all foreign namespaces,
+ * as we need to use user-defined tags in documentations to generate javadoc.
+ *
+ * <p>
+ * The class needs to know the list of extension binding namespaces
+ * that the RI recognizes.
+ * To add new URI, modify the isSupportedExtension method.
+ *
+
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class ExtensionBindingChecker extends XMLFilterImpl {
+
+    /** Remembers in-scope namespace bindings. */
+    private final NamespaceSupport nsSupport = new NamespaceSupport();
+
+    /**
+     * Number of the elements encountered. Used to detect the root element.
+     */
+    private int count=0;
+
+    /**
+     * Set of namespace URIs that designates enabled extensions.
+     */
+    private final Set<String> enabledExtensions = new HashSet<String>();
+
+    private final Set<String> recognizableExtensions = new HashSet<String>();
+
+    private Locator locator;
+
+    /**
+     * When we are pruning a sub tree, this field holds the depth of
+     * elements that are being cut. Used to resume event forwarding.
+     *
+     * As long as this value is 0, we will pass through data.
+     */
+    private int cutDepth=0;
+
+    /**
+     * This object will receive SAX events while a sub tree is being
+     * pruned.
+     */
+    private static final ContentHandler stub = new DefaultHandler();
+
+    /**
+     * This field remembers the user-specified ContentHandler.
+     * So that we can restore it once the sub tree is completely pruned.
+     */
+    private ContentHandler next;
+
+    /**
+     * Namespace URI of the target schema language. Elements in this
+     * namespace are always allowed.
+     */
+    private final String schemaLanguage;
+
+    /**
+     * If false, any use of extensions is reported as an error.
+     */
+    private final boolean allowExtensions;
+
+    private final Options options;
+
+    /**
+     * @param handler
+     *      This error handler will receive detected errors.
+     */
+    public ExtensionBindingChecker( String schemaLanguage, Options options, ErrorHandler handler ) {
+        this.schemaLanguage = schemaLanguage;
+        this.allowExtensions = options.compatibilityMode!=Options.STRICT;
+        this.options = options;
+        setErrorHandler(handler);
+
+        for (Plugin plugin : options.getAllPlugins())
+            recognizableExtensions.addAll(plugin.getCustomizationURIs());
+        recognizableExtensions.add(Const.XJC_EXTENSION_URI);
+    }
+
+    /**
+     * Checks if the given namespace URI is supported as the extension
+     * bindings.
+     */
+    private boolean isSupportedExtension( String namespaceUri ) {
+        if(namespaceUri.equals(Const.XJC_EXTENSION_URI))
+            return true;
+        return options.pluginURIs.contains(namespaceUri);
+    }
+
+    /**
+     * Checks if the given namespace URI can be potentially recognized
+     * by this XJC.
+     */
+    private boolean isRecognizableExtension( String namespaceUri ) {
+        return recognizableExtensions.contains(namespaceUri);
+    }
+
+    /**
+     * Returns true if the elements with the given namespace URI
+     * should be blocked by this filter.
+     */
+    private boolean needsToBePruned( String uri ) {
+        if( uri.equals(schemaLanguage) )
+            return false;
+        if( uri.equals(Const.JAXB_NSURI) )
+            return false;
+        if( enabledExtensions.contains(uri) )
+            return false;
+
+        // we don't need to prune something unless
+        // the rest of the processor recognizes it as something special.
+        // this allows us to send the documentation and other harmless
+        // foreign XML fragments, which may be picked up as documents.
+        return isRecognizableExtension(uri);
+    }
+
+
+
+    public void startDocument() throws SAXException {
+        super.startDocument();
+
+        count=0;
+        cutDepth=0;
+        nsSupport.reset();
+        enabledExtensions.clear();
+    }
+
+    public void startPrefixMapping(String prefix, String uri) throws SAXException {
+        super.startPrefixMapping(prefix, uri);
+        nsSupport.pushContext();
+        nsSupport.declarePrefix(prefix,uri);
+    }
+
+    public void endPrefixMapping(String prefix) throws SAXException {
+        super.endPrefixMapping(prefix);
+        nsSupport.popContext();
+    }
+
+    public void startElement(String namespaceURI, String localName, String qName, Attributes atts)
+        throws SAXException {
+
+        if( cutDepth==0 ) {
+            String v = atts.getValue(Const.JAXB_NSURI,"extensionBindingPrefixes");
+            if(v!=null) {
+                if(count!=0)
+                    // the binding attribute is allowed only at the root level.
+                    error( Messages.ERR_UNEXPECTED_EXTENSION_BINDING_PREFIXES.format() );
+
+                if(!allowExtensions)
+                    error( Messages.ERR_VENDOR_EXTENSION_DISALLOWED_IN_STRICT_MODE.format() );
+
+                // then remember the associated namespace URIs.
+                StringTokenizer tokens = new StringTokenizer(v);
+                while(tokens.hasMoreTokens()) {
+                    String prefix = tokens.nextToken();
+                    String uri = nsSupport.getURI(prefix);
+                    if( uri==null ) {
+                        // undeclared prefix
+                        error( Messages.ERR_UNDECLARED_PREFIX.format(prefix) );
+                    } else {
+                        if( !isRecognizableExtension(uri) )
+                            // not the namespace URI we know of
+                            error( Messages.ERR_UNSUPPORTED_EXTENSION.format(prefix) );
+                        else
+                        if( !isSupportedExtension(uri) ) {
+                            // recognizable but not not supported, meaning
+                            // the plug-in isn't enabled
+
+                            // look for plug-in that handles this URI
+                            Plugin owner = null;
+                            for( Plugin p : options.getAllPlugins() ) {
+                                if(p.getCustomizationURIs().contains(uri)) {
+                                    owner = p;
+                                    break;
+                                }
+                            }
+                            if(owner!=null)
+                                // we know the plug-in that supports this namespace, but it's not enabled
+                                error( Messages.ERR_PLUGIN_NOT_ENABLED.format(owner.getOptionName(),uri));
+                            else {
+                                // this shouldn't happen, but be defensive...
+                                error( Messages.ERR_UNSUPPORTED_EXTENSION.format(prefix) );
+                            }
+                        }
+
+                        // as an error recovery enable this namespace URI anyway.
+                        enabledExtensions.add(uri);
+                    }
+                }
+            }
+
+            if( needsToBePruned(namespaceURI) ) {
+                // start pruning the tree. Call the super class method directly.
+                if( isRecognizableExtension(namespaceURI) ) {
+                    // but this is a supported customization.
+                    // isn't the user forgetting @jaxb:extensionBindingPrefixes?
+                    warning( Messages.ERR_SUPPORTED_EXTENSION_IGNORED.format(namespaceURI) );
+                }
+                super.setContentHandler(stub);
+                cutDepth=1;
+            }
+            else
+            if(options.pluginURIs.contains(namespaceURI)) {
+                // make sure that this is a valid tag name
+                boolean correct = false;
+                for( Plugin p : options.activePlugins ) {
+                    if(p.isCustomizationTagName(namespaceURI,localName)) {
+                        correct = true;
+                        break;
+                    }
+                }
+                if(!correct) {
+                    error( Messages.ERR_ILLEGAL_CUSTOMIZATION_TAGNAME.format(qName) );
+                    super.setContentHandler(stub);
+                    cutDepth=1;
+                }
+            }
+        } else
+            cutDepth++;
+
+        count++;
+        super.startElement(namespaceURI, localName, qName, atts);
+    }
+
+    public void endElement(String namespaceURI, String localName, String qName) throws SAXException {
+        super.endElement(namespaceURI, localName, qName);
+
+        if( cutDepth!=0 ) {
+            cutDepth--;
+            if( cutDepth == 0 )
+                // pruning completed. restore the user handler
+                super.setContentHandler(next);
+        }
+    }
+
+    public void setDocumentLocator(Locator locator) {
+        super.setDocumentLocator(locator);
+        this.locator = locator;
+    }
+
+    public void setContentHandler(ContentHandler handler) {
+        next = handler;
+        // changes take effect immediately unless the sub-tree is being pruned
+        if(getContentHandler()!=stub)
+            super.setContentHandler(handler);
+    }
+
+
+    /**
+     * Reports an error and returns the created SAXParseException
+     */
+    private SAXParseException error( String msg ) throws SAXException {
+        SAXParseException spe = new SAXParseException( msg, locator );
+        getErrorHandler().error(spe);
+        return spe;
+    }
+
+    /**
+     * Reports a warning.
+     */
+    private void warning( String msg ) throws SAXException {
+        SAXParseException spe = new SAXParseException( msg, locator );
+        getErrorHandler().warning(spe);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/MessageBundle.properties
new file mode 100644
index 0000000..97907cf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/MessageBundle.properties
@@ -0,0 +1,46 @@
+#
+# Message resource file
+#
+
+
+
+ERR_UNDECLARED_PREFIX = \
+	Prefix "{0}" is undeclared
+
+ERR_UNEXPECTED_EXTENSION_BINDING_PREFIXES = \
+	extensionBindingPrefixes attribute must be declared at the root element
+
+ERR_VENDOR_EXTENSION_DISALLOWED_IN_STRICT_MODE = \
+    vendor extension bindings (jaxb:extensionBindingPrefixes) are not allowed in the strict mode. Use -extension.
+
+ERR_UNSUPPORTED_EXTENSION = \
+	Unsupported binding namespace "{0}"
+
+ERR_SUPPORTED_EXTENSION_IGNORED = \
+	Binding declaration namespace "{0}" will be ignored because it is \
+	not designated by the jaxb:extensionBindingPrefixes attribute.
+
+ERR_RELEVANT_LOCATION = \
+	The following location is relevant to the above error
+
+
+ERR_CLASS_NOT_FOUND = \
+	Unable to find type "{0}". Without knowing the proper inheritance hierarchy of this type, \
+	XJC may fail to generate some signatures correctly. \
+	Make this class available via the -classpath option.
+	
+DUPLICATE_PROPERTY = \
+    Property "{0}" is already defined.
+
+DUPLICATE_PROPERTY_LOC = \
+    (related to above error) another definition is given here.
+
+PROPERTY_CLASS_IS_RESERVED = \
+    Property name "Class" is reserved by java.lang.Object.
+
+ERR_ILLEGAL_CUSTOMIZATION_TAGNAME = \
+    "{0}" is not a valid customization.
+
+ERR_PLUGIN_NOT_ENABLED = \
+    Using "{1}" customizations requires the "-{0}" switch to enable this plug-in.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Messages.java
new file mode 100644
index 0000000..a79954f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Messages.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.reader;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+enum Messages {
+    DUPLICATE_PROPERTY, // 1 arg
+
+    ERR_UNDECLARED_PREFIX,
+    ERR_UNEXPECTED_EXTENSION_BINDING_PREFIXES,
+    ERR_UNSUPPORTED_EXTENSION,
+    ERR_SUPPORTED_EXTENSION_IGNORED,
+    ERR_RELEVANT_LOCATION,
+    ERR_CLASS_NOT_FOUND,
+    PROPERTY_CLASS_IS_RESERVED,
+    ERR_VENDOR_EXTENSION_DISALLOWED_IN_STRICT_MODE,
+    ERR_ILLEGAL_CUSTOMIZATION_TAGNAME, // 1 arg
+    ERR_PLUGIN_NOT_ENABLED, // 2 args
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getPackage().getName() +".MessageBundle");
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/ModelChecker.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/ModelChecker.java
new file mode 100644
index 0000000..fafd9c5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/ModelChecker.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader;
+
+import java.util.List;
+
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.Model;
+
+/**
+ * Checks errors on model classes.
+ *
+ * <p>
+ * This should be used as a {@link Ring} component.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ModelChecker {
+    private final Model model = Ring.get(Model.class);
+    private final ErrorReceiver errorReceiver = Ring.get(ErrorReceiver.class);
+
+    public ModelChecker() {
+    }
+
+    public void check() {
+        for( CClassInfo ci : model.beans().values() )
+            check(ci);
+    }
+
+    private void check( CClassInfo ci ) {
+        List<CPropertyInfo> props = ci.getProperties();
+
+        OUTER:
+        for( int i=0; i<props.size(); i++ ) {
+            CPropertyInfo p1 = props.get(i);
+
+            if(p1.getName(true).equals("Class")) {
+                errorReceiver.error(p1.locator,Messages.PROPERTY_CLASS_IS_RESERVED.format());
+                continue;
+            }
+
+            for( int j=i+1; j<props.size(); j++ ) {
+                if(checkPropertyCollision(p1,props.get(j)))
+                    continue OUTER;
+            }
+            for( CClassInfo c=ci.getBaseClass(); c!=null; c=c.getBaseClass() ) {
+                for( CPropertyInfo p2 : c.getProperties() )
+                    if(checkPropertyCollision(p1,p2))
+                        continue OUTER;
+            }
+        }
+    }
+
+    private boolean checkPropertyCollision(CPropertyInfo p1, CPropertyInfo p2) {
+        if(!p1.getName(true).equals(p2.getName(true)))
+            return false;
+        errorReceiver.error(p1.locator,Messages.DUPLICATE_PROPERTY.format(p1.getName(true)));
+        errorReceiver.error(p2.locator,Messages.ERR_RELEVANT_LOCATION.format());
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/RawTypeSet.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/RawTypeSet.java
new file mode 100644
index 0000000..a0a8154
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/RawTypeSet.java
@@ -0,0 +1,348 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader;
+
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import javax.activation.MimeType;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CCustomizations;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import static com.sun.tools.internal.xjc.model.CElementPropertyInfo.CollectionMode.*;
+import com.sun.tools.internal.xjc.model.CNonElement;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.model.Multiplicity;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.model.nav.NType;
+import com.sun.tools.internal.xjc.reader.xmlschema.BGMBuilder;
+import com.sun.tools.internal.xjc.reader.xmlschema.ClassSelector;
+import com.sun.tools.internal.xjc.reader.xmlschema.SimpleTypeBuilder;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIGlobalBinding;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XmlString;
+
+import org.xml.sax.Locator;
+
+/**
+ * Set of {@link Ref}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class RawTypeSet {
+
+
+    public final Set<Ref> refs;
+
+    /**
+     * True if this type set can form references to types.
+     */
+    public final Mode canBeTypeRefs;
+
+    /**
+     * The occurence of the whole references.
+     */
+    public final Multiplicity mul;
+
+    // computed inside canBeTypeRefs()
+    private CElementPropertyInfo.CollectionMode collectionMode;
+
+    /**
+     * Should be called from one of the raw type set builders.
+     */
+    public RawTypeSet( Set<Ref> refs, Multiplicity m ) {
+        this.refs = refs;
+        mul = m;
+        canBeTypeRefs = canBeTypeRefs();
+    }
+
+    public CElementPropertyInfo.CollectionMode getCollectionMode() {
+        return collectionMode;
+    }
+
+    public boolean isRequired() {
+        return mul.min>0;
+    }
+
+
+    /**
+     * Represents the possible binding option for this {@link RawTypeSet}.
+     */
+    public enum Mode {
+        /**
+         * This {@link RawTypeSet} can be either an reference property or
+         * an element property, and XJC recommends element property.
+         */
+        SHOULD_BE_TYPEREF(0),
+        /**
+         * This {@link RawTypeSet} can be either an reference property or
+         * an element property, and XJC recommends reference property.
+         */
+        CAN_BE_TYPEREF(1),
+        /**
+         * This {@link RawTypeSet} can be only bound to a reference property.
+         */
+        MUST_BE_REFERENCE(2);
+
+        private final int rank;
+
+        Mode(int rank) {
+           this.rank = rank;
+        }
+
+        Mode or(Mode that) {
+            switch(Math.max(this.rank,that.rank)) {
+            case 0:     return SHOULD_BE_TYPEREF;
+            case 1:     return CAN_BE_TYPEREF;
+            case 2:     return MUST_BE_REFERENCE;
+            }
+            throw new AssertionError();
+        }
+    }
+
+    /**
+     * Returns true if {@link #refs} can form refs of types.
+     *
+     * If there are multiple {@link Ref}s with the same type,
+     * we cannot make them into type refs. Or if any of the {@link Ref}
+     * says they cannot be in type refs, we cannot do that either.
+     *
+     * TODO: just checking if the refs are the same is not suffice.
+     * If two refs derive from each other, they cannot form a list of refs
+     * (because of a possible ambiguity).
+     */
+    private Mode canBeTypeRefs() {
+        Set<NType> types = new HashSet<NType>();
+
+        collectionMode = mul.isAtMostOnce()?NOT_REPEATED:REPEATED_ELEMENT;
+
+        // the way we compute this is that we start from the most optimistic value,
+        // and then gradually degrade as we find something problematic.
+        Mode mode = Mode.SHOULD_BE_TYPEREF;
+
+        for( Ref r : refs ) {
+            mode = mode.or(r.canBeType(this));
+            if(mode== Mode.MUST_BE_REFERENCE)
+                return mode;    // no need to continue the processing
+
+            if(!types.add(r.toTypeRef(null).getTarget().getType()))
+                return Mode.MUST_BE_REFERENCE;   // collision
+            if(r.isListOfValues()) {
+                if(refs.size()>1 || !mul.isAtMostOnce())
+                    return Mode.MUST_BE_REFERENCE;   // restriction on @XmlList
+                collectionMode = REPEATED_VALUE;
+            }
+        }
+        return mode;
+    }
+
+
+
+
+    public void addTo(CElementPropertyInfo prop) {
+        assert canBeTypeRefs!= Mode.MUST_BE_REFERENCE;
+        if(mul.isZero())
+            return; // the property can't have any value
+
+        List<CTypeRef> dst = prop.getTypes();
+        for( Ref t : refs )
+            dst.add(t.toTypeRef(prop));
+    }
+
+    public void addTo(CReferencePropertyInfo prop) {
+        if(mul.isZero())
+            return; // the property can't have any value
+        for( Ref t : refs )
+            t.toElementRef(prop);
+    }
+
+    public ID id() {
+        for( Ref t : refs ) {
+            ID id = t.id();
+            if(id!=ID.NONE)    return id;
+        }
+        return ID.NONE;
+    }
+
+    public MimeType getExpectedMimeType() {
+        for( Ref t : refs ) {
+            MimeType mt = t.getExpectedMimeType();
+            if(mt!=null)    return mt;
+        }
+        return null;
+    }
+
+
+    /**
+     * A reference to something.
+     *
+     * <p>
+     * A {@link Ref} can be either turned into {@link CTypeRef} to form
+     * an element property, or {@link Element} to form a reference property.
+     */
+    public static abstract class Ref {
+        /**
+         * @param ep
+         *      the property to which the returned {@link CTypeRef} will be
+         *      added to.
+         */
+        protected abstract CTypeRef toTypeRef(CElementPropertyInfo ep);
+        protected abstract void toElementRef(CReferencePropertyInfo prop);
+        /**
+         * Can this {@link Ref} be a type ref?
+         * @return false to veto.
+         * @param parent
+         */
+        protected abstract Mode canBeType(RawTypeSet parent);
+        protected abstract boolean isListOfValues();
+        /**
+         * When this {@link RawTypeSet} binds to a {@link CElementPropertyInfo},
+         * this method is used to determine if the property is ID or not.
+         */
+        protected abstract ID id();
+
+        /**
+         * When this {@link RawTypeSet} binds to a {@link CElementPropertyInfo},
+         * this method is used to determine if the property has an associated expected MIME type or not.
+         */
+        protected MimeType getExpectedMimeType() { return null; }
+    }
+
+    /**
+     * References to a type. Could be global or local.
+     */
+    public static final class XmlTypeRef extends Ref {
+        public final QName elementName;
+        public final TypeUse target;
+        public final Locator locator;
+        public final XSComponent source;
+        public final CCustomizations custs;
+        public final boolean nillable;
+        public final XmlString defaultValue;
+
+        public XmlTypeRef(QName elementName, TypeUse target, boolean nillable, XmlString defaultValue, XSComponent source, CCustomizations custs, Locator loc) {
+            assert elementName!=null;
+            assert target!=null;
+
+            this.elementName = elementName;
+            this.target = target;
+            this.source = source;
+            this.custs = custs;
+            this.nillable = nillable;
+            this.defaultValue = defaultValue;
+            this.locator = loc;
+        }
+
+        public XmlTypeRef(QName elementName, XSType target, boolean nillable, XmlString defaultValue) {
+            this(elementName,Ring.get(ClassSelector.class).bindToType(target), nillable, defaultValue, target,
+                    Ring.get(BGMBuilder.class).getBindInfo(target).toCustomizationList(),
+                    target.getLocator());
+        }
+
+        public XmlTypeRef(XSElementDecl decl) {
+            this(new QName(decl.getTargetNamespace(),decl.getName()),bindToType(decl),
+                    decl.isNillable(), decl.getDefaultValue(), decl,
+                    Ring.get(BGMBuilder.class).getBindInfo(decl).toCustomizationList(),
+                    decl.getLocator());
+        }
+
+        protected CTypeRef toTypeRef(CElementPropertyInfo ep) {
+            if(ep!=null && target.getAdapterUse()!=null)
+                ep.setAdapter(target.getAdapterUse());
+            return new CTypeRef((CNonElement)target.getInfo(),elementName,nillable,defaultValue);
+        }
+
+        /**
+         * The whole type set can be later bound to a reference property,
+         * in which case we need to generate additional code to wrap this
+         * type reference into an element class.
+         *
+         * This method generates such an element class and returns it.
+         */
+        protected void toElementRef(CReferencePropertyInfo prop) {
+            CClassInfo scope = Ring.get(ClassSelector.class).getCurrentBean();
+            Model model = Ring.get(Model.class);
+
+            if(target instanceof CClassInfo && Ring.get(BIGlobalBinding.class).isSimpleMode()) {
+                CClassInfo bean = new CClassInfo(model,scope,
+                                model.getNameConverter().toClassName(elementName.getLocalPart()),
+                                locator,null,elementName,source,custs);
+                bean.setBaseClass((CClassInfo)target);
+                prop.getElements().add(bean);
+            } else {
+                CElementInfo e = new CElementInfo(model,elementName,scope,target,defaultValue,source,custs,locator);
+                prop.getElements().add(e);
+            }
+        }
+
+        protected Mode canBeType(RawTypeSet parent) {
+            // if we have an adapter or IDness, which requires special
+            // annotation, and there's more than one element,
+            // we have no place to put the special annotation, so we need JAXBElement.
+            if(parent.refs.size()>1 || !parent.mul.isAtMostOnce()) {
+                if(target.getAdapterUse()!=null || target.idUse()!=ID.NONE)
+                    return Mode.MUST_BE_REFERENCE;
+            }
+
+            // nillable and optional at the same time. needs an element wrapper to distinguish those
+            // two states. But this is not a hard requirement.
+            if(nillable && parent.mul.isOptional())
+                return Mode.CAN_BE_TYPEREF;
+
+            return Mode.SHOULD_BE_TYPEREF;
+        }
+
+        protected boolean isListOfValues() {
+            return target.isCollection();
+        }
+
+        protected ID id() {
+            return target.idUse();
+        }
+
+        protected MimeType getExpectedMimeType() {
+            return target.getExpectedMimeType();
+        }
+    }
+
+    private static TypeUse bindToType(XSElementDecl decl) {
+        SimpleTypeBuilder stb = Ring.get(SimpleTypeBuilder.class);
+        stb.refererStack.push(decl);
+        TypeUse r = Ring.get(ClassSelector.class).bindToType(decl.getType());
+        stb.refererStack.pop();
+        return r;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Ring.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Ring.java
new file mode 100644
index 0000000..cdeedee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Ring.java
@@ -0,0 +1,132 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader;
+
+import java.lang.reflect.Constructor;
+import java.lang.reflect.InvocationTargetException;
+import java.util.HashMap;
+import java.util.Map;
+
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.model.Model;
+
+/**
+ * Holds all the binding related singleton components in a "ring",
+ * and let you access those components, creating them as necessary.
+ *
+ * <p>
+ * A {@link Ring} is local to a thread,
+ * and only one instanceof {@link Ring} can be active at any given time.
+ *
+ * Use {@link #begin()} and {@link #end(Ring)} to start/end a ring scope.
+ * Inside a scope, use {@link #get()} to obtain the instance.
+ *
+ * <p>
+ * When a {@link Model} is built by the reader, an active {@link Ring} scope
+ * is assumed.
+ *
+ *
+ * <h2>Components in Ring</h2>
+ * <p>
+ * Depending on the schema language we are dealing with, different
+ * components are in the model. But at least the following components
+ * are in the ring.
+ *
+ * <ul>
+ *  <li>{@link ErrorReceiver}
+ * </ul>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Ring {
+
+    private final Map<Class,Object> components = new HashMap<Class,Object>();
+
+    private static final ThreadLocal<Ring> instances = new ThreadLocal<Ring>() {
+        public Ring initialValue() {
+            return new Ring();
+        }
+    };
+
+    private Ring() {}
+
+    public static <T> void add( Class<T> clazz, T instance ) {
+        assert !get().components.containsKey(clazz);
+        get().components.put(clazz,instance);
+    }
+
+    public static <T> void add( T o ) {
+        add((Class<T>)o.getClass(),o);
+    }
+
+    public static <T> T get( Class<T> key ) {
+        T t = (T)get().components.get(key);
+        if(t==null) {
+            try {
+                Constructor<T> c = key.getDeclaredConstructor();
+                c.setAccessible(true);
+                t = c.newInstance();
+                if(!get().components.containsKey(key))
+                    // many components register themselves.
+                    add(key,t);
+            } catch (InstantiationException e) {
+                throw new Error(e);
+            } catch (IllegalAccessException e) {
+                throw new Error(e);
+            } catch (NoSuchMethodException e) {
+                throw new Error(e);
+            } catch (InvocationTargetException e) {
+                throw new Error(e);
+            }
+        }
+
+        assert t!=null;
+        return t;
+    }
+
+    /**
+     * A {@link Ring} instance is associated with a thread.
+     */
+    public static Ring get() {
+        return instances.get();
+    }
+
+    /**
+     * Starts a new scope.
+     */
+    public static Ring begin() {
+        Ring r = instances.get();
+        instances.set(new Ring());
+        return r;
+    }
+
+    /**
+     * Ends a scope.
+     */
+    public static void end(Ring old) {
+        instances.set(old);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/TypeUtil.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/TypeUtil.java
new file mode 100644
index 0000000..5643aa4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/TypeUtil.java
@@ -0,0 +1,267 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Comparator;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+import java.util.TreeSet;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JClassAlreadyExistsException;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+
+import org.xml.sax.Locator;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Type-related utility methods.
+ *
+ * @author
+ *    <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public class TypeUtil {
+
+
+    /**
+     * Computes the common base type of two types.
+     *
+     * @param types
+     *      set of {@link JType} objects.
+     */
+    public static JType getCommonBaseType( JCodeModel codeModel, Collection<? extends JType> types ) {
+        return getCommonBaseType( codeModel, types.toArray(new JType[types.size()]) );
+    }
+
+    /**
+     * Computes the common base type of types.
+     *
+     * TODO: this is a very interesting problem. Since one type has possibly
+     * multiple base types, it's not an easy problem.
+     * The current implementation is very naive.
+     *
+     * To make the result deterministic across differente JVMs, we have to
+     * use a Set whose ordering is deterministic.
+     */
+    public static JType getCommonBaseType(JCodeModel codeModel, JType... t) {
+        // first, eliminate duplicates.
+        Set<JType> uniqueTypes = new TreeSet<JType>(typeComparator);
+        for (JType type : t)
+            uniqueTypes.add(type);
+
+        // if this yields only one type. return now.
+        // this is the only case where we can return a primitive type
+        // from this method
+        if (uniqueTypes.size() == 1)
+            return uniqueTypes.iterator().next();
+
+        // assertion failed. nullType can be used only under a very special circumstance
+        assert !uniqueTypes.isEmpty();
+
+        // the null type doesn't need to be taken into account.
+        uniqueTypes.remove(codeModel.NULL);
+
+        // box all the types and compute the intersection of all types
+        Set<JClass> s = null;
+
+        for (JType type : uniqueTypes) {
+            JClass cls = type.boxify();
+
+            if (s == null)
+                s = getAssignableTypes(cls);
+            else
+                s.retainAll(getAssignableTypes(cls));
+        }
+
+        // any JClass can be casted to Object, so make sure it's always there
+        s.add( codeModel.ref(Object.class));
+
+        // refine 's' by removing "lower" types.
+        // for example, if we have both java.lang.Object and
+        // java.io.InputStream, then we don't want to use java.lang.Object.
+
+        JClass[] raw = s.toArray(new JClass[s.size()]);
+        s.clear();
+
+        for (int i = 0; i < raw.length; i++) { // for each raw[i]
+            int j;
+            for (j = 0; j < raw.length; j++) { // see if raw[j] "includes" raw[i]
+                if (i == j)
+                    continue;
+
+                if (raw[i].isAssignableFrom(raw[j]))
+                    break; // raw[j] is derived from raw[i], hence j includes i.
+            }
+
+            if (j == raw.length)
+                // no other type inclueds raw[i]. remember this value.
+                s.add(raw[i]);
+        }
+
+        assert !s.isEmpty(); // since at least java.lang.Object has to be there
+
+        // we now pick the candidate for the return type
+        JClass result = pickOne(s);
+
+        // finally, sometimes this method is used to compute the base type of types like
+        // JAXBElement<A>, JAXBElement<B>, and JAXBElement<C>.
+        // for those inputs, at this point result=JAXBElement.
+        //
+        // here, we'll try to figure out the parameterization
+        // so that we can return JAXBElement<? extends D> instead of just "JAXBElement".
+        if(result.isParameterized())
+            return result;
+
+        // for each uniqueType we store the list of base type parameterization
+        List<List<JClass>> parameters = new ArrayList<List<JClass>>(uniqueTypes.size());
+        int paramLen = -1;
+
+        for (JType type : uniqueTypes) {
+            JClass cls = type.boxify();
+            JClass bp = cls.getBaseClass(result);
+            // if there's no parameterization in the base type,
+            // we won't do any better than <?>. Thus no point in trying to figure out the parameterization.
+            // just return the base type.
+            if(bp.equals(result))
+                return result;
+
+            assert bp.isParameterized();
+            List<JClass> tp = bp.getTypeParameters();
+            parameters.add(tp);
+
+            assert paramLen==-1 || paramLen==tp.size();
+                // since 'bp' always is a parameterized version of 'result', it should always
+                // have the same number of parameters.
+            paramLen = tp.size();
+        }
+
+        List<JClass> paramResult = new ArrayList<JClass>();
+        List<JClass> argList = new ArrayList<JClass>(parameters.size());
+        // for each type parameter compute the common base type
+        for( int i=0; i<paramLen; i++ ) {
+            argList.clear();
+            for (List<JClass> list : parameters)
+                argList.add(list.get(i));
+
+            // compute the lower bound.
+            JClass bound = (JClass)getCommonBaseType(codeModel,argList);
+            boolean allSame = true;
+            for (JClass a : argList)
+                allSame &= a.equals(bound);
+            if(!allSame)
+                bound = bound.wildcard();
+
+            paramResult.add(bound);
+        }
+
+        return result.narrow(paramResult);
+    }
+
+    private static JClass pickOne(Set<JClass> s) {
+        // we may have more than one candidates at this point.
+        // any user-defined generated types should have
+        // precedence over system-defined existing types.
+        //
+        // so try to return such a type if any.
+        for (JClass c : s)
+            if (c instanceof JDefinedClass)
+                return c;
+
+        // we can do more if we like. for example,
+        // we can avoid types in the RI runtime.
+        // but for now, just return the first one.
+        return s.iterator().next();
+    }
+
+    private static Set<JClass> getAssignableTypes( JClass t ) {
+        Set<JClass> r = new TreeSet<JClass>(typeComparator);
+        getAssignableTypes(t,r);
+        return r;
+    }
+
+    /**
+     * Returns the set of all classes/interfaces that a given type
+     * implements/extends, including itself.
+     *
+     * For example, if you pass java.io.FilterInputStream, then the returned
+     * set will contain java.lang.Object, java.lang.InputStream, and
+     * java.lang.FilterInputStream.
+     */
+    private static void getAssignableTypes( JClass t, Set<JClass> s ) {
+        if(!s.add(t))
+            return;
+
+        // add its raw type
+        s.add(t.erasure());
+
+        // if this type is added for the first time,
+        // recursively process the super class.
+        JClass _super = t._extends();
+        if(_super!=null)
+            getAssignableTypes(_super,s);
+
+        // recursively process all implemented interfaces
+        Iterator<JClass> itr = t._implements();
+        while(itr.hasNext())
+            getAssignableTypes(itr.next(),s);
+    }
+
+    /**
+     * Obtains a {@link JType} object for the string representation
+     * of a type.
+     */
+    public static JType getType( JCodeModel codeModel,
+        String typeName, ErrorReceiver errorHandler, Locator errorSource ) {
+
+        try {
+            return codeModel.parseType(typeName);
+        } catch( ClassNotFoundException ee ) {
+
+            // make it a warning
+            errorHandler.warning( new SAXParseException(
+                Messages.ERR_CLASS_NOT_FOUND.format(typeName)
+                ,errorSource));
+
+            // recover by assuming that it's a class that derives from Object
+            return codeModel.directClass(typeName);
+        }
+    }
+
+    /**
+     * Compares {@link JType} objects by their names.
+     */
+    private static final Comparator<JType> typeComparator = new Comparator<JType>() {
+        public int compare(JType t1, JType t2) {
+            return t1.fullName().compareTo(t2.fullName());
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Util.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Util.java
new file mode 100644
index 0000000..cb4b814
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/Util.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader;
+
+import java.io.File;
+import java.io.IOException;
+import java.net.MalformedURLException;
+import java.net.URL;
+
+import org.xml.sax.InputSource;
+
+public class Util
+{
+    /**
+     * Parses the specified string either as an {@link URL} or as a {@link File}.
+     *
+     * @throws IOException
+     *      if the parameter is neither.
+     */
+    public static Object getFileOrURL(String fileOrURL) throws IOException {
+        try {
+            return new URL(fileOrURL);
+        } catch (MalformedURLException e) {
+            return new File(fileOrURL).getCanonicalFile();
+        }
+    }
+    /**
+     * Gets an InputSource from a string, which contains either
+     * a file name or an URL.
+     */
+    public static InputSource getInputSource(String fileOrURL) {
+        try {
+            Object o = getFileOrURL(fileOrURL);
+            if(o instanceof URL) {
+                return new InputSource(escapeSpace(((URL)o).toExternalForm()));
+            } else {
+                String url = ((File)o).toURL().toExternalForm();
+                return new InputSource(escapeSpace(url));
+            }
+        } catch (IOException e) {
+            return new InputSource(fileOrURL);
+        }
+    }
+
+    public static String escapeSpace( String url ) {
+        // URLEncoder didn't work.
+        StringBuffer buf = new StringBuffer();
+        for (int i = 0; i < url.length(); i++) {
+            // TODO: not sure if this is the only character that needs to be escaped.
+            if (url.charAt(i) == ' ')
+                buf.append("%20");
+            else
+                buf.append(url.charAt(i));
+        }
+        return buf.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Block.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Block.java
new file mode 100644
index 0000000..e4c66f1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Block.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd;
+
+import java.util.LinkedHashSet;
+import java.util.Set;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class Block {
+    final boolean isOptional;
+    final boolean isRepeated;
+
+    /**
+     * {@link Element}s that belong to this block.
+     * <p>
+     * We want to preserve the order they are added, but we don't want
+     * dupliates.
+     */
+    final Set<Element> elements = new LinkedHashSet<Element>();
+
+    Block(boolean optional, boolean repeated) {
+        isOptional = optional;
+        isRepeated = repeated;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Element.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Element.java
new file mode 100644
index 0000000..676549a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Element.java
@@ -0,0 +1,318 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CNonElement;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.tools.internal.xjc.model.CValuePropertyInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.reader.dtd.bindinfo.BIConversion;
+import com.sun.tools.internal.xjc.reader.dtd.bindinfo.BIElement;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+import com.sun.xml.internal.dtdparser.DTDEventListener;
+
+import org.xml.sax.Locator;
+
+import static com.sun.tools.internal.xjc.model.CElementPropertyInfo.CollectionMode.NOT_REPEATED;
+import static com.sun.tools.internal.xjc.model.CElementPropertyInfo.CollectionMode.REPEATED_VALUE;
+import static com.sun.tools.internal.xjc.model.CElementPropertyInfo.CollectionMode.REPEATED_ELEMENT;
+
+/**
+ * DTD Element.
+ *
+ * <p>
+ * This class extends {@link Term} to participate in the content model tree.
+ *
+ * <p>
+ * This class is repsonsible for binding the element.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class Element extends Term implements Comparable<Element> {
+
+    /**
+     * Name of the element.
+     */
+    final String name;
+
+    private final TDTDReader owner;
+
+    /**
+     * @see DTDEventListener#endContentModel(String, short)
+     */
+    private short contentModelType;
+
+    private Term contentModel;
+
+    /**
+     * True if this element is referenced from another element.
+     */
+    boolean isReferenced;
+
+    /**
+     * If this element maps to a class, that class representation.
+     * Otherwise null.
+     */
+    private CClassInfo classInfo;
+
+    /**
+     * True if {@link #classInfo} field is computed.
+     */
+    private boolean classInfoComputed;
+
+    /**
+     * List of attribute properties on this element
+     */
+    final List<CPropertyInfo> attributes = new ArrayList<CPropertyInfo>();
+
+    /**
+     * Normalized blocks of the content model.
+     */
+    private final List<Block> normalizedBlocks = new ArrayList<Block>();
+
+    /**
+     * True if this element needs to be a class.
+     *
+     * Currently, if an element is referenced from a construct like (A|B|C),
+     * we require those A,B, and C to be a class.
+     */
+    private boolean mustBeClass;
+
+    /**
+     * The source location where this element is defined.
+     */
+    private Locator locator;
+
+    public Element(TDTDReader owner,String name) {
+        this.owner = owner;
+        this.name = name;
+    }
+
+    void normalize(List<Block> r, boolean optional) {
+        Block o = new Block(optional,false);
+        o.elements.add(this);
+        r.add(o);
+    }
+
+    void addAllElements(Block b) {
+        b.elements.add(this);
+    }
+
+    boolean isOptional() {
+        return false;
+    }
+
+    boolean isRepeated() {
+        return false;
+    }
+
+
+    /**
+     * Define its content model.
+     */
+    void define(short contentModelType, Term contentModel, Locator locator) {
+        assert this.contentModel==null; // may not be called twice
+        this.contentModelType = contentModelType;
+        this.contentModel = contentModel;
+        this.locator = locator;
+        contentModel.normalize(normalizedBlocks,false);
+
+        for( Block b : normalizedBlocks ) {
+            if(b.isRepeated || b.elements.size()>1) {
+                for( Element e : b.elements ) {
+                    owner.getOrCreateElement(e.name).mustBeClass = true;
+                }
+            }
+        }
+    }
+
+    /**
+     * When this element is an PCDATA-only content model,
+     * returns the conversion for it. Otherwise the behavior is undefined.
+     */
+    private TypeUse getConversion() {
+        assert contentModel == Term.EMPTY; // this is PCDATA-only element
+
+        BIElement e = owner.bindInfo.element(name);
+        if(e!=null) {
+            BIConversion conv = e.getConversion();
+            if(conv!=null)
+                return conv.getTransducer();
+        }
+        return CBuiltinLeafInfo.STRING;
+    }
+
+    /**
+     * Return null if this class is not bound to a class.
+     */
+    CClassInfo getClassInfo() {
+        if(!classInfoComputed) {
+            classInfoComputed = true;
+            classInfo = calcClass();
+        }
+        return classInfo;
+    }
+
+    private CClassInfo calcClass() {
+        BIElement e = owner.bindInfo.element(name);
+        if(e==null) {
+            if(contentModelType!=DTDEventListener.CONTENT_MODEL_MIXED
+            || !attributes.isEmpty()
+            || mustBeClass)
+                return createDefaultClass();
+            if(contentModel!=Term.EMPTY) {
+                throw new UnsupportedOperationException("mixed content model not supported");
+            } else {
+                // just #PCDATA
+                if(isReferenced)
+                    return null;
+                else
+                    // if no one else is referencing, assumed to be the root.
+                    return createDefaultClass();
+            }
+        } else {
+            return e.clazz;
+        }
+    }
+
+    private CClassInfo createDefaultClass() {
+        String className = owner.model.getNameConverter().toClassName(name);
+        QName tagName = new QName("",name);
+
+        return new CClassInfo(owner.model,owner.getTargetPackage(),className,locator,null,tagName,null,null/*TODO*/);
+    }
+
+    void bind() {
+        CClassInfo  ci = getClassInfo();
+        assert ci!=null || attributes.isEmpty();
+        for( CPropertyInfo p : attributes )
+            ci.addProperty(p);
+
+        switch(contentModelType) {
+        case DTDEventListener.CONTENT_MODEL_ANY:
+            CReferencePropertyInfo rp = new CReferencePropertyInfo("Content",true,true,null,null/*TODO*/,locator);
+            rp.setWildcard(WildcardMode.SKIP);
+            ci.addProperty(rp);
+            return;
+        case DTDEventListener.CONTENT_MODEL_CHILDREN:
+            break;  // handling follows
+        case DTDEventListener.CONTENT_MODEL_MIXED:
+            if(contentModel!=Term.EMPTY)
+                throw new UnsupportedOperationException("mixed content model unsupported yet");
+
+            if(ci!=null) {
+                // if this element is mapped to a class, just put one property
+                CValuePropertyInfo p = new CValuePropertyInfo("value", null,null/*TODO*/,locator,getConversion());
+                ci.addProperty(p);
+            }
+            return;
+        case DTDEventListener.CONTENT_MODEL_EMPTY:
+            // no content model
+            assert ci!=null;
+            return;
+        }
+
+        // normalize
+        List<Block> n = new ArrayList<Block>();
+        contentModel.normalize(n,false);
+
+        {// check collision among Blocks
+            Set<String> names = new HashSet<String>();
+            boolean collision = false;
+
+            OUTER:
+            for( Block b : n )
+                for( Element e : b.elements )
+                    if(!names.add(e.name)) {
+                        collision = true;
+                        break OUTER;
+                    }
+
+            if(collision) {
+                // collapse all blocks into one
+                Block all = new Block(true,true);
+                for( Block b : n )
+                    all.elements.addAll(b.elements);
+                n.clear();
+                n.add(all);
+            }
+        }
+
+        for( Block b : n ) {
+            CElementPropertyInfo p;
+            if(b.isRepeated || b.elements.size()>1) {
+                // collection
+                StringBuilder name = new StringBuilder();
+                for( Element e : b.elements ) {
+                    if(name.length()>0)
+                        name.append("Or");
+                    name.append(owner.model.getNameConverter().toPropertyName(e.name));
+                }
+                p = new CElementPropertyInfo(name.toString(), REPEATED_ELEMENT, ID.NONE, null, null,null/*TODO*/, locator, !b.isOptional );
+                for( Element e : b.elements ) {
+                    CClassInfo child = owner.getOrCreateElement(e.name).getClassInfo();
+                    assert child!=null; // we are requiring them to be classes.
+                    p.getTypes().add(new CTypeRef(child,new QName("",e.name),false,null));
+                }
+            } else {
+                // single property
+                String name = b.elements.iterator().next().name;
+                String propName = owner.model.getNameConverter().toPropertyName(name);
+
+                TypeUse refType;
+                Element ref = owner.getOrCreateElement(name);
+                if(ref.getClassInfo()!=null)
+                    refType = ref.getClassInfo();
+                else {
+                    refType = ref.getConversion().getInfo();
+                }
+
+                p = new CElementPropertyInfo(propName,
+                    refType.isCollection()?REPEATED_VALUE:NOT_REPEATED, ID.NONE, null, null,null/*TODO*/, locator, !b.isOptional );
+
+                p.getTypes().add(new CTypeRef((CNonElement)refType.getInfo(),new QName("",name),false,null));
+            }
+            ci.addProperty(p);
+        }
+    }
+
+    public int compareTo(Element that) {
+        return this.name.compareTo(that.name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/MessageBundle.properties
new file mode 100644
index 0000000..f0e9960
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/MessageBundle.properties
@@ -0,0 +1,24 @@
+TDTDReader.NoRootElement = \
+	No root element was specified.
+
+TDTDReader.UndefinedElementInBindInfo = \
+	Binding information contains element "{0}", but it's not defined in DTD.
+
+TDTDReader.ConversionForNonValueElement = \
+	Conversion declaration is specified for the element "{0}", but \
+	the content model of this element is not #PCDATA.
+
+TDTDReader.ContentProperty.ParticleMismatch = \
+	The content model of the element "{0}" does not match \
+	the content-property declaration of the specified binding information.
+
+TDTDReader.ContentProperty.DeclarationTooShort = \
+	The content-property declaration for the element "{0}" is too short.
+
+TDTDReader.BindInfo.NonExistentElementDeclaration = \
+	DTD does not contain the element "{0}"
+
+TDTDReader.BindInfo.NonExistentInterfaceMember = \
+	"{0}" is specified as a member of an interface, \
+	but there is no such class nor interface.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Messages.java
new file mode 100644
index 0000000..93aae3c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Messages.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getPackage().getName() + ".MessageBundle").getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+
+    public static final String ERR_NO_ROOT_ELEMENT = // arg:0
+        "TDTDReader.NoRootElement";
+
+    public static final String ERR_UNDEFINED_ELEMENT_IN_BINDINFO = // arg:1
+        "TDTDReader.UndefinedElementInBindInfo";
+
+    public static final String ERR_CONVERSION_FOR_NON_VALUE_ELEMENT = // arg:1
+        "TDTDReader.ConversionForNonValueElement";
+
+    public static final String ERR_CONTENT_PROPERTY_PARTICLE_MISMATCH = // arg:1
+        "TDTDReader.ContentProperty.ParticleMismatch";
+
+    public static final String ERR_CONTENT_PROPERTY_DECLARATION_TOO_SHORT = // arg:1
+        "TDTDReader.ContentProperty.DeclarationTooShort";
+
+    public static final String ERR_BINDINFO_NON_EXISTENT_ELEMENT_DECLARATION = // arg:1
+        "TDTDReader.BindInfo.NonExistentElementDeclaration";
+
+    public static final String ERR_BINDINFO_NON_EXISTENT_INTERFACE_MEMBER = // arg:1
+        "TDTDReader.BindInfo.NonExistentInterfaceMember";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/ModelGroup.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/ModelGroup.java
new file mode 100644
index 0000000..1f83d88
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/ModelGroup.java
@@ -0,0 +1,138 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import com.sun.xml.internal.dtdparser.DTDEventListener;
+
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class ModelGroup extends Term {
+    enum Kind {
+        CHOICE, SEQUENCE
+    }
+
+    Kind kind;
+
+    private final List<Term> terms = new ArrayList<Term>();
+
+    void normalize(List<Block> r, boolean optional) {
+        switch(kind) {
+        case SEQUENCE:
+            for( Term t : terms )
+                t.normalize(r,optional);
+            return;
+        case CHOICE:
+            Block b = new Block(isOptional()||optional,isRepeated());
+            addAllElements(b);
+            r.add(b);
+            return;
+        }
+    }
+
+    void addAllElements(Block b) {
+        for( Term t : terms )
+            t.addAllElements(b);
+    }
+
+    boolean isOptional() {
+        switch(kind) {
+        case SEQUENCE:
+            for( Term t : terms )
+                if(!t.isOptional())
+                    return false;
+            return true;
+        case CHOICE:
+            for( Term t : terms )
+                if(t.isOptional())
+                    return true;
+            return false;
+        default:
+            throw new IllegalArgumentException();
+        }
+    }
+
+    boolean isRepeated() {
+        switch(kind) {
+        case SEQUENCE:
+            return true;
+        case CHOICE:
+            for( Term t : terms )
+                if(t.isRepeated())
+                    return true;
+            return false;
+        default:
+            throw new IllegalArgumentException();
+        }
+    }
+
+    void setKind(short connectorType) {
+        Kind k;
+        switch(connectorType) {
+        case DTDEventListener.SEQUENCE:
+            k = Kind.SEQUENCE;
+            break;
+        case DTDEventListener.CHOICE:
+            k = Kind.CHOICE;
+            break;
+        default:
+            throw new IllegalArgumentException();
+        }
+
+        assert kind==null || k==kind;
+        kind = k;
+    }
+
+    void addTerm(Term t) {
+        if (t instanceof ModelGroup) {
+            ModelGroup mg = (ModelGroup) t;
+            if(mg.kind==this.kind) {
+                terms.addAll(mg.terms);
+                return;
+            }
+        }
+        terms.add(t);
+    }
+
+
+    Term wrapUp() {
+        switch(terms.size()) {
+        case 0:
+            return EMPTY;
+        case 1:
+            assert kind==null;
+            return terms.get(0);
+        default:
+            assert kind!=null;
+            return this;
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Occurence.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Occurence.java
new file mode 100644
index 0000000..41924a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Occurence.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd;
+
+import java.util.List;
+
+import com.sun.xml.internal.dtdparser.DTDEventListener;
+
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class Occurence extends Term {
+    final Term term;
+    final boolean isOptional;
+    final boolean isRepeated;
+
+    Occurence(Term term, boolean optional, boolean repeated) {
+        this.term = term;
+        isOptional = optional;
+        isRepeated = repeated;
+    }
+
+    static Term wrap( Term t, int occurence ) {
+        switch(occurence) {
+        case DTDEventListener.OCCURENCE_ONCE:
+            return t;
+        case DTDEventListener.OCCURENCE_ONE_OR_MORE:
+            return new Occurence(t,false,true);
+        case DTDEventListener.OCCURENCE_ZERO_OR_MORE:
+            return new Occurence(t,true,true);
+        case DTDEventListener.OCCURENCE_ZERO_OR_ONE:
+            return new Occurence(t,true,false);
+        default:
+            throw new IllegalArgumentException();
+        }
+    }
+
+    void normalize(List<Block> r, boolean optional) {
+        if(isRepeated) {
+            Block b = new Block(isOptional||optional,true);
+            addAllElements(b);
+            r.add(b);
+        } else {
+            term.normalize(r,optional||isOptional);
+        }
+    }
+
+    void addAllElements(Block b) {
+        term.addAllElements(b);
+    }
+
+    boolean isOptional() {
+        return isOptional||term.isOptional();
+    }
+
+    boolean isRepeated() {
+        return isRepeated||term.isRepeated();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/TDTDReader.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/TDTDReader.java
new file mode 100644
index 0000000..0829ba3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/TDTDReader.java
@@ -0,0 +1,471 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd;
+
+import java.io.IOException;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Stack;
+
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.AbortException;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.model.CAttributePropertyInfo;
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.model.TypeUseFactory;
+import com.sun.tools.internal.xjc.model.CDefaultValue;
+import com.sun.tools.internal.xjc.reader.ModelChecker;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.dtd.bindinfo.BIAttribute;
+import com.sun.tools.internal.xjc.reader.dtd.bindinfo.BIElement;
+import com.sun.tools.internal.xjc.reader.dtd.bindinfo.BIInterface;
+import com.sun.tools.internal.xjc.reader.dtd.bindinfo.BindInfo;
+import com.sun.tools.internal.xjc.util.CodeModelClassFactory;
+import com.sun.tools.internal.xjc.util.ErrorReceiverFilter;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.dtdparser.DTDHandlerBase;
+import com.sun.xml.internal.dtdparser.DTDParser;
+import com.sun.xml.internal.dtdparser.InputEntity;
+import com.sun.xml.internal.xsom.XmlString;
+import com.sun.istack.internal.SAXParseException2;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.LocatorImpl;
+
+/**
+ * Parses DTD grammar along with binding information into BGM.
+ *
+ * @author
+ *    <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public class TDTDReader extends DTDHandlerBase
+{
+    /**
+     * Parses DTD grammar and a binding information into BGM.
+     *
+     * <p>
+     * This method is just a utility method that covers 80% of the use
+     * cases.
+     *
+     * @param    bindingInfo
+     *        binding information file, if any. Can be null.
+     */
+    public static Model parse(
+        InputSource dtd,
+        InputSource bindingInfo,
+        ErrorReceiver errorReceiver,
+        Options opts) {
+
+        try {
+            // set up a ring
+            final Ring old = Ring.begin();
+            try {
+                ErrorReceiverFilter ef = new ErrorReceiverFilter(errorReceiver);
+
+                JCodeModel cm = new JCodeModel();
+                Model model = new Model(opts,cm,NameConverter.standard,opts.classNameAllocator);
+
+                Ring.add(cm);
+                Ring.add(model);
+                Ring.add(ErrorReceiver.class,ef);
+
+                TDTDReader reader = new TDTDReader( ef, opts.entityResolver,
+                    opts, bindingInfo);
+
+                DTDParser parser = new DTDParser();
+                parser.setDtdHandler(reader);
+                if( opts.entityResolver!=null )
+                    parser.setEntityResolver(opts.entityResolver);
+
+                try {
+                    parser.parse(dtd);
+                } catch (SAXParseException e) {
+                    return null; // this error was already handled by GrammarReaderController
+                }
+
+                Ring.get(ModelChecker.class).check();
+
+                if(ef.hadError())   return null;
+                else                return model;
+            } finally {
+                Ring.end(old);
+            }
+        } catch (IOException e) {
+            errorReceiver.error(new SAXParseException2(e.getMessage(),null,e));
+            return null;
+        } catch (SAXException e) {
+            errorReceiver.error(new SAXParseException2(e.getMessage(),null,e));
+            return null;
+        } catch (AbortException e) {
+            // parsing was aborted but the error was already reported
+            return null;
+        }
+    }
+    protected TDTDReader(ErrorReceiver errorReceiver, EntityResolver entityResolver, Options opts, InputSource _bindInfo)
+        throws AbortException {
+        this.entityResolver = entityResolver;
+        this.errorReceiver = new ErrorReceiverFilter(errorReceiver);
+        this.opts = opts;
+        bindInfo = new BindInfo(model,_bindInfo, this.errorReceiver);
+        classFactory = new CodeModelClassFactory(errorReceiver);
+    }
+
+    private final EntityResolver entityResolver;
+
+    private final Options opts;
+
+    /**
+     * binding information.
+     *
+     * <p>
+     * This is always non-null even if no binding information was specified.
+     * (In that case, a dummy object will be provided.)
+     */
+    final BindInfo bindInfo;
+
+    private final JCodeModel codeModel = Ring.get(JCodeModel.class);
+
+    final Model model = Ring.get(Model.class);
+
+    private final CodeModelClassFactory classFactory;
+
+    private final ErrorReceiverFilter errorReceiver;
+
+    /**
+     * Element name to its content model definition.
+     */
+    private final Map<String,Element> elements = new HashMap<String,Element>();
+
+
+    public void startDTD(InputEntity entity) throws SAXException {
+    }
+
+    public void endDTD() throws SAXException {
+
+        // bind them all.
+        // we need to know how elements are referencing each other before we do this,
+        // so this can be only done at the endDTD method
+        for( Element e : elements.values() )
+            e.bind();
+
+        // if there was an error by now, just abort.
+        if (errorReceiver.hadError())
+            return;
+
+        processInterfaceDeclarations();
+
+        // check XJC extensions and realize them
+        model.serialVersionUID = bindInfo.getSerialVersionUID();
+        model.rootClass = bindInfo.getSuperClass();
+        model.rootInterface = bindInfo.getSuperInterface();
+
+// TODO: do we need to reimplement them?
+//        // performs annotation
+//        Annotator.annotate(model, this);
+//        FieldCollisionChecker.check( model, this );
+
+
+        processConstructorDeclarations();
+    }
+
+    /** Processes interface declarations. */
+    private void processInterfaceDeclarations() {
+
+
+        Map<String,InterfaceAcceptor> fromName = new HashMap<String,InterfaceAcceptor>();
+
+        // first, create empty InterfaceItem declaration for all interfaces
+        Map<BIInterface,JClass> decls = new HashMap<BIInterface,JClass>();
+
+        for( BIInterface decl : bindInfo.interfaces() ) {
+            final JDefinedClass intf = classFactory.createInterface(
+                                getTargetPackage(), decl.name(), copyLocator() );
+            decls.put(decl,intf);
+            fromName.put(decl.name(),new InterfaceAcceptor() {
+                public void implement(JClass c) {
+                    intf._implements(c);
+                }
+            });
+        }
+
+        for( final CClassInfo ci : model.beans().values() ) {
+            fromName.put(ci.getName(),new InterfaceAcceptor() {
+                public void implement(JClass c) {
+                    ci._implements(c);
+                }
+            });
+        }
+
+        // traverse the interface declarations again
+        // and populate its expression according to the members attribute.
+        for( Map.Entry<BIInterface,JClass> e : decls.entrySet() ) {
+            BIInterface decl = e.getKey();
+            JClass c = e.getValue();
+
+            for (String member : decl.members()) {
+                InterfaceAcceptor acc = fromName.get(member);
+                if (acc == null) {
+                    // there is no such class/interface
+                    // TODO: error location
+                    error(decl.getSourceLocation(),
+                            Messages.ERR_BINDINFO_NON_EXISTENT_INTERFACE_MEMBER,
+                            member);
+                    continue;
+                }
+
+                acc.implement(c);
+            }
+        }
+
+        // TODO: check the cyclic interface definition
+    }
+
+    private static interface InterfaceAcceptor {
+        void implement( JClass c );
+    }
+
+
+    JPackage getTargetPackage() {
+        // "-p" takes precedence over everything else
+        if(opts.defaultPackage!=null)
+            return codeModel._package(opts.defaultPackage);
+        else
+            return bindInfo.getTargetPackage();
+    }
+
+
+    /**
+     * Creates constructor declarations as specified in the
+     * binding information.
+     *
+     * <p>
+     * Also checks that the binding file does not contain
+     * declarations for non-existent elements.
+     */
+    private void processConstructorDeclarations() {
+        for( BIElement decl: bindInfo.elements() ) {
+            Element e = elements.get(decl.name());
+            if(e==null) {
+                error(decl.getSourceLocation(),
+                    Messages.ERR_BINDINFO_NON_EXISTENT_ELEMENT_DECLARATION,decl.name());
+                continue;   // continue to process next declaration
+            }
+
+            if(!decl.isClass())
+                // only element-class declaration has constructor definitions
+                continue;
+
+            decl.declareConstructors(e.getClassInfo());
+        }
+    }
+
+    public void attributeDecl(String elementName, String attributeName, String attributeType, String[] enumeration, short attributeUse, String defaultValue) throws SAXException {
+        getOrCreateElement(elementName).attributes.add(
+            createAttribute(elementName, attributeName, attributeType, enumeration, attributeUse, defaultValue)
+        );
+    }
+
+    protected CPropertyInfo createAttribute(
+        String elementName, String attributeName, String attributeType,
+        String[] enums, short attributeUse, String defaultValue )
+            throws SAXException {
+
+        boolean required = attributeUse==USE_REQUIRED;
+
+        // get the attribute-property declaration
+        BIElement edecl = bindInfo.element(elementName);
+        BIAttribute decl=null;
+        if(edecl!=null)     decl=edecl.attribute(attributeName);
+
+        String propName;
+        if(decl==null)  propName = model.getNameConverter().toPropertyName(attributeName);
+        else            propName = decl.getPropertyName();
+
+        QName qname = new QName("",attributeName);
+
+        // if no declaration is specified, just wrap it by
+        // a FieldItem and let the normalizer handle its content.
+        TypeUse use;
+
+        if(decl!=null && decl.getConversion()!=null)
+            use = decl.getConversion().getTransducer();
+        else
+            use = builtinConversions.get(attributeType);
+
+        CPropertyInfo r = new CAttributePropertyInfo(
+            propName, null,null/*TODO*/, copyLocator(), qname, use, required );
+
+        if(defaultValue!=null)
+            r.defaultValue = CDefaultValue.create( use, new XmlString(defaultValue) );
+
+        return r;
+    }
+
+
+
+    Element getOrCreateElement( String elementName ) {
+        Element r = elements.get(elementName);
+        if(r==null) {
+            r = new Element(this,elementName);
+            elements.put(elementName,r);
+        }
+
+        return r;
+    }
+
+
+    public void startContentModel(String elementName, short contentModelType) throws SAXException {
+        assert modelGroups.isEmpty();
+        modelGroups.push(new ModelGroup());
+    }
+
+    public void endContentModel(String elementName, short contentModelType) throws SAXException {
+        assert modelGroups.size()==1;
+        Term term = modelGroups.pop().wrapUp();
+
+        Element e = getOrCreateElement(elementName);
+        e.define( contentModelType, term, copyLocator() );
+    }
+
+
+    private final Stack<ModelGroup> modelGroups = new Stack<ModelGroup>();
+
+    public void startModelGroup() throws SAXException {
+        modelGroups.push(new ModelGroup());
+    }
+
+    public void endModelGroup(short occurence) throws SAXException {
+        Term t = Occurence.wrap( modelGroups.pop().wrapUp(), occurence );
+        modelGroups.peek().addTerm(t);
+    }
+
+    public void connector(short connectorType) throws SAXException {
+        modelGroups.peek().setKind(connectorType);
+    }
+
+    // TODO: for now, we just ignore all the content model specification
+    // and treat it as (A,B,C,....)
+
+    public void childElement(String elementName, short occurence) throws SAXException {
+        Element child = getOrCreateElement(elementName);
+        modelGroups.peek().addTerm( Occurence.wrap( child, occurence ) );
+        child.isReferenced = true;
+    }
+
+
+
+
+
+    /**
+     * Mutable {@link Locator} instance that points to
+     * the current source line.
+     * <p>
+     * Use {@link #copyLocator()} to get a immutable clone.
+     */
+    private Locator locator;
+
+    public void setDocumentLocator(Locator loc) {
+        this.locator = loc;
+    }
+
+    /**
+     * Creates a snapshot of the current {@link #locator} values.
+     */
+    private Locator copyLocator(){
+        return new LocatorImpl(locator);
+    }
+
+
+
+//
+//
+// builtin datatype handling
+//
+//
+
+    /** Transducers for the built-in types. Read-only. */
+    private static final Map<String,TypeUse> builtinConversions;
+
+
+    static {
+        // list of datatypes which have built-in conversions.
+        // note that although xs:token and xs:normalizedString are not
+        // specified in the spec, they need to be here because they
+        // have different whitespace normalization semantics.
+        Map<String,TypeUse> m = new HashMap<String,TypeUse>();
+
+        m.put("CDATA",      CBuiltinLeafInfo.NORMALIZED_STRING);
+        m.put("ENTITY",     CBuiltinLeafInfo.TOKEN);
+        m.put("ENTITIES",   CBuiltinLeafInfo.STRING.makeCollection());
+        m.put("NMTOKEN",    CBuiltinLeafInfo.TOKEN);
+        m.put("NMTOKENS",   CBuiltinLeafInfo.STRING.makeCollection());
+        m.put("ID",         CBuiltinLeafInfo.ID);
+        m.put("IDREF",      CBuiltinLeafInfo.IDREF);
+        m.put("IDREFS",     TypeUseFactory.makeCollection(CBuiltinLeafInfo.IDREF));
+        m.put("ENUMERATION",CBuiltinLeafInfo.TOKEN);
+
+        builtinConversions = Collections.unmodifiableMap(m);
+    }
+
+
+//
+//
+// error related utility methods
+//
+//
+    public void error(SAXParseException e) throws SAXException {
+        errorReceiver.error(e);
+    }
+
+    public void fatalError(SAXParseException e) throws SAXException {
+        errorReceiver.fatalError(e);
+    }
+
+    public void warning(SAXParseException e) throws SAXException {
+        errorReceiver.warning(e);
+    }
+
+    protected final void error( Locator loc, String prop, Object... args ) {
+        errorReceiver.error(loc,Messages.format(prop,args));
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Term.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Term.java
new file mode 100644
index 0000000..975a9f5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/Term.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd;
+
+import java.util.List;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class Term {
+    abstract void normalize( List<Block> r, boolean optional );
+
+    abstract void addAllElements(Block b);
+
+    abstract boolean isOptional();
+
+    abstract boolean isRepeated();
+
+    /**
+     * Represents empty term.
+     * <p>
+     * This special term is only used to represent #PCDATA-only content model.
+     */
+    static final Term EMPTY = new Term() {
+        void normalize(List<Block> r, boolean optional) {
+        }
+
+        void addAllElements(Block b) {
+        }
+
+        boolean isOptional() {
+            return false;
+        }
+
+        boolean isRepeated() {
+            return false;
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIAttribute.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIAttribute.java
new file mode 100644
index 0000000..a47c727
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIAttribute.java
@@ -0,0 +1,107 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.util.ArrayList;
+
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRenderer;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRendererFactory;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Element;
+
+/** &lt;attribute> declaration in the binding file. */
+public class BIAttribute
+{
+    /**
+     * Wraps a given &lt;attribute> element.
+     * <p>
+     * Should be created only from {@link BIElement}.
+     */
+    BIAttribute( BIElement _parent, Element _e ) {
+        this.parent = _parent;
+        this.element = _e;
+    }
+
+    private final BIElement parent;
+    private final Element element;
+
+    /** Gets the name of this attribute-property declaration. */
+    public final String name() {
+        return element.getAttribute("name");
+    }
+
+
+    /**
+     * Gets the conversion method for this attribute, if any.
+     *
+     * @return
+     *        If the convert attribute is not specified, this
+     *        method returns null.
+     */
+    public BIConversion getConversion() {
+        if (element.getAttributeNode("convert") == null)
+            return null;
+
+        String cnv = element.getAttribute("convert");
+        return parent.conversion(cnv);
+    }
+
+    /**
+     * Gets the realization of this particle, if any.
+     *
+     * @return
+     *      null if the "collection" attribute was not specified.
+     */
+    public final FieldRenderer getRealization() {
+        Attr a = element.getAttributeNode("collection");
+        if(a==null)     return null;
+
+        String v = element.getAttribute("collection").trim();
+
+        FieldRendererFactory frf = parent.parent.model.options.getFieldRendererFactory();
+        if(v.equals("array"))   return frf.getArray();
+        if(v.equals("list"))
+            return frf.getList(
+                parent.parent.codeModel.ref(ArrayList.class));
+
+        // the correctness of the attribute value must be
+        // checked by the validator.
+        throw new InternalError("unexpected collection value: "+v);
+    }
+
+    /**
+     * Gets the property name for this attribute.
+     *
+     * @return
+     *      always a non-null, valid string.
+     */
+    public final String getPropertyName() {
+        String r = DOMUtil.getAttribute(element,"property");
+        if(r!=null)     return r;
+        else            return name();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIConstructor.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIConstructor.java
new file mode 100644
index 0000000..a04d707
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIConstructor.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.StringTokenizer;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+
+/**
+ * &lt;constructor> declaration in the binding file.
+ *
+ * <p>
+ * Since JAXB will generate both interfaces and implementations,
+ * A constructor declaration will create:
+ *
+ * <ul>
+ *  <li> a method declaration in the factory interface
+ *  <li> a method implementation in the factory implementation class
+ *  <li> a constructor implementation in the actual implementation class
+ * </ul>
+ */
+public class BIConstructor
+{
+    BIConstructor( Element _node ) {
+        this.dom = _node;
+
+        StringTokenizer tokens = new StringTokenizer(
+            DOMUtil.getAttribute(_node,"properties"));
+
+        List<String> vec = new ArrayList<String>();
+        while(tokens.hasMoreTokens())
+            vec.add(tokens.nextToken());
+        properties = vec.toArray(new String[0]);
+
+        if( properties.length==0 )
+            throw new AssertionError("this error should be catched by the validator");
+    }
+
+    /** &lt;constructor> element in the source binding file. */
+    private final Element dom;
+
+    /** properties specified by @properties. */
+    private final String[] properties;
+
+    /**
+     * Creates a constructor declaration into the ClassItem.
+     *
+     * @param   cls
+     *      ClassItem object that corresponds to the
+     *      element declaration that contains this declaration.
+     */
+    public void createDeclaration( CClassInfo cls ) {
+        cls.addConstructor(properties);
+    }
+
+    /** Gets the location where this declaration is declared. */
+    public Locator getSourceLocation() {
+        return DOM4JLocator.getLocationInfo(dom);
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIContent.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIContent.java
new file mode 100644
index 0000000..f1529a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIContent.java
@@ -0,0 +1,138 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.util.ArrayList;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRenderer;
+
+import org.w3c.dom.Element;
+
+/**
+ * Particles in the &lt;content> declaration in the binding file.
+ *
+ */
+public class BIContent
+{
+    /**
+     * Wraps a given particle.
+     *
+     * <p>
+     * This object should be created through
+     * the {@link #create(Element, BIElement)} method.
+     */
+    private BIContent( Element e, BIElement _parent ) {
+        this.element = e;
+        this.parent = _parent;
+        this.opts = parent.parent.model.options;
+    }
+
+    /** The particle element which this object is wrapping. */
+    protected final Element element;
+
+    /** The parent object.*/
+    protected final BIElement parent;
+
+    private final Options opts;
+
+    /**
+     * Gets the realization of this particle, if any.
+     *
+     * @return
+     *      null if the "collection" attribute was not specified.
+     */
+    public final FieldRenderer getRealization() {
+        String v = DOMUtil.getAttribute(element,"collection");
+        if(v==null)     return null;
+
+        v = v.trim();
+        if(v.equals("array"))   return opts.getFieldRendererFactory().getArray();
+        if(v.equals("list"))
+            return opts.getFieldRendererFactory().getList(
+                parent.parent.codeModel.ref(ArrayList.class));
+
+        // the correctness of the attribute value must be
+        // checked by the validator.
+        throw new InternalError("unexpected collection value: "+v);
+    }
+
+    /**
+     * Gets the property name of this particle.
+     *
+     * @return
+     *      always a non-null, valid string.
+     */
+    public final String getPropertyName() {
+        String r = DOMUtil.getAttribute(element,"property");
+
+        // in case of <element-ref>, @property is optional and
+        // defaults to @name.
+        // in all other cases, @property is mandatory.
+        if(r!=null)     return r;
+        return DOMUtil.getAttribute(element,"name");
+    }
+
+    /**
+     * Gets the type of this property, if any.
+     * <p>
+     * &lt;element-ref> particle doesn't have the type.
+     *
+     * @return
+     *      null if none is specified.
+     */
+    public final JClass getType() {
+        try {
+            String type = DOMUtil.getAttribute(element,"supertype");
+            if(type==null)     return null;
+
+            // TODO: does this attribute defaults to the current package?
+            int idx = type.lastIndexOf('.');
+            if(idx<0)   return parent.parent.codeModel.ref(type);
+            else        return parent.parent.getTargetPackage().ref(type);
+        } catch( ClassNotFoundException e ) {
+            // TODO: better error handling
+            throw new NoClassDefFoundError(e.getMessage());
+        }
+    }
+
+
+
+
+
+    /**
+     * Creates an appropriate subclass of BIContent
+     * by sniffing the tag name.
+     * <p>
+     * This method should be only called by the BIElement class.
+     */
+    static BIContent create( Element e, BIElement _parent ) {
+        return new BIContent(e,_parent);
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIConversion.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIConversion.java
new file mode 100644
index 0000000..a66e71a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIConversion.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import com.sun.tools.internal.xjc.model.TypeUse;
+
+/**
+ * conversion declaration (&lt;conversion> and &lt;enumeration>).
+ */
+public interface BIConversion
+{
+    /** Gets the conversion name. */
+    String name();
+
+    /** Gets a transducer for this conversion. */
+    TypeUse getTransducer();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIElement.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIElement.java
new file mode 100644
index 0000000..ea695d9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIElement.java
@@ -0,0 +1,273 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+
+
+/**
+ * &lt;element> declaration in the binding file.
+ */
+public final class BIElement
+{
+    /**
+     * Wraps a given &lt;element> element in the binding file.
+     *
+     * <p>
+     * Should be created only from {@link BindInfo}.
+     */
+    BIElement( BindInfo bi, Element _e ) {
+        this.parent = bi;
+        this.e = _e;
+
+        {
+            Element c = DOMUtil.getElement(e,"content");
+            if(c!=null) {
+                if(DOMUtil.getAttribute(c,"property")!=null) {
+                    // if @property is there, this is a general declaration
+                    this.rest = BIContent.create(c,this);
+                } else {
+                    // this must be a model-based declaration
+                    for( Element p : DOMUtil.getChildElements(c) ) {
+                        if(p.getLocalName().equals("rest"))
+                            this.rest = BIContent.create(p,this);
+                        else
+                            this.contents.add(BIContent.create(p,this));
+                    }
+                }
+            }
+        }
+
+        // parse <attribute>s
+        for( Element atr : DOMUtil.getChildElements(e,"attribute") ) {
+            BIAttribute a = new BIAttribute( this, atr );
+            attributes.put(a.name(),a);
+        }
+
+        if(isClass()) {
+            // if this is a class-declaration, create JClass object now
+            String className = DOMUtil.getAttribute(e,"class");
+            if(className==null)
+                // none was specified. infer the name.
+                className = NameConverter.standard.toClassName(name());
+            this.className = className;
+        } else {
+            // this is not an element-class declaration
+            className = null;
+        }
+
+        // process conversion declarations
+        for( Element conv : DOMUtil.getChildElements(e,"conversion") ) {
+            BIConversion c = new BIUserConversion(bi,conv);
+            conversions.put(c.name(),c);
+        }
+        for( Element en : DOMUtil.getChildElements(e,"enumeration") ) {
+            BIConversion c = BIEnumeration.create(en,this);
+            conversions.put(c.name(),c);
+        }
+
+        // parse <constructor>s
+        for( Element c : DOMUtil.getChildElements(e,"constructor") ) {
+            constructors.add( new BIConstructor(c) );
+        }
+
+        String name = name();
+        QName tagName = new QName("",name);
+
+        this.clazz = new CClassInfo(parent.model,parent.getTargetPackage(),className,getLocation(),null,tagName,null,null/*TODO*/);
+    }
+
+    /**
+     * Gets the source location where this element is declared.
+     */
+    public Locator getLocation() {
+        return DOM4JLocator.getLocationInfo(e);
+    }
+
+
+    /** The parent {@link BindInfo} object to which this object belongs. */
+    final BindInfo parent;
+
+    /** &lt;element> element which this object is wrapping. */
+    private final Element e;
+
+    /**
+     * The bean representation for this element.
+     */
+    public final CClassInfo clazz;
+
+    /**
+     * Content-property declarations.
+     * <p>
+     * This vector will be empty if no content-property declaration is made.
+     */
+    private final List<BIContent> contents = new ArrayList<BIContent>();
+
+    /** Conversion declarations. */
+    private final Map<String,BIConversion> conversions = new HashMap<String,BIConversion>();
+
+    /**
+     * The "rest" content-property declaration.
+     * <p>
+     * This field is null when there was no "rest" declaration.
+     */
+    private BIContent rest;
+
+    /** Attribute-property declarations. */
+    private final Map<String,BIAttribute> attributes = new HashMap<String,BIAttribute>();
+
+    /** Constructor declarations. */
+    private final List<BIConstructor> constructors = new ArrayList<BIConstructor>();
+
+    /**
+     * the class which is generated by this declaration.
+     * This field will be null if this declaration is an element-property
+     * declaration.
+     */
+    private final String className;
+
+
+
+    /** Gets the element name. */
+    public String name() { return DOMUtil.getAttribute(e,"name"); }
+
+    /**
+     * Checks if the element type is "class".
+     * If false, that means this element will be a value.
+     */
+    public boolean isClass() {
+        return "class".equals(e.getAttribute("type"));
+    }
+
+    /**
+     * Checks if this element is designated as a root element.
+     */
+    public boolean isRoot() {
+        return "true".equals(e.getAttribute("root"));
+    }
+
+    /**
+     * Gets the JClass object that represents this declaration.
+     *
+     * <p>
+     * This method returns null if this declaration
+     * is an element-property declaration.
+     */
+    public String getClassName() {
+        return className;
+    }
+
+    /**
+     * Creates constructor declarations for this element.
+     *
+     * <p>
+     * This method should only be called by DTDReader <b>after</b>
+     * the normalization has completed.
+     *
+     * @param   src
+     *      The ClassItem object that corresponds to this declaration
+     */
+    public void declareConstructors( CClassInfo src ) {
+        for( BIConstructor c : constructors )
+            c.createDeclaration(src);
+    }
+
+    /**
+     * Gets the conversion method for this element.
+     *
+     * <p>
+     * This method can be called only when this element
+     * declaration is designated as element-value.
+     *
+     * @return
+     *        If the convert attribute is not specified, this
+     *        method returns null.
+     */
+    public BIConversion getConversion() {
+          String cnv = DOMUtil.getAttribute(e,"convert");
+          if(cnv==null)        return null;
+
+          return conversion(cnv);
+    }
+
+    /**
+     * Resolves the conversion name to the conversion declaration.
+     *
+     * <p>
+     * Element-local declarations are checked first.
+     *
+     * @return
+     *        A non-null valid BIConversion object.
+     */
+    public BIConversion conversion( String name ) {
+        BIConversion r = conversions.get(name);
+        if(r!=null)     return r;
+
+        // check the global conversion declarations
+        return parent.conversion(name);
+    }
+
+
+    /**
+     * Iterates all content-property declarations (except 'rest').
+     */
+    public List<BIContent> getContents() {
+        return contents;
+    }
+
+    /**
+     * Gets the attribute-property declaration, if any.
+     *
+     * @return
+     *      null if attribute declaration was not given by that name.
+     */
+    public BIAttribute attribute( String name ) {
+        return attributes.get(name);
+    }
+
+    /**
+     * Gets the 'rest' content-property declaration, if any.
+     * @return
+     *      if there is no 'rest' declaration, return null.
+     */
+    public BIContent getRest() { return this.rest; }
+
+    /** Gets the location where this declaration is declared. */
+    public Locator getSourceLocation() {
+        return DOM4JLocator.getLocationInfo(e);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIEnumeration.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIEnumeration.java
new file mode 100644
index 0000000..3b9382a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIEnumeration.java
@@ -0,0 +1,112 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.StringTokenizer;
+
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.CClassInfoParent;
+import com.sun.tools.internal.xjc.model.CEnumConstant;
+import com.sun.tools.internal.xjc.model.CEnumLeafInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.model.TypeUse;
+
+import org.w3c.dom.Element;
+
+/**
+ * &lt;enumeration> declaration in the binding file.
+ */
+public final class BIEnumeration implements BIConversion
+{
+    /** Creates an object from &lt;enumeration> declaration. */
+    private BIEnumeration( Element _e, TypeUse _xducer ) {
+        this.e = _e;
+        this.xducer = _xducer;
+    }
+
+    /** &lt;enumeration> element in DOM. */
+    private final Element e;
+
+    private final TypeUse xducer;
+
+    public String name() { return DOMUtil.getAttribute(e,"name"); }
+
+    /** Returns a transducer for this enumeration declaration. */
+    public TypeUse getTransducer() { return xducer; }
+
+
+
+
+    /** Creates a global enumeration declaration. */
+    static BIEnumeration create( Element dom, BindInfo parent ) {
+        // create a class in the target package.
+        return new BIEnumeration(
+            dom,
+            new CEnumLeafInfo(
+                parent.model,
+                null,
+                new CClassInfoParent.Package(parent.getTargetPackage()),
+                DOMUtil.getAttribute(dom,"name"),
+                CBuiltinLeafInfo.STRING,
+                buildMemberList(parent.model,dom),
+                null, null/*TODO*/,
+                DOM4JLocator.getLocationInfo(dom)));
+    }
+
+    /** Creates an element-local enumeration declaration. */
+    static BIEnumeration create( Element dom, BIElement parent ) {
+        // create a class as a nested class
+        return new BIEnumeration(
+            dom,
+            new CEnumLeafInfo(
+                parent.parent.model,
+                null,
+                parent.clazz,
+                DOMUtil.getAttribute(dom,"name"),
+                CBuiltinLeafInfo.STRING,
+                buildMemberList(parent.parent.model,dom),
+                null, null/*TODO*/,
+                DOM4JLocator.getLocationInfo(dom) ));
+    }
+
+    private static List<CEnumConstant> buildMemberList( Model model, Element dom ) {
+        List<CEnumConstant> r = new ArrayList<CEnumConstant>();
+
+        String members = DOMUtil.getAttribute(dom,"members");
+        if(members==null) members="";   // TODO: error handling
+
+        StringTokenizer tokens = new StringTokenizer(members);
+        while(tokens.hasMoreTokens()) {
+            String token = tokens.nextToken();
+            r.add(new CEnumConstant(model.getNameConverter().toConstantName(token),
+                    null,token,null));
+        }
+
+        return r;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIInterface.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIInterface.java
new file mode 100644
index 0000000..5cc68f8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIInterface.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.util.StringTokenizer;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+
+/**
+ * &lt;interface> declaration in the binding file.
+ */
+public final class BIInterface
+{
+    BIInterface( Element e ) {
+        this.dom = e;
+        name = DOMUtil.getAttribute(e,"name");
+        members = parseTokens(DOMUtil.getAttribute(e,"members"));
+
+        if(DOMUtil.getAttribute(e,"properties")!=null) {
+            fields = parseTokens(DOMUtil.getAttribute(e,"properties"));
+            throw new AssertionError("//interface/@properties is not supported");
+        } else    // no property was specified
+            fields = new String[0];
+    }
+
+    /** &lt;interface> element in the binding file. */
+    private final Element dom;
+
+    /** Name of the generated Java interface. */
+    private final String name;
+
+    /**
+     * Gets the name of this interface.
+     * This name should also used as the class name.
+     */
+    public String name() { return name; }
+
+
+    private final String[] members;
+
+    /**
+     * Gets the names of interfaces/classes that implement
+     * this interface.
+     */
+    public String[] members() { return members; }
+
+
+    private final String[] fields;
+
+    /** Gets the names of fields in this interface. */
+    public String[] fields() { return fields; }
+
+
+    /** Gets the location where this declaration is declared. */
+    public Locator getSourceLocation() {
+        return DOM4JLocator.getLocationInfo(dom);
+    }
+
+
+
+    /** splits a list into an array of strings. */
+    private static String[] parseTokens( String value ) {
+        StringTokenizer tokens = new StringTokenizer(value);
+
+        String[] r = new String[tokens.countTokens()];
+        int i=0;
+        while(tokens.hasMoreTokens())
+            r[i++] = tokens.nextToken();
+
+        return r;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIUserConversion.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIUserConversion.java
new file mode 100644
index 0000000..35edd57
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BIUserConversion.java
@@ -0,0 +1,228 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.io.IOException;
+import java.io.StringReader;
+import java.util.Map;
+
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.ParserConfigurationException;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JClassAlreadyExistsException;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JPrimitiveType;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.model.CAdapter;
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.model.TypeUseFactory;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.ClassSelector;
+
+import org.w3c.dom.Element;
+import org.xml.sax.InputSource;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+/**
+ * &lt;conversion> declaration in the binding file.
+ * This declaration declares a conversion by user-specified methods.
+ */
+public class BIUserConversion implements BIConversion
+{
+    /**
+     * Wraps a given &lt;conversion> element in the binding file.
+     */
+    BIUserConversion( BindInfo bi, Element _e ) {
+        this.owner = bi;
+        this.e = _e;
+    }
+
+    private static void add( Map<String,BIConversion> m, BIConversion c ) {
+        m.put( c.name(), c );
+    }
+
+    /** Adds all built-in conversions into the given map. */
+    static void addBuiltinConversions( BindInfo bi, Map<String,BIConversion> m ) {
+        add( m, new BIUserConversion( bi, parse("<conversion name='boolean' type='java.lang.Boolean' parse='getBoolean' />")));
+        add( m, new BIUserConversion( bi, parse("<conversion name='byte' type='java.lang.Byte' parse='parseByte' />")));
+        add( m, new BIUserConversion( bi, parse("<conversion name='short' type='java.lang.Short' parse='parseShort' />")));
+        add( m, new BIUserConversion( bi, parse("<conversion name='int' type='java.lang.Integer' parse='parseInt' />")));
+        add( m, new BIUserConversion( bi, parse("<conversion name='long' type='java.lang.Long' parse='parseLong' />")));
+        add( m, new BIUserConversion( bi, parse("<conversion name='float' type='java.lang.Float' parse='parseFloat' />")));
+        add( m, new BIUserConversion( bi, parse("<conversion name='double' type='java.lang.Double' parse='parseDouble' />")));
+    }
+
+    private static Element parse(String text) {
+        try {
+            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+            dbf.setNamespaceAware(true);
+            InputSource is = new InputSource(new StringReader(text));
+            return dbf.newDocumentBuilder().parse(is).getDocumentElement();
+        } catch (SAXException x) {
+            throw new Error(x);
+        } catch (IOException x) {
+            throw new Error(x);
+        } catch (ParserConfigurationException x) {
+            throw new Error(x);
+        }
+    }
+
+
+    /** The owner {@link BindInfo} object to which this object belongs. */
+    private final BindInfo owner;
+
+    /** &lt;conversion> element which this object is wrapping. */
+    private final Element e;
+
+
+
+    /** Gets the location where this declaration is declared. */
+    public Locator getSourceLocation() {
+        return DOM4JLocator.getLocationInfo(e);
+    }
+
+    /** Gets the conversion name. */
+    public String name() { return DOMUtil.getAttribute(e,"name"); }
+
+    /** Gets a transducer for this conversion. */
+    public TypeUse getTransducer() {
+
+        String ws = DOMUtil.getAttribute(e,"whitespace");
+        if(ws==null)    ws = "collapse";
+
+        String type = DOMUtil.getAttribute(e,"type");
+        if(type==null)  type=name();
+        JType t=null;
+
+        int idx = type.lastIndexOf('.');
+        if(idx<0) {
+            // no package name is specified.
+            try {
+                t = JPrimitiveType.parse(owner.codeModel,type);
+            } catch( IllegalArgumentException e ) {
+                // otherwise treat it as a class name in the current package
+                type = owner.getTargetPackage().name()+'.'+type;
+            }
+        }
+        if(t==null) {
+            try {
+                // TODO: revisit this later
+                JDefinedClass cls = owner.codeModel._class(type);
+                cls.hide();
+                t = cls;
+            } catch( JClassAlreadyExistsException e ) {
+                t = e.getExistingClass();
+            }
+        }
+
+        String parse = DOMUtil.getAttribute(e,"parse");
+        if(parse==null)  parse="new";
+
+        String print = DOMUtil.getAttribute(e,"print");
+        if(print==null)  parse="toString";
+
+        JDefinedClass adapter = generateAdapter(owner.codeModel, parse, print, t.boxify());
+
+        // XmlJavaType customization always converts between string and an user-defined type.
+        return TypeUseFactory.adapt(CBuiltinLeafInfo.STRING,new CAdapter(adapter));
+    }
+
+    // TODO: anyway to reuse this code between XML Schema compiler?
+    private JDefinedClass generateAdapter(JCodeModel cm, String parseMethod, String printMethod, JClass inMemoryType) {
+        JDefinedClass adapter = null;
+
+        int id = 1;
+        while(adapter==null) {
+            try {
+                JPackage pkg = Ring.get(ClassSelector.class).getClassScope().getOwnerPackage();
+                adapter = pkg._class("Adapter"+id);
+            } catch (JClassAlreadyExistsException e) {
+                // try another name in search for an unique name.
+                // this isn't too efficient, but we expect people to usually use
+                // a very small number of adapters.
+                id++;
+            }
+        }
+
+        adapter._extends(cm.ref(XmlAdapter.class).narrow(String.class).narrow(inMemoryType));
+
+        JMethod unmarshal = adapter.method(JMod.PUBLIC, inMemoryType, "unmarshal");
+        JVar $value = unmarshal.param(String.class, "value");
+
+        JExpression inv;
+
+        if( parseMethod.equals("new") ) {
+            // "new" indicates that the constructor of the target type
+            // will do the unmarshalling.
+
+            // RESULT: new <type>()
+            inv = JExpr._new(inMemoryType).arg($value);
+        } else {
+            int idx = parseMethod.lastIndexOf('.');
+            if(idx<0) {
+                // parseMethod specifies the static method of the target type
+                // which will do the unmarshalling.
+
+                // because of an error check at the constructor,
+                // we can safely assume that this cast works.
+                inv = inMemoryType.staticInvoke(parseMethod).arg($value);
+            } else {
+                inv = JExpr.direct(parseMethod+"(value)");
+            }
+        }
+        unmarshal.body()._return(inv);
+
+
+        JMethod marshal = adapter.method(JMod.PUBLIC, String.class, "marshal");
+        $value = marshal.param(inMemoryType,"value");
+
+        int idx = printMethod.lastIndexOf('.');
+        if(idx<0) {
+            // printMethod specifies a method in the target type
+            // which performs the serialization.
+
+            // RESULT: <value>.<method>()
+            inv = $value.invoke(printMethod);
+        } else {
+            // RESULT: <className>.<method>(<value>)
+            inv = JExpr.direct(printMethod+"(value)");
+        }
+        marshal.body()._return(inv);
+
+        return adapter;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BindInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BindInfo.java
new file mode 100644
index 0000000..1a0d97f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/BindInfo.java
@@ -0,0 +1,298 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.io.IOException;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.parsers.SAXParserFactory;
+import javax.xml.validation.ValidatorHandler;
+
+import com.sun.codemodel.internal.ClassType;
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JClassAlreadyExistsException;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.istack.internal.SAXParseException2;
+import com.sun.tools.internal.xjc.AbortException;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.SchemaCache;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.util.CodeModelClassFactory;
+import com.sun.tools.internal.xjc.util.ErrorReceiverFilter;
+import com.sun.tools.internal.xjc.util.ForkContentHandler;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+
+/**
+ * Root of the binding information.
+ */
+public class BindInfo
+{
+    /** Controller object that can be used to report errors. */
+    protected final ErrorReceiver errorReceiver;
+
+    /*package*/ final Model model;
+
+    /**
+     * The -p option that should control the default Java package that
+     * will contain the generated code. Null if unspecified. This takes
+     * precedence over the value specified in the binding file.
+     */
+    private final String defaultPackage;
+
+    public BindInfo(Model model, InputSource source, ErrorReceiver _errorReceiver) throws AbortException {
+
+        this( model, parse(source,_errorReceiver), _errorReceiver);
+    }
+
+    public BindInfo(Model model, Document _dom, ErrorReceiver _errorReceiver) {
+        this.model = model;
+        this.dom = _dom.getDocumentElement();
+        this.codeModel = model.codeModel;
+        this.errorReceiver = _errorReceiver;
+        this.classFactory = new CodeModelClassFactory(_errorReceiver);
+        // TODO: decide name converter from the binding file
+
+        this.defaultPackage = model.options.defaultPackage;
+
+        // process element declarations
+        for( Element ele : DOMUtil.getChildElements(dom,"element")) {
+            BIElement e = new BIElement(this,ele);
+            elements.put(e.name(),e);
+        }
+
+        // add built-in conversions
+        BIUserConversion.addBuiltinConversions(this,conversions);
+
+        // process conversion declarations
+        for( Element cnv : DOMUtil.getChildElements(dom,"conversion")) {
+            BIConversion c = new BIUserConversion(this,cnv);
+            conversions.put(c.name(),c);
+        }
+        for( Element en : DOMUtil.getChildElements(dom,"enumeration")) {
+            BIConversion c = BIEnumeration.create( en, this );
+            conversions.put(c.name(),c);
+        }
+        // TODO: check the uniquness of conversion name
+
+
+        // process interface definitions
+        for( Element itf : DOMUtil.getChildElements(dom,"interface")) {
+            BIInterface c = new BIInterface(itf);
+            interfaces.put(c.name(),c);
+        }
+    }
+
+
+    /** CodeModel object that is used by this binding file. */
+    final JCodeModel codeModel;
+
+    /** Wrap the codeModel object and automate error reporting. */
+    final CodeModelClassFactory classFactory;
+
+    /** DOM tree that represents binding info. */
+    private final Element dom;
+
+    /** Conversion declarations. */
+    private final Map<String,BIConversion> conversions = new HashMap<String,BIConversion>();
+
+    /** Element declarations keyed by names. */
+    private final Map<String,BIElement> elements = new HashMap<String,BIElement>();
+
+    /** interface declarations keyed by names. */
+    private final Map<String,BIInterface> interfaces = new HashMap<String,BIInterface>();
+
+
+    /** XJC extension namespace. */
+    private static final String XJC_NS = Const.XJC_EXTENSION_URI;
+
+//
+//
+//    Exposed public methods
+//
+//
+    /** Gets the serialVersionUID if it's turned on. */
+    public Long getSerialVersionUID() {
+        Element serial = DOMUtil.getElement(dom,XJC_NS,"serializable");
+        if(serial==null)    return null;
+
+        String v = DOMUtil.getAttribute(serial,"uid");
+        if(v==null) v="1";
+        return new Long(v);
+    }
+
+    /** Gets the xjc:superClass customization if it's turned on. */
+    public JClass getSuperClass() {
+        Element sc = DOMUtil.getElement(dom,XJC_NS,"superClass");
+        if (sc == null) return null;
+
+        JDefinedClass c;
+
+        try {
+            String v = DOMUtil.getAttribute(sc,"name");
+            if(v==null)     return null;
+            c = codeModel._class(v);
+            c.hide();
+        } catch (JClassAlreadyExistsException e) {
+            c = e.getExistingClass();
+        }
+
+        return c;
+    }
+
+    /** Gets the xjc:superInterface customization if it's turned on. */
+    public JClass getSuperInterface() {
+        Element sc = DOMUtil.getElement(dom,XJC_NS,"superInterface");
+        if (sc == null) return null;
+
+        String name = DOMUtil.getAttribute(sc,"name");
+        if (name == null) return null;
+
+        JDefinedClass c;
+
+        try {
+            c = codeModel._class(name, ClassType.INTERFACE);
+            c.hide();
+        } catch (JClassAlreadyExistsException e) {
+            c = e.getExistingClass();
+        }
+
+        return c;
+    }
+
+    /** Gets the specified package name (options/@package). */
+    public JPackage getTargetPackage() {
+        String p;
+        if( defaultPackage!=null )
+            p = defaultPackage;
+        else
+            p = getOption("package", "");
+        return codeModel._package(p);
+    }
+
+    /**
+     * Gets the conversion declaration from the binding info.
+     *
+     * @return
+     *        A non-null valid BIConversion object.
+     */
+    public BIConversion conversion(String name) {
+        BIConversion r = conversions.get(name);
+        if (r == null)
+            throw new AssertionError("undefined conversion name: this should be checked by the validator before we read it");
+        return r;
+    }
+
+    /**
+     * Gets the element declaration from the binding info.
+     *
+     * @return
+     *        If there is no declaration with a given name,
+     *        this method returns null.
+     */
+    public BIElement element( String name ) {
+        return elements.get(name);
+    }
+    /** Iterates all {@link BIElement}s in a read-only set. */
+    public Collection<BIElement> elements() {
+        return elements.values();
+    }
+
+    /** Returns all {@link BIInterface}s in a read-only set. */
+    public Collection<BIInterface> interfaces() {
+        return interfaces.values();
+    }
+
+
+
+//
+//
+//    Internal utility methods
+//
+//
+
+
+    /** Gets the value from the option element. */
+    private String getOption(String attName, String defaultValue) {
+        Element opt = DOMUtil.getElement(dom,"options");
+        if (opt != null) {
+            String s = DOMUtil.getAttribute(opt,attName);
+            if (s != null)
+                return s;
+        }
+        return defaultValue;
+    }
+
+    /**
+     * Lazily parsed schema for the binding file.
+     */
+    private static SchemaCache bindingFileSchema = new SchemaCache(BindInfo.class.getResource("bindingfile.xsd"));
+
+    /**
+     * Parses an InputSource into dom4j Document.
+     * Returns null in case of an exception.
+     */
+    private static Document parse( InputSource is, ErrorReceiver receiver ) throws AbortException {
+        try {
+            ValidatorHandler validator = bindingFileSchema.newValidator();
+
+            // set up the pipe line as :
+            //   parser->validator->factory
+            SAXParserFactory pf = SAXParserFactory.newInstance();
+            pf.setNamespaceAware(true);
+            DOMBuilder builder = new DOMBuilder();
+
+            ErrorReceiverFilter controller = new ErrorReceiverFilter(receiver);
+            validator.setErrorHandler(controller);
+            XMLReader reader = pf.newSAXParser().getXMLReader();
+            reader.setErrorHandler(controller);
+            reader.setContentHandler(new ForkContentHandler(validator,builder));
+
+            reader.parse(is);
+
+            if(controller.hadError())   throw new AbortException();
+            return (Document)builder.getDOM();
+        } catch( IOException e ) {
+            receiver.error( new SAXParseException2(e.getMessage(),null,e) );
+        } catch( SAXException e ) {
+            receiver.error( new SAXParseException2(e.getMessage(),null,e) );
+        } catch( ParserConfigurationException e ) {
+            receiver.error( new SAXParseException2(e.getMessage(),null,e) );
+        }
+
+        throw new AbortException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOM4JLocator.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOM4JLocator.java
new file mode 100644
index 0000000..9f04a1c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOM4JLocator.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+
+class DOM4JLocator
+{
+    private static final String locationNamespace =
+        "http://www.sun.com/xmlns/jaxb/dom4j-location";
+    private static final String systemId    = "systemid";
+    private static final String column      = "column";
+    private static final String line        = "line";
+
+    /** Sets the location information to a specified element. */
+    public static void setLocationInfo( Element e, Locator loc ) {
+        e.setAttributeNS(locationNamespace,"loc:"+systemId,loc.getSystemId());
+        e.setAttributeNS(locationNamespace,"loc:"+column,Integer.toString(loc.getLineNumber()));
+        e.setAttributeNS(locationNamespace,"loc:"+line,Integer.toString(loc.getColumnNumber()));
+    }
+
+    /**
+     * Gets the location information from an element.
+     *
+     * <p>
+     * For this method to work, the setLocationInfo method has to be
+     * called before.
+     */
+    public static Locator getLocationInfo( final Element e ) {
+        if(DOMUtil.getAttribute(e,locationNamespace,systemId)==null)
+            return null;    // no location information
+
+        return new Locator(){
+            public int getLineNumber() {
+                return Integer.parseInt(DOMUtil.getAttribute(e,locationNamespace,line));
+            }
+            public int getColumnNumber() {
+                return Integer.parseInt(DOMUtil.getAttribute(e,locationNamespace,column));
+            }
+            public String getSystemId() {
+                return DOMUtil.getAttribute(e,locationNamespace,systemId);
+            }
+            // we are not interested in PUBLIC ID.
+            public String getPublicId() { return null; }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOMBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOMBuilder.java
new file mode 100644
index 0000000..7ae8e69
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOMBuilder.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import javax.xml.parsers.ParserConfigurationException;
+
+import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.Locator;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class DOMBuilder extends SAX2DOMEx {
+    private Locator locator;
+
+    public DOMBuilder() throws ParserConfigurationException {
+    }
+
+    public void setDocumentLocator(Locator locator) {
+        super.setDocumentLocator(locator);
+        this.locator = locator;
+    }
+
+    public void startElement(String namespace, String localName, String qName, Attributes attrs) {
+        super.startElement(namespace, localName, qName, attrs);
+        DOM4JLocator.setLocationInfo(getCurrentElement(),locator);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOMUtil.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOMUtil.java
new file mode 100644
index 0000000..a5ffd3f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/DOMUtil.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public final class DOMUtil {
+    final static String getAttribute(Element e,String attName) {
+        if(e.getAttributeNode(attName)==null)   return null;
+        return e.getAttribute(attName);
+    }
+
+    public static String getAttribute(Element e, String nsUri, String local) {
+        if(e.getAttributeNodeNS(nsUri,local)==null) return null;
+        return e.getAttributeNS(nsUri,local);
+    }
+
+    public static Element getElement(Element e, String nsUri, String localName) {
+        NodeList l = e.getChildNodes();
+        for(int i=0;i<l.getLength();i++) {
+            Node n = l.item(i);
+            if(n.getNodeType()==Node.ELEMENT_NODE) {
+                Element r = (Element)n;
+                if(equals(r.getLocalName(),localName) && equals(fixNull(r.getNamespaceURI()),nsUri))
+                    return r;
+            }
+        }
+        return null;
+    }
+
+    /**
+     * Used for defensive string comparisons, as many DOM methods often return null
+     * depending on how they are created.
+     */
+    private static boolean equals(String a,String b) {
+        if(a==b)    return true;
+        if(a==null || b==null)  return false;
+        return a.equals(b);
+    }
+
+    /**
+     * DOM API returns null for the default namespace whereas it should return "".
+     */
+    private static String fixNull(String s) {
+        if(s==null) return "";
+        else        return s;
+    }
+
+    public static Element getElement(Element e, String localName) {
+        return getElement(e,"",localName);
+    }
+
+    public static List<Element> getChildElements(Element e) {
+        List<Element> r = new ArrayList<Element>();
+        NodeList l = e.getChildNodes();
+        for(int i=0;i<l.getLength();i++) {
+            Node n = l.item(i);
+            if(n.getNodeType()==Node.ELEMENT_NODE)
+                r.add((Element)n);
+        }
+        return r;
+    }
+
+    public static List<Element> getChildElements(Element e,String localName) {
+        List<Element> r = new ArrayList<Element>();
+        NodeList l = e.getChildNodes();
+        for(int i=0;i<l.getLength();i++) {
+            Node n = l.item(i);
+            if(n.getNodeType()==Node.ELEMENT_NODE) {
+                Element c = (Element)n;
+                if(c.getLocalName().equals(localName))
+                    r.add(c);
+            }
+        }
+        return r;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/MessageBundle.properties
new file mode 100644
index 0000000..a6343d1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/MessageBundle.properties
@@ -0,0 +1,5 @@
+
+BIConstructor.UndefinedField = \
+	Property "{0}" is declared in the <constructor> declaration \
+	but is not defined in DTD
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/Messages.java
new file mode 100644
index 0000000..6536bc7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/Messages.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.dtd.bindinfo;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getPackage().getName() + ".MessageBundle").getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+
+    static final String ERR_UNDEFINED_FIELD = // arg:1
+        "BIConstructor.UndefinedField";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/bindingfile.rng b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/bindingfile.rng
new file mode 100644
index 0000000..2e639f5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/bindingfile.rng
@@ -0,0 +1,293 @@
+<?xml version="1.0"?>
+<!--
+DTD binding information file which is supported by this version of XJC.
+$Id: bindingfile.rng,v 1.1 2005/04/15 20:09:43 kohsuke Exp $
+
+- Changes from the EA1 is marked by "CHANGE:"
+- "ref:key" and "ref:keyref" are used to specify cross-reference
+  information.
+- "a:defaultValue" is used to specify the default behavior.
+  Note that default behaviors are hard-coded to the source code.
+  Values specified in this schema is not used in the actual processing.
+-->
+<grammar
+  xmlns="http://relaxng.org/ns/structure/1.0"
+  xmlns:xjc="http://java.sun.com/xml/ns/jaxb/xjc"
+  xmlns:a="http://relaxng.org/ns/annotation/1.0"
+  xmlns:ref="urn:crossreference"
+  datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes">
+
+  <start>
+    <element name="xml-java-binding-schema">
+      <optional>
+        <attribute name="version">
+          <value>1.0ea2</value>
+        </attribute>
+      </optional>
+
+      <interleave>
+        <optional>
+          <element name="options">
+            <optional>
+              <attribute name="package"/>
+            </optional>
+          </element>
+        </optional>
+        <optional>
+          <element name="xjc:serializable">
+            <optional>
+              <attribute name="uid">
+                <data type="long"/>
+              </attribute>
+            </optional>
+          </element>
+        </optional>
+        <optional>
+          <element name="xjc:superClass">
+            <attribute name="name"/>
+          </element>
+        </optional>
+        <!-- light-weight runtime -->
+        <optional>
+          <element name="xjc:noMarshaller">
+            <empty/>
+          </element>
+        </optional>
+        <optional>
+          <element name="xjc:noUnmarshaller">
+            <empty/>
+          </element>
+        </optional>
+        <optional>
+          <element name="xjc:noValidator">
+            <empty/>
+          </element>
+        </optional>
+        <optional>
+          <element name="xjc:noValidatingUnmarshaller">
+            <empty/>
+          </element>
+        </optional>
+        <zeroOrMore>
+          <choice>
+            <ref name="toplevel.declaration"/>
+            <ref name="global.or.local.declaration"/>
+          </choice>
+        </zeroOrMore>
+      </interleave>
+    </element>
+  </start>
+ 
+ 
+ 
+ 
+  <!-- element-class declaration -->
+  <define name="toplevel.declaration" combine="choice">
+    <element name="element">
+      <attribute name="name"/>
+      <attribute name="type">
+        <value>class</value>
+      </attribute>
+      <optional>
+        <attribute name="class">
+          <ref name="java.classname.datatype"/>
+        </attribute>
+      </optional>
+      <optional>
+        <attribute name="root" a:defaultValue="false">
+          <choice>
+            <value>true</value>
+            <value>false</value>
+          </choice>
+        </attribute>
+      </optional>
+
+      <interleave>
+        <!-- attribute-property declaration -->
+        <zeroOrMore>
+          <element name="attribute">
+            <attribute name="name"/>
+            <optional>
+              <attribute name="property"/>
+            </optional>
+            <optional>
+              <ref name="collection.att"/>
+            </optional>
+            <optional>
+              <attribute name="convert">
+                <text ref:keyref="conversion"/>
+              </attribute>
+            </optional>
+          </element>
+        </zeroOrMore>
+
+        <zeroOrMore>
+          <ref name="global.or.local.declaration"/>
+        </zeroOrMore>
+
+        <!-- element-local declarations -->
+        <zeroOrMore>
+          <element name="constructor">
+            <attribute name="properties">
+              <list>
+                <oneOrMore>
+                  <!-- point to a property defined in this element -->
+                  <data type="token"/>
+                </oneOrMore>
+              </list>
+            </attribute>
+          </element>
+        </zeroOrMore>
+
+        <optional>
+          <element name="content">
+            <interleave>
+              <choice>
+                <!-- general content-property declaration -->
+                <ref name="collection.particle.decl"/>
+
+                <!-- model-based content property declaration -->
+                <group>
+                  <zeroOrMore>
+                    <choice>
+                      <element name="element-ref">
+                        <attribute name="name"/>
+                        <optional>
+                          <attribute name="property"/>
+                        </optional>
+                        <optional>
+                          <ref name="collection.att"/>
+                        </optional>
+                      </element>
+                      <element>
+                        <choice>
+                          <name>sequence</name>
+                          <name>choice</name>
+                        </choice>
+                        <ref name="collection.particle.decl"/>
+                      </element>
+                    </choice>
+                  </zeroOrMore>
+                  <optional><!-- followed by an optional <rest> -->
+                    <element name="rest">
+                      <ref name="collection.particle.decl"/>
+                    </element>
+                  </optional>
+                </group>
+              </choice>
+            </interleave>
+          </element>
+        </optional>
+      </interleave>
+    </element>
+  </define>
+
+  <define name="collection.particle.decl">
+    <attribute name="property"/>
+    <optional>
+      <ref name="collection.att"/>
+    </optional>
+    <optional>
+      <attribute name="supertype"/>
+    </optional>
+  </define>
+
+  <define name="collection.att">
+    <attribute name="collection">
+      <!-- CHANGE: array is removed and set,vector are added -->
+      <choice>
+        <value>list</value>
+        <value>set</value>
+        <value>vector</value>
+      </choice>
+    </attribute>
+  </define>
+
+ 
+ 
+  <!-- conversion declaration -->
+  <define name="global.or.local.declaration" combine="choice">
+    <element name="conversion">
+      <attribute name="name" ref:key="conversion"/>
+      <optional>
+        <!-- defaults to @name -->
+        <attribute name="type"/>
+      </optional>
+      <optional>
+        <attribute name="parse" a:defaultValue="new"/>
+      </optional>
+      <optional>
+        <attribute name="print" a:defaultValue="toString"/>
+      </optional>
+      <optional>
+        <attribute name="whitespace" a:defaultValue="collapse">
+          <choice>
+            <value>preserve</value>
+            <value>replace</value><!-- CHANGE: it was normalize -->
+            <value>collapse</value>
+          </choice>
+        </attribute>
+      </optional>
+    </element>
+  </define>
+ 
+  <!-- element-value declaration -->
+  <define name="toplevel.declaration" combine="choice">
+    <element name="element">
+      <attribute name="name"/>
+      <attribute name="type">
+        <value>value</value>
+      </attribute>
+      <optional>
+        <attribute name="convert">
+          <text ref:keyref="conversion"/>
+        </attribute>
+      </optional>
+    </element>
+  </define>
+ 
+  <!-- interface declaration -->
+  <define name="toplevel.declaration" combine="choice">
+    <element name="interface">
+      <attribute name="name">
+        <ref name="java.classname.datatype"/>
+      </attribute>
+      <attribute name="members">
+        <list>
+          <oneOrMore>
+            <ref name="java.classname.datatype"/>
+          </oneOrMore>
+        </list>
+      </attribute>
+      <!-- CHANGE: TODO: @properties is not supported yet -->
+    </element>
+  </define>
+ 
+  <!-- enumeration declaration -->
+  <define name="global.or.local.declaration" combine="choice">
+    <element name="enumeration">
+      <attribute name="name">
+        <ref name="java.classname.datatype"/>
+      </attribute>
+      <attribute name="members">
+        <list>
+          <oneOrMore>
+            <data type="token"/>
+          </oneOrMore>
+        </list>
+      </attribute>
+    </element>
+  </define>
+ 
+ 
+ 
+  <!-- valid Java name -->
+  <define name="java.name.datatype">
+    <!-- TODO: add pattern facet or implement a custom datatype -->
+    <data type="token"/>
+  </define>
+
+  <define name="java.classname.datatype">
+    <ref name="java.name.datatype"/>
+  </define>
+</grammar>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/bindingfile.xsd b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/bindingfile.xsd
new file mode 100644
index 0000000..825f3a8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/bindingfile.xsd
@@ -0,0 +1,273 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!--
+ Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+ This code is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License version 2 only, as
+ published by the Free Software Foundation.  Sun designates this
+ particular file as subject to the "Classpath" exception as provided
+ by Sun in the LICENSE file that accompanied this code.
+
+ This code is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ version 2 for more details (a copy is included in the LICENSE file that
+ accompanied this code).
+
+ You should have received a copy of the GNU General Public License version
+ 2 along with this work; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+ Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ CA 95054 USA or visit www.sun.com if you need additional information or
+ have any questions.
+-->
+
+<!--
+  DTD binding information file which is supported by this version of XJC.
+  $Id: bindingfile.xsd,v 1.1 2005/04/29 18:11:05 kohsuke Exp $
+  
+  - Changes from the EA1 is marked by "CHANGE:"
+  - "ref:key" and "ref:keyref" are used to specify cross-reference
+    information.
+  - "a:defaultValue" is used to specify the default behavior.
+    Note that default behaviors are hard-coded to the source code.
+    Values specified in this schema is not used in the actual processing.
+-->
+<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" xmlns:xjc="http://java.sun.com/xml/ns/jaxb/xjc">
+  <xs:import namespace="http://java.sun.com/xml/ns/jaxb/xjc" schemaLocation="xjc.xsd"/>
+  <xs:element name="xml-java-binding-schema">
+    <xs:complexType>
+      <xs:choice minOccurs="0" maxOccurs="unbounded">
+        <xs:element ref="options"/>
+        <xs:element ref="xjc:serializable"/>
+        <xs:element ref="xjc:superClass"/>
+        <xs:element ref="xjc:noMarshaller"/>
+        <xs:element ref="xjc:noUnmarshaller"/>
+        <xs:element ref="xjc:noValidator"/>
+        <xs:element ref="xjc:noValidatingUnmarshaller"/>
+        <xs:choice>
+          <xs:group ref="toplevel.declaration"/>
+          <xs:element ref="global.or.local.declaration"/>
+        </xs:choice>
+      </xs:choice>
+      <xs:attribute name="version">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="1.0ea2"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="options">
+    <xs:complexType>
+      <xs:attribute name="package"/>
+    </xs:complexType>
+  </xs:element>
+  <!-- element-class declaration -->
+  <xs:group name="toplevel.declaration">
+    <xs:choice>
+      <xs:element name="element">
+        <xs:complexType>
+          <xs:choice minOccurs="0" maxOccurs="unbounded">
+            <xs:element ref="attribute"/>
+            <xs:element ref="global.or.local.declaration"/>
+            <xs:element ref="constructor"/>
+            <xs:element ref="content"/>
+          </xs:choice>
+          <xs:attribute name="name" use="required"/>
+          <xs:attribute name="type" use="required">
+            <xs:simpleType>
+              <xs:restriction base="xs:token">
+                <xs:enumeration value="class"/>
+                <xs:enumeration value="value"/>
+              </xs:restriction>
+            </xs:simpleType>
+          </xs:attribute>
+          <xs:attribute name="class" type="java.classname.datatype"/>
+          <xs:attribute name="root">
+            <xs:simpleType>
+              <xs:restriction base="xs:token">
+                <xs:enumeration value="true"/>
+                <xs:enumeration value="false"/>
+              </xs:restriction>
+            </xs:simpleType>
+          </xs:attribute>
+          <xs:attribute name="convert"/>
+        </xs:complexType>
+      </xs:element>
+      <xs:element ref="interface"/>
+    </xs:choice>
+  </xs:group>
+  <xs:element name="attribute">
+    <xs:complexType>
+      <xs:attribute name="name" use="required"/>
+      <xs:attribute name="property"/>
+      <xs:attribute name="collection">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="list"/>
+            <xs:enumeration value="set"/>
+            <xs:enumeration value="vector"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="convert"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="constructor">
+    <xs:complexType>
+      <xs:attribute name="properties" use="required">
+        <xs:simpleType>
+          <xs:restriction>
+            <xs:simpleType>
+              <xs:list itemType="xs:token"/>
+            </xs:simpleType>
+            <xs:minLength value="1"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="content">
+    <xs:complexType>
+      <xs:sequence minOccurs="0">
+        <xs:choice minOccurs="0" maxOccurs="unbounded">
+          <xs:element ref="element-ref"/>
+          <xs:choice>
+            <xs:element ref="sequence"/>
+            <xs:element ref="choice"/>
+          </xs:choice>
+        </xs:choice>
+        <xs:element minOccurs="0" ref="rest"/>
+      </xs:sequence>
+      <xs:attribute name="property"/>
+      <xs:attribute name="collection">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="list"/>
+            <xs:enumeration value="set"/>
+            <xs:enumeration value="vector"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="supertype"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="element-ref">
+    <xs:complexType>
+      <xs:attribute name="name" use="required"/>
+      <xs:attribute name="property"/>
+      <xs:attribute name="collection">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="list"/>
+            <xs:enumeration value="set"/>
+            <xs:enumeration value="vector"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="sequence">
+    <xs:complexType>
+      <xs:attributeGroup ref="collection.particle.decl"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="choice">
+    <xs:complexType>
+      <xs:attributeGroup ref="collection.particle.decl"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="rest">
+    <xs:complexType>
+      <xs:attributeGroup ref="collection.particle.decl"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="interface">
+    <xs:complexType>
+      <xs:attribute name="name" use="required" type="java.classname.datatype"/>
+      <xs:attribute name="members" use="required">
+        <xs:simpleType>
+          <xs:restriction>
+            <xs:simpleType>
+              <xs:list itemType="java.classname.datatype"/>
+            </xs:simpleType>
+            <xs:minLength value="1"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+    </xs:complexType>
+  </xs:element>
+  <xs:attributeGroup name="collection.particle.decl">
+    <xs:attribute name="property" use="required"/>
+    <xs:attribute name="collection">
+      <xs:simpleType>
+        <xs:restriction base="xs:token">
+          <xs:enumeration value="list"/>
+          <xs:enumeration value="set"/>
+          <xs:enumeration value="vector"/>
+        </xs:restriction>
+      </xs:simpleType>
+    </xs:attribute>
+    <xs:attribute name="supertype"/>
+  </xs:attributeGroup>
+  <xs:attributeGroup name="collection.att">
+    <xs:attribute name="collection" use="required">
+      <xs:simpleType>
+        <xs:restriction base="xs:token">
+          <xs:enumeration value="list"/>
+          <xs:enumeration value="set"/>
+          <xs:enumeration value="vector"/>
+        </xs:restriction>
+      </xs:simpleType>
+    </xs:attribute>
+  </xs:attributeGroup>
+  <!-- conversion declaration -->
+  <xs:element name="global.or.local.declaration" abstract="true"/>
+  <xs:element name="conversion" substitutionGroup="global.or.local.declaration">
+    <xs:complexType>
+      <xs:attribute name="name" use="required"/>
+      <xs:attribute name="type"/>
+      <xs:attribute name="parse"/>
+      <xs:attribute name="print"/>
+      <xs:attribute name="whitespace">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="preserve"/>
+            <xs:enumeration value="replace"/>
+            <xs:enumeration value="collapse"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="enumeration" substitutionGroup="global.or.local.declaration">
+    <xs:complexType>
+      <xs:attribute name="name" use="required" type="java.classname.datatype"/>
+      <xs:attribute name="members" use="required">
+        <xs:simpleType>
+          <xs:restriction>
+            <xs:simpleType>
+              <xs:list itemType="xs:token"/>
+            </xs:simpleType>
+            <xs:minLength value="1"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+    </xs:complexType>
+  </xs:element>
+  <!-- element-value declaration -->
+  <!-- interface declaration -->
+  <!-- enumeration declaration -->
+  <!-- valid Java name -->
+  <xs:simpleType name="java.name.datatype">
+    <xs:restriction base="xs:token"/>
+  </xs:simpleType>
+  <xs:simpleType name="java.classname.datatype">
+    <xs:restriction base="java.name.datatype"/>
+  </xs:simpleType>
+</xs:schema>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/package.html
new file mode 100644
index 0000000..ab4988a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/package.html
@@ -0,0 +1 @@
+<body><p>Object Model that represents DTD binding information.</p></body>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/xjc.xsd b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/xjc.xsd
new file mode 100644
index 0000000..2fceabd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/dtd/bindinfo/xjc.xsd
@@ -0,0 +1,52 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!--
+ Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+ This code is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License version 2 only, as
+ published by the Free Software Foundation.  Sun designates this
+ particular file as subject to the "Classpath" exception as provided
+ by Sun in the LICENSE file that accompanied this code.
+
+ This code is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ version 2 for more details (a copy is included in the LICENSE file that
+ accompanied this code).
+
+ You should have received a copy of the GNU General Public License version
+ 2 along with this work; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+ Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ CA 95054 USA or visit www.sun.com if you need additional information or
+ have any questions.
+-->
+
+<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" targetNamespace="http://java.sun.com/xml/ns/jaxb/xjc" xmlns:xjc="http://java.sun.com/xml/ns/jaxb/xjc">
+  <xs:import schemaLocation="bindingfile.xsd"/>
+  <xs:element name="serializable">
+    <xs:complexType>
+      <xs:attribute name="uid" type="xs:long"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="superClass">
+    <xs:complexType>
+      <xs:attribute name="name" use="required"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="noMarshaller">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="noUnmarshaller">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="noValidator">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="noValidatingUnmarshaller">
+    <xs:complexType/>
+  </xs:element>
+</xs:schema>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Choice.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Choice.java
new file mode 100644
index 0000000..e583222
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Choice.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+/**
+ * {@link Expression} that represents the union of two expressions "A|B".
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Choice extends Expression {
+    /**
+     * "A" of "A|B".
+     */
+    private final Expression lhs;
+    /**
+     * "B" of "A|B".
+     */
+    private final Expression rhs;
+    /**
+     * Compute this value eagerly for better performance
+     */
+    private final boolean isNullable;
+
+    public Choice(Expression lhs, Expression rhs) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+        this.isNullable = lhs.isNullable() || rhs.isNullable();
+    }
+
+    boolean isNullable() {
+        return isNullable;
+    }
+
+    ElementSet lastSet() {
+        return ElementSets.union(lhs.lastSet(),rhs.lastSet());
+    }
+
+    void buildDAG(ElementSet incoming) {
+        lhs.buildDAG(incoming);
+        rhs.buildDAG(incoming);
+    }
+
+    public String toString() {
+        return '('+lhs.toString()+'|'+rhs.toString()+')';
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ConnectedComponent.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ConnectedComponent.java
new file mode 100644
index 0000000..0061dba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ConnectedComponent.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+/**
+ * Represents one strongly-connected component
+ * of the {@link Element} graph.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ConnectedComponent implements Iterable<Element> {
+    /**
+     * {@link Element}s that belong to this component.
+     */
+    private final List<Element> elements = new ArrayList<Element>();
+
+    /*package*/ boolean isRequired;
+
+    /**
+     * Returns true iff this {@link ConnectedComponent}
+     * can match a substring whose length is greater than 1.
+     *
+     * <p>
+     * That means this property will become a collection property.
+     */
+    public final boolean isCollection() {
+        assert !elements.isEmpty();
+
+        // a strongly connected component by definition has a cycle,
+        // so if its size is bigger than 1 there must be a cycle.
+        if(elements.size()>1)
+            return true;
+
+        // if size is 1, it might be still forming a self-cycle
+        Element n = elements.get(0);
+        return n.hasSelfLoop();
+    }
+
+    /**
+     * Returns true iff this {@link ConnectedComponent}
+     * forms a cut set of a graph.
+     *
+     * <p>
+     * That means any valid element sequence must have at least
+     * one value for this property.
+     */
+    public final boolean isRequired() {
+        return isRequired;
+    }
+
+    /*package*/void add(Element e) {
+        assert !elements.contains(e);
+        elements.add(e);
+    }
+
+    public Iterator<Element> iterator() {
+        return elements.iterator();
+    }
+
+    /**
+     * Just produces debug representation
+     */
+    public String toString() {
+        String s = elements.toString();
+        if(isRequired())
+            s += '!';
+        if(isCollection())
+            s += '*';
+        return s;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Element.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Element.java
new file mode 100644
index 0000000..c07ed08
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Element.java
@@ -0,0 +1,215 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+import java.util.Collections;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+/**
+ * {@link Expression} that represents an alphabet of a regular language.
+ *
+ * <p>
+ * Since this package is about a regular expression over element declarations,
+ * this represents an XML element declaration (hence the name.)
+ *
+ * Element needs to be interned, meaning one {@link Element} per one tag name.
+ *
+ * <p>
+ * Implements {@link ElementSet} to represent a self.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Element extends Expression implements ElementSet {
+    /**
+     * Once we build a graph from {@link Expression},
+     * we represent an edge e1 -> e2 by {@code e1.foreEdges.contains(e2)}
+     * and {@code e2.backEdges.contains(e1)}.
+     */
+    final Set<Element> foreEdges = new HashSet<Element>();
+    final Set<Element> backEdges = new HashSet<Element>();
+
+    /**
+     * Previous element in the DFS post-order traveral
+     * of the element graph.
+     *
+     * <p>
+     * We use {@code prevPostOrder==null} as a check if the element is visted in DFS,
+     * so this chain terminates by a self-reference, not by having null.
+     *
+     * Set in {@link #assignDfsPostOrder(Element)}
+     */
+    /*package*/ Element prevPostOrder;
+
+    /**
+     * {@link ConnectedComponent} to which this element belongs.
+     *
+     * Set in {@link #buildStronglyConnectedComponents(List<ConnectedComponent>)}
+     */
+    private ConnectedComponent cc;
+
+    protected Element() {
+    }
+
+    ElementSet lastSet() {
+        return this;
+    }
+
+    boolean isNullable() {
+        return false;
+    }
+
+    /**
+     * True if this {@link Element} is {@link SourceNode}.
+     */
+    boolean isSource() {
+        return false;
+    }
+
+    /**
+     * True if this {@link Element} is {@link SinkNode}.
+     */
+    boolean isSink() {
+        return false;
+    }
+
+    void buildDAG(ElementSet incoming) {
+        incoming.addNext(this);
+    }
+
+    public void addNext(Element element) {
+        foreEdges.add(element);
+        element.backEdges.add(this);
+    }
+
+    public boolean contains(ElementSet rhs) {
+        return this==rhs || rhs==ElementSet.EMPTY_SET;
+    }
+
+    /**
+     * Just to satisfy the {@link ElementSet} contract.
+     *
+     * @deprecated
+     *      if you statically call this method, there's something wrong.
+     */
+    public Iterator<Element> iterator() {
+        return Collections.singleton(this).iterator();
+    }
+
+    /**
+     * Traverses the {@link Element} graph with DFS
+     * and set {@link #prevPostOrder}.
+     *
+     * Should be first invoked on the source node of the graph.
+     */
+    /*package*/ Element assignDfsPostOrder(Element prev) {
+        if(prevPostOrder!=null)
+            return prev;        // already visited
+
+        prevPostOrder = this;   // set a dummy value to prepare for cycles
+
+        for (Element next : foreEdges) {
+            prev = next.assignDfsPostOrder(prev);
+        }
+        this.prevPostOrder = prev;  // set to the real value
+        return this;
+    }
+
+    /**
+     * Builds a set of strongly connected components and puts them
+     * all into the given set.
+     */
+    public void buildStronglyConnectedComponents(List<ConnectedComponent> ccs) {
+        for(Element cur=this; cur!=cur.prevPostOrder; cur=cur.prevPostOrder) {
+            if(cur.belongsToSCC())
+                continue;
+
+            // start a new component
+            ConnectedComponent cc = new ConnectedComponent();
+            ccs.add(cc);
+
+            cur.formConnectedComponent(cc);
+        }
+    }
+
+    private boolean belongsToSCC() {
+        return cc!=null || isSource() || isSink();
+    }
+
+    /**
+     * Forms a strongly connected component by doing a reverse DFS.
+     */
+    private void formConnectedComponent(ConnectedComponent group) {
+        if(belongsToSCC())
+            return;
+
+        this.cc=group;
+        group.add(this);
+        for (Element prev : backEdges)
+            prev.formConnectedComponent(group);
+    }
+
+    public boolean hasSelfLoop() {
+        // if foreEdges have a loop, backEdges must have one. Or vice versa
+        assert foreEdges.contains(this)==backEdges.contains(this);
+
+        return foreEdges.contains(this);
+    }
+
+    /**
+     * Checks if the given {@link ConnectedComponent} forms a cut-set
+     * of a graph.
+     *
+     * @param visited
+     *      Used to keep track of visited nodes.
+     * @return
+     *      true if it is indeed a cut-set. false if not.
+     */
+    /*package*/ final boolean checkCutSet(ConnectedComponent cc, Set<Element> visited) {
+        assert belongsToSCC();  // SCC discomposition must be done first
+
+        if(isSink())
+            // the definition of the cut set is that without those nodes
+            // you can't reach from soruce to sink
+            return false;
+
+        if(!visited.add(this))
+            return true;
+
+        if(this.cc==cc)
+            return true;
+
+        for (Element next : foreEdges) {
+            if(!next.checkCutSet(cc,visited))
+                // we've found a path to the sink
+                return false;
+        }
+
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ElementSet.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ElementSet.java
new file mode 100644
index 0000000..08cdfc6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ElementSet.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+import java.util.Collections;
+import java.util.Iterator;
+
+/**
+ * A set over a list of {@link Element}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+interface ElementSet extends Iterable<Element> {
+    /**
+     * For each element in this set, adds an edge to the given element.
+     */
+    void addNext(Element element);
+
+    public static final ElementSet EMPTY_SET = new ElementSet() {
+        public void addNext(Element element) {
+            // noop
+        }
+
+        public boolean contains(ElementSet element) {
+            return this==element;
+        }
+
+        public Iterator<Element> iterator() {
+            return Collections.<Element>emptySet().iterator();
+        }
+    };
+
+    /**
+     * Doesn't have to be strict (it's OK for this method to return false
+     * when it's actually true) since this is used just for optimization.
+     *
+     * (Erring on the other side is NG)
+     */
+    boolean contains(ElementSet rhs);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ElementSets.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ElementSets.java
new file mode 100644
index 0000000..bbce4a9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/ElementSets.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+import java.util.HashSet;
+
+/**
+ * Factory methods for {@link ElementSet}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ElementSets {
+    /**
+     * Returns an union of two {@link ElementSet}s.
+     *
+     * This method performs better if lhs is bigger than rhs
+     */
+    public static ElementSet union(ElementSet lhs, ElementSet rhs) {
+        if(lhs.contains(rhs))
+            return lhs;
+        if(lhs==ElementSet.EMPTY_SET)
+            return rhs;
+        if(rhs==ElementSet.EMPTY_SET)
+            return lhs;
+        return new MultiValueSet(lhs,rhs);
+    }
+
+    /**
+     * {@link ElementSet} that has multiple {@link Element}s in it.
+     *
+     * This isn't particularly efficient or anything, but it will do for now.
+     */
+    private static final class MultiValueSet extends HashSet<Element> implements ElementSet {
+        public MultiValueSet(ElementSet lhs, ElementSet rhs) {
+            addAll(lhs);
+            addAll(rhs);
+            // not that anything will break with size==1 MultiValueSet,
+            // but it does suggest that we are missing an easy optimization
+            assert size()>1;
+        }
+
+        private void addAll(ElementSet lhs) {
+            if(lhs instanceof MultiValueSet) {
+                super.addAll((MultiValueSet)lhs);
+            } else {
+                for (Element e : lhs)
+                    add(e);
+            }
+        }
+
+        public boolean contains(ElementSet rhs) {
+            // this isn't complete but sound
+            return super.contains(rhs) || rhs==ElementSet.EMPTY_SET;
+        }
+
+        public void addNext(Element element) {
+            for (Element e : this)
+                e.addNext(element);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Expression.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Expression.java
new file mode 100644
index 0000000..efd6bb0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Expression.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+import java.util.Set;
+
+/**
+ * This builds content models.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Expression {
+
+    /**
+     * Computes <tt>LAST(exp)</tt>
+     */
+    abstract ElementSet lastSet();
+
+    /**
+     * True of <tt>\epsilon \in L(exp)</tt>
+     */
+    abstract boolean isNullable();
+
+    /**
+     * Builds up a DAG among {@link Element}s in this expression.
+     */
+    abstract void buildDAG(ElementSet incoming);
+
+    /**
+     * {@link Expression} that represents epsilon, the length-0 string.
+     */
+    public static final Expression EPSILON = new Expression() {
+        ElementSet lastSet() {
+            return ElementSet.EMPTY_SET;
+        }
+
+        boolean isNullable() {
+            return true;
+        }
+
+        void buildDAG(ElementSet incoming) {
+            // noop
+        }
+
+        void assignElementNumber(Set<Element> allElements) {
+            // noop
+        }
+
+        public String toString() {
+            return "-";
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Graph.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Graph.java
new file mode 100644
index 0000000..c3d0bce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Graph.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+/**
+ * Graph of {@link Element}s.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Graph implements Iterable<ConnectedComponent> {
+    private final Element source = new SourceNode();
+    private final Element sink = new SinkNode();
+
+    /**
+     * Strongly connected components of this graph.
+     */
+    private final List<ConnectedComponent> ccs = new ArrayList<ConnectedComponent>();
+
+    /**
+     * Builds a {@link Graph} from an {@link Expression} tree.
+     *
+     * {@link Expression} given to the graph will be modified forever,
+     * and it will not be able to create another {@link Graph}.
+     */
+    public Graph(Expression body) {
+        // attach source and sink
+        Expression whole = new Sequence(new Sequence(source,body),sink);
+
+        // build up a graph
+        whole.buildDAG(ElementSet.EMPTY_SET);
+
+        // decompose into strongly connected components.
+        // the algorithm is standard DFS-based algorithm,
+        // one illustration of this algorithm is available at
+        // http://www.personal.kent.edu/~rmuhamma/Algorithms/MyAlgorithms/GraphAlgor/strongComponent.htm
+        source.assignDfsPostOrder(sink);
+        source.buildStronglyConnectedComponents(ccs);
+
+        // cut-set check
+        Set<Element> visited = new HashSet<Element>();
+        for (ConnectedComponent cc : ccs) {
+            visited.clear();
+            if(source.checkCutSet(cc,visited)) {
+                cc.isRequired = true;
+            }
+        }
+    }
+
+    /**
+     * List up {@link ConnectedComponent}s of this graph in an order.
+     */
+    public Iterator<ConnectedComponent> iterator() {
+        return ccs.iterator();
+    }
+
+    public String toString() {
+        return ccs.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/OneOrMore.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/OneOrMore.java
new file mode 100644
index 0000000..5a5e2ab
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/OneOrMore.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+/**
+ * {@link Expression} that represents kleene-star operation (A+)
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class OneOrMore extends Expression {
+    /**
+     * 'A' of 'A+'.
+     */
+    private final Expression child;
+
+    public OneOrMore(Expression child) {
+        this.child = child;
+    }
+
+    ElementSet lastSet() {
+        return child.lastSet();
+    }
+
+    boolean isNullable() {
+        return child.isNullable();
+    }
+
+    void buildDAG(ElementSet incoming) {
+        child.buildDAG(ElementSets.union(incoming,child.lastSet()));
+    }
+
+    public String toString() {
+        return child.toString()+'+';
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Sequence.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Sequence.java
new file mode 100644
index 0000000..1a7888c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/Sequence.java
@@ -0,0 +1,85 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+/**
+ * {@link Expression} that represents a concatanation of two expressions
+ * "A,B".
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Sequence extends Expression {
+    /**
+     * 'A' of 'A,B'
+     */
+    private final Expression lhs;
+    /**
+     * 'B' of 'A,B'
+     */
+    private final Expression rhs;
+    /**
+     * Compute this value eagerly for better performance
+     */
+    private final boolean isNullable;
+
+    /**
+     * Cached value of {@link #lastSet()} for better performance.
+     * Sequence tends to be where the recursive lastSet computation occurs.
+     */
+    private ElementSet lastSet;
+
+    public Sequence(Expression lhs, Expression rhs) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+        isNullable = lhs.isNullable() && rhs.isNullable();
+    }
+
+    ElementSet lastSet() {
+        if(lastSet==null) {
+            if(rhs.isNullable())
+                lastSet = ElementSets.union(lhs.lastSet(),rhs.lastSet());
+            else
+                lastSet = rhs.lastSet();
+        }
+        return lastSet;
+    }
+
+    boolean isNullable() {
+        return isNullable;
+    }
+
+    void buildDAG(ElementSet incoming) {
+        lhs.buildDAG(incoming);
+        if(lhs.isNullable())
+            rhs.buildDAG(ElementSets.union(incoming,lhs.lastSet()));
+        else
+            rhs.buildDAG(lhs.lastSet());
+    }
+
+    public String toString() {
+        return '('+lhs.toString()+','+rhs.toString()+')';
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/SinkNode.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/SinkNode.java
new file mode 100644
index 0000000..a58803b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/SinkNode.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+/**
+ * Sink node of a grpah.
+ * @author Kohsuke Kawaguchi
+ */
+public final class SinkNode extends Element {
+    public String toString() {
+        return "#sink";
+    }
+
+    @Override
+    boolean isSink() {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/SourceNode.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/SourceNode.java
new file mode 100644
index 0000000..96584b2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/SourceNode.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.gbind;
+
+/**
+ * Source node of a graph.
+ * @author Kohsuke Kawaguchi
+ */
+public final class SourceNode extends Element {
+    public String toString() {
+        return "#source";
+    }
+
+    @Override
+    boolean isSource() {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/package.html
new file mode 100644
index 0000000..ab9a91b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/gbind/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+    Binary expressions are left-associative. IOW, ((A,B),C) instead of (A,(B,C))
+</body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/AbstractReferenceFinderImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/AbstractReferenceFinderImpl.java
new file mode 100644
index 0000000..55b57d2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/AbstractReferenceFinderImpl.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import java.io.IOException;
+import java.net.URI;
+import java.net.URISyntaxException;
+
+import com.sun.istack.internal.SAXParseException2;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * XMLFilter that finds references to other schema files from
+ * SAX events.
+ *
+ * This implementation is a base implementation for typical case
+ * where we just need to look for a particular attribute which
+ * contains an URL to another schema file.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class AbstractReferenceFinderImpl extends XMLFilterImpl {
+    protected final DOMForest parent;
+
+    protected AbstractReferenceFinderImpl( DOMForest _parent ) {
+        this.parent = _parent;
+    }
+
+    /**
+     * IF the given element contains a reference to an external resource,
+     * return its URL.
+     *
+     * @param nsURI
+     *      Namespace URI of the current element
+     * @param localName
+     *      Local name of the current element
+     * @return
+     *      It's OK to return a relative URL.
+     */
+    protected abstract String findExternalResource( String nsURI, String localName, Attributes atts);
+
+    public void startElement(String namespaceURI, String localName, String qName, Attributes atts)
+        throws SAXException {
+        super.startElement(namespaceURI, localName, qName, atts);
+
+        String relativeRef = findExternalResource(namespaceURI,localName,atts);
+        if(relativeRef==null)   return; // non found
+
+        try {
+            // absolutize URL.
+            String ref = new URI(locator.getSystemId()).resolve(new URI(relativeRef)).toString();
+
+            // then parse this schema as well,
+            // but don't mark this document as a root.
+            parent.parse(ref,false);
+        } catch( URISyntaxException e ) {
+            SAXParseException spe = new SAXParseException2(
+                Messages.format(Messages.ERR_UNABLE_TO_PARSE,relativeRef,e.getMessage()),
+                locator, e );
+
+            fatalError(spe);
+            throw spe;
+        } catch( IOException e ) {
+            SAXParseException spe = new SAXParseException2(
+                Messages.format(Messages.ERR_UNABLE_TO_PARSE,relativeRef,e.getMessage()),
+                locator, e );
+
+            fatalError(spe);
+            throw spe;
+        }
+    }
+
+    private Locator locator;
+
+    public void setDocumentLocator(Locator locator) {
+        super.setDocumentLocator(locator);
+        this.locator = locator;
+    }
+};
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/ContentHandlerNamespacePrefixAdapter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/ContentHandlerNamespacePrefixAdapter.java
new file mode 100644
index 0000000..aa9c9914
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/ContentHandlerNamespacePrefixAdapter.java
@@ -0,0 +1,110 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import javax.xml.XMLConstants;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXNotRecognizedException;
+import org.xml.sax.SAXNotSupportedException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.AttributesImpl;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * {@link XMLReader} filter for supporting
+ * <tt>http://xml.org/sax/features/namespace-prefixes</tt> feature.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ContentHandlerNamespacePrefixAdapter extends XMLFilterImpl {
+    /**
+     * True if <tt>http://xml.org/sax/features/namespace-prefixes</tt> is set to true.
+     */
+    private boolean namespacePrefixes = false;
+
+    private String[] nsBinding = new String[8];
+    private int len;
+
+    public ContentHandlerNamespacePrefixAdapter() {
+    }
+
+    public ContentHandlerNamespacePrefixAdapter(XMLReader parent) {
+        setParent(parent);
+    }
+
+    public boolean getFeature(String name) throws SAXNotRecognizedException, SAXNotSupportedException {
+        if(name.equals(PREFIX_FEATURE))
+            return namespacePrefixes;
+        return super.getFeature(name);
+    }
+
+    public void setFeature(String name, boolean value) throws SAXNotRecognizedException, SAXNotSupportedException {
+        if(name.equals(PREFIX_FEATURE)) {
+            this.namespacePrefixes = value;
+            return;
+        }
+        if(name.equals(NAMESPACE_FEATURE) && value)
+            return;
+        super.setFeature(name, value);
+    }
+
+
+    public void startPrefixMapping(String prefix, String uri) throws SAXException {
+        if(len==nsBinding.length) {
+            // reallocate
+            String[] buf = new String[nsBinding.length*2];
+            System.arraycopy(nsBinding,0,buf,0,nsBinding.length);
+            nsBinding = buf;
+        }
+        nsBinding[len++] = prefix;
+        nsBinding[len++] = uri;
+        super.startPrefixMapping(prefix,uri);
+    }
+
+    public void startElement(String uri, String localName, String qName, Attributes atts) throws SAXException {
+        if(namespacePrefixes) {
+            this.atts.setAttributes(atts);
+            // add namespace bindings back as attributes
+            for( int i=0; i<len; i+=2 ) {
+                String prefix = nsBinding[i];
+                if(prefix.length()==0)
+                    this.atts.addAttribute(XMLConstants.XML_NS_URI,"xmlns","xmlns","CDATA",nsBinding[i+1]);
+                else
+                    this.atts.addAttribute(XMLConstants.XML_NS_URI,prefix,"xmlns:"+prefix,"CDATA",nsBinding[i+1]);
+            }
+            atts = this.atts;
+        }
+        len=0;
+        super.startElement(uri, localName, qName, atts);
+    }
+
+    private final AttributesImpl atts = new AttributesImpl();
+
+    private static final String PREFIX_FEATURE = "http://xml.org/sax/features/namespace-prefixes";
+    private static final String NAMESPACE_FEATURE = "http://xml.org/sax/features/namespaces";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMBuilder.java
new file mode 100644
index 0000000..96bb428
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMBuilder.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import java.util.Set;
+
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.xml.sax.Attributes;
+import org.xml.sax.Locator;
+
+/**
+ * Builds DOM while keeping the location information.
+ *
+ * <p>
+ * This class also looks for outer most &lt;jaxb:bindings>
+ * customizations.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class DOMBuilder extends SAX2DOMEx {
+    /**
+     * Grows a DOM tree under the given document, and
+     * stores location information to the given table.
+     *
+     * @param outerMostBindings
+     *      This set will receive newly found outermost
+     *      jaxb:bindings customizations.
+     */
+    public DOMBuilder( Document dom, LocatorTable ltable, Set outerMostBindings ) {
+        super( dom );
+        this.locatorTable = ltable;
+        this.outerMostBindings = outerMostBindings;
+    }
+
+    /** Location information will be stored into this object. */
+    private final LocatorTable locatorTable;
+
+    private final Set outerMostBindings;
+
+    private Locator locator;
+
+    public void setDocumentLocator(Locator locator) {
+        this.locator = locator;
+        super.setDocumentLocator(locator);
+    }
+
+
+    public void startElement(String namespaceURI, String localName, String qName, Attributes atts) {
+        super.startElement(namespaceURI, localName, qName, atts);
+
+        Element e = getCurrentElement();
+        locatorTable.storeStartLocation( e, locator );
+
+        // check if this element is an outer-most <jaxb:bindings>
+        if( Const.JAXB_NSURI.equals(e.getNamespaceURI())
+        &&  "bindings".equals(e.getLocalName()) ) {
+
+            // if this is the root node (meaning that this file is an
+            // external binding file) or if the parent is XML Schema element
+            // (meaning that this is an "inlined" external binding)
+            Node p = e.getParentNode();
+            if( p instanceof Document
+            ||( p instanceof Element && !e.getNamespaceURI().equals(p.getNamespaceURI()))) {
+                outerMostBindings.add(e);   // remember this value
+            }
+        }
+    }
+
+    public void endElement(String namespaceURI, String localName, String qName) {
+        locatorTable.storeEndLocation( getCurrentElement(), locator );
+        super.endElement(namespaceURI, localName, qName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForest.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForest.java
new file mode 100644
index 0000000..03fe2e2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForest.java
@@ -0,0 +1,566 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import static javax.xml.XMLConstants.W3C_XML_SCHEMA_NS_URI;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.parsers.SAXParserFactory;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.sax.SAXResult;
+import javax.xml.transform.sax.SAXSource;
+import javax.xml.validation.SchemaFactory;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.reader.xmlschema.parser.SchemaConstraintChecker;
+import com.sun.tools.internal.xjc.util.ErrorReceiverFilter;
+import com.sun.tools.internal.xjc.util.XMLStreamReaderToContentHandler;
+import com.sun.xml.internal.bind.marshaller.DataWriter;
+import com.sun.xml.internal.xsom.parser.JAXPParser;
+import com.sun.xml.internal.xsom.parser.XMLParser;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+
+/**
+ * Builds a DOM forest and maintains association from
+ * system IDs to DOM trees.
+ *
+ * <p>
+ * A forest is a transitive reflexive closure of referenced documents.
+ * IOW, if a document is in a forest, all the documents referenced from
+ * it is in a forest, too. To support this semantics, {@link DOMForest}
+ * uses {@link InternalizationLogic} to find referenced documents.
+ *
+ * <p>
+ * Some documents are marked as "root"s, meaning those documents were
+ * put into a forest explicitly, not because it is referenced from another
+ * document. (However, a root document can be referenced from other
+ * documents, too.)
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class DOMForest {
+    /** actual data storage map&lt;SystemId,Document>. */
+    private final Map<String,Document> core = new HashMap<String,Document>();
+
+    /**
+     * To correctly feed documents to a schema parser, we need to remember
+     * which documents (of the forest) were given as the root
+     * documents, and which of them are read as included/imported
+     * documents.
+     *
+     * <p>
+     * Set of system ids as strings.
+     */
+    private final Set<String> rootDocuments = new HashSet<String>();
+
+    /** Stores location information for all the trees in this forest. */
+    public final LocatorTable locatorTable = new LocatorTable();
+
+    /** Stores all the outer-most &lt;jaxb:bindings> customizations. */
+    public final Set<Element> outerMostBindings = new HashSet<Element>();
+
+    /** Used to resolve references to other schema documents. */
+    private EntityResolver entityResolver = null;
+
+    /** Errors encountered during the parsing will be sent to this object. */
+    private ErrorReceiver errorReceiver = null;
+
+    /** Schema language dependent part of the processing. */
+    protected final InternalizationLogic logic;
+
+    private final SAXParserFactory parserFactory;
+    private final DocumentBuilder documentBuilder;
+
+
+    public DOMForest(
+        SAXParserFactory parserFactory, DocumentBuilder documentBuilder,
+        InternalizationLogic logic ) {
+
+        this.parserFactory = parserFactory;
+        this.documentBuilder = documentBuilder;
+        this.logic = logic;
+    }
+
+    public DOMForest( InternalizationLogic logic ) {
+        try {
+            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+            dbf.setNamespaceAware(true);
+            this.documentBuilder = dbf.newDocumentBuilder();
+
+            this.parserFactory = SAXParserFactory.newInstance();
+            this.parserFactory.setNamespaceAware(true);
+        } catch( ParserConfigurationException e ) {
+            throw new AssertionError(e);
+        }
+
+        this.logic = logic;
+    }
+
+    /**
+     * Gets the DOM tree associated with the specified system ID,
+     * or null if none is found.
+     */
+    public Document get( String systemId ) {
+        Document doc = core.get(systemId);
+
+        if( doc==null && systemId.startsWith("file:/") && !systemId.startsWith("file://") ) {
+            // As of JDK1.4, java.net.URL.toExternal method returns URLs like
+            // "file:/abc/def/ghi" which is an incorrect file protocol URL according to RFC1738.
+            // Some other correctly functioning parts return the correct URLs ("file:///abc/def/ghi"),
+            // and this descripancy breaks DOM look up by system ID.
+
+            // this extra check solves this problem.
+            doc = core.get( "file://"+systemId.substring(5) );
+        }
+
+        if( doc==null && systemId.startsWith("file:") ) {
+            // on Windows, filenames are case insensitive.
+            // perform case-insensitive search for improved user experience
+            String systemPath = getPath(systemId);
+            for (String key : core.keySet()) {
+                if(key.startsWith("file:") && getPath(key).equalsIgnoreCase(systemPath)) {
+                    doc = core.get(key);
+                    break;
+                }
+            }
+        }
+
+        return doc;
+    }
+
+    /**
+     * Strips off the leading 'file:///' portion from an URL.
+     */
+    private String getPath(String key) {
+        key = key.substring(5); // skip 'file:'
+        while(key.length()>0 && key.charAt(0)=='/')
+            key = key.substring(1);
+        return key;
+    }
+
+    /**
+     * Returns a read-only set of root document system IDs.
+     */
+    public Set<String> getRootDocuments() {
+        return Collections.unmodifiableSet(rootDocuments);
+    }
+
+    /**
+     * Checks the correctness of the XML Schema documents and return true
+     * if it's OK.
+     *
+     * <p>
+     * This method performs a weaker version of the tests where error messages
+     * are provided without line number information. So whenever possible
+     * use {@link SchemaConstraintChecker}.
+     *
+     * @see SchemaConstraintChecker
+     */
+    public boolean checkSchemaCorrectness(ErrorReceiver errorHandler) {
+        try {
+            SchemaFactory sf = SchemaFactory.newInstance(W3C_XML_SCHEMA_NS_URI);
+            ErrorReceiverFilter filter = new ErrorReceiverFilter(errorHandler);
+            sf.setErrorHandler(filter);
+            Set<String> roots = getRootDocuments();
+            Source[] sources = new Source[roots.size()];
+            int i=0;
+            for (String root : roots) {
+                sources[i++] = new DOMSource(get(root),root);
+            }
+            sf.newSchema(sources);
+            return !filter.hadError();
+        } catch (SAXException e) {
+            // the errors should have been reported
+            return false;
+        }
+    }
+
+    /**
+     * Gets the system ID from which the given DOM is parsed.
+     * <p>
+     * Poor-man's base URI.
+     */
+    public String getSystemId( Document dom ) {
+        for (Map.Entry<String,Document> e : core.entrySet()) {
+            if (e.getValue() == dom)
+                return e.getKey();
+        }
+        return null;
+    }
+
+    public Document parse( InputSource source, boolean root ) throws SAXException {
+        if( source.getSystemId()==null )
+            throw new IllegalArgumentException();
+
+        return parse( source.getSystemId(), source, root );
+    }
+
+    /**
+     * Parses an XML at the given location (
+     * and XMLs referenced by it) into DOM trees
+     * and stores them to this forest.
+     *
+     * @return the parsed DOM document object.
+     */
+    public Document parse( String systemId, boolean root ) throws SAXException, IOException {
+
+        systemId = normalizeSystemId(systemId);
+
+        if( core.containsKey(systemId) )
+            // this document has already been parsed. Just ignore.
+            return core.get(systemId);
+
+        InputSource is=null;
+
+        // allow entity resolver to find the actual byte stream.
+        if( entityResolver!=null )
+            is = entityResolver.resolveEntity(null,systemId);
+        if( is==null )
+            is = new InputSource(systemId);
+
+        // but we still use the original system Id as the key.
+        return parse( systemId, is, root );
+    }
+
+    /**
+     * Returns a {@link ContentHandler} to feed SAX events into.
+     *
+     * <p>
+     * The client of this class can feed SAX events into the handler
+     * to parse a document into this DOM forest.
+     *
+     * This version requires that the DOM object to be created and registered
+     * to the map beforehand.
+     */
+    private ContentHandler getParserHandler( Document dom ) {
+        ContentHandler handler = new DOMBuilder(dom,locatorTable,outerMostBindings);
+        handler = new WhitespaceStripper(handler,errorReceiver,entityResolver);
+        handler = new VersionChecker(handler,errorReceiver,entityResolver);
+
+        // insert the reference finder so that
+        // included/imported schemas will be also parsed
+        XMLFilterImpl f = logic.createExternalReferenceFinder(this);
+        f.setContentHandler(handler);
+
+        if(errorReceiver!=null)
+            f.setErrorHandler(errorReceiver);
+        if(entityResolver!=null)
+            f.setEntityResolver(entityResolver);
+
+        return f;
+    }
+
+    public interface Handler extends ContentHandler {
+        /**
+         * Gets the DOM that was built.
+         */
+        public Document getDocument();
+    }
+
+    private static abstract class HandlerImpl extends XMLFilterImpl implements Handler {
+    }
+
+    /**
+     * Returns a {@link ContentHandler} to feed SAX events into.
+     *
+     * <p>
+     * The client of this class can feed SAX events into the handler
+     * to parse a document into this DOM forest.
+     */
+    public Handler getParserHandler( String systemId, boolean root ) {
+        final Document dom = documentBuilder.newDocument();
+        core.put( systemId, dom );
+        if(root)
+            rootDocuments.add(systemId);
+
+        ContentHandler handler = getParserHandler(dom);
+
+        // we will register the DOM to the map once the system ID becomes available.
+        // but the SAX allows the event source to not to provide that information,
+        // so be prepared for such case.
+        HandlerImpl x = new HandlerImpl() {
+            public Document getDocument() {
+                return dom;
+            }
+        };
+        x.setContentHandler(handler);
+
+        return x;
+   }
+
+    /**
+     * Parses the given document and add it to the DOM forest.
+     *
+     * @return
+     *      null if there was a parse error. otherwise non-null.
+     */
+    public Document parse( String systemId, InputSource inputSource, boolean root ) throws SAXException {
+        Document dom = documentBuilder.newDocument();
+
+        systemId = normalizeSystemId(systemId);
+
+        // put into the map before growing a tree, to
+        // prevent recursive reference from causing infinite loop.
+        core.put( systemId, dom );
+        if(root)
+            rootDocuments.add(systemId);
+
+        try {
+            XMLReader reader = parserFactory.newSAXParser().getXMLReader();
+            reader.setContentHandler(getParserHandler(dom));
+            if(errorReceiver!=null)
+                reader.setErrorHandler(errorReceiver);
+            if(entityResolver!=null)
+                reader.setEntityResolver(entityResolver);
+            reader.parse(inputSource);
+        } catch( ParserConfigurationException e ) {
+            // in practice, this exception won't happen.
+            errorReceiver.error(e.getMessage(),e);
+            core.remove(systemId);
+            rootDocuments.remove(systemId);
+            return null;
+        } catch( IOException e ) {
+            errorReceiver.error(e.getMessage(),e);
+            core.remove(systemId);
+            rootDocuments.remove(systemId);
+            return null;
+        }
+
+        return dom;
+    }
+
+    private String normalizeSystemId(String systemId) {
+        try {
+            systemId = new URI(systemId).normalize().toString();
+        } catch (URISyntaxException e) {
+            // leave the system ID untouched. In my experience URI is often too strict
+        }
+        return systemId;
+    }
+
+    public Document parse( String systemId, XMLStreamReader parser, boolean root ) throws XMLStreamException {
+        Document dom = documentBuilder.newDocument();
+
+        systemId = normalizeSystemId(systemId);
+
+        if(root)
+            rootDocuments.add(systemId);
+
+        if(systemId==null)
+            throw new IllegalArgumentException("system id cannot be null");
+        core.put( systemId, dom );
+
+        new XMLStreamReaderToContentHandler(parser,getParserHandler(dom)).bridge();
+
+        return dom;
+    }
+
+    /**
+     * Performs internalization.
+     *
+     * This method should be called only once, only after all the
+     * schemas are parsed.
+     */
+    public void transform() {
+        Internalizer.transform(this);
+    }
+
+    /**
+     * Performs the schema correctness check by using JAXP 1.3.
+     *
+     * <p>
+     * This is "weak", because {@link SchemaFactory#newSchema(Source[])}
+     * doesn't handle inclusions very correctly (it ends up parsing it
+     * from its original source, not in this tree), and because
+     * it doesn't handle two documents for the same namespace very
+     * well.
+     *
+     * <p>
+     * We should eventually fix JAXP (and Xerces), but meanwhile
+     * this weaker and potentially wrong correctness check is still
+     * better than nothing when used inside JAX-WS (JAXB CLI and Ant
+     * does a better job of checking this.)
+     *
+     * <p>
+     * To receive errors, use {@link SchemaFactory#setErrorHandler(ErrorHandler)}.
+     */
+    public void weakSchemaCorrectnessCheck(SchemaFactory sf) {
+        List<SAXSource> sources = new ArrayList<SAXSource>();
+        for( String systemId : getRootDocuments() ) {
+            Document dom = get(systemId);
+            if (dom.getDocumentElement().getNamespaceURI().equals(Const.JAXB_NSURI))
+                continue;   // this isn't a schema. we have to do a negative check because if we see completely unrelated ns, we want to report that as an error
+
+            SAXSource ss = createSAXSource(systemId);
+            try {
+                ss.getXMLReader().setFeature("http://xml.org/sax/features/namespace-prefixes",true);
+            } catch (SAXException e) {
+                throw new AssertionError(e);    // Xerces wants this. See 6395322.
+            }
+            sources.add(ss);
+        }
+
+        try {
+            sf.newSchema(sources.toArray(new SAXSource[0]));
+        } catch (SAXException e) {
+            // error should have been reported.
+        } catch (RuntimeException e) {
+            // JAXP RI isn't very trustworthy when it comes to schema error check,
+            // and we know some cases where it just dies with NPE. So handle it gracefully.
+            // this masks a bug in the JAXP RI, but we need a release that we have to make.
+            try {
+                sf.getErrorHandler().warning(
+                    new SAXParseException(Messages.format(
+                        Messages.ERR_GENERAL_SCHEMA_CORRECTNESS_ERROR,e.getMessage()),
+                        null,null,-1,-1,e));
+            } catch (SAXException _) {
+                // ignore
+            }
+        }
+    }
+
+    /**
+     * Creates a {@link SAXSource} that, when parsed, reads from this {@link DOMForest}
+     * (instead of parsing the original source identified by the system ID.)
+     */
+    public @NotNull SAXSource createSAXSource(String systemId) {
+        ContentHandlerNamespacePrefixAdapter reader = new ContentHandlerNamespacePrefixAdapter(new XMLFilterImpl() {
+            // XMLReader that uses XMLParser to parse. We need to use XMLFilter to indrect
+            // handlers, since SAX allows handlers to be changed while parsing.
+            public void parse(InputSource input) throws SAXException, IOException {
+                createParser().parse(input, this, this, this);
+            }
+
+            public void parse(String systemId) throws SAXException, IOException {
+                parse(new InputSource(systemId));
+            }
+        });
+
+        return new SAXSource(reader,new InputSource(systemId));
+    }
+
+    /**
+     * Creates {@link XMLParser} for XSOM which reads documents from
+     * this DOMForest rather than doing a fresh parse.
+     *
+     * The net effect is that XSOM will read transformed XML Schemas
+     * instead of the original documents.
+     */
+    public XMLParser createParser() {
+        return new DOMForestParser(this,new JAXPParser());
+    }
+
+
+
+    public EntityResolver getEntityResolver() {
+        return entityResolver;
+    }
+
+    public void setEntityResolver(EntityResolver entityResolver) {
+        this.entityResolver = entityResolver;
+    }
+
+    public ErrorReceiver getErrorHandler() {
+        return errorReceiver;
+    }
+
+    public void setErrorHandler(ErrorReceiver errorHandler) {
+        this.errorReceiver = errorHandler;
+    }
+
+    /**
+     * Gets all the parsed documents.
+     */
+    public Document[] listDocuments() {
+        return core.values().toArray(new Document[core.size()]);
+    }
+
+    /**
+     * Gets all the system IDs of the documents.
+     */
+    public String[] listSystemIDs() {
+        return core.keySet().toArray(new String[core.keySet().size()]);
+    }
+
+    /**
+     * Dumps the contents of the forest to the specified stream.
+     *
+     * This is a debug method. As such, error handling is sloppy.
+     */
+    public void dump( OutputStream out ) throws IOException {
+        try {
+            // create identity transformer
+            Transformer it = TransformerFactory.newInstance().newTransformer();
+
+            for (Map.Entry<String, Document> e : core.entrySet()) {
+                out.write( ("---<< "+e.getKey()+'\n').getBytes() );
+
+                DataWriter dw = new DataWriter(new OutputStreamWriter(out),null);
+                dw.setIndentStep("  ");
+                it.transform( new DOMSource(e.getValue()),
+                    new SAXResult(dw));
+
+                out.write( "\n\n\n".getBytes() );
+            }
+        } catch( TransformerException e ) {
+            e.printStackTrace();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForestParser.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForestParser.java
new file mode 100644
index 0000000..4182938
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForestParser.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import java.io.IOException;
+
+import com.sun.xml.internal.xsom.parser.XMLParser;
+
+import org.w3c.dom.Document;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+
+/**
+ * {@link XMLParser} implementation that
+ * parses XML from a DOM forest instead of parsing it from
+ * its original location.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class DOMForestParser implements XMLParser {
+
+    /** DOM forest to be "parsed". */
+    private final DOMForest forest;
+
+    /** Scanner object will do the actual SAX events generation. */
+    private final DOMForestScanner scanner;
+
+    private final XMLParser fallbackParser;
+
+    /**
+     * @param fallbackParser
+     *      This parser will be used when DOMForestParser needs to parse
+     *      documents that are not in the forest.
+     */
+    DOMForestParser( DOMForest forest, XMLParser fallbackParser ) {
+        this.forest = forest;
+        this.scanner = new DOMForestScanner(forest);
+        this.fallbackParser = fallbackParser;
+    }
+
+    public void parse(
+        InputSource source,
+        ContentHandler contentHandler,
+        ErrorHandler errorHandler,
+        EntityResolver entityResolver )
+        throws SAXException, IOException {
+
+        String systemId = source.getSystemId();
+        Document dom = forest.get(systemId);
+
+        if(dom==null) {
+            // if no DOM tree is built for it,
+            // let the fall back parser parse the original document.
+            //
+            // for example, XSOM parses datatypes.xsd (XML Schema part 2)
+            // but this will never be built into the forest.
+            fallbackParser.parse( source, contentHandler, errorHandler, entityResolver );
+            return;
+        }
+
+        scanner.scan( dom, contentHandler );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForestScanner.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForestScanner.java
new file mode 100644
index 0000000..3f9b639
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/DOMForestScanner.java
@@ -0,0 +1,179 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import com.sun.xml.internal.bind.unmarshaller.DOMScanner;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+
+
+/**
+ * Produces a complete series of SAX events from any DOM node
+ * in the DOMForest.
+ *
+ * <p>
+ * This class hides a logic of re-associating {@link Locator}
+ * to the generated SAX event stream.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class DOMForestScanner {
+
+    private final DOMForest forest;
+
+    /**
+     * Scans DOM nodes of the given forest.
+     *
+     * DOM node parameters to the scan method must be a part of
+     * this forest.
+     */
+    public DOMForestScanner( DOMForest _forest ) {
+        this.forest = _forest;
+    }
+
+    /**
+     * Generates the whole set of SAX events by treating
+     * element e as if it's a root element.
+     */
+    public void scan( Element e, ContentHandler contentHandler ) throws SAXException {
+        DOMScanner scanner = new DOMScanner();
+
+        // insert the location resolver into the pipe line
+        LocationResolver resolver = new LocationResolver(scanner);
+        resolver.setContentHandler(contentHandler);
+
+        // parse this DOM.
+        scanner.setContentHandler(resolver);
+        scanner.scan(e);
+    }
+
+    /**
+     * Generates the whole set of SAX events from the given Document
+     * in the DOMForest.
+     */
+    public void scan( Document d, ContentHandler contentHandler ) throws SAXException {
+        scan( d.getDocumentElement(), contentHandler );
+    }
+
+    /**
+     * Intercepts the invocation of the setDocumentLocator method
+     * and passes itself as the locator.
+     *
+     * If the client calls one of the methods on the Locator interface,
+     * use the LocatorTable to resolve the source location.
+     */
+    private class LocationResolver extends XMLFilterImpl implements Locator {
+        LocationResolver( DOMScanner _parent ) {
+            this.parent = _parent;
+        }
+
+        private final DOMScanner parent;
+
+        /**
+         * Flag that tells us whether we are processing a start element event
+         * or an end element event.
+         *
+         * DOMScanner's getCurrentLocation method doesn't tell us which, but
+         * this information is necessary to return the correct source line information.
+         *
+         * Thus we set this flag appropriately before we pass an event to
+         * the next ContentHandler, thereby making it possible to figure
+         * out which location to return.
+         */
+        private boolean inStart = false;
+
+        public void setDocumentLocator(Locator locator) {
+            // ignore one set by the parent.
+
+            super.setDocumentLocator(this);
+        }
+
+        public void endElement(String namespaceURI, String localName, String qName) throws SAXException {
+            inStart = false;
+            super.endElement(namespaceURI, localName, qName);
+        }
+
+        public void startElement(String namespaceURI, String localName, String qName, Attributes atts)
+            throws SAXException {
+            inStart = true;
+            super.startElement(namespaceURI, localName, qName, atts);
+        }
+
+
+
+
+        private Locator findLocator() {
+            Node n = parent.getCurrentLocation();
+            if( n instanceof Element ) {
+                Element e = (Element)n;
+                if( inStart )
+                    return forest.locatorTable.getStartLocation( e );
+                else
+                    return forest.locatorTable.getEndLocation( e );
+            }
+            return null;
+        }
+
+        //
+        //
+        // Locator methods
+        //
+        //
+        public int getColumnNumber() {
+            Locator l = findLocator();
+            if(l!=null)     return l.getColumnNumber();
+            return          -1;
+        }
+
+        public int getLineNumber() {
+            Locator l = findLocator();
+            if(l!=null)     return l.getLineNumber();
+            return          -1;
+        }
+
+        public String getPublicId() {
+            Locator l = findLocator();
+            if(l!=null)     return l.getPublicId();
+            return          null;
+        }
+
+        public String getSystemId() {
+            Locator l = findLocator();
+            if(l!=null)     return l.getSystemId();
+            return          null;
+        }
+
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/InternalizationLogic.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/InternalizationLogic.java
new file mode 100644
index 0000000..3028300
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/InternalizationLogic.java
@@ -0,0 +1,94 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import org.w3c.dom.Element;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * Encapsulates schema-language dependent internalization logic.
+ *
+ * {@link Internalizer} and {@link DOMForest} are responsible for
+ * doing schema language independent part, and this object is responsible
+ * for schema language dependent part.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface InternalizationLogic {
+    /**
+     * Creates a new instance of XMLFilter that can be used to
+     * find references to external schemas.
+     *
+     * <p>
+     * Schemas that are included/imported need to be a part of
+     * {@link DOMForest}, and this filter will be expected to
+     * find such references.
+     *
+     * <p>
+     * Once such a reference is found, the filter is expected to
+     * call the parse method of DOMForest.
+     *
+     * <p>
+     * {@link DOMForest} will register ErrorHandler to the returned
+     * object, so any error should be sent to that error handler.
+     *
+     * @return
+     *      This method returns {@link XMLFilterImpl} because
+     *      the filter has to be usable for two directions
+     *      (wrapping a reader and wrapping a ContentHandler)
+     */
+    XMLFilterImpl createExternalReferenceFinder( DOMForest parent );
+
+    /**
+     * Checks if the specified element is a valid target node
+     * to attach a customization.
+     *
+     * @param parent
+     *      The owner DOMForest object. Probably useful only
+     *      to obtain context information, such as error handler.
+     * @param bindings
+     *      &lt;jaxb:bindings> element or a customization element.
+     * @return
+     *      true if it's OK, false if not.
+     */
+    boolean checkIfValidTargetNode( DOMForest parent, Element bindings, Element target );
+
+    /**
+     * Prepares an element that actually receives customizations.
+     *
+     * <p>
+     * For example, in XML Schema, target nodes can be any schema
+     * element but it is always the &lt;xsd:appinfo> element that
+     * receives customization.
+     *
+     * @param target
+     *      The target node designated by the customization.
+     * @return
+     *      Always return non-null valid object
+     */
+    Element refineTarget( Element target );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/Internalizer.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/Internalizer.java
new file mode 100644
index 0000000..b2d71ef
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/Internalizer.java
@@ -0,0 +1,442 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.xpath.XPath;
+import javax.xml.xpath.XPathConstants;
+import javax.xml.xpath.XPathExpressionException;
+import javax.xml.xpath.XPathFactory;
+
+import com.sun.istack.internal.SAXParseException2;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.util.DOMUtils;
+import com.sun.xml.internal.bind.v2.util.EditDistance;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+import org.xml.sax.SAXParseException;
+
+
+
+/**
+ * Internalizes external binding declarations.
+ * <p>
+ * The static "transform" method is the entry point.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class Internalizer {
+
+    private static final XPathFactory xpf = XPathFactory.newInstance();
+
+    private final XPath xpath = xpf.newXPath();
+
+    /**
+     * Internalize all &lt;jaxb:bindings> customizations in the given forest.
+     */
+    static void transform( DOMForest forest ) {
+        new Internalizer( forest ).transform();
+    }
+
+
+    private Internalizer( DOMForest forest ) {
+        this.errorHandler = forest.getErrorHandler();
+        this.forest = forest;
+    }
+
+    /**
+     * DOMForest object currently being processed.
+     */
+    private final DOMForest forest;
+
+    /**
+     * All errors found during the transformation is sent to this object.
+     */
+    private ErrorReceiver errorHandler;
+
+
+
+    private void transform() {
+
+        Map<Element,Node> targetNodes = new HashMap<Element,Node>();
+
+        //
+        // identify target nodes for all <jaxb:bindings>
+        //
+        for (Element jaxbBindings : forest.outerMostBindings) {
+            // initially, the inherited context is itself
+            buildTargetNodeMap(jaxbBindings, jaxbBindings, targetNodes);
+        }
+
+        //
+        // then move them to their respective positions.
+        //
+        for (Element jaxbBindings : forest.outerMostBindings) {
+            move(jaxbBindings, targetNodes);
+        }
+    }
+
+    /**
+     * Validates attributes of a &lt;jaxb:bindings> element.
+     */
+    private void validate( Element bindings ) {
+        NamedNodeMap atts = bindings.getAttributes();
+        for( int i=0; i<atts.getLength(); i++ ) {
+            Attr a = (Attr)atts.item(i);
+            if( a.getNamespaceURI()!=null )
+                continue;   // all foreign namespace OK.
+            if( a.getLocalName().equals("node") )
+                continue;
+            if( a.getLocalName().equals("schemaLocation"))
+                continue;
+
+            // TODO: flag error for this undefined attribute
+        }
+    }
+
+    /**
+     * Determines the target node of the "bindings" element
+     * by using the inherited target node, then put
+     * the result into the "result" map.
+     */
+    private void buildTargetNodeMap( Element bindings, Node inheritedTarget, Map<Element,Node> result ) {
+        // start by the inherited target
+        Node target = inheritedTarget;
+
+        validate(bindings); // validate this node
+
+        // look for @schemaLocation
+        if( bindings.getAttributeNode("schemaLocation")!=null ) {
+            String schemaLocation = bindings.getAttribute("schemaLocation");
+
+            try {
+                // absolutize this URI.
+                // TODO: use the URI class
+                // TODO: honor xml:base
+                schemaLocation = new URL(
+                    new URL( forest.getSystemId(bindings.getOwnerDocument()) ),
+                    schemaLocation ).toExternalForm();
+            } catch( MalformedURLException e ) {
+                ;   // continue with the original schemaLocation value
+            }
+
+            target = forest.get(schemaLocation);
+            if(target==null) {
+                reportError( bindings,
+                    Messages.format(Messages.ERR_INCORRECT_SCHEMA_REFERENCE,
+                        schemaLocation,
+                        EditDistance.findNearest(schemaLocation,forest.listSystemIDs())));
+
+                return; // abort processing this <jaxb:bindings>
+            }
+        }
+
+        // look for @node
+        if( bindings.getAttributeNode("node")!=null ) {
+            String nodeXPath = bindings.getAttribute("node");
+
+            // evaluate this XPath
+            NodeList nlst;
+            try {
+                xpath.setNamespaceContext(new NamespaceContextImpl(bindings));
+                nlst = (NodeList)xpath.evaluate(nodeXPath,target,XPathConstants.NODESET);
+            } catch (XPathExpressionException e) {
+                reportError( bindings,
+                    Messages.format(Messages.ERR_XPATH_EVAL,e.getMessage()),
+                    e );
+                return; // abort processing this <jaxb:bindings>
+            }
+
+            if( nlst.getLength()==0 ) {
+                reportError( bindings,
+                    Messages.format(Messages.NO_XPATH_EVAL_TO_NO_TARGET,
+                        nodeXPath) );
+                return; // abort
+            }
+
+            if( nlst.getLength()!=1 ) {
+                reportError( bindings,
+                    Messages.format(Messages.NO_XPATH_EVAL_TOO_MANY_TARGETS,
+                        nodeXPath,nlst.getLength()) );
+                return; // abort
+            }
+
+            Node rnode = nlst.item(0);
+            if(!(rnode instanceof Element )) {
+                reportError( bindings,
+                    Messages.format(Messages.NO_XPATH_EVAL_TO_NON_ELEMENT,
+                        nodeXPath) );
+                return; // abort
+            }
+
+            if( !forest.logic.checkIfValidTargetNode(forest,bindings,(Element)rnode) ) {
+                reportError( bindings,
+                    Messages.format(Messages.XPATH_EVAL_TO_NON_SCHEMA_ELEMENT,
+                        nodeXPath,
+                        rnode.getNodeName() ) );
+                return; // abort
+            }
+
+            target = rnode;
+        }
+
+        // update the result map
+        result.put( bindings, target );
+
+        // look for child <jaxb:bindings> and process them recursively
+        Element[] children = DOMUtils.getChildElements( bindings, Const.JAXB_NSURI, "bindings" );
+        for (Element value : children)
+            buildTargetNodeMap(value, target, result);
+    }
+
+    /**
+     * Moves JAXB customizations under their respective target nodes.
+     */
+    private void move( Element bindings, Map<Element,Node> targetNodes ) {
+        Node target = targetNodes.get(bindings);
+        if(target==null)
+            // this must be the result of an error on the external binding.
+            // recover from the error by ignoring this node
+            return;
+
+        Element[] children = DOMUtils.getChildElements(bindings);
+        for (Element item : children) {
+            if ("bindings".equals(item.getLocalName()))
+            // process child <jaxb:bindings> recursively
+                move(item, targetNodes);
+            else {
+                if (!(target instanceof Element)) {
+                    if(target instanceof Document) {
+                        // we set the context node to the document when @schemaLocation is used.
+                        reportError(item,
+                                Messages.format(Messages.NO_CONTEXT_NODE_SPECIFIED));
+                    } else {
+                        reportError(item,
+                                Messages.format(Messages.CONTEXT_NODE_IS_NOT_ELEMENT));
+                    }
+                    return; // abort
+                }
+
+                if (!forest.logic.checkIfValidTargetNode(forest, item, (Element)target)) {
+                    reportError(item,
+                            Messages.format(Messages.ORPHANED_CUSTOMIZATION, item.getNodeName()));
+                    return; // abort
+                }
+                // move this node under the target
+                moveUnder(item,(Element)target);
+            }
+        }
+    }
+
+    /**
+     * Moves the "decl" node under the "target" node.
+     *
+     * @param decl
+     *      A JAXB customization element (e.g., &lt;jaxb:class>)
+     *
+     * @param target
+     *      XML Schema element under which the declaration should move.
+     *      For example, &lt;xs:element>
+     */
+    private void moveUnder( Element decl, Element target ) {
+        Element realTarget = forest.logic.refineTarget(target);
+
+        declExtensionNamespace( decl, target );
+
+        // copy in-scope namespace declarations of the decl node
+        // to the decl node itself so that this move won't change
+        // the in-scope namespace bindings.
+        Element p = decl;
+        Set<String> inscopes = new HashSet<String>();
+        while(true) {
+            NamedNodeMap atts = p.getAttributes();
+            for( int i=0; i<atts.getLength(); i++ ) {
+                Attr a = (Attr)atts.item(i);
+                if( Const.XMLNS_URI.equals(a.getNamespaceURI()) ) {
+                    String prefix;
+                    if( a.getName().indexOf(':')==-1 )  prefix = "";
+                    else                                prefix = a.getLocalName();
+
+                    if( inscopes.add(prefix) && p!=decl ) {
+                        // if this is the first time we see this namespace bindings,
+                        // copy the declaration.
+                        // if p==decl, there's no need to. Note that
+                        // we want to add prefix to inscopes even if p==Decl
+
+                        decl.setAttributeNodeNS( (Attr)a.cloneNode(true) );
+                    }
+                }
+            }
+
+            if( p.getParentNode() instanceof Document )
+                break;
+
+            p = (Element)p.getParentNode();
+        }
+
+        if( !inscopes.contains("") ) {
+            // if the default namespace was undeclared in the context of decl,
+            // it must be explicitly set to "" since the new environment might
+            // have a different default namespace URI.
+            decl.setAttributeNS(Const.XMLNS_URI,"xmlns","");
+        }
+
+
+        // finally move the declaration to the target node.
+        if( realTarget.getOwnerDocument()!=decl.getOwnerDocument() ) {
+            // if they belong to different DOM documents, we need to clone them
+            Element original = decl;
+            decl = (Element)realTarget.getOwnerDocument().importNode(decl,true);
+
+            // this effectively clones a ndoe,, so we need to copy locators.
+            copyLocators( original, decl );
+        }
+
+
+        realTarget.appendChild( decl );
+    }
+
+    /**
+     * Recursively visits sub-elements and declare all used namespaces.
+     * TODO: the fact that we recognize all namespaces in the extension
+     * is a bad design.
+     */
+    private void declExtensionNamespace(Element decl, Element target) {
+        // if this comes from external namespaces, add the namespace to
+        // @extensionBindingPrefixes.
+        if( !Const.JAXB_NSURI.equals(decl.getNamespaceURI()) )
+            declareExtensionNamespace( target, decl.getNamespaceURI() );
+
+        NodeList lst = decl.getChildNodes();
+        for( int i=0; i<lst.getLength(); i++ ) {
+            Node n = lst.item(i);
+            if( n instanceof Element )
+                declExtensionNamespace( (Element)n, target );
+        }
+    }
+
+
+    /** Attribute name. */
+    private static final String EXTENSION_PREFIXES = "extensionBindingPrefixes";
+
+    /**
+     * Adds the specified namespace URI to the jaxb:extensionBindingPrefixes
+     * attribute of the target document.
+     */
+    private void declareExtensionNamespace( Element target, String nsUri ) {
+        // look for the attribute
+        Element root = target.getOwnerDocument().getDocumentElement();
+        Attr att = root.getAttributeNodeNS(Const.JAXB_NSURI,EXTENSION_PREFIXES);
+        if( att==null ) {
+            String jaxbPrefix = allocatePrefix(root,Const.JAXB_NSURI);
+            // no such attribute. Create one.
+            att = target.getOwnerDocument().createAttributeNS(
+                Const.JAXB_NSURI,jaxbPrefix+':'+EXTENSION_PREFIXES);
+            root.setAttributeNodeNS(att);
+        }
+
+        String prefix = allocatePrefix(root,nsUri);
+        if( att.getValue().indexOf(prefix)==-1 )
+            // avoid redeclaring the same namespace twice.
+            att.setValue( att.getValue()+' '+prefix);
+    }
+
+    /**
+     * Declares a new prefix on the given element and associates it
+     * with the specified namespace URI.
+     * <p>
+     * Note that this method doesn't use the default namespace
+     * even if it can.
+     */
+    private String allocatePrefix( Element e, String nsUri ) {
+        // look for existing namespaces.
+        NamedNodeMap atts = e.getAttributes();
+        for( int i=0; i<atts.getLength(); i++ ) {
+            Attr a = (Attr)atts.item(i);
+            if( Const.XMLNS_URI.equals(a.getNamespaceURI()) ) {
+                if( a.getName().indexOf(':')==-1 )  continue;
+
+                if( a.getValue().equals(nsUri) )
+                    return a.getLocalName();    // found one
+            }
+        }
+
+        // none found. allocate new.
+        while(true) {
+            String prefix = "p"+(int)(Math.random()*1000000)+'_';
+            if(e.getAttributeNodeNS(Const.XMLNS_URI,prefix)!=null)
+                continue;   // this prefix is already allocated.
+
+            e.setAttributeNS(Const.XMLNS_URI,"xmlns:"+prefix,nsUri);
+            return prefix;
+        }
+    }
+
+
+    /**
+     * Copies location information attached to the "src" node to the "dst" node.
+     */
+    private void copyLocators( Element src, Element dst ) {
+        forest.locatorTable.storeStartLocation(
+            dst, forest.locatorTable.getStartLocation(src) );
+        forest.locatorTable.storeEndLocation(
+            dst, forest.locatorTable.getEndLocation(src) );
+
+        // recursively process child elements
+        Element[] srcChilds = DOMUtils.getChildElements(src);
+        Element[] dstChilds = DOMUtils.getChildElements(dst);
+
+        for( int i=0; i<srcChilds.length; i++ )
+            copyLocators( srcChilds[i], dstChilds[i] );
+    }
+
+
+    private void reportError( Element errorSource, String formattedMsg ) {
+        reportError( errorSource, formattedMsg, null );
+    }
+
+    private void reportError( Element errorSource,
+        String formattedMsg, Exception nestedException ) {
+
+        SAXParseException e = new SAXParseException2( formattedMsg,
+            forest.locatorTable.getStartLocation(errorSource),
+            nestedException );
+        errorHandler.error(e);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/LocatorTable.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/LocatorTable.java
new file mode 100644
index 0000000..dedf9ec
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/LocatorTable.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+import org.xml.sax.helpers.LocatorImpl;
+
+/**
+ * Stores {@link Locator} objects for every {@link Element}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class LocatorTable {
+    /** Locations of the start element. */
+    private final Map startLocations = new HashMap();
+
+    /** Locations of the end element. */
+    private final Map endLocations = new HashMap();
+
+    public void storeStartLocation( Element e, Locator loc ) {
+        startLocations.put(e,new LocatorImpl(loc));
+    }
+
+    public void storeEndLocation( Element e, Locator loc ) {
+        endLocations.put(e,new LocatorImpl(loc));
+    }
+
+    public Locator getStartLocation( Element e ) {
+        return (Locator)startLocations.get(e);
+    }
+
+    public Locator getEndLocation( Element e ) {
+        return (Locator)endLocations.get(e);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/MessageBundle.properties
new file mode 100644
index 0000000..95bf780
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/MessageBundle.properties
@@ -0,0 +1,51 @@
+#
+# Message resource file
+#
+
+
+AbstractReferenceFinderImpl.UnableToParse = \
+	Unable to parse "{0}" : {1}
+
+	
+
+
+Internalizer.IncorrectSchemaReference = \
+	"{0}" is not a part of this compilation. Is this a mistake for "{1}"?
+
+Internalizer.XPathEvaluationError = \
+	XPath error: {0}
+
+Internalizer.XPathEvaluatesToNoTarget = \
+	XPath evaluation of "{0}" results in empty target node
+
+Internalizer.XPathEvaulatesToTooManyTargets = \
+	XPath evaluation of "{0}" results in too many ({1}) target nodes
+
+Internalizer.XPathEvaluatesToNonElement = \
+	XPath evaluation of "{0}" needs to result in an element.
+
+Internalizer.XPathEvaluatesToNonSchemaElement = \
+	XPath evaluation of "{0}" needs to result in an element of the schema language, \
+	but it results in {1}
+
+Internalizer.ContextNodeIsNotElement = \
+	Context node is not an element.
+
+Internalizer.NoContextNodeSpecified = \
+	A schema document is selected but @node is not specified. Maybe you meant node="/xs:schema"? 
+
+Internalizer.OrphanedCustomization = \
+	The "{0}" customization is not associated with any schema element.
+
+Internalizer.IncorrectVersion = \
+	JAXB version attribute must be "1.0"
+
+Internalizer.VersionNotPresent = \
+	JAXB version attribute must be present
+
+Internalizer.TwoVersionAttributes = \
+	Both jaxb:version and version are present
+
+ERR_GENERAL_SCHEMA_CORRECTNESS_ERROR = \
+    We were unable to ensure the correctness of the schema: {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/Messages.java
new file mode 100644
index 0000000..270d3fc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/Messages.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getPackage().getName() +".MessageBundle").getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+    static final String ERR_INCORRECT_SCHEMA_REFERENCE = // args:2
+        "Internalizer.IncorrectSchemaReference";
+    static final String ERR_XPATH_EVAL = // arg:1
+        "Internalizer.XPathEvaluationError";
+    static final String NO_XPATH_EVAL_TO_NO_TARGET = // arg:1
+        "Internalizer.XPathEvaluatesToNoTarget";
+    static final String NO_XPATH_EVAL_TOO_MANY_TARGETS = // arg:2
+        "Internalizer.XPathEvaulatesToTooManyTargets";
+    static final String NO_XPATH_EVAL_TO_NON_ELEMENT = // arg:1
+        "Internalizer.XPathEvaluatesToNonElement";
+    static final String XPATH_EVAL_TO_NON_SCHEMA_ELEMENT = // arg:2
+        "Internalizer.XPathEvaluatesToNonSchemaElement";
+    static final String CONTEXT_NODE_IS_NOT_ELEMENT = // arg:0
+        "Internalizer.ContextNodeIsNotElement";
+    static final String NO_CONTEXT_NODE_SPECIFIED = // arg:0
+            "Internalizer.NoContextNodeSpecified";
+    static final String ERR_INCORRECT_VERSION = // arg:0
+        "Internalizer.IncorrectVersion";
+    static final String ERR_VERSION_NOT_FOUND = // arg:0
+        "Internalizer.VersionNotPresent";
+    static final String TWO_VERSION_ATTRIBUTES = // arg:0
+        "Internalizer.TwoVersionAttributes";
+    static final String ORPHANED_CUSTOMIZATION = // arg:1
+        "Internalizer.OrphanedCustomization";
+    static final String ERR_UNABLE_TO_PARSE = // arg:2
+        "AbstractReferenceFinderImpl.UnableToParse";
+    static final String ERR_GENERAL_SCHEMA_CORRECTNESS_ERROR = // arg:1
+        "ERR_GENERAL_SCHEMA_CORRECTNESS_ERROR";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/NamespaceContextImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/NamespaceContextImpl.java
new file mode 100644
index 0000000..f30a550
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/NamespaceContextImpl.java
@@ -0,0 +1,94 @@
+/*
+ * reserved comment block
+ * DO NOT REMOVE OR ALTER!
+ */
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.NamespaceContext;
+
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+
+/**
+ * Implements {@link NamespaceContext} by looking at the in-scope
+ * namespace binding of a DOM element.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class NamespaceContextImpl implements NamespaceContext {
+    private final Element e;
+
+    public NamespaceContextImpl(Element e) {
+        this.e = e;
+    }
+
+    /*
+     * Copyright 1999-2004 The Apache Software Foundation.
+     *
+     * Licensed under the Apache License, Version 2.0 (the "License");
+     * you may not use this file except in compliance with the License.
+     * You may obtain a copy of the License at
+     *
+     *     http://www.apache.org/licenses/LICENSE-2.0
+     *
+     * Unless required by applicable law or agreed to in writing, software
+     * distributed under the License is distributed on an "AS IS" BASIS,
+     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+     * See the License for the specific language governing permissions and
+     * limitations under the License.
+     */
+    public String getNamespaceURI(String prefix) {
+        Node parent = e;
+        String namespace = null;
+
+        if (prefix.equals("xml")) {
+            namespace = WellKnownNamespace.XML_NAMESPACE_URI;
+        } else {
+            int type;
+
+            while ((null != parent) && (null == namespace)
+                    && (((type = parent.getNodeType()) == Node.ELEMENT_NODE)
+                    || (type == Node.ENTITY_REFERENCE_NODE))) {
+                if (type == Node.ELEMENT_NODE) {
+                    if (parent.getNodeName().indexOf(prefix + ':') == 0)
+                        return parent.getNamespaceURI();
+                    NamedNodeMap nnm = parent.getAttributes();
+
+                    for (int i = 0; i < nnm.getLength(); i++) {
+                        Node attr = nnm.item(i);
+                        String aname = attr.getNodeName();
+                        boolean isPrefix = aname.startsWith("xmlns:");
+
+                        if (isPrefix || aname.equals("xmlns")) {
+                            int index = aname.indexOf(':');
+                            String p = isPrefix ? aname.substring(index + 1) : "";
+
+                            if (p.equals(prefix)) {
+                                namespace = attr.getNodeValue();
+
+                                break;
+                            }
+                        }
+                    }
+                }
+
+                parent = parent.getParentNode();
+            }
+        }
+
+        return namespace;
+    }
+
+    public String getPrefix(String namespaceURI) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Iterator getPrefixes(String namespaceURI) {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/VersionChecker.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/VersionChecker.java
new file mode 100644
index 0000000..1170d47
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/VersionChecker.java
@@ -0,0 +1,133 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import com.sun.tools.internal.xjc.reader.Const;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.LocatorImpl;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * Checks the jaxb:version attribute on a XML Schema document.
+ *
+ * jaxb:version is optional if no binding customization is used,
+ * but if present, its value must be "1.0".
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class VersionChecker extends XMLFilterImpl {
+
+    /**
+     * We store the value of the version attribute in this variable
+     * when we hit the root element.
+     */
+    private String version = null ;
+
+    /** Will be set to true once we hit the root element. */
+    private boolean seenRoot = false;
+
+    /** Will be set to true once we hit a binding declaration. */
+    private boolean seenBindings = false;
+
+    private Locator locator;
+
+    /**
+     * Stores the location of the start tag of the root tag.
+     */
+    private Locator rootTagStart;
+
+    public VersionChecker( XMLReader parent ) {
+        setParent(parent);
+    }
+
+    public VersionChecker( ContentHandler handler,ErrorHandler eh,EntityResolver er ) {
+        setContentHandler(handler);
+        if(eh!=null)    setErrorHandler(eh);
+        if(er!=null)    setEntityResolver(er);
+    }
+
+    public void startElement(String namespaceURI, String localName, String qName, Attributes atts)
+        throws SAXException {
+
+        super.startElement(namespaceURI, localName, qName, atts);
+
+        if(!seenRoot) {
+            // if this is the root element
+            seenRoot = true;
+            rootTagStart = new LocatorImpl(locator);
+
+            version = atts.getValue(Const.JAXB_NSURI,"version");
+            if( namespaceURI.equals(Const.JAXB_NSURI) ) {
+                String version2 = atts.getValue("","version");
+                if( version!=null && version2!=null ) {
+                    // we have both @version and @jaxb:version. error.
+                    SAXParseException e = new SAXParseException(
+                        Messages.format( Messages.TWO_VERSION_ATTRIBUTES ), locator );
+                    getErrorHandler().error(e);
+                }
+                if( version==null )
+                    version = version2;
+            }
+
+        }
+
+        if( Const.JAXB_NSURI.equals(namespaceURI) )
+            seenBindings = true;
+    }
+
+    public void endDocument() throws SAXException {
+        super.endDocument();
+
+        if( seenBindings && version==null ) {
+            // if we see a binding declaration but not version attribute
+            SAXParseException e = new SAXParseException(
+                Messages.format(Messages.ERR_VERSION_NOT_FOUND),rootTagStart);
+            getErrorHandler().error(e);
+        }
+
+        // if present, the value must be either 1.0 or 2.0
+        if( version!=null && !version.equals("1.0") && !version.equals("2.0") ) {
+            SAXParseException e = new SAXParseException(
+                Messages.format(Messages.ERR_INCORRECT_VERSION),rootTagStart);
+            getErrorHandler().error(e);
+        }
+    }
+
+    public void setDocumentLocator(Locator locator) {
+        super.setDocumentLocator(locator);
+        this.locator = locator;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/WhitespaceStripper.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/WhitespaceStripper.java
new file mode 100644
index 0000000..c55813d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/WhitespaceStripper.java
@@ -0,0 +1,127 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.internalizer;
+
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * Strips ignorable whitespace from SAX event stream.
+ *
+ * <p>
+ * This filter works only when the event stream doesn't
+ * contain any mixed content.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class WhitespaceStripper extends XMLFilterImpl {
+
+    private int state = 0;
+
+    private char[] buf = new char[1024];
+    private int bufLen = 0;
+
+    private static final int AFTER_START_ELEMENT = 1;
+    private static final int AFTER_END_ELEMENT = 2;
+
+    public WhitespaceStripper(XMLReader reader) {
+        setParent(reader);
+    }
+
+    public WhitespaceStripper(ContentHandler handler,ErrorHandler eh,EntityResolver er) {
+        setContentHandler(handler);
+        if(eh!=null)    setErrorHandler(eh);
+        if(er!=null)    setEntityResolver(er);
+    }
+
+    public void characters(char[] ch, int start, int length) throws SAXException {
+        switch(state) {
+        case AFTER_START_ELEMENT:
+            // we have to store the characters here, even if it consists entirely
+            // of whitespaces. This is because successive characters event might
+            // include non-whitespace char, in which case all the whitespaces in
+            // this event may suddenly become significant.
+            if( bufLen+length>buf.length ) {
+                // reallocate buffer
+                char[] newBuf = new char[Math.max(bufLen+length,buf.length*2)];
+                System.arraycopy(buf,0,newBuf,0,bufLen);
+                buf = newBuf;
+            }
+            System.arraycopy(ch,start,buf,bufLen,length);
+            bufLen += length;
+            break;
+        case AFTER_END_ELEMENT:
+            // check if this is ignorable.
+            int len = start+length;
+            for( int i=start; i<len; i++ )
+                if( !WhiteSpaceProcessor.isWhiteSpace(ch[i]) ) {
+                    super.characters(ch, start, length);
+                    return;
+                }
+            // if it's entirely whitespace, ignore it.
+            break;
+        }
+    }
+
+    public void startElement(String uri, String localName, String qName, Attributes atts) throws SAXException {
+        processPendingText();
+        super.startElement(uri, localName, qName, atts);
+        state = AFTER_START_ELEMENT;
+        bufLen = 0;
+    }
+
+    public void endElement(String uri, String localName, String qName) throws SAXException {
+        processPendingText();
+        super.endElement(uri, localName, qName);
+        state = AFTER_END_ELEMENT;
+    }
+
+    /**
+     * Forwars the buffered characters if it contains any non-whitespace
+     * character.
+     */
+    private void processPendingText() throws SAXException {
+        if(state==AFTER_START_ELEMENT) {
+            for( int i=bufLen-1; i>=0; i-- )
+                if( !WhiteSpaceProcessor.isWhiteSpace(buf[i]) ) {
+                    super.characters(buf, 0, bufLen);
+                    return;
+               }
+        }
+    }
+
+    public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
+        // ignore completely.
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/package.html
new file mode 100644
index 0000000..259b4ff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/internalizer/package.html
@@ -0,0 +1 @@
+<body><p>internalization of external binding files and &lt;jaxb:bindings> customizations.</p></body>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/package.html
new file mode 100644
index 0000000..d355bc8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/package.html
@@ -0,0 +1 @@
+<body><p>Front-end that reads schema(s) and produce BGM.</p></body>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/BindStyle.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/BindStyle.java
new file mode 100644
index 0000000..63f23b7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/BindStyle.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+enum BindStyle {
+    TYPE, ELEMENT
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/ContentModelBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/ContentModelBinder.java
new file mode 100644
index 0000000..53fd3f8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/ContentModelBinder.java
@@ -0,0 +1,130 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.CAttributePropertyInfo;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.Multiplicity;
+import com.sun.tools.internal.xjc.reader.RawTypeSet;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+
+import com.sun.xml.internal.rngom.digested.DAttributePattern;
+import com.sun.xml.internal.rngom.digested.DChoicePattern;
+import com.sun.xml.internal.rngom.digested.DMixedPattern;
+import com.sun.xml.internal.rngom.digested.DOneOrMorePattern;
+import com.sun.xml.internal.rngom.digested.DOptionalPattern;
+import com.sun.xml.internal.rngom.digested.DPattern;
+import com.sun.xml.internal.rngom.digested.DPatternWalker;
+import com.sun.xml.internal.rngom.digested.DZeroOrMorePattern;
+
+import static com.sun.tools.internal.xjc.model.CElementPropertyInfo.CollectionMode.REPEATED_ELEMENT;
+
+/**
+ * Recursively visits {@link DPattern} and
+ * decides which patterns to map to properties.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ContentModelBinder extends DPatternWalker {
+    private final RELAXNGCompiler compiler;
+    private final CClassInfo clazz;
+
+    private boolean insideOptional = false;
+    private int iota=1;
+
+    public ContentModelBinder(RELAXNGCompiler compiler,CClassInfo clazz) {
+        this.compiler = compiler;
+        this.clazz = clazz;
+    }
+
+    public Void onMixed(DMixedPattern p) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Void onChoice(DChoicePattern p) {
+        boolean old = insideOptional;
+        insideOptional = true;
+        super.onChoice(p);
+        insideOptional = old;
+        return null;
+    }
+
+    public Void onOptional(DOptionalPattern p) {
+        boolean old = insideOptional;
+        insideOptional = true;
+        super.onOptional(p);
+        insideOptional = old;
+        return null;
+    }
+
+    public Void onZeroOrMore(DZeroOrMorePattern p) {
+        return onRepeated(p,true);
+    }
+
+    public Void onOneOrMore(DOneOrMorePattern p) {
+        return onRepeated(p,insideOptional);
+
+    }
+
+    private Void onRepeated(DPattern p,boolean optional) {
+        RawTypeSet rts = RawTypeSetBuilder.build(compiler, p, optional? Multiplicity.STAR : Multiplicity.PLUS);
+        if(rts.canBeTypeRefs==RawTypeSet.Mode.SHOULD_BE_TYPEREF) {
+            CElementPropertyInfo prop = new CElementPropertyInfo(
+                    calcName(p),REPEATED_ELEMENT,ID.NONE,null,null,null,p.getLocation(),!optional);
+            rts.addTo(prop);
+            clazz.addProperty(prop);
+        } else {
+            CReferencePropertyInfo prop = new CReferencePropertyInfo(
+                    calcName(p),true,false/*TODO*/,null,null,p.getLocation());
+            rts.addTo(prop);
+            clazz.addProperty(prop);
+        }
+
+        return null;
+    }
+
+    public Void onAttribute(DAttributePattern p) {
+        // TODO: support multiple names
+        QName name = p.getName().listNames().iterator().next();
+
+        CAttributePropertyInfo ap = new CAttributePropertyInfo(
+           calcName(p), null,null/*TODO*/, p.getLocation(), name,
+                p.getChild().accept(compiler.typeUseBinder),
+                !insideOptional);
+        clazz.addProperty(ap);
+
+        return null;
+    }
+
+    private String calcName(DPattern p) {
+        // TODO
+        return "field"+(iota++);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/DatatypeLib.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/DatatypeLib.java
new file mode 100644
index 0000000..8aabe55
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/DatatypeLib.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.reader.xmlschema.SimpleTypeBuilder;
+
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+
+/**
+ * Data-bindable datatype library.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class DatatypeLib {
+    /**
+     * Datatype library's namespace URI.
+     */
+    public final String nsUri;
+
+    private final Map<String,TypeUse> types = new HashMap<String,TypeUse>();
+
+    public DatatypeLib(String nsUri) {
+        this.nsUri = nsUri;
+    }
+
+    /**
+     * Maps the type name to the information.
+     */
+    TypeUse get(String name) {
+        return types.get(name);
+    }
+
+    /**
+     * Datatype library for the built-in type.
+     */
+    public static final DatatypeLib BUILTIN = new DatatypeLib("");
+
+    /**
+     * Datatype library for XML Schema datatypes.
+     */
+    public static final DatatypeLib XMLSCHEMA = new DatatypeLib(WellKnownNamespaces.XML_SCHEMA_DATATYPES);
+
+    static {
+        BUILTIN.types.put("token",CBuiltinLeafInfo.TOKEN);
+        BUILTIN.types.put("string",CBuiltinLeafInfo.STRING);
+        XMLSCHEMA.types.putAll(SimpleTypeBuilder.builtinConversions);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/DefineFinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/DefineFinder.java
new file mode 100644
index 0000000..32f2861
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/DefineFinder.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import com.sun.xml.internal.rngom.digested.DDefine;
+import com.sun.xml.internal.rngom.digested.DGrammarPattern;
+import com.sun.xml.internal.rngom.digested.DPatternWalker;
+import com.sun.xml.internal.rngom.digested.DRefPattern;
+
+/**
+ * Recursively find all {@link DDefine}s in the grammar.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class DefineFinder extends DPatternWalker {
+
+    public final Set<DDefine> defs = new HashSet<DDefine>();
+
+    public Void onGrammar(DGrammarPattern p) {
+        for( DDefine def : p ) {
+            defs.add(def);
+            def.getPattern().accept(this);
+        }
+
+        return p.getStart().accept(this);
+    }
+
+    /**
+     * We visit all {@link DDefine}s from {@link DGrammarPattern},
+     * so no point in resolving refs.
+     */
+    public Void onRef(DRefPattern p) {
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/NameCalculator.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/NameCalculator.java
new file mode 100644
index 0000000..e45fecf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/NameCalculator.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import com.sun.xml.internal.rngom.digested.DPatternWalker;
+
+/**
+ * Decides the name for a particle.
+ * @author Kohsuke Kawaguchi
+ */
+class NameCalculator extends DPatternWalker {
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RELAXNGCompiler.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RELAXNGCompiler.java
new file mode 100644
index 0000000..c532e37
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RELAXNGCompiler.java
@@ -0,0 +1,270 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CClassInfoParent;
+import com.sun.tools.internal.xjc.model.CEnumConstant;
+import com.sun.tools.internal.xjc.model.CEnumLeafInfo;
+import com.sun.tools.internal.xjc.model.CNonElement;
+import com.sun.tools.internal.xjc.model.CTypeInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+
+import com.sun.xml.internal.rngom.digested.DChoicePattern;
+import com.sun.xml.internal.rngom.digested.DDefine;
+import com.sun.xml.internal.rngom.digested.DElementPattern;
+import com.sun.xml.internal.rngom.digested.DPattern;
+import com.sun.xml.internal.rngom.digested.DPatternWalker;
+import com.sun.xml.internal.rngom.digested.DRefPattern;
+import com.sun.xml.internal.rngom.digested.DValuePattern;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public final class RELAXNGCompiler {
+    /**
+     * Schema to compile.
+     */
+    final DPattern grammar;
+
+    /**
+     * All named patterns in this schema.
+     */
+    final Set<DDefine> defs;
+
+    final Options opts;
+
+    final Model model;
+
+    /**
+     * The package to which we generate the code into.
+     */
+    final JPackage pkg;
+
+    final Map<String,DatatypeLib> datatypes = new HashMap<String, DatatypeLib>();
+
+    /**
+     * Patterns that are mapped to Java concepts.
+     *
+     * <p>
+     * The value is an array because we map elements with finite names
+     * to multiple classes.
+     *
+     * TODO: depending on the type of the key, the type of the values can be further
+     * restricted. Make this into its own class to represent those constraints better.
+     */
+    final Map<DPattern,CTypeInfo[]> classes = new HashMap<DPattern,CTypeInfo[]>();
+
+    /**
+     * Classes that need to be bound.
+     *
+     * The value is the content model to be bound.
+     */
+    final Map<CClassInfo,DPattern> bindQueue = new HashMap<CClassInfo,DPattern>();
+
+    final TypeUseBinder typeUseBinder = new TypeUseBinder(this);
+
+    public static Model build(DPattern grammar, JCodeModel codeModel, Options opts ) {
+        RELAXNGCompiler compiler = new RELAXNGCompiler(grammar, codeModel, opts);
+        compiler.compile();
+        return compiler.model;
+    }
+
+    public RELAXNGCompiler(DPattern grammar, JCodeModel codeModel, Options opts) {
+        this.grammar = grammar;
+        this.opts = opts;
+        this.model = new Model(opts,codeModel, NameConverter.smart,opts.classNameAllocator);
+
+        datatypes.put("",DatatypeLib.BUILTIN);
+        datatypes.put(WellKnownNamespaces.XML_SCHEMA_DATATYPES,DatatypeLib.XMLSCHEMA);
+
+        // find all defines
+        DefineFinder deff = new DefineFinder();
+        grammar.accept(deff);
+        this.defs = deff.defs;
+
+        if(opts.defaultPackage2!=null)
+            pkg = codeModel._package(opts.defaultPackage2);
+        else
+        if(opts.defaultPackage!=null)
+            pkg = codeModel._package(opts.defaultPackage);
+        else
+            pkg = codeModel.rootPackage();
+    }
+
+    private void compile() {
+        // decide which patterns to map to classes
+        promoteElementDefsToClasses();
+        promoteTypeSafeEnums();
+        // TODO: promote patterns with <jaxb:class> to classes
+        // TODO: promote 'type' patterns to classes
+        promoteTypePatternsToClasses();
+
+        for (Map.Entry<CClassInfo,DPattern> e : bindQueue.entrySet())
+            bindContentModel(e.getKey(),e.getValue());
+    }
+
+    private void bindContentModel(CClassInfo clazz, DPattern pattern) {
+        // first we decide which patterns in it map to properties
+        // then we process each of them by using RawTypeSetBuilder.
+        // much like DefaultParticleBinder in XSD
+        pattern.accept(new ContentModelBinder(this,clazz));
+    }
+
+    private void promoteTypeSafeEnums() {
+        // we'll be trying a lot of choices,
+        // and most of them will not be type-safe enum.
+        // using the same list improves the memory efficiency.
+        List<CEnumConstant> members = new ArrayList<CEnumConstant>();
+
+        OUTER:
+        for( DDefine def : defs ) {
+            DPattern p = def.getPattern();
+            if (p instanceof DChoicePattern) {
+                DChoicePattern cp = (DChoicePattern) p;
+
+                members.clear();
+
+                // check if the choice consists of all value patterns
+                // and that they are of the same datatype
+                DValuePattern vp = null;
+
+                for( DPattern child : cp ) {
+                    if(child instanceof DValuePattern) {
+                        DValuePattern c = (DValuePattern) child;
+                        if(vp==null)
+                            vp=c;
+                        else {
+                            if(!vp.getDatatypeLibrary().equals(c.getDatatypeLibrary())
+                            || !vp.getType().equals(c.getType()) )
+                                continue OUTER; // different type name
+                        }
+
+                        members.add(new CEnumConstant(
+                            model.getNameConverter().toConstantName(c.getValue()),
+                            null, c.getValue(), c.getLocation()
+                        ));
+                    } else
+                        continue OUTER; // not a value
+                }
+
+                if(members.isEmpty())
+                    continue;   // empty choice
+
+                CNonElement base = CBuiltinLeafInfo.STRING;
+
+                DatatypeLib lib = datatypes.get(vp.getNs());
+                if(lib!=null) {
+                    TypeUse use = lib.get(vp.getType());
+                    if(use instanceof CNonElement)
+                        base = (CNonElement)use;
+                }
+
+                CEnumLeafInfo xducer = new CEnumLeafInfo(model, null,
+                        new CClassInfoParent.Package(pkg), def.getName(), base,
+                        new ArrayList<CEnumConstant>(members),
+                        null, null/*TODO*/, cp.getLocation());
+
+                classes.put(cp,new CTypeInfo[]{xducer});
+            }
+        }
+    }
+
+
+    private void promoteElementDefsToClasses() {
+        // look for elements among named patterns
+        for( DDefine def : defs ) {
+            DPattern p = def.getPattern();
+            if (p instanceof DElementPattern) {
+                DElementPattern ep = (DElementPattern) p;
+
+                mapToClass(ep);
+            }
+        }
+
+        // also look for root elements
+        grammar.accept(new DPatternWalker() {
+            public Void onRef(DRefPattern p) {
+                return null;    // stop recursion
+            }
+
+            public Void onElement(DElementPattern p) {
+                mapToClass(p);
+                return null;
+            }
+        });
+    }
+
+    private void mapToClass(DElementPattern p) {
+        NameClass nc = p.getName();
+        if(nc.isOpen())
+            return;   // infinite name. can't map to a class.
+
+        Set<QName> names = nc.listNames();
+
+        CClassInfo[] types = new CClassInfo[names.size()];
+        int i=0;
+        for( QName n : names ) {
+            // TODO: read class names from customization
+            String name = model.getNameConverter().toClassName(n.getLocalPart());
+
+            bindQueue.put(
+                types[i++] = new CClassInfo(model,pkg,name,p.getLocation(),null,n,null,null/*TODO*/),
+                p.getChild() );
+        }
+
+        classes.put(p,types);
+    }
+
+    /**
+     * Looks for named patterns that are not bound to classes so far,
+     * but that can be bound to classes.
+     */
+    private void promoteTypePatternsToClasses() {
+
+//        for( DDefine def : defs ) {
+//        ;
+//
+//        def.getPattern().accept(new InheritanceChecker());
+//        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RELAXNGInternalizationLogic.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RELAXNGInternalizationLogic.java
new file mode 100644
index 0000000..18e7ee8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RELAXNGInternalizationLogic.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.reader.internalizer.AbstractReferenceFinderImpl;
+import com.sun.tools.internal.xjc.reader.internalizer.DOMForest;
+import com.sun.tools.internal.xjc.reader.internalizer.InternalizationLogic;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Attributes;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * RELAX NG specific internalization logic.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class RELAXNGInternalizationLogic implements InternalizationLogic {
+
+    /**
+     * This filter looks for &lt;xs:import> and &lt;xs:include>
+     * and parses those documents referenced by them.
+     */
+    private static final class ReferenceFinder extends AbstractReferenceFinderImpl {
+        ReferenceFinder( DOMForest parent ) {
+            super(parent);
+        }
+
+        protected String findExternalResource( String nsURI, String localName, Attributes atts) {
+            if( Const.RELAXNG_URI.equals(nsURI)
+            && ("include".equals(localName) || "externalRef".equals(localName) ) )
+                return atts.getValue("href");
+            else
+                return null;
+        }
+    };
+
+    public XMLFilterImpl createExternalReferenceFinder(DOMForest parent) {
+        return new ReferenceFinder(parent);
+    }
+
+    public boolean checkIfValidTargetNode(DOMForest parent, Element bindings, Element target) {
+        return Const.RELAXNG_URI.equals(target.getNamespaceURI());
+    }
+
+    public Element refineTarget(Element target) {
+        // no refinement necessary
+        return target;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RawTypeSetBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RawTypeSetBuilder.java
new file mode 100644
index 0000000..04a7076
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/RawTypeSetBuilder.java
@@ -0,0 +1,137 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.tools.internal.xjc.model.Multiplicity;
+import com.sun.tools.internal.xjc.reader.RawTypeSet;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+
+import com.sun.xml.internal.rngom.digested.DAttributePattern;
+import com.sun.xml.internal.rngom.digested.DElementPattern;
+import com.sun.xml.internal.rngom.digested.DOneOrMorePattern;
+import com.sun.xml.internal.rngom.digested.DPattern;
+import com.sun.xml.internal.rngom.digested.DPatternWalker;
+import com.sun.xml.internal.rngom.digested.DZeroOrMorePattern;
+
+/**
+ * Builds {@link RawTypeSet} for RELAX NG.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class RawTypeSetBuilder extends DPatternWalker {
+    public static RawTypeSet build( RELAXNGCompiler compiler, DPattern contentModel, Multiplicity mul ) {
+        RawTypeSetBuilder builder = new RawTypeSetBuilder(compiler,mul);
+        contentModel.accept(builder);
+        return builder.create();
+    }
+
+    /**
+     * Multiplicity of the property.
+     */
+    private Multiplicity mul;
+
+    /**
+     * Accumulates discovered {@link RawTypeSet.Ref}s.
+     */
+    private final Set<RawTypeSet.Ref> refs = new HashSet<RawTypeSet.Ref>();
+
+    private final RELAXNGCompiler compiler;
+
+    public RawTypeSetBuilder(RELAXNGCompiler compiler,Multiplicity mul) {
+        this.mul = mul;
+        this.compiler = compiler;
+    }
+
+    private RawTypeSet create() {
+        return new RawTypeSet(refs,mul);
+    }
+
+    public Void onAttribute(DAttributePattern p) {
+        // attributes form their own properties
+        return null;
+    }
+
+    public Void onElement(DElementPattern p) {
+        CTypeInfo[] tis = compiler.classes.get(p);
+        if(tis!=null) {
+            for( CTypeInfo ti : tis )
+                refs.add(new CClassInfoRef((CClassInfo)ti));
+        } else {
+            // TODO
+            assert false;
+        }
+        return null;
+    }
+
+    public Void onZeroOrMore(DZeroOrMorePattern p) {
+        mul = mul.makeRepeated();
+        return super.onZeroOrMore(p);
+    }
+
+    public Void onOneOrMore(DOneOrMorePattern p) {
+        mul = mul.makeRepeated();
+        return super.onOneOrMore(p);
+    }
+
+    /**
+     * For {@link CClassInfo}s that map to elements.
+     */
+    private static final class CClassInfoRef extends RawTypeSet.Ref {
+        private final CClassInfo ci;
+        CClassInfoRef(CClassInfo ci) {
+            this.ci = ci;
+            assert ci.isElement();
+        }
+
+        protected ID id() {
+            return ID.NONE;
+        }
+
+        protected boolean isListOfValues() {
+            return false;
+        }
+
+        protected RawTypeSet.Mode canBeType(RawTypeSet parent) {
+            return RawTypeSet.Mode.SHOULD_BE_TYPEREF;
+        }
+
+        protected void toElementRef(CReferencePropertyInfo prop) {
+            prop.getElements().add(ci);
+        }
+
+        protected CTypeRef toTypeRef(CElementPropertyInfo ep) {
+            return new CTypeRef(ci,ci.getElementName(),false,null);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/TypePatternBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/TypePatternBinder.java
new file mode 100644
index 0000000..18d6da4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/TypePatternBinder.java
@@ -0,0 +1,140 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import java.util.HashSet;
+import java.util.Set;
+import java.util.Stack;
+
+import com.sun.xml.internal.rngom.digested.DAttributePattern;
+import com.sun.xml.internal.rngom.digested.DChoicePattern;
+import com.sun.xml.internal.rngom.digested.DDefine;
+import com.sun.xml.internal.rngom.digested.DListPattern;
+import com.sun.xml.internal.rngom.digested.DMixedPattern;
+import com.sun.xml.internal.rngom.digested.DOneOrMorePattern;
+import com.sun.xml.internal.rngom.digested.DOptionalPattern;
+import com.sun.xml.internal.rngom.digested.DPatternWalker;
+import com.sun.xml.internal.rngom.digested.DRefPattern;
+import com.sun.xml.internal.rngom.digested.DZeroOrMorePattern;
+
+/**
+ * Fumigate the named patterns that can be bound to inheritance.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class TypePatternBinder extends DPatternWalker {
+    private boolean canInherit;
+    private final Stack<Boolean> stack = new Stack<Boolean>();
+
+    /**
+     * Patterns that are determined not to be bindable to inheritance.
+     */
+    private final Set<DDefine> cannotBeInherited = new HashSet<DDefine>();
+
+
+    void reset() {
+        canInherit = true;
+        stack.clear();
+    }
+
+    public Void onRef(DRefPattern p) {
+        if(!canInherit) {
+            cannotBeInherited.add(p.getTarget());
+        } else {
+            // if the whole pattern is like "A,B", we can only inherit from
+            // either A or B. For now, always derive from A.
+            // it might be worthwhile to have a smarter binding logic where
+            // we pick A and B based on their 'usefulness' --- by taking into
+            // account how many other paterns are derived from those.
+            canInherit = false;
+        }
+        return null;
+    }
+
+    /*
+        Set the flag to false if we hit a pattern that cannot include
+        a <ref> to be bound as an inheritance.
+
+        All the following code are the same
+    */
+    public Void onChoice(DChoicePattern p) {
+        push(false);
+        super.onChoice(p);
+        pop();
+        return null;
+    }
+
+    public Void onAttribute(DAttributePattern p) {
+        push(false);
+        super.onAttribute(p);
+        pop();
+        return null;
+    }
+
+    public Void onList(DListPattern p) {
+        push(false);
+        super.onList(p);
+        pop();
+        return null;
+    }
+
+    public Void onMixed(DMixedPattern p) {
+        push(false);
+        super.onMixed(p);
+        pop();
+        return null;
+    }
+
+    public Void onOneOrMore(DOneOrMorePattern p) {
+        push(false);
+        super.onOneOrMore(p);
+        pop();
+        return null;
+    }
+
+    public Void onZeroOrMore(DZeroOrMorePattern p) {
+        push(false);
+        super.onZeroOrMore(p);
+        pop();
+        return null;
+    }
+
+    public Void onOptional(DOptionalPattern p) {
+        push(false);
+        super.onOptional(p);
+        pop();
+        return null;
+    }
+
+    private void push(boolean v) {
+        stack.push(canInherit);
+        canInherit = v;
+    }
+
+    private void pop() {
+        canInherit = stack.pop();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/TypeUseBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/TypeUseBinder.java
new file mode 100644
index 0000000..8ab880d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/relaxng/TypeUseBinder.java
@@ -0,0 +1,172 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.relaxng;
+
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.model.TypeUseFactory;
+
+import com.sun.xml.internal.rngom.digested.DAttributePattern;
+import com.sun.xml.internal.rngom.digested.DChoicePattern;
+import com.sun.xml.internal.rngom.digested.DContainerPattern;
+import com.sun.xml.internal.rngom.digested.DDataPattern;
+import com.sun.xml.internal.rngom.digested.DElementPattern;
+import com.sun.xml.internal.rngom.digested.DEmptyPattern;
+import com.sun.xml.internal.rngom.digested.DGrammarPattern;
+import com.sun.xml.internal.rngom.digested.DGroupPattern;
+import com.sun.xml.internal.rngom.digested.DInterleavePattern;
+import com.sun.xml.internal.rngom.digested.DListPattern;
+import com.sun.xml.internal.rngom.digested.DMixedPattern;
+import com.sun.xml.internal.rngom.digested.DNotAllowedPattern;
+import com.sun.xml.internal.rngom.digested.DOneOrMorePattern;
+import com.sun.xml.internal.rngom.digested.DOptionalPattern;
+import com.sun.xml.internal.rngom.digested.DPattern;
+import com.sun.xml.internal.rngom.digested.DPatternVisitor;
+import com.sun.xml.internal.rngom.digested.DRefPattern;
+import com.sun.xml.internal.rngom.digested.DTextPattern;
+import com.sun.xml.internal.rngom.digested.DValuePattern;
+import com.sun.xml.internal.rngom.digested.DZeroOrMorePattern;
+
+/**
+ * Walks the pattern tree and binds it to a {@link TypeUse}.
+ *
+ * The singleton instance is kept in {@link RELAXNGCompiler}.
+ *
+ * TODO: I should really normalize before process.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class TypeUseBinder implements DPatternVisitor<TypeUse> {
+    private final RELAXNGCompiler compiler;
+
+    public TypeUseBinder(RELAXNGCompiler compiler) {
+        this.compiler = compiler;
+    }
+
+
+    public TypeUse onGrammar(DGrammarPattern p) {
+        return CBuiltinLeafInfo.STRING;
+    }
+
+    public TypeUse onChoice(DChoicePattern p) {
+        // can't support unions
+        return CBuiltinLeafInfo.STRING;
+    }
+
+    public TypeUse onData(DDataPattern p) {
+        return onDataType(p.getDatatypeLibrary(), p.getType());
+    }
+
+    public TypeUse onValue(DValuePattern p) {
+        return onDataType(p.getDatatypeLibrary(),p.getType());
+    }
+
+    private TypeUse onDataType(String datatypeLibrary, String type) {
+        DatatypeLib lib = compiler.datatypes.get(datatypeLibrary);
+        if(lib!=null) {
+            TypeUse use = lib.get(type);
+            if(use!=null)
+                return use;
+        }
+
+        // unknown
+        return CBuiltinLeafInfo.STRING;
+    }
+
+    public TypeUse onInterleave(DInterleavePattern p) {
+        return onContainer(p);
+    }
+
+    public TypeUse onGroup(DGroupPattern p) {
+        return onContainer(p);
+    }
+
+    private TypeUse onContainer(DContainerPattern p) {
+        TypeUse t=null;
+        for( DPattern child : p ) {
+            TypeUse s = child.accept(this);
+            if(t!=null && t!=s)
+                return CBuiltinLeafInfo.STRING; // heterogenous
+            t = s;
+        }
+        return t;
+    }
+
+    public TypeUse onNotAllowed(DNotAllowedPattern p) {
+        // TODO
+        return error();
+    }
+
+    public TypeUse onEmpty(DEmptyPattern p) {
+        return CBuiltinLeafInfo.STRING;
+    }
+
+    public TypeUse onList(DListPattern p) {
+        return p.getChild().accept(this);
+    }
+
+    public TypeUse onOneOrMore(DOneOrMorePattern p) {
+        return TypeUseFactory.makeCollection( p.getChild().accept(this) );
+    }
+
+    public TypeUse onZeroOrMore(DZeroOrMorePattern p) {
+        return TypeUseFactory.makeCollection( p.getChild().accept(this) );
+    }
+
+    public TypeUse onOptional(DOptionalPattern p) {
+        return CBuiltinLeafInfo.STRING;
+    }
+
+    public TypeUse onRef(DRefPattern p) {
+        // TODO: check for enums
+        return p.getTarget().getPattern().accept(this);
+    }
+
+    public TypeUse onText(DTextPattern p) {
+        return CBuiltinLeafInfo.STRING;
+    }
+
+//
+//
+// Not allowed in this context
+//
+//
+    public TypeUse onAttribute(DAttributePattern p) {
+        return error();
+    }
+
+    public TypeUse onElement(DElementPattern p) {
+        return error();
+    }
+
+    public TypeUse onMixed(DMixedPattern p) {
+        return error();
+    }
+
+    private TypeUse error() {
+        throw new IllegalStateException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/Abstractifier.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/Abstractifier.java
new file mode 100644
index 0000000..89511e5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/Abstractifier.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+
+/**
+ * {@link ClassBinder} that marks abstract components as abstract.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+class Abstractifier extends ClassBinderFilter {
+    public Abstractifier(ClassBinder core) {
+        super(core);
+    }
+
+    public CClassInfo complexType(XSComplexType xs) {
+        CClassInfo ci = (CClassInfo)super.complexType(xs);
+        if(ci!=null && xs.isAbstract())
+            ci.setAbstract();
+        return ci;
+    }
+
+    public CElement elementDecl(XSElementDecl xs) {
+        CElement ci = super.elementDecl(xs);
+        if(ci!=null && xs.isAbstract())
+            ci.setAbstract();
+        return ci;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BGMBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BGMBuilder.java
new file mode 100644
index 0000000..f3c2f3f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BGMBuilder.java
@@ -0,0 +1,506 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.bind.DatatypeConverter;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerConfigurationException;
+import javax.xml.transform.TransformerFactory;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.fmt.JTextFile;
+import com.sun.istack.internal.NotNull;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRendererFactory;
+import com.sun.tools.internal.xjc.model.CClassInfoParent;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.reader.ModelChecker;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIDeclaration;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIDom;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIGlobalBinding;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BISchemaBinding;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BISerializable;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BindInfo;
+import com.sun.tools.internal.xjc.util.CodeModelClassFactory;
+import com.sun.tools.internal.xjc.util.ErrorReceiverFilter;
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.util.XSFinder;
+
+import org.xml.sax.Locator;
+
+/**
+ * Root of the XML Schema binder.
+ *
+ * <div><img src="doc-files/binding_chart.png"/></div>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class BGMBuilder extends BindingComponent {
+
+    /**
+     * Entry point.
+     */
+    public static Model build( XSSchemaSet _schemas, JCodeModel codeModel,
+            ErrorReceiver _errorReceiver, Options opts ) {
+        // set up a ring
+        final Ring old = Ring.begin();
+        try {
+            ErrorReceiverFilter ef = new ErrorReceiverFilter(_errorReceiver);
+
+            Ring.add(XSSchemaSet.class,_schemas);
+            Ring.add(codeModel);
+            Model model = new Model(opts, codeModel, null/*set later*/, opts.classNameAllocator);
+            Ring.add(model);
+            Ring.add(ErrorReceiver.class,ef);
+            Ring.add(CodeModelClassFactory.class,new CodeModelClassFactory(ef));
+
+            BGMBuilder builder = new BGMBuilder(opts.defaultPackage,opts.defaultPackage2,
+                opts.compatibilityMode==Options.EXTENSION,opts.getFieldRendererFactory());
+            builder._build();
+
+            if(ef.hadError())   return null;
+            else                return model;
+        } finally {
+            Ring.end(old);
+        }
+    }
+
+
+    /**
+     * True if the compiler is running in the extension mode
+     * (as opposed to the strict conformance mode.)
+     */
+    public final boolean inExtensionMode;
+
+    /**
+     * If this is non-null, this package name takes over
+     * all the schema customizations.
+     */
+    public final String defaultPackage1;
+
+    /**
+     * If this is non-null, this package name will be
+     * used when no customization is specified.
+     */
+    public final String defaultPackage2;
+
+    private final BindGreen green = Ring.get(BindGreen.class);
+    private final BindPurple purple = Ring.get(BindPurple.class);
+
+    public final Model model = Ring.get(Model.class);
+
+    public final FieldRendererFactory fieldRendererFactory;
+
+    /**
+     * Lazily computed {@link RefererFinder}.
+     *
+     * @see #getReferer
+     */
+    private RefererFinder refFinder;
+
+
+
+
+    protected BGMBuilder(String defaultPackage1, String defaultPackage2, boolean _inExtensionMode, FieldRendererFactory fieldRendererFactory) {
+        this.inExtensionMode = _inExtensionMode;
+        this.defaultPackage1 = defaultPackage1;
+        this.defaultPackage2 = defaultPackage2;
+        this.fieldRendererFactory = fieldRendererFactory;
+
+        DatatypeConverter.setDatatypeConverter(DatatypeConverterImpl.theInstance);
+
+        promoteGlobalBindings();
+    }
+
+
+
+
+    private void _build() {
+        // do the binding
+        buildContents();
+        getClassSelector().executeTasks();
+
+        // additional error check
+        // Reports unused customizations to the user as errors.
+        Ring.get(UnusedCustomizationChecker.class).run();
+
+        Ring.get(ModelChecker.class).check();
+    }
+
+
+    /** List up all the global bindings. */
+    private void promoteGlobalBindings() {
+        // promote any global bindings in the schema
+        XSSchemaSet schemas = Ring.get(XSSchemaSet.class);
+
+        for( XSSchema s : schemas.getSchemas() ) {
+            BindInfo bi = getBindInfo(s);
+
+            BIGlobalBinding gb = bi.get(BIGlobalBinding.class);
+            if(gb==null)
+                continue;
+
+            if(globalBinding==null) {
+                globalBinding = gb;
+                globalBinding.markAsAcknowledged();
+            } else {
+                // acknowledge this customization and report an error
+                // otherwise the user will see "customization is attached to a wrong place" error,
+                // which is incorrect
+                gb.markAsAcknowledged();
+                getErrorReporter().error( gb.getLocation(),
+                    Messages.ERR_MULTIPLE_GLOBAL_BINDINGS);
+                getErrorReporter().error( globalBinding.getLocation(),
+                    Messages.ERR_MULTIPLE_GLOBAL_BINDINGS_OTHER);
+            }
+        }
+
+        if( globalBinding==null ) {
+            // no global customization is present.
+            // use the default one
+            globalBinding = new BIGlobalBinding();
+            BindInfo big = new BindInfo();
+            big.addDecl(globalBinding);
+            big.setOwner(this,null);
+        }
+
+        // code generation mode
+        model.strategy = globalBinding.getCodeGenerationStrategy();
+        model.rootClass = globalBinding.getSuperClass();
+        model.rootInterface = globalBinding.getSuperInterface();
+
+        particleBinder = globalBinding.isSimpleMode() ? new ExpressionParticleBinder() : new DefaultParticleBinder();
+
+        // check XJC extensions and realize them
+        BISerializable serial = globalBinding.getSerializable();
+        if(serial!=null) {
+            model.serializable = true;
+            model.serialVersionUID = serial.uid;
+        }
+
+        // obtain the name conversion mode
+        if(globalBinding.nameConverter!=null)
+            model.setNameConverter(globalBinding.nameConverter);
+
+        // attach global conversions to the appropriate simple types
+        globalBinding.dispatchGlobalConversions(schemas);
+
+        globalBinding.errorCheck();
+    }
+
+    /**
+     * Global bindings.
+     *
+     * The empty global binding is set as the default, so that
+     * there will be no need to test if the value is null.
+     */
+    private BIGlobalBinding globalBinding;
+
+    /**
+     * Gets the global bindings.
+     */
+    public @NotNull BIGlobalBinding getGlobalBinding() { return globalBinding; }
+
+
+    private ParticleBinder particleBinder;
+
+    /**
+     * Gets the particle binder for this binding.
+     */
+    public @NotNull ParticleBinder getParticleBinder() { return particleBinder; }
+
+
+    /**
+     * Name converter that implements "XML->Java name conversion"
+     * as specified in the spec.
+     *
+     * This object abstracts the detail that we use different name
+     * conversion depending on the customization.
+     *
+     * <p>
+     * This object should be used to perform any name conversion
+     * needs, instead of the JJavaName class in CodeModel.
+     */
+    public NameConverter getNameConverter() { return model.getNameConverter(); }
+
+
+
+
+
+    /** Fill-in the contents of each classes. */
+    private void buildContents() {
+        ClassSelector cs = getClassSelector();
+        SimpleTypeBuilder stb = Ring.get(SimpleTypeBuilder.class);
+
+        for( XSSchema s : Ring.get(XSSchemaSet.class).getSchemas() ) {
+            getClassSelector().pushClassScope( new CClassInfoParent.Package(
+                getClassSelector().getPackage(s.getTargetNamespace())) );
+
+            if(!s.getTargetNamespace().equals(WellKnownNamespace.XML_SCHEMA)) {
+                checkMultipleSchemaBindings(s);
+                processPackageJavadoc(s);
+                populate(s.getAttGroupDecls());
+                populate(s.getAttributeDecls());
+                populate(s.getElementDecls());
+                populate(s.getModelGroupDecls());
+            }
+
+            // fill in typeUses
+            for (XSType t : s.getTypes().values()) {
+                stb.refererStack.push(t);
+                model.typeUses().put( new QName(t.getTargetNamespace(),t.getName()), cs.bindToType(t) );
+                stb.refererStack.pop();
+            }
+
+            getClassSelector().popClassScope();
+        }
+    }
+
+    /** Reports an error if there are more than one jaxb:schemaBindings customization. */
+    private void checkMultipleSchemaBindings( XSSchema schema ) {
+        ArrayList<Locator> locations = new ArrayList<Locator>();
+
+        BindInfo bi = getBindInfo(schema);
+        for( BIDeclaration bid : bi ) {
+            if( bid.getName()==BISchemaBinding.NAME )
+                locations.add( bid.getLocation() );
+        }
+        if(locations.size()<=1)    return; // OK
+
+        // error
+        getErrorReporter().error( locations.get(0),
+            Messages.ERR_MULTIPLE_SCHEMA_BINDINGS,
+            schema.getTargetNamespace() );
+        for( int i=1; i<locations.size(); i++ )
+            getErrorReporter().error( (Locator)locations.get(i),
+                Messages.ERR_MULTIPLE_SCHEMA_BINDINGS_LOCATION);
+    }
+
+    /**
+     * Calls {@link ClassSelector} for each item in the iterator
+     * to populate class items if there is any.
+     */
+    private void populate( Map<String,? extends XSComponent> col ) {
+        ClassSelector cs = getClassSelector();
+        for( XSComponent sc : col.values() )
+            cs.bindToType(sc);
+    }
+
+    /**
+     * Generates <code>package.html</code> if the customization
+     * says so.
+     */
+    private void processPackageJavadoc( XSSchema s ) {
+        // look for the schema-wide customization
+        BISchemaBinding cust = getBindInfo(s).get(BISchemaBinding.class);
+        if(cust==null)      return; // not present
+
+        cust.markAsAcknowledged();
+        if( cust.getJavadoc()==null )   return;     // no javadoc customization
+
+        // produce a HTML file
+        JTextFile html = new JTextFile("package.html");
+        html.setContents(cust.getJavadoc());
+        getClassSelector().getPackage(s.getTargetNamespace()).addResourceFile(html);
+    }
+
+
+
+
+
+
+    /**
+     * Gets or creates the BindInfo object associated to a schema component.
+     *
+     * @return
+     *      Always return a non-null valid BindInfo object.
+     *      Even if no declaration was specified, this method creates
+     *      a new BindInfo so that new decls can be added.
+     */
+    public BindInfo getOrCreateBindInfo( XSComponent schemaComponent ) {
+
+        BindInfo bi = _getBindInfoReadOnly(schemaComponent);
+        if(bi!=null)    return bi;
+
+        // XSOM is read-only, so we cannot add new annotations.
+        // for components that didn't have annotations,
+        // we maintain an external map.
+        bi = new BindInfo();
+        bi.setOwner(this,schemaComponent);
+        externalBindInfos.put(schemaComponent,bi);
+        return bi;
+    }
+
+
+    /**
+     * Used as a constant instance to represent the empty {@link BindInfo}.
+     */
+    private final BindInfo emptyBindInfo = new BindInfo();
+
+    /**
+     * Gets the BindInfo object associated to a schema component.
+     *
+     * @return
+     *      always return a valid {@link BindInfo} object. If none
+     *      is specified for the given component, a dummy empty BindInfo
+     *      will be returned.
+     */
+    public BindInfo getBindInfo( XSComponent schemaComponent ) {
+        BindInfo bi = _getBindInfoReadOnly(schemaComponent);
+        if(bi!=null)    return bi;
+        else            return emptyBindInfo;
+    }
+
+    /**
+     * Gets the BindInfo object associated to a schema component.
+     *
+     * @return
+     *      null if no bind info is associated to this schema component.
+     */
+    private BindInfo _getBindInfoReadOnly( XSComponent schemaComponent ) {
+
+        BindInfo bi = externalBindInfos.get(schemaComponent);
+        if(bi!=null)    return bi;
+
+        XSAnnotation annon = schemaComponent.getAnnotation();
+        if(annon!=null) {
+            bi = (BindInfo)annon.getAnnotation();
+            if(bi!=null) {
+                if(bi.getOwner()==null)
+                    bi.setOwner(this,schemaComponent);
+                return bi;
+            }
+        }
+
+        return null;
+    }
+
+    /**
+     * A map that stores binding declarations augmented by XJC.
+     */
+    private final Map<XSComponent,BindInfo> externalBindInfos = new HashMap<XSComponent,BindInfo>();
+
+    /**
+     * Gets the {@link BIDom} object that applies to the given particle.
+     */
+    protected final BIDom getLocalDomCustomization( XSParticle p ) {
+        BIDom dom = getBindInfo(p).get(BIDom.class);
+        if(dom!=null)  return dom;
+
+        // if not, the term might have one.
+        dom = getBindInfo(p.getTerm()).get(BIDom.class);
+        if(dom!=null)  return dom;
+
+        XSTerm t = p.getTerm();
+        // type could also have one, in case of the dom customization
+        if(t.isElementDecl())
+            return getBindInfo(t.asElementDecl().getType()).get(BIDom.class);
+        // similarly the model group in a model group definition may have one.
+        if(t.isModelGroupDecl())
+            return getBindInfo(t.asModelGroupDecl().getModelGroup()).get(BIDom.class);
+
+        return null;
+    }
+
+    /**
+     * Returns true if the component should be processed by purple.
+     */
+    private final XSFinder toPurple = new XSFinder() {
+        public Boolean attributeUse(XSAttributeUse use) {
+            // attribute use always maps to a property
+            return true;
+        }
+
+        public Boolean simpleType(XSSimpleType xsSimpleType) {
+            // simple type always maps to a type, hence we should take purple
+            return true;
+        }
+
+        public Boolean wildcard(XSWildcard xsWildcard) {
+            // attribute wildcards always maps to a property.
+            // element wildcards should have been processed with particle binders
+            return true;
+        }
+    };
+    /**
+     * If the component maps to a property, forwards to purple, otherwise to green.
+     *
+     * If the component is mapped to a type, this method needs to return true.
+     * See the chart at the class javadoc.
+     */
+    public void ying( XSComponent sc ) {
+        if(sc.apply(toPurple)==true || getClassSelector().bindToType(sc)!=null)
+            sc.visit(purple);
+        else
+            sc.visit(green);
+    }
+
+    private Transformer identityTransformer;
+
+    /**
+     * Gets the shared instance of the identity transformer.
+     */
+    public Transformer getIdentityTransformer() {
+        try {
+            if(identityTransformer==null)
+                identityTransformer = TransformerFactory.newInstance().newTransformer();
+            return identityTransformer;
+        } catch (TransformerConfigurationException e) {
+            throw new Error(e); // impossible
+        }
+    }
+
+    /**
+     * Find all types that refer to the given complex type.
+     */
+    public Set<XSComponent> getReferer(XSType c) {
+        if(refFinder==null) {
+            refFinder = new RefererFinder();
+            refFinder.schemaSet(Ring.get(XSSchemaSet.class));
+        }
+        return refFinder.getReferer(c);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindBlue.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindBlue.java
new file mode 100644
index 0000000..67792a9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindBlue.java
@@ -0,0 +1,107 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+
+/**
+ * This is the first color invoked from the parent component.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class BindBlue extends ColorBinder {
+
+    public void complexType(XSComplexType ct) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void elementDecl(XSElementDecl e) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+
+
+
+    public void wildcard(XSWildcard xsWildcard) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void attGroupDecl(XSAttGroupDecl xsAttGroupDecl) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void attributeDecl(XSAttributeDecl xsAttributeDecl) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void attributeUse(XSAttributeUse use) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void modelGroupDecl(XSModelGroupDecl xsModelGroupDecl) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void modelGroup(XSModelGroup xsModelGroup) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void particle(XSParticle xsParticle) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void empty(XSContentType xsContentType) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+
+/**
+ * Components that always map to a type
+ */
+    public void simpleType(XSSimpleType type) {
+        throw new IllegalStateException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindGreen.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindGreen.java
new file mode 100644
index 0000000..1cc5f14
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindGreen.java
@@ -0,0 +1,131 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.Iterator;
+
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.ct.ComplexTypeFieldBuilder;
+import com.sun.xml.internal.xsom.XSAttContainer;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public final class BindGreen extends ColorBinder {
+
+    private final ComplexTypeFieldBuilder ctBuilder = Ring.get(ComplexTypeFieldBuilder.class);
+
+    public void attGroupDecl(XSAttGroupDecl ag) {
+        attContainer(ag);
+    }
+
+    public void attContainer(XSAttContainer cont) {
+        // inline
+        Iterator itr = cont.iterateDeclaredAttributeUses();
+        while(itr.hasNext())
+            builder.ying((XSAttributeUse)itr.next());
+        itr = cont.iterateAttGroups();
+        while(itr.hasNext())
+            builder.ying((XSAttGroupDecl)itr.next());
+
+        XSWildcard w = cont.getAttributeWildcard();
+        if(w!=null)
+            builder.ying(w);
+    }
+
+    public void complexType(XSComplexType ct) {
+        ctBuilder.build(ct);
+    }
+
+
+
+
+
+
+
+
+    public void attributeDecl(XSAttributeDecl xsAttributeDecl) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void wildcard(XSWildcard xsWildcard) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void modelGroupDecl(XSModelGroupDecl xsModelGroupDecl) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void modelGroup(XSModelGroup xsModelGroup) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void elementDecl(XSElementDecl xsElementDecl) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void particle(XSParticle xsParticle) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void empty(XSContentType xsContentType) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+
+/*
+
+    Components for which ying should yield to purple.
+
+*/
+    public void simpleType(XSSimpleType xsSimpleType) {
+        // simple type always maps to a type, so this is never possible
+        throw new IllegalStateException();
+    }
+
+    public void attributeUse(XSAttributeUse use) {
+        // attribute use always maps to a property
+        throw new IllegalStateException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindPurple.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindPurple.java
new file mode 100644
index 0000000..4ad103f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindPurple.java
@@ -0,0 +1,147 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CDefaultValue;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class BindPurple extends ColorBinder {
+    public void attGroupDecl(XSAttGroupDecl xsAttGroupDecl) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void attributeDecl(XSAttributeDecl xsAttributeDecl) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * Attribute use always becomes a property.
+     */
+    public void attributeUse(XSAttributeUse use) {
+        boolean hasFixedValue = use.getFixedValue()!=null;
+        BIProperty pc = BIProperty.getCustomization(use);
+
+        // map to a constant property ?
+        boolean toConstant = pc.isConstantProperty() && hasFixedValue;
+        TypeUse attType = bindAttDecl(use.getDecl());
+
+        CPropertyInfo prop = pc.createAttributeProperty( use, attType );
+
+        if(toConstant) {
+            prop.defaultValue = CDefaultValue.create(attType,use.getFixedValue());
+            prop.realization = builder.fieldRendererFactory.getConst(prop.realization);
+        } else
+        if(!attType.isCollection()) {
+            // don't support a collection default value. That's difficult to do.
+
+            if(use.getDefaultValue()!=null) {
+                // this attribute use has a default value.
+                // the item type is guaranteed to be a leaf type... or TODO: is it really so?
+                // don't support default values if it's a list
+                prop.defaultValue = CDefaultValue.create(attType,use.getDefaultValue());
+            } else
+            if(use.getFixedValue()!=null) {
+                prop.defaultValue = CDefaultValue.create(attType,use.getFixedValue());
+            }
+        }
+
+        getCurrentBean().addProperty(prop);
+    }
+
+    private TypeUse bindAttDecl(XSAttributeDecl decl) {
+        SimpleTypeBuilder stb = Ring.get(SimpleTypeBuilder.class);
+        stb.refererStack.push( decl );
+        try {
+            return stb.build(decl.getType());
+        } finally {
+            stb.refererStack.pop();
+        }
+    }
+
+
+    public void complexType(XSComplexType ct) {
+        CClassInfo ctBean = selector.bindToType(ct, false);
+        if(getCurrentBean()!=ctBean)
+            // in some case complex type and element binds to the same class
+            // don't make it has-a. Just make it is-a.
+            getCurrentBean().setBaseClass(ctBean);
+    }
+
+    public void wildcard(XSWildcard xsWildcard) {
+        // element wildcards are processed by particle binders,
+        // so this one is for attribute wildcard.
+
+        getCurrentBean().hasAttributeWildcard(true);
+    }
+
+    public void modelGroupDecl(XSModelGroupDecl xsModelGroupDecl) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void modelGroup(XSModelGroup xsModelGroup) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void elementDecl(XSElementDecl xsElementDecl) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void simpleType(XSSimpleType type) {
+        createSimpleTypeProperty(type,"Value");
+    }
+
+    public void particle(XSParticle xsParticle) {
+        // TODO
+        throw new UnsupportedOperationException();
+    }
+
+    public void empty(XSContentType ct) {
+        // empty generates nothing
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindRed.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindRed.java
new file mode 100644
index 0000000..fc92e31
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindRed.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.ct.ComplexTypeFieldBuilder;
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+
+/**
+ * This is where a binding of a new class starts.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class BindRed extends ColorBinder {
+
+    private final ComplexTypeFieldBuilder ctBuilder = Ring.get(ComplexTypeFieldBuilder.class);
+
+
+
+
+
+
+
+
+
+
+    public void complexType(XSComplexType ct) {
+        ctBuilder.build(ct);
+    }
+
+
+
+    public void wildcard(XSWildcard xsWildcard) {
+        // TODO: implement this method later
+        // I guess we might allow this to be mapped to a generic element property ---
+        // not sure exactly how do we do it.
+        TODO.checkSpec();
+        throw new UnsupportedOperationException();
+    }
+
+    public void elementDecl(XSElementDecl e) {
+        SimpleTypeBuilder stb = Ring.get(SimpleTypeBuilder.class);
+        stb.refererStack.push(e);    // referer is element
+        builder.ying(e.getType());
+        stb.refererStack.pop();
+    }
+
+    public void simpleType(XSSimpleType type) {
+        SimpleTypeBuilder stb = Ring.get(SimpleTypeBuilder.class);
+        stb.refererStack.push(type);    // referer is itself
+        createSimpleTypeProperty(type,"Value");
+        stb.refererStack.pop();
+    }
+
+
+
+/*
+    Components that can never be mapped to a class
+*/
+    public void attGroupDecl(XSAttGroupDecl ag) {
+        throw new IllegalStateException();
+    }
+    public void attributeDecl(XSAttributeDecl ad) {
+        throw new IllegalStateException();
+    }
+    public void attributeUse(XSAttributeUse au) {
+        throw new IllegalStateException();
+    }
+    public void empty(XSContentType xsContentType) {
+        throw new IllegalStateException();
+    }
+    public void modelGroupDecl(XSModelGroupDecl xsModelGroupDecl) {
+        throw new IllegalStateException();
+    }
+    public void modelGroup(XSModelGroup xsModelGroup) {
+        throw new IllegalStateException();
+    }
+    public void particle(XSParticle p) {
+        throw new IllegalStateException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindYellow.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindYellow.java
new file mode 100644
index 0000000..9fc9a75
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindYellow.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public final class BindYellow extends ColorBinder {
+    public void complexType(XSComplexType ct) {
+    }
+
+    public void wildcard(XSWildcard xsWildcard) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void elementDecl(XSElementDecl xsElementDecl) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void simpleType(XSSimpleType xsSimpleType) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+    public void attributeDecl(XSAttributeDecl xsAttributeDecl) {
+        // TODO: implement this method later
+        throw new UnsupportedOperationException();
+    }
+
+
+/*
+
+    Components that can never map to a type
+
+*/
+    public void attGroupDecl(XSAttGroupDecl xsAttGroupDecl) {
+        throw new IllegalStateException();
+    }
+
+    public void attributeUse(XSAttributeUse use) {
+        throw new IllegalStateException();
+    }
+
+    public void modelGroupDecl(XSModelGroupDecl xsModelGroupDecl) {
+        throw new IllegalStateException();
+    }
+
+    public void modelGroup(XSModelGroup xsModelGroup) {
+        throw new IllegalStateException();
+    }
+
+    public void particle(XSParticle xsParticle) {
+        throw new IllegalStateException();
+    }
+
+    public void empty(XSContentType xsContentType) {
+        throw new IllegalStateException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindingComponent.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindingComponent.java
new file mode 100644
index 0000000..a884527
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/BindingComponent.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.reader.Ring;
+
+/**
+ * Component accessible from {@link Ring}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class BindingComponent {
+    protected BindingComponent() {
+        Ring.add(this);
+    }
+
+//
+//
+// Accessor to common components.
+//
+//
+
+    protected final ErrorReporter getErrorReporter() {
+        return Ring.get(ErrorReporter.class);
+    }
+    protected final ClassSelector getClassSelector() {
+        return Ring.get(ClassSelector.class);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassBinder.java
new file mode 100644
index 0000000..391d191
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassBinder.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+
+/**
+ * Marker interface for an object that determines how to map
+ * a component to a class. If a component is mapped to a class,
+ * this object returns a {@link CClassInfo} pr {@link CElementInfo} object.
+ *
+ * Otherwise, return null.
+ */
+interface ClassBinder extends XSFunction<CElement> {
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassBinderFilter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassBinderFilter.java
new file mode 100644
index 0000000..abe2ac3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassBinderFilter.java
@@ -0,0 +1,126 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSXPath;
+
+/**
+ * {@link ClassBinder} that delegates the call to another {@link ClassBinder}.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+abstract class ClassBinderFilter implements ClassBinder {
+    private final ClassBinder core;
+
+    protected ClassBinderFilter(ClassBinder core) {
+        this.core = core;
+    }
+
+    public CElement annotation(XSAnnotation xsAnnotation) {
+        return core.annotation(xsAnnotation);
+    }
+
+    public CElement attGroupDecl(XSAttGroupDecl xsAttGroupDecl) {
+        return core.attGroupDecl(xsAttGroupDecl);
+    }
+
+    public CElement attributeDecl(XSAttributeDecl xsAttributeDecl) {
+        return core.attributeDecl(xsAttributeDecl);
+    }
+
+    public CElement attributeUse(XSAttributeUse xsAttributeUse) {
+        return core.attributeUse(xsAttributeUse);
+    }
+
+    public CElement complexType(XSComplexType xsComplexType) {
+        return core.complexType(xsComplexType);
+    }
+
+    public CElement schema(XSSchema xsSchema) {
+        return core.schema(xsSchema);
+    }
+
+    public CElement facet(XSFacet xsFacet) {
+        return core.facet(xsFacet);
+    }
+
+    public CElement notation(XSNotation xsNotation) {
+        return core.notation(xsNotation);
+    }
+
+    public CElement simpleType(XSSimpleType xsSimpleType) {
+        return core.simpleType(xsSimpleType);
+    }
+
+    public CElement particle(XSParticle xsParticle) {
+        return core.particle(xsParticle);
+    }
+
+    public CElement empty(XSContentType xsContentType) {
+        return core.empty(xsContentType);
+    }
+
+    public CElement wildcard(XSWildcard xsWildcard) {
+        return core.wildcard(xsWildcard);
+    }
+
+    public CElement modelGroupDecl(XSModelGroupDecl xsModelGroupDecl) {
+        return core.modelGroupDecl(xsModelGroupDecl);
+    }
+
+    public CElement modelGroup(XSModelGroup xsModelGroup) {
+        return core.modelGroup(xsModelGroup);
+    }
+
+    public CElement elementDecl(XSElementDecl xsElementDecl) {
+        return core.elementDecl(xsElementDecl);
+    }
+
+    public CElement identityConstraint(XSIdentityConstraint xsIdentityConstraint) {
+        return core.identityConstraint(xsIdentityConstraint);
+    }
+
+    public CElement xpath(XSXPath xsxPath) {
+        return core.xpath(xsxPath);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassSelector.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassSelector.java
new file mode 100644
index 0000000..de268d6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ClassSelector.java
@@ -0,0 +1,466 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.io.StringWriter;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+import java.util.Stack;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JJavaName;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.util.JavadocEscapeWriter;
+import com.sun.istack.internal.NotNull;
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CClassInfoParent;
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CTypeInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BISchemaBinding;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.LocalScoping;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSDeclaration;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.impl.util.SchemaWriter;
+import com.sun.xml.internal.xsom.util.ComponentNameFunction;
+
+import org.xml.sax.Locator;
+
+/**
+ * Manages association between XSComponents and generated
+ * content interfaces.
+ *
+ * <p>
+ * All the content interfaces are created, registered, and
+ * maintained in this class.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class ClassSelector extends BindingComponent {
+    /** Center of owner classes. */
+    private final BGMBuilder builder = Ring.get(BGMBuilder.class);
+
+
+    /**
+     * Map from XSComponents to {@link Binding}s. Keeps track of all
+     * content interfaces that are already built or being built.
+     */
+    private final Map<XSComponent,Binding> bindMap = new HashMap<XSComponent,Binding>();
+
+    /**
+     * UGLY HACK.
+     * <p>
+     * To avoid cyclic dependency between binding elements and types,
+     * we need additional markers that tell which elements are definitely not bound
+     * to a class.
+     * <p>
+     * the cyclic dependency is as follows:
+     * elements need to bind its types first, because otherwise it can't
+     * determine T of JAXBElement<T>.
+     * OTOH, types need to know whether its parent is bound to a class to decide
+     * which class name to use.
+     */
+    /*package*/ final Map<XSComponent,CElementInfo> boundElements = new HashMap<XSComponent,CElementInfo>();
+
+    /**
+     * A list of {@link Binding}s object that needs to be built.
+     */
+    private final Stack<Binding> bindQueue = new Stack<Binding>();
+
+    /**
+     * {@link CClassInfo}s that are already {@link Binding#build() built}.
+     */
+    private final Set<CClassInfo> built = new HashSet<CClassInfo>();
+
+    /**
+     * Object that determines components that are mapped
+     * to classes.
+     */
+    private final ClassBinder classBinder;
+
+    /**
+     * {@link CClassInfoParent}s that determines where a new class
+     * should be created.
+     */
+    private final Stack<CClassInfoParent> classScopes = new Stack<CClassInfoParent>();
+
+    /**
+     * The component that is being bound to {@link #currentBean}.
+     */
+    private XSComponent currentRoot;
+    /**
+     * The bean representation we are binding right now.
+     */
+    private CClassInfo currentBean;
+
+
+    private final class Binding {
+        private final XSComponent sc;
+        private final CTypeInfo bean;
+
+        public Binding(XSComponent sc, CTypeInfo bean) {
+            this.sc = sc;
+            this.bean = bean;
+        }
+
+        void build() {
+            if(!(this.bean instanceof CClassInfo))
+                return; // no need to "build"
+
+            CClassInfo bean = (CClassInfo)this.bean;
+
+            if(!built.add(bean))
+                return; // already built
+
+            for( String reservedClassName : reservedClassNames ) {
+                if( bean.getName().equals(reservedClassName) ) {
+                    getErrorReporter().error( sc.getLocator(),
+                        Messages.ERR_RESERVED_CLASS_NAME, reservedClassName );
+                    break;
+                }
+            }
+
+            // if this schema component is an element declaration
+            // and it satisfies a set of conditions specified in the spec,
+            // this class will receive a constructor.
+            if(needValueConstructor(sc)) {
+                // TODO: fragile. There is no guarantee that the property name
+                // is in fact "value".
+                bean.addConstructor("value");
+            }
+
+            if(bean.javadoc==null)
+                addSchemaFragmentJavadoc(bean,sc);
+
+            // build the body
+            if(builder.getGlobalBinding().getFlattenClasses()==LocalScoping.NESTED)
+                pushClassScope(bean);
+            else
+                pushClassScope(bean.parent());
+            XSComponent oldRoot = currentRoot;
+            CClassInfo oldBean = currentBean;
+            currentRoot = sc;
+            currentBean = bean;
+            sc.visit(Ring.get(BindRed.class));
+            currentBean = oldBean;
+            currentRoot = oldRoot;
+            popClassScope();
+
+            // acknowledge property customization on this schema component,
+            // since it is OK to have a customization at the point of declaration
+            // even when no one is using it.
+            BIProperty prop = builder.getBindInfo(sc).get(BIProperty.class);
+            if(prop!=null)  prop.markAsAcknowledged();
+        }
+    }
+
+
+    // should be instanciated only from BGMBuilder.
+    public ClassSelector() {
+        classBinder = new Abstractifier(new DefaultClassBinder());
+        Ring.add(ClassBinder.class,classBinder);
+
+        classScopes.push(null);  // so that the getClassFactory method returns null
+
+        XSComplexType anyType = Ring.get(XSSchemaSet.class).getComplexType(WellKnownNamespace.XML_SCHEMA,"anyType");
+        bindMap.put(anyType,new Binding(anyType,CBuiltinLeafInfo.ANYTYPE));
+    }
+
+    /** Gets the current class scope. */
+    public final CClassInfoParent getClassScope() {
+        assert !classScopes.isEmpty();
+        return classScopes.peek();
+    }
+
+    public final void pushClassScope( CClassInfoParent clsFctry ) {
+        assert clsFctry!=null;
+        classScopes.push(clsFctry);
+    }
+
+    public final void popClassScope() {
+        classScopes.pop();
+    }
+
+    public XSComponent getCurrentRoot() {
+        return currentRoot;
+    }
+
+    public CClassInfo getCurrentBean() {
+        return currentBean;
+    }
+
+    /**
+     * Checks if the given component is bound to a class.
+     */
+    public final CElement isBound( XSElementDecl x ) {
+        CElementInfo r = boundElements.get(x);
+        if(r!=null)
+            return r;
+        return bindToType(x);
+    }
+
+    /**
+     * Checks if the given component is being mapped to a type.
+     * If so, build that type and return that object.
+     * If it is not being mapped to a type item, return null.
+     */
+    public CTypeInfo bindToType( XSComponent sc ) {
+//        TypeToken t = domBinder.bind(sc);
+//        if(t!=null)     return t;
+//        else            return _bindToClass(sc,false);
+        return _bindToClass(sc,false);
+    }
+
+    //
+    // some schema components are guaranteed to map to a particular CTypeInfo.
+    // the following versions capture those constraints in the signature
+    // and making the bindToType invocation more type safe.
+    //
+
+    public CElement bindToType( XSElementDecl e ) {
+        return (CElement)_bindToClass(e,false);
+    }
+
+    public CClassInfo bindToType( XSComplexType t ) {
+        return bindToType(t,false);
+    }
+
+    public CClassInfo bindToType( XSComplexType t, boolean cannotBeDelayed ) {
+        // this assumption that a complex type always binds to a ClassInfo
+        // does not hold for xs:anyType --- our current approach of handling
+        // this idiosynchracy is to make sure that xs:anyType doesn't use
+        // this codepath.
+        return (CClassInfo)_bindToClass(t,cannotBeDelayed);
+    }
+
+    public TypeUse bindToType( XSType t ) {
+        if(t instanceof XSSimpleType) {
+            return Ring.get(SimpleTypeBuilder.class).build((XSSimpleType)t);
+        } else
+            return _bindToClass(t,false);
+    }
+
+    /**
+     * @param cannotBeDelayed
+     *      if the binding of the body of the class cannot be defered
+     *      and needs to be done immediately. If the flag is false,
+     *      the binding of the body will be done later, to avoid
+     *      cyclic binding problem.
+     */
+    // TODO: consider getting rid of "cannotBeDelayed"
+    CTypeInfo _bindToClass( @NotNull XSComponent sc, boolean cannotBeDelayed ) {
+        // check if this class is already built.
+        if(!bindMap.containsKey(sc)) {
+            // craete a bind task
+
+            // if this is a global declaration, make sure they will be generated
+            // under a package.
+            boolean isGlobal = false;
+            if( sc instanceof XSDeclaration ) {
+                isGlobal = ((XSDeclaration)sc).isGlobal();
+                if( isGlobal )
+                    pushClassScope( new CClassInfoParent.Package(
+                        getPackage(((XSDeclaration)sc).getTargetNamespace())) );
+            }
+
+            // otherwise check if this component should become a class.
+            CElement bean = sc.apply(classBinder);
+
+            if( isGlobal )
+                popClassScope();
+
+            if(bean==null)
+                return null;
+
+            queueBuild( sc, bean );
+        }
+
+        Binding bind = bindMap.get(sc);
+        if( cannotBeDelayed )
+            bind.build();
+
+        return bind.bean;
+    }
+
+    /**
+     * Runs all the pending build tasks.
+     */
+    public void executeTasks() {
+        while( bindQueue.size()!=0 )
+            bindQueue.pop().build();
+    }
+
+
+
+
+
+
+
+
+    /**
+     * Determines if the given component needs to have a value
+     * constructor (a constructor that takes a parmater.) on ObjectFactory.
+     */
+    private boolean needValueConstructor( XSComponent sc ) {
+        if(!(sc instanceof XSElementDecl))  return false;
+
+        XSElementDecl decl = (XSElementDecl)sc;
+        if(!decl.getType().isSimpleType())  return false;
+
+        return true;
+    }
+
+    private static final String[] reservedClassNames = new String[]{"ObjectFactory"};
+
+    public void queueBuild( XSComponent sc, CElement bean ) {
+        // it is an error if the same component is built twice,
+        // or the association is modified.
+        Binding b = new Binding(sc,bean);
+        bindQueue.push(b);
+        Binding old = bindMap.put(sc, b);
+        assert old==null || old.bean==bean;
+    }
+
+
+    /**
+     * Copies a schema fragment into the javadoc of the generated class.
+     */
+    private void addSchemaFragmentJavadoc( CClassInfo bean, XSComponent sc ) {
+
+        // first, pick it up from <documentation> if any.
+        String doc = builder.getBindInfo(sc).getDocumentation();
+        if(doc!=null)
+            append(bean, doc);
+
+        // then the description of where this component came from
+        Locator loc = sc.getLocator();
+        String fileName = null;
+        if(loc!=null) {
+            fileName = loc.getPublicId();
+            if(fileName==null)
+                fileName = loc.getSystemId();
+        }
+        if(fileName==null)  fileName="";
+
+        String lineNumber=Messages.format( Messages.JAVADOC_LINE_UNKNOWN);
+        if(loc!=null && loc.getLineNumber()!=-1)
+            lineNumber = String.valueOf(loc.getLineNumber());
+
+        String componentName = sc.apply( new ComponentNameFunction() );
+        String jdoc = Messages.format( Messages.JAVADOC_HEADING, componentName, fileName, lineNumber );
+        append(bean,jdoc);
+
+        // then schema fragment
+        StringWriter out = new StringWriter();
+        out.write("<pre>\n");
+        SchemaWriter sw = new SchemaWriter(new JavadocEscapeWriter(out));
+        sc.visit(sw);
+        out.write("</pre>");
+        append(bean,out.toString());
+    }
+
+    private void append(CClassInfo bean, String doc) {
+        if(bean.javadoc==null)
+            bean.javadoc = doc+'\n';
+        else
+            bean.javadoc += '\n'+doc+'\n';
+    }
+
+
+    /**
+     * Set of package names that are tested (set of <code>String</code>s.)
+     *
+     * This set is used to avoid duplicating "incorrect package name"
+     * errors.
+     */
+    private static Set<String> checkedPackageNames = new HashSet<String>();
+
+    /**
+     * Gets the Java package to which classes from
+     * this namespace should go.
+     *
+     * <p>
+     * Usually, the getOuterClass method should be used
+     * to determine where to put a class.
+     */
+    public JPackage getPackage(String targetNamespace) {
+        XSSchema s = Ring.get(XSSchemaSet.class).getSchema(targetNamespace);
+
+        BISchemaBinding sb =
+            builder.getBindInfo(s).get(BISchemaBinding.class);
+
+        String name = null;
+
+        // "-p" takes precedence over everything else
+        if( builder.defaultPackage1 != null )
+            name = builder.defaultPackage1;
+
+        // use the <jaxb:package> customization
+        if( name == null && sb!=null && sb.getPackageName()!=null )
+            name = sb.getPackageName();
+
+        // the JAX-RPC option goes below the <jaxb:package>
+        if( name == null && builder.defaultPackage2 != null )
+            name = builder.defaultPackage2;
+
+        // generate the package name from the targetNamespace
+        if( name == null )
+            name = builder.getNameConverter().toPackageName( targetNamespace );
+
+        // hardcode a package name because the code doesn't compile
+        // if it generated into the default java package
+        if( name == null )
+            name = "generated"; // the last resort
+
+
+        // check if the package name is a valid name.
+        if( checkedPackageNames.add(name) ) {
+            // this is the first time we hear about this package name.
+            if( !JJavaName.isJavaPackageName(name) )
+                // TODO: s.getLocator() is not very helpful.
+                // ideally, we'd like to use the locator where this package name
+                // comes from.
+                getErrorReporter().error(s.getLocator(),
+                    Messages.ERR_INCORRECT_PACKAGE_NAME, targetNamespace, name );
+        }
+
+        return Ring.get(JCodeModel.class)._package(name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/CollisionInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/CollisionInfo.java
new file mode 100644
index 0000000..958267b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/CollisionInfo.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import org.xml.sax.Locator;
+
+/**
+ * Details of a name collision.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class CollisionInfo {
+    private final String name;
+    private final Locator source1;
+    private final Locator source2;
+
+    public CollisionInfo(String name, Locator source1, Locator source2) {
+        this.name = name;
+        this.source1 = source1;
+        this.source2 = source2;
+    }
+
+    /**
+     * Returns a localized message that describes the collision.
+     */
+    public String toString() {
+        return Messages.format( Messages.MSG_COLLISION_INFO,
+                name, printLocator(source1), printLocator(source2) );
+    }
+
+    private String printLocator(Locator loc) {
+        if( loc==null )     return "";
+
+        int line = loc.getLineNumber();
+        String sysId = loc.getSystemId();
+        if(sysId==null)     sysId = Messages.format(Messages.MSG_UNKNOWN_FILE);
+
+        if( line!=-1 )
+            return Messages.format( Messages.MSG_LINE_X_OF_Y,
+                    Integer.toString(line), sysId );
+        else
+            return sysId;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ColorBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ColorBinder.java
new file mode 100644
index 0000000..efed1df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ColorBinder.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class ColorBinder extends BindingComponent implements XSVisitor {
+    protected final BGMBuilder builder = Ring.get(BGMBuilder.class);
+    protected final ClassSelector selector = getClassSelector();
+
+    protected final CClassInfo getCurrentBean() {
+        return selector.getCurrentBean();
+    }
+    protected final XSComponent getCurrentRoot() {
+        return selector.getCurrentRoot();
+    }
+
+    protected CTypeInfo boundToType(XSComponent sc) {
+        if(sc==selector.getCurrentRoot())    return null;
+        return selector.bindToType(sc);
+    }
+
+
+
+
+    protected final void createSimpleTypeProperty(XSSimpleType type,String propName) {
+        BIProperty prop = BIProperty.getCustomization(type);
+
+        SimpleTypeBuilder stb = Ring.get(SimpleTypeBuilder.class);
+        // since we are building the simple type here, use buildDef
+        CPropertyInfo p = prop.createValueProperty(propName,false,type,stb.buildDef(type));
+        getCurrentBean().addProperty(p);
+    }
+
+
+
+
+
+    public final void annotation(XSAnnotation xsAnnotation) {
+        throw new IllegalStateException();
+    }
+
+    public final void schema(XSSchema xsSchema) {
+        throw new IllegalStateException();
+    }
+
+    public final void facet(XSFacet xsFacet) {
+        throw new IllegalStateException();
+    }
+
+    public final void notation(XSNotation xsNotation) {
+        throw new IllegalStateException();
+    }
+
+    public final void identityConstraint(XSIdentityConstraint xsIdentityConstraint) {
+        throw new IllegalStateException();
+    }
+
+    public final void xpath(XSXPath xsxPath) {
+        throw new IllegalStateException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/DefaultClassBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/DefaultClassBinder.java
new file mode 100644
index 0000000..e4c722b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/DefaultClassBinder.java
@@ -0,0 +1,522 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JJavaName;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.istack.internal.NotNull;
+import com.sun.istack.internal.Nullable;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CClassInfoParent;
+import com.sun.tools.internal.xjc.model.CCustomizations;
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIClass;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIGlobalBinding;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BISchemaBinding;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BindInfo;
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSDeclaration;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSXPath;
+
+/**
+ * Default classBinder implementation. Honors &lt;jaxb:class> customizations
+ * and default bindings.
+ */
+final class DefaultClassBinder implements ClassBinder
+{
+    private final SimpleTypeBuilder stb = Ring.get(SimpleTypeBuilder.class);
+    private final Model model = Ring.get(Model.class);
+
+    protected final BGMBuilder builder = Ring.get(BGMBuilder.class);
+    protected final ClassSelector selector = Ring.get(ClassSelector.class);
+
+
+    public CElement attGroupDecl(XSAttGroupDecl decl) {
+        return allow(decl,decl.getName());
+    }
+
+    public CElement attributeDecl(XSAttributeDecl decl) {
+        return allow(decl,decl.getName());
+    }
+
+    public CElement modelGroup(XSModelGroup mgroup) {
+        return never();
+    }
+
+    public CElement modelGroupDecl(XSModelGroupDecl decl) {
+        return never();
+    }
+
+
+    public CElement complexType(XSComplexType type) {
+        CElement ci = allow(type,type.getName());
+        if(ci!=null)    return ci;
+
+        // no customization is given -- do as the default binding.
+
+        BindInfo bi = builder.getBindInfo(type);
+
+        if(type.isGlobal()) {
+            QName tagName = null;
+            String className = deriveName(type);
+            if(getGlobalBinding().isSimpleMode()) {
+                // in the simple mode, we may optimize it away
+                XSElementDecl referer = getSoleElementReferer(type);
+                if(referer!=null && isCollapsable(referer)) {
+                    // if a global element contains
+                    // a collpsable complex type, we bind this element to a named one
+                    // and collapses element and complex type.
+                    tagName = new QName(referer.getTargetNamespace(),referer.getName());
+                    className = deriveName(referer);
+                }
+            }
+
+            // by default, global ones get their own classes.
+
+            JPackage pkg = selector.getPackage(type.getTargetNamespace());
+
+            return new CClassInfo(model,pkg,className,type.getLocator(),getTypeName(type),tagName,type,bi.toCustomizationList());
+        } else {
+            XSElementDecl element = type.getScope();
+
+            if( element.isGlobal() && isCollapsable(element)) {
+                if(builder.getBindInfo(element).get(BIClass.class)!=null)
+                    // the parent element was bound to a class. Don't bind this again to
+                    // cause unnecessary wrapping
+                    return null;
+
+                // generate one class from element and complex type together.
+                // this needs to be done before selector.isBound to avoid infinite recursion.
+
+                // but avoid doing so when the element is mapped to a class,
+                // which creates unnecessary classes
+                return new CClassInfo( model, selector.getClassScope(),
+                    deriveName(element), element.getLocator(), null,
+                    new QName(element.getTargetNamespace(),element.getName()), element, bi.toCustomizationList() );
+            }
+
+
+            CElement parentType = selector.isBound(element);
+
+            String className;
+            CClassInfoParent scope;
+
+
+            if( parentType!=null
+             && parentType instanceof CElementInfo
+             && ((CElementInfo)parentType).hasClass() ) {
+                // special case where we put a nested 'Type' element
+                scope = parentType;
+                className = "Type";
+            } else {
+                // since the parent element isn't bound to a type, merge the customizations associated to it, too.
+//                custs = CCustomizations.merge( custs, builder.getBindInfo(type.getScope()).toCustomizationList());
+                className = builder.getNameConverter().toClassName(element.getName());
+
+                BISchemaBinding sb = builder.getBindInfo(
+                    type.getOwnerSchema() ).get(BISchemaBinding.class);
+                if(sb!=null)    className = sb.mangleAnonymousTypeClassName(className);
+                scope = selector.getClassScope();
+            }
+
+            return new CClassInfo(model, scope, className, type.getLocator(), null, null, type, bi.toCustomizationList() );
+        }
+    }
+
+    private QName getTypeName(XSType type) {
+        return new QName(type.getTargetNamespace(),type.getName());
+    }
+
+    private QName getTypeName(XSComplexType type) {
+        if(type.getRedefinedBy()!=null)
+            return null;
+        else
+            return getTypeName((XSType)type);
+    }
+
+    /**
+     * Returns true if the complex type of the given element can be "optimized away"
+     * and unified with its parent element decl to form a single class.
+     */
+    private boolean isCollapsable(XSElementDecl decl) {
+        XSType type = decl.getType();
+
+        if(!type.isComplexType())
+            return false;   // not a complex type
+
+        if(decl.getSubstitutables().size()>1 || decl.getSubstAffiliation()!=null)
+            // because element substitution calls for a proper JAXBElement hierarchy
+            return false;
+
+        if(decl.isNillable())
+            // because nillable needs JAXBElement to represent correctly
+            return false;
+
+        if( getGlobalBinding().isSimpleMode() && decl.isGlobal()) {
+            // in the simple mode, we do more aggressive optimization, and get rid of
+            // a complex type class if it's only used once from a global element
+            XSElementDecl referer = getSoleElementReferer(decl.getType());
+            if(referer!=null) {
+                assert referer==decl;  // I must be the sole referer
+                return true;
+            }
+        }
+
+        if(!type.isLocal() || !type.isComplexType())
+            return false;
+
+        return true;
+    }
+
+    /**
+     * If only one global {@link XSElementDecl} is refering to {@link XSType},
+     * return that element, otherwise null.
+     */
+    private @Nullable XSElementDecl getSoleElementReferer(@NotNull XSType t) {
+        Set<XSComponent> referer = builder.getReferer(t);
+
+        XSElementDecl sole = null;
+        for (XSComponent r : referer) {
+            if(r instanceof XSElementDecl) {
+                XSElementDecl x = (XSElementDecl) r;
+                if(!x.isGlobal())
+                    // local element references can be ignored, as their names are either given
+                    // by the property, or by the JAXBElement (for things like mixed contents)
+                    continue;
+                if(sole==null)  sole=x;
+                else            return null;    // more than one
+            } else {
+                // if another type refers to this type, that means
+                // this type has a sub-type, so type substitution is possible now.
+                return null;
+            }
+        }
+
+        return sole;
+    }
+
+    public CElement elementDecl(XSElementDecl decl) {
+        CElement r = allow(decl,decl.getName());
+
+        if(r==null) {
+            QName tagName = new QName(decl.getTargetNamespace(),decl.getName());
+            CCustomizations custs = builder.getBindInfo(decl).toCustomizationList();
+
+            if(decl.isGlobal()) {
+                if(isCollapsable(decl)) {
+                    // we want the returned type to be built as a complex type,
+                    // so the binding cannot be delayed.
+                    return selector.bindToType(decl.getType().asComplexType(),true);
+                } else {
+                    String className = null;
+                    if(getGlobalBinding().isGenerateElementClass())
+                        className = deriveName(decl);
+
+                    // otherwise map global elements to JAXBElement
+                    CElementInfo cei = new CElementInfo(
+                        model, tagName, selector.getClassScope(), className, custs, decl.getLocator());
+                    selector.boundElements.put(decl,cei);
+
+                    stb.refererStack.push(decl);    // referer is element
+                    cei.initContentType( selector.bindToType(decl.getType()), decl, decl.getDefaultValue() );
+                    stb.refererStack.pop();
+                    r = cei;
+                }
+            }
+        }
+
+        // have the substitution member derive from the substitution head
+        XSElementDecl top = decl.getSubstAffiliation();
+        if(top!=null) {
+            CElement topci = selector.bindToType(top);
+
+            if(r instanceof CClassInfo && topci instanceof CClassInfo)
+                ((CClassInfo)r).setBaseClass((CClassInfo)topci);
+            if (r instanceof CElementInfo && topci instanceof CElementInfo)
+                ((CElementInfo)r).setSubstitutionHead((CElementInfo)topci);
+        }
+
+        TODO.checkSpec();
+
+        return r;
+    }
+
+    public CClassInfo empty( XSContentType ct ) { return null; }
+
+    public CClassInfo identityConstraint(XSIdentityConstraint xsIdentityConstraint) {
+        return never();
+    }
+
+    public CClassInfo xpath(XSXPath xsxPath) {
+        return never();
+    }
+
+    public CClassInfo attributeUse(XSAttributeUse use) {
+        return never();
+    }
+
+    public CElement simpleType(XSSimpleType type) {
+        CElement c = allow(type,type.getName());
+        if(c!=null) return c;
+
+        if(getGlobalBinding().isSimpleTypeSubstitution() && type.isGlobal()) {
+            return new CClassInfo(model,selector.getClassScope(),
+                    deriveName(type), type.getLocator(), getTypeName(type), null, type, null );
+        }
+
+        return never();
+    }
+
+    public CClassInfo particle(XSParticle particle) {
+        return never();
+    }
+
+    public CClassInfo wildcard(XSWildcard wc) {
+        return never();
+    }
+
+
+    // these methods won't be used
+    public CClassInfo annotation(XSAnnotation annon) {
+        assert false;
+        return null;
+    }
+
+    public CClassInfo notation(XSNotation not) {
+        assert false;
+        return null;
+    }
+
+    public CClassInfo facet(XSFacet decl) {
+        assert false;
+        return null;
+    }
+    public CClassInfo schema(XSSchema schema) {
+        assert false;
+        return null;
+    }
+
+
+
+
+
+    /**
+     * Makes sure that the component doesn't carry a {@link BIClass}
+     * customization.
+     *
+     * @return
+     *      return value is unused. Since most of the caller needs to
+     *      return null, to make the code a little bit shorter, this
+     *      method always return null (so that the caller can always
+     *      say <code>return never(sc);</code>.
+     */
+    private CClassInfo never() {
+        // all we need to do here is just not to acknowledge
+        // any class customization. Then this class customization
+        // will be reported as an error later when we check all
+        // unacknowledged customizations.
+
+
+//        BIDeclaration cust=owner.getBindInfo(component).get(BIClass.NAME);
+//        if(cust!=null) {
+//            // error
+//            owner.errorReporter.error(
+//                cust.getLocation(),
+//                "test {0}", NameGetter.get(component) );
+//        }
+        return null;
+    }
+
+    /**
+     * Checks if a component carries a customization to map it to a class.
+     * If so, make it a class.
+     *
+     * @param defaultBaseName
+     *      The token which will be used as the basis of the class name
+     *      if the class name is not specified in the customization.
+     *      This is usually the name of an element declaration, and so on.
+     *
+     *      This parameter can be null, in that case it would be an error
+     *      if a name is not given by the customization.
+     */
+    private CElement allow( XSComponent component, String defaultBaseName ) {
+        BindInfo bindInfo = builder.getBindInfo(component);
+        BIClass decl=bindInfo.get(BIClass.class);
+        if(decl==null)  return null;
+
+        decl.markAsAcknowledged();
+
+        // determine the package to put this class in.
+
+        String clsName = decl.getClassName();
+        if(clsName==null) {
+            // if the customiztion doesn't give us a name, derive one
+            // from the current component.
+            if( defaultBaseName==null ) {
+                Ring.get(ErrorReceiver.class).error( decl.getLocation(),
+                    Messages.format(Messages.ERR_CLASS_NAME_IS_REQUIRED) );
+
+                // recover by generating a pseudo-random name
+                defaultBaseName = "undefined"+component.hashCode();
+            }
+            clsName = deriveName( defaultBaseName, component );
+        } else {
+            if( !JJavaName.isJavaIdentifier(clsName) ) {
+                // not a valid Java class name
+                Ring.get(ErrorReceiver.class).error( decl.getLocation(),
+                    Messages.format( Messages.ERR_INCORRECT_CLASS_NAME, clsName ));
+                // recover by a dummy name
+                clsName = "Undefined"+component.hashCode();
+            }
+        }
+
+        QName typeName = null;
+        QName elementName = null;
+
+        if(component instanceof XSType) {
+            XSType t = (XSType) component;
+            if(t.isGlobal())
+                typeName = new QName(t.getTargetNamespace(),t.getName());
+        }
+
+        if (component instanceof XSElementDecl) {
+            XSElementDecl e = (XSElementDecl) component;
+            elementName = new QName(e.getTargetNamespace(),e.getName());
+        }
+
+        if (component instanceof XSElementDecl && !isCollapsable((XSElementDecl)component)) {
+            XSElementDecl e = ((XSElementDecl)component);
+
+            CElementInfo cei = new CElementInfo(model, elementName,
+                    selector.getClassScope(), clsName,
+                    bindInfo.toCustomizationList(), decl.getLocation() );
+            selector.boundElements.put(e,cei);
+
+            stb.refererStack.push(component);    // referer is element
+            cei.initContentType(
+                selector.bindToType(e.getType()),
+                e,e.getDefaultValue());
+            stb.refererStack.pop();
+            return cei;
+            // TODO: support javadoc and userSpecifiedImplClass
+        } else {
+            CClassInfo bt = new CClassInfo(model,selector.getClassScope(),
+                    clsName, decl.getLocation(), typeName, elementName, component, bindInfo.toCustomizationList() );
+
+            // set javadoc class comment.
+            if(decl.getJavadoc()!=null )
+                bt.javadoc = decl.getJavadoc()+"\n\n";
+                // add extra blank lines so that the schema fragment
+                // and user-specified javadoc would be separated
+
+
+            // if the implClass is given, set it to ClassItem
+            String implClass = decl.getUserSpecifiedImplClass();
+            if( implClass!=null )
+                bt.setUserSpecifiedImplClass( implClass );
+
+            return bt;
+        }
+    }
+
+    private BIGlobalBinding getGlobalBinding() {
+        return builder.getGlobalBinding();
+    }
+
+    /**
+     * Derives a name from a schema component.
+     * Use the name of the schema component as the default name.
+     */
+    private String deriveName( XSDeclaration comp ) {
+        return deriveName( comp.getName(), comp );
+    }
+
+    /**
+     * Derives a name from a schema component.
+     * For complex types, we take redefinition into account when
+     * deriving a default name.
+     */
+    private String deriveName( XSComplexType comp ) {
+        String seed = deriveName( comp.getName(), comp );
+        int cnt = comp.getRedefinedCount();
+        for( ; cnt>0; cnt-- )
+            seed = "Original"+seed;
+        return seed;
+    }
+
+    /**
+     * Derives a name from a schema component.
+     *
+     * This method handles prefix/suffix modification and
+     * XML-to-Java name conversion.
+     *
+     * @param name
+     *      The base name. This should be things like element names
+     *      or type names.
+     * @param comp
+     *      The component from which the base name was taken.
+     *      Used to determine how names are modified.
+     */
+    private String deriveName( String name, XSComponent comp ) {
+        XSSchema owner = comp.getOwnerSchema();
+
+        name = builder.getNameConverter().toClassName(name);
+
+        if( owner!=null ) {
+            BISchemaBinding sb = builder.getBindInfo(
+                owner).get(BISchemaBinding.class);
+
+            if(sb!=null)    name = sb.mangleClassName(name,comp);
+        }
+
+        return name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/DefaultParticleBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/DefaultParticleBinder.java
new file mode 100644
index 0000000..c174d74
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/DefaultParticleBinder.java
@@ -0,0 +1,385 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Hashtable;
+import java.util.List;
+import java.util.Map;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+
+/**
+ * {@link ParticleBinder} that follows the JAXB spec.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class DefaultParticleBinder extends ParticleBinder {
+
+    @Override
+    public void build( XSParticle p, Collection<XSParticle> forcedProps ) {
+        Checker checker = checkCollision(p,forcedProps);
+
+        if(checker.hasNameCollision()) {
+            CReferencePropertyInfo prop = new CReferencePropertyInfo(
+                getCurrentBean().getBaseClass()==null?"Content":"Rest",
+                true, false, p,
+                builder.getBindInfo(p).toCustomizationList(),
+                p.getLocator() );
+            RawTypeSetBuilder.build(p,false).addTo(prop);
+            prop.javadoc = Messages.format( Messages.MSG_FALLBACK_JAVADOC,
+                    checker.getCollisionInfo().toString() );
+
+            getCurrentBean().addProperty(prop);
+        } else {
+            new Builder(checker.markedParticles).particle(p);
+        }
+    }
+
+    @Override
+    public boolean checkFallback( XSParticle p ) {
+        return checkCollision(p,Collections.<XSParticle>emptyList()).hasNameCollision();
+    }
+
+    private Checker checkCollision( XSParticle p, Collection<XSParticle> forcedProps ) {
+        // scan the tree by a checker.
+        Checker checker = new Checker(forcedProps);
+
+        CClassInfo superClass = getCurrentBean().getBaseClass();
+
+        if(superClass!=null)
+            checker.readSuperClass(superClass);
+        checker.particle(p);
+
+        return checker;
+    }
+
+
+
+
+
+
+
+
+
+
+    /**
+     * Marks particles that need to be mapped to properties,
+     * by reading customization info.
+     */
+    private final class Checker implements XSTermVisitor {
+
+        Checker(Collection<XSParticle> forcedProps) {
+            this.forcedProps = forcedProps;
+        }
+
+        boolean hasNameCollision() {
+            return collisionInfo!=null;
+        }
+
+        CollisionInfo getCollisionInfo() {
+            return collisionInfo;
+        }
+
+        /**
+         * If a collision is found, this field will be non-null.
+         */
+        private CollisionInfo collisionInfo = null;
+
+        /** Used to check name collision. */
+        private final NameCollisionChecker cchecker = new NameCollisionChecker();
+
+        /**
+         * @see DefaultParticleBinder#build(XSParticle, Collection<com.sun.xml.internal.xsom.XSParticle>)
+         */
+        private final Collection<XSParticle> forcedProps;
+
+        public void particle( XSParticle p ) {
+
+            if(getLocalPropCustomization(p)!=null
+            || builder.getLocalDomCustomization(p)!=null) {
+                // if a property customization is specfied,
+                // check that value and turn around.
+                check(p);
+                mark(p);
+                return;
+            }
+
+            XSTerm t = p.getTerm();
+
+            if(p.isRepeated() && (t.isModelGroup() || t.isModelGroupDecl())) {
+                // a repeated model group gets its own property
+                mark(p);
+                return;
+            }
+
+            if(forcedProps.contains(p)) {
+                // this particle must become a property
+                mark(p);
+                return;
+            }
+
+            outerParticle = p;
+            t.visit(this);
+        }
+
+        /**
+         * This field points to the parent XSParticle.
+         * The value is only valid when we are processing XSTerm.
+         */
+        private XSParticle outerParticle;
+
+        public void elementDecl(XSElementDecl decl) {
+            check(outerParticle);
+            mark(outerParticle);
+        }
+
+        public void modelGroup(XSModelGroup mg) {
+            for( XSParticle child : mg.getChildren() )
+                particle(child);
+        }
+
+        public void modelGroupDecl(XSModelGroupDecl decl) {
+            modelGroup(decl.getModelGroup());
+        }
+
+        public void wildcard(XSWildcard wc) {
+            mark(outerParticle);
+        }
+
+        void readSuperClass( CClassInfo ci ) {
+            cchecker.readSuperClass(ci);
+        }
+
+
+
+
+        /**
+         * Checks the name collision of a newly found particle.
+         */
+        private void check( XSParticle p ) {
+            if( collisionInfo==null )
+                collisionInfo = cchecker.check(p);
+        }
+
+        /**
+         * Marks a particle that it's going to be mapped to a property.
+         */
+        private void mark( XSParticle p ) {
+            markedParticles.put(p,computeLabel(p));
+        }
+
+        /**
+         * Marked particles.
+         *
+         * A map from XSParticle to its label.
+         */
+        public final Map<XSParticle,String> markedParticles = new HashMap<XSParticle,String>();
+
+
+        /**
+         * Checks name collisions among particles that belong to sequences.
+         */
+        private final class NameCollisionChecker {
+
+            /**
+             * Checks the label conflict of a particle.
+             * This method shall be called for each marked particle.
+             *
+             * @return
+             *      a description of a collision if a name collision is
+             *      found. Otherwise null.
+             */
+            CollisionInfo check( XSParticle p ) {
+                // this can be used for particles with a property customization,
+                // which may not have element declaration as its term.
+//                // we only check particles with element declarations.
+//                _assert( p.getTerm().isElementDecl() );
+
+                String label = computeLabel(p);
+                if( occupiedLabels.containsKey(label) ) {
+                    // collide with occupied labels
+                    return new CollisionInfo(label,p.getLocator(),
+                            occupiedLabels.get(label).locator);
+                }
+
+                for( XSParticle jp : particles ) {
+                    if(!check( p, jp )) {
+                        // problem was found. no need to check further
+                        return new CollisionInfo( label, p.getLocator(), jp.getLocator() );
+                    }
+                }
+                particles.add(p);
+                return null;
+            }
+
+            /** List of particles reported through the check method. */
+            private final List<XSParticle> particles = new ArrayList<XSParticle>();
+
+            /**
+             * Label names already used in the base type.
+             */
+            private final Map<String,CPropertyInfo> occupiedLabels = new HashMap<String,CPropertyInfo>();
+
+            /**
+             * Checks the conflict of two particles.
+             * @return
+             *      true if the check was successful.
+             */
+            private boolean check( XSParticle p1, XSParticle p2 ) {
+                return !computeLabel(p1).equals(computeLabel(p2));
+            }
+
+            /**
+             * Reads fields of the super class and includes them
+             * to name collision tests.
+             */
+            void readSuperClass( CClassInfo base ) {
+                for( ; base!=null; base=base.getBaseClass() ) {
+                    for( CPropertyInfo p : base.getProperties() )
+                        occupiedLabels.put(p.getName(true),p);
+                }
+            }
+        }
+
+
+
+
+
+        /** Keep the computed label names for particles. */
+        private final Map<XSParticle,String> labelCache = new Hashtable<XSParticle,String>();
+
+        /**
+         * Hides the computeLabel method of the outer class
+         * and adds caching.
+         */
+        private String computeLabel( XSParticle p ) {
+            String label = labelCache.get(p);
+            if(label==null)
+                labelCache.put( p, label=DefaultParticleBinder.this.computeLabel(p) );
+            return label;
+        }
+    }
+
+
+
+
+
+
+
+
+
+
+
+
+    /**
+     * Builds properties by using the result computed by Checker
+     */
+    private final class Builder implements XSTermVisitor {
+        Builder( Map<XSParticle,String> markedParticles ) {
+            this.markedParticles = markedParticles;
+        }
+
+        /** All marked particles. */
+        private final Map<XSParticle,String/*label*/> markedParticles;
+
+        /**
+         * When we are visiting inside an optional particle, this flag
+         * is set to true.
+         *
+         * <p>
+         * This allows us to correctly generate primitive/boxed types.
+         */
+        private boolean insideOptionalParticle;
+
+
+        /** Returns true if a particle is marked. */
+        private boolean marked( XSParticle p ) {
+            return markedParticles.containsKey(p);
+        }
+        /** Gets a label of a particle. */
+        private String getLabel( XSParticle p ) {
+            return markedParticles.get(p);
+        }
+
+        public void particle( XSParticle p ) {
+            XSTerm t = p.getTerm();
+
+            if(marked(p)) {
+                BIProperty cust = BIProperty.getCustomization(p);
+                CPropertyInfo prop = cust.createElementOrReferenceProperty(
+                    getLabel(p), false, p, RawTypeSetBuilder.build(p,insideOptionalParticle));
+                getCurrentBean().addProperty(prop);
+            } else {
+                // repeated model groups should have been marked already
+                assert !p.isRepeated();
+
+                boolean oldIOP = insideOptionalParticle;
+                insideOptionalParticle |= p.getMinOccurs()==0;
+                // this is an unmarked particle
+                t.visit(this);
+                insideOptionalParticle = oldIOP;
+            }
+        }
+
+        public void elementDecl( XSElementDecl e ) {
+            // because the corresponding particle must be marked.
+            assert false;
+        }
+
+        public void wildcard( XSWildcard wc ) {
+            // because the corresponding particle must be marked.
+            assert false;
+        }
+
+        public void modelGroupDecl( XSModelGroupDecl decl ) {
+            modelGroup(decl.getModelGroup());
+        }
+
+        public void modelGroup( XSModelGroup mg ) {
+            boolean oldIOP = insideOptionalParticle;
+            insideOptionalParticle |= mg.getCompositor()==XSModelGroup.CHOICE;
+
+            for( XSParticle p : mg.getChildren())
+                particle(p);
+
+            insideOptionalParticle = oldIOP;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ErrorReporter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ErrorReporter.java
new file mode 100644
index 0000000..c5ffb55
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ErrorReporter.java
@@ -0,0 +1,109 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.reader.Ring;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Provides error report capability to other owner components
+ * by encapsulating user-specified {@link ErrorHandler}
+ * and exposing utlity methods.
+ *
+ * <p>
+ * This class also wraps SAXException to a RuntimeException
+ * so that the exception thrown inside the error handler
+ * can abort the process.
+ *
+ * <p>
+ * At the end of the day, we need to know if there was any error.
+ * So it is important that all the error messages go through this
+ * object. This is done by hiding the errorHandler from the rest
+ * of the components.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class ErrorReporter extends BindingComponent {
+
+    /**
+     * Error handler to report any binding error to.
+     * To report errors, use the error method.
+     */
+    private final ErrorReceiver errorReceiver = Ring.get(ErrorReceiver.class);
+
+
+    //
+    // helper methods for classes in this package.
+    //    properties are localized through the Messages.properties file
+    //    in this package
+    //
+    void error( Locator loc, String prop, Object... args ) {
+        errorReceiver.error( loc, Messages.format(prop,args) );
+    }
+
+    void warning( Locator loc, String prop, Object... args ) {
+        errorReceiver.warning( new SAXParseException(
+            Messages.format(prop,args), loc ));
+    }
+
+
+
+    /*
+    private String format( String prop, Object[] args ) {
+        // use a bit verbose code to make it portable.
+        String className = this.getClass().getName();
+        int idx = className.lastIndexOf('.');
+        String packageName = className.substring(0,idx);
+
+        String fmt = ResourceBundle.getBundle(packageName+".Messages").getString(prop);
+
+        return MessageFormat.format(fmt,args);
+    }
+    */
+
+////
+////
+//// ErrorHandler implementation
+////
+////
+//    public void error(SAXParseException exception) {
+//        errorReceiver.error(exception);
+//    }
+//
+//    public void fatalError(SAXParseException exception) {
+//        errorReceiver.fatalError(exception);
+//    }
+//
+//    public void warning(SAXParseException exception) {
+//        errorReceiver.warning(exception);
+//    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ExpressionBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ExpressionBuilder.java
new file mode 100644
index 0000000..4e25af6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ExpressionBuilder.java
@@ -0,0 +1,132 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.bind.annotation.XmlAnyElement;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.gbind.Choice;
+import com.sun.tools.internal.xjc.reader.gbind.Element;
+import com.sun.tools.internal.xjc.reader.gbind.Expression;
+import com.sun.tools.internal.xjc.reader.gbind.OneOrMore;
+import com.sun.tools.internal.xjc.reader.gbind.Sequence;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.visitor.XSTermFunction;
+
+/**
+ * Visits {@link XSParticle} and creates a corresponding {@link Expression} tree.
+ * @author Kohsuke Kawaguchi
+ */
+public final class ExpressionBuilder implements XSTermFunction<Expression> {
+
+    public static Expression createTree(XSParticle p) {
+        return new ExpressionBuilder().particle(p);
+    }
+
+    private ExpressionBuilder() {}
+
+    /**
+     * Wildcard instance needs to be consolidated to one,
+     * and this is such instance (if any.)
+     */
+    private GWildcardElement wildcard = null;
+
+    private final Map<QName,GElementImpl> decls = new HashMap<QName,GElementImpl>();
+
+    private XSParticle current;
+
+    /**
+     * We can only have one {@link XmlAnyElement} property,
+     * so all the wildcards need to be treated as one node.
+     */
+    public Expression wildcard(XSWildcard wc) {
+        if(wildcard==null)
+            wildcard = new GWildcardElement();
+        wildcard.particles.add(current);
+        return wildcard;
+    }
+
+    public Expression modelGroupDecl(XSModelGroupDecl decl) {
+        return modelGroup(decl.getModelGroup());
+    }
+
+    public Expression modelGroup(XSModelGroup group) {
+        XSModelGroup.Compositor comp = group.getCompositor();
+        if(comp==XSModelGroup.CHOICE) {
+            // empty choice is not epsilon, but empty set,
+            // so this initial value is incorrect. But this
+            // kinda works.
+            // properly handling empty set requires more work.
+            Expression e = Expression.EPSILON;
+            for (XSParticle p : group.getChildren()) {
+                if(e==null)     e = particle(p);
+                else            e = new Choice(e,particle(p));
+            }
+            return e;
+        } else {
+            Expression e = Expression.EPSILON;
+            for (XSParticle p : group.getChildren()) {
+                if(e==null)     e = particle(p);
+                else            e = new Sequence(e,particle(p));
+            }
+            return e;
+        }
+    }
+
+    public Element elementDecl(XSElementDecl decl) {
+        QName n = new QName(decl.getTargetNamespace(),decl.getName());
+
+        GElementImpl e = decls.get(n);
+        if(e==null)
+            decls.put(n,e=new GElementImpl(n,decl));
+
+        e.particles.add(current);
+        assert current.getTerm()==decl;
+
+        return e;
+    }
+
+    public Expression particle(XSParticle p) {
+        current = p;
+        Expression e = p.getTerm().apply(this);
+
+        if(p.isRepeated())
+            e = new OneOrMore(e);
+
+        if(p.getMinOccurs()==0)
+            e = new Choice(e,Expression.EPSILON);
+
+        return e;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ExpressionParticleBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ExpressionParticleBinder.java
new file mode 100644
index 0000000..cdabcec
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ExpressionParticleBinder.java
@@ -0,0 +1,141 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.Collection;
+
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.Multiplicity;
+import com.sun.tools.internal.xjc.reader.RawTypeSet;
+import com.sun.tools.internal.xjc.reader.gbind.ConnectedComponent;
+import com.sun.tools.internal.xjc.reader.gbind.Element;
+import com.sun.tools.internal.xjc.reader.gbind.Expression;
+import com.sun.tools.internal.xjc.reader.gbind.Graph;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+import com.sun.xml.internal.xsom.XSParticle;
+
+/**
+ * {@link ParticleBinder} that uses {@link ExpressionBuilder} et al
+ * for better, more intuitive (but non spec-conforming) binding.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ExpressionParticleBinder extends ParticleBinder {
+    public void build(XSParticle p, Collection<XSParticle> forcedProps) {
+        // this class isn't about spec conformance, but
+        // for the ease of use.
+        // so we don't give a damn about 'forcedProps'.
+        // although, for a future note, it's conceivable to expand
+        // the binding algorithm to cover this notion.
+
+        Expression tree = ExpressionBuilder.createTree(p);
+        Graph g = new Graph(tree);
+        for (ConnectedComponent cc : g) {
+            buildProperty(cc);
+        }
+    }
+
+    /**
+     * Builds a property ouf ot a connected component.
+     */
+    private void buildProperty(ConnectedComponent cc) {
+        StringBuilder propName = new StringBuilder(); // property name
+        int nameTokenCount = 0; // combine only up to 3
+
+        RawTypeSetBuilder rtsb = new RawTypeSetBuilder();
+        for (Element e : cc) {
+            GElement ge = (GElement)e;
+
+            if(nameTokenCount<3) {
+                if(nameTokenCount!=0)
+                    propName.append("And");
+                propName.append(makeJavaName(cc.isCollection(),ge.getPropertyNameSeed()));
+                nameTokenCount++;
+            }
+
+            if(e instanceof GElementImpl) {
+                GElementImpl ei = (GElementImpl) e;
+                rtsb.elementDecl(ei.decl);
+                continue;
+            }
+            if(e instanceof GWildcardElement) {
+                rtsb.getRefs().add(new RawTypeSetBuilder.WildcardRef(WildcardMode.SKIP));
+                continue;
+            }
+            assert false : e;   // no other kind should be here
+        }
+
+        Multiplicity m = Multiplicity.ONE;
+        if(cc.isCollection())
+            m = m.makeRepeated();
+        if(!cc.isRequired())
+            m = m.makeOptional();
+
+        RawTypeSet rts = new RawTypeSet(rtsb.getRefs(),m);
+
+        XSParticle p = findSourceParticle(cc);
+
+        BIProperty cust = BIProperty.getCustomization(p);
+        CPropertyInfo prop = cust.createElementOrReferenceProperty(
+            propName.toString(), false, p, rts );
+        getCurrentBean().addProperty(prop);
+    }
+
+    /**
+     * Finds a {@link XSParticle} that can serve as the representative property of
+     * the given {@link ConnectedComponent}.
+     *
+     * The representative property is used for reporting an error location and
+     * taking {@link BIProperty} customization. Right now, the algorithm is just pick
+     * the first one with {@link BIProperty}, but one can think of a better algorithm,
+     * such as taking a choice of (A|B) if CC={A,B}.
+     */
+    private XSParticle findSourceParticle(ConnectedComponent cc) {
+        XSParticle first = null;
+
+        for (Element e : cc) {
+            GElement ge = (GElement)e;
+            for (XSParticle p : ge.particles) {
+                if(first==null)
+                    first = p;
+                if(getLocalPropCustomization(p)!=null)
+                    return p;
+            }
+            // if there are multiple property customizations,
+            // all but one will be left unused, which will be detected as an error
+            // later, so no need to check that now.
+        }
+
+        // if no customization was found, just use the first one.
+        return first;
+    }
+
+    public boolean checkFallback(XSParticle p) {
+        // this algorithm never falls back to 'getContent'.
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GElement.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GElement.java
new file mode 100644
index 0000000..076ee51
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GElement.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import com.sun.tools.internal.xjc.reader.gbind.Element;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class GElement extends Element {
+    /**
+     * All the {@link XSParticle}s (whose term is {@link XSElementDecl})
+     * that are coereced into a single {@link Element}.
+     */
+    final Set<XSParticle> particles = new HashSet<XSParticle>();
+
+    /**
+     * Gets the seed (raw XML name) to be used to generate a property name.
+     */
+    abstract String getPropertyNameSeed();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GElementImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GElementImpl.java
new file mode 100644
index 0000000..6d21fbf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GElementImpl.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.gbind.Element;
+import com.sun.xml.internal.xsom.XSElementDecl;
+
+/**
+ * {@link Element} that wraps {@link XSElementDecl}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class GElementImpl extends GElement {
+    public final QName tagName;
+
+    /**
+     * The representative {@link XSElementDecl}.
+     *
+     * Even though multiple {@link XSElementDecl}s maybe represented by
+     * a single {@link GElementImpl} (especially when they are local),
+     * the schema spec requires that they share the same type and other
+     * characteristic.
+     *
+     * (To be really precise, you may have different default values,
+     * nillability, all that, so if that becomes a real issue we have
+     * to reconsider this design.)
+     */
+    public final XSElementDecl decl;
+
+    public GElementImpl(QName tagName, XSElementDecl decl) {
+        this.tagName = tagName;
+        this.decl = decl;
+    }
+
+    public String toString() {
+        return tagName.toString();
+    }
+
+    String getPropertyNameSeed() {
+        return tagName.getLocalPart();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GWildcardElement.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GWildcardElement.java
new file mode 100644
index 0000000..a1c18b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/GWildcardElement.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.reader.gbind.Element;
+
+/**
+ * {@link Element} that represents a wildcard,
+ * for the "ease of binding" we always just bind this to DOM elements.
+ * @author Kohsuke Kawaguchi
+ */
+final class GWildcardElement extends GElement {
+    public String toString() {
+        return "#any";
+    }
+
+    String getPropertyNameSeed() {
+        return "any";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/MessageBundle.properties
new file mode 100644
index 0000000..4b5d824
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/MessageBundle.properties
@@ -0,0 +1,145 @@
+#
+# Message resource file
+#
+
+
+
+BGMBuilder.NoGlobalElement = \
+	Schema contains no global element declaration.
+
+BGMBuilder.MultipleSchemaBindings = \
+	Multiple <schemaBindings> are defined for the target namespace "{0}"
+
+BGMBuilder.MultipleSchemaBindings.Location = \
+	Another <schemaBindings> is defined here
+
+
+
+ClassSelector.ClassNameIsRequired = \
+	Cannot derive a name from schema. A name attribute specified to the <class> customization.
+
+ClassSelector.IncorrectClassName = \
+	Specified name ''{0}'' is not a valid Java identifier.
+
+ClassSelector.IncorrectPackageName = \
+	The package name ''{1}'' used for this schema is not a valid package name.
+
+ClassSelector.JavadocHeading = \
+	<p>Java class for {0}.\n\n<p>The following schema fragment specifies the expected \
+	content contained within this class.
+
+ClassSelector.JavadocLineUnknown = \
+	unknown
+
+ClassSelector.ReservedClassName = \
+	Attempt to create a class having the same name as the reserved word "{0}".
+
+
+CollisionInfo.CollisionInfo = \
+	The field name "{0}" is used by two different parts of a schema. See: \n\
+	{1}\n\
+	{2}
+
+CollisionInfo.UnknownFile = \
+	unknown file
+
+CollisionInfo.LineXOfY = \
+	line {0} of {1}
+
+
+ConversionFinder.CannotBeTypeSafeEnum = \
+	A type safe enum customization is specified to a simple type that cannot \
+	be mapped to a type safe enum.
+ConversionFinder.CannotBeTypeSafeEnum.Location = \
+	Ths relevant simple type declaration is specified at this location
+ConversionFinder.NoEnumNameAvailable = \
+	A name attribute is required to customize an anonymous simple type to type-safe enum.
+ERR_ILLEGAL_EXPECTED_MIME_TYPE = \
+    Unable to parse the expected MIME type "{0}". {1}. 
+
+
+DatatypeBuilder.DatatypeError = \
+	Simple type error: {0}
+
+
+
+
+
+
+DefaultParticleBinder.UnableToGenerateNameFromModelGroup = \
+	Unable to generate a property name from a model group. A customization is required.
+
+DefaultParticleBinder.FallbackJavadoc = \
+	Gets the rest of the content model. \n\
+	\n\
+	<p>\n\
+	You are getting this "catch-all" property because of the following reason: \n\
+	{0}\n\
+	<p>\n\
+	To get rid of this property, apply a property customization to one \n\
+	of both of the following declarations to change their names: \n
+
+
+
+
+
+
+
+FieldBuilder.IncorrectFixedValue = \
+	The value specified in the fixed attribute "{0}" is not a valid value for the datatype
+
+FieldBuilder.IncorrectDefaultValue = \
+	The value specified in the default attribute "{0}" is not a valid value for the datatype
+
+FieldBuilder.ConflictBetweenUserTypeAndActualType.AttUse = \
+	"{0}" is specified by a customization but this attribute has incompatible type "{1}"
+
+FieldBuilder.ConflictBetweenUserTypeAndActualType.AttUse.Source = \
+	The relevant customization is specified	at this location
+
+FieldBuilder.Javadoc.NilProperty = \
+	This property is used to control \
+	<a href="http://www.w3.org/TR/2001/REC-xmlschema-0-20010502/#Nils">the xsi:nil feature</a> \
+	of W3C XML Schema. \nSetting this property to true will cause \
+	the output to be &lt;{0} xsi:nil="true" /> regardless of the \
+	values of the other properties.
+
+FieldBuilder.Javadoc.ValueObject = \
+	get/set the complex type value associated with this element.\n \
+	when you unmarshal a document that contains xsi:type, the get{1} method \
+	would return an instance of derived classes of '{'@link {0}'}'. Similarly, if you set \
+	an instance of derived classes, then you would get the instance with xsi:type \
+	when you marshal out to XML.
+
+
+SimpleTypeBuilder.UnnestedJavaTypeCustomization = \
+    <javaType> customization in this context must be nested (JAXB spec sec 6.8.1): \n\
+    \t<property>\n\
+    \t  <baseType>\n\
+    \t    <javaType ...>\n\
+    \t  </baseType>\n\
+    \t</property>
+
+UnusedCustomizationChecker.UnacknolwedgedCustomization = \
+	compiler was unable to honor this {0} customization. It is attached to a wrong place, \
+	or it's inconsistent with other bindings.
+
+UnusedCustomizationChecker.UnacknolwedgedCustomization.Relevant = \
+	(the above customization is attached to the following location in the schema)
+
+ERR_ENUM_MEMBER_NAME_COLLISION = \
+    Two enum members yield the same constant name {0}
+
+ERR_ENUM_MEMBER_NAME_COLLISION_RELATED = \
+    (related to above) the other enum is defined at this location
+
+ERR_CANNOT_GENERATE_ENUM_NAME = \
+    Cannot generate a constant name from the enumeration value "{0}". \
+    Use <jaxb:typesafeEnumMember name="..."/> to specify one. 
+
+ERR_MULTIPLE_GLOBAL_BINDINGS = \
+    only one globalBindings customization is allowed in a whole compilation
+
+ERR_MULTIPLE_GLOBAL_BINDINGS_OTHER = \
+    (related to above) but one is already given at this location
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/Messages.java
new file mode 100644
index 0000000..59f9a35
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/Messages.java
@@ -0,0 +1,140 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+public class Messages
+{
+    /** Loads a string resource and formats it with specified arguments. */
+    public static String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getPackage().getName() +".MessageBundle").getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+
+    static final String WARN_NO_GLOBAL_ELEMENT =
+        "BGMBuilder.NoGlobalElement";
+
+    static final String ERR_MULTIPLE_SCHEMA_BINDINGS =
+        "BGMBuilder.MultipleSchemaBindings"; // arg:1
+
+    static final String ERR_MULTIPLE_SCHEMA_BINDINGS_LOCATION =
+        "BGMBuilder.MultipleSchemaBindings.Location"; // arg:0
+
+    static final String JAVADOC_HEADING = // 1 arg
+        "ClassSelector.JavadocHeading";
+
+    static final String ERR_RESERVED_CLASS_NAME = // 1 arg
+        "ClassSelector.ReservedClassName";
+
+    static final String ERR_CLASS_NAME_IS_REQUIRED =
+        "ClassSelector.ClassNameIsRequired";    // arg:0
+
+    static final String ERR_INCORRECT_CLASS_NAME =
+        "ClassSelector.IncorrectClassName";     // arg:1
+
+    static final String ERR_INCORRECT_PACKAGE_NAME =
+        "ClassSelector.IncorrectPackageName";   // arg:2
+
+    static final String ERR_CANNOT_BE_TYPE_SAFE_ENUM =
+        "ConversionFinder.CannotBeTypeSafeEnum";            // arg:0
+
+    static final String ERR_CANNOT_BE_TYPE_SAFE_ENUM_LOCATION =
+        "ConversionFinder.CannotBeTypeSafeEnum.Location";    // arg:0
+
+    static final String ERR_NO_ENUM_NAME_AVAILABLE =
+        "ConversionFinder.NoEnumNameAvailable"; // arg:0
+
+    static final String ERR_ILLEGAL_EXPECTED_MIME_TYPE =
+        "ERR_ILLEGAL_EXPECTED_MIME_TYPE"; // args:2
+
+    static final String ERR_DATATYPE_ERROR =
+        "DatatypeBuilder.DatatypeError"; // arg:1
+
+    static final String ERR_UNABLE_TO_GENERATE_NAME_FROM_MODELGROUP =
+        "DefaultParticleBinder.UnableToGenerateNameFromModelGroup"; // arg:0
+
+    static final String ERR_INCORRECT_FIXED_VALUE =
+        "FieldBuilder.IncorrectFixedValue"; // arg:1
+
+    static final String ERR_INCORRECT_DEFAULT_VALUE =
+        "FieldBuilder.IncorrectDefaultValue"; // arg:1
+
+    static final String ERR_CONFLICT_BETWEEN_USERTYPE_AND_ACTUALTYPE_ATTUSE =
+        "FieldBuilder.ConflictBetweenUserTypeAndActualType.AttUse"; // arg:2
+
+    static final String ERR_CONFLICT_BETWEEN_USERTYPE_AND_ACTUALTYPE_ATTUSE_SOURCE =
+        "FieldBuilder.ConflictBetweenUserTypeAndActualType.AttUse.Source"; // arg:0
+
+    static final String ERR_UNNESTED_JAVATYPE_CUSTOMIZATION_ON_SIMPLETYPE =
+        "SimpleTypeBuilder.UnnestedJavaTypeCustomization"; // arg:0
+
+    static final String JAVADOC_NIL_PROPERTY =
+        "FieldBuilder.Javadoc.NilProperty"; // arg:1
+
+    static final String JAVADOC_LINE_UNKNOWN = // 0 args
+        "ClassSelector.JavadocLineUnknown";
+
+    static final String JAVADOC_VALUEOBJECT_PROPERTY =
+        "FieldBuilder.Javadoc.ValueObject"; // args:2
+
+    static final String MSG_COLLISION_INFO =
+        "CollisionInfo.CollisionInfo"; // args:3
+
+    static final String MSG_UNKNOWN_FILE =
+        "CollisionInfo.UnknownFile"; // arg:1
+
+    static final String MSG_LINE_X_OF_Y =
+        "CollisionInfo.LineXOfY"; // args:2
+
+    static final String MSG_FALLBACK_JAVADOC =
+        "DefaultParticleBinder.FallbackJavadoc"; // arg:1
+
+    static final String ERR_ENUM_MEMBER_NAME_COLLISION =
+        "ERR_ENUM_MEMBER_NAME_COLLISION";
+    static final String ERR_ENUM_MEMBER_NAME_COLLISION_RELATED =
+        "ERR_ENUM_MEMBER_NAME_COLLISION_RELATED";
+    static final String ERR_CANNOT_GENERATE_ENUM_NAME =
+        "ERR_CANNOT_GENERATE_ENUM_NAME";
+
+
+    // they are shared from the model
+    public static final String ERR_UNACKNOWLEDGED_CUSTOMIZATION =
+        "UnusedCustomizationChecker.UnacknolwedgedCustomization"; // arg:1
+    public static final String ERR_UNACKNOWLEDGED_CUSTOMIZATION_LOCATION =
+        "UnusedCustomizationChecker.UnacknolwedgedCustomization.Relevant"; // arg:0
+
+    public static final String ERR_MULTIPLE_GLOBAL_BINDINGS =
+        "ERR_MULTIPLE_GLOBAL_BINDINGS";
+    public static final String ERR_MULTIPLE_GLOBAL_BINDINGS_OTHER =
+        "ERR_MULTIPLE_GLOBAL_BINDINGS_OTHER";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/MultiplicityCounter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/MultiplicityCounter.java
new file mode 100644
index 0000000..9b53ac1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/MultiplicityCounter.java
@@ -0,0 +1,94 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import com.sun.tools.internal.xjc.model.Multiplicity;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.visitor.XSTermFunction;
+
+import static com.sun.tools.internal.xjc.model.Multiplicity.ONE;
+import static com.sun.tools.internal.xjc.model.Multiplicity.ZERO;
+
+/**
+ * Counts {@link Multiplicity} for a particle/term.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class MultiplicityCounter implements XSTermFunction<Multiplicity> {
+
+    public static final MultiplicityCounter theInstance = new MultiplicityCounter();
+
+    private MultiplicityCounter() {}
+
+    public Multiplicity particle( XSParticle p ) {
+        Multiplicity m = p.getTerm().apply(this);
+
+        Integer max;
+        if(m.max==null || p.getMaxOccurs()==XSParticle.UNBOUNDED)
+            max=null;
+        else
+            max=p.getMaxOccurs();
+
+        return Multiplicity.multiply( m, Multiplicity.create(p.getMinOccurs(),max) );
+    }
+
+    public Multiplicity wildcard(XSWildcard wc) {
+        return ONE;
+    }
+
+    public Multiplicity modelGroupDecl(XSModelGroupDecl decl) {
+        return modelGroup(decl.getModelGroup());
+    }
+
+    public Multiplicity modelGroup(XSModelGroup group) {
+        boolean isChoice = group.getCompositor() == XSModelGroup.CHOICE;
+
+        Multiplicity r = ZERO;
+
+        for( XSParticle p : group.getChildren()) {
+            Multiplicity m = particle(p);
+
+            if(r==null) {
+                r=m;
+                continue;
+            }
+            if(isChoice) {
+                r = Multiplicity.choice(r,m);
+            } else {
+                r = Multiplicity.group(r,m);
+            }
+        }
+        return r;
+    }
+
+    public Multiplicity elementDecl(XSElementDecl decl) {
+        return ONE;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ParticleBinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ParticleBinder.java
new file mode 100644
index 0000000..4783215
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ParticleBinder.java
@@ -0,0 +1,255 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.text.ParseException;
+import java.util.Collection;
+import java.util.Collections;
+
+import com.sun.codemodel.internal.JJavaName;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIDeclaration;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+
+/**
+ * Binds the content models of {@link XSParticle} as properties of the class that's being built.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class ParticleBinder {
+
+    protected final BGMBuilder builder = Ring.get(BGMBuilder.class);
+
+    protected ParticleBinder() {
+        // make sure that this object is available as ParticleBinder, not as their actual implementation classes
+        Ring.add(ParticleBinder.class,this);
+    }
+
+    /**
+     * Builds the {@link CPropertyInfo}s from the given particle
+     * (and its descendants), and set them to the class returned by
+     * {@link ClassSelector#getCurrentBean()}.
+     */
+    public final void build( XSParticle p ) {
+        build(p, Collections.<XSParticle>emptySet());
+    }
+
+    /**
+     * The version of the build method that forces a specified set of particles
+     * to become a property.
+     */
+    public abstract void build( XSParticle p, Collection<XSParticle> forcedProps );
+
+    /**
+     * Similar to the build method but this method only checks if
+     * the BGM that will be built by the build method will
+     * do the fallback (map all the properties into one list) or not.
+     *
+     * @return
+     *      false if the fallback will not happen.
+     */
+    public abstract boolean checkFallback( XSParticle p );
+
+
+//
+//
+// convenient utility methods
+//
+//
+
+    protected final CClassInfo getCurrentBean() {
+        return getClassSelector().getCurrentBean();
+    }
+
+
+    /**
+     * Gets the BIProperty object that applies to the given particle.
+     */
+    protected final BIProperty getLocalPropCustomization( XSParticle p ) {
+        return getLocalCustomization(p,BIProperty.class);
+    }
+
+    protected final <T extends BIDeclaration> T getLocalCustomization( XSParticle p, Class<T> type ) {
+        // check the property customization of this component first
+        T cust = builder.getBindInfo(p).get(type);
+        if(cust!=null)  return cust;
+
+        // if not, the term might have one.
+        cust = builder.getBindInfo(p.getTerm()).get(type);
+        if(cust!=null)  return cust;
+
+        return null;
+    }
+
+    /**
+     * Computes the label of a given particle.
+     * Usually, the getLabel method should be used instead.
+     */
+    protected final String computeLabel( XSParticle p ) {
+        // if the particle carries a customization, use that value.
+        // since we are binding content models, it's always non-constant properties.
+        BIProperty cust = getLocalPropCustomization(p);
+        if(cust!=null && cust.getPropertyName(false)!=null)
+            return cust.getPropertyName(false);
+
+        // no explicit property name is given. Compute one.
+
+        XSTerm t = p.getTerm();
+
+//        // first, check if a term is going to be a class, if so, use that name.
+//        ClassItem ci = owner.selector.select(t);
+//        if(ci!=null) {
+//            return makeJavaName(ci.getTypeAsDefined().name());
+//        }
+
+        // if it fails, compute the default name according to the spec.
+        if(t.isElementDecl())
+            // for element, take the element name.
+            return makeJavaName(p,t.asElementDecl().getName());
+        if(t.isModelGroupDecl())
+            // for named model groups, take that name
+            return makeJavaName(p,t.asModelGroupDecl().getName());
+        if(t.isWildcard())
+            // the spec says it will map to "any" by default.
+            return makeJavaName(p,"Any");
+        if(t.isModelGroup()) {
+            try {
+                return getSpecDefaultName(t.asModelGroup(),p.isRepeated());
+            } catch( ParseException e ) {
+                // unable to generate a name.
+                getErrorReporter().error(t.getLocator(),
+                    Messages.ERR_UNABLE_TO_GENERATE_NAME_FROM_MODELGROUP);
+                return "undefined"; // recover from error by assuming something
+            }
+        }
+
+        // there are only four types of XSTerm.
+        throw new AssertionError();
+    }
+
+    /** Converts an XML name to the corresponding Java name. */
+    protected final String makeJavaName( boolean isRepeated, String xmlName ) {
+        String name = builder.getNameConverter().toPropertyName(xmlName);
+        if(builder.getGlobalBinding().isSimpleMode() && isRepeated )
+            name = JJavaName.getPluralForm(name);
+        return name;
+    }
+
+    protected final String makeJavaName( XSParticle p, String xmlName ) {
+        return makeJavaName(p.isRepeated(),xmlName);
+    }
+
+    /**
+     * Computes a name from unnamed model group by following the spec.
+     *
+     * Taking first three elements and combine them.
+     *
+     * @param repeated
+     *      if the said model group is repeated more than once
+     *
+     * @exception ParseException
+     *      If the method cannot generate a name. For example, when
+     *      a model group doesn't contain any element reference/declaration
+     *      at all.
+     */
+    protected final String getSpecDefaultName( XSModelGroup mg, final boolean repeated ) throws ParseException {
+
+        final StringBuilder name = new StringBuilder();
+
+        mg.visit(new XSTermVisitor() {
+            /**
+             * Count the number of tokens we combined.
+             * We will concat up to 3.
+             */
+            private int count=0;
+
+            /**
+             * Is the current particple/term repeated?
+             */
+            private boolean rep = repeated;
+
+            public void wildcard(XSWildcard wc) {
+                append("any");
+            }
+
+            public void modelGroupDecl(XSModelGroupDecl mgd) {
+                modelGroup(mgd.getModelGroup());
+            }
+
+            public void modelGroup(XSModelGroup mg) {
+                String operator;
+                if(mg.getCompositor()==XSModelGroup.CHOICE)     operator = "Or";
+                else                                            operator = "And";
+
+                int size = mg.getSize();
+                for( int i=0; i<size; i++ ) {
+                    XSParticle p = mg.getChild(i);
+                    boolean oldRep = rep;
+                    rep |= p.isRepeated();
+                    p.getTerm().visit(this);
+                    rep = oldRep;
+
+                    if(count==3)    return; // we have enough
+                    if(i!=size-1)   name.append(operator);
+                }
+            }
+
+            public void elementDecl(XSElementDecl ed) {
+                append(ed.getName());
+            }
+
+            private void append(String token) {
+                if( count<3 ) {
+                    name.append(makeJavaName(rep,token));
+                    count++;
+                }
+            }
+        });
+
+        if(name.length()==0) throw new ParseException("no element",-1);
+
+        return name.toString();
+    }
+
+
+
+    protected final ErrorReporter getErrorReporter() {
+        return Ring.get(ErrorReporter.class);
+    }
+    protected final ClassSelector getClassSelector() {
+        return Ring.get(ClassSelector.class);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/RawTypeSetBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/RawTypeSetBuilder.java
new file mode 100644
index 0000000..4862e9a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/RawTypeSetBuilder.java
@@ -0,0 +1,283 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import javax.activation.MimeType;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.model.CAdapter;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CElement;
+import com.sun.tools.internal.xjc.model.CElementInfo;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.CTypeRef;
+import com.sun.tools.internal.xjc.model.Multiplicity;
+import com.sun.tools.internal.xjc.reader.RawTypeSet;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIDom;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+
+/**
+ * Builds {@link RawTypeSet} for XML Schema.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class RawTypeSetBuilder implements XSTermVisitor {
+    /**
+     * @param optional
+     *      if this whole property is optional due to the
+     *      occurence constraints on ancestors, set this to true.
+     *      this will prevent the primitive types to be generated.
+     */
+    public static RawTypeSet build( XSParticle p, boolean optional ) {
+        RawTypeSetBuilder rtsb = new RawTypeSetBuilder();
+        rtsb.particle(p);
+        Multiplicity mul = MultiplicityCounter.theInstance.particle(p);
+
+        if(optional)
+            mul = mul.makeOptional();
+
+        return new RawTypeSet(rtsb.refs,mul);
+    }
+
+
+    /**
+     * To avoid declaring the same element twice for a content model like
+     * (A,A), we keep track of element names here while we are building up
+     * this instance.
+     */
+    private final Set<QName> elementNames = new HashSet<QName>();
+
+    private final Set<RawTypeSet.Ref> refs = new HashSet<RawTypeSet.Ref>();
+
+    protected final BGMBuilder builder = Ring.get(BGMBuilder.class);
+
+    public RawTypeSetBuilder() {}
+
+
+    /**
+     * Gets the {@link RawTypeSet.Ref}s that were built.
+     */
+    public Set<RawTypeSet.Ref> getRefs() {
+        return refs;
+    }
+
+    /**
+     * Build up {@link #refs} and compute the total multiplicity of this {@link RawTypeSet.Ref} set.
+     */
+    private void particle( XSParticle p ) {
+        // if the DOM customization is present, bind it like a wildcard
+        BIDom dom = builder.getLocalDomCustomization(p);
+        if(dom!=null) {
+            dom.markAsAcknowledged();
+            refs.add(new WildcardRef(WildcardMode.SKIP));
+        } else {
+            p.getTerm().visit(this);
+        }
+    }
+
+    public void wildcard(XSWildcard wc) {
+        refs.add(new WildcardRef(wc));
+    }
+
+    public void modelGroupDecl(XSModelGroupDecl decl) {
+        modelGroup(decl.getModelGroup());
+    }
+
+    public void modelGroup(XSModelGroup group) {
+        for( XSParticle p : group.getChildren())
+            particle(p);
+    }
+
+    public void elementDecl(XSElementDecl decl) {
+
+        QName n = new QName(decl.getTargetNamespace(),decl.getName());
+        if(elementNames.add(n)) {
+            CElement elementBean = Ring.get(ClassSelector.class).bindToType(decl);
+            if(elementBean==null)
+                refs.add(new RawTypeSet.XmlTypeRef(decl));
+            else {
+                if(elementBean instanceof CClassInfo)
+                    refs.add(new CClassInfoRef(decl,(CClassInfo)elementBean));
+                else
+                    refs.add(new CElementInfoRef(decl,(CElementInfo)elementBean));
+            }
+        }
+    }
+
+    /**
+     * Reference to a wildcard.
+     */
+    public static final class WildcardRef extends RawTypeSet.Ref {
+        private final WildcardMode mode;
+
+        WildcardRef(XSWildcard wildcard) {
+            this.mode = getMode(wildcard);
+        }
+        WildcardRef(WildcardMode mode) {
+            this.mode = mode;
+        }
+
+        private static WildcardMode getMode(XSWildcard wildcard) {
+            switch(wildcard.getMode()) {
+            case XSWildcard.LAX:
+                return WildcardMode.LAX;
+            case XSWildcard.STRTICT:
+                return WildcardMode.STRICT;
+            case XSWildcard.SKIP:
+                return WildcardMode.SKIP;
+            default:
+                throw new IllegalStateException();
+            }
+        }
+
+        protected CTypeRef toTypeRef(CElementPropertyInfo ep) {
+            // we don't allow a mapping to typeRef if the wildcard is present
+            throw new IllegalStateException();
+        }
+
+        protected void toElementRef(CReferencePropertyInfo prop) {
+            prop.setWildcard(mode);
+        }
+
+        protected RawTypeSet.Mode canBeType(RawTypeSet parent) {
+            return RawTypeSet.Mode.MUST_BE_REFERENCE;
+        }
+
+        protected boolean isListOfValues() {
+            return false;
+        }
+
+        protected ID id() {
+            return ID.NONE;
+        }
+    }
+
+
+    /**
+     * Reference to a class that maps from an element.
+     */
+    public static final class CClassInfoRef extends RawTypeSet.Ref {
+        public final CClassInfo target;
+        public final XSElementDecl decl;
+
+        CClassInfoRef(XSElementDecl decl, CClassInfo target) {
+            this.decl = decl;
+            this.target = target;
+        }
+
+        protected CTypeRef toTypeRef(CElementPropertyInfo ep) {
+            return new CTypeRef(target,target.getElementName(),decl.isNillable(),decl.getDefaultValue());
+        }
+
+        protected void toElementRef(CReferencePropertyInfo prop) {
+            prop.getElements().add(target);
+        }
+
+        protected RawTypeSet.Mode canBeType(RawTypeSet parent) {
+            // if element substitution can occur, no way it can be mapped to a list of types
+            if(decl.getSubstitutables().size()>1)
+                return RawTypeSet.Mode.MUST_BE_REFERENCE;
+
+            return RawTypeSet.Mode.SHOULD_BE_TYPEREF;
+        }
+
+        protected boolean isListOfValues() {
+            return false;
+        }
+
+        protected ID id() {
+            return ID.NONE;
+        }
+    }
+
+    /**
+     * Reference to a class that maps from an element.
+     */
+    public static final class CElementInfoRef extends RawTypeSet.Ref {
+        public final CElementInfo target;
+        public final XSElementDecl decl;
+
+        CElementInfoRef(XSElementDecl decl, CElementInfo target) {
+            this.decl = decl;
+            this.target = target;
+        }
+
+        protected CTypeRef toTypeRef(CElementPropertyInfo ep) {
+            assert !target.isCollection();
+            CAdapter a = target.getProperty().getAdapter();
+            if(a!=null && ep!=null) ep.setAdapter(a);
+
+            return new CTypeRef(target.getContentType(),target.getElementName(),
+                decl.isNillable(),decl.getDefaultValue());
+        }
+
+        protected void toElementRef(CReferencePropertyInfo prop) {
+            prop.getElements().add(target);
+        }
+
+        protected RawTypeSet.Mode canBeType(RawTypeSet parent) {
+            // if element substitution can occur, no way it can be mapped to a list of types
+            if(decl.getSubstitutables().size()>1)
+                return RawTypeSet.Mode.MUST_BE_REFERENCE;
+
+            // we have no place to put an adater if this thing maps to a type
+            CElementPropertyInfo p = target.getProperty();
+            // if we have an adapter or IDness, which requires special
+            // annotation, and there's more than one element,
+            // we have no place to put the special annotation, so we need JAXBElement.
+            if(parent.refs.size()>1 || !parent.mul.isAtMostOnce()) {
+                if(p.getAdapter()!=null || p.id()!=ID.NONE)
+                    return RawTypeSet.Mode.MUST_BE_REFERENCE;
+            }
+
+            return RawTypeSet.Mode.SHOULD_BE_TYPEREF;
+        }
+
+        protected boolean isListOfValues() {
+            return target.getProperty().isValueList();
+        }
+
+        protected ID id() {
+            return target.getProperty().id();
+        }
+
+        protected MimeType getExpectedMimeType() {
+            return target.getProperty().getExpectedMimeType();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/RefererFinder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/RefererFinder.java
new file mode 100644
index 0000000..6538872
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/RefererFinder.java
@@ -0,0 +1,154 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+import java.util.Collections;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+
+/**
+ * Finds which {@link XSComponent}s refer to which {@link XSComplexType}s.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class RefererFinder implements XSVisitor {
+    private final Set<Object> visited = new HashSet<Object>();
+
+    private final Map<XSComponent,Set<XSComponent>> referers = new HashMap<XSComponent,Set<XSComponent>>();
+
+    public Set<XSComponent> getReferer(XSComponent src) {
+        Set<XSComponent> r = referers.get(src);
+        if(r==null) return Collections.emptySet();
+        return r;
+    }
+
+
+    public void schemaSet(XSSchemaSet xss) {
+        if(!visited.add(xss))       return;
+
+        for (XSSchema xs : xss.getSchemas()) {
+            schema(xs);
+        }
+    }
+
+    public void schema(XSSchema xs) {
+        if(!visited.add(xs))       return;
+
+        for (XSComplexType ct : xs.getComplexTypes().values()) {
+            complexType(ct);
+        }
+
+        for (XSElementDecl e : xs.getElementDecls().values()) {
+            elementDecl(e);
+        }
+    }
+
+    public void elementDecl(XSElementDecl e) {
+        if(!visited.add(e))       return;
+
+        refer(e,e.getType());
+        e.getType().visit(this);
+    }
+
+    public void complexType(XSComplexType ct) {
+        if(!visited.add(ct))       return;
+
+        refer(ct,ct.getBaseType());
+        ct.getBaseType().visit(this);
+        ct.getContentType().visit(this);
+    }
+
+    public void modelGroupDecl(XSModelGroupDecl decl) {
+        if(!visited.add(decl))  return;
+
+        modelGroup(decl.getModelGroup());
+    }
+
+    public void modelGroup(XSModelGroup group) {
+        if(!visited.add(group))  return;
+
+        for (XSParticle p : group.getChildren()) {
+            particle(p);
+        }
+    }
+
+    public void particle(XSParticle particle) {
+        // since the particle method is side-effect free, no need to check for double-visit.
+        particle.getTerm().visit(this);
+    }
+
+
+    // things we don't care
+    public void simpleType(XSSimpleType simpleType) {}
+    public void annotation(XSAnnotation ann) {}
+    public void attGroupDecl(XSAttGroupDecl decl) {}
+    public void attributeDecl(XSAttributeDecl decl) {}
+    public void attributeUse(XSAttributeUse use) {}
+    public void facet(XSFacet facet) {}
+    public void notation(XSNotation notation) {}
+    public void identityConstraint(XSIdentityConstraint decl) {}
+    public void xpath(XSXPath xp) {}
+    public void wildcard(XSWildcard wc) {}
+    public void empty(XSContentType empty) {}
+
+    /**
+     * Called for each reference to record the fact.
+     *
+     * So far we only care about references to types.
+     */
+    private void refer(XSComponent source, XSType target) {
+        Set<XSComponent> r = referers.get(target);
+        if(r==null) {
+            r = new HashSet<XSComponent>();
+            referers.put(target,r);
+        }
+        r.add(source);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/SimpleTypeBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/SimpleTypeBuilder.java
new file mode 100644
index 0000000..39fc39d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/SimpleTypeBuilder.java
@@ -0,0 +1,865 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.io.StringWriter;
+import java.math.BigInteger;
+import java.text.ParseException;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.Stack;
+
+import javax.activation.MimeTypeParseException;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JJavaName;
+import com.sun.codemodel.internal.util.JavadocEscapeWriter;
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.model.CClassInfoParent;
+import com.sun.tools.internal.xjc.model.CEnumConstant;
+import com.sun.tools.internal.xjc.model.CEnumLeafInfo;
+import com.sun.tools.internal.xjc.model.CNonElement;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.model.TypeUseFactory;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIConversion;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIEnum;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIEnumMember;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BindInfo;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.EnumMemberMode;
+import com.sun.tools.internal.xjc.util.MimeTypeRange;
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import static com.sun.xml.internal.bind.v2.WellKnownNamespace.XML_MIME_URI;
+import com.sun.xml.internal.bind.v2.runtime.SwaRefAdapter;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+import com.sun.xml.internal.xsom.XSVariety;
+import com.sun.xml.internal.xsom.impl.util.SchemaWriter;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+
+import org.xml.sax.Locator;
+
+/**
+ * Builds {@link TypeUse} from simple types.
+ *
+ * <p>
+ * This code consists of two main portions. The {@link #compose(XSSimpleType)} method
+ * and {@link #composer} forms an outer cycle, which gradually ascends the type
+ * inheritance chain until it finds the suitable binding. When it does this
+ * {@link #initiatingType} is set to the type which started binding, so that we can refer
+ * to the actual constraint facets and such that are applicable on the type.
+ *
+ * <p>
+ * For each intermediate type in the chain, the {@link #find(XSSimpleType)} method
+ * is used to find the binding on that type, sine the outer loop is doing the ascending,
+ * this method only sees if the current type has some binding available.
+ *
+ * <p>
+ * There is at least one ugly code that you need to aware of
+ * when you are modifying the code. See the documentation
+ * about <a href="package.html#stref_cust">
+ * "simple type customization at the point of reference."</a>
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class SimpleTypeBuilder extends BindingComponent {
+
+    protected final BGMBuilder builder = Ring.get(BGMBuilder.class);
+
+    private final Model model = Ring.get(Model.class);
+
+    /**
+     * The component that is refering to the simple type
+     * which we are building. This is ugly but necessary
+     * to support the customization of simple types at
+     * its point of reference. See my comment at the header
+     * of this class for details.
+     *
+     * UGLY: Implemented as a Stack of XSComponent to fix a bug
+     */
+    public final Stack<XSComponent> refererStack = new Stack<XSComponent>();
+
+    /**
+     * The type that was originally passed to this {@link SimpleTypeBuilder#build(XSSimpleType)}.
+     * Never null.
+     */
+    private XSSimpleType initiatingType;
+
+    /** {@link TypeUse}s for the built-in types. Read-only. */
+    public static final Map<String,TypeUse> builtinConversions = new HashMap<String,TypeUse>();
+
+
+    /**
+     * Entry point from outside. Builds a BGM type expression
+     * from a simple type schema component.
+     *
+     * @param type
+     *      the simple type to be bound.
+     */
+    public TypeUse build( XSSimpleType type ) {
+        XSSimpleType oldi = initiatingType;
+        this.initiatingType = type;
+
+        TypeUse e = checkRefererCustomization(type);
+        if(e==null)
+            e = compose(type);
+
+        initiatingType = oldi;
+
+        return e;
+    }
+
+    /**
+     * A version of the {@link #build(XSSimpleType)} method
+     * used to bind the definition of a class generated from
+     * the given simple type.
+     */
+    public TypeUse buildDef( XSSimpleType type ) {
+        XSSimpleType oldi = initiatingType;
+        this.initiatingType = type;
+
+        TypeUse e = type.apply(composer);
+
+        initiatingType = oldi;
+
+        return e;
+    }
+
+
+    /**
+     * Returns a javaType customization specified to the referer, if present.
+     * @return can be null.
+     */
+    private BIConversion getRefererCustomization() {
+        BindInfo info = builder.getBindInfo(getReferer());
+        BIProperty prop = info.get(BIProperty.class);
+        if(prop==null)  return null;
+        return prop.getConv();
+    }
+
+    public XSComponent getReferer() {
+        return refererStack.peek();
+    }
+
+    /**
+     * Checks if the referer has a conversion customization or not.
+     * If it does, use it to bind this simple type. Otherwise
+     * return null;
+     */
+    private TypeUse checkRefererCustomization( XSSimpleType type ) {
+
+        // assertion check. referer must be set properly
+        // before the build method is called.
+        // since the handling of the simple type point-of-reference
+        // customization is very error prone, it deserves a strict
+        // assertion check.
+        // UGLY CODE WARNING
+        XSComponent top = getReferer();
+
+        if( top instanceof XSElementDecl ) {
+            // if the parent is element type, its content type must be us.
+            XSElementDecl eref = (XSElementDecl)top;
+            assert eref.getType()==type;
+
+            // for elements, you can't use <property>,
+            // so we allow javaType to appear directly.
+            BindInfo info = builder.getBindInfo(top);
+            BIConversion conv = info.get(BIConversion.class);
+            if(conv!=null) {
+                conv.markAsAcknowledged();
+                // the conversion is given.
+                return conv.getTypeUse(type);
+            }
+            detectJavaTypeCustomization();
+        } else
+        if( top instanceof XSAttributeDecl ) {
+            XSAttributeDecl aref = (XSAttributeDecl)top;
+            assert aref.getType()==type;
+            detectJavaTypeCustomization();
+        } else
+        if( top instanceof XSComplexType ) {
+            XSComplexType tref = (XSComplexType)top;
+            assert tref.getBaseType()==type || tref.getContentType()==type;
+            detectJavaTypeCustomization();
+        } else
+        if( top == type ) {
+            // this means the simple type is built by itself and
+            // not because it's referenced by something.
+        } else
+            // unexpected referer type.
+            assert false;
+
+        // now we are certain that the referer is OK.
+        // see if it has a conversion customization.
+        BIConversion conv = getRefererCustomization();
+        if(conv!=null) {
+            conv.markAsAcknowledged();
+            // the conversion is given.
+            return conv.getTypeUse(type);
+        } else
+            // not found
+            return null;
+    }
+
+    /**
+     * Detect "javaType" customizations placed directly on simple types, rather
+     * than being enclosed by "property" and "baseType" customizations (see
+     * sec 6.8.1 of the spec).
+     *
+     * Report an error if any exist.
+     */
+    private void detectJavaTypeCustomization() {
+        BindInfo info = builder.getBindInfo(getReferer());
+        BIConversion conv = info.get(BIConversion.class);
+
+        if( conv != null ) {
+            // ack this conversion to prevent further error messages
+            conv.markAsAcknowledged();
+
+            // report the error
+            getErrorReporter().error( conv.getLocation(),
+                    Messages.ERR_UNNESTED_JAVATYPE_CUSTOMIZATION_ON_SIMPLETYPE );
+        }
+    }
+
+    /**
+     * Recursively decend the type inheritance chain to find a binding.
+     */
+    TypeUse compose( XSSimpleType t ) {
+        TypeUse e = find(t);
+        if(e!=null)     return e;
+        return t.apply(composer);
+    }
+
+    public final XSSimpleTypeFunction<TypeUse> composer = new XSSimpleTypeFunction<TypeUse>() {
+
+        public TypeUse listSimpleType(XSListSimpleType type) {
+            // bind item type individually and then compose them into a list
+            // facets on the list shouldn't be taken account when binding item types,
+            // so weed to call build(), not compose().
+            XSSimpleType itemType = type.getItemType();
+            refererStack.push(itemType);
+            TypeUse tu = TypeUseFactory.makeCollection(build(type.getItemType()));
+            refererStack.pop();
+            return tu;
+        }
+
+        public TypeUse unionSimpleType(XSUnionSimpleType type) {
+            boolean isCollection = false;
+            for( int i=0; i<type.getMemberSize(); i++ )
+                if(type.getMember(i).getVariety()==XSVariety.LIST) {
+                    isCollection = true;
+                    break;
+                }
+
+            TypeUse r = CBuiltinLeafInfo.STRING;
+            if(isCollection)
+                r = TypeUseFactory.makeCollection(r);
+            return r;
+        }
+
+        public TypeUse restrictionSimpleType(XSRestrictionSimpleType type) {
+            // just process the base type.
+            return compose(type.getSimpleBaseType());
+        }
+    };
+
+
+    /**
+     * Checks if there's any binding available on the given type.
+     *
+     * @return
+     *      null if not (which causes the {@link #compose(XSSimpleType)} method
+     *      to do ascending.
+     */
+    private TypeUse find( XSSimpleType type ) {
+        TypeUse r;
+        boolean noAutoEnum = false;
+
+        // check for user specified conversion
+        BindInfo info = builder.getBindInfo(type);
+        BIConversion conv = info.get(BIConversion.class);
+
+        if( conv!=null ) {
+            // a conversion was found
+            conv.markAsAcknowledged();
+            return conv.getTypeUse(type);
+        }
+
+        // look for enum customization, which is noather user specified conversion
+        BIEnum en = info.get(BIEnum.class);
+        if( en!=null ) {
+            en.markAsAcknowledged();
+
+            if(!en.isMapped()) {
+                noAutoEnum = true;
+            } else {
+                // if an enum customization is specified, make sure
+                // the type is OK
+                if( !canBeMappedToTypeSafeEnum(type) ) {
+                    getErrorReporter().error( en.getLocation(),
+                        Messages.ERR_CANNOT_BE_TYPE_SAFE_ENUM );
+                    getErrorReporter().error( type.getLocator(),
+                        Messages.ERR_CANNOT_BE_TYPE_SAFE_ENUM_LOCATION );
+                    // recover by ignoring this customization
+                    return null;
+                }
+                // list and union cannot be mapped to a type-safe enum,
+                // so in this stage we can safely cast it to XSRestrictionSimpleType
+                return bindToTypeSafeEnum( (XSRestrictionSimpleType)type,
+                        en.className, en.javadoc, en.members,
+                        getEnumMemberMode().getModeWithEnum(),
+                        en.getLocation() );
+            }
+        }
+
+
+        // if the type is built in, look for the default binding
+        if(type.getTargetNamespace().equals(WellKnownNamespace.XML_SCHEMA)) {
+            String name = type.getName();
+            if(name!=null) {
+                r = lookupBuiltin(name);
+                if(r!=null)
+                    return r;
+            }
+        }
+
+        // also check for swaRef
+        if(type.getTargetNamespace().equals(WellKnownNamespace.SWA_URI)) {
+            String name = type.getName();
+            if(name!=null && name.equals("swaRef"))
+                return CBuiltinLeafInfo.STRING.makeAdapted(SwaRefAdapter.class,false);
+        }
+
+
+        // see if this type should be mapped to a type-safe enumeration by default.
+        // if so, built a EnumXDucer from it and return it.
+        if(type.isRestriction() && !noAutoEnum) {
+            XSRestrictionSimpleType rst = type.asRestriction();
+            if(shouldBeMappedToTypeSafeEnumByDefault(rst)) {
+                r = bindToTypeSafeEnum(rst,null,null, Collections.<String, BIEnumMember>emptyMap(),
+                            getEnumMemberMode(),null);
+                if(r!=null)
+                    return r;
+            }
+        }
+
+        return getClassSelector()._bindToClass(type,false);
+    }
+
+    /**
+     * Returns true if a type-safe enum should be created from
+     * the given simple type by default without an explicit &lt;jaxb:enum> customization.
+     */
+    private boolean shouldBeMappedToTypeSafeEnumByDefault( XSRestrictionSimpleType type ) {
+
+        // if not, there will be a problem wrt the class name of this type safe enum type.
+        if( type.isLocal() )    return false;
+
+        // if redefined, we should map the new definition, not the old one.
+        if( type.getRedefinedBy()!=null )   return false;
+
+        List<XSFacet> facets = type.getDeclaredFacets(XSFacet.FACET_ENUMERATION);
+        if( facets.isEmpty() || facets.size()>builder.getGlobalBinding().getDefaultEnumMemberSizeCap() )
+            // if the type itself doesn't have the enumeration facet,
+            // it won't be mapped to a type-safe enum.
+            //
+            // if there are too many facets, it's not very useful
+            return false;
+
+        if( !canBeMappedToTypeSafeEnum(type) )
+            // we simply can't map this to an enumeration
+            return false;
+
+        // check for collisions among constant names. if a collision will happen,
+        // don't try to bind it to an enum.
+
+        // return true only when this type is derived from one of the "enum base type".
+        for( XSSimpleType t = type; t!=null; t=t.getSimpleBaseType() )
+            if( t.isGlobal() && builder.getGlobalBinding().canBeMappedToTypeSafeEnum(t) )
+                return true;
+
+        return false;
+    }
+
+
+    private static final Set<String> builtinTypeSafeEnumCapableTypes;
+
+    static {
+        Set<String> s = new HashSet<String>();
+
+        // see a bullet of 6.5.1 of the spec.
+        String[] typeNames = new String[] {
+            "string", "boolean", "float", "decimal", "double", "anyURI"
+        };
+
+        for(String type : typeNames)
+            s.add(type);
+
+        builtinTypeSafeEnumCapableTypes = Collections.unmodifiableSet(s);
+    }
+
+
+    /**
+     * Returns true if the given simple type can be mapped to a
+     * type-safe enum class.
+     *
+     * <p>
+     * JAXB spec places a restrictrion as to what type can be
+     * mapped to a type-safe enum. This method enforces this
+     * constraint.
+     */
+    public static boolean canBeMappedToTypeSafeEnum( XSSimpleType type ) {
+        do {
+            if( WellKnownNamespace.XML_SCHEMA.equals(type.getTargetNamespace()) ) {
+                // type must be derived from one of these types
+                String localName = type.getName();
+                if( localName!=null ) {
+                    if( localName.equals("anySimpleType") )
+                        return false;   // catch all case
+                    if( localName.equals("ID") || localName.equals("IDREF") )
+                        return false;   // not ID/IDREF
+
+                    // other allowed list
+                    if( builtinTypeSafeEnumCapableTypes.contains(localName) )
+                        return true;
+                }
+            }
+
+            type = type.getSimpleBaseType();
+        } while( type!=null );
+
+        return false;
+    }
+
+
+
+    /**
+     * Builds a type-safe enum conversion from a simple type
+     * with enumeration facets.
+     *
+     * @param className
+     *      The class name of the type-safe enum. Or null to
+     *      create a default name.
+     * @param javadoc
+     *      Additional javadoc that will be added at the beginning of the
+     *      class, or null if none is necessary.
+     * @param members
+     *      A map from enumeration values (as String) to BIEnumMember objects.
+     *      if some of the value names need to be overrided.
+     *      Cannot be null, but the map may not contain entries
+     *      for all enumeration values.
+     * @param loc
+     *      The source location where the above customizations are
+     *      specified, or null if none is available.
+     */
+    private TypeUse bindToTypeSafeEnum( XSRestrictionSimpleType type,
+                                        String className, String javadoc, Map<String,BIEnumMember> members,
+                                        EnumMemberMode mode, Locator loc ) {
+
+        if( loc==null )  // use the location of the simple type as the default
+            loc = type.getLocator();
+
+        if( className==null ) {
+            // infer the class name. For this to be possible,
+            // the simple type must be a global one.
+            if( !type.isGlobal() ) {
+                getErrorReporter().error( loc, Messages.ERR_NO_ENUM_NAME_AVAILABLE );
+                // recover by returning a meaningless conversion
+                return CBuiltinLeafInfo.STRING;
+            }
+            className = type.getName();
+        }
+        // we apply name conversion in any case
+        className = builder.getNameConverter().toClassName(className);
+
+        {// compute Javadoc
+            StringWriter out = new StringWriter();
+            SchemaWriter sw = new SchemaWriter(new JavadocEscapeWriter(out));
+            type.visit((XSVisitor)sw);
+
+            if(javadoc!=null)   javadoc += "\n\n";
+            else                javadoc = "";
+
+            javadoc += Messages.format( Messages.JAVADOC_HEADING, type.getName() )
+                +"\n<p>\n<pre>\n"+out.getBuffer()+"</pre>";
+
+        }
+
+        // build base type
+        refererStack.push(type.getSimpleBaseType());
+        TypeUse use = build(type.getSimpleBaseType());
+        refererStack.pop();
+
+        if(use.isCollection())
+            return null;    // can't bind a list to enum constant
+
+        CNonElement baseDt = (CNonElement)use.getInfo();   // for now just ignore that case
+
+        if(baseDt instanceof CClassInfo)
+            return null;    // can't bind to an enum if the base is a class, since we don't have the value constrctor
+
+        // if the member names collide, re-generate numbered constant names.
+        XSFacet[] errorRef = new XSFacet[1];
+        List<CEnumConstant> memberList = buildCEnumConstants(type, false, members, errorRef);
+        if(memberList==null || checkMemberNameCollision(memberList)!=null) {
+            switch(mode) {
+            case SKIP:
+                // abort
+                return null;
+            case ERROR:
+                // error
+                if(memberList==null) {
+                    getErrorReporter().error( errorRef[0].getLocator(),
+                        Messages.ERR_CANNOT_GENERATE_ENUM_NAME,
+                        errorRef[0].getValue() );
+                } else {
+                    CEnumConstant[] collision = checkMemberNameCollision(memberList);
+                    getErrorReporter().error( collision[0].getLocator(),
+                        Messages.ERR_ENUM_MEMBER_NAME_COLLISION,
+                        collision[0].getName() );
+                    getErrorReporter().error( collision[1].getLocator(),
+                        Messages.ERR_ENUM_MEMBER_NAME_COLLISION_RELATED );
+                }
+                return null;    // recover from error
+            case GENERATE:
+                // generate
+                memberList = buildCEnumConstants(type,true,members,null);
+                break;
+            }
+        }
+
+        QName typeName = null;
+        if(type.isGlobal())
+            typeName = new QName(type.getTargetNamespace(),type.getName());
+
+
+        // use the name of the simple type as the name of the class.
+        CClassInfoParent scope;
+        if(type.isGlobal())
+            scope = new CClassInfoParent.Package(getClassSelector().getPackage(type.getTargetNamespace()));
+        else
+            scope = getClassSelector().getClassScope();
+        CEnumLeafInfo xducer = new CEnumLeafInfo( model, typeName, scope,
+            className, baseDt, memberList, type,
+            builder.getBindInfo(type).toCustomizationList(), loc );
+        xducer.javadoc = javadoc;
+
+        BIConversion conv = new BIConversion.Static( type.getLocator(),xducer);
+        conv.markAsAcknowledged();
+
+        // attach this new conversion object to this simple type
+        // so that successive look up will use the same object.
+        builder.getOrCreateBindInfo(type).addDecl(conv);
+
+        return conv.getTypeUse(type);
+    }
+
+    /**
+     *
+     * @param errorRef
+     *      if constant names couldn't be generated, return a reference to that enum facet.
+     * @return
+     *      null if unable to generate names for some of the constants.
+     */
+    private List<CEnumConstant> buildCEnumConstants(XSRestrictionSimpleType type, boolean needsToGenerateMemberName, Map<String, BIEnumMember> members, XSFacet[] errorRef) {
+        List<CEnumConstant> memberList = new ArrayList<CEnumConstant>();
+        int idx=1;
+        for( XSFacet facet : type.getDeclaredFacets(XSFacet.FACET_ENUMERATION)) {
+            String name=null;
+            String mdoc=null;
+
+            if( needsToGenerateMemberName ) {
+                // generate names for all member names.
+                // this will even override names specified by the user. that's crazy.
+                name = "VALUE_"+(idx++);
+            } else {
+                String facetValue = facet.getValue().value;
+                BIEnumMember mem = members.get(facetValue);
+                if( mem==null )
+                    // look at the one attached to the facet object
+                    mem = builder.getBindInfo(facet).get(BIEnumMember.class);
+
+                if( mem!=null ) {
+                    name = mem.name;
+                    mdoc = mem.javadoc;
+                }
+
+                if(name==null) {
+                    StringBuilder sb = new StringBuilder();
+                    for( int i=0; i<facetValue.length(); i++) {
+                        char ch = facetValue.charAt(i);
+                        if(Character.isJavaIdentifierPart(ch))
+                            sb.append(ch);
+                        else
+                            sb.append('_');
+                    }
+                    name = model.getNameConverter().toConstantName(sb.toString());
+                }
+            }
+
+            if(!JJavaName.isJavaIdentifier(name)) {
+                if(errorRef!=null)  errorRef[0] = facet;
+                return null;    // unable to generate a name
+            }
+
+            memberList.add(new CEnumConstant(name,mdoc,facet.getValue().value,facet.getLocator()));
+        }
+        return memberList;
+    }
+
+    /**
+     * Returns non-null if {@link CEnumConstant}s have name collisions among them.
+     *
+     * @return
+     *      if there's a collision, return two {@link CEnumConstant}s that collided.
+     *      otherwise return null.
+     */
+    private CEnumConstant[] checkMemberNameCollision( List<CEnumConstant> memberList ) {
+        Map<String,CEnumConstant> names = new HashMap<String,CEnumConstant>();
+        for (CEnumConstant c : memberList) {
+            CEnumConstant old = names.put(c.getName(),c);
+            if(old!=null)
+                // collision detected
+                return new CEnumConstant[]{old,c};
+        }
+        return null;
+    }
+
+
+
+    private EnumMemberMode getEnumMemberMode() {
+        return builder.getGlobalBinding().getEnumMemberMode();
+    }
+
+    private TypeUse lookupBuiltin( String typeLocalName ) {
+        if(typeLocalName.equals("integer") || typeLocalName.equals("long")) {
+            /*
+                attempt an optimization so that we can
+                improve the binding for types like this:
+
+                <simpleType>
+                  <restriciton baseType="integer">
+                    <maxInclusive value="100" />
+                  </
+                </
+
+                ... to int, not BigInteger.
+            */
+
+            BigInteger xe = readFacet(XSFacet.FACET_MAXEXCLUSIVE,-1);
+            BigInteger xi = readFacet(XSFacet.FACET_MAXINCLUSIVE,0);
+            BigInteger max = min(xe,xi);    // most restrictive one takes precedence
+
+            if(max!=null) {
+                BigInteger ne = readFacet(XSFacet.FACET_MINEXCLUSIVE,+1);
+                BigInteger ni = readFacet(XSFacet.FACET_MININCLUSIVE,0);
+                BigInteger min = max(ne,ni);
+
+                if(min!=null) {
+                    if(min.compareTo(INT_MIN )>=0 && max.compareTo(INT_MAX )<=0)
+                        typeLocalName = "int";
+                    else
+                    if(min.compareTo(LONG_MIN)>=0 && max.compareTo(LONG_MAX)<=0)
+                        typeLocalName = "long";
+                }
+            }
+        } else
+        if(typeLocalName.equals("boolean") && isRestrictedTo0And1()) {
+            // this is seen in the SOAP schema and too common to ignore
+            return CBuiltinLeafInfo.BOOLEAN_ZERO_OR_ONE;
+        } else
+        if(typeLocalName.equals("base64Binary")) {
+            return lookupBinaryTypeBinding();
+        } else
+        if(typeLocalName.equals("anySimpleType")) {
+            if(getReferer() instanceof XSAttributeDecl || getReferer() instanceof XSSimpleType)
+                return CBuiltinLeafInfo.STRING;
+            else
+                return CBuiltinLeafInfo.ANYTYPE;
+        }
+        return builtinConversions.get(typeLocalName);
+    }
+
+    /**
+     * Decides the way xs:base64Binary binds.
+     *
+     * This method checks the expected media type.
+     */
+    private TypeUse lookupBinaryTypeBinding() {
+        XSComponent referer = getReferer();
+        String emt = referer.getForeignAttribute(XML_MIME_URI,"expectedContentTypes");
+        if(emt!=null) {
+            try {
+                // see http://www.xml.com/lpt/a/2004/07/21/dive.html
+                List<MimeTypeRange> types = MimeTypeRange.parseRanges(emt);
+                MimeTypeRange mt = MimeTypeRange.merge(types);
+
+                // see spec table I-1 in appendix I section 2.1.1 for bindings
+                if(mt.majorType.equals("image"))
+                    return CBuiltinLeafInfo.IMAGE.makeMimeTyped(mt.toMimeType());
+
+                if(( mt.majorType.equals("application") || mt.majorType.equals("text"))
+                        && isXml(mt.subType))
+                    return CBuiltinLeafInfo.XML_SOURCE.makeMimeTyped(mt.toMimeType());
+
+                if((mt.majorType.equals("text") && (mt.subType.equals("plain")) )) {
+                    return CBuiltinLeafInfo.STRING.makeMimeTyped(mt.toMimeType());
+                }
+
+                return CBuiltinLeafInfo.DATA_HANDLER.makeMimeTyped(mt.toMimeType());
+            } catch (ParseException e) {
+                getErrorReporter().error( referer.getLocator(),
+                    Messages.format(Messages.ERR_ILLEGAL_EXPECTED_MIME_TYPE,emt, e.getMessage()) );
+                // recover by using the default
+            } catch (MimeTypeParseException e) {
+                getErrorReporter().error( referer.getLocator(),
+                    Messages.format(Messages.ERR_ILLEGAL_EXPECTED_MIME_TYPE,emt, e.getMessage()) );
+            }
+        }
+        // default
+        return CBuiltinLeafInfo.BASE64_BYTE_ARRAY;
+    }
+
+    /**
+     * Returns true if the specified sub-type is an XML type.
+     */
+    private boolean isXml(String subType) {
+        return subType.equals("xml") || subType.endsWith("+xml");
+    }
+
+    /**
+     * Returns true if the {@link #initiatingType} is restricted
+     * to '0' and '1'. This logic is not complete, but it at least
+     * finds the such definition in SOAP @mustUnderstand.
+     */
+    private boolean isRestrictedTo0And1() {
+        XSFacet pattern = initiatingType.getFacet(XSFacet.FACET_PATTERN);
+        if(pattern!=null) {
+            String v = pattern.getValue().value;
+            if(v.equals("0|1") || v.equals("1|0") || v.equals("\\d"))
+                return true;
+        }
+        XSFacet enumf = initiatingType.getFacet(XSFacet.FACET_ENUMERATION);
+        if(enumf!=null) {
+            String v = enumf.getValue().value;
+            if(v.equals("0") || v.equals("1"))
+                return true;
+        }
+        return false;
+    }
+
+    private BigInteger readFacet(String facetName,int offset) {
+        XSFacet me = initiatingType.getFacet(facetName);
+        if(me==null)
+            return null;
+        BigInteger bi = DatatypeConverterImpl._parseInteger(me.getValue().value);
+        if(offset!=0)
+            bi = bi.add(BigInteger.valueOf(offset));
+        return bi;
+    }
+
+    private BigInteger min(BigInteger a, BigInteger b) {
+        if(a==null) return b;
+        if(b==null) return a;
+        return a.min(b);
+    }
+
+    private BigInteger max(BigInteger a, BigInteger b) {
+        if(a==null) return b;
+        if(b==null) return a;
+        return a.max(b);
+    }
+
+    private static final BigInteger LONG_MIN = BigInteger.valueOf(Long.MIN_VALUE);
+    private static final BigInteger LONG_MAX = BigInteger.valueOf(Long.MAX_VALUE);
+    private static final BigInteger INT_MIN = BigInteger.valueOf(Integer.MIN_VALUE);
+    private static final BigInteger INT_MAX = BigInteger.valueOf(Integer.MAX_VALUE);
+
+    static {
+        // list of datatypes which have built-in conversions.
+        // note that although xs:token and xs:normalizedString are not
+        // specified in the spec, they need to be here because they
+        // have different whitespace normalization semantics.
+        Map<String,TypeUse> m = builtinConversions;
+
+        // TODO: this is so dumb
+        m.put("string",         CBuiltinLeafInfo.STRING);
+        m.put("anyURI",         CBuiltinLeafInfo.STRING);
+        m.put("boolean",        CBuiltinLeafInfo.BOOLEAN);
+        // we'll also look at the expected media type, so don't just add this to the map
+        // m.put("base64Binary",   CBuiltinLeafInfo.BASE64_BYTE_ARRAY);
+        m.put("hexBinary",      CBuiltinLeafInfo.HEXBIN_BYTE_ARRAY);
+        m.put("float",          CBuiltinLeafInfo.FLOAT);
+        m.put("decimal",        CBuiltinLeafInfo.BIG_DECIMAL);
+        m.put("integer",        CBuiltinLeafInfo.BIG_INTEGER);
+        m.put("long",           CBuiltinLeafInfo.LONG);
+        m.put("unsignedInt",    CBuiltinLeafInfo.LONG);
+        m.put("int",            CBuiltinLeafInfo.INT);
+        m.put("unsignedShort",  CBuiltinLeafInfo.INT);
+        m.put("short",          CBuiltinLeafInfo.SHORT);
+        m.put("unsignedByte",   CBuiltinLeafInfo.SHORT);
+        m.put("byte",           CBuiltinLeafInfo.BYTE);
+        m.put("double",         CBuiltinLeafInfo.DOUBLE);
+        m.put("QName",          CBuiltinLeafInfo.QNAME);
+        m.put("NOTATION",       CBuiltinLeafInfo.QNAME);
+        m.put("dateTime",       CBuiltinLeafInfo.CALENDAR);
+        m.put("date",           CBuiltinLeafInfo.CALENDAR);
+        m.put("time",           CBuiltinLeafInfo.CALENDAR);
+        m.put("gYearMonth",     CBuiltinLeafInfo.CALENDAR);
+        m.put("gYear",          CBuiltinLeafInfo.CALENDAR);
+        m.put("gMonthDay",      CBuiltinLeafInfo.CALENDAR);
+        m.put("gDay",           CBuiltinLeafInfo.CALENDAR);
+        m.put("gMonth",         CBuiltinLeafInfo.CALENDAR);
+        m.put("duration",       CBuiltinLeafInfo.DURATION);
+        m.put("token",          CBuiltinLeafInfo.TOKEN);
+        m.put("normalizedString",CBuiltinLeafInfo.NORMALIZED_STRING);
+        m.put("ID",             CBuiltinLeafInfo.ID);
+        m.put("IDREF",          CBuiltinLeafInfo.IDREF);
+        // TODO: handling dateTime, time, and date type
+//        String[] names = {
+//            "date", "dateTime", "time", "hexBinary" };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/UnusedCustomizationChecker.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/UnusedCustomizationChecker.java
new file mode 100644
index 0000000..9a424a1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/UnusedCustomizationChecker.java
@@ -0,0 +1,244 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Set;
+
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIDeclaration;
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttContainer;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+
+/**
+ * Reports all unacknowledged customizations as errors.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class UnusedCustomizationChecker extends BindingComponent implements XSVisitor, XSSimpleTypeVisitor {
+    private final BGMBuilder builder = Ring.get(BGMBuilder.class);
+
+    private final Set<XSComponent> visitedComponents = new HashSet<XSComponent>();
+
+    /**
+     * Runs the check.
+     */
+    void run() {
+        for( XSSchema s : Ring.get(XSSchemaSet.class).getSchemas() ) {
+            schema(s);
+            run( s.getAttGroupDecls() );
+            run( s.getAttributeDecls() );
+            run( s.getComplexTypes() );
+            run( s.getElementDecls() );
+            run( s.getModelGroupDecls() );
+            run( s.getNotations() );
+            run( s.getSimpleTypes() );
+        }
+    }
+
+    private void run( Map<String,? extends XSComponent> col ) {
+        for( XSComponent c : col.values() )
+            c.visit(this);
+    }
+
+
+    /**
+     * Checks unused customizations on this component
+     * and returns true if this is the first time this
+     * component is checked.
+     */
+    private boolean check( XSComponent c ) {
+        if( !visitedComponents.add(c) )
+            return false;   // already processed
+
+        for( BIDeclaration decl : builder.getBindInfo(c).getDecls() )
+            check(decl, c);
+
+        return true;
+    }
+
+    private void check(BIDeclaration decl, XSComponent c) {
+        if( !decl.isAcknowledged() ) {
+            getErrorReporter().error(
+                decl.getLocation(),
+                Messages.ERR_UNACKNOWLEDGED_CUSTOMIZATION,
+                decl.getName().getLocalPart()
+                );
+            getErrorReporter().error(
+                c.getLocator(),
+                Messages.ERR_UNACKNOWLEDGED_CUSTOMIZATION_LOCATION);
+            // mark it as acknowledged to avoid
+            // duplicated error messages.
+            decl.markAsAcknowledged();
+        }
+        for (BIDeclaration d : decl.getChildren())
+            check(d,c);
+    }
+
+
+    public void annotation(XSAnnotation ann) {}
+
+    public void attGroupDecl(XSAttGroupDecl decl) {
+        if(check(decl))
+            attContainer(decl);
+    }
+
+    public void attributeDecl(XSAttributeDecl decl) {
+        if(check(decl))
+            decl.getType().visit((XSSimpleTypeVisitor)this);
+    }
+
+    public void attributeUse(XSAttributeUse use) {
+        if(check(use))
+            use.getDecl().visit(this);
+    }
+
+    public void complexType(XSComplexType type) {
+        if(check(type)) {
+            // don't need to check the base type -- it must be global, thus
+            // it is covered already
+            type.getContentType().visit(this);
+            attContainer(type);
+        }
+    }
+
+    private void attContainer( XSAttContainer cont ) {
+        for( Iterator itr = cont.iterateAttGroups(); itr.hasNext(); )
+            ((XSAttGroupDecl)itr.next()).visit(this);
+
+        for( Iterator itr = cont.iterateDeclaredAttributeUses(); itr.hasNext(); )
+            ((XSAttributeUse)itr.next()).visit(this);
+
+        XSWildcard wc = cont.getAttributeWildcard();
+        if(wc!=null)        wc.visit(this);
+    }
+
+    public void schema(XSSchema schema) {
+        check(schema);
+    }
+
+    public void facet(XSFacet facet) {
+        check(facet);
+    }
+
+    public void notation(XSNotation notation) {
+        check(notation);
+    }
+
+    public void wildcard(XSWildcard wc) {
+        check(wc);
+    }
+
+    public void modelGroupDecl(XSModelGroupDecl decl) {
+        if(check(decl))
+            decl.getModelGroup().visit(this);
+    }
+
+    public void modelGroup(XSModelGroup group) {
+        if(check(group)) {
+            for( int i=0; i<group.getSize(); i++ )
+                group.getChild(i).visit(this);
+        }
+    }
+
+    public void elementDecl(XSElementDecl decl) {
+        if(check(decl)) {
+            decl.getType().visit(this);
+            for( XSIdentityConstraint id : decl.getIdentityConstraints() )
+                id.visit(this);
+        }
+    }
+
+    public void simpleType(XSSimpleType simpleType) {
+        if(check(simpleType))
+            simpleType.visit( (XSSimpleTypeVisitor)this );
+    }
+
+    public void particle(XSParticle particle) {
+        if(check(particle))
+            particle.getTerm().visit(this);
+    }
+
+    public void empty(XSContentType empty) {
+        check(empty);
+    }
+
+    public void listSimpleType(XSListSimpleType type) {
+        if(check(type))
+            type.getItemType().visit((XSSimpleTypeVisitor)this);
+    }
+
+    public void restrictionSimpleType(XSRestrictionSimpleType type) {
+        if(check(type))
+            type.getBaseType().visit(this);
+    }
+
+    public void unionSimpleType(XSUnionSimpleType type) {
+        if(check(type)) {
+            for( int i=0; i<type.getMemberSize(); i++ )
+                type.getMember(i).visit((XSSimpleTypeVisitor)this);
+        }
+    }
+
+    public void identityConstraint(XSIdentityConstraint id) {
+        if(check(id)) {
+            id.getSelector().visit(this);
+            for( XSXPath xp : id.getFields() )
+                xp.visit(this);
+        }
+    }
+
+    public void xpath(XSXPath xp) {
+        check(xp);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/WildcardNameClassBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/WildcardNameClassBuilder.java
new file mode 100644
index 0000000..2710125
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/WildcardNameClassBuilder.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.tools.internal.xjc.reader.xmlschema;
+
+import java.util.Iterator;
+
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.visitor.XSWildcardFunction;
+
+import com.sun.xml.internal.rngom.nc.AnyNameExceptNameClass;
+import com.sun.xml.internal.rngom.nc.ChoiceNameClass;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import com.sun.xml.internal.rngom.nc.NsNameClass;
+
+/**
+ * Builds a name class representation of a wildcard.
+ *
+ * <p>
+ * Singleton. Use the build method to create a NameClass.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class WildcardNameClassBuilder implements XSWildcardFunction<NameClass> {
+    private WildcardNameClassBuilder() {}
+
+    private static final XSWildcardFunction<NameClass> theInstance =
+        new WildcardNameClassBuilder();
+
+    public static NameClass build( XSWildcard wc ) {
+        return wc.apply(theInstance);
+    }
+
+    public NameClass any(XSWildcard.Any wc) {
+        return NameClass.ANY;
+    }
+
+    public NameClass other(XSWildcard.Other wc) {
+        return new AnyNameExceptNameClass(
+            new ChoiceNameClass(
+                new NsNameClass(""),
+                new NsNameClass(wc.getOtherNamespace())));
+    }
+
+    public NameClass union(XSWildcard.Union wc) {
+        NameClass nc = null;
+        for (Iterator itr = wc.iterateNamespaces(); itr.hasNext();) {
+            String ns = (String) itr.next();
+
+            if(nc==null)    nc = new NsNameClass(ns);
+            else
+                nc = new ChoiceNameClass(nc,new NsNameClass(ns));
+        }
+
+        // there should be at least one.
+        assert nc!=null;
+
+        return nc;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/AbstractDeclarationImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/AbstractDeclarationImpl.java
new file mode 100644
index 0000000..f45c12c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/AbstractDeclarationImpl.java
@@ -0,0 +1,87 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.util.Collection;
+import java.util.Collections;
+
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.BGMBuilder;
+import com.sun.xml.internal.bind.annotation.XmlLocation;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.xml.sax.Locator;
+
+/**
+ * Abstract partial implementation of {@link BIDeclaration}
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+abstract class AbstractDeclarationImpl implements BIDeclaration {
+
+    @Deprecated // eventually delete this in favor of using JAXB
+    protected AbstractDeclarationImpl(Locator loc) {
+        this.loc = loc;
+    }
+
+    protected AbstractDeclarationImpl() {}
+
+
+    @XmlLocation
+    Locator loc;    // set by JAXB
+    public Locator getLocation() { return loc; }
+
+    protected BindInfo parent;
+    public void setParent(BindInfo p) { this.parent=p; }
+
+    protected final XSComponent getOwner() {
+        return parent.getOwner();
+    }
+    protected final BGMBuilder getBuilder() {
+        return parent.getBuilder();
+    }
+    protected final JCodeModel getCodeModel() {
+        return Ring.get(JCodeModel.class);
+    }
+
+
+    private boolean isAcknowledged = false;
+
+    public final boolean isAcknowledged() { return isAcknowledged; }
+
+    public void onSetOwner() {
+    }
+
+    public Collection<BIDeclaration> getChildren() {
+        return Collections.emptyList();
+    }
+
+    public void markAsAcknowledged() {
+        isAcknowledged = true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/AnnotationParserFactoryImpl.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/AnnotationParserFactoryImpl.java
new file mode 100644
index 0000000..210738c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/AnnotationParserFactoryImpl.java
@@ -0,0 +1,186 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.util.Collections;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.UnmarshallerHandler;
+import javax.xml.bind.helpers.DefaultValidationEventHandler;
+import javax.xml.validation.ValidatorHandler;
+
+import com.sun.tools.internal.xjc.Options;
+import com.sun.tools.internal.xjc.SchemaCache;
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.xsom.parser.AnnotationContext;
+import com.sun.xml.internal.xsom.parser.AnnotationParser;
+import com.sun.xml.internal.xsom.parser.AnnotationParserFactory;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * Implementation of XSOM {@link AnnotationParserFactory} that
+ * parses JAXB customization declarations.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class AnnotationParserFactoryImpl implements AnnotationParserFactory {
+    public AnnotationParserFactoryImpl(Options opts) {
+        this.options=opts;
+    }
+
+    private final Options options;
+    /**
+     * Lazily created validator, so that the schema for binding won't be
+     * prepared unless absolutely necessary.
+     */
+    private ValidatorHandler validator;
+
+    /**
+     * Lazily parsed schema for the binding file.
+     */
+    private static final SchemaCache bindingFileSchema = new SchemaCache(AnnotationParserFactoryImpl.class.getResource("binding.xsd"));
+
+    /**
+     * Lazily prepared {@link JAXBContext}.
+     */
+    private static JAXBContextImpl customizationContext;
+
+    private static JAXBContextImpl getJAXBContext() {
+        synchronized(AnnotationParserFactoryImpl.class) {
+            try {
+                if(customizationContext==null)
+                    customizationContext = new JAXBContextImpl(
+                        new Class[] {
+                            BindInfo.class, // for xs:annotation
+                            BIClass.class,
+                            BIConversion.User.class,
+                            BIConversion.UserAdapter.class,
+                            BIDom.class,
+                            BIXDom.class,
+                            BIEnum.class,
+                            BIEnumMember.class,
+                            BIGlobalBinding.class,
+                            BIProperty.class,
+                            BISchemaBinding.class
+                        }, Collections.<TypeReference>emptyList(), null, false);
+                return customizationContext;
+            } catch (JAXBException e) {
+                throw new AssertionError(e);
+            }
+        }
+    }
+
+    public AnnotationParser create() {
+        return new AnnotationParser() {
+            private Unmarshaller u = getJAXBContext().createUnmarshaller();
+
+            private UnmarshallerHandler handler;
+
+            public ContentHandler getContentHandler(
+                AnnotationContext context, String parentElementName,
+                final ErrorHandler errorHandler, EntityResolver entityResolver ) {
+
+                // return a ContentHandler that validates the customization and also
+                // parses them into the internal structure.
+                if(handler!=null)
+                    // interface contract violation.
+                    // this method will be called only once.
+                    throw new AssertionError();
+
+                if(options.debugMode)
+                    try {
+                        u.setEventHandler(new DefaultValidationEventHandler());
+                    } catch (JAXBException e) {
+                        throw new AssertionError(e);    // ridiculous!
+                    }
+
+                handler = u.getUnmarshallerHandler();
+
+                // configure so that the validator will receive events for JAXB islands
+                return new ForkingFilter(handler) {
+                    @Override
+                    public void startElement(String uri, String localName, String qName, Attributes atts) throws SAXException {
+                        super.startElement(uri, localName, qName, atts);
+                        if((uri.equals(Const.JAXB_NSURI) || uri.equals(Const.XJC_EXTENSION_URI))
+                        && getSideHandler()==null) {
+                            // set up validator
+                            if(validator==null)
+                                validator = bindingFileSchema.newValidator();
+                            validator.setErrorHandler(errorHandler);
+                            startForking(uri,localName,qName,atts,new ValidatorProtecter(validator));
+                        }
+                    }
+                };
+            }
+
+            public Object getResult( Object existing ) {
+                if(handler==null)
+                    // interface contract violation.
+                    // the getContentHandler method must have been called.
+                    throw new AssertionError();
+
+                try {
+                    BindInfo result = (BindInfo)handler.getResult();
+
+                    if(existing!=null) {
+                        BindInfo bie = (BindInfo)existing;
+                        bie.absorb(result);
+                        return bie;
+                    } else {
+                        if(!result.isPointless())
+                            return result;   // just annotation. no meaningful customization
+                        else
+                            return null;
+                    }
+                } catch (JAXBException e) {
+                    throw new AssertionError(e);
+                }
+            }
+        };
+    }
+
+    private static final class ValidatorProtecter extends XMLFilterImpl {
+        public ValidatorProtecter(ContentHandler h) {
+            setContentHandler(h);
+        }
+
+        public void startPrefixMapping(String prefix, String uri) throws SAXException {
+            // work around a bug in the validator implementation in Tiger
+            super.startPrefixMapping(prefix.intern(),uri);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIClass.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIClass.java
new file mode 100644
index 0000000..4e32c91
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIClass.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+
+import org.xml.sax.Locator;
+
+/**
+ * Class declaration.
+ *
+ * This customization turns arbitrary schema component into a Java
+ * content interface.
+ *
+ * <p>
+ * This customization is acknowledged by the ClassSelector.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+@XmlRootElement(name="class")
+public final class BIClass extends AbstractDeclarationImpl {
+
+    public BIClass( Locator loc, String _className, String _implClass, String _javadoc ) {
+        super(loc);
+        this.className = _className;
+        this.javadoc = _javadoc;
+        this.userSpecifiedImplClass = _implClass;
+    }
+
+    protected BIClass() {
+    }
+
+    @XmlAttribute(name="name")
+    private String className;
+
+    /**
+     * Gets the specified class name, or null if not specified.
+     *
+     * @return
+     *      Returns a class name. The caller should <em>NOT</em>
+     *      apply XML-to-Java name conversion to the name
+     *      returned from this method.
+     */
+    public String getClassName() {
+        if( className==null )   return null;
+
+        BIGlobalBinding gb = getBuilder().getGlobalBinding();
+        NameConverter nc = getBuilder().model.getNameConverter();
+
+        if(gb.isJavaNamingConventionEnabled()) return nc.toClassName(className);
+        else
+            // don't change it
+            return className;
+    }
+
+    @XmlAttribute(name="implClass")
+    private String userSpecifiedImplClass;
+
+    /**
+     * Gets the fully qualified name of the
+     * user-specified implementation class, if any.
+     * Or null.
+     */
+    public String getUserSpecifiedImplClass() {
+        return userSpecifiedImplClass;
+    }
+
+    @XmlElement
+    private String javadoc;
+    /**
+     * Gets the javadoc comment specified in the customization.
+     * Can be null if none is specified.
+     */
+    public String getJavadoc() { return javadoc; }
+
+    public QName getName() { return NAME; }
+
+    /** Name of this declaration. */
+    public static final QName NAME = new QName(
+        Const.JAXB_NSURI, "class" );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIConversion.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIConversion.java
new file mode 100644
index 0000000..265ffe1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIConversion.java
@@ -0,0 +1,340 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.DatatypeConverter;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JClassAlreadyExistsException;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JExpr;
+import com.sun.codemodel.internal.JExpression;
+import com.sun.codemodel.internal.JMethod;
+import com.sun.codemodel.internal.JMod;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JType;
+import com.sun.codemodel.internal.JVar;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.model.CAdapter;
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.model.TypeUseFactory;
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.TypeUtil;
+import com.sun.tools.internal.xjc.reader.xmlschema.ClassSelector;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.xsom.XSSimpleType;
+
+import org.xml.sax.Locator;
+
+/**
+ * Conversion declaration.
+ *
+ * <p>
+ * A conversion declaration specifies how an XML type gets mapped
+ * to a Java type.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class BIConversion extends AbstractDeclarationImpl {
+    @Deprecated
+    public BIConversion( Locator loc ) {
+        super(loc);
+    }
+
+    protected BIConversion() {
+    }
+
+    /**
+     * Gets the {@link TypeUse} object that this conversion represents.
+     * <p>
+     * The returned {@link TypeUse} object is properly adapted.
+     *
+     * @param owner
+     *      A {@link BIConversion} is always associated with one
+     *      {@link XSSimpleType}, but that's not always available
+     *      when a {@link BIConversion} is built. So we pass this
+     *      as a parameter to this method.
+     */
+    public abstract TypeUse getTypeUse( XSSimpleType owner );
+
+    public QName getName() { return NAME; }
+
+    /** Name of the conversion declaration. */
+    public static final QName NAME = new QName(
+        Const.JAXB_NSURI, "conversion" );
+
+    /**
+     * Implementation that returns a statically-determined constant {@link TypeUse}.
+     */
+    public static final class Static extends BIConversion {
+        /**
+         * Always non-null.
+         */
+        private final TypeUse transducer;
+
+        public Static(Locator loc, TypeUse transducer) {
+            super(loc);
+            this.transducer = transducer;
+        }
+
+        public TypeUse getTypeUse(XSSimpleType owner) {
+            return transducer;
+        }
+    }
+
+    /**
+     * User-specified &lt;javaType> customization.
+     *
+     * The parse/print methods are allowed to be null,
+     * and their default values are determined based on the
+     * owner of the token.
+     */
+    @XmlRootElement(name="javaType")
+    public static class User extends BIConversion {
+        @XmlAttribute
+        private String parseMethod;
+        @XmlAttribute
+        private String printMethod;
+        @XmlAttribute(name="name")
+        private String type = "java.lang.String";
+
+        /**
+         * If null, computed from {@link #type}.
+         * Sometimes this can be set instead of {@link #type}.
+         */
+        private JType inMemoryType;
+
+        public User(Locator loc, String parseMethod, String printMethod, JType inMemoryType) {
+            super(loc);
+            this.parseMethod = parseMethod;
+            this.printMethod = printMethod;
+            this.inMemoryType = inMemoryType;
+        }
+
+        public User() {
+        }
+
+        /**
+         * Cache used by {@link #getTypeUse(XSSimpleType)} to improve the performance.
+         */
+        private TypeUse typeUse;
+
+        public TypeUse getTypeUse(XSSimpleType owner) {
+            if(typeUse!=null)
+                return typeUse;
+
+            JCodeModel cm = getCodeModel();
+
+            if(inMemoryType==null)
+                inMemoryType = TypeUtil.getType(cm,type,Ring.get(ErrorReceiver.class),getLocation());
+
+            JDefinedClass adapter = generateAdapter(parseMethodFor(owner),printMethodFor(owner),owner);
+
+            // XmlJavaType customization always converts between string and an user-defined type.
+            typeUse = TypeUseFactory.adapt(CBuiltinLeafInfo.STRING,new CAdapter(adapter));
+
+            return typeUse;
+        }
+
+        /**
+         * generate the adapter class.
+         */
+        private JDefinedClass generateAdapter(String parseMethod, String printMethod,XSSimpleType owner) {
+            JDefinedClass adapter = null;
+
+            int id = 1;
+            while(adapter==null) {
+                try {
+                    JPackage pkg = Ring.get(ClassSelector.class).getClassScope().getOwnerPackage();
+                    adapter = pkg._class("Adapter"+id);
+                } catch (JClassAlreadyExistsException e) {
+                    // try another name in search for an unique name.
+                    // this isn't too efficient, but we expect people to usually use
+                    // a very small number of adapters.
+                    id++;
+                }
+            }
+
+            JClass bim = inMemoryType.boxify();
+
+            adapter._extends(getCodeModel().ref(XmlAdapter.class).narrow(String.class).narrow(bim));
+
+            JMethod unmarshal = adapter.method(JMod.PUBLIC, bim, "unmarshal");
+            JVar $value = unmarshal.param(String.class, "value");
+
+            JExpression inv;
+
+            if( parseMethod.equals("new") ) {
+                // "new" indicates that the constructor of the target type
+                // will do the unmarshalling.
+
+                // RESULT: new <type>()
+                inv = JExpr._new(bim).arg($value);
+            } else {
+                int idx = parseMethod.lastIndexOf('.');
+                if(idx<0) {
+                    // parseMethod specifies the static method of the target type
+                    // which will do the unmarshalling.
+
+                    // because of an error check at the constructor,
+                    // we can safely assume that this cast works.
+                    inv = bim.staticInvoke(parseMethod).arg($value);
+                } else {
+                    inv = JExpr.direct(parseMethod+"(value)");
+                }
+            }
+            unmarshal.body()._return(inv);
+
+
+            JMethod marshal = adapter.method(JMod.PUBLIC, String.class, "marshal");
+            $value = marshal.param(bim,"value");
+
+            if(printMethod.startsWith("javax.xml.bind.DatatypeConverter.")) {
+                // UGLY: if this conversion is the system-driven conversion,
+                // check for null
+                marshal.body()._if($value.eq(JExpr._null()))._then()._return(JExpr._null());
+            }
+
+            int idx = printMethod.lastIndexOf('.');
+            if(idx<0) {
+                // printMethod specifies a method in the target type
+                // which performs the serialization.
+
+                // RESULT: <value>.<method>()
+                inv = $value.invoke(printMethod);
+            } else {
+                // RESULT: <className>.<method>(<value>)
+                if(this.printMethod==null) {
+                    // HACK HACK HACK
+                    JType t = inMemoryType.unboxify();
+                    inv = JExpr.direct(printMethod+"(("+findBaseConversion(owner).toLowerCase()+")("+t.fullName()+")value)");
+                } else
+                    inv = JExpr.direct(printMethod+"(value)");
+            }
+            marshal.body()._return(inv);
+
+            return adapter;
+        }
+
+        private String printMethodFor(XSSimpleType owner) {
+            if(printMethod!=null)   return printMethod;
+
+            String method = getConversionMethod("print",owner);
+            if(method!=null)
+                return method;
+
+            return "toString";
+        }
+
+        private String parseMethodFor(XSSimpleType owner) {
+            if(parseMethod!=null)   return parseMethod;
+
+            String method = getConversionMethod("parse", owner);
+            if(method!=null) {
+                // this cast is necessary for conversion between primitive Java types
+                return '('+inMemoryType.unboxify().fullName()+')'+method;
+            }
+
+            return "new";
+        }
+
+        private static final String[] knownBases = new String[]{
+            "Float", "Double", "Byte", "Short", "Int", "Long", "Boolean"
+        };
+
+        private String getConversionMethod(String methodPrefix, XSSimpleType owner) {
+            String bc = findBaseConversion(owner);
+            if(bc==null)    return null;
+
+            return DatatypeConverter.class.getName()+'.'+methodPrefix+bc;
+        }
+
+        private String findBaseConversion(XSSimpleType owner) {
+            // find the base simple type mapping.
+            for( XSSimpleType st=owner; st!=null; st = st.getSimpleBaseType() ) {
+                if( !WellKnownNamespace.XML_SCHEMA.equals(st.getTargetNamespace()) )
+                    continue;   // user-defined type
+
+                String name = st.getName().intern();
+                for( String s : knownBases )
+                    if(name.equalsIgnoreCase(s))
+                        return s;
+            }
+
+            return null;
+        }
+
+        public QName getName() { return NAME; }
+
+        /** Name of the conversion declaration. */
+        public static final QName NAME = new QName(
+            Const.JAXB_NSURI, "javaType" );
+    }
+
+    @XmlRootElement(name="javaType",namespace=Const.XJC_EXTENSION_URI)
+    public static class UserAdapter extends BIConversion {
+        @XmlAttribute(name="name")
+        private String type = null;
+
+        @XmlAttribute
+        private String adapter = null;
+
+        private TypeUse typeUse;
+
+        public TypeUse getTypeUse(XSSimpleType owner) {
+            if(typeUse!=null)
+                return typeUse;
+
+            JCodeModel cm = getCodeModel();
+
+            JDefinedClass a;
+            try {
+                a = cm._class(adapter);
+                a.hide();   // we assume this is given by the user
+                a._extends(cm.ref(XmlAdapter.class).narrow(String.class).narrow(
+                        cm.ref(type)));
+            } catch (JClassAlreadyExistsException e) {
+                a = e.getExistingClass();
+            }
+
+            // TODO: it's not correct to say that it adapts from String,
+            // but OTOH I don't think we can compute that.
+            typeUse = TypeUseFactory.adapt(
+                    CBuiltinLeafInfo.STRING,
+                    new CAdapter(a));
+
+            return typeUse;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIDeclaration.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIDeclaration.java
new file mode 100644
index 0000000..77fab0f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIDeclaration.java
@@ -0,0 +1,103 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.util.Collection;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.xmlschema.BGMBuilder;
+
+import org.xml.sax.Locator;
+
+/**
+ * Base interface for all binding customization declarations.
+ *
+ * <p>
+ * Because of the setParent method, one customization declaration
+ * can be attached to one component alone.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface BIDeclaration {
+
+    /**
+     * Sets the parent BindInfo object of this declaration.
+     * A declaration object can use this pointer to access
+     * context information, such as other customizations.
+     *
+     * <p>
+     * This method can be only called from {@link BindInfo},
+     * and only once.
+     */
+    void setParent( BindInfo parent );
+
+    /**
+     * Gets the name of this binding declaration,
+     * which is the same as the tag name of the binding element.
+     */
+    QName getName();
+
+    /**
+     * Gets the source location where this declaration was written.
+     * For declarations that are generated by XJC itself,
+     * this method returns null.
+     */
+    Locator getLocation();
+
+    /**
+     * Marks this declaration to be acknowledged -- either actually
+     * used or the existence is admitted (for example when
+     * a property customization is given at the point of definition.)
+     *
+     * <p>
+     * Declarations that are not acknowledged will be considered
+     * as an error.
+     */
+    void markAsAcknowledged();
+
+    /**
+     * Checks if this declaration was acknowledged.
+     */
+    boolean isAcknowledged();
+
+    /**
+     * Called when the parent {@link BindInfo} got its owner set.
+     *
+     * This is when declarations are connected to {@link BGMBuilder} and
+     * its sibling components.
+     */
+    void onSetOwner();
+
+    /**
+     * Gets child {@link BIDeclaration}s if any.
+     *
+     * @return
+     *      can be empty but always non-null. read-only.
+     */
+    Collection<BIDeclaration> getChildren();
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIDom.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIDom.java
new file mode 100644
index 0000000..553cbd9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIDom.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.Const;
+
+/**
+ * DOM customization.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+@XmlRootElement(name="dom")
+public class BIDom extends AbstractDeclarationImpl {
+
+    // unsupported yet
+    @XmlAttribute
+    String type;
+
+    public final QName getName() { return NAME; }
+
+    /** Name of the conversion declaration. */
+    public static final QName NAME = new QName(Const.JAXB_NSURI,"dom");
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIEnum.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIEnum.java
new file mode 100644
index 0000000..643e8b9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIEnum.java
@@ -0,0 +1,118 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.reader.xmlschema.SimpleTypeBuilder;
+
+/**
+ * Enumeration customization.
+ * <p>
+ * This customization binds a simple type to a type-safe enum class.
+ * The actual binding process takes place in {@link SimpleTypeBuilder}.
+ *
+ * <p>
+ * This customization is acknowledged by {@link SimpleTypeBuilder}.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+@XmlRootElement(name="typesafeEnumClass")
+public final class BIEnum extends AbstractDeclarationImpl {
+
+    /**
+     * If false, it means not to bind to a type-safe enum.
+     *
+     * this takes precedence over all the other properties of this class.
+     */
+    @XmlAttribute(name="map")
+    private boolean map = true;
+
+    /** Gets the specified class name, or null if not specified. */
+    @XmlAttribute(name="name")
+    public final String className = null;
+
+    /**
+     * Gets the javadoc comment specified in the customization.
+     * Can be null if none is specified.
+     */
+    @XmlElement
+    public final String javadoc = null;
+
+    public boolean isMapped() {
+        return map;
+    }
+
+    /**
+     * Gets the map that contains XML value->BIEnumMember pairs.
+     * This table is built from &lt;enumMember> customizations.
+     *
+     * Always return non-null.
+     */
+    @XmlTransient
+    public final Map<String,BIEnumMember> members = new HashMap<String,BIEnumMember>();
+
+    public QName getName() { return NAME; }
+
+    public void setParent(BindInfo p) {
+        super.setParent(p);
+        for( BIEnumMember mem : members.values() )
+            mem.setParent(p);
+    }
+
+    /** Name of this declaration. */
+    public static final QName NAME = new QName(
+        Const.JAXB_NSURI, "enum" );
+
+    // setter method for JAXB runtime
+    @XmlElement(name="typesafeEnumMember")
+    private void setMembers(BIEnumMember2[] mems) {
+        for (BIEnumMember2 e : mems)
+            members.put(e.value,e);
+    }
+
+
+
+    /**
+     * {@link BIEnumMember} used inside {@link BIEnum} has additional 'value' attribute.
+     */
+    static class BIEnumMember2 extends BIEnumMember {
+        /**
+         * The lexical representaion of the constant to which we are attaching.
+         */
+        @XmlAttribute(required=true)
+        String value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIEnumMember.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIEnumMember.java
new file mode 100644
index 0000000..1696771
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIEnumMember.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.Const;
+
+/**
+ * Enumeration member customization.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+@XmlRootElement(name="typesafeEnumMember")
+public class BIEnumMember extends AbstractDeclarationImpl {
+    protected BIEnumMember() {
+        name = null;
+        javadoc = null;
+    }
+
+    /** Gets the specified class name, or null if not specified. */
+    // regardless of the BIGlobalBinding.isJavaNamingConventionEnabled flag,
+    // we don't modify the constant name.
+    @XmlAttribute
+    public final String name;
+
+    /**
+     * Gets the javadoc comment specified in the customization.
+     * Can be null if none is specified.
+     */
+    @XmlElement
+    public final String javadoc;
+
+    public QName getName() { return NAME; }
+
+    /** Name of this declaration. */
+    public static final QName NAME = new QName(
+        Const.JAXB_NSURI, "typesafeEnumMember" );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIGlobalBinding.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIGlobalBinding.java
new file mode 100644
index 0000000..062516e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIGlobalBinding.java
@@ -0,0 +1,483 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlEnumValue;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.ClassType;
+import com.sun.codemodel.internal.JClassAlreadyExistsException;
+import com.sun.codemodel.internal.JCodeModel;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.generator.bean.ImplStructureStrategy;
+import static com.sun.tools.internal.xjc.generator.bean.ImplStructureStrategy.BEAN_ONLY;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.SimpleTypeBuilder;
+import com.sun.tools.internal.xjc.util.ReadOnlyAdapter;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.xsom.XSDeclaration;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+
+/**
+ * Global binding customization. The code is highly temporary.
+ *
+ * <p>
+ * One of the information contained in a global customization
+ * is the default binding for properties. This object contains a
+ * BIProperty object to keep this information.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+@XmlRootElement(name="globalBindings")
+public final class BIGlobalBinding extends AbstractDeclarationImpl {
+
+
+    /**
+     * Gets the name converter that will govern the XML->Java
+     * name conversion process for this compilation.
+     *
+     * <p>
+     * The "underscoreBinding" customization will determine
+     * the exact object returned from this method. The rest of XJC
+     * should just use the NameConverter interface.
+     *
+     * <p>
+     * Always non-null.
+     */
+    @XmlTransient
+    public NameConverter nameConverter = NameConverter.standard;
+
+    // JAXB will use this property to set nameConverter
+    @XmlAttribute
+    void setUnderscoreBinding( UnderscoreBinding ub ) {
+        nameConverter = ub.nc;
+    }
+
+    UnderscoreBinding getUnderscoreBinding() {
+        throw new IllegalStateException();  // no need for this
+    }
+
+    public JDefinedClass getSuperClass() {
+        if(superClass==null)    return null;
+        return superClass.getClazz(ClassType.CLASS);
+    }
+
+    public JDefinedClass getSuperInterface() {
+        if(superInterface==null)    return null;
+        return superInterface.getClazz(ClassType.INTERFACE);
+    }
+
+    public BIProperty getDefaultProperty() {
+        return defaultProperty;
+    }
+
+    public boolean isJavaNamingConventionEnabled() {
+        return isJavaNamingConventionEnabled;
+    }
+
+    public BISerializable getSerializable() {
+        return serializable;
+    }
+
+    public boolean isGenerateElementClass() {
+        return generateElementClass;
+    }
+
+    public boolean isChoiceContentPropertyEnabled() {
+        return choiceContentProperty;
+    }
+
+    public int getDefaultEnumMemberSizeCap() {
+        return defaultEnumMemberSizeCap;
+    }
+
+    public boolean isSimpleMode() {
+        return simpleMode!=null;
+    }
+
+    public EnumMemberMode getEnumMemberMode() {
+        return generateEnumMemberName;
+    }
+
+    public boolean isSimpleTypeSubstitution() {
+        return simpleTypeSubstitution;
+    }
+
+    public ImplStructureStrategy getCodeGenerationStrategy() {
+        return codeGenerationStrategy;
+    }
+
+    public LocalScoping getFlattenClasses() {
+        return flattenClasses;
+    }
+
+    /**
+     * Performs error check
+     */
+    public void errorCheck() {
+        ErrorReceiver er = Ring.get(ErrorReceiver.class);
+        for (QName n : enumBaseTypes) {
+            XSSchemaSet xs = Ring.get(XSSchemaSet.class);
+            XSSimpleType st = xs.getSimpleType(n.getNamespaceURI(), n.getLocalPart());
+            if(st==null) {
+                er.error(loc,Messages.ERR_UNDEFINED_SIMPLE_TYPE.format(n));
+                continue;
+            }
+
+            if(!SimpleTypeBuilder.canBeMappedToTypeSafeEnum(st)) {
+                er.error(loc,Messages.ERR_CANNOT_BE_BOUND_TO_SIMPLETYPE.format(n));
+                continue;
+            }
+        }
+    }
+
+    private static enum UnderscoreBinding {
+        @XmlEnumValue("asWordSeparator")
+        WORD_SEPARATOR(NameConverter.standard),
+        @XmlEnumValue("asCharInWord")
+        CHAR_IN_WORD(NameConverter.jaxrpcCompatible);
+
+        final NameConverter nc;
+
+        UnderscoreBinding(NameConverter nc) {
+            this.nc = nc;
+        }
+    }
+
+    /**
+     * Returns true if the "isJavaNamingConventionEnabled" option is turned on.
+     *
+     * In this mode, the compiler is expected to apply XML-to-Java name
+     * conversion algorithm even to names given by customizations.
+     *
+     * This method is intended to be called by other BIXXX classes.
+     * The effect of this switch should be hidden inside this package.
+     * IOW, the reader.xmlschema package shouldn't be aware of this switch.
+     */
+    @XmlAttribute(name="enableJavaNamingConventions")
+    /*package*/ boolean isJavaNamingConventionEnabled = true;
+
+    /**
+     * True to generate classes for every simple type.
+     */
+    @XmlAttribute(name="mapSimpleTypeDef")
+    boolean simpleTypeSubstitution = false;
+
+    /**
+     * Gets the default defaultProperty customization.
+     */
+    @XmlTransient
+    private BIProperty defaultProperty;
+
+    /*
+        Three properties used to construct a default property
+    */
+    @XmlAttribute
+    private boolean fixedAttributeAsConstantProperty = false;
+    @XmlAttribute
+    private CollectionTypeAttribute collectionType = new CollectionTypeAttribute();
+    @XmlAttribute
+    void setGenerateIsSetMethod(boolean b) {
+        optionalProperty = b ? OptionalPropertyMode.ISSET : OptionalPropertyMode.WRAPPER;
+    }
+
+
+    /**
+     * Returns true if the compiler needs to generate type-safe enum
+     * member names when enumeration values cannot be used as constant names.
+     */
+    @XmlAttribute(name="typesafeEnumMemberName")
+    EnumMemberMode generateEnumMemberName = EnumMemberMode.SKIP;
+
+    /**
+     * The code generation strategy.
+     */
+    @XmlAttribute(name="generateValueClass")
+    ImplStructureStrategy codeGenerationStrategy = BEAN_ONLY;
+
+    /**
+     * Set of datatype names. For a type-safe enum class
+     * to be generated, the underlying XML datatype must be derived from
+     * one of the types in this set.
+     */
+    // default value is set in the post-init action
+    @XmlAttribute(name="typesafeEnumBase")
+    private Set<QName> enumBaseTypes;
+
+    /**
+     * Returns {@link BISerializable} if the extension is specified,
+     * or null otherwise.
+     */
+    @XmlElement
+    private BISerializable serializable = null;
+
+    /**
+     * If &lt;xjc:superClass> extension is specified,
+     * returns the specified root class. Otherwise null.
+     */
+    @XmlElement(namespace=Const.XJC_EXTENSION_URI)
+    ClassNameBean superClass = null;
+
+    /**
+     * If &lt;xjc:superInterface> extension is specified,
+     * returns the specified root class. Otherwise null.
+     */
+    @XmlElement(namespace=Const.XJC_EXTENSION_URI)
+    ClassNameBean superInterface = null;
+
+    /**
+     * Generate the simpler optimized code, but not necessarily
+     * conforming to the spec.
+     */
+    @XmlElement(name="simple",namespace=Const.XJC_EXTENSION_URI)
+    String simpleMode = null;
+
+    /**
+     * True to generate a class for elements by default.
+     */
+    @XmlAttribute
+    boolean generateElementClass = false;
+
+    @XmlElement(namespace=Const.XJC_EXTENSION_URI)
+    Boolean generateElementProperty = null;
+
+    @XmlAttribute
+    boolean choiceContentProperty = false;
+
+    @XmlAttribute
+    OptionalPropertyMode optionalProperty = OptionalPropertyMode.WRAPPER;
+
+    /**
+     * Default cap to the number of constants in the enum.
+     * We won't attempt to produce a type-safe enum by default
+     * if there are more enumeration facets than specified in this field.
+     */
+    @XmlAttribute(name="typesafeEnumMaxMembers")
+    int defaultEnumMemberSizeCap = 256;
+
+    /**
+     * If true, interfaces/classes that are normally generated as a nested interface/class
+     * will be generated into the package, allowing the generated classes to be flat.
+     *
+     * See <a href="http://monaco.sfbay/detail.jsf?cr=4969415">Bug 4969415</a> for the motivation.
+     */
+    @XmlAttribute(name="localScoping")
+    LocalScoping flattenClasses = LocalScoping.NESTED;
+
+    /**
+     * Globally-defined conversion customizations.
+     *
+     * @see #setGlobalConversions
+     */
+    @XmlTransient
+    private final Map<QName,BIConversion> globalConversions = new HashMap<QName, BIConversion>();
+
+    // method for JAXB unmarshaller
+    @XmlElement(name="javaType")
+    private void setGlobalConversions(GlobalStandardConversion[] convs) {
+        for (GlobalStandardConversion u : convs) {
+            globalConversions.put(u.xmlType,u);
+        }
+    }
+
+    @XmlElement(name="javaType",namespace=Const.XJC_EXTENSION_URI)
+    private void setGlobalConversions2(GlobalVendorConversion[] convs) {
+        for (GlobalVendorConversion u : convs) {
+            globalConversions.put(u.xmlType,u);
+        }
+    }
+
+    //
+    // these customizations were valid in 1.0, but in 2.0 we don't
+    // use them. OTOH, we don't want to issue an error for them,
+    // so we just define a mapping and ignore the value.
+    //
+    @XmlElement(namespace=Const.XJC_EXTENSION_URI)
+    String noMarshaller = null;
+    @XmlElement(namespace=Const.XJC_EXTENSION_URI)
+    String noUnmarshaller = null;
+    @XmlElement(namespace=Const.XJC_EXTENSION_URI)
+    String noValidator = null;
+    @XmlElement(namespace=Const.XJC_EXTENSION_URI)
+    String noValidatingUnmarshaller = null;
+    @XmlElement(namespace=Const.XJC_EXTENSION_URI)
+    TypeSubstitutionElement typeSubstitution = null;
+
+    /**
+     * Another 1.0 compatibility customization (but we accept it
+     * and treat it as {@link #serializable})
+     */
+    @XmlElement(name="serializable",namespace=Const.XJC_EXTENSION_URI)
+    void setXjcSerializable(BISerializable s) {
+        this.serializable = s;
+    }
+
+
+
+    private static final class TypeSubstitutionElement {
+        @XmlAttribute
+        String type;
+    }
+
+    public void onSetOwner() {
+        super.onSetOwner();
+        // if one is given by options, use that
+        NameConverter nc = Ring.get(Model.class).options.getNameConverter();
+        if(nc!=null)
+            nameConverter = nc;
+    }
+
+    /**
+     * Creates a bind info object with the default values
+     */
+    public BIGlobalBinding() {
+    }
+
+    public void setParent(BindInfo parent) {
+        super.setParent(parent);
+        // fill in the remaining default values
+        if(enumBaseTypes==null)
+            enumBaseTypes = Collections.singleton(new QName(WellKnownNamespace.XML_SCHEMA,"string"));
+
+        this.defaultProperty = new BIProperty(getLocation(),null,null,null,
+                collectionType, fixedAttributeAsConstantProperty, optionalProperty, generateElementProperty );
+        defaultProperty.setParent(parent); // don't forget to initialize the defaultProperty
+    }
+
+    /**
+     * Moves global BIConversion to the right object.
+     */
+    public void dispatchGlobalConversions( XSSchemaSet schema ) {
+        // also set parent to the global conversions
+        for( Map.Entry<QName,BIConversion> e : globalConversions.entrySet() ) {
+
+            QName name = e.getKey();
+            BIConversion conv = e.getValue();
+
+            XSSimpleType st = schema.getSimpleType(name.getNamespaceURI(),name.getLocalPart());
+            if(st==null) {
+                Ring.get(ErrorReceiver.class).error(
+                    getLocation(),
+                    Messages.ERR_UNDEFINED_SIMPLE_TYPE.format(name)
+                );
+                continue; // abort
+            }
+
+            getBuilder().getOrCreateBindInfo(st).addDecl(conv);
+        }
+    }
+
+
+    /**
+     * Checks if the given XML Schema built-in type can be mapped to
+     * a type-safe enum class.
+     *
+     * @param typeName
+     */
+    public boolean canBeMappedToTypeSafeEnum( QName typeName ) {
+        return enumBaseTypes.contains(typeName);
+    }
+
+    public boolean canBeMappedToTypeSafeEnum( String nsUri, String localName ) {
+        return canBeMappedToTypeSafeEnum(new QName(nsUri,localName));
+    }
+
+    public boolean canBeMappedToTypeSafeEnum( XSDeclaration decl ) {
+        return canBeMappedToTypeSafeEnum( decl.getTargetNamespace(), decl.getName() );
+    }
+
+
+    public QName getName() { return NAME; }
+    public static final QName NAME = new QName(
+        Const.JAXB_NSURI, "globalBindings" );
+
+
+    /**
+     * Used to unmarshal
+     * <xmp>
+     * <[element] name="className" />
+     * </xmp>
+     */
+    static final class ClassNameBean {
+        @XmlAttribute(required=true)
+        String name;
+
+        /**
+         * Computed from {@link #name} on demand.
+         */
+        @XmlTransient
+        JDefinedClass clazz;
+
+        JDefinedClass getClazz(ClassType t) {
+            if (clazz != null) return clazz;
+            try {
+                JCodeModel codeModel = Ring.get(JCodeModel.class);
+                clazz = codeModel._class(name, t);
+                clazz.hide();
+                return clazz;
+            } catch (JClassAlreadyExistsException e) {
+                return e.getExistingClass();
+            }
+        }
+    }
+
+    static final class ClassNameAdapter extends ReadOnlyAdapter<ClassNameBean,String> {
+        public String unmarshal(ClassNameBean bean) throws Exception {
+            return bean.name;
+        }
+    }
+
+    /**
+     * Global &lt;jaxb:javaType>.
+     */
+    static final class GlobalStandardConversion extends BIConversion.User {
+        @XmlAttribute
+        QName xmlType;
+    }
+
+    /**
+     * Global &lt;xjc:javaType>.
+     */
+    static final class GlobalVendorConversion extends BIConversion.UserAdapter {
+        @XmlAttribute
+        QName xmlType;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIProperty.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIProperty.java
new file mode 100644
index 0000000..8026848
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIProperty.java
@@ -0,0 +1,717 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.util.Collection;
+import java.util.Collections;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlElementRef;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.namespace.QName;
+
+import com.sun.codemodel.internal.JJavaName;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRenderer;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRendererFactory;
+import com.sun.tools.internal.xjc.generator.bean.field.IsSetFieldRenderer;
+import com.sun.tools.internal.xjc.model.CAttributePropertyInfo;
+import com.sun.tools.internal.xjc.model.CCustomizations;
+import com.sun.tools.internal.xjc.model.CElementPropertyInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.CReferencePropertyInfo;
+import com.sun.tools.internal.xjc.model.CValuePropertyInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.tools.internal.xjc.reader.RawTypeSet;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.TypeUtil;
+import com.sun.tools.internal.xjc.reader.xmlschema.BGMBuilder;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.util.XSFinder;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+
+import org.xml.sax.Locator;
+
+/**
+ * Property customization.
+ *
+ * This customization turns an arbitrary schema component
+ * into a Java property (some restrictions apply.)
+ *
+ * <p>
+ * All the getter methods (such as <code>getBaseType</code> or
+ * <code>getBindStyle</code>) honors the delegation chain of
+ * property customization specified in the spec. Namely,
+ * if two property customizations are attached to an attribute
+ * use and an attribute decl, then anything unspecified in the
+ * attribute use defaults to attribute decl.
+ *
+ * <p>
+ * Property customizations are acknowledged
+ * (1) when they are actually used, and
+ * (2) when they are given at the component, which is mapped to a class.
+ *     (so-called "point of declaration" customization)
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+@XmlRootElement(name="property")
+public final class BIProperty extends AbstractDeclarationImpl {
+
+    // can be null
+    @XmlAttribute
+    private String name = null;
+
+    // can be null
+    @XmlElement
+    private String javadoc = null;
+
+    // can be null
+    @XmlElement
+    private BaseTypeBean baseType = null;
+
+    // TODO: report 'unsupported' error if this is true
+    @XmlAttribute
+    private boolean generateFailFastSetterMethod = false;
+
+
+
+    public BIProperty(Locator loc, String _propName, String _javadoc,
+                      BaseTypeBean _baseType, CollectionTypeAttribute collectionType, Boolean isConst,
+                      OptionalPropertyMode optionalProperty, Boolean genElemProp) {
+        super(loc);
+
+        this.name = _propName;
+        this.javadoc = _javadoc;
+        this.baseType = _baseType;
+        this.collectionType = collectionType;
+        this.isConstantProperty = isConst;
+        this.optionalProperty = optionalProperty;
+        this.generateElementProperty = genElemProp;
+    }
+
+    protected BIProperty() {}
+
+    @Override
+    public Collection<BIDeclaration> getChildren() {
+        BIConversion conv = getConv();
+        if(conv==null)
+            return super.getChildren();
+        else
+            return Collections.<BIDeclaration>singleton(conv);
+    }
+
+    public void setParent( BindInfo parent ) {
+        super.setParent(parent);
+        if(baseType!=null && baseType.conv!=null)
+            baseType.conv.setParent(parent);
+    }
+
+
+
+    /**
+     * Returns the customized property name.
+     *
+     * This method honors the "enableJavaNamingConvention" customization
+     * and formats the property name accordingly if necessary.
+     *
+     * Thus the caller should <em>NOT</em> apply the XML-to-Java name
+     * conversion algorithm to the value returned from this method.
+     *
+     * @param forConstant
+     *      If the property name is intended for a constant property name,
+     *      set to true. This will change the result
+     *
+     * @return
+     *      This method can return null if the customization doesn't
+     *      specify the name.
+     */
+    public String getPropertyName( boolean forConstant ) {
+        if(name!=null) {
+            BIGlobalBinding gb = getBuilder().getGlobalBinding();
+            NameConverter nc = getBuilder().model.getNameConverter();
+
+            if( gb.isJavaNamingConventionEnabled() && !forConstant )
+                // apply XML->Java conversion
+                return nc.toPropertyName(name);
+            else
+                return name;    // ... or don't change the value
+        }
+        BIProperty next = getDefault();
+        if(next!=null)  return next.getPropertyName(forConstant);
+        else            return null;
+    }
+
+    /**
+     * Gets the associated javadoc.
+     *
+     * @return
+     *      null if none is specfieid.
+     */
+    public String getJavadoc() {
+        return javadoc;
+    }
+
+    // can be null
+    public JType getBaseType() {
+        if(baseType!=null && baseType.name!=null) {
+            return TypeUtil.getType(getCodeModel(),
+                    baseType.name,
+                    Ring.get(ErrorReceiver.class),getLocation());
+        }
+        BIProperty next = getDefault();
+        if(next!=null)  return next.getBaseType();
+        else            return null;
+    }
+
+
+    // can be null
+    @XmlAttribute
+    private CollectionTypeAttribute collectionType = null;
+
+    /**
+     * Gets the realization of this field.
+     * @return Always return non-null.
+     */
+    CollectionTypeAttribute getCollectionType() {
+        if(collectionType!=null)   return collectionType;
+        return getDefault().getCollectionType();
+    }
+
+
+    @XmlAttribute
+    private OptionalPropertyMode optionalProperty = null;
+
+    // virtual property for @generateIsSetMethod
+    @XmlAttribute
+    void setGenerateIsSetMethod(boolean b) {
+        optionalProperty = b ? OptionalPropertyMode.ISSET : OptionalPropertyMode.WRAPPER;
+    }
+
+    public OptionalPropertyMode getOptionalPropertyMode() {
+        if(optionalProperty!=null)   return optionalProperty;
+        return getDefault().getOptionalPropertyMode();
+    }
+
+    // null if delegated
+    @XmlAttribute
+    private Boolean generateElementProperty = null;
+    /**
+     * If true, the property will automatically be a reference property.
+     * (Talk about confusing names!)
+     */
+    private Boolean generateElementProperty() {
+        if(generateElementProperty!=null)   return generateElementProperty;
+        BIProperty next = getDefault();
+        if(next!=null)      return next.generateElementProperty();
+
+        return null;
+    }
+
+
+    // true, false, or null (which means the value should be inherited.)
+    @XmlAttribute(name="fixedAttributeAsConstantProperty")
+    private Boolean isConstantProperty;
+    /**
+     * Gets the inherited value of the "fixedAttrToConstantProperty" customization.
+     *
+     * <p>
+     * Note that returning true from this method doesn't necessarily mean
+     * that a property needs to be mapped to a constant property.
+     * It just means that it's mapped to a constant property
+     * <b>if an attribute use carries a fixed value.</b>
+     *
+     * <p>
+     * I don't like this semantics but that's what the spec implies.
+     */
+    public boolean isConstantProperty() {
+        if(isConstantProperty!=null)    return isConstantProperty;
+
+        BIProperty next = getDefault();
+        if(next!=null)      return next.isConstantProperty();
+
+        // globalBinding always has true or false in this property,
+        // so this can't happen
+        throw new AssertionError();
+    }
+
+    public CValuePropertyInfo createValueProperty(String defaultName,boolean forConstant,
+        XSComponent source,TypeUse tu) {
+
+        markAsAcknowledged();
+        constantPropertyErrorCheck();
+
+        String name = getPropertyName(forConstant);
+        if(name==null) {
+            name = defaultName;
+            if(tu.isCollection() && getBuilder().getGlobalBinding().isSimpleMode())
+                name = JJavaName.getPluralForm(name);
+        }
+
+        return wrapUp(new CValuePropertyInfo(name, source,getCustomizations(source),source.getLocator(), tu ),source);
+    }
+
+    public CAttributePropertyInfo createAttributeProperty( XSAttributeUse use, TypeUse tu ) {
+
+        boolean forConstant =
+            getCustomization(use).isConstantProperty() &&
+            use.getFixedValue()!=null;
+
+        String name = getPropertyName(forConstant);
+        if(name==null) {
+            NameConverter conv = getBuilder().getNameConverter();
+            if(forConstant)
+                name = conv.toConstantName(use.getDecl().getName());
+            else
+                name = conv.toPropertyName(use.getDecl().getName());
+            if(tu.isCollection() && getBuilder().getGlobalBinding().isSimpleMode())
+                name = JJavaName.getPluralForm(name);
+        }
+
+        QName n = new QName(use.getDecl().getTargetNamespace(),use.getDecl().getName());
+
+        markAsAcknowledged();
+        constantPropertyErrorCheck();
+
+        return wrapUp(new CAttributePropertyInfo(name,use,getCustomizations(use),use.getLocator(), n, tu, use.isRequired() ),use);
+    }
+
+    /**
+     *
+     *
+     * @param defaultName
+     *      If the name is not customized, this name will be used
+     *      as the default. Note that the name conversion <b>MUST</b>
+     *      be applied before this method is called if necessary.
+     * @param source
+     *      Source schema component from which a field is built.
+     */
+    public CElementPropertyInfo createElementProperty(String defaultName, boolean forConstant, XSParticle source,
+                                                      RawTypeSet types) {
+
+        if(!types.refs.isEmpty())
+            // if this property is empty, don't acknowleedge the customization
+            // this allows pointless property customization to be reported as an error
+            markAsAcknowledged();
+        constantPropertyErrorCheck();
+
+        String name = getPropertyName(forConstant);
+        if(name==null)
+            name = defaultName;
+
+        CElementPropertyInfo prop = wrapUp(
+            new CElementPropertyInfo(
+                name, types.getCollectionMode(),
+                types.id(),
+                types.getExpectedMimeType(),
+                source, getCustomizations(source),
+                source.getLocator(), types.isRequired()),
+            source);
+
+        types.addTo(prop);
+
+        return prop;
+    }
+
+    public CReferencePropertyInfo createReferenceProperty(
+            String defaultName, boolean forConstant, XSComponent source,
+            RawTypeSet types, boolean isMixed) {
+
+        if(!types.refs.isEmpty())
+            // if this property is empty, don't acknowleedge the customization
+            // this allows pointless property customization to be reported as an error
+            markAsAcknowledged();
+        constantPropertyErrorCheck();
+
+        String name = getPropertyName(forConstant);
+        if(name==null)
+            name = defaultName;
+
+        CReferencePropertyInfo prop = wrapUp(
+            new CReferencePropertyInfo(
+                name,
+                types.getCollectionMode().isRepeated()||isMixed,
+                isMixed, source,
+                getCustomizations(source), source.getLocator() ),
+            source);
+
+        types.addTo(prop);
+
+        return prop;
+    }
+
+    public CPropertyInfo createElementOrReferenceProperty(
+            String defaultName, boolean forConstant, XSParticle source,
+            RawTypeSet types) {
+
+        boolean generateRef;
+
+        switch(types.canBeTypeRefs) {
+        case CAN_BE_TYPEREF:
+        case SHOULD_BE_TYPEREF:
+            // it's up to the use
+            Boolean b = generateElementProperty();
+            if(b==null) // follow XJC recommendation
+                generateRef = types.canBeTypeRefs== RawTypeSet.Mode.CAN_BE_TYPEREF;
+            else // use the value user gave us
+                generateRef = b;
+            break;
+        case MUST_BE_REFERENCE:
+            generateRef = true;
+            break;
+        default:
+            throw new AssertionError();
+        }
+
+        if(generateRef) {
+            return createReferenceProperty(defaultName,forConstant,source,types, false);
+        } else {
+            return createElementProperty(defaultName,forConstant,source,types);
+        }
+    }
+
+    /**
+     * Common finalization of {@link CPropertyInfo} for the create***Property methods.
+     */
+    private <T extends CPropertyInfo> T wrapUp(T prop, XSComponent source) {
+        prop.javadoc = concat(javadoc,
+            getBuilder().getBindInfo(source).getDocumentation());
+        if(prop.javadoc==null)
+            prop.javadoc="";
+
+        // decide the realization.
+        FieldRenderer r;
+        OptionalPropertyMode opm = getOptionalPropertyMode();
+        if(prop.isCollection()) {
+            CollectionTypeAttribute ct = getCollectionType();
+            r = ct.get(getBuilder().model);
+        } else {
+            FieldRendererFactory frf = getBuilder().fieldRendererFactory;
+
+            if(prop.isOptionalPrimitive()) {
+                // the property type can be primitive type if we are to ignore absence
+                switch(opm) {
+                case PRIMITIVE:
+                    r = frf.getRequiredUnboxed();
+                    break;
+                case WRAPPER:
+                    // force the wrapper type
+                    r = frf.getSingle();
+                    break;
+                case ISSET:
+                    r = frf.getSinglePrimitiveAccess();
+                    break;
+                default:
+                    throw new Error();
+                }
+            } else {
+                r = frf.getDefault();
+            }
+        }
+        if(opm==OptionalPropertyMode.ISSET) {
+            // only isSet is allowed on a collection. these 3 modes aren't really symmetric.
+
+            // if the property is a primitive type, we need an explicit unset because
+            // we can't overload the meaning of set(null).
+            // if it's a collection, we need to be able to unset it so that we can distinguish
+            // null list and empty list.
+            r = new IsSetFieldRenderer( r, prop.isOptionalPrimitive()||prop.isCollection(), true );
+        }
+
+        prop.realization = r;
+
+        JType bt = getBaseType();
+        if(bt!=null)
+            prop.baseType = bt;
+
+        return prop;
+    }
+
+    private CCustomizations getCustomizations( XSComponent src ) {
+        return getBuilder().getBindInfo(src).toCustomizationList();
+    }
+
+    private CCustomizations getCustomizations( XSComponent... src ) {
+        CCustomizations c = null;
+        for (XSComponent s : src) {
+            CCustomizations r = getCustomizations(s);
+            if(c==null)     c = r;
+            else            c = CCustomizations.merge(c,r);
+        }
+        return c;
+    }
+
+    private CCustomizations getCustomizations( XSAttributeUse src ) {
+        // customizations for an attribute use should include those defined in the local attribute.
+        // this is so that the schema like:
+        //
+        // <xs:attribute name="foo" type="xs:int">
+        //   <xs:annotation><xs:appinfo>
+        //     <hyperjaxb:... />
+        //
+        // would be picked up
+        if(src.getDecl().isLocal())
+            return getCustomizations(src,src.getDecl());
+        else
+            return getCustomizations((XSComponent)src);
+    }
+
+    private CCustomizations getCustomizations( XSParticle src ) {
+        // customizations for a particle  should include those defined in the term unless it's global
+        // this is so that the schema like:
+        //
+        // <xs:sequence>
+        //   <xs:element name="foo" type="xs:int">
+        //     <xs:annotation><xs:appinfo>
+        //       <hyperjaxb:... />
+        //
+        // would be picked up
+        if(src.getTerm().isElementDecl()) {
+            XSElementDecl xed = src.getTerm().asElementDecl();
+            if(xed.isGlobal())
+                return getCustomizations((XSComponent)src);
+        }
+
+        return getCustomizations(src,src.getTerm());
+    }
+
+
+
+    public void markAsAcknowledged() {
+        if( isAcknowledged() )  return;
+
+        // mark the parent as well.
+        super.markAsAcknowledged();
+
+        BIProperty def = getDefault();
+        if(def!=null)   def.markAsAcknowledged();
+    }
+
+    private void constantPropertyErrorCheck() {
+        if( isConstantProperty!=null && getOwner()!=null ) {
+            // run additional check on the isCOnstantProperty value.
+            // this value is not allowed if the schema component doesn't have
+            // a fixed value constraint.
+            //
+            // the setParent method associates a customization with the rest of
+            // XSOM object graph, so this is the earliest possible moment where
+            // we can test this.
+
+            if( !hasFixedValue.find(getOwner()) ) {
+                Ring.get(ErrorReceiver.class).error(
+                    getLocation(),
+                    Messages.ERR_ILLEGAL_FIXEDATTR.format()
+                );
+                // set this value to null to avoid the same error to be reported more than once.
+                isConstantProperty = null;
+            }
+        }
+    }
+
+    /**
+     * Function object that returns true if a component has
+     * a fixed value constraint.
+     */
+    private final XSFinder hasFixedValue = new XSFinder() {
+        public Boolean attributeDecl(XSAttributeDecl decl) {
+            return decl.getFixedValue()!=null;
+        }
+
+        public Boolean attributeUse(XSAttributeUse use) {
+            return use.getFixedValue()!=null;
+        }
+
+        public Boolean schema(XSSchema s) {
+            // we allow globalBindings to have isConstantProperty==true,
+            // so this method returns true to allow this.
+            return true;
+        }
+    };
+
+    /**
+     * Finds a BIProperty which this object should delegate to.
+     *
+     * @return
+     *      always return non-null for normal BIProperties.
+     *      If this object is contained in the BIGlobalBinding, then
+     *      this method returns null to indicate that there's no more default.
+     */
+    protected BIProperty getDefault() {
+        if(getOwner()==null)    return null;
+        BIProperty next = getDefault(getBuilder(),getOwner());
+        if(next==this)  return null;    // global.
+        else            return next;
+    }
+
+    private static BIProperty getDefault( BGMBuilder builder, XSComponent c ) {
+        while(c!=null) {
+            c = c.apply(defaultCustomizationFinder);
+            if(c!=null) {
+                BIProperty prop = builder.getBindInfo(c).get(BIProperty.class);
+                if(prop!=null)  return prop;
+            }
+        }
+
+        // default to the global one
+        return builder.getGlobalBinding().getDefaultProperty();
+    }
+
+
+    /**
+     * Finds a property customization that describes how the given
+     * component should be mapped to a property (if it's mapped to
+     * a property at all.)
+     *
+     * <p>
+     * Consider an attribute use that does NOT carry a property
+     * customization. This schema component is nonetheless considered
+     * to carry a (sort of) implicit property customization, whose values
+     * are defaulted.
+     *
+     * <p>
+     * This method can be think of the method that returns this implied
+     * property customization.
+     *
+     * <p>
+     * Note that this doesn't mean the given component needs to be
+     * mapped to a property. But if it does map to a property, it needs
+     * to follow this customization.
+     *
+     * I think this semantics is next to non-sense but I couldn't think
+     * of any other way to follow the spec.
+     *
+     * @param c
+     *      A customization effective on this component will be returned.
+     *      Can be null just to get the global customization.
+     * @return
+     *      Always return non-null valid object.
+     */
+    public static BIProperty getCustomization( XSComponent c ) {
+        BGMBuilder builder = Ring.get(BGMBuilder.class);
+
+        // look for a customization on this component
+        if( c!=null ) {
+            BIProperty prop = builder.getBindInfo(c).get(BIProperty.class);
+            if(prop!=null)  return prop;
+        }
+
+        // if no such thing exists, defeault.
+        return getDefault(builder,c);
+    }
+
+    private final static XSFunction<XSComponent> defaultCustomizationFinder = new XSFunction<XSComponent>() {
+
+        public XSComponent attributeUse(XSAttributeUse use) {
+            return use.getDecl();   // inherit from the declaration
+        }
+
+        public XSComponent particle(XSParticle particle) {
+            return particle.getTerm(); // inherit from the term
+        }
+
+        public XSComponent schema(XSSchema schema) {
+            // no more delegation
+            return null;
+        }
+
+        // delegates to the context schema object
+        public XSComponent attributeDecl(XSAttributeDecl decl) { return decl.getOwnerSchema(); }
+        public XSComponent wildcard(XSWildcard wc) { return wc.getOwnerSchema(); }
+        public XSComponent modelGroupDecl(XSModelGroupDecl decl) { return decl.getOwnerSchema(); }
+        public XSComponent modelGroup(XSModelGroup group) { return group.getOwnerSchema(); }
+        public XSComponent elementDecl(XSElementDecl decl) { return decl.getOwnerSchema(); }
+        public XSComponent complexType(XSComplexType type) { return type.getOwnerSchema(); }
+        public XSComponent simpleType(XSSimpleType st) { return st.getOwnerSchema(); }
+
+        // property customizations are not allowed on these components.
+        public XSComponent attGroupDecl(XSAttGroupDecl decl) { throw new IllegalStateException(); }
+        public XSComponent empty(XSContentType empty) { throw new IllegalStateException(); }
+        public XSComponent annotation(XSAnnotation xsAnnotation) { throw new IllegalStateException(); }
+        public XSComponent facet(XSFacet xsFacet) { throw new IllegalStateException(); }
+        public XSComponent notation(XSNotation xsNotation) { throw new IllegalStateException(); }
+        public XSComponent identityConstraint(XSIdentityConstraint x) { throw new IllegalStateException(); }
+        public XSComponent xpath(XSXPath xsxPath) { throw new IllegalStateException(); }
+    };
+
+
+    private static String concat( String s1, String s2 ) {
+        if(s1==null)    return s2;
+        if(s2==null)    return s1;
+        return s1+"\n\n"+s2;
+    }
+
+    public QName getName() { return NAME; }
+
+    /** Name of this declaration. */
+    public static final QName NAME = new QName(
+        Const.JAXB_NSURI, "property" );
+
+    public BIConversion getConv() {
+        if(baseType!=null)
+            return baseType.conv;
+        else
+            return null;
+    }
+
+    private static final class BaseTypeBean {
+        /**
+         * If there's a nested javaType customization, this field
+         * will keep that customization. Otherwise null.
+         *
+         * This customization, if present, is used to customize
+         * the simple type mapping at the point of reference.
+         */
+        @XmlElementRef
+        BIConversion conv;
+
+        /**
+         * Java type name.
+         */
+        @XmlAttribute
+        String name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BISchemaBinding.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BISchemaBinding.java
new file mode 100644
index 0000000..210ea4e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BISchemaBinding.java
@@ -0,0 +1,150 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSType;
+
+/**
+ * Schema-wide binding customization.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+@XmlRootElement(name="schemaBindings")
+public final class BISchemaBinding extends AbstractDeclarationImpl {
+
+    /**
+     * Name conversion rules. All defaults to {@link BISchemaBinding#defaultNamingRule}.
+     */
+    @XmlType(propOrder={})
+    private static final class NameRules {
+        @XmlElement
+        NamingRule typeName = defaultNamingRule;
+        @XmlElement
+        NamingRule elementName = defaultNamingRule;
+        @XmlElement
+        NamingRule attributeName = defaultNamingRule;
+        @XmlElement
+        NamingRule modelGroupName = defaultNamingRule;
+        @XmlElement
+        NamingRule anonymousTypeName = defaultNamingRule;
+    }
+
+    @XmlElement
+    private NameRules nameXmlTransform = new NameRules();
+
+    private static final class PackageInfo {
+        @XmlAttribute
+        String name;
+        @XmlElement
+        String javadoc;
+    }
+
+    @XmlElement(name="package")
+    private PackageInfo packageInfo = new PackageInfo();
+
+    /**
+     * Default naming rule, that doesn't change the name.
+     */
+    private static final NamingRule defaultNamingRule = new NamingRule("","");
+
+
+    /**
+     * Default naming rules of the generated interfaces.
+     *
+     * It simply adds prefix and suffix to the name, but
+     * the caller shouldn't care how the name mangling is
+     * done.
+     */
+    public static final class NamingRule {
+        @XmlAttribute
+        private String prefix = "";
+        @XmlAttribute
+        private String suffix = "";
+
+        public NamingRule( String _prefix, String _suffix ) {
+            this.prefix = _prefix;
+            this.suffix = _suffix;
+        }
+
+        public NamingRule() {
+        }
+
+        /** Changes the name according to the rule. */
+        public String mangle( String originalName ) {
+            return prefix+originalName+suffix;
+        }
+    }
+
+    /**
+     * Transforms the default name produced from XML name
+     * by following the customization.
+     *
+     * This shouldn't be applied to a class name specified
+     * by a customization.
+     *
+     * @param cmp
+     *      The schema component from which the default name is derived.
+     */
+    public String mangleClassName( String name, XSComponent cmp ) {
+        if( cmp instanceof XSType )
+            return nameXmlTransform.typeName.mangle(name);
+        if( cmp instanceof XSElementDecl )
+            return nameXmlTransform.elementName.mangle(name);
+        if( cmp instanceof XSAttributeDecl )
+            return nameXmlTransform.attributeName.mangle(name);
+        if( cmp instanceof XSModelGroup || cmp instanceof XSModelGroupDecl )
+            return nameXmlTransform.modelGroupName.mangle(name);
+
+        // otherwise no modification
+        return name;
+    }
+
+    public String mangleAnonymousTypeClassName( String name ) {
+        return nameXmlTransform.anonymousTypeName.mangle(name);
+    }
+
+
+    public String getPackageName() { return packageInfo.name; }
+
+    public String getJavadoc() { return packageInfo.javadoc; }
+
+    public QName getName() { return NAME; }
+    public static final QName NAME = new QName(
+        Const.JAXB_NSURI, "schemaBinding" );
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BISerializable.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BISerializable.java
new file mode 100644
index 0000000..954878c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BISerializable.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlAttribute;
+
+
+/**
+ * This customization will enable serialization support on XJC.
+ * This is used as a child of a {@link BIGlobalBinding} object,
+ * and this doesn't implement BIDeclaration by itself.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class BISerializable {
+
+    /** serial version UID, or null to avoid generating the serialVersionUID field. */
+    @XmlAttribute
+    public Long uid;
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIXDom.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIXDom.java
new file mode 100644
index 0000000..5e70e34
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIXDom.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+
+import com.sun.tools.internal.xjc.reader.Const;
+
+/**
+ * Compatibility with 1.0.
+ *
+ * Read &lt;xjc:dom> as &lt;jaxb:dom>.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@XmlRootElement(name="dom",namespace=Const.XJC_EXTENSION_URI)
+public class BIXDom extends BIDom {
+
+    // unsupported yet
+    @XmlAttribute
+    String type = "w3c";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIXPluginCustomization.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIXPluginCustomization.java
new file mode 100644
index 0000000..e9808c3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BIXPluginCustomization.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.Plugin;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.reader.Ring;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+
+/**
+ * Customization specified via {@link Plugin#getCustomizationURIs()}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class BIXPluginCustomization extends AbstractDeclarationImpl {
+
+    /**
+     * Customization element.
+     */
+    public final Element element;
+
+    private QName name;
+
+    public BIXPluginCustomization(Element e, Locator _loc) {
+        super(_loc);
+        element = e;
+    }
+
+    public void onSetOwner() {
+        super.onSetOwner();
+        if(!Ring.get(Model.class).options.pluginURIs.contains(element.getNamespaceURI()))
+            markAsAcknowledged();
+    }
+
+    public final QName getName() {
+        if(name==null)
+            name = new QName(element.getNamespaceURI(),element.getLocalName());
+        return name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BindInfo.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BindInfo.java
new file mode 100644
index 0000000..09f889e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/BindInfo.java
@@ -0,0 +1,307 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.io.FilterWriter;
+import java.io.IOException;
+import java.io.StringWriter;
+import java.io.Writer;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.bind.annotation.XmlAnyElement;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlMixed;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.stream.StreamResult;
+
+import com.sun.codemodel.internal.JDocComment;
+import com.sun.tools.internal.xjc.model.CCustomizations;
+import com.sun.tools.internal.xjc.model.CPluginCustomization;
+import com.sun.tools.internal.xjc.model.Model;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.BGMBuilder;
+import com.sun.xml.internal.bind.annotation.XmlLocation;
+import com.sun.xml.internal.bind.marshaller.MinimumEscapeHandler;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.xsom.XSComponent;
+
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+
+/**
+ * Container for customization declarations.
+ *
+ * We use JAXB ourselves and parse this object from "xs:annotation".
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke,kawaguchi@sun.com)
+ */
+@XmlRootElement(namespace=WellKnownNamespace.XML_SCHEMA,name="annotation")
+@XmlType(namespace=WellKnownNamespace.XML_SCHEMA,name="foobar")
+public final class BindInfo implements Iterable<BIDeclaration> {
+
+    private BGMBuilder builder;
+
+    @XmlLocation
+    private Locator location;
+
+    /**
+     * Documentation taken from &lt;xs:documentation>s.
+     */
+    @XmlElement
+    private Documentation documentation;
+
+    /**
+     * Returns true if this {@link BindInfo} doesn't contain any useful
+     * information.
+     *
+     * This flag is used to discard unused {@link BindInfo}s early to save memory footprint.
+     */
+    public boolean isPointless() {
+        if(size()>0)     return false;
+        if(documentation!=null && !documentation.contents.isEmpty())
+            return false;
+
+        return true;
+    }
+
+    private static final class Documentation {
+        @XmlAnyElement
+        @XmlMixed
+        List<Object> contents = new ArrayList<Object>();
+
+        void addAll(Documentation rhs) {
+            if(rhs==null)   return;
+
+            if(contents==null)
+                contents = new ArrayList<Object>();
+            if(!contents.isEmpty())
+                contents.add("\n\n");
+            contents.addAll(rhs.contents);
+        }
+    }
+
+    /** list of individual declarations. */
+    private final List<BIDeclaration> decls = new ArrayList<BIDeclaration>();
+
+    private static final class AppInfo {
+        /**
+         * Receives {@link BIDeclaration}s and other DOMs.
+         */
+        @XmlAnyElement(lax=true,value=DomHandlerEx.class)
+        List<Object> contents = new ArrayList<Object>();
+
+        public void addTo(BindInfo bi) {
+            if(contents==null)  return;
+
+            for (Object o : contents) {
+                if(o instanceof BIDeclaration)
+                    bi.addDecl((BIDeclaration)o);
+                // this is really PITA! I can't get the source location
+                if(o instanceof DomHandlerEx.DomAndLocation) {
+                    DomHandlerEx.DomAndLocation e = (DomHandlerEx.DomAndLocation)o;
+                    String nsUri = e.element.getNamespaceURI();
+                    if(nsUri==null || nsUri.equals("")
+                    || nsUri.equals(WellKnownNamespace.XML_SCHEMA))
+                        continue;   // this is definitely not a customization
+                    bi.addDecl(new BIXPluginCustomization(e.element,e.loc));
+                }
+            }
+        }
+    }
+
+
+    // only used by JAXB
+    @XmlElement
+    void setAppinfo(AppInfo aib) {
+        aib.addTo(this);
+    }
+
+
+
+    /**
+     * Gets the location of this annotation in the source file.
+     *
+     * @return
+     *      If the declarations are in fact specified in the source
+     *      code, a non-null valid object will be returned.
+     *      If this BindInfo is generated internally by XJC, then
+     *      null will be returned.
+     */
+    public Locator getSourceLocation() { return location; }
+
+
+    private XSComponent owner;
+    /**
+     * Sets the owner schema component and a reference to BGMBuilder.
+     * This method is called from the BGMBuilder before
+     * any BIDeclaration inside it is used.
+     */
+    public void setOwner( BGMBuilder _builder, XSComponent _owner ) {
+        this.owner = _owner;
+        this.builder = _builder;
+        for (BIDeclaration d : decls)
+            d.onSetOwner();
+    }
+    public XSComponent getOwner() { return owner; }
+
+    /**
+     * Back pointer to the BGMBuilder which is building
+     * a BGM from schema components including this customization.
+     */
+    public BGMBuilder getBuilder() { return builder; }
+
+    /** Adds a new declaration. */
+    public void addDecl( BIDeclaration decl ) {
+        if(decl==null)  throw new IllegalArgumentException();
+        decl.setParent(this);
+        decls.add(decl);
+    }
+
+    /**
+     * Gets the first declaration with a given name, or null
+     * if none is found.
+     */
+    public <T extends BIDeclaration>
+    T get( Class<T> kind ) {
+        for( BIDeclaration decl : decls ) {
+            if( kind.isInstance(decl) )
+                return kind.cast(decl);
+        }
+        return null; // not found
+    }
+
+    /**
+     * Gets all the declarations
+     */
+    public BIDeclaration[] getDecls() {
+        return decls.toArray(new BIDeclaration[decls.size()]);
+    }
+
+    /**
+     * Gets the documentation parsed from &lt;xs:documentation>s.
+     * The returned collection is to be added to {@link JDocComment#append(Object)}.
+     * @return  maybe null.
+     */
+    public String getDocumentation() {
+        // TODO: FIXME: correctly turn individual items to String including DOM
+        if(documentation==null || documentation.contents==null) return null;
+
+        StringBuilder buf = new StringBuilder();
+        for (Object c : documentation.contents) {
+            if(c instanceof String) {
+                buf.append(c.toString());
+            }
+            if(c instanceof Element) {
+                Transformer t = builder.getIdentityTransformer();
+                StringWriter w = new StringWriter();
+                try {
+                    Writer fw = new FilterWriter(w) {
+                        char[] buf = new char[1];
+
+                        public void write(int c) throws IOException {
+                            buf[0] = (char)c;
+                            write(buf,0,1);
+                        }
+
+                        public void write(char[] cbuf, int off, int len) throws IOException {
+                            MinimumEscapeHandler.theInstance.escape(cbuf,off,len,false,out);
+                        }
+
+                        public void write(String str, int off, int len) throws IOException {
+                            write(str.toCharArray(),off,len);
+                        }
+                    };
+                    t.transform(new DOMSource((Element)c),new StreamResult(fw));
+                } catch (TransformerException e) {
+                    throw new Error(e); // impossible
+                }
+                buf.append("\n<pre>\n");
+                buf.append(w);
+                buf.append("\n</pre>\n");
+            }
+        }
+        return buf.toString();
+    }
+
+    /**
+     * Merges all the declarations inside the given BindInfo
+     * to this BindInfo.
+     */
+    public void absorb( BindInfo bi ) {
+        for( BIDeclaration d : bi )
+            d.setParent(this);
+        this.decls.addAll( bi.decls );
+
+        if(this.documentation==null)
+            this.documentation = bi.documentation;
+        else
+            this.documentation.addAll(bi.documentation);
+    }
+
+    /** Gets the number of declarations. */
+    public int size() { return decls.size(); }
+
+    public BIDeclaration get( int idx ) { return decls.get(idx); }
+
+    public Iterator<BIDeclaration> iterator() {
+        return decls.iterator();
+    }
+
+    /**
+     * Gets the list of {@link CPluginCustomization}s from this.
+     *
+     * <p>
+     * Note that calling this method marks all those plug-in customizations
+     * as 'used'. So call it only when it's really necessary.
+     */
+    public CCustomizations toCustomizationList() {
+        CCustomizations r=null;
+        for( BIDeclaration d : this ) {
+            if(d instanceof BIXPluginCustomization) {
+                BIXPluginCustomization pc = (BIXPluginCustomization) d;
+                pc.markAsAcknowledged();
+                if(!Ring.get(Model.class).options.pluginURIs.contains(pc.getName().getNamespaceURI()))
+                    continue;   // this isn't a plugin customization
+                if(r==null)
+                    r = new CCustomizations();
+                r.add(new CPluginCustomization(pc.element,pc.getLocation()));
+            }
+        }
+
+        if(r==null)     r = CCustomizations.EMPTY;
+        return new CCustomizations(r);
+    }
+    /** An instance with the empty contents. */
+    public final static BindInfo empty = new BindInfo();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/CollectionTypeAttribute.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/CollectionTypeAttribute.java
new file mode 100644
index 0000000..c61e323
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/CollectionTypeAttribute.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.bind.annotation.XmlValue;
+
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRenderer;
+import com.sun.tools.internal.xjc.generator.bean.field.UntypedListFieldRenderer;
+import com.sun.tools.internal.xjc.generator.bean.field.FieldRendererFactory;
+import com.sun.tools.internal.xjc.model.Model;
+
+/**
+ * Bean used by JAXB to bind a collection type attribute to our {@link FieldRenderer}.
+ * @author Kohsuke Kawaguchi
+ */
+final class CollectionTypeAttribute {
+    @XmlValue
+    String collectionType = null;
+
+    /**
+     * Computed from {@link #collectionType} on demand.
+     */
+    @XmlTransient
+    private FieldRenderer fr;
+
+    FieldRenderer get(Model m) {
+        if(fr==null)
+            fr = calcFr(m);
+        return fr;
+    }
+
+    private FieldRenderer calcFr(Model m) {
+        FieldRendererFactory frf = m.options.getFieldRendererFactory();
+        if (collectionType==null)
+            return frf.getDefault();
+
+        if (collectionType.equals("indexed"))
+            return frf.getArray();
+
+        return frf.getList(m.codeModel.ref(collectionType));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/DomHandlerEx.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/DomHandlerEx.java
new file mode 100644
index 0000000..8a65a4c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/DomHandlerEx.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.annotation.DomHandler;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.transform.Source;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.sax.SAXResult;
+
+import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.xml.sax.Locator;
+import org.xml.sax.helpers.LocatorImpl;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * {@link DomHandler} that produces a W3C DOM but with a location information.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class DomHandlerEx implements DomHandler<DomHandlerEx.DomAndLocation,DomHandlerEx.ResultImpl> {
+
+    public static final class DomAndLocation {
+        public final Element element;
+        public final Locator loc;
+
+        public DomAndLocation(Element element, Locator loc) {
+            this.element = element;
+            this.loc = loc;
+        }
+    }
+
+    public ResultImpl createUnmarshaller(ValidationEventHandler errorHandler) {
+        return new ResultImpl();
+    }
+
+    public DomAndLocation getElement(ResultImpl r) {
+        return new DomAndLocation( ((Document)r.s2d.getDOM()).getDocumentElement(), r.location );
+    }
+
+    public Source marshal(DomAndLocation domAndLocation, ValidationEventHandler errorHandler) {
+        return new DOMSource(domAndLocation.element);
+    }
+
+    public static final class ResultImpl extends SAXResult {
+        final SAX2DOMEx s2d;
+
+        Locator location = null;
+
+        ResultImpl() {
+            try {
+                s2d = new SAX2DOMEx();
+            } catch (ParserConfigurationException e) {
+                throw new AssertionError(e);    // impossible
+            }
+
+            XMLFilterImpl f = new XMLFilterImpl() {
+                public void setDocumentLocator(Locator locator) {
+                    super.setDocumentLocator(locator);
+                    location = new LocatorImpl(locator);
+                }
+            };
+            f.setContentHandler(s2d);
+
+            setHandler(f);
+        }
+
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/EnumMemberMode.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/EnumMemberMode.java
new file mode 100644
index 0000000..c48a8ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/EnumMemberMode.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlEnum;
+import javax.xml.bind.annotation.XmlEnumValue;
+
+/**
+ * Enum member name handling mode.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@XmlEnum
+public enum EnumMemberMode {
+    @XmlEnumValue("skipGeneration")
+    SKIP,
+    @XmlEnumValue("generateError")
+    ERROR,
+    @XmlEnumValue("generateName")
+    GENERATE
+
+    ;
+
+    /**
+     * The mode will change to this when there's &lt;jaxb:enum> customization.
+     */
+    public EnumMemberMode getModeWithEnum() {
+        if(this==SKIP)  return ERROR;
+        return this;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/ForkingFilter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/ForkingFilter.java
new file mode 100644
index 0000000..34308f8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/ForkingFilter.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.util.ArrayList;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLFilter;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * {@link XMLFilter} that can fork an event to another {@link ContentHandler}
+ * in the middle.
+ *
+ * <p>
+ * The side handler receives SAX events before the next handler in the filter chain does.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class ForkingFilter extends XMLFilterImpl {
+
+    /**
+     * Non-null if we are also forking events to this handler.
+     */
+    private ContentHandler side;
+
+    /**
+     * The depth of the current element that the {@link #side} handler
+     * is seeing.
+     */
+    private int depth;
+
+    /**
+     * In-scope namespace mapping.
+     * namespaces[2n  ] := prefix
+     * namespaces[2n+1] := namespace URI
+     */
+    private final ArrayList<String> namespaces = new ArrayList<String>();
+
+    private Locator loc;
+
+    public ForkingFilter() {
+    }
+
+    public ForkingFilter(ContentHandler next) {
+        setContentHandler(next);
+    }
+
+    public ContentHandler getSideHandler() {
+        return side;
+    }
+
+    public void setDocumentLocator(Locator locator) {
+        super.setDocumentLocator(locator);
+        this.loc = locator;
+    }
+
+    public void startDocument() throws SAXException {
+        reset();
+        super.startDocument();
+    }
+
+    private void reset() {
+        namespaces.clear();
+        side = null;
+        depth = 0;
+    }
+
+    public void endDocument() throws SAXException {
+        loc = null;
+        reset();
+        super.endDocument();
+    }
+
+    public void startPrefixMapping(String prefix, String uri) throws SAXException {
+        if(side!=null)
+            side.startPrefixMapping(prefix,uri);
+        namespaces.add(prefix);
+        namespaces.add(uri);
+        super.startPrefixMapping(prefix,uri);
+    }
+
+    public void endPrefixMapping(String prefix) throws SAXException {
+        if(side!=null)
+            side.endPrefixMapping(prefix);
+        super.endPrefixMapping(prefix);
+        namespaces.remove(namespaces.size()-1);
+        namespaces.remove(namespaces.size()-1);
+    }
+
+    public void startElement(String uri, String localName, String qName, Attributes atts) throws SAXException {
+        if(side!=null) {
+            side.startElement(uri,localName,qName,atts);
+            depth++;
+        }
+        super.startElement(uri, localName, qName, atts);
+    }
+
+    /**
+     * Starts the event forking.
+     */
+    public void startForking(String uri, String localName, String qName, Attributes atts, ContentHandler side) throws SAXException {
+        if(this.side!=null)     throw new IllegalStateException();  // can't fork to two handlers
+
+        this.side = side;
+        depth = 1;
+        side.setDocumentLocator(loc);
+        side.startDocument();
+        for( int i=0; i<namespaces.size(); i+=2 )
+            side.startPrefixMapping(namespaces.get(i),namespaces.get(i+1));
+        side.startElement(uri,localName,qName,atts);
+    }
+
+    public void endElement(String uri, String localName, String qName) throws SAXException {
+        if(side!=null) {
+            side.endElement(uri,localName,qName);
+            depth--;
+            if(depth==0) {
+                for( int i=namespaces.size()-2; i>=0; i-=2 )
+                    side.endPrefixMapping(namespaces.get(i));
+                side.endDocument();
+                side = null;
+            }
+        }
+        super.endElement(uri, localName, qName);
+    }
+
+    public void characters(char ch[], int start, int length) throws SAXException {
+        if(side!=null)
+            side.characters(ch, start, length);
+        super.characters(ch, start, length);
+    }
+
+    public void ignorableWhitespace(char ch[], int start, int length) throws SAXException {
+        if(side!=null)
+            side.ignorableWhitespace(ch, start, length);
+        super.ignorableWhitespace(ch, start, length);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/LocalScoping.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/LocalScoping.java
new file mode 100644
index 0000000..7ab528a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/LocalScoping.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlEnumValue;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public enum LocalScoping {
+    @XmlEnumValue("nested")
+    NESTED,
+    @XmlEnumValue("toplevel")
+    TOPLEVEL
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/MessageBundle.properties
new file mode 100644
index 0000000..0c9db62
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/MessageBundle.properties
@@ -0,0 +1,28 @@
+#
+# Message resource file
+#
+
+
+NGCCRuntimeEx.Unimplemented = \
+	The "{0}" feature is not implemented yet
+
+NGCCRuntimeEx.Unsupported = \
+	The "{0}" feature is an unsupported optional feature
+
+NGCCRuntimeEx.UndefinedPrefix = \
+	Prefix "{0}" is undefined
+
+
+
+MagicTransducer.AttributeRequired = \
+	parseMethod/printMethod attributes are both required.
+
+ERR_ILLEGAL_FIXEDATTR = \
+	fixedAttributeAsConstantProperty is allowed only with attributes with a fixed value constraint.
+
+ERR_UNDEFINED_SIMPLE_TYPE = \
+	undefined simple type "{0}".
+
+ERR_CANNOT_BE_BOUND_TO_SIMPLETYPE = \
+    Simple type "{0}" is not allowed by the spec to be bound to a type-safe enum.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/Messages.java
new file mode 100644
index 0000000..7dc8549
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/Messages.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+enum Messages
+{
+    ERR_CANNOT_BE_BOUND_TO_SIMPLETYPE,
+    ERR_UNDEFINED_SIMPLE_TYPE,
+    ERR_ILLEGAL_FIXEDATTR
+    ;
+
+    /** Loads a string resource and formats it with specified arguments. */
+    String format( Object... args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getPackage().getName() + ".MessageBundle").getString(name());
+        return MessageFormat.format(text,args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/OptionalPropertyMode.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/OptionalPropertyMode.java
new file mode 100644
index 0000000..dfccd35
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/OptionalPropertyMode.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlEnumValue;
+
+/**
+ * Represents three constants of globalBindings/@optionalProperty.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public enum OptionalPropertyMode {
+    @XmlEnumValue("primitive")
+    PRIMITIVE,
+    @XmlEnumValue("wrapper")
+    WRAPPER,
+    @XmlEnumValue("isSet")
+    ISSET
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/binding.rng b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/binding.rng
new file mode 100644
index 0000000..d8de4ab
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/binding.rng
@@ -0,0 +1,880 @@
+<?xml version="1.0"?>
+<!DOCTYPE grammar [
+
+<!ENTITY XJCURI "http://java.sun.com/xml/ns/jaxb/xjc">
+]>
+<grammar
+  xmlns="http://relaxng.org/ns/structure/1.0"
+  xmlns:cc="http://www.xml.gr.jp/xmlns/relaxngcc"
+  xmlns:xs="http://www.w3.org/2001/XMLSchema"
+  xmlns:xjc="&XJCURI;"
+  xmlns:p="post-processor-to-build-schema-for-validation"
+  
+  ns="http://java.sun.com/xml/ns/jaxb"
+  
+  cc:runtime-type="com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.NGCCRuntimeEx"
+  cc:package="com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.parser"
+  datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes">
+<!--  cc:$runtime-type="com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx">-->
+  
+  <cc:java-import>
+    import com.sun.codemodel.internal.*;
+    import com.sun.tools.internal.xjc.generator.bean.field.*;
+    import com.sun.tools.internal.xjc.model.*;
+    import com.sun.xml.internal.bind.api.impl.NameConverter;
+    import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+    import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
+    import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.*;
+    import com.sun.tools.internal.xjc.reader.Const;
+    import org.xml.sax.*;
+    import org.w3c.dom.Document;
+    import org.xml.sax.helpers.DefaultHandler;
+    import java.util.*;
+    import javax.xml.namespace.QName;
+    import javax.xml.parsers.ParserConfigurationException;
+  </cc:java-import>
+  
+  <start cc:class="Root">
+    <choice>
+      <!-- root of the external binding file. -->
+      <ref name="declaration"/>
+      <!-- root of the internal binding -->
+      <ref name="annotation"/>
+    </choice>
+  </start>
+  
+  <!--
+    in context of XML Schema annotation
+  -->
+  <define name="annotation" cc:access="public" cc:class="AnnotationState"
+    cc:return-type="BindInfo" cc:return-value="bi">
+    
+    <cc:java-import>
+      import java.io.StringWriter;
+      import com.sun.xml.internal.bind.marshaller.DataWriter;
+    </cc:java-import>
+    <cc:java-body>
+      // customization declarations
+      public BindInfo bi;
+      
+      private StringWriter w;
+
+      private SAX2DOMEx sax2dom;
+    </cc:java-body>
+    
+    <element name="xs:annotation">
+      bi = new BindInfo($runtime.copyLocator());
+      $runtime.currentBindInfo = bi;
+      
+      <p:ignore><ref name="anyAttributes"/></p:ignore>
+      <zeroOrMore>
+        <choice>
+          <element name="xs:appinfo">
+            <p:ignore><ref name="anyAttributes"/></p:ignore>
+            <zeroOrMore>
+              <choice>
+                <group>
+                  result = <ref name="declaration" />
+                  bi.addDecl(result);
+                </group>
+                <element>
+                  <anyName><except>
+                    <nsName ns="&XJCURI;"/>
+                    <nsName /><!-- JAXB namespace URI -->
+                    <nsName ns="http://www.w3.org/2001/XMLSchema" />
+                  </except></anyName>
+
+                  if($runtime.isExtensionURI($uri)) {
+                    // parse this sub-tree as an extension
+                    try {
+                      sax2dom = new SAX2DOMEx();
+                    } catch( ParserConfigurationException e ) {
+                      throw new Error(e); // impossible
+                    }
+                    $runtime.redirectSubtree(sax2dom,$uri,$localName,$qname);
+                  } else {
+                    // ignore this sub-tree
+                    sax2dom = null;
+                    $runtime.redirectSubtree(new DefaultHandler(),$uri,$localName,$qname);
+                  }
+                  <empty/>
+                  <p:ignore><ref name="anyContents"/></p:ignore>
+                  if(sax2dom!=null) {
+                    bi.addDecl(new BIXPluginCustomization(((Document)sax2dom.getDOM()).getDocumentElement(),$runtime.copyLocator()));
+                  }
+                </element>
+                <text/>
+              </choice>
+            </zeroOrMore>
+          </element>
+          <!-- ignore documentations -->
+          <element name="xs:documentation">
+            <p:ignore><ref name="anyAttributes"/></p:ignore>
+            <zeroOrMore>
+              <choice>
+                <group>
+                  msg = <text />
+                  bi.appendDocumentation($runtime.truncateDocComment(msg),true);
+                </group>
+                <group>
+                  <element>
+                    <anyName />
+                    w = new StringWriter();
+                    DataWriter xw = new DataWriter(w,"UTF-8");
+                    xw.setXmlDecl(false);
+                    $runtime.redirectSubtree(xw,$uri,$localName,$qname);
+                    <empty/>
+                    <p:ignore><ref name="anyContents"/></p:ignore>
+                  </element>
+                  <![CDATA[
+                  bi.appendDocumentation("<pre>"+
+                    $runtime.escapeMarkup($runtime.truncateDocComment(w.toString()))+
+                    "</pre>",
+                    false );
+                  w=null;
+                  ]]>
+                </group>
+              </choice>
+            </zeroOrMore>
+          </element>
+        </choice>
+      </zeroOrMore>
+    </element>
+  </define>
+  
+  
+  
+  <!--
+  
+    Individual customization declarations
+  
+  -->
+  
+  <define name="declaration"
+    cc:return-type="BIDeclaration" cc:return-value="result">
+    
+    <cc:java-body>
+      private BIDeclaration result;
+    </cc:java-body>
+    <!-- result field will have the parsed object -->
+    <choice>
+      result = <ref name="globalBindings" />
+      result = <ref name="schemaBindings" />
+      result = <ref name="class"/>
+      result = <ref name="conversion"/>
+      result = <ref name="property"/>
+      result = <ref name="typesafeEnum"/>
+      result = <ref name="enumMember"/>
+      <!-- result = <ref name="idSymbolSpace"/-->
+      <!-- result = <ref name="dom"/-->
+    </choice>
+  </define>
+  
+  
+  <define name="globalBindings"
+    cc:return-type="BIGlobalBinding" cc:return-value="makeResult()">
+    
+    <cc:java-body>
+      private Locator loc;
+      private Map globalConvs = new HashMap();
+      private NameConverter nameConverter = NameConverter.standard;
+      private String enableJavaNamingConvention = "true";
+      private String fixedAttrToConstantProperty = "false";
+      private String needIsSetMethod = "false";
+      private String simpleTypeSubstitution = "false";
+      private boolean flattenClasses = false;
+      private Set enumBaseTypes = new HashSet();
+      private int defaultEnumSizeCap = 256;
+      private boolean generateEnumMemberName = false;
+      private boolean choiceContentPropertyWithModelGroupBinding = false;
+      private boolean xSmartWildcardDefaultBinding = false;
+      private boolean xSimpleMode;
+      private boolean generateValueClass = true;
+      private boolean generateElementClass = false;
+
+      public BIGlobalBinding makeResult() {
+        if( enumBaseTypes.size()==0 )
+          enumBaseTypes.add(new QName(WellKnownNamespace.XML_SCHEMA,"NCName")); // defaults to NCName
+        
+        return new BIGlobalBinding(
+          globalConvs,nameConverter,
+          choiceContentPropertyWithModelGroupBinding,
+          generateValueClass,
+          generateElementClass,
+          $runtime.parseBoolean(enableJavaNamingConvention),
+          $runtime.parseBoolean(fixedAttrToConstantProperty),
+          $runtime.parseBoolean(needIsSetMethod),
+          $runtime.parseBoolean(simpleTypeSubstitution),
+          generateEnumMemberName,
+          flattenClasses,
+          enumBaseTypes,
+          defaultEnumSizeCap,
+          ct,
+          serializable,
+          xSuperClass,
+          xSuperInterface,
+          xSimpleMode,
+          xSmartWildcardDefaultBinding,
+          loc);
+      }
+    </cc:java-body>
+    <element name="globalBindings">
+      loc = $runtime.copyLocator();
+      
+      <optional>
+        <attribute name="underscoreBinding">
+          <choice>
+            <value>asWordSeparator</value><!-- default -->
+            <group>
+              <value>asCharInWord</value>
+              nameConverter = NameConverter.jaxrpcCompatible;
+            </group>
+          </choice>
+        </attribute>
+      </optional>
+      
+      <optional>
+        <attribute name="enableJavaNamingConventions">
+          enableJavaNamingConvention = <data type="boolean"/>
+        </attribute>
+      </optional>
+      
+      <optional>
+        <attribute name="fixedAttributeAsConstantProperty">
+          fixedAttrToConstantProperty = <data type="boolean"/>
+        </attribute>
+      </optional>
+      
+      <optional>
+        <attribute name="generateIsSetMethod">
+          needIsSetMethod = <data type="boolean"/>
+        </attribute>
+      </optional>
+
+      <optional>
+        <attribute name="mapSimpleTypeDef">
+          simpleTypeSubstitution = <data type="boolean"/>
+        </attribute>
+      </optional>
+
+      <optional>
+        <attribute name="localScoping">
+          <choice>
+            <group>
+              <value>nested</value>
+              flattenClasses = false;
+            </group>
+            <group>
+              <value>toplevel</value>
+              flattenClasses = true;
+            </group>
+          </choice>
+        </attribute>
+      </optional>
+
+      <optional>
+        <attribute name="collectionType">
+          ct = <ref name="collectionType" />
+        </attribute>
+      </optional>
+      
+      <optional>
+        <attribute name="typesafeEnumMemberName">
+          <choice>
+            <value>generateError</value> <!-- default -->
+            <group>
+              <value>generateName</value>
+              generateEnumMemberName = true;
+            </group>
+          </choice>
+        </attribute>
+      </optional>
+      
+      <optional>
+        <attribute name="typesafeEnumBase">
+          <list>
+            <oneOrMore>
+              value = <data type="QName"/>
+              QName qn = $runtime.parseQName(value);
+              enumBaseTypes.add( qn );
+            </oneOrMore>
+          </list>
+        </attribute>
+      </optional>
+
+      <optional>
+        <attribute name="typesafeEnumMaxMembers">
+          <list>
+            <oneOrMore>
+              value = <data type="int"/>
+              defaultEnumSizeCap = Integer.parseInt(value);
+            </oneOrMore>
+          </list>
+        </attribute>
+      </optional>
+
+
+      <optional>
+        <attribute name="choiceContentProperty">
+          value = <data type="boolean"/>
+          choiceContentPropertyWithModelGroupBinding = $runtime.parseBoolean(value);
+        </attribute>
+      </optional>
+
+      <optional>
+        <attribute name="generateValueClass">
+          value = <data type="boolean"/>
+          generateValueClass = $runtime.parseBoolean(value);
+        </attribute>
+      </optional>
+
+      <optional>
+        <attribute name="generateElementClass">
+          value = <data type="boolean"/>
+          generateElementClass = $runtime.parseBoolean(value);
+        </attribute>
+      </optional>
+
+
+      <!-- unimplemented attributes -->
+      <optional>
+        <attribute name="enableValidation">
+          value = <data type="boolean"/>
+          if( $runtime.parseBoolean(value)==true )
+            $runtime.reportUnsupportedFeature("enableValidation");
+        </attribute>
+      </optional>
+      <optional>
+        <attribute name="enableFailFastCheck">
+          value = <data type="boolean"/>
+          if( $runtime.parseBoolean(value)==true )
+            $runtime.reportUnsupportedFeature("enableFailFastCheck");
+        </attribute>
+      </optional>
+      
+      <!-- body -->
+      <zeroOrMore>
+        <choice>
+          <element name="javaType">
+            <attribute name="xmlType">
+              xmlType = <data type="QName"/>
+            </attribute>
+            conv = <ref name="conversionBody" />
+            
+            globalConvs.put( $runtime.parseQName(xmlType), conv );
+          </element>
+          <element name="serializable">
+            <optional>
+              <attribute name="uid">
+                serialuid = <data type="long"/>
+              </attribute>
+            </optional>
+            if(serialuid!=null)
+              serializable = new BISerializable(Long.parseLong(serialuid));
+            else
+              serializable = new BISerializable(null);
+          </element>
+
+          <!-- global vendor extensions -->
+          serializable = <ref name="serializable"/>
+          xSuperClass = <ref name="superClass"/>
+          xSuperInterface = <ref name="superInterface"/>
+          <ref name="typeSubstitution" />
+          <element name="xjc:smartWildcardDefaultBinding">
+            <!--
+              changes the default binding of wildcards so that unknown elements will be
+              bound to DOM. This feature is not publicly available, and we may change it
+              later.
+            -->
+            xSmartWildcardDefaultBinding = true;
+            <empty />
+          </element>
+
+          <element name="xjc:simple">
+            xSimpleMode = true;
+            <empty />
+          </element>
+
+          <!--
+            light-weight runtime. we no longer support them,
+            but we don't issue an error when we see them.
+          -->
+          <element name="xjc:noMarshaller">
+            <empty />
+          </element>
+          <element name="xjc:noUnmarshaller">
+            <empty />
+          </element>
+          <element name="xjc:noValidator">
+            <empty />
+          </element>
+          <element name="xjc:noValidatingUnmarshaller">
+            <empty />
+          </element>
+        </choice>
+      </zeroOrMore>
+    </element>
+  </define>
+  
+  
+  <define name="schemaBindings"
+    cc:return-type="BISchemaBinding" cc:return-value="makeResult()">
+    
+    <cc:java-body>
+      private Locator loc;
+      public BISchemaBinding makeResult() {
+        return new BISchemaBinding(packageName,javadoc,tt,et,at,mt,nt,loc);
+      }
+    </cc:java-body>
+    
+    <element name="schemaBindings">
+      loc = $runtime.copyLocator();
+      
+      <optional>
+        <element name="package">
+          <optional>
+            packageName = <attribute name="name"/>
+          </optional>
+          <optional>
+            javadoc = <ref name="javadoc"/>
+          </optional>
+        </element>
+      </optional>
+      
+      <optional>
+        <element name="nameXmlTransform">
+          <!-- use newer version of RELAXNGCC and wrap them by <interleave> -->
+          <zeroOrMore>
+            <choice>
+              <element name="typeName">
+                tt = <ref name="nameXmlTransformRule"/>
+              </element>
+              <element name="elementName">
+                et = <ref name="nameXmlTransformRule"/>
+              </element>
+              <element name="attributeName">
+                at = <ref name="nameXmlTransformRule"/>
+              </element>
+              <element name="modelGroupName">
+                mt = <ref name="nameXmlTransformRule"/>
+              </element>
+              <element name="anonymousTypeName">
+                nt = <ref name="nameXmlTransformRule"/>
+              </element>
+            </choice>
+          </zeroOrMore>
+        </element>
+      </optional>
+    </element>
+  </define>
+  
+  <define name="nameXmlTransformRule"
+    cc:return-type="BISchemaBinding.NamingRule"
+    cc:return-value="new BISchemaBinding.NamingRule(prefix,suffix)">
+    
+    <cc:java-body>
+      private String prefix="";
+      private String suffix="";
+    </cc:java-body>
+    
+    
+    <optional>
+      <attribute name="prefix">
+        prefix = <data type="NCName"/>
+      </attribute>
+    </optional>
+    <optional>
+      <attribute name="suffix">
+        suffix = <data type="NCName"/>
+      </attribute>
+    </optional>
+  </define>
+  
+  
+  
+  <define name="javadoc" cc:return-type="String" cc:return-value="javadoc">
+      <element name="javadoc">
+        javadoc = <text />
+        javadoc = $runtime.truncateDocComment(javadoc);
+      </element>
+  </define>
+  
+  <define name="collectionType" cc:class="CollectionTypeState"
+    cc:return-type="FieldRenderer" cc:return-value="r">
+    <cc:java-body>
+      private FieldRenderer r = null;
+    </cc:java-body>
+    type = <data type="token"/>
+    
+    if( type.equals("indexed") )
+      r = FieldRenderer.ARRAY;
+    else
+      try {
+        r = new UntypedListFieldRenderer( $runtime.codeModel.ref(type) );
+      } catch( ClassNotFoundException e ) {
+        throw new NoClassDefFoundError(e.getMessage());
+      }
+  </define>
+  
+  
+  
+  <define name="class" cc:class="BIClassState"
+    cc:return-type="BIClass" cc:return-value="makeResult()">
+    
+    <cc:java-body>
+      private Locator loc;
+      public BIClass makeResult() {
+        return new BIClass(loc,name,implClass,javadoc);
+      }
+    </cc:java-body>
+    
+    <element name="class">
+      loc = $runtime.copyLocator();
+      <optional>
+        javadoc = <ref name="javadoc"/>
+      </optional>
+      <optional>
+        <attribute name="name">
+          name = <data type="identifier" datatypeLibrary="http://java.sun.com/xml/ns/relaxng/java-datatypes"/>
+        </attribute>
+      </optional>
+      <optional>
+        implClass = <attribute name="implClass"/>
+      </optional>
+    </element>
+  </define>
+  
+  <define name="property"
+    cc:return-type="BIProperty" cc:return-value="makeResult()">
+    
+    <cc:java-body>
+      private Locator loc;
+      private Boolean isConst = null;
+      private Boolean isSet = null;
+      private Boolean genElemProp = null;
+
+      public BIProperty makeResult() throws SAXException {
+        JType baseTypeRef = null;
+        if(baseType!=null)
+          baseTypeRef = $runtime.getType(baseType);
+          
+        return new BIProperty(loc,name,javadoc,baseTypeRef,conv,ct,isConst,isSet,genElemProp);
+      }
+    </cc:java-body>
+    
+    <element name="property">
+      loc = $runtime.copyLocator();
+      <optional>
+        name = <attribute name="name"/>
+      </optional>
+      <optional>
+        baseType = <attribute name="baseType"/>
+      </optional>
+      <optional>
+        <attribute name="collectionType">
+          ct = <ref name="collectionType" />
+        </attribute>
+      </optional>
+      <optional>
+        <attribute name="fixedAttributeAsConstantProperty">
+          isConstStr = <data type="boolean"/>
+          isConst = $runtime.parseBoolean(isConstStr)?Boolean.TRUE:Boolean.FALSE;
+        </attribute>
+      </optional>
+      <optional>
+        <attribute name="generateIsSetMethod">
+          isSetStr = <data type="boolean"/>
+          isSet = $runtime.parseBoolean(isSetStr)?Boolean.TRUE:Boolean.FALSE;
+        </attribute>
+      </optional>
+      <optional>
+        <attribute name="generateElementProperty">
+          genElemPropStr = <data type="boolean"/>
+          genElemProp = $runtime.parseBoolean(genElemPropStr)?Boolean.TRUE:Boolean.FALSE;
+        </attribute>
+      </optional>
+      <optional>
+        <attribute name="generateFailFastSetterMethod">
+          failFast = <data type="boolean"/>
+        </attribute>
+        if( $runtime.parseBoolean(failFast) ) {
+          $runtime.reportUnimplementedFeature("generateFailFastSetterMethod");
+        }
+      </optional>
+
+
+      <interleave>
+        <optional>
+          javadoc = <ref name="javadoc"/>
+        </optional>
+        <optional>
+          <element name="baseType">
+            conv = <ref name="conversion"/>
+          </element>
+        </optional>
+      </interleave>
+    </element>
+  </define>
+  
+  <define name="conversion"
+    cc:return-type="BIConversion" cc:return-value="r">
+    <element name="javaType">
+      r = <ref name="conversionBody"/>
+    </element>
+  </define>
+  
+  
+  <define name="conversionBody"
+    cc:return-type="BIConversion" cc:return-value="makeResult()">
+    
+    <cc:java-import>
+      import com.sun.tools.internal.xjc.generator.util.WhitespaceNormalizer;
+    </cc:java-import>
+    <cc:java-body><![CDATA[
+      public BIConversion makeResult() throws SAXException {
+        return new BIConversion.User( $runtime.copyLocator(), parse, print, $runtime.getType(type) );
+      }
+
+      // initialize with default values.
+      private String type  = "java.lang.String"; // in case a schema has an error
+      private String parse = null;
+      private String print = null;
+      private boolean context = false;
+    ]]></cc:java-body>
+    
+    
+    <optional>
+      parse = <attribute name="parseMethod" />
+    </optional>
+    <optional>
+      print = <attribute name="printMethod" />
+    </optional>
+    <attribute name="name" cc:alias="type"/>
+    <optional>
+      <attribute name="hasNsContext">
+        _context = <data type="boolean"/>
+        context = $runtime.parseBoolean(_context);
+      </attribute>
+    </optional>
+  </define>
+  
+  
+  <!-- type safe enum customization -->
+  <define name="typesafeEnum"
+    cc:return-type="BIEnum" cc:return-value="makeResult()">
+    
+    <cc:java-import>
+      import java.util.HashMap;
+    </cc:java-import>
+    <cc:java-body>
+      private HashMap members = new HashMap();
+      private boolean dontBind = false;
+      private Locator loc,loc2;
+      
+      private BIEnum makeResult() {
+        return new BIEnum(loc,dontBind,name,javadoc,members);
+      }
+    </cc:java-body>
+    
+    <element name="typesafeEnumClass">
+      loc = $runtime.copyLocator();
+      <choice>
+        <attribute name="map">
+          <value>false</value>
+          dontBind = true;
+        </attribute>
+        <group>
+          <optional>
+            name = <attribute name="name"/>
+          </optional>
+          <optional>
+            javadoc = <ref name="javadoc" />
+          </optional>
+          <zeroOrMore>
+            jname = null;
+            javadoc = null;
+            <element name="typesafeEnumMember">
+              loc2 = $runtime.copyLocator();
+              <optional>
+                jname = <attribute name="name"/>
+              </optional>
+              value = <attribute name="value"/>
+              <optional>
+                javadoc = <ref name="javadoc" />
+              </optional>
+              members.put( value, new BIEnumMember(loc2,jname,javadoc) );
+            </element>
+          </zeroOrMore>
+        </group>
+      </choice>
+    </element>
+  </define>
+  
+  
+  <!-- stand-alone type safe enum member customization -->
+  <!--
+     Note that only the name attribute is allowed here, and the same element
+     under the typesafeEnumClass is handled differently.
+  -->
+  <define name="enumMember"
+    cc:return-type="BIEnumMember" cc:return-value="makeResult()">
+    <cc:java-body>
+      private Locator loc;
+      private BIEnumMember makeResult() {
+        return new BIEnumMember(loc,name,javadoc);
+      }
+    </cc:java-body>
+  
+    <element name="typesafeEnumMember">
+      loc = $runtime.copyLocator();
+      name = <attribute name="name"/>
+      <optional>
+        javadoc = <ref name="javadoc" />
+      </optional>
+    </element>
+  </define>
+  
+  
+  <!-- XJC-exntension: root class support -->
+  <define name="superClass" cc:return-type="JDefinedClass" cc:return-value="makeResult()">
+    <cc:java-body>
+      private JDefinedClass makeResult() {
+        try {
+          JDefinedClass c = $runtime.codeModel._class(name);
+          c.hide();
+          return c;
+        } catch( JClassAlreadyExistsException e ) {
+          return e.getExistingClass();
+        }
+      }
+    </cc:java-body>
+    
+    <element name="xjc:superClass">
+      name = <attribute name="name" />
+    </element>
+  </define>
+  
+  <!-- XJC-exntension: root interface support -->
+  <define name="superInterface" cc:return-type="JDefinedClass" cc:return-value="makeResult()">
+    <cc:java-body>
+      private JDefinedClass makeResult() {
+        try {
+          JDefinedClass c = $runtime.codeModel._class(name,ClassType.INTERFACE);
+          c.hide();
+          return c;
+        } catch( JClassAlreadyExistsException e ) {
+          return e.getExistingClass();
+        }
+      }
+    </cc:java-body>
+
+    <element name="xjc:superInterface">
+      name = <attribute name="name" />
+    </element>
+  </define>
+
+  <!-- XJC-exntension: serialization support -->
+  <define name="serializable" cc:return-type="BISerializable" cc:return-value="makeResult()">
+    <cc:java-body>
+      private long uid = 1;
+      private BISerializable makeResult() {
+        return new BISerializable(uid);
+      }
+    </cc:java-body>
+    
+    <element name="xjc:serializable">
+//      loc = $runtime.copyLocator();
+      <optional>
+        <attribute name="uid">
+          v = <data type="long"/>
+          uid = Long.parseLong(v);
+        </attribute>
+      </optional>
+    </element>
+  </define>
+  
+  
+  <!-- XJC extension: type substitution -->
+  <define name="typeSubstitution" cc:return-type="boolean" cc:return-value="true">
+    <element name="xjc:typeSubstitution">
+      <attribute name="type"><value>complex</value></attribute>
+    </element>
+  </define>
+  
+  
+  <!-- XJC extension: ID symbol space support -->
+  <!--define name="idSymbolSpace" cc:return-type="BIXIdSymbolSpace" cc:return-value="makeResult()">
+    <cc:java-body>
+      private Locator loc;
+      private BIXIdSymbolSpace makeResult() {
+        return new BIXIdSymbolSpace(loc,name);
+      }
+    </cc:java-body>
+    
+    <element name="xjc:idSymbolSpace">
+      loc = $runtime.copyLocator();
+      name = <attribute name="name"/>
+    </element>
+  </define-->
+  
+  
+  <!-- XJC extension: DOM support -->
+  <!--define name="dom" cc:return-type="BIXDom" cc:return-value="makeResult()">
+    <cc:java-import>
+      import com.sun.tools.internal.xjc.grammar.ext.*;
+    </cc:java-import>
+    <cc:java-body>
+      private String factoryName = "w3c";
+      private Locator loc;
+      private BIXDom makeResult() {
+        try {
+          return new BIXDom(DOMItemFactory.getInstance(factoryName),loc);
+        } catch( DOMItemFactory.UndefinedNameException e ) {
+          throw new InternalError(); // impossible since we use validation to reject incorrect values
+        }
+      }
+    </cc:java-body>
+    
+    <element name="xjc:dom">
+      loc = $runtime.copyLocator();
+      <optional>
+        <attribute name="type">
+          <choice>
+            factoryName = <value>dom4j</value>
+            factoryName = <value>w3c</value>
+          </choice>
+        </attribute>
+      </optional>
+    </element>
+  </define-->
+  
+  
+  
+  
+  
+  
+  <p:ignore>
+    <!-- these patterns are ignored when using RelaxNGCC -->
+    <define name="anyContents">
+      <zeroOrMore>
+        <choice>
+          <text/>
+          <ref name="anyAttributes"/>
+          <element>
+            <anyName/>
+            <ref name="anyContents"/>
+          </element>
+        </choice>
+      </zeroOrMore>
+    </define>
+    
+    <define name="anyAttributes">
+      <zeroOrMore>
+        <attribute>
+          <anyName/>
+          <text/>
+        </attribute>
+      </zeroOrMore>
+    </define>
+  </p:ignore>
+</grammar>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/binding.xsd b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/binding.xsd
new file mode 100644
index 0000000..77b8cd1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/binding.xsd
@@ -0,0 +1,279 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!--
+ Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+ This code is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License version 2 only, as
+ published by the Free Software Foundation.  Sun designates this
+ particular file as subject to the "Classpath" exception as provided
+ by Sun in the LICENSE file that accompanied this code.
+
+ This code is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ version 2 for more details (a copy is included in the LICENSE file that
+ accompanied this code).
+
+ You should have received a copy of the GNU General Public License version
+ 2 along with this work; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+ Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ CA 95054 USA or visit www.sun.com if you need additional information or
+ have any questions.
+-->
+
+<!-- THIS IS A GENERATED FILE. DO NOT MODIFY. -->
+<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" targetNamespace="http://java.sun.com/xml/ns/jaxb" xmlns:jaxb="http://java.sun.com/xml/ns/jaxb" xmlns:xjc="http://java.sun.com/xml/ns/jaxb/xjc">
+  <xs:import namespace="http://java.sun.com/xml/ns/jaxb/xjc" schemaLocation="xjc.xsd"/>
+  <xs:import namespace="http://www.w3.org/2001/XMLSchema" schemaLocation="xs.xsd"/>
+  <xs:element name="declaration" abstract="true"/>
+  <xs:element name="globalBindings" substitutionGroup="jaxb:declaration">
+    <xs:complexType>
+      <xs:choice minOccurs="0" maxOccurs="unbounded">
+        <xs:element name="javaType">
+          <xs:complexType>
+            <xs:attribute name="xmlType" use="required" type="xs:QName"/>
+            <xs:attributeGroup ref="jaxb:conversionBody"/>
+          </xs:complexType>
+        </xs:element>
+        <xs:element ref="jaxb:serializable"/>
+        <xs:element ref="xjc:serializable"/>
+        <xs:element ref="xjc:superClass"/>
+        <xs:element ref="xjc:superInterface"/>
+        <xs:element ref="xjc:typeSubstitution"/>
+        <xs:element ref="xjc:smartWildcardDefaultBinding"/>
+        <xs:element ref="xjc:simple"/>
+        <xs:group   ref="xjc:globalJavaType" />
+        <xs:element ref="xjc:generateElementProperty"/>
+        <xs:element ref="xjc:noMarshaller"/>
+        <xs:element ref="xjc:noUnmarshaller"/>
+        <xs:element ref="xjc:noValidator"/>
+        <xs:element ref="xjc:noValidatingUnmarshaller"/>
+      </xs:choice>
+      <xs:attribute name="underscoreBinding">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="asWordSeparator"/>
+            <xs:enumeration value="asCharInWord"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="optionalProperty">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="wrapper"/>
+            <xs:enumeration value="primitive"/>
+            <xs:enumeration value="isSet"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="enableJavaNamingConventions" type="xs:boolean"/>
+      <xs:attribute name="fixedAttributeAsConstantProperty" type="xs:boolean"/>
+      <xs:attribute name="generateIsSetMethod" type="xs:boolean"/>
+      <xs:attribute name="mapSimpleTypeDef" type="xs:boolean"/>
+      <xs:attribute name="localScoping">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="nested" />
+            <xs:enumeration value="toplevel" />
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="collectionType" type="jaxb:collectionType"/>
+      <xs:attribute name="typesafeEnumMemberName">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="generateError"/>
+            <xs:enumeration value="generateName"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="typesafeEnumBase">
+        <xs:simpleType>
+          <xs:restriction>
+            <xs:simpleType>
+              <xs:list itemType="xs:QName"/>
+            </xs:simpleType>
+            <xs:minLength value="1"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="typesafeEnumMaxMembers">
+        <xs:simpleType>
+          <xs:restriction>
+            <xs:simpleType>
+              <xs:list itemType="xs:int"/>
+            </xs:simpleType>
+            <xs:minLength value="1"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="choiceContentProperty" type="xs:boolean"/>
+      <xs:attribute name="generateValueClass" type="xs:boolean"/>
+      <xs:attribute name="generateElementClass" type="xs:boolean"/>
+      <xs:attribute name="enableValidation" type="xs:boolean"/>
+      <xs:attribute name="enableFailFastCheck" type="xs:boolean"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="serializable">
+    <xs:complexType>
+      <xs:attribute name="uid" type="xs:long"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="schemaBindings" substitutionGroup="jaxb:declaration">
+    <xs:complexType>
+      <xs:sequence>
+        <xs:element minOccurs="0" ref="jaxb:package"/>
+        <xs:element minOccurs="0" ref="jaxb:nameXmlTransform"/>
+      </xs:sequence>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="package">
+    <xs:complexType>
+      <xs:sequence>
+        <xs:element minOccurs="0" ref="jaxb:javadoc"/>
+      </xs:sequence>
+      <xs:attribute name="name"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="nameXmlTransform">
+    <xs:complexType>
+      <xs:choice minOccurs="0" maxOccurs="unbounded">
+        <xs:element ref="jaxb:typeName"/>
+        <xs:element ref="jaxb:elementName"/>
+        <xs:element ref="jaxb:attributeName"/>
+        <xs:element ref="jaxb:modelGroupName"/>
+        <xs:element ref="jaxb:anonymousTypeName"/>
+      </xs:choice>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="typeName">
+    <xs:complexType>
+      <xs:attributeGroup ref="jaxb:nameXmlTransformRule"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="elementName">
+    <xs:complexType>
+      <xs:attributeGroup ref="jaxb:nameXmlTransformRule"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="attributeName">
+    <xs:complexType>
+      <xs:attributeGroup ref="jaxb:nameXmlTransformRule"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="modelGroupName">
+    <xs:complexType>
+      <xs:attributeGroup ref="jaxb:nameXmlTransformRule"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="anonymousTypeName">
+    <xs:complexType>
+      <xs:attributeGroup ref="jaxb:nameXmlTransformRule"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:attributeGroup name="nameXmlTransformRule">
+    <xs:attribute name="prefix" type="xs:NCName"/>
+    <xs:attribute name="suffix" type="xs:NCName"/>
+  </xs:attributeGroup>
+  <xs:element name="javadoc" type="xs:string"/>
+  <xs:simpleType name="collectionType">
+    <xs:restriction base="xs:token"/>
+  </xs:simpleType>
+  <xs:element name="class" substitutionGroup="jaxb:declaration">
+    <xs:complexType>
+      <xs:sequence>
+        <xs:element minOccurs="0" ref="jaxb:javadoc"/>
+      </xs:sequence>
+      <xs:attribute name="name" type="xs:string"/>
+      <xs:attribute name="implClass"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="property" substitutionGroup="jaxb:declaration">
+    <xs:complexType>
+      <xs:choice minOccurs="0" maxOccurs="unbounded">
+        <xs:element ref="jaxb:javadoc"/>
+        <xs:element ref="jaxb:baseType"/>
+      </xs:choice>
+      <xs:attribute name="name"/>
+      <xs:attribute name="collectionType" type="jaxb:collectionType"/>
+      <xs:attribute name="fixedAttributeAsConstantProperty" type="xs:boolean"/>
+      <xs:attribute name="generateIsSetMethod" type="xs:boolean"/>
+      <xs:attribute name="generateElementProperty" type="xs:boolean"/>
+      <xs:attribute name="generateFailFastSetterMethod" type="xs:boolean"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="baseType">
+    <xs:complexType>
+      <xs:sequence>
+        <xs:choice minOccurs="0"><!-- XML Schema is brain dead -->
+          <xs:element ref="jaxb:javaType" />
+          <xs:element ref="xjc:javaType" />
+        </xs:choice>
+      </xs:sequence>
+      <xs:attribute name="name"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="javaType" substitutionGroup="jaxb:declaration">
+    <xs:complexType>
+      <xs:attributeGroup ref="jaxb:conversionBody"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:attributeGroup name="conversionBody">
+    <xs:attribute name="parseMethod"/>
+    <xs:attribute name="printMethod"/>
+    <xs:attribute name="name" use="required"/>
+    <xs:attribute name="hasNsContext" type="xs:boolean"/>
+  </xs:attributeGroup>
+  <xs:element name="typesafeEnumClass" substitutionGroup="jaxb:declaration">
+    <xs:complexType>
+      <xs:sequence>
+        <xs:element minOccurs="0" ref="jaxb:javadoc"/>
+        <xs:element minOccurs="0" maxOccurs="unbounded" name="typesafeEnumMember">
+          <xs:complexType>
+            <xs:sequence>
+              <xs:element minOccurs="0" ref="jaxb:javadoc"/>
+            </xs:sequence>
+            <xs:attribute name="name"/>
+            <xs:attribute name="value" use="required"/>
+          </xs:complexType>
+        </xs:element>
+      </xs:sequence>
+      <xs:attribute name="map">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="false"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+      <xs:attribute name="name"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="typesafeEnumMember" substitutionGroup="jaxb:declaration">
+    <xs:complexType>
+      <xs:sequence>
+        <xs:element minOccurs="0" ref="jaxb:javadoc"/>
+      </xs:sequence>
+      <xs:attribute name="name" use="required"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="dom">
+    <xs:complexType>
+      <xs:attribute name="type" default="w3c"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:group name="anyContents">
+    <xs:sequence>
+      <xs:any minOccurs="0" maxOccurs="unbounded" processContents="skip"/>
+    </xs:sequence>
+  </xs:group>
+  <xs:attributeGroup name="anyContents">
+    <xs:attributeGroup ref="jaxb:anyAttributes"/>
+  </xs:attributeGroup>
+  <xs:attributeGroup name="anyAttributes">
+    <xs:anyAttribute processContents="skip"/>
+  </xs:attributeGroup>
+</xs:schema>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/package-info.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/package-info.java
new file mode 100644
index 0000000..2a4c6cf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/package-info.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+@XmlSchema(elementFormDefault = QUALIFIED, namespace=Const.JAXB_NSURI)
+package com.sun.tools.internal.xjc.reader.xmlschema.bindinfo;
+
+import javax.xml.bind.annotation.XmlSchema;
+
+import com.sun.tools.internal.xjc.reader.Const;
+
+import static javax.xml.bind.annotation.XmlNsForm.QUALIFIED;
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/package.html
new file mode 100644
index 0000000..4e0c1cb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/package.html
@@ -0,0 +1,9 @@
+<body>
+Object Model that represents customization declarations.
+
+<p>
+	<a href="http://relaxngcc.sourceforge.net/">RelaxNGCC</a> is used to parse
+	XML syntax into this representation, and the other parts of XJC will use
+	this object model.
+</p>
+</body>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/xjc.xsd b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/xjc.xsd
new file mode 100644
index 0000000..585b480
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/xjc.xsd
@@ -0,0 +1,101 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!--
+ Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+ This code is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License version 2 only, as
+ published by the Free Software Foundation.  Sun designates this
+ particular file as subject to the "Classpath" exception as provided
+ by Sun in the LICENSE file that accompanied this code.
+
+ This code is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ version 2 for more details (a copy is included in the LICENSE file that
+ accompanied this code).
+
+ You should have received a copy of the GNU General Public License version
+ 2 along with this work; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+ Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ CA 95054 USA or visit www.sun.com if you need additional information or
+ have any questions.
+-->
+
+<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" targetNamespace="http://java.sun.com/xml/ns/jaxb/xjc" xmlns:jaxb="http://java.sun.com/xml/ns/jaxb" xmlns:xjc="http://java.sun.com/xml/ns/jaxb/xjc">
+  <xs:import namespace="http://java.sun.com/xml/ns/jaxb" schemaLocation="binding.xsd"/>
+  <xs:import namespace="http://www.w3.org/2001/XMLSchema" schemaLocation="xs.xsd"/>
+  <xs:element name="smartWildcardDefaultBinding">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="simple">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="noMarshaller">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="noUnmarshaller">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="noValidator">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="noValidatingUnmarshaller">
+    <xs:complexType/>
+  </xs:element>
+  <xs:element name="superClass">
+    <xs:complexType>
+      <xs:attribute name="name" use="required"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="superInterface">
+    <xs:complexType>
+      <xs:attribute name="name" use="required"/>
+    </xs:complexType>
+  </xs:element>
+
+  <xs:complexType name="javaTypeContent">
+    <xs:attribute name="name" use="required"/>
+    <xs:attribute name="adapter" use="required"/>
+  </xs:complexType>
+  <xs:element name="javaType" type="xjc:javaTypeContent"/>
+  <xs:group name="globalJavaType">
+    <xs:sequence>
+      <xs:element name="javaType">
+        <xs:complexType>
+          <xs:complexContent>
+            <xs:extension base="xjc:javaTypeContent">
+              <xs:attribute name="xmlType" use="required" type="xs:QName"/>
+            </xs:extension>
+          </xs:complexContent>
+        </xs:complexType>
+      </xs:element>
+    </xs:sequence>
+  </xs:group>
+
+  <xs:element name="generateElementProperty" type="xs:boolean" />
+  <xs:element name="dom">
+    <xs:complexType>
+      <xs:attribute name="type" default="w3c"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="serializable">
+    <xs:complexType>
+      <xs:attribute name="uid" type="xs:long"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="typeSubstitution">
+    <xs:complexType>
+      <xs:attribute name="type" use="required">
+        <xs:simpleType>
+          <xs:restriction base="xs:token">
+            <xs:enumeration value="complex"/>
+          </xs:restriction>
+        </xs:simpleType>
+      </xs:attribute>
+    </xs:complexType>
+  </xs:element>
+</xs:schema>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/xs.xsd b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/xs.xsd
new file mode 100644
index 0000000..2796ebd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/bindinfo/xs.xsd
@@ -0,0 +1,56 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!--
+ Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+ This code is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License version 2 only, as
+ published by the Free Software Foundation.  Sun designates this
+ particular file as subject to the "Classpath" exception as provided
+ by Sun in the LICENSE file that accompanied this code.
+
+ This code is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ version 2 for more details (a copy is included in the LICENSE file that
+ accompanied this code).
+
+ You should have received a copy of the GNU General Public License version
+ 2 along with this work; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+ Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ CA 95054 USA or visit www.sun.com if you need additional information or
+ have any questions.
+-->
+
+<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" targetNamespace="http://www.w3.org/2001/XMLSchema" xmlns:jaxb="http://java.sun.com/xml/ns/jaxb" xmlns:xjc="http://java.sun.com/xml/ns/jaxb/xjc">
+  <xs:import namespace="http://java.sun.com/xml/ns/jaxb" schemaLocation="binding.xsd"/>
+  <xs:import namespace="http://java.sun.com/xml/ns/jaxb/xjc" schemaLocation="xjc.xsd"/>
+  <xs:element name="annotation">
+    <xs:complexType>
+      <xs:choice minOccurs="0" maxOccurs="unbounded">
+        <xs:element ref="xs:appinfo"/>
+        <xs:element ref="xs:documentation"/>
+      </xs:choice>
+      <xs:attributeGroup ref="jaxb:anyAttributes"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="appinfo">
+    <xs:complexType mixed="true">
+      <xs:choice minOccurs="0" maxOccurs="unbounded">
+        <xs:any processContents="lax" />
+      </xs:choice>
+      <xs:attributeGroup ref="jaxb:anyAttributes"/>
+    </xs:complexType>
+  </xs:element>
+  <xs:element name="documentation">
+    <xs:complexType mixed="true">
+      <xs:sequence>
+        <xs:any minOccurs="0" maxOccurs="unbounded" processContents="skip"/>
+      </xs:sequence>
+      <xs:attributeGroup ref="jaxb:anyAttributes"/>
+    </xs:complexType>
+  </xs:element>
+</xs:schema>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/CTBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/CTBuilder.java
new file mode 100644
index 0000000..b96d1a7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/CTBuilder.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.reader.Ring;
+import com.sun.tools.internal.xjc.reader.xmlschema.BGMBuilder;
+import com.sun.tools.internal.xjc.reader.xmlschema.BindGreen;
+import com.sun.tools.internal.xjc.reader.xmlschema.ClassSelector;
+import com.sun.tools.internal.xjc.reader.xmlschema.SimpleTypeBuilder;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+
+/**
+ * Builds a field expression from a complex type.
+ *
+ * Depending on a "kind" of complex type, the binding is
+ * quite different. For example, how a complex type is bound
+ * when it is extended from another complex type is very
+ * different from how it's bound when it has, say, mixed content model.
+ *
+ * Each different algorithm of binding a complex type is implemented
+ * as an implementation of this interface.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+abstract class CTBuilder {
+    /**
+     * Returns true if this owner can handle the given complex type.
+     */
+    abstract boolean isApplicable(XSComplexType ct);
+
+    /**
+     * Binds the given complex type. This method will be called
+     * only when the <code>isApplicable</code> method returns true.
+     */
+    abstract void build(XSComplexType ct);
+
+    protected final ComplexTypeFieldBuilder builder = Ring.get(ComplexTypeFieldBuilder.class);
+    protected final ClassSelector selector = Ring.get(ClassSelector.class);
+    protected final SimpleTypeBuilder simpleTypeBuilder = Ring.get(SimpleTypeBuilder.class);
+    protected final ErrorReceiver errorReceiver = Ring.get(ErrorReceiver.class);
+    protected final BindGreen green = Ring.get(BindGreen.class);
+    protected final XSSchemaSet schemas = Ring.get(XSSchemaSet.class);
+    protected final BGMBuilder bgmBuilder = Ring.get(BGMBuilder.class);
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ChoiceContentComplexTypeBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ChoiceContentComplexTypeBuilder.java
new file mode 100644
index 0000000..1cfbaac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ChoiceContentComplexTypeBuilder.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import java.util.Collections;
+
+import static com.sun.tools.internal.xjc.reader.xmlschema.ct.ComplexTypeBindingMode.NORMAL;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSParticle;
+
+/**
+ * Binds a complex type whose immediate child is a choice
+ * model group to a choice content interface.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ChoiceContentComplexTypeBuilder extends CTBuilder {
+
+    public boolean isApplicable(XSComplexType ct) {
+        if( !bgmBuilder.getGlobalBinding().isChoiceContentPropertyEnabled() )
+            return false;
+
+        if( ct.getBaseType()!=schemas.getAnyType() )
+            // My reading of the spec is that if a complex type is
+            // derived from another complex type by extension,
+            // its top level model group is always a sequence
+            // that combines the base type content model and
+            // the extension defined in the new complex type.
+            return false;
+
+        XSParticle p = ct.getContentType().asParticle();
+        if(p==null)
+            return false;
+
+        XSModelGroup mg = getTopLevelModelGroup(p);
+
+        if( mg.getCompositor()!=XSModelGroup.CHOICE )
+            return false;
+
+        if( p.isRepeated() )
+            return false;
+
+        return true;
+    }
+
+
+
+    private XSModelGroup getTopLevelModelGroup(XSParticle p) {
+        XSModelGroup mg = p.getTerm().asModelGroup();
+        if( p.getTerm().isModelGroupDecl() )
+            mg = p.getTerm().asModelGroupDecl().getModelGroup();
+        return mg;
+    }
+
+    public void build(XSComplexType ct) {
+        XSParticle p = ct.getContentType().asParticle();
+
+        builder.recordBindingMode(ct,NORMAL);
+
+        bgmBuilder.getParticleBinder().build(p,Collections.singleton(p));
+
+        green.attContainer(ct);
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ComplexTypeBindingMode.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ComplexTypeBindingMode.java
new file mode 100644
index 0000000..2880fce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ComplexTypeBindingMode.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+/**
+ * Three-state flag for a complex type.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+enum ComplexTypeBindingMode {
+
+    /**
+     * Neither FALLBACK nor NOMOREEXTENSION.
+     */
+    NORMAL,
+
+    /**
+     * If a complex type has falled back to the general list content and
+     * it is not NOMOREEXTENSION.
+     */
+    FALLBACK_CONTENT,
+
+    /**
+     * If a complex type has falled back to the rest content and
+     * it is not NOMOREEXTENSION.
+     */
+    FALLBACK_REST
+//
+//    /**
+//     * If a complex type is derived by restriction from a complex type
+//     * other than the ur-type. Once this flag is turned on, no more
+//     * derivation by extension is allowed.
+//     */
+//    static final ComplexTypeBindingMode NOMOREEXTENSION = new ComplexTypeBindingMode("noMoreExtension");
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ComplexTypeFieldBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ComplexTypeFieldBuilder.java
new file mode 100644
index 0000000..6117554
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ComplexTypeFieldBuilder.java
@@ -0,0 +1,105 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import com.sun.tools.internal.xjc.reader.xmlschema.BGMBuilder;
+import com.sun.tools.internal.xjc.reader.xmlschema.BindingComponent;
+import com.sun.xml.internal.xsom.XSComplexType;
+
+/**
+ * single entry point of building a field expression from a complex type.
+ *
+ * One object is created for one {@link BGMBuilder}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class ComplexTypeFieldBuilder extends BindingComponent {
+
+    /**
+     * All installed available complex type builders.
+     *
+     * <p>
+     * Builders are tried in this order, to put specific ones first.
+     */
+    private final CTBuilder[] complexTypeBuilders = new CTBuilder[]{
+        new ChoiceContentComplexTypeBuilder(),
+        new MixedComplexTypeBuilder(),
+        new FreshComplexTypeBuilder(),
+        new ExtendedComplexTypeBuilder(),
+        new RestrictedComplexTypeBuilder(),
+        new STDerivedComplexTypeBuilder()
+    };
+
+    /** Records ComplexTypeBindingMode for XSComplexType. */
+    private final Map<XSComplexType,ComplexTypeBindingMode> complexTypeBindingModes =
+        new HashMap<XSComplexType,ComplexTypeBindingMode>();
+
+    /**
+     * Binds a complex type to a field expression.
+     */
+    public void build( XSComplexType type ) {
+        for( CTBuilder ctb : complexTypeBuilders )
+            if( ctb.isApplicable(type) ) {
+                ctb.build(type);
+                return;
+            }
+
+        assert false; // shall never happen
+    }
+
+    /**
+     * Records the binding mode of the given complex type.
+     *
+     * <p>
+     * Binding of a derived complex type often depends on that of the
+     * base complex type. For example, when a base type is bound to
+     * the getRest() method, all the derived complex types will be bound
+     * in the same way.
+     *
+     * <p>
+     * For this reason, we have to record how each complex type is being
+     * bound.
+     */
+    protected void recordBindingMode( XSComplexType type, ComplexTypeBindingMode flag ) {
+        // it is an error to override the flag.
+        Object o = complexTypeBindingModes.put(type,flag);
+        assert o==null;
+    }
+
+    /**
+     * Obtains the binding mode recorded through
+     * {@link #recordBindingMode(XSComplexType, ComplexTypeBindingMode)}.
+     */
+    protected ComplexTypeBindingMode getBindingMode( XSComplexType type ) {
+        ComplexTypeBindingMode r = complexTypeBindingModes.get(type);
+        assert r!=null;
+        return r;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ExtendedComplexTypeBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ExtendedComplexTypeBuilder.java
new file mode 100644
index 0000000..1341a84
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/ExtendedComplexTypeBuilder.java
@@ -0,0 +1,277 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.tools.internal.xjc.reader.xmlschema.WildcardNameClassBuilder;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSDeclaration;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.visitor.XSTermFunction;
+
+import com.sun.xml.internal.rngom.nc.ChoiceNameClass;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import com.sun.xml.internal.rngom.nc.SimpleNameClass;
+
+/**
+ * Binds a complex type derived from another complex type by extension.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class ExtendedComplexTypeBuilder extends CTBuilder {
+
+    /**
+     * Map from {@link XSComplexType} to {@link NameClass}[2] that
+     * represents the names used in its child elements [0] and
+     * attributes [1].
+     */
+    private final Map<XSComplexType,NameClass[]> characteristicNameClasses = new HashMap<XSComplexType,NameClass[]>();
+
+    public boolean isApplicable(XSComplexType ct) {
+        XSType baseType = ct.getBaseType();
+        return baseType!=schemas.getAnyType()
+            &&  baseType.isComplexType()
+            &&  ct.getDerivationMethod()==XSType.EXTENSION;
+    }
+
+    public void build(XSComplexType ct) {
+        XSComplexType baseType = ct.getBaseType().asComplexType();
+
+        // build the base class
+        CClassInfo baseClass = selector.bindToType(baseType,true);
+        assert baseClass!=null;   // global complex type must map to a class
+
+        selector.getCurrentBean().setBaseClass(baseClass);
+
+        // derivation by extension.
+        ComplexTypeBindingMode baseTypeFlag = builder.getBindingMode(baseType);
+
+        XSContentType explicitContent = ct.getExplicitContent();
+
+        if(!checkIfExtensionSafe(baseType,ct)) {
+            // error. We can't handle any further extension
+            errorReceiver.error( ct.getLocator(),
+                Messages.ERR_NO_FURTHER_EXTENSION.format(
+                    baseType.getName(), ct.getName() )
+            );
+            return;
+        }
+
+
+        // explicit content is always either empty or a particle.
+        if( explicitContent!=null && explicitContent.asParticle()!=null ) {
+
+            if( baseTypeFlag==ComplexTypeBindingMode.NORMAL) {
+                // if we have additional explicit content, process them.
+
+                builder.recordBindingMode(ct,
+                    bgmBuilder.getParticleBinder().checkFallback(explicitContent.asParticle())
+                    ?ComplexTypeBindingMode.FALLBACK_REST
+                    :ComplexTypeBindingMode.NORMAL);
+
+                bgmBuilder.getParticleBinder().build(explicitContent.asParticle());
+
+            } else {
+                // the base class has already done the fallback.
+                // don't add anything new
+                builder.recordBindingMode(ct, baseTypeFlag );
+            }
+        } else {
+            // if it's empty, no additional processing is necessary
+            builder.recordBindingMode(ct, baseTypeFlag );
+        }
+
+        // adds attributes and we are through.
+        green.attContainer(ct);
+    }
+
+    /**
+     * Checks if this new extension is safe.
+     *
+     * UGLY.
+     * <p>
+     * If you have ctA extending ctB and ctB restricting ctC, our
+     * Java classes will look like CtAImpl extending CtBImpl
+     * extending CtCImpl.
+     *
+     * <p>
+     * Since a derived class unmarshaller uses the base class unmarshaller,
+     * this could potentially result in incorrect unmarshalling.
+     * We used to just reject such a case, but then we found that
+     * there are schemas that are using it.
+     *
+     * <p>
+     * One generalized observation that we reached is that if the extension
+     * is only adding new elements/attributes which has never been used
+     * in any of its base class (IOW, if none of the particle / attribute use /
+     * attribute wildcard can match the name of newly added elements/attributes)
+     * then it is safe to add them.
+     *
+     * <p>
+     * This function checks if the derivation chain to this type is
+     * not using restriction, and if it is, then checks if it is safe
+     * according to the above condition.
+     *
+     * @return false
+     *      If this complex type needs to be rejected.
+     */
+    private boolean checkIfExtensionSafe( XSComplexType baseType, XSComplexType thisType ) {
+        XSComplexType lastType = getLastRestrictedType(baseType);
+
+        if(lastType==null)
+            return true;    // no restriction in derivation chain
+
+        NameClass anc = NameClass.NULL;
+        // build name class for attributes in new complex type
+        Iterator itr = thisType.iterateDeclaredAttributeUses();
+        while( itr.hasNext() )
+            anc = new ChoiceNameClass( anc, getNameClass(((XSAttributeUse)itr.next()).getDecl()) );
+        // TODO: attribute wildcard
+
+        NameClass enc = getNameClass(thisType.getExplicitContent());
+
+        // check against every base type ... except the root anyType
+        while(lastType!=lastType.getBaseType()) {
+            if(checkCollision(anc,enc,lastType))
+                return false;
+
+            if(lastType.getBaseType().isSimpleType())
+                // if the base type is a simple type, there won't be
+                // any further name collision.
+                return true;
+
+            lastType = lastType.getBaseType().asComplexType();
+        }
+
+
+
+        return true;    // OK
+    }
+
+    /**
+     * Checks if the particles/attributes defined in the type parameter
+     * collides with the name classes of anc/enc.
+     *
+     * @return true if there's a collision.
+     */
+    private boolean checkCollision(NameClass anc, NameClass enc, XSComplexType type) {
+        NameClass[] chnc = characteristicNameClasses.get(type);
+        if(chnc==null) {
+            chnc = new NameClass[2];
+            chnc[0] = getNameClass(type.getContentType());
+
+            // build attribute name classes
+            NameClass nc = NameClass.NULL;
+            Iterator itr = type.iterateAttributeUses();
+            while( itr.hasNext() )
+                anc = new ChoiceNameClass( anc, getNameClass(((XSAttributeUse)itr.next()).getDecl()) );
+            XSWildcard wc = type.getAttributeWildcard();
+            if(wc!=null)
+                nc = new ChoiceNameClass( nc, WildcardNameClassBuilder.build(wc) );
+            chnc[1] = nc;
+
+            characteristicNameClasses.put(type,chnc);
+        }
+
+        return chnc[0].hasOverlapWith(enc) || chnc[1].hasOverlapWith(anc);
+    }
+
+    /**
+     * Gets a {@link NameClass} that represents all the terms in the given content type.
+     * If t is not a particle, just return an empty name class.
+     */
+    private NameClass getNameClass( XSContentType t ) {
+        if(t==null) return NameClass.NULL;
+        XSParticle p = t.asParticle();
+        if(p==null) return NameClass.NULL;
+        else        return p.getTerm().apply(contentModelNameClassBuilder);
+    }
+
+    /**
+     * Gets a {@link SimpleNameClass} from the name of a {@link XSDeclaration}.
+     */
+    private NameClass getNameClass( XSDeclaration decl ) {
+        return new SimpleNameClass(decl.getTargetNamespace(),decl.getName());
+    }
+
+    /**
+     * Computes a name class that represents everything in a given content model.
+     */
+    private final XSTermFunction<NameClass> contentModelNameClassBuilder = new XSTermFunction<NameClass>() {
+        public NameClass wildcard(XSWildcard wc) {
+            return WildcardNameClassBuilder.build(wc);
+        }
+
+        public NameClass modelGroupDecl(XSModelGroupDecl decl) {
+            return modelGroup(decl.getModelGroup());
+        }
+
+        public NameClass modelGroup(XSModelGroup group) {
+            NameClass nc = NameClass.NULL;
+            for( int i=0; i<group.getSize(); i++ )
+                nc = new ChoiceNameClass(nc,group.getChild(i).getTerm().apply(this));
+            return nc;
+        }
+
+        public NameClass elementDecl(XSElementDecl decl) {
+            return getNameClass(decl);
+        }
+    };
+
+
+    /**
+     * Looks for the derivation chain t_1 > t_2 > ... > t
+     * and find t_i such that t_i derives by restriction but
+     * for every j>i, t_j derives by extension.
+     *
+     * @return null
+     *      If there's no such t_i or if t_i is any type.
+     */
+    private XSComplexType getLastRestrictedType( XSComplexType t ) {
+        if( t.getBaseType()==schemas.getAnyType() )
+            return null;   // we don't count the restriction from anyType
+        if( t.getDerivationMethod()==XSType.RESTRICTION )
+            return t;
+
+        XSComplexType baseType = t.getBaseType().asComplexType();
+        if(baseType!=null)
+            return getLastRestrictedType(baseType);
+        else
+            return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/FreshComplexTypeBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/FreshComplexTypeBuilder.java
new file mode 100644
index 0000000..9e11068
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/FreshComplexTypeBuilder.java
@@ -0,0 +1,93 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import static com.sun.tools.internal.xjc.reader.xmlschema.ct.ComplexTypeBindingMode.FALLBACK_CONTENT;
+import static com.sun.tools.internal.xjc.reader.xmlschema.ct.ComplexTypeBindingMode.NORMAL;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor;
+
+/**
+ * Builds a complex type that inherits from the anyType complex type.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class FreshComplexTypeBuilder extends CTBuilder {
+
+    public boolean isApplicable(XSComplexType ct) {
+        return ct.getBaseType()==schemas.getAnyType()
+            &&  !ct.isMixed();  // not mixed
+    }
+
+    public void build(final XSComplexType ct) {
+        XSContentType contentType = ct.getContentType();
+
+        contentType.visit(new XSContentTypeVisitor() {
+            public void simpleType(XSSimpleType st) {
+                builder.recordBindingMode(ct,ComplexTypeBindingMode.NORMAL);
+
+                simpleTypeBuilder.refererStack.push(ct);
+                TypeUse use = simpleTypeBuilder.build(st);
+                simpleTypeBuilder.refererStack.pop();
+
+                BIProperty prop = BIProperty.getCustomization(ct);
+                CPropertyInfo p = prop.createValueProperty("Value",false,ct,use);
+                selector.getCurrentBean().addProperty(p);
+            }
+
+            public void particle(XSParticle p) {
+                // determine the binding of this complex type.
+
+                builder.recordBindingMode(ct,
+                    bgmBuilder.getParticleBinder().checkFallback(p)?FALLBACK_CONTENT:NORMAL);
+
+                bgmBuilder.getParticleBinder().build(p);
+
+                XSTerm term = p.getTerm();
+                if(term.isModelGroup() && term.asModelGroup().getCompositor()==XSModelGroup.ALL)
+                    selector.getCurrentBean().setOrdered(false);
+
+            }
+
+            public void empty(XSContentType e) {
+                builder.recordBindingMode(ct,NORMAL);
+            }
+        });
+
+        // adds attributes and we are through.
+        green.attContainer(ct);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/MessageBundle.properties
new file mode 100644
index 0000000..cdbb96d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/MessageBundle.properties
@@ -0,0 +1,5 @@
+ERR_NO_FURTHER_EXTENSION = \
+    Base complex type "{0}" is derived by restriction, while this complex type "{1}" \
+    is derived by extension. This is not currently handled by XJC, but we are \
+    seeking input on this issue. Please report this to the JAXB team.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/Messages.java
new file mode 100644
index 0000000..49b2bfc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/Messages.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources
+ */
+enum Messages {
+    ERR_NO_FURTHER_EXTENSION;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getPackage().getName() + ".MessageBundle");
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/MixedComplexTypeBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/MixedComplexTypeBuilder.java
new file mode 100644
index 0000000..96f5a8b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/MixedComplexTypeBuilder.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import com.sun.tools.internal.xjc.model.CBuiltinLeafInfo;
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.reader.RawTypeSet;
+import com.sun.tools.internal.xjc.reader.xmlschema.RawTypeSetBuilder;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import static com.sun.tools.internal.xjc.reader.xmlschema.ct.ComplexTypeBindingMode.FALLBACK_CONTENT;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSType;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class MixedComplexTypeBuilder extends CTBuilder {
+
+    public boolean isApplicable(XSComplexType ct) {
+        XSType bt = ct.getBaseType();
+        if(bt ==schemas.getAnyType() && ct.isMixed())
+            return true;    // fresh mixed complex type
+
+        // see issue 148. handle complex type extended from another and added mixed=true.
+        // the current implementation only works when the base type doesn't define
+        // any elements, and we should ideally warn it.
+        if(bt.isComplexType() && !bt.asComplexType().isMixed()
+        && ct.isMixed() && ct.getDerivationMethod()==XSType.EXTENSION)
+            return true;
+
+        return false;
+    }
+
+    public void build(XSComplexType ct) {
+        XSContentType contentType = ct.getContentType();
+
+        // if mixed, we fallback immediately
+        builder.recordBindingMode(ct,FALLBACK_CONTENT);
+
+        BIProperty prop = BIProperty.getCustomization(ct);
+
+        CPropertyInfo p;
+
+        if(contentType.asEmpty()!=null) {
+            p = prop.createValueProperty("Content",false,ct,CBuiltinLeafInfo.STRING);
+        } else {
+            RawTypeSet ts = RawTypeSetBuilder.build(contentType.asParticle(),false);
+            p = prop.createReferenceProperty("Content",false,ct,ts, true);
+        }
+
+        selector.getCurrentBean().addProperty(p);
+
+        // adds attributes and we are through.
+        green.attContainer(ct);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/RestrictedComplexTypeBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/RestrictedComplexTypeBuilder.java
new file mode 100644
index 0000000..3b00a77
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/RestrictedComplexTypeBuilder.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import com.sun.tools.internal.xjc.model.CClassInfo;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSType;
+
+/**
+ * Binds a complex type derived from another complex type
+ * by restriction.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class RestrictedComplexTypeBuilder extends CTBuilder {
+
+    public boolean isApplicable(XSComplexType ct) {
+        XSType baseType = ct.getBaseType();
+        return baseType!=schemas.getAnyType()
+            &&  baseType.isComplexType()
+            &&  ct.getDerivationMethod()==XSType.RESTRICTION;
+    }
+
+    public void build(XSComplexType ct) {
+        XSComplexType baseType = ct.getBaseType().asComplexType();
+
+        // build the base class
+        CClassInfo baseClass = selector.bindToType(baseType,true);
+        assert baseClass!=null;   // global complex type must map to a class
+
+        selector.getCurrentBean().setBaseClass(baseClass);
+
+        // determine the binding of this complex type.
+        builder.recordBindingMode(ct,builder.getBindingMode(baseType));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/STDerivedComplexTypeBuilder.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/STDerivedComplexTypeBuilder.java
new file mode 100644
index 0000000..d53fb2e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/ct/STDerivedComplexTypeBuilder.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.ct;
+
+import com.sun.tools.internal.xjc.model.CPropertyInfo;
+import com.sun.tools.internal.xjc.model.TypeUse;
+import com.sun.tools.internal.xjc.reader.xmlschema.bindinfo.BIProperty;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+
+/**
+ * Binds a complex type derived from a simple type.
+ * When a complex type is derived from a simple type, it is always
+ * by extension.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class STDerivedComplexTypeBuilder extends CTBuilder {
+
+    public boolean isApplicable(XSComplexType ct) {
+        return ct.getBaseType().isSimpleType();
+    }
+
+    public void build(XSComplexType ct) {
+        assert ct.getDerivationMethod()==XSType.EXTENSION;
+
+        // base type is a simple type
+        XSSimpleType baseType = ct.getBaseType().asSimpleType();
+
+        // determine the binding of this complex type.
+        builder.recordBindingMode(ct,ComplexTypeBindingMode.NORMAL);
+
+        simpleTypeBuilder.refererStack.push(ct);
+        TypeUse use = simpleTypeBuilder.build(baseType);
+        simpleTypeBuilder.refererStack.pop();
+
+        BIProperty prop = BIProperty.getCustomization(ct);
+        CPropertyInfo p = prop.createValueProperty("Value",false,baseType,use);
+        selector.getCurrentBean().addProperty(p);
+
+        // adds attributes and we are through.
+        green.attContainer(ct);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/CustomizationContextChecker.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/CustomizationContextChecker.java
new file mode 100644
index 0000000..efe86a6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/CustomizationContextChecker.java
@@ -0,0 +1,194 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.parser;
+
+import java.util.HashSet;
+import java.util.Set;
+import java.util.Stack;
+
+import javax.xml.namespace.QName;
+
+import com.sun.tools.internal.xjc.reader.Const;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * Checks if binding declarations are placed where they are allowed.
+ *
+ * <p>
+ * For example, if a &lt;jaxb:property> customization is given under
+ * the &lt;xs:simpleContent> element, this class raises an error.
+ *
+ * <p>
+ * our main checkpoint of misplaced customizations are in BGMBuilder.
+ * There, we mark a customization whenever we use it. At the end of the
+ * day, we look for unmarked customizations and raise errors for them.
+ *
+ * <p>
+ * Between this approach and the JAXB spec 1.0 is a problem that
+ * the spec allows/prohibits customizations at schema element level,
+ * while BGMBuilder and XSOM works on schema component levels.
+ *
+ * <p>
+ * For example, a property customization is allowed on a complex type
+ * schema component, but it's only allowed on the &lt;complexType>
+ * element. The spec team informed us that they would consider resolving
+ * this discrepancy in favor of RI, but meanwhile we need to detect
+ * errors correctly.
+ *
+ * <p>
+ * This filter is implemented for this purpose.
+ *
+ *
+ * <h2>Customization and allowed locations</h2>
+ *
+ * - globalBinding/schemaBinding
+ *     schema
+ *
+ * - class
+ *     complexType(*), modelGroupDecl, modelGroup, element
+ *
+ * - property
+ *     attribute, element, any, modelGroup, modelGroupRef, complexType(*)
+ *
+ * - javaType
+ *     simpleType(*)
+ *
+ * - typesafeEnumClass
+ *     simpleType(*)
+ *
+ * - typesafeEnumMember
+ *     simpleType(*), enumeration
+ *
+ * Components marked with '*' needs a check by this component
+ * since more than one schema element corresponds to one schema component
+ * of that type.
+ *
+ * <p>
+ * For simple types, customizations are allowed only under the &lt;xs:simpleType>
+ * element, and for complex types they are allowed only under the
+ * &lt;xs:cimplexType> element.
+ *
+ * <p>
+ * So the bottom line is that it would be suffice if we just make sure
+ * that no customization will be attached under other elements of
+ * simple types and complex types. Those are:
+ *
+ * - simpleType/restriction
+ * - list
+ * - union
+ * - complexType/(simple or complex)Content
+ * - complexType/(simple or complex)Content/(restriction of extension)
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class CustomizationContextChecker extends XMLFilterImpl {
+
+    /** Keep names of all the ancestor elements. */
+    private final Stack<QName> elementNames = new Stack<QName>();
+
+    private final ErrorHandler errorHandler;
+
+    private Locator locator;
+
+    /** Set of element names that cannot have JAXB customizations. */
+    private static final Set<String> prohibitedSchemaElementNames = new HashSet<String>();
+
+    /**
+     * @param _errorHandler
+     *      Detected errors will be sent to this object.
+     */
+    public CustomizationContextChecker( ErrorHandler _errorHandler ) {
+        this.errorHandler = _errorHandler;
+    }
+
+    static {
+        prohibitedSchemaElementNames.add("restriction");
+        prohibitedSchemaElementNames.add("extension");
+        prohibitedSchemaElementNames.add("simpleContent");
+        prohibitedSchemaElementNames.add("complexContent");
+        prohibitedSchemaElementNames.add("list");
+        prohibitedSchemaElementNames.add("union");
+    }
+
+
+
+
+    /** Gets the stack top. */
+    private QName top() {
+        return elementNames.peek();
+    }
+
+    public void startElement(String namespaceURI, String localName, String qName, Attributes atts) throws SAXException {
+        QName newElement = new QName(namespaceURI,localName);
+
+        if( newElement.getNamespaceURI().equals(Const.JAXB_NSURI)
+         && top().getNamespaceURI().equals(WellKnownNamespace.XML_SCHEMA) ) {
+            // we hit a JAXB customization. the stack top should be
+            // <xs:appinfo>
+            if( elementNames.size()>=3 ) {
+                // the above statement checks if the following statement doesn't
+                // cause an exception.
+                QName schemaElement = elementNames.get( elementNames.size()-3 );
+                if( prohibitedSchemaElementNames.contains(schemaElement.getLocalPart()) ) {
+                    // the owner schema element is in the wanted list.
+                    errorHandler.error( new SAXParseException(
+                        Messages.format(
+                            Messages.ERR_UNACKNOWLEDGED_CUSTOMIZATION,
+                            localName ),
+                        locator ) );
+                }
+            }
+
+
+        }
+
+        elementNames.push(newElement);
+
+        super.startElement(namespaceURI, localName, qName, atts );
+    }
+
+    public void endElement(String namespaceURI, String localName, String qName)
+        throws SAXException {
+
+        super.endElement(namespaceURI, localName, qName);
+
+        elementNames.pop();
+    }
+
+    public void setDocumentLocator(Locator locator) {
+        super.setDocumentLocator(locator);
+        this.locator = locator;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/IncorrectNamespaceURIChecker.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/IncorrectNamespaceURIChecker.java
new file mode 100644
index 0000000..4677fa9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/IncorrectNamespaceURIChecker.java
@@ -0,0 +1,118 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.parser;
+
+import com.sun.tools.internal.xjc.reader.Const;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * This filter detects the use of incorrect JAXB namespace URI.
+ *
+ * When the binding compiler looks at a schema file, it always look
+ * for the namespace URI of the elements (which is correct, BTW.)
+ *
+ * <p>
+ * However, one unfortunate downside of this philosophically correct
+ * behavior is that there is no provision or safety check when an user
+ * misspelled JAXB binding customization namespace.
+ *
+ * <p>
+ * This checker inspects the input document and look for the use of the
+ * prefix "jaxb". If the document doesn't associate any prefix to the
+ * JAXB customization URI and if it does associate the jaxb prefix,
+ * this checker will issue a warning.
+ *
+ * <p>
+ * This warning can happen to completely correct schema (because
+ * nothing prevents you from using the prefix "jaxb" for other purpose
+ * while using a JAXB compiler on the same schema) but in practice
+ * this would be quite unlikely.
+ *
+ * <p>
+ * This justifies the use of this filter.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class IncorrectNamespaceURIChecker extends XMLFilterImpl {
+
+    public IncorrectNamespaceURIChecker( ErrorHandler handler ) {
+        this.errorHandler = handler;
+    }
+
+    private ErrorHandler errorHandler;
+
+    private Locator locator = null;
+
+    /** Sets to true once we see the jaxb prefix in use. */
+    private boolean isJAXBPrefixUsed = false;
+    /** Sets to true once we see the JAXB customization namespace URI. */
+    private boolean isCustomizationUsed = false;
+
+    public void endDocument() throws SAXException {
+        if( isJAXBPrefixUsed && !isCustomizationUsed ) {
+            SAXParseException e = new SAXParseException(
+                Messages.format(Messages.WARN_INCORRECT_URI, Const.JAXB_NSURI),
+                locator );
+            errorHandler.warning(e);
+        }
+
+        super.endDocument();
+    }
+
+    public void startPrefixMapping(String prefix, String uri) throws SAXException {
+        if( prefix.equals("jaxb") )
+            isJAXBPrefixUsed = true;
+        if( uri.equals(Const.JAXB_NSURI) )
+            isCustomizationUsed = true;
+
+        super.startPrefixMapping(prefix, uri);
+    }
+
+    public void startElement(String namespaceURI, String localName, String qName, Attributes atts)
+        throws SAXException {
+        super.startElement(namespaceURI, localName, qName, atts);
+
+        // I'm not sure if this is necessary (SAX might report the change of the default prefix
+        // through the startPrefixMapping method, and I think it does indeed.)
+        //
+        // but better safe than sorry.
+
+        if( namespaceURI.equals(Const.JAXB_NSURI) )
+            isCustomizationUsed = true;
+    }
+
+    public void setDocumentLocator( Locator locator ) {
+        super.setDocumentLocator( locator );
+        this.locator = locator;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/LSInputSAXWrapper.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/LSInputSAXWrapper.java
new file mode 100644
index 0000000..da990ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/LSInputSAXWrapper.java
@@ -0,0 +1,110 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.parser;
+
+import java.io.InputStream;
+import java.io.Reader;
+
+import org.w3c.dom.ls.LSInput;
+import org.xml.sax.InputSource;
+
+/**
+ * LSInput implementation that wraps a SAX InputSource
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+public class LSInputSAXWrapper implements LSInput {
+    private InputSource core;
+
+    public LSInputSAXWrapper(InputSource inputSource) {
+        assert inputSource!=null;
+        core = inputSource;
+    }
+
+    public Reader getCharacterStream() {
+        return core.getCharacterStream();
+    }
+
+    public void setCharacterStream(Reader characterStream) {
+        core.setCharacterStream(characterStream);
+    }
+
+    public InputStream getByteStream() {
+        return core.getByteStream();
+    }
+
+    public void setByteStream(InputStream byteStream) {
+        core.setByteStream(byteStream);
+    }
+
+    public String getStringData() {
+        return null;
+    }
+
+    public void setStringData(String stringData) {
+        // no-op
+    }
+
+    public String getSystemId() {
+        return core.getSystemId();
+    }
+
+    public void setSystemId(String systemId) {
+        core.setSystemId(systemId);
+    }
+
+    public String getPublicId() {
+        return core.getPublicId();
+    }
+
+    public void setPublicId(String publicId) {
+        core.setPublicId(publicId);
+    }
+
+    public String getBaseURI() {
+        return null;
+    }
+
+    public void setBaseURI(String baseURI) {
+        // no-op
+    }
+
+    public String getEncoding() {
+        return core.getEncoding();
+    }
+
+    public void setEncoding(String encoding) {
+        core.setEncoding(encoding);
+    }
+
+    public boolean getCertifiedText() {
+        return true;
+    }
+
+    public void setCertifiedText(boolean certifiedText) {
+        // no-op
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/MessageBundle.properties
new file mode 100644
index 0000000..a620ea1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/MessageBundle.properties
@@ -0,0 +1,28 @@
+#
+# Message resource file
+#
+
+
+
+CustomizationContextChecker.UnacknolwedgedCustomization = \
+	Specified {0} customization is not used.
+
+
+SchemaConstraintChecker.UnableToCheckCorrectness = \
+    Unable to check the correctness of the schema due to OutOfMemoryError. \
+    This typically happens when your schema contains constructs like maxOccurs="999". \
+    In the future compilation, add the '-nv' option to skip the correctness check \
+    for faster compilation. 
+
+
+
+
+IncorrectNamespaceURIChecker.WarnIncorrectURI = \
+	No JAXB customization was detected in the schema but the prefix "jaxb" is used for \
+	other namespace URIs. If you did intend to use JAXB customization, make sure the namespace URI is "{0}"
+
+	
+
+
+	
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/Messages.java
new file mode 100644
index 0000000..981adf2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/Messages.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.parser;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getPackage().getName() +".MessageBundle").getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+
+
+    static final String ERR_UNACKNOWLEDGED_CUSTOMIZATION =
+        "CustomizationContextChecker.UnacknolwedgedCustomization"; // arg:1
+
+    static final String WARN_INCORRECT_URI = // 1 args
+        "IncorrectNamespaceURIChecker.WarnIncorrectURI";
+
+    static final String WARN_UNABLE_TO_CHECK_CORRECTNESS = // 0 args
+        "SchemaConstraintChecker.UnableToCheckCorrectness";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/SchemaConstraintChecker.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/SchemaConstraintChecker.java
new file mode 100644
index 0000000..a12967c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/SchemaConstraintChecker.java
@@ -0,0 +1,124 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.parser;
+
+import java.io.File;
+import java.io.IOException;
+
+import javax.xml.transform.Source;
+import javax.xml.transform.sax.SAXSource;
+import javax.xml.validation.SchemaFactory;
+
+import com.sun.tools.internal.xjc.ConsoleErrorReporter;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.util.ErrorReceiverFilter;
+
+import org.w3c.dom.ls.LSInput;
+import org.w3c.dom.ls.LSResourceResolver;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+import static javax.xml.XMLConstants.W3C_XML_SCHEMA_NS_URI;
+
+/**
+ * Checks XML Schema XML representation constraints and
+ * schema component constraints by using JAXP 1.3 validation framework.
+ * <p/>
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ * @author Ryan Shoemaker (ryan.shoemaker@sun.com)
+ */
+public class SchemaConstraintChecker {
+
+    /**
+     * @param schemas      Schema files to be checked.
+     * @param errorHandler detected errors will be reported to this handler.
+     * @return true if there was no error, false if there were errors.
+     */
+    public static boolean check(InputSource[] schemas,
+                                ErrorReceiver errorHandler, final EntityResolver entityResolver) {
+
+        ErrorReceiverFilter errorFilter = new ErrorReceiverFilter(errorHandler);
+        boolean hadErrors = false;
+
+        SchemaFactory sf = SchemaFactory.newInstance(W3C_XML_SCHEMA_NS_URI);
+        sf.setErrorHandler(errorFilter);
+        if( entityResolver != null ) {
+            sf.setResourceResolver(new LSResourceResolver() {
+                public LSInput resolveResource(String type, String namespaceURI, String publicId, String systemId, String baseURI) {
+                    try {
+                        // XSOM passes the namespace URI to the publicID parameter.
+                        // we do the same here .
+                        InputSource is = entityResolver.resolveEntity(namespaceURI, systemId);
+                        if(is==null)    return null;
+                        return new LSInputSAXWrapper(is);
+                    } catch (SAXException e) {
+                        // TODO: is this sufficient?
+                        return null;
+                    } catch (IOException e) {
+                        // TODO: is this sufficient?
+                        return null;
+                    }
+                }
+            });
+        }
+
+        try {
+            sf.newSchema(getSchemaSource(schemas));
+        } catch (SAXException e) {
+            // TODO: we haven't thrown exceptions from here before. should we just trap them and return false?
+            hadErrors = true;
+        } catch( OutOfMemoryError e) {
+            errorHandler.warning(null,Messages.format(Messages.WARN_UNABLE_TO_CHECK_CORRECTNESS));
+        }
+
+        return !(hadErrors || errorFilter.hadError());
+    }
+
+    /**
+     * convert an array of {@link InputSource InputSource} into an
+     * array of {@link Source Source}
+     *
+     * @param schemas array of {@link InputSource InputSource}
+     * @return array of {@link Source Source}
+     */
+    private static Source[] getSchemaSource(InputSource[] schemas) {
+        SAXSource[] sources = new SAXSource[schemas.length];
+        for (int i = 0; i < schemas.length; i++)
+            sources[i] = new SAXSource(schemas[i]);
+        return sources;
+    }
+
+    // quick test
+    public static void main(String[] args) throws IOException {
+        InputSource[] sources = new InputSource[args.length];
+        for (int i = 0; i < args.length; i++)
+            sources[i] = new InputSource(new File(args[i]).toURL().toExternalForm());
+
+        check(sources, new ConsoleErrorReporter(), null);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/XMLSchemaInternalizationLogic.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/XMLSchemaInternalizationLogic.java
new file mode 100644
index 0000000..1ab176a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/reader/xmlschema/parser/XMLSchemaInternalizationLogic.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.reader.xmlschema.parser;
+
+import com.sun.tools.internal.xjc.reader.internalizer.AbstractReferenceFinderImpl;
+import com.sun.tools.internal.xjc.reader.internalizer.DOMForest;
+import com.sun.tools.internal.xjc.reader.internalizer.InternalizationLogic;
+import com.sun.tools.internal.xjc.util.DOMUtils;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.NodeList;
+import org.xml.sax.Attributes;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * XML Schema specific internalization logic.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class XMLSchemaInternalizationLogic implements InternalizationLogic {
+
+    /**
+     * This filter looks for &lt;xs:import> and &lt;xs:include>
+     * and parses those documents referenced by them.
+     */
+    private static final class ReferenceFinder extends AbstractReferenceFinderImpl {
+        ReferenceFinder( DOMForest parent ) {
+            super(parent);
+        }
+
+        protected String findExternalResource( String nsURI, String localName, Attributes atts) {
+            if( WellKnownNamespace.XML_SCHEMA.equals(nsURI)
+            && ("import".equals(localName) || "include".equals(localName) ) )
+                return atts.getValue("schemaLocation");
+            else
+                return null;
+        }
+    }
+
+    public XMLFilterImpl createExternalReferenceFinder(DOMForest parent) {
+        return new ReferenceFinder(parent);
+    }
+
+    public boolean checkIfValidTargetNode(DOMForest parent, Element bindings, Element target) {
+        return WellKnownNamespace.XML_SCHEMA.equals(target.getNamespaceURI());
+    }
+
+    public Element refineTarget(Element target) {
+        // look for existing xs:annotation
+        Element annotation = DOMUtils.getFirstChildElement(target, WellKnownNamespace.XML_SCHEMA, "annotation");
+        if(annotation==null)
+            // none exists. need to make one
+            annotation = insertXMLSchemaElement( target, "annotation" );
+
+        // then look for appinfo
+        Element appinfo = DOMUtils.getFirstChildElement(annotation, WellKnownNamespace.XML_SCHEMA, "appinfo" );
+        if(appinfo==null)
+            // none exists. need to make one
+            appinfo = insertXMLSchemaElement( annotation, "appinfo" );
+
+        return appinfo;
+    }
+
+    /**
+     * Creates a new XML Schema element of the given local name
+     * and insert it as the first child of the given parent node.
+     *
+     * @return
+     *      Newly create element.
+     */
+    private Element insertXMLSchemaElement( Element parent, String localName ) {
+        // use the same prefix as the parent node to avoid modifying
+        // the namespace binding.
+        String qname = parent.getTagName();
+        int idx = qname.indexOf(':');
+        if(idx==-1)     qname = localName;
+        else            qname = qname.substring(0,idx+1)+localName;
+
+        Element child = parent.getOwnerDocument().createElementNS( WellKnownNamespace.XML_SCHEMA, qname );
+
+        NodeList children = parent.getChildNodes();
+
+        if( children.getLength()==0 )
+            parent.appendChild(child);
+        else
+            parent.insertBefore( child, children.item(0) );
+
+        return child;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/JAXBContextFactory.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/JAXBContextFactory.java
new file mode 100644
index 0000000..e71064f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/JAXBContextFactory.java
@@ -0,0 +1,156 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.runtime;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Map;
+import java.util.StringTokenizer;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+
+/**
+ * This class implements the actual logic of {@link JAXBContext#newInstance}.
+ *
+ * <p>
+ * This class works as a facade and all the actual work is delegated to
+ * a JAXB provider that happens to be in the runtime (not necessarily the JAXB RI.)
+ * This allows the generated code to be run with any JAXB provider.
+ *
+ * <p>
+ * This code is only used when XJC generates interfaces/implementations.
+ *
+ * <p>
+ * The trick to make this work is two ObjectFactory classes that we generate
+ * in the interface/implementation mode.
+ *
+ * <p>
+ * The public ObjectFactory follows the spec, and this is the one that's exposed
+ * to users. The public ObjectFactory refers to interfaces, so they aren't
+ * directly usable by a JAXB 2.0 implementation.
+ *
+ * <p>
+ * The private one lives in the impl package, and this one is indistinguishable
+ * from the ObjectFactory that we generate for the value class generation mode.
+ * This private ObjectFactory refers to implementation classes, which are
+ * also indistinguishable from value classes that JAXB generates.
+ *
+ * <p>
+ * All in all, the private ObjectFactory plus implementation classes give
+ * a JAXB provider an illusion that they are dealing with value classes
+ * that happens to implement some interfaces.
+ *
+ * <p>
+ * In this way, the JAXB RI can provide the portability even for the
+ * interface/implementation generation mode.
+ *
+ * @since 2.0
+ * @author Kohsuke Kawaguchi
+ */
+public class JAXBContextFactory {
+    private static final String DOT_OBJECT_FACTORY = ".ObjectFactory";
+    private static final String IMPL_DOT_OBJECT_FACTORY = ".impl.ObjectFactory";
+
+    /**
+     * The JAXB API will invoke this method via reflection
+     */
+    public static JAXBContext createContext( Class[] classes, Map properties ) throws JAXBException {
+        Class[] r = new Class[classes.length];
+        boolean modified = false;
+
+        // find any reference to our 'public' ObjectFactory and
+        // replace that to our 'private' ObjectFactory.
+        for( int i=0; i<r.length; i++ ) {
+            Class c = classes[i];
+            String name = c.getName();
+            if(name.endsWith(DOT_OBJECT_FACTORY)
+            && !name.endsWith(IMPL_DOT_OBJECT_FACTORY)) {
+                // we never generate into the root package, so no need to worry about FQCN "ObjectFactory"
+
+                // if we find one, tell the real JAXB provider to
+                // load foo.bar.impl.ObjectFactory
+                name = name.substring(name.length()-DOT_OBJECT_FACTORY.length())+IMPL_DOT_OBJECT_FACTORY;
+
+                try {
+                    c = c.getClassLoader().loadClass(name);
+                } catch (ClassNotFoundException e) {
+                    throw new JAXBException(e);
+                }
+
+                modified = true;
+            }
+
+            r[i] = c;
+        }
+
+        if(!modified) {
+            // if the class list doesn't contain any of our classes,
+            // this ContextFactory shouldn't have been called in the first place
+            // if we simply continue, we'll just end up with the infinite recursion.
+
+            // the only case that I can think of where this could happen is
+            // when the user puts additional classes into the JAXB-generated
+            // package and pass them to JAXBContext.newInstance().
+            // Under normal use, this shouldn't happen.
+
+            // anyway, bail out now.
+            // if you hit this problem and wondering how to get around the problem,
+            // subscribe and send a note to users@jaxb.dev.java.net (http://jaxb.dev.java.net/)
+            throw new JAXBException("Unable to find a JAXB implementation to delegate");
+        }
+
+        // delegate to the JAXB provider in the system
+        return JAXBContext.newInstance(r,properties);
+    }
+
+
+    /**
+     * The JAXB API will invoke this method via reflection
+     */
+    public static JAXBContext createContext( String contextPath,
+                                             ClassLoader classLoader, Map properties ) throws JAXBException {
+
+        List<Class> classes = new ArrayList<Class>();
+        StringTokenizer tokens = new StringTokenizer(contextPath,":");
+
+        // each package should be pointing to a JAXB RI generated
+        // content interface package.
+        //
+        // translate them into a list of private ObjectFactories.
+        try {
+            while(tokens.hasMoreTokens()) {
+                String pkg = tokens.nextToken();
+                classes.add(classLoader.loadClass(pkg+IMPL_DOT_OBJECT_FACTORY));
+            }
+        } catch (ClassNotFoundException e) {
+            throw new JAXBException(e);
+        }
+
+        // delegate to the JAXB provider in the system
+        return JAXBContext.newInstance(classes.toArray(new Class[classes.size()]),properties);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/ZeroOneBooleanAdapter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/ZeroOneBooleanAdapter.java
new file mode 100644
index 0000000..899b454
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/ZeroOneBooleanAdapter.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.runtime;
+
+import javax.xml.bind.DatatypeConverter;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+
+/**
+ * Serializes <tt>boolean</tt> as 0 or 1.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since 2.0
+ */
+public class ZeroOneBooleanAdapter extends XmlAdapter<String,Boolean> {
+    public Boolean unmarshal(String v) {
+        if(v==null)     return null;
+        return DatatypeConverter.parseBoolean(v);
+    }
+
+    public String marshal(Boolean v) {
+        if(v==null)     return null;
+        if(v) {
+            return "1";
+        } else {
+            return "0";
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/package.html b/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/package.html
new file mode 100644
index 0000000..9b87fa7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/runtime/package.html
@@ -0,0 +1,4 @@
+<html><body>
+  Code generated into the user's packages in certain compilation mode.
+
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/CodeModelClassFactory.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/CodeModelClassFactory.java
new file mode 100644
index 0000000..e5e8a14
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/CodeModelClassFactory.java
@@ -0,0 +1,137 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import com.sun.codemodel.internal.ClassType;
+import com.sun.codemodel.internal.JClassAlreadyExistsException;
+import com.sun.codemodel.internal.JClassContainer;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JJavaName;
+import com.sun.codemodel.internal.JMod;
+import com.sun.tools.internal.xjc.ErrorReceiver;
+
+import org.xml.sax.Locator;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Create new {@link JDefinedClass} and report class collision errors,
+ * if necessary.
+ *
+ * This is just a helper class that simplifies the class name collision
+ * detection. This object maintains no state, so it is OK to use
+ * multiple instances of this.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class CodeModelClassFactory {
+
+    /** errors are reported to this object. */
+    private ErrorReceiver errorReceiver;
+
+    /** unique id generator. */
+    private int ticketMaster = 0;
+
+
+    public CodeModelClassFactory( ErrorReceiver _errorReceiver ) {
+        this.errorReceiver = _errorReceiver;
+    }
+
+    public JDefinedClass createClass( JClassContainer parent, String name, Locator source ) {
+        return createClass( parent, JMod.PUBLIC, name, source );
+    }
+    public JDefinedClass createClass( JClassContainer parent, int mod, String name, Locator source ) {
+        return createClass(parent,mod,name,source,ClassType.CLASS);
+    }
+
+    public JDefinedClass createInterface( JClassContainer parent, String name, Locator source ) {
+        return createInterface( parent, JMod.PUBLIC, name, source );
+    }
+    public JDefinedClass createInterface( JClassContainer parent, int mod, String name, Locator source ) {
+        return createClass(parent,mod,name,source,ClassType.INTERFACE);
+    }
+    public JDefinedClass createClass(
+        JClassContainer parent, String name, Locator source, ClassType kind ) {
+        return createClass(parent,JMod.PUBLIC,name,source,kind);
+    }
+    public JDefinedClass createClass(
+        JClassContainer parent, int mod, String name, Locator source, ClassType kind ) {
+
+        if(!JJavaName.isJavaIdentifier(name)) {
+            // report the error
+            errorReceiver.error( new SAXParseException(
+                Messages.format( Messages.ERR_INVALID_CLASSNAME, name ), source ));
+            return createDummyClass(parent);
+        }
+
+
+        try {
+            if(parent.isClass() && kind==ClassType.CLASS)
+                mod |= JMod.STATIC;
+
+            JDefinedClass r = parent._class(mod,name,kind);
+            // use the metadata field to store the source location,
+            // so that we can report class name collision errors.
+            r.metadata = source;
+
+            return r;
+        } catch( JClassAlreadyExistsException e ) {
+            // class collision.
+            JDefinedClass cls = e.getExistingClass();
+
+            // report the error
+            errorReceiver.error( new SAXParseException(
+                Messages.format( Messages.ERR_CLASSNAME_COLLISION, cls.fullName() ),
+                (Locator)cls.metadata ));
+            errorReceiver.error( new SAXParseException(
+                Messages.format( Messages.ERR_CLASSNAME_COLLISION_SOURCE, name ),
+                source ));
+
+            if( !name.equals(cls.name()) ) {
+                // on Windows, FooBar and Foobar causes name collision
+                errorReceiver.error( new SAXParseException(
+                    Messages.format( Messages.ERR_CASE_SENSITIVITY_COLLISION,
+                        name, cls.name() ), null ) );
+            }
+
+            return createDummyClass(parent);
+        }
+    }
+
+    /**
+     * Create a dummy class to recover from an error.
+     *
+     * We won't generate the code, so the client will never see this class
+     * getting generated.
+     */
+    private JDefinedClass createDummyClass(JClassContainer parent) {
+        try {
+            return parent._class("$$$garbage$$$"+(ticketMaster++));
+        } catch( JClassAlreadyExistsException ee ) {
+            return ee.getExistingClass();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/DOMUtils.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/DOMUtils.java
new file mode 100644
index 0000000..f5f94b5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/DOMUtils.java
@@ -0,0 +1,160 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+/*
+ * DOMUtils.java
+ *
+ * Created on May 7th 2002
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import java.util.ArrayList;
+
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.DOMException;
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+
+
+/**
+ *
+ * @author  Vivek Pandey
+ *
+ */
+public class DOMUtils {
+    /** Gets the fist child of the given name, or null. */
+    public static Element getFirstChildElement( Element parent, String nsUri, String localPart ) {
+        NodeList children = parent.getChildNodes();
+        for( int i=0; i<children.getLength(); i++ ) {
+            Node item = children.item(i);
+            if(!(item instanceof Element ))     continue;
+
+            if(nsUri.equals(item.getNamespaceURI())
+            && localPart.equals(item.getLocalName()) )
+                return (Element)item;
+        }
+        return null;
+    }
+
+    /** Gets the child elements of the given name. */
+    public static Element[] getChildElements(Element parent, String nsUri, String localPart ) {
+        ArrayList a = new ArrayList();
+        NodeList children = parent.getChildNodes();
+        for( int i=0; i<children.getLength(); i++ ) {
+            Node item = children.item(i);
+            if(!(item instanceof Element ))     continue;
+
+            if(nsUri.equals(item.getNamespaceURI())
+            && localPart.equals(item.getLocalName()) )
+                a.add(item);
+        }
+        return (Element[]) a.toArray(new Element[a.size()]);
+    }
+
+    /** Gets all the child elements. */
+    public static Element[] getChildElements( Element parent ) {
+        ArrayList a = new ArrayList();
+        NodeList children = parent.getChildNodes();
+        for( int i=0; i<children.getLength(); i++ ) {
+            Node item = children.item(i);
+            if(!(item instanceof Element ))     continue;
+
+            a.add(item);
+        }
+        return (Element[]) a.toArray(new Element[a.size()]);
+    }
+
+
+  public static String getElementText(Element element) throws DOMException{
+    for (Node child = element.getFirstChild(); child != null;
+     child = child.getNextSibling()) {
+      if(child.getNodeType() == Node.TEXT_NODE)
+    return child.getNodeValue();
+    }
+    return element.getNodeValue();
+  }
+
+  public static Element getElement(Document parent, String name){
+    NodeList children = parent.getElementsByTagName(name);
+    if(children.getLength() >= 1)
+      return (Element)children.item(0);
+    return null;
+  }
+
+  public static Element getElement(Document parent, QName qname){
+    NodeList children = parent.getElementsByTagNameNS(qname.getNamespaceURI(), qname.getLocalPart());
+    if(children.getLength() >= 1)
+      return (Element)children.item(0);
+    return null;
+  }
+
+  public static Element getElement(Document parent, String namespaceURI,
+                       String localName) {
+    NodeList children = parent.getElementsByTagNameNS(namespaceURI, localName);
+    if(children.getLength() >= 1)
+      return (Element)children.item(0);
+    return null;
+  }
+
+// these implementations look wrong to me, since getElementsByTagName returns
+// all the elements in descendants, not just children.
+//
+//   public static Element[] getChildElements(Element parent, QName qname) {
+//    NodeList children = parent.getElementsByTagNameNS(qname.uri, qname.localpart);
+//    return getElements(children);
+//  }
+//
+//  public static Element[] getChildElements(Element parent, String namespaceURI,
+//                       String localName) {
+//    NodeList children = parent.getElementsByTagNameNS(namespaceURI, localName);
+//    return getElements(children);
+//  }
+//
+//  public static Element[] getChildElements(Element parent, String name) {
+//    NodeList children = parent.getElementsByTagName(name);
+//    return getElements(children);
+//  }
+
+    public static Element[] getElements(NodeList children) {
+        Element[] elements = null;
+        int len = 0;
+        for (int i = 0; i < children.getLength(); ++i) {
+            if (elements == null)
+                elements = new Element[1];
+            if (elements.length == len) {
+                Element[] buf = new Element[elements.length + 1];
+                System.arraycopy(elements, 0, buf, 0, elements.length);
+                elements = buf;
+            }
+            elements[len++] = (Element)children.item(i);
+        }
+        return elements;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ErrorReceiverFilter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ErrorReceiverFilter.java
new file mode 100644
index 0000000..df7b0c4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ErrorReceiverFilter.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import com.sun.tools.internal.xjc.ErrorReceiver;
+import com.sun.tools.internal.xjc.api.ErrorListener;
+
+import org.xml.sax.SAXParseException;
+
+/**
+ * Filter implementation of the ErrorReceiver.
+ *
+ * If an error is encountered, this filter sets a flag.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ErrorReceiverFilter extends ErrorReceiver {
+
+    public ErrorReceiverFilter() {}
+
+    public ErrorReceiverFilter( ErrorListener h ) {
+        setErrorReceiver(h);
+    }
+
+    private ErrorListener core;
+    public void setErrorReceiver( ErrorListener handler ) {
+        core = handler;
+    }
+
+    private boolean hadError = false;
+    public final boolean hadError() { return hadError; }
+
+    public void info(SAXParseException exception) {
+        if(core!=null)  core.info(exception);
+    }
+
+    public void warning(SAXParseException exception) {
+        if(core!=null)  core.warning(exception);
+    }
+
+    public void error(SAXParseException exception) {
+        hadError = true;
+        if(core!=null)  core.error(exception);
+    }
+
+    public void fatalError(SAXParseException exception) {
+        hadError = true;
+        if(core!=null)  core.fatalError(exception);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ForkContentHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ForkContentHandler.java
new file mode 100644
index 0000000..60f2ab5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ForkContentHandler.java
@@ -0,0 +1,128 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+/**
+ * ContentHandler that "forks" the incoming SAX2 events to
+ * two ContentHandlers.
+ *
+ *
+ * @author  <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public class ForkContentHandler implements ContentHandler {
+
+        /**
+         * Creates a ForkContentHandler.
+         *
+         * @param first
+         *     This handler will receive a SAX event first.
+         * @param second
+         *     This handler will receive a SAX event after the first handler
+         *     receives it.
+         */
+        public ForkContentHandler( ContentHandler first, ContentHandler second ) {
+                lhs = first;
+                rhs = second;
+        }
+
+        /**
+         * Creates ForkContentHandlers so that the specified handlers
+         * will receive SAX events in the order of the array.
+         */
+        public static ContentHandler create( ContentHandler[] handlers ) {
+                if(handlers.length==0)
+                        throw new IllegalArgumentException();
+
+                ContentHandler result = handlers[0];
+                for( int i=1; i<handlers.length; i++ )
+                        result = new ForkContentHandler( result, handlers[i] );
+                return result;
+        }
+
+
+        private final ContentHandler lhs,rhs;
+
+        public void setDocumentLocator (Locator locator) {
+                lhs.setDocumentLocator(locator);
+                rhs.setDocumentLocator(locator);
+        }
+
+        public void startDocument() throws SAXException {
+                lhs.startDocument();
+                rhs.startDocument();
+        }
+
+        public void endDocument () throws SAXException {
+                lhs.endDocument();
+                rhs.endDocument();
+        }
+
+        public void startPrefixMapping (String prefix, String uri) throws SAXException {
+                lhs.startPrefixMapping(prefix,uri);
+                rhs.startPrefixMapping(prefix,uri);
+        }
+
+        public void endPrefixMapping (String prefix) throws SAXException {
+                lhs.endPrefixMapping(prefix);
+                rhs.endPrefixMapping(prefix);
+        }
+
+        public void startElement (String uri, String localName, String qName, Attributes attributes) throws SAXException {
+                lhs.startElement(uri,localName,qName,attributes);
+                rhs.startElement(uri,localName,qName,attributes);
+        }
+
+        public void endElement (String uri, String localName, String qName) throws SAXException {
+                lhs.endElement(uri,localName,qName);
+                rhs.endElement(uri,localName,qName);
+        }
+
+        public void characters (char ch[], int start, int length) throws SAXException {
+                lhs.characters(ch,start,length);
+                rhs.characters(ch,start,length);
+        }
+
+        public void ignorableWhitespace (char ch[], int start, int length) throws SAXException {
+                lhs.ignorableWhitespace(ch,start,length);
+                rhs.ignorableWhitespace(ch,start,length);
+        }
+
+        public void processingInstruction (String target, String data) throws SAXException {
+                lhs.processingInstruction(target,data);
+                rhs.processingInstruction(target,data);
+        }
+
+        public void skippedEntity (String name) throws SAXException {
+                lhs.skippedEntity(name);
+                rhs.skippedEntity(name);
+        }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ForkEntityResolver.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ForkEntityResolver.java
new file mode 100644
index 0000000..becf369
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ForkEntityResolver.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import java.io.IOException;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+/**
+ * {@link EntityResolver} that delegates to two {@link EntityResolver}s.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class ForkEntityResolver implements EntityResolver {
+    private final EntityResolver lhs;
+    private final EntityResolver rhs;
+
+    public ForkEntityResolver(EntityResolver lhs, EntityResolver rhs) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public InputSource resolveEntity(String publicId, String systemId) throws SAXException, IOException {
+        InputSource is = lhs.resolveEntity(publicId, systemId);
+        if(is!=null)
+            return is;
+        return rhs.resolveEntity(publicId,systemId);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/MessageBundle.properties b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/MessageBundle.properties
new file mode 100644
index 0000000..df19627
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/MessageBundle.properties
@@ -0,0 +1,22 @@
+#
+# Message resource file
+#
+
+
+
+CodeModelClassFactory.ClassNameCollision = \
+	A class/interface with the same name "{0}" is already in use. \
+    Use a class customization to resolve this conflict.
+
+CodeModelClassFactory.ClassNameCollision.Source = \
+	(Relevant to above error) another "{0}" is generated from here.
+
+ERR_INVALID_CLASSNAME = \
+    Invalid class name "{0}". Either XJC has failed to derive a class name \
+    from XML name, or invalid name is given. Use <jaxb:class> customization \
+    to override a name.
+
+CodeModelClassFactory.CaseSensitivityCollision = \
+	This error is caused because on Windows you cannot have both "{0}.java" and "{1}.java" \
+	in the same directory.
+ 
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/Messages.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/Messages.java
new file mode 100644
index 0000000..b00af65
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/Messages.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getPackage().getName() +".MessageBundle").getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+
+    static final String ERR_CLASSNAME_COLLISION =
+        "CodeModelClassFactory.ClassNameCollision";
+
+    static final String ERR_CLASSNAME_COLLISION_SOURCE =
+        "CodeModelClassFactory.ClassNameCollision.Source";
+
+    static final String ERR_INVALID_CLASSNAME =
+        "ERR_INVALID_CLASSNAME";
+
+    static final String ERR_CASE_SENSITIVITY_COLLISION = // 2 args
+        "CodeModelClassFactory.CaseSensitivityCollision";
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/MimeTypeRange.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/MimeTypeRange.java
new file mode 100644
index 0000000..5f814aa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/MimeTypeRange.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import java.text.ParseException;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import javax.activation.MimeType;
+import javax.activation.MimeTypeParseException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class MimeTypeRange {
+    public final String majorType;
+    public final String subType;
+
+    public final Map<String,String> parameters = new HashMap<String, String>();
+
+    /**
+     * Each media-range MAY be followed by one or more accept-params,
+     * beginning with the "q" parameter for indicating a relative quality
+     * factor. The first "q" parameter (if any) separates the media-range
+     * parameter(s) from the accept-params. Quality factors allow the user
+     * or user agent to indicate the relative degree of preference for that
+     * media-range, using the qvalue scale from 0 to 1 (section 3.9). The
+     * default value is q=1.
+     */
+    public final float q;
+
+    // accept-extension is not implemented
+
+    public static List<MimeTypeRange> parseRanges(String s) throws ParseException {
+        StringCutter cutter = new StringCutter(s,true);
+        List<MimeTypeRange> r = new ArrayList<MimeTypeRange>();
+        while(cutter.length()>0) {
+            r.add(new MimeTypeRange(cutter));
+        }
+        return r;
+    }
+
+    public MimeTypeRange(String s) throws ParseException {
+        this(new StringCutter(s,true));
+    }
+
+    /**
+     * Used only to produce the static constants within this class.
+     */
+    private static MimeTypeRange create(String s) {
+        try {
+            return new MimeTypeRange(s);
+        } catch (ParseException e) {
+            // we only use this method for known inputs
+            throw new Error(e);
+        }
+    }
+
+    /**
+     * @param cutter
+     *      A string like "text/html; charset=utf-8;
+     */
+    private MimeTypeRange(StringCutter cutter) throws ParseException {
+        majorType = cutter.until("/");
+        cutter.next("/");
+        subType = cutter.until("[;,]");
+
+        float q = 1.0f;
+
+        while(cutter.length()>0) {
+            String sep = cutter.next("[;,]");
+            if(sep.equals(","))
+                break;
+
+            String key = cutter.until("=");
+            cutter.next("=");
+            String value;
+            char ch = cutter.peek();
+            if(ch=='"') {
+                // quoted
+                cutter.next("\"");
+                value = cutter.until("\"");
+                cutter.next("\"");
+            } else {
+                value = cutter.until("[;,]");
+            }
+
+            if(key.equals("q")) {
+                q = Float.parseFloat(value);
+            } else {
+                parameters.put(key,value);
+            }
+        }
+
+        this.q = q;
+    }
+
+    public MimeType toMimeType() throws MimeTypeParseException {
+        // due to the additional error check done in the MimeType class,
+        // an error at this point is possible
+        return new MimeType(toString());
+    }
+
+    public String toString() {
+        StringBuilder sb = new StringBuilder(majorType+'/'+subType);
+        if(q!=1)
+            sb.append("; q=").append(q);
+
+        for( Map.Entry<String,String> p : parameters.entrySet() ) {
+            // I'm too lazy to quote the value
+            sb.append("; ").append(p.getKey()).append('=').append(p.getValue());
+        }
+        return sb.toString();
+    }
+
+    public static final MimeTypeRange ALL = create("*/*");
+
+    /**
+     * Creates a range by merging all the given types.
+     */
+    public static MimeTypeRange merge( Collection<MimeTypeRange> types ) {
+        if(types.size()==0)     throw new IllegalArgumentException();
+        if(types.size()==1)     return types.iterator().next();
+
+        String majorType=null;
+        for (MimeTypeRange mt : types) {
+            if(majorType==null)     majorType = mt.majorType;
+            if(!majorType.equals(mt.majorType))
+                return ALL;
+        }
+
+        return create(majorType+"/*");
+    }
+
+    public static void main(String[] args) throws ParseException {
+        for( MimeTypeRange m : parseRanges(args[0]))
+            System.out.println(m.toString());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/NamespaceContextAdapter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/NamespaceContextAdapter.java
new file mode 100644
index 0000000..3c62253
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/NamespaceContextAdapter.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import java.util.Collections;
+import java.util.Iterator;
+
+import javax.xml.namespace.NamespaceContext;
+
+import com.sun.xml.internal.xsom.XmlString;
+
+import org.relaxng.datatype.ValidationContext;
+
+/**
+ * Take a {@link ValidationContext} and make it look like a {@link NamespaceContext}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class NamespaceContextAdapter implements NamespaceContext {
+    private XmlString xstr;
+
+    public NamespaceContextAdapter(XmlString xstr) {
+        this.xstr = xstr;
+    }
+
+    public String getNamespaceURI(String prefix) {
+        return xstr.resolvePrefix(prefix);
+    }
+
+    public String getPrefix(String namespaceURI) {
+        return null;
+    }
+
+    public Iterator getPrefixes(String namespaceURI) {
+        return Collections.EMPTY_LIST.iterator();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/NullStream.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/NullStream.java
new file mode 100644
index 0000000..03f50e8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/NullStream.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import java.io.IOException;
+import java.io.OutputStream;
+
+/**
+ * Just consumes the byte stream. Kind of like /dev/null.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class NullStream extends OutputStream {
+
+    public void write(int b) throws IOException {
+    }
+
+    public void close() throws IOException {
+    }
+
+    public void flush() throws IOException {
+    }
+
+    public void write(byte[] b, int off, int len) throws IOException {
+    }
+
+    public void write(byte[] b) throws IOException {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ReadOnlyAdapter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ReadOnlyAdapter.java
new file mode 100644
index 0000000..db32e24
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/ReadOnlyAdapter.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+
+/**
+ * {@link XmlAdapter} used inside XJC is almost always unmarshal-only.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class ReadOnlyAdapter<OnTheWire,InMemory> extends XmlAdapter<OnTheWire,InMemory> {
+    public final OnTheWire marshal(InMemory onTheWire) {
+        // the unmarshaller uses this method
+        // to get the current collection object from the property.
+        // so we can't just throw UnsupportedOperationException here
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/StringCutter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/StringCutter.java
new file mode 100644
index 0000000..414344f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/StringCutter.java
@@ -0,0 +1,97 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import java.text.ParseException;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+/**
+ * Utility class to parse a string
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class StringCutter {
+    private final String original;
+    private String s;
+    private boolean ignoreWhitespace;
+
+    public StringCutter(String s, boolean ignoreWhitespace) {
+        this.s = this.original = s;
+        this.ignoreWhitespace = ignoreWhitespace;
+    }
+
+    public void skip(String regexp) throws ParseException {
+        next(regexp);
+    }
+
+    public String next(String regexp) throws ParseException {
+        trim();
+        Pattern p = Pattern.compile(regexp);
+        Matcher m = p.matcher(s);
+        if(m.lookingAt()) {
+            String r = m.group();
+            s = s.substring(r.length());
+            trim();
+            return r;
+        } else
+            throw error();
+    }
+
+    private ParseException error() {
+        return new ParseException(original,original.length()-s.length());
+    }
+
+    public String until(String regexp) throws ParseException {
+        Pattern p = Pattern.compile(regexp);
+        Matcher m = p.matcher(s);
+        if(m.find()) {
+            String r =  s.substring(0,m.start());
+            s = s.substring(m.start());
+            if(ignoreWhitespace)
+                r = r.trim();
+            return r;
+        } else {
+            // return everything left
+            String r = s;
+            s = "";
+            return r;
+        }
+    }
+
+    public char peek() {
+        return s.charAt(0);
+    }
+
+    private void trim() {
+        if(ignoreWhitespace)
+            s = s.trim();
+    }
+
+    public int length() {
+        return s.length();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/Util.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/Util.java
new file mode 100644
index 0000000..0b8d77f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/Util.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+
+/**
+ * Other miscellaneous utility methods.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class Util {
+    private Util() {}   // no instanciation please
+
+    /**
+     * An easier-to-use version of the System.getProperty method
+     * that doesn't throw an exception even if a property cannot be
+     * read.
+     */
+    public static final String getSystemProperty( String name ) {
+        try {
+            return System.getProperty(name);
+        } catch( SecurityException e ) {
+            return null;
+        }
+    }
+
+    /**
+     * Calls the other getSystemProperty method with
+     * "[clazz]&#x2E;[name].
+     */
+    public static final String getSystemProperty( Class clazz, String name ) {
+        return getSystemProperty( clazz.getName()+'.'+name );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/XMLStreamReaderToContentHandler.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/XMLStreamReaderToContentHandler.java
new file mode 100644
index 0000000..33b49f0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/util/XMLStreamReaderToContentHandler.java
@@ -0,0 +1,337 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.util;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.AttributesImpl;
+
+/**
+ * This is a simple utility class that adapts StAX events from an
+ * {@link javax.xml.stream.XMLStreamReader} to SAX events on a
+ * {@link org.xml.sax.ContentHandler}, bridging between the two
+ * parser technologies.
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+public class XMLStreamReaderToContentHandler {
+
+    // StAX event source
+    private final XMLStreamReader staxStreamReader;
+
+    // SAX event sink
+    private final ContentHandler saxHandler;
+
+    /**
+     * Construct a new StAX to SAX adapter that will convert a StAX event
+     * stream into a SAX event stream.
+     *
+     * @param staxCore
+     *                StAX event source
+     * @param saxCore
+     *                SAXevent sink
+     */
+    public XMLStreamReaderToContentHandler(XMLStreamReader staxCore, ContentHandler saxCore) {
+        staxStreamReader = staxCore;
+        saxHandler = saxCore;
+    }
+
+    /*
+     * @see StAXReaderToContentHandler#bridge()
+     */
+    public void bridge() throws XMLStreamException {
+
+        try {
+            // remembers the nest level of elements to know when we are done.
+            int depth=0;
+
+            // if the parser is at the start tag, proceed to the first element
+            int event = staxStreamReader.getEventType();
+            if(event == XMLStreamConstants.START_DOCUMENT) {
+                // nextTag doesn't correctly handle DTDs
+                while( !staxStreamReader.isStartElement() )
+                    event = staxStreamReader.next();
+            }
+
+
+            if( event!=XMLStreamConstants.START_ELEMENT)
+                throw new IllegalStateException("The current event is not START_ELEMENT\n but " + event);
+
+            handleStartDocument();
+
+            do {
+                // These are all of the events listed in the javadoc for
+                // XMLEvent.
+                // The spec only really describes 11 of them.
+                switch (event) {
+                    case XMLStreamConstants.START_ELEMENT :
+                        depth++;
+                        handleStartElement();
+                        break;
+                    case XMLStreamConstants.END_ELEMENT :
+                        handleEndElement();
+                        depth--;
+                        break;
+                    case XMLStreamConstants.CHARACTERS :
+                        handleCharacters();
+                        break;
+                    case XMLStreamConstants.ENTITY_REFERENCE :
+                        handleEntityReference();
+                        break;
+                    case XMLStreamConstants.PROCESSING_INSTRUCTION :
+                        handlePI();
+                        break;
+                    case XMLStreamConstants.COMMENT :
+                        handleComment();
+                        break;
+                    case XMLStreamConstants.DTD :
+                        handleDTD();
+                        break;
+                    case XMLStreamConstants.ATTRIBUTE :
+                        handleAttribute();
+                        break;
+                    case XMLStreamConstants.NAMESPACE :
+                        handleNamespace();
+                        break;
+                    case XMLStreamConstants.CDATA :
+                        handleCDATA();
+                        break;
+                    case XMLStreamConstants.ENTITY_DECLARATION :
+                        handleEntityDecl();
+                        break;
+                    case XMLStreamConstants.NOTATION_DECLARATION :
+                        handleNotationDecl();
+                        break;
+                    case XMLStreamConstants.SPACE :
+                        handleSpace();
+                        break;
+                    default :
+                        throw new InternalError("processing event: " + event);
+                }
+
+                event=staxStreamReader.next();
+            } while (depth!=0);
+
+            handleEndDocument();
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private void handleEndDocument() throws SAXException {
+        saxHandler.endDocument();
+    }
+
+    private void handleStartDocument() throws SAXException {
+        saxHandler.setDocumentLocator(new Locator() {
+            public int getColumnNumber() {
+                return staxStreamReader.getLocation().getColumnNumber();
+            }
+            public int getLineNumber() {
+                return staxStreamReader.getLocation().getLineNumber();
+            }
+            public String getPublicId() {
+                return staxStreamReader.getLocation().getPublicId();
+            }
+            public String getSystemId() {
+                return staxStreamReader.getLocation().getSystemId();
+            }
+        });
+        saxHandler.startDocument();
+    }
+
+    private void handlePI() throws XMLStreamException {
+        try {
+            saxHandler.processingInstruction(
+                staxStreamReader.getPITarget(),
+                staxStreamReader.getPIData());
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private void handleCharacters() throws XMLStreamException {
+        try {
+            saxHandler.characters(
+                staxStreamReader.getTextCharacters(),
+                staxStreamReader.getTextStart(),
+                staxStreamReader.getTextLength() );
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private void handleEndElement() throws XMLStreamException {
+        QName qName = staxStreamReader.getName();
+
+        try {
+            // fire endElement
+            saxHandler.endElement(
+                qName.getNamespaceURI(),
+                qName.getLocalPart(),
+                qName.toString());
+
+            // end namespace bindings
+            int nsCount = staxStreamReader.getNamespaceCount();
+            for (int i = nsCount - 1; i >= 0; i--) {
+                String prefix = staxStreamReader.getNamespacePrefix(i);
+                if (prefix == null) { // true for default namespace
+                    prefix = "";
+                }
+                saxHandler.endPrefixMapping(prefix);
+            }
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private void handleStartElement() throws XMLStreamException {
+
+        try {
+            // start namespace bindings
+            int nsCount = staxStreamReader.getNamespaceCount();
+            for (int i = 0; i < nsCount; i++) {
+                saxHandler.startPrefixMapping(
+                    fixNull(staxStreamReader.getNamespacePrefix(i)),
+                    fixNull(staxStreamReader.getNamespaceURI(i)));
+            }
+
+            // fire startElement
+            QName qName = staxStreamReader.getName();
+            String prefix = qName.getPrefix();
+            String rawname;
+            if(prefix==null || prefix.length()==0)
+                rawname = qName.getLocalPart();
+            else
+                rawname = prefix + ':' + qName.getLocalPart();
+            Attributes attrs = getAttributes();
+            saxHandler.startElement(
+                qName.getNamespaceURI(),
+                qName.getLocalPart(),
+                rawname,
+                attrs);
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private static String fixNull(String s) {
+        if(s==null)     return "";
+        else            return s;
+    }
+
+    /**
+     * Get the attributes associated with the given START_ELEMENT or ATTRIBUTE
+     * StAXevent.
+     *
+     * @return the StAX attributes converted to an org.xml.sax.Attributes
+     */
+    private Attributes getAttributes() {
+        AttributesImpl attrs = new AttributesImpl();
+
+        int eventType = staxStreamReader.getEventType();
+        if (eventType != XMLStreamConstants.ATTRIBUTE
+            && eventType != XMLStreamConstants.START_ELEMENT) {
+            throw new InternalError(
+                "getAttributes() attempting to process: " + eventType);
+        }
+
+        // in SAX, namespace declarations are not part of attributes by default.
+        // (there's a property to control that, but as far as we are concerned
+        // we don't use it.) So don't add xmlns:* to attributes.
+
+        // gather non-namespace attrs
+        for (int i = 0; i < staxStreamReader.getAttributeCount(); i++) {
+            String uri = staxStreamReader.getAttributeNamespace(i);
+            if(uri==null)   uri="";
+            String localName = staxStreamReader.getAttributeLocalName(i);
+            String prefix = staxStreamReader.getAttributePrefix(i);
+            String qName;
+            if(prefix==null || prefix.length()==0)
+                qName = localName;
+            else
+                qName = prefix + ':' + localName;
+            String type = staxStreamReader.getAttributeType(i);
+            String value = staxStreamReader.getAttributeValue(i);
+
+            attrs.addAttribute(uri, localName, qName, type, value);
+        }
+
+        return attrs;
+    }
+
+    private void handleNamespace() {
+        // no-op ???
+        // namespace events don't normally occur outside of a startElement
+        // or endElement
+    }
+
+    private void handleAttribute() {
+        // no-op ???
+        // attribute events don't normally occur outside of a startElement
+        // or endElement
+    }
+
+    private void handleDTD() {
+        // no-op ???
+        // it seems like we need to pass this info along, but how?
+    }
+
+    private void handleComment() {
+        // no-op ???
+    }
+
+    private void handleEntityReference() {
+        // no-op ???
+    }
+
+    private void handleSpace() {
+        // no-op ???
+        // this event is listed in the javadoc, but not in the spec.
+    }
+
+    private void handleNotationDecl() {
+        // no-op ???
+        // this event is listed in the javadoc, but not in the spec.
+    }
+
+    private void handleEntityDecl() {
+        // no-op ???
+        // this event is listed in the javadoc, but not in the spec.
+    }
+
+    private void handleCDATA() {
+        // no-op ???
+        // this event is listed in the javadoc, but not in the spec.
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/tools/internal/xjc/writer/SignatureWriter.java b/jaxws/src/share/classes/com/sun/tools/internal/xjc/writer/SignatureWriter.java
new file mode 100644
index 0000000..fcd5f88
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/tools/internal/xjc/writer/SignatureWriter.java
@@ -0,0 +1,163 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.tools.internal.xjc.writer;
+
+import java.io.IOException;
+import java.io.Writer;
+import java.util.Collection;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeSet;
+
+import com.sun.codemodel.internal.JClass;
+import com.sun.codemodel.internal.JClassContainer;
+import com.sun.codemodel.internal.JDefinedClass;
+import com.sun.codemodel.internal.JPackage;
+import com.sun.codemodel.internal.JType;
+import com.sun.tools.internal.xjc.outline.ClassOutline;
+import com.sun.tools.internal.xjc.outline.FieldOutline;
+import com.sun.tools.internal.xjc.outline.Outline;
+
+/**
+ * Dumps an annotated grammar in a simple format that
+ * makes signature check easy.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class SignatureWriter {
+
+    public static void write( Outline model, Writer out )
+        throws IOException {
+
+        new SignatureWriter(model,out).dump();
+    }
+
+    private SignatureWriter( Outline model, Writer out ) {
+        this.out = out;
+        this.classes = model.getClasses();
+
+        for( ClassOutline ci : classes )
+            classSet.put( ci.ref, ci );
+    }
+
+    /** All the ClassItems in this grammar. */
+    private final Collection<? extends ClassOutline> classes;
+    /** Map from content interfaces to ClassItem. */
+    private final Map<JDefinedClass,ClassOutline> classSet = new HashMap<JDefinedClass,ClassOutline>();
+
+    private final Writer out;
+    private int indent=0;
+    private void printIndent() throws IOException {
+        for( int i=0; i<indent; i++ )
+            out.write("  ");
+    }
+    private void println(String s) throws IOException {
+        printIndent();
+        out.write(s);
+        out.write('\n');
+    }
+
+    private void dump() throws IOException {
+
+        // collect packages used in the class.
+        Set<JPackage> packages = new TreeSet<JPackage>(new Comparator<JPackage>() {
+            public int compare(JPackage lhs, JPackage rhs) {
+                return lhs.name().compareTo(rhs.name());
+            }
+        });
+        for( ClassOutline ci : classes )
+            packages.add(ci._package()._package());
+
+        for( JPackage pkg : packages )
+            dump( pkg );
+
+        out.flush();
+    }
+
+    private void dump( JPackage pkg ) throws IOException {
+        println("package "+pkg.name()+" {");
+        indent++;
+        dumpChildren(pkg);
+        indent--;
+        println("}");
+    }
+
+    private void dumpChildren( JClassContainer cont ) throws IOException {
+        Iterator itr = cont.classes();
+        while(itr.hasNext()) {
+            JDefinedClass cls = (JDefinedClass)itr.next();
+            ClassOutline ci = classSet.get(cls);
+            if(ci!=null)
+                dump(ci);
+        }
+    }
+
+    private void dump( ClassOutline ci ) throws IOException {
+        JDefinedClass cls = ci.implClass;
+
+        StringBuilder buf = new StringBuilder();
+        buf.append("interface ");
+        buf.append(cls.name());
+
+        boolean first=true;
+        Iterator itr = cls._implements();
+        while(itr.hasNext()) {
+            if(first) {
+                buf.append(" extends ");
+                first=false;
+            } else {
+                buf.append(", ");
+            }
+            buf.append( printName((JClass)itr.next()) );
+        }
+        buf.append(" {");
+        println(buf.toString());
+        indent++;
+
+        // dump the field
+        for( FieldOutline fo : ci.getDeclaredFields() ) {
+            String type = printName(fo.getRawType());
+            println(type+' '+fo.getPropertyInfo().getName(true)+';');
+        }
+
+        dumpChildren(cls);
+
+        indent--;
+        println("}");
+    }
+
+    /** Get the display name of a type. */
+    private String printName( JType t ) {
+        String name = t.fullName();
+        if(name.startsWith("java.lang."))
+            name = name.substring(10);  // chop off the package name
+        return name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/DatatypeConverterImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/DatatypeConverterImpl.java
new file mode 100644
index 0000000..6bc55f8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/DatatypeConverterImpl.java
@@ -0,0 +1,889 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind;
+
+import java.math.BigDecimal;
+import java.math.BigInteger;
+import java.util.Calendar;
+import java.util.GregorianCalendar;
+import java.util.TimeZone;
+
+import javax.xml.bind.DatatypeConverter;
+import javax.xml.bind.DatatypeConverterInterface;
+import javax.xml.datatype.DatatypeConfigurationException;
+import javax.xml.datatype.DatatypeFactory;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.TODO;
+
+/**
+ * This class is the JAXB RI's default implementation of the
+ * {@link DatatypeConverterInterface}.
+ *
+ * <p>
+ * When client apps specify the use of the static print/parse
+ * methods in {@link DatatypeConverter}, it will delegate
+ * to this class.
+ *
+ * <p>
+ * This class is responsible for whitespace normalization.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @since JAXB1.0
+ */
+public final class DatatypeConverterImpl implements DatatypeConverterInterface {
+
+    /**
+     * To avoid re-creating instances, we cache one instance.
+     */
+    public static final DatatypeConverterInterface theInstance = new DatatypeConverterImpl();
+
+    protected DatatypeConverterImpl() {
+    }
+
+    public String parseString(String lexicalXSDString) {
+        return lexicalXSDString;
+    }
+
+    public BigInteger parseInteger(String lexicalXSDInteger) {
+        return _parseInteger(lexicalXSDInteger);
+    }
+
+    public static BigInteger _parseInteger(CharSequence s) {
+        return new BigInteger(removeOptionalPlus(WhiteSpaceProcessor.trim(s)).toString());
+    }
+
+    public String printInteger(BigInteger val) {
+        return _printInteger(val);
+    }
+
+    public static String _printInteger(BigInteger val) {
+        return val.toString();
+    }
+
+    public int parseInt(String s) {
+        return _parseInt(s);
+    }
+
+    /**
+     * Faster but less robust String->int conversion.
+     *
+     * Note that:
+     * <ol>
+     *  <li>XML Schema allows '+', but {@link Integer#valueOf(String)} is not.
+     *  <li>XML Schema allows leading and trailing (but not in-between) whitespaces..
+     *      {@link Integer#valueOf(String)} doesn't allow any.
+     * </ol>
+     */
+    public static int _parseInt(CharSequence s) {
+        int len = s.length();
+        int sign = 1;
+
+        int r = 0;
+
+        for( int i=0; i<len; i++ ) {
+            char ch = s.charAt(i);
+            if(WhiteSpaceProcessor.isWhiteSpace(ch)) {
+                // skip whitespace
+            } else
+            if('0'<=ch && ch<='9') {
+                r = r*10 + (ch-'0');
+            } else
+            if(ch=='-') {
+                sign = -1;
+            } else
+            if(ch=='+') {
+                ; // noop
+            } else
+                throw new NumberFormatException("Not a number: "+s);
+        }
+
+        return r*sign;
+    }
+
+    public long parseLong(String lexicalXSLong) {
+        return _parseLong(lexicalXSLong);
+    }
+
+    public static long _parseLong(CharSequence s) {
+        return Long.valueOf(removeOptionalPlus(WhiteSpaceProcessor.trim(s)).toString());
+    }
+
+    public short parseShort(String lexicalXSDShort) {
+        return _parseShort(lexicalXSDShort);
+    }
+
+    public static final short _parseShort(CharSequence s) {
+        return (short)_parseInt(s);
+    }
+
+    public String printShort(short val) {
+        return _printShort(val);
+    }
+
+    public static String _printShort(short val) {
+        return String.valueOf(val);
+    }
+
+    public BigDecimal parseDecimal(String content) {
+        return _parseDecimal(content);
+    }
+    public static BigDecimal _parseDecimal(CharSequence content) {
+        content = WhiteSpaceProcessor.trim(content);
+
+        return new BigDecimal(content.toString());
+
+        // from purely XML Schema perspective,
+        // this implementation has a problem, since
+        // in xs:decimal "1.0" and "1" is equal whereas the above
+        // code will return different values for those two forms.
+        //
+        // the code was originally using com.sun.msv.datatype.xsd.NumberType.load,
+        // but a profiling showed that the process of normalizing "1.0" into "1"
+        // could take non-trivial time.
+        //
+        // also, from the user's point of view, one might be surprised if
+        // 1 (not 1.0) is returned from "1.000"
+    }
+
+    public float parseFloat(String lexicalXSDFloat) {
+        return _parseFloat(lexicalXSDFloat);
+    }
+
+    public static float _parseFloat( CharSequence _val ) {
+        String s = WhiteSpaceProcessor.trim(_val).toString();
+        /* Incompatibilities of XML Schema's float "xfloat" and Java's float "jfloat"
+
+            * jfloat.valueOf ignores leading and trailing whitespaces,
+              whereas this is not allowed in xfloat.
+            * jfloat.valueOf allows "float type suffix" (f, F) to be
+              appended after float literal (e.g., 1.52e-2f), whereare
+              this is not the case of xfloat.
+
+            gray zone
+            ---------
+            * jfloat allows ".523". And there is no clear statement that mentions
+              this case in xfloat. Although probably this is allowed.
+            *
+        */
+
+        if(s.equals("NaN"))         return Float.NaN;
+        if(s.equals("INF"))         return Float.POSITIVE_INFINITY;
+        if(s.equals("-INF"))        return Float.NEGATIVE_INFINITY;
+
+        if(s.length()==0
+        || !isDigitOrPeriodOrSign(s.charAt(0))
+        || !isDigitOrPeriodOrSign(s.charAt(s.length()-1)) )
+            throw new NumberFormatException();
+
+        // these screening process is necessary due to the wobble of Float.valueOf method
+        return Float.parseFloat(s);
+    }
+
+    public String printFloat(float v) {
+        return _printFloat(v);
+    }
+
+    public static String _printFloat(float v) {
+        if( v==Float.NaN )                  return "NaN";
+        if( v==Float.POSITIVE_INFINITY )    return "INF";
+        if( v==Float.NEGATIVE_INFINITY )    return "-INF";
+        return String.valueOf(v);
+    }
+
+
+
+    public double parseDouble(String lexicalXSDDouble) {
+        return _parseDouble(lexicalXSDDouble);
+    }
+
+    public static double _parseDouble( CharSequence _val ) {
+        String val = WhiteSpaceProcessor.trim(_val).toString();
+
+        if(val.equals("NaN"))    return Double.NaN;
+        if(val.equals("INF"))    return Double.POSITIVE_INFINITY;
+        if(val.equals("-INF"))    return Double.NEGATIVE_INFINITY;
+
+        if(val.length()==0
+        || !isDigitOrPeriodOrSign(val.charAt(0))
+        || !isDigitOrPeriodOrSign(val.charAt(val.length()-1)) )
+            throw new NumberFormatException(val);
+
+
+        // these screening process is necessary due to the wobble of Float.valueOf method
+        return Double.parseDouble(val);
+    }
+
+    public boolean parseBoolean(String lexicalXSDBoolean) {
+        return _parseBoolean(lexicalXSDBoolean);
+    }
+
+    public static boolean _parseBoolean(CharSequence literal) {
+        int i=0;
+        int len = literal.length();
+        char ch;
+        do {
+            ch = literal.charAt(i++);
+        } while(WhiteSpaceProcessor.isWhiteSpace(ch) && i<len);
+
+        // if we are strict about errors, check i==len. and report an error
+
+        if( ch=='t' || ch=='1' )        return true;
+        if( ch=='f' || ch=='0' )        return false;
+        TODO.checkSpec("issue #42");
+        return false;
+    }
+
+    public String printBoolean(boolean val) {
+        return val?"true":"false";
+    }
+    public static String _printBoolean(boolean val) {
+        return val?"true":"false";
+    }
+
+    public byte parseByte(String lexicalXSDByte) {
+        return _parseByte(lexicalXSDByte);
+    }
+
+    public static byte _parseByte(CharSequence literal) {
+        return (byte)_parseInt(literal);
+    }
+
+    public String printByte(byte val) {
+        return _printByte(val);
+    }
+
+    public static String _printByte(byte val) {
+        return String.valueOf(val);
+    }
+
+    public QName parseQName(String lexicalXSDQName, NamespaceContext nsc) {
+        return _parseQName(lexicalXSDQName,nsc);
+    }
+
+    /**
+     * @return null if fails to convert.
+     */
+    public static QName _parseQName(CharSequence text, NamespaceContext nsc) {
+        int length = text.length();
+
+        // trim whitespace
+        int start=0;
+        while(start<length && WhiteSpaceProcessor.isWhiteSpace(text.charAt(start)))
+            start++;
+
+        int end = length;
+        while(end>start && WhiteSpaceProcessor.isWhiteSpace(text.charAt(end-1)))
+            end--;
+
+        if(end==start)
+            throw new IllegalArgumentException("input is empty");
+
+
+        String uri;
+        String localPart;
+        String prefix;
+
+        // search ':'
+        int idx=start+1;    // no point in searching the first char. that's not valid.
+        while(idx<end && text.charAt(idx)!=':' )
+            idx++;
+
+        if( idx==end ) {
+            uri = nsc.getNamespaceURI("");
+            localPart = text.subSequence(start,end).toString();
+            prefix = "";
+        } else {
+            // Prefix exists, check everything
+            prefix = text.subSequence(start,idx).toString();
+            localPart = text.subSequence(idx+1,end).toString();
+            uri = nsc.getNamespaceURI(prefix);
+            // uri can never be null according to javadoc,
+            // but some users reported that there are implementations that return null.
+            if(uri==null || uri.length()==0) // crap. the NamespaceContext interface is broken.
+                // error: unbound prefix
+                throw new IllegalArgumentException("prefix "+prefix+" is not bound to a namespace");
+        }
+
+        return new QName(uri,localPart,prefix);
+    }
+
+    public Calendar parseDateTime(String lexicalXSDDateTime) {
+        return _parseDateTime(lexicalXSDDateTime);
+    }
+
+    public static GregorianCalendar _parseDateTime(CharSequence s) {
+        String val = WhiteSpaceProcessor.trim(s).toString();
+        return datatypeFactory.newXMLGregorianCalendar(val).toGregorianCalendar();
+    }
+
+    public String printDateTime(Calendar val) {
+        return _printDateTime(val);
+    }
+
+    public static String _printDateTime(Calendar val) {
+        return CalendarFormatter.doFormat("%Y-%M-%DT%h:%m:%s%z",val);
+    }
+
+    public byte[] parseBase64Binary(String lexicalXSDBase64Binary) {
+        return _parseBase64Binary(lexicalXSDBase64Binary);
+    }
+
+
+    public byte[] parseHexBinary(String s) {
+        final int len = s.length();
+
+        // "111" is not a valid hex encoding.
+        if( len%2 != 0 )    return null;
+
+        byte[] out = new byte[len/2];
+
+        for( int i=0; i<len; i+=2 ) {
+            int h = hexToBin(s.charAt(i  ));
+            int l = hexToBin(s.charAt(i+1));
+            if( h==-1 || l==-1 )
+                return null;    // illegal character
+
+            out[i/2] = (byte)(h*16+l);
+        }
+
+        return out;
+    }
+
+    private static int hexToBin( char ch ) {
+        if( '0'<=ch && ch<='9' )    return ch-'0';
+        if( 'A'<=ch && ch<='F' )    return ch-'A'+10;
+        if( 'a'<=ch && ch<='f' )    return ch-'a'+10;
+        return -1;
+    }
+
+    private static final char[] hexCode = "0123456789ABCDEF".toCharArray();
+
+    public String printHexBinary(byte[] data) {
+        StringBuilder r = new StringBuilder(data.length*2);
+        for ( byte b : data) {
+            r.append(hexCode[(b >> 4) & 0xF]);
+            r.append(hexCode[(b & 0xF)]);
+        }
+        return r.toString();
+    }
+
+
+    public long parseUnsignedInt(String lexicalXSDUnsignedInt) {
+        return _parseLong(lexicalXSDUnsignedInt);
+    }
+
+    public String printUnsignedInt(long val) {
+        return _printLong(val);
+    }
+
+    public int parseUnsignedShort(String lexicalXSDUnsignedShort) {
+        return _parseInt(lexicalXSDUnsignedShort);
+    }
+
+    public Calendar parseTime(String lexicalXSDTime) {
+        return datatypeFactory.newXMLGregorianCalendar(lexicalXSDTime).toGregorianCalendar();
+    }
+
+    public String printTime(Calendar val) {
+        return CalendarFormatter.doFormat("%h:%m:%s%z",val);
+    }
+
+    public Calendar parseDate(String lexicalXSDDate) {
+        return datatypeFactory.newXMLGregorianCalendar(lexicalXSDDate).toGregorianCalendar();
+    }
+
+    public String printDate(Calendar val) {
+
+        return CalendarFormatter.doFormat((new StringBuilder("%Y-%M-%D").append("%z")).toString(),val);
+    }
+
+    public String parseAnySimpleType(String lexicalXSDAnySimpleType) {
+        return lexicalXSDAnySimpleType;
+//        return (String)SimpleURType.theInstance._createValue( lexicalXSDAnySimpleType, null );
+    }
+
+    public String printString(String val) {
+//        return StringType.theInstance.convertToLexicalValue( val, null );
+        return val;
+    }
+
+
+    public String printInt(int val) {
+        return _printInt(val);
+    }
+
+    public static String _printInt(int val) {
+        return String.valueOf(val);
+    }
+
+    public String printLong(long val) {
+        return _printLong(val);
+    }
+
+    public static String _printLong(long val) {
+        return String.valueOf(val);
+    }
+
+    public String printDecimal(BigDecimal val) {
+        return _printDecimal(val);
+    }
+
+    public static String _printDecimal(BigDecimal val) {
+        return val.toString();
+    }
+
+    public String printDouble(double v) {
+        return _printDouble(v);
+    }
+
+    public static String _printDouble(double v) {
+        if( v==Double.NaN )                    return "NaN";
+        if( v==Double.POSITIVE_INFINITY )    return "INF";
+        if( v==Double.NEGATIVE_INFINITY )    return "-INF";
+        return String.valueOf(v);
+    }
+
+    public String printQName(QName val, NamespaceContext nsc) {
+        return _printQName(val,nsc);
+    }
+
+    public static String _printQName(QName val, NamespaceContext nsc) {
+        // Double-check
+        String qname;
+        String prefix = nsc.getPrefix( val.getNamespaceURI() );
+        String localPart = val.getLocalPart();
+
+        if( prefix == null || prefix.length()==0 ) { // be defensive
+            qname = localPart;
+        } else {
+            qname = prefix + ':' + localPart;
+        }
+
+        return qname;
+    }
+
+    public String printBase64Binary(byte[] val) {
+        return _printBase64Binary(val);
+    }
+
+    public String printUnsignedShort(int val) {
+        return String.valueOf(val);
+    }
+
+    public String printAnySimpleType(String val) {
+        return val;
+    }
+
+
+    /**
+     * Just return the string passed as a parameter but
+     * installs an instance of this class as the DatatypeConverter
+     * implementation. Used from static fixed value initializers.
+     */
+    public static String installHook( String s ) {
+        DatatypeConverter.setDatatypeConverter(theInstance);
+        return s;
+    }
+
+
+
+
+// base64 decoder
+//====================================
+
+    private static final byte[] decodeMap = initDecodeMap();
+    private static final byte PADDING = 127;
+
+    private static byte[] initDecodeMap() {
+        byte[] map = new byte[128];
+        int i;
+        for( i=0; i<128; i++ )        map[i] = -1;
+
+        for( i='A'; i<='Z'; i++ )    map[i] = (byte)(i-'A');
+        for( i='a'; i<='z'; i++ )    map[i] = (byte)(i-'a'+26);
+        for( i='0'; i<='9'; i++ )    map[i] = (byte)(i-'0'+52);
+        map['+'] = 62;
+        map['/'] = 63;
+        map['='] = PADDING;
+
+        return map;
+    }
+
+    /**
+     * computes the length of binary data.
+     *
+     * This function also performs format check.
+     * @return    -1        if format is illegal.
+     *
+     */
+    private static int calcLength( String text ) {
+        final int len = text.length();
+        int base64count=0;
+        int i;
+
+        for( i=0; i<len; i++ ) {
+            char ch = text.charAt(i);
+            if( ch=='=' )    // decodeMap['=']!=-1, so we have to check this first.
+                break;
+            if( ch>=128 )
+                return -1;      // incorrect character
+            if( decodeMap[ch]!=-1 )
+                base64count++;
+        }
+
+        return (base64count/4)*3+Math.max(0,(base64count%4)-1);
+    }
+
+    /**
+     * @param text
+     *      base64Binary data is likely to be long, and decoding requires
+     *      each character to be accessed twice (once for counting length, another
+     *      for decoding.)
+     *
+     *      A benchmark showed that taking {@link String} is faster, presumably
+     *      because JIT can inline a lot of string access (with data of 1K chars, it was twice as fast)
+     */
+    public static byte[] _parseBase64Binary(String text) {
+        final int outlen = calcLength(text);
+        if( outlen==-1 )    return null;
+        final byte[] out = new byte[outlen];
+        int o=0;
+
+        final int len = text.length();
+        int i;
+
+        final byte[] quadruplet = new byte[4];
+        int q=0;
+
+        // convert each quadruplet to three bytes.
+        for( i=0; i<len; i++ ) {
+            char ch = text.charAt(i);
+            byte v = decodeMap[ch];
+            if( v!=-1 )
+                quadruplet[q++] = v;
+
+            if(q==4) {
+                // quadruplet is now filled.
+                out[o++] = (byte)((quadruplet[0]<<2)|(quadruplet[1]>>4));
+                if( quadruplet[2]!=PADDING )
+                    out[o++] = (byte)((quadruplet[1]<<4)|(quadruplet[2]>>2));
+                if( quadruplet[3]!=PADDING )
+                    out[o++] = (byte)((quadruplet[2]<<6)|(quadruplet[3]));
+                q=0;
+            }
+        }
+
+        return out;
+    }
+
+    private static final char[] encodeMap = initEncodeMap();
+
+    private static char[] initEncodeMap() {
+        char[] map = new char[64];
+        int i;
+        for( i= 0; i<26; i++ )        map[i] = (char)('A'+i);
+        for( i=26; i<52; i++ )        map[i] = (char)('a'+(i-26));
+        for( i=52; i<62; i++ )        map[i] = (char)('0'+(i-52));
+        map[62] = '+';
+        map[63] = '/';
+
+        return map;
+    }
+
+    public static char encode( int i ) {
+        return encodeMap[i&0x3F];
+    }
+
+    public static byte encodeByte( int i ) {
+        return (byte)encodeMap[i&0x3F];
+    }
+
+    public static String _printBase64Binary(byte[] input) {
+        return _printBase64Binary(input, 0, input.length);
+    }
+    public static String _printBase64Binary(byte[] input, int offset, int len) {
+        char[] buf = new char[((len+2)/3)*4];
+        int ptr = _printBase64Binary(input,offset,len,buf,0);
+        assert ptr==buf.length;
+        return new String(buf);
+    }
+
+    /**
+     * Encodes a byte array into a char array by doing base64 encoding.
+     *
+     * The caller must supply a big enough buffer.
+     *
+     * @return
+     *      the value of {@code ptr+((len+2)/3)*4}, which is the new offset
+     *      in the output buffer where the further bytes should be placed.
+     */
+    public static int _printBase64Binary(byte[] input, int offset, int len, char[] buf, int ptr) {
+        for( int i=offset; i<len; i+=3 ) {
+            switch( len-i ) {
+            case 1:
+                buf[ptr++] = encode(input[i]>>2);
+                buf[ptr++] = encode(((input[i])&0x3)<<4);
+                buf[ptr++] = '=';
+                buf[ptr++] = '=';
+                break;
+            case 2:
+                buf[ptr++] = encode(input[i]>>2);
+                buf[ptr++] = encode(
+                            ((input[i]&0x3)<<4) |
+                            ((input[i+1]>>4)&0xF));
+                buf[ptr++] = encode((input[i+1]&0xF)<<2);
+                buf[ptr++] = '=';
+                break;
+            default:
+                buf[ptr++] = encode(input[i]>>2);
+                buf[ptr++] = encode(
+                            ((input[i]&0x3)<<4) |
+                            ((input[i+1]>>4)&0xF));
+                buf[ptr++] = encode(
+                            ((input[i+1]&0xF)<<2)|
+                            ((input[i+2]>>6)&0x3));
+                buf[ptr++] = encode(input[i+2]&0x3F);
+                break;
+            }
+        }
+        return ptr;
+    }
+
+    /**
+     * Encodes a byte array into another byte array by first doing base64 encoding
+     * then encoding the result in ASCII.
+     *
+     * The caller must supply a big enough buffer.
+     *
+     * @return
+     *      the value of {@code ptr+((len+2)/3)*4}, which is the new offset
+     *      in the output buffer where the further bytes should be placed.
+     */
+    public static int _printBase64Binary(byte[] input, int offset, int len, byte[] out, int ptr) {
+        byte[] buf = out;
+        int max = len+offset;
+        for( int i=offset; i<max; i+=3 ) {
+            switch( max-i ) {
+            case 1:
+                buf[ptr++] = encodeByte(input[i]>>2);
+                buf[ptr++] = encodeByte(((input[i])&0x3)<<4);
+                buf[ptr++] = '=';
+                buf[ptr++] = '=';
+                break;
+            case 2:
+                buf[ptr++] = encodeByte(input[i]>>2);
+                buf[ptr++] = encodeByte(
+                            ((input[i]&0x3)<<4) |
+                            ((input[i+1]>>4)&0xF));
+                buf[ptr++] = encodeByte((input[i+1]&0xF)<<2);
+                buf[ptr++] = '=';
+                break;
+            default:
+                buf[ptr++] = encodeByte(input[i]>>2);
+                buf[ptr++] = encodeByte(
+                            ((input[i]&0x3)<<4) |
+                            ((input[i+1]>>4)&0xF));
+                buf[ptr++] = encodeByte(
+                            ((input[i+1]&0xF)<<2)|
+                            ((input[i+2]>>6)&0x3));
+                buf[ptr++] = encodeByte(input[i+2]&0x3F);
+                break;
+            }
+        }
+
+        return ptr;
+    }
+
+    private static CharSequence removeOptionalPlus(CharSequence s) {
+        int len = s.length();
+
+        if(len<=1 || s.charAt(0)!='+')    return s;
+
+        s = s.subSequence(1,len);
+        char ch = s.charAt(0);
+        if('0'<=ch && ch<='9')    return s;
+        if('.'==ch )    return s;
+
+        throw new NumberFormatException();
+    }
+
+    private static boolean isDigitOrPeriodOrSign( char ch ) {
+        if( '0'<=ch && ch<='9' )    return true;
+        if( ch=='+' || ch=='-' || ch=='.' )    return true;
+        return false;
+    }
+
+    private static final DatatypeFactory datatypeFactory;
+
+    static {
+        try {
+            datatypeFactory = DatatypeFactory.newInstance();
+        } catch (DatatypeConfigurationException e) {
+            throw new Error(e);
+        }
+    }
+
+
+    private static final class CalendarFormatter {
+        public static String doFormat( String format, Calendar cal ) throws IllegalArgumentException {
+            int fidx = 0;
+            int flen = format.length();
+            StringBuilder buf = new StringBuilder();
+
+            while(fidx<flen) {
+                char fch = format.charAt(fidx++);
+
+                if(fch!='%') {  // not a meta character
+                    buf.append(fch);
+                    continue;
+                }
+
+                // seen meta character. we don't do error check against the format
+                switch (format.charAt(fidx++)) {
+                case 'Y' : // year
+                    formatYear(cal, buf);
+                    break;
+
+                case 'M' : // month
+                    formatMonth(cal, buf);
+                    break;
+
+                case 'D' : // days
+                    formatDays(cal, buf);
+                    break;
+
+                case 'h' : // hours
+                    formatHours(cal, buf);
+                    break;
+
+                case 'm' : // minutes
+                    formatMinutes(cal, buf);
+                    break;
+
+                case 's' : // parse seconds.
+                    formatSeconds(cal, buf);
+                    break;
+
+                case 'z' : // time zone
+                    formatTimeZone(cal,buf);
+                    break;
+
+                default :
+                    // illegal meta character. impossible.
+                    throw new InternalError();
+                }
+            }
+
+            return buf.toString();
+        }
+
+
+        private static void formatYear(Calendar cal, StringBuilder buf) {
+            int year = cal.get(Calendar.YEAR);
+
+            String s;
+            if (year <= 0) // negative value
+                s = Integer.toString(1 - year);
+            else // positive value
+                s = Integer.toString(year);
+
+            while (s.length() < 4)
+                s = '0' + s;
+            if (year <= 0)
+                s = '-' + s;
+
+            buf.append(s);
+        }
+
+        private static void formatMonth(Calendar cal, StringBuilder buf) {
+            formatTwoDigits(cal.get(Calendar.MONTH)+1,buf);
+        }
+
+        private static void formatDays(Calendar cal, StringBuilder buf) {
+            formatTwoDigits(cal.get(Calendar.DAY_OF_MONTH),buf);
+        }
+
+        private static void formatHours(Calendar cal, StringBuilder buf) {
+            formatTwoDigits(cal.get(Calendar.HOUR_OF_DAY),buf);
+        }
+
+        private static void formatMinutes(Calendar cal, StringBuilder buf) {
+            formatTwoDigits(cal.get(Calendar.MINUTE),buf);
+        }
+
+        private static void formatSeconds(Calendar cal, StringBuilder buf) {
+            formatTwoDigits(cal.get(Calendar.SECOND),buf);
+            if (cal.isSet(Calendar.MILLISECOND)) { // milliseconds
+                int n = cal.get(Calendar.MILLISECOND);
+                if(n!=0) {
+                    String ms = Integer.toString(n);
+                    while (ms.length() < 3)
+                        ms = '0' + ms; // left 0 paddings.
+
+                    buf.append('.');
+                    buf.append(ms);
+                }
+            }
+        }
+
+        /** formats time zone specifier. */
+        private static void formatTimeZone(Calendar cal,StringBuilder buf) {
+            TimeZone tz = cal.getTimeZone();
+
+            if (tz == null)      return;
+
+            // otherwise print out normally.
+            int offset;
+            if (tz.inDaylightTime(cal.getTime())) {
+                offset = tz.getRawOffset() + (tz.useDaylightTime()?3600000:0);
+            } else {
+                offset = tz.getRawOffset();
+            }
+
+            if (offset >= 0)
+                buf.append('+');
+            else {
+                buf.append('-');
+                offset *= -1;
+            }
+
+            offset /= 60 * 1000; // offset is in milli-seconds
+
+            formatTwoDigits(offset / 60, buf);
+            buf.append(':');
+            formatTwoDigits(offset % 60, buf);
+        }
+
+        /** formats Integer into two-character-wide string. */
+        private static final void formatTwoDigits(int n,StringBuilder buf) {
+            // n is always non-negative.
+            if (n < 10) buf.append('0');
+            buf.append(n);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/IDResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/IDResolver.java
new file mode 100644
index 0000000..5f95208
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/IDResolver.java
@@ -0,0 +1,162 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind;
+
+import java.util.concurrent.Future;
+import java.util.concurrent.Callable;
+import java.util.concurrent.Executors;
+
+import javax.xml.bind.annotation.XmlIDREF;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.ValidationEventHandler;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Pluggable ID/IDREF handling layer.
+ *
+ * <p>
+ * <b>THIS INTERFACE IS SUBJECT TO CHANGE WITHOUT NOTICE.</b>
+ *
+ * <p>
+ * This 'interface' can be implemented by applications and specified to
+ * {@link Unmarshaller#setProperty(String, Object)} to ovierride the ID/IDREF
+ * processing of the JAXB RI like this:
+ *
+ * <pre>
+ * unmarshaller.setProperty(IDResolver.class.getName(),new MyIDResolverImpl());
+ * </pre>
+ *
+ * <h2>Error Handling</h2>
+ * <p>
+ * This component runs inside the JAXB RI unmarshaller. Therefore, it needs
+ * to coordinate with the JAXB RI unmarshaller when it comes to reporting
+ * errors. This makes sure that applications see consistent error handling behaviors.
+ *
+ * <p>
+ * When the {@link #startDocument(ValidationEventHandler)} method is invoked,
+ * the unmarshaller passes in a {@link ValidationEventHandler} that can be used
+ * by this component to report any errors encountered during the ID/IDREF processing.
+ *
+ * <p>
+ * When an error is detected, the error should be first reported to this
+ * {@link ValidationEventHandler}. If the error is fatal or the event handler
+ * decided to abort, the implementation should throw a {@link SAXException}.
+ * This signals the unmarshaller to abort the processing.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB 2.0 beta
+ */
+public abstract class IDResolver {
+
+    /**
+     * Called when the unmarshalling starts.
+     *
+     * <p>
+     * Since one {@link Unmarshaller} may be used multiple times
+     * to unmarshal documents, one {@link IDResolver} may be used multiple times, too.
+     *
+     * @param eventHandler
+     *      Any errors found during the unmarshalling should be reported to this object.
+     */
+    public void startDocument(ValidationEventHandler eventHandler) throws SAXException {
+
+    }
+
+    /**
+     * Called after the unmarshalling completes.
+     *
+     * <p>
+     * This is a good opporunity to reset any internal state of this object,
+     * so that it doesn't keep references to other objects unnecessarily.
+     */
+    public void endDocument() throws SAXException {
+
+    }
+
+    /**
+     * Binds the given object to the specified ID.
+     *
+     * <p>
+     * While a document is being unmarshalled, every time
+     * an ID value is found, this method is invoked to
+     * remember the association between ID and objects.
+     * This association is supposed to be used later to resolve
+     * IDREFs.
+     *
+     * <p>
+     * This method is invoked right away as soon as a new ID value is found.
+     *
+     * @param id
+     *      The ID value found in the document being unmarshalled.
+     *      Always non-null.
+     * @param obj
+     *      The object being unmarshalled which is going to own the ID.
+     *      Always non-null.
+     */
+    public abstract void bind( String id, Object obj ) throws SAXException;
+
+    /**
+     * Obtains the object to be pointed by the IDREF value.
+     *
+     * <p>
+     * While a document is being unmarshalled, every time
+     * an IDREF value is found, this method is invoked immediately to
+     * obtain the object that the IDREF is pointing to.
+     *
+     * <p>
+     * This method returns a {@link Callable} to support forward-references.
+     * When this method returns with a non-null return value,
+     * the JAXB RI unmarshaller invokes the {@link Callable#call()} method immediately.
+     * If the implementation can find the target object (in which case
+     * it was a backward reference), then a non-null object shall be returned,
+     * and it is used as the target object.
+     *
+     * <p>
+     * When a forward-reference happens, the <tt>call</tt> method
+     * should return null. In this case the JAXB RI unmarshaller invokes
+     * the <tt>call</tt> method again after all the documents are fully unmarshalled.
+     * If the <tt>call</tt> method still returns null, then the JAXB RI unmarshaller
+     * treats it as an error.
+     *
+     * <p>
+     * A {@link Callable} object returned from this method may not throw
+     * any exception other than a {@link SAXException} (which means a fatal error.)
+     *
+     * @param id
+     *      The IDREF value found in the document being unmarshalled.
+     *      Always non-null.
+     * @param targetType
+     *      The expected type to which ID resolves to. JAXB infers this
+     *      information from the signature of the fields that has {@link XmlIDREF}.
+     *      When a property is a collection, this parameter will be the type
+     *      of the individual item in the collection.
+     * @return
+     *      null if the implementation is sure that the parameter combination
+     *      will never yield a valid object. Otherwise non-null.
+     */
+    public abstract Callable<?> resolve( String id, Class targetType ) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/Locatable.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/Locatable.java
new file mode 100644
index 0000000..7bbb351
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/Locatable.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind;
+
+import com.sun.xml.internal.bind.annotation.XmlLocation;
+
+import org.xml.sax.Locator;
+
+/**
+ * Optional interface implemented by JAXB objects to expose
+ * location information from which an object is unmarshalled.
+ *
+ * <p>
+ * This is used during JAXB RI 1.0.x.
+ * In JAXB 2.0, use {@link XmlLocation}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ *
+ * @since JAXB RI 1.0
+ */
+public interface Locatable {
+    /**
+     * @return
+     *      null if the location information is unavaiable,
+     *      or otherwise return a immutable valid {@link Locator}
+     *      object.
+     */
+    Locator sourceLocation();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/Util.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/Util.java
new file mode 100644
index 0000000..7be5a87
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/Util.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind;
+
+import java.util.logging.Logger;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Util {
+    private Util() {}   // no instanciation
+
+    /**
+     * Gets the logger for the caller's class.
+     *
+     * @since 2.0
+     */
+    public static Logger getClassLogger() {
+        try {
+//            StackTraceElement[] trace = Thread.currentThread().getStackTrace();
+            StackTraceElement[] trace = new Exception().getStackTrace();
+            return Logger.getLogger(trace[1].getClassName());
+        } catch( SecurityException _ ) {
+            return Logger.getLogger("com.sun.xml.internal.bind"); // use the default
+        }
+    }
+
+    /**
+     * Reads the system property value and takes care of {@link SecurityException}.
+     */
+    public static String getSystemProperty(String name) {
+        try {
+            return System.getProperty(name);
+        } catch( SecurityException e ) {
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/ValidationEventLocatorEx.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/ValidationEventLocatorEx.java
new file mode 100644
index 0000000..6cc3897
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/ValidationEventLocatorEx.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind;
+
+import javax.xml.bind.ValidationEventLocator;
+
+/**
+ * Defines additional accessor methods for the event source location.
+ * <p>
+ * This interface exposes the location information only available
+ * in the JAXB RI specific extension.
+ * <p>
+ * <em>DO NOT IMPLEMENT THIS INTERFACE BY YOUR CODE</em> because
+ * we might add more methods on this interface in the future release
+ * of the RI.
+ *
+ * <h2>Usage</h2>
+ * <p>
+ * If you obtain a reference to {@link javax.xml.bind.ValidationEventLocator},
+ * check if you can cast it to {@link ValidationEventLocatorEx} first, like this:
+ * <pre>
+ * void foo( ValidationEvent e ) {
+ *     ValidationEventLocator loc = e.getLocator();
+ *     if( loc instanceof ValidationEventLocatorEx ) {
+ *         String fieldName = ((ValidationEventLocatorEx)loc).getFieldName();
+ *         if( fieldName!=null ) {
+ *             // do something with location.
+ *         }
+ *     }
+ * }
+ * </pre>
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface ValidationEventLocatorEx extends ValidationEventLocator {
+    /**
+     * Returns the field name of the object where the error occured.
+     * <p>
+     * This method always returns null when you are doing
+     * a validation during unmarshalling.
+     *
+     * When not null, the field name indicates the field of the object
+     * designated by the {@link #getObject()} method where the error
+     * occured.
+     */
+    String getFieldName();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/WhiteSpaceProcessor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/WhiteSpaceProcessor.java
new file mode 100644
index 0000000..90c4565
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/WhiteSpaceProcessor.java
@@ -0,0 +1,198 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind;
+
+/**
+ * Processes white space normalization.
+ *
+ * @since 1.0
+ */
+public abstract class WhiteSpaceProcessor {
+
+// benchmarking (see test/src/ReplaceTest.java in the CVS Attic)
+// showed that this code is slower than the current code.
+//
+//    public static String replace(String text) {
+//        final int len = text.length();
+//        StringBuffer result = new StringBuffer(len);
+//
+//        for (int i = 0; i < len; i++) {
+//            char ch = text.charAt(i);
+//            if (isWhiteSpace(ch))
+//                result.append(' ');
+//            else
+//                result.append(ch);
+//        }
+//
+//        return result.toString();
+//    }
+
+    public static String replace(String text) {
+        return replace( (CharSequence)text ).toString();
+    }
+
+    /**
+     * @since 2.0
+     */
+    public static CharSequence replace(CharSequence text) {
+        int i=text.length()-1;
+
+        // look for the first whitespace char.
+        while( i>=0 && !isWhiteSpaceExceptSpace(text.charAt(i)) )
+            i--;
+
+        if( i<0 )
+            // no such whitespace. replace(text)==text.
+            return text;
+
+        // we now know that we need to modify the text.
+        // allocate a char array to do it.
+        StringBuilder buf = new StringBuilder(text);
+
+        buf.setCharAt(i--,' ');
+        for( ; i>=0; i-- )
+            if( isWhiteSpaceExceptSpace(buf.charAt(i)))
+                buf.setCharAt(i,' ');
+
+        return new String(buf);
+    }
+
+    /**
+     * Equivalent of {@link String#trim()}.
+     * @since 2.0
+     */
+    public static CharSequence trim(CharSequence text) {
+        int len = text.length();
+        int start = 0;
+
+        while( start<len && isWhiteSpace(text.charAt(start)) )
+            start++;
+
+        int end = len-1;
+
+        while( end>start && isWhiteSpace(text.charAt(end)) )
+            end--;
+
+        if(start==0 && end==len-1)
+            return text;    // no change
+        else
+            return text.subSequence(start,end+1);
+    }
+
+    public static String collapse(String text) {
+        return collapse( (CharSequence)text ).toString();
+    }
+
+    /**
+     * This is usually the biggest processing bottleneck.
+     *
+     * @since 2.0
+     */
+    public static CharSequence collapse(CharSequence text) {
+        int len = text.length();
+
+        // most of the texts are already in the collapsed form.
+        // so look for the first whitespace in the hope that we will
+        // never see it.
+        int s=0;
+        while(s<len) {
+            if(isWhiteSpace(text.charAt(s)))
+                break;
+            s++;
+        }
+        if(s==len)
+            // the input happens to be already collapsed.
+            return text;
+
+        // we now know that the input contains spaces.
+        // let's sit down and do the collapsing normally.
+
+        StringBuilder result = new StringBuilder(len /*allocate enough size to avoid re-allocation*/ );
+
+        if(s!=0) {
+            for( int i=0; i<s; i++ )
+                result.append(text.charAt(i));
+            result.append(' ');
+        }
+
+        boolean inStripMode = true;
+        for (int i = s+1; i < len; i++) {
+            char ch = text.charAt(i);
+            boolean b = isWhiteSpace(ch);
+            if (inStripMode && b)
+                continue; // skip this character
+
+            inStripMode = b;
+            if (inStripMode)
+                result.append(' ');
+            else
+                result.append(ch);
+        }
+
+        // remove trailing whitespaces
+        len = result.length();
+        if (len > 0 && result.charAt(len - 1) == ' ')
+            result.setLength(len - 1);
+        // whitespaces are already collapsed,
+        // so all we have to do is to remove the last one character
+        // if it's a whitespace.
+
+        return result;
+    }
+
+    /**
+     * Returns true if the specified string is all whitespace.
+     */
+    public static final boolean isWhiteSpace(CharSequence s) {
+        for( int i=s.length()-1; i>=0; i-- )
+            if(!isWhiteSpace(s.charAt(i)))
+                return false;
+        return true;
+    }
+
+    /** returns true if the specified char is a white space character. */
+    public static final boolean isWhiteSpace(char ch) {
+        // most of the characters are non-control characters.
+        // so check that first to quickly return false for most of the cases.
+        if( ch>0x20 )   return false;
+
+        // other than we have to do four comparisons.
+        return ch == 0x9 || ch == 0xA || ch == 0xD || ch == 0x20;
+    }
+
+    /**
+     * Returns true if the specified char is a white space character
+     * but not 0x20.
+     */
+    protected static final boolean isWhiteSpaceExceptSpace(char ch) {
+        // most of the characters are non-control characters.
+        // so check that first to quickly return false for most of the cases.
+        if( ch>=0x20 )   return false;
+
+        // other than we have to do four comparisons.
+        return ch == 0x9 || ch == 0xA || ch == 0xD;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/annotation/XmlIsSet.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/annotation/XmlIsSet.java
new file mode 100644
index 0000000..996e6ea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/annotation/XmlIsSet.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlElementRef;
+import javax.xml.bind.annotation.XmlValue;
+
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+
+/**
+ * Designates a boolean field/property as a flag to indicate
+ * whether another property is present or not.
+ *
+ * <p>
+ * Sometimes you'd want to map a Java primitive type to an
+ * optional element/attribute. Doing this makes it impossible
+ * to represent the absence of the property, thus you always
+ * end up producing the value when you marshal to XML.
+ *
+ * For example,
+ * <pre>
+ * {@link XmlElement}
+ * class Foo {
+ *      {@link XmlElement}
+ *      int x;
+ * }
+ *
+ * marshaller.marshal(new Foo());
+ * </pre>
+ * and you get:
+ * <pre><xmp>
+ * <foo><x>0</x></foo>
+ * </xmp></pre>
+ *
+ * <p>
+ * By creating a side boolean field/property that has this annotation,
+ * you can indicate the absence of the property by setting this boolean
+ * to false.
+ * <pre>
+ * {@link XmlElement}
+ * class Foo {
+ *      {@link XmlElement}
+ *      int x;
+ *      {@link XmlIsSet}("x")
+ *      boolean xIsPresent;
+ * }
+ *
+ * Foo f = new Foo();
+ * f.x = 5;
+ * f.xIsPresent = false;
+ *
+ * marshaller.marshal(f);
+ *
+ * <xmp>
+ * <foo/>
+ * </xmp>
+ *
+ * f.xIsPresent = true;
+ * <xmp>
+ * <foo><x>5</x></foo>
+ * </xmp>
+ * </pre>
+ *
+ * <p>
+ * A property/field annotated with {@link XmlIsSet} itself will not show up in XML.
+ * It is an error to use this annotation on the same property/field
+ * as {@link XmlElement}, {@link XmlAttribute}, {@link XmlValue}, or {@link XmlElementRef},
+ * ...<b>TBD</b>.
+ *
+ * @deprecated
+ *      this hasn't been implemented in the RI, and this hasn't been speced yet.
+ *      I believe Joe asked for this feature. I'd like to drop this.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD})
+public @interface XmlIsSet {
+    /**
+     * Specifies the name of the property to attach to.
+     */
+    String value();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/annotation/XmlLocation.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/annotation/XmlLocation.java
new file mode 100644
index 0000000..bc0a78d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/annotation/XmlLocation.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import org.xml.sax.Locator;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+
+/**
+ * Marks a property that receives a location from which the object is unmarshalled.
+ *
+ * <h2>Usage</h2>
+ * <p>
+ * The @XmlLocation can be specified on:
+ * <ul>
+ *  <li>a field whose type is {@link Locator}, or
+ *  <li>a method that takes a {@link Locator} as the sole parameter
+ * </ul>
+ *
+ * <p>
+ * When a class that contains such a field/method is unmarshalled by the JAXB RI,
+ * such a field/method will receive an immutable {@link Locator} object that describes
+ * the location in the XML document where the object is unmarshalled from.
+ *
+ * <p>
+ * If the unmarshaller does not know the source location information, the locator
+ * will not be set. For example, this happens when it is unmarshalling from a DOM tree.
+ * This also happens if you use JAXB implementations other than the JAXB RI.
+ *
+ * <p>
+ * This information can be used by applications, for example to provide user-friendly
+ * error information.
+ *
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB RI 2.0 EA
+ */
+@Retention(RUNTIME) @Target({FIELD,METHOD})
+public @interface XmlLocation {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/AccessorException.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/AccessorException.java
new file mode 100644
index 0000000..ef66bfa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/AccessorException.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api;
+
+
+/**
+ * Signals an error in {@link RawAccessor}.
+ *
+ * <p>
+ * This error is not reported to the user handler. Once reported
+ * the error should be wrapped into another exception.
+ *
+ * <p>
+ * This exception happens primarily when JAXB accesses the getter/setter
+ * method and it throws a checked exception.
+ *
+ * <p>
+ * <b>Subject to change without notice</b>.
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @since 2.0 EA1
+ */
+public final class AccessorException extends Exception {
+    public AccessorException() {
+    }
+
+    public AccessorException(String message) {
+        super(message);
+    }
+
+    public AccessorException(String message, Throwable cause) {
+        super(message, cause);
+    }
+
+    public AccessorException(Throwable cause) {
+        super(cause);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/Bridge.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/Bridge.java
new file mode 100644
index 0000000..049b054
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/Bridge.java
@@ -0,0 +1,311 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api;
+
+import java.io.InputStream;
+import java.io.OutputStream;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.Result;
+import javax.xml.transform.Source;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.istack.internal.Nullable;
+import com.sun.xml.internal.bind.v2.runtime.BridgeContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+
+import org.w3c.dom.Node;
+import org.xml.sax.ContentHandler;
+
+/**
+ * Mini-marshaller/unmarshaller that is specialized for a particular
+ * element name and a type.
+ *
+ * <p>
+ * Instances of this class is stateless and multi-thread safe.
+ * They are reentrant.
+ *
+ * <p>
+ * All the marshal operation generates fragments.
+ *
+ * <p>
+ * <b>Subject to change without notice</b>.
+ *
+ * @since JAXB 2.0 EA1
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Bridge<T> {
+    protected Bridge(JAXBContextImpl context) {
+        this.context = context;
+    }
+
+    protected final JAXBContextImpl context;
+
+    /**
+     *
+     * @throws JAXBException
+     *      if there was an error while marshalling.
+     *
+     * @since 2.0 EA1
+     */
+    public final void marshal(T object,XMLStreamWriter output) throws JAXBException {
+        marshal(object,output,null);
+    }
+    public final void marshal(T object,XMLStreamWriter output, AttachmentMarshaller am) throws JAXBException {
+        Marshaller m = context.marshallerPool.take();
+        m.setAttachmentMarshaller(am);
+        marshal(m,object,output);
+        m.setAttachmentMarshaller(null);
+        context.marshallerPool.recycle(m);
+    }
+
+    public final void marshal(@NotNull BridgeContext context,T object,XMLStreamWriter output) throws JAXBException {
+        marshal( ((BridgeContextImpl)context).marshaller, object, output );
+    }
+
+    public abstract void marshal(@NotNull Marshaller m,T object,XMLStreamWriter output) throws JAXBException;
+
+
+    /**
+     * Marshals the specified type object with the implicit element name
+     * associated with this instance of {@link Bridge}.
+     *
+     * @param nsContext
+     *      if this marshalling is done to marshal a subelement, this {@link NamespaceContext}
+     *      represents in-scope namespace bindings available for that element. Can be null,
+     *      in which case JAXB assumes no in-scope namespaces.
+     * @throws JAXBException
+     *      if there was an error while marshalling.
+     *
+     * @since 2.0 EA1
+     */
+    public void marshal(T object,OutputStream output, NamespaceContext nsContext) throws JAXBException {
+        marshal(object,output,nsContext,null);
+    }
+    /**
+     * @since 2.0.2
+     */
+    public void marshal(T object,OutputStream output, NamespaceContext nsContext, AttachmentMarshaller am) throws JAXBException {
+        Marshaller m = context.marshallerPool.take();
+        m.setAttachmentMarshaller(am);
+        marshal(m,object,output,nsContext);
+        m.setAttachmentMarshaller(null);
+        context.marshallerPool.recycle(m);
+    }
+
+    public final void marshal(@NotNull BridgeContext context,T object,OutputStream output, NamespaceContext nsContext) throws JAXBException {
+        marshal( ((BridgeContextImpl)context).marshaller, object, output, nsContext );
+    }
+
+    public abstract void marshal(@NotNull Marshaller m,T object,OutputStream output, NamespaceContext nsContext) throws JAXBException;
+
+
+    public final void marshal(T object,Node output) throws JAXBException {
+        Marshaller m = context.marshallerPool.take();
+        marshal(m,object,output);
+        context.marshallerPool.recycle(m);
+    }
+
+    public final void marshal(@NotNull BridgeContext context,T object,Node output) throws JAXBException {
+        marshal( ((BridgeContextImpl)context).marshaller, object, output );
+    }
+
+    public abstract void marshal(@NotNull Marshaller m,T object,Node output) throws JAXBException;
+
+
+    /**
+     * @since 2.0 EA4
+     */
+    public final void marshal(T object, ContentHandler contentHandler) throws JAXBException {
+        marshal(object,contentHandler,null);
+    }
+    /**
+     * @since 2.0.2
+     */
+    public final void marshal(T object, ContentHandler contentHandler, AttachmentMarshaller am) throws JAXBException {
+        Marshaller m = context.marshallerPool.take();
+        m.setAttachmentMarshaller(am);
+        marshal(m,object,contentHandler);
+        m.setAttachmentMarshaller(null);
+        context.marshallerPool.recycle(m);
+    }
+    public final void marshal(@NotNull BridgeContext context,T object, ContentHandler contentHandler) throws JAXBException {
+        marshal( ((BridgeContextImpl)context).marshaller, object, contentHandler );
+    }
+    public abstract void marshal(@NotNull Marshaller m,T object, ContentHandler contentHandler) throws JAXBException;
+
+    /**
+     * @since 2.0 EA4
+     */
+    public final void marshal(T object, Result result) throws JAXBException {
+        Marshaller m = context.marshallerPool.take();
+        marshal(m,object,result);
+        context.marshallerPool.recycle(m);
+    }
+    public final void marshal(@NotNull BridgeContext context,T object, Result result) throws JAXBException {
+        marshal( ((BridgeContextImpl)context).marshaller, object, result );
+    }
+    public abstract void marshal(@NotNull Marshaller m,T object, Result result) throws JAXBException;
+
+
+
+    private T exit(T r, Unmarshaller u) {
+        u.setAttachmentUnmarshaller(null);
+        context.unmarshallerPool.recycle(u);
+        return r;
+    }
+
+    /**
+     * Unmarshals the specified type object.
+     *
+     * @param in
+     *      the parser must be pointing at a start tag
+     *      that encloses the XML type that this {@link Bridge} is
+     *      instanciated for.
+     *
+     * @return
+     *      never null.
+     *
+     * @throws JAXBException
+     *      if there was an error while unmarshalling.
+     *
+     * @since 2.0 EA1
+     */
+    public final @NotNull T unmarshal(@NotNull XMLStreamReader in) throws JAXBException {
+        return unmarshal(in,null);
+    }
+    /**
+     * @since 2.0.3
+     */
+    public final @NotNull T unmarshal(@NotNull XMLStreamReader in, @Nullable AttachmentUnmarshaller au) throws JAXBException {
+        Unmarshaller u = context.unmarshallerPool.take();
+        u.setAttachmentUnmarshaller(au);
+        return exit(unmarshal(u,in),u);
+    }
+    public final @NotNull T unmarshal(@NotNull BridgeContext context, @NotNull XMLStreamReader in) throws JAXBException {
+        return unmarshal( ((BridgeContextImpl)context).unmarshaller, in );
+    }
+    public abstract @NotNull T unmarshal(@NotNull Unmarshaller u, @NotNull XMLStreamReader in) throws JAXBException;
+
+    /**
+     * Unmarshals the specified type object.
+     *
+     * @param in
+     *      the parser must be pointing at a start tag
+     *      that encloses the XML type that this {@link Bridge} is
+     *      instanciated for.
+     *
+     * @return
+     *      never null.
+     *
+     * @throws JAXBException
+     *      if there was an error while unmarshalling.
+     *
+     * @since 2.0 EA1
+     */
+    public final @NotNull T unmarshal(@NotNull Source in) throws JAXBException {
+        return unmarshal(in,null);
+    }
+    /**
+     * @since 2.0.3
+     */
+    public final @NotNull T unmarshal(@NotNull Source in, @Nullable AttachmentUnmarshaller au) throws JAXBException {
+        Unmarshaller u = context.unmarshallerPool.take();
+        u.setAttachmentUnmarshaller(au);
+        return exit(unmarshal(u,in),u);
+    }
+    public final @NotNull T unmarshal(@NotNull BridgeContext context, @NotNull Source in) throws JAXBException {
+        return unmarshal( ((BridgeContextImpl)context).unmarshaller, in );
+    }
+    public abstract @NotNull T unmarshal(@NotNull Unmarshaller u, @NotNull Source in) throws JAXBException;
+
+    /**
+     * Unmarshals the specified type object.
+     *
+     * @param in
+     *      the parser must be pointing at a start tag
+     *      that encloses the XML type that this {@link Bridge} is
+     *      instanciated for.
+     *
+     * @return
+     *      never null.
+     *
+     * @throws JAXBException
+     *      if there was an error while unmarshalling.
+     *
+     * @since 2.0 EA1
+     */
+    public final @NotNull T unmarshal(@NotNull InputStream in) throws JAXBException {
+        Unmarshaller u = context.unmarshallerPool.take();
+        return exit(unmarshal(u,in),u);
+    }
+    public final @NotNull T unmarshal(@NotNull BridgeContext context, @NotNull InputStream in) throws JAXBException {
+        return unmarshal( ((BridgeContextImpl)context).unmarshaller, in );
+    }
+    public abstract @NotNull T unmarshal(@NotNull Unmarshaller u, @NotNull InputStream in) throws JAXBException;
+
+    /**
+     * Unmarshals the specified type object.
+     *
+     * @param n
+     *      Node to be unmarshalled.
+     *
+     * @return
+     *      never null.
+     *
+     * @throws JAXBException
+     *      if there was an error while unmarshalling.
+     *
+     * @since 2.0 FCS
+     */
+    public final @NotNull T unmarshal(@NotNull Node n) throws JAXBException {
+        return unmarshal(n,null);
+    }
+    /**
+     * @since 2.0.3
+     */
+    public final @NotNull T unmarshal(@NotNull Node n, @Nullable AttachmentUnmarshaller au) throws JAXBException {
+        Unmarshaller u = context.unmarshallerPool.take();
+        u.setAttachmentUnmarshaller(au);
+        return exit(unmarshal(u,n),u);
+    }
+    public final @NotNull T unmarshal(@NotNull BridgeContext context, @NotNull Node n) throws JAXBException {
+        return unmarshal( ((BridgeContextImpl)context).unmarshaller, n );
+    }
+    public abstract @NotNull T unmarshal(@NotNull Unmarshaller context, @NotNull Node n) throws JAXBException;
+
+    /**
+     * Gets the {@link TypeReference} from which this bridge was created.
+     */
+    public abstract TypeReference getTypeReference();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/BridgeContext.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/BridgeContext.java
new file mode 100644
index 0000000..60fc478
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/BridgeContext.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api;
+
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+
+/**
+ * Holds thread specific state information for {@link Bridge}s,
+ * to make {@link Bridge} thread-safe.
+ *
+ * <p>
+ * This object cannot be used concurrently; two threads cannot
+ * use the same object with {@link Bridge}s at the same time, nor
+ * a thread can use a {@link BridgeContext} with one {@link Bridge} while
+ * the same context is in use by another {@link Bridge}.
+ *
+ * <p>
+ * {@link BridgeContext} is relatively a heavy-weight object, and
+ * therefore it is expected to be cached by the JAX-RPC RI.
+ *
+ * <p>
+ * <b>Subject to change without notice</b>.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since 2.0 EA1
+ * @see Bridge
+ * @deprecated
+ *      The caller no longer needs to use this, as {@link Bridge} has
+ *      methods that can work without {@link BridgeContext}.
+ */
+public abstract class BridgeContext {
+    protected BridgeContext() {}
+
+    /**
+     * Registers the error handler that receives unmarshalling/marshalling errors.
+     *
+     * @param handler
+     *      can be null, in which case all errors will be considered fatal.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract void setErrorHandler(ValidationEventHandler handler);
+
+    /**
+     * Sets the {@link AttachmentMarshaller}.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract void setAttachmentMarshaller(AttachmentMarshaller m);
+
+    /**
+     * Sets the {@link AttachmentUnmarshaller}.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract void setAttachmentUnmarshaller(AttachmentUnmarshaller m);
+
+    /**
+     * Gets the last {@link AttachmentMarshaller} set through
+     * {@link AttachmentMarshaller}.
+     *
+     * @since 2.0 EA2
+     */
+    public abstract AttachmentMarshaller getAttachmentMarshaller();
+
+    /**
+     * Gets the last {@link AttachmentUnmarshaller} set through
+     * {@link AttachmentUnmarshaller}.
+     *
+     * @since 2.0 EA2
+     */
+    public abstract AttachmentUnmarshaller getAttachmentUnmarshaller();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/CompositeStructure.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/CompositeStructure.java
new file mode 100644
index 0000000..e49b4ab
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/CompositeStructure.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api;
+
+/**
+ * A JAXB Bean that works like a DOM.
+ *
+ * <p>
+ * This bean is bound to XML as a sequence of elements, where each
+ * element[i] is from bridges[i] (which defines the tag name and the expected type)
+ * and values[i] (which defines the actual value.)
+ *
+ * <p>
+ * This object allows you to treat multiple unrelated JAXB beans as a single tree.
+ * This in turn allows you to marshal this tree in one marshal method invocation,
+ * which is faster than multiple invocations of the marshal method.
+ *
+ * <p>
+ * The binding of this class is always known to {@link JAXBRIContext}, so it can be
+ * used without passing anything to {@link JAXBRIContext#newInstance}.
+ * This object can be only used for marshalling, not for unmarshalling.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class CompositeStructure {
+    public Bridge[] bridges;
+    public Object[] values;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/JAXBRIContext.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/JAXBRIContext.java
new file mode 100644
index 0000000..6d6064b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/JAXBRIContext.java
@@ -0,0 +1,346 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api;
+
+import java.io.IOException;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.Collection;
+import java.util.List;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.namespace.QName;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.istack.internal.Nullable;
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+
+/**
+ * {@link JAXBContext} enhanced with JAXB RI specific functionalities.
+ *
+ * <p>
+ * <b>Subject to change without notice</b>.
+ *
+ * @since 2.0 EA1
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class JAXBRIContext extends JAXBContext {
+    protected JAXBRIContext() {}
+
+    /**
+     * Creates a new {@link JAXBRIContext}.
+     *
+     * <p>
+     * {@link JAXBContext#newInstance(Class[]) JAXBContext.newInstance()} methods may
+     * return other JAXB providers that are not compatible with the JAX-RPC RI.
+     * This method guarantees that the JAX-WS RI will finds the JAXB RI.
+     *
+     * @param classes
+     *      Classes to be bound. See {@link JAXBContext#newInstance(Class[])} for the meaning.
+     * @param typeRefs
+     *      See {@link #TYPE_REFERENCES} for the meaning of this parameter.
+     *      Can be null.
+     * @param defaultNamespaceRemap
+     *      See {@link #DEFAULT_NAMESPACE_REMAP} for the meaning of this parameter.
+     *      Can be null (and should be null for ordinary use of JAXB.)
+     * @param c14nSupport
+     *      See {@link #CANONICALIZATION_SUPPORT} for the meaning of this parameter.
+     */
+    public static JAXBRIContext newInstance(@NotNull Class[] classes, @Nullable Collection<TypeReference> typeRefs, @Nullable String defaultNamespaceRemap, boolean c14nSupport ) throws JAXBException {
+        try {
+            Class c = Class.forName("com.sun.xml.internal.bind.v2.ContextFactory");
+            Method method = c.getMethod("createContext",Class[].class,Collection.class,String.class,boolean.class);
+            Object o = method.invoke(null,classes,typeRefs,defaultNamespaceRemap,c14nSupport);
+            return (JAXBRIContext)o;
+        } catch (ClassNotFoundException e) {
+            throw new JAXBException(e);
+        } catch (NoSuchMethodException e) {
+            throw new JAXBException(e);
+        } catch (IllegalAccessException e) {
+            throw new JAXBException(e);
+        } catch (InvocationTargetException e) {
+            Throwable te = e.getTargetException();
+            if(te instanceof JAXBException)
+                throw (JAXBException)te;
+            if(te instanceof RuntimeException)
+                throw (RuntimeException)te;
+            if(te instanceof Error)
+                throw (Error)te;
+            throw new JAXBException(e);
+        }
+    }
+
+    /**
+     * If the given object is bound to an element in XML by JAXB,
+     * returns the element name.
+     *
+     * @return null
+     *      if the object is not bound to an element.
+     * @throws JAXBException
+     *      if the object is not known to this context.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract @Nullable QName getElementName(@NotNull Object o) throws JAXBException;
+
+    /**
+     * Creates a mini-marshaller/unmarshaller that can process a {@link TypeReference}.
+     *
+     * @return
+     *      null if the specified reference is not given to {@link JAXBRIContext#newInstance}.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract Bridge createBridge(@NotNull TypeReference ref);
+
+    /**
+     * Creates a new {@link BridgeContext} instance.
+     *
+     * @return
+     *      always a valid non-null instance.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract @NotNull BridgeContext createBridgeContext();
+
+    /**
+     * Gets a {@link RawAccessor} for the specified element property of the specified wrapper bean class.
+     *
+     * <p>
+     * This method is designed to assist the JAX-RPC RI fill in a wrapper bean (in the doc/lit/wrap mode.)
+     * In the said mode, a wrapper bean is supposed to only have properties that match elements,
+     * and for each element that appear in the content model there's one property.
+     *
+     * <p>
+     * Therefore, this method takes a wrapper bean and a tag name that identifies a property
+     * on the given wrapper bean, then returns a {@link RawAccessor} that allows the caller
+     * to set/get a value from the property of the bean.
+     *
+     * <p>
+     * This method is not designed for a performance. The caller is expected to cache the result.
+     *
+     * @param <B>
+     *      type of the wrapper bean
+     * @param <V>
+     *      type of the property of the bean
+     * @return
+     *      always return non-null valid accessor object.
+     * @throws JAXBException
+     *      if the specified wrapper bean is not bound by JAXB, or if it doesn't have an element property
+     *      of the given name.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract <B,V> RawAccessor<B,V> getElementPropertyAccessor( Class<B> wrapperBean, String nsUri, String localName )
+            throws JAXBException;
+
+    /**
+     * Gets the namespace URIs statically known to this {@link JAXBContext}.
+     *
+     * <p>
+     * When JAXB is used to marshal into sub-trees, it declares
+     * these namespace URIs at each top-level element that it marshals.
+     *
+     * To avoid repeated namespace declarations at sub-elements, the application
+     * may declare those namespaces at a higher level.
+     *
+     * @return
+     *      always non-null.
+     *
+     * @since 2.0 EA2
+     */
+    public abstract @NotNull List<String> getKnownNamespaceURIs();
+
+
+    /**
+     * Generates the schema documents from the model.
+     *
+     * <p>
+     * The caller can use the additionalElementDecls parameter to
+     * add element declarations to the generate schema.
+     * For example, if the JAX-RPC passes in the following entry:
+     *
+     * {foo}bar -> DeclaredType for java.lang.String
+     *
+     * then JAXB generates the following element declaration (in the schema
+     * document for the namespace "foo")"
+     *
+     * &lt;xs:element name="bar" type="xs:string" />
+     *
+     * This can be used for generating schema components necessary for WSDL.
+     *
+     * @param outputResolver
+     *      this object controls the output to which schemas
+     *      will be sent.
+     *
+     * @throws IOException
+     *      if {@link SchemaOutputResolver} throws an {@link IOException}.
+     */
+    public abstract void generateSchema(@NotNull SchemaOutputResolver outputResolver) throws IOException;
+
+    /**
+     * Returns the name of the XML Type bound to the
+     * specified Java type.
+     *
+     * @param tr
+     *      must not be null. This must be one of the {@link TypeReference}s specified
+     *      in the {@link JAXBRIContext#newInstance} method.
+     *
+     * @throws IllegalArgumentException
+     *      if the parameter is null or not a part of the {@link TypeReference}s specified
+     *      in the {@link JAXBRIContext#newInstance} method.
+     *
+     * @return null
+     *      if the referenced type is an anonymous and therefore doesn't have a name.
+     */
+    public abstract QName getTypeName(@NotNull TypeReference tr);
+
+    /**
+     * Gets the build information of the JAXB runtime.
+     *
+     * @return
+     *      may be null, if the runtime is loaded by a class loader that doesn't support
+     *      the access to the manifest informatino.
+     */
+    public abstract @NotNull String getBuildId();
+
+    /**
+     * Computes a Java identifier from a local name.
+     *
+     * <p>
+     * This method faithfully implements the name mangling rule as specified in the JAXB spec.
+     *
+     * <p>
+     * In JAXB, a collision with a Java reserved word (such as "return") never happens.
+     * Accordingly, this method may return an identifier that collides with reserved words.
+     *
+     * <p>
+     * Use {@link JJavaName#isJavaIdentifier(String)} to check for such collision.
+     *
+     * @return
+     *      Typically, this method returns "nameLikeThis".
+     *
+     * @see JJavaName#isJavaIdentifier(String)
+     */
+    public static @NotNull String mangleNameToVariableName(@NotNull String localName) {
+        return NameConverter.standard.toVariableName(localName);
+    }
+
+    /**
+     * Computes a Java class name from a local name.
+     *
+     * <p>
+     * This method faithfully implements the name mangling rule as specified in the JAXB spec.
+     *
+     * @return
+     *      Typically, this method returns "NameLikeThis".
+     */
+    public static @NotNull String mangleNameToClassName(@NotNull String localName) {
+        return NameConverter.standard.toClassName(localName);
+    }
+
+    /**
+     * Gets the parameterization of the given base type.
+     *
+     * <p>
+     * For example, given the following
+     * <pre><xmp>
+     * interface Foo<T> extends List<List<T>> {}
+     * interface Bar extends Foo<String> {}
+     * </xmp></pre>
+     * This method works like this:
+     * <pre><xmp>
+     * getBaseClass( Bar, List ) = List<List<String>
+     * getBaseClass( Bar, Foo  ) = Foo<String>
+     * getBaseClass( Foo<? extends Number>, Collection ) = Collection<List<? extends Number>>
+     * getBaseClass( ArrayList<? extends BigInteger>, List ) = List<? extends BigInteger>
+     * </xmp></pre>
+     *
+     * @param type
+     *      The type that derives from {@code baseType}
+     * @param baseType
+     *      The class whose parameterization we are interested in.
+     * @return
+     *      The use of {@code baseType} in {@code type}.
+     *      or null if the type is not assignable to the base type.
+     * @since 2.0 FCS
+     */
+    public static @Nullable Type getBaseType(@NotNull Type type, @NotNull Class baseType) {
+        return Navigator.REFLECTION.getBaseClass(type,baseType);
+    }
+
+
+    /**
+     * The property that you can specify to {@link JAXBContext#newInstance}
+     * to reassign the default namespace URI to something else at the runtime.
+     *
+     * <p>
+     * The value of the property is {@link String}, and it is used as the namespace URI
+     * that succeeds the default namespace URI.
+     *
+     * @since 2.0 EA1
+     */
+    public static final String DEFAULT_NAMESPACE_REMAP = "com.sun.xml.internal.bind.defaultNamespaceRemap";
+
+    /**
+     * The property that you can specify to {@link JAXBContext#newInstance}
+     * to put additional JAXB type references into the {@link JAXBContext}.
+     *
+     * <p>
+     * The value of the property is {@link Collection}&lt;{@link TypeReference}>.
+     * Those {@link TypeReference}s can then be used to create {@link Bridge}s.
+     *
+     * <p>
+     * This mechanism allows additional element declarations that were not a part of
+     * the schema into the created {@link JAXBContext}.
+     *
+     * @since 2.0 EA1
+     */
+    public static final String TYPE_REFERENCES = "com.sun.xml.internal.bind.typeReferences";
+
+    /**
+     * The property that you can specify to {@link JAXBContext#newInstance}
+     * and {@link Marshaller#setProperty(String, Object)}
+     * to enable the c14n marshalling support in the {@link JAXBContext}.
+     *
+     * @see C14nSupport_ArchitectureDocument
+     * @since 2.0 EA2
+     */
+    public static final String CANONICALIZATION_SUPPORT = "com.sun.xml.internal.bind.c14n";
+
+    /**
+     * Marshaller/Unmarshaller property to enable XOP processing.
+     *
+     * @since 2.0 EA2
+     */
+    public static final String ENABLE_XOP = "com.sun.xml.internal.bind.XOP";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/RawAccessor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/RawAccessor.java
new file mode 100644
index 0000000..ad6ae5f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/RawAccessor.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api;
+
+
+
+/**
+ * Accesses a particular property of a bean.
+ *
+ * <p>
+ * This interface allows JAX-RPC to access an element property of a JAXB bean.
+ *
+ * <p>
+ * <b>Subject to change without notice</b>.
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @since 2.0 EA1
+ */
+public abstract class RawAccessor<B,V> {
+
+    /**
+     * Gets the value of the property of the given bean object.
+     *
+     * @param bean
+     *      must not be null.
+     * @throws AccessorException
+     *      if failed to set a value. For example, the getter method
+     *      may throw an exception.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract V get(B bean) throws AccessorException;
+
+    /**
+     * Sets the value of the property of the given bean object.
+     *
+     * @param bean
+     *      must not be null.
+     * @param value
+     *      the value to be set. Setting value to null means resetting
+     *      to the VM default value (even for primitive properties.)
+     * @throws AccessorException
+     *      if failed to set a value. For example, the setter method
+     *      may throw an exception.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract void set(B bean,V value) throws AccessorException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/TypeReference.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/TypeReference.java
new file mode 100644
index 0000000..480694c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/TypeReference.java
@@ -0,0 +1,105 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api;
+
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Type;
+import java.util.Collection;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+
+/**
+ * A reference to a JAXB-bound type.
+ *
+ * <p>
+ * <b>Subject to change without notice</b>.
+ *
+ * @since 2.0 EA1
+ * @author Kohsuke Kawaguchi
+ */
+public final class TypeReference {
+
+    /**
+     * The associated XML element name that the JAX-RPC uses with this type reference.
+     *
+     * Always non-null. Strings are interned.
+     */
+    public final QName tagName;
+
+    /**
+     * The Java type that's being referenced.
+     *
+     * Always non-null.
+     */
+    public final Type type;
+
+    /**
+     * The annotations associated with the reference of this type.
+     *
+     * Always non-null.
+     */
+    public final Annotation[] annotations;
+
+    public TypeReference(QName tagName, Type type, Annotation... annotations) {
+        if(tagName==null || type==null || annotations==null)
+            throw new IllegalArgumentException();
+
+        this.tagName = new QName(tagName.getNamespaceURI().intern(), tagName.getLocalPart().intern(), tagName.getPrefix());
+        this.type = type;
+        this.annotations = annotations;
+    }
+
+    /**
+     * Finds the specified annotation from the array and returns it.
+     * Null if not found.
+     */
+    public <A extends Annotation> A get( Class<A> annotationType ) {
+        for (Annotation a : annotations) {
+            if(a.annotationType()==annotationType)
+                return annotationType.cast(a);
+        }
+        return null;
+    }
+
+    /**
+     * Creates a {@link TypeReference} for the item type,
+     * if this {@link TypeReference} represents a collection type.
+     * Otherwise returns an identical type.
+     */
+    public TypeReference toItemType() {
+        // if we are to reinstitute this check, check JAXB annotations only
+        // assert annotations.length==0;   // not designed to work with adapters.
+
+        Type base = Navigator.REFLECTION.getBaseClass(type, Collection.class);
+        if(base==null)
+            return this;    // not a collection
+
+        return new TypeReference(tagName,
+            Navigator.REFLECTION.getTypeArgument(base,0));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/impl/NameConverter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/impl/NameConverter.java
new file mode 100644
index 0000000..3cce7e1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/impl/NameConverter.java
@@ -0,0 +1,271 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api.impl;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.StringTokenizer;
+
+/**
+ * Converts aribitrary strings into Java identifiers.
+ *
+ * @author
+ *    <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public interface NameConverter
+{
+    /**
+     * converts a string into an identifier suitable for classes.
+     *
+     * In general, this operation should generate "NamesLikeThis".
+     */
+    String toClassName( String token );
+
+    /**
+     * converts a string into an identifier suitable for interfaces.
+     *
+     * In general, this operation should generate "NamesLikeThis".
+     * But for example, it can prepend every interface with 'I'.
+     */
+    String toInterfaceName( String token );
+
+    /**
+     * converts a string into an identifier suitable for properties.
+     *
+     * In general, this operation should generate "NamesLikeThis",
+     * which will be used with known prefixes like "get" or "set".
+     */
+    String toPropertyName( String token );
+
+    /**
+     * converts a string into an identifier suitable for constants.
+     *
+     * In the standard Java naming convention, this operation should
+     * generate "NAMES_LIKE_THIS".
+     */
+    String toConstantName( String token );
+
+    /**
+     * Converts a string into an identifier suitable for variables.
+     *
+     * In general it should generate "namesLikeThis".
+     */
+    String toVariableName( String token );
+
+    /**
+     * Converts a namespace URI into a package name.
+     * This method should expect strings like
+     * "http://foo.bar.zot/org", "urn:abc:def:ghi" "", or even "###"
+     * (basically anything) and expected to return a package name,
+     * liks "org.acme.foo".
+     *
+     */
+    String toPackageName( String namespaceUri );
+
+    /**
+     * The name converter implemented by Code Model.
+     *
+     * This is the standard name conversion for JAXB.
+     */
+    public static final NameConverter standard = new Standard();
+
+    static class Standard extends NameUtil implements NameConverter {
+        public String toClassName(String s) {
+            return toMixedCaseName(toWordList(s), true);
+        }
+        public String toVariableName(String s) {
+            return toMixedCaseName(toWordList(s), false);
+        }
+        public String toInterfaceName( String token ) {
+            return toClassName(token);
+        }
+        public String toPropertyName(String s) {
+            String prop = toClassName(s);
+            // property name "Class" with collide with Object.getClass,
+            // so escape this.
+            if(prop.equals("Class"))
+                prop = "Clazz";
+            return prop;
+        }
+        public String toConstantName( String token ) {
+            return super.toConstantName(token);
+        }
+        /**
+         * Computes a Java package name from a namespace URI,
+         * as specified in the spec.
+         *
+         * @return
+         *      null if it fails to derive a package name.
+         */
+        public String toPackageName( String nsUri ) {
+            // remove scheme and :, if present
+            // spec only requires us to remove 'http' and 'urn'...
+            int idx = nsUri.indexOf(':');
+            String scheme = "";
+            if(idx>=0) {
+                scheme = nsUri.substring(0,idx);
+                if( scheme.equalsIgnoreCase("http") || scheme.equalsIgnoreCase("urn") )
+                    nsUri = nsUri.substring(idx+1);
+            }
+
+            // tokenize string
+            ArrayList<String> tokens = tokenize( nsUri, "/: " );
+            if( tokens.size() == 0 ) {
+                return null;
+            }
+
+            // remove trailing file type, if necessary
+            if( tokens.size() > 1 ) {
+                // for uri's like "www.foo.com" and "foo.com", there is no trailing
+                // file, so there's no need to look at the last '.' and substring
+                // otherwise, we loose the "com" (which would be wrong)
+                String lastToken = tokens.get( tokens.size()-1 );
+                idx = lastToken.lastIndexOf( '.' );
+                if( idx > 0 ) {
+                    lastToken = lastToken.substring( 0, idx );
+                    tokens.set( tokens.size()-1, lastToken );
+                }
+            }
+
+            // tokenize domain name and reverse.  Also remove :port if it exists
+            String domain = tokens.get( 0 );
+            idx = domain.indexOf(':');
+            if( idx >= 0) domain = domain.substring(0, idx);
+            ArrayList<String> r = reverse( tokenize( domain, scheme.equals("urn")?".-":"." ) );
+            if( r.get( r.size()-1 ).equalsIgnoreCase( "www" ) ) {
+                // remove leading www
+                r.remove( r.size()-1 );
+            }
+
+            // replace the domain name with tokenized items
+            tokens.addAll( 1, r );
+            tokens.remove( 0 );
+
+            // iterate through the tokens and apply xml->java name algorithm
+            for( int i = 0; i < tokens.size(); i++ ) {
+
+                // get the token and remove illegal chars
+                String token = tokens.get( i );
+                token = removeIllegalIdentifierChars( token );
+
+                // this will check for reserved keywords
+                if( !NameUtil.isJavaIdentifier( token ) ) {
+                    token = '_' + token;
+                }
+
+                tokens.set( i, token.toLowerCase() );
+            }
+
+            // concat all the pieces and return it
+            return combine( tokens, '.' );
+        }
+
+
+        private static String removeIllegalIdentifierChars(String token) {
+            StringBuffer newToken = new StringBuffer();
+            for( int i = 0; i < token.length(); i++ ) {
+                char c = token.charAt( i );
+
+                if( i ==0 && !Character.isJavaIdentifierStart( c ) ) {
+                    // prefix an '_' if the first char is illegal
+                    newToken.append('_').append(c);
+                } else if( !Character.isJavaIdentifierPart( c ) ) {
+                    // replace the char with an '_' if it is illegal
+                    newToken.append( '_' );
+                } else {
+                    // add the legal char
+                    newToken.append( c );
+                }
+            }
+            return newToken.toString();
+        }
+
+
+        private static ArrayList<String> tokenize( String str, String sep ) {
+            StringTokenizer tokens = new StringTokenizer(str,sep);
+            ArrayList<String> r = new ArrayList<String>();
+
+            while(tokens.hasMoreTokens())
+                r.add( tokens.nextToken() );
+
+            return r;
+        }
+
+        private static <T> ArrayList<T> reverse( List<T> a ) {
+            ArrayList<T> r = new ArrayList<T>();
+
+            for( int i=a.size()-1; i>=0; i-- )
+                r.add( a.get(i) );
+
+            return r;
+        }
+
+        private static String combine( List r, char sep ) {
+            StringBuilder buf = new StringBuilder(r.get(0).toString());
+
+            for( int i=1; i<r.size(); i++ ) {
+                buf.append(sep);
+                buf.append(r.get(i));
+            }
+
+            return buf.toString();
+        }
+    }
+
+    /**
+     * JAX-PRC compatible name converter implementation.
+     *
+     * The only difference is that we treat '_' as a valid character
+     * and not as a word separator.
+     */
+    public static final NameConverter jaxrpcCompatible = new Standard() {
+        protected boolean isPunct(char c) {
+            return (c == '.' || c == '-' || c == ';' /*|| c == '_'*/ || c == '\u00b7'
+                    || c == '\u0387' || c == '\u06dd' || c == '\u06de');
+        }
+        protected boolean isLetter(char c) {
+            return super.isLetter(c) || c=='_';
+        }
+
+        protected int classify(char c0) {
+            if(c0=='_') return NameUtil.OTHER_LETTER;
+            return super.classify(c0);
+        }
+    };
+
+    /**
+     * Smarter converter used for RELAX NG support.
+     */
+    public static final NameConverter smart = new Standard() {
+        public String toConstantName( String token ) {
+            String name = super.toConstantName(token);
+            if( NameUtil.isJavaIdentifier(name) )
+                return name;
+            else
+                return '_'+name;
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/impl/NameUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/impl/NameUtil.java
new file mode 100644
index 0000000..619204a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/impl/NameUtil.java
@@ -0,0 +1,415 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.api.impl;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.List;
+
+/**
+ * Methods that convert strings into various formats.
+ *
+ * <p>
+ * What JAX-RPC name binding tells us is that even such basic method
+ * like "isLetter" can be different depending on the situation.
+ *
+ * For this reason, a whole lot of methods are made non-static,
+ * even though they look like they should be static.
+ */
+class NameUtil {
+    protected boolean isPunct(char c) {
+        return c == '-' || c == '.' || c == ':' || c == '_' || c == '\u00b7' || c == '\u0387' || c == '\u06dd' || c == '\u06de';
+    }
+
+    protected static boolean isDigit(char c) {
+        return c >= '0' && c <= '9' || Character.isDigit(c);
+    }
+
+    protected static boolean isUpper(char c) {
+        return c >= 'A' && c <= 'Z' || Character.isUpperCase(c);
+    }
+
+    protected static boolean isLower(char c) {
+        return c >= 'a' && c <= 'z' || Character.isLowerCase(c);
+    }
+
+    protected boolean isLetter(char c) {
+        return c >= 'A' && c <= 'Z' || c >= 'a' && c <= 'z' || Character.isLetter(c);
+    }
+
+    /**
+     * Capitalizes the first character of the specified string,
+     * and de-capitalize the rest of characters.
+     */
+    public String capitalize(String s) {
+        if (!isLower(s.charAt(0)))
+            return s;
+        StringBuilder sb = new StringBuilder(s.length());
+        sb.append(Character.toUpperCase(s.charAt(0)));
+        sb.append(s.substring(1).toLowerCase());
+        return sb.toString();
+    }
+
+    // Precondition: s[start] is not punctuation
+    private int nextBreak(String s, int start) {
+        int n = s.length();
+
+        char c1 = s.charAt(start);
+        int t1 = classify(c1);
+
+        for (int i=start+1; i<n; i++) {
+            // shift (c1,t1) into (c0,t0)
+            // char c0 = c1;  --- conceptually, but c0 won't be used
+            int t0 = t1;
+
+            c1 = s.charAt(i);
+            t1 = classify(c1);
+
+            switch(actionTable[t0*5+t1]) {
+            case ACTION_CHECK_PUNCT:
+                if(isPunct(c1)) return i;
+                break;
+            case ACTION_CHECK_C2:
+                if (i < n-1) {
+                    char c2 = s.charAt(i+1);
+                    if (isLower(c2))
+                        return i;
+                }
+                break;
+            case ACTION_BREAK:
+                return i;
+            }
+        }
+        return -1;
+    }
+
+    // the 5-category classification that we use in this code
+    // to find work breaks
+    static protected final int UPPER_LETTER = 0;
+    static protected final int LOWER_LETTER = 1;
+    static protected final int OTHER_LETTER = 2;
+    static protected final int DIGIT = 3;
+    static protected final int OTHER = 4;
+
+    /**
+     * Look up table for actions.
+     * type0*5+type1 would yield the action to be taken.
+     */
+    private static final byte[] actionTable = new byte[5*5];
+
+    // action constants. see nextBreak for the meaning
+    static private final byte ACTION_CHECK_PUNCT = 0;
+    static private final byte ACTION_CHECK_C2 = 1;
+    static private final byte ACTION_BREAK = 2;
+    static private final byte ACTION_NOBREAK = 3;
+
+    /**
+     * Decide the action to be taken given
+     * the classification of the preceding character 't0' and
+     * the classification of the next character 't1'.
+     */
+    private static byte decideAction( int t0, int t1 ) {
+        if(t0==OTHER && t1==OTHER)  return ACTION_CHECK_PUNCT;
+        if(!xor(t0==DIGIT,t1==DIGIT))  return ACTION_BREAK;
+        if(t0==LOWER_LETTER && t1!=LOWER_LETTER)    return ACTION_BREAK;
+        if(!xor(t0<=OTHER_LETTER,t1<=OTHER_LETTER)) return ACTION_BREAK;
+        if(!xor(t0==OTHER_LETTER,t1==OTHER_LETTER)) return ACTION_BREAK;
+
+        if(t0==UPPER_LETTER && t1==UPPER_LETTER)    return ACTION_CHECK_C2;
+
+        return ACTION_NOBREAK;
+    }
+
+    private static boolean xor(boolean x,boolean y) {
+        return (x&&y) || (!x&&!y);
+    }
+
+    static {
+        // initialize the action table
+        for( int t0=0; t0<5; t0++ )
+            for( int t1=0; t1<5; t1++ )
+                actionTable[t0*5+t1] = decideAction(t0,t1);
+    }
+
+    /**
+     * Classify a character into 5 categories that determine the word break.
+     */
+    protected int classify(char c0) {
+        switch(Character.getType(c0)) {
+        case Character.UPPERCASE_LETTER:        return UPPER_LETTER;
+        case Character.LOWERCASE_LETTER:        return LOWER_LETTER;
+        case Character.TITLECASE_LETTER:
+        case Character.MODIFIER_LETTER:
+        case Character.OTHER_LETTER:            return OTHER_LETTER;
+        case Character.DECIMAL_DIGIT_NUMBER:    return DIGIT;
+        default:                                return OTHER;
+        }
+    }
+
+
+    /**
+     * Tokenizes a string into words and capitalizes the first
+     * character of each word.
+     *
+     * <p>
+     * This method uses a change in character type as a splitter
+     * of two words. For example, "abc100ghi" will be splitted into
+     * {"Abc", "100","Ghi"}.
+     */
+    public List<String> toWordList(String s) {
+        ArrayList<String> ss = new ArrayList<String>();
+        int n = s.length();
+        for (int i = 0; i < n;) {
+
+            // Skip punctuation
+            while (i < n) {
+                if (!isPunct(s.charAt(i)))
+                    break;
+                i++;
+            }
+            if (i >= n) break;
+
+            // Find next break and collect word
+            int b = nextBreak(s, i);
+            String w = (b == -1) ? s.substring(i) : s.substring(i, b);
+            ss.add(escape(capitalize(w)));
+            if (b == -1) break;
+            i = b;
+        }
+
+//      we can't guarantee a valid Java identifier anyway,
+//      so there's not much point in rejecting things in this way.
+//        if (ss.size() == 0)
+//            throw new IllegalArgumentException("Zero-length identifier");
+        return ss;
+    }
+
+    protected String toMixedCaseName(List<String> ss, boolean startUpper) {
+        StringBuilder sb = new StringBuilder();
+        if(!ss.isEmpty()) {
+            sb.append(startUpper ? ss.get(0) : ss.get(0).toLowerCase());
+            for (int i = 1; i < ss.size(); i++)
+                sb.append(ss.get(i));
+        }
+        return sb.toString();
+    }
+
+    protected String toMixedCaseVariableName(String[] ss,
+                                                  boolean startUpper,
+                                                  boolean cdrUpper) {
+        if (cdrUpper)
+            for (int i = 1; i < ss.length; i++)
+                ss[i] = capitalize(ss[i]);
+        StringBuilder sb = new StringBuilder();
+        if( ss.length>0 ) {
+            sb.append(startUpper ? ss[0] : ss[0].toLowerCase());
+            for (int i = 1; i < ss.length; i++)
+                sb.append(ss[i]);
+        }
+        return sb.toString();
+    }
+
+
+    /**
+     * Formats a string into "THIS_KIND_OF_FORMAT_ABC_DEF".
+     *
+     * @return
+     *      Always return a string but there's no guarantee that
+     *      the generated code is a valid Java identifier.
+     */
+    public String toConstantName(String s) {
+        return toConstantName(toWordList(s));
+    }
+
+    /**
+     * Formats a string into "THIS_KIND_OF_FORMAT_ABC_DEF".
+     *
+     * @return
+     *      Always return a string but there's no guarantee that
+     *      the generated code is a valid Java identifier.
+     */
+    public String toConstantName(List<String> ss) {
+        StringBuilder sb = new StringBuilder();
+        if( !ss.isEmpty() ) {
+            sb.append(ss.get(0).toUpperCase());
+            for (int i = 1; i < ss.size(); i++) {
+                sb.append('_');
+                sb.append(ss.get(i).toUpperCase());
+            }
+        }
+        return sb.toString();
+    }
+
+
+
+    /**
+     * Escapes characters is the given string so that they can be
+     * printed by only using US-ASCII characters.
+     *
+     * The escaped characters will be appended to the given
+     * StringBuffer.
+     *
+     * @param sb
+     *      StringBuffer that receives escaped string.
+     * @param s
+     *      String to be escaped. <code>s.substring(start)</code>
+     *      will be escaped and copied to the string buffer.
+     */
+    public static void escape(StringBuilder sb, String s, int start) {
+        int n = s.length();
+        for (int i = start; i < n; i++) {
+            char c = s.charAt(i);
+            if (Character.isJavaIdentifierPart(c))
+                sb.append(c);
+            else {
+                sb.append('_');
+                if (c <= '\u000f') sb.append("000");
+                else if (c <= '\u00ff') sb.append("00");
+                else if (c <= '\u0fff') sb.append('0');
+                sb.append(Integer.toString(c, 16));
+            }
+        }
+    }
+
+    /**
+     * Escapes characters that are unusable as Java identifiers
+     * by replacing unsafe characters with safe characters.
+     */
+    private static String escape(String s) {
+        int n = s.length();
+        for (int i = 0; i < n; i++)
+            if (!Character.isJavaIdentifierPart(s.charAt(i))) {
+                StringBuilder sb = new StringBuilder(s.substring(0, i));
+                escape(sb, s, i);
+                return sb.toString();
+            }
+        return s;
+    }
+
+
+    /**
+     * Checks if a given string is usable as a Java identifier.
+     */
+    public static boolean isJavaIdentifier(String s) {
+        if(s.length()==0)   return false;
+        if( reservedKeywords.contains(s) )  return false;
+
+        if(!Character.isJavaIdentifierStart(s.charAt(0)))   return false;
+
+        for (int i = 1; i < s.length(); i++)
+            if (!Character.isJavaIdentifierPart(s.charAt(i)))
+                return false;
+
+        return true;
+    }
+
+    /**
+     * Checks if the given string is a valid Java package name.
+     */
+    public static boolean isJavaPackageName(String s) {
+        while(s.length()!=0) {
+            int idx = s.indexOf('.');
+            if(idx==-1) idx=s.length();
+            if( !isJavaIdentifier(s.substring(0,idx)) )
+                return false;
+
+            s = s.substring(idx);
+            if(s.length()!=0)    s = s.substring(1);    // remove '.'
+        }
+        return true;
+    }
+
+
+    /** All reserved keywords of Java. */
+    private static HashSet<String> reservedKeywords = new HashSet<String>();
+
+    static {
+        // see http://java.sun.com/docs/books/tutorial/java/nutsandbolts/_keywords.html
+        String[] words = new String[]{
+            "abstract",
+            "boolean",
+            "break",
+            "byte",
+            "case",
+            "catch",
+            "char",
+            "class",
+            "const",
+            "continue",
+            "default",
+            "do",
+            "double",
+            "else",
+            "extends",
+            "final",
+            "finally",
+            "float",
+            "for",
+            "goto",
+            "if",
+            "implements",
+            "import",
+            "instanceof",
+            "int",
+            "interface",
+            "long",
+            "native",
+            "new",
+            "package",
+            "private",
+            "protected",
+            "public",
+            "return",
+            "short",
+            "static",
+            "strictfp",
+            "super",
+            "switch",
+            "synchronized",
+            "this",
+            "throw",
+            "throws",
+            "transient",
+            "try",
+            "void",
+            "volatile",
+            "while",
+
+            // technically these are not reserved words but they cannot be used as identifiers.
+            "true",
+            "false",
+            "null",
+
+            // and I believe assert is also a new keyword
+            "assert",
+
+            // and 5.0 keywords
+            "enum"
+            };
+        for (String word : words)
+            reservedKeywords.add(word);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/api/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/package-info.java
new file mode 100644
index 0000000..3992e0e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/api/package-info.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * <h1>Runtime API for the JAX-WS RI</h1>.
+ *
+ * This API is designed for the use by the JAX-WS RI runtime. The API is is subject to
+ * change without notice.
+ *
+ * <p>
+ * In an container environment, such as in J2SE/J2EE, if a new version with
+ * a modified runtime API is loaded into a child class loader, it will still be bound
+ * against the old runtime API in the base class loader.
+ *
+ * <p>
+ * So the compatibility of this API has to be managed carefully.
+ */
+package com.sun.xml.internal.bind.api;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/CharacterEscapeHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/CharacterEscapeHandler.java
new file mode 100644
index 0000000..bab4534
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/CharacterEscapeHandler.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.io.IOException;
+import java.io.Writer;
+
+/**
+ * Performs character escaping and write the result
+ * to the output.
+ *
+ * @since 1.0.1
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface CharacterEscapeHandler {
+
+    /**
+     * @param ch The array of characters.
+     * @param start The starting position.
+     * @param length The number of characters to use.
+     * @param isAttVal true if this is an attribute value literal.
+     */
+    void escape( char[] ch, int start, int length, boolean isAttVal, Writer out ) throws IOException;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/DataWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/DataWriter.java
new file mode 100644
index 0000000..a74cde4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/DataWriter.java
@@ -0,0 +1,376 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+//@@3RD PARTY CODE@@
+
+// DataWriter.java - XML writer for data-oriented files.
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.io.IOException;
+import java.io.Writer;
+import java.util.Stack;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+
+/**
+ * Write data- or field-oriented XML.
+ *
+ * <p>This filter pretty-prints field-oriented XML without mixed content.
+ * all added indentation and newlines will be passed on down
+ * the filter chain (if any).</p>
+ *
+ * <p>In general, all whitespace in an XML document is potentially
+ * significant, so a general-purpose XML writing tool like the
+ * {@link XMLWriter} class cannot
+ * add newlines or indentation.</p>
+ *
+ * <p>There is, however, a large class of XML documents where information
+ * is strictly fielded: each element contains either character data
+ * or other elements, but not both.  For this special case, it is possible
+ * for a writing tool to provide automatic indentation and newlines
+ * without requiring extra work from the user.  Note that this class
+ * will likely not yield appropriate results for document-oriented
+ * XML like XHTML pages, which mix character data and elements together.</p>
+ *
+ * <p>This writer will automatically place each start tag on a new line,
+ * optionally indented if an indent step is provided (by default, there
+ * is no indentation).  If an element contains other elements, the end
+ * tag will also appear on a new line with leading indentation.  Consider,
+ * for example, the following code:</p>
+ *
+ * <pre>
+ * DataWriter w = new DataWriter();
+ *
+ * w.setIndentStep(2);
+ * w.startDocument();
+ * w.startElement("Person");
+ * w.dataElement("name", "Jane Smith");
+ * w.dataElement("date-of-birth", "1965-05-23");
+ * w.dataElement("citizenship", "US");
+ * w.endElement("Person");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>This code will produce the following document:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;Person>
+ *   &lt;name>Jane Smith&lt;/name>
+ *   &lt;date-of-birth>1965-05-23&lt;/date-of-birth>
+ *   &lt;citizenship>US&lt;/citizenship>
+ * &lt;/Person>
+ * </pre>
+ *
+ * <p>This class inherits from {@link XMLWriter},
+ * and provides all of the same support for Namespaces.</p>
+ *
+ * @since 1.0
+ * @author David Megginson, david@megginson.com
+ * @see XMLWriter
+ */
+public class DataWriter extends XMLWriter
+{
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constructors.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Create a new data writer for the specified output.
+     *
+     * @param writer The character stream where the XML document
+     *        will be written.
+     * @param encoding
+     *      If non-null string is specified, it is written as a part
+     *      of the XML declaration.
+     */
+    public DataWriter ( Writer writer, String encoding, CharacterEscapeHandler _escapeHandler )
+    {
+        super(writer,encoding,_escapeHandler);
+    }
+
+
+    public DataWriter (Writer writer, String encoding ) {
+        this( writer, encoding, DumbEscapeHandler.theInstance );
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Accessors and setters.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Return the current indent step.
+     *
+     * <p>Return the current indent step: each start tag will be
+     * indented by this number of spaces times the number of
+     * ancestors that the element has.</p>
+     *
+     * @return The number of spaces in each indentation step,
+     *         or 0 or less for no indentation.
+     * @see #setIndentStep(int)
+     *
+     * @deprecated
+     *      Only return the length of the indent string.
+     */
+    public int getIndentStep ()
+    {
+        return indentStep.length();
+    }
+
+
+    /**
+     * Set the current indent step.
+     *
+     * @param indentStep The new indent step (0 or less for no
+     *        indentation).
+     * @see #getIndentStep()
+     *
+     * @deprecated
+     *      Should use the version that takes string.
+     */
+    public void setIndentStep (int indentStep)
+    {
+        StringBuilder buf = new StringBuilder();
+        for( ; indentStep>0; indentStep-- )
+            buf.append(' ');
+        setIndentStep(buf.toString());
+    }
+
+    public void setIndentStep(String s) {
+        this.indentStep = s;
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Override methods from XMLWriter.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Reset the writer so that it can be reused.
+     *
+     * <p>This method is especially useful if the writer failed
+     * with an exception the last time through.</p>
+     *
+     * @see XMLWriter#reset()
+     */
+    public void reset ()
+    {
+        depth = 0;
+        state = SEEN_NOTHING;
+        stateStack = new Stack<Object>();
+        super.reset();
+    }
+
+    protected void writeXmlDecl(String decl) throws IOException {
+        super.writeXmlDecl(decl);
+        write('\n');
+    }
+
+
+    /**
+     * Write a start tag.
+     *
+     * <p>Each tag will begin on a new line, and will be
+     * indented by the current indent step times the number
+     * of ancestors that the element has.</p>
+     *
+     * <p>The newline and indentation will be passed on down
+     * the filter chain through regular characters events.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @param qName The element's qualified (prefixed) name.
+     * @param atts The element's attribute list.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the start tag, or if a filter further
+     *            down the chain raises an exception.
+     * @see XMLWriter#startElement(String, String, String, Attributes)
+     */
+    public void startElement (String uri, String localName,
+                              String qName, Attributes atts)
+        throws SAXException
+    {
+        stateStack.push(SEEN_ELEMENT);
+        state = SEEN_NOTHING;
+        if (depth > 0) {
+            super.characters("\n");
+        }
+        doIndent();
+        super.startElement(uri, localName, qName, atts);
+        depth++;
+    }
+
+
+    /**
+     * Write an end tag.
+     *
+     * <p>If the element has contained other elements, the tag
+     * will appear indented on a new line; otherwise, it will
+     * appear immediately following whatever came before.</p>
+     *
+     * <p>The newline and indentation will be passed on down
+     * the filter chain through regular characters events.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @param qName The element's qualified (prefixed) name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the end tag, or if a filter further
+     *            down the chain raises an exception.
+     * @see XMLWriter#endElement(String, String, String)
+     */
+    public void endElement (String uri, String localName, String qName)
+        throws SAXException
+    {
+        depth--;
+        if (state == SEEN_ELEMENT) {
+            super.characters("\n");
+            doIndent();
+        }
+        super.endElement(uri, localName, qName);
+        state = stateStack.pop();
+    }
+
+    public void endDocument() throws SAXException {
+        try {
+            write('\n');
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+        super.endDocument();
+    }
+
+//    /**
+//     * Write a empty element tag.
+//     *
+//     * <p>Each tag will appear on a new line, and will be
+//     * indented by the current indent step times the number
+//     * of ancestors that the element has.</p>
+//     *
+//     * <p>The newline and indentation will be passed on down
+//     * the filter chain through regular characters events.</p>
+//     *
+//     * @param uri The element's Namespace URI.
+//     * @param localName The element's local name.
+//     * @param qName The element's qualified (prefixed) name.
+//     * @param atts The element's attribute list.
+//     * @exception org.xml.sax.SAXException If there is an error
+//     *            writing the empty tag, or if a filter further
+//     *            down the chain raises an exception.
+//     * @see XMLWriter#emptyElement(String, String, String, Attributes)
+//     */
+//    public void emptyElement (String uri, String localName,
+//                              String qName, Attributes atts)
+//        throws SAXException
+//    {
+//        state = SEEN_ELEMENT;
+//        if (depth > 0) {
+//            super.characters("\n");
+//        }
+//        doIndent();
+//        super.emptyElement(uri, localName, qName, atts);
+//    }
+
+
+    /**
+     * Write a sequence of characters.
+     *
+     * @param ch The characters to write.
+     * @param start The starting position in the array.
+     * @param length The number of characters to use.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the characters, or if a filter further
+     *            down the chain raises an exception.
+     * @see XMLWriter#characters(char[], int, int)
+     */
+    public void characters (char ch[], int start, int length)
+        throws SAXException
+    {
+        state = SEEN_DATA;
+        super.characters(ch, start, length);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Print indentation for the current level.
+     *
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the indentation characters, or if a filter
+     *            further down the chain raises an exception.
+     */
+    private void doIndent ()
+        throws SAXException
+    {
+        if (depth > 0) {
+            char[] ch = indentStep.toCharArray();
+            for( int i=0; i<depth; i++ )
+                characters(ch, 0, ch.length);
+        }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constants.
+    ////////////////////////////////////////////////////////////////////
+
+    private final static Object SEEN_NOTHING = new Object();
+    private final static Object SEEN_ELEMENT = new Object();
+    private final static Object SEEN_DATA = new Object();
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    private Object state = SEEN_NOTHING;
+    private Stack<Object> stateStack = new Stack<Object>();
+
+    private String indentStep = "";
+    private int depth = 0;
+
+}
+
+// end of DataWriter.java
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/DumbEscapeHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/DumbEscapeHandler.java
new file mode 100644
index 0000000..a696ff3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/DumbEscapeHandler.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.io.IOException;
+import java.io.Writer;
+
+/**
+ * Escape everything above the US-ASCII code range.
+ * A fallback position.
+ *
+ * Works with any JDK, any encoding.
+ *
+ * @since 1.0.1
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class DumbEscapeHandler implements CharacterEscapeHandler {
+
+    private DumbEscapeHandler() {}  // no instanciation please
+
+    public static final CharacterEscapeHandler theInstance = new DumbEscapeHandler();
+
+    public void escape(char[] ch, int start, int length, boolean isAttVal, Writer out) throws IOException {
+        int limit = start+length;
+        for (int i = start; i < limit; i++) {
+            switch (ch[i]) {
+            case '&':
+                out.write("&amp;");
+                break;
+            case '<':
+                out.write("&lt;");
+                break;
+            case '>':
+                out.write("&gt;");
+                break;
+            case '\"':
+                if (isAttVal) {
+                    out.write("&quot;");
+                } else {
+                    out.write('\"');
+                }
+                break;
+            default:
+                if (ch[i] > '\u007f') {
+                    out.write("&#");
+                    out.write(Integer.toString(ch[i]));
+                    out.write(';');
+                } else {
+                    out.write(ch[i]);
+                }
+            }
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/Messages.java
new file mode 100644
index 0000000..21dfe8b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/Messages.java
@@ -0,0 +1,109 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ *
+ * @since JAXB1.0
+ */
+public class Messages
+{
+    public static String format( String property ) {
+        return format( property, null );
+    }
+
+    public static String format( String property, Object arg1 ) {
+        return format( property, new Object[]{arg1} );
+    }
+
+    public static String format( String property, Object arg1, Object arg2 ) {
+        return format( property, new Object[]{arg1,arg2} );
+    }
+
+    public static String format( String property, Object arg1, Object arg2, Object arg3 ) {
+        return format( property, new Object[]{arg1,arg2,arg3} );
+    }
+
+    // add more if necessary.
+
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object[] args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getName()).getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+//
+//
+// Message resources
+//
+//
+    public static final String NOT_MARSHALLABLE = // 0 args
+        "MarshallerImpl.NotMarshallable";
+
+    public static final String UNSUPPORTED_RESULT = // 0 args
+        "MarshallerImpl.UnsupportedResult";
+
+    public static final String UNSUPPORTED_ENCODING = // 1 arg
+        "MarshallerImpl.UnsupportedEncoding";
+
+    public static final String NULL_WRITER = // 0 args
+        "MarshallerImpl.NullWriterParam";
+
+    public static final String ASSERT_FAILED = // 0 args
+        "SAXMarshaller.AssertFailed";
+
+    /**
+     * @deprecated use ERR_MISSING_OBJECT2
+     */
+    public static final String ERR_MISSING_OBJECT = // 0 args
+        "SAXMarshaller.MissingObject";
+
+    /**
+     * @deprecated
+     *  use {@link com.sun.xml.internal.bind.v2.runtime.XMLSerializer#reportMissingObjectError(String)}
+     */
+    public static final String ERR_MISSING_OBJECT2 = // 1 arg
+        "SAXMarshaller.MissingObject2";
+
+    /**
+     * @deprecated only used from 1.0
+     */
+    public static final String ERR_DANGLING_IDREF = // 1 arg
+        "SAXMarshaller.DanglingIDREF";
+
+    /**
+     * @deprecated only used from 1.0
+     */
+    public static final String ERR_NOT_IDENTIFIABLE = // 0 args
+        "SAXMarshaller.NotIdentifiable";
+
+    public static final String DOM_IMPL_DOESNT_SUPPORT_CREATELEMENTNS = // 2 args
+        "SAX2DOMEx.DomImplDoesntSupportCreateElementNs";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/Messages.properties
new file mode 100644
index 0000000..4c15aa0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/Messages.properties
@@ -0,0 +1,34 @@
+#
+# don't modify nor delete anything for backward compatibility
+#
+
+MarshallerImpl.NotMarshallable = \
+	the object parameter to marshal() is not marshallable
+	
+MarshallerImpl.UnsupportedResult = \
+	unsupported javax.xml.parser.transform.Result parameter
+	
+MarshallerImpl.UnsupportedEncoding = \
+	unsupported encoding: {0}
+	
+MarshallerImpl.NullWriterParam = \
+	StAX writer parameter must not be null
+	
+SAXMarshaller.AssertFailed = \
+	assertion failed
+	 
+SAXMarshaller.MissingObject = \
+	a required object is missing
+	 
+SAXMarshaller.MissingObject2 = \
+	a required field "{0}" is missing an object
+
+SAXMarshaller.DanglingIDREF = \
+	A tree contains a reference to ID "{0}" but it's not a part of the object graph
+
+SAXMarshaller.NotIdentifiable = \
+	An object is referenced as IDREF but its ID field is null
+
+SAX2DOMEx.DomImplDoesntSupportCreateElementNs = \
+	DOM implementation ({0} from {1}) is broken. It does not support the createElementNS method.
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/MinimumEscapeHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/MinimumEscapeHandler.java
new file mode 100644
index 0000000..b0bf37e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/MinimumEscapeHandler.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.io.IOException;
+import java.io.Writer;
+
+/**
+ * Performs no character escaping. Usable only when the output encoding
+ * is UTF, but this handler gives the maximum performance.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class MinimumEscapeHandler implements CharacterEscapeHandler {
+
+    private MinimumEscapeHandler() {}  // no instanciation please
+
+    public static final CharacterEscapeHandler theInstance = new MinimumEscapeHandler();
+
+    public void escape(char[] ch, int start, int length, boolean isAttVal, Writer out) throws IOException {
+        // avoid calling the Writerwrite method too much by assuming
+        // that the escaping occurs rarely.
+        // profiling revealed that this is faster than the naive code.
+        int limit = start+length;
+        for (int i = start; i < limit; i++) {
+            char c = ch[i];
+            if( c=='&' || c=='<' || c=='>' || (c=='\"' && isAttVal) ) {
+                if(i!=start)
+                    out.write(ch,start,i-start);
+                start = i+1;
+                switch (ch[i]) {
+                case '&' :
+                    out.write("&amp;");
+                    break;
+                case '<' :
+                    out.write("&lt;");
+                    break;
+                case '>' :
+                    out.write("&gt;");
+                    break;
+                case '\"' :
+                    out.write("&quot;");
+                    break;
+                }
+            }
+        }
+
+        if( start!=limit )
+            out.write(ch,start,limit-start);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/NamespacePrefixMapper.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/NamespacePrefixMapper.java
new file mode 100644
index 0000000..d7dc75e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/NamespacePrefixMapper.java
@@ -0,0 +1,237 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.io.OutputStream;
+
+import javax.xml.stream.XMLEventWriter;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.dom.DOMResult;
+
+import org.w3c.dom.Node;
+
+// be careful about changing this class. this class is supposed to be
+// extended by users and therefore we are not allowed to break
+// those user code.
+//
+// this means:
+// - don't add any abstract method
+// - don't change any existing method signature
+// - don't remove any existing method.
+
+/**
+ * Implemented by the user application to determine URI -> prefix
+ * mapping.
+ *
+ * This is considered as an interface, though it's implemented
+ * as an abstract class to make it easy to add new methods in
+ * a future.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class NamespacePrefixMapper {
+
+    private static final String[] EMPTY_STRING = new String[0];
+
+    /**
+     * Returns a preferred prefix for the given namespace URI.
+     *
+     * This method is intended to be overrided by a derived class.
+     *
+     * @param namespaceUri
+     *      The namespace URI for which the prefix needs to be found.
+     *      Never be null. "" is used to denote the default namespace.
+     * @param suggestion
+     *      When the content tree has a suggestion for the prefix
+     *      to the given namespaceUri, that suggestion is passed as a
+     *      parameter. Typicall this value comes from the QName.getPrefix
+     *      to show the preference of the content tree. This parameter
+     *      may be null, and this parameter may represent an already
+     *      occupied prefix.
+     * @param requirePrefix
+     *      If this method is expected to return non-empty prefix.
+     *      When this flag is true, it means that the given namespace URI
+     *      cannot be set as the default namespace.
+     *
+     * @return
+     *      null if there's no prefered prefix for the namespace URI.
+     *      In this case, the system will generate a prefix for you.
+     *
+     *      Otherwise the system will try to use the returned prefix,
+     *      but generally there's no guarantee if the prefix will be
+     *      actually used or not.
+     *
+     *      return "" to map this namespace URI to the default namespace.
+     *      Again, there's no guarantee that this preference will be
+     *      honored.
+     *
+     *      If this method returns "" when requirePrefix=true, the return
+     *      value will be ignored and the system will generate one.
+     *
+     * @since JAXB 1.0.1
+     */
+    public abstract String getPreferredPrefix(String namespaceUri, String suggestion, boolean requirePrefix);
+
+    /**
+     * Returns a list of namespace URIs that should be declared
+     * at the root element.
+     *
+     * <p>
+     * By default, the JAXB RI 1.0.x produces namespace declarations only when
+     * they are necessary, only at where they are used. Because of this
+     * lack of look-ahead, sometimes the marshaller produces a lot of
+     * namespace declarations that look redundant to human eyes. For example,
+     * <pre><xmp>
+     * <?xml version="1.0"?>
+     * <root>
+     *   <ns1:child xmlns:ns1="urn:foo"> ... </ns1:child>
+     *   <ns2:child xmlns:ns2="urn:foo"> ... </ns2:child>
+     *   <ns3:child xmlns:ns3="urn:foo"> ... </ns3:child>
+     *   ...
+     * </root>
+     * <xmp></pre>
+     *
+     * <p>
+     * The JAXB RI 2.x mostly doesn't exhibit this behavior any more,
+     * as it declares all statically known namespace URIs (those URIs
+     * that are used as element/attribute names in JAXB annotations),
+     * but it may still declare additional namespaces in the middle of
+     * a document, for example when (i) a QName as an attribute/element value
+     * requires a new namespace URI, or (ii) DOM nodes as a portion of an object
+     * tree requires a new namespace URI.
+     *
+     * <p>
+     * If you know in advance that you are going to use a certain set of
+     * namespace URIs, you can override this method and have the marshaller
+     * declare those namespace URIs at the root element.
+     *
+     * <p>
+     * For example, by returning <code>new String[]{"urn:foo"}</code>,
+     * the marshaller will produce:
+     * <pre><xmp>
+     * <?xml version="1.0"?>
+     * <root xmlns:ns1="urn:foo">
+     *   <ns1:child> ... </ns1:child>
+     *   <ns1:child> ... </ns1:child>
+     *   <ns1:child> ... </ns1:child>
+     *   ...
+     * </root>
+     * <xmp></pre>
+     * <p>
+     * To control prefixes assigned to those namespace URIs, use the
+     * {@link #getPreferredPrefix(String, String, boolean)} method.
+     *
+     * @return
+     *      A list of namespace URIs as an array of {@link String}s.
+     *      This method can return a length-zero array but not null.
+     *      None of the array component can be null. To represent
+     *      the empty namespace, use the empty string <code>""</code>.
+     *
+     * @since
+     *      JAXB RI 1.0.2
+     */
+    public String[] getPreDeclaredNamespaceUris() {
+        return EMPTY_STRING;
+    }
+
+    /**
+     * Similar to {@link #getPreDeclaredNamespaceUris()} but allows the
+     * (prefix,nsUri) pairs to be returned.
+     *
+     * <p>
+     * With {@link #getPreDeclaredNamespaceUris()}, applications who wish to control
+     * the prefixes as well as the namespaces needed to implement both
+     * {@link #getPreDeclaredNamespaceUris()} and {@link #getPreferredPrefix(String, String, boolean)}.
+     *
+     * <p>
+     * This version eliminates the needs by returning an array of pairs.
+     *
+     * @return
+     *      always return a non-null (but possibly empty) array. The array stores
+     *      data like (prefix1,nsUri1,prefix2,nsUri2,...) Use an empty string to represent
+     *      the empty namespace URI and the default prefix. Null is not allowed as a value
+     *      in the array.
+     *
+     * @since
+     *      JAXB RI 2.0 beta
+     */
+    public String[] getPreDeclaredNamespaceUris2() {
+        return EMPTY_STRING;
+    }
+
+    /**
+     * Returns a list of (prefix,namespace URI) pairs that represents
+     * namespace bindings available on ancestor elements (that need not be repeated
+     * by the JAXB RI.)
+     *
+     * <p>
+     * Sometimes JAXB is used to marshal an XML document, which will be
+     * used as a subtree of a bigger document. When this happens, it's nice
+     * for a JAXB marshaller to be able to use in-scope namespace bindings
+     * of the larger document and avoid declaring redundant namespace URIs.
+     *
+     * <p>
+     * This is automatically done when you are marshalling to {@link XMLStreamWriter},
+     * {@link XMLEventWriter}, {@link DOMResult}, or {@link Node}, because
+     * those output format allows us to inspect what's currently available
+     * as in-scope namespace binding. However, with other output format,
+     * such as {@link OutputStream}, the JAXB RI cannot do this automatically.
+     * That's when this method comes into play.
+     *
+     * <p>
+     * Namespace bindings returned by this method will be used by the JAXB RI,
+     * but will not be re-declared. They are assumed to be available when you insert
+     * this subtree into a bigger document.
+     *
+     * <p>
+     * It is <b>NOT</b> OK to return  the same binding, or give
+     * the receiver a conflicting binding information.
+     * It's a responsibility of the caller to make sure that this doesn't happen
+     * even if the ancestor elements look like:
+     * <pre><xmp>
+     *   <foo:abc xmlns:foo="abc">
+     *     <foo:abc xmlns:foo="def">
+     *       <foo:abc xmlns:foo="abc">
+     *         ... JAXB marshalling into here.
+     *       </foo:abc>
+     *     </foo:abc>
+     *   </foo:abc>
+     * </xmp></pre>
+     * <!-- TODO: shall we relax this constraint? -->
+     *
+     * @return
+     *      always return a non-null (but possibly empty) array. The array stores
+     *      data like (prefix1,nsUri1,prefix2,nsUri2,...) Use an empty string to represent
+     *      the empty namespace URI and the default prefix. Null is not allowed as a value
+     *      in the array.
+     *
+     * @since JAXB RI 2.0 beta
+     */
+    public String[] getContextualNamespaceDecls() {
+        return EMPTY_STRING;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/NioEscapeHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/NioEscapeHandler.java
new file mode 100644
index 0000000..e9d787a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/NioEscapeHandler.java
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.io.IOException;
+import java.io.Writer;
+import java.nio.charset.Charset;
+import java.nio.charset.CharsetEncoder;
+
+/**
+ * Uses JDK1.4 NIO functionality to escape characters smartly.
+ *
+ * @since 1.0.1
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class NioEscapeHandler implements CharacterEscapeHandler {
+
+    private final CharsetEncoder encoder;
+
+    // exposing those variations upset javac 1.3.1, since it needs to
+    // know about those classes to determine which overloaded version
+    // of the method it wants to use. So comment it out for the compatibility.
+
+//    public NioEscapeHandler(CharsetEncoder _encoder) {
+//        this.encoder = _encoder;
+//        if(encoder==null)
+//            throw new NullPointerException();
+//    }
+//
+//    public NioEscapeHandler(Charset charset) {
+//        this(charset.newEncoder());
+//    }
+
+    public NioEscapeHandler(String charsetName) {
+//        this(Charset.forName(charsetName));
+        this.encoder = Charset.forName(charsetName).newEncoder();
+    }
+
+    public void escape(char[] ch, int start, int length, boolean isAttVal, Writer out) throws IOException {
+        int limit = start+length;
+        for (int i = start; i < limit; i++) {
+            switch (ch[i]) {
+            case '&':
+                out.write("&amp;");
+                break;
+            case '<':
+                out.write("&lt;");
+                break;
+            case '>':
+                out.write("&gt;");
+                break;
+            case '\"':
+                if (isAttVal) {
+                    out.write("&quot;");
+                } else {
+                    out.write('\"');
+                }
+                break;
+            default:
+                if( encoder.canEncode(ch[i]) ) {
+                    out.write(ch[i]);
+                } else {
+                    out.write("&#");
+                    out.write(Integer.toString(ch[i]));
+                    out.write(';');
+                }
+            }
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/SAX2DOMEx.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/SAX2DOMEx.java
new file mode 100644
index 0000000..24dc2bf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/SAX2DOMEx.java
@@ -0,0 +1,205 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * SAX2DOMEx.java
+ *
+ * Created on February 22, 2002, 1:55 PM
+ */
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.util.Stack;
+
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.ParserConfigurationException;
+
+import com.sun.xml.internal.bind.util.Which;
+import com.sun.istack.internal.FinalArrayList;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.w3c.dom.Text;
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+
+/**
+ * Builds a DOM tree from SAX2 events.
+ *
+ * @author  Vivek Pandey
+ * @since 1.0
+ */
+public class SAX2DOMEx implements ContentHandler {
+
+    private Node node=null;
+    private final Stack<Node> nodeStack = new Stack<Node>();
+    private final FinalArrayList<String> unprocessedNamespaces = new FinalArrayList<String>();
+
+
+    /**
+     * Document object that owns the specified node.
+     */
+    private final Document document;
+
+    /**
+     * @param   node
+     *      Nodes will be created and added under this object.
+     */
+    public SAX2DOMEx(Node node)
+    {
+        this.node = node;
+        nodeStack.push(this.node);
+
+        if( node instanceof Document )
+            this.document = (Document)node;
+        else
+            this.document = node.getOwnerDocument();
+    }
+
+    /**
+     * Creates a fresh empty DOM document and adds nodes under this document.
+     */
+    public SAX2DOMEx() throws ParserConfigurationException {
+        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
+        factory.setNamespaceAware(true);
+        factory.setValidating(false);
+
+        document = factory.newDocumentBuilder().newDocument();
+        node = document;
+        nodeStack.push( document );
+    }
+
+    public final Element getCurrentElement() {
+        return (Element) nodeStack.peek();
+    }
+
+    public Node getDOM() {
+        return node;
+    }
+
+    public void startDocument() {
+    }
+
+    public void endDocument(){
+    }
+
+    public void startElement(String namespace, String localName, String qName, Attributes attrs){
+        Node parent = nodeStack.peek();
+
+        // some broken DOM implementatino (we confirmed it with SAXON)
+        // return null from this method.
+        Element element = document.createElementNS(namespace, qName);
+
+        if( element==null ) {
+            // if so, report an user-friendly error message,
+            // rather than dying mysteriously with NPE.
+            throw new AssertionError(
+                Messages.format(Messages.DOM_IMPL_DOESNT_SUPPORT_CREATELEMENTNS,
+                    document.getClass().getName(),
+                    Which.which(document.getClass())));
+        }
+
+        // process namespace bindings
+        for( int i=0; i<unprocessedNamespaces.size(); i+=2 ) {
+            String prefix = unprocessedNamespaces.get(i+0);
+            String uri = unprocessedNamespaces.get(i+1);
+
+            String qname;
+            if( "".equals(prefix) || prefix==null )
+                qname = "xmlns";
+            else
+                qname = "xmlns:"+prefix;
+
+            // older version of Xerces (I confirmed that the bug is gone with Xerces 2.4.0)
+            // have a problem of re-setting the same namespace attribute twice.
+            // work around this bug removing it first.
+            if( element.hasAttributeNS("http://www.w3.org/2000/xmlns/",qname) ) {
+                // further workaround for an old Crimson bug where the removeAttribtueNS
+                // method throws NPE when the element doesn't have any attribute.
+                // to be on the safe side, check the existence of attributes before
+                // attempting to remove it.
+                // for details about this bug, see org.apache.crimson.tree.ElementNode2
+                // line 540 or the following message:
+                // https://jaxb.dev.java.net/servlets/ReadMsg?list=users&msgNo=2767
+                element.removeAttributeNS("http://www.w3.org/2000/xmlns/",qname);
+            }
+            // workaround until here
+
+            element.setAttributeNS("http://www.w3.org/2000/xmlns/",qname, uri);
+        }
+        unprocessedNamespaces.clear();
+
+
+        int length = attrs.getLength();
+        for(int i=0;i<length;i++){
+            String namespaceuri = attrs.getURI(i);
+            String value = attrs.getValue(i);
+            String qname = attrs.getQName(i);
+            element.setAttributeNS(namespaceuri, qname, value);
+        }
+        // append this new node onto current stack node
+        parent.appendChild(element);
+        // push this node onto stack
+        nodeStack.push(element);
+    }
+
+    public void endElement(String namespace, String localName, String qName){
+        nodeStack.pop();
+    }
+
+
+    public void characters(char[] ch, int start, int length) {
+        Node parent = nodeStack.peek();
+        Text text = document.createTextNode(new String(ch, start, length));
+        parent.appendChild(text);
+    }
+
+
+
+    public void ignorableWhitespace(char[] ch, int start, int length) {
+    }
+
+    public void processingInstruction(String target, String data) throws org.xml.sax.SAXException{
+        Node parent = nodeStack.peek();
+        Node node = document.createProcessingInstruction(target, data);
+        parent.appendChild(node);
+    }
+
+    public void setDocumentLocator(Locator locator) {
+    }
+
+    public void skippedEntity(String name) {
+    }
+
+    public void startPrefixMapping(String prefix, String uri) {
+        unprocessedNamespaces.add(prefix);
+        unprocessedNamespaces.add(uri);
+    }
+
+    public void endPrefixMapping(String prefix) {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/XMLWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/XMLWriter.java
new file mode 100644
index 0000000..d0089a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/marshaller/XMLWriter.java
@@ -0,0 +1,975 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+// @@3RD PARTY CODE@@
+
+// XMLWriter.java - serialize an XML document.
+// Written by David Megginson, david@megginson.com
+// NO WARRANTY!  This class is in the public domain.
+
+// Id: XMLWriter.java,v 1.5 2000/09/17 01:08:16 david Exp
+
+package com.sun.xml.internal.bind.marshaller;
+
+import java.io.IOException;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+import java.util.HashMap;
+import java.util.Map;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.AttributesImpl;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+
+/**
+ * Filter to write an XML document from a SAX event stream.
+ *
+ * <p>This class can be used by itself or as part of a SAX event
+ * stream: it takes as input a series of SAX2 ContentHandler
+ * events and uses the information in those events to write
+ * an XML document.  Since this class is a filter, it can also
+ * pass the events on down a filter chain for further processing
+ * (you can use the XMLWriter to take a snapshot of the current
+ * state at any point in a filter chain), and it can be
+ * used directly as a ContentHandler for a SAX2 XMLReader.</p>
+ *
+ * <p>The client creates a document by invoking the methods for
+ * standard SAX2 events, always beginning with the
+ * {@link #startDocument startDocument} method and ending with
+ * the {@link #endDocument endDocument} method.  There are convenience
+ * methods provided so that clients to not have to create empty
+ * attribute lists or provide empty strings as parameters; for
+ * example, the method invocation</p>
+ *
+ * <pre>
+ * w.startElement("foo");
+ * </pre>
+ *
+ * <p>is equivalent to the regular SAX2 ContentHandler method</p>
+ *
+ * <pre>
+ * w.startElement("", "foo", "", new AttributesImpl());
+ * </pre>
+ *
+ * <p>Except that it is more efficient because it does not allocate
+ * a new empty attribute list each time.  The following code will send
+ * a simple XML document to standard output:</p>
+ *
+ * <pre>
+ * XMLWriter w = new XMLWriter();
+ *
+ * w.startDocument();
+ * w.startElement("greeting");
+ * w.characters("Hello, world!");
+ * w.endElement("greeting");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>The resulting document will look like this:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;greeting>Hello, world!&lt;/greeting>
+ * </pre>
+ *
+ * <p>In fact, there is an even simpler convenience method,
+ * <var>dataElement</var>, designed for writing elements that
+ * contain only character data, so the code to generate the
+ * document could be shortened to</p>
+ *
+ * <pre>
+ * XMLWriter w = new XMLWriter();
+ *
+ * w.startDocument();
+ * w.dataElement("greeting", "Hello, world!");
+ * w.endDocument();
+ * </pre>
+ *
+ * <h2>Whitespace</h2>
+ *
+ * <p>According to the XML Recommendation, <em>all</em> whitespace
+ * in an XML document is potentially significant to an application,
+ * so this class never adds newlines or indentation.  If you
+ * insert three elements in a row, as in</p>
+ *
+ * <pre>
+ * w.dataElement("item", "1");
+ * w.dataElement("item", "2");
+ * w.dataElement("item", "3");
+ * </pre>
+ *
+ * <p>you will end up with</p>
+ *
+ * <pre>
+ * &lt;item>1&lt;/item>&lt;item>3&lt;/item>&lt;item>3&lt;/item>
+ * </pre>
+ *
+ * <p>You need to invoke one of the <var>characters</var> methods
+ * explicitly to add newlines or indentation.  Alternatively, you
+ * can use {@link DataWriter}, which
+ * is derived from this class -- it is optimized for writing
+ * purely data-oriented (or field-oriented) XML, and does automatic
+ * linebreaks and indentation (but does not support mixed content
+ * properly).</p>
+ *
+ *
+ * <h2>Namespace Support</h2>
+ *
+ * <p>The writer contains extensive support for XML Namespaces, so that
+ * a client application does not have to keep track of prefixes and
+ * supply <var>xmlns</var> attributes.  By default, the XML writer will
+ * generate Namespace declarations in the form _NS1, _NS2, etc., wherever
+ * they are needed, as in the following example:</p>
+ *
+ * <pre>
+ * w.startDocument();
+ * w.emptyElement("http://www.foo.com/ns/", "foo");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>The resulting document will look like this:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;_NS1:foo xmlns:_NS1="http://www.foo.com/ns/"/>
+ * </pre>
+ *
+ * <p>In many cases, document authors will prefer to choose their
+ * own prefixes rather than using the (ugly) default names.  The
+ * XML writer allows two methods for selecting prefixes:</p>
+ *
+ * <ol>
+ * <li>the qualified name</li>
+ * </ol>
+ *
+ * <p>Whenever the XML writer finds a new Namespace URI, it checks
+ * to see if a qualified (prefixed) name is also available; if so
+ * it attempts to use the name's prefix (as long as the prefix is
+ * not already in use for another Namespace URI).</p>
+ *
+ * <p>The resulting document will look like this:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;foo:foo xmlns:foo="http://www.foo.com/ns/"/>
+ * </pre>
+ *
+ * <p>The default Namespace simply uses an empty string as the prefix:</p>
+ *
+ * <pre>
+ * w.setPrefix("http://www.foo.com/ns/", "");
+ * w.startDocument();
+ * w.emptyElement("http://www.foo.com/ns/", "foo");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>The resulting document will look like this:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;foo xmlns="http://www.foo.com/ns/"/>
+ * </pre>
+ *
+ * <p>By default, the XML writer will not declare a Namespace until
+ * it is actually used.  Sometimes, this approach will create
+ * a large number of Namespace declarations, as in the following
+ * example:</p>
+ *
+ * <pre>
+ * &lt;xml version="1.0" standalone="yes"?>
+ *
+ * &lt;rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ *  &lt;rdf:Description about="http://www.foo.com/ids/books/12345">
+ *   &lt;dc:title xmlns:dc="http://www.purl.org/dc/">A Dark Night&lt;/dc:title>
+ *   &lt;dc:creator xmlns:dc="http://www.purl.org/dc/">Jane Smith&lt;/dc:title>
+ *   &lt;dc:date xmlns:dc="http://www.purl.org/dc/">2000-09-09&lt;/dc:title>
+ *  &lt;/rdf:Description>
+ * &lt;/rdf:RDF>
+ * </pre>
+ *
+ * <p>The "rdf" prefix is declared only once, because the RDF Namespace
+ * is used by the root element and can be inherited by all of its
+ * descendants; the "dc" prefix, on the other hand, is declared three
+ * times, because no higher element uses the Namespace.  To solve this
+ * problem, you can instruct the XML writer to predeclare Namespaces
+ * on the root element even if they are not used there:</p>
+ *
+ * <pre>
+ * w.forceNSDecl("http://www.purl.org/dc/");
+ * </pre>
+ *
+ * <p>Now, the "dc" prefix will be declared on the root element even
+ * though it's not needed there, and can be inherited by its
+ * descendants:</p>
+ *
+ * <pre>
+ * &lt;xml version="1.0" standalone="yes"?>
+ *
+ * &lt;rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ *             xmlns:dc="http://www.purl.org/dc/">
+ *  &lt;rdf:Description about="http://www.foo.com/ids/books/12345">
+ *   &lt;dc:title>A Dark Night&lt;/dc:title>
+ *   &lt;dc:creator>Jane Smith&lt;/dc:title>
+ *   &lt;dc:date>2000-09-09&lt;/dc:title>
+ *  &lt;/rdf:Description>
+ * &lt;/rdf:RDF>
+ * </pre>
+ *
+ * <p>This approach is also useful for declaring Namespace prefixes
+ * that be used by qualified names appearing in attribute values or
+ * character data.</p>
+ *
+ * @author David Megginson, david@megginson.com
+ * @since JAXB1.0
+ * @see org.xml.sax.XMLFilter
+ * @see org.xml.sax.ContentHandler
+ */
+public class XMLWriter extends XMLFilterImpl
+{
+
+    ////////////////////////////////////////////////////////////////////
+    // Constructors.
+    ////////////////////////////////////////////////////////////////////
+
+
+
+
+    /**
+     * Create a new XML writer.
+     *
+     * <p>Write to the writer provided.</p>
+     *
+     * @param writer
+     *      The output destination, or null to use standard output.
+     * @param encoding
+     *      If non-null string is specified, it is written as a part
+     *      of the XML declaration.
+     */
+    public XMLWriter (Writer writer, String encoding, CharacterEscapeHandler _escapeHandler )
+    {
+        init(writer,encoding);
+        this.escapeHandler = _escapeHandler;
+    }
+
+    public XMLWriter (Writer writer, String encoding ) {
+        this( writer, encoding, DumbEscapeHandler.theInstance );
+    }
+
+
+
+    /**
+     * Internal initialization method.
+     *
+     * <p>All of the public constructors invoke this method.
+     *
+     * @param writer The output destination, or null to use
+     *        standard output.
+     */
+    private void init (Writer writer,String encoding)
+    {
+        setOutput(writer,encoding);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Public methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Reset the writer.
+     *
+     * <p>This method is especially useful if the writer throws an
+     * exception before it is finished, and you want to reuse the
+     * writer for a new document.  It is usually a good idea to
+     * invoke {@link #flush flush} before resetting the writer,
+     * to make sure that no output is lost.</p>
+     *
+     * <p>This method is invoked automatically by the
+     * {@link #startDocument startDocument} method before writing
+     * a new document.</p>
+     *
+     * <p><strong>Note:</strong> this method will <em>not</em>
+     * clear the prefix or URI information in the writer or
+     * the selected output writer.</p>
+     *
+     * @see #flush()
+     */
+    public void reset ()
+    {
+        elementLevel = 0;
+        startTagIsClosed = true;
+    }
+
+
+    /**
+     * Flush the output.
+     *
+     * <p>This method flushes the output stream.  It is especially useful
+     * when you need to make certain that the entire document has
+     * been written to output but do not want to close the output
+     * stream.</p>
+     *
+     * <p>This method is invoked automatically by the
+     * {@link #endDocument endDocument} method after writing a
+     * document.</p>
+     *
+     * @see #reset()
+     */
+    public void flush ()
+        throws IOException
+    {
+        output.flush();
+    }
+
+
+    /**
+     * Set a new output destination for the document.
+     *
+     * @param writer The output destination, or null to use
+     *        standard output.
+     * @see #flush()
+     */
+    public void setOutput (Writer writer,String _encoding)
+    {
+        if (writer == null) {
+            output = new OutputStreamWriter(System.out);
+        } else {
+            output = writer;
+        }
+        encoding = _encoding;
+    }
+
+    /**
+     * Set whether the writer should print out the XML declaration
+     * (&lt;?xml version='1.0' ... ?>).
+     * <p>
+     * This option is set to true by default.
+     */
+    public void setXmlDecl( boolean _writeXmlDecl ) {
+        this.writeXmlDecl = _writeXmlDecl;
+    }
+
+    /**
+     * Sets the header string.
+     *
+     * This string will be written right after the xml declaration
+     * without any escaping. Useful for generating a boiler-plate
+     * DOCTYPE decl, PIs, and comments.
+     *
+     * @param _header
+     *      passing null will work as if the empty string is passed.
+     */
+    public void setHeader( String _header ) {
+        this.header = _header;
+    }
+
+
+    private final HashMap<String,String> locallyDeclaredPrefix = new HashMap<String,String>();
+    public void startPrefixMapping( String prefix, String uri ) throws SAXException {
+        locallyDeclaredPrefix.put(prefix,uri);
+    }
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Methods from org.xml.sax.ContentHandler.
+    ////////////////////////////////////////////////////////////////////
+
+    /**
+     * Write the XML declaration at the beginning of the document.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the XML declaration, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#startDocument()
+     */
+    public void startDocument ()
+        throws SAXException
+    {
+        try {
+            reset();
+
+            if(writeXmlDecl) {
+                String e="";
+                if(encoding!=null)
+                    e = " encoding=\""+encoding+'\"';
+
+                writeXmlDecl("<?xml version=\"1.0\""+e +" standalone=\"yes\"?>");
+            }
+
+            if(header!=null)
+                write(header);
+
+            super.startDocument();
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+    protected void writeXmlDecl(String decl) throws IOException {
+        write(decl);
+    }
+
+
+    /**
+     * Write a newline at the end of the document.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the newline, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#endDocument()
+     */
+    public void endDocument ()
+        throws SAXException
+    {
+        try {
+            super.endDocument();
+            flush();
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write a start tag.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param uri The Namespace URI, or the empty string if none
+     *        is available.
+     * @param localName The element's local (unprefixed) name (required).
+     * @param qName The element's qualified (prefixed) name, or the
+     *        empty string is none is available.  This method will
+     *        use the qName as a template for generating a prefix
+     *        if necessary, but it is not guaranteed to use the
+     *        same qName.
+     * @param atts The element's attribute list (must not be null).
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the start tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#startElement(java.lang.String, java.lang.String, java.lang.String, org.xml.sax.Attributes)
+     */
+    public void startElement (String uri, String localName,
+                              String qName, Attributes atts)
+        throws SAXException
+    {
+        try {
+            if (!startTagIsClosed) {
+                write(">");
+            }
+            elementLevel++;
+//            nsSupport.pushContext();
+
+            write('<');
+            write(qName);
+            writeAttributes(atts);
+
+            // declare namespaces specified by the startPrefixMapping methods
+            if(!locallyDeclaredPrefix.isEmpty()) {
+                for (Map.Entry<String,String> e : locallyDeclaredPrefix.entrySet()) {
+                    String p = e.getKey();
+                    String u = e.getValue();
+                    if (u == null) {
+                        u = "";
+                    }
+                    write(' ');
+                    if ("".equals(p)) {
+                        write("xmlns=\"");
+                    } else {
+                        write("xmlns:");
+                        write(p);
+                        write("=\"");
+                    }
+                    char ch[] = u.toCharArray();
+                    writeEsc(ch, 0, ch.length, true);
+                    write('\"');
+                }
+                locallyDeclaredPrefix.clear();  // clear the contents
+            }
+
+//            if (elementLevel == 1) {
+//                forceNSDecls();
+//            }
+//            writeNSDecls();
+            super.startElement(uri, localName, qName, atts);
+            startTagIsClosed = false;
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write an end tag.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param uri The Namespace URI, or the empty string if none
+     *        is available.
+     * @param localName The element's local (unprefixed) name (required).
+     * @param qName The element's qualified (prefixed) name, or the
+     *        empty string is none is available.  This method will
+     *        use the qName as a template for generating a prefix
+     *        if necessary, but it is not guaranteed to use the
+     *        same qName.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the end tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#endElement(java.lang.String, java.lang.String, java.lang.String)
+     */
+    public void endElement (String uri, String localName, String qName)
+        throws SAXException
+    {
+        try {
+            if (startTagIsClosed) {
+                write("</");
+                write(qName);
+                write('>');
+            } else {
+                write("/>");
+                startTagIsClosed = true;
+            }
+            super.endElement(uri, localName, qName);
+//            nsSupport.popContext();
+            elementLevel--;
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write character data.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param ch The array of characters to write.
+     * @param start The starting position in the array.
+     * @param len The number of characters to write.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the characters, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#characters(char[], int, int)
+     */
+    public void characters (char ch[], int start, int len)
+        throws SAXException
+    {
+        try {
+            if (!startTagIsClosed) {
+                write('>');
+                startTagIsClosed = true;
+            }
+            writeEsc(ch, start, len, false);
+            super.characters(ch, start, len);
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write ignorable whitespace.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param ch The array of characters to write.
+     * @param start The starting position in the array.
+     * @param length The number of characters to write.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the whitespace, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#ignorableWhitespace(char[], int, int)
+     */
+    public void ignorableWhitespace (char ch[], int start, int length)
+        throws SAXException
+    {
+        try {
+            writeEsc(ch, start, length, false);
+            super.ignorableWhitespace(ch, start, length);
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+
+    /**
+     * Write a processing instruction.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param target The PI target.
+     * @param data The PI data.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the PI, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#processingInstruction(java.lang.String, java.lang.String)
+     */
+    public void processingInstruction (String target, String data)
+        throws SAXException
+    {
+        try {
+            if (!startTagIsClosed) {
+                write('>');
+                startTagIsClosed = true;
+            }
+            write("<?");
+            write(target);
+            write(' ');
+            write(data);
+            write("?>");
+            if (elementLevel < 1) {
+                write('\n');
+            }
+            super.processingInstruction(target, data);
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Convenience methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+
+    /**
+     * Start a new element without a qname or attributes.
+     *
+     * <p>This method will provide a default empty attribute
+     * list and an empty string for the qualified name.
+     * It invokes {@link
+     * #startElement(String, String, String, Attributes)}
+     * directly.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the start tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     */
+    public void startElement (String uri, String localName)
+        throws SAXException
+    {
+        startElement(uri, localName, "", EMPTY_ATTS);
+    }
+
+
+    /**
+     * Start a new element without a qname, attributes or a Namespace URI.
+     *
+     * <p>This method will provide an empty string for the
+     * Namespace URI, and empty string for the qualified name,
+     * and a default empty attribute list. It invokes
+     * #startElement(String, String, String, Attributes)}
+     * directly.</p>
+     *
+     * @param localName The element's local name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the start tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     */
+    public void startElement (String localName)
+        throws SAXException
+    {
+        startElement("", localName, "", EMPTY_ATTS);
+    }
+
+
+    /**
+     * End an element without a qname.
+     *
+     * <p>This method will supply an empty string for the qName.
+     * It invokes {@link #endElement(String, String, String)}
+     * directly.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the end tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #endElement(String, String, String)
+     */
+    public void endElement (String uri, String localName)
+        throws SAXException
+    {
+        endElement(uri, localName, "");
+    }
+
+
+    /**
+     * End an element without a Namespace URI or qname.
+     *
+     * <p>This method will supply an empty string for the qName
+     * and an empty string for the Namespace URI.
+     * It invokes {@link #endElement(String, String, String)}
+     * directly.</p>
+     *
+     * @param localName The element's local name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the end tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #endElement(String, String, String)
+     */
+    public void endElement (String localName)
+        throws SAXException
+    {
+        endElement("", localName, "");
+    }
+
+
+    /**
+     * Write an element with character data content.
+     *
+     * <p>This is a convenience method to write a complete element
+     * with character data content, including the start tag
+     * and end tag.</p>
+     *
+     * <p>This method invokes
+     * {@link #startElement(String, String, String, Attributes)},
+     * followed by
+     * {@link #characters(String)}, followed by
+     * {@link #endElement(String, String, String)}.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @param qName The element's default qualified name.
+     * @param atts The element's attributes.
+     * @param content The character data content.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the empty tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     * @see #characters(String)
+     * @see #endElement(String, String, String)
+     */
+    public void dataElement (String uri, String localName,
+                             String qName, Attributes atts,
+                             String content)
+        throws SAXException
+    {
+        startElement(uri, localName, qName, atts);
+        characters(content);
+        endElement(uri, localName, qName);
+    }
+
+
+    /**
+     * Write an element with character data content but no attributes.
+     *
+     * <p>This is a convenience method to write a complete element
+     * with character data content, including the start tag
+     * and end tag.  This method provides an empty string
+     * for the qname and an empty attribute list.</p>
+     *
+     * <p>This method invokes
+     * {@link #startElement(String, String, String, Attributes)},
+     * followed by
+     * {@link #characters(String)}, followed by
+     * {@link #endElement(String, String, String)}.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @param content The character data content.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the empty tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     * @see #characters(String)
+     * @see #endElement(String, String, String)
+     */
+    public void dataElement (String uri, String localName, String content)
+        throws SAXException
+    {
+        dataElement(uri, localName, "", EMPTY_ATTS, content);
+    }
+
+
+    /**
+     * Write an element with character data content but no attributes or Namespace URI.
+     *
+     * <p>This is a convenience method to write a complete element
+     * with character data content, including the start tag
+     * and end tag.  The method provides an empty string for the
+     * Namespace URI, and empty string for the qualified name,
+     * and an empty attribute list.</p>
+     *
+     * <p>This method invokes
+     * {@link #startElement(String, String, String, Attributes)},
+     * followed by
+     * {@link #characters(String)}, followed by
+     * {@link #endElement(String, String, String)}.</p>
+     *
+     * @param localName The element's local name.
+     * @param content The character data content.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the empty tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     * @see #characters(String)
+     * @see #endElement(String, String, String)
+     */
+    public void dataElement (String localName, String content)
+        throws SAXException
+    {
+        dataElement("", localName, "", EMPTY_ATTS, content);
+    }
+
+
+    /**
+     * Write a string of character data, with XML escaping.
+     *
+     * <p>This is a convenience method that takes an XML
+     * String, converts it to a character array, then invokes
+     * {@link #characters(char[], int, int)}.</p>
+     *
+     * @param data The character data.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the string, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #characters(char[], int, int)
+     */
+    public void characters (String data) throws SAXException {
+        try {
+            if (!startTagIsClosed) {
+                write('>');
+                startTagIsClosed = true;
+            }
+            char ch[] = data.toCharArray();
+            characters(ch, 0, ch.length);
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+
+
+    /**
+     * Write a raw character.
+     *
+     * @param c The character to write.
+     */
+    protected final void write (char c) throws IOException {
+        output.write(c);
+    }
+
+
+    /**
+     * Write a raw string.
+     */
+    protected final void write(String s) throws IOException {
+        output.write(s);
+    }
+
+
+    /**
+     * Write out an attribute list, escaping values.
+     *
+     * The names will have prefixes added to them.
+     *
+     * @param atts The attribute list to write.
+     */
+    private void writeAttributes (Attributes atts) throws IOException {
+        int len = atts.getLength();
+        for (int i = 0; i < len; i++) {
+            char ch[] = atts.getValue(i).toCharArray();
+            write(' ');
+            write(atts.getQName(i));
+            write("=\"");
+            writeEsc(ch, 0, ch.length, true);
+            write('"');
+        }
+    }
+
+
+    /**
+     * Write an array of data characters with escaping.
+     *
+     * @param ch The array of characters.
+     * @param start The starting position.
+     * @param length The number of characters to use.
+     * @param isAttVal true if this is an attribute value literal.
+     */
+    private void writeEsc (char ch[], int start,
+                             int length, boolean isAttVal)
+        throws IOException
+    {
+        escapeHandler.escape(ch, start, length, isAttVal, output);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constants.
+    ////////////////////////////////////////////////////////////////////
+
+    private final Attributes EMPTY_ATTS = new AttributesImpl();
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    private int elementLevel = 0;
+    private Writer output;
+    private String encoding;
+    private boolean writeXmlDecl = true;
+    /**
+     * This string will be written right after the xml declaration
+     * without any escaping. Useful for generating a boiler-plate DOCTYPE decl
+     * , PIs, and comments.
+     */
+    private String header=null;
+
+    private final CharacterEscapeHandler escapeHandler;
+
+    private boolean startTagIsClosed = true;
+}
+
+// end of XMLWriter.java
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/DOMScanner.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/DOMScanner.java
new file mode 100644
index 0000000..51c5bd6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/DOMScanner.java
@@ -0,0 +1,316 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.unmarshaller;
+
+import java.util.Enumeration;
+
+import javax.xml.bind.ValidationEventLocator;
+import javax.xml.bind.helpers.AbstractUnmarshallerImpl;
+import javax.xml.bind.helpers.ValidationEventLocatorImpl;
+
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.LocatorEx;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+import org.w3c.dom.ProcessingInstruction;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.AttributesImpl;
+import org.xml.sax.helpers.NamespaceSupport;
+
+/**
+ * Visits a W3C DOM tree and generates SAX2 events from it.
+ *
+ * <p>
+ * This class is just intended to be used by {@link AbstractUnmarshallerImpl}.
+ * The javax.xml.bind.helpers package is generally a wrong place to put
+ * classes like this.
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li></ul>
+ * @since JAXB1.0
+ */
+public class DOMScanner implements LocatorEx,InfosetScanner/*<Node> --- but can't do this to protect 1.0 clients, or can I? */
+{
+
+    /** reference to the current node being scanned - used for determining
+     *  location info for validation events */
+    private Node currentNode = null;
+
+    /** To save memory, only one instance of AttributesImpl will be used. */
+    private final AttributesImpl atts = new AttributesImpl();
+
+    /** This handler will receive SAX2 events. */
+    private ContentHandler receiver=null;
+
+    private Locator locator=this;
+
+    public DOMScanner() {
+    }
+
+
+    /**
+     * Configures the locator object that the SAX {@link ContentHandler} will see.
+     */
+    public void setLocator( Locator loc ) {
+        this.locator = loc;
+    }
+
+    public void scan(Object node) throws SAXException {
+        if( node instanceof Document ) {
+            scan( (Document)node );
+        } else {
+            scan( (Element)node );
+        }
+    }
+
+    public void scan( Document doc ) throws SAXException {
+        scan( doc.getDocumentElement() );
+    }
+
+    public void scan( Element e) throws SAXException {
+        setCurrentLocation( e );
+        receiver.startDocument();
+
+        receiver.setDocumentLocator(locator);
+
+        NamespaceSupport nss = new NamespaceSupport();
+        buildNamespaceSupport( nss, e.getParentNode() );
+
+        for( Enumeration en = nss.getPrefixes(); en.hasMoreElements(); ) {
+            String prefix = (String)en.nextElement();
+            receiver.startPrefixMapping( prefix, nss.getURI(prefix) );
+        }
+
+        visit(e);
+
+        for( Enumeration en = nss.getPrefixes(); en.hasMoreElements(); ) {
+            String prefix = (String)en.nextElement();
+            receiver.endPrefixMapping( prefix );
+        }
+
+
+        setCurrentLocation( e );
+        receiver.endDocument();
+    }
+
+    /**
+     * Parses a subtree starting from the element e and
+     * reports SAX2 events to the specified handler.
+     *
+     * @deprecated in JAXB 2.0
+     *      Use {@link #scan(Element)}
+     */
+    public void parse( Element e, ContentHandler handler ) throws SAXException {
+        // it might be better to set receiver at the constructor.
+        receiver = handler;
+
+        setCurrentLocation( e );
+        receiver.startDocument();
+
+        receiver.setDocumentLocator(locator);
+        visit(e);
+
+        setCurrentLocation( e );
+        receiver.endDocument();
+    }
+
+    /**
+     * Similar to the parse method but it visits the ancestor nodes
+     * and properly emulate the all in-scope namespace declarations.
+     *
+     * @deprecated in JAXB 2.0
+     *      Use {@link #scan(Element)}
+     */
+    public void parseWithContext( Element e, ContentHandler handler ) throws SAXException {
+        setContentHandler(handler);
+        scan(e);
+    }
+
+    /**
+     * Recursively visit ancestors and build up {@link NamespaceSupport} oject.
+     */
+    private void buildNamespaceSupport(NamespaceSupport nss, Node node) {
+        if(node==null || node.getNodeType()!=Node.ELEMENT_NODE)
+            return;
+
+        buildNamespaceSupport( nss, node.getParentNode() );
+
+        nss.pushContext();
+        NamedNodeMap atts = node.getAttributes();
+        for( int i=0; i<atts.getLength(); i++ ) {
+            Attr a = (Attr)atts.item(i);
+            if( "xmlns".equals(a.getPrefix()) ) {
+                nss.declarePrefix( a.getLocalName(), a.getValue() );
+                continue;
+            }
+            if( "xmlns".equals(a.getName()) ) {
+                nss.declarePrefix( "", a.getValue() );
+                continue;
+            }
+        }
+    }
+
+    /**
+     * Visits an element and its subtree.
+     */
+    public void visit( Element e ) throws SAXException {
+        setCurrentLocation( e );
+        final NamedNodeMap attributes = e.getAttributes();
+
+        atts.clear();
+        int len = attributes==null ? 0: attributes.getLength();
+
+        for( int i=len-1; i>=0; i-- ) {
+            Attr a = (Attr)attributes.item(i);
+            String name = a.getName();
+            // start namespace binding
+           if(name.startsWith("xmlns")) {
+                if(name.length()==5) {
+                    receiver.startPrefixMapping( "", a.getValue() );
+                } else {
+                    String localName = a.getLocalName();
+                    if(localName==null) {
+                        // DOM built without namespace support has this problem
+                        localName = name.substring(6);
+                    }
+                    receiver.startPrefixMapping( localName, a.getValue() );
+                }
+                continue;
+            }
+
+            String uri = a.getNamespaceURI();
+            if(uri==null)   uri="";
+
+            String local = a.getLocalName();
+            if(local==null) local = a.getName();
+            // add other attributes to the attribute list
+            // that we will pass to the ContentHandler
+            atts.addAttribute(
+                uri,
+                local,
+                a.getName(),
+                "CDATA",
+                a.getValue());
+        }
+
+        String uri = e.getNamespaceURI();
+        if(uri==null)   uri="";
+        String local = e.getLocalName();
+        String qname = e.getTagName();
+        if(local==null) local = qname;
+        receiver.startElement( uri, local, qname, atts );
+
+        // visit its children
+        NodeList children = e.getChildNodes();
+        int clen = children.getLength();
+        for( int i=0; i<clen; i++ )
+            visit(children.item(i));
+
+
+
+        setCurrentLocation( e );
+        receiver.endElement( uri, local, qname );
+
+        // call the endPrefixMapping method
+        for( int i=len-1; i>=0; i-- ) {
+            Attr a = (Attr)attributes.item(i);
+            String name = a.getName();
+            if(name.startsWith("xmlns")) {
+                if(name.length()==5)
+                    receiver.endPrefixMapping("");
+                else
+                    receiver.endPrefixMapping(a.getLocalName());
+            }
+        }
+    }
+
+    private void visit( Node n ) throws SAXException {
+        setCurrentLocation( n );
+
+        // if a case statement gets too big, it should be made into a separate method.
+        switch(n.getNodeType()) {
+        case Node.CDATA_SECTION_NODE:
+        case Node.TEXT_NODE:
+            String value = n.getNodeValue();
+            receiver.characters( value.toCharArray(), 0, value.length() );
+            break;
+        case Node.ELEMENT_NODE:
+            visit( (Element)n );
+            break;
+        case Node.ENTITY_REFERENCE_NODE:
+            receiver.skippedEntity(n.getNodeName());
+            break;
+        case Node.PROCESSING_INSTRUCTION_NODE:
+            ProcessingInstruction pi = (ProcessingInstruction)n;
+            receiver.processingInstruction(pi.getTarget(),pi.getData());
+            break;
+        }
+    }
+
+    private void setCurrentLocation( Node currNode ) {
+        currentNode = currNode;
+    }
+
+    /**
+     * The same as {@link #getCurrentElement()} but
+     * better typed.
+     */
+    public Node getCurrentLocation() {
+        return currentNode;
+    }
+
+    public Object getCurrentElement() {
+        return currentNode;
+    }
+
+    public LocatorEx getLocator() {
+        return this;
+    }
+
+    public void setContentHandler(ContentHandler handler) {
+        this.receiver = handler;
+    }
+
+    public ContentHandler getContentHandler() {
+        return this.receiver;
+    }
+
+
+    // LocatorEx implementation
+    public String getPublicId() { return null; }
+    public String getSystemId() { return null; }
+    public int getLineNumber() { return -1; }
+    public int getColumnNumber() { return -1; }
+
+    public ValidationEventLocator getLocation() {
+        return new ValidationEventLocatorImpl(getCurrentLocation());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/InfosetScanner.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/InfosetScanner.java
new file mode 100644
index 0000000..8523893
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/InfosetScanner.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.unmarshaller;
+
+import javax.xml.bind.Binder;
+
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.LocatorEx;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.SAXException;
+
+/**
+ * Visits a DOM-ish API and generates SAX events.
+ *
+ * <p>
+ * This interface is not tied to any particular DOM API.
+ * Used by the {@link Binder}.
+ *
+ * <p>
+ * Since we are parsing a DOM-ish tree, I don't think this
+ * scanner itself will ever find an error, so this class
+ * doesn't have its own error reporting scheme.
+ *
+ * <p>
+ * This interface <b>MAY NOT</b> be implemented by the generated
+ * runtime nor the generated code. We may add new methods on
+ * this interface later. This is to be implemented by the static runtime
+ * only.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ * @since 2.0
+ */
+public interface InfosetScanner<XmlNode> {
+    /**
+     * Parses the given DOM-ish element/document and generates
+     * SAX events.
+     *
+     * @throws ClassCastException
+     *      If the type of the node is not known to this implementation.
+     *
+     * @throws SAXException
+     *      If the {@link ContentHandler} throws a {@link SAXException}.
+     *      Do not throw an exception just because the scanner failed
+     *      (if that can happen we need to change the API.)
+     */
+    void scan( XmlNode node ) throws SAXException;
+
+    /**
+     * Sets the {@link ContentHandler}.
+     *
+     * This handler receives the SAX events.
+     */
+    void setContentHandler( ContentHandler handler );
+    ContentHandler getContentHandler();
+
+    /**
+     * Gets the current element we are parsing.
+     *
+     * <p>
+     * This method could
+     * be called from the {@link ContentHandler#startElement(String, String, String, Attributes)}
+     * or {@link ContentHandler#endElement(String, String, String)}.
+     *
+     * <p>
+     * Otherwise the behavior of this method is undefined.
+     *
+     * @return
+     *      never return null.
+     */
+    XmlNode getCurrentElement();
+
+    LocatorEx getLocator();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Messages.java
new file mode 100644
index 0000000..8df8e1a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Messages.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.unmarshaller;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ *
+ * @since JAXB1.0
+ */
+public class Messages
+{
+    public static String format( String property ) {
+        return format( property, null );
+    }
+
+    public static String format( String property, Object arg1 ) {
+        return format( property, new Object[]{arg1} );
+    }
+
+    public static String format( String property, Object arg1, Object arg2 ) {
+        return format( property, new Object[]{arg1,arg2} );
+    }
+
+    public static String format( String property, Object arg1, Object arg2, Object arg3 ) {
+        return format( property, new Object[]{arg1,arg2,arg3} );
+    }
+
+    // add more if necessary.
+
+    /** Loads a string resource and formats it with specified arguments. */
+    public static String format( String property, Object[] args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getName()).getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+//
+//
+// Message resources
+//
+//
+    public static final String UNEXPECTED_ENTER_ELEMENT =  // arg:2
+        "ContentHandlerEx.UnexpectedEnterElement";
+
+    public static final String UNEXPECTED_LEAVE_ELEMENT =  // arg:2
+        "ContentHandlerEx.UnexpectedLeaveElement";
+
+    public static final String UNEXPECTED_ENTER_ATTRIBUTE =// arg:2
+        "ContentHandlerEx.UnexpectedEnterAttribute";
+
+    public static final String UNEXPECTED_LEAVE_ATTRIBUTE =// arg:2
+        "ContentHandlerEx.UnexpectedLeaveAttribute";
+
+    public static final String UNEXPECTED_TEXT =// arg:1
+        "ContentHandlerEx.UnexpectedText";
+
+    public static final String UNEXPECTED_LEAVE_CHILD = // 0 args
+        "ContentHandlerEx.UnexpectedLeaveChild";
+
+    public static final String UNEXPECTED_ROOT_ELEMENT = // 1 arg
+        "SAXUnmarshallerHandlerImpl.UnexpectedRootElement";
+
+    public static final String UNEXPECTED_ROOT_ELEMENT2 = // 3 arg
+        "SAXUnmarshallerHandlerImpl.UnexpectedRootElement2";
+
+    public static final String UNDEFINED_PREFIX = // 1 arg
+        "Util.UndefinedPrefix";
+
+    public static final String NULL_READER = // 0 args
+        "Unmarshaller.NullReader";
+
+    public static final String ILLEGAL_READER_STATE = // 1 arg
+        "Unmarshaller.IllegalReaderState";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Messages.properties
new file mode 100644
index 0000000..39c705a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Messages.properties
@@ -0,0 +1,38 @@
+#
+# don't modify nor delete anything for backward compatibility
+#
+
+ContentHandlerEx.UnexpectedEnterElement = \
+	Unexpected element '{'{0}'}':{1}
+
+ContentHandlerEx.UnexpectedLeaveElement = \
+	Unexpected end of element '{'{0}'}':{1}
+
+ContentHandlerEx.UnexpectedEnterAttribute = \
+	Unexpected attribute '{'{0}'}':{1}
+
+ContentHandlerEx.UnexpectedLeaveAttribute = \
+	Unexpected end of attribute '{'{0}'}':{1}
+
+ContentHandlerEx.UnexpectedText = \
+	Unexpected text "{0}"
+
+ContentHandlerEx.UnexpectedLeaveChild = \
+	compiler error(unexpectedLeaveChild)
+	
+SAXUnmarshallerHandlerImpl.UnexpectedRootElement = \
+	unexpected root element {0}
+	
+SAXUnmarshallerHandlerImpl.UnexpectedRootElement2 = \
+	unexpected root element (uri:"{0}", local:"{1}"). Expected elements are {2}
+	
+Util.UndefinedPrefix = \
+	undefined prefix: {0}
+	
+Unmarshaller.NullReader = \
+	reader can not be null	
+	
+Unmarshaller.IllegalReaderState = \
+	reader must be on a START_ELEMENT event, not a {0} event
+	
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Patcher.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Patcher.java
new file mode 100644
index 0000000..97ed179
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/unmarshaller/Patcher.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.unmarshaller;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Runs by UnmarshallingContext after all the parsing is done.
+ *
+ * Primarily used to resolve forward IDREFs, but it can run any action.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Patcher {
+    /**
+     * Runs an post-action.
+     *
+     * @throws SAXException
+     *      if an error is found during the action, it should be reporeted to the context.
+     *      The context may then throw a {@link SAXException} to abort the processing,
+     *      and that's when you can throw a {@link SAXException}.
+     */
+    void run() throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/util/AttributesImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/util/AttributesImpl.java
new file mode 100644
index 0000000..2b1ab19
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/util/AttributesImpl.java
@@ -0,0 +1,654 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+// AttributesImpl.java - default implementation of Attributes.
+// http://www.saxproject.org
+// Written by David Megginson
+// NO WARRANTY!  This class is in the public domain.
+// $Id: AttributesImpl.java,v 1.2 2005/05/11 19:44:28 kohsuke Exp $
+package com.sun.xml.internal.bind.util;
+
+import org.xml.sax.Attributes;
+
+
+/**
+ * Default implementation of the Attributes interface.
+ *
+ * <blockquote>
+ * <em>This module, both source code and documentation, is in the
+ * Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
+ * See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
+ * for further information.
+ * </blockquote>
+ *
+ * <p>This class provides a default implementation of the SAX2
+ * {@link org.xml.sax.Attributes Attributes} interface, with the
+ * addition of manipulators so that the list can be modified or
+ * reused.</p>
+ *
+ * <p>There are two typical uses of this class:</p>
+ *
+ * <ol>
+ * <li>to take a persistent snapshot of an Attributes object
+ *  in a {@link org.xml.sax.ContentHandler#startElement startElement} event; or</li>
+ * <li>to construct or modify an Attributes object in a SAX2 driver or filter.</li>
+ * </ol>
+ *
+ * <p>This class replaces the now-deprecated SAX1 {@link
+ * org.xml.sax.helpers.AttributeListImpl AttributeListImpl}
+ * class; in addition to supporting the updated Attributes
+ * interface rather than the deprecated {@link org.xml.sax.AttributeList
+ * AttributeList} interface, it also includes a much more efficient
+ * implementation using a single array rather than a set of Vectors.</p>
+ *
+ * @since JAXB1.0
+ * @since SAX 2.0
+ * @author David Megginson
+ */
+public class AttributesImpl implements Attributes
+{
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constructors.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Construct a new, empty AttributesImpl object.
+     */
+    public AttributesImpl ()
+    {
+        length = 0;
+        data = null;
+    }
+
+
+    /**
+     * Copy an existing Attributes object.
+     *
+     * <p>This constructor is especially useful inside a
+     * {@link org.xml.sax.ContentHandler#startElement startElement} event.</p>
+     *
+     * @param atts The existing Attributes object.
+     */
+    public AttributesImpl (Attributes atts)
+    {
+        setAttributes(atts);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Implementation of org.xml.sax.Attributes.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Return the number of attributes in the list.
+     *
+     * @return The number of attributes in the list.
+     * @see org.xml.sax.Attributes#getLength()
+     */
+    public int getLength ()
+    {
+        return length;
+    }
+
+
+    /**
+     * Return an attribute's Namespace URI.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The Namespace URI, the empty string if none is
+     *         available, or null if the index is out of range.
+     * @see org.xml.sax.Attributes#getURI(int)
+     */
+    public String getURI (int index)
+    {
+        if (index >= 0 && index < length) {
+            return data[index*5];
+        } else {
+            return null;
+        }
+    }
+
+
+    /**
+     * Return an attribute's local name.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's local name, the empty string if
+     *         none is available, or null if the index if out of range.
+     * @see org.xml.sax.Attributes#getLocalName(int)
+     */
+    public String getLocalName (int index)
+    {
+        if (index >= 0 && index < length) {
+            return data[index*5+1];
+        } else {
+            return null;
+        }
+    }
+
+
+    /**
+     * Return an attribute's qualified (prefixed) name.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's qualified name, the empty string if
+     *         none is available, or null if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getQName(int)
+     */
+    public String getQName (int index)
+    {
+        if (index >= 0 && index < length) {
+            return data[index*5+2];
+        } else {
+            return null;
+        }
+    }
+
+
+    /**
+     * Return an attribute's type by index.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's type, "CDATA" if the type is unknown, or null
+     *         if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getType(int)
+     */
+    public String getType (int index)
+    {
+        if (index >= 0 && index < length) {
+            return data[index*5+3];
+        } else {
+            return null;
+        }
+    }
+
+
+    /**
+     * Return an attribute's value by index.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's value or null if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getValue(int)
+     */
+    public String getValue (int index)
+    {
+        if (index >= 0 && index < length) {
+            return data[index*5+4];
+        } else {
+            return null;
+        }
+    }
+
+
+    /**
+     * Look up an attribute's index by Namespace name.
+     *
+     * <p>In many cases, it will be more efficient to look up the name once and
+     * use the index query methods rather than using the name query methods
+     * repeatedly.</p>
+     *
+     * @param uri The attribute's Namespace URI, or the empty
+     *        string if none is available.
+     * @param localName The attribute's local name.
+     * @return The attribute's index, or -1 if none matches.
+     * @see org.xml.sax.Attributes#getIndex(java.lang.String,java.lang.String)
+     */
+    public int getIndex (String uri, String localName)
+    {
+        int max = length * 5;
+        for (int i = 0; i < max; i += 5) {
+            if (data[i].equals(uri) && data[i+1].equals(localName)) {
+                return i / 5;
+            }
+        }
+        return -1;
+    }
+
+    /**
+     * Can be used if parameters are interned.
+     */
+    public int getIndexFast(String uri, String localName) {
+        for (int i = (length-1)*5; i>=0; i-=5) {
+            // local names tend to be different, so test it first
+            if (data[i + 1] == localName && data[i] == uri ) {
+                return i / 5;
+            }
+        }
+        return -1;
+    }
+
+
+    /**
+     * Look up an attribute's index by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's index, or -1 if none matches.
+     * @see org.xml.sax.Attributes#getIndex(java.lang.String)
+     */
+    public int getIndex (String qName)
+    {
+        int max = length * 5;
+        for (int i = 0; i < max; i += 5) {
+            if (data[i+2].equals(qName)) {
+                return i / 5;
+            }
+        }
+        return -1;
+    }
+
+
+    /**
+     * Look up an attribute's type by Namespace-qualified name.
+     *
+     * @param uri The Namespace URI, or the empty string for a name
+     *        with no explicit Namespace URI.
+     * @param localName The local name.
+     * @return The attribute's type, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getType(java.lang.String,java.lang.String)
+     */
+    public String getType (String uri, String localName)
+    {
+        int max = length * 5;
+        for (int i = 0; i < max; i += 5) {
+            if (data[i].equals(uri) && data[i+1].equals(localName)) {
+                return data[i+3];
+            }
+        }
+        return null;
+    }
+
+
+    /**
+     * Look up an attribute's type by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's type, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getType(java.lang.String)
+     */
+    public String getType (String qName)
+    {
+        int max = length * 5;
+        for (int i = 0; i < max; i += 5) {
+            if (data[i+2].equals(qName)) {
+                return data[i+3];
+            }
+        }
+        return null;
+    }
+
+
+    /**
+     * Look up an attribute's value by Namespace-qualified name.
+     *
+     * @param uri The Namespace URI, or the empty string for a name
+     *        with no explicit Namespace URI.
+     * @param localName The local name.
+     * @return The attribute's value, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getValue(java.lang.String,java.lang.String)
+     */
+    public String getValue (String uri, String localName)
+    {
+        int max = length * 5;
+        for (int i = 0; i < max; i += 5) {
+            if (data[i].equals(uri) && data[i+1].equals(localName)) {
+                return data[i+4];
+            }
+        }
+        return null;
+    }
+
+
+    /**
+     * Look up an attribute's value by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's value, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getValue(java.lang.String)
+     */
+    public String getValue (String qName)
+    {
+        int max = length * 5;
+        for (int i = 0; i < max; i += 5) {
+            if (data[i+2].equals(qName)) {
+                return data[i+4];
+            }
+        }
+        return null;
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Manipulators.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Clear the attribute list for reuse.
+     *
+     * <p>Note that little memory is freed by this call:
+     * the current array is kept so it can be
+     * reused.</p>
+     */
+    public void clear ()
+    {
+        if (data != null) {
+            for (int i = 0; i < (length * 5); i++)
+                data [i] = null;
+        }
+        length = 0;
+    }
+
+
+    /**
+     * Copy an entire Attributes object.
+     *
+     * <p>It may be more efficient to reuse an existing object
+     * rather than constantly allocating new ones.</p>
+     *
+     * @param atts The attributes to copy.
+     */
+    public void setAttributes (Attributes atts)
+    {
+        clear();
+        length = atts.getLength();
+        if (length > 0) {
+            data = new String[length*5];
+            for (int i = 0; i < length; i++) {
+                data[i*5] = atts.getURI(i);
+                data[i*5+1] = atts.getLocalName(i);
+                data[i*5+2] = atts.getQName(i);
+                data[i*5+3] = atts.getType(i);
+                data[i*5+4] = atts.getValue(i);
+            }
+        }
+    }
+
+
+    /**
+     * Add an attribute to the end of the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * to see if the attribute is already in the list: that is
+     * the responsibility of the application.</p>
+     *
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified (prefixed) name, or the empty string
+     *        if qualified names are not available.
+     * @param type The attribute type as a string.
+     * @param value The attribute value.
+     */
+    public void addAttribute (String uri, String localName, String qName,
+                              String type, String value)
+    {
+        ensureCapacity(length+1);
+        data[length*5] = uri;
+        data[length*5+1] = localName;
+        data[length*5+2] = qName;
+        data[length*5+3] = type;
+        data[length*5+4] = value;
+        length++;
+    }
+
+
+    /**
+     * Set an attribute in the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * for name conflicts or well-formedness: such checks are the
+     * responsibility of the application.</p>
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified name, or the empty string
+     *        if qualified names are not available.
+     * @param type The attribute type as a string.
+     * @param value The attribute value.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setAttribute (int index, String uri, String localName,
+                              String qName, String type, String value)
+    {
+        if (index >= 0 && index < length) {
+            data[index*5] = uri;
+            data[index*5+1] = localName;
+            data[index*5+2] = qName;
+            data[index*5+3] = type;
+            data[index*5+4] = value;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+    /**
+     * Remove an attribute from the list.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void removeAttribute (int index)
+    {
+        if (index >= 0 && index < length) {
+            if (index < length - 1) {
+                System.arraycopy(data, (index+1)*5, data, index*5,
+                                 (length-index-1)*5);
+            }
+            index = (length - 1) * 5;
+            data [index++] = null;
+            data [index++] = null;
+            data [index++] = null;
+            data [index++] = null;
+            data [index] = null;
+            length--;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+    /**
+     * Set the Namespace URI of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param uri The attribute's Namespace URI, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setURI (int index, String uri)
+    {
+        if (index >= 0 && index < length) {
+            data[index*5] = uri;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+    /**
+     * Set the local name of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param localName The attribute's local name, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setLocalName (int index, String localName)
+    {
+        if (index >= 0 && index < length) {
+            data[index*5+1] = localName;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+    /**
+     * Set the qualified name of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param qName The attribute's qualified name, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setQName (int index, String qName)
+    {
+        if (index >= 0 && index < length) {
+            data[index*5+2] = qName;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+    /**
+     * Set the type of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param type The attribute's type.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setType (int index, String type)
+    {
+        if (index >= 0 && index < length) {
+            data[index*5+3] = type;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+    /**
+     * Set the value of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param value The attribute's value.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setValue (int index, String value)
+    {
+        if (index >= 0 && index < length) {
+            data[index*5+4] = value;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Ensure the internal array's capacity.
+     *
+     * @param n The minimum number of attributes that the array must
+     *        be able to hold.
+     */
+    private void ensureCapacity (int n)    {
+        if (n <= 0) {
+            return;
+        }
+        int max;
+        if (data == null || data.length == 0) {
+            max = 25;
+        }
+        else if (data.length >= n * 5) {
+            return;
+        }
+        else {
+            max = data.length;
+        }
+        while (max < n * 5) {
+            max *= 2;
+        }
+
+        String newData[] = new String[max];
+        if (length > 0) {
+            System.arraycopy(data, 0, newData, 0, length*5);
+        }
+        data = newData;
+    }
+
+
+    /**
+     * Report a bad array index in a manipulator.
+     *
+     * @param index The index to report.
+     * @exception java.lang.ArrayIndexOutOfBoundsException Always.
+     */
+    private void badIndex (int index)
+        throws ArrayIndexOutOfBoundsException
+    {
+        String msg =
+            "Attempt to modify attribute at illegal index: " + index;
+        throw new ArrayIndexOutOfBoundsException(msg);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    int length;
+    String data [];
+
+}
+
+// end of AttributesImpl.java
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/util/ValidationEventLocatorExImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/util/ValidationEventLocatorExImpl.java
new file mode 100644
index 0000000..a0aa0b6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/util/ValidationEventLocatorExImpl.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.util;
+
+import javax.xml.bind.helpers.ValidationEventLocatorImpl;
+
+import com.sun.xml.internal.bind.ValidationEventLocatorEx;
+
+/**
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ValidationEventLocatorExImpl
+    extends ValidationEventLocatorImpl implements ValidationEventLocatorEx {
+
+    private final String fieldName;
+
+    public ValidationEventLocatorExImpl( Object target, String fieldName ) {
+        super(target);
+        this.fieldName = fieldName;
+    }
+
+    public String getFieldName() {
+        return fieldName;
+    }
+
+    /**
+     * Returns a nice string representation for better debug experience.
+     */
+    public String toString() {
+        StringBuffer buf = new StringBuffer();
+        buf.append("[url=");
+        buf.append(getURL());
+        buf.append(",line=");
+        buf.append(getLineNumber());
+        buf.append(",column=");
+        buf.append(getColumnNumber());
+        buf.append(",node=");
+        buf.append(getNode());
+        buf.append(",object=");
+        buf.append(getObject());
+        buf.append(",field=");
+        buf.append(getFieldName());
+        buf.append("]");
+
+        return buf.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/util/Which.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/util/Which.java
new file mode 100644
index 0000000..7699edf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/util/Which.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.util;
+
+import java.net.URL;
+
+/**
+ * Finds out where a class file is loaded from.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class Which {
+
+    public static String which( Class clazz ) {
+        return which( clazz.getName(), clazz.getClassLoader() );
+    }
+
+    /**
+     * Search the specified classloader for the given classname.
+     *
+     * @param classname the fully qualified name of the class to search for
+     * @param loader the classloader to search
+     * @return the source location of the resource, or null if it wasn't found
+     */
+    public static String which(String classname, ClassLoader loader) {
+
+        String classnameAsResource = classname.replace('.', '/') + ".class";
+
+        if(loader == null) {
+            loader = ClassLoader.getSystemClassLoader();
+        }
+
+        URL it = loader.getResource(classnameAsResource);
+        if (it != null) {
+            return it.toString();
+        } else {
+            return null;
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/ClassFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/ClassFactory.java
new file mode 100644
index 0000000..98c4427
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/ClassFactory.java
@@ -0,0 +1,213 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2;
+
+import java.lang.reflect.Constructor;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.lang.reflect.Modifier;
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.LinkedList;
+import java.util.Map;
+import java.util.Stack;
+import java.util.TreeSet;
+import java.util.WeakHashMap;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.sun.xml.internal.bind.Util;
+
+/**
+ * Creates new instances of classes.
+ *
+ * <p>
+ * This code handles the case where the class is not public or the constructor is
+ * not public.
+ *
+ * @since 2.0
+ * @author Kohsuke Kawaguchi
+ */
+public final class ClassFactory {
+    private static final Class[] emptyClass = new Class[0];
+    private static final Object[] emptyObject = new Object[0];
+
+    private static final Logger logger = Util.getClassLogger();
+
+    /**
+     * Cache from a class to its default constructor.
+     *
+     * To avoid synchronization among threads, we use {@link ThreadLocal}.
+     */
+    private static final ThreadLocal<Map<Class,Constructor>> tls = new ThreadLocal<Map<Class,Constructor>>() {
+        public Map<Class, Constructor> initialValue() {
+            return new WeakHashMap<Class,Constructor>();
+        }
+    };
+
+    /**
+     * Creates a new instance of the class but throw exceptions without catching it.
+     */
+    public static <T> T create0( final Class<T> clazz ) throws IllegalAccessException, InvocationTargetException, InstantiationException {
+        Map<Class,Constructor> m = tls.get();
+        Constructor<T> cons = m.get(clazz);
+        if(cons==null) {
+            try {
+                cons = clazz.getDeclaredConstructor(emptyClass);
+            } catch (NoSuchMethodException e) {
+                logger.log(Level.INFO,"No default constructor found on "+clazz,e);
+                NoSuchMethodError exp;
+                if(clazz.getDeclaringClass()!=null && !Modifier.isStatic(clazz.getModifiers())) {
+                    exp = new NoSuchMethodError(Messages.NO_DEFAULT_CONSTRUCTOR_IN_INNER_CLASS.format(clazz.getName()));
+                } else {
+                    exp = new NoSuchMethodError(e.getMessage());
+                }
+                exp.initCause(e);
+                throw exp;
+            }
+
+            int classMod = clazz.getModifiers();
+
+            if(!Modifier.isPublic(classMod) || !Modifier.isPublic(cons.getModifiers())) {
+                // attempt to make it work even if the constructor is not accessible
+                try {
+                    cons.setAccessible(true);
+                } catch(SecurityException e) {
+                    // but if we don't have a permission to do so, work gracefully.
+                    logger.log(Level.FINE,"Unable to make the constructor of "+clazz+" accessible",e);
+                    throw e;
+                }
+            }
+
+            m.put(clazz,cons);
+        }
+
+        return cons.newInstance(emptyObject);
+    }
+
+    /**
+     * The same as {@link #create0} but with an error handling to make
+     * the instanciation error fatal.
+     */
+    public static <T> T create( Class<T> clazz ) {
+        try {
+            return create0(clazz);
+        } catch (InstantiationException e) {
+            logger.log(Level.INFO,"failed to create a new instance of "+clazz,e);
+            throw new InstantiationError(e.toString());
+        } catch (IllegalAccessException e) {
+            logger.log(Level.INFO,"failed to create a new instance of "+clazz,e);
+            throw new IllegalAccessError(e.toString());
+        } catch (InvocationTargetException e) {
+            Throwable target = e.getTargetException();
+
+            // most likely an error on the user's code.
+            // just let it through for the ease of debugging
+            if(target instanceof RuntimeException)
+                throw (RuntimeException)target;
+
+            // error. just forward it for the ease of debugging
+            if(target instanceof Error)
+                throw (Error)target;
+
+            // a checked exception.
+            // not sure how we should report this error,
+            // but for now we just forward it by wrapping it into a runtime exception
+            throw new IllegalStateException(target);
+        }
+    }
+
+    /**
+     *  Call a method in the factory class to get the object.
+     */
+    public static Object create(final Method method) {
+        Object cons = null;
+        Throwable errorMsg = null;
+        try {
+            cons = method.invoke(null, emptyObject);
+        } catch (InvocationTargetException ive) {
+            Throwable target = ive.getTargetException();
+
+            if(target instanceof RuntimeException)
+                throw (RuntimeException)target;
+
+            if(target instanceof Error)
+                throw (Error)target;
+
+            throw new IllegalStateException(target);
+        } catch (IllegalAccessException e) {
+            logger.log(Level.INFO,"failed to create a new instance of "+method.getReturnType().getName(),e);
+            throw new IllegalAccessError(e.toString());
+        } catch (IllegalArgumentException iae){
+            logger.log(Level.INFO,"failed to create a new instance of "+method.getReturnType().getName(),iae);
+            errorMsg = iae;
+        } catch (NullPointerException npe){
+            logger.log(Level.INFO,"failed to create a new instance of "+method.getReturnType().getName(),npe);
+            errorMsg = npe;
+        } catch (ExceptionInInitializerError eie){
+            logger.log(Level.INFO,"failed to create a new instance of "+method.getReturnType().getName(),eie);
+            errorMsg = eie;
+        }
+        if (errorMsg != null){
+            NoSuchMethodError exp;
+            exp = new NoSuchMethodError(errorMsg.getMessage());
+            exp.initCause(errorMsg);
+            throw exp;
+        }
+        return cons;
+    }
+
+    /**
+     * Infers the instanciable implementation class that can be assigned to the given field type.
+     *
+     * @return null
+     *      if inference fails.
+     */
+    public static <T> Class<? extends T> inferImplClass(Class<T> fieldType, Class[] knownImplClasses) {
+        if(!fieldType.isInterface())
+            // instanciable class?
+            // TODO: check if it has a default constructor
+            return fieldType;
+
+        for( Class<?> impl : knownImplClasses ) {
+            if(fieldType.isAssignableFrom(impl))
+                return impl.asSubclass(fieldType);
+        }
+
+        // if we can't find an implementation class,
+        // let's just hope that we will never need to create a new object,
+        // and returns null
+        return null;
+    }
+
+    public static final Class[] COLLECTION_IMPL_CLASSES = new Class[] {
+        ArrayList.class,
+        LinkedList.class,
+        HashSet.class,
+        TreeSet.class,
+        Stack.class,
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/ContextFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/ContextFactory.java
new file mode 100644
index 0000000..597672a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/ContextFactory.java
@@ -0,0 +1,200 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2;
+
+import java.io.BufferedReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.StringTokenizer;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+
+import com.sun.istack.internal.FinalArrayList;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+
+/**
+ * This class is responsible for producing RI JAXBContext objects.  In
+ * the RI, this is the class that the javax.xml.bind.context.factory
+ * property will point to.
+ *
+ * <p>
+ * Used to create JAXBContext objects for v1.0.1 and forward
+ *
+ * @since 2.0
+ * @author Kohsuke Kawaguchi
+ */
+public class ContextFactory {
+    /**
+     * The API will invoke this method via reflection
+     */
+    public static JAXBContext createContext( Class[] classes, Map<String,Object> properties ) throws JAXBException {
+        // fool-proof check, and copy the map to make it easier to find unrecognized properties.
+        if(properties==null)
+            properties = Collections.emptyMap();
+        else
+            properties = new HashMap<String,Object>(properties);
+
+        String defaultNsUri = getPropertyValue(properties,JAXBRIContext.DEFAULT_NAMESPACE_REMAP,String.class);
+
+        Boolean c14nSupport = getPropertyValue(properties,JAXBRIContext.CANONICALIZATION_SUPPORT,Boolean.class);
+        if(c14nSupport==null)
+            c14nSupport = false;
+
+
+        if(!properties.isEmpty()) {
+            throw new JAXBException(Messages.UNSUPPORTED_PROPERTY.format(properties.keySet().iterator().next()));
+        }
+
+        return createContext(classes,Collections.<TypeReference>emptyList(),defaultNsUri,c14nSupport);
+    }
+
+    /**
+     * If a key is present in the map, remove the value and return it.
+     */
+    private static <T> T getPropertyValue(Map<String, Object> properties, String keyName, Class<T> type ) throws JAXBException {
+        Object o = properties.get(keyName);
+        if(o==null)     return null;
+
+        properties.remove(keyName);
+        if(!type.isInstance(o))
+            throw new JAXBException(Messages.INVALID_PROPERTY_VALUE.format(keyName,o));
+        else
+            return type.cast(o);
+    }
+
+    /**
+     * Used from the JAXB RI runtime API, invoked via reflection.
+     */
+    public static JAXBContext createContext( Class[] classes, Collection<TypeReference> typeRefs, String defaultNsUri, boolean c14nSupport ) throws JAXBException {
+        return new JAXBContextImpl(classes,typeRefs,defaultNsUri,c14nSupport);
+    }
+
+    /**
+     * The API will invoke this method via reflection.
+     */
+    public static JAXBContext createContext( String contextPath,
+                                             ClassLoader classLoader, Map<String,Object> properties ) throws JAXBException {
+        FinalArrayList<Class> classes = new FinalArrayList<Class>();
+        StringTokenizer tokens = new StringTokenizer(contextPath,":");
+        List<Class> indexedClasses;
+
+        // at least on of these must be true per package
+        boolean foundObjectFactory;
+        boolean foundJaxbIndex;
+
+        while(tokens.hasMoreTokens()) {
+            foundObjectFactory = foundJaxbIndex = false;
+            String pkg = tokens.nextToken();
+
+            // look for ObjectFactory and load it
+            final Class<?> o;
+            try {
+                o = classLoader.loadClass(pkg+".ObjectFactory");
+                classes.add(o);
+                foundObjectFactory = true;
+            } catch (ClassNotFoundException e) {
+                // not necessarily an error
+            }
+
+            // look for jaxb.index and load the list of classes
+            try {
+                indexedClasses = loadIndexedClasses(pkg, classLoader);
+            } catch (IOException e) {
+                //TODO: think about this more
+                throw new JAXBException(e);
+            }
+            if(indexedClasses != null) {
+                classes.addAll(indexedClasses);
+                foundJaxbIndex = true;
+            }
+
+            if( !(foundObjectFactory || foundJaxbIndex) ) {
+                throw new JAXBException( Messages.BROKEN_CONTEXTPATH.format(pkg));
+            }
+        }
+
+
+        return createContext(classes.toArray(new Class[classes.size()]),properties);
+    }
+
+    /**
+     * Look for jaxb.index file in the specified package and load it's contents
+     *
+     * @param pkg package name to search in
+     * @param classLoader ClassLoader to search in
+     * @return a List of Class objects to load, null if there weren't any
+     * @throws IOException if there is an error reading the index file
+     * @throws JAXBException if there are any errors in the index file
+     */
+    private static List<Class> loadIndexedClasses(String pkg, ClassLoader classLoader) throws IOException, JAXBException {
+        final String resource = pkg.replace('.', '/') + "/jaxb.index";
+        final InputStream resourceAsStream = classLoader.getResourceAsStream(resource);
+
+        if (resourceAsStream == null) {
+            return null;
+        }
+
+        BufferedReader in =
+                new BufferedReader(new InputStreamReader(resourceAsStream, "UTF-8"));
+        try {
+            FinalArrayList<Class> classes = new FinalArrayList<Class>();
+            String className = in.readLine();
+            while (className != null) {
+                className = className.trim();
+                if (className.startsWith("#") || (className.length() == 0)) {
+                    className = in.readLine();
+                    continue;
+                }
+
+                if (className.endsWith(".class")) {
+                    throw new JAXBException(Messages.ILLEGAL_ENTRY.format(className));
+                }
+
+                try {
+                    classes.add(classLoader.loadClass(pkg + '.' + className));
+                } catch (ClassNotFoundException e) {
+                    throw new JAXBException(Messages.ERROR_LOADING_CLASS.format(className, resource),e);
+                }
+
+                className = in.readLine();
+            }
+            return classes;
+        } finally {
+            in.close();
+        }
+    }
+
+    public static final String USE_JAXB_PROPERTIES = "_useJAXBProperties";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/Messages.java
new file mode 100644
index 0000000..a598a9e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/Messages.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+enum Messages {
+    ILLEGAL_ENTRY,          // 1 arg
+    ERROR_LOADING_CLASS,    // 2 args
+    INVALID_PROPERTY_VALUE, // 2 args
+    UNSUPPORTED_PROPERTY,   // 1 arg
+    BROKEN_CONTEXTPATH,     // 1 arg
+    NO_DEFAULT_CONSTRUCTOR_IN_INNER_CLASS, // 1 arg
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/Messages.properties
new file mode 100644
index 0000000..1909248
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/Messages.properties
@@ -0,0 +1,19 @@
+
+ILLEGAL_ENTRY = \
+    illegal entry: "{0}", entries should be of the form "ClassName" or "OuterClass.InnerClass", not "ClassName.class" or "fully.qualified.ClassName"
+
+ERROR_LOADING_CLASS = \
+    error loading class "{0}" listed in {1}, make sure that entries are accessable on CLASSPATH and of the form "ClassName" or "OuterClass.InnerClass", not "ClassName.class" or "fully.qualified.ClassName"
+
+INVALID_PROPERTY_VALUE = \
+    {1} is not a valid value for property "{0}"
+
+UNSUPPORTED_PROPERTY = \
+    property "{0}" is not supported
+
+BROKEN_CONTEXTPATH = \
+    "{0}" doesn't contain ObjectFactory.class or jaxb.index
+
+NO_DEFAULT_CONSTRUCTOR_IN_INNER_CLASS = \
+    "{0}" is an inner class, and therefore it can never have a default no-argument constructor. Add 'static'.
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/TODO.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/TODO.java
new file mode 100644
index 0000000..6b353d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/TODO.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2;
+
+/**
+ * Place holder for TODOs.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class TODO {
+    /**
+     * When this method is called,
+     * that means we need to check the spec and corrects
+     * the behavior.
+     *
+     * Search the usage of this method.
+     */
+    public static void checkSpec() {}
+    public static void checkSpec(String comment) {}
+
+    /**
+     * When this method iscalled,
+     * that means the current code is a mock up and
+     * it needs to be properly implemented later.
+     */
+    public static void prototype() {}
+
+    public static void prototype(String comment) {}
+
+    /**
+     * When this method is called, it means that there is an
+     * unimplemeted portion of the spec in the schema generator.
+     */
+    public static void schemaGenerator(String comment) {}
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/WellKnownNamespace.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/WellKnownNamespace.java
new file mode 100644
index 0000000..1c0007c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/WellKnownNamespace.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2;
+
+/**
+ * Well-known namespace URIs.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ * @since 2.0
+ */
+public abstract class WellKnownNamespace {
+    private WellKnownNamespace() {} // no instanciation please
+
+    public static final String XML_SCHEMA =
+        "http://www.w3.org/2001/XMLSchema";
+
+    public static final String XML_SCHEMA_INSTANCE =
+        "http://www.w3.org/2001/XMLSchema-instance";
+
+    public static final Object XML_SCHEMA_DATATYPES =
+        "http://www.w3.org/2001/XMLSchema-datatypes";
+
+    public static final String XML_NAMESPACE_URI =
+        "http://www.w3.org/XML/1998/namespace";
+
+    public static final String XOP =
+        "http://www.w3.org/2004/08/xop/include";
+
+    public static final String SWA_URI =
+        "http://ws-i.org/profiles/basic/1.1/xsd";
+
+    public static final String XML_MIME_URI = "http://www.w3.org/2005/05/xmlmime";
+
+
+//    public static final QName XSI_NIL = new QName(XML_SCHEMA_INSTANCE,"nil");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/bytecode/ClassTailor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/bytecode/ClassTailor.java
new file mode 100644
index 0000000..a8015f7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/bytecode/ClassTailor.java
@@ -0,0 +1,191 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.bytecode;
+
+import java.io.ByteArrayOutputStream;
+import java.io.DataInputStream;
+import java.io.DataOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.sun.xml.internal.bind.Util;
+
+/**
+ * Replaces a few constant pool tokens from a class "template" and then loads it into the VM.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ClassTailor {
+
+    private ClassTailor() {} // no instanciation please
+
+    private static final Logger logger = Util.getClassLogger();
+
+    /**
+     * Returns the class name in the JVM format (such as "java/lang/String")
+     */
+    public static final String toVMClassName( Class c ) {
+        assert !c.isPrimitive();
+        if(c.isArray())
+            // I have no idea why it is designed like this, but javap says so.
+            return toVMTypeName(c);
+        return c.getName().replace('.','/');
+    }
+
+    public static final String toVMTypeName( Class c ) {
+        if(c.isArray()) {
+            // TODO: study how an array type is encoded.
+            return '['+toVMTypeName(c.getComponentType());
+        }
+        if(c.isPrimitive()) {
+            if(c==Boolean.TYPE)     return "Z";
+            if(c==Character.TYPE)   return "C";
+            if(c==Byte.TYPE)        return "B";
+            if(c==Double.TYPE)      return "D";
+            if(c==Float.TYPE)       return "F";
+            if(c==Integer.TYPE)     return "I";
+            if(c==Long.TYPE)        return "J";
+            if(c==Short.TYPE)       return "S";
+
+            throw new IllegalArgumentException(c.getName());
+        }
+        return 'L'+c.getName().replace('.','/')+';';
+    }
+
+
+
+    public static final byte[] tailor( Class templateClass, String newClassName, String... replacements ) {
+        String vmname = toVMClassName(templateClass);
+        return tailor(
+            templateClass.getClassLoader().getResourceAsStream(vmname+".class"),
+            vmname, newClassName, replacements );
+    }
+
+
+    /**
+     * Customizes a class file by replacing constant pools.
+     *
+     * @param image
+     *      The image of the template class.
+     * @param replacements
+     *      A list of pair of strings that specify the substitution
+     *      {@code String[]{search_0, replace_0, search_1, replace_1, ..., search_n, replace_n }}
+     *
+     *      The search strings found in the constant pool will be replaced by the corresponding
+     *      replacement string.
+     */
+    public static final byte[] tailor( InputStream image, String templateClassName, String newClassName, String... replacements ) {
+        DataInputStream in = new DataInputStream(image);
+
+        try {
+            ByteArrayOutputStream baos = new ByteArrayOutputStream(1024);
+            DataOutputStream out = new DataOutputStream(baos);
+
+            // skip until the constant pool count
+            long l = in.readLong();
+            out.writeLong(l);
+
+            // read the constant pool size
+            short count = in.readShort();
+            out.writeShort(count);
+
+            // replace constant pools
+            for( int i=0; i<count; i++ ) {
+                byte tag = in.readByte();
+                out.writeByte(tag);
+                switch(tag) {
+                case 0:
+                    // this isn't described in the spec,
+                    // but class files often seem to have this '0' tag.
+                    // we can apparently just ignore it, but not sure
+                    // what this really means.
+                    break;
+
+                case 1: // CONSTANT_UTF8
+                    {
+                        String value = in.readUTF();
+                        if(value.equals(templateClassName))
+                            value = newClassName;
+                        else {
+                            for( int j=0; j<replacements.length; j+=2 )
+                                if(value.equals(replacements[j])) {
+                                    value = replacements[j+1];
+                                    break;
+                                }
+                        }
+                        out.writeUTF(value);
+                    }
+                break;
+
+                case 3: // CONSTANT_Integer
+                case 4: // CONSTANT_Float
+                    out.writeInt(in.readInt());
+                    break;
+
+                case 5: // CONSTANT_Long
+                case 6: // CONSTANT_Double
+                    i++; // doubles and longs take two entries
+                    out.writeLong(in.readLong());
+                    break;
+
+                case 7: // CONSTANT_Class
+                case 8: // CONSTANT_String
+                    out.writeShort(in.readShort());
+                    break;
+
+                case 9: // CONSTANT_Fieldref
+                case 10: // CONSTANT_Methodref
+                case 11: // CONSTANT_InterfaceMethodref
+                case 12: // CONSTANT_NameAndType
+                    out.writeInt(in.readInt());
+                    break;
+
+                default:
+                    throw new IllegalArgumentException("Unknown constant type "+tag);
+                }
+            }
+
+            // then copy the rest
+            byte[] buf = new byte[512];
+            int len;
+            while((len=in.read(buf))>0)
+                out.write(buf,0,len);
+
+            in.close();
+            out.close();
+
+            // by now we got the properly tailored class file image
+            return baos.toByteArray();
+
+        } catch( IOException e ) {
+            // never happen
+            logger.log(Level.WARNING,"failed to tailor",e);
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/bytecode/package.html b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/bytecode/package.html
new file mode 100644
index 0000000..3f5f97d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/bytecode/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+  Code that deals with low level byte code manipulation.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/packages.png b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/packages.png
new file mode 100644
index 0000000..366fe5b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/packages.png
Binary files differ
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/packages.vsd b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/packages.vsd
new file mode 100644
index 0000000..db3bef4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/packages.vsd
Binary files differ
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/readme.txt b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/readme.txt
new file mode 100644
index 0000000..14720ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/doc-files/readme.txt
@@ -0,0 +1 @@
+The sxd/vsd files are the master, and the gif file should be created from it.
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AbstractInlineAnnotationReaderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AbstractInlineAnnotationReaderImpl.java
new file mode 100644
index 0000000..ec6b246
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AbstractInlineAnnotationReaderImpl.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+
+import com.sun.xml.internal.bind.v2.model.core.ErrorHandler;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+
+/**
+ * {@link AnnotationReader} that reads annotation from classes,
+ * not from external binding files.
+ *
+ * This is meant to be used as a convenient partial implementation.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class AbstractInlineAnnotationReaderImpl<T,C,F,M>
+    implements AnnotationReader<T,C,F,M> {
+
+    private ErrorHandler errorHandler;
+
+    public void setErrorHandler(ErrorHandler errorHandler) {
+        if(errorHandler==null)
+            throw new IllegalArgumentException();
+        this.errorHandler = errorHandler;
+    }
+
+    /**
+     * Always return a non-null valid {@link ErrorHandler}
+     */
+    public final ErrorHandler getErrorHandler() {
+        assert errorHandler!=null : "error handler must be set before use";
+        return errorHandler;
+    }
+
+    public final <A extends Annotation> A getMethodAnnotation(Class<A> annotation, M getter, M setter, Locatable srcPos) {
+        A a1 = getter==null?null:getMethodAnnotation(annotation,getter,srcPos);
+        A a2 = setter==null?null:getMethodAnnotation(annotation,setter,srcPos);
+
+        if(a1==null) {
+            if(a2==null)
+                return null;
+            else
+                return a2;
+        } else {
+            if(a2==null)
+                return a1;
+            else {
+                // both are present
+                getErrorHandler().error(new IllegalAnnotationException(
+                    Messages.DUPLICATE_ANNOTATIONS.format(
+                        annotation.getName(), fullName(getter),fullName(setter)),
+                    a1, a2 ));
+                // recover by ignoring one of them
+                return a1;
+            }
+        }
+    }
+
+    public boolean hasMethodAnnotation(Class<? extends Annotation> annotation, String propertyName, M getter, M setter, Locatable srcPos) {
+        boolean x = ( getter != null && hasMethodAnnotation(annotation, getter) );
+        boolean y = ( setter != null && hasMethodAnnotation(annotation, setter) );
+
+        if(x && y) {
+            // both are present. have getMethodAnnotation report an error
+            getMethodAnnotation(annotation,getter,setter,srcPos);
+        }
+
+        return x||y;
+    }
+
+    /**
+     * Gets the fully-qualified name of the method.
+     *
+     * Used for error messages.
+     */
+    protected abstract String fullName(M m);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AnnotationReader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AnnotationReader.java
new file mode 100644
index 0000000..8626e50
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AnnotationReader.java
@@ -0,0 +1,147 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+
+import com.sun.xml.internal.bind.v2.model.core.ErrorHandler;
+
+/**
+ * Reads annotations for the given property.
+ *
+ * <p>
+ * This is the lowest abstraction that encapsulates the difference
+ * between reading inline annotations and external binding files.
+ *
+ * <p>
+ * Because the former operates on a {@link Field} and {@link Method}
+ * while the latter operates on a "property", the methods defined
+ * on this interface takes both, and the callee gets to choose which
+ * to use.
+ *
+ * <p>
+ * Most of the get method takes {@link Locatable}, which points to
+ * the place/context in which the annotation is read. The returned
+ * annotation also implements {@link Locatable} (so that it can
+ * point to the place where the annotation is placed), and its
+ * {@link Locatable#getUpstream()} will return the given
+ * {@link Locatable}.
+ *
+ *
+ * <p>
+ * Errors found during reading annotations are reported through the error handler.
+ * A valid {@link ErrorHandler} must be registered before the {@link AnnotationReader}
+ * is used.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface AnnotationReader<T,C,F,M> {
+
+    /**
+     * Sets the error handler that receives errors found
+     * during reading annotations.
+     *
+     * @param errorHandler
+     *      must not be null.
+     */
+    void setErrorHandler(ErrorHandler errorHandler);
+
+    /**
+     * Reads an annotation on a property that consists of a field.
+     */
+    <A extends Annotation> A getFieldAnnotation(Class<A> annotation,
+                                                F field, Locatable srcpos);
+
+    /**
+     * Checks if the given field has an annotation.
+     */
+    boolean hasFieldAnnotation(Class<? extends Annotation> annotationType, F field);
+
+    /**
+     * Gets all the annotations on a field.
+     */
+    Annotation[] getAllFieldAnnotations(F field, Locatable srcPos);
+
+    /**
+     * Reads an annotation on a property that consists of a getter and a setter.
+     *
+     */
+    <A extends Annotation> A getMethodAnnotation(Class<A> annotation,
+                                                 M getter, M setter, Locatable srcpos);
+
+    /**
+     * Checks if the given method has an annotation.
+     */
+    boolean hasMethodAnnotation(Class<? extends Annotation> annotation, String propertyName, M getter, M setter, Locatable srcPos);
+
+    /**
+     * Gets all the annotations on a method.
+     *
+     * @param srcPos
+     *      the location from which this annotation is read.
+     */
+    Annotation[] getAllMethodAnnotations(M method, Locatable srcPos);
+
+    // TODO: we do need this to read certain annotations,
+    // but that shows inconsistency wrt the spec. consult the spec team about the abstraction.
+    <A extends Annotation> A getMethodAnnotation(Class<A> annotation, M method, Locatable srcpos );
+
+    boolean hasMethodAnnotation(Class<? extends Annotation> annotation, M method );
+
+    /**
+     * Reads an annotation on a parameter of the method.
+     *
+     * @return null
+     *      if the annotation was not found.
+     */
+    <A extends Annotation> A getMethodParameterAnnotation(
+            Class<A> annotation, M method, int paramIndex, Locatable srcPos );
+
+    /**
+     * Reads an annotation on a class.
+     */
+    <A extends Annotation> A getClassAnnotation(Class<A> annotation, C clazz, Locatable srcpos) ;
+
+    /**
+     * Reads an annotation on the package that the given class belongs to.
+     */
+    <A extends Annotation> A getPackageAnnotation(Class<A> annotation, C clazz, Locatable srcpos);
+
+    /**
+     * Reads a value of an annotation that returns a Class object.
+     *
+     * <p>
+     * Depending on the underlying reflection library, you can't always
+     * obtain the {@link Class} object directly (see the APT MirrorTypeException
+     * for example), so use this method to avoid that.
+     *
+     * @param name
+     *      The name of the annotation parameter to be read.
+     */
+    T getClassValue( Annotation a, String name );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AnnotationSource.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AnnotationSource.java
new file mode 100644
index 0000000..c4c5e59
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/AnnotationSource.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+
+/**
+ * Implemented by objects that can have annotations.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface AnnotationSource {
+    /**
+     * Gets the value of the specified annotation from the given property.
+     *
+     * <p>
+     * When this method is used for a property that consists of a getter and setter,
+     * it returns the annotation on either of those methods. If both methods have
+     * the same annotation, it is an error.
+     *
+     * @return
+     *      null if the annotation is not present.
+     */
+    <A extends Annotation> A readAnnotation(Class<A> annotationType);
+
+    /**
+     * Returns true if the property has the specified annotation.
+     * <p>
+     * Short for <code>readAnnotation(annotationType)!=null</code>,
+     * but this method is typically faster.
+     */
+    boolean hasAnnotation(Class<? extends Annotation> annotationType);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/ClassLocatable.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/ClassLocatable.java
new file mode 100644
index 0000000..24087f6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/ClassLocatable.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link Locatable} implementation for a class.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class ClassLocatable<C> implements Locatable {
+    private final Locatable upstream;
+    private final C clazz;
+    private final Navigator<?,C,?,?> nav;
+
+    public ClassLocatable(Locatable upstream, C clazz, Navigator<?,C,?,?> nav) {
+        this.upstream = upstream;
+        this.clazz = clazz;
+        this.nav = nav;
+    }
+
+    public Locatable getUpstream() {
+        return upstream;
+    }
+
+    public Location getLocation() {
+        return nav.getClassLocation(clazz);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/FieldLocatable.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/FieldLocatable.java
new file mode 100644
index 0000000..ca30ab2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/FieldLocatable.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link Locatable} implementation for a field.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldLocatable<F> implements Locatable {
+    private final Locatable upstream;
+    private final F field;
+    private final Navigator<?,?,F,?> nav;
+
+    public FieldLocatable(Locatable upstream, F field, Navigator<?,?,F,?> nav) {
+        this.upstream = upstream;
+        this.field = field;
+        this.nav = nav;
+    }
+
+    public Locatable getUpstream() {
+        return upstream;
+    }
+
+    public Location getLocation() {
+        return nav.getFieldLocation(field);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Init.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Init.java
new file mode 100644
index 0000000..48a1a78
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Init.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+
+class Init {
+
+
+    static Quick[] getAll() {
+        return new Quick[] {new XmlAttributeQuick(null, null), new XmlElementRefQuick(null, null), new XmlElementQuick(null, null), new XmlElementRefsQuick(null, null), new XmlElementDeclQuick(null, null), new XmlRootElementQuick(null, null), new XmlTransientQuick(null, null), new XmlEnumQuick(null, null), new XmlSchemaQuick(null, null), new XmlValueQuick(null, null), new XmlTypeQuick(null, null)};
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Locatable.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Locatable.java
new file mode 100644
index 0000000..d895bf4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Locatable.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link Location} that is chained.
+ *
+ * <p>
+ * {@link Locatable} forms a tree structure, where each {@link Locatable}
+ * points back to the upstream {@link Locatable}.
+ * For example, image {@link Locatable} X that points to a particular annotation,
+ * whose upstream is {@link Locatable} Y, which points to a particular method
+ * (on which the annotation is put), whose upstream is {@link Locatable} Z,
+ * which points to a particular class (in which the method is defined),
+ * whose upstream is {@link Locatable} W,
+ * which points to another class (which refers to the class Z), and so on.
+ *
+ * <p>
+ * This chain will be turned into a list when we report the error to users.
+ * This allows them to know where the error happened
+ * and why that place became relevant.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Locatable {
+    /**
+     * Gets the upstream {@link Location} information.
+     *
+     * @return
+     *      can be null.
+     */
+    Locatable getUpstream();
+
+    /**
+     * Gets the location object that this object points to.
+     *
+     * This operation could be inefficient and costly.
+     */
+    Location getLocation();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/LocatableAnnotation.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/LocatableAnnotation.java
new file mode 100644
index 0000000..405e098
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/LocatableAnnotation.java
@@ -0,0 +1,120 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import java.lang.reflect.InvocationHandler;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.lang.reflect.Proxy;
+import java.util.HashMap;
+import java.util.Map;
+
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link Annotation} that also implements {@link Locatable}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class LocatableAnnotation implements InvocationHandler, Locatable, Location {
+    private final Annotation core;
+
+    private final Locatable upstream;
+
+    /**
+     * Wraps the annotation into a proxy so that the returned object will also implement
+     * {@link Locatable}.
+     */
+    public static <A extends Annotation> A create( A annotation, Locatable parentSourcePos ) {
+        if(annotation==null)    return null;
+        Class<? extends Annotation> type = annotation.annotationType();
+        if(quicks.containsKey(type)) {
+            // use the existing proxy implementation if available
+            return (A)quicks.get(type).newInstance(parentSourcePos,annotation);
+        }
+
+        // otherwise take the slow route
+
+        ClassLoader cl = LocatableAnnotation.class.getClassLoader();
+
+        try {
+            Class loadableT = Class.forName(type.getName(), false, cl);
+            if(loadableT !=type)
+                return annotation;  // annotation type not loadable from this class loader
+
+            return (A)Proxy.newProxyInstance(cl,
+                    new Class[]{ type, Locatable.class },
+                    new LocatableAnnotation(annotation,parentSourcePos));
+        } catch (ClassNotFoundException e) {
+            // annotation not loadable
+            return annotation;
+        }
+
+    }
+
+    LocatableAnnotation(Annotation core, Locatable upstream) {
+        this.core = core;
+        this.upstream = upstream;
+    }
+
+    public Locatable getUpstream() {
+        return upstream;
+    }
+
+    public Location getLocation() {
+        return this;
+    }
+
+    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
+        try {
+            if(method.getDeclaringClass()==Locatable.class)
+                return method.invoke(this,args);
+            else
+                return method.invoke(core,args);
+        } catch (InvocationTargetException e) {
+            if(e.getTargetException()!=null)
+                throw e.getTargetException();
+            throw e;
+        }
+    }
+
+    public String toString() {
+        return core.toString();
+    }
+
+
+    /**
+     * List of {@link Quick} implementations keyed by their annotation type.
+     */
+    private static final Map<Class,Quick> quicks = new HashMap<Class, Quick>();
+
+    static {
+        for( Quick q : Init.getAll() ) {
+            quicks.put(q.annotationType(),q);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Messages.java
new file mode 100644
index 0000000..05f1a2d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Messages.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources
+ */
+enum Messages {
+    // AnnotationParser
+    DUPLICATE_ANNOTATIONS,
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Messages.properties
new file mode 100644
index 0000000..319a34f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Messages.properties
@@ -0,0 +1,3 @@
+DUPLICATE_ANNOTATIONS = \
+    Annotation "{0}" is present on both "{1}" and "{2}"
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/MethodLocatable.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/MethodLocatable.java
new file mode 100644
index 0000000..2c44c46
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/MethodLocatable.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link Locatable} implementation for a method.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodLocatable<M> implements Locatable {
+    private final Locatable upstream;
+    private final M method;
+    private final Navigator<?,?,?,M> nav;
+
+    public MethodLocatable(Locatable upstream, M method, Navigator<?,?,?,M> nav) {
+        this.upstream = upstream;
+        this.method = method;
+        this.nav = nav;
+    }
+
+    public Locatable getUpstream() {
+        return upstream;
+    }
+
+    public Location getLocation() {
+        return nav.getMethodLocation(method);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Quick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Quick.java
new file mode 100644
index 0000000..2fd0ea4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/Quick.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * Base implementation of {@link Locatable} {@link Annotation}.
+ *
+ * <p>
+ * Derived classes of this class is provided for annotations that are commonly
+ * used in JAXB, to improve the performance of {@link LocatableAnnotation#create}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public /*so that our code generator can refer to this class*/ abstract class Quick implements Annotation, Locatable, Location {
+    private final Locatable upstream;
+
+    protected Quick(Locatable upstream) {
+        this.upstream = upstream;
+    }
+
+    /**
+     * Gets the annotation object that this object is wrapping.
+     */
+    protected abstract Annotation getAnnotation();
+
+    /**
+     * Factory method to create a new instance of the same kind.
+     * A {@link Quick} object also works as a factory of itself
+     */
+    protected abstract Quick newInstance( Locatable upstream, Annotation core );
+
+    public final Location getLocation() {
+        return this;
+    }
+
+    public final Locatable getUpstream() {
+        return upstream;
+    }
+
+    public final String toString() {
+        return getAnnotation().toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/RuntimeAnnotationReader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/RuntimeAnnotationReader.java
new file mode 100644
index 0000000..961ff0b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/RuntimeAnnotationReader.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeAnnotationReader extends AnnotationReader<Type,Class,Field,Method> {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/RuntimeInlineAnnotationReader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/RuntimeInlineAnnotationReader.java
new file mode 100644
index 0000000..12b356c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/RuntimeInlineAnnotationReader.java
@@ -0,0 +1,133 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Field;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * {@link AnnotationReader} that uses {@code java.lang.reflect} to
+ * read annotations from class files.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public final class RuntimeInlineAnnotationReader extends AbstractInlineAnnotationReaderImpl<Type,Class,Field,Method>
+    implements RuntimeAnnotationReader {
+
+    public <A extends Annotation> A getFieldAnnotation(Class<A> annotation, Field field, Locatable srcPos) {
+        return LocatableAnnotation.create(field.getAnnotation(annotation),srcPos);
+    }
+
+    public boolean hasFieldAnnotation(Class<? extends Annotation> annotationType, Field field) {
+        return field.isAnnotationPresent(annotationType);
+    }
+
+    public Annotation[] getAllFieldAnnotations(Field field, Locatable srcPos) {
+        Annotation[] r = field.getAnnotations();
+        for( int i=0; i<r.length; i++ ) {
+            r[i] = LocatableAnnotation.create(r[i],srcPos);
+        }
+        return r;
+    }
+
+    public <A extends Annotation> A getMethodAnnotation(Class<A> annotation, Method method, Locatable srcPos) {
+        return LocatableAnnotation.create(method.getAnnotation(annotation),srcPos);
+    }
+
+    public boolean hasMethodAnnotation(Class<? extends Annotation> annotation, Method method) {
+        return method.isAnnotationPresent(annotation);
+    }
+
+    public Annotation[] getAllMethodAnnotations(Method method, Locatable srcPos) {
+        Annotation[] r = method.getAnnotations();
+        for( int i=0; i<r.length; i++ ) {
+            r[i] = LocatableAnnotation.create(r[i],srcPos);
+        }
+        return r;
+    }
+
+    public <A extends Annotation> A getMethodParameterAnnotation(Class<A> annotation, Method method, int paramIndex, Locatable srcPos) {
+        Annotation[] pa = method.getParameterAnnotations()[paramIndex];
+        for( Annotation a : pa ) {
+            if(a.annotationType()==annotation)
+                return LocatableAnnotation.create((A)a,srcPos);
+        }
+        return null;
+    }
+
+    public <A extends Annotation> A getClassAnnotation(Class<A> a, Class clazz, Locatable srcPos) {
+        return LocatableAnnotation.create(((Class<?>)clazz).getAnnotation(a),srcPos);
+    }
+
+
+    /**
+     * Cache for package-level annotations.
+     */
+    private final Map<Class<? extends Annotation>,Map<Package,Annotation>> packageCache =
+            new HashMap<Class<? extends Annotation>,Map<Package,Annotation>>();
+
+    public <A extends Annotation> A getPackageAnnotation(Class<A> a, Class clazz, Locatable srcPos) {
+        Package p = clazz.getPackage();
+        if(p==null) return null;
+
+        Map<Package,Annotation> cache = packageCache.get(a);
+        if(cache==null) {
+            cache = new HashMap<Package,Annotation>();
+            packageCache.put(a,cache);
+        }
+
+        if(cache.containsKey(p))
+            return (A)cache.get(p);
+        else {
+            A ann = LocatableAnnotation.create(p.getAnnotation(a),srcPos);
+            cache.put(p,ann);
+            return ann;
+        }
+    }
+
+    public Class getClassValue(Annotation a, String name) {
+        try {
+            return (Class)a.annotationType().getMethod(name).invoke(a);
+        } catch (IllegalAccessException e) {
+            // impossible
+            throw new IllegalAccessError(e.getMessage());
+        } catch (InvocationTargetException e) {
+            // impossible
+            throw new InternalError(e.getMessage());
+        } catch (NoSuchMethodException e) {
+            throw new NoSuchMethodError(e.getMessage());
+        }
+    }
+
+    protected String fullName(Method m) {
+        return m.getDeclaringClass().getName()+'#'+m.getName();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlAttributeQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlAttributeQuick.java
new file mode 100644
index 0000000..437750f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlAttributeQuick.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlAttribute;
+
+final class XmlAttributeQuick
+    extends Quick
+    implements XmlAttribute
+{
+
+    private final XmlAttribute core;
+
+    public XmlAttributeQuick(Locatable upstream, XmlAttribute core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlAttributeQuick(upstream, ((XmlAttribute) core));
+    }
+
+    public Class<XmlAttribute> annotationType() {
+        return XmlAttribute.class;
+    }
+
+    public String name() {
+        return core.name();
+    }
+
+    public String namespace() {
+        return core.namespace();
+    }
+
+    public boolean required() {
+        return core.required();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementDeclQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementDeclQuick.java
new file mode 100644
index 0000000..59134c9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementDeclQuick.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlElementDecl;
+
+final class XmlElementDeclQuick
+    extends Quick
+    implements XmlElementDecl
+{
+
+    private final XmlElementDecl core;
+
+    public XmlElementDeclQuick(Locatable upstream, XmlElementDecl core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlElementDeclQuick(upstream, ((XmlElementDecl) core));
+    }
+
+    public Class<XmlElementDecl> annotationType() {
+        return XmlElementDecl.class;
+    }
+
+    public String name() {
+        return core.name();
+    }
+
+    public String namespace() {
+        return core.namespace();
+    }
+
+    public String defaultValue() {
+        return core.defaultValue();
+    }
+
+    public Class scope() {
+        return core.scope();
+    }
+
+    public String substitutionHeadNamespace() {
+        return core.substitutionHeadNamespace();
+    }
+
+    public String substitutionHeadName() {
+        return core.substitutionHeadName();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementQuick.java
new file mode 100644
index 0000000..a2ac960
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementQuick.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlElement;
+
+final class XmlElementQuick
+    extends Quick
+    implements XmlElement
+{
+
+    private final XmlElement core;
+
+    public XmlElementQuick(Locatable upstream, XmlElement core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlElementQuick(upstream, ((XmlElement) core));
+    }
+
+    public Class<XmlElement> annotationType() {
+        return XmlElement.class;
+    }
+
+    public String name() {
+        return core.name();
+    }
+
+    public Class type() {
+        return core.type();
+    }
+
+    public String namespace() {
+        return core.namespace();
+    }
+
+    public String defaultValue() {
+        return core.defaultValue();
+    }
+
+    public boolean required() {
+        return core.required();
+    }
+
+    public boolean nillable() {
+        return core.nillable();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementRefQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementRefQuick.java
new file mode 100644
index 0000000..5faa75a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementRefQuick.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlElementRef;
+
+final class XmlElementRefQuick
+    extends Quick
+    implements XmlElementRef
+{
+
+    private final XmlElementRef core;
+
+    public XmlElementRefQuick(Locatable upstream, XmlElementRef core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlElementRefQuick(upstream, ((XmlElementRef) core));
+    }
+
+    public Class<XmlElementRef> annotationType() {
+        return XmlElementRef.class;
+    }
+
+    public String name() {
+        return core.name();
+    }
+
+    public Class type() {
+        return core.type();
+    }
+
+    public String namespace() {
+        return core.namespace();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementRefsQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementRefsQuick.java
new file mode 100644
index 0000000..fa3de58
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlElementRefsQuick.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlElementRef;
+import javax.xml.bind.annotation.XmlElementRefs;
+
+final class XmlElementRefsQuick
+    extends Quick
+    implements XmlElementRefs
+{
+
+    private final XmlElementRefs core;
+
+    public XmlElementRefsQuick(Locatable upstream, XmlElementRefs core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlElementRefsQuick(upstream, ((XmlElementRefs) core));
+    }
+
+    public Class<XmlElementRefs> annotationType() {
+        return XmlElementRefs.class;
+    }
+
+    public XmlElementRef[] value() {
+        return core.value();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlEnumQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlEnumQuick.java
new file mode 100644
index 0000000..1bb7706
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlEnumQuick.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlEnum;
+
+final class XmlEnumQuick
+    extends Quick
+    implements XmlEnum
+{
+
+    private final XmlEnum core;
+
+    public XmlEnumQuick(Locatable upstream, XmlEnum core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlEnumQuick(upstream, ((XmlEnum) core));
+    }
+
+    public Class<XmlEnum> annotationType() {
+        return XmlEnum.class;
+    }
+
+    public Class value() {
+        return core.value();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlRootElementQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlRootElementQuick.java
new file mode 100644
index 0000000..0aaa98f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlRootElementQuick.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlRootElement;
+
+final class XmlRootElementQuick
+    extends Quick
+    implements XmlRootElement
+{
+
+    private final XmlRootElement core;
+
+    public XmlRootElementQuick(Locatable upstream, XmlRootElement core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlRootElementQuick(upstream, ((XmlRootElement) core));
+    }
+
+    public Class<XmlRootElement> annotationType() {
+        return XmlRootElement.class;
+    }
+
+    public String name() {
+        return core.name();
+    }
+
+    public String namespace() {
+        return core.namespace();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlSchemaQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlSchemaQuick.java
new file mode 100644
index 0000000..dac134f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlSchemaQuick.java
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlNs;
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.bind.annotation.XmlSchema;
+
+final class XmlSchemaQuick
+    extends Quick
+    implements XmlSchema
+{
+
+    private final XmlSchema core;
+
+    public XmlSchemaQuick(Locatable upstream, XmlSchema core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlSchemaQuick(upstream, ((XmlSchema) core));
+    }
+
+    public Class<XmlSchema> annotationType() {
+        return XmlSchema.class;
+    }
+
+    public String namespace() {
+        return core.namespace();
+    }
+
+    public XmlNs[] xmlns() {
+        return core.xmlns();
+    }
+
+    public XmlNsForm elementFormDefault() {
+        return core.elementFormDefault();
+    }
+
+    public XmlNsForm attributeFormDefault() {
+        return core.attributeFormDefault();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlTransientQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlTransientQuick.java
new file mode 100644
index 0000000..ebca8e5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlTransientQuick.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlTransient;
+
+final class XmlTransientQuick
+    extends Quick
+    implements XmlTransient
+{
+
+    private final XmlTransient core;
+
+    public XmlTransientQuick(Locatable upstream, XmlTransient core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlTransientQuick(upstream, ((XmlTransient) core));
+    }
+
+    public Class<XmlTransient> annotationType() {
+        return XmlTransient.class;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlTypeQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlTypeQuick.java
new file mode 100644
index 0000000..f2458d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlTypeQuick.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlType;
+
+final class XmlTypeQuick
+    extends Quick
+    implements XmlType
+{
+
+    private final XmlType core;
+
+    public XmlTypeQuick(Locatable upstream, XmlType core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlTypeQuick(upstream, ((XmlType) core));
+    }
+
+    public Class<XmlType> annotationType() {
+        return XmlType.class;
+    }
+
+    public String name() {
+        return core.name();
+    }
+
+    public String namespace() {
+        return core.namespace();
+    }
+
+    public String[] propOrder() {
+        return core.propOrder();
+    }
+
+    public Class factoryClass() {
+        return core.factoryClass();
+    }
+
+    public String factoryMethod() {
+        return core.factoryMethod();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlValueQuick.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlValueQuick.java
new file mode 100644
index 0000000..034b9ce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/XmlValueQuick.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.model.annotation;
+
+import java.lang.annotation.Annotation;
+import javax.xml.bind.annotation.XmlValue;
+
+final class XmlValueQuick
+    extends Quick
+    implements XmlValue
+{
+
+    private final XmlValue core;
+
+    public XmlValueQuick(Locatable upstream, XmlValue core) {
+        super(upstream);
+        this.core = core;
+    }
+
+    protected Annotation getAnnotation() {
+        return core;
+    }
+
+    protected Quick newInstance(Locatable upstream, Annotation core) {
+        return new XmlValueQuick(upstream, ((XmlValue) core));
+    }
+
+    public Class<XmlValue> annotationType() {
+        return XmlValue.class;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/package.html b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/package.html
new file mode 100644
index 0000000..0f980ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/annotation/package.html
@@ -0,0 +1,3 @@
+<html><body>
+  Abstraction around reading annotations, to support internal/external annotations.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Adapter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Adapter.java
new file mode 100644
index 0000000..3512c81
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Adapter.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+
+/**
+ * {@link Adapter} that wraps {@link XmlJavaTypeAdapter}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class Adapter<TypeT,ClassDeclT> {
+    /**
+     * The adapter class. Always non-null.
+     *
+     * A class that derives from {@link javax.xml.bind.annotation.adapters.XmlAdapter}.
+     */
+    public final ClassDeclT adapterType;
+
+    /**
+     * The type that the JAXB can handle natively.
+     * The <tt>Default</tt> parameter of <tt>XmlAdapter&lt;Default,Custom></tt>.
+     *
+     * Always non-null.
+     */
+    public final TypeT defaultType;
+
+    /**
+     * The type that is stored in memory.
+     * The <tt>Custom</tt> parameter of <tt>XmlAdapter&lt;Default,Custom></tt>.
+     */
+    public final TypeT customType;
+
+
+
+    public Adapter(
+        XmlJavaTypeAdapter spec,
+        AnnotationReader<TypeT,ClassDeclT,?,?> reader,
+        Navigator<TypeT,ClassDeclT,?,?> nav) {
+
+        this( nav.asDecl(reader.getClassValue(spec,"value")), nav );
+    }
+
+    public Adapter(ClassDeclT adapterType,Navigator<TypeT,ClassDeclT,?,?> nav) {
+        this.adapterType = adapterType;
+        TypeT baseClass = nav.getBaseClass(nav.use(adapterType), nav.asDecl(XmlAdapter.class));
+
+        // because the parameterization of XmlJavaTypeAdapter requires that the class derives from XmlAdapter.
+        assert baseClass!=null;
+
+        if(nav.isParameterizedType(baseClass))
+            defaultType = nav.getTypeArgument(baseClass,0);
+        else
+            defaultType = nav.ref(Object.class);
+
+        if(nav.isParameterizedType(baseClass))
+            customType = nav.getTypeArgument(baseClass,1);
+        else
+            customType = nav.ref(Object.class);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ArrayInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ArrayInfo.java
new file mode 100644
index 0000000..4cb64ed
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ArrayInfo.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+/**
+ * Stand-alone array that can be marshalled/unmarshalled on its own
+ * (without being part of any encloding {@link ClassInfo}.)
+ *
+ * <p>
+ * Most of the times arrays are treated as properties of their enclosing classes,
+ * but sometimes we do need to map an array class to its own XML type.
+ * This object is used for that purpose.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface ArrayInfo<T,C> extends NonElement<T,C> {
+    /**
+     * T of T[]. The type of the items of the array.
+     *
+     * @return  never null
+     */
+    NonElement<T,C> getItemType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/AttributePropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/AttributePropertyInfo.java
new file mode 100644
index 0000000..5d6e44b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/AttributePropertyInfo.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Attribute {@link PropertyInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface AttributePropertyInfo<T,C> extends PropertyInfo<T,C>, NonElementRef<T,C> {
+    /**
+     * Gets the type of the attribute.
+     *
+     * <p>
+     * Note that when this property is a collection, this method returns
+     * the type of each item in the collection.
+     *
+     * @return
+     *      always non-null.
+     */
+    NonElement<T,C> getTarget();
+
+    /**
+     * Returns true if this attribute is mandatory.
+     */
+    boolean isRequired();
+
+    /**
+     * Gets the attribute name.
+     *
+     * @return
+     *      must be non-null.
+     */
+    QName getXmlName();
+
+    Adapter<T,C> getAdapter();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/BuiltinLeafInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/BuiltinLeafInfo.java
new file mode 100644
index 0000000..d0344fb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/BuiltinLeafInfo.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.namespace.QName;
+
+/**
+ * JAXB spec designates a few Java classes to be mapped to leaves in XML.
+ *
+ * <p>
+ * Built-in leaves also have another priviledge; specifically, they often
+ * have more than one XML type names associated with it.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface BuiltinLeafInfo<T,C> extends LeafInfo<T,C> {
+    /**
+     * {@inheritDoc}
+     *
+     * <p>
+     * This method returns the 'primary' type name of this built-in leaf,
+     * which should be used when values of this type are marshalled.
+     *
+     * @return
+     *      never null.
+     */
+    public QName getTypeName();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ClassInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ClassInfo.java
new file mode 100644
index 0000000..41506a8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ClassInfo.java
@@ -0,0 +1,175 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.util.List;
+
+import javax.xml.bind.annotation.XmlTransient;
+
+/**
+ * Information about JAXB-bound class.
+ *
+ * <p>
+ * All the JAXB annotations are already reflected to the model so that
+ * the caller doesn't have to worry about them. For this reason, you
+ * cannot access annotations on properties.
+ *
+ * <h2>XML representation</h2>
+ * <p>
+ * A JAXB-bound class always have at least one representation
+ * (called "type representation"),but it can optionally have another
+ * representation ("element representation").
+ *
+ * <p>
+ * In the type representaion, a class
+ * is represented as a set of attributes and (elements or values).
+ * You can inspect the details of those attributes/elements/values by {@link #getProperties()}.
+ * This representation corresponds to a complex/simple type in XML Schema.
+ * You can obtain the schema type name by {@link #getTypeName()}.
+ *
+ * <p>
+ * If a class has an element representation, {@link #isElement()} returns true.
+ * This representation is mostly similar to the type representation
+ * except that the whoe attributes/elements/values are wrapped into
+ * one element. You can obtain the name of this element through {@link #asElement()}.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface ClassInfo<T,C> extends MaybeElement<T,C> {
+
+    /**
+     * Obtains the information about the base class.
+     *
+     * @return null
+     *      if this info extends from {@link Object}.
+     */
+    ClassInfo<T,C> getBaseClass();
+
+    /**
+     * Gets the declaration this object is wrapping.
+     */
+    C getClazz();
+
+    /**
+     * Gets the fully-qualified name of the class.
+     */
+    String getName();
+
+    /**
+     * Returns all the properties newly declared in this class.
+     *
+     * <p>
+     * This excludes properties defined in the super class.
+     *
+     * <p>
+     * If the properties are {@link #isOrdered() ordered},
+     * it will be returned in the order that appear in XML.
+     * Otherwise it will be returned in no particular order.
+     *
+     * <p>
+     * Properties marked with {@link XmlTransient} will not show up
+     * in this list. As far as JAXB is concerned, they are considered
+     * non-existent.
+     *
+     * @return
+     *      always non-null, but can be empty.
+     */
+    List<? extends PropertyInfo<T,C>> getProperties();
+
+    /**
+     * Gets the property that has the specified name.
+     *
+     * <p>
+     * This is just a convenience method for:
+     * <pre>
+     * for( PropertyInfo p : getProperties() ) {
+     *   if(p.getName().equals(name))
+     *     return p;
+     * }
+     * return null;
+     * </pre>
+     *
+     * @return null
+     *      if the property was not found.
+     *
+     * @see PropertyInfo#getName()
+     */
+    PropertyInfo<T,C> getProperty(String name);
+
+    /**
+     * If the class has properties, return true.  This is only
+     * true if the Collection object returned by {@link #getProperties()}
+     * is not empty.
+     */
+    boolean hasProperties();
+
+    /**
+     * If this class is abstract and thus shall never be directly instanciated.
+     */
+    boolean isAbstract();
+
+    /**
+     * Returns true if the properties of this class is ordered in XML.
+     * False if it't not.
+     *
+     * <p>
+     * In RELAX NG context, ordered properties mean &lt;group> and
+     * unordered properties mean &lt;interleave>.
+     */
+    boolean isOrdered();
+
+    /**
+     * If this class is marked as final and no further extension/restriction is allowed.
+     */
+    boolean isFinal();
+
+    /**
+     * True if there's a known sub-type of this class in {@link TypeInfoSet}.
+     */
+    boolean hasSubClasses();
+
+    /**
+     * Returns true if this bean class has an attribute wildcard.
+     *
+     * <p>
+     * This is true if the class declares an attribute wildcard,
+     * or it is inherited from its super classes.
+     *
+     * @see #inheritsAttributeWildcard()
+     */
+    boolean hasAttributeWildcard();
+
+    /**
+     * Returns true iff this class inherits a wildcard attribute
+     * from its ancestor classes.
+     */
+    boolean inheritsAttributeWildcard();
+
+    /**
+     * Returns true iff this class declares a wildcard attribute.
+     */
+    boolean declaresAttributeWildcard();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Element.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Element.java
new file mode 100644
index 0000000..a51429f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Element.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.namespace.QName;
+
+/**
+ * {@link TypeInfo} that maps to an element.
+ *
+ * Either {@link ElementInfo} or {@link ClassInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Element<T,C> extends TypeInfo<T,C> {
+    /**
+     * Gets the element name of the class.
+     *
+     * @return
+     *      Always non-null.
+     */
+    QName getElementName();
+
+    /**
+     * If this element can substitute another element, return that element.
+     *
+     * <p>
+     * Substitutability of elements are transitive.
+     *
+     * @return
+     *      null if no such element exists.
+     */
+    Element<T,C> getSubstitutionHead();
+
+    /**
+     * If non-null, this element is only active inside the given scope.
+     */
+    ClassInfo<T,C> getScope();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ElementInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ElementInfo.java
new file mode 100644
index 0000000..6d2c029
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ElementInfo.java
@@ -0,0 +1,97 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.util.Collection;
+
+import javax.xml.bind.JAXBElement;
+
+/**
+ * A particular use (specialization) of {@link JAXBElement}.
+ *
+ * TODO: is ElementInfo adaptable?
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface ElementInfo<T,C> extends Element<T,C> {
+
+    /**
+     * Gets the object that represents the value property.
+     *
+     * @return
+     *      non-null.
+     */
+    ElementPropertyInfo<T,C> getProperty();
+
+    /**
+     * Short for <code>getProperty().ref().get(0)</code>.
+     *
+     * The type of the value this element holds.
+     *
+     * Normally, this is the T of {@code JAXBElement<T>}.
+     * But if the property is adapted, this is the on-the-wire type.
+     *
+     * Or if the element has a list of values, then this field
+     * represents the type of the individual item.
+     *
+     * @see #getContentInMemoryType()
+     */
+    NonElement<T,C> getContentType();
+
+    /**
+     * T of {@code JAXBElement<T>}.
+     *
+     * <p>
+     * This is tied to the in-memory representation.
+     *
+     * @see #getContentType()
+     */
+    T getContentInMemoryType();
+
+    /**
+     * Returns the representation for {@link JAXBElement}&lt;<i>contentInMemoryType</i>&gt;.
+     *
+     * <p>
+     * This returns the signature in Java and thus isn't affected by the adapter.
+     */
+    T getType();
+
+    /**
+     * @inheritDoc
+     *
+     * {@link ElementInfo} can only substitute {@link ElementInfo}.
+     */
+    ElementInfo<T,C> getSubstitutionHead();
+
+    /**
+     * All the {@link ElementInfo}s whose {@link #getSubstitutionHead()} points
+     * to this object.
+     *
+     * @return
+     *      can be empty but never null.
+     */
+    Collection<? extends ElementInfo<T,C>> getSubstitutionMembers();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ElementPropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ElementPropertyInfo.java
new file mode 100644
index 0000000..500457f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ElementPropertyInfo.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Property that maps to an element.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+// TODO: there seems to be too much interactions between switches, and that's no good.
+public interface ElementPropertyInfo<T,C> extends PropertyInfo<T,C> {
+    /**
+     * Returns the information about the types allowed in this property.
+     *
+     * <p>
+     * In a simple case like the following, an element property only has
+     * one {@link TypeRef} that points to {@link String} and tag name "foo".
+     * <pre>
+     * &#64;XmlElement
+     * String abc;
+     * </pre>
+     *
+     * <p>
+     * However, in a general case an element property can be heterogeneous,
+     * meaning you can put different types in it, each with a different tag name
+     * (and a few other settings.)
+     * <pre>
+     * // list can contain String or Integer.
+     * &#64;XmlElements({
+     *   &#64;XmlElement(name="a",type=String.class),
+     *   &#64;XmlElement(name="b",type=Integer.class),
+     * })
+     * List&lt;Object> abc;
+     * </pre>
+     * <p>
+     * In this case this method returns a list of two {@link TypeRef}s.
+     *
+     *
+     * @return
+     *      Always non-null. Contains at least one entry.
+     *      If {@link #isValueList()}==true, there's always exactly one type.
+     */
+    List<? extends TypeRef<T,C>> getTypes();
+
+    /**
+     * Gets the wrapper element name.
+     *
+     * @return
+     *      must be null if {@link #isCollection()}==false or
+     *      if {@link #isValueList()}==true.
+     *
+     *      Otherwise,
+     *      this can be null (in which case there'll be no wrapper),
+     *      or it can be non-null (in which case there'll be a wrapper)
+     */
+    QName getXmlName();
+
+    /**
+     * Returns true if this property is nillable
+     * (meaning the absence of the value is treated as nil='true')
+     *
+     * <p>
+     * This method is only used when this property is a collection.
+     */
+    boolean isCollectionNillable();
+
+    /**
+     * Returns true if this property is a collection but its XML
+     * representation is a list of values, not repeated elements.
+     *
+     * <p>
+     * If {@link #isCollection()}==false, this property is always false.
+     *
+     * <p>
+     * When this flag is true, <tt>getTypes().size()==1</tt> always holds.
+     */
+    boolean isValueList();
+
+    /**
+     * Returns true if this element is mandatory.
+     *
+     * For collections, this property isn't used.
+     * TODO: define the semantics when this is a collection
+     */
+    boolean isRequired();
+
+    Adapter<T,C> getAdapter();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/EnumConstant.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/EnumConstant.java
new file mode 100644
index 0000000..a25baea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/EnumConstant.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.bind.annotation.XmlEnumValue;
+
+/**
+ * Individual constant of an enumeration.
+ *
+ * <p>
+ * Javadoc in this class uses the following sample to explain the semantics:
+ * <pre>
+ * &#64;XmlEnum(Integer.class)
+ * enum Foo {
+ *   &#64;XmlEnumValue("1")
+ *   ONE,
+ *   &#64;XmlEnumValue("2")
+ *   TWO
+ * }
+ * </pre>
+ *
+ * @see EnumLeafInfo
+ * @author Kohsuke Kawaguchi
+ */
+public interface EnumConstant<T,C> {
+
+    /**
+     * Gets the {@link EnumLeafInfo} to which this constant belongs to.
+     *
+     * @return never null.
+     */
+    EnumLeafInfo<T,C> getEnclosingClass();
+
+    /**
+     * Lexical value of this constant.
+     *
+     * <p>
+     * This value should be evaluated against
+     * {@link EnumLeafInfo#getBaseType()} to obtain the typed value.
+     *
+     * <p>
+     * This is the same value as written in the {@link XmlEnumValue} annotation.
+     * In the above example, this method returns "1" and "2".
+     *
+     * @return
+     *      never null.
+     */
+    String getLexicalValue();
+
+    /**
+     * Gets the constant name.
+     *
+     * <p>
+     * In the above example this method return "ONE" and "TWO".
+     *
+     * @return
+     *      never null. A valid Java identifier.
+     */
+    String getName();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/EnumLeafInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/EnumLeafInfo.java
new file mode 100644
index 0000000..6a074cb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/EnumLeafInfo.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+/**
+ * {@link NonElement} that represents an {@link Enum} class.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface EnumLeafInfo<T,C> extends LeafInfo<T,C> {
+    /**
+     * The same as {@link #getType()} but an {@link EnumLeafInfo}
+     * is guaranteed to represent an enum declaration, which is a
+     * kind of a class declaration.
+     *
+     * @return
+     *      always non-null.
+     */
+    C getClazz();
+
+    /**
+     * Returns the base type of the enumeration.
+     *
+     * <p>
+     * For example, with the following enum class, this method
+     * returns {@link BuiltinLeafInfo} for {@link Integer}.
+     *
+     * <pre>
+     * &amp;XmlEnum(Integer.class)
+     * enum Foo {
+     *   &amp;XmlEnumValue("1")
+     *   ONE,
+     *   &amp;XmlEnumValue("2")
+     *   TWO
+     * }
+     * </pre>
+     *
+     * @return
+     *      never null.
+     */
+    NonElement<T,C> getBaseType();
+
+    /**
+     * Returns the read-only list of enumeration constants.
+     *
+     * @return
+     *      never null. Can be empty (really?).
+     */
+    Iterable<? extends EnumConstant> getConstants();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ErrorHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ErrorHandler.java
new file mode 100644
index 0000000..b87a2aa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ErrorHandler.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import com.sun.xml.internal.bind.v2.model.impl.ModelBuilder;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+
+/**
+ * listen to static errors found during building a JAXB model from a set of classes.
+ * Implemented by the client of {@link ModelBuilder}.
+ *
+ * <p>
+ * All the static errors have to be reported while constructing a
+ * model, not when a model is used (IOW, until the {@link ModelBuilder#link} completes.
+ * Internally, {@link ModelBuilder} wraps an {@link ErrorHandler} and all the model
+ * components should report errors through it.
+ *
+ * <p>
+ * {@link IllegalAnnotationException} is a checked exception to remind
+ * the model classes to report it rather than to throw it.
+ *
+ * @see ModelBuilder
+ * @author Kohsuke Kawaguchi
+ */
+public interface ErrorHandler {
+    /**
+     * Receives a notification for an error in the annotated code.
+     */
+    void error( IllegalAnnotationException e );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ID.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ID.java
new file mode 100644
index 0000000..2f448b1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ID.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public enum ID {
+    ID,IDREF,NONE
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/LeafInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/LeafInfo.java
new file mode 100644
index 0000000..4c16d93
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/LeafInfo.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+/**
+ * Either {@link BuiltinLeafInfo} or {@link EnumLeafInfo}.
+ *
+ * <p>
+ * Those Java types are all mapped to a chunk of text, so we call
+ * them "leaves".
+ * This interface represents the mapping information for those
+ * special Java types.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface LeafInfo<T,C> extends MaybeElement<T,C> {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/MapPropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/MapPropertyInfo.java
new file mode 100644
index 0000000..03dbc06
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/MapPropertyInfo.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Property that maps to the following schema fragment.
+ *
+ * <pre><xmp>
+ * <xs:complexType>
+ *   <xs:sequence>
+ *     <xs:element name="entry" minOccurs="0" maxOccurs="unbounded">
+ *       <xs:complexType>
+ *         <xs:sequence>
+ *           <xs:element name="key"   type="XXXX"/>
+ *           <xs:element name="value" type="YYYY"/>
+ *         </xs:sequence>
+ *       </xs:complexType>
+ *     </xs:element>
+ *   </xs:sequence>
+ * </xs:complexType>
+ * </xmp></pre>
+ *
+ * <p>
+ * This property is used to represent a default binding of a {@link Map} property.
+ * ({@link Map} properties with adapters will be represented by {@link ElementPropertyInfo}.)
+ *
+ *
+ * <h2>Design Thinking Led to This</h2>
+ * <p>
+ * I didn't like the idea of adding such a special-purpose {@link PropertyInfo} to a model.
+ * The alternative was to implicitly assume an adapter, and have internal representation of
+ * the Entry class ready.
+ * But the fact that the key type and the value type changes with the parameterization makes
+ * it very difficult to have such a class (especially inside APT, where we can't even generate
+ * classes.)
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface MapPropertyInfo<T,C> extends PropertyInfo<T,C> {
+    /**
+     * Gets the wrapper element name.
+     *
+     * @return
+     *      always non-null.
+     */
+    QName getXmlName();
+
+    /**
+     * Returns true if this property is nillable
+     * (meaning the absence of the value is treated as nil='true')
+     *
+     * <p>
+     * This method is only used when this property is a collection.
+     */
+    boolean isCollectionNillable();
+
+    /**
+     * Type of the key of the map. K of {@code HashMap<K,V>}
+     *
+     * @return never null.
+     */
+    NonElement<T,C> getKeyType();
+
+    /**
+     * Type of the value of the map. V of {@code HashMap<K,V>}
+     *
+     * @return never null.
+     */
+    NonElement<T,C> getValueType();
+
+    // TODO
+    // Adapter<T,C> getKeyAdapter();
+    // Adapter<T,C> getValueAdapter();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/MaybeElement.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/MaybeElement.java
new file mode 100644
index 0000000..81cb3c1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/MaybeElement.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Some {@link NonElement} can optionally be an {@link Element}.
+ *
+ * This interface captures such characteristics.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface MaybeElement<T,C> extends NonElement<T,C> {
+    /**
+     * If the class is bound to an element, return true.
+     *
+     * <p>
+     * Note that when this is true, the class is bound to both an element
+     * and a type.
+     */
+    boolean isElement();
+
+    /**
+     * Gets the element name of the class, if the class is bound
+     * to an element.
+     *
+     * @return
+     *      non-null iff {@link #isElement()}.
+     */
+    QName getElementName();
+
+    /**
+     * Returns the {@link Element} aspect of this {@link ClassInfo}.
+     *
+     * @return
+     *      null if {@link #isElement()}==false, non-null if {@link #isElement()}==true.
+     */
+    Element<T,C> asElement();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/NonElement.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/NonElement.java
new file mode 100644
index 0000000..25ade4d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/NonElement.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.namespace.QName;
+
+/**
+ * {@link TypeInfo} that maps to an element.
+ *
+ * Either {@link LeafInfo} or {@link ClassInfo}.
+ *
+ * TODO: better name.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface NonElement<T,C> extends TypeInfo<T,C> {
+    /**
+     * Gets the primary XML type name of the class.
+     *
+     * <p>
+     * A Java type can be mapped to multiple XML types, but one of them is
+     * considered "primary" and used when we generate a schema.
+     *
+     * @return
+     *      null if the object doesn't have an explicit type name (AKA anonymous.)
+     */
+    QName getTypeName();
+
+    /**
+     * Returns true if this {@link NonElement} maps to text in XML,
+     * without any attribute nor child elements.
+     */
+    boolean isSimpleType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/NonElementRef.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/NonElementRef.java
new file mode 100644
index 0000000..9c623e9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/NonElementRef.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+
+
+/**
+ * Reference to a {@link NonElement}.
+ *
+ * This interface defines properties of a reference.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface NonElementRef<T,C> {
+    /**
+     * Target of the reference.
+     *
+     * @return never null
+     */
+    NonElement<T,C> getTarget();
+
+    /**
+     * Gets the property which is the source of this reference.
+     *
+     * @return never null
+     */
+    PropertyInfo<T,C> getSource();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/PropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/PropertyInfo.java
new file mode 100644
index 0000000..3cbca34
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/PropertyInfo.java
@@ -0,0 +1,151 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.util.Collection;
+
+import javax.activation.MimeType;
+import javax.xml.bind.annotation.XmlID;
+import javax.xml.bind.annotation.XmlIDREF;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.XmlSchemaType;
+import javax.xml.namespace.QName;
+
+import com.sun.istack.internal.Nullable;
+
+/**
+ * Information about a JAXB-bound property.
+ *
+ * <p>
+ * All the JAXB annotations are already incorporated into the model so that
+ * the caller doesn't have to worry about reading them. For this reason, you
+ * cannot access annotations on properties directly.
+ *
+ * TODO: don't we need a visitor?
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface PropertyInfo<T,C> {
+
+    /**
+     * Gets the {@link ClassInfo} or {@link ElementInfo} to which this property belongs.
+     */
+    TypeInfo<T,C> parent();
+
+    /**
+     * Gets the name of the property.
+     *
+     * <p>
+     * For example, "foo" or "bar".
+     * Generally, a property name is different from XML,
+     * (although they are often related, as a property name is often
+     * computed from tag names / attribute names.)
+     * In fact, <b>property names do not directly affect XML</b>.
+     * The property name uniquely identifies a property within a class.
+     *
+     * @see XmlType#propOrder()
+     */
+    String getName();
+
+    /**
+     * Gets the display name of the property.
+     *
+     * <p>
+     * This is a convenience method for
+     * {@code parent().getName()+'#'+getName()}.
+     */
+    String displayName();
+
+    /**
+     * Returns true if this is a multi-valued collection property.
+     * Otherwise false, in which case the property is a single value.
+     */
+    boolean isCollection();
+
+    /**
+     * List of {@link TypeInfo}s that this property references.
+     *
+     * This allows the caller to traverse the reference graph without
+     * getting into the details of each different property type.
+     *
+     * @return
+     *      non-null read-only collection.
+     */
+    Collection<? extends TypeInfo<T,C>> ref();
+
+    /**
+     * Gets the kind of this proeprty.
+     *
+     * @return
+     *      always non-null.
+     */
+    PropertyKind kind();
+
+    /**
+     * @return
+     *      null if the property is not adapted.
+     */
+    Adapter<T,C> getAdapter();
+
+    /**
+     * Returns the IDness of the value of this element.
+     *
+     * @see XmlID
+     * @see XmlIDREF
+     *
+     * @return
+     *      always non-null
+     */
+    ID id();
+
+    /**
+     * Expected MIME type, if any.
+     */
+    MimeType getExpectedMimeType();
+
+    /**
+     * If this is true and this property indeed represents a binary data,
+     * it should be always inlined.
+     */
+    boolean inlineBinaryData();
+
+    /**
+     * The effective value of {@link XmlSchemaType} annotation, if any.
+     *
+     * <p>
+     * If the property doesn't have {@link XmlSchemaType} annotation,
+     * this method returns null.
+     *
+     * <p>
+     * Since a type name is a property of a Java type, not a Java property,
+     * A schema type name of a Java type should be primarily obtained
+     * by using {@link NonElement#getTypeName()}. This method is to correctly
+     * implement the ugly semantics of {@link XmlSchemaType} (namely
+     * when this returns non-null, it overrides the type names of all types
+     * that are in this property.)
+     */
+    @Nullable QName getSchemaType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/PropertyKind.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/PropertyKind.java
new file mode 100644
index 0000000..b9b88d5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/PropertyKind.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.bind.annotation.XmlMimeType;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.XmlInlineBinaryData;
+
+import com.sun.xml.internal.bind.v2.runtime.property.PropertyFactory;
+
+
+/**
+ * An Enum that indicates if the property is
+ * Element, ElementRef, Value, or Attribute.
+ *
+ * <p>
+ * Corresponds to the four different kind of {@link PropertyInfo}.
+ * @author Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+public enum PropertyKind {
+    VALUE(true,false,Integer.MAX_VALUE),
+    ATTRIBUTE(false,false,Integer.MAX_VALUE),
+    ELEMENT(true,true,0),
+    REFERENCE(false,true,1),
+    MAP(false,true,2),
+    ;
+
+    /**
+     * This kind of property can have {@link XmlMimeType} and {@link XmlInlineBinaryData}
+     * annotation with it.
+     */
+    public final boolean canHaveXmlMimeType;
+
+    /**
+     * This kind of properties need to show up in {@link XmlType#propOrder()}.
+     */
+    public final boolean isOrdered;
+
+    /**
+     * {@link PropertyFactory} benefits from having index numbers assigned to
+     * {@link #ELEMENT}, {@link #REFERENCE}, and {@link #MAP} in this order.
+     */
+    public final int propertyIndex;
+
+    PropertyKind(boolean canHaveExpectedContentType, boolean isOrdered, int propertyIndex) {
+        this.canHaveXmlMimeType = canHaveExpectedContentType;
+        this.isOrdered = isOrdered;
+        this.propertyIndex = propertyIndex;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Ref.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Ref.java
new file mode 100644
index 0000000..a61584d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/Ref.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.bind.annotation.XmlList;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.impl.ModelBuilder;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+
+/**
+ * Reference to a type in a model.
+ *
+ * TODO: isn't there a similarity between this and TypeUse in XJC?
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Ref<T,C> {
+    /**
+     * The type being referenced.
+     * <p>
+     * If the type is adapted, this field is the same as the adapter's default type.
+     */
+    public final T type;
+    /**
+     * If the reference has an adapter, non-null.
+     */
+    public final Adapter<T,C> adapter;
+    /**
+     * If the {@link #type} is an array and it is a value list,
+     * true.
+     */
+    public final boolean valueList;
+
+    public Ref(T type) {
+        this(type,null,false);
+    }
+
+    public Ref(T type, Adapter<T, C> adapter, boolean valueList) {
+        this.adapter = adapter;
+        if(adapter!=null)
+            type=adapter.defaultType;
+        this.type = type;
+        this.valueList = valueList;
+    }
+
+    public Ref(ModelBuilder<T,C,?,?> builder, T type, XmlJavaTypeAdapter xjta, XmlList xl ) {
+        this(builder.reader,builder.nav,type,xjta,xl);
+    }
+
+    public Ref(AnnotationReader<T,C,?,?> reader,
+               Navigator<T,C,?,?> nav,
+               T type, XmlJavaTypeAdapter xjta, XmlList xl ) {
+        Adapter<T,C> adapter=null;
+        if(xjta!=null) {
+            adapter = new Adapter<T,C>(xjta,reader,nav);
+            type = adapter.defaultType;
+        }
+
+        this.type = type;
+        this.adapter = adapter;
+        this.valueList = xl!=null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ReferencePropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ReferencePropertyInfo.java
new file mode 100644
index 0000000..4ae9fe7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ReferencePropertyInfo.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.util.Collection;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+/**
+ * {@link PropertyInfo} that holds references to other {@link Element}s.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface ReferencePropertyInfo<T,C> extends PropertyInfo<T,C> {
+    /**
+     * Returns the information about the possible elements in this property.
+     *
+     * <p>
+     * As of 2004/08/17, the spec only allows you to use different element names
+     * when a property is a collection, but I think there's really no reason
+     * to limit it there --- if the user wants to use a different tag name
+     * for different objects, I don't see why this can be limited to collections.
+     *
+     * <p>
+     * So this is a generalization of the spec. We always allow a property to have
+     * multiple types and use different tag names for it, depending on the actual type.
+     *
+     * <p>
+     * In most of the cases, this collection only contains 1 item. So the runtime system
+     * is encouraged to provide a faster code-path that is optimized toward such cases.
+     *
+     * @return
+     *      Always non-null. Contains at least one entry.
+     */
+    Set<? extends Element<T,C>> getElements();
+
+    /**
+     * {@inheritDoc}.
+     *
+     * If this {@link ReferencePropertyInfo} has a wildcard in it,
+     * then the returned list will contain {@link WildcardTypeInfo}.
+     */
+    Collection<? extends TypeInfo<T,C>> ref();
+
+    /**
+     * Gets the wrapper element name.
+     *
+     * @return
+     *      must be null if not collection. If the property is a collection,
+     *      this can be null (in which case there'll be no wrapper),
+     *      or it can be non-null (in which case there'll be a wrapper)
+     */
+    QName getXmlName();
+
+    /**
+     * Returns true if this property is nillable
+     * (meaning the absence of the value is treated as nil='true')
+     *
+     * <p>
+     * This method is only used when this property is a collection.
+     */
+    boolean isCollectionNillable();
+
+    /**
+     * Returns true if this property can hold {@link String}s to represent
+     * mixed content model.
+     */
+    boolean isMixed();
+
+    /**
+     * If this property supports the wildcard, returns its mode.
+     *
+     * @return null
+     *      if the wildcard is not allowed on this element.
+     */
+    WildcardMode getWildcard();
+
+    /**
+     * If this property supports the wildcard, returns its DOM handler.
+     *
+     * @return null
+     *      if the wildcard is not allowed on this element.
+     */
+    C getDOMHandler();
+
+    Adapter<T,C> getAdapter();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/RegistryInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/RegistryInfo.java
new file mode 100644
index 0000000..03638d6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/RegistryInfo.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.util.Set;
+
+import javax.xml.bind.annotation.XmlRegistry;
+
+import com.sun.xml.internal.bind.v2.model.impl.ModelBuilder;
+
+/**
+ * Represents the information in a class with {@link XmlRegistry} annotaion.
+ *
+ * <p>
+ * This interface is only meant to be used as a return type from {@link ModelBuilder}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface RegistryInfo<T,C> {
+    /**
+     * Returns all the references to other types in this registry.
+     */
+    Set<TypeInfo<T,C>> getReferences();
+
+    /**
+     * Returns the class with {@link XmlRegistry}.
+     */
+    C getClazz();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeInfo.java
new file mode 100644
index 0000000..aaaffc7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeInfo.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.bind.annotation.XmlIDREF;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+
+
+/**
+ * Either {@link ClassInfo}, {@link ElementInfo}, or {@link LeafInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface TypeInfo<T,C> extends Locatable {
+
+    /**
+     * Gets the underlying Java type that object represents.
+     *
+     * @return
+     *      always non-null.
+     */
+    T getType();
+
+    /**
+     * True if this type is a valid target from a property annotated with {@link XmlIDREF}.
+     */
+    boolean canBeReferencedByIDREF();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeInfoSet.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeInfoSet.java
new file mode 100644
index 0000000..e440614
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeInfoSet.java
@@ -0,0 +1,178 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.util.Map;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.annotation.XmlSchema;
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Result;
+
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+
+/**
+ * Root of models.&nbsp;Set of {@link TypeInfo}s.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface TypeInfoSet<T,C,F,M> {
+
+    /**
+     * {@link Navigator} for this model.
+     */
+    Navigator<T,C,F,M> getNavigator();
+
+//  turns out we can't have AnnotationReader in XJC, so it's impossible to have this here.
+//  perhaps we should revisit this in the future.
+//    /**
+//     * {@link AnnotationReader} for this model.
+//     */
+//    AnnotationReader<T,C,F,M> getReader();
+
+    /**
+     * Returns a {@link TypeInfo} for the given type.
+     *
+     * @return
+     *      null if the specified type cannot be bound by JAXB, or
+     *      not known to this set.
+     */
+    NonElement<T,C> getTypeInfo( T type );
+
+    /**
+     * Gets the {@link TypeInfo} for the any type.
+     */
+    NonElement<T,C> getAnyTypeInfo();
+
+    /**
+     * Returns a {@link ClassInfo}, {@link ArrayInfo}, or {@link LeafInfo}
+     * for the given bean.
+     *
+     * <p>
+     * This method is almost like refinement of {@link #getTypeInfo(Object)} except
+     * our C cannot derive from T.
+     *
+     * @return
+     *      null if the specified type is not bound by JAXB or otherwise
+     *      unknown to this set.
+     */
+    NonElement<T,C> getClassInfo( C type );
+
+    /**
+     * Returns all the {@link ArrayInfo}s known to this set.
+     */
+    Map<? extends T,? extends ArrayInfo<T,C>> arrays();
+
+    /**
+     * Returns all the {@link ClassInfo}s known to this set.
+     */
+    Map<C,? extends ClassInfo<T,C>> beans();
+
+    /**
+     * Returns all the {@link BuiltinLeafInfo}s known to this set.
+     */
+    Map<T,? extends BuiltinLeafInfo<T,C>> builtins();
+
+    /**
+     * Returns all the {@link EnumLeafInfo}s known to this set.
+     */
+    Map<C,? extends EnumLeafInfo<T,C>> enums();
+
+    /**
+     * Returns a {@link ElementInfo} for the given element.
+     *
+     * @param scope
+     *      if null, return the info about a global element.
+     *      Otherwise return a local element in the given scope if available,
+     *      then look for a global element next.
+     */
+    ElementInfo<T,C> getElementInfo( C scope, QName name );
+
+    /**
+     * Returns a type information for the given reference.
+     */
+    NonElement<T,C> getTypeInfo(Ref<T,C> ref);
+
+    /**
+     * Returns all  {@link ElementInfo}s in the given scope.
+     *
+     * @param scope
+     *      if non-null, this method only returns the local element mapping.
+     */
+    Map<QName,? extends ElementInfo<T,C>> getElementMappings( C scope );
+
+    /**
+     * Returns all the {@link ElementInfo} known to this set.
+     */
+    Iterable<? extends ElementInfo<T,C>> getAllElements();
+
+
+    /**
+     * Gets all {@link XmlSchema#xmlns()} found in this context for the given namespace URI.
+     *
+     * <p>
+     * This operation is expected to be only used in schema generator, so it can be slow.
+     *
+     * @return
+     *      A map from prefixes to namespace URIs, which should be declared when generating a schema.
+     *      Could be empty but never null.
+     */
+    Map<String,String> getXmlNs(String namespaceUri);
+
+    /**
+     * Gets the reasonable {@link XmlNsForm} for the given namespace URI.
+     *
+     * <p>
+     * The spec doesn't define very precisely what the {@link XmlNsForm} value
+     * for the given namespace would be, so this method is implemented in rather
+     * ad-hoc way. It should work as what most people expect for simple cases.
+     *
+     * @return never null.
+     */
+    XmlNsForm getElementFormDefault(String nsUri);
+
+    /**
+     * Gets the reasonable {@link XmlNsForm} for the given namespace URI.
+     *
+     * <p>
+     * The spec doesn't define very precisely what the {@link XmlNsForm} value
+     * for the given namespace would be, so this method is implemented in rather
+     * ad-hoc way. It should work as what most people expect for simple cases.
+     *
+     * @return never null.
+     */
+    XmlNsForm getAttributeFormDefault(String nsUri);
+
+    /**
+     * Dumps this model into XML.
+     *
+     * For debug only.
+     *
+     * TODO: not sure if this actually works. We don't really know what are T,C.
+     */
+    public void dump( Result out ) throws JAXBException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeRef.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeRef.java
new file mode 100644
index 0000000..158801f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/TypeRef.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Information about a type referenced from {@link ElementPropertyInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface TypeRef<T,C> extends NonElementRef<T,C> {
+    /**
+     * The associated element name.
+     *
+     * @return
+     *      never null.
+     */
+    QName getTagName();
+
+    /**
+     * Returns true if this element is nillable.
+     */
+    boolean isNillable();
+
+    /**
+     * The default value for this element if any.
+     * Otherwise null.
+     */
+    String getDefaultValue();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ValuePropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ValuePropertyInfo.java
new file mode 100644
index 0000000..6e7a88f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/ValuePropertyInfo.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+/**
+ * Value {@link PropertyInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface ValuePropertyInfo<T,C> extends PropertyInfo<T,C>, NonElementRef<T,C> {
+    Adapter<T,C> getAdapter();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/WildcardMode.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/WildcardMode.java
new file mode 100644
index 0000000..3320c1d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/WildcardMode.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+/**
+ * Mode of the wildcard.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public enum WildcardMode {
+    STRICT(false,true), SKIP(true,false), LAX(true,true);
+
+    public final boolean allowDom;
+    public final boolean allowTypedObject;
+
+    WildcardMode(boolean allowDom, boolean allowTypedObject) {
+        this.allowDom = allowDom;
+        this.allowTypedObject = allowTypedObject;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/WildcardTypeInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/WildcardTypeInfo.java
new file mode 100644
index 0000000..45d088c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/WildcardTypeInfo.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.core;
+
+/**
+ * Type referenced as a result of having the wildcard.
+ *
+ * TODO: think about how to gracefully handle the difference between LAX,SKIP, and STRICT.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface WildcardTypeInfo<T,C> extends TypeInfo<T,C> {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/package-info.java
new file mode 100644
index 0000000..459113a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/core/package-info.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * The in-memory model of the JAXB-bound beans.
+ *
+ * <h2>Parameterizations</h2>
+ * <p>
+ * Interfaces in this package are parameterized to work with arbitrary Java reflection library.
+ * This is necessary because the RI needs to work with both the runtime reflection library
+ * ({@link java.lang.reflect}) and the APT.
+ *
+ * <p>
+ * The meaning of parameterizations are as follows:
+ *
+ * <dl>
+ *  <dt><b>T</b>
+ *  <dd>Represents an use of type, such as {@code int}, {@code Foo[]}, or {@code List<Foo>}.
+ *      Corresponds to {@link Type}.
+ *
+ *  <dt><b>C</b>
+ *  <dd>Represents a declaration of a type (that is, class, interface, enum, or annotation.)
+ *      This doesn't include {@code int}, {@code Foo[]}, or {@code List<Foo>}, because
+ *      they don't have corresponding declarations.
+ *      Corresponds to {@link Class} (roughly).
+ *
+ *  <dt><b>F</b>
+ *  <dd>Represents a field.
+ *      Corresponds to {@link Field}.
+ *
+ *  <dt><b>M</b>
+ *  <dd>Represents a method.
+ *      Corresponds to {@link Method}.
+ *
+ * <dt>
+ */
+@XmlSchema(namespace="http://jaxb.dev.java.net/xjc/model",elementFormDefault=QUALIFIED)
+package com.sun.xml.internal.bind.v2.model.core;
+
+import java.lang.reflect.Type;
+import java.lang.reflect.Method;
+import java.lang.reflect.Field;
+
+import javax.xml.bind.annotation.XmlSchema;
+
+import static javax.xml.bind.annotation.XmlNsForm.QUALIFIED;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/AnyTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/AnyTypeImpl.java
new file mode 100644
index 0000000..e1fe7dc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/AnyTypeImpl.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import javax.xml.namespace.QName;
+import javax.xml.bind.annotation.XmlIDREF;
+
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+
+/**
+ * {@link TypeInfo} implementation for <tt>xs:anyType</tt>.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class AnyTypeImpl<T,C> implements NonElement<T,C> {
+
+    private final T type;
+    private final Navigator<T,C,?,?> nav;
+
+    public AnyTypeImpl(Navigator<T,C,?,?> nav) {
+        this.type = nav.ref(Object.class);
+        this.nav = nav;
+    }
+
+    public QName getTypeName() {
+        return name;
+    }
+
+    public T getType() {
+        return type;
+    }
+
+    public Locatable getUpstream() {
+        return null;
+    }
+
+    public boolean isSimpleType() {
+        return false;
+    }
+
+    public Location getLocation() {
+        return nav.getClassLocation(nav.asDecl(Object.class));
+    }
+
+    /**
+     * xs:anyType can be referenced from {@link XmlIDREF}.
+     *
+     * @deprecated
+     *      why are you calling a method whose return value is always known?
+     */
+    public final boolean canBeReferencedByIDREF() {
+        return true;
+    }
+
+    private static final QName name = new QName(WellKnownNamespace.XML_SCHEMA,"anyType");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ArrayInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ArrayInfoImpl.java
new file mode 100644
index 0000000..29e11fe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ArrayInfoImpl.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.ArrayInfo;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ *
+ * <p>
+ * Public because XJC needs to access it
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class ArrayInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    extends TypeInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    implements ArrayInfo<TypeT,ClassDeclT>, Location {
+
+    private final NonElement<TypeT,ClassDeclT> itemType;
+
+    private final QName typeName;
+
+    /**
+     * The representation of T[] in the underlying reflection library.
+     */
+    private final TypeT arrayType;
+
+    public ArrayInfoImpl(ModelBuilder<TypeT,ClassDeclT,FieldT,MethodT> builder,
+                         Locatable upstream, TypeT arrayType) {
+        super(builder, upstream);
+        this.arrayType = arrayType;
+        this.itemType = builder.getTypeInfo(nav().getComponentType(arrayType), this);
+
+        // TODO: check itemType.getTypeName()!=null and report an error
+        QName n = itemType.getTypeName();
+        this.typeName = calcArrayTypeName(n);
+    }
+
+    /**
+     * Computes the type name of the array from that of the item type.
+     */
+    public static final QName calcArrayTypeName(QName n) {
+        String uri;
+        if(n.getNamespaceURI().equals(WellKnownNamespace.XML_SCHEMA)) {
+            TODO.checkSpec("this URI");
+            uri = "http://jaxb.dev.java.net/array";
+        } else
+            uri = n.getNamespaceURI();
+        return new QName(uri,n.getLocalPart()+"Array");
+    }
+
+    public NonElement<TypeT, ClassDeclT> getItemType() {
+        return itemType;
+    }
+
+    public QName getTypeName() {
+        return typeName;
+    }
+
+    public boolean isSimpleType() {
+        return false;
+    }
+
+    public TypeT getType() {
+        return arrayType;
+    }
+
+    /**
+     * Leaf-type cannot be referenced from IDREF.
+     *
+     * @deprecated
+     *      why are you calling a method whose return value is always known?
+     */
+    public final boolean canBeReferencedByIDREF() {
+        return false;
+    }
+
+    public Location getLocation() {
+        return this;
+    }
+    public String toString() {
+        return nav().getTypeName(arrayType);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/AttributePropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/AttributePropertyInfoImpl.java
new file mode 100644
index 0000000..39ea191
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/AttributePropertyInfoImpl.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlSchema;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.bind.v2.model.core.AttributePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class AttributePropertyInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    extends SingleTypePropertyInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    implements AttributePropertyInfo<TypeT,ClassDeclT> {
+
+    private final QName xmlName;
+
+    private final boolean isRequired;
+
+    AttributePropertyInfoImpl(ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> parent, PropertySeed<TypeT,ClassDeclT,FieldT,MethodT> seed ) {
+        super(parent,seed);
+        XmlAttribute att = seed.readAnnotation(XmlAttribute.class);
+        assert att!=null;
+
+        if(att.required())
+            isRequired = true;
+        else isRequired = nav().isPrimitive(getIndividualType());
+
+        this.xmlName = calcXmlName(att);
+    }
+
+    private QName calcXmlName(XmlAttribute att) {
+        String uri;
+        String local;
+
+        uri = att.namespace();
+        local = att.name();
+
+        // compute the default
+        if(local.equals("##default"))
+            local = NameConverter.standard.toVariableName(getName());
+        if(uri.equals("##default")) {
+            XmlSchema xs = reader().getPackageAnnotation( XmlSchema.class, parent.getClazz(), this );
+            // JAX-RPC doesn't want the default namespace URI swapping to take effect to
+            // local "unqualified" elements. UGLY.
+            if(xs!=null) {
+                switch(xs.attributeFormDefault()) {
+                case QUALIFIED:
+                    uri = parent.getTypeName().getNamespaceURI();
+                    if(uri.length()==0)
+                        uri = parent.builder.defaultNsUri;
+                    break;
+                case UNQUALIFIED:
+                case UNSET:
+                    uri = "";
+                }
+            } else
+                uri = "";
+        }
+
+        return new QName(uri.intern(),local.intern());
+    }
+
+    public boolean isRequired() {
+        return isRequired;
+    }
+
+    public final QName getXmlName() {
+        return xmlName;
+    }
+
+    public final PropertyKind kind() {
+        return PropertyKind.ATTRIBUTE;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/BuiltinLeafInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/BuiltinLeafInfoImpl.java
new file mode 100644
index 0000000..16b7ecd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/BuiltinLeafInfoImpl.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.core.BuiltinLeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.LeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+
+/**
+ * JAXB spec designates a few Java classes to be mapped to XML types
+ * in a way that ignores restrictions placed on user-defined beans.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class BuiltinLeafInfoImpl<TypeT,ClassDeclT> extends LeafInfoImpl<TypeT,ClassDeclT> implements BuiltinLeafInfo<TypeT,ClassDeclT> {
+
+    private final QName[] typeNames;
+
+    protected BuiltinLeafInfoImpl(TypeT type, QName... typeNames) {
+        super(type, typeNames.length>0?typeNames[0]:null);
+        this.typeNames = typeNames;
+    }
+
+    /**
+     * Returns all the type names recognized by this bean info.
+     *
+     * @return
+     *      do not modify the returned array.
+     */
+    public final QName[] getTypeNames() {
+        return typeNames;
+    }
+
+    /**
+     * @deprecated always return false at this level.
+     */
+    public final boolean isElement() {
+        return false;
+    }
+
+    /**
+     * @deprecated always return null at this level.
+     */
+    public final QName getElementName() {
+        return null;
+    }
+
+    /**
+     * @deprecated always return null at this level.
+     */
+    public final Element<TypeT,ClassDeclT> asElement() {
+        return null;
+    }
+
+    /**
+     * Creates all the {@link BuiltinLeafInfoImpl}s as specified in the spec.
+     *
+     * {@link LeafInfo}s are all defined by the spec.
+     */
+    public static <TypeT,ClassDeclT>
+    Map<TypeT,BuiltinLeafInfoImpl<TypeT,ClassDeclT>> createLeaves( Navigator<TypeT,ClassDeclT,?,?> nav ) {
+        Map<TypeT,BuiltinLeafInfoImpl<TypeT,ClassDeclT>> leaves = new HashMap<TypeT,BuiltinLeafInfoImpl<TypeT,ClassDeclT>>();
+
+        for( RuntimeBuiltinLeafInfoImpl<?> leaf : RuntimeBuiltinLeafInfoImpl.builtinBeanInfos ) {
+            TypeT t = nav.ref(leaf.getClazz());
+            leaves.put( t, new BuiltinLeafInfoImpl<TypeT,ClassDeclT>(t,leaf.getTypeNames()) );
+        }
+
+        return leaves;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ClassInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ClassInfoImpl.java
new file mode 100644
index 0000000..3ef9e11
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ClassInfoImpl.java
@@ -0,0 +1,1190 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Method;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.LinkedHashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeSet;
+
+import javax.xml.bind.annotation.XmlAccessOrder;
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorOrder;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAnyAttribute;
+import javax.xml.bind.annotation.XmlAnyElement;
+import javax.xml.bind.annotation.XmlAttachmentRef;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlElementRef;
+import javax.xml.bind.annotation.XmlElementRefs;
+import javax.xml.bind.annotation.XmlElementWrapper;
+import javax.xml.bind.annotation.XmlElements;
+import javax.xml.bind.annotation.XmlID;
+import javax.xml.bind.annotation.XmlIDREF;
+import javax.xml.bind.annotation.XmlInlineBinaryData;
+import javax.xml.bind.annotation.XmlList;
+import javax.xml.bind.annotation.XmlMimeType;
+import javax.xml.bind.annotation.XmlMixed;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlSchemaType;
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.XmlValue;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+
+import com.sun.istack.internal.FinalArrayList;
+import com.sun.xml.internal.bind.annotation.XmlLocation;
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.annotation.MethodLocatable;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+
+/**
+ * A part of the {@link ClassInfo} that doesn't depend on a particular
+ * reflection library.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+class ClassInfoImpl<T,C,F,M>
+    extends TypeInfoImpl<T,C,F,M>
+    implements ClassInfo<T,C>, Element<T,C> {
+
+    protected final C clazz;
+
+    /**
+     * @see #getElementName()
+     */
+    private final QName elementName;
+
+    /**
+     * @see #getTypeName()
+     */
+    private final QName typeName;
+
+    /**
+     * Lazily created.
+     *
+     * @see #getProperties()
+     */
+    private FinalArrayList<PropertyInfoImpl<T,C,F,M>> properties;
+
+    /**
+     * The property order.
+     *
+     * null if unordered. {@link #DEFAULT_ORDER} if ordered but the order is defaulted
+     *
+     * @see #isOrdered()
+     */
+    private final String[] propOrder;
+
+    /**
+     * Lazily computed.
+     *
+     * To avoid the cyclic references of the form C1 --base--> C2 --property--> C1.
+     */
+    private ClassInfoImpl<T,C,F,M> baseClass;
+
+    private boolean baseClassComputed = false;
+
+    private boolean hasSubClasses = false;
+
+    /**
+     * If this class has a declared (not inherited) attribute wildcard,  keep the reference
+     * to it.
+     *
+     * This parameter is initialized at the construction time and never change.
+     */
+    protected /*final*/ PropertySeed<T,C,F,M> attributeWildcard;
+
+
+    /**
+     * @see #getFactoryMethod()
+     */
+    private M factoryMethod = null;
+
+    ClassInfoImpl(ModelBuilder<T,C,F,M> builder, Locatable upstream, C clazz) {
+        super(builder,upstream);
+        this.clazz = clazz;
+        assert clazz!=null;
+
+        // compute the element name
+        elementName = parseElementName(clazz);
+
+        // compute the type name
+        XmlType t = reader().getClassAnnotation(XmlType.class,clazz,this);
+        typeName = parseTypeName(clazz,t);
+
+        if(t!=null) {
+            String[] propOrder = t.propOrder();
+            if(propOrder.length==0)
+                this.propOrder = null;   // unordered
+            else {
+                if(propOrder[0].length()==0)
+                    this.propOrder = DEFAULT_ORDER;
+                else
+                    this.propOrder = propOrder;
+            }
+        } else {
+            propOrder = DEFAULT_ORDER;
+        }
+
+        // the class must have the default constructor
+        if (!hasFactoryConstructor(t)){
+            if(!nav().hasDefaultConstructor(clazz)){
+                Messages msg;
+                if(nav().isInterface(clazz))
+                    msg = Messages.CANT_HANDLE_INTERFACE;
+                else
+                    msg = Messages.NO_DEFAULT_CONSTRUCTOR;
+
+                builder.reportError(new IllegalAnnotationException(
+                    msg.format(nav().getClassName(clazz)), this ));
+            }
+        }
+    }
+
+    public ClassInfoImpl<T,C,F,M> getBaseClass() {
+        if(!baseClassComputed) {
+            baseClassComputed = true;
+            // compute the base class
+            C s = nav().getSuperClass(clazz);
+            if(s==null || s==nav().asDecl(Object.class))
+                baseClass = null;
+            else {
+                baseClass = (ClassInfoImpl<T,C,F,M>) builder.getClassInfo(s,this);
+                baseClass.hasSubClasses = true;
+            }
+        }
+        return baseClass;
+    }
+
+    /**
+     * {@inheritDoc}
+     *
+     * The substitution hierarchy is the same as the inheritance hierarchy.
+     */
+    public final Element<T,C> getSubstitutionHead() {
+        ClassInfoImpl<T,C,F,M> c = getBaseClass();
+        while(c!=null && !c.isElement())
+            c = c.getBaseClass();
+        return c;
+    }
+
+    public final C getClazz() {
+        return clazz;
+    }
+
+    /**
+     * When a bean binds to an element, it's always through {@link XmlRootElement},
+     * so this method always return null.
+     *
+     * @deprecated
+     *      you shouldn't be invoking this method on {@link ClassInfoImpl}.
+     */
+    public ClassInfoImpl<T,C,F,M> getScope() {
+        return null;
+    }
+
+    public final T getType() {
+        return nav().use(clazz);
+    }
+
+    /**
+     * A {@link ClassInfo} can be referenced by {@link XmlIDREF} if
+     * it has an ID property.
+     */
+    public boolean canBeReferencedByIDREF() {
+        for (PropertyInfo<T,C> p : getProperties()) {
+            if(p.id()== ID.ID)
+                return true;
+        }
+        ClassInfoImpl<T, C, F, M> base = getBaseClass();
+        if(base!=null)
+            return base.canBeReferencedByIDREF();
+        else
+            return false;
+    }
+
+    public final String getName() {
+        return nav().getClassName(clazz);
+    }
+
+    public <A extends Annotation> A readAnnotation(Class<A> a) {
+        return reader().getClassAnnotation(a,clazz,this);
+    }
+
+    public Element<T,C> asElement() {
+        if(isElement())
+            return this;
+        else
+            return null;
+    }
+
+    public List<? extends PropertyInfo<T,C>> getProperties() {
+        if(properties!=null)    return properties;
+
+        // check the access type first
+        XmlAccessType at = getAccessType();
+
+        properties = new FinalArrayList<PropertyInfoImpl<T,C,F,M>>();
+
+        // find properties from fields
+        for( F f : nav().getDeclaredFields(clazz) ) {
+            Annotation[] annotations = reader().getAllFieldAnnotations(f,this);
+            if( nav().isTransient(f) ) {
+                // it's an error for transient field to have any binding annotation
+                if(hasJAXBAnnotation(annotations))
+                    builder.reportError(new IllegalAnnotationException(
+                        Messages.TRANSIENT_FIELD_NOT_BINDABLE.format(nav().getFieldName(f)),
+                            getSomeJAXBAnnotation(annotations)));
+            } else
+            if( nav().isStaticField(f) ) {
+                // static fields are bound only when there's explicit annotation.
+                if(hasJAXBAnnotation(annotations))
+                    addProperty(createFieldSeed(f),annotations);
+            } else {
+                if(at==XmlAccessType.FIELD
+                ||(at==XmlAccessType.PUBLIC_MEMBER && nav().isPublicField(f))
+                || hasJAXBAnnotation(annotations))
+                    addProperty(createFieldSeed(f),annotations);
+                checkFieldXmlLocation(f);
+            }
+        }
+
+        findGetterSetterProperties(at);
+
+        if(propOrder==DEFAULT_ORDER || propOrder==null) {
+            XmlAccessOrder ao = getAccessorOrder();
+            if(ao==XmlAccessOrder.ALPHABETICAL)
+                Collections.sort(properties);
+        } else {
+            //sort them as specified
+            PropertySorter sorter = new PropertySorter();
+            for (PropertyInfoImpl p : properties)
+                sorter.checkedGet(p);   // have it check for errors
+            Collections.sort(properties,sorter);
+            sorter.checkUnusedProperties();
+        }
+
+        {// additional error checks
+            PropertyInfoImpl vp=null; // existing value property
+            PropertyInfoImpl ep=null; // existing element property
+
+            for (PropertyInfoImpl p : properties) {
+                switch(p.kind()) {
+                case ELEMENT:
+                case REFERENCE:
+                case MAP:
+                    ep = p;
+                    break;
+                case VALUE:
+                    if(vp!=null) {
+                        // can't have multiple value properties.
+                        builder.reportError(new IllegalAnnotationException(
+                            Messages.MULTIPLE_VALUE_PROPERTY.format(),
+                            vp, p ));
+                    }
+                    if(getBaseClass()!=null) {
+                        builder.reportError(new IllegalAnnotationException(
+                            Messages.XMLVALUE_IN_DERIVED_TYPE.format(), p ));
+                    }
+                    vp = p;
+                    break;
+                case ATTRIBUTE:
+                    break;  // noop
+                default:
+                    assert false;
+                }
+            }
+
+            if(ep!=null && vp!=null) {
+                // can't have element and value property at the same time
+                builder.reportError(new IllegalAnnotationException(
+                    Messages.ELEMENT_AND_VALUE_PROPERTY.format(),
+                    vp, ep
+                ));
+            }
+        }
+
+        return properties;
+    }
+
+    public PropertyInfo<T,C> getProperty(String name) {
+        for( PropertyInfo<T,C> p: getProperties() ) {
+            if(p.getName().equals(name))
+                return p;
+        }
+        return null;
+    }
+
+    /**
+     * This hook is used by {@link RuntimeClassInfoImpl} to look for {@link XmlLocation}.
+     */
+    protected void checkFieldXmlLocation(F f) {
+    }
+
+    /**
+     * Gets an annotation that are allowed on both class and type.
+     */
+    private <T extends Annotation> T getClassOrPackageAnnotation(Class<T> type) {
+        T t = reader().getClassAnnotation(type,clazz,this);
+        if(t!=null)
+            return t;
+        // defaults to the package level
+        return reader().getPackageAnnotation(type,clazz,this);
+    }
+
+    /**
+     * Computes the {@link XmlAccessType} on this class by looking at {@link XmlAccessorType}
+     * annotations.
+     */
+    private XmlAccessType getAccessType() {
+        XmlAccessorType xat = getClassOrPackageAnnotation(XmlAccessorType.class);
+        if(xat!=null)
+            return xat.value();
+        else
+            return XmlAccessType.PUBLIC_MEMBER;
+    }
+
+    /**
+     * Gets the accessor order for this class by consulting {@link XmlAccessorOrder}.
+     */
+    private XmlAccessOrder getAccessorOrder() {
+        XmlAccessorOrder xao = getClassOrPackageAnnotation(XmlAccessorOrder.class);
+        if(xao!=null)
+            return xao.value();
+        else
+            return XmlAccessOrder.UNDEFINED;
+    }
+
+    /**
+     * Compares orders among {@link PropertyInfoImpl} according to {@link ClassInfoImpl#propOrder}.
+     *
+     * <p>
+     * extends {@link HashMap} to save memory.
+     */
+    private final class PropertySorter extends HashMap<String,Integer> implements Comparator<PropertyInfoImpl> {
+        /**
+         * Mark property names that are used, so that we can report unused property names in the propOrder array.
+         */
+        PropertyInfoImpl[] used = new PropertyInfoImpl[propOrder.length];
+
+        /**
+         * If any name collides, it will be added to this set.
+         * This is used to avoid repeating the same error message.
+         */
+        private Set<String> collidedNames;
+
+        PropertySorter() {
+            super(propOrder.length);
+            for( String name : propOrder )
+                if(put(name,size())!=null) {
+                    // two properties with the same name
+                    builder.reportError(new IllegalAnnotationException(
+                        Messages.DUPLICATE_ENTRY_IN_PROP_ORDER.format(name),ClassInfoImpl.this));
+                }
+        }
+
+        public int compare(PropertyInfoImpl o1, PropertyInfoImpl o2) {
+            int lhs = checkedGet(o1);
+            int rhs = checkedGet(o2);
+
+            return lhs-rhs;
+        }
+
+        private int checkedGet(PropertyInfoImpl p) {
+            Integer i = get(p.getName());
+            if(i==null) {
+                // missing
+                if((p.kind().isOrdered))
+                    builder.reportError(new IllegalAnnotationException(
+                        Messages.PROPERTY_MISSING_FROM_ORDER.format(p.getName()),p));
+
+                // give it an order to recover from an error
+                i = size();
+                put(p.getName(),i);
+            }
+
+            // mark the used field
+            int ii = i;
+            if(ii<used.length) {
+                if(used[ii]!=null && used[ii]!=p) {
+                    if(collidedNames==null) collidedNames = new HashSet<String>();
+
+                    if(collidedNames.add(p.getName()))
+                        // report the error only on the first time
+                        builder.reportError(new IllegalAnnotationException(
+                            Messages.DUPLICATE_PROPERTIES.format(p.getName()),p,used[ii]));
+                }
+                used[ii] = p;
+            }
+
+            return i;
+        }
+
+        /**
+         * Report errors for unused propOrder entries.
+         */
+        public void checkUnusedProperties() {
+            for( int i=0; i<used.length; i++ )
+                if(used[i]==null) {
+                    String unusedName = propOrder[i];
+                    builder.reportError(new IllegalAnnotationException(
+                        Messages.PROPERTY_ORDER_CONTAINS_UNUSED_ENTRY.format(unusedName),ClassInfoImpl.this));
+                }
+        }
+    }
+
+    public boolean hasProperties() {
+        return !properties.isEmpty();
+    }
+
+
+    /**
+     * Picks the first non-null argument, or null if all arguments are null.
+     */
+    private static <T> T pickOne( T... args ) {
+        for( T arg : args )
+            if(arg!=null)
+                return arg;
+        return null;
+    }
+
+    private static <T> List<T> makeSet( T... args ) {
+        List<T> l = new FinalArrayList<T>();
+        for( T arg : args )
+            if(arg!=null)   l.add(arg);
+        return l;
+    }
+
+    private static final class ConflictException extends Exception {
+        final List<Annotation> annotations;
+
+        public ConflictException(List<Annotation> one) {
+            this.annotations = one;
+        }
+    }
+
+    private static final class DupliateException extends Exception {
+        final Annotation a1,a2;
+        public DupliateException(Annotation a1, Annotation a2) {
+            this.a1 = a1;
+            this.a2 = a2;
+        }
+    }
+
+    /**
+     * Represents 6 groups of secondary annotations
+     */
+    private static enum SecondaryAnnotation {
+        JAVA_TYPE       (0x01, XmlJavaTypeAdapter.class),
+        ID_IDREF        (0x02, XmlID.class, XmlIDREF.class),
+        BINARY          (0x04, XmlInlineBinaryData.class, XmlMimeType.class, XmlAttachmentRef.class),
+        ELEMENT_WRAPPER (0x08, XmlElementWrapper.class),
+        LIST            (0x10, XmlList.class),
+        SCHEMA_TYPE     (0x20, XmlSchemaType.class);
+
+        /**
+         * Each constant gets an unique bit mask so that the presence/absence
+         * of them can be represented in a single byte.
+         */
+        final int bitMask;
+        /**
+         * List of annotations that belong to this member.
+         */
+        final Class<? extends Annotation>[] members;
+
+        SecondaryAnnotation(int bitMask, Class<? extends Annotation>... members) {
+            this.bitMask = bitMask;
+            this.members = members;
+        }
+    }
+
+    private static final SecondaryAnnotation[] SECONDARY_ANNOTATIONS = SecondaryAnnotation.values();
+
+    /**
+     * Represents 7 groups of properties.
+     *
+     * Each instance is also responsible for rejecting annotations
+     * that are not allowed on that kind.
+     */
+    private static enum PropertyGroup {
+        TRANSIENT       (false,false,false,false,false,false),
+        ANY_ATTRIBUTE   (true, false,false,false,false,false),
+        ATTRIBUTE       (true, true, true, false,true, true ),
+        VALUE           (true, true, true, false,true, true ),
+        ELEMENT         (true, true, true, true, true, true ),
+        ELEMENT_REF     (true, false,false,true, false,false),
+        MAP             (false,false,false,true, false,false);
+
+        /**
+         * Bit mask that represents secondary annotations that are allowed on this group.
+         *
+         * T = not allowed, F = allowed
+         */
+        final int allowedsecondaryAnnotations;
+
+        PropertyGroup(boolean... bits) {
+            int mask = 0;
+            assert bits.length==SECONDARY_ANNOTATIONS.length;
+            for( int i=0; i<bits.length; i++ ) {
+                if(bits[i])
+                    mask |= SECONDARY_ANNOTATIONS[i].bitMask;
+            }
+            allowedsecondaryAnnotations = ~mask;
+        }
+
+        boolean allows(SecondaryAnnotation a) {
+            return (allowedsecondaryAnnotations&a.bitMask)==0;
+        }
+    }
+
+    private static final Annotation[] EMPTY_ANNOTATIONS = new Annotation[0];
+
+    /**
+     * All the annotations in JAXB to their internal index.
+     */
+    private static final HashMap<Class,Integer> ANNOTATION_NUMBER_MAP = new HashMap<Class,Integer>();
+    static {
+        Class[] annotations = {
+            XmlTransient.class,     // 0
+            XmlAnyAttribute.class,  // 1
+            XmlAttribute.class,     // 2
+            XmlValue.class,         // 3
+            XmlElement.class,       // 4
+            XmlElements.class,      // 5
+            XmlElementRef.class,    // 6
+            XmlElementRefs.class,   // 7
+            XmlAnyElement.class,    // 8
+            XmlMixed.class,         // 9
+        };
+
+        HashMap<Class,Integer> m = ANNOTATION_NUMBER_MAP;
+
+        // characterizing annotations
+        for( Class c : annotations )
+            m.put(c, m.size() );
+
+        // secondary annotations
+        int index = 20;
+        for( SecondaryAnnotation sa : SECONDARY_ANNOTATIONS ) {
+            for( Class member : sa.members )
+                m.put(member,index);
+            index++;
+        }
+    }
+
+    private void checkConflict(Annotation a, Annotation b) throws DupliateException {
+        assert b!=null;
+        if(a!=null)
+            throw new DupliateException(a,b);
+    }
+
+    /**
+     * Called only from {@link #getProperties()}.
+     *
+     * <p>
+     * This is where we decide the type of the property and checks for annotations
+     * that are not allowed.
+     *
+     * @param annotations
+     *      all annotations on this property. It's the same as
+     *      {@code seed.readAllAnnotation()}, but taken as a parameter
+     *      because the caller should know it already.
+     */
+    private void addProperty( PropertySeed<T,C,F,M> seed, Annotation[] annotations ) {
+        // since typically there's a very few annotations on a method,
+        // this runs faster than checking for each annotation via readAnnotation(A)
+
+
+        // characterizing annotations. these annotations (or lack thereof) decides
+        // the kind of the property it goes to.
+        // I wish I could use an array...
+        XmlTransient t = null;
+        XmlAnyAttribute aa = null;
+        XmlAttribute a = null;
+        XmlValue v = null;
+        XmlElement e1 = null;
+        XmlElements e2 = null;
+        XmlElementRef r1 = null;
+        XmlElementRefs r2 = null;
+        XmlAnyElement xae = null;
+        XmlMixed mx = null;
+
+        // encountered secondary annotations are accumulated into a bit mask
+        int secondaryAnnotations = 0;
+
+        try {
+            for( Annotation ann : annotations ) {
+                Integer index = ANNOTATION_NUMBER_MAP.get(ann.annotationType());
+                if(index==null) continue;
+                switch(index) {
+                case 0:     checkConflict(t  ,ann); t   = (XmlTransient) ann; break;
+                case 1:     checkConflict(aa ,ann); aa  = (XmlAnyAttribute) ann; break;
+                case 2:     checkConflict(a  ,ann); a   = (XmlAttribute) ann; break;
+                case 3:     checkConflict(v  ,ann); v   = (XmlValue) ann; break;
+                case 4:     checkConflict(e1 ,ann); e1  = (XmlElement) ann; break;
+                case 5:     checkConflict(e2 ,ann); e2  = (XmlElements) ann; break;
+                case 6:     checkConflict(r1 ,ann); r1  = (XmlElementRef) ann; break;
+                case 7:     checkConflict(r2 ,ann); r2  = (XmlElementRefs) ann; break;
+                case 8:     checkConflict(xae,ann); xae = (XmlAnyElement) ann; break;
+                case 9:     checkConflict(mx, ann); mx  = (XmlMixed) ann; break;
+                default:
+                    // secondary annotations
+                    secondaryAnnotations |= (1<<(index-20));
+                    break;
+                }
+            }
+
+            // determine the group kind, and also count the numbers, since
+            // characterizing annotations are mutually exclusive.
+            PropertyGroup group = null;
+            int groupCount = 0;
+
+            if(t!=null) {
+                group = PropertyGroup.TRANSIENT;
+                groupCount++;
+            }
+            if(aa!=null) {
+                group = PropertyGroup.ANY_ATTRIBUTE;
+                groupCount++;
+            }
+            if(a!=null) {
+                group = PropertyGroup.ATTRIBUTE;
+                groupCount++;
+            }
+            if(v!=null) {
+                group = PropertyGroup.VALUE;
+                groupCount++;
+            }
+            if(e1!=null || e2!=null) {
+                group = PropertyGroup.ELEMENT;
+                groupCount++;
+            }
+            if(r1!=null || r2!=null || xae!=null || mx!=null) {
+                group = PropertyGroup.ELEMENT_REF;
+                groupCount++;
+            }
+
+            if(groupCount>1) {
+                // collision between groups
+                List<Annotation> err = makeSet(t,aa,a,v,pickOne(e1,e2),pickOne(r1,r2,xae));
+                throw new ConflictException(err);
+            }
+
+            if(group==null) {
+                // if no characterizing annotation was found, it's either element or map
+                // sniff the signature and then decide.
+                assert groupCount==0;
+
+                // UGLY: the presence of XmlJavaTypeAdapter makes it an element property. ARGH.
+                if(nav().isSubClassOf( seed.getRawType(), nav().ref(Map.class) )
+                && !seed.hasAnnotation(XmlJavaTypeAdapter.class))
+                    group = PropertyGroup.MAP;
+                else
+                    group = PropertyGroup.ELEMENT;
+            }
+
+            // group determined by now
+            // make sure that there are no prohibited secondary annotations
+            if( (secondaryAnnotations&group.allowedsecondaryAnnotations)!=0 ) {
+                // uh oh. find the offending annotation
+                for( SecondaryAnnotation sa : SECONDARY_ANNOTATIONS ) {
+                    if(group.allows(sa))
+                        continue;
+                    for( Class<? extends Annotation> m : sa.members ) {
+                        Annotation offender = seed.readAnnotation(m);
+                        if(offender!=null) {
+                            // found it
+                            builder.reportError(new IllegalAnnotationException(
+                                Messages.ANNOTATION_NOT_ALLOWED.format(m.getSimpleName()),offender));
+                            return;
+                        }
+                    }
+                }
+                // there must have been an offender
+                assert false;
+            }
+
+            // actually create annotations
+            switch(group) {
+            case TRANSIENT:
+                return;
+            case ANY_ATTRIBUTE:
+                // an attribute wildcard property
+                if(attributeWildcard!=null) {
+                    builder.reportError(new IllegalAnnotationException(
+                        Messages.TWO_ATTRIBUTE_WILDCARDS.format(
+                            nav().getClassName(getClazz())),aa,attributeWildcard));
+                    return; // recover by ignore
+                }
+                attributeWildcard = seed;
+
+                if(inheritsAttributeWildcard()) {
+                    builder.reportError(new IllegalAnnotationException(
+                        Messages.SUPER_CLASS_HAS_WILDCARD.format(),
+                            aa,getInheritedAttributeWildcard()));
+                    return;
+                }
+
+                // check the signature and make sure it's assignable to Map
+                if(!nav().isSubClassOf(seed.getRawType(),nav().ref(Map.class))) {
+                    builder.reportError(new IllegalAnnotationException(
+                        Messages.INVALID_ATTRIBUTE_WILDCARD_TYPE.format(nav().getTypeName(seed.getRawType())),
+                            aa,getInheritedAttributeWildcard()));
+                    return;
+                }
+
+
+                return;
+            case ATTRIBUTE:
+                properties.add(createAttributeProperty(seed));
+                return;
+            case VALUE:
+                properties.add(createValueProperty(seed));
+                return;
+            case ELEMENT:
+                properties.add(createElementProperty(seed));
+                return;
+            case ELEMENT_REF:
+                properties.add(createReferenceProperty(seed));
+                return;
+            case MAP:
+                properties.add(createMapProperty(seed));
+                return;
+            default:
+                assert false;
+            }
+        } catch( ConflictException x ) {
+            // report a conflicting annotation
+            List<Annotation> err = x.annotations;
+
+            builder.reportError(new IllegalAnnotationException(
+                Messages.MUTUALLY_EXCLUSIVE_ANNOTATIONS.format(
+                    nav().getClassName(getClazz())+'#'+seed.getName(),
+                    err.get(0).annotationType().getName(), err.get(1).annotationType().getName()),
+                    err.get(0), err.get(1) ));
+
+            // recover by ignoring this property
+        } catch( DupliateException e ) {
+            // both are present
+            builder.reportError(new IllegalAnnotationException(
+                Messages.DUPLICATE_ANNOTATIONS.format(e.a1.annotationType().getName()),
+                e.a1, e.a2 ));
+            // recover by ignoring this property
+
+        }
+    }
+
+    protected ReferencePropertyInfoImpl<T,C,F,M> createReferenceProperty(PropertySeed<T, C, F, M> seed) {
+        return new ReferencePropertyInfoImpl<T,C,F,M>(this,seed);
+    }
+
+    protected AttributePropertyInfoImpl<T, C, F, M> createAttributeProperty(PropertySeed<T, C, F, M> seed) {
+        return new AttributePropertyInfoImpl<T,C,F,M>(this,seed);
+    }
+
+    protected ValuePropertyInfoImpl<T, C, F, M> createValueProperty(PropertySeed<T, C, F, M> seed) {
+        return new ValuePropertyInfoImpl<T,C,F,M>(this,seed);
+    }
+
+    protected ElementPropertyInfoImpl<T, C, F, M> createElementProperty(PropertySeed<T, C, F, M> seed) {
+        return new ElementPropertyInfoImpl<T,C,F,M>(this,seed);
+    }
+
+    protected MapPropertyInfoImpl<T, C, F, M> createMapProperty(PropertySeed<T, C, F, M> seed) {
+        return new MapPropertyInfoImpl<T,C,F,M>(this,seed);
+    }
+
+
+    /**
+     * Adds properties that consists of accessors.
+     */
+    private void findGetterSetterProperties(XmlAccessType at) {
+        TODO.checkSpec();   // TODO: I don't think the spec describes how properties are found
+
+        // in the first step we accumulate getters and setters
+        // into this map keyed by the property name.
+        Map<String,M> getters = new LinkedHashMap<String,M>();
+        Map<String,M> setters = new LinkedHashMap<String,M>();
+
+        Collection<? extends M> methods = nav().getDeclaredMethods(clazz);
+        for( M method : methods ) {
+            boolean used = false;   // if this method is added to getters or setters
+
+            if(nav().isBridgeMethod(method))
+                continue;   // ignore
+
+            String name = nav().getMethodName(method);
+            int arity = nav().getMethodParameters(method).length;
+
+            if(nav().isStaticMethod(method)) {
+                ensureNoAnnotation(method);
+                continue;
+            }
+
+            // don't look at XmlTransient. We'll deal with that later.
+
+            // is this a get method?
+            String propName = getPropertyNameFromGetMethod(name);
+            if(propName!=null) {
+                if(arity==0) {
+                    getters.put(propName,method);
+                    used = true;
+                }
+                // TODO: do we support indexed property?
+            }
+
+            // is this a set method?
+            propName = getPropertyNameFromSetMethod(name);
+            if(propName!=null) {
+                if(arity==1) {
+                    // TODO: we should check collisions like setFoo(int) and setFoo(String)
+                    setters.put(propName,method);
+                    used = true;
+                }
+                // TODO: do we support indexed property?
+            }
+
+            if(!used)
+                ensureNoAnnotation(method);
+        }
+
+        // compute the intersection
+        Set<String> complete = new TreeSet<String>(getters.keySet());
+        complete.retainAll(setters.keySet());
+
+        resurrect(getters, complete);
+        resurrect(setters, complete);
+
+        // then look for read/write properties.
+        for (String name : complete) {
+            M getter = getters.get(name);
+            M setter = setters.get(name);
+
+            Annotation[] ga = getter!=null ? reader().getAllMethodAnnotations(getter,new MethodLocatable<M>(this,getter,nav())) : EMPTY_ANNOTATIONS;
+            Annotation[] sa = setter!=null ? reader().getAllMethodAnnotations(setter,new MethodLocatable<M>(this,setter,nav())) : EMPTY_ANNOTATIONS;
+
+            boolean hasAnnotation = hasJAXBAnnotation(ga) || hasJAXBAnnotation(sa);
+            boolean isOverriding = false;
+            if(!hasAnnotation) {
+                // checking if the method is overriding others isn't free,
+                // so we don't compute it if it's not necessary.
+                isOverriding = (getter!=null && nav().isOverriding(getter))
+                            || (setter!=null && nav().isOverriding(setter));
+            }
+
+            if((at==XmlAccessType.PROPERTY && !isOverriding)
+            || (at==XmlAccessType.PUBLIC_MEMBER && isConsideredPublic(getter) && isConsideredPublic(setter) && !isOverriding)
+            || hasAnnotation) {
+                // make sure that the type is consistent
+                if(getter!=null && setter!=null
+                && !nav().getReturnType(getter).equals(nav().getMethodParameters(setter)[0])) {
+                    // inconsistent
+                    builder.reportError(new IllegalAnnotationException(
+                        Messages.GETTER_SETTER_INCOMPATIBLE_TYPE.format(
+                            nav().getTypeName(nav().getReturnType(getter)),
+                            nav().getTypeName(nav().getMethodParameters(setter)[0])
+                        ),
+                        new MethodLocatable<M>( this, getter, nav()),
+                        new MethodLocatable<M>( this, setter, nav())));
+                    continue;
+                }
+
+                // merge annotations from two list
+                Annotation[] r;
+                if(ga.length==0) {
+                    r = sa;
+                } else
+                if(sa.length==0) {
+                    r = ga;
+                } else {
+                    r = new Annotation[ga.length+sa.length];
+                    System.arraycopy(ga,0,r,0,ga.length);
+                    System.arraycopy(sa,0,r,ga.length,sa.length);
+                }
+
+                addProperty(createAccessorSeed(getter, setter),r);
+            }
+        }
+        // done with complete pairs
+        getters.keySet().removeAll(complete);
+        setters.keySet().removeAll(complete);
+
+        // TODO: think about
+        // class Foo {
+        //   int getFoo();
+        // }
+        // class Bar extends Foo {
+        //   void setFoo(int x);
+        // }
+        // and how it will be XML-ized.
+    }
+
+    /**
+     * Returns true if the method is considered 'public'.
+     */
+    private boolean isConsideredPublic(M m) {
+        return m ==null || nav().isPublicMethod(m);
+    }
+
+    /**
+     * If the method has an explicit annotation, allow it to participate
+     * to the processing even if it lacks the setter or the getter.
+     */
+    private void resurrect(Map<String, M> methods, Set<String> complete) {
+        for (Map.Entry<String, M> e : methods.entrySet()) {
+            if(complete.contains(e.getKey()))
+                continue;
+            if(hasJAXBAnnotation(reader().getAllMethodAnnotations(e.getValue(),this)))
+                complete.add(e.getKey());
+        }
+    }
+
+    /**
+     * Makes sure that the method doesn't have any annotation, if it does,
+     * report it as an error
+     */
+    private void ensureNoAnnotation(M method) {
+        Annotation[] annotations = reader().getAllMethodAnnotations(method,this);
+        for( Annotation a : annotations ) {
+            if(isJAXBAnnotation(a)) {
+                builder.reportError(new IllegalAnnotationException(
+                    Messages.ANNOTATION_ON_WRONG_METHOD.format(),
+                    a));
+                return;
+            }
+        }
+    }
+
+    /**
+     * Returns true if a given annotation is a JAXB annotation.
+     */
+    private static boolean isJAXBAnnotation(Annotation a) {
+        return ANNOTATION_NUMBER_MAP.containsKey(a.annotationType());
+    }
+
+    /**
+     * Returns true if the array contains a JAXB annotation.
+     */
+    private static boolean hasJAXBAnnotation(Annotation[] annotations) {
+        return getSomeJAXBAnnotation(annotations)!=null;
+    }
+
+    private static Annotation getSomeJAXBAnnotation(Annotation[] annotations) {
+        for( Annotation a : annotations )
+            if(isJAXBAnnotation(a))
+                return a;
+        return null;
+    }
+
+
+    /**
+     * Returns "Foo" from "getFoo" or "isFoo".
+     *
+     * @return null
+     *      if the method name doesn't look like a getter.
+     */
+    private static String getPropertyNameFromGetMethod(String name) {
+        if(name.startsWith("get") && name.length()>3)
+            return name.substring(3);
+        if(name.startsWith("is") && name.length()>2)
+            return name.substring(2);
+        return null;
+    }
+
+    /**
+     * Returns "Foo" from "setFoo".
+     *
+     * @return null
+     *      if the method name doesn't look like a setter.
+     */
+    private static String getPropertyNameFromSetMethod(String name) {
+        if(name.startsWith("set") && name.length()>3)
+            return name.substring(3);
+        return null;
+    }
+
+    /**
+     * Creates a new {@link FieldPropertySeed} object.
+     *
+     * <p>
+     * Derived class can override this method to create a sub-class.
+     */
+    protected PropertySeed<T,C,F,M> createFieldSeed(F f) {
+        return new FieldPropertySeed<T,C,F,M>(this, f);
+    }
+
+    /**
+     * Creates a new {@link GetterSetterPropertySeed} object.
+     */
+    protected PropertySeed<T,C,F,M> createAccessorSeed(M getter, M setter) {
+        return new GetterSetterPropertySeed<T,C,F,M>(this, getter,setter);
+    }
+
+    public final boolean isElement() {
+        return elementName!=null;
+    }
+
+    public boolean isAbstract() {
+        return nav().isAbstract(clazz);
+    }
+
+    public boolean isOrdered() {
+        return propOrder!=null;
+    }
+
+    public final boolean isFinal() {
+        return nav().isFinal(clazz);
+    }
+
+    public final boolean hasSubClasses() {
+        return hasSubClasses;
+    }
+
+    public final boolean hasAttributeWildcard() {
+        return declaresAttributeWildcard() || inheritsAttributeWildcard();
+    }
+
+    public final boolean inheritsAttributeWildcard() {
+        return getInheritedAttributeWildcard()!=null;
+    }
+
+    public final boolean declaresAttributeWildcard() {
+        return attributeWildcard!=null;
+    }
+
+    /**
+     * Gets the {@link PropertySeed} object for the inherited attribute wildcard.
+     */
+    private PropertySeed<T,C,F,M> getInheritedAttributeWildcard() {
+        for( ClassInfoImpl<T,C,F,M> c=getBaseClass(); c!=null; c=c.getBaseClass() )
+            if(c.attributeWildcard!=null)
+                return c.attributeWildcard;
+        return null;
+    }
+
+    public final QName getElementName() {
+        return elementName;
+    }
+
+    public final QName getTypeName() {
+        return typeName;
+    }
+
+    public final boolean isSimpleType() {
+        List<? extends PropertyInfo> props = getProperties();
+        if(props.size()!=1)     return false;
+        return props.get(0).kind()==PropertyKind.VALUE;
+    }
+
+    /**
+     * Called after all the {@link TypeInfo}s are collected into the {@link #owner}.
+     */
+    @Override
+    /*package*/ void link() {
+        getProperties();    // make sure properties!=null
+
+        // property name collision cehck
+        Map<String,PropertyInfoImpl> names = new HashMap<String,PropertyInfoImpl>();
+        for( PropertyInfoImpl<T,C,F,M> p : properties ) {
+            p.link();
+            PropertyInfoImpl old = names.put(p.getName(),p);
+            if(old!=null) {
+                builder.reportError(new IllegalAnnotationException(
+                    Messages.PROPERTY_COLLISION.format(p.getName()),
+                    p, old ));
+            }
+        }
+        super.link();
+    }
+
+    public Location getLocation() {
+        return nav().getClassLocation(clazz);
+    }
+
+    /**
+     *  XmlType allows specification of factoryClass and
+     *  factoryMethod.  There are to be used if no default
+     *  constructor is found.
+     *
+     * @return
+     *      true if the factory method was found. False if not.
+     */
+    private  boolean hasFactoryConstructor(XmlType t){
+        if (t == null) return false;
+
+        String method = t.factoryMethod();
+        T fClass = reader().getClassValue(t, "factoryClass");
+        if (method.length() > 0){
+            if(fClass.equals(nav().ref(XmlType.DEFAULT.class))){
+                fClass = nav().use(clazz);
+            }
+            for(M m: nav().getDeclaredMethods(nav().asDecl(fClass))){
+                //- Find the zero-arg public static method with the required return type
+                if (nav().getMethodName(m).equals(method) &&
+                    nav().getReturnType(m).equals(nav().use(clazz)) &&
+                    nav().getMethodParameters(m).length == 0 &&
+                    nav().isStaticMethod(m)){
+                    factoryMethod = m;
+                    break;
+                }
+            }
+            if (factoryMethod == null){
+                builder.reportError(new IllegalAnnotationException(
+                Messages.NO_FACTORY_METHOD.format(nav().getClassName(nav().asDecl(fClass)), method), this ));
+            }
+        } else if(!fClass.equals(nav().ref(XmlType.DEFAULT.class))){
+            builder.reportError(new IllegalAnnotationException(
+                Messages.FACTORY_CLASS_NEEDS_FACTORY_METHOD.format(nav().getClassName(nav().asDecl(fClass))), this ));
+        }
+        return factoryMethod != null;
+    }
+
+
+    public Method getFactoryMethod(){
+        return (Method) factoryMethod;
+    }
+    private static final String[] DEFAULT_ORDER = new String[0];
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ERPropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ERPropertyInfoImpl.java
new file mode 100644
index 0000000..e79d57a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ERPropertyInfoImpl.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import javax.xml.bind.annotation.XmlElementWrapper;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+
+/**
+ * Common part of {@link ElementPropertyInfoImpl} and {@link ReferencePropertyInfoImpl}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class ERPropertyInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    extends PropertyInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> {
+
+    public ERPropertyInfoImpl(ClassInfoImpl<TypeT, ClassDeclT, FieldT, MethodT> classInfo, PropertySeed<TypeT, ClassDeclT, FieldT, MethodT> propertySeed) {
+        super(classInfo, propertySeed);
+
+        XmlElementWrapper e = seed.readAnnotation(XmlElementWrapper.class);
+
+        boolean nil = false;
+        if(!isCollection()) {
+            xmlName = null;
+            if(e!=null)
+                classInfo.builder.reportError(new IllegalAnnotationException(
+                    Messages.XML_ELEMENT_WRAPPER_ON_NON_COLLECTION.format(
+                        nav().getClassName(parent.getClazz())+'.'+seed.getName()),
+                    e
+                ));
+        } else {
+            if(e!=null) {
+                xmlName = calcXmlName(e);
+                nil = e.nillable();
+            } else
+                xmlName = null;
+        }
+
+        wrapperNillable = nil;
+    }
+
+    private final QName xmlName;
+
+    /**
+     * True if the wrapper tag name is nillable.
+     */
+    private final boolean wrapperNillable;
+
+    /**
+     * Gets the wrapper element name.
+     */
+    public final QName getXmlName() {
+        return xmlName;
+    }
+
+    public final boolean isCollectionNillable() {
+        return wrapperNillable;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ElementInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ElementInfoImpl.java
new file mode 100644
index 0000000..1c7f6f3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ElementInfoImpl.java
@@ -0,0 +1,423 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.annotation.Annotation;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.List;
+
+import javax.activation.MimeType;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.annotation.XmlAttachmentRef;
+import javax.xml.bind.annotation.XmlElementDecl;
+import javax.xml.bind.annotation.XmlID;
+import javax.xml.bind.annotation.XmlIDREF;
+import javax.xml.bind.annotation.XmlInlineBinaryData;
+import javax.xml.bind.annotation.XmlSchema;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationSource;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.ElementInfo;
+import com.sun.xml.internal.bind.v2.model.core.ElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeRef;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+import com.sun.xml.internal.bind.v2.runtime.SwaRefAdapter;
+import com.sun.istack.internal.FinalArrayList;
+
+/**
+ * {@link ElementInfo} implementation.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class ElementInfoImpl<T,C,F,M> extends TypeInfoImpl<T,C,F,M> implements ElementInfo<T,C> {
+
+    private final QName tagName;
+
+    private final NonElement<T,C> contentType;
+
+    private final T elementType;
+
+    private final ClassInfo<T,C> scope;
+
+    /**
+     * Annotation that controls the binding.
+     */
+    private final XmlElementDecl anno;
+
+    /**
+     * If this element can substitute another element, the element name.
+     * @see #link()
+     */
+    private ElementInfoImpl<T,C,F,M> substitutionHead;
+
+    /**
+     * Lazily constructed list of {@link ElementInfo}s that can substitute this element.
+     * This could be null.
+     * @see #link()
+     */
+    private FinalArrayList<ElementInfoImpl<T,C,F,M>> substitutionMembers;
+
+    /**
+     * The factory method from which this mapping was created.
+     */
+    private final M method;
+
+    /**
+     * If the content type is adapter, return that adapter.
+     */
+    private final Adapter<T,C> adapter;
+
+    private final boolean isCollection;
+
+    private final ID id;
+
+    private final PropertyImpl property;
+    private final MimeType expectedMimeType;
+    private final boolean inlineBinary;
+    private final QName schemaType;
+
+    /**
+     * Singleton instance of {@link ElementPropertyInfo} for this element.
+     */
+    protected class PropertyImpl implements
+            ElementPropertyInfo<T,C>,
+            TypeRef<T,C>,
+            AnnotationSource {
+        //
+        // TypeRef impl
+        //
+        public NonElement<T,C> getTarget() {
+            return contentType;
+        }
+        public QName getTagName() {
+            return tagName;
+        }
+
+        public List<? extends TypeRef<T,C>> getTypes() {
+            return Collections.singletonList(this);
+        }
+
+        public List<? extends NonElement<T,C>> ref() {
+            return Collections.singletonList(contentType);
+        }
+
+        public QName getXmlName() {
+            return tagName;
+        }
+
+        public boolean isCollectionNillable() {
+            return true;
+        }
+
+        public boolean isNillable() {
+            return true;
+        }
+
+        public String getDefaultValue() {
+            String v = anno.defaultValue();
+            if(v.equals("\u0000"))
+                return null;
+            else
+                return v;
+        }
+
+        public ElementInfoImpl<T,C,F,M> parent() {
+            return ElementInfoImpl.this;
+        }
+
+        public String getName() {
+            return "value";
+        }
+
+        public String displayName() {
+            return "JAXBElement#value";
+        }
+
+        public boolean isCollection() {
+            return isCollection;
+        }
+
+        /**
+         * For {@link ElementInfo}s, a collection always means a list of values.
+         */
+        public boolean isValueList() {
+            return isCollection;
+        }
+
+        public boolean isRequired() {
+            return true;
+        }
+
+        public PropertyKind kind() {
+            return PropertyKind.ELEMENT;
+        }
+
+        public Adapter<T,C> getAdapter() {
+            return adapter;
+        }
+
+        public ID id() {
+            return id;
+        }
+
+        public MimeType getExpectedMimeType() {
+            return expectedMimeType;
+        }
+
+        public QName getSchemaType() {
+            return schemaType;
+        }
+
+        public boolean inlineBinaryData() {
+            return inlineBinary;
+        }
+
+        public PropertyInfo<T,C> getSource() {
+            return this;
+        }
+
+        //
+        //
+        // AnnotationSource impl
+        //
+        //
+        public <A extends Annotation> A readAnnotation(Class<A> annotationType) {
+            return reader().getMethodAnnotation(annotationType,method,ElementInfoImpl.this);
+        }
+
+        public boolean hasAnnotation(Class<? extends Annotation> annotationType) {
+            return reader().hasMethodAnnotation(annotationType,method);
+        }
+    }
+
+    /**
+     * @param m
+     *      The factory method on ObjectFactory that comes with {@link XmlElementDecl}.
+     */
+    public ElementInfoImpl(ModelBuilder<T,C,F,M> builder,
+                           RegistryInfoImpl<T,C,F,M> registry, M m ) throws IllegalAnnotationException {
+        super(builder,registry);
+
+        this.method = m;
+        anno = reader().getMethodAnnotation( XmlElementDecl.class, m, this );
+        assert anno!=null;  // the caller should check this
+        assert anno instanceof Locatable;
+
+        elementType = nav().getReturnType(m);
+        T baseClass = nav().getBaseClass(elementType,nav().asDecl(JAXBElement.class));
+        if(baseClass==null)
+            throw new IllegalAnnotationException(
+                Messages.XML_ELEMENT_MAPPING_ON_NON_IXMLELEMENT_METHOD.format(nav().getMethodName(m)),
+                anno );
+
+        tagName = parseElementName(anno);
+        T[] methodParams = nav().getMethodParameters(m);
+
+        // adapter
+        Adapter<T,C> a = null;
+        if(methodParams.length>0) {
+            XmlJavaTypeAdapter adapter = reader().getMethodAnnotation(XmlJavaTypeAdapter.class,m,this);
+            if(adapter!=null)
+                a = new Adapter<T,C>(adapter,reader(),nav());
+            else {
+                XmlAttachmentRef xsa = reader().getMethodAnnotation(XmlAttachmentRef.class,m,this);
+                if(xsa!=null) {
+                    TODO.prototype("in APT swaRefAdapter isn't avaialble, so this returns null");
+                    a = new Adapter<T,C>(owner.nav.asDecl(SwaRefAdapter.class),owner.nav);
+                }
+            }
+        }
+        this.adapter = a;
+
+        if(adapter==null) {
+            // T of JAXBElement<T>
+            T typeType =
+                methodParams.length>0 ? methodParams[0] // this is more reliable, as it works even for ObjectFactory that sometimes have to return public types
+                : nav().getTypeArgument(baseClass,0); // fall back to infer from the return type if no parameter.
+            T list = nav().getBaseClass(typeType,nav().asDecl(List.class));
+            if(list==null) {
+                isCollection = false;
+                contentType = builder.getTypeInfo(typeType,this);  // suck this type into the current set.
+            } else {
+                isCollection = true;
+                contentType = builder.getTypeInfo(nav().getTypeArgument(list,0),this);
+            }
+        } else {
+            // but if adapted, use the adapted type
+            contentType = builder.getTypeInfo(this.adapter.defaultType,this);
+            isCollection = false;
+        }
+
+        // scope
+        T s = reader().getClassValue(anno,"scope");
+        if(s.equals(nav().ref(XmlElementDecl.GLOBAL.class)))
+            scope = null;
+        else {
+            // TODO: what happens if there's an error?
+            NonElement<T,C> scp = builder.getClassInfo(nav().asDecl(s),this);
+            if(!(scp instanceof ClassInfo)) {
+                throw new IllegalAnnotationException(
+                    Messages.SCOPE_IS_NOT_COMPLEXTYPE.format(nav().getTypeName(s)),
+                    anno );
+            }
+            scope = (ClassInfo<T,C>)scp;
+        }
+
+        id = calcId();
+
+        property = createPropertyImpl();
+
+        this.expectedMimeType = Util.calcExpectedMediaType(property,builder);
+        this.inlineBinary = reader().hasMethodAnnotation(XmlInlineBinaryData.class,method);
+        this.schemaType = Util.calcSchemaType(reader(),property,registry.registryClass,
+                getContentInMemoryType(),this);
+    }
+
+    final QName parseElementName(XmlElementDecl e) {
+        String local = e.name();
+        String nsUri = e.namespace();
+        if(nsUri.equals("##default")) {
+            // if defaulted ...
+            XmlSchema xs = reader().getPackageAnnotation(XmlSchema.class,
+                nav().getDeclaringClassForMethod(method),this);
+            if(xs!=null)
+                nsUri = xs.namespace();
+            else {
+                nsUri = builder.defaultNsUri;
+            }
+        }
+
+        return new QName(nsUri.intern(),local.intern());
+    }
+
+    protected PropertyImpl createPropertyImpl() {
+        return new PropertyImpl();
+    }
+
+    public ElementPropertyInfo<T,C> getProperty() {
+        return property;
+    }
+
+    public NonElement<T,C> getContentType() {
+        return contentType;
+    }
+
+    public T getContentInMemoryType() {
+        if(adapter==null) {
+            return contentType.getType();
+        } else {
+            return adapter.customType;
+        }
+    }
+
+    public QName getElementName() {
+        return tagName;
+    }
+
+    public T getType() {
+        return elementType;
+    }
+
+    /**
+     * Leaf-type cannot be referenced from IDREF.
+     *
+     * @deprecated
+     *      why are you calling a method whose return value is always known?
+     */
+    public final boolean canBeReferencedByIDREF() {
+        return false;
+    }
+
+    private ID calcId() {
+        // TODO: share code with PropertyInfoImpl
+        if(reader().hasMethodAnnotation(XmlID.class,method)) {
+            return ID.ID;
+        } else
+        if(reader().hasMethodAnnotation(XmlIDREF.class,method)) {
+            return ID.IDREF;
+        } else {
+            return ID.NONE;
+        }
+    }
+
+    public ClassInfo<T, C> getScope() {
+        return scope;
+    }
+
+    public ElementInfo<T,C> getSubstitutionHead() {
+        return substitutionHead;
+    }
+
+    public Collection<? extends ElementInfoImpl<T,C,F,M>> getSubstitutionMembers() {
+        if(substitutionMembers==null)
+            return Collections.emptyList();
+        else
+            return substitutionMembers;
+    }
+
+    /**
+     * Called after all the {@link TypeInfo}s are collected into the {@link #owner}.
+     */
+    /*package*/ void link() {
+        // substitution head
+        if(anno.substitutionHeadName().length()!=0) {
+            QName name = new QName(
+                anno.substitutionHeadNamespace(), anno.substitutionHeadName() );
+            substitutionHead = owner.getElementInfo(null,name);
+            if(substitutionHead==null) {
+                builder.reportError(
+                    new IllegalAnnotationException(Messages.NON_EXISTENT_ELEMENT_MAPPING.format(
+                        name.getNamespaceURI(),name.getLocalPart()), anno));
+                // recover by ignoring this substitution declaration
+            } else
+                substitutionHead.addSubstitutionMember(this);
+        } else
+            substitutionHead = null;
+        super.link();
+    }
+
+    private void addSubstitutionMember(ElementInfoImpl<T,C,F,M> child) {
+        if(substitutionMembers==null)
+            substitutionMembers = new FinalArrayList<ElementInfoImpl<T,C,F,M>>();
+        substitutionMembers.add(child);
+    }
+
+    public Location getLocation() {
+        return nav().getMethodLocation(method);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ElementPropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ElementPropertyInfoImpl.java
new file mode 100644
index 0000000..d0e737e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ElementPropertyInfoImpl.java
@@ -0,0 +1,200 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.AbstractList;
+import java.util.Collections;
+import java.util.List;
+
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlElements;
+import javax.xml.bind.annotation.XmlList;
+import javax.xml.namespace.QName;
+
+import com.sun.istack.internal.FinalArrayList;
+import com.sun.xml.internal.bind.v2.model.core.ElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeRef;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+
+/**
+ * Common {@link ElementPropertyInfo} implementation used for both
+ * APT and runtime.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class ElementPropertyInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    extends ERPropertyInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    implements ElementPropertyInfo<TypeT,ClassDeclT>
+{
+    /**
+     * Lazily computed.
+     * @see #getTypes()
+     */
+    private List<TypeRefImpl<TypeT,ClassDeclT>> types;
+
+    private final List<TypeInfo<TypeT,ClassDeclT>> ref = new AbstractList<TypeInfo<TypeT,ClassDeclT>>() {
+        public TypeInfo<TypeT,ClassDeclT> get(int index) {
+            return getTypes().get(index).getTarget();
+        }
+
+        public int size() {
+            return getTypes().size();
+        }
+    };
+
+    /**
+     * Lazily computed.
+     * @see #isRequired()
+     */
+    private Boolean isRequired;
+
+    /**
+     * @see #isValueList()
+     */
+    private final boolean isValueList;
+
+    ElementPropertyInfoImpl(
+        ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> parent,
+        PropertySeed<TypeT,ClassDeclT,FieldT,MethodT> propertySeed) {
+        super(parent, propertySeed);
+
+        isValueList = seed.hasAnnotation(XmlList.class);
+
+    }
+
+    public List<? extends TypeRefImpl<TypeT,ClassDeclT>> getTypes() {
+        if(types==null) {
+            types = new FinalArrayList<TypeRefImpl<TypeT,ClassDeclT>>();
+            XmlElement[] ann=null;
+
+            XmlElement xe = seed.readAnnotation(XmlElement.class);
+            XmlElements xes = seed.readAnnotation(XmlElements.class);
+
+            if(xe!=null && xes!=null) {
+                parent.builder.reportError(new IllegalAnnotationException(
+                        Messages.MUTUALLY_EXCLUSIVE_ANNOTATIONS.format(
+                                nav().getClassName(parent.getClazz())+'#'+seed.getName(),
+                                xe.annotationType().getName(), xes.annotationType().getName()),
+                        xe, xes ));
+            }
+
+            isRequired = true;
+
+            if(xe!=null)
+                ann = new XmlElement[]{xe};
+            else
+            if(xes!=null)
+                ann = xes.value();
+
+            if(ann==null) {
+                // default
+                TypeT t = getIndividualType();
+                if(!nav().isPrimitive(t) || isCollection())
+                    isRequired = false;
+                // nillableness defaults to true if it's collection
+                types.add(createTypeRef(calcXmlName((XmlElement)null),t,isCollection(),null));
+            } else {
+                for( XmlElement item : ann ) {
+                    // TODO: handle defaulting in names.
+                    QName name = calcXmlName(item);
+                    TypeT type = reader().getClassValue(item, "type");
+                    if(type.equals(nav().ref(XmlElement.DEFAULT.class))) type = getIndividualType();
+                    if((!nav().isPrimitive(type) || isCollection()) && !item.required())
+                        isRequired = false;
+                    types.add(createTypeRef(name, type, item.nillable(), getDefaultValue(item.defaultValue()) ));
+                }
+            }
+            types = Collections.unmodifiableList(types);
+            assert !types.contains(null);
+        }
+        return types;
+    }
+
+    private String getDefaultValue(String value) {
+        if(value.equals("\u0000"))
+            return null;
+        else
+            return value;
+    }
+
+    /**
+     * Used by {@link PropertyInfoImpl} to create new instances of {@link TypeRef}
+     */
+    protected TypeRefImpl<TypeT,ClassDeclT> createTypeRef(QName name,TypeT type,boolean isNillable,String defaultValue) {
+        return new TypeRefImpl<TypeT,ClassDeclT>(this,name,type,isNillable,defaultValue);
+    }
+
+    public boolean isValueList() {
+        return isValueList;
+    }
+
+    public boolean isRequired() {
+        if(isRequired==null)
+            getTypes(); // compute the value
+        return isRequired;
+    }
+
+    public List<? extends TypeInfo<TypeT,ClassDeclT>> ref() {
+        return ref;
+    }
+
+    public final PropertyKind kind() {
+        return PropertyKind.ELEMENT;
+    }
+
+    protected void link() {
+        super.link();
+        for (TypeRefImpl<TypeT, ClassDeclT> ref : getTypes() ) {
+            ref.link();
+        }
+
+        if(isValueList()) {
+            // ugly test, because IDREF's are represented as text on the wire,
+            // it's OK to be a value list in that case.
+            if(id()!= ID.IDREF) {
+                // check if all the item types are simple types
+                // this can't be done when we compute types because
+                // not all TypeInfos are available yet
+                for (TypeRefImpl<TypeT,ClassDeclT> ref : types) {
+                    if(!ref.getTarget().isSimpleType()) {
+                        parent.builder.reportError(new IllegalAnnotationException(
+                        Messages.XMLLIST_NEEDS_SIMPLETYPE.format(
+                            nav().getTypeName(ref.getTarget().getType())), this ));
+                        break;
+                    }
+                }
+            }
+
+            if(!isCollection())
+                parent.builder.reportError(new IllegalAnnotationException(
+                    Messages.XMLLIST_ON_SINGLE_PROPERTY.format(), this
+                ));
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/EnumConstantImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/EnumConstantImpl.java
new file mode 100644
index 0000000..d852123
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/EnumConstantImpl.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import com.sun.xml.internal.bind.v2.model.core.EnumConstant;
+import com.sun.xml.internal.bind.v2.model.core.EnumLeafInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class EnumConstantImpl<T,C,F,M> implements EnumConstant<T,C> {
+    protected final String lexical;
+    protected final EnumLeafInfoImpl<T,C,F,M> owner;
+    protected final String name;
+
+    /**
+     * All the constants of the {@link EnumConstantImpl} is linked in one list.
+     */
+    protected final EnumConstantImpl<T,C,F,M> next;
+
+    public EnumConstantImpl(EnumLeafInfoImpl<T,C,F,M> owner, String name, String lexical, EnumConstantImpl<T,C,F,M> next) {
+        this.lexical = lexical;
+        this.owner = owner;
+        this.name = name;
+        this.next = next;
+    }
+
+    public EnumLeafInfo<T,C> getEnclosingClass() {
+        return owner;
+    }
+
+    public final String getLexicalValue() {
+        return lexical;
+    }
+
+    public final String getName() {
+        return name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/EnumLeafInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/EnumLeafInfoImpl.java
new file mode 100644
index 0000000..ae2ae6a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/EnumLeafInfoImpl.java
@@ -0,0 +1,228 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.Iterator;
+
+import javax.xml.bind.annotation.XmlEnum;
+import javax.xml.bind.annotation.XmlEnumValue;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.EnumConstant;
+import com.sun.xml.internal.bind.v2.model.core.EnumLeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link EnumLeafInfo} implementation.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class EnumLeafInfoImpl<T,C,F,M> extends TypeInfoImpl<T,C,F,M>
+        implements EnumLeafInfo<T,C>, Element<T,C>, Iterable<EnumConstantImpl<T,C,F,M>> {
+
+    /**
+     * The enum class whose information this object represents.
+     */
+    /*package*/ final C clazz;
+
+    NonElement<T,C> baseType;
+
+    private final T type;
+
+    /**
+     * Can be null for anonymous types.
+     */
+    private final QName typeName;
+
+    /**
+     * All the {@link EnumConstantImpl}s are linked in this list.
+     */
+    private EnumConstantImpl<T,C,F,M> firstConstant;
+
+    /**
+     * If this enum is also bound to an element, that tag name.
+     * Or else null.
+     */
+    private QName elementName;
+
+    /**
+     * @param clazz
+     * @param type
+     *      clazz and type should both point to the enum class
+     *      that this {@link EnumLeafInfo} represents.
+     *      Because of the type parameterization we have to take them separately.
+     */
+    public EnumLeafInfoImpl(ModelBuilder<T,C,F,M> builder,
+                            Locatable upstream, C clazz, T type ) {
+        super(builder,upstream);
+        this.clazz = clazz;
+        this.type = type;
+
+        elementName = parseElementName(clazz);
+
+        // compute the type name
+        // TODO: I guess it must be allowed for enums to have @XmlElement
+        typeName = parseTypeName(clazz);
+
+        // locate the base type.
+        // this can be done eagerly because there shouldn't be no cycle.
+        XmlEnum xe = builder.reader.getClassAnnotation(XmlEnum.class, clazz, this);
+        if(xe!=null) {
+            T base = builder.reader.getClassValue(xe, "value");
+            baseType = builder.getTypeInfo(base,this);
+        } else {
+            baseType = builder.getTypeInfo(builder.nav.ref(String.class),this);
+        }
+    }
+
+    /**
+     * Build {@link EnumConstant}s and discover/report any error in it.
+     */
+    protected void calcConstants() {
+        EnumConstantImpl<T,C,F,M> last = null;
+        for( F constant : nav().getEnumConstants(clazz) ) {
+            String name = nav().getFieldName(constant);
+            XmlEnumValue xev = builder.reader.getFieldAnnotation(XmlEnumValue.class, constant, this);
+
+            String literal;
+            if(xev==null)   literal = name;
+            else            literal = xev.value();
+
+            last = createEnumConstant(name,literal,constant,last);
+        }
+        this.firstConstant = last;
+    }
+
+    protected EnumConstantImpl<T,C,F,M> createEnumConstant(String name, String literal, F constant, EnumConstantImpl<T,C,F,M> last) {
+        return new EnumConstantImpl<T,C,F,M>(this, name, literal, last);
+    }
+
+
+    public T getType() {
+        return type;
+    }
+
+    /**
+     * Leaf-type cannot be referenced from IDREF.
+     *
+     * @deprecated
+     *      why are you calling a method whose return value is always known?
+     */
+    public final boolean canBeReferencedByIDREF() {
+        return false;
+    }
+
+    public QName getTypeName() {
+        return typeName;
+    }
+
+    public C getClazz() {
+        return clazz;
+    }
+
+    public NonElement<T,C> getBaseType() {
+        return baseType;
+    }
+
+    public boolean isSimpleType() {
+        return true;
+    }
+
+    public Location getLocation() {
+        return nav().getClassLocation(clazz);
+    }
+
+    public Iterable<? extends EnumConstantImpl<T,C,F,M>> getConstants() {
+        if(firstConstant==null)
+            calcConstants();
+        return this;
+    }
+
+    public void link() {
+        // make sure we've computed constants
+        getConstants();
+        super.link();
+    }
+
+    /**
+     * No substitution.
+     *
+     * @deprecated if you are invoking this method directly, there's something wrong.
+     */
+    public Element<T, C> getSubstitutionHead() {
+        return null;
+    }
+
+    public QName getElementName() {
+        return elementName;
+    }
+
+    public boolean isElement() {
+        return elementName!=null;
+    }
+
+    public Element<T,C> asElement() {
+        if(isElement())
+            return this;
+        else
+            return null;
+    }
+
+    /**
+     * When a bean binds to an element, it's always through {@link XmlRootElement},
+     * so this method always return null.
+     *
+     * @deprecated
+     *      you shouldn't be invoking this method on {@link ClassInfoImpl}.
+     */
+    public ClassInfo<T,C> getScope() {
+        return null;
+    }
+
+    public Iterator<EnumConstantImpl<T,C,F,M>> iterator() {
+        return new Iterator<EnumConstantImpl<T,C,F,M>>() {
+            private EnumConstantImpl<T,C,F,M> next = firstConstant;
+            public boolean hasNext() {
+                return next!=null;
+            }
+
+            public EnumConstantImpl<T,C,F,M> next() {
+                EnumConstantImpl<T,C,F,M> r = next;
+                next = next.next;
+                return r;
+            }
+
+            public void remove() {
+                throw new UnsupportedOperationException();
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/FieldPropertySeed.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/FieldPropertySeed.java
new file mode 100644
index 0000000..33f3da9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/FieldPropertySeed.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.annotation.Annotation;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link PropertyInfo} implementation backed by a field.
+ */
+class FieldPropertySeed<TypeT,ClassDeclT,FieldT,MethodT> implements
+        PropertySeed<TypeT,ClassDeclT,FieldT,MethodT> {
+
+    protected final FieldT field;
+    private ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> parent;
+
+    FieldPropertySeed(ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> classInfo, FieldT field) {
+        this.parent = classInfo;
+        this.field = field;
+    }
+
+    public <A extends Annotation> A readAnnotation(Class<A> a) {
+        return parent.reader().getFieldAnnotation(a, field,this);
+    }
+
+    public boolean hasAnnotation(Class<? extends Annotation> annotationType) {
+        return parent.reader().hasFieldAnnotation(annotationType,field);
+    }
+
+    public String getName() {
+        // according to the spec team, the BeanIntrospector.decapitalize does not apply
+        // to the fields. Don't call Introspector.decapitalize
+        return parent.nav().getFieldName(field);
+    }
+
+    public TypeT getRawType() {
+        return parent.nav().getFieldType(field);
+    }
+
+    /**
+     * Use the enclosing class as the upsream {@link Location}.
+     */
+    public Locatable getUpstream() {
+        return parent;
+    }
+
+    public Location getLocation() {
+        return parent.nav().getFieldLocation(field);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/GetterSetterPropertySeed.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/GetterSetterPropertySeed.java
new file mode 100644
index 0000000..a08ba9a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/GetterSetterPropertySeed.java
@@ -0,0 +1,107 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.annotation.Annotation;
+import java.beans.Introspector;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link PropertyInfo} implementation backed by a getter and a setter.
+ *
+ * We allow the getter or setter to be null, in which case the bean
+ * can only participate in unmarshalling (or marshalling)
+ */
+class GetterSetterPropertySeed<TypeT,ClassDeclT,FieldT,MethodT> implements
+        PropertySeed<TypeT,ClassDeclT,FieldT,MethodT> {
+
+    protected final MethodT getter;
+    protected final MethodT setter;
+    private ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> parent;
+
+    GetterSetterPropertySeed(ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> parent, MethodT getter, MethodT setter) {
+        this.parent = parent;
+        this.getter = getter;
+        this.setter = setter;
+
+        if(getter==null && setter==null)
+            throw new IllegalArgumentException();
+    }
+
+    public TypeT getRawType() {
+        if(getter!=null)
+            return parent.nav().getReturnType(getter);
+        else
+            return parent.nav().getMethodParameters(setter)[0];
+    }
+
+    public <A extends Annotation> A readAnnotation(Class<A> annotation) {
+        return parent.reader().getMethodAnnotation(annotation, getter,setter,this);
+    }
+
+    public boolean hasAnnotation(Class<? extends Annotation> annotationType) {
+        return parent.reader().hasMethodAnnotation(annotationType,getName(),getter,setter,this);
+    }
+
+    public String getName() {
+        if(getter!=null)
+            return getName(getter);
+        else
+            return getName(setter);
+    }
+
+    private String getName(MethodT m) {
+        String seed = parent.nav().getMethodName(m);
+        String lseed = seed.toLowerCase();
+        if(lseed.startsWith("get") || lseed.startsWith("set"))
+            return camelize(seed.substring(3));
+        if(lseed.startsWith("is"))
+            return camelize(seed.substring(2));
+        return seed;
+    }
+
+
+    private static String camelize(String s) {
+        return Introspector.decapitalize(s);
+    }
+
+    /**
+     * Use the enclosing class as the upsream {@link Location}.
+     */
+    public Locatable getUpstream() {
+        return parent;
+    }
+
+    public Location getLocation() {
+        if(getter!=null)
+            return parent.nav().getMethodLocation(getter);
+        else
+            return parent.nav().getMethodLocation(setter);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/LeafInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/LeafInfoImpl.java
new file mode 100644
index 0000000..9229704
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/LeafInfoImpl.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.LeafInfo;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class LeafInfoImpl<TypeT,ClassDeclT> implements LeafInfo<TypeT,ClassDeclT>, Location {
+    private final TypeT type;
+    /**
+     * Can be null for anonymous types.
+     */
+    private final QName typeName;
+
+    protected LeafInfoImpl(TypeT type,QName typeName) {
+        assert type!=null;
+
+        this.type = type;
+        this.typeName = typeName;
+    }
+
+    /**
+     * A reference to the representation of the type.
+     */
+    public TypeT getType() {
+        return type;
+    }
+
+    /**
+     * Leaf-type cannot be referenced from IDREF.
+     *
+     * @deprecated
+     *      why are you calling a method whose return value is always known?
+     */
+    public final boolean canBeReferencedByIDREF() {
+        return false;
+    }
+
+    public QName getTypeName() {
+        return typeName;
+    }
+
+    public Locatable getUpstream() {
+        return null;
+    }
+
+    public Location getLocation() {
+        // this isn't very accurate, but it's not too bad
+        // doing it correctly need leaves to hold navigator.
+        // otherwise revisit the design so that we take navigator as a parameter
+        return this;
+    }
+
+    public boolean isSimpleType() {
+        return true;
+    }
+
+    public String toString() {
+        return type.toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/MapPropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/MapPropertyInfoImpl.java
new file mode 100644
index 0000000..8e8535b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/MapPropertyInfoImpl.java
@@ -0,0 +1,106 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.Map;
+
+import javax.xml.bind.annotation.XmlElementWrapper;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.core.MapPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class MapPropertyInfoImpl<T,C,F,M> extends PropertyInfoImpl<T,C,F,M> implements MapPropertyInfo<T,C> {
+
+    private final QName xmlName;
+    private boolean nil;
+    private final T keyType;
+    private final T valueType;
+
+    // laziy computed to handle cyclic references
+    private NonElement<T,C> keyTypeInfo;
+    private NonElement<T,C> valueTypeInfo;
+
+
+    public MapPropertyInfoImpl(ClassInfoImpl<T,C,F,M> ci, PropertySeed<T,C,F,M> seed) {
+        super(ci, seed);
+
+        XmlElementWrapper xe = seed.readAnnotation(XmlElementWrapper.class);
+        xmlName = calcXmlName(xe);
+        nil = xe!=null && xe.nillable();
+
+        T raw = getRawType();
+        T bt = nav().getBaseClass(raw, nav().asDecl(Map.class) );
+        assert bt!=null;    // Map property is only for Maps
+
+        if(nav().isParameterizedType(bt)) {
+            keyType = nav().getTypeArgument(bt,0);
+            valueType = nav().getTypeArgument(bt,1);
+        } else {
+            keyType = valueType = nav().ref(Object.class);
+        }
+    }
+
+    public Collection<? extends TypeInfo<T,C>> ref() {
+        return Arrays.asList(getKeyType(),getValueType());
+    }
+
+    public final PropertyKind kind() {
+        return PropertyKind.MAP;
+    }
+
+    public QName getXmlName() {
+        return xmlName;
+    }
+
+    public boolean isCollectionNillable() {
+        return nil;
+    }
+
+    public NonElement<T,C> getKeyType() {
+        if(keyTypeInfo==null)
+            keyTypeInfo = getTarget(keyType);
+        return keyTypeInfo;
+    }
+
+    public NonElement<T,C> getValueType() {
+        if(valueTypeInfo==null)
+            valueTypeInfo = getTarget(valueType);
+        return valueTypeInfo;
+    }
+
+    public NonElement<T,C> getTarget(T type) {
+        assert parent.builder!=null : "this method must be called during the build stage";
+        return parent.builder.getTypeInfo(type,this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Messages.java
new file mode 100644
index 0000000..8f9e79a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Messages.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources
+ */
+enum Messages {
+    // ClassInfoImpl
+    ID_MUST_BE_STRING, // 1 arg
+
+    MUTUALLY_EXCLUSIVE_ANNOTATIONS,  // 2 args
+    DUPLICATE_ANNOTATIONS, // 1 arg
+    NO_DEFAULT_CONSTRUCTOR, // 1 arg
+    CANT_HANDLE_INTERFACE, // 1 arg
+    ANNOTATION_ON_WRONG_METHOD, // 0 args
+    GETTER_SETTER_INCOMPATIBLE_TYPE, // 2 args
+    DUPLICATE_ENTRY_IN_PROP_ORDER, // 1 arg
+    DUPLICATE_PROPERTIES, // 1 arg
+
+    XML_ELEMENT_MAPPING_ON_NON_IXMLELEMENT_METHOD, // 1 arg
+    SCOPE_IS_NOT_COMPLEXTYPE, // 1 arg
+    CONFLICTING_XML_ELEMENT_MAPPING,    // 2 args
+
+    REFERENCE_TO_NON_ELEMENT, // 1 arg
+
+    NON_EXISTENT_ELEMENT_MAPPING, // 2 args
+
+    TWO_ATTRIBUTE_WILDCARDS, // 1 arg
+    SUPER_CLASS_HAS_WILDCARD, // 0 args
+    INVALID_ATTRIBUTE_WILDCARD_TYPE, // 1 arg
+    PROPERTY_MISSING_FROM_ORDER, // 1 arg
+    PROPERTY_ORDER_CONTAINS_UNUSED_ENTRY, // 1 arg
+
+    INVALID_XML_ENUM_VALUE, // 2 arg
+    FAILED_TO_INITIALE_DATATYPE_FACTORY, // 0 args
+    NO_IMAGE_WRITER, // 1 arg
+
+    ILLEGAL_MIME_TYPE, // 2 args
+    ILLEGAL_ANNOTATION, // 1 arg
+
+    MULTIPLE_VALUE_PROPERTY, // 0 args
+    ELEMENT_AND_VALUE_PROPERTY, // 0 args
+    CONFLICTING_XML_TYPE_MAPPING, // 1 arg
+    XMLVALUE_IN_DERIVED_TYPE, // 0 args
+    SIMPLE_TYPE_IS_REQUIRED, // 1 arg
+    PROPERTY_COLLISION, // 1 arg
+    INVALID_IDREF, // 1 arg
+    INVALID_XML_ELEMENT_REF, // 0 arg
+    NO_XML_ELEMENT_DECL, // 2 args
+    XML_ELEMENT_WRAPPER_ON_NON_COLLECTION, // 1 arg
+
+    ANNOTATION_NOT_ALLOWED, // 1 arg
+    XMLLIST_NEEDS_SIMPLETYPE, // 1 arg
+    XMLLIST_ON_SINGLE_PROPERTY, // 0 arg
+    NO_FACTORY_METHOD, // 2 args
+    FACTORY_CLASS_NEEDS_FACTORY_METHOD, // 1 arg
+
+    MISSING_JAXB_PROPERTIES, // 1arg
+    TRANSIENT_FIELD_NOT_BINDABLE, // 1 arg
+    THERE_MUST_BE_VALUE_IN_XMLVALUE // 1 arg
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Messages.properties
new file mode 100644
index 0000000..a32e0b0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Messages.properties
@@ -0,0 +1,127 @@
+ID_MUST_BE_STRING = \
+    Property "{0}" has an XmlID annotation but its type is not String.
+
+MUTUALLY_EXCLUSIVE_ANNOTATIONS = \
+    {0} has mutually exclusive annotations @{1} and @{2}
+
+DUPLICATE_ANNOTATIONS = \
+    @{0} annotation is found on two places; one would be suffice.
+
+NO_DEFAULT_CONSTRUCTOR = \
+    {0} does not have a no-arg default constructor.
+
+CANT_HANDLE_INTERFACE = \
+    {0} is an interface, and JAXB can''t handle interfaces.
+
+ANNOTATION_ON_WRONG_METHOD = \
+    JAXB annotation is placed on a method that is not a JAXB property
+
+GETTER_SETTER_INCOMPATIBLE_TYPE = \
+    The type of the getter is {0} but that of the setter is {1}. They have to be the same.
+
+DUPLICATE_ENTRY_IN_PROP_ORDER = \
+    Property "{0}" appears more than once in the @XmlType.propOrder
+
+DUPLICATE_PROPERTIES = \
+    There are two properties named "{0}" 
+
+XML_ELEMENT_MAPPING_ON_NON_IXMLELEMENT_METHOD = \
+    The {0} method has @XmlElementMapping on it, but it doesn''t return a sub-type of JAXBElement.
+
+SCOPE_IS_NOT_COMPLEXTYPE = \
+    {0} is not bound to a complex type, and therefore illegal as the scope.
+
+CONFLICTING_XML_ELEMENT_MAPPING = \
+    The element name '{'{0}'}'{1} has more than one mapping.
+    
+REFERENCE_TO_NON_ELEMENT = \
+    Property {0} is annotated with @XmlReference but doesn''t refer to an element.
+
+NON_EXISTENT_ELEMENT_MAPPING = \
+    No element mapping exists for "{0}":"{1}"
+
+TWO_ATTRIBUTE_WILDCARDS = \
+    {0} has two properties with the @XmlAnyAttribute annotation.
+
+SUPER_CLASS_HAS_WILDCARD = \
+    Can''t have @XmlAnyAttribute when a base class has it already.
+
+INVALID_ATTRIBUTE_WILDCARD_TYPE = \
+    @XmlAnyAttribute is placed on a property whose type is {0} but it needs to be assignable to java.util.Map.
+
+PROPERTY_MISSING_FROM_ORDER = \
+    Property {0} is present but not specified in @XmlType.propOrder
+
+PROPERTY_ORDER_CONTAINS_UNUSED_ENTRY = \
+    Property {0} appears in @XmlType.propOrder, but no such property exists
+    
+INVALID_XML_ENUM_VALUE = \
+    "{0}" is not a valid value for {1}.
+
+FAILED_TO_INITIALE_DATATYPE_FACTORY = \
+    Failed to initialize JAXP 1.3 DatatypeFactory class.
+
+NO_IMAGE_WRITER = \
+    No javax.imageio.ImageWriter is available for the specified MIME type "{0}"
+
+ILLEGAL_MIME_TYPE = \
+    "{0}" is not a valid MIME type: {1}
+
+ILLEGAL_ANNOTATION = \
+    {0} annotation cannot be placed here
+
+MULTIPLE_VALUE_PROPERTY = \
+    @XmlValue is only allowed one per class, but two properties are annotated with @XmlValue.
+
+XMLVALUE_IN_DERIVED_TYPE = \
+    @XmlValue is not allowed on a class that derives another class.
+
+ELEMENT_AND_VALUE_PROPERTY = \
+    If a class has @XmlElement property, it cannot have @XmlValue property.
+
+CONFLICTING_XML_TYPE_MAPPING = \
+    Two classes have the same XML type name "{0}". Use @XmlType.name and @XmlType.namespace to \
+    assign different names to them.
+
+SIMPLE_TYPE_IS_REQUIRED = \
+    @XmlAttribute/@XmlValue need to reference a Java type that maps to text in XML.
+
+PROPERTY_COLLISION = \
+    Class has two properties of the same name "{0}"
+
+INVALID_IDREF = \
+    XmlIDREF property is referencing a type "{0}" that doesn''t have an XmlID property.
+
+INVALID_XML_ELEMENT_REF = \
+    XmlElementRef points to a non-existent class.
+
+NO_XML_ELEMENT_DECL = \
+    There''s no ObjectFactory with an @XmlElementDecl for the element '{'{0}'}'{1}.
+
+XML_ELEMENT_WRAPPER_ON_NON_COLLECTION = \
+    @XmlElementWrapper is only allowed on a collection property but "{0}" is not a collection property.
+
+ANNOTATION_NOT_ALLOWED = \
+    {0} annotation is not allowed on this kind of property.
+
+XMLLIST_NEEDS_SIMPLETYPE = \
+    {0} maps to a structured XML fragment (AKA complex type), and therefore incompatible with @XmlList.
+
+XMLLIST_ON_SINGLE_PROPERTY = \
+    @XmlList cannot be placed on a single-value property
+
+NO_FACTORY_METHOD = \
+    Factory class "{0}" does not have static zero args factory method "{1}".
+
+FACTORY_CLASS_NEEDS_FACTORY_METHOD = \
+    XmlType has not defined a factory method for Factory class "{0}".
+
+MISSING_JAXB_PROPERTIES = \
+    Package "{0}" is missing jaxb.properties file. Have you copied this from the generated source directory or include it in the classpath?
+
+TRANSIENT_FIELD_NOT_BINDABLE = \
+    Transient field "{0}" cannot have any JAXB annotations.
+
+THERE_MUST_BE_VALUE_IN_XMLVALUE = \
+    Object must have some value in its @XmlValue field: {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ModelBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ModelBuilder.java
new file mode 100644
index 0000000..e7fc190
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ModelBuilder.java
@@ -0,0 +1,327 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.bind.annotation.XmlRegistry;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.ErrorHandler;
+import com.sun.xml.internal.bind.v2.model.core.LeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.Ref;
+import com.sun.xml.internal.bind.v2.model.core.RegistryInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+
+
+/**
+ * Builds a {@link TypeInfoSet} (a set of JAXB properties)
+ * by using {@link ElementInfoImpl} and {@link ClassInfoImpl}.
+ * from annotated Java classes.
+ *
+ * <p>
+ * This class uses {@link Navigator} and {@link AnnotationReader} to
+ * work with arbitrary annotation source and arbitrary Java model.
+ * For this purpose this class is parameterized.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ModelBuilder<T,C,F,M> {
+
+    /**
+     * {@link TypeInfo}s that are built will go into this set.
+     */
+    final TypeInfoSetImpl<T,C,F,M> typeInfoSet;
+
+    public final AnnotationReader<T,C,F,M> reader;
+
+    public final Navigator<T,C,F,M> nav;
+
+    /**
+     * Used to detect collisions among global type names.
+     */
+    private final Map<QName,TypeInfo> typeNames = new HashMap<QName,TypeInfo>();
+
+    /**
+     * JAXB doesn't want to use namespaces unless we are told to, but WS-I BP
+     * conformace requires JAX-RPC to always use a non-empty namespace URI.
+     * (see http://www.ws-i.org/Profiles/BasicProfile-1.0-2004-04-16.html#WSDLTYPES R2105)
+     *
+     * <p>
+     * To work around this issue, we allow the use of the empty namespaces to be
+     * replaced by a particular designated namespace URI.
+     *
+     * <p>
+     * This field keeps the value of that replacing namespace URI.
+     * When there's no replacement, this field is set to "".
+     */
+    public final String defaultNsUri;
+
+    /**
+     * Packages whose registries are already added.
+     */
+    /*package*/ final Map<String,RegistryInfoImpl> registries = new HashMap<String,RegistryInfoImpl>();
+
+    /**
+     * @see #setErrorHandler
+     */
+    private ErrorHandler errorHandler;
+    private boolean hadError;
+
+    private final ErrorHandler proxyErrorHandler = new ErrorHandler() {
+        public void error(IllegalAnnotationException e) {
+            reportError(e);
+        }
+    };
+
+
+    public ModelBuilder(
+        AnnotationReader<T,C,F,M> reader,
+        Navigator<T,C,F,M> navigator,
+        String defaultNamespaceRemap ) {
+
+        this.reader = reader;
+        this.nav = navigator;
+        if(defaultNamespaceRemap==null)
+            defaultNamespaceRemap = "";
+        this.defaultNsUri = defaultNamespaceRemap;
+        reader.setErrorHandler(proxyErrorHandler);
+        typeInfoSet = createTypeInfoSet();
+    }
+
+    protected TypeInfoSetImpl<T,C,F,M> createTypeInfoSet() {
+        return new TypeInfoSetImpl(nav,reader,BuiltinLeafInfoImpl.createLeaves(nav));
+    }
+
+    /**
+     * Builds a JAXB {@link ClassInfo} model from a given class declaration
+     * and adds that to this model owner.
+     *
+     * <p>
+     * Return type is either {@link ClassInfo} or {@link LeafInfo} (for types like
+     * {@link String} or {@link Enum}-derived ones)
+     */
+    public NonElement<T,C> getClassInfo( C clazz, Locatable upstream ) {
+        assert clazz!=null;
+        NonElement<T,C> r = typeInfoSet.getClassInfo(clazz);
+        if(r!=null)
+            return r;
+
+        if(nav.isEnum(clazz)) {
+            EnumLeafInfoImpl<T,C,F,M> li = createEnumLeafInfo(clazz,upstream);
+            typeInfoSet.add(li);
+            r = li;
+        } else {
+            ClassInfoImpl<T,C,F,M> ci = createClassInfo(clazz,upstream);
+            typeInfoSet.add(ci);
+
+            // compute the closure by eagerly expanding references
+            for( PropertyInfo<T,C> p : ci.getProperties() ) {
+                if(p.kind()== PropertyKind.REFERENCE) {
+                    // make sure that we have a registry for this package
+                    String pkg = nav.getPackageName(ci.getClazz());
+                    if(!registries.containsKey(pkg)) {
+                        // insert the package's object factory
+                        C c = nav.findClass(pkg + ".ObjectFactory",ci.getClazz());
+                        if(c!=null)
+                            addRegistry(c,(Locatable)p);
+                    }
+                }
+
+                for( TypeInfo<T,C> t : p.ref() )
+                    ; // just compute a reference should be suffice
+            }
+            ci.getBaseClass();
+
+            r = ci;
+        }
+
+        addTypeName(r);
+
+        return r;
+    }
+
+    /**
+     * Checks the uniqueness of the type name.
+     */
+    private void addTypeName(NonElement<T, C> r) {
+        QName t = r.getTypeName();
+        if(t==null)     return;
+
+        TypeInfo old = typeNames.put(t,r);
+        if(old!=null) {
+            // collision
+            reportError(new IllegalAnnotationException(
+                    Messages.CONFLICTING_XML_TYPE_MAPPING.format(r.getTypeName()),
+                    old, r ));
+        }
+    }
+
+    /**
+     * Have the builder recognize the type (if it hasn't done so yet),
+     * and returns a {@link NonElement} that represents it.
+     *
+     * @return
+     *      always non-null.
+     */
+    public NonElement<T,C> getTypeInfo(T t,Locatable upstream) {
+        NonElement<T,C> r = typeInfoSet.getTypeInfo(t);
+        if(r!=null)     return r;
+
+        if(nav.isArray(t)) { // no need for checking byte[], because above typeInfoset.getTypeInfo() would return non-null
+            ArrayInfoImpl<T,C,F,M> ai =
+                createArrayInfo(upstream, t);
+            addTypeName(ai);
+            typeInfoSet.add(ai);
+            return ai;
+        }
+
+        C c = nav.asDecl(t);
+        assert c!=null : t.toString()+" must be a leaf, but we failed to recognize it.";
+        return getClassInfo(c,upstream);
+    }
+
+    /**
+     * This method is used to add a root reference to a model.
+     */
+    public NonElement<T,C> getTypeInfo(Ref<T,C> ref) {
+        // TODO: handle XmlValueList
+        assert !ref.valueList;
+        C c = nav.asDecl(ref.type);
+        if(c!=null && reader.getClassAnnotation(XmlRegistry.class,c,null/*TODO: is this right?*/)!=null) {
+            if(!registries.containsKey(nav.getPackageName(c)))
+                addRegistry(c,null);
+            return null;    // TODO: is this correct?
+        } else
+            return getTypeInfo(ref.type,null);
+    }
+
+
+    protected EnumLeafInfoImpl<T,C,F,M> createEnumLeafInfo(C clazz,Locatable upstream) {
+        return new EnumLeafInfoImpl<T,C,F,M>(this,upstream,clazz,nav.use(clazz));
+    }
+
+    protected ClassInfoImpl<T,C,F,M> createClassInfo(
+            C clazz, Locatable upstream ) {
+        return new ClassInfoImpl<T,C,F,M>(this,upstream,clazz);
+    }
+
+    protected ElementInfoImpl<T,C,F,M> createElementInfo(
+        RegistryInfoImpl<T,C,F,M> registryInfo, M m) throws IllegalAnnotationException {
+        return new ElementInfoImpl<T,C,F,M>(this,registryInfo,m);
+    }
+
+    protected ArrayInfoImpl<T,C,F,M> createArrayInfo(Locatable upstream, T arrayType) {
+        return new ArrayInfoImpl<T, C, F, M>(this,upstream,arrayType);
+    }
+
+
+    /**
+     * Visits a class with {@link XmlRegistry} and records all the element mappings
+     * in it.
+     */
+    public RegistryInfo<T,C> addRegistry(C registryClass, Locatable upstream ) {
+        RegistryInfoImpl<T,C,F,M> r = new RegistryInfoImpl<T,C,F,M>(this,upstream,registryClass);
+        return r;
+    }
+
+    /**
+     * Gets a {@link RegistryInfo} for the given package.
+     *
+     * @return
+     *      null if no registry exists for the package.
+     *      unlike other getXXX methods on this class,
+     *      this method is side-effect free.
+     */
+    public RegistryInfo<T,C> getRegistry(String packageName) {
+        return registries.get(packageName);
+    }
+
+    private boolean linked;
+
+    /**
+     * Called after all the classes are added to the type set
+     * to "link" them together.
+     *
+     * <p>
+     * Don't expose implementation classes in the signature.
+     *
+     * @return
+     *      fully built {@link TypeInfoSet} that represents the model,
+     *      or null if there was an error.
+     */
+    public TypeInfoSet<T,C,F,M> link() {
+
+        assert !linked;
+        linked = true;
+
+        for( ElementInfoImpl ei : typeInfoSet.getAllElements() )
+            ei.link();
+
+        for( ClassInfoImpl ci : typeInfoSet.beans().values() )
+            ci.link();
+
+        for( EnumLeafInfoImpl li : typeInfoSet.enums().values() )
+            li.link();
+
+        if(hadError)
+            return null;
+        else
+            return typeInfoSet;
+    }
+
+//
+//
+// error handling
+//
+//
+
+    /**
+     * Sets the error handler that receives errors discovered during the model building.
+     *
+     * @param errorHandler
+     *      can be null.
+     */
+    public void setErrorHandler(ErrorHandler errorHandler) {
+        this.errorHandler = errorHandler;
+    }
+
+    public final void reportError(IllegalAnnotationException e) {
+        hadError = true;
+        if(errorHandler!=null)
+            errorHandler.error(e);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/PropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/PropertyInfoImpl.java
new file mode 100644
index 0000000..8675beb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/PropertyInfoImpl.java
@@ -0,0 +1,334 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.Collection;
+
+import javax.activation.MimeType;
+import javax.xml.bind.annotation.XmlAttachmentRef;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlElementWrapper;
+import javax.xml.bind.annotation.XmlID;
+import javax.xml.bind.annotation.XmlIDREF;
+import javax.xml.bind.annotation.XmlInlineBinaryData;
+import javax.xml.bind.annotation.XmlMimeType;
+import javax.xml.bind.annotation.XmlSchema;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapters;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+import com.sun.xml.internal.bind.v2.runtime.SwaRefAdapter;
+
+/**
+ * Default partial implementation for {@link PropertyInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class PropertyInfoImpl<T,C,F,M>
+    implements PropertyInfo<T,C>, Locatable, Comparable<PropertyInfoImpl> /*by their names*/ {
+
+    /**
+     * Object that reads annotations.
+     */
+    protected final PropertySeed<T,C,F,M> seed;
+
+    private final boolean isCollection;
+
+    private final ID id;
+
+    private final MimeType expectedMimeType;
+    private final boolean inlineBinary;
+    private final QName schemaType;
+
+    protected final ClassInfoImpl<T,C,F,M> parent;
+
+    private final Adapter<T,C> adapter;
+
+    protected PropertyInfoImpl(ClassInfoImpl<T,C,F,M> parent, PropertySeed<T,C,F,M> spi) {
+        this.seed = spi;
+        this.parent = parent;
+        this.id = calcId();
+
+        MimeType mt = Util.calcExpectedMediaType(seed,parent.builder);
+        if(mt!=null && !kind().canHaveXmlMimeType) {
+            parent.builder.reportError(new IllegalAnnotationException(
+                Messages.ILLEGAL_ANNOTATION.format(XmlMimeType.class.getName()),
+                seed.readAnnotation(XmlMimeType.class)
+            ));
+            mt = null;
+        }
+        this.expectedMimeType = mt;
+        this.inlineBinary = seed.hasAnnotation(XmlInlineBinaryData.class);
+        this.schemaType = Util.calcSchemaType(reader(),seed,parent.clazz,
+                getIndividualType(),this);
+
+        T t = seed.getRawType();
+        this.isCollection = nav().isSubClassOf(t, nav().ref(Collection.class))
+                         || nav().isArrayButNotByteArray(t);
+
+        XmlJavaTypeAdapter xjta = getApplicableAdapter(getIndividualType());
+        if(xjta==null) {
+            // ugly ugly hack, but we implement swaRef as adapter
+            XmlAttachmentRef xsa = seed.readAnnotation(XmlAttachmentRef.class);
+            if(xsa!=null) {
+                adapter = new Adapter<T,C>(nav().asDecl(SwaRefAdapter.class),nav());
+            } else {
+                adapter = null;
+            }
+        } else {
+            adapter = new Adapter<T,C>(xjta,reader(),nav());
+        }
+    }
+
+
+    public ClassInfoImpl<T,C,F,M> parent() {
+        return parent;
+    }
+
+    protected final Navigator<T,C,F,M> nav() {
+        return parent.nav();
+    }
+    protected final AnnotationReader<T,C,F,M> reader() {
+        return parent.reader();
+    }
+
+    public T getRawType() {
+        return seed.getRawType();
+    }
+
+    public T getIndividualType() {
+        if(adapter!=null)
+            return adapter.defaultType;
+        T raw = getRawType();
+        if(!isCollection()) {
+            return raw;
+        } else {
+            if(nav().isArrayButNotByteArray(raw))
+                return nav().getComponentType(raw);
+
+            T bt = nav().getBaseClass(raw, nav().asDecl(Collection.class) );
+            if(nav().isParameterizedType(bt))
+                return nav().getTypeArgument(bt,0);
+            else
+                return nav().ref(Object.class);
+        }
+    }
+
+    public final String getName() {
+        return seed.getName();
+    }
+
+    /**
+     * Checks if the given adapter is applicable to the declared property type.
+     */
+    private boolean isApplicable(XmlJavaTypeAdapter jta, T declaredType ) {
+        if(jta==null)   return false;
+
+        T type = reader().getClassValue(jta,"type");
+        return declaredType.equals(type);
+
+    }
+
+    private XmlJavaTypeAdapter getApplicableAdapter(T type) {
+        XmlJavaTypeAdapter jta = seed.readAnnotation(XmlJavaTypeAdapter.class);
+        if(jta!=null)
+            return jta;
+
+        // check the applicable adapters on the package
+        XmlJavaTypeAdapters jtas = reader().getPackageAnnotation(XmlJavaTypeAdapters.class, parent.clazz, seed );
+        if(jtas!=null) {
+            for (XmlJavaTypeAdapter xjta : jtas.value()) {
+                if(isApplicable(xjta,type))
+                    return xjta;
+            }
+        }
+        jta = reader().getPackageAnnotation(XmlJavaTypeAdapter.class, parent.clazz, seed );
+        if(isApplicable(jta,type))
+            return jta;
+
+        // then on the target class
+        C refType = nav().asDecl(seed.getRawType());
+        if(refType!=null) {
+            jta = reader().getClassAnnotation(XmlJavaTypeAdapter.class, refType, seed );
+            if(jta!=null) // the one on the type always apply.
+                return jta;
+        }
+
+        return null;
+    }
+
+    /**
+     * This is the default implementation of the getAdapter method
+     * defined on many of the {@link PropertyInfo}-derived classes.
+     */
+    public Adapter<T,C> getAdapter() {
+        return adapter;
+    }
+
+
+    public final String displayName() {
+        return nav().getClassName(parent.getClazz())+'#'+getName();
+    }
+
+    public final ID id() {
+        return id;
+    }
+
+    private ID calcId() {
+        if(seed.hasAnnotation(XmlID.class)) {
+            // check the type
+            if(!seed.getRawType().equals(nav().ref(String.class)))
+                parent.builder.reportError(new IllegalAnnotationException(
+                    Messages.ID_MUST_BE_STRING.format(getName()), seed )
+                );
+            return ID.ID;
+        } else
+        if(seed.hasAnnotation(XmlIDREF.class)) {
+            return ID.IDREF;
+        } else {
+            return ID.NONE;
+        }
+    }
+
+    public final MimeType getExpectedMimeType() {
+        return expectedMimeType;
+    }
+
+    public final boolean inlineBinaryData() {
+        return inlineBinary;
+    }
+
+    public final QName getSchemaType() {
+        return schemaType;
+    }
+
+    public final boolean isCollection() {
+        return isCollection;
+    }
+
+    /**
+     * Called after all the {@link TypeInfo}s are collected into the governing {@link TypeInfoSet}.
+     *
+     * Derived class can do additional actions to complete the model.
+     */
+    protected void link() {
+        if(id==ID.IDREF) {
+            // make sure that the refereced type has ID
+            for (TypeInfo<T,C> ti : ref()) {
+                if(!ti.canBeReferencedByIDREF())
+                    parent.builder.reportError(new IllegalAnnotationException(
+                    Messages.INVALID_IDREF.format(
+                        parent.builder.nav.getTypeName(ti.getType())), this ));
+            }
+        }
+    }
+
+    /**
+     * A {@link PropertyInfoImpl} is always referenced by its enclosing class,
+     * so return that as the upstream.
+     */
+    public Locatable getUpstream() {
+        return parent;
+    }
+
+    public Location getLocation() {
+        return seed.getLocation();
+    }
+
+
+//
+//
+// convenience methods for derived classes
+//
+//
+
+
+    /**
+     * Computes the tag name from a {@link XmlElement} by taking the defaulting into account.
+     */
+    protected final QName calcXmlName(XmlElement e) {
+        if(e!=null)
+            return calcXmlName(e.namespace(),e.name());
+        else
+            return calcXmlName("##default","##default");
+    }
+
+    /**
+     * Computes the tag name from a {@link XmlElementWrapper} by taking the defaulting into account.
+     */
+    protected final QName calcXmlName(XmlElementWrapper e) {
+        if(e!=null)
+            return calcXmlName(e.namespace(),e.name());
+        else
+            return calcXmlName("##default","##default");
+    }
+
+    private QName calcXmlName(String uri,String local) {
+        // compute the default
+        TODO.checkSpec();
+        if(local.length()==0 || local.equals("##default"))
+            local = seed.getName();
+        if(uri.equals("##default")) {
+            XmlSchema xs = reader().getPackageAnnotation( XmlSchema.class, parent.getClazz(), this );
+            // JAX-RPC doesn't want the default namespace URI swapping to take effect to
+            // local "unqualified" elements. UGLY.
+            if(xs!=null) {
+                switch(xs.elementFormDefault()) {
+                case QUALIFIED:
+                    QName typeName = parent.getTypeName();
+                    if(typeName!=null)
+                        uri = typeName.getNamespaceURI();
+                    else
+                        uri = xs.namespace();
+                    if(uri.length()==0)
+                        uri = parent.builder.defaultNsUri;
+                    break;
+                case UNQUALIFIED:
+                case UNSET:
+                    uri = "";
+                }
+            } else {
+                uri = "";
+            }
+        }
+        return new QName(uri.intern(),local.intern());
+    }
+
+    public int compareTo(PropertyInfoImpl that) {
+        return this.getName().compareTo(that.getName());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/PropertySeed.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/PropertySeed.java
new file mode 100644
index 0000000..9c190a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/PropertySeed.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationSource;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+
+/**
+ * Exposes the core information that forms a {@link PropertyInfo}.
+ */
+interface PropertySeed<T,C,F,M> extends Locatable, AnnotationSource {
+
+    /**
+     * The name of the property is a spec defined concept --- although it doesn't do
+     * so explicitly in anywhere.
+     *
+     * @see PropertyInfo#getName()
+     */
+    String getName();
+
+
+    /**
+     * Gets the actual data type of the field.
+     *
+     * <p>
+     * The data of the property is stored by using this type.
+     *
+     * <p>
+     * The difference between the {@link RuntimePropertyInfo#getIndividualType()}
+     * and this method is clear when the property is a multi-value property.
+     * The {@link RuntimePropertyInfo#getIndividualType()} method returns the type of the item,
+     * but this method returns the actual collection type.
+     */
+    T getRawType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ReferencePropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ReferencePropertyInfoImpl.java
new file mode 100644
index 0000000..7e95ce1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ReferencePropertyInfoImpl.java
@@ -0,0 +1,261 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.Collections;
+import java.util.LinkedHashSet;
+import java.util.Set;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.annotation.XmlAnyElement;
+import javax.xml.bind.annotation.XmlElementRef;
+import javax.xml.bind.annotation.XmlElementRefs;
+import javax.xml.bind.annotation.XmlMixed;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.bind.v2.model.core.ElementInfo;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.ReferencePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+
+/**
+ * Implementation of {@link ReferencePropertyInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class ReferencePropertyInfoImpl<T,C,F,M>
+    extends ERPropertyInfoImpl<T,C,F,M>
+    implements ReferencePropertyInfo<T,C>
+{
+    /**
+     * Lazily computed.
+     * @see #getElements()
+     */
+    private Set<Element<T,C>> types;
+
+    private final boolean isMixed;
+
+    private final WildcardMode wildcard;
+    private final C domHandler;
+
+
+    public ReferencePropertyInfoImpl(
+        ClassInfoImpl<T,C,F,M> classInfo,
+        PropertySeed<T,C,F,M> seed) {
+
+        super(classInfo, seed);
+
+        isMixed = seed.readAnnotation(XmlMixed.class)!=null;
+
+        XmlAnyElement xae = seed.readAnnotation(XmlAnyElement.class);
+        if(xae==null) {
+            wildcard = null;
+            domHandler = null;
+        } else {
+            wildcard = xae.lax()?WildcardMode.LAX:WildcardMode.SKIP;
+            domHandler = nav().asDecl(reader().getClassValue(xae,"value"));
+        }
+    }
+
+    public Set<? extends Element<T,C>> ref() {
+        return getElements();
+    }
+
+    public PropertyKind kind() {
+        return PropertyKind.REFERENCE;
+    }
+
+    public Set<? extends Element<T,C>> getElements() {
+        if(types==null)
+            calcTypes(false);
+        assert types!=null;
+        return types;
+    }
+
+    /**
+     * Compute {@link #types}.
+     *
+     * @param last
+     *      if true, every {@link XmlElementRef} must yield at least one type.
+     */
+    private void calcTypes(boolean last) {
+        XmlElementRef[] ann;
+        types = new LinkedHashSet<Element<T,C>>();
+        XmlElementRefs refs = seed.readAnnotation(XmlElementRefs.class);
+        XmlElementRef ref = seed.readAnnotation(XmlElementRef.class);
+
+        if(refs!=null && ref!=null) {
+            parent.builder.reportError(new IllegalAnnotationException(
+                    Messages.MUTUALLY_EXCLUSIVE_ANNOTATIONS.format(
+                    nav().getClassName(parent.getClazz())+'#'+seed.getName(),
+                    ref.annotationType().getName(), refs.annotationType().getName()),
+                    ref, refs ));
+        }
+
+        if(refs!=null)
+            ann = refs.value();
+        else {
+            if(ref!=null)
+                ann = new XmlElementRef[]{ref};
+            else
+                ann = null;
+        }
+
+        if(ann!=null) {
+            Navigator<T,C,F,M> nav = nav();
+            AnnotationReader<T,C,F,M> reader = reader();
+
+            final T defaultType = nav.ref(XmlElementRef.DEFAULT.class);
+            final C je = nav.asDecl(JAXBElement.class);
+
+            for( XmlElementRef r : ann ) {
+                boolean yield;
+                T type = reader.getClassValue(r,"type");
+                if( type.equals(defaultType) ) type = nav.erasure(getIndividualType());
+                if(nav.getBaseClass(type,je)!=null)
+                    yield = addGenericElement(r);
+                else
+                    yield = addAllSubtypes(type);
+
+                if(last && !yield) {
+                    // a reference didn't produce any type.
+                    // diagnose the problem
+                    if(type.equals(nav.ref(JAXBElement.class))) {
+                        // no XmlElementDecl
+                        parent.builder.reportError(new IllegalAnnotationException(
+                            Messages.NO_XML_ELEMENT_DECL.format(
+                                getEffectiveNamespaceFor(r), r.name()),
+                            this
+                        ));
+                    } else {
+                        parent.builder.reportError(new IllegalAnnotationException(
+                            Messages.INVALID_XML_ELEMENT_REF.format(),this));
+                    }
+
+                    // reporting one error would do.
+                    // often the element ref field is using @XmlElementRefs
+                    // to point to multiple JAXBElements.
+                    // reporting one error for each @XmlElemetnRef is thus often redundant.
+                    return;
+                }
+            }
+        }
+
+        types = Collections.unmodifiableSet(types);
+    }
+
+    /**
+     * @return
+     *      true if the reference yields at least one type
+     */
+    private boolean addGenericElement(XmlElementRef r) {
+        String nsUri = getEffectiveNamespaceFor(r);
+        // TODO: check spec. defaulting of localName.
+        return addGenericElement(parent.owner.getElementInfo(parent.getClazz(),new QName(nsUri,r.name())));
+    }
+
+    private String getEffectiveNamespaceFor(XmlElementRef r) {
+        String nsUri = r.namespace();
+        if(nsUri.length()==0)
+            nsUri = parent.builder.defaultNsUri;
+        return nsUri;
+    }
+
+    private boolean addGenericElement(ElementInfo<T,C> ei) {
+        if(ei==null)
+            return false;
+        types.add(ei);
+        for( ElementInfo<T,C> subst : ei.getSubstitutionMembers() )
+            addGenericElement(subst);
+        return true;
+    }
+
+    private boolean addAllSubtypes(T type) {
+        Navigator<T,C,F,M> nav = nav();
+
+        // this allows the explicitly referenced type to be sucked in to the model
+        NonElement<T,C> t = parent.builder.getClassInfo(nav.asDecl(type),this);
+        if(!(t instanceof ClassInfo))
+            // this is leaf.
+            return false;
+
+        boolean result = false;
+
+        ClassInfo<T,C> c = (ClassInfo<T,C>) t;
+        if(c.isElement()) {
+            types.add(c.asElement());
+            result = true;
+        }
+
+        // look for other possible types
+        for( ClassInfo<T,C> ci : parent.owner.beans().values() ) {
+            if(ci.isElement() && nav.isSubClassOf(ci.getType(),type)) {
+                types.add(ci.asElement());
+                result = true;
+            }
+        }
+
+        // don't allow local elements to substitute.
+        for( ElementInfo<T,C> ei : parent.owner.getElementMappings(null).values()) {
+            if(nav.isSubClassOf(ei.getType(),type)) {
+                types.add(ei);
+                result = true;
+            }
+        }
+
+        return result;
+    }
+
+
+    protected void link() {
+        super.link();
+
+        // until we get the whole thing into TypeInfoSet,
+        // we never really know what are all the possible types that can be assigned on this field.
+        // so recompute this value when we have all the information.
+        calcTypes(true);
+
+    }
+
+
+    public final boolean isMixed() {
+        return isMixed;
+    }
+
+    public final WildcardMode getWildcard() {
+        return wildcard;
+    }
+
+    public final C getDOMHandler() {
+        return domHandler;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RegistryInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RegistryInfoImpl.java
new file mode 100644
index 0000000..eebc654
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RegistryInfoImpl.java
@@ -0,0 +1,133 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.LinkedHashSet;
+import java.util.Set;
+
+import javax.xml.bind.annotation.XmlElementDecl;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.annotation.MethodLocatable;
+import com.sun.xml.internal.bind.v2.model.core.RegistryInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+import com.sun.xml.internal.bind.v2.ContextFactory;
+
+/**
+ * Implementation of {@link RegistryInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+// experimenting with shorter type parameters for <T,C,F,M> quadruple.
+// the idea is that they show so often that you'd understand the meaning
+// without relying on the whole name.
+final class RegistryInfoImpl<T,C,F,M> implements Locatable, RegistryInfo<T,C> {
+
+    final C registryClass;
+    private final Locatable upstream;
+    private final Navigator<T,C,F,M> nav;
+
+    /**
+     * Types that are referenced from this registry.
+     */
+    private final Set<TypeInfo<T,C>> references = new LinkedHashSet<TypeInfo<T,C>>();
+
+    /**
+     * Picks up references in this registry to other types.
+     */
+    RegistryInfoImpl(ModelBuilder<T,C,F,M> builder, Locatable upstream, C registryClass) {
+        this.nav = builder.nav;
+        this.registryClass = registryClass;
+        this.upstream = upstream;
+        builder.registries.put(getPackageName(),this);
+
+        if(nav.getDeclaredField(registryClass,ContextFactory.USE_JAXB_PROPERTIES)!=null) {
+            // the user is trying to use ObjectFactory that we generate for interfaces,
+            // that means he's missing jaxb.properties
+            builder.reportError(new IllegalAnnotationException(
+                Messages.MISSING_JAXB_PROPERTIES.format(getPackageName()),
+                this
+            ));
+            // looking at members will only add more errors, so just abort now
+            return;
+        }
+
+        for( M m : nav.getDeclaredMethods(registryClass) ) {
+            XmlElementDecl em = builder.reader.getMethodAnnotation(
+                XmlElementDecl.class, m, this );
+
+            if(em==null) {
+                if(nav.getMethodName(m).startsWith("create")) {
+                    // this is a factory method. visit this class
+                    references.add(
+                        builder.getTypeInfo(nav.getReturnType(m),
+                            new MethodLocatable<M>(this,m,nav)));
+                }
+
+                continue;
+            }
+
+            ElementInfoImpl<T,C,F,M> ei;
+            try {
+                ei = builder.createElementInfo(this,m);
+            } catch (IllegalAnnotationException e) {
+                builder.reportError(e);
+                continue;   // recover by ignoring this element
+            }
+
+            // register this mapping
+            // TODO: any chance this could cause a stack overflow (by recursively visiting classes)?
+            builder.typeInfoSet.add(ei,builder);
+            references.add(ei);
+        }
+    }
+
+    public Locatable getUpstream() {
+        return upstream;
+    }
+
+    public Location getLocation() {
+        return nav.getClassLocation(registryClass);
+    }
+
+    public Set<TypeInfo<T,C>> getReferences() {
+        return references;
+    }
+
+    /**
+     * Gets the name of the package that this registry governs.
+     */
+    public String getPackageName() {
+        return nav.getPackageName(registryClass);
+    }
+
+    public C getClazz() {
+        return registryClass;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeAnyTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeAnyTypeImpl.java
new file mode 100644
index 0000000..06e5214
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeAnyTypeImpl.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class RuntimeAnyTypeImpl extends AnyTypeImpl<Type,Class> implements RuntimeNonElement {
+    private RuntimeAnyTypeImpl() {
+        super(Navigator.REFLECTION);
+    }
+
+    public <V> Transducer<V> getTransducer() {
+        return null;
+    }
+
+    static final RuntimeNonElement theInstance = new RuntimeAnyTypeImpl();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeArrayInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeArrayInfoImpl.java
new file mode 100644
index 0000000..2731afa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeArrayInfoImpl.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeArrayInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class RuntimeArrayInfoImpl extends ArrayInfoImpl<Type,Class,Field,Method> implements RuntimeArrayInfo {
+    RuntimeArrayInfoImpl(RuntimeModelBuilder builder, Locatable upstream, Class arrayType) {
+        super(builder, upstream, arrayType);
+    }
+
+    public Class getType() {
+        return (Class)super.getType();
+    }
+
+    public RuntimeNonElement getItemType() {
+        return (RuntimeNonElement)super.getItemType();
+    }
+
+    public <V> Transducer<V> getTransducer() {
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeAttributePropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeAttributePropertyInfoImpl.java
new file mode 100644
index 0000000..a4e3bd1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeAttributePropertyInfoImpl.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.List;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeAttributePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class RuntimeAttributePropertyInfoImpl extends AttributePropertyInfoImpl<Type,Class,Field,Method>
+    implements RuntimeAttributePropertyInfo {
+
+    RuntimeAttributePropertyInfoImpl(RuntimeClassInfoImpl classInfo, PropertySeed<Type,Class,Field,Method> seed) {
+        super(classInfo, seed);
+    }
+
+    public boolean elementOnlyContent() {
+        return true;
+    }
+
+    public RuntimeNonElement getTarget() {
+        return (RuntimeNonElement) super.getTarget();
+    }
+
+    public List<? extends RuntimeNonElement> ref() {
+        return (List<? extends RuntimeNonElement>)super.ref();
+    }
+
+    public RuntimePropertyInfo getSource() {
+        return this;
+    }
+
+    public void link() {
+        getTransducer();
+        super.link();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeBuiltinLeafInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeBuiltinLeafInfoImpl.java
new file mode 100644
index 0000000..719ae13
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeBuiltinLeafInfoImpl.java
@@ -0,0 +1,867 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.awt.*;
+import java.awt.image.BufferedImage;
+import java.io.ByteArrayInputStream;
+import java.io.File;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStreamWriter;
+import java.io.UnsupportedEncodingException;
+import java.lang.reflect.Type;
+import java.math.BigDecimal;
+import java.math.BigInteger;
+import java.net.MalformedURLException;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.Calendar;
+import java.util.Collections;
+import java.util.Date;
+import java.util.GregorianCalendar;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.UUID;
+
+import javax.activation.DataHandler;
+import javax.activation.DataSource;
+import javax.activation.MimeType;
+import javax.activation.MimeTypeParseException;
+import javax.imageio.ImageIO;
+import javax.imageio.ImageWriter;
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.datatype.DatatypeConfigurationException;
+import javax.xml.datatype.DatatypeConstants;
+import javax.xml.datatype.DatatypeFactory;
+import javax.xml.datatype.Duration;
+import javax.xml.datatype.XMLGregorianCalendar;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.transform.Source;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.stream.StreamResult;
+
+import com.sun.istack.internal.ByteArrayDataSource;
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeBuiltinLeafInfo;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.output.Pcdata;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Base64Data;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.util.ByteArrayOutputStreamEx;
+import com.sun.xml.internal.bind.v2.util.DataSourceSource;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link BuiltinLeafInfoImpl} with a support for runtime.
+ *
+ * <p>
+ * In particular this class defines {@link Transducer}s for the built-in types.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class RuntimeBuiltinLeafInfoImpl<T> extends BuiltinLeafInfoImpl<Type,Class>
+    implements RuntimeBuiltinLeafInfo, Transducer<T> {
+
+    private RuntimeBuiltinLeafInfoImpl(Class type, QName... typeNames) {
+        super(type, typeNames);
+        LEAVES.put(type,this);
+    }
+
+    public final Class getClazz() {
+        return (Class)getType();
+    }
+
+
+    public final Transducer getTransducer() {
+        return this;
+    }
+
+    public boolean useNamespace() {
+        return false;
+    }
+
+    public final boolean isDefault() {
+        return true;
+    }
+
+    public void declareNamespace(T o, XMLSerializer w) throws AccessorException {
+    }
+
+    public QName getTypeName(T instance) {
+        return null;
+    }
+
+    /**
+     * Those built-in types that print to {@link String}.
+     */
+    private static abstract class StringImpl<T> extends RuntimeBuiltinLeafInfoImpl<T> {
+        protected StringImpl(Class type, QName... typeNames) {
+            super(type,typeNames);
+        }
+
+        public abstract String print(T o) throws AccessorException;
+
+        public void writeText(XMLSerializer w, T o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+            w.text(print(o),fieldName);
+        }
+
+        public void writeLeafElement(XMLSerializer w, Name tagName, T o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+            w.leafElement(tagName,print(o),fieldName);
+        }
+    }
+
+    /**
+     * Those built-in types that print to {@link Pcdata}.
+     */
+    private static abstract class PcdataImpl<T> extends RuntimeBuiltinLeafInfoImpl<T> {
+        protected PcdataImpl(Class type, QName... typeNames) {
+            super(type,typeNames);
+        }
+
+        public abstract Pcdata print(T o) throws AccessorException;
+
+        public final void writeText(XMLSerializer w, T o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+            w.text(print(o),fieldName);
+        }
+
+        public final void writeLeafElement(XMLSerializer w, Name tagName, T o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+            w.leafElement(tagName,print(o),fieldName);
+        }
+
+    }
+
+    /**
+     * All instances of {@link RuntimeBuiltinLeafInfoImpl}s keyed by their type.
+     */
+    public static final Map<Type,RuntimeBuiltinLeafInfoImpl<?>> LEAVES = new HashMap<Type, RuntimeBuiltinLeafInfoImpl<?>>();
+
+    public static final RuntimeBuiltinLeafInfoImpl<String> STRING = new StringImpl<String>(String.class,
+        createXS("string"),
+        createXS("normalizedString"),
+        createXS("token"),
+        createXS("language"),
+        createXS("Name"),
+        createXS("NCName"),
+        createXS("NMTOKEN"),
+        createXS("ENTITY")
+        ) {
+        public String parse(CharSequence text) {
+            return text.toString();
+        }
+        public String print(String s) {
+            return s;
+        }
+        @Override
+        public final void writeText(XMLSerializer w, String o, String fieldName) throws IOException, SAXException, XMLStreamException {
+            w.text(o,fieldName);
+        }
+        @Override
+        public final void writeLeafElement(XMLSerializer w, Name tagName, String o, String fieldName) throws IOException, SAXException, XMLStreamException {
+            w.leafElement(tagName,o,fieldName);
+        }
+    };
+
+    /**
+     * List of all {@link RuntimeBuiltinLeafInfoImpl}s.
+     *
+     * <p>
+     * This corresponds to the built-in Java classes that are specified to be
+     * handled differently than ordinary classes. See table 8-2 "Mapping of Standard Java classes".
+     */
+    public static final List<RuntimeBuiltinLeafInfoImpl<?>> builtinBeanInfos;
+
+    static {
+        RuntimeBuiltinLeafInfoImpl[] secondary = new RuntimeBuiltinLeafInfoImpl[] {
+            /*
+                There are cases where more than one Java classes map to the same XML type.
+                But when we see the same XML type in an incoming document, we only pick
+                one of those Java classes to unmarshal. This Java class is called 'primary'.
+                The rest are called 'secondary'.
+
+                Currently we lack the proper infrastructure to handle those nicely.
+                For now, we rely on a hack.
+
+                We define secondary mappings first, then primary ones later. GrammarInfo
+                builds a map from type name to BeanInfo. By defining primary ones later,
+                those primary bindings will overwrite the secondary ones.
+            */
+
+            /*
+                secondary bindings
+            */
+            new StringImpl<Character>(Character.class, createXS("unsignedShort")) {
+                public Character parse(CharSequence text) {
+                    // TODO.checkSpec("default mapping for char is not defined yet");
+                    return (char)DatatypeConverterImpl._parseInt(text);
+                }
+                public String print(Character v) {
+                    return Integer.toString(v);
+                }
+            },
+            new StringImpl<Calendar>(Calendar.class, DatatypeConstants.DATETIME) {
+                public Calendar parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseDateTime(text.toString());
+                }
+                public String print(Calendar v) {
+                    return DatatypeConverterImpl._printDateTime(v);
+                }
+            },
+            new StringImpl<GregorianCalendar>(GregorianCalendar.class, DatatypeConstants.DATETIME) {
+                public GregorianCalendar parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseDateTime(text.toString());
+                }
+                public String print(GregorianCalendar v) {
+                    return DatatypeConverterImpl._printDateTime(v);
+                }
+            },
+            new StringImpl<Date>(Date.class, DatatypeConstants.DATETIME) {
+                public Date parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseDateTime(text.toString()).getTime();
+                }
+                public String print(Date v) {
+                    GregorianCalendar cal = new GregorianCalendar(0,0,0);
+                    cal.setTime(v);
+                    return DatatypeConverterImpl._printDateTime(cal);
+                }
+            },
+            new StringImpl<File>(File.class, createXS("string")) {
+                public File parse(CharSequence text) {
+                    return new File(WhiteSpaceProcessor.trim(text).toString());
+                }
+                public String print(File v) {
+                    return v.getPath();
+                }
+            },
+            new StringImpl<URL>(URL.class, createXS("anyURI")) {
+                public URL parse(CharSequence text) throws SAXException {
+                    TODO.checkSpec("JSR222 Issue #42");
+                    try {
+                        return new URL(WhiteSpaceProcessor.trim(text).toString());
+                    } catch (MalformedURLException e) {
+                        UnmarshallingContext.getInstance().handleError(e);
+                        return null;
+                    }
+                }
+                public String print(URL v) {
+                    return v.toExternalForm();
+                }
+            },
+            new StringImpl<Class>(Class.class, createXS("string")) {
+                public Class parse(CharSequence text) throws SAXException {
+                    TODO.checkSpec("JSR222 Issue #42");
+                    try {
+                        String name = WhiteSpaceProcessor.trim(text).toString();
+                        ClassLoader cl = Thread.currentThread().getContextClassLoader();
+                        if(cl!=null)
+                            return cl.loadClass(name);
+                        else
+                            return Class.forName(name);
+                    } catch (ClassNotFoundException e) {
+                        UnmarshallingContext.getInstance().handleError(e);
+                        return null;
+                    }
+                }
+                public String print(Class v) {
+                    return v.getName();
+                }
+            },
+
+            /*
+                classes that map to base64Binary / MTOM related classes.
+                a part of the secondary binding.
+            */
+            new PcdataImpl<Image>(Image.class, createXS("base64Binary")) {
+                public Image parse(CharSequence text) throws SAXException  {
+                    try {
+                        InputStream is;
+                        if(text instanceof Base64Data)
+                            is = ((Base64Data)text).getInputStream();
+                        else
+                            is = new ByteArrayInputStream(decodeBase64(text)); // TODO: buffering is inefficient
+
+                        // technically we should check the MIME type here, but
+                        // normally images can be content-sniffed.
+                        // so the MIME type check will only make us slower and draconian, both of which
+                        // JAXB 2.0 isn't interested.
+                        return ImageIO.read(is);
+                    } catch (IOException e) {
+                        UnmarshallingContext.getInstance().handleError(e);
+                        return null;
+                    }
+                }
+
+                private BufferedImage convertToBufferedImage(Image image) throws IOException {
+                    if (image instanceof BufferedImage) {
+                        return (BufferedImage)image;
+
+                    } else {
+                        MediaTracker tracker = new MediaTracker(new Component(){}); // not sure if this is the right thing to do.
+                        tracker.addImage(image, 0);
+                        try {
+                            tracker.waitForAll();
+                        } catch (InterruptedException e) {
+                            throw new IOException(e.getMessage());
+                        }
+                        BufferedImage bufImage = new BufferedImage(
+                                image.getWidth(null),
+                                image.getHeight(null),
+                                BufferedImage.TYPE_INT_ARGB);
+
+                        Graphics g = bufImage.createGraphics();
+                        g.drawImage(image, 0, 0, null);
+                        return bufImage;
+                    }
+                }
+
+                public Base64Data print(Image v) {
+                    ByteArrayOutputStreamEx imageData = new ByteArrayOutputStreamEx();
+                    XMLSerializer xs = XMLSerializer.getInstance();
+
+                    String mimeType = xs.getXMIMEContentType();
+                    if(mimeType==null || mimeType.startsWith("image/*"))
+                        // because PNG is lossless, it's a good default
+                        //
+                        // mime type can be a range, in which case we can't just pass that
+                        // to ImageIO.getImageWritersByMIMEType, so here I'm just assuming
+                        // the default of PNG. Not sure if this is complete.
+                        mimeType = "image/png";
+
+                    try {
+                        Iterator<ImageWriter> itr = ImageIO.getImageWritersByMIMEType(mimeType);
+                        if(itr.hasNext()) {
+                            ImageWriter w = itr.next();
+                            w.setOutput(ImageIO.createImageOutputStream(imageData));
+                            w.write(convertToBufferedImage(v));
+                            w.dispose();
+                        } else {
+                            // no encoder
+                            xs.handleEvent(new ValidationEventImpl(
+                                ValidationEvent.ERROR,
+                                Messages.NO_IMAGE_WRITER.format(mimeType),
+                                xs.getCurrentLocation(null) ));
+                            // TODO: proper error reporting
+                            throw new RuntimeException("no encoder for MIME type "+mimeType);
+                        }
+                    } catch (IOException e) {
+                        xs.handleError(e);
+                        // TODO: proper error reporting
+                        throw new RuntimeException(e);
+                    }
+                    Base64Data bd = xs.getCachedBase64DataInstance();
+                    imageData.set(bd,mimeType);
+                    return bd;
+                }
+            },
+            new PcdataImpl<DataHandler>(DataHandler.class, createXS("base64Binary")) {
+                public DataHandler parse(CharSequence text) {
+                    if(text instanceof Base64Data)
+                        return ((Base64Data)text).getDataHandler();
+                    else
+                        return new DataHandler(new ByteArrayDataSource(decodeBase64(text),
+                            UnmarshallingContext.getInstance().getXMIMEContentType()));
+                }
+
+                public Base64Data print(DataHandler v) {
+                    Base64Data bd = XMLSerializer.getInstance().getCachedBase64DataInstance();
+                    bd.set(v);
+                    return bd;
+                }
+            },
+            new PcdataImpl<Source>(Source.class, createXS("base64Binary")) {
+                public Source parse(CharSequence text) throws SAXException  {
+                    try {
+                        if(text instanceof Base64Data)
+                            return new DataSourceSource( ((Base64Data)text).getDataHandler() );
+                        else
+                            return new DataSourceSource(new ByteArrayDataSource(decodeBase64(text),
+                                UnmarshallingContext.getInstance().getXMIMEContentType()));
+                    } catch (MimeTypeParseException e) {
+                        UnmarshallingContext.getInstance().handleError(e);
+                        return null;
+                    }
+                }
+
+                public Base64Data print(Source v) {
+                    XMLSerializer xs = XMLSerializer.getInstance();
+                    Base64Data bd = xs.getCachedBase64DataInstance();
+
+                    String contentType = xs.getXMIMEContentType();
+                    MimeType mt = null;
+                    if(contentType!=null)
+                        try {
+                            mt = new MimeType(contentType);
+                        } catch (MimeTypeParseException e) {
+                            xs.handleError(e);
+                            // recover by ignoring the content type specification
+                        }
+
+                    if( v instanceof DataSourceSource ) {
+                        // if so, we already have immutable DataSource so
+                        // this can be done efficiently
+                        DataSource ds = ((DataSourceSource)v).getDataSource();
+
+                        String dsct = ds.getContentType();
+                        if(dsct!=null && (contentType==null || contentType.equals(dsct))) {
+                            bd.set(new DataHandler(ds));
+                            return bd;
+                        }
+                    }
+
+                    // general case. slower.
+
+                    // find out the encoding
+                    String charset=null;
+                    if(mt!=null)
+                        charset = mt.getParameter("charset");
+                    if(charset==null)
+                        charset = "UTF-8";
+
+                    try {
+                        ByteArrayOutputStreamEx baos = new ByteArrayOutputStreamEx();
+                        xs.getIdentityTransformer().transform(v,
+                            new StreamResult(new OutputStreamWriter(baos,charset)));
+                        baos.set(bd,"application/xml; charset="+charset);
+                        return bd;
+                    } catch (TransformerException e) {
+                        // TODO: marshaller error handling
+                        xs.handleError(e);
+                    } catch (UnsupportedEncodingException e) {
+                        xs.handleError(e);
+                    }
+
+                    // error recoverly
+                    bd.set(new byte[0],"application/xml");
+                    return bd;
+                }
+            },
+            new StringImpl<XMLGregorianCalendar>(XMLGregorianCalendar.class,
+                    createXS("anySimpleType"),
+                    DatatypeConstants.DATE,
+                    DatatypeConstants.DATETIME,
+                    DatatypeConstants.TIME,
+                    DatatypeConstants.GMONTH,
+                    DatatypeConstants.GDAY,
+                    DatatypeConstants.GYEAR,
+                    DatatypeConstants.GYEARMONTH,
+                    DatatypeConstants.GMONTHDAY
+                ) {
+                public String print(XMLGregorianCalendar cal) {
+                    XMLSerializer xs = XMLSerializer.getInstance();
+
+                    QName type = xs.getSchemaType();
+                    if(type!=null) {
+                        String format = xmlGregorianCalendarFormatString.get(type);
+                        if(format!=null)
+                            return format(format,cal);
+                        // TODO:
+                        // we need to think about how to report an error where @XmlSchemaType
+                        // didn't take effect. a general case is when a transducer isn't even
+                        // written to look at that value.
+                    }
+
+                    return cal.toXMLFormat();
+                }
+
+                public XMLGregorianCalendar parse(CharSequence lexical) throws SAXException {
+                    try {
+                        return datatypeFactory.newXMLGregorianCalendar(lexical.toString());
+                    } catch (Exception e) {
+                        UnmarshallingContext.getInstance().handleError(e);
+                        return null;
+                    }
+                }
+
+                // code duplicated from JAXP RI 1.3. See 6277586
+                private String format( String format, XMLGregorianCalendar value ) {
+                    StringBuilder buf = new StringBuilder();
+                    int fidx=0,flen=format.length();
+
+                    while(fidx<flen) {
+                        char fch = format.charAt(fidx++);
+                        if(fch!='%') {// not a meta char
+                            buf.append(fch);
+                            continue;
+                        }
+
+                        switch(format.charAt(fidx++)) {
+                        case 'Y':
+                            printNumber(buf,value.getEonAndYear(), 4);
+                            break;
+                        case 'M':
+                            printNumber(buf,value.getMonth(),2);
+                            break;
+                        case 'D':
+                            printNumber(buf,value.getDay(),2);
+                            break;
+                        case 'h':
+                            printNumber(buf,value.getHour(),2);
+                            break;
+                        case 'm':
+                            printNumber(buf,value.getMinute(),2);
+                            break;
+                        case 's':
+                            printNumber(buf,value.getSecond(),2);
+                    if (value.getFractionalSecond() != null) {
+                        String frac = value.getFractionalSecond().toString();
+                        //skip leading zero.
+                        buf.append(frac.substring(1, frac.length()));
+                    }
+                            break;
+                        case 'z':
+                    int offset = value.getTimezone();
+                            if(offset == 0) {
+                        buf.append('Z');
+                    } else if (offset != DatatypeConstants.FIELD_UNDEFINED) {
+                        if(offset<0) {
+                        buf.append('-');
+                        offset *= -1;
+                        } else {
+                        buf.append('+');
+                        }
+                        printNumber(buf,offset/60,2);
+                                buf.append(':');
+                                printNumber(buf,offset%60,2);
+                            }
+                            break;
+                        default:
+                            throw new InternalError();  // impossible
+                        }
+                    }
+
+                    return buf.toString();
+                }
+                private void printNumber( StringBuilder out, BigInteger number, int nDigits) {
+                    String s = number.toString();
+                    for( int i=s.length(); i<nDigits; i++ )
+                        out.append('0');
+                    out.append(s);
+                }
+                private void printNumber( StringBuilder out, int number, int nDigits ) {
+                    String s = String.valueOf(number);
+                    for( int i=s.length(); i<nDigits; i++ )
+                        out.append('0');
+                    out.append(s);
+                }
+                @Override
+                public QName getTypeName(XMLGregorianCalendar cal) {
+                    return cal.getXMLSchemaType();
+                }
+            }
+        };
+
+        RuntimeBuiltinLeafInfoImpl[] primary = new RuntimeBuiltinLeafInfoImpl[] {
+            /*
+                primary bindings
+            */
+            STRING,
+            new StringImpl<Boolean>(Boolean.class,
+                createXS("boolean")
+                ) {
+                public Boolean parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseBoolean(text);
+                }
+
+                public String print(Boolean v) {
+                    return v.toString();
+                }
+            },
+            new PcdataImpl<byte[]>(byte[].class,
+                createXS("base64Binary"),
+                createXS("hexBinary")
+                ) {
+                public byte[] parse(CharSequence text) {
+                    return decodeBase64(text);
+                }
+
+                public Base64Data print(byte[] v) {
+                    XMLSerializer w = XMLSerializer.getInstance();
+                    Base64Data bd = w.getCachedBase64DataInstance();
+                    String mimeType = w.getXMIMEContentType();
+                    bd.set(v,mimeType);
+                    return bd;
+                }
+            },
+            new StringImpl<Byte>(Byte.class,
+                createXS("byte")
+                ) {
+                public Byte parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseByte(text);
+                }
+
+                public String print(Byte v) {
+                    return DatatypeConverterImpl._printByte(v);
+                }
+            },
+            new StringImpl<Short>(Short.class,
+                createXS("short"),
+                createXS("unsignedByte")
+                ) {
+                public Short parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseShort(text);
+                }
+
+                public String print(Short v) {
+                    return DatatypeConverterImpl._printShort(v);
+                }
+            },
+            new StringImpl<Integer>(Integer.class,
+                createXS("int"),
+                createXS("unsignedShort")
+                ) {
+                public Integer parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseInt(text);
+                }
+
+                public String print(Integer v) {
+                    return DatatypeConverterImpl._printInt(v);
+                }
+            },
+            new StringImpl<Long>(Long.class,
+                createXS("long"),
+                createXS("unsignedInt")
+                ) {
+                public Long parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseLong(text);
+                }
+
+                public String print(Long v) {
+                    return DatatypeConverterImpl._printLong(v);
+                }
+            },
+            new StringImpl<Float>(Float.class,
+                createXS("float")
+                ) {
+                public Float parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseFloat(text.toString());
+                }
+
+                public String print(Float v) {
+                    return DatatypeConverterImpl._printFloat(v);
+                }
+            },
+            new StringImpl<Double>(Double.class,
+                createXS("double")
+                ) {
+                public Double parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseDouble(text);
+                }
+
+                public String print(Double v) {
+                    return DatatypeConverterImpl._printDouble(v);
+                }
+            },
+            new StringImpl<BigInteger>(BigInteger.class,
+                createXS("integer"),
+                createXS("positiveInteger"),
+                createXS("negativeInteger"),
+                createXS("nonPositiveInteger"),
+                createXS("nonNegativeInteger"),
+                createXS("unsignedLong")
+                ) {
+                public BigInteger parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseInteger(text);
+                }
+
+                public String print(BigInteger v) {
+                    return DatatypeConverterImpl._printInteger(v);
+                }
+            },
+            new StringImpl<BigDecimal>(BigDecimal.class,
+                createXS("decimal")
+                ) {
+                public BigDecimal parse(CharSequence text) {
+                    return DatatypeConverterImpl._parseDecimal(text.toString());
+                }
+
+                public String print(BigDecimal v) {
+                    return DatatypeConverterImpl._printDecimal(v);
+                }
+            },
+            new StringImpl<QName>(QName.class,
+                createXS("QName")
+                ) {
+                public QName parse(CharSequence text) throws SAXException {
+                    try {
+                        return DatatypeConverterImpl._parseQName(text.toString(),UnmarshallingContext.getInstance());
+                    } catch (IllegalArgumentException e) {
+                        UnmarshallingContext.getInstance().handleError(e);
+                        return null;
+                    }
+                }
+
+                public String print(QName v) {
+                    return DatatypeConverterImpl._printQName(v,XMLSerializer.getInstance().getNamespaceContext());
+                }
+
+                public boolean useNamespace() {
+                    return true;
+                }
+
+                public void declareNamespace(QName v, XMLSerializer w) {
+                    w.getNamespaceContext().declareNamespace(v.getNamespaceURI(),v.getPrefix(),false);
+                }
+            },
+            new StringImpl<URI>(URI.class, createXS("anyURI")) {
+                public URI parse(CharSequence text) throws SAXException {
+                    TODO.checkSpec("JSR222 Issue #42");
+                    try {
+                        return new URI(text.toString());
+                    } catch (URISyntaxException e) {
+                        UnmarshallingContext.getInstance().handleError(e);
+                        return null;
+                    }
+                }
+
+                public String print(URI v) {
+                    return v.toString();
+                }
+            },
+            new StringImpl<Duration>(Duration.class,  createXS("duration")) {
+                public String print(Duration duration) {
+                    return duration.toString();
+                }
+
+                public Duration parse(CharSequence lexical) {
+                    TODO.checkSpec("JSR222 Issue #42");
+                    return datatypeFactory.newDuration(lexical.toString());
+                }
+            },
+            new StringImpl<Void>(Void.class) {
+                // 'void' binding isn't defined by the spec, but when the JAX-RPC processes user-defined
+                // methods like "int actionFoo()", they need this pseudo-void property.
+
+                public String print(Void value) {
+                    return "";
+                }
+
+                public Void parse(CharSequence lexical) {
+                    return null;
+                }
+            }
+        };
+
+        List<RuntimeBuiltinLeafInfoImpl<?>> l = new ArrayList<RuntimeBuiltinLeafInfoImpl<?>>(secondary.length+primary.length+1);
+        for (RuntimeBuiltinLeafInfoImpl<?> item : secondary)
+            l.add(item);
+
+        // UUID may fail to load if we are running on JDK 1.4. Handle gracefully
+        try {
+            l.add(new UUIDImpl());
+        } catch (LinkageError e) {
+            // ignore
+        }
+
+        for (RuntimeBuiltinLeafInfoImpl<?> item : primary)
+            l.add(item);
+
+        builtinBeanInfos = Collections.unmodifiableList(l);
+    }
+
+    private static byte[] decodeBase64(CharSequence text) {
+        if (text instanceof Base64Data) {
+            Base64Data base64Data = (Base64Data) text;
+            return base64Data.getExact();
+        } else {
+            return DatatypeConverterImpl._parseBase64Binary(text.toString());
+        }
+    }
+
+
+    private static QName createXS(String typeName) {
+        return new QName(WellKnownNamespace.XML_SCHEMA,typeName);
+    }
+
+    /**
+     * Cached instance of {@link DatatypeFactory} to create
+     * {@link XMLGregorianCalendar} and {@link Duration}.
+     */
+    private static final DatatypeFactory datatypeFactory = init();
+
+    private static DatatypeFactory init() {
+        try {
+            return DatatypeFactory.newInstance();
+        } catch (DatatypeConfigurationException e) {
+            throw new Error(Messages.FAILED_TO_INITIALE_DATATYPE_FACTORY.format(),e);
+        }
+    }
+
+    /**
+     * Format string for the {@link XMLGregorianCalendar}.
+     */
+    private static final Map<QName,String> xmlGregorianCalendarFormatString = new HashMap<QName, String>();
+
+    static {
+        Map<QName,String> m = xmlGregorianCalendarFormatString;
+        // See 4971612: be careful for SCCS substitution
+        m.put(DatatypeConstants.DATETIME,   "%Y-%M-%DT%h:%m:%s"+ "%z");
+        m.put(DatatypeConstants.DATE,       "%Y-%M-%D" +"%z");
+        m.put(DatatypeConstants.TIME,       "%h:%m:%s"+ "%z");
+        m.put(DatatypeConstants.GMONTH,     "--%M--%z");
+        m.put(DatatypeConstants.GDAY,       "---%D" + "%z");
+        m.put(DatatypeConstants.GYEAR,      "%Y" + "%z");
+        m.put(DatatypeConstants.GYEARMONTH, "%Y-%M" + "%z");
+        m.put(DatatypeConstants.GMONTHDAY,  "--%M-%D" +"%z");
+    }
+
+    /**
+     * {@link RuntimeBuiltinLeafInfoImpl} for {@link UUID}.
+     *
+     * This class is given a name so that failing to load this class won't cause a fatal problem.
+     */
+    private static class UUIDImpl extends StringImpl<UUID> {
+        public UUIDImpl() {
+            super(UUID.class, RuntimeBuiltinLeafInfoImpl.createXS("string"));
+        }
+
+        public UUID parse(CharSequence text) throws SAXException {
+            TODO.checkSpec("JSR222 Issue #42");
+            try {
+                return UUID.fromString(WhiteSpaceProcessor.trim(text).toString());
+            } catch (IllegalArgumentException e) {
+                UnmarshallingContext.getInstance().handleError(e);
+                return null;
+            }
+        }
+
+        public String print(UUID v) {
+            return v.toString();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeClassInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeClassInfoImpl.java
new file mode 100644
index 0000000..93dac63
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeClassInfoImpl.java
@@ -0,0 +1,339 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.io.IOException;
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Modifier;
+import java.lang.reflect.Type;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.xml.internal.bind.annotation.XmlLocation;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeClassInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeValuePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.Location;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+class RuntimeClassInfoImpl extends ClassInfoImpl<Type,Class,Field,Method>
+        implements RuntimeClassInfo, RuntimeElement {
+
+    /**
+     * If this class has a property annotated with {@link XmlLocation},
+     * this field will get the accessor for it.
+     *
+     * TODO: support method based XmlLocation
+     */
+    private Accessor<?,Locator> xmlLocationAccessor;
+
+    public RuntimeClassInfoImpl(RuntimeModelBuilder modelBuilder, Locatable upstream, Class clazz) {
+        super(modelBuilder, upstream, clazz);
+    }
+
+    public Method getFactoryMethod(){
+        return super.getFactoryMethod();
+    }
+
+    public final RuntimeClassInfoImpl getBaseClass() {
+        return (RuntimeClassInfoImpl)super.getBaseClass();
+    }
+
+    @Override
+    protected ReferencePropertyInfoImpl createReferenceProperty(PropertySeed<Type,Class,Field,Method> seed) {
+        return new RuntimeReferencePropertyInfoImpl(this,seed);
+    }
+
+    @Override
+    protected AttributePropertyInfoImpl createAttributeProperty(PropertySeed<Type,Class,Field,Method> seed) {
+        return new RuntimeAttributePropertyInfoImpl(this,seed);
+    }
+
+    @Override
+    protected ValuePropertyInfoImpl createValueProperty(PropertySeed<Type,Class,Field,Method> seed) {
+        return new RuntimeValuePropertyInfoImpl(this,seed);
+    }
+
+    @Override
+    protected ElementPropertyInfoImpl createElementProperty(PropertySeed<Type,Class,Field,Method> seed) {
+        return new RuntimeElementPropertyInfoImpl(this,seed);
+    }
+
+    @Override
+    protected MapPropertyInfoImpl createMapProperty(PropertySeed<Type,Class,Field,Method> seed) {
+        return new RuntimeMapPropertyInfoImpl(this,seed);
+    }
+
+
+    @Override
+    public List<? extends RuntimePropertyInfo> getProperties() {
+        return (List<? extends RuntimePropertyInfo>)super.getProperties();
+    }
+
+    @Override
+    public RuntimePropertyInfo getProperty(String name) {
+        return (RuntimePropertyInfo)super.getProperty(name);
+    }
+
+
+    public void link() {
+        super.link();
+        getTransducer();    // populate the transducer
+    }
+
+    private Accessor<?,Map<QName,String>> attributeWildcardAccessor;
+
+    public <B> Accessor<B,Map<QName,String>> getAttributeWildcard() {
+        for( RuntimeClassInfoImpl c=this; c!=null; c=c.getBaseClass() ) {
+            if(c.attributeWildcard!=null) {
+                if(c.attributeWildcardAccessor==null)
+                    c.attributeWildcardAccessor = c.createAttributeWildcardAccessor();
+                return (Accessor<B,Map<QName,String>>)c.attributeWildcardAccessor;
+            }
+        }
+        return null;
+    }
+
+    private boolean computedTransducer = false;
+    private Transducer xducer = null;
+
+    public Transducer getTransducer() {
+        if(!computedTransducer) {
+            computedTransducer = true;
+            xducer = calcTransducer();
+        }
+        return xducer;
+    }
+
+    /**
+     * Creates a transducer if this class is bound to a text in XML.
+     */
+    private Transducer calcTransducer() {
+        RuntimeValuePropertyInfo valuep=null;
+        if(hasAttributeWildcard())
+            return null;        // has attribute wildcard. Can't be handled as a leaf
+        for (RuntimeClassInfoImpl ci = this; ci != null; ci = ci.getBaseClass()) {
+            for( RuntimePropertyInfo pi : ci.getProperties() )
+                if(pi.kind()==PropertyKind.VALUE) {
+                    valuep = (RuntimeValuePropertyInfo)pi;
+                } else {
+                    // this bean has something other than a value
+                    return null;
+                }
+        }
+        if(valuep==null)
+            return null;
+        if( !valuep.getTarget().isSimpleType() )
+            return null;    // if there's an error, recover from it by returning null.
+
+        return new TransducerImpl(getClazz(),TransducedAccessor.get(valuep));
+    }
+
+    /**
+     * Creates
+     */
+    private Accessor<?,Map<QName,String>> createAttributeWildcardAccessor() {
+        assert attributeWildcard!=null;
+        return ((RuntimePropertySeed)attributeWildcard).getAccessor();
+    }
+
+    @Override
+    protected RuntimePropertySeed createFieldSeed(Field field) {
+        Accessor.FieldReflection acc;
+        if(Modifier.isStatic(field.getModifiers()))
+            acc = new Accessor.ReadOnlyFieldReflection(field);
+        else
+            acc = new Accessor.FieldReflection(field);
+
+        return new RuntimePropertySeed(
+            super.createFieldSeed(field),
+                acc );
+    }
+
+    @Override
+    public RuntimePropertySeed createAccessorSeed(Method getter, Method setter) {
+        Accessor acc;
+        if(getter==null)
+            acc = new Accessor.SetterOnlyReflection(setter);
+        else
+        if(setter==null)
+            acc = new Accessor.GetterOnlyReflection(getter);
+        else
+            acc = new Accessor.GetterSetterReflection(getter, setter);
+
+        return new RuntimePropertySeed( super.createAccessorSeed(getter,setter), acc );
+    }
+
+    @Override
+    protected void checkFieldXmlLocation(Field f) {
+        if(reader().hasFieldAnnotation(XmlLocation.class,f))
+            // TODO: check for XmlLocation signature
+            // TODO: check a collision with the super class
+            xmlLocationAccessor = new Accessor.FieldReflection<Object,Locator>(f);
+    }
+
+    public Accessor<?,Locator> getLocatorField() {
+        return xmlLocationAccessor;
+    }
+
+    static final class RuntimePropertySeed implements PropertySeed<Type,Class,Field,Method> {
+        /**
+         * @see #getAccessor()
+         */
+        private final Accessor acc;
+
+        private final PropertySeed<Type,Class,Field,Method> core;
+
+        public RuntimePropertySeed(PropertySeed<Type,Class,Field,Method> core, Accessor acc) {
+            this.core = core;
+            this.acc = acc;
+        }
+
+        public String getName() {
+            return core.getName();
+        }
+
+        public <A extends Annotation> A readAnnotation(Class<A> annotationType) {
+            return core.readAnnotation(annotationType);
+        }
+
+        public boolean hasAnnotation(Class<? extends Annotation> annotationType) {
+            return core.hasAnnotation(annotationType);
+        }
+
+        public Type getRawType() {
+            return core.getRawType();
+        }
+
+        public Location getLocation() {
+            return core.getLocation();
+        }
+
+        public Locatable getUpstream() {
+            return core.getUpstream();
+        }
+
+        public Accessor getAccessor() {
+            return acc;
+        }
+    }
+
+
+
+    /**
+     * {@link Transducer} implementation used when this class maps to PCDATA in XML.
+     *
+     * TODO: revisit the exception handling
+     */
+    private static final class TransducerImpl<BeanT> implements Transducer<BeanT> {
+        private final TransducedAccessor<BeanT> xacc;
+        private final Class<BeanT> ownerClass;
+
+        public TransducerImpl(Class<BeanT> ownerClass,TransducedAccessor<BeanT> xacc) {
+            this.xacc = xacc;
+            this.ownerClass = ownerClass;
+        }
+
+        public boolean useNamespace() {
+            return xacc.useNamespace();
+        }
+
+        public boolean isDefault() {
+            return false;
+        }
+
+        public void declareNamespace(BeanT bean, XMLSerializer w) throws AccessorException {
+            try {
+                xacc.declareNamespace(bean,w);
+            } catch (SAXException e) {
+                throw new AccessorException(e);
+            }
+        }
+
+        public @NotNull CharSequence print(BeanT o) throws AccessorException {
+            try {
+                CharSequence value = xacc.print(o);
+                if(value==null)
+                    throw new AccessorException(Messages.THERE_MUST_BE_VALUE_IN_XMLVALUE.format(o));
+                return value;
+            } catch (SAXException e) {
+                throw new AccessorException(e);
+            }
+        }
+
+        public BeanT parse(CharSequence lexical) throws AccessorException, SAXException {
+            UnmarshallingContext ctxt = UnmarshallingContext.getInstance();
+            BeanT inst;
+            if(ctxt!=null)
+                inst = (BeanT)ctxt.createInstance(ownerClass);
+            else
+                // when this runs for parsing enum constants,
+                // there's no UnmarshallingContext.
+                inst = ClassFactory.create(ownerClass);
+
+            xacc.parse(inst,lexical);
+            return inst;
+        }
+
+        public void writeText(XMLSerializer w, BeanT o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+            if(!xacc.hasValue(o))
+                throw new AccessorException(Messages.THERE_MUST_BE_VALUE_IN_XMLVALUE.format(o));
+            xacc.writeText(w,o,fieldName);
+        }
+
+        public void writeLeafElement(XMLSerializer w, Name tagName, BeanT o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+            if(!xacc.hasValue(o))
+                throw new AccessorException(Messages.THERE_MUST_BE_VALUE_IN_XMLVALUE.format(o));
+            xacc.writeLeafElement(w,tagName,o,fieldName);
+        }
+
+        public QName getTypeName(BeanT instance) {
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeElementInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeElementInfoImpl.java
new file mode 100644
index 0000000..7bf5397
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeElementInfoImpl.java
@@ -0,0 +1,134 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.List;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeClassInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeRef;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class RuntimeElementInfoImpl extends ElementInfoImpl<Type,Class,Field,Method>
+    implements RuntimeElementInfo {
+
+    public RuntimeElementInfoImpl(RuntimeModelBuilder modelBuilder, RegistryInfoImpl registry, Method method) throws IllegalAnnotationException {
+        super(modelBuilder, registry, method);
+
+        Adapter<Type,Class> a = getProperty().getAdapter();
+
+        if(a!=null)
+            adapterType = a.adapterType;
+        else
+            adapterType = null;
+    }
+
+    @Override
+    protected PropertyImpl createPropertyImpl() {
+        return new RuntimePropertyImpl();
+    }
+
+    class RuntimePropertyImpl extends PropertyImpl implements RuntimeElementPropertyInfo, RuntimeTypeRef {
+        public Accessor getAccessor() {
+            if(adapterType==null)
+                return Accessor.JAXB_ELEMENT_VALUE;
+            else
+                return Accessor.JAXB_ELEMENT_VALUE.adapt(
+                        (Class)getAdapter().defaultType,(Class)adapterType);
+        }
+
+        public Type getRawType() {
+            return Collection.class;
+        }
+
+        public Type getIndividualType() {
+             return getContentType().getType();
+        }
+
+
+        public boolean elementOnlyContent() {
+            return false;   // this method doesn't make sense here
+        }
+
+        public List<? extends RuntimeTypeRef> getTypes() {
+            return Collections.singletonList(this);
+        }
+
+        public List<? extends RuntimeNonElement> ref() {
+            return (List<? extends RuntimeNonElement>)super.ref();
+        }
+
+        public RuntimeNonElement getTarget() {
+            return (RuntimeNonElement)super.getTarget();
+        }
+
+        public RuntimePropertyInfo getSource() {
+            return this;
+        }
+
+        public Transducer getTransducer() {
+            return RuntimeModelBuilder.createTransducer(this);
+        }
+    }
+
+    /**
+     * The adapter specified by <code>getProperty().getAdapter()</code>.
+     */
+    private final Class<? extends XmlAdapter> adapterType;
+
+    public RuntimeElementPropertyInfo getProperty() {
+        return (RuntimeElementPropertyInfo)super.getProperty();
+    }
+
+    public Class<? extends JAXBElement> getType() {
+        return JAXBElement.class;
+    }
+
+    public RuntimeClassInfo getScope() {
+        return (RuntimeClassInfo)super.getScope();
+    }
+
+    public RuntimeNonElement getContentType() {
+        return (RuntimeNonElement)super.getContentType();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeElementPropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeElementPropertyInfoImpl.java
new file mode 100644
index 0000000..24edc32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeElementPropertyInfoImpl.java
@@ -0,0 +1,77 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfo;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class RuntimeElementPropertyInfoImpl extends ElementPropertyInfoImpl<Type,Class,Field,Method>
+    implements RuntimeElementPropertyInfo {
+
+    private final Accessor acc;
+
+    RuntimeElementPropertyInfoImpl(RuntimeClassInfoImpl classInfo, PropertySeed<Type,Class,Field,Method> seed) {
+        super(classInfo, seed);
+        Accessor rawAcc = ((RuntimeClassInfoImpl.RuntimePropertySeed)seed).getAccessor();
+        if(getAdapter()!=null && !isCollection())
+            // adapter for a single-value property is handled by accessor.
+            // adapter for a collection property is handled by lister.
+            rawAcc = rawAcc.adapt(getAdapter());
+        this.acc = rawAcc;
+    }
+
+    public Accessor getAccessor() {
+        return acc;
+    }
+
+    public boolean elementOnlyContent() {
+        return true;
+    }
+
+    public List<? extends RuntimeTypeInfo> ref() {
+        return (List<? extends RuntimeTypeInfo>)super.ref();
+    }
+
+    @Override
+    protected RuntimeTypeRefImpl createTypeRef(QName name, Type type, boolean isNillable, String defaultValue) {
+        return new RuntimeTypeRefImpl(this,name,type,isNillable,defaultValue);
+    }
+
+    public List<RuntimeTypeRefImpl> getTypes() {
+        return (List<RuntimeTypeRefImpl>)super.getTypes();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeEnumConstantImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeEnumConstantImpl.java
new file mode 100644
index 0000000..a4eb831
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeEnumConstantImpl.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class RuntimeEnumConstantImpl extends EnumConstantImpl<Type,Class,Field,Method> {
+    public RuntimeEnumConstantImpl(
+        RuntimeEnumLeafInfoImpl owner, String name, String lexical,
+        EnumConstantImpl<Type,Class,Field,Method> next) {
+        super(owner, name, lexical, next);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeEnumLeafInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeEnumLeafInfoImpl.java
new file mode 100644
index 0000000..92fad55
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeEnumLeafInfoImpl.java
@@ -0,0 +1,156 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.io.IOException;
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.EnumMap;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.annotation.FieldLocatable;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeEnumLeafInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class RuntimeEnumLeafInfoImpl<T extends Enum<T>,B> extends EnumLeafInfoImpl<Type,Class,Field,Method>
+    implements RuntimeEnumLeafInfo, Transducer<T> {
+
+    public Transducer<T> getTransducer() {
+        return this;
+    }
+
+    /**
+     * {@link Transducer} that knows how to convert a lexical value
+     * into the Java value that we can handle.
+     */
+    private final Transducer<B> baseXducer;
+
+    private final Map<B,T> parseMap = new HashMap<B,T>();
+    private final Map<T,B> printMap;
+
+    RuntimeEnumLeafInfoImpl(RuntimeModelBuilder builder, Locatable upstream, Class<T> enumType) {
+        super(builder,upstream,enumType,enumType);
+        this.printMap = new EnumMap<T,B>(enumType);
+
+        baseXducer = ((RuntimeNonElement)baseType).getTransducer();
+    }
+
+    @Override
+    public RuntimeEnumConstantImpl createEnumConstant(String name, String literal, Field constant, EnumConstantImpl<Type,Class,Field,Method> last) {
+        T t;
+        try {
+            try {
+                constant.setAccessible(true);
+            } catch (SecurityException e) {
+                // in case the constant is already accessible, swallow this error.
+                // if the constant is indeed not accessible, we will get IllegalAccessException
+                // in the following line, and that is not too late.
+            }
+            t = (T)constant.get(null);
+        } catch (IllegalAccessException e) {
+            // impossible, because this is an enum constant
+            throw new IllegalAccessError(e.getMessage());
+        }
+
+        B b = null;
+        try {
+            b = baseXducer.parse(literal);
+        } catch (Exception e) {
+            builder.reportError(new IllegalAnnotationException(
+                Messages.INVALID_XML_ENUM_VALUE.format(literal,baseType.getType().toString()), e,
+                    new FieldLocatable<Field>(this,constant,nav()) ));
+        }
+
+        parseMap.put(b,t);
+        printMap.put(t,b);
+
+        return new RuntimeEnumConstantImpl(this, name, literal, last);
+    }
+
+    public QName[] getTypeNames() {
+        return new QName[]{getTypeName()};
+    }
+
+    public boolean isDefault() {
+        return false;
+    }
+
+    public Class getClazz() {
+        return clazz;
+    }
+
+    public boolean useNamespace() {
+        return baseXducer.useNamespace();
+    }
+
+    public void declareNamespace(T t, XMLSerializer w) throws AccessorException {
+        baseXducer.declareNamespace(printMap.get(t),w);
+    }
+
+    public CharSequence print(T t) throws AccessorException {
+        return baseXducer.print(printMap.get(t));
+    }
+
+    public T parse(CharSequence lexical) throws AccessorException, SAXException {
+        // TODO: error handling
+
+        B b = baseXducer.parse(lexical);
+        if(b==null) {
+
+            return null;
+        }
+
+        return parseMap.get(b);
+    }
+
+    public void writeText(XMLSerializer w, T t, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        baseXducer.writeText(w,printMap.get(t),fieldName);
+    }
+
+    public void writeLeafElement(XMLSerializer w, Name tagName, T o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        baseXducer.writeLeafElement(w,tagName,printMap.get(o),fieldName);
+    }
+
+    public QName getTypeName(T instance) {
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeMapPropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeMapPropertyInfoImpl.java
new file mode 100644
index 0000000..245e73d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeMapPropertyInfoImpl.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.List;
+
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeMapPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfo;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class RuntimeMapPropertyInfoImpl extends MapPropertyInfoImpl<Type,Class,Field,Method> implements RuntimeMapPropertyInfo {
+    private final Accessor acc;
+
+    RuntimeMapPropertyInfoImpl(RuntimeClassInfoImpl classInfo, PropertySeed<Type,Class,Field,Method> seed) {
+        super(classInfo, seed);
+        this.acc = ((RuntimeClassInfoImpl.RuntimePropertySeed)seed).getAccessor();
+    }
+
+    public Accessor getAccessor() {
+        return acc;
+    }
+
+    public boolean elementOnlyContent() {
+        return true;
+    }
+
+    public RuntimeNonElement getKeyType() {
+        return (RuntimeNonElement)super.getKeyType();
+    }
+
+    public RuntimeNonElement getValueType() {
+        return (RuntimeNonElement)super.getValueType();
+    }
+
+    public List<? extends RuntimeTypeInfo> ref() {
+        return (List<? extends RuntimeTypeInfo>)super.ref();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeModelBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeModelBuilder.java
new file mode 100644
index 0000000..8455748
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeModelBuilder.java
@@ -0,0 +1,162 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+
+import javax.activation.MimeType;
+
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.annotation.RuntimeAnnotationReader;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.model.nav.ReflectionNavigator;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElementRef;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfoSet;
+import com.sun.xml.internal.bind.v2.runtime.FilterTransducer;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.InlineBinaryTransducer;
+import com.sun.xml.internal.bind.v2.runtime.MimeTypedTransducer;
+import com.sun.xml.internal.bind.v2.runtime.SchemaTypeTransducer;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link ModelBuilder} that works at the run-time by using
+ * the {@code java.lang.reflect} package.
+ *
+ * <p>
+ * This extends {@link ModelBuilder} by providing more functionalities such
+ * as accessing the fields and classes.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class RuntimeModelBuilder extends ModelBuilder<Type,Class,Field,Method> {
+
+    public RuntimeModelBuilder(RuntimeAnnotationReader annotationReader, String defaultNamespaceRemap) {
+        super(annotationReader, Navigator.REFLECTION, defaultNamespaceRemap);
+    }
+
+    @Override
+    public RuntimeNonElement getClassInfo( Class clazz, Locatable upstream ) {
+        return (RuntimeNonElement)super.getClassInfo(clazz,upstream);
+    }
+
+    @Override
+    protected RuntimeEnumLeafInfoImpl createEnumLeafInfo(Class clazz, Locatable upstream) {
+        return new RuntimeEnumLeafInfoImpl(this,upstream,clazz);
+    }
+
+    @Override
+    protected RuntimeClassInfoImpl createClassInfo( Class clazz, Locatable upstream ) {
+        return new RuntimeClassInfoImpl(this,upstream,clazz);
+    }
+
+    @Override
+    public RuntimeElementInfoImpl createElementInfo(RegistryInfoImpl<Type,Class,Field,Method> registryInfo, Method method) throws IllegalAnnotationException {
+        return new RuntimeElementInfoImpl(this,registryInfo, method);
+    }
+
+    @Override
+    public RuntimeArrayInfoImpl createArrayInfo(Locatable upstream, Type arrayType) {
+        return new RuntimeArrayInfoImpl(this, upstream, (Class)arrayType);
+    }
+
+    public ReflectionNavigator getNavigator() {
+        return (ReflectionNavigator)nav;
+    }
+
+    @Override
+    protected RuntimeTypeInfoSetImpl createTypeInfoSet() {
+        return new RuntimeTypeInfoSetImpl(reader);
+    }
+
+    @Override
+    public RuntimeTypeInfoSet link() {
+        return (RuntimeTypeInfoSet)super.link();
+    }
+
+    /**
+     * Creates a {@link Transducer} given a reference.
+     *
+     * Used to implement {@link RuntimeNonElementRef#getTransducer()}.
+     * Shouldn't be called from anywhere else.
+     *
+     * TODO: this is not the proper place for this class to be in.
+     */
+    public static Transducer createTransducer(RuntimeNonElementRef ref) {
+        Transducer t = ref.getTarget().getTransducer();
+        RuntimePropertyInfo src = ref.getSource();
+        ID id = src.id();
+
+        if(id==ID.IDREF)
+            return RuntimeBuiltinLeafInfoImpl.STRING;
+
+        if(id==ID.ID)
+            t = new IDTransducerImpl(t);
+
+        MimeType emt = src.getExpectedMimeType();
+        if(emt!=null)
+            t = new MimeTypedTransducer(t,emt);
+
+        if(src.inlineBinaryData())
+            t = new InlineBinaryTransducer(t);
+
+        if(src.getSchemaType()!=null)
+            t = new SchemaTypeTransducer(t,src.getSchemaType());
+
+        return t;
+    }
+
+
+
+    /**
+     * Transducer implementation for ID.
+     *
+     * This transducer wraps another {@link Transducer} and adds
+     * handling for ID.
+     */
+    private static final class IDTransducerImpl<ValueT> extends FilterTransducer<ValueT> {
+        public IDTransducerImpl(Transducer<ValueT> core) {
+            super(core);
+        }
+
+        @Override
+        public ValueT parse(CharSequence lexical) throws AccessorException, SAXException {
+            String value = WhiteSpaceProcessor.trim(lexical).toString();
+            UnmarshallingContext.getInstance().addToIdTable(value);
+            return core.parse(value);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeReferencePropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeReferencePropertyInfoImpl.java
new file mode 100644
index 0000000..fdd90f2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeReferencePropertyInfoImpl.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.Set;
+
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeReferencePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class RuntimeReferencePropertyInfoImpl extends ReferencePropertyInfoImpl<Type,Class,Field,Method>
+    implements RuntimeReferencePropertyInfo {
+
+    private final Accessor acc;
+
+    public RuntimeReferencePropertyInfoImpl(RuntimeClassInfoImpl classInfo, PropertySeed<Type,Class,Field,Method> seed) {
+        super(classInfo,seed);
+        Accessor rawAcc = ((RuntimeClassInfoImpl.RuntimePropertySeed)seed).getAccessor();
+        if(getAdapter()!=null && !isCollection())
+            // adapter for a single-value property is handled by accessor.
+            // adapter for a collection property is handled by lister.
+            rawAcc = rawAcc.adapt(getAdapter());
+        this.acc = rawAcc;
+    }
+
+    public Set<? extends RuntimeElement> getElements() {
+        return (Set<? extends RuntimeElement>)super.getElements();
+    }
+
+    public Set<? extends RuntimeElement> ref() {
+        return (Set<? extends RuntimeElement>)super.ref();
+    }
+
+    public Accessor getAccessor() {
+        return acc;
+    }
+
+    public boolean elementOnlyContent() {
+        return !isMixed();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeTypeInfoSetImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeTypeInfoSetImpl.java
new file mode 100644
index 0000000..23e29ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeTypeInfoSetImpl.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.model.nav.ReflectionNavigator;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfoSet;
+
+/**
+ * {@link TypeInfoSet} specialized for runtime.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class RuntimeTypeInfoSetImpl extends TypeInfoSetImpl<Type,Class,Field,Method> implements RuntimeTypeInfoSet {
+    public RuntimeTypeInfoSetImpl(AnnotationReader<Type,Class,Field,Method> reader) {
+        super(Navigator.REFLECTION,reader,RuntimeBuiltinLeafInfoImpl.LEAVES);
+    }
+
+    @Override
+    protected RuntimeNonElement createAnyType() {
+        return RuntimeAnyTypeImpl.theInstance;
+    }
+
+    public ReflectionNavigator getNavigator() {
+        return (ReflectionNavigator)super.getNavigator();
+    }
+
+    public RuntimeNonElement getTypeInfo( Type type ) {
+        return (RuntimeNonElement)super.getTypeInfo(type);
+    }
+
+    public RuntimeNonElement getAnyTypeInfo() {
+        return (RuntimeNonElement)super.getAnyTypeInfo();
+    }
+
+    public RuntimeNonElement getClassInfo(Class clazz) {
+        return (RuntimeNonElement)super.getClassInfo(clazz);
+    }
+
+    public Map<Class,RuntimeClassInfoImpl> beans() {
+        return (Map<Class,RuntimeClassInfoImpl>)super.beans();
+    }
+
+    public Map<Type,RuntimeBuiltinLeafInfoImpl<?>> builtins() {
+        return (Map<Type,RuntimeBuiltinLeafInfoImpl<?>>)super.builtins();
+    }
+
+    public Map<Class,RuntimeEnumLeafInfoImpl<?,?>> enums() {
+        return (Map<Class,RuntimeEnumLeafInfoImpl<?,?>>)super.enums();
+    }
+
+    public Map<Class,RuntimeArrayInfoImpl> arrays() {
+        return (Map<Class,RuntimeArrayInfoImpl>)super.arrays();
+    }
+
+    public RuntimeElementInfoImpl getElementInfo(Class scope,QName name) {
+        return (RuntimeElementInfoImpl)super.getElementInfo(scope,name);
+    }
+
+    public Map<QName,RuntimeElementInfoImpl> getElementMappings(Class scope) {
+        return (Map<QName,RuntimeElementInfoImpl>)super.getElementMappings(scope);
+    }
+
+    public Iterable<RuntimeElementInfoImpl> getAllElements() {
+        return (Iterable<RuntimeElementInfoImpl>)super.getAllElements();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeTypeRefImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeTypeRefImpl.java
new file mode 100644
index 0000000..43316b2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeTypeRefImpl.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Type;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeRef;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class RuntimeTypeRefImpl extends TypeRefImpl<Type,Class> implements RuntimeTypeRef {
+
+    public RuntimeTypeRefImpl(RuntimeElementPropertyInfoImpl elementPropertyInfo, QName elementName, Type type, boolean isNillable, String defaultValue) {
+        super(elementPropertyInfo, elementName, type, isNillable, defaultValue);
+    }
+
+    public RuntimeNonElement getTarget() {
+        return (RuntimeNonElement)super.getTarget();
+    }
+
+    public Transducer getTransducer() {
+        return RuntimeModelBuilder.createTransducer(this);
+    }
+
+    public RuntimePropertyInfo getSource() {
+        return (RuntimePropertyInfo)owner;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeValuePropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeValuePropertyInfoImpl.java
new file mode 100644
index 0000000..88d8ad0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/RuntimeValuePropertyInfoImpl.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.List;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeValuePropertyInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class RuntimeValuePropertyInfoImpl extends ValuePropertyInfoImpl<Type,Class,Field,Method>
+    implements RuntimeValuePropertyInfo {
+
+    RuntimeValuePropertyInfoImpl(RuntimeClassInfoImpl classInfo, PropertySeed<Type,Class,Field,Method> seed) {
+        super(classInfo, seed);
+    }
+
+    public boolean elementOnlyContent() {
+        return false;
+    }
+
+    public RuntimePropertyInfo getSource() {
+        return (RuntimePropertyInfo)super.getSource();
+    }
+
+    public RuntimeNonElement getTarget() {
+        return (RuntimeNonElement)super.getTarget();
+    }
+
+    public List<? extends RuntimeNonElement> ref() {
+        return (List<? extends RuntimeNonElement>)super.ref();
+    }
+
+    public void link() {
+        getTransducer();
+        super.link();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/SingleTypePropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/SingleTypePropertyInfoImpl.java
new file mode 100644
index 0000000..18f5fd9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/SingleTypePropertyInfoImpl.java
@@ -0,0 +1,134 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.Collections;
+import java.util.List;
+
+import javax.xml.bind.annotation.XmlList;
+
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElementRef;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * {@link PropertyInfoImpl} that can only have one type.
+ *
+ * Specifically, {@link AttributePropertyInfoImpl} and {@link ValuePropertyInfoImpl}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class SingleTypePropertyInfoImpl<T,C,F,M>
+    extends PropertyInfoImpl<T,C,F,M> {
+
+    /**
+     * Computed lazily.
+     *
+     * @see {@link #getTarget()}.
+     */
+    private NonElement<T,C> type;
+
+    public SingleTypePropertyInfoImpl(ClassInfoImpl<T,C,F,M> classInfo, PropertySeed<T,C,F,M> seed) {
+        super(classInfo, seed);
+        if(this instanceof RuntimePropertyInfo) {
+            Accessor rawAcc = ((RuntimeClassInfoImpl.RuntimePropertySeed)seed).getAccessor();
+            if(getAdapter()!=null && !isCollection())
+                // adapter for a single-value property is handled by accessor.
+                // adapter for a collection property is handled by lister.
+                rawAcc = rawAcc.adapt(getAdapter());
+            this.acc = rawAcc;
+        } else
+            this.acc = null;
+    }
+
+    public List<? extends NonElement<T,C>> ref() {
+        return Collections.singletonList(getTarget());
+    }
+
+    public NonElement<T,C> getTarget() {
+        if(type==null) {
+            assert parent.builder!=null : "this method must be called during the build stage";
+            type = parent.builder.getTypeInfo(getIndividualType(),this);
+        }
+        return type;
+    }
+
+    public PropertyInfo<T,C> getSource() {
+        return this;
+    }
+
+    public void link() {
+        super.link();
+
+        if(!type.isSimpleType() && id()!=ID.IDREF) {
+            parent.builder.reportError(new IllegalAnnotationException(
+                Messages.SIMPLE_TYPE_IS_REQUIRED.format(),
+                seed
+            ));
+        }
+
+        if(!isCollection() && seed.hasAnnotation(XmlList.class)) {
+            parent.builder.reportError(new IllegalAnnotationException(
+                Messages.XMLLIST_ON_SINGLE_PROPERTY.format(), this
+            ));
+        }
+    }
+
+//
+//
+// technically these code belong to runtime implementation, but moving the code up here
+// allows this to be shared between RuntimeValuePropertyInfoImpl and RuntimeAttributePropertyInfoImpl
+//
+//
+
+    private final Accessor acc;
+    /**
+     * Lazily created.
+     */
+    private Transducer xducer;
+
+    public Accessor getAccessor() {
+        return acc;
+    }
+
+
+    public Transducer getTransducer() {
+        if(xducer==null) {
+            xducer = RuntimeModelBuilder.createTransducer((RuntimeNonElementRef)this);
+            if(xducer==null) {
+                // this situation is checked by by the link method.
+                // avoid repeating the same error by silently recovering
+                xducer = RuntimeBuiltinLeafInfoImpl.STRING;
+            }
+        }
+        return xducer;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeInfoImpl.java
new file mode 100644
index 0000000..d9e8d41
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeInfoImpl.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlSchema;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.api.impl.NameConverter;
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+
+/**
+ * Common implementation between {@link ClassInfoImpl} and {@link ElementInfoImpl}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class TypeInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+        implements TypeInfo<TypeT,ClassDeclT>, Locatable {
+
+    /**
+     * The Java class that caused this Java class to be a part of the JAXB processing.
+     *
+     * null if it's specified explicitly by the user.
+     */
+    private final Locatable upstream;
+
+    /**
+     * {@link TypeInfoSet} to which this class belongs.
+     */
+    protected final TypeInfoSetImpl<TypeT,ClassDeclT,FieldT,MethodT> owner;
+
+    /**
+     * Reference to the {@link ModelBuilder}, only until we link {@link TypeInfo}s all together,
+     * because we don't want to keep {@link ModelBuilder} too long.
+     */
+    protected ModelBuilder<TypeT,ClassDeclT,FieldT,MethodT> builder;
+
+    protected TypeInfoImpl(
+        ModelBuilder<TypeT,ClassDeclT,FieldT,MethodT> builder,
+        Locatable upstream) {
+
+        this.builder = builder;
+        this.owner = builder.typeInfoSet;
+        this.upstream = upstream;
+    }
+
+    public Locatable getUpstream() {
+        return upstream;
+    }
+
+    /*package*/ void link() {
+        builder = null;
+    }
+
+    protected final Navigator<TypeT,ClassDeclT,FieldT,MethodT> nav() {
+        return owner.nav;
+    }
+
+    protected final AnnotationReader<TypeT,ClassDeclT,FieldT,MethodT> reader() {
+        return owner.reader;
+    }
+
+    /**
+     * Parses an {@link XmlRootElement} annotation on a class
+     * and determine the element name.
+     *
+     * @return null
+     *      if none was found.
+     */
+    protected final QName parseElementName(ClassDeclT clazz) {
+        XmlRootElement e = reader().getClassAnnotation(XmlRootElement.class,clazz,this);
+        if(e==null)
+            return null;
+
+        String local = e.name();
+        if(local.equals("##default")) {
+            // if defaulted...
+            local = NameConverter.standard.toVariableName(nav().getClassShortName(clazz));
+        }
+        String nsUri = e.namespace();
+        if(nsUri.equals("##default")) {
+            // if defaulted ...
+            XmlSchema xs = reader().getPackageAnnotation(XmlSchema.class,clazz,this);
+            if(xs!=null)
+                nsUri = xs.namespace();
+            else {
+                nsUri = builder.defaultNsUri;
+            }
+        }
+
+        return new QName(nsUri.intern(),local.intern());
+    }
+
+    protected final QName parseTypeName(ClassDeclT clazz) {
+        return parseTypeName( clazz, reader().getClassAnnotation(XmlType.class,clazz,this) );
+    }
+
+    /**
+     * Parses a (potentially-null) {@link XmlType} annotation on a class
+     * and determine the actual value.
+     *
+     * @param clazz
+     *      The class on which the XmlType annotation is checked.
+     * @param t
+     *      The {@link XmlType} annotation on the clazz. This value
+     *      is taken as a parameter to improve the performance for the case where
+     *      't' is pre-computed.
+     */
+    protected final QName parseTypeName(ClassDeclT clazz, XmlType t) {
+        String nsUri="##default";
+        String local="##default";
+        if(t!=null) {
+            nsUri = t.namespace();
+            local = t.name();
+        }
+
+        if(local.length()==0)
+            return null; // anonymous
+
+
+        if(local.equals("##default"))
+            // if defaulted ...
+            local = NameConverter.standard.toVariableName(nav().getClassShortName(clazz));
+
+        if(nsUri.equals("##default")) {
+            // if defaulted ...
+            XmlSchema xs = reader().getPackageAnnotation(XmlSchema.class,clazz,this);
+            if(xs!=null)
+                nsUri = xs.namespace();
+            else {
+                nsUri = builder.defaultNsUri;
+            }
+        }
+
+        return new QName(nsUri.intern(),local.intern());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeInfoSetImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeInfoSetImpl.java
new file mode 100644
index 0000000..ef5fa01
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeInfoSetImpl.java
@@ -0,0 +1,376 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.LinkedHashMap;
+import java.util.Map;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.annotation.XmlNs;
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.bind.annotation.XmlRegistry;
+import javax.xml.bind.annotation.XmlSchema;
+import javax.xml.bind.annotation.XmlTransient;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Result;
+
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.core.BuiltinLeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.LeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.Ref;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+import com.sun.xml.internal.bind.v2.runtime.RuntimeUtil;
+import com.sun.xml.internal.bind.v2.util.FlattenIterator;
+
+/**
+ * Set of {@link TypeInfo}s.
+ *
+ * <p>
+ * This contains a fixed set of {@link LeafInfo}s and arbitrary set of {@link ClassInfo}s.
+ *
+ * <p>
+ * Members are annotated with JAXB annotations so that we can dump it easily.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class TypeInfoSetImpl<TypeT,ClassDeclT,FieldT,MethodT> implements
+        TypeInfoSet<TypeT,ClassDeclT,FieldT,MethodT> {
+
+    @XmlTransient
+    public final Navigator<TypeT,ClassDeclT,FieldT,MethodT> nav;
+
+    @XmlTransient
+    public final AnnotationReader<TypeT,ClassDeclT,FieldT,MethodT> reader;
+
+    /**
+     * All the leaves.
+     */
+    private final Map<TypeT,BuiltinLeafInfo<TypeT,ClassDeclT>> builtins =
+            new LinkedHashMap<TypeT,BuiltinLeafInfo<TypeT,ClassDeclT>>();
+
+    /** All {@link EnumLeafInfoImpl}s. */
+    private final Map<ClassDeclT,EnumLeafInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> enums =
+            new LinkedHashMap<ClassDeclT,EnumLeafInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>();
+
+    /** All {@link ArrayInfoImpl}s. */
+    private final Map<TypeT,ArrayInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> arrays =
+            new LinkedHashMap<TypeT,ArrayInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>();
+
+    /**
+     * All the user-defined classes.
+     *
+     * Using {@link LinkedHashMap} allows us to process classes
+     * in the order they are given to us. When the user incorrectly
+     * puts an unexpected class into a reference graph, this causes
+     * an error to be reported on a class closer to the user's code.
+     */
+    @XmlJavaTypeAdapter(RuntimeUtil.ToStringAdapter.class)
+    private final Map<ClassDeclT,ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> beans
+            = new LinkedHashMap<ClassDeclT,ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>();
+
+    @XmlTransient
+    private final Map<ClassDeclT,ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> beansView =
+        Collections.unmodifiableMap(beans);
+
+    /**
+     * The element mapping.
+     */
+    private final Map<ClassDeclT,Map<QName,ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>> elementMappings =
+        new LinkedHashMap<ClassDeclT,Map<QName,ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>>();
+
+    private final Iterable<? extends ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> allElements =
+        new Iterable<ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>() {
+            public Iterator<ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> iterator() {
+                return new FlattenIterator<ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>(elementMappings.values());
+            }
+        };
+
+    /**
+     * {@link TypeInfo} for <tt>xs:anyType</tt>.
+     *
+     * anyType is the only {@link TypeInfo} that works with an interface,
+     * and accordingly it requires a lot of special casing.
+     */
+    private final NonElement<TypeT,ClassDeclT> anyType;
+
+    /**
+     * Lazily parsed set of {@link XmlNs}s.
+     *
+     * @see #getXmlNs(String)
+     */
+    private Map<String,Map<String,String>> xmlNsCache;
+
+    public TypeInfoSetImpl(Navigator<TypeT,ClassDeclT,FieldT,MethodT> nav,
+                           AnnotationReader<TypeT,ClassDeclT,FieldT,MethodT> reader,
+                           Map<TypeT,? extends BuiltinLeafInfoImpl<TypeT,ClassDeclT>> leaves) {
+        this.nav = nav;
+        this.reader = reader;
+        this.builtins.putAll(leaves);
+
+        this.anyType = createAnyType();
+
+        // register primitive types.
+        for (Map.Entry<Class, Class> e : RuntimeUtil.primitiveToBox.entrySet()) {
+            this.builtins.put( nav.getPrimitive(e.getKey()), leaves.get(nav.ref(e.getValue())) );
+        }
+
+        // make sure at lease we got a map for global ones.
+        elementMappings.put(null,new LinkedHashMap<QName,ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>());
+    }
+
+    protected NonElement<TypeT,ClassDeclT> createAnyType() {
+        return new AnyTypeImpl<TypeT,ClassDeclT>(nav);
+    }
+
+    public Navigator<TypeT,ClassDeclT,FieldT,MethodT> getNavigator() {
+        return nav;
+    }
+
+    /**
+     * Adds a new {@link ClassInfo} to the set.
+     */
+    public void add( ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> ci ) {
+        beans.put( ci.getClazz(), ci );
+    }
+
+    /**
+     * Adds a new {@link LeafInfo} to the set.
+     */
+    public void add( EnumLeafInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> li ) {
+        enums.put( li.clazz,  li );
+    }
+
+    public void add(ArrayInfoImpl<TypeT, ClassDeclT, FieldT, MethodT> ai) {
+        arrays.put( ai.getType(), ai );
+    }
+
+    /**
+     * Returns a {@link TypeInfo} for the given type.
+     *
+     * @return
+     *      null if the specified type cannot be bound by JAXB, or
+     *      not known to this set.
+     */
+    public NonElement<TypeT,ClassDeclT> getTypeInfo( TypeT type ) {
+        type = nav.erasure(type);   // replace type variables by their bounds
+
+        LeafInfo<TypeT,ClassDeclT> l = builtins.get(type);
+        if(l!=null)     return l;
+
+        if( nav.isArray(type) ) {
+            return arrays.get(type);
+        }
+
+        ClassDeclT d = nav.asDecl(type);
+        if(d==null)     return null;
+        return getClassInfo(d);
+    }
+
+    public NonElement<TypeT,ClassDeclT> getAnyTypeInfo() {
+        return anyType;
+    }
+
+    /**
+     * This method is used to add a root reference to a model.
+     */
+    public NonElement<TypeT,ClassDeclT> getTypeInfo(Ref<TypeT,ClassDeclT> ref) {
+        // TODO: handle XmlValueList
+        assert !ref.valueList;
+        ClassDeclT c = nav.asDecl(ref.type);
+        if(c!=null && reader.getClassAnnotation(XmlRegistry.class,c,null/*TODO: is this right?*/)!=null) {
+            return null;    // TODO: is this correct?
+        } else
+            return getTypeInfo(ref.type);
+    }
+
+    /**
+     * Returns all the {@link ClassInfo}s known to this set.
+     */
+    public Map<ClassDeclT,? extends ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> beans() {
+        return beansView;
+    }
+
+    public Map<TypeT, ? extends BuiltinLeafInfo<TypeT,ClassDeclT>> builtins() {
+        return builtins;
+    }
+
+    public Map<ClassDeclT, ? extends EnumLeafInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> enums() {
+        return enums;
+    }
+
+    public Map<? extends TypeT, ? extends ArrayInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> arrays() {
+        return arrays;
+    }
+
+    /**
+     * Returns a {@link ClassInfo} for the given bean.
+     *
+     * <p>
+     * This method is almost like refinement of {@link #getTypeInfo(Object)} except
+     * our C cannot derive from T.
+     *
+     * @return
+     *      null if the specified type is not bound by JAXB or otherwise
+     *      unknown to this set.
+     */
+    public NonElement<TypeT,ClassDeclT> getClassInfo( ClassDeclT type ) {
+        LeafInfo<TypeT,ClassDeclT> l = builtins.get(nav.use(type));
+        if(l!=null)     return l;
+
+        l = enums.get(type);
+        if(l!=null)     return l;
+
+        if(nav.asDecl(Object.class).equals(type))
+            return anyType;
+
+        return beans.get(type);
+    }
+
+    public ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> getElementInfo( ClassDeclT scope, QName name ) {
+        while(scope!=null) {
+            Map<QName,ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> m = elementMappings.get(scope);
+            if(m!=null) {
+                ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> r = m.get(name);
+                if(r!=null)     return r;
+            }
+            scope = nav.getSuperClass(scope);
+        }
+        return elementMappings.get(null).get(name);
+    }
+
+    /**
+     * @param builder
+     *      used for reporting errors.
+     */
+    public final void add( ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> ei, ModelBuilder<TypeT,ClassDeclT,FieldT,MethodT> builder ) {
+        ClassDeclT scope = null;
+        if(ei.getScope()!=null)
+            scope = ei.getScope().getClazz();
+
+        Map<QName,ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> m = elementMappings.get(scope);
+        if(m==null)
+            elementMappings.put(scope,m=new LinkedHashMap<QName,ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>>());
+
+        ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> existing = m.put(ei.getElementName(),ei);
+
+        if(existing!=null) {
+            QName en = ei.getElementName();
+            builder.reportError(
+                new IllegalAnnotationException(
+                    Messages.CONFLICTING_XML_ELEMENT_MAPPING.format(en.getNamespaceURI(),en.getLocalPart()),
+                    ei, existing ));
+        }
+    }
+
+    public Map<QName,? extends ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> getElementMappings( ClassDeclT scope ) {
+        return elementMappings.get(scope);
+    }
+
+    public Iterable<? extends ElementInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>> getAllElements() {
+        return allElements;
+    }
+
+    public Map<String,String> getXmlNs(String namespaceUri) {
+        if(xmlNsCache==null) {
+            xmlNsCache = new HashMap<String,Map<String,String>>();
+
+            for (ClassInfoImpl<TypeT, ClassDeclT, FieldT, MethodT> ci : beans().values()) {
+                XmlSchema xs = reader.getPackageAnnotation( XmlSchema.class, ci.getClazz(), null );
+                if(xs==null)
+                    continue;
+
+                String uri = xs.namespace();
+                Map<String,String> m = xmlNsCache.get(uri);
+                if(m==null)
+                    xmlNsCache.put(uri,m=new HashMap<String, String>());
+
+                for( XmlNs xns : xs.xmlns() ) {
+                    m.put(xns.prefix(),xns.namespaceURI());
+                }
+            }
+        }
+
+        Map<String,String> r = xmlNsCache.get(namespaceUri);
+        if(r!=null)     return r;
+        else            return Collections.emptyMap();
+    }
+
+    public final XmlNsForm getElementFormDefault(String nsUri) {
+        for (ClassInfoImpl<TypeT, ClassDeclT, FieldT, MethodT> ci : beans().values()) {
+            XmlSchema xs = reader.getPackageAnnotation( XmlSchema.class, ci.getClazz(), null );
+            if(xs==null)
+                continue;
+
+            if(!xs.namespace().equals(nsUri))
+                continue;
+
+            XmlNsForm xnf = xs.elementFormDefault();
+            if(xnf!=XmlNsForm.UNSET)
+                return xnf;
+        }
+        return XmlNsForm.UNSET;
+    }
+
+    public final XmlNsForm getAttributeFormDefault(String nsUri) {
+        for (ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> ci : beans().values()) {
+            XmlSchema xs = reader.getPackageAnnotation( XmlSchema.class, ci.getClazz(), null );
+            if(xs==null)
+                continue;
+
+            if(!xs.namespace().equals(nsUri))
+                continue;
+
+            XmlNsForm xnf = xs.attributeFormDefault();
+            if(xnf!=XmlNsForm.UNSET)
+                return xnf;
+        }
+        return XmlNsForm.UNSET;
+    }
+
+    /**
+     * Dumps this model into XML.
+     *
+     * For debug only.
+     *
+     * TODO: not sure if this actually works. We don't really know what are T,C.
+     */
+    public void dump( Result out ) throws JAXBException {
+        JAXBContext context = JAXBContext.newInstance(this.getClass());
+        Marshaller m = context.createMarshaller();
+        m.marshal(this,out);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeRefImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeRefImpl.java
new file mode 100644
index 0000000..7c63cfc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/TypeRefImpl.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeRef;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class TypeRefImpl<TypeT,ClassDeclT> implements TypeRef<TypeT,ClassDeclT> {
+    private final QName elementName;
+    private final TypeT type;
+    protected final ElementPropertyInfoImpl<TypeT,ClassDeclT,?,?> owner;
+    private NonElement<TypeT,ClassDeclT> ref;
+    private final boolean isNillable;
+    private String defaultValue;
+
+    public TypeRefImpl(ElementPropertyInfoImpl<TypeT, ClassDeclT, ?, ?> owner, QName elementName, TypeT type, boolean isNillable, String defaultValue) {
+        this.owner = owner;
+        this.elementName = elementName;
+        this.type = type;
+        this.isNillable = isNillable;
+        this.defaultValue = defaultValue;
+        assert owner!=null;
+        assert elementName!=null;
+        assert type!=null;
+    }
+
+    public NonElement<TypeT,ClassDeclT> getTarget() {
+        if(ref==null)
+            calcRef();
+        return ref;
+    }
+
+    public QName getTagName() {
+        return elementName;
+    }
+
+    public boolean isNillable() {
+        return isNillable;
+    }
+
+    public String getDefaultValue() {
+        return defaultValue;
+    }
+
+    protected void link() {
+        // if we have'nt computed the ref yet, do so now.
+        calcRef();
+    }
+
+    private void calcRef() {
+        // we can't do this eagerly because of a cyclic dependency
+        ref = owner.parent.builder.getTypeInfo(type,owner);
+        assert ref!=null;
+    }
+
+    public PropertyInfo<TypeT,ClassDeclT> getSource() {
+        return owner;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Util.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Util.java
new file mode 100644
index 0000000..03f7f34
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/Util.java
@@ -0,0 +1,94 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import javax.activation.MimeType;
+import javax.activation.MimeTypeParseException;
+import javax.xml.bind.annotation.XmlMimeType;
+import javax.xml.bind.annotation.XmlSchemaType;
+import javax.xml.bind.annotation.XmlSchemaTypes;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
+import com.sun.xml.internal.bind.v2.model.annotation.AnnotationSource;
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+import com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationException;
+
+/**
+ * Common code between {@link PropertyInfoImpl} and {@link ElementInfoImpl}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class Util {
+    static <T,C,F,M> QName calcSchemaType(
+            AnnotationReader<T,C,F,M> reader,
+            AnnotationSource primarySource, C enclosingClass, T individualType, Locatable src ) {
+
+        XmlSchemaType xst = primarySource.readAnnotation(XmlSchemaType.class);
+        if(xst!=null) {
+            return new QName(xst.namespace(),xst.name());
+        }
+
+        // check the defaulted annotation
+        XmlSchemaTypes xsts = reader.getPackageAnnotation(XmlSchemaTypes.class,enclosingClass,src);
+        XmlSchemaType[] values = null;
+        if(xsts!=null)
+            values = xsts.value();
+        else {
+            xst = reader.getPackageAnnotation(XmlSchemaType.class,enclosingClass,src);
+            if(xst!=null) {
+                values = new XmlSchemaType[1];
+                values[0] = xst;
+            }
+        }
+        if(values!=null) {
+            for( XmlSchemaType item : values ) {
+                if(reader.getClassValue(item,"type").equals(individualType)) {
+                    return new QName(item.namespace(),item.name());
+                }
+            }
+        }
+
+        return null;
+    }
+
+    static MimeType calcExpectedMediaType(AnnotationSource primarySource,
+                        ModelBuilder builder ) {
+        XmlMimeType xmt = primarySource.readAnnotation(XmlMimeType.class);
+        if(xmt==null)
+            return null;
+
+        try {
+            return new MimeType(xmt.value());
+        } catch (MimeTypeParseException e) {
+            builder.reportError(new IllegalAnnotationException(
+                Messages.ILLEGAL_MIME_TYPE.format(xmt.value(),e.getMessage()),
+                xmt
+            ));
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ValuePropertyInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ValuePropertyInfoImpl.java
new file mode 100644
index 0000000..aac00b1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/ValuePropertyInfoImpl.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.impl;
+
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.ValuePropertyInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class ValuePropertyInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    extends SingleTypePropertyInfoImpl<TypeT,ClassDeclT,FieldT,MethodT>
+    implements ValuePropertyInfo<TypeT,ClassDeclT> {
+
+    ValuePropertyInfoImpl(
+        ClassInfoImpl<TypeT,ClassDeclT,FieldT,MethodT> parent,
+        PropertySeed<TypeT,ClassDeclT,FieldT,MethodT> seed) {
+
+        super(parent,seed);
+    }
+
+    public PropertyKind kind() {
+        return PropertyKind.VALUE;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/package.html b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/package.html
new file mode 100644
index 0000000..1644fb0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/impl/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+Implementation of the com.sun.xml.internal.bind.j2s.model package.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/GenericArrayTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/GenericArrayTypeImpl.java
new file mode 100644
index 0000000..2cc55cb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/GenericArrayTypeImpl.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.nav;
+
+import java.lang.reflect.GenericArrayType;
+import java.lang.reflect.Type;
+
+/**
+ * Implementation of GenericArrayType interface for core reflection.
+ */
+final class GenericArrayTypeImpl implements GenericArrayType {
+    private Type genericComponentType;
+
+    GenericArrayTypeImpl(Type ct) {
+        assert ct!=null;
+        genericComponentType = ct;
+    }
+
+    /**
+     * Returns  a <tt>Type</tt> object representing the component type
+     * of this array.
+     *
+     * @return a <tt>Type</tt> object representing the component type
+     *         of this array
+     * @since 1.5
+     */
+    public Type getGenericComponentType() {
+        return genericComponentType; // return cached component type
+    }
+
+    public String toString() {
+        Type componentType = getGenericComponentType();
+        StringBuilder sb = new StringBuilder();
+
+        if (componentType instanceof Class)
+            sb.append(((Class) componentType).getName());
+        else
+            sb.append(componentType.toString());
+        sb.append("[]");
+        return sb.toString();
+    }
+
+    @Override
+    public boolean equals(Object o) {
+        if (o instanceof GenericArrayType) {
+            GenericArrayType that = (GenericArrayType) o;
+
+            Type thatComponentType = that.getGenericComponentType();
+            return genericComponentType.equals(thatComponentType);
+        } else
+            return false;
+    }
+
+    @Override
+    public int hashCode() {
+        return genericComponentType.hashCode();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/Navigator.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/Navigator.java
new file mode 100644
index 0000000..38c89be
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/Navigator.java
@@ -0,0 +1,384 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.nav;
+
+import java.util.Collection;
+
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * Provides unified view of the underlying reflection library,
+ * such as {@code java.lang.reflect} and/or APT.
+ *
+ * <p>
+ * This interface provides navigation over the reflection model
+ * to decouple the caller from any particular implementation.
+ * This allows the JAXB RI to reuse much of the code between
+ * the compile time (which works on top of APT) and the run-time
+ * (which works on top of {@code java.lang.reflect})
+ *
+ * <p>
+ * {@link Navigator} instances are stateless and immutable.
+ *
+ *
+ * <h2>Parameterization</h2>
+ * <h3>C</h3>
+ * <p>
+ * A Java class declaration (not an interface, a class and an enum.)
+ *
+ * <h3>T</h3>
+ * <p>
+ * A Java type. This includs declaration, but also includes such
+ * things like arrays, primitive types, parameterized types, and etc.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface Navigator<T,C,F,M> {
+    /**
+     * Gets the base class of the specified class.
+     *
+     * @return
+     *      null if the parameter represents {@link Object}.
+     */
+    C getSuperClass(C clazz);
+
+    /**
+     * Gets the parameterization of the given base type.
+     *
+     * <p>
+     * For example, given the following
+     * <pre><xmp>
+     * interface Foo<T> extends List<List<T>> {}
+     * interface Bar extends Foo<String> {}
+     * </xmp></pre>
+     * This method works like this:
+     * <pre><xmp>
+     * getBaseClass( Bar, List ) = List<List<String>
+     * getBaseClass( Bar, Foo  ) = Foo<String>
+     * getBaseClass( Foo<? extends Number>, Collection ) = Collection<List<? extends Number>>
+     * getBaseClass( ArrayList<? extends BigInteger>, List ) = List<? extends BigInteger>
+     * </xmp></pre>
+     *
+     * @param type
+     *      The type that derives from {@code baseType}
+     * @param baseType
+     *      The class whose parameterization we are interested in.
+     * @return
+     *      The use of {@code baseType} in {@code type}.
+     *      or null if the type is not assignable to the base type.
+     */
+    T getBaseClass(T type, C baseType);
+
+    /**
+     * Gets the fully-qualified name of the class.
+     * ("java.lang.Object" for {@link Object})
+     */
+    String getClassName(C clazz);
+
+    /**
+     * Gets the display name of the type object
+     *
+     * @return
+     *      a human-readable name that the type represents.
+     */
+    String getTypeName(T rawType);
+
+    /**
+     * Gets the short name of the class ("Object" for {@link Object}.)
+     *
+     * For nested classes, this method should just return the inner name.
+     * (for example "Inner" for "com.acme.Outer$Inner".
+     */
+    String getClassShortName(C clazz);
+
+    /**
+     * Gets all the declared fields of the given class.
+     */
+    Collection<? extends F> getDeclaredFields(C clazz);
+
+    /**
+     * Gets the named field declared on the given class.
+     *
+     * This method doesn't visit ancestors, but does recognize
+     * non-public fields.
+     *
+     * @return
+     *      null if not found
+     */
+    F getDeclaredField(C clazz, String fieldName);
+
+    /**
+     * Gets all the declared methods of the given class
+     * (regardless of their access modifiers, regardless
+     * of whether they override methods of the base classes.)
+     *
+     * <p>
+     * Note that this method does not list methods declared on base classes.
+     *
+     * @return
+     *      can be empty but always non-null.
+     */
+    Collection<? extends M> getDeclaredMethods(C clazz);
+
+    /**
+     * Gets the class that declares the given field.
+     */
+    C getDeclaringClassForField(F field);
+
+    /**
+     * Gets the class that declares the given method.
+     */
+    C getDeclaringClassForMethod(M method);
+
+    /**
+     * Gets the type of the field.
+     */
+    T getFieldType(F f);
+
+    /**
+     * Gets the name of the field.
+     */
+    String getFieldName(F field);
+
+    /**
+     * Gets the name of the method, such as "toString" or "equals".
+     */
+    String getMethodName(M m);
+
+    /**
+     * Gets the return type of a method.
+     */
+    T getReturnType(M m);
+
+    /**
+     * Returns the list of parameters to the method.
+     */
+    T[] getMethodParameters(M method);
+
+    /**
+     * Returns true if the method is static.
+     */
+    boolean isStaticMethod(M method);
+
+    /**
+     * Checks if {@code sub} is a sub-type of {@code sup}.
+     *
+     * TODO: should this method take T or C?
+     */
+    boolean isSubClassOf(T sub, T sup);
+
+    /**
+     * Gets the representation of the given Java type in {@code T}.
+     *
+     * @param c
+     *      can be a primitive, array, class, or anything.
+     *      (therefore the return type has to be T, not C)
+     */
+    T ref(Class c);
+
+    /**
+     * Gets the T for the given C.
+     */
+    T use(C c);
+
+    /**
+     * If the given type is an use of class declaration,
+     * returns the type casted as {@code C}.
+     * Otherwise null.
+     *
+     * <p>
+     * TODO: define the exact semantics.
+     */
+    C asDecl(T type);
+
+    /**
+     * Gets the {@code C} representation for the given class.
+     *
+     * The behavior is undefined if the class object represents
+     * primitives, arrays, and other types that are not class declaration.
+     */
+    C asDecl(Class c);
+
+    /**
+     * Checks if the type is an array type.
+     */
+    boolean isArray(T t);
+
+    /**
+     * Checks if the type is an array type but not byte[].
+     */
+    boolean isArrayButNotByteArray(T t);
+
+    /**
+     * Gets the component type of the array.
+     *
+     * @param t
+     *      must be an array.
+     */
+    T getComponentType(T t);
+
+
+    /** The singleton instance. */
+    public static final ReflectionNavigator REFLECTION = new ReflectionNavigator();
+
+    /**
+     * Gets the i-th type argument from a parameterized type.
+     *
+     * For example, {@code getTypeArgument([Map<Integer,String>],0)=Integer}
+     *
+     * @throws IllegalArgumentException
+     *      If t is not a parameterized type
+     * @throws IndexOutOfBoundsException
+     *      If i is out of range.
+     *
+     * @see #isParameterizedType(Object)
+     */
+    T getTypeArgument(T t, int i);
+
+    /**
+     * Returns true if t is a parameterized type.
+     */
+    boolean isParameterizedType(T t);
+
+    /**
+     * Checks if the given type is a primitive type.
+     */
+    boolean isPrimitive(T t);
+
+    /**
+     * Returns the representation for the given primitive type.
+     *
+     * @param primitiveType
+     *      must be Class objects like {@link Integer#TYPE}.
+     */
+    T getPrimitive(Class primitiveType);
+
+    /**
+     * Returns a location of the specified class.
+     */
+    Location getClassLocation(C clazz);
+
+    Location getFieldLocation(F field);
+
+    Location getMethodLocation(M getter);
+
+    /**
+     * Returns true if the given class has a no-arg default constructor.
+     * The constructor does not need to be public.
+     */
+    boolean hasDefaultConstructor(C clazz);
+
+    /**
+     * Returns true if the field is static.
+     */
+    boolean isStaticField(F field);
+
+    /**
+     * Returns true if the method is public.
+     */
+    boolean isPublicMethod(M method);
+
+    /**
+     * Returns true if the field is public.
+     */
+    boolean isPublicField(F field);
+
+    /**
+     * Returns true if this is an enum class.
+     */
+    boolean isEnum(C clazz);
+
+    /**
+     * Computes the erasure
+     */
+    <P> T erasure(T contentInMemoryType);
+    // This unused P is necessary to make ReflectionNavigator.erasure work nicely
+
+    /**
+     * Returns true if this is an abstract class.
+     */
+    boolean isAbstract(C clazz);
+
+    /**
+     * Returns true if this is a final class.
+     */
+    boolean isFinal(C clazz);
+
+    /**
+     * Gets the enumeration constants from an enum class.
+     *
+     * @param clazz
+     *      must derive from {@link Enum}.
+     *
+     * @return
+     *      can be empty but never null.
+     */
+    F[] getEnumConstants(C clazz);
+
+    /**
+     * Gets the representation of the primitive "void" type.
+     */
+    T getVoidType();
+
+    /**
+     * Gets the package name of the given class.
+     *
+     * @return
+     *      i.e. "", "java.lang" but not null.
+     */
+    String getPackageName(C clazz);
+
+    /**
+     * Finds the class/interface/enum/annotation of the given name.
+     *
+     * @param referencePoint
+     *      The class that refers to the specified class.
+     * @return
+     *      null if not found.
+     */
+    C findClass(String className, C referencePoint);
+
+    /**
+     * Returns true if this method is a bridge method as defined in JLS.
+     */
+    boolean isBridgeMethod(M method);
+
+    /**
+     * Returns true if the given method is overriding another one
+     * defined in the base class.
+     */
+    boolean isOverriding(M method);
+
+    /**
+     * Returns true if 'clazz' is an interface.
+     */
+    boolean isInterface(C clazz);
+
+    /**
+     * Returns true if the field is transient.
+     */
+    boolean isTransient(F f);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/ParameterizedTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/ParameterizedTypeImpl.java
new file mode 100644
index 0000000..9af56d9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/ParameterizedTypeImpl.java
@@ -0,0 +1,178 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.nav;
+
+import java.lang.reflect.MalformedParameterizedTypeException;
+import java.lang.reflect.ParameterizedType;
+import java.lang.reflect.Type;
+import java.lang.reflect.TypeVariable;
+import java.util.Arrays;
+
+
+/**
+ * {@link ParameterizedType} implementation.
+ */
+class ParameterizedTypeImpl implements ParameterizedType {
+    private Type[] actualTypeArguments;
+    private Class<?> rawType;
+    private Type ownerType;
+
+    ParameterizedTypeImpl(Class<?> rawType,
+                                  Type[] actualTypeArguments,
+                                  Type ownerType) {
+        this.actualTypeArguments = actualTypeArguments;
+        this.rawType = rawType;
+        if (ownerType != null) {
+            this.ownerType = ownerType;
+        } else {
+            this.ownerType = rawType.getDeclaringClass();
+        }
+        validateConstructorArguments();
+    }
+
+    private void validateConstructorArguments() {
+        TypeVariable/*<?>*/[] formals = rawType.getTypeParameters();
+        // check correct arity of actual type args
+        if (formals.length != actualTypeArguments.length) {
+            throw new MalformedParameterizedTypeException();
+        }
+        for (int i = 0; i < actualTypeArguments.length; i++) {
+            // check actuals against formals' bounds
+        }
+
+    }
+
+    public Type[] getActualTypeArguments() {
+        return actualTypeArguments.clone();
+    }
+
+    public Class<?> getRawType() {
+        return rawType;
+    }
+
+    public Type getOwnerType() {
+        return ownerType;
+    }
+
+    /*
+     * From the JavaDoc for java.lang.reflect.ParameterizedType
+     * "Instances of classes that implement this interface must
+     * implement an equals() method that equates any two instances
+     * that share the same generic type declaration and have equal
+     * type parameters."
+     */
+    @Override
+    public boolean equals(Object o) {
+        if (o instanceof ParameterizedType) {
+            // Check that information is equivalent
+            ParameterizedType that = (ParameterizedType) o;
+
+            if (this == that)
+                return true;
+
+            Type thatOwner = that.getOwnerType();
+            Type thatRawType = that.getRawType();
+
+            if (false) { // Debugging
+                boolean ownerEquality = (ownerType == null ?
+                        thatOwner == null :
+                        ownerType.equals(thatOwner));
+                boolean rawEquality = (rawType == null ?
+                        thatRawType == null :
+                        rawType.equals(thatRawType));
+
+                boolean typeArgEquality = Arrays.equals(actualTypeArguments, // avoid clone
+                        that.getActualTypeArguments());
+                for (Type t : actualTypeArguments) {
+                    System.out.printf("\t\t%s%s%n", t, t.getClass());
+                }
+
+                System.out.printf("\towner %s\traw %s\ttypeArg %s%n",
+                        ownerEquality, rawEquality, typeArgEquality);
+                return ownerEquality && rawEquality && typeArgEquality;
+            }
+
+
+            return
+                    (ownerType == null ?
+                    thatOwner == null :
+                    ownerType.equals(thatOwner)) &&
+                    (rawType == null ?
+                    thatRawType == null :
+                    rawType.equals(thatRawType)) &&
+                    Arrays.equals(actualTypeArguments, // avoid clone
+                            that.getActualTypeArguments());
+        } else
+            return false;
+    }
+
+    @Override
+    public int hashCode() {
+        return  Arrays.hashCode(actualTypeArguments) ^
+                (ownerType == null ? 0 : ownerType.hashCode()) ^
+                (rawType == null ? 0 : rawType.hashCode());
+    }
+
+    public String toString() {
+        StringBuilder sb = new StringBuilder();
+
+        if (ownerType != null) {
+            if (ownerType instanceof Class)
+                sb.append(((Class) ownerType).getName());
+            else
+                sb.append(ownerType.toString());
+
+            sb.append(".");
+
+            if (ownerType instanceof ParameterizedTypeImpl) {
+                // Find simple name of nested type by removing the
+                // shared prefix with owner.
+                sb.append(rawType.getName().replace(((ParameterizedTypeImpl) ownerType).rawType.getName() + "$",
+                        ""));
+            } else
+                sb.append(rawType.getName());
+        } else
+            sb.append(rawType.getName());
+
+        if (actualTypeArguments != null &&
+                actualTypeArguments.length > 0) {
+            sb.append("<");
+            boolean first = true;
+            for (Type t : actualTypeArguments) {
+                if (!first)
+                    sb.append(", ");
+                if (t instanceof Class)
+                    sb.append(((Class) t).getName());
+                else
+                    sb.append(t.toString());
+                first = false;
+            }
+            sb.append(">");
+        }
+
+        return sb.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/ReflectionNavigator.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/ReflectionNavigator.java
new file mode 100644
index 0000000..e826a09
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/ReflectionNavigator.java
@@ -0,0 +1,568 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.nav;
+
+import java.lang.reflect.Array;
+import java.lang.reflect.Field;
+import java.lang.reflect.GenericArrayType;
+import java.lang.reflect.GenericDeclaration;
+import java.lang.reflect.Method;
+import java.lang.reflect.Modifier;
+import java.lang.reflect.ParameterizedType;
+import java.lang.reflect.Type;
+import java.lang.reflect.TypeVariable;
+import java.lang.reflect.WildcardType;
+import java.util.Arrays;
+import java.util.Collection;
+
+import com.sun.xml.internal.bind.v2.runtime.Location;
+
+/**
+ * {@link Navigator} implementation for {@code java.lang.reflect}.
+ *
+ */
+public final class ReflectionNavigator implements Navigator<Type,Class,Field,Method> {
+    /**
+     * Singleton.
+     *
+     * Use {@link Navigator#REFLECTION}
+     */
+    ReflectionNavigator() {}
+
+    public Class getSuperClass(Class clazz) {
+        return clazz.getSuperclass();
+    }
+
+    private static final TypeVisitor<Type,Class> baseClassFinder = new TypeVisitor<Type,Class>() {
+        public Type onClass(Class c, Class sup) {
+            // t is a raw type
+            if(sup==c)
+                return sup;
+
+            Type r;
+
+            Type sc = c.getGenericSuperclass();
+            if(sc!=null) {
+                r = visit(sc,sup);
+                if(r!=null)     return r;
+            }
+
+            for( Type i : c.getGenericInterfaces() ) {
+                r = visit(i,sup);
+                if(r!=null)  return r;
+            }
+
+            return null;
+        }
+
+        public Type onParameterizdType(ParameterizedType p, Class sup) {
+            Class raw = (Class) p.getRawType();
+            if(raw==sup) {
+                // p is of the form sup<...>
+                return p;
+            } else {
+                // recursively visit super class/interfaces
+                Type r = raw.getGenericSuperclass();
+                if(r!=null)
+                    r = visit(bind(r,raw,p),sup);
+                if(r!=null)
+                    return r;
+                for( Type i : raw.getGenericInterfaces() ) {
+                    r = visit(bind(i,raw,p),sup);
+                    if(r!=null)  return r;
+                }
+                return null;
+            }
+        }
+
+        public Type onGenericArray(GenericArrayType g, Class sup) {
+            // not clear what I should do here
+            return null;
+        }
+
+        public Type onVariable(TypeVariable v, Class sup) {
+            return visit(v.getBounds()[0],sup);
+        }
+
+        public Type onWildcard(WildcardType w, Class sup) {
+            // not clear what I should do here
+            return null;
+        }
+
+        /**
+         * Replaces the type variables in {@code t} by its actual arguments.
+         *
+         * @param decl
+         *      provides a list of type variables. See {@link GenericDeclaration#getTypeParameters()}
+         * @param args
+         *      actual arguments. See {@link ParameterizedType#getActualTypeArguments()}
+         */
+        private Type bind( Type t, GenericDeclaration decl, ParameterizedType args ) {
+            return binder.visit(t,new BinderArg(decl,args.getActualTypeArguments()));
+        }
+    };
+
+    private static class BinderArg {
+        final TypeVariable[] params;
+        final Type[] args;
+
+        BinderArg(TypeVariable[] params, Type[] args) {
+            this.params = params;
+            this.args = args;
+            assert params.length==args.length;
+        }
+
+        public BinderArg( GenericDeclaration decl, Type[] args ) {
+            this(decl.getTypeParameters(),args);
+        }
+
+        Type replace( TypeVariable v ) {
+            for(int i=0; i<params.length; i++)
+                if(params[i]==v)
+                    return args[i];
+            return v;   // this is a free variable
+        }
+    }
+    private static final TypeVisitor<Type,BinderArg> binder = new TypeVisitor<Type,BinderArg>() {
+        public Type onClass(Class c, BinderArg args) {
+            return c;
+        }
+
+        public Type onParameterizdType(ParameterizedType p, BinderArg args) {
+            Type[] params = p.getActualTypeArguments();
+
+            boolean different = false;
+            for( int i=0; i<params.length; i++ ) {
+                Type t = params[i];
+                params[i] = visit(t,args);
+                different |= t!=params[i];
+            }
+
+            Type newOwner = p.getOwnerType();
+            if(newOwner!=null)
+                newOwner = visit(newOwner,args);
+            different |= p.getOwnerType()!=newOwner;
+
+            if(!different)  return p;
+
+            return new ParameterizedTypeImpl( (Class<?>)p.getRawType(), params, newOwner );
+        }
+
+        public Type onGenericArray(GenericArrayType g, BinderArg types) {
+            Type c = visit(g.getGenericComponentType(),types);
+            if(c==g.getGenericComponentType())  return g;
+
+            return new GenericArrayTypeImpl(c);
+        }
+
+        public Type onVariable(TypeVariable v, BinderArg types) {
+            return types.replace(v);
+        }
+
+        public Type onWildcard(WildcardType w, BinderArg types) {
+            // TODO: this is probably still incorrect
+            // bind( "? extends T" ) with T= "? extends Foo" should be "? extends Foo",
+            // not "? extends (? extends Foo)"
+            Type[] lb = w.getLowerBounds();
+            Type[] ub = w.getUpperBounds();
+            boolean diff = false;
+
+            for( int i=0; i<lb.length; i++ ) {
+                Type t = lb[i];
+                lb[i] = visit(t,types);
+                diff |= (t!=lb[i]);
+            }
+
+            for( int i=0; i<ub.length; i++ ) {
+                Type t = ub[i];
+                ub[i] = visit(t,types);
+                diff |= (t!=ub[i]);
+            }
+
+            if(!diff)       return w;
+
+            return new WildcardTypeImpl(lb,ub);
+        }
+    };
+
+
+    public Type getBaseClass(Type t, Class sup) {
+        return baseClassFinder.visit(t,sup);
+    }
+
+    public String getClassName(Class clazz) {
+        return clazz.getName();
+    }
+
+    public String getTypeName(Type type) {
+        if (type instanceof Class) {
+            Class c = (Class) type;
+            if(c.isArray())
+                return getTypeName(c.getComponentType())+"[]";
+            return c.getName();
+        }
+        return type.toString();
+    }
+
+    public String getClassShortName(Class clazz) {
+        return clazz.getSimpleName();
+    }
+
+    public Collection<? extends Field> getDeclaredFields(Class clazz) {
+        return Arrays.asList(clazz.getDeclaredFields());
+    }
+
+    public Field getDeclaredField(Class clazz, String fieldName) {
+        try {
+            return clazz.getDeclaredField(fieldName);
+        } catch (NoSuchFieldException e) {
+            return null;
+        }
+    }
+
+    public Collection<? extends Method> getDeclaredMethods(Class clazz) {
+        return Arrays.asList(clazz.getDeclaredMethods());
+    }
+
+    public Class getDeclaringClassForField(Field field) {
+        return field.getDeclaringClass();
+    }
+
+    public Class getDeclaringClassForMethod(Method method) {
+        return method.getDeclaringClass();
+    }
+
+    public Type getFieldType(Field field) {
+        return fix(field.getGenericType());
+    }
+
+    public String getFieldName(Field field) {
+        return field.getName();
+    }
+
+    public String getMethodName(Method method) {
+        return method.getName();
+    }
+
+    public Type getReturnType(Method method) {
+        return fix(method.getGenericReturnType());
+    }
+
+    public Type[] getMethodParameters(Method method) {
+        return method.getGenericParameterTypes();
+    }
+
+    public boolean isStaticMethod(Method method) {
+        return Modifier.isStatic(method.getModifiers());
+    }
+
+    public boolean isSubClassOf(Type sub, Type sup) {
+        return erasure(sup).isAssignableFrom(erasure(sub));
+    }
+
+    public Class ref(Class c) {
+        return c;
+    }
+
+    public Class use(Class c) {
+        return c;
+    }
+
+    public Class asDecl(Type t) {
+        return erasure(t);
+    }
+
+    public Class asDecl(Class c) {
+        return c;
+    }
+
+
+    /**
+     * Implements the logic for {@link #erasure(Type)}.
+     */
+    private static final TypeVisitor<Class,Void> eraser = new TypeVisitor<Class,Void>() {
+        public Class onClass(Class c,Void _) {
+            return c;
+        }
+
+        public Class onParameterizdType(ParameterizedType p,Void _) {
+            // TODO: why getRawType returns Type? not Class?
+            return visit(p.getRawType(),null);
+        }
+
+        public Class onGenericArray(GenericArrayType g,Void _) {
+            return Array.newInstance(
+                visit(g.getGenericComponentType(),null),
+                0 ).getClass();
+        }
+
+        public Class onVariable(TypeVariable v,Void _) {
+            return visit(v.getBounds()[0],null);
+        }
+
+        public Class onWildcard(WildcardType w,Void _) {
+            return visit(w.getUpperBounds()[0],null);
+        }
+    };
+
+    /**
+     * Returns the runtime representation of the given type.
+     *
+     * This corresponds to the notion of the erasure in JSR-14.
+     *
+     * <p>
+     * Because of the difference in the way APT and the Java reflection
+     * treats primitive type and array type, we can't define this method
+     * on {@link Navigator}.
+     *
+     * <p>
+     * It made me realize how difficult it is to define the common navigation
+     * layer for two different underlying reflection library. The other way
+     * is to throw away the entire parameterization and go to the wrapper approach.
+     */
+    public <T> Class<T> erasure(Type t) {
+        return eraser.visit(t,null);
+    }
+
+    public boolean isAbstract(Class clazz) {
+        return Modifier.isAbstract(clazz.getModifiers());
+    }
+
+    public boolean isFinal(Class clazz) {
+        return Modifier.isFinal(clazz.getModifiers());
+    }
+
+    /**
+     * Returns the {@link Type} object that represents {@code clazz&lt;T1,T2,T3>}.
+     */
+    public Type createParameterizedType( Class rawType, Type... arguments ) {
+        return new ParameterizedTypeImpl(rawType,arguments,null);
+    }
+
+    public boolean isArray(Type t) {
+        if (t instanceof Class) {
+            Class c = (Class) t;
+            return c.isArray();
+        }
+        if(t instanceof GenericArrayType)
+            return true;
+        return false;
+    }
+
+    public boolean isArrayButNotByteArray(Type t) {
+        if (t instanceof Class) {
+            Class c = (Class) t;
+            return c.isArray() && c!=byte[].class;
+        }
+        if(t instanceof GenericArrayType) {
+            t = ((GenericArrayType)t).getGenericComponentType();
+            return t!=Byte.TYPE;
+        }
+        return false;
+    }
+
+
+    public Type getComponentType(Type t) {
+        if (t instanceof Class) {
+            Class c = (Class) t;
+            return c.getComponentType();
+        }
+        if(t instanceof GenericArrayType)
+            return ((GenericArrayType)t).getGenericComponentType();
+
+        throw new IllegalArgumentException();
+    }
+
+    public Type getTypeArgument(Type type, int i) {
+        if (type instanceof ParameterizedType) {
+            ParameterizedType p = (ParameterizedType) type;
+            return fix(p.getActualTypeArguments()[i]);
+        } else
+            throw new IllegalArgumentException();
+    }
+
+    public boolean isParameterizedType(Type type) {
+        return type instanceof ParameterizedType;
+    }
+
+    public boolean isPrimitive(Type type) {
+        if (type instanceof Class) {
+            Class c = (Class) type;
+            return c.isPrimitive();
+        }
+        return false;
+    }
+
+    public Type getPrimitive(Class primitiveType) {
+        assert primitiveType.isPrimitive();
+        return primitiveType;
+    }
+
+    public Location getClassLocation(final Class clazz) {
+        return new Location() {
+            public String toString() {
+                return clazz.getName();
+            }
+        };
+    }
+
+    public Location getFieldLocation(final Field field) {
+        return new Location() {
+            public String toString() {
+                return field.toString();
+            }
+        };
+    }
+
+    public Location getMethodLocation(final Method method) {
+        return new Location() {
+            public String toString() {
+                return method.toString();
+            }
+        };
+    }
+
+    public boolean hasDefaultConstructor(Class c) {
+        try {
+            c.getDeclaredConstructor();
+            return true;
+        } catch (NoSuchMethodException e) {
+            return false;
+        }
+    }
+
+    public boolean isStaticField(Field field) {
+        return Modifier.isStatic(field.getModifiers());
+    }
+
+    public boolean isPublicMethod(Method method) {
+        return Modifier.isPublic(method.getModifiers());
+    }
+
+    public boolean isPublicField(Field field) {
+        return Modifier.isPublic(field.getModifiers());
+    }
+
+    public boolean isEnum(Class c) {
+        return Enum.class.isAssignableFrom(c);
+    }
+
+    public Field[] getEnumConstants(Class clazz) {
+        try {
+            Object[] values = clazz.getEnumConstants();
+            Field[] fields = new Field[values.length];
+            for( int i=0; i<values.length; i++ ) {
+                fields[i] = clazz.getField(((Enum)values[i]).name());
+            }
+            return fields;
+        } catch (NoSuchFieldException e) {
+            // impossible
+            throw new NoSuchFieldError(e.getMessage());
+        }
+    }
+
+    public Type getVoidType() {
+        return Void.class;
+    }
+
+    public String getPackageName(Class clazz) {
+        String name = clazz.getName();
+        int idx = name.lastIndexOf('.');
+        if(idx<0)   return "";
+        else        return name.substring(0,idx);
+    }
+
+    public Class findClass(String className, Class referencePoint) {
+        try {
+        ClassLoader cl = referencePoint.getClassLoader();
+        if(cl==null)  cl = ClassLoader.getSystemClassLoader();
+            return cl.loadClass(className);
+        } catch (ClassNotFoundException e) {
+            return null;
+        }
+    }
+
+    public boolean isBridgeMethod(Method method) {
+        return method.isBridge();
+    }
+
+    public boolean isOverriding(Method method) {
+        // this isn't actually correct,
+        // as the JLS considers
+        // class Derived extends Base<Integer> {
+        //   Integer getX() { ... }
+        // }
+        // class Base<T> {
+        //   T getX() { ... }
+        // }
+        // to be overrided. Handling this correctly needs a careful implementation
+
+        Class<?> s = method.getDeclaringClass().getSuperclass();
+        String name = method.getName();
+        Class[] params = method.getParameterTypes();
+
+        while(s!=null) {
+            try {
+                if(s.getDeclaredMethod(name,params)!=null)
+                    return true;
+            } catch (NoSuchMethodException e) {
+                ; // recursively go into the base class
+            }
+
+            s = s.getSuperclass();
+        }
+
+        return false;
+    }
+
+    public boolean isInterface(Class clazz) {
+        return clazz.isInterface();
+    }
+
+    public boolean isTransient(Field f) {
+        return Modifier.isTransient(f.getModifiers());
+    }
+
+
+    /**
+     * JDK 5.0 has a bug of createing {@link GenericArrayType} where it shouldn't.
+     * fix that manually to work around the problem.
+     *
+     * See bug 6202725.
+     */
+    private Type fix(Type t) {
+        if(!(t instanceof GenericArrayType))
+            return t;
+
+        GenericArrayType gat = (GenericArrayType) t;
+        if(gat.getGenericComponentType() instanceof Class) {
+            Class c = (Class) gat.getGenericComponentType();
+            return Array.newInstance(c,0).getClass();
+        }
+
+        return t;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/TypeVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/TypeVisitor.java
new file mode 100644
index 0000000..528f7c9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/TypeVisitor.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.nav;
+
+import java.lang.reflect.GenericArrayType;
+import java.lang.reflect.ParameterizedType;
+import java.lang.reflect.Type;
+import java.lang.reflect.TypeVariable;
+import java.lang.reflect.WildcardType;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class TypeVisitor<T,P> {
+    public final T visit( Type t, P param ) {
+        assert t!=null;
+
+        if (t instanceof Class)
+            return onClass((Class)t,param);
+        if (t instanceof ParameterizedType)
+            return onParameterizdType( (ParameterizedType)t,param);
+        if(t instanceof GenericArrayType)
+            return onGenericArray((GenericArrayType)t,param);
+        if(t instanceof WildcardType)
+            return onWildcard((WildcardType)t,param);
+        if(t instanceof TypeVariable)
+            return onVariable((TypeVariable)t,param);
+
+        // covered all the cases
+        assert false;
+        throw new IllegalArgumentException();
+    }
+
+    protected abstract T onClass(Class c, P param);
+    protected abstract T onParameterizdType(ParameterizedType p, P param);
+    protected abstract T onGenericArray(GenericArrayType g, P param);
+    protected abstract T onVariable(TypeVariable v, P param);
+    protected abstract T onWildcard(WildcardType w, P param);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/WildcardTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/WildcardTypeImpl.java
new file mode 100644
index 0000000..3d3fe4c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/WildcardTypeImpl.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.nav;
+
+import java.lang.reflect.Type;
+import java.lang.reflect.WildcardType;
+import java.util.Arrays;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class WildcardTypeImpl implements WildcardType {
+
+    private final Type[] ub;
+    private final Type[] lb;
+
+    public WildcardTypeImpl(Type[] ub, Type[] lb) {
+        this.ub = ub;
+        this.lb = lb;
+    }
+
+    public Type[] getUpperBounds() {
+        return ub;
+    }
+
+    public Type[] getLowerBounds() {
+        return lb;
+    }
+
+    public int hashCode() {
+        return Arrays.hashCode(lb) ^ Arrays.hashCode(ub);
+    }
+
+    public boolean equals(Object obj) {
+        if (obj instanceof WildcardType) {
+            WildcardType that = (WildcardType) obj;
+            return Arrays.equals(that.getLowerBounds(),lb)
+                && Arrays.equals(that.getUpperBounds(),ub);
+        }
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/package.html b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/package.html
new file mode 100644
index 0000000..e1ff6df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/nav/package.html
@@ -0,0 +1,3 @@
+<html><body>
+  Abstraction around the reflection library, to support various reflection models (such as java.lang.reflect and APT).
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeArrayInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeArrayInfo.java
new file mode 100644
index 0000000..f1a5648
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeArrayInfo.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.ArrayInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeArrayInfo extends ArrayInfo<Type,Class>, RuntimeNonElement {
+    /**
+     * Represents <tt>T[]</tt>.
+     *
+     * The same as {@link TypeInfo#getType()} but at the runtime, an array
+     * is guaranteed to have a {@link Class} representation, not just any {@link Type}.
+     */
+    Class getType();
+
+    /**
+     * {@inheritDoc}
+     */
+    RuntimeNonElement getItemType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeAttributePropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeAttributePropertyInfo.java
new file mode 100644
index 0000000..8b8de96
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeAttributePropertyInfo.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.AttributePropertyInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeAttributePropertyInfo extends AttributePropertyInfo<Type,Class>, RuntimePropertyInfo, RuntimeNonElementRef {
+    // refinement
+    RuntimeNonElement getTarget();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeBuiltinLeafInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeBuiltinLeafInfo.java
new file mode 100644
index 0000000..204d763
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeBuiltinLeafInfo.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.BuiltinLeafInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeBuiltinLeafInfo extends BuiltinLeafInfo<Type,Class>, RuntimeLeafInfo {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeClassInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeClassInfo.java
new file mode 100644
index 0000000..44d7b2a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeClassInfo.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+import java.lang.reflect.Method;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.annotation.XmlLocation;
+
+import org.xml.sax.Locator;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface RuntimeClassInfo extends ClassInfo<Type,Class>, RuntimeNonElement {
+    RuntimeClassInfo getBaseClass();
+
+    // refined to return RuntimePropertyInfo
+    List<? extends RuntimePropertyInfo> getProperties();
+    RuntimePropertyInfo getProperty(String name);
+
+    Method getFactoryMethod();
+
+    /**
+     * If {@link #hasAttributeWildcard()} is true,
+     * returns the accessor to access the property.
+     *
+     * @return
+     *      unoptimized accessor.
+     *      non-null iff {@link #hasAttributeWildcard()}==true.
+     *
+     * @see Accessor#optimize()
+     */
+    <BeanT> Accessor<BeanT,Map<QName,String>> getAttributeWildcard();
+
+    /**
+     * If this JAXB bean has a property annotated with {@link XmlLocation},
+     * this method returns it.
+     *
+     * @return may be null.
+     */
+    <BeanT> Accessor<BeanT,Locator> getLocatorField();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElement.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElement.java
new file mode 100644
index 0000000..ecb204c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElement.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.Element;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeElement extends Element<Type,Class>, RuntimeTypeInfo {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElementInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElementInfo.java
new file mode 100644
index 0000000..0ae24cf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElementInfo.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import javax.xml.bind.JAXBElement;
+
+import com.sun.xml.internal.bind.v2.model.core.ElementInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeElementInfo extends ElementInfo<Type,Class>, RuntimeElement {
+    RuntimeClassInfo getScope();
+
+    RuntimeElementPropertyInfo getProperty();
+
+    /**
+     * Returns the custom {@link JAXBElement} class tailored this element.
+     */
+    Class<? extends JAXBElement> getType();
+
+    /**
+     * {@inheritDoc}
+     */
+    RuntimeNonElement getContentType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElementPropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElementPropertyInfo.java
new file mode 100644
index 0000000..c018c35
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeElementPropertyInfo.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+import java.util.Collection;
+import java.util.List;
+
+import com.sun.xml.internal.bind.v2.model.core.ElementPropertyInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeElementPropertyInfo extends ElementPropertyInfo<Type,Class>, RuntimePropertyInfo {
+    /** {@inheritDoc} */
+    Collection<? extends RuntimeTypeInfo> ref();
+
+    List<? extends RuntimeTypeRef> getTypes();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeEnumLeafInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeEnumLeafInfo.java
new file mode 100644
index 0000000..fc1cfd1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeEnumLeafInfo.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.EnumLeafInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeEnumLeafInfo extends EnumLeafInfo<Type,Class>, RuntimeLeafInfo {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeLeafInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeLeafInfo.java
new file mode 100644
index 0000000..91cbcce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeLeafInfo.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.core.LeafInfo;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeLeafInfo extends LeafInfo<Type,Class>, RuntimeNonElement {
+    /**
+     * {@inheritDoc}
+     *
+     * @return
+     *      always non-null.
+     */
+    <V> Transducer<V> getTransducer();
+
+    /**
+     * The same as {@link #getType()} but returns the type as a {@link Class}.
+     * <p>
+     * Note that the returned {@link Class} object does not necessarily represents
+     * a class declaration. It can be primitive types.
+     */
+    Class getClazz();
+
+    /**
+     * Returns all the type names recognized by this type for unmarshalling.
+     *
+     * <p>
+     * While conceptually this method belongs to {@link RuntimeNonElement},
+     * if we do that we have to put a lot of dummy implementations everywhere,
+     * so it's placed here, where it's actually needed.
+     *
+     * @return
+     *      Always non-null. Do not modify the returned array.
+     */
+    QName[] getTypeNames();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeMapPropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeMapPropertyInfo.java
new file mode 100644
index 0000000..eeb1666
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeMapPropertyInfo.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.MapPropertyInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeMapPropertyInfo extends RuntimePropertyInfo, MapPropertyInfo<Type,Class> {
+    RuntimeNonElement getKeyType();
+    RuntimeNonElement getValueType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeNonElement.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeNonElement.java
new file mode 100644
index 0000000..bffafd1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeNonElement.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeNonElement extends NonElement<Type,Class>, RuntimeTypeInfo {
+    /**
+     * This method doesn't take the reference properties defined on
+     * {@link RuntimeNonElementRef} into account (such as ID-ness.)
+     *
+     * @see RuntimeNonElementRef#getTransducer()
+     */
+    <V> Transducer<V> getTransducer();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeNonElementRef.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeNonElementRef.java
new file mode 100644
index 0000000..94ce8ed
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeNonElementRef.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.NonElementRef;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+
+/**
+ * Runtime version of {@link NonElementRef}.
+ *
+ * <p>
+ * Inside the implementation, reference decorators implement this interface
+ * and this interface is used for chaining. Also, every {@link RuntimeNonElement}
+ * implementation implements this interface so that undecorated plain
+ * reference can be represented without using a separate object.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeNonElementRef extends NonElementRef<Type,Class> {
+    // refinements
+    RuntimeNonElement getTarget();
+    RuntimePropertyInfo getSource();
+
+    /**
+     * If the XML representation of the referenced Java type is just a text,
+     * return a transducer that converts between the bean and XML.
+     */
+    Transducer getTransducer();
+
+    // TransducedAccessor should be created
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimePropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimePropertyInfo.java
new file mode 100644
index 0000000..cac777a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimePropertyInfo.java
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+import java.util.Collection;
+
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * {@link PropertyInfo} that exposes more information.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface RuntimePropertyInfo extends PropertyInfo<Type,Class> {
+
+    /** {@inheritDoc} */
+    Collection<? extends RuntimeTypeInfo> ref();
+
+
+    /**
+     * Gets the {@link Accessor} for this property.
+     *
+     * <p>
+     * Even for a multi-value property, this method returns an accessor
+     * to that property. IOW, the accessor works against the raw type.
+     *
+     * <p>
+     * This methods returns unoptimized accessor (because optimization
+     * accessors are often combined into bigger pieces, and optimization
+     * generally works better if you can look at a bigger piece, as opposed
+     * to individually optimize a smaller components)
+     *
+     * @return
+     *      never null.
+     *
+     * @see Accessor#optimize()
+     */
+    Accessor getAccessor();
+
+    /**
+     * Returns true if this property has an element-only content. False otherwise.
+     */
+    public boolean elementOnlyContent();
+
+    /**
+     * Gets the "raw" type of the field.
+     *
+     * The raw type is the actual signature of the property.
+     * For example, if the field is the primitive int, this will be the primitive int.
+     * If the field is Object, this will be Object.
+     * If the property is the collection and typed as {@code Collection<Integer>},
+     * this method returns {@code Collection<Integer>}.
+     *
+     * @return always non-null.
+     */
+    Type getRawType();
+
+    /**
+     * Gets the type of the individual item.
+     *
+     * The individual type is the signature of the property used to store individual
+     * values. For a non-collection field, this is the same as {@link #getRawType()}.
+     * For acollection property, this is the type used to store individual value.
+     * So if {@link #getRawType()} is {@code Collection<Integer>}, this method will
+     * return {@link Integer}.
+     *
+     * @return always non-null.
+     */
+    Type getIndividualType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeReferencePropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeReferencePropertyInfo.java
new file mode 100644
index 0000000..f2dcbce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeReferencePropertyInfo.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+import java.util.Set;
+
+import com.sun.xml.internal.bind.v2.model.core.ReferencePropertyInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeReferencePropertyInfo extends ReferencePropertyInfo<Type,Class>, RuntimePropertyInfo {
+    Set<? extends RuntimeElement> getElements();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeInfo.java
new file mode 100644
index 0000000..ab88d9f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeInfo.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeTypeInfo extends TypeInfo<Type,Class> {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeInfoSet.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeInfoSet.java
new file mode 100644
index 0000000..dc59cd3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeInfoSet.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.nav.ReflectionNavigator;
+
+/**
+ * {@link TypeInfoSet} refined for runtime.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeTypeInfoSet extends TypeInfoSet<Type,Class,Field,Method>{
+    Map<Class,? extends RuntimeArrayInfo> arrays();
+    Map<Class,? extends RuntimeClassInfo> beans();
+    Map<Type,? extends RuntimeBuiltinLeafInfo> builtins();
+    Map<Class,? extends RuntimeEnumLeafInfo> enums();
+    RuntimeNonElement getTypeInfo( Type type );
+    RuntimeNonElement getAnyTypeInfo();
+    RuntimeNonElement getClassInfo( Class type );
+    RuntimeElementInfo getElementInfo( Class scope, QName name );
+    Map<QName,? extends RuntimeElementInfo> getElementMappings( Class scope );
+    Iterable<? extends RuntimeElementInfo> getAllElements();
+    ReflectionNavigator getNavigator();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeRef.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeRef.java
new file mode 100644
index 0000000..2f1aecb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeTypeRef.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.TypeRef;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeTypeRef extends TypeRef<Type,Class>, RuntimeNonElementRef {
+    RuntimeNonElement getTarget();
+    RuntimePropertyInfo getSource();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeValuePropertyInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeValuePropertyInfo.java
new file mode 100644
index 0000000..bc6e310
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/RuntimeValuePropertyInfo.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import java.lang.reflect.Type;
+
+import com.sun.xml.internal.bind.v2.model.core.ValuePropertyInfo;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface RuntimeValuePropertyInfo extends ValuePropertyInfo<Type,Class>,RuntimePropertyInfo,RuntimeNonElementRef {
+    RuntimeNonElement getTarget();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/package-info.java
new file mode 100644
index 0000000..fe560ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/model/runtime/package-info.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * The specialization of {@link com.sun.xml.internal.bind.v2.model.core} for the runtime.
+ *
+ * <p>
+ * This package offers stronger types and additional methods available at the runtime
+ * to access objects according to the model. Most of the interfaces correspond one to one
+ * with the core package, and they are simply named with {@code Runtime} prefix.
+ */
+@XmlSchema(namespace="http://jaxb.dev.java.net/xjc/model",elementFormDefault=XmlNsForm.QUALIFIED)
+package com.sun.xml.internal.bind.v2.model.runtime;
+
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.bind.annotation.XmlSchema;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/package-info.java
new file mode 100644
index 0000000..6913902
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/package-info.java
@@ -0,0 +1,186 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * <h1>The JAXB 2.0 runtime</h1>.
+ *
+ * <h1>Overview</h1>
+ * <p>
+ * This module provides code that implements {@link JAXBContext}.
+ * Roughly speaking the runtime works like this:
+ *
+ * <ol>
+ *  <li>There's a set of classes and interfaces that model JAXB-bound types.
+ *      You can think of this as a reflection library for JAXB.
+ *  <li>There's a set of classes that constitute the unmarshaller and marshaller.
+ *      Each class represents a small portion, and they are composed to perform
+ *      the operations.
+ *  <li>{@link JAXBContextImpl} builds itself by reading the model and
+ *      composing unmarshallers and marshallers.
+ * </ol>
+ *
+ * <h1>Interesting Pieces inside Runtime</h1>
+ * <p>
+ * The followings are the interesting pieces inside the runtime.
+ *
+ * <dl>
+ *  <dt>{@link com.sun.xml.internal.bind.v2.model model}
+ *  <dd>
+ *    This set of classes and interfaces models JAXB-bound types.
+ *
+ *  <dt>{@link com.sun.xml.internal.bind.v2.runtime XML I/O}
+ *  <dd>
+ *    This set of classes implements the JAXB API and provides the XML I/O functionality.
+ * </dl>
+ *
+ * <p>
+ * The classes <b>NOT</b> in the {@link com.sun.xml.internal.bind.v2} package (and its subpackages)
+ * are also used by old JAXB 1.0 clients.
+ *
+ * <h1>Models</h1>
+ * <p>
+ * "Model" is the portion of the code that represents JAXB-bound types.
+ *
+ * <p>
+ * The following picture illustrates the relationship among major
+ * packages of the binding model.
+ *
+ * <div>
+ *   <img src="doc-files/packages.png"/>
+ * </div>
+ *
+ * <p>
+ * The core model contracts are all interfaces, and they are parameterized
+ * so that they can be used
+ * with different reflection libraries. This is necessary, as the model
+ * is used:
+ * <ol>
+ *  <li> at runtime to process loaded classes,
+ *  <li> at tool-time to process source files / class files, and
+ *  <li> at schema compile time to generate source code.
+ * </ol>
+ * They all use different reflection libraries.
+ *
+ * <p>
+ * This portion is used by all
+ * three running mode of JAXB.
+ * <a href="model/impl/package-summary.html">The corresponding base-level implementaion</a>
+ * is also parameterized.
+ *
+ * <p>
+ * The runtime model contract and implementation are used only at the run-time.
+ * These packages fix the parameterization to the Java reflection,
+ * and also exposes additional functionalities to actually do the
+ * unmarshalling/marshalling. These classes have "Runtime" prefix.
+ *
+ * <p>
+ * Finally XJC has its own implementation of the contract in
+ * its own package. This package also fixes the parameterization
+ * to its own reflection library.
+ *
+ * <p>
+ * When you work on the code, it is often helpful to know the layer you are in.
+ *
+ *
+ * <p>
+ * The binding model design roughly looks like the following.
+ * For more details, see the javadoc of each component.
+ *
+ * <div>
+ *  <img src="doc-files/j2s_architecture.gif"/>
+ * </div>
+ *
+ * <b><i>TODO: link to classes from above pictures</i></b>
+ *
+ *
+ * <h3>Evolution Rules</h3>
+ * None of the class in this package or below should be directly
+ * referenced by the generated code. Hence they can be changed freely
+ * from versions to versions.
+ *
+ *
+ *
+ *
+ * <h1>Performance Characteristics</h1>
+ * <p>
+ * Model construction happens inside {@link JAXBContext#newInstance(Class[])}.
+ * It's desirable for this step to be fast and consume less memory,
+ * but it's not too performance sensitive.
+ *
+ * <p>
+ * Code that implements the unmarshaller and the marshaller OTOH
+ * needs to be very carefully written to achieve maximum sustaining
+ * performance.
+ *
+ *
+ *
+ *
+ * <h1>Bootstrap Sequence</h1>
+ * <p>
+ * The following picture illustrates how the {@link JAXBContext#newInstance(Class[])} method
+ * triggers activities.
+ *
+ * {@SequenceDiagram
+     boxwid=1.2;
+
+     pobject(U,"user");
+     object(A,"JAXB API");
+     object(CF,"ContextFactory");
+     pobject(JC);
+     step();
+
+     message(U,A,"JAXBContext.newInstance()");
+     active(A);
+     message(A,A,"locate JAXB RI 2.0");
+     active(A);
+     step();
+     inactive(A);
+
+     message(A,CF,"createContext");
+     active(CF);
+
+     create_message(CF,JC,"c:JAXBContextImpl");
+     active(JC);
+
+     message(JC,JC,"build runtime model");
+     message(JC,JC,"build JaxBeanInfos");
+     inactive(JC);
+
+     rmessage(A,U,"return c");
+     inactive(CF);
+     inactive(A);
+
+     complete(JC);
+     complete(CF);
+     complete(A);
+ * }
+ *
+ * @ArchitectureDocument
+ */
+package com.sun.xml.internal.bind.v2;
+
+import javax.xml.bind.JAXBContext;
+
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/AnyTypeBeanInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/AnyTypeBeanInfo.java
new file mode 100644
index 0000000..6cc85b7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/AnyTypeBeanInfo.java
@@ -0,0 +1,167 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.bind.annotation.W3CDomHandler;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.bind.ValidationEvent;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfo;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.DomLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiTypeLoader;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Element;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+import org.xml.sax.SAXException;
+
+/**
+ * {@link JaxBeanInfo} for handling <tt>xs:anyType</tt>.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class AnyTypeBeanInfo extends JaxBeanInfo<Object> {
+
+    public AnyTypeBeanInfo(JAXBContextImpl grammar,RuntimeTypeInfo anyTypeInfo) {
+        super(grammar, anyTypeInfo, Object.class, new QName(WellKnownNamespace.XML_SCHEMA,"anyType"), false, true, false);
+    }
+
+    public String getElementNamespaceURI(Object element) {
+        throw new UnsupportedOperationException();
+    }
+
+    public String getElementLocalName(Object element) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Object createInstance(UnmarshallingContext context) {
+        throw new UnsupportedOperationException();
+        // return JAXBContextImpl.createDom().createElementNS("","noname");
+    }
+
+    public boolean reset(Object element, UnmarshallingContext context) {
+        return false;
+//        NodeList nl = element.getChildNodes();
+//        while(nl.getLength()>0)
+//            element.removeChild(nl.item(0));
+//        NamedNodeMap al = element.getAttributes();
+//        while(al.getLength()>0)
+//            element.removeAttributeNode((Attr)al.item(0));
+//        return true;
+    }
+
+    public String getId(Object element, XMLSerializer target) {
+        return null;
+    }
+
+    public void serializeBody(Object element, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        NodeList childNodes = ((Element)element).getChildNodes();
+        int len = childNodes.getLength();
+        for( int i=0; i<len; i++ ) {
+            Node child = childNodes.item(i);
+            switch(child.getNodeType()) {
+            case Node.CDATA_SECTION_NODE:
+            case Node.TEXT_NODE:
+                target.text(child.getNodeValue(),null);
+                break;
+            case Node.ELEMENT_NODE:
+                target.writeDom((Element)child,domHandler,null,null);
+                break;
+            }
+        }
+    }
+
+    public void serializeAttributes(Object element, XMLSerializer target) throws SAXException {
+        NamedNodeMap al = ((Element)element).getAttributes();
+        int len = al.getLength();
+        for( int i=0; i<len; i++ ) {
+            Attr a = (Attr)al.item(i);
+            // work defensively
+            String uri = a.getNamespaceURI();
+            if(uri==null)   uri="";
+            String local = a.getLocalName();
+            String name = a.getName();
+            if(local==null) local = name;
+
+            if(name.startsWith("xmlns")) continue;// DOM reports ns decls as attributes
+
+            target.attribute(uri,local,a.getValue());
+        }
+    }
+
+    public void serializeRoot(Object element, XMLSerializer target) throws SAXException {
+        target.reportError(
+                new ValidationEventImpl(
+                        ValidationEvent.ERROR,
+                        Messages.UNABLE_TO_MARSHAL_NON_ELEMENT.format(element.getClass().getName()),
+                        null,
+                        null));
+    }
+
+    public void serializeURIs(Object element, XMLSerializer target) {
+        NamedNodeMap al = ((Element)element).getAttributes();
+        int len = al.getLength();
+        NamespaceContext2 context = target.getNamespaceContext();
+        for( int i=0; i<len; i++ ) {
+            Attr a = (Attr)al.item(i);
+            if( "xmlns".equals(a.getPrefix()) ) {
+                context.declareNamespace( a.getValue(), a.getLocalName(), true );
+                continue;
+            }
+            if( "xmlns".equals(a.getName()) ) {
+                context.declareNamespace( a.getValue(), "", false );
+                continue;
+            }
+            String nsUri = a.getNamespaceURI();
+            if(nsUri!=null && nsUri.length()>0)
+                context.declareNamespace( nsUri, a.getPrefix(), true );
+        }
+    }
+
+    public Transducer<Object> getTransducer() {
+        return null;
+    }
+
+    public Loader getLoader(JAXBContextImpl context, boolean typeSubstitutionCapable) {
+        if(typeSubstitutionCapable)
+            return substLoader;
+        else
+            return domLoader;
+    }
+
+    private static final W3CDomHandler domHandler = new W3CDomHandler();
+    private static final DomLoader domLoader = new DomLoader(domHandler);
+    private final XsiTypeLoader substLoader = new XsiTypeLoader(this);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ArrayBeanInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ArrayBeanInfoImpl.java
new file mode 100644
index 0000000..eb30d24
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ArrayBeanInfoImpl.java
@@ -0,0 +1,175 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.lang.reflect.Array;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.List;
+
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeArrayInfo;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Receiver;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.TagName;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link JaxBeanInfo} implementation that binds T[] to a complex type
+ * with an element for each item.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ArrayBeanInfoImpl  extends JaxBeanInfo {
+
+    private final Class itemType;
+    private final JaxBeanInfo itemBeanInfo;
+    private final Loader loader;
+
+    public ArrayBeanInfoImpl(JAXBContextImpl owner, RuntimeArrayInfo rai) {
+        super(owner,rai,rai.getType(), rai.getTypeName(), false, true, false);
+        this.itemType = jaxbType.getComponentType();
+        this.itemBeanInfo = owner.getOrCreate(rai.getItemType());
+
+        loader = new ArrayLoader(owner);
+    }
+
+    private final class ArrayLoader extends Loader implements Receiver {
+        public ArrayLoader(JAXBContextImpl owner) {
+            super(false);
+            itemLoader = itemBeanInfo.getLoader(owner,true);
+        }
+
+        private final Loader itemLoader;
+
+        @Override
+        public void startElement(UnmarshallingContext.State state, TagName ea) {
+            state.target = new ArrayList();
+        }
+
+        @Override
+        public void leaveElement(UnmarshallingContext.State state, TagName ea) {
+            state.target = toArray((List)state.target);
+        }
+
+        @Override
+        public void childElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+            if(ea.matches("","item")) {
+                state.loader = itemLoader;
+                state.receiver = this;
+            } else {
+                super.childElement(state,ea);
+            }
+        }
+
+        @Override
+        public Collection<QName> getExpectedChildElements() {
+            return Collections.singleton(new QName("","item"));
+        }
+
+        public void receive(UnmarshallingContext.State state, Object o) {
+            ((List)state.target).add(o);
+        }
+    };
+
+    protected Object toArray( List list ) {
+        int len = list.size();
+        Object array = Array.newInstance(itemType,len);
+        for( int i=0; i<len; i++ )
+            Array.set(array,i,list.get(i));
+        return array;
+    }
+
+    public void serializeBody(Object array, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        int len = Array.getLength(array);
+        for( int i=0; i<len; i++ )  {
+            Object item = Array.get(array,i);
+            // TODO: check the namespace URI.
+            target.startElement("","item",null,null);
+            if(item==null) {
+                target.writeXsiNilTrue();
+            } else {
+                target.childAsXsiType(item,"arrayItem",itemBeanInfo);
+            }
+            target.endElement();
+        }
+    }
+
+    public final String getElementNamespaceURI(Object array) {
+        throw new UnsupportedOperationException();
+    }
+
+    public final String getElementLocalName(Object array) {
+        throw new UnsupportedOperationException();
+    }
+
+    public final Object createInstance(UnmarshallingContext context) {
+        // we first create a List and then later convert it to an array
+        return new ArrayList();
+    }
+
+    public final boolean reset(Object array, UnmarshallingContext context) {
+        return false;
+    }
+
+    public final String getId(Object array, XMLSerializer target) {
+        return null;
+    }
+
+    public final void serializeAttributes(Object array, XMLSerializer target) {
+        // noop
+    }
+
+    public final void serializeRoot(Object array, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        target.reportError(
+                new ValidationEventImpl(
+                        ValidationEvent.ERROR,
+                        Messages.UNABLE_TO_MARSHAL_NON_ELEMENT.format(array.getClass().getName()),
+                        null,
+                        null));
+    }
+
+    public final void serializeURIs(Object array, XMLSerializer target) {
+        // noop
+    }
+
+    public final Transducer getTransducer() {
+        return null;
+    }
+
+    public final Loader getLoader(JAXBContextImpl context, boolean typeSubstitutionCapable) {
+        // type substitution not possible
+        return loader;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/AssociationMap.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/AssociationMap.java
new file mode 100644
index 0000000..5f60346
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/AssociationMap.java
@@ -0,0 +1,141 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Set;
+import java.util.HashSet;
+
+/**
+ * Bi-directional map between elements, inner peers,
+ * and outer peers.
+ *
+ * <p>
+ * TODO: this should be rewritten for efficiency.
+ *
+ * @since 2.0
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class AssociationMap<XmlNode> {
+    final static class Entry<XmlNode> {
+        /** XML element. */
+        private XmlNode element;
+        /** inner peer, or null. */
+        private Object inner;
+        /** outer peer, or null. */
+        private Object outer;
+
+        public XmlNode element() {
+                return element;
+        }
+        public Object inner() {
+                return inner;
+        }
+        public Object outer() {
+                return outer;
+        }
+    }
+
+    private final Map<XmlNode,Entry<XmlNode>> byElement = new HashMap<XmlNode,Entry<XmlNode>>();
+    private final Map<Object,Entry<XmlNode>> byPeer = new HashMap<Object,Entry<XmlNode>>();
+    private final Set<XmlNode> usedNodes = new HashSet<XmlNode>();
+
+    /** Records the new element&lt;->inner peer association. */
+    public void addInner( XmlNode element, Object inner ) {
+        Entry<XmlNode> e = byElement.get(element);
+        if(e!=null) {
+                if(e.inner!=null)
+                byPeer.remove(e.inner);
+            e.inner = inner;
+        } else {
+                e = new Entry<XmlNode>();
+            e.element = element;
+            e.inner = inner;
+        }
+
+        byElement.put(element,e);
+
+        Entry<XmlNode> old = byPeer.put(inner,e);
+        if(old!=null) {
+            if(old.outer!=null)
+                byPeer.remove(old.outer);
+            if(old.element!=null)
+                byElement.remove(old.element);
+        }
+    }
+
+    /** Records the new element&lt;->outer peer association. */
+    public void addOuter( XmlNode element, Object outer ) {
+        Entry<XmlNode> e = byElement.get(element);
+        if(e!=null) {
+            if(e.outer!=null)
+                byPeer.remove(e.outer);
+            e.outer = outer;
+        } else {
+            e = new Entry<XmlNode>();
+            e.element = element;
+            e.outer = outer;
+        }
+
+        byElement.put(element,e);
+
+        Entry<XmlNode> old = byPeer.put(outer,e);
+        if(old!=null) {
+            old.outer=null;
+
+            if(old.inner==null)
+                // remove this entry
+                byElement.remove(old.element);
+        }
+    }
+
+    public void addUsed( XmlNode n ) {
+        usedNodes.add(n);
+    }
+
+    public Entry<XmlNode> byElement( Object e ) {
+        return byElement.get(e);
+    }
+
+    public Entry<XmlNode> byPeer( Object o ) {
+        return byPeer.get(o);
+    }
+
+    public Object getInnerPeer( XmlNode element ) {
+        Entry e = byElement(element);
+        if(e==null)     return null;
+        else            return e.inner;
+    }
+
+    public Object getOuterPeer( XmlNode element ) {
+        Entry e = byElement(element);
+        if(e==null)     return null;
+        else            return e.outer;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BinderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BinderImpl.java
new file mode 100644
index 0000000..f1eb450
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BinderImpl.java
@@ -0,0 +1,272 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import javax.xml.bind.Binder;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.PropertyException;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.validation.Schema;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.unmarshaller.InfosetScanner;
+import com.sun.xml.internal.bind.v2.runtime.output.DOMOutput;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.InterningXmlVisitor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.SAXConnector;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.xml.sax.SAXException;
+
+/**
+ * Implementation of {@link Binder}.
+ *
+ * TODO: investigate how much in-place unmarshalling is implemented
+ *      - some preliminary work is there. Probably buggy.
+ * TODO: work on the marshaller side.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class BinderImpl<XmlNode> extends Binder<XmlNode> {
+
+    /**
+     * The parent context object.
+     */
+    private final JAXBContextImpl context;
+
+    /**
+     * Lazily created unmarshaller to do XML->Java binding.
+     * @see #getUnmarshaller()
+     */
+    private UnmarshallerImpl unmarshaller;
+
+    /**
+     * Lazily create marshaller to do Java->XML binding.
+     * @see #getMarshaller()
+     */
+    private MarshallerImpl marshaller;
+
+    private final InfosetScanner<XmlNode> scanner;
+
+    /**
+     * A {@link Binder} always works with the same
+     * association map.
+     */
+    private final AssociationMap<XmlNode> assoc = new AssociationMap<XmlNode>();
+
+    BinderImpl(JAXBContextImpl _context,InfosetScanner<XmlNode> scanner) {
+        this.context = _context;
+        this.scanner = scanner;
+    }
+
+    private UnmarshallerImpl getUnmarshaller() {
+        if(unmarshaller==null)
+            unmarshaller = new UnmarshallerImpl(context,assoc);
+        return unmarshaller;
+    }
+
+    private MarshallerImpl getMarshaller() {
+        if(marshaller==null)
+            marshaller = new MarshallerImpl(context,assoc);
+        return marshaller;
+    }
+
+    public void marshal(Object jaxbObject, XmlNode xmlNode) throws JAXBException {
+        if ((xmlNode == null) || (jaxbObject == null))
+            throw new IllegalArgumentException();
+        getMarshaller().marshal(jaxbObject,createOutput(xmlNode));
+    }
+
+    // TODO move this to a sub class once we support something other than W3C DOM
+    private DOMOutput createOutput(XmlNode xmlNode) {
+        return new DOMOutput((Node)xmlNode,assoc);
+    }
+
+
+    public Object updateJAXB(XmlNode xmlNode) throws JAXBException {
+        return associativeUnmarshal(xmlNode,true,null);
+    }
+
+    public Object unmarshal( XmlNode xmlNode ) throws JAXBException {
+        return associativeUnmarshal(xmlNode,false,null);
+    }
+
+    public <T> JAXBElement<T> unmarshal(XmlNode xmlNode, Class<T> expectedType) throws JAXBException {
+        if(expectedType==null)  throw new IllegalArgumentException();
+        return (JAXBElement)associativeUnmarshal(xmlNode,true,expectedType);
+    }
+
+    public void setSchema(Schema schema) {
+        getUnmarshaller().setSchema(schema);
+    }
+
+    public Schema getSchema() {
+        return getUnmarshaller().getSchema();
+    }
+
+    private Object associativeUnmarshal(XmlNode xmlNode, boolean inplace, Class expectedType) throws JAXBException {
+        if (xmlNode == null)
+            throw new IllegalArgumentException();
+
+        JaxBeanInfo bi = null;
+        if(expectedType!=null)
+            bi = context.getBeanInfo(expectedType, true);
+
+        InterningXmlVisitor handler = new InterningXmlVisitor(
+            getUnmarshaller().createUnmarshallerHandler(scanner,inplace,bi));
+        scanner.setContentHandler(new SAXConnector(handler,scanner.getLocator()));
+        try {
+            scanner.scan(xmlNode);
+        } catch( SAXException e ) {
+            throw unmarshaller.createUnmarshalException(e);
+        }
+
+        return handler.getContext().getResult();
+    }
+
+    public XmlNode getXMLNode(Object jaxbObject) {
+        AssociationMap.Entry<XmlNode> e = assoc.byPeer(jaxbObject);
+        if(e==null)     return null;
+        return e.element();
+    }
+
+    public Object getJAXBNode(XmlNode xmlNode) {
+        AssociationMap.Entry e = assoc.byElement(xmlNode);
+        if(e==null)     return null;
+        if(e.outer()!=null)     return e.outer();
+        return e.inner();
+    }
+
+    public XmlNode updateXML(Object jaxbObject) throws JAXBException {
+        return updateXML(jaxbObject,getXMLNode(jaxbObject));
+    }
+
+    public XmlNode updateXML(Object jaxbObject, XmlNode xmlNode) throws JAXBException {
+        if(jaxbObject==null || xmlNode==null)   throw new IllegalArgumentException();
+
+        // TODO
+        // for now just marshal
+        // TODO: object model independenc
+        Element e = (Element)xmlNode;
+        Node ns = e.getNextSibling();
+        Node p = e.getParentNode();
+        p.removeChild(e);
+
+        // if the type object is passed, the following step is necessary to make
+        // the marshalling successful.
+        JaxBeanInfo bi = context.getBeanInfo(jaxbObject, true);
+        if(!bi.isElement())
+            jaxbObject = new JAXBElement(new QName(e.getNamespaceURI(),e.getLocalName()),bi.jaxbType,jaxbObject);
+
+
+        getMarshaller().marshal(jaxbObject,p);
+        Node newNode = p.getLastChild();
+        p.removeChild(newNode);
+        p.insertBefore(newNode,ns);
+
+        return (XmlNode)newNode;
+    }
+
+    public void setEventHandler(ValidationEventHandler handler) throws JAXBException {
+        getUnmarshaller().setEventHandler(handler);
+        getMarshaller().setEventHandler(handler);
+    }
+
+    public ValidationEventHandler getEventHandler() {
+        return getUnmarshaller().getEventHandler();
+    }
+
+    public Object getProperty(String name) throws PropertyException {
+        if (name == null)
+            throw new IllegalArgumentException(Messages.NULL_PROPERTY_NAME.format());
+
+        // exclude RI properties that don't make sense for Binder
+        if (excludeProperty(name)) {
+            throw new PropertyException(name);
+        }
+
+        Object prop = null;
+        PropertyException pe = null;
+
+        try {
+            prop = getMarshaller().getProperty(name);
+            return prop;
+        } catch (PropertyException p) {
+            pe = p;
+        }
+
+        try {
+            prop = getUnmarshaller().getProperty(name);
+            return prop;
+        } catch (PropertyException p) {
+            pe = p;
+        }
+
+        pe.setStackTrace(Thread.currentThread().getStackTrace());
+        throw pe;
+    }
+
+    public void setProperty(String name, Object value) throws PropertyException {
+        if (name == null)
+            throw new IllegalArgumentException(Messages.NULL_PROPERTY_NAME.format());
+
+        // exclude RI properties that don't make sense for Binder
+        if (excludeProperty(name)) {
+            throw new PropertyException(name, value);
+        }
+
+        PropertyException pe = null;
+
+        try {
+            getMarshaller().setProperty(name, value);
+            return;
+        } catch (PropertyException p) {
+            pe = p;
+        }
+
+        try {
+            getUnmarshaller().setProperty(name, value);
+            return;
+        } catch (PropertyException p) {
+            pe = p;
+        }
+
+        // replace the stacktrace - we don't want to see a trace
+        // originating from Un|Marshaller.setProperty
+        pe.setStackTrace(Thread.currentThread().getStackTrace());
+        throw pe;
+    }
+
+    private boolean excludeProperty(String name) {
+        return name.equals(
+                MarshallerImpl.ENCODING_HANDLER) ||
+                        name.equals(MarshallerImpl.XMLDECLARATION) ||
+                        name.equals(MarshallerImpl.XML_HEADERS);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeAdapter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeAdapter.java
new file mode 100644
index 0000000..4c338d4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeAdapter.java
@@ -0,0 +1,154 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.MarshalException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.UnmarshalException;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.Result;
+import javax.xml.transform.Source;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.xml.internal.bind.api.Bridge;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl;
+
+import org.w3c.dom.Node;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Bridge} decorator for {@link XmlAdapter}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class BridgeAdapter<OnWire,InMemory> extends InternalBridge<InMemory> {
+    private final InternalBridge<OnWire> core;
+    private final Class<? extends XmlAdapter<OnWire,InMemory>> adapter;
+
+    public BridgeAdapter(InternalBridge<OnWire> core, Class<? extends XmlAdapter<OnWire,InMemory>> adapter) {
+        super(core.getContext());
+        this.core = core;
+        this.adapter = adapter;
+    }
+
+    public void marshal(Marshaller m, InMemory inMemory, XMLStreamWriter output) throws JAXBException {
+        core.marshal(m,adaptM(m,inMemory),output);
+    }
+
+    public void marshal(Marshaller m, InMemory inMemory, OutputStream output, NamespaceContext nsc) throws JAXBException {
+        core.marshal(m,adaptM(m,inMemory),output,nsc);
+    }
+
+    public void marshal(Marshaller m, InMemory inMemory, Node output) throws JAXBException {
+        core.marshal(m,adaptM(m,inMemory),output);
+    }
+
+    public void marshal(Marshaller context, InMemory inMemory, ContentHandler contentHandler) throws JAXBException {
+        core.marshal(context,adaptM(context,inMemory),contentHandler);
+    }
+
+    public void marshal(Marshaller context, InMemory inMemory, Result result) throws JAXBException {
+        core.marshal(context,adaptM(context,inMemory),result);
+    }
+
+    private OnWire adaptM(Marshaller m,InMemory v) throws JAXBException {
+        XMLSerializer serializer = ((MarshallerImpl)m).serializer;
+        serializer.setThreadAffinity();
+        serializer.pushCoordinator();
+        try {
+            return _adaptM(serializer, v);
+        } finally {
+            serializer.popCoordinator();
+            serializer.resetThreadAffinity();
+        }
+    }
+
+    private OnWire _adaptM(XMLSerializer serializer, InMemory v) throws MarshalException {
+        XmlAdapter<OnWire,InMemory> a = serializer.getAdapter(adapter);
+        try {
+            return a.marshal(v);
+        } catch (Exception e) {
+            serializer.handleError(e,v,null);
+            throw new MarshalException(e);
+        }
+    }
+
+
+    public @NotNull InMemory unmarshal(Unmarshaller u, XMLStreamReader in) throws JAXBException {
+        return adaptU(u, core.unmarshal(u,in));
+    }
+
+    public @NotNull InMemory unmarshal(Unmarshaller u, Source in) throws JAXBException {
+        return adaptU(u, core.unmarshal(u,in));
+    }
+
+    public @NotNull InMemory unmarshal(Unmarshaller u, InputStream in) throws JAXBException {
+        return adaptU(u, core.unmarshal(u,in));
+    }
+
+    public @NotNull InMemory unmarshal(Unmarshaller u, Node n) throws JAXBException {
+        return adaptU(u, core.unmarshal(u,n));
+    }
+
+    public TypeReference getTypeReference() {
+        return core.getTypeReference();
+    }
+
+    private @NotNull InMemory adaptU(Unmarshaller _u, OnWire v) throws JAXBException {
+        UnmarshallerImpl u = (UnmarshallerImpl) _u;
+        XmlAdapter<OnWire,InMemory> a = u.coordinator.getAdapter(adapter);
+        u.coordinator.setThreadAffinity();
+        u.coordinator.pushCoordinator();
+        try {
+            return a.unmarshal(v);
+        } catch (Exception e) {
+            throw new UnmarshalException(e);
+        } finally {
+            u.coordinator.popCoordinator();
+            u.coordinator.resetThreadAffinity();
+        }
+    }
+
+    void marshal(InMemory o, XMLSerializer out) throws IOException, SAXException, XMLStreamException {
+        try {
+            core.marshal(_adaptM( XMLSerializer.getInstance(), o ), out );
+        } catch (MarshalException e) {
+            // recover from error by not marshalling this element.
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeContextImpl.java
new file mode 100644
index 0000000..d1b10d0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeContextImpl.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl;
+
+/**
+ * {@link BridgeContext} implementation.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class BridgeContextImpl extends BridgeContext {
+
+    public final UnmarshallerImpl unmarshaller;
+    public final MarshallerImpl marshaller;
+
+    BridgeContextImpl(JAXBContextImpl context) {
+        unmarshaller = context.createUnmarshaller();
+        marshaller = context.createMarshaller();
+    }
+
+    public void setErrorHandler(ValidationEventHandler handler) {
+        try {
+            unmarshaller.setEventHandler(handler);
+            marshaller.setEventHandler(handler);
+        } catch (JAXBException e) {
+            // impossible
+            throw new Error(e);
+        }
+    }
+
+    public void setAttachmentMarshaller(AttachmentMarshaller m) {
+        marshaller.setAttachmentMarshaller(m);
+    }
+
+    public void setAttachmentUnmarshaller(AttachmentUnmarshaller u) {
+        unmarshaller.setAttachmentUnmarshaller(u);
+    }
+
+    public AttachmentMarshaller getAttachmentMarshaller() {
+        return marshaller.getAttachmentMarshaller();
+    }
+
+    public AttachmentUnmarshaller getAttachmentUnmarshaller() {
+        return unmarshaller.getAttachmentUnmarshaller();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeImpl.java
new file mode 100644
index 0000000..5cb5d76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/BridgeImpl.java
@@ -0,0 +1,141 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.Result;
+import javax.xml.transform.Source;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.xml.internal.bind.api.Bridge;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
+import com.sun.xml.internal.bind.v2.runtime.output.SAXOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.XMLStreamWriterOutput;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl;
+
+import org.w3c.dom.Node;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Bridge} implementaiton.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class BridgeImpl<T> extends InternalBridge<T> {
+
+    /**
+     * Tag name associated with this {@link Bridge}.
+     * Used for marshalling.
+     */
+    private final Name tagName;
+    private final JaxBeanInfo<T> bi;
+    private final TypeReference typeRef;
+
+    public BridgeImpl(JAXBContextImpl context, Name tagName, JaxBeanInfo<T> bi,TypeReference typeRef) {
+        super(context);
+        this.tagName = tagName;
+        this.bi = bi;
+        this.typeRef = typeRef;
+    }
+
+    public void marshal(Marshaller _m, T t, XMLStreamWriter output) throws JAXBException {
+        MarshallerImpl m = (MarshallerImpl)_m;
+        m.write(tagName,bi,t,XMLStreamWriterOutput.create(output),new StAXPostInitAction(output,m.serializer));
+    }
+
+    public void marshal(Marshaller _m, T t, OutputStream output, NamespaceContext nsContext) throws JAXBException {
+        MarshallerImpl m = (MarshallerImpl)_m;
+
+        Runnable pia = null;
+        if(nsContext!=null)
+            pia = new StAXPostInitAction(nsContext,m.serializer);
+
+        m.write(tagName,bi,t,m.createWriter(output),pia);
+    }
+
+    public void marshal(Marshaller _m, T t, Node output) throws JAXBException {
+        MarshallerImpl m = (MarshallerImpl)_m;
+        m.write(tagName,bi,t,new SAXOutput(new SAX2DOMEx(output)),new DomPostInitAction(output,m.serializer));
+    }
+
+    public void marshal(Marshaller _m, T t, ContentHandler contentHandler) throws JAXBException {
+        MarshallerImpl m = (MarshallerImpl)_m;
+        m.write(tagName,bi,t,new SAXOutput(contentHandler),null);
+    }
+
+    public void marshal(Marshaller _m, T t, Result result) throws JAXBException {
+        MarshallerImpl m = (MarshallerImpl)_m;
+        m.write(tagName,bi,t, m.createXmlOutput(result),m.createPostInitAction(result));
+    }
+
+    public @NotNull T unmarshal(Unmarshaller _u, XMLStreamReader in) throws JAXBException {
+        UnmarshallerImpl u = (UnmarshallerImpl)_u;
+        return ((JAXBElement<T>)u.unmarshal0(in,bi)).getValue();
+    }
+
+    public @NotNull T unmarshal(Unmarshaller _u, Source in) throws JAXBException {
+        UnmarshallerImpl u = (UnmarshallerImpl)_u;
+        return ((JAXBElement<T>)u.unmarshal0(in,bi)).getValue();
+    }
+
+    public @NotNull T unmarshal(Unmarshaller _u, InputStream in) throws JAXBException {
+        UnmarshallerImpl u = (UnmarshallerImpl)_u;
+        return ((JAXBElement<T>)u.unmarshal0(in,bi)).getValue();
+    }
+
+    public @NotNull T unmarshal(Unmarshaller _u, Node n) throws JAXBException {
+        UnmarshallerImpl u = (UnmarshallerImpl)_u;
+        return ((JAXBElement<T>)u.unmarshal0(n,bi)).getValue();
+    }
+
+    public TypeReference getTypeReference() {
+        return typeRef;
+    }
+
+    public void marshal(T value, XMLSerializer out) throws IOException, SAXException, XMLStreamException {
+        out.startElement(tagName,null);
+        if(value==null) {
+            out.writeXsiNilTrue();
+        } else {
+            out.childAsXsiType(value,null,bi);
+        }
+        out.endElement();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ClassBeanInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ClassBeanInfoImpl.java
new file mode 100644
index 0000000..c64bf83
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ClassBeanInfoImpl.java
@@ -0,0 +1,373 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.lang.reflect.Modifier;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.List;
+import java.util.Map;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.FinalArrayList;
+import com.sun.xml.internal.bind.Util;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeClassInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.property.AttributeProperty;
+import com.sun.xml.internal.bind.v2.runtime.property.Property;
+import com.sun.xml.internal.bind.v2.runtime.property.PropertyFactory;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.StructureLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiTypeLoader;
+
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.LocatorImpl;
+
+/**
+ * {@link JaxBeanInfo} implementation for j2s bean.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class ClassBeanInfoImpl<BeanT> extends JaxBeanInfo<BeanT> {
+
+    /**
+     * Properties of this bean class but not its ancestor classes.
+     */
+    public final Property<BeanT>[] properties;
+
+    /**
+     * Non-null if this bean has an ID property.
+     */
+    private Property<? super BeanT> idProperty;
+
+    /**
+     * Immutable configured loader for this class.
+     *
+     * <p>
+     * Set from the link method, but considered final.
+     */
+    private Loader loader;
+    private Loader loaderWithTypeSubst;
+
+    /**
+     * Set only until the link phase to avoid leaking memory.
+     */
+    private RuntimeClassInfo ci;
+
+    private final Accessor<? super BeanT,Map<QName,String>> inheritedAttWildcard;
+    private final Transducer<BeanT> xducer;
+
+    /**
+     * {@link ClassBeanInfoImpl} that represents the super class of {@link #jaxbType}.
+     */
+    public final ClassBeanInfoImpl<? super BeanT> superClazz;
+
+    private final Accessor<? super BeanT,Locator> xmlLocatorField;
+
+    private final Name tagName;
+
+    /**
+     * The {@link AttributeProperty}s for this type and all its ancestors.
+     * If {@link JAXBContextImpl#c14nSupport} is true, this is sorted alphabetically.
+     */
+    private /*final*/ AttributeProperty<BeanT>[] attributeProperties;
+
+    /**
+     * {@link Property}s that need to receive {@link Property#serializeURIs(Object, XMLSerializer)} callback.
+     */
+    private /*final*/ Property<BeanT>[] uriProperties;
+
+    private final Method factoryMethod;
+
+    /*package*/ ClassBeanInfoImpl(JAXBContextImpl owner, RuntimeClassInfo ci) {
+        super(owner,ci,ci.getClazz(),ci.getTypeName(),ci.isElement(),false,true);
+
+        this.ci = ci;
+        this.inheritedAttWildcard = ci.getAttributeWildcard();
+        this.xducer = ci.getTransducer();
+        this.factoryMethod = ci.getFactoryMethod();
+        // make the factory accessible
+        if(factoryMethod!=null) {
+            int classMod = factoryMethod.getDeclaringClass().getModifiers();
+
+            if(!Modifier.isPublic(classMod) || !Modifier.isPublic(factoryMethod.getModifiers())) {
+                // attempt to make it work even if the constructor is not accessible
+                try {
+                    factoryMethod.setAccessible(true);
+                } catch(SecurityException e) {
+                    // but if we don't have a permission to do so, work gracefully.
+                    logger.log(Level.FINE,"Unable to make the method of "+factoryMethod+" accessible",e);
+                    throw e;
+                }
+            }
+        }
+
+
+        if(ci.getBaseClass()==null)
+            this.superClazz = null;
+        else
+            this.superClazz = owner.getOrCreate(ci.getBaseClass());
+
+        if(superClazz!=null && superClazz.xmlLocatorField!=null)
+            xmlLocatorField = superClazz.xmlLocatorField;
+        else
+            xmlLocatorField = ci.getLocatorField();
+
+        // create property objects
+        Collection<? extends RuntimePropertyInfo> ps = ci.getProperties();
+        this.properties = new Property[ps.size()];
+        int idx=0;
+        boolean elementOnly = true;
+        for( RuntimePropertyInfo info : ps ) {
+            Property p = PropertyFactory.create(owner,info);
+            if(info.id()==ID.ID)
+                idProperty = p;
+            properties[idx++] = p;
+            elementOnly &= info.elementOnlyContent();
+        }
+        // super class' idProperty might not be computed at this point,
+        // so check that later
+
+        hasElementOnlyContentModel( elementOnly );
+        // again update this value later when we know that of the super class
+
+        if(ci.isElement())
+            tagName = owner.nameBuilder.createElementName(ci.getElementName());
+        else
+            tagName = null;
+
+        setLifecycleFlags();
+    }
+
+    @Override
+    protected void link(JAXBContextImpl grammar) {
+        if(uriProperties!=null)
+            return; // avoid linking twice
+
+        super.link(grammar);
+
+        if(superClazz!=null)
+            superClazz.link(grammar);
+
+        getLoader(grammar,true);    // make sure to build the loader if we haven't done so.
+
+        // propagate values from super class
+        if(superClazz!=null) {
+            if(idProperty==null)
+                idProperty = superClazz.idProperty;
+
+            if(!superClazz.hasElementOnlyContentModel())
+                hasElementOnlyContentModel(false);
+        }
+
+        // create a list of attribute/URI handlers
+        List<AttributeProperty> attProps = new FinalArrayList<AttributeProperty>();
+        List<Property> uriProps = new FinalArrayList<Property>();
+        for (ClassBeanInfoImpl bi = this; bi != null; bi = bi.superClazz) {
+            for (int i = bi.properties.length - 1; i >= 0; i--) {
+                Property p = bi.properties[i];
+                if(p instanceof AttributeProperty)
+                    attProps.add((AttributeProperty) p);
+                if(p.hasSerializeURIAction())
+                    uriProps.add(p);
+            }
+        }
+        if(grammar.c14nSupport)
+            Collections.sort(attProps);
+
+        if(attProps.isEmpty())
+            attributeProperties = EMPTY_PROPERTIES;
+        else
+            attributeProperties = attProps.toArray(new AttributeProperty[attProps.size()]);
+
+        if(uriProps.isEmpty())
+            uriProperties = EMPTY_PROPERTIES;
+        else
+            uriProperties = uriProps.toArray(new Property[uriProps.size()]);
+    }
+
+    public void wrapUp() {
+        for (Property p : properties)
+            p.wrapUp();
+        ci = null;
+        super.wrapUp();
+    }
+
+    public String getElementNamespaceURI(BeanT bean) {
+        return tagName.nsUri;
+    }
+
+    public String getElementLocalName(BeanT bean) {
+        return tagName.localName;
+    }
+
+    public BeanT createInstance(UnmarshallingContext context) throws IllegalAccessException, InvocationTargetException, InstantiationException, SAXException {
+
+        BeanT bean = null;
+        if (factoryMethod == null){
+           bean = ClassFactory.create0(jaxbType);
+        }else {
+            Object o = ClassFactory.create(factoryMethod);
+            if( jaxbType.isInstance(o) ){
+                bean = (BeanT)o;
+            } else {
+                throw new InstantiationException("The factory method didn't return a correct object");
+            }
+        }
+
+        if(xmlLocatorField!=null)
+            // need to copy because Locator is mutable
+            try {
+                xmlLocatorField.set(bean,new LocatorImpl(context.getLocator()));
+            } catch (AccessorException e) {
+                context.handleError(e);
+            }
+        return bean;
+    }
+
+    public boolean reset(BeanT bean, UnmarshallingContext context) throws SAXException {
+        try {
+            if(superClazz!=null)
+                superClazz.reset(bean,context);
+            for( Property<BeanT> p : properties )
+                p.reset(bean);
+            return true;
+        } catch (AccessorException e) {
+            context.handleError(e);
+            return false;
+        }
+    }
+
+    public String getId(BeanT bean, XMLSerializer target) throws SAXException {
+        if(idProperty!=null) {
+            try {
+                return idProperty.getIdValue(bean);
+            } catch (AccessorException e) {
+                target.reportError(null,e);
+            }
+        }
+        return null;
+    }
+
+    public void serializeRoot(BeanT bean, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        if(tagName==null) {
+            target.reportError(
+                    new ValidationEventImpl(
+                            ValidationEvent.ERROR,
+                            Messages.UNABLE_TO_MARSHAL_NON_ELEMENT.format(bean.getClass().getName()),
+                            null,
+                            null));
+        }
+        else {
+            target.startElement(tagName,bean);
+            target.childAsSoleContent(bean,null);
+            target.endElement();
+        }
+    }
+
+    public void serializeBody(BeanT bean, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        if(superClazz!=null)
+            superClazz.serializeBody(bean,target);
+        try {
+            for( Property<BeanT> p : properties )
+                p.serializeBody(bean,target, null);
+        } catch (AccessorException e) {
+            target.reportError(null,e);
+        }
+    }
+
+    public void serializeAttributes(BeanT bean, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        try {
+            for( AttributeProperty<BeanT> p : attributeProperties )
+                p.serializeAttributes(bean,target);
+
+            if(inheritedAttWildcard!=null) {
+                Map<QName,String> map = inheritedAttWildcard.get(bean);
+                target.attWildcardAsAttributes(map,null);
+            }
+        } catch (AccessorException e) {
+            target.reportError(null,e);
+        }
+    }
+
+    public void serializeURIs(BeanT bean, XMLSerializer target) throws SAXException {
+        try {
+            for( Property<BeanT> p : uriProperties )
+                p.serializeURIs(bean,target);
+
+            if(inheritedAttWildcard!=null) {
+                Map<QName,String> map = inheritedAttWildcard.get(bean);
+                target.attWildcardAsURIs(map,null);
+            }
+        } catch (AccessorException e) {
+            target.reportError(null,e);
+        }
+    }
+
+    public Loader getLoader(JAXBContextImpl context, boolean typeSubstitutionCapable) {
+        if(loader==null) {
+            // these variables have to be set before they are initialized,
+            // because the initialization may build other loaders and they may refer to this.
+            StructureLoader sl = new StructureLoader(this);
+            loader = sl;
+            if(ci.hasSubClasses())
+                loaderWithTypeSubst = new XsiTypeLoader(this);
+            else
+                // optimization. we know there can be no @xsi:type
+                loaderWithTypeSubst = loader;
+
+
+            sl.init(context,this,ci.getAttributeWildcard());
+        }
+        if(typeSubstitutionCapable)
+            return loaderWithTypeSubst;
+        else
+            return loader;
+    }
+
+    public Transducer<BeanT> getTransducer() {
+        return xducer;
+    }
+
+    private static final AttributeProperty[] EMPTY_PROPERTIES = new AttributeProperty[0];
+
+    private static final Logger logger = Util.getClassLogger();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/CompositeStructureBeanInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/CompositeStructureBeanInfo.java
new file mode 100644
index 0000000..283fb2e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/CompositeStructureBeanInfo.java
@@ -0,0 +1,103 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.lang.reflect.InvocationTargetException;
+
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.CompositeStructure;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class CompositeStructureBeanInfo extends JaxBeanInfo<CompositeStructure> {
+    public CompositeStructureBeanInfo(JAXBContextImpl context) {
+        super(context,null, CompositeStructure.class,false,true,false);
+    }
+
+    public String getElementNamespaceURI(CompositeStructure o) {
+        throw new UnsupportedOperationException();
+    }
+
+    public String getElementLocalName(CompositeStructure o) {
+        throw new UnsupportedOperationException();
+    }
+
+    public CompositeStructure createInstance(UnmarshallingContext context) throws IllegalAccessException, InvocationTargetException, InstantiationException, SAXException {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean reset(CompositeStructure o, UnmarshallingContext context) throws SAXException {
+        throw new UnsupportedOperationException();
+    }
+
+    public String getId(CompositeStructure o, XMLSerializer target) throws SAXException {
+        return null;
+    }
+
+    public Loader getLoader(JAXBContextImpl context, boolean typeSubstitutionCapable) {
+        // no unmarshaller support for this.
+        throw new UnsupportedOperationException();
+    }
+
+    public void serializeRoot(CompositeStructure o, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        target.reportError(
+                new ValidationEventImpl(
+                        ValidationEvent.ERROR,
+                        Messages.UNABLE_TO_MARSHAL_NON_ELEMENT.format(o.getClass().getName()),
+                        null,
+                        null));
+    }
+
+    public void serializeURIs(CompositeStructure o, XMLSerializer target) throws SAXException {
+        // noop
+    }
+
+    public void serializeAttributes(CompositeStructure o, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        // noop
+    }
+
+    public void serializeBody(CompositeStructure o, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        int len = o.bridges.length;
+        for( int i=0; i<len; i++ ) {
+            Object value = o.values[i];
+            InternalBridge bi = (InternalBridge)o.bridges[i];
+            bi.marshal( value, target );
+        }
+    }
+
+    public Transducer<CompositeStructure> getTransducer() {
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ContentHandlerAdaptor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ContentHandlerAdaptor.java
new file mode 100644
index 0000000..e640f63
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ContentHandlerAdaptor.java
@@ -0,0 +1,140 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.FinalArrayList;
+import com.sun.istack.internal.SAXException2;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.DefaultHandler;
+
+/**
+ * Receives SAX2 events and send the equivalent events to
+ * {@link XMLSerializer}
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final class ContentHandlerAdaptor extends DefaultHandler {
+
+    /** Stores newly declared prefix-URI mapping. */
+    private final FinalArrayList prefixMap = new FinalArrayList();
+
+    /** Events will be sent to this object. */
+    private final XMLSerializer serializer;
+
+    private final StringBuffer text = new StringBuffer();
+
+
+    ContentHandlerAdaptor( XMLSerializer _serializer ) {
+        this.serializer = _serializer;
+    }
+
+    public void startDocument() {
+        prefixMap.clear();
+    }
+
+    public void startPrefixMapping(String prefix, String uri) {
+        prefixMap.add(prefix);
+        prefixMap.add(uri);
+    }
+
+    public void startElement(String namespaceURI, String localName, String qName, Attributes atts)
+        throws SAXException {
+        try {
+            flushText();
+
+            int len = atts.getLength();
+
+            serializer.startElement(namespaceURI,localName,getPrefix(qName),null);
+            // declare namespace events
+            for( int i=0; i<len; i++ ) {
+                String qname = atts.getQName(i);
+                if(qname.startsWith("xmlns"))
+                    continue;
+                String prefix = getPrefix(qname);
+
+                serializer.getNamespaceContext().declareNamespace(
+                    atts.getURI(i), prefix, true );
+            }
+            for( int i=0; i<prefixMap.size(); i+=2 ) {
+                String prefix = (String)prefixMap.get(i);
+                serializer.getNamespaceContext().declareNamespace(
+                    (String)prefixMap.get(i+1),
+                    prefix,
+                    prefix.length()!=0 );
+            }
+
+            serializer.endNamespaceDecls(null);
+            // fire attribute events
+            for( int i=0; i<len; i++ ) {
+                // be defensive.
+                if(atts.getQName(i).startsWith("xmlns"))
+                    continue;
+                serializer.attribute( atts.getURI(i), atts.getLocalName(i), atts.getValue(i));
+            }
+            prefixMap.clear();
+            serializer.endAttributes();
+        } catch (IOException e) {
+            throw new SAXException2(e);
+        } catch (XMLStreamException e) {
+            throw new SAXException2(e);
+        }
+    }
+
+    private String getPrefix(String qname) {
+        int idx = qname.indexOf(':');
+        String prefix = (idx==-1)?qname:qname.substring(0,idx);
+        return prefix;
+    }
+
+    public void endElement(String namespaceURI, String localName, String qName) throws SAXException {
+        try {
+            flushText();
+            serializer.endElement();
+        } catch (IOException e) {
+            throw new SAXException2(e);
+        } catch (XMLStreamException e) {
+            throw new SAXException2(e);
+        }
+    }
+
+    private void flushText() throws SAXException, IOException, XMLStreamException {
+        if( text.length()!=0 ) {
+            serializer.text(text.toString(),null);
+            text.setLength(0);
+        }
+    }
+
+    public void characters(char[] ch, int start, int length) {
+        text.append(ch,start,length);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Coordinator.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Coordinator.java
new file mode 100644
index 0000000..ebdc76b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Coordinator.java
@@ -0,0 +1,208 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.util.HashMap;
+
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.ValidationEventLocator;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.helpers.ValidationEventImpl;
+
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Object that coordinates the marshalling/unmarshalling.
+ *
+ * <p>
+ * This class takes care of the logic that allows code to obtain
+ * {@link UnmarshallingContext} and {@link XMLSerializer} instances
+ * during the unmarshalling/marshalling.
+ *
+ * <p>
+ * This is done by using a {@link ThreadLocal}. Therefore one unmarshalling/marshalling
+ * episode has to be done from the beginning till end by the same thread.
+ * (Note that the same {@link Coordinator} can be then used by a different thread
+ * for an entirely different episode.)
+ *
+ * This class also maintains the user-configured instances of {@link XmlAdapter}s.
+ *
+ * <p>
+ * This class implements {@link ErrorHandler} and propages erros to this object
+ * as the {@link ValidationEventHandler}, which will be implemented in a derived class.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Coordinator implements ErrorHandler, ValidationEventHandler {
+
+    private final HashMap<Class<? extends XmlAdapter>,XmlAdapter> adapters =
+            new HashMap<Class<? extends XmlAdapter>,XmlAdapter>();
+
+
+    public final XmlAdapter putAdapter(Class<? extends XmlAdapter> c, XmlAdapter a) {
+        if(a==null)
+            return adapters.remove(c);
+        else
+            return adapters.put(c,a);
+    }
+
+    /**
+     * Gets the instance of the adapter.
+     *
+     * @return
+     *      always non-null.
+     */
+    public final <T extends XmlAdapter> T getAdapter(Class<T> key) {
+        T v = key.cast(adapters.get(key));
+        if(v==null) {
+            v = ClassFactory.create(key);
+            putAdapter(key,v);
+        }
+        return v;
+    }
+
+    public <T extends XmlAdapter> boolean containsAdapter(Class<T> type) {
+        return adapters.containsKey(type);
+    }
+
+    /**
+     * The {@link Coordinator} in charge before this {@link Coordinator}.
+     */
+    private Coordinator old;
+
+    /**
+     * A 'pointer' to a {@link Coordinator} that keeps track of the currently active {@link Coordinator}.
+     * Having this improves the runtime performance.
+     */
+    private Coordinator[] table;
+
+    /**
+     * When we set {@link #table} to null, record who did it.
+     * This is for trouble-shooting a possible concurrency issue reported at:
+     * http://forums.java.net/jive/thread.jspa?threadID=15132
+     */
+    public Exception guyWhoSetTheTableToNull;
+
+    /**
+     * Associates this {@link Coordinator} with the current thread.
+     * Should be called at the very beginning of the episode.
+     */
+    protected final void setThreadAffinity() {
+        table = activeTable.get();
+        assert table!=null;
+    }
+
+    /**
+     * Dis-associate this {@link Coordinator} with the current thread.
+     * Sohuld be called at the end of the episode to avoid memory leak.
+     */
+    protected final void resetThreadAffinity() {
+        guyWhoSetTheTableToNull = new Exception(); // remember that we set it to null
+        table = null;
+    }
+
+    /**
+     * Called whenever an execution flow enters the realm of this {@link Coordinator}.
+     */
+    protected final void pushCoordinator() {
+        old = table[0];
+        table[0] = this;
+    }
+
+    /**
+     * Called whenever an execution flow exits the realm of this {@link Coordinator}.
+     */
+    protected final void popCoordinator() {
+        assert table[0]==this;
+        table[0] = old;
+        old = null; // avoid memory leak
+    }
+
+    public static Coordinator _getInstance() {
+        return activeTable.get()[0];
+    }
+
+    // this much is necessary to avoid calling get and set twice when we push.
+    private static final ThreadLocal<Coordinator[]> activeTable = new ThreadLocal<Coordinator[]>() {
+        public Coordinator[] initialValue() {
+            return new Coordinator[1];
+        }
+    };
+
+
+//
+//
+// ErrorHandler implementation
+//
+//
+    /**
+     * Gets the current location. Used for reporting the error source location.
+     */
+    protected abstract ValidationEventLocator getLocation();
+
+    public final void error(SAXParseException exception) throws SAXException {
+        propagateEvent( ValidationEvent.ERROR, exception );
+    }
+
+    public final void warning(SAXParseException exception) throws SAXException {
+        propagateEvent( ValidationEvent.WARNING, exception );
+    }
+
+    public final void fatalError(SAXParseException exception) throws SAXException {
+        propagateEvent( ValidationEvent.FATAL_ERROR, exception );
+    }
+
+    private void propagateEvent( int severity, SAXParseException saxException )
+        throws SAXException {
+
+        ValidationEventImpl ve =
+            new ValidationEventImpl( severity, saxException.getMessage(), getLocation() );
+
+        Exception e = saxException.getException();
+        if( e != null ) {
+            ve.setLinkedException( e );
+        } else {
+            ve.setLinkedException( saxException );
+        }
+
+        // call the client's event handler.  If it returns false, then bail-out
+        // and terminate the unmarshal operation.
+        boolean result = handleEvent( ve );
+        if( ! result ) {
+            // bail-out of the parse with a SAX exception, but convert it into
+            // an UnmarshalException back in in the AbstractUnmarshaller
+            throw saxException;
+        }
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/DomPostInitAction.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/DomPostInitAction.java
new file mode 100644
index 0000000..5602da5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/DomPostInitAction.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import javax.xml.XMLConstants;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+
+/**
+ * Post-init action for {@link MarshallerImpl} that incorporate the in-scope namespace bindings
+ * from a DOM node.
+ *
+ * TODO: do we really need this? think about a better way to put this logic back into marshaller.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class DomPostInitAction implements Runnable {
+
+    private final Node node;
+    private final XMLSerializer serializer;
+
+    DomPostInitAction(Node node, XMLSerializer serializer) {
+        this.node = node;
+        this.serializer = serializer;
+    }
+
+    // declare the currently in-scope namespace bindings
+    public void run() {
+        Set<String> declaredPrefixes = new HashSet<String>();
+        for( Node n=node; n!=null && n.getNodeType()==Node.ELEMENT_NODE; n=n.getParentNode() ) {
+            NamedNodeMap atts = n.getAttributes();
+            if(atts==null)      continue; // broken DOM. but be graceful.
+            for( int i=0; i<atts.getLength(); i++ ) {
+                Attr a = (Attr)atts.item(i);
+                String nsUri = a.getNamespaceURI();
+                if(nsUri==null || !nsUri.equals(XMLConstants.XMLNS_ATTRIBUTE_NS_URI))
+                    continue;   // not a namespace declaration
+                String prefix = a.getLocalName();
+                if(prefix==null)
+                    continue;   // broken DOM. skip to be safe
+                if(prefix.equals("xmlns")) {
+                    prefix = "";
+                }
+                String value = a.getValue();
+                if(value==null)
+                    continue;   // broken DOM. skip to be safe
+                if(declaredPrefixes.add(prefix)) {
+                    serializer.addInscopeBinding(value,prefix);
+                }
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ElementBeanInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ElementBeanInfoImpl.java
new file mode 100644
index 0000000..04967bd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ElementBeanInfoImpl.java
@@ -0,0 +1,300 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.JAXBException;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementInfo;
+import com.sun.xml.internal.bind.v2.runtime.property.Property;
+import com.sun.xml.internal.bind.v2.runtime.property.PropertyFactory;
+import com.sun.xml.internal.bind.v2.runtime.property.UnmarshallerChain;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Discarder;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Intercepter;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.TagName;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link JaxBeanInfo} implementation for {@link RuntimeElementInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ElementBeanInfoImpl extends JaxBeanInfo<JAXBElement> {
+
+    private Loader loader;
+
+    private final Property property;
+
+    // used to create new instances of JAXBElement.
+    private final QName tagName;
+    public final Class expectedType;
+    private final Class scope;
+
+    ElementBeanInfoImpl(JAXBContextImpl grammar, RuntimeElementInfo rei) {
+        super(grammar,rei,(Class<JAXBElement>)rei.getType(),true,false,true);
+
+        this.property = PropertyFactory.create(grammar,rei.getProperty());
+
+        tagName = rei.getElementName();
+        expectedType = Navigator.REFLECTION.erasure(rei.getContentInMemoryType());
+        scope = rei.getScope()==null ? JAXBElement.GlobalScope.class : rei.getScope().getClazz();
+    }
+
+    /**
+     * The constructor for the sole instanceof {@link JaxBeanInfo} for
+     * handling user-created {@link JAXBElement}.
+     *
+     * Such {@link JaxBeanInfo} is used only for marshalling.
+     *
+     * This is a hack.
+     */
+    protected ElementBeanInfoImpl(final JAXBContextImpl grammar) {
+        super(grammar,null,JAXBElement.class,true,false,true);
+        tagName = null;
+        expectedType = null;
+        scope = null;
+
+        this.property = new Property<JAXBElement>() {
+            public void reset(JAXBElement o) {
+                throw new UnsupportedOperationException();
+            }
+
+            public void serializeBody(JAXBElement e, XMLSerializer target, Object outerPeer) throws SAXException, IOException, XMLStreamException {
+                Class scope = e.getScope();
+                if(e.isGlobalScope())   scope = null;
+                QName n = e.getName();
+                ElementBeanInfoImpl bi = grammar.getElement(scope,n);
+                if(bi==null) {
+                    // infer what to do from the type
+                    JaxBeanInfo tbi;
+                    try {
+                        tbi = grammar.getBeanInfo(e.getDeclaredType(),true);
+                    } catch (JAXBException x) {
+                        // if e.getDeclaredType() isn't known to this JAXBContext
+                        target.reportError(null,x);
+                        return;
+                    }
+                    Object value = e.getValue();
+                    target.startElement(n.getNamespaceURI(),n.getLocalPart(),n.getPrefix(),null);
+                    if(value==null) {
+                        target.writeXsiNilTrue();
+                    } else {
+                        target.childAsXsiType(value,"value",tbi);
+                    }
+                    target.endElement();
+                } else {
+                    try {
+                        bi.property.serializeBody(e,target,e);
+                    } catch (AccessorException x) {
+                        target.reportError(null,x);
+                    }
+                }
+            }
+
+            public void serializeURIs(JAXBElement o, XMLSerializer target) {
+            }
+
+            public boolean hasSerializeURIAction() {
+                return false;
+            }
+
+            public String getIdValue(JAXBElement o) {
+                return null;
+            }
+
+            public PropertyKind getKind() {
+                return PropertyKind.ELEMENT;
+            }
+
+            public void buildChildElementUnmarshallers(UnmarshallerChain chain, QNameMap<ChildLoader> handlers) {
+            }
+
+            public Accessor getElementPropertyAccessor(String nsUri, String localName) {
+                throw new UnsupportedOperationException();
+            }
+
+            public void wrapUp() {
+            }
+        };
+    }
+
+    /**
+     * Use the previous {@link UnmarshallingContext.State}'s target to store
+     * {@link JAXBElement} object to be unmarshalled. This allows the property {@link Loader}
+     * to correctly find the parent object.
+     * This is a hack.
+     */
+    private final class IntercepterLoader extends Loader implements Intercepter {
+        private final Loader core;
+
+        public IntercepterLoader(Loader core) {
+            this.core = core;
+        }
+
+        public final void startElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+            state.loader = core;
+            state.intercepter = this;
+
+            // TODO: make sure there aren't too many duplicate of this code
+            // create the object to unmarshal
+            Object child;
+            UnmarshallingContext context = state.getContext();
+
+            // let's see if we can reuse the existing peer object
+            child = context.getOuterPeer();
+
+            if(child!=null && jaxbType!=child.getClass())
+                child = null;   // unexpected type.
+
+            if(child!=null)
+                reset((JAXBElement)child,context);
+
+            if(child==null)
+                child = context.createInstance(ElementBeanInfoImpl.this);
+
+            fireBeforeUnmarshal(ElementBeanInfoImpl.this, child, state);
+
+            context.recordOuterPeer(child);
+            UnmarshallingContext.State p = state.prev;
+            p.backup = p.target;
+            p.target = child;
+
+            core.startElement(state,ea);
+        }
+
+        public Object intercept(UnmarshallingContext.State state, Object o) throws SAXException {
+            JAXBElement e = (JAXBElement)state.target;
+            state.target = state.backup;
+            state.backup = null;
+
+            if(o!=null)
+                // if the value is a leaf type, it's often already set to the element
+                // through Accessor.
+                e.setValue(o);
+
+            fireAfterUnmarshal(ElementBeanInfoImpl.this, e, state);
+
+            return e;
+        }
+    }
+
+    public String getElementNamespaceURI(JAXBElement e) {
+        return e.getName().getNamespaceURI();
+    }
+
+    public String getElementLocalName(JAXBElement e) {
+        return e.getName().getLocalPart();
+    }
+
+    public Loader getLoader(JAXBContextImpl context, boolean typeSubstitutionCapable) {
+        if(loader==null) {
+            // this has to be done lazily to avoid cyclic reference issue
+            UnmarshallerChain c = new UnmarshallerChain(context);
+            QNameMap<ChildLoader> result = new QNameMap<ChildLoader>();
+            property.buildChildElementUnmarshallers(c,result);
+            if(result.size()==1)
+                // for ElementBeanInfoImpl created from RuntimeElementInfo
+                this.loader = new IntercepterLoader(result.getOne().getValue().loader);
+            else
+                // for special ElementBeanInfoImpl only used for marshalling
+                this.loader = Discarder.INSTANCE;
+        }
+        return loader;
+    }
+
+    public final JAXBElement createInstance(UnmarshallingContext context) {
+        return createInstanceFromValue(null);
+    }
+
+    public final JAXBElement createInstanceFromValue(Object o) {
+        return new JAXBElement(tagName,expectedType,scope,o);
+    }
+
+    public boolean reset(JAXBElement e, UnmarshallingContext context) {
+        e.setValue(null);
+        return true;
+    }
+
+    public String getId(JAXBElement e, XMLSerializer target) {
+        // TODO: is this OK? Should we be returning the ID value of the type property?
+        /*
+            There's one case where we JAXBElement needs to be designated as ID,
+            and that is when there's a global element whose type is ID.
+        */
+        Object o = e.getValue();
+        if(o instanceof String)
+            return (String)o;
+        else
+            return null;
+    }
+
+    public void serializeBody(JAXBElement element, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        try {
+            property.serializeBody(element,target,null);
+        } catch (AccessorException x) {
+            target.reportError(null,x);
+        }
+    }
+
+    public void serializeRoot(JAXBElement e, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        serializeBody(e,target);
+    }
+
+    public void serializeAttributes(JAXBElement e, XMLSerializer target) {
+        // noop
+    }
+
+    public void serializeURIs(JAXBElement e, XMLSerializer target) {
+        // noop
+    }
+
+    public final Transducer<JAXBElement> getTransducer() {
+        return null;
+    }
+
+    public void wrapUp() {
+        super.wrapUp();
+        property.wrapUp();
+    }
+
+    public void link(JAXBContextImpl grammar) {
+        super.link(grammar);
+        getLoader(grammar,true);    // make sure to build them, if we hadn't done so
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/FilterTransducer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/FilterTransducer.java
new file mode 100644
index 0000000..a85fbaf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/FilterTransducer.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.xml.internal.bind.api.AccessorException;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Transducer} that delegates to another {@link Transducer}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class FilterTransducer<T> implements Transducer<T> {
+    protected final Transducer<T> core;
+
+    protected FilterTransducer(Transducer<T> core) {
+        this.core = core;
+    }
+
+    public final boolean isDefault() {
+        // this must be used as a decorating transducer,
+        // so it may never be default.
+        return false;
+    }
+
+    public boolean useNamespace() {
+        return core.useNamespace();
+    }
+
+    public void declareNamespace(T o, XMLSerializer w) throws AccessorException {
+        core.declareNamespace(o, w);
+    }
+
+    public @NotNull CharSequence print(@NotNull T o) throws AccessorException {
+        return core.print(o);
+    }
+
+    public T parse(CharSequence lexical) throws AccessorException, SAXException {
+        return core.parse(lexical);
+    }
+
+    public void writeText(XMLSerializer w, T o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        core.writeText(w, o, fieldName);
+    }
+
+    public void writeLeafElement(XMLSerializer w, Name tagName, T o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        core.writeLeafElement(w,tagName,o,fieldName);
+    }
+
+    public QName getTypeName(T instance) {
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/IllegalAnnotationException.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/IllegalAnnotationException.java
new file mode 100644
index 0000000..34030d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/IllegalAnnotationException.java
@@ -0,0 +1,187 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.lang.annotation.Annotation;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+
+import com.sun.xml.internal.bind.v2.model.annotation.Locatable;
+
+/**
+ * Signals an incorrect use of JAXB annotations.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ * @since JAXB 2.0 EA1
+ */
+public class IllegalAnnotationException extends JAXBException {
+
+    /**
+     * Read-only list of {@link Location}s.
+     */
+    private final List<List<Location>> pos;
+
+    private static final long serialVersionUID = 1L;
+
+    public IllegalAnnotationException(String message, Locatable src) {
+        super(message);
+        pos = build(src);
+    }
+
+    public IllegalAnnotationException(String message, Annotation src) {
+        this(message,cast(src));
+    }
+
+    public IllegalAnnotationException(String message, Locatable src1, Locatable src2) {
+        super(message);
+        pos = build(src1,src2);
+    }
+
+    public IllegalAnnotationException(String message, Annotation src1, Annotation src2) {
+        this(message,cast(src1),cast(src2));
+    }
+
+    public IllegalAnnotationException(String message, Annotation src1, Locatable src2) {
+        this(message,cast(src1),src2);
+    }
+
+    public IllegalAnnotationException(String message, Throwable cause, Locatable src) {
+        super(message, cause);
+        pos = build(src);
+    }
+
+    private static Locatable cast(Annotation a) {
+        if(a instanceof Locatable)
+            return (Locatable)a;
+        else
+            return null;
+    }
+
+    private List<List<Location>> build(Locatable... srcs) {
+        List<List<Location>> r = new ArrayList<List<Location>>();
+        for( Locatable l : srcs ) {
+            if(l!=null) {
+                List<Location> ll = convert(l);
+                if(ll!=null && !ll.isEmpty())
+                    r.add(ll);
+            }
+        }
+        return Collections.unmodifiableList(r);
+    }
+
+    /**
+     * Builds a list of {@link Location}s out of a {@link Locatable}.
+     */
+    private List<Location> convert(Locatable src) {
+        if(src==null)   return null;
+
+        List<Location> r = new ArrayList<Location>();
+        for( ; src!=null; src=src.getUpstream())
+            r.add(src.getLocation());
+        return Collections.unmodifiableList(r);
+    }
+
+
+
+    /**
+     * Returns a read-only list of {@link Location} that indicates
+     * where in the source code the problem has happened.
+     *
+     * <p>
+     * Normally, an annotation error happens on one particular
+     * annotation, in which case this method returns a list that
+     * contains another list, which in turn contains the location
+     * information that leads to the error location
+     * (IOW, <tt>[ [pos1,pos2,...,posN] ]</tt>)
+     *
+     * <p>
+     * Sometimes, an error could occur because of two or more conflicting
+     * annotations, in which case this method returns a list
+     * that contains many lists, where each list contains
+     * the location information that leads to each of the conflicting
+     * annotations
+     * (IOW, <tt>[ [pos11,pos12,...,pos1N],[pos21,pos22,...,pos2M], ... ]</tt>)
+     *
+     * <p>
+     * Yet some other time, the runtime can fail to provide any
+     * error location, in which case this method returns an empty list.
+     * (IOW, <tt>[]</tt>). We do try hard to make sure this won't happen,
+     * so please <a href="http://jaxb.dev.java.net/">let us know</a>
+     * if you see this behavior.
+     *
+     *
+     * <h3>List of {@link Location}</h3>
+     * <p>
+     * Each error location is identified not just by one {@link Location}
+     * object, but by a sequence of {@link Location}s that shows why
+     * the runtime is led to the place of the error.
+     * This list is sorted such that the most specific {@link Location} comes
+     * to the first in the list, sort of like a stack trace.
+     *
+     * <p>
+     * For example, suppose you specify class <tt>Foo</tt> to {@link JAXBContext},
+     * <tt>Foo</tt> derives from <tt>Bar</tt>, <tt>Bar</tt> has a field <tt>pea</tt>
+     * that points to <tt>Zot</tt>, <tt>Zot</tt> contains a <tt>gum</tt>
+     * property, and this property has an errornous annotation.
+     * Then when this exception is thrown, the list of {@link Location}s
+     * will look something like
+     * <tt>[ "gum property", "Zot class", "pea property", "Bar class", "Foo class" ]</tt>
+     *
+     *
+     * @return
+     *      can be empty when no source position is available,
+     *      but never null. The returned list will never contain
+     *      null nor length-0 {@link List}.
+     */
+    public List<List<Location>> getSourcePos() {
+        return pos;
+    }
+
+    /**
+     * Returns the exception name, message, and related information
+     * together in one string.
+     *
+     * <p>
+     * Overriding this method (instead of {@link #printStackTrace} allows
+     * this crucial detail to show up even when this exception is nested
+     * inside other exceptions.
+     */
+    public String toString() {
+        StringBuilder sb = new StringBuilder(getMessage());
+
+        for( List<Location> locs : pos ) {
+            sb.append("\n\tthis problem is related to the following location:");
+            for( Location loc : locs )
+                sb.append("\n\t\tat ").append(loc.toString());
+        }
+
+        return sb.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/IllegalAnnotationsException.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/IllegalAnnotationsException.java
new file mode 100644
index 0000000..0f63671
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/IllegalAnnotationsException.java
@@ -0,0 +1,94 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+
+import com.sun.xml.internal.bind.v2.model.core.ErrorHandler;
+
+/**
+ * A list of {@link IllegalAnnotationException} wrapped in one exception.
+ *
+ * <p>
+ * This exception is used to report all the errors to the client application
+ * through {@link JAXBContext#newInstance}.
+ *
+ * @since JAXB 2.0 EA1
+ * @author Kohsuke Kawaguchi
+ */
+public class IllegalAnnotationsException extends JAXBException {
+    private final List<IllegalAnnotationException> errors;
+
+    private static final long serialVersionUID = 1L;
+
+    public IllegalAnnotationsException(List<IllegalAnnotationException> errors) {
+        super(errors.size()+" counts of IllegalAnnotationExceptions");
+        assert !errors.isEmpty() : "there must be at least one error";
+        this.errors = Collections.unmodifiableList(new ArrayList<IllegalAnnotationException>(errors));
+    }
+
+    public String toString() {
+        StringBuilder sb = new StringBuilder(super.toString());
+        sb.append('\n');
+
+        for( IllegalAnnotationException error : errors )
+            sb.append(error.toString()).append('\n');
+
+        return sb.toString();
+    }
+
+    /**
+     * Returns a read-only list of {@link IllegalAnnotationException}s
+     * wrapped in this exception.
+     *
+     * @return
+     *      a non-null list.
+     */
+    public List<IllegalAnnotationException> getErrors() {
+        return errors;
+    }
+
+    public static class Builder implements ErrorHandler {
+        private final List<IllegalAnnotationException> list = new ArrayList<IllegalAnnotationException>();
+        public void error(IllegalAnnotationException e) {
+            list.add(e);
+        }
+        /**
+         * If an error was reported, throw the exception.
+         * Otherwise exit normally.
+         */
+        public void check() throws IllegalAnnotationsException {
+            if(list.isEmpty())
+                return;
+            throw new IllegalAnnotationsException(list);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/InlineBinaryTransducer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/InlineBinaryTransducer.java
new file mode 100644
index 0000000..36e7a0e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/InlineBinaryTransducer.java
@@ -0,0 +1,77 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.xml.internal.bind.api.AccessorException;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Transducer that signals the runtime that this binary data shall be always inlined.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class InlineBinaryTransducer<V> extends FilterTransducer<V> {
+    public InlineBinaryTransducer(Transducer<V> core) {
+        super(core);
+    }
+
+    @Override
+    public @NotNull CharSequence print(@NotNull V o) throws AccessorException {
+        XMLSerializer w = XMLSerializer.getInstance();
+        boolean old = w.setInlineBinaryFlag(true);
+        try {
+            return core.print(o);
+        } finally {
+            w.setInlineBinaryFlag(old);
+        }
+    }
+
+    @Override
+    public void writeText(XMLSerializer w, V o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        boolean old = w.setInlineBinaryFlag(true);
+        try {
+            core.writeText(w,o,fieldName);
+        } finally {
+            w.setInlineBinaryFlag(old);
+        }
+    }
+
+    @Override
+    public void writeLeafElement(XMLSerializer w, Name tagName, V o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        boolean old = w.setInlineBinaryFlag(true);
+        try {
+            core.writeLeafElement(w, tagName, o, fieldName);
+        } finally {
+            w.setInlineBinaryFlag(old);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/InternalBridge.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/InternalBridge.java
new file mode 100644
index 0000000..415ea5e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/InternalBridge.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.Bridge;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Additional methods on {@link Bridge} that are only available for the JAXB runtime.
+ * @author Kohsuke Kawaguchi
+ */
+abstract class InternalBridge<T> extends Bridge<T> {
+    protected InternalBridge(JAXBContextImpl context) {
+        super(context);
+    }
+
+    public JAXBContextImpl getContext() {
+        return context;
+    }
+
+    /**
+     * Called from {@link CompositeStructureBeanInfo} to marshal this bridge as a sub-tree.
+     */
+    abstract void marshal( T o, XMLSerializer out ) throws IOException, SAXException, XMLStreamException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/JAXBContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/JAXBContextImpl.java
new file mode 100644
index 0000000..35b340b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/JAXBContextImpl.java
@@ -0,0 +1,885 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.lang.ref.WeakReference;
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Type;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.LinkedHashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeSet;
+
+import javax.xml.bind.Binder;
+import javax.xml.bind.DatatypeConverter;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.JAXBIntrospector;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.Validator;
+import javax.xml.bind.annotation.XmlAttachmentRef;
+import javax.xml.bind.annotation.XmlList;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.namespace.QName;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.FactoryConfigurationError;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.transform.Result;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerConfigurationException;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.sax.SAXResult;
+import javax.xml.transform.sax.SAXTransformerFactory;
+import javax.xml.transform.sax.TransformerHandler;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.istack.internal.Pool;
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.api.Bridge;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.bind.api.CompositeStructure;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.bind.api.RawAccessor;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.bind.unmarshaller.DOMScanner;
+import com.sun.xml.internal.bind.util.Which;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.model.annotation.RuntimeInlineAnnotationReader;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.Ref;
+import com.sun.xml.internal.bind.v2.model.impl.RuntimeBuiltinLeafInfoImpl;
+import com.sun.xml.internal.bind.v2.model.impl.RuntimeModelBuilder;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.model.nav.ReflectionNavigator;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeArrayInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeBuiltinLeafInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeClassInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeEnumLeafInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeLeafInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfoSet;
+import com.sun.xml.internal.bind.v2.runtime.output.Encoded;
+import com.sun.xml.internal.bind.v2.runtime.property.AttributeProperty;
+import com.sun.xml.internal.bind.v2.runtime.property.Property;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.TagName;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.schemagen.XmlSchemaGenerator;
+import com.sun.xml.internal.bind.v2.util.EditDistance;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.DefaultHandler;
+
+/**
+ * This class provides the implementation of JAXBContext.
+ *
+ */
+public final class JAXBContextImpl extends JAXBRIContext {
+
+    /**
+     * All the bridge classes.
+     */
+    private final Map<TypeReference,Bridge> bridges = new LinkedHashMap<TypeReference,Bridge>();
+
+    /**
+     * Shared instance of {@link TransformerFactory}.
+     * Lock before use, because a {@link TransformerFactory} is not thread-safe
+     * whereas {@link JAXBContextImpl} is.
+     * Lazily created.
+     */
+    private static SAXTransformerFactory tf;
+
+    /**
+     * Shared instance of {@link DocumentBuilder}.
+     * Lock before use. Lazily created.
+     */
+    private static DocumentBuilder db;
+
+    private final QNameMap<JaxBeanInfo> rootMap = new QNameMap<JaxBeanInfo>();
+    private final HashMap<QName,JaxBeanInfo> typeMap = new HashMap<QName,JaxBeanInfo>();
+
+    /**
+     * Map from JAXB-bound {@link Class} to its {@link JaxBeanInfo}.
+     */
+    private final Map<Class,JaxBeanInfo> beanInfoMap = new LinkedHashMap<Class,JaxBeanInfo>();
+
+    /**
+     * All created {@link JaxBeanInfo}s.
+     * Updated from each {@link JaxBeanInfo}s constructors to avoid infinite recursion
+     * for a cyclic reference.
+     *
+     * <p>
+     * This map is only used while the {@link JAXBContextImpl} is built and set to null
+     * to avoid keeping references too long.
+     */
+    protected Map<RuntimeTypeInfo,JaxBeanInfo> beanInfos = new LinkedHashMap<RuntimeTypeInfo, JaxBeanInfo>();
+
+    private final Map<Class/*scope*/,Map<QName,ElementBeanInfoImpl>> elements = new LinkedHashMap<Class, Map<QName, ElementBeanInfoImpl>>();
+
+    /**
+     * Pool of {@link Marshaller}s.
+     */
+    public final Pool<Marshaller> marshallerPool = new Pool.Impl<Marshaller>() {
+        protected @NotNull Marshaller create() {
+            return createMarshaller();
+        }
+    };
+
+    public final Pool<Unmarshaller> unmarshallerPool = new Pool.Impl<Unmarshaller>() {
+        protected @NotNull Unmarshaller create() {
+            return createUnmarshaller();
+        }
+    };
+
+    /**
+     * Used to assign indices to known names in this grammar.
+     * Reset to null once the build phase is completed.
+     */
+    public NameBuilder nameBuilder = new NameBuilder();
+
+    /**
+     * Keeps the list of known names.
+     * This field is set once the build pahse is completed.
+     */
+    public final NameList nameList;
+
+    /**
+     * Input to the JAXBContext.newInstance, so that we can recreate
+     * {@link RuntimeTypeInfoSet} whenever we need.
+     */
+    private final String defaultNsUri;
+    private final Class[] classes;
+
+    /**
+     * true to reorder attributes lexicographically in preparation of the c14n support.
+     */
+    protected final boolean c14nSupport;
+
+    private WeakReference<RuntimeTypeInfoSet> typeInfoSetCache;
+
+    /**
+     *
+     * @param typeRefs
+     *      used to build {@link Bridge}s. Can be empty.
+     * @param c14nSupport
+     *      {@link #c14nSupport}.
+     */
+    public JAXBContextImpl(Class[] classes, Collection<TypeReference> typeRefs, String defaultNsUri, boolean c14nSupport) throws JAXBException {
+
+        // initialize datatype converter with ours
+        DatatypeConverter.setDatatypeConverter(DatatypeConverterImpl.theInstance);
+
+        if(defaultNsUri==null)      defaultNsUri="";    // fool-proof
+
+        this.defaultNsUri = defaultNsUri;
+        this.c14nSupport = c14nSupport;
+        this.classes = new Class[classes.length];
+        System.arraycopy(classes,0,this.classes,0,classes.length);
+
+        RuntimeTypeInfoSet typeSet = getTypeInfoSet();
+
+
+        // at least prepare the empty table so that we don't have to check for null later
+        elements.put(null,new LinkedHashMap<QName, ElementBeanInfoImpl>());
+
+        // recognize leaf bean infos
+        for( RuntimeBuiltinLeafInfo leaf : RuntimeBuiltinLeafInfoImpl.builtinBeanInfos ) {
+            LeafBeanInfoImpl<?> bi = new LeafBeanInfoImpl(this,leaf);
+            beanInfoMap.put(leaf.getClazz(),bi);
+            for( QName t : bi.getTypeNames() )
+                typeMap.put(t,bi);
+        }
+
+        for (RuntimeEnumLeafInfo e : typeSet.enums().values()) {
+            JaxBeanInfo<?> bi = getOrCreate(e);
+            for (QName qn : bi.getTypeNames())
+                typeMap.put( qn, bi );
+            if(e.isElement())
+                rootMap.put( e.getElementName(), bi );
+        }
+
+        for (RuntimeArrayInfo a : typeSet.arrays().values()) {
+            JaxBeanInfo<?> ai = getOrCreate(a);
+            for (QName qn : ai.getTypeNames())
+                typeMap.put( qn, ai );
+        }
+
+        for( RuntimeClassInfo ci : typeSet.beans().values() ) {
+            ClassBeanInfoImpl<?> bi = getOrCreate(ci);
+
+            if(bi.isElement())
+                rootMap.put( ci.getElementName(), bi );
+
+            for (QName qn : bi.getTypeNames())
+                typeMap.put( qn, bi );
+        }
+
+        // fill in element mappings
+        for( RuntimeElementInfo n : typeSet.getAllElements() ) {
+            ElementBeanInfoImpl bi = getOrCreate(n);
+            if(n.getScope()==null)
+                rootMap.put(n.getElementName(),bi);
+
+            RuntimeClassInfo scope = n.getScope();
+            Class scopeClazz = scope==null?null:scope.getClazz();
+            Map<QName,ElementBeanInfoImpl> m = elements.get(scopeClazz);
+            if(m==null) {
+                m = new LinkedHashMap<QName, ElementBeanInfoImpl>();
+                elements.put(scopeClazz,m);
+            }
+            m.put(n.getElementName(),bi);
+        }
+
+        // this one is so that we can handle plain JAXBElements.
+        beanInfoMap.put(JAXBElement.class,new ElementBeanInfoImpl(this));
+        // another special BeanInfoImpl just for marshalling
+        beanInfoMap.put(CompositeStructure.class,new CompositeStructureBeanInfo(this));
+
+        getOrCreate(typeSet.getAnyTypeInfo());
+
+        // then link them all!
+        for (JaxBeanInfo bi : beanInfos.values())
+            bi.link(this);
+
+        // register primitives for boxed types just to make GrammarInfo fool-proof
+        for( Map.Entry<Class,Class> e : RuntimeUtil.primitiveToBox.entrySet() )
+            beanInfoMap.put( e.getKey(), beanInfoMap.get(e.getValue()) );
+
+        // build bridges
+        ReflectionNavigator nav = typeSet.getNavigator();
+
+        for (TypeReference tr : typeRefs) {
+            XmlJavaTypeAdapter xjta = tr.get(XmlJavaTypeAdapter.class);
+            Adapter<Type,Class> a=null;
+            XmlList xl = tr.get(XmlList.class);
+
+            // eventually compute the in-memory type
+            Class erasedType = nav.erasure(tr.type);
+
+            if(xjta!=null) {
+                a = new Adapter<Type,Class>(xjta.value(),nav);
+            }
+            if(tr.get(XmlAttachmentRef.class)!=null) {
+                a = new Adapter<Type,Class>(SwaRefAdapter.class,nav);
+            }
+
+            if(a!=null) {
+                erasedType = nav.erasure(a.defaultType);
+            }
+
+            Name name = nameBuilder.createElementName(tr.tagName);
+
+            InternalBridge bridge;
+            if(xl==null)
+                bridge = new BridgeImpl(this, name,getBeanInfo(erasedType,true),tr);
+            else
+                bridge = new BridgeImpl(this, name,new ValueListBeanInfoImpl(this,erasedType),tr);
+
+            if(a!=null)
+                bridge = new BridgeAdapter(bridge,a.adapterType);
+
+            bridges.put(tr,bridge);
+        }
+
+
+        this.nameList = nameBuilder.conclude();
+
+        for (JaxBeanInfo bi : beanInfos.values())
+            bi.wrapUp();
+
+        // no use for them now
+        nameBuilder = null;
+        beanInfos = null;
+    }
+
+    /**
+     * Creates a {@link RuntimeTypeInfoSet}.
+     */
+    private RuntimeTypeInfoSet getTypeInfoSet() throws IllegalAnnotationsException {
+
+        // check cache
+        if(typeInfoSetCache!=null) {
+            RuntimeTypeInfoSet r = typeInfoSetCache.get();
+            if(r!=null)
+                return r;
+        }
+
+        final RuntimeModelBuilder builder = new RuntimeModelBuilder(
+                new RuntimeInlineAnnotationReader(),
+                defaultNsUri);
+        IllegalAnnotationsException.Builder errorHandler = new IllegalAnnotationsException.Builder();
+        builder.setErrorHandler(errorHandler);
+
+        for( Class c : classes ) {
+            if(c==CompositeStructure.class)
+                // CompositeStructure doesn't have TypeInfo, so skip it.
+                // We'll add JaxBeanInfo for this later automatically
+                continue;
+            builder.getTypeInfo(new Ref<Type,Class>(c));
+        }
+
+        RuntimeTypeInfoSet r = builder.link();
+
+        errorHandler.check();
+        assert r!=null : "if no error was reported, the link must be a success";
+
+        typeInfoSetCache = new WeakReference<RuntimeTypeInfoSet>(r);
+
+        return r;
+    }
+
+
+    public ElementBeanInfoImpl getElement(Class scope, QName name) {
+        Map<QName,ElementBeanInfoImpl> m = elements.get(scope);
+        if(m!=null) {
+            ElementBeanInfoImpl bi = m.get(name);
+            if(bi!=null)
+                return bi;
+        }
+        m = elements.get(null);
+        return m.get(name);
+    }
+
+
+
+
+
+    private ElementBeanInfoImpl getOrCreate( RuntimeElementInfo rei ) {
+        JaxBeanInfo bi = beanInfos.get(rei);
+        if(bi!=null)    return (ElementBeanInfoImpl)bi;
+
+        // all elements share the same type, so we can't register them to beanInfoMap
+        return new ElementBeanInfoImpl(this, rei);
+    }
+
+    protected JaxBeanInfo getOrCreate( RuntimeEnumLeafInfo eli ) {
+        JaxBeanInfo bi = beanInfos.get(eli);
+        if(bi!=null)    return bi;
+        bi = new LeafBeanInfoImpl(this,eli);
+        beanInfoMap.put(bi.jaxbType,bi);
+        return bi;
+    }
+
+    protected ClassBeanInfoImpl getOrCreate( RuntimeClassInfo ci ) {
+        ClassBeanInfoImpl bi = (ClassBeanInfoImpl)beanInfos.get(ci);
+        if(bi!=null)    return bi;
+        bi = new ClassBeanInfoImpl(this,ci);
+        beanInfoMap.put(bi.jaxbType,bi);
+        return bi;
+    }
+
+    protected JaxBeanInfo getOrCreate( RuntimeArrayInfo ai ) {
+        JaxBeanInfo abi = beanInfos.get(ai.getType());
+        if(abi!=null)   return abi;
+
+        abi = new ArrayBeanInfoImpl(this,ai);
+
+        beanInfoMap.put(ai.getType(),abi);
+        return abi;
+    }
+
+    public JaxBeanInfo getOrCreate(RuntimeTypeInfo e) {
+        if(e instanceof RuntimeElementInfo)
+            return getOrCreate((RuntimeElementInfo)e);
+        if(e instanceof RuntimeClassInfo)
+            return getOrCreate((RuntimeClassInfo)e);
+        if(e instanceof RuntimeLeafInfo) {
+            JaxBeanInfo bi = beanInfos.get(e); // must have been created
+            assert bi!=null;
+            return bi;
+        }
+        if(e instanceof RuntimeArrayInfo)
+            return getOrCreate((RuntimeArrayInfo)e);
+        if(e.getType()==Object.class) {
+            // anyType
+            JaxBeanInfo bi = beanInfoMap.get(Object.class);
+            if(bi==null) {
+                bi = new AnyTypeBeanInfo(this,e);
+                beanInfoMap.put(Object.class,bi);
+            }
+            return bi;
+        }
+
+        throw new IllegalArgumentException();
+    }
+
+    /**
+     * Gets the {@link JaxBeanInfo} object that can handle
+     * the given JAXB-bound object.
+     *
+     * <p>
+     * This method traverses the base classes of the given object.
+     *
+     * @return null
+     *      if <tt>c</tt> isn't a JAXB-bound class and <tt>fatal==false</tt>.
+     */
+    public final JaxBeanInfo getBeanInfo(Object o) {
+        // don't allow xs:anyType beanInfo to handle all the unbound objects
+        for( Class c=o.getClass(); c!=Object.class; c=c.getSuperclass()) {
+            JaxBeanInfo bi = beanInfoMap.get(c);
+            if(bi!=null)    return bi;
+        }
+        if(o instanceof Element)
+            return beanInfoMap.get(Object.class);   // return the BeanInfo for xs:anyType
+        return null;
+    }
+
+    /**
+     * Gets the {@link JaxBeanInfo} object that can handle
+     * the given JAXB-bound object.
+     *
+     * @param fatal
+     *      if true, the failure to look up will throw an exception.
+     *      Otherwise it will just return null.
+     */
+    public final JaxBeanInfo getBeanInfo(Object o,boolean fatal) throws JAXBException {
+        JaxBeanInfo bi = getBeanInfo(o);
+        if(bi!=null)    return bi;
+        if(fatal)
+            throw new JAXBException(o.getClass().getName()+" nor any of its super class is known to this context");
+        return null;
+    }
+
+    /**
+     * Gets the {@link JaxBeanInfo} object that can handle
+     * the given JAXB-bound class.
+     *
+     * <p>
+     * This method doesn't look for base classes.
+     *
+     * @return null
+     *      if <tt>c</tt> isn't a JAXB-bound class and <tt>fatal==false</tt>.
+     */
+    public final <T> JaxBeanInfo<T> getBeanInfo(Class<T> clazz) {
+        return (JaxBeanInfo<T>)beanInfoMap.get(clazz);
+    }
+
+    /**
+     * Gets the {@link JaxBeanInfo} object that can handle
+     * the given JAXB-bound class.
+     *
+     * @param fatal
+     *      if true, the failure to look up will throw an exception.
+     *      Otherwise it will just return null.
+     */
+    public final <T> JaxBeanInfo<T> getBeanInfo(Class<T> clazz,boolean fatal) throws JAXBException {
+        JaxBeanInfo<T> bi = getBeanInfo(clazz);
+        if(bi!=null)    return bi;
+        if(fatal)
+            throw new JAXBException(clazz.getName()+" is not known to this context");
+        return null;
+    }
+
+    /**
+     * Based on the tag name, determine what object to unmarshal,
+     * and then set a new object and its loader to the current unmarshaller state.
+     *
+     * @return
+     *      null if the given name pair is not recognized.
+     */
+    public final Loader selectRootLoader( UnmarshallingContext.State state, TagName ea ) {
+        JaxBeanInfo beanInfo = rootMap.get(ea.uri,ea.local);
+        if(beanInfo==null)
+            // TODO: this is probably the right place to handle @xsi:type
+            return null;
+
+        return beanInfo.getLoader(this,true);
+    }
+
+    /**
+     * Gets the {@link JaxBeanInfo} for the given named XML Schema type.
+     *
+     * @return
+     *      null if the type name is not recognized. For schema
+     *      languages other than XML Schema, this method always
+     *      returns null.
+     */
+    public JaxBeanInfo getGlobalType(QName name) {
+        return typeMap.get(name);
+    }
+
+    /**
+     * Finds a type name that this context recognizes which is
+     * "closest" to the given type name.
+     *
+     * <p>
+     * This method is used for error recovery.
+     */
+    public String getNearestTypeName(QName name) {
+        String[] all = new String[typeMap.size()];
+        int i=0;
+        for (QName qn : typeMap.keySet()) {
+            if(qn.getLocalPart().equals(name.getLocalPart()))
+                return qn.toString();  // probably a match, as people often gets confused about namespace.
+            all[i++] = qn.toString();
+        }
+
+        String nearest = EditDistance.findNearest(name.toString(), all);
+
+        if(EditDistance.editDistance(nearest,name.toString())>10)
+            return null;    // too far apart.
+
+        return nearest;
+    }
+
+    /**
+     * Returns the set of valid root tag names.
+     * For diagnostic use.
+     */
+    public Set<QName> getValidRootNames() {
+        Set<QName> r = new TreeSet<QName>(QNAME_COMPARATOR);
+        for (QNameMap.Entry e : rootMap.entrySet()) {
+            r.add(e.createQName());
+        }
+        return r;
+    }
+
+    /**
+     * Cache of UTF-8 encoded local names to improve the performance for the marshalling.
+     */
+    private Encoded[] utf8nameTable;
+
+    public synchronized Encoded[] getUTF8NameTable() {
+        if(utf8nameTable==null) {
+            Encoded[] x = new Encoded[nameList.localNames.length];
+            for( int i=0; i<x.length; i++ ) {
+                Encoded e = new Encoded(nameList.localNames[i]);
+                e.compact();
+                x[i] = e;
+            }
+            utf8nameTable = x;
+        }
+        return utf8nameTable;
+    }
+
+    public int getNumberOfLocalNames() {
+        return nameList.localNames.length;
+    }
+
+    public int getNumberOfElementNames() {
+        return nameList.numberOfElementNames;
+    }
+
+    public int getNumberOfAttributeNames() {
+        return nameList.numberOfAttributeNames;
+    }
+
+    /**
+     * Creates a new identity transformer.
+     */
+    static Transformer createTransformer() {
+        try {
+            synchronized(JAXBContextImpl.class) {
+                if(tf==null)
+                    tf = (SAXTransformerFactory)TransformerFactory.newInstance();
+                return tf.newTransformer();
+            }
+        } catch (TransformerConfigurationException e) {
+            throw new Error(e); // impossible
+        }
+    }
+
+    /**
+     * Creates a new identity transformer.
+     */
+    public static TransformerHandler createTransformerHandler() {
+        try {
+            synchronized(JAXBContextImpl.class) {
+                if(tf==null)
+                    tf = (SAXTransformerFactory)TransformerFactory.newInstance();
+                return tf.newTransformerHandler();
+            }
+        } catch (TransformerConfigurationException e) {
+            throw new Error(e); // impossible
+        }
+    }
+
+    /**
+     * Creates a new DOM document.
+     */
+    static Document createDom() {
+        synchronized(JAXBContextImpl.class) {
+            if(db==null) {
+                try {
+                    DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+                    dbf.setNamespaceAware(true);
+                    db = dbf.newDocumentBuilder();
+                } catch (ParserConfigurationException e) {
+                    // impossible
+                    throw new FactoryConfigurationError(e);
+                }
+            }
+            return db.newDocument();
+        }
+    }
+
+    public MarshallerImpl createMarshaller() {
+        return new MarshallerImpl(this,null);
+    }
+
+    public UnmarshallerImpl createUnmarshaller() {
+        return new UnmarshallerImpl(this,null);
+    }
+
+    public Validator createValidator() {
+        throw new UnsupportedOperationException(Messages.NOT_IMPLEMENTED_IN_2_0.format());
+    }
+
+    @Override
+    public JAXBIntrospector createJAXBIntrospector() {
+        return new JAXBIntrospector() {
+            public boolean isElement(Object object) {
+                return getElementName(object)!=null;
+            }
+
+            public QName getElementName(Object jaxbElement) {
+                try {
+                    return JAXBContextImpl.this.getElementName(jaxbElement);
+                } catch (JAXBException e) {
+                    return null;
+                }
+            }
+        };
+    }
+
+    private NonElement<Type,Class> getXmlType(RuntimeTypeInfoSet tis, TypeReference tr) {
+        if(tr==null)
+            throw new IllegalArgumentException();
+
+        XmlJavaTypeAdapter xjta = tr.get(XmlJavaTypeAdapter.class);
+        XmlList xl = tr.get(XmlList.class);
+
+        Ref<Type,Class> ref = new Ref<Type,Class>(
+            new RuntimeInlineAnnotationReader(), tis.getNavigator(), tr.type, xjta, xl );
+
+        return tis.getTypeInfo(ref);
+    }
+
+    public void generateSchema(SchemaOutputResolver outputResolver) throws IOException {
+        if(outputResolver==null) {
+            throw new IOException(Messages.NULL_OUTPUT_RESOLVER.format());
+        }
+
+        RuntimeTypeInfoSet tis;
+        try {
+            tis = getTypeInfoSet();
+        } catch (IllegalAnnotationsException e) {
+            // this shouldn't happen because we've already
+            throw new AssertionError(e);
+        }
+
+        XmlSchemaGenerator<Type,Class, Field, Method> xsdgen =
+                new XmlSchemaGenerator<Type,Class, Field, Method>(tis.getNavigator(),tis);
+
+        // JAX-RPC uses Bridge objects that collide with
+        // @XmlRootElement.
+        // we will avoid collision here
+        Set<QName> rootTagNames = new HashSet<QName>();
+        for (RuntimeElementInfo ei : tis.getAllElements()) {
+            rootTagNames.add(ei.getElementName());
+        }
+        for (RuntimeClassInfo ci : tis.beans().values()) {
+            if(ci.isElement())
+                rootTagNames.add(ci.asElement().getElementName());
+        }
+
+        for (TypeReference tr : bridges.keySet()) {
+            if(rootTagNames.contains(tr.tagName))
+                continue;
+
+            if(tr.type==void.class || tr.type==Void.class) {
+                xsdgen.add(tr.tagName,false,null);
+            } else {
+                NonElement<Type,Class> typeInfo = getXmlType(tis,tr);
+                xsdgen.add(tr.tagName, !Navigator.REFLECTION.isPrimitive(tr.type),typeInfo);
+            }
+        }
+
+        xsdgen.write(outputResolver);
+    }
+
+    public QName getTypeName(TypeReference tr) {
+        try {
+            NonElement<Type,Class> xt = getXmlType(getTypeInfoSet(),tr);
+            if(xt==null)    throw new IllegalArgumentException();
+            return xt.getTypeName();
+        } catch (IllegalAnnotationsException e) {
+            // impossible given that JAXBRIContext has been successfully built in the first place
+            throw new AssertionError(e);
+        }
+    }
+
+    /**
+     * Used for testing.
+     */
+    public SchemaOutputResolver createTestResolver() {
+        return new SchemaOutputResolver() {
+            public Result createOutput(String namespaceUri, String suggestedFileName) {
+                SAXResult r = new SAXResult(new DefaultHandler());
+                r.setSystemId(suggestedFileName);
+                return r;
+            }
+        };
+    }
+
+    @Override
+    public <T> Binder<T> createBinder(Class<T> domType) {
+        if(domType==Node.class)
+            return (Binder<T>)createBinder();
+        else
+            return super.createBinder(domType);
+    }
+
+    @Override
+    public Binder<Node> createBinder() {
+        return new BinderImpl<Node>(this,new DOMScanner());
+    }
+
+    public QName getElementName(Object o) throws JAXBException {
+        JaxBeanInfo bi = getBeanInfo(o,true);
+        if(!bi.isElement())
+            return null;
+        return new QName(bi.getElementNamespaceURI(o),bi.getElementLocalName(o));
+    }
+
+    public Bridge createBridge(TypeReference ref) {
+        return bridges.get(ref);
+    }
+
+    public @NotNull BridgeContext createBridgeContext() {
+        return new BridgeContextImpl(this);
+    }
+
+    public RawAccessor getElementPropertyAccessor(Class wrapperBean, String nsUri, String localName) throws JAXBException {
+        JaxBeanInfo bi = getBeanInfo(wrapperBean,true);
+        if(!(bi instanceof ClassBeanInfoImpl))
+            throw new JAXBException(wrapperBean+" is not a bean");
+
+        for( ClassBeanInfoImpl cb = (ClassBeanInfoImpl) bi; cb!=null; cb=cb.superClazz) {
+            for (Property p : cb.properties) {
+                final Accessor acc = p.getElementPropertyAccessor(nsUri,localName);
+                if(acc!=null)
+                    return new RawAccessor() {
+                        // Accessor.set/get are designed for unmarshaller/marshaller, and hence
+                        // they go through an adapter behind the scene.
+                        // this isn't desirable for JAX-WS, which essentially uses this method
+                        // just as a reflection library. So use the "unadapted" version to
+                        // achieve the desired semantics
+                        public Object get(Object bean) throws AccessorException {
+                            return acc.getUnadapted(bean);
+                        }
+
+                        public void set(Object bean, Object value) throws AccessorException {
+                            acc.setUnadapted(bean,value);
+                        }
+                    };
+            }
+        }
+        throw new JAXBException(new QName(nsUri,localName)+" is not a valid property on "+wrapperBean);
+    }
+
+    public List<String> getKnownNamespaceURIs() {
+        return Arrays.asList(nameList.namespaceURIs);
+    }
+
+    public String getBuildId() {
+        Package pkg = getClass().getPackage();
+        if(pkg==null)   return null;
+        return pkg.getImplementationVersion();
+    }
+
+    public String toString() {
+        StringBuilder buf = new StringBuilder(Which.which(getClass()) + " Build-Id: " + getBuildId());
+        buf.append("\nClasses known to this context:\n");
+
+        Set<String> names = new TreeSet<String>();  // sort them so that it's easy to read
+
+        for (Class key : beanInfoMap.keySet())
+            names.add(key.getName());
+
+        for(String name: names)
+            buf.append("  ").append(name).append('\n');
+
+        return buf.toString();
+    }
+
+    /**
+     * Gets the value of the xmime:contentType attribute on the given object, or null
+     * if for some reason it couldn't be found, including any error.
+     */
+    public String getXMIMEContentType( Object o ) {
+        JaxBeanInfo bi = getBeanInfo(o);
+        if(!(bi instanceof ClassBeanInfoImpl))
+            return null;
+
+        ClassBeanInfoImpl cb = (ClassBeanInfoImpl) bi;
+        for (Property p : cb.properties) {
+            if (p instanceof AttributeProperty) {
+                AttributeProperty ap = (AttributeProperty) p;
+                if(ap.attName.equals(WellKnownNamespace.XML_MIME_URI,"contentType"))
+                    try {
+                        return (String)ap.xacc.print(o);
+                    } catch (AccessorException e) {
+                        return null;
+                    } catch (SAXException e) {
+                        return null;
+                    } catch (ClassCastException e) {
+                        return null;
+                    }
+            }
+        }
+        return null;
+    }
+
+    private static final Comparator<QName> QNAME_COMPARATOR = new Comparator<QName>() {
+        public int compare(QName lhs, QName rhs) {
+            int r = lhs.getLocalPart().compareTo(rhs.getLocalPart());
+            if(r!=0)    return r;
+
+            return lhs.getNamespaceURI().compareTo(rhs.getNamespaceURI());
+        }
+    }; ;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/JaxBeanInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/JaxBeanInfo.java
new file mode 100644
index 0000000..02fdd8c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/JaxBeanInfo.java
@@ -0,0 +1,530 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.datatype.XMLGregorianCalendar;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.xml.internal.bind.Util;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfo;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Encapsulates various JAXB operations on objects bound by JAXB.
+ * Immutable and thread-safe.
+ *
+ * <p>
+ * Each JAXB-bound class has a corresponding {@link JaxBeanInfo} object,
+ * which performs all the JAXB related operations on behalf of
+ * the JAXB-bound object.
+ *
+ * <p>
+ * Given a class, the corresponding {@link JaxBeanInfo} can be located
+ * via {@link JAXBContextImpl#getBeanInfo(Class,boolean)}.
+ *
+ * <p>
+ * Typically, {@link JaxBeanInfo} implementations should be generated
+ * by XJC/JXC. Those impl classes will register themselves to their
+ * master <tt>ObjectFactory</tt> class.
+ *
+ * <p>
+ * The type parameter BeanT is the Java class of the bean that this represents.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class JaxBeanInfo<BeanT> {
+
+    /**
+     * For {@link JaxBeanInfo} that has multiple type names.
+     */
+    protected JaxBeanInfo(JAXBContextImpl grammar, RuntimeTypeInfo rti, Class<BeanT> jaxbType, QName[] typeNames, boolean isElement,boolean isImmutable, boolean hasLifecycleEvents) {
+        this(grammar,rti,jaxbType,(Object)typeNames,isElement,isImmutable,hasLifecycleEvents);
+    }
+
+    /**
+     * For {@link JaxBeanInfo} that has one type name.
+     */
+    protected JaxBeanInfo(JAXBContextImpl grammar, RuntimeTypeInfo rti, Class<BeanT> jaxbType, QName typeName, boolean isElement,boolean isImmutable, boolean hasLifecycleEvents) {
+        this(grammar,rti,jaxbType,(Object)typeName,isElement,isImmutable,hasLifecycleEvents);
+    }
+
+    /**
+     * For {@link JaxBeanInfo} that has no type names.
+     */
+    protected JaxBeanInfo(JAXBContextImpl grammar, RuntimeTypeInfo rti, Class<BeanT> jaxbType, boolean isElement,boolean isImmutable, boolean hasLifecycleEvents) {
+        this(grammar,rti,jaxbType,(Object)null,isElement,isImmutable,hasLifecycleEvents);
+    }
+
+    private JaxBeanInfo(JAXBContextImpl grammar, RuntimeTypeInfo rti, Class<BeanT> jaxbType, Object typeName, boolean isElement,boolean isImmutable, boolean hasLifecycleEvents) {
+        grammar.beanInfos.put(rti,this);
+
+        this.jaxbType = jaxbType;
+        this.typeName = typeName;
+        this.flag = (short)((isElement?FLAG_IS_ELEMENT:0)
+                |(isImmutable?FLAG_IS_IMMUTABLE:0)
+                |(hasLifecycleEvents?FLAG_HAS_LIFECYCLE_EVENTS:0));
+    }
+
+    /**
+     * Various boolean flags combined into one field to improve memory footprint.
+     */
+    protected short flag;
+
+    private static final short FLAG_IS_ELEMENT = 1;
+    private static final short FLAG_IS_IMMUTABLE = 2;
+    private static final short FLAG_HAS_ELEMENT_ONLY_CONTENTMODEL = 4;
+    private static final short FLAG_HAS_BEFORE_UNMARSHAL_METHOD = 8;
+    private static final short FLAG_HAS_AFTER_UNMARSHAL_METHOD = 16;
+    private static final short FLAG_HAS_BEFORE_MARSHAL_METHOD = 32;
+    private static final short FLAG_HAS_AFTER_MARSHAL_METHOD = 64;
+    private static final short FLAG_HAS_LIFECYCLE_EVENTS = 128;
+
+    /** cache of lifecycle methods */
+    private LifecycleMethods lcm = null;
+
+    /**
+     * True if {@link #jaxbType} has the  lifecycle method.
+     */
+    public final boolean hasBeforeUnmarshalMethod() {
+        return (flag&FLAG_HAS_BEFORE_UNMARSHAL_METHOD) != 0;
+    }
+
+    /**
+     * True if {@link #jaxbType} has the  lifecycle method.
+     */
+    public final boolean hasAfterUnmarshalMethod() {
+        return (flag&FLAG_HAS_AFTER_UNMARSHAL_METHOD) != 0;
+    }
+
+    /**
+     * True if {@link #jaxbType} has the  lifecycle method.
+     */
+    public final boolean hasBeforeMarshalMethod() {
+        return (flag&FLAG_HAS_BEFORE_MARSHAL_METHOD) != 0;
+    }
+
+    /**
+     * True if {@link #jaxbType} has the  lifecycle method.
+     */
+    public final boolean hasAfterMarshalMethod() {
+        return (flag&FLAG_HAS_AFTER_MARSHAL_METHOD) != 0;
+    }
+
+    /**
+     * Gets the JAXB bound class type that this {@link JaxBeanInfo}
+     * handles.
+     *
+     * <p>
+     * IOW, when a bean info object is requested for T,
+     * sometimes the bean info for one of its base classes might be
+     * returned.
+     */
+    public final Class<BeanT> jaxbType;
+
+    /**
+     * Returns true if the bean is mapped to/from an XML element.
+     *
+     * <p>
+     * When this method returns true, {@link #getElementNamespaceURI(Object)}
+     * and {@link #getElementLocalName(Object)} returns the element name of
+     * the bean.
+     */
+    public final boolean isElement() {
+        return (flag&FLAG_IS_ELEMENT)!=0;
+    }
+
+    /**
+     * Returns true if the bean is immutable.
+     *
+     * <p>
+     * If this is true, Binder won't try to ueuse this object, and the unmarshaller
+     * won't create a new instance of it before it starts.
+     */
+    public final boolean isImmutable() {
+        return (flag&FLAG_IS_IMMUTABLE)!=0;
+    }
+
+    /**
+     * True if this bean has an element-only content model.
+     * <p>
+     * If this flag is true, the unmarshaller can work
+     * faster by ignoring whitespaces more efficiently.
+     */
+    public final boolean hasElementOnlyContentModel() {
+        return (flag&FLAG_HAS_ELEMENT_ONLY_CONTENTMODEL)!=0;
+    }
+
+    /**
+     * True if this bean has an element-only content model.
+     * <p>
+     * Should be considered immutable, though I can't mark it final
+     * because it cannot be computed in this constructor.
+     */
+    protected final void hasElementOnlyContentModel(boolean value) {
+        if(value)
+            flag |= FLAG_HAS_ELEMENT_ONLY_CONTENTMODEL;
+        else
+            flag &= ~FLAG_HAS_ELEMENT_ONLY_CONTENTMODEL;
+    }
+
+    /**
+     * This method is used to determine which of the sub-classes should be
+     * interrogated for the existence of lifecycle methods.
+     *
+     * @return true if the un|marshaller should look for lifecycle methods
+     *         on this beanInfo, false otherwise.
+     */
+    public boolean lookForLifecycleMethods() {
+        return (flag&FLAG_HAS_LIFECYCLE_EVENTS)!=0;
+    }
+
+    /**
+     * Returns the namespace URI portion of the element name,
+     * if the bean that this class represents is mapped from/to
+     * an XML element.
+     *
+     * @throws UnsupportedOperationException
+     *      if {@link #isElement} is false.
+     */
+    public abstract String getElementNamespaceURI(BeanT o);
+
+    /**
+     * Returns the local name portion of the element name,
+     * if the bean that this class represents is mapped from/to
+     * an XML element.
+     *
+     * @throws UnsupportedOperationException
+     *      if {@link #isElement} is false.
+     */
+    public abstract String getElementLocalName(BeanT o);
+
+    /**
+     * Type names associated with this {@link JaxBeanInfo}.
+     *
+     * @see #getTypeNames()
+     */
+    private final Object typeName; // either null, QName, or QName[]. save memory since most of them have just one.
+
+    /**
+     * Returns XML Schema type names if the bean is mapped from
+     * a complex/simple type of XML Schema.
+     *
+     * <p>
+     * This is an ugly necessity to correctly handle
+     * the type substitution semantics of XML Schema.
+     *
+     * <p>
+     * A single Java class maybe mapped to more than one
+     * XML types. All the types listed here are recognized
+     * when we are unmarshalling XML.
+     *
+     * <p>
+     * null if the class is not bound to a named schema type.
+     *
+     * <p>
+     */
+    public Collection<QName> getTypeNames() {
+        if(typeName==null)  return Collections.emptyList();
+        if(typeName instanceof QName)   return Collections.singletonList((QName)typeName);
+        return Arrays.asList((QName[])typeName);
+    }
+
+    /**
+     * Returns the XML type name to be used to marshal the specified instance.
+     *
+     * <P>
+     * Most of the times the type can be determined regardless of the actual
+     * instance, but there's a few exceptions (most notably {@link XMLGregorianCalendar}),
+     * so as a general rule we need an instance to determine it.
+     */
+    public QName getTypeName(@NotNull BeanT instance) {
+        if(typeName==null)  return null;
+        if(typeName instanceof QName)   return (QName)typeName;
+        return ((QName[])typeName)[0];
+    }
+
+    /**
+     * Creates a new instance of the bean.
+     *
+     * <p>
+     * This operation is only supported when {@link #isImmutable} is false.
+     *
+     * @param context
+     *      Sometimes the created bean remembers the corresponding source location,
+     */
+    public abstract BeanT createInstance(UnmarshallingContext context) throws IllegalAccessException, InvocationTargetException, InstantiationException, SAXException;
+
+    /**
+     * Resets the object to the initial state, as if the object
+     * is created fresh.
+     *
+     * <p>
+     * This is used to reuse an existing object for unmarshalling.
+     *
+     * @param context
+     *      used for reporting any errors.
+     *
+     * @return
+     *      true if the object was successfuly resetted.
+     *      False if the object is not resettable, in which case the object will be
+     *      discarded and new one will be created.
+     *      <p>
+     *      If the object is resettable but failed by an error, it should be reported to the context,
+     *      then return false. If the object is not resettable to begin with, do not report an error.
+     *
+     * @throws SAXException
+     *      as a result of reporting an error, the context may throw a {@link SAXException}.
+     */
+    public abstract boolean reset( BeanT o, UnmarshallingContext context ) throws SAXException;
+
+    /**
+     * Gets the ID value of the given bean, if it has an ID value.
+     * Otherwise return null.
+     */
+    public abstract String getId(BeanT o, XMLSerializer target) throws SAXException;
+
+    /**
+     * Serializes child elements and texts into the specified target.
+     */
+    public abstract void serializeBody( BeanT o, XMLSerializer target ) throws SAXException, IOException, XMLStreamException;
+
+    /**
+     * Serializes attributes into the specified target.
+     */
+    public abstract void serializeAttributes( BeanT o, XMLSerializer target ) throws SAXException, IOException, XMLStreamException;
+
+    /**
+     * Serializes the bean as the root element.
+     *
+     * <p>
+     * In the java-to-schema binding, an object might marshal in two different
+     * ways depending on whether it is used as the root of the graph or not.
+     * In the former case, an object could marshal as an element, whereas
+     * in the latter case, it marshals as a type.
+     *
+     * <p>
+     * This method is used to marshal the root of the object graph to allow
+     * this semantics to be implemented.
+     *
+     * <p>
+     * It is doubtful to me if it's a good idea for an object to marshal
+     * in two ways depending on the context.
+     *
+     * <p>
+     * For schema-to-java, this is equivalent to {@link #serializeBody(Object, XMLSerializer)}.
+     */
+    public abstract void serializeRoot( BeanT o, XMLSerializer target ) throws SAXException, IOException, XMLStreamException;
+
+    /**
+     * Declares all the namespace URIs this object is using at
+     * its top-level scope into the specified target.
+     */
+    public abstract void serializeURIs( BeanT o, XMLSerializer target ) throws SAXException;
+
+    /**
+     * Gets the {@link Loader} that will unmarshall the given object.
+     *
+     * @param context
+     *      The {@link JAXBContextImpl} object that governs this object.
+     *      This object is taken as a parameter so that {@link JaxBeanInfo} doesn't have
+     *      to store them on its own.
+     *
+     *      When this method is invoked from within the unmarshaller, tihs parameter can be
+     *      null (because the loader is constructed already.)
+     *
+     * @param typeSubstitutionCapable
+     *      If true, the returned {@link Loader} is capable of recognizing @xsi:type (if necessary)
+     *      and unmarshals a subtype. This allowes an optimization where this bean info
+     *      is guaranteed not to have a type substitution.
+     *      If false, the returned {@link Loader} doesn't look for @xsi:type.
+     * @return
+     *      must return non-null valid object
+     */
+    public abstract Loader getLoader(JAXBContextImpl context, boolean typeSubstitutionCapable);
+
+    /**
+     * If the bean's representation in XML is just a text,
+     * this method return a {@link Transducer} that lets you convert
+     * values between the text and the bean.
+     */
+    public abstract Transducer<BeanT> getTransducer();
+
+
+    /**
+     * Called after all the {@link JaxBeanInfo}s are created.
+     * @param grammar
+     */
+    protected  void link(JAXBContextImpl grammar) {
+    }
+
+    /**
+     * Called at the end of the {@link JAXBContext} initialization phase
+     * to clean up any unnecessary references.
+     */
+    public void wrapUp() {}
+
+
+    private static final Class[] unmarshalEventParams = { Unmarshaller.class, Object.class };
+    private static Class[] marshalEventParams = { Marshaller.class };
+
+    /**
+     * use reflection to determine which of the 4 object lifecycle methods exist on
+     * the JAXB bound type.
+     */
+    protected final void setLifecycleFlags() {
+        try {
+            Method m;
+
+            // beforeUnmarshal
+            try {
+                m = jaxbType.getDeclaredMethod("beforeUnmarshal", unmarshalEventParams);
+                cacheLifecycleMethod(m, FLAG_HAS_BEFORE_UNMARSHAL_METHOD);
+            } catch (NoSuchMethodException e) {
+                // no-op, look for the next method
+            }
+
+            // afterUnmarshal
+            try {
+                m = jaxbType.getDeclaredMethod("afterUnmarshal", unmarshalEventParams);
+                cacheLifecycleMethod(m, FLAG_HAS_AFTER_UNMARSHAL_METHOD);
+            } catch (NoSuchMethodException e) {
+                // no-op, look for the next method
+            }
+
+            // beforeMarshal
+            try {
+                m = jaxbType.getDeclaredMethod("beforeMarshal", marshalEventParams);
+                cacheLifecycleMethod(m, FLAG_HAS_BEFORE_MARSHAL_METHOD);
+            } catch (NoSuchMethodException e) {
+                // no-op, look for the next method
+            }
+
+            // afterMarshal
+            try {
+                m = jaxbType.getDeclaredMethod("afterMarshal", marshalEventParams);
+                cacheLifecycleMethod(m, FLAG_HAS_AFTER_MARSHAL_METHOD);
+            } catch (NoSuchMethodException e) {
+                // no-op
+            }
+        } catch(SecurityException e) {
+            // this happens when we don't have enough permission.
+            logger.log( Level.WARNING, Messages.UNABLE_TO_DISCOVER_EVENTHANDLER.format(
+                jaxbType.getName(),
+                e ));
+        }
+    }
+
+    /**
+     * Cache a reference to the specified lifecycle method for the jaxbType
+     * associated with this beanInfo.
+     *
+     * @param m Method reference
+     * @param lifecycleFlag byte representing which of the 4 lifecycle methods
+     *        is being cached
+     */
+    private void cacheLifecycleMethod(Method m, short lifecycleFlag) {
+        //LifecycleMethods lcm = getLifecycleMethods();
+        if(lcm==null) {
+            lcm = new LifecycleMethods();
+            //lcmCache.put(jaxbType, lcm);
+        }
+
+        m.setAccessible(true);
+
+        flag |= lifecycleFlag;
+
+        switch (lifecycleFlag) {
+        case FLAG_HAS_BEFORE_UNMARSHAL_METHOD:
+            lcm.setBeforeUnmarshal(m);
+            break;
+        case FLAG_HAS_AFTER_UNMARSHAL_METHOD:
+            lcm.setAfterUnmarshal(m);
+            break;
+        case FLAG_HAS_BEFORE_MARSHAL_METHOD:
+            lcm.setBeforeMarshal(m);
+            break;
+        case FLAG_HAS_AFTER_MARSHAL_METHOD:
+            lcm.setAfterMarshal(m);
+            break;
+        }
+    }
+
+    /**
+     * Return the LifecycleMethods cache for this ClassBeanInfo's corresponding
+     * jaxbType if it exists, else return null.
+     *
+     */
+    public final LifecycleMethods getLifecycleMethods() {
+        return lcm;
+    }
+
+    /**
+     * Invokes the beforeUnmarshal method if applicable.
+     */
+    public final void invokeBeforeUnmarshalMethod(UnmarshallerImpl unm, Object child, Object parent) throws SAXException {
+        Method m = getLifecycleMethods().getBeforeUnmarshal();
+        invokeUnmarshallCallback(m, child, unm, parent);
+    }
+
+    /**
+     * Invokes the afterUnmarshal method if applicable.
+     */
+    public final void invokeAfterUnmarshalMethod(UnmarshallerImpl unm, Object child, Object parent) throws SAXException {
+        Method m = getLifecycleMethods().getAfterUnmarshal();
+        invokeUnmarshallCallback(m, child, unm, parent);
+    }
+
+    private void invokeUnmarshallCallback(Method m, Object child, UnmarshallerImpl unm, Object parent) throws SAXException {
+        try {
+            m.invoke(child,unm,parent);
+        } catch (IllegalAccessException e) {
+            UnmarshallingContext.getInstance().handleError(e);
+        } catch (InvocationTargetException e) {
+            UnmarshallingContext.getInstance().handleError(e);
+        }
+    }
+
+    private static final Logger logger = Util.getClassLogger();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/LeafBeanInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/LeafBeanInfoImpl.java
new file mode 100644
index 0000000..32f1929
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/LeafBeanInfoImpl.java
@@ -0,0 +1,162 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeLeafInfo;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.TextLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiTypeLoader;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link JaxBeanInfo} implementation for immutable leaf classes.
+ *
+ * <p>
+ * Leaf classes are always bound to a text and they are often immutable.
+ * The JAXB spec allows this binding for a few special Java classes plus
+ * type-safe enums.
+ *
+ * <p>
+ * This implementation obtains necessary information from {@link RuntimeLeafInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class LeafBeanInfoImpl<BeanT> extends JaxBeanInfo<BeanT> {
+
+    private final Loader loader;
+    private final Loader loaderWithSubst;
+
+    private final Transducer<BeanT> xducer;
+
+    /**
+     * Non-null only if the leaf is also an element.
+     */
+    private final Name tagName;
+
+    public LeafBeanInfoImpl(JAXBContextImpl grammar, RuntimeLeafInfo li) {
+        super(grammar,li,li.getClazz(),li.getTypeNames(),li.isElement(),true,false);
+
+        xducer = li.getTransducer();
+        loader = new TextLoader(xducer);
+        loaderWithSubst = new XsiTypeLoader(this);
+
+        if(isElement())
+            tagName = grammar.nameBuilder.createElementName(li.getElementName());
+        else
+            tagName = null;
+    }
+
+    public QName getTypeName(BeanT instance) {
+        QName tn = xducer.getTypeName(instance);
+        if(tn!=null)    return tn;
+        // rely on default
+        return super.getTypeName(instance);
+    }
+
+    public final String getElementNamespaceURI(BeanT _) {
+        return tagName.nsUri;
+    }
+
+    public final String getElementLocalName(BeanT _) {
+        return tagName.localName;
+    }
+
+    public BeanT createInstance(UnmarshallingContext context) {
+        throw new UnsupportedOperationException();
+    }
+
+    public final boolean reset(BeanT bean, UnmarshallingContext context) {
+        return false;
+    }
+
+    public final String getId(BeanT bean, XMLSerializer target) {
+        return null;
+    }
+
+    public final void serializeBody(BeanT bean, XMLSerializer w) throws SAXException, IOException, XMLStreamException {
+        // most of the times leaves are printed as leaf element/attribute property,
+        // so this code is only used for example when you have multiple XmlElement on a property
+        // and some of them are leaves. Hence this doesn't need to be super-fast.
+        try {
+            xducer.writeText(w,bean,null);
+        } catch (AccessorException e) {
+            w.reportError(null,e);
+        }
+    }
+
+    public final void serializeAttributes(BeanT bean, XMLSerializer target) {
+        // noop
+    }
+
+    public final void serializeRoot(BeanT bean, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        if(tagName==null) {
+            target.reportError(
+                new ValidationEventImpl(
+                    ValidationEvent.ERROR,
+                    Messages.UNABLE_TO_MARSHAL_NON_ELEMENT.format(bean.getClass().getName()),
+                    null,
+                    null));
+        }
+        else {
+            target.startElement(tagName,bean);
+            target.childAsSoleContent(bean,null);
+            target.endElement();
+        }
+    }
+
+    public final void serializeURIs(BeanT bean, XMLSerializer target) throws SAXException {
+        // TODO: maybe we should create another LeafBeanInfoImpl class for
+        // context-dependent xducers?
+        if(xducer.useNamespace()) {
+            try {
+                xducer.declareNamespace(bean,target);
+            } catch (AccessorException e) {
+                target.reportError(null,e);
+            }
+        }
+    }
+
+    public final Loader getLoader(JAXBContextImpl context, boolean typeSubstitutionCapable) {
+        if(typeSubstitutionCapable)
+            return loaderWithSubst;
+        else
+            return loader;
+    }
+
+    public Transducer<BeanT> getTransducer() {
+        return xducer;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/LifecycleMethods.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/LifecycleMethods.java
new file mode 100644
index 0000000..4c60cd9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/LifecycleMethods.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.lang.reflect.Method;
+
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+
+/**
+ * This class is a simple container for caching lifecycle methods that are
+ * discovered during construction of (@link JAXBContext}.
+ *
+ * @see JaxBeanInfo#lcm
+ * @see Loader#fireBeforeUnmarshal(JaxBeanInfo, Object, UnmarshallingContext.State)
+ * @see Loader#fireAfterUnmarshal(JaxBeanInfo, Object, UnmarshallingContext.State)
+ * @see XMLSerializer#fireMarshalEvent(Object, Method)
+ */
+public final class LifecycleMethods {
+    private Method beforeUnmarshal;
+    private Method afterUnmarshal;
+    private Method beforeMarshal;
+    private Method afterMarshal;
+
+    public Method getAfterMarshal() {
+        return afterMarshal;
+    }
+
+    public void setAfterMarshal(Method afterMarshal) {
+        this.afterMarshal = afterMarshal;
+    }
+
+    public Method getAfterUnmarshal() {
+        return afterUnmarshal;
+    }
+
+    public void setAfterUnmarshal(Method afterUnmarshal) {
+        this.afterUnmarshal = afterUnmarshal;
+    }
+
+    public Method getBeforeMarshal() {
+        return beforeMarshal;
+    }
+
+    public void setBeforeMarshal(Method beforeMarshal) {
+        this.beforeMarshal = beforeMarshal;
+    }
+
+    public Method getBeforeUnmarshal() {
+        return beforeUnmarshal;
+    }
+
+    public void setBeforeUnmarshal(Method beforeUnmarshal) {
+        this.beforeUnmarshal = beforeUnmarshal;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Location.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Location.java
new file mode 100644
index 0000000..b0acf59
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Location.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+
+
+/**
+ * Location information for {@link IllegalAnnotationException}.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB 2.0 EA1
+ */
+// internally, Location is created from Locatable.
+public interface Location {
+    /**
+     * Returns a human-readable string that represents this position.
+     *
+     * @return
+     *      never null.
+     */
+    String toString();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/MarshallerImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/MarshallerImpl.java
new file mode 100644
index 0000000..1f5c5fd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/MarshallerImpl.java
@@ -0,0 +1,591 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.BufferedWriter;
+import java.io.Closeable;
+import java.io.FileOutputStream;
+import java.io.Flushable;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.UnsupportedEncodingException;
+import java.io.Writer;
+
+import javax.xml.bind.DatatypeConverter;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.MarshalException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.PropertyException;
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.bind.helpers.AbstractMarshallerImpl;
+import javax.xml.stream.XMLEventWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.Result;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.sax.SAXResult;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.validation.Schema;
+import javax.xml.validation.ValidatorHandler;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.bind.marshaller.CharacterEscapeHandler;
+import com.sun.xml.internal.bind.marshaller.DataWriter;
+import com.sun.xml.internal.bind.marshaller.DumbEscapeHandler;
+import com.sun.xml.internal.bind.marshaller.MinimumEscapeHandler;
+import com.sun.xml.internal.bind.marshaller.NamespacePrefixMapper;
+import com.sun.xml.internal.bind.marshaller.NioEscapeHandler;
+import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
+import com.sun.xml.internal.bind.marshaller.XMLWriter;
+import com.sun.xml.internal.bind.v2.runtime.output.C14nXmlOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.Encoded;
+import com.sun.xml.internal.bind.v2.runtime.output.ForkXmlOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.IndentingUTF8XmlOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.NamespaceContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.output.SAXOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.UTF8XmlOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.XMLEventWriterOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.XMLStreamWriterOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.XmlOutput;
+import com.sun.xml.internal.bind.v2.util.FatalAdapter;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Node;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+/**
+ * Implementation of {@link Marshaller} interface for the JAXB RI.
+ *
+ * <p>
+ * Eventually all the {@link #marshal} methods call into
+ * the {@link #write} method.
+ *
+ * @author Kohsuke Kawaguchi
+ * @author Vivek Pandey
+ */
+public /*to make unit tests happy*/ final class MarshallerImpl extends AbstractMarshallerImpl implements ValidationEventHandler
+{
+    /** Indentation string. Default is four whitespaces. */
+    private String indent = "    ";
+
+    /** Used to assign prefixes to namespace URIs. */
+    private NamespacePrefixMapper prefixMapper = null;
+
+    /** Object that handles character escaping. */
+    private CharacterEscapeHandler escapeHandler = null;
+
+    /** XML BLOB written after the XML declaration. */
+    private String header=null;
+
+    /** reference to the context that created this object */
+    final JAXBContextImpl context;
+
+    protected final XMLSerializer serializer;
+
+    /**
+     * Non-null if we do the marshal-time validation.
+     */
+    private Schema schema;
+
+    /** Marshaller.Listener */
+    private Listener externalListener = null;
+
+    /** Configured for c14n? */
+    private boolean c14nSupport;
+
+    // while createing XmlOutput those values may be set.
+    // if these are non-null they need to be cleaned up
+    private Flushable toBeFlushed;
+    private Closeable toBeClosed;
+
+    /**
+     * @param assoc
+     *      non-null if the marshaller is working inside {@link BinderImpl}.
+     */
+    public MarshallerImpl( JAXBContextImpl c, AssociationMap assoc ) {
+        // initialize datatype converter with ours
+        DatatypeConverter.setDatatypeConverter(DatatypeConverterImpl.theInstance);
+
+        context = c;
+        serializer = new XMLSerializer(this);
+        c14nSupport = context.c14nSupport;
+
+        try {
+            setEventHandler(this);
+        } catch (JAXBException e) {
+            throw new AssertionError(e);    // impossible
+        }
+    }
+
+    public JAXBContextImpl getContext() {
+        return context;
+    }
+
+    public void marshal(Object obj, XMLStreamWriter writer) throws JAXBException {
+        write(obj, XMLStreamWriterOutput.create(writer), new StAXPostInitAction(writer,serializer));
+    }
+
+    public void marshal(Object obj, XMLEventWriter writer) throws JAXBException {
+        write(obj, new XMLEventWriterOutput(writer), new StAXPostInitAction(writer,serializer));
+    }
+
+    public void marshal(Object obj, XmlOutput output) throws JAXBException {
+        write(obj, output, null );
+    }
+
+    /**
+     * Creates {@link XmlOutput} from the given {@link Result} object.
+     */
+    final XmlOutput createXmlOutput(Result result) throws JAXBException {
+        if (result instanceof SAXResult)
+            return new SAXOutput(((SAXResult) result).getHandler());
+
+        if (result instanceof DOMResult) {
+            final Node node = ((DOMResult) result).getNode();
+
+            if (node == null) {
+                Document doc = JAXBContextImpl.createDom();
+                ((DOMResult) result).setNode(doc);
+                return new SAXOutput(new SAX2DOMEx(doc));
+            } else {
+                return new SAXOutput(new SAX2DOMEx(node));
+            }
+        }
+        if (result instanceof StreamResult) {
+            StreamResult sr = (StreamResult) result;
+
+            if (sr.getWriter() != null)
+                return createWriter(sr.getWriter());
+            else if (sr.getOutputStream() != null)
+                return createWriter(sr.getOutputStream());
+            else if (sr.getSystemId() != null) {
+                String fileURL = sr.getSystemId();
+
+                if (fileURL.startsWith("file:///")) {
+                    if (fileURL.substring(8).indexOf(":") > 0)
+                        fileURL = fileURL.substring(8);
+                    else
+                        fileURL = fileURL.substring(7);
+                } // otherwise assume that it's a file name
+
+                try {
+                    FileOutputStream fos = new FileOutputStream(fileURL);
+                    assert toBeClosed==null;
+                    toBeClosed = fos;
+                    return createWriter(fos);
+                } catch (IOException e) {
+                    throw new MarshalException(e);
+                }
+            }
+        }
+
+        // unsupported parameter type
+        throw new MarshalException(Messages.UNSUPPORTED_RESULT.format());
+    }
+
+    /**
+     * Creates an appropriate post-init action object.
+     */
+    final Runnable createPostInitAction(Result result) {
+        if (result instanceof DOMResult) {
+            Node node = ((DOMResult) result).getNode();
+            return new DomPostInitAction(node,serializer);
+        }
+        return null;
+    }
+
+    public void marshal(Object target,Result result) throws JAXBException {
+        write(target, createXmlOutput(result), createPostInitAction(result));
+    }
+
+
+    /**
+     * Used by {@link BridgeImpl} to write an arbitrary object as a fragment.
+     */
+    protected final <T> void write(Name rootTagName, JaxBeanInfo<T> bi, T obj, XmlOutput out,Runnable postInitAction) throws JAXBException {
+        try {
+            try {
+                prewrite(out, true, postInitAction);
+                serializer.startElement(rootTagName,null);
+                if(bi.jaxbType==Void.class || bi.jaxbType==void.class) {
+                    // special case for void
+                    serializer.endNamespaceDecls(null);
+                    serializer.endAttributes();
+                } else { // normal cases
+                    if(obj==null)
+                        serializer.writeXsiNilTrue();
+                    else
+                        serializer.childAsXsiType(obj,"root",bi);
+                }
+                serializer.endElement();
+                postwrite(out);
+            } catch( SAXException e ) {
+                throw new MarshalException(e);
+            } catch (IOException e) {
+                throw new MarshalException(e);
+            } catch (XMLStreamException e) {
+                throw new MarshalException(e);
+            } finally {
+                serializer.close();
+            }
+        } finally {
+            cleanUp();
+        }
+    }
+
+    /**
+     * All the marshal method invocation eventually comes down to this call.
+     */
+    private void write(Object obj, XmlOutput out, Runnable postInitAction) throws JAXBException {
+        try {
+            if( obj == null )
+                throw new IllegalArgumentException(Messages.NOT_MARSHALLABLE.format());
+
+            if( schema!=null ) {
+                // send the output to the validator as well
+                ValidatorHandler validator = schema.newValidatorHandler();
+                validator.setErrorHandler(new FatalAdapter(serializer));
+                // work around a bug in JAXP validator in Tiger
+                XMLFilterImpl f = new XMLFilterImpl() {
+                    public void startPrefixMapping(String prefix, String uri) throws SAXException {
+                        super.startPrefixMapping(prefix.intern(), uri.intern());
+                    }
+                };
+                f.setContentHandler(validator);
+                out = new ForkXmlOutput( new SAXOutput(f) {
+                    @Override
+                    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws SAXException, IOException, XMLStreamException {
+                        super.startDocument(serializer, false, nsUriIndex2prefixIndex, nsContext);
+                    }
+                    @Override
+                    public void endDocument(boolean fragment) throws SAXException, IOException, XMLStreamException {
+                        super.endDocument(false);
+                    }
+                }, out );
+            }
+
+            try {
+                prewrite(out,isFragment(),postInitAction);
+                serializer.childAsRoot(obj);
+                postwrite(out);
+            } catch( SAXException e ) {
+                throw new MarshalException(e);
+            } catch (IOException e) {
+                throw new MarshalException(e);
+            } catch (XMLStreamException e) {
+                throw new MarshalException(e);
+            } finally {
+                serializer.close();
+            }
+        } finally {
+            cleanUp();
+        }
+    }
+
+    private void cleanUp() {
+        if(toBeFlushed!=null)
+            try {
+                toBeFlushed.flush();
+            } catch (IOException e) {
+                // ignore
+            }
+        if(toBeClosed!=null)
+            try {
+                toBeClosed.close();
+            } catch (IOException e) {
+                // ignore
+            }
+        toBeFlushed = null;
+        toBeClosed = null;
+    }
+
+    // common parts between two write methods.
+
+    private void prewrite(XmlOutput out, boolean fragment, Runnable postInitAction) throws IOException, SAXException, XMLStreamException {
+        serializer.startDocument(out,fragment,getSchemaLocation(),getNoNSSchemaLocation());
+        if(postInitAction!=null)    postInitAction.run();
+        if(prefixMapper!=null) {
+            // be defensive as we work with the user's code
+            String[] decls = prefixMapper.getContextualNamespaceDecls();
+            if(decls!=null) { // defensive check
+                for( int i=0; i<decls.length; i+=2 ) {
+                    String prefix = decls[i];
+                    String nsUri = decls[i+1];
+                    if(nsUri!=null && prefix!=null) // defensive check
+                        serializer.addInscopeBinding(nsUri,prefix);
+                }
+            }
+        }
+        serializer.setPrefixMapper(prefixMapper);
+    }
+
+    private void postwrite(XmlOutput out) throws IOException, SAXException, XMLStreamException {
+        serializer.endDocument();
+        serializer.reconcileID();   // extra check
+        out.flush();
+    }
+
+
+    //
+    //
+    // create XMLWriter by specifing various type of output.
+    //
+    //
+
+    protected CharacterEscapeHandler createEscapeHandler( String encoding ) {
+        if( escapeHandler!=null )
+            // user-specified one takes precedence.
+            return escapeHandler;
+
+        if( encoding.startsWith("UTF") )
+            // no need for character reference. Use the handler
+            // optimized for that pattern.
+            return MinimumEscapeHandler.theInstance;
+
+        // otherwise try to find one from the encoding
+        try {
+            // try new JDK1.4 NIO
+            return new NioEscapeHandler( getJavaEncoding(encoding) );
+        } catch( Throwable e ) {
+            // if that fails, fall back to the dumb mode
+            return DumbEscapeHandler.theInstance;
+        }
+    }
+
+    public XmlOutput createWriter( Writer w, String encoding ) {
+        // XMLWriter doesn't do buffering, so do it here if it looks like a good idea
+        if(!(w instanceof BufferedWriter))
+            w = new BufferedWriter(w);
+
+        assert toBeFlushed==null;
+        toBeFlushed = w;
+
+        CharacterEscapeHandler ceh = createEscapeHandler(encoding);
+        XMLWriter xw;
+
+        if(isFormattedOutput()) {
+            DataWriter d = new DataWriter(w,encoding,ceh);
+            d.setIndentStep(indent);
+            xw=d;
+        } else
+            xw = new XMLWriter(w,encoding,ceh);
+
+        xw.setXmlDecl(!isFragment());
+        xw.setHeader(header);
+        return new SAXOutput(xw);   // TODO: don't we need a better writer?
+    }
+
+    public XmlOutput createWriter(Writer w) {
+        return createWriter(w, getEncoding());
+    }
+
+    public XmlOutput createWriter( OutputStream os ) throws JAXBException {
+        return createWriter(os, getEncoding());
+    }
+
+    public XmlOutput createWriter( OutputStream os, String encoding ) throws JAXBException {
+        // UTF8XmlOutput does buffering on its own, and
+        // otherwise createWriter(Writer) inserts a buffering,
+        // so no point in doing a buffering here.
+
+        if(encoding.equals("UTF-8")) {
+            Encoded[] table = context.getUTF8NameTable();
+            if(isFormattedOutput())
+                return new IndentingUTF8XmlOutput(os,indent,table);
+            else {
+                if(c14nSupport)
+                    return new C14nXmlOutput(os,table,context.c14nSupport);
+                else
+                    return new UTF8XmlOutput(os,table);
+            }
+        }
+
+        try {
+            return createWriter(
+                new OutputStreamWriter(os,getJavaEncoding(encoding)),
+                encoding );
+        } catch( UnsupportedEncodingException e ) {
+            throw new MarshalException(
+                Messages.UNSUPPORTED_ENCODING.format(encoding),
+                e );
+        }
+    }
+
+
+    public Object getProperty(String name) throws PropertyException {
+        if( INDENT_STRING.equals(name) )
+            return indent;
+        if( ENCODING_HANDLER.equals(name) )
+            return escapeHandler;
+        if( PREFIX_MAPPER.equals(name) )
+            return prefixMapper;
+        if( XMLDECLARATION.equals(name) )
+            return !isFragment();
+        if( XML_HEADERS.equals(name) )
+            return header;
+        if( C14N.equals(name) )
+            return c14nSupport;
+
+        return super.getProperty(name);
+    }
+
+    public void setProperty(String name, Object value) throws PropertyException {
+        if( INDENT_STRING.equals(name) ) {
+            checkString(name, value);
+            indent = (String)value;
+            return;
+        }
+        if( ENCODING_HANDLER.equals(name) ) {
+            if(!(value instanceof CharacterEscapeHandler))
+                throw new PropertyException(
+                    Messages.MUST_BE_X.format(
+                            name,
+                            CharacterEscapeHandler.class.getName(),
+                            value.getClass().getName() ) );
+            escapeHandler = (CharacterEscapeHandler)value;
+            return;
+        }
+        if( PREFIX_MAPPER.equals(name) ) {
+            if(!(value instanceof NamespacePrefixMapper))
+                throw new PropertyException(
+                    Messages.MUST_BE_X.format(
+                            name,
+                            NamespacePrefixMapper.class.getName(),
+                            value.getClass().getName() ) );
+            prefixMapper = (NamespacePrefixMapper)value;
+            return;
+        }
+        if( XMLDECLARATION.equals(name) ) {
+            checkBoolean(name, value);
+            // com.sun.xml.internal.bind.xmlDeclaration is an alias for JAXB_FRAGMENT
+            // setting it to false is treated the same as setting fragment to true.
+            super.setProperty(JAXB_FRAGMENT, !(Boolean)value);
+            return;
+        }
+        if( XML_HEADERS.equals(name) ) {
+            checkString(name, value);
+            header = (String)value;
+            return;
+        }
+        if( C14N.equals(name) ) {
+            checkBoolean(name,value);
+            c14nSupport = (Boolean)value;
+            return;
+        }
+
+        super.setProperty(name, value);
+    }
+
+    /*
+     * assert that the given object is a Boolean
+     */
+    private void checkBoolean( String name, Object value ) throws PropertyException {
+        if(!(value instanceof Boolean))
+            throw new PropertyException(
+                Messages.MUST_BE_X.format(
+                        name,
+                        Boolean.class.getName(),
+                        value.getClass().getName() ) );
+    }
+
+    /*
+     * assert that the given object is a String
+     */
+    private void checkString( String name, Object value ) throws PropertyException {
+        if(!(value instanceof String))
+            throw new PropertyException(
+                Messages.MUST_BE_X.format(
+                        name,
+                        String.class.getName(),
+                        value.getClass().getName() ) );
+    }
+
+    @Override
+    public <A extends XmlAdapter> void setAdapter(Class<A> type, A adapter) {
+        if(type==null)
+            throw new IllegalArgumentException();
+        serializer.putAdapter(type,adapter);
+    }
+
+    @Override
+    public <A extends XmlAdapter> A getAdapter(Class<A> type) {
+        if(type==null)
+            throw new IllegalArgumentException();
+        if(serializer.containsAdapter(type))
+            // so as not to create a new instance when this method is called
+            return serializer.getAdapter(type);
+        else
+            return null;
+    }
+
+    @Override
+    public void setAttachmentMarshaller(AttachmentMarshaller am) {
+        serializer.attachmentMarshaller = am;
+    }
+
+    @Override
+    public AttachmentMarshaller getAttachmentMarshaller() {
+        return serializer.attachmentMarshaller;
+    }
+
+    public Schema getSchema() {
+        return schema;
+    }
+
+    public void setSchema(Schema s) {
+        this.schema = s;
+    }
+
+    /**
+     * Default error handling behavior fot {@link Marshaller}.
+     */
+    public boolean handleEvent(ValidationEvent event) {
+        // draconian by default
+        return false;
+    }
+
+    public Listener getListener() {
+        return externalListener;
+    }
+
+    public void setListener(Listener listener) {
+        externalListener = listener;
+    }
+
+    // features supported
+    protected static final String INDENT_STRING = "com.sun.xml.internal.bind.indentString";
+    protected static final String PREFIX_MAPPER = "com.sun.xml.internal.bind.namespacePrefixMapper";
+    protected static final String ENCODING_HANDLER = "com.sun.xml.internal.bind.characterEscapeHandler";
+    protected static final String XMLDECLARATION = "com.sun.xml.internal.bind.xmlDeclaration";
+    protected static final String XML_HEADERS = "com.sun.xml.internal.bind.xmlHeaders";
+    protected static final String C14N = JAXBRIContext.CANONICALIZATION_SUPPORT;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Messages.java
new file mode 100644
index 0000000..0d74210
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Messages.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources
+ */
+enum Messages {
+    ILLEGAL_PARAMETER, // 2 args
+    UNABLE_TO_FIND_CONVERSION_METHOD, // 3 args
+    MISSING_ID, // 1 arg
+    NOT_IMPLEMENTED_IN_2_0,
+    UNRECOGNIZED_ELEMENT_NAME,
+    TYPE_MISMATCH, // 3 args
+    MISSING_OBJECT, // 1 arg
+    NOT_IDENTIFIABLE, // 0 args
+    DANGLING_IDREF, // 1 arg
+    NULL_OUTPUT_RESOLVER, // 0 args
+    UNABLE_TO_MARSHAL_NON_ELEMENT, // 1 arg
+    UNSUPPORTED_PROPERTY, // 1 arg
+    NULL_PROPERTY_NAME, // 0 args
+    MUST_BE_X, // 3 args
+    NOT_MARSHALLABLE, // 0 args
+    UNSUPPORTED_RESULT, // 0 args
+    UNSUPPORTED_ENCODING, // 1 arg
+    SUBSTITUTED_BY_ANONYMOUS_TYPE, // 3 arg
+    CYCLE_IN_MARSHALLER, // 1 arg
+    UNABLE_TO_DISCOVER_EVENTHANDLER, // 1 arg
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Messages.properties
new file mode 100644
index 0000000..d3c25d9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Messages.properties
@@ -0,0 +1,61 @@
+NOT_MARSHALLABLE = \
+	the object parameter to marshal() is not marshallable
+
+UNSUPPORTED_RESULT = \
+	unsupported javax.xml.parser.transform.Result parameter
+
+UNSUPPORTED_ENCODING = \
+	unsupported encoding: {0}
+
+ILLEGAL_PARAMETER = \
+    Illegal "{0}" parameter: {1}
+
+UNABLE_TO_FIND_CONVERSION_METHOD = \
+    {0} doesn''t have a method {1} {2}();
+
+MISSING_ID = \
+    Object "{0}" is found in an IDREF property but this object doesn't have an ID.
+
+NOT_IMPLEMENTED_IN_2_0 = \
+    This feature is not available in JAXB RI 2.0
+
+UNRECOGNIZED_ELEMENT_NAME = \
+    The tag name "{0}" is not known to this JAXBContext.
+
+TYPE_MISMATCH = \
+	"{1}" property of a "{0}" object contains an object of type "{2}" but this is not allowed. \
+	See javadoc of this property for what this property can accept.
+
+MISSING_OBJECT = \
+	a required field "{0}" is missing an object
+
+NOT_IDENTIFIABLE = \
+	An object is referenced as IDREF but its ID field is null
+
+DANGLING_IDREF = \
+	A tree contains a reference to ID "{0}" but it's not a part of the object graph
+
+NULL_OUTPUT_RESOLVER = \
+    schema output resolver must not be null
+
+UNABLE_TO_MARSHAL_NON_ELEMENT = \
+    unable to marshal type "{0}" as an element because it is missing an @XmlRootElement annotation
+
+UNSUPPORTED_PROPERTY = \
+    "{0}" is not a supported property
+
+NULL_PROPERTY_NAME = \
+    property name parameter can not be null
+
+MUST_BE_X = \
+    property "{0}" must be an instance of type {1}, not {2}
+    
+SUBSTITUTED_BY_ANONYMOUS_TYPE = \
+    Instance of "{1}" is substituting "{0}", but "{2}" is bound to an anonymous type.
+
+CYCLE_IN_MARSHALLER = \
+    A cycle is detected in the object graph. This will cause infinitely deep XML: {0}
+
+UNABLE_TO_DISCOVER_EVENTHANDLER = \
+    Unable to list methods of "{0}". If there is any event callback handler on this class, it will be ignored.
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/MimeTypedTransducer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/MimeTypedTransducer.java
new file mode 100644
index 0000000..20b088e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/MimeTypedTransducer.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.awt.*;
+import java.io.IOException;
+
+import javax.activation.MimeType;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Transducer} decorator that wraps another {@link Transducer}
+ * and sets the expected MIME type to the context.
+ *
+ * <p>
+ * Combined with {@link Transducer} implementations (such as one for {@link Image}),
+ * this is used to control the marshalling of the BLOB types.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class MimeTypedTransducer<V> extends FilterTransducer<V> {
+    private final MimeType expectedMimeType;
+
+    public MimeTypedTransducer(Transducer<V> core,MimeType expectedMimeType) {
+        super(core);
+        this.expectedMimeType = expectedMimeType;
+    }
+
+    @Override
+    public CharSequence print(V o) throws AccessorException {
+        XMLSerializer w = XMLSerializer.getInstance();
+        MimeType old = w.setExpectedMimeType(expectedMimeType);
+        try {
+            return core.print(o);
+        } finally {
+            w.setExpectedMimeType(old);
+        }
+    }
+
+    @Override
+    public void writeText(XMLSerializer w, V o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        MimeType old = w.setExpectedMimeType(expectedMimeType);
+        try {
+            core.writeText(w, o, fieldName);
+        } finally {
+            w.setExpectedMimeType(old);
+        }
+    }
+
+    @Override
+    public void writeLeafElement(XMLSerializer w, Name tagName, V o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        MimeType old = w.setExpectedMimeType(expectedMimeType);
+        try {
+            core.writeLeafElement(w, tagName, o, fieldName);
+        } finally {
+            w.setExpectedMimeType(old);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Name.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Name.java
new file mode 100644
index 0000000..4db0810
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Name.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import javax.xml.namespace.QName;
+
+/**
+ * The internal representation of an XML name.
+ *
+ * <p>
+ * This class keeps indicies for URI and local name for enabling faster processing.
+ *
+ * <p>
+ * {@link Name}s are ordered lexicographically (nsUri first, local name next.)
+ * This is the same order required by canonical XML.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Name implements Comparable<Name> {
+    /**
+     * Namespace URI. interned.
+     */
+    public final String nsUri;
+
+    /**
+     * Local name. interned.
+     */
+    public final String localName;
+
+    /**
+     * Index -1 is reserved for representing the empty namespace URI of attributes.
+     */
+    public final short nsUriIndex;
+    public final short localNameIndex;
+
+    /**
+     * Index of the Name for an EII or AII
+     */
+    public final short qNameIndex;
+
+    /**
+     * Specifies if the Name is associated with an EII or AII
+     */
+    public final boolean isAttribute;
+
+    Name(int qNameIndex, int nsUriIndex, String nsUri, int localIndex, String localName, boolean isAttribute) {
+        this.qNameIndex = (short)qNameIndex;
+        this.nsUri = nsUri;
+        this.localName = localName;
+        this.nsUriIndex = (short)nsUriIndex;
+        this.localNameIndex = (short)localIndex;
+        this.isAttribute = isAttribute;
+    }
+
+    public String toString() {
+        return '{'+nsUri+'}'+localName;
+    }
+
+    /**
+     * Creates a {@link QName} from this.
+     */
+    public QName toQName() {
+        return new QName(nsUri,localName);
+    }
+
+    public boolean equals( String nsUri, String localName ) {
+        return localName.equals(this.localName) && nsUri.equals(this.nsUri);
+    }
+
+    public int compareTo(Name that) {
+        int r = this.nsUri.compareTo(that.nsUri);
+        if(r!=0)    return r;
+        return this.localName.compareTo(that.localName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NameBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NameBuilder.java
new file mode 100644
index 0000000..82a4994
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NameBuilder.java
@@ -0,0 +1,143 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+/**
+ * Creates {@link Name}s and assign index numbers to them.
+ *
+ * <p>
+ * During this process, this class also finds out which namespace URIs
+ * are statically known to be un-bindable as the default namespace.
+ * Those are the namespace URIs that are used by attribute names.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@SuppressWarnings({"StringEquality"})
+public final class NameBuilder {
+    private Map<String,Integer> uriIndexMap = new HashMap<String, Integer>();
+    private Set<String> nonDefaultableNsUris = new HashSet<String>();
+    private Map<String,Integer> localNameIndexMap = new HashMap<String, Integer>();
+    private QNameMap<Integer> elementQNameIndexMap = new QNameMap<Integer>();
+    private QNameMap<Integer> attributeQNameIndexMap = new QNameMap<Integer>();
+
+    public Name createElementName(QName name) {
+        return createElementName(name.getNamespaceURI(),name.getLocalPart());
+    }
+
+    public Name createElementName(String nsUri, String localName) {
+        return createName(nsUri, localName, false, elementQNameIndexMap);
+    }
+
+    public Name createAttributeName(QName name) {
+        return createAttributeName(name.getNamespaceURI(),name.getLocalPart());
+    }
+
+    public Name createAttributeName(String nsUri, String localName) {
+        assert nsUri.intern()==nsUri;
+        assert localName.intern()==localName;
+
+        if(nsUri.length()==0)
+            return new Name(
+                    allocIndex(attributeQNameIndexMap,"",localName),
+                    -1,
+                    nsUri,
+                    allocIndex(localNameIndexMap,localName),
+                    localName,
+                    true);
+        else {
+            nonDefaultableNsUris.add(nsUri);
+            return createName(nsUri,localName, true, attributeQNameIndexMap);
+        }
+    }
+
+    private Name createName(String nsUri, String localName, boolean isAttribute, QNameMap<Integer> map) {
+        assert nsUri.intern()==nsUri;
+        assert localName.intern()==localName;
+
+        return new Name(
+                allocIndex(map,nsUri,localName),
+                allocIndex(uriIndexMap,nsUri),
+                nsUri,
+                allocIndex(localNameIndexMap,localName),
+                localName,
+                isAttribute );
+    }
+
+    private int allocIndex(Map<String,Integer> map, String str) {
+        Integer i = map.get(str);
+        if(i==null) {
+            i = map.size();
+            map.put(str,i);
+        }
+        return i;
+    }
+
+    private int allocIndex(QNameMap<Integer> map, String nsUri, String localName) {
+        Integer i = map.get(nsUri,localName);
+        if(i==null) {
+            i = map.size();
+            map.put(nsUri,localName,i);
+        }
+        return i;
+    }
+
+    /**
+     * Wraps up everything and creates {@link NameList}.
+     */
+    public NameList conclude() {
+        boolean[] nsUriCannotBeDefaulted = new boolean[uriIndexMap.size()];
+        for (Map.Entry<String,Integer> e : uriIndexMap.entrySet()) {
+            nsUriCannotBeDefaulted[e.getValue()] = nonDefaultableNsUris.contains(e.getKey());
+        }
+
+        NameList r = new NameList(
+                list(uriIndexMap),
+                nsUriCannotBeDefaulted,
+                list(localNameIndexMap),
+                elementQNameIndexMap.size(),
+                attributeQNameIndexMap.size() );
+        // delete them so that the create method can never be called again
+        uriIndexMap = null;
+        localNameIndexMap = null;
+        return r;
+    }
+
+    private String[] list(Map<String, Integer> map) {
+        String[] r = new String[map.size()];
+        for (Map.Entry<String, Integer> e : map.entrySet())
+            r[e.getValue()] = e.getKey();
+        return r;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NameList.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NameList.java
new file mode 100644
index 0000000..e0fc006
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NameList.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+/**
+ * Namespace URIs and local names sorted by their indices.
+ * Number of Names used for EIIs and AIIs
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class NameList {
+    /**
+     * Namespace URIs by their indices. No nulls in this array.
+     * Read-only.
+     */
+    public final String[] namespaceURIs;
+
+    /**
+     * For each entry in {@link #namespaceURIs}, whether the namespace URI
+     * can be declared as the default. If namespace URI is used in attributes,
+     * we always need a prefix, so we can't.
+     *
+     * True if this URI has to have a prefix.
+     */
+    public final boolean[] nsUriCannotBeDefaulted;
+
+    /**
+     * Local names by their indices. No nulls in this array.
+     * Read-only.
+     */
+    public final String[] localNames;
+
+    /**
+     * Number of Names for elements
+     */
+    public final int numberOfElementNames;
+
+    /**
+     * Number of Names for attributes
+     */
+    public final int numberOfAttributeNames;
+
+    public NameList(String[] namespaceURIs, boolean[] nsUriCannotBeDefaulted, String[] localNames, int numberElementNames, int numberAttributeNames) {
+        this.namespaceURIs = namespaceURIs;
+        this.nsUriCannotBeDefaulted = nsUriCannotBeDefaulted;
+        this.localNames = localNames;
+        this.numberOfElementNames = numberElementNames;
+        this.numberOfAttributeNames = numberAttributeNames;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NamespaceContext2.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NamespaceContext2.java
new file mode 100644
index 0000000..2e63730
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/NamespaceContext2.java
@@ -0,0 +1,77 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import javax.xml.namespace.NamespaceContext;
+
+/**
+ * Maintains namespace&lt;->prefix bindings.
+ *
+ * <p>
+ * This interface extends {@link NamespaceContext} and provides
+ * an additional functionality, which is necessary to declare
+ * namespaced attributes on elements. The added method is for
+ * self-consumption by the marshaller.
+ *
+ * This object is composed into a Serializer.
+ */
+public interface NamespaceContext2 extends NamespaceContext
+{
+    /**
+     * Declares a new namespace binding within the current context.
+     *
+     * <p>
+     * The prefix is automatically assigned by MarshallingContext. If
+     * a given namespace URI is already declared, nothing happens.
+     *
+     * <p>
+     * It is <b>NOT</b> an error to declare the same namespace URI
+     * more than once.
+     *
+     * <p>
+     * For marshalling to work correctly, all namespace bindings
+     * for an element must be declared between its startElement method and
+     * its endAttributes event. Calling the same method with the same
+     * parameter between the endAttributes and the endElement returns
+     * the same prefix.
+     *
+     * @param   requirePrefix
+     *      If this parameter is true, this method must assign a prefix
+     *      to this namespace, even if it's already bound to the default
+     *      namespace. IOW, this method will never return null if this
+     *      flag is true. This functionality is necessary to declare
+     *      namespace URI used for attribute names.
+     * @param   preferedPrefix
+     *      If the caller has any particular preference to the
+     *      prefix, pass that as a parameter. The callee will try
+     *      to honor it. Set null if there's no particular preference.
+     *
+     * @return
+     *      returns the assigned prefix. If the namespace is bound to
+     *      the default namespace, null is returned.
+     */
+    String declareNamespace( String namespaceUri, String preferedPrefix, boolean requirePrefix );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/RuntimeUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/RuntimeUtil.java
new file mode 100644
index 0000000..6921a9c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/RuntimeUtil.java
@@ -0,0 +1,133 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.helpers.PrintConversionEventImpl;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.bind.helpers.ValidationEventLocatorImpl;
+
+import com.sun.xml.internal.bind.util.ValidationEventLocatorExImpl;
+
+import org.xml.sax.SAXException;
+
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class RuntimeUtil {
+    /**
+     * XmlAdapter for printing arbitrary object by using {@link Object#toString()}.
+     */
+    public static final class ToStringAdapter extends XmlAdapter<String,Object> {
+        public Object unmarshal(String s) {
+            throw new UnsupportedOperationException();
+        }
+
+        public String marshal(Object o) {
+            if(o==null)     return null;
+            return o.toString();
+        }
+    }
+
+    /**
+     * Map from {@link Class} objects representing primitive types
+     * to {@link Class} objects representing their boxed types.
+     * <p>
+     * e.g., int -> Integer.
+     */
+    public static final Map<Class,Class> boxToPrimitive;
+
+    /**
+     * Reverse map of {@link #boxToPrimitive}.
+     */
+    public static final Map<Class,Class> primitiveToBox;
+
+    static {
+        Map<Class,Class> b = new HashMap<Class,Class>();
+        b.put(Byte.TYPE,Byte.class);
+        b.put(Short.TYPE,Short.class);
+        b.put(Integer.TYPE,Integer.class);
+        b.put(Long.TYPE,Long.class);
+        b.put(Character.TYPE,Character.class);
+        b.put(Boolean.TYPE,Boolean.class);
+        b.put(Float.TYPE,Float.class);
+        b.put(Double.TYPE,Double.class);
+        b.put(Void.TYPE,Void.class);
+
+        primitiveToBox = Collections.unmodifiableMap(b);
+
+        Map<Class,Class> p = new HashMap<Class,Class>();
+        for( Map.Entry<Class,Class> e :  b.entrySet() )
+            p.put(e.getValue(),e.getKey());
+
+        boxToPrimitive = Collections.unmodifiableMap(p);
+    }
+
+    /**
+     * Reports a print conversion error while marshalling.
+     */
+    public static void handlePrintConversionException(
+        Object caller, Exception e, XMLSerializer serializer ) throws SAXException {
+
+        if( e instanceof SAXException )
+            // assume this exception is not from application.
+            // (e.g., when a marshaller aborts the processing, this exception
+            //        will be thrown)
+            throw (SAXException)e;
+
+        ValidationEvent ve = new PrintConversionEventImpl(
+            ValidationEvent.ERROR, e.getMessage(),
+            new ValidationEventLocatorImpl(caller), e );
+        serializer.reportError(ve);
+    }
+
+    /**
+     * Reports that the type of an object in a property is unexpected.
+     */
+    public static void handleTypeMismatchError( XMLSerializer serializer,
+            Object parentObject, String fieldName, Object childObject ) throws SAXException {
+
+         ValidationEvent ve = new ValidationEventImpl(
+            ValidationEvent.ERROR, // maybe it should be a fatal error.
+             Messages.TYPE_MISMATCH.format(
+                getTypeName(parentObject),
+                fieldName,
+                getTypeName(childObject) ),
+            new ValidationEventLocatorExImpl(parentObject,fieldName) );
+
+        serializer.reportError(ve);
+    }
+
+    private static String getTypeName( Object o ) {
+        return o.getClass().getName();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/SchemaTypeTransducer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/SchemaTypeTransducer.java
new file mode 100644
index 0000000..1b1db3b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/SchemaTypeTransducer.java
@@ -0,0 +1,87 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.bind.annotation.XmlSchemaType;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Transducer} that signals the runtime that this datatype
+ * is marshalled to a different XML Schema type.
+ *
+ * <p>
+ * This transducer is used to implement the semantics of {@link XmlSchemaType} annotation.
+ *
+ *
+ * @see XMLSerializer#schemaType
+ * @author Kohsuke Kawaguchi
+ */
+public class SchemaTypeTransducer<V> extends FilterTransducer<V> {
+    private final QName schemaType;
+
+    public SchemaTypeTransducer(Transducer<V> core, QName schemaType) {
+        super(core);
+        this.schemaType = schemaType;
+    }
+
+    @Override
+    public CharSequence print(V o) throws AccessorException {
+        XMLSerializer w = XMLSerializer.getInstance();
+        QName old = w.setSchemaType(schemaType);
+        try {
+            return core.print(o);
+        } finally {
+            w.setSchemaType(old);
+        }
+    }
+
+    @Override
+    public void writeText(XMLSerializer w, V o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        QName old = w.setSchemaType(schemaType);
+        try {
+            core.writeText(w,o,fieldName);
+        } finally {
+            w.setSchemaType(old);
+        }
+    }
+
+    @Override
+    public void writeLeafElement(XMLSerializer w, Name tagName, V o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException {
+        QName old = w.setSchemaType(schemaType);
+        try {
+            core.writeLeafElement(w, tagName, o, fieldName);
+        } finally {
+            w.setSchemaType(old);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/StAXPostInitAction.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/StAXPostInitAction.java
new file mode 100644
index 0000000..023e0f9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/StAXPostInitAction.java
@@ -0,0 +1,89 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.XMLEventWriter;
+import javax.xml.stream.XMLStreamWriter;
+
+/**
+ * Post-init action for {@link MarshallerImpl} that incorporate the in-scope namespace bindings
+ * from a StAX writer.
+ *
+ * <p>
+ * It's always used either with {@link XMLStreamWriter}, {@link XMLEventWriter}, or bare
+ * {@link NamespaceContext},
+ * but to reduce the # of classes in the runtime I wrote only one class that handles both.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class StAXPostInitAction implements Runnable {
+    private final XMLStreamWriter xsw;
+    private final XMLEventWriter xew;
+    private final NamespaceContext nsc;
+    private final XMLSerializer serializer;
+
+    StAXPostInitAction(XMLStreamWriter xsw,XMLSerializer serializer) {
+        this.xsw = xsw;
+        this.xew = null;
+        this.nsc = null;
+        this.serializer = serializer;
+    }
+
+    StAXPostInitAction(XMLEventWriter xew,XMLSerializer serializer) {
+        this.xsw = null;
+        this.xew = xew;
+        this.nsc = null;
+        this.serializer = serializer;
+    }
+
+    StAXPostInitAction(NamespaceContext nsc,XMLSerializer serializer) {
+        this.xsw = null;
+        this.xew = null;
+        this.nsc = nsc;
+        this.serializer = serializer;
+    }
+
+    public void run() {
+        NamespaceContext ns = nsc;
+        if(xsw!=null)   ns = xsw.getNamespaceContext();
+        if(xew!=null)   ns = xew.getNamespaceContext();
+
+        // StAX javadoc isn't very clear on the behavior,
+        // so work defensively in anticipation of broken implementations.
+        if(ns==null)
+            return;
+
+        // we can't enumerate all the in-scope namespace bindings in StAX,
+        // so we only look for the known static namespace URIs.
+        // this is less than ideal, but better than nothing.
+        for( String nsUri : serializer.grammar.nameList.namespaceURIs ) {
+            String p = ns.getPrefix(nsUri);
+            if(p!=null)
+                serializer.addInscopeBinding(nsUri,p);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/SwaRefAdapter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/SwaRefAdapter.java
new file mode 100644
index 0000000..2e2d2ad
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/SwaRefAdapter.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+
+import javax.activation.DataHandler;
+import javax.xml.bind.annotation.XmlAttachmentRef;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+
+/**
+ * {@link XmlAdapter} that binds the value as a SOAP attachment.
+ *
+ * <p>
+ * On the user classes the SwA handling is done by using the {@link XmlAttachmentRef}
+ * annotation, but internally we treat it as a {@link XmlJavaTypeAdapter} with this
+ * adapter class. This is true with both XJC and the runtime.
+ *
+ * <p>
+ * the model builder code and the code generator does the conversion and
+ * shield the rest of the RI from this mess.
+ * Also see @see <a href="http://webservices.xml.com/pub/a/ws/2003/09/16/wsbp.html?page=2">http://webservices.xml.com/pub/a/ws/2003/09/16/wsbp.html?page=2</a>.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class SwaRefAdapter extends XmlAdapter<String,DataHandler> {
+
+    public SwaRefAdapter() {
+    }
+
+    public DataHandler unmarshal(String cid) {
+        AttachmentUnmarshaller au = UnmarshallingContext.getInstance().parent.getAttachmentUnmarshaller();
+        // TODO: error check
+        return au.getAttachmentAsDataHandler(cid);
+    }
+
+    public String marshal(DataHandler data) {
+        if(data==null)      return null;
+        AttachmentMarshaller am = XMLSerializer.getInstance().attachmentMarshaller;
+        // TODO: error check
+        return am.addSwaRefAttachment(data);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Transducer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Transducer.java
new file mode 100644
index 0000000..c47a7bb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/Transducer.java
@@ -0,0 +1,134 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+
+import javax.xml.bind.annotation.XmlValue;
+import javax.xml.datatype.XMLGregorianCalendar;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.reflect.opt.OptimizedTransducedAccessorFactory;
+
+import org.xml.sax.SAXException;
+
+
+/**
+ * Responsible for converting a Java object to a lexical representation
+ * and vice versa.
+ *
+ * <p>
+ * An implementation of this interface hides how this conversion happens.
+ *
+ * <p>
+ * {@link Transducer}s are immutable.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface Transducer<ValueT> {
+
+    /**
+     * If this {@link Transducer} is the default transducer for the <code>ValueT</code>,
+     * this method returns true.
+     *
+     * Used exclusively by {@link OptimizedTransducedAccessorFactory#get(RuntimePropertyInfo)}
+     */
+    boolean isDefault();
+
+    /**
+     * If true, this {@link Transducer} doesn't declare any namespace,
+     * and therefore {@link #declareNamespace(Object, XMLSerializer)} is no-op.
+     *
+     * It also means that the {@link #parse(CharSequence)} method
+     * won't use the context parameter.
+     */
+    boolean useNamespace();
+
+    /**
+     * Declares the namespace URIs used in the given value to {@code w}.
+     *
+     * @param o
+     *      never be null.
+     * @param w
+     *      may be null if {@code !{@link #useNamespace()}}.
+     */
+    void declareNamespace( ValueT o, XMLSerializer w ) throws AccessorException;
+
+    /**
+     * Converts the given value to its lexical representation.
+     *
+     * @param o
+     *      never be null.
+     * @return
+     *      always non-null valid lexical representation.
+     */
+    @NotNull CharSequence print(@NotNull ValueT o) throws AccessorException;
+
+    /**
+     * Converts the lexical representation to a value object.
+     *
+     * @param lexical
+     *      never be null.
+     * @throws AccessorException
+     *      if the transducer is used to parse an user bean that uses {@link XmlValue},
+     *      then this exception may occur when it tries to set the leaf value to the bean.
+     * @throws SAXException
+     *      if the lexical form is incorrect, the error should be reported
+     *      and SAXException may thrown (or it can return null to recover.)
+     */
+    ValueT parse(CharSequence lexical) throws AccessorException, SAXException;
+
+    /**
+     * Sends the result of the {@link #print(Object)} operation
+     * to one of the {@link XMLSerializer#text(String, String)} method,
+     * but with the best representation of the value, not necessarily String.
+     */
+    void writeText(XMLSerializer w, ValueT o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException;
+
+    /**
+     * Sends the result of the {@link #print(Object)} operation
+     * to one of the {@link XMLSerializer#leafElement(Name, String, String)} method.
+     * but with the best representation of the value, not necessarily String.
+     */
+    void writeLeafElement(XMLSerializer w, Name tagName, @NotNull ValueT o, String fieldName) throws IOException, SAXException, XMLStreamException, AccessorException;
+
+    /**
+     * Transducers implicitly work against a single XML type,
+     * but sometimes (most notably {@link XMLGregorianCalendar},
+     * an instance may choose different XML types.
+     *
+     * @return
+     *      return non-null from this method allows transducers
+     *      to specify the type it wants to marshal to.
+     *      Most of the time this method returns null, in which case
+     *      the implicitly associated type will be used.
+     */
+    QName getTypeName(@NotNull ValueT instance);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ValueListBeanInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ValueListBeanInfoImpl.java
new file mode 100644
index 0000000..8ed9574
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/ValueListBeanInfoImpl.java
@@ -0,0 +1,172 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.lang.reflect.Array;
+import java.util.List;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.FinalArrayList;
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link JaxBeanInfo} implementation that binds T[] to a list of simple types.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ValueListBeanInfoImpl extends JaxBeanInfo {
+
+    private final Class itemType;
+    private final Transducer xducer;    // for items
+
+    public ValueListBeanInfoImpl(JAXBContextImpl owner, Class arrayType) throws JAXBException {
+        super(owner, null, arrayType, false, true, false);
+        this.itemType = jaxbType.getComponentType();
+        this.xducer = owner.getBeanInfo(arrayType.getComponentType(),true).getTransducer();
+        assert xducer!=null;
+    }
+
+    private final Loader loader = new Loader(true) {
+        @Override
+        public void text(UnmarshallingContext.State state, CharSequence text) throws SAXException {
+            List<Object> r = new FinalArrayList<Object>();
+
+            int idx = 0;
+            int len = text.length();
+
+            while(true) {
+                int p = idx;
+                while( p<len && !WhiteSpaceProcessor.isWhiteSpace(text.charAt(p)) )
+                    p++;
+
+                CharSequence token = text.subSequence(idx,p);
+                if (!token.equals(""))
+                    try {
+                        r.add(xducer.parse(token));
+                    } catch (AccessorException e) {
+                        handleGenericException(e,true);
+                        continue;   // move on to next
+                    }
+
+                if(p==len)      break;  // done
+
+                while( p<len && WhiteSpaceProcessor.isWhiteSpace(text.charAt(p)) )
+                    p++;
+                if(p==len)      break;  // done
+
+                idx = p;
+            }
+
+            state.target = toArray(r);
+        }
+    };
+
+    private Object toArray( List list ) {
+        int len = list.size();
+        Object array = Array.newInstance(itemType,len);
+        for( int i=0; i<len; i++ )
+            Array.set(array,i,list.get(i));
+        return array;
+    }
+
+    public void serializeBody(Object array, XMLSerializer target) throws SAXException, IOException, XMLStreamException {
+        int len = Array.getLength(array);
+        for( int i=0; i<len; i++ )  {
+            Object item = Array.get(array,i);
+            try {
+                xducer.writeText(target,item,"arrayItem");
+            } catch (AccessorException e) {
+                target.reportError("arrayItem",e);
+            }
+        }
+    }
+
+    public final void serializeURIs(Object array, XMLSerializer target) throws SAXException {
+        if(xducer.useNamespace()) {
+            int len = Array.getLength(array);
+            for( int i=0; i<len; i++ )  {
+                Object item = Array.get(array,i);
+                try {
+                    xducer.declareNamespace(item,target);
+                } catch (AccessorException e) {
+                    target.reportError("arrayItem",e);
+                }
+            }
+        }
+    }
+
+    public final String getElementNamespaceURI(Object array) {
+        throw new UnsupportedOperationException();
+    }
+
+    public final String getElementLocalName(Object array) {
+        throw new UnsupportedOperationException();
+    }
+
+    public final Object createInstance(UnmarshallingContext context) {
+        throw new UnsupportedOperationException();
+    }
+
+    public final boolean reset(Object array, UnmarshallingContext context) {
+        return false;
+    }
+
+    public final String getId(Object array, XMLSerializer target) {
+        return null;
+    }
+
+    public final void serializeAttributes(Object array, XMLSerializer target) {
+        // noop
+    }
+
+    public final void serializeRoot(Object array, XMLSerializer target) throws SAXException {
+        target.reportError(
+                new ValidationEventImpl(
+                        ValidationEvent.ERROR,
+                        Messages.UNABLE_TO_MARSHAL_NON_ELEMENT.format(array.getClass().getName()),
+                        null,
+                        null));
+    }
+
+    public final Transducer getTransducer() {
+        return null;
+    }
+
+    public final Loader getLoader(JAXBContextImpl context, boolean typeSubstitutionCapable) {
+        // type substitution impossible
+        return loader;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/XMLSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/XMLSerializer.java
new file mode 100644
index 0000000..fb85c09
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/XMLSerializer.java
@@ -0,0 +1,987 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime;
+
+import java.io.IOException;
+import java.lang.reflect.Method;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+
+import javax.activation.MimeType;
+import javax.xml.bind.DatatypeConverter;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.ValidationEventLocator;
+import javax.xml.bind.annotation.DomHandler;
+import javax.xml.bind.annotation.XmlSchemaType;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.bind.helpers.NotIdentifiableEventImpl;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.bind.helpers.ValidationEventLocatorImpl;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.sax.SAXResult;
+
+import com.sun.istack.internal.SAXException2;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.marshaller.NamespacePrefixMapper;
+import com.sun.xml.internal.bind.util.ValidationEventLocatorExImpl;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeBuiltinLeafInfo;
+import com.sun.xml.internal.bind.v2.runtime.output.MTOMXmlOutput;
+import com.sun.xml.internal.bind.v2.runtime.output.NamespaceContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.output.Pcdata;
+import com.sun.xml.internal.bind.v2.runtime.output.XmlOutput;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Base64Data;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.IntData;
+import com.sun.xml.internal.bind.v2.util.CollisionCheckStack;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Receives XML serialization event and writes to {@link XmlOutput}.
+ *
+ * <p>
+ * This object coordinates the overall marshalling efforts across different
+ * content-tree objects and different target formats.
+ *
+ * <p>
+ * The following CFG gives the proper sequence of method invocation.
+ *
+ * <pre>
+ * MARSHALLING  :=  ELEMENT
+ * ELEMENT      :=  "startElement" NSDECL* "endNamespaceDecls"
+ *                        ATTRIBUTE* "endAttributes" BODY "endElement"
+ *
+ * NSDECL       :=  "declareNamespace"
+ *
+ * ATTRIBUTE    :=  "attribute"
+ * ATTVALUES    :=  "text"*
+ *
+ *
+ * BODY         :=  ( "text" | ELEMENT )*
+ * </pre>
+ *
+ * <p>
+ * A marshalling of one element consists of two stages. The first stage is
+ * for marshalling attributes and collecting namespace declarations.
+ * The second stage is for marshalling characters/child elements of that element.
+ *
+ * <p>
+ * Observe that multiple invocation of "text" is allowed.
+ *
+ * <p>
+ * Also observe that the namespace declarations are allowed only between
+ * "startElement" and "endAttributes".
+ *
+ * <h2>Exceptions in marshaller</h2>
+ * <p>
+ * {@link IOException}, {@link SAXException}, and {@link XMLStreamException}
+ * are thrown from {@link XmlOutput}. They are always considered fatal, and
+ * therefore caught only by {@link MarshallerImpl}.
+ * <p>
+ * {@link AccessorException} can be thrown when an access to a property/field
+ * fails, and this is considered as a recoverable error, so it's caught everywhere.
+ *
+ * @author  Kohsuke Kawaguchi
+ */
+public final class XMLSerializer extends Coordinator {
+    public final JAXBContextImpl grammar;
+
+    /** The XML printer. */
+    private XmlOutput out;
+
+    // TODO: fix the access modifier
+    public final NameList nameList;
+
+    // TODO: fix the access modifier
+    public final int[] knownUri2prefixIndexMap;
+
+    private final NamespaceContextImpl nsContext;
+
+    private NamespaceContextImpl.Element nse;
+
+    /**
+     * Set to true if a text is already written,
+     * and we need to print ' ' for additional text methods.
+     */
+    private boolean textHasAlreadyPrinted = false;
+
+    /**
+     * Set to false once we see the start tag of the root element.
+     */
+    private boolean seenRoot = false;
+
+    /** Marshaller object to which this object belongs. */
+    private final MarshallerImpl marshaller;
+
+    /** Objects referenced through IDREF. */
+    private final Set<Object> idReferencedObjects = new HashSet<Object>();
+
+    /** Objects with ID. */
+    private final Set<Object> objectsWithId = new HashSet<Object>();
+
+    /**
+     * Used to detect cycles in the object.
+     * Also used to learn what's being marshalled.
+     */
+    private final CollisionCheckStack<Object> cycleDetectionStack = new CollisionCheckStack<Object>();
+
+    /** Optional attributes to go with root element. */
+    private String schemaLocation;
+    private String noNsSchemaLocation;
+
+    /** Lazily created identitiy transformer. */
+    private Transformer identityTransformer;
+
+    /** Lazily created. */
+    private ContentHandlerAdaptor contentHandlerAdapter;
+
+    private boolean fragment;
+
+    /**
+     * Cached instance of {@link Base64Data}.
+     */
+    private Base64Data base64Data;
+
+    /**
+     * Cached instance of {@link IntData}.
+     */
+    private final IntData intData = new IntData();
+
+    public AttachmentMarshaller attachmentMarshaller;
+
+
+    /*package*/ XMLSerializer( MarshallerImpl _owner ) {
+        this.marshaller = _owner;
+        this.grammar = marshaller.context;
+        nsContext = new NamespaceContextImpl(this);
+        nameList = marshaller.context.nameList;
+        knownUri2prefixIndexMap = new int[nameList.namespaceURIs.length];
+    }
+
+    /**
+     * Gets the cached instance of {@link Base64Data}.
+     */
+    public Base64Data getCachedBase64DataInstance() {
+        if(base64Data==null)
+            base64Data = new Base64Data();
+        return base64Data;
+    }
+
+    /**
+     * Gets the ID value from an identifiable object.
+     */
+    private String getIdFromObject(Object identifiableObject) throws SAXException, JAXBException {
+        return grammar.getBeanInfo(identifiableObject,true).getId(identifiableObject,this);
+    }
+
+    private void handleMissingObjectError(String fieldName) throws SAXException, IOException, XMLStreamException {
+        reportMissingObjectError(fieldName);
+        // as a marshaller, we should be robust, so we'll continue to marshal
+        // this document by skipping this missing object.
+        endNamespaceDecls(null);
+        endAttributes();
+    }
+
+
+    public void reportError( ValidationEvent ve ) throws SAXException {
+        ValidationEventHandler handler;
+
+        try {
+            handler = marshaller.getEventHandler();
+        } catch( JAXBException e ) {
+            throw new SAXException2(e);
+        }
+
+        if(!handler.handleEvent(ve)) {
+            if(ve.getLinkedException() instanceof Exception)
+                throw new SAXException2((Exception)ve.getLinkedException());
+            else
+                throw new SAXException2(ve.getMessage());
+        }
+    }
+
+    /**
+     * Report an error found as an exception.
+     *
+     * @param fieldName
+     *      the name of the property being processed when an error is found.
+     */
+    public final void reportError(String fieldName, Throwable t) throws SAXException {
+        ValidationEvent ve = new ValidationEventImpl(ValidationEvent.ERROR,
+            t.getMessage(), getCurrentLocation(fieldName), t);
+        reportError(ve);
+    }
+
+    public void startElement(Name tagName, Object outerPeer) {
+        startElement();
+        nse.setTagName(tagName,outerPeer);
+    }
+
+    public void startElement(String nsUri, String localName, String preferredPrefix, Object outerPeer) {
+        startElement();
+        int idx = nsContext.declareNsUri(nsUri, preferredPrefix, false);
+        nse.setTagName(idx,localName,outerPeer);
+    }
+
+    public void endNamespaceDecls(Object innerPeer) throws IOException, XMLStreamException {
+        nsContext.collectionMode = false;
+        nse.startElement(out,innerPeer);
+    }
+
+    /**
+     * Switches to the "marshal child texts/elements" mode.
+     * This method has to be called after the 1st pass is completed.
+     */
+    public void endAttributes() throws SAXException, IOException, XMLStreamException  {
+        if(!seenRoot) {
+            seenRoot = true;
+            if(schemaLocation!=null || noNsSchemaLocation!=null) {
+                int p = nsContext.getPrefixIndex(WellKnownNamespace.XML_SCHEMA_INSTANCE);
+                if(schemaLocation!=null)
+                    out.attribute(p,"schemaLocation",schemaLocation);
+                if(noNsSchemaLocation!=null)
+                    out.attribute(p,"noNamespaceSchemaLocation",noNsSchemaLocation);
+            }
+        }
+
+        out.endStartTag();
+    }
+
+    /**
+     * Ends marshalling of an element.
+     * Pops the internal stack.
+     */
+    public void endElement() throws SAXException, IOException, XMLStreamException {
+        nse.endElement(out);
+        nse = nse.pop();
+        textHasAlreadyPrinted = false;
+    }
+
+    public void leafElement( Name tagName, String data, String fieldName ) throws SAXException, IOException, XMLStreamException {
+        if(seenRoot) {
+            textHasAlreadyPrinted = false;
+            nse = nse.push();
+            out.beginStartTag(tagName);
+            out.endStartTag();
+            out.text(data,false);
+            out.endTag(tagName);
+            nse = nse.pop();
+        } else {
+            // root element has additional processing like xsi:schemaLocation,
+            // so we need to go the slow way
+            startElement(tagName,null);
+            endNamespaceDecls(null);
+            endAttributes();
+            out.text(data,false);
+            endElement();
+        }
+    }
+
+    public void leafElement( Name tagName, Pcdata data, String fieldName ) throws SAXException, IOException, XMLStreamException {
+        if(seenRoot) {
+            textHasAlreadyPrinted = false;
+            nse = nse.push();
+            out.beginStartTag(tagName);
+            out.endStartTag();
+            out.text(data,false);
+            out.endTag(tagName);
+            nse = nse.pop();
+        } else {
+            // root element has additional processing like xsi:schemaLocation,
+            // so we need to go the slow way
+            startElement(tagName,null);
+            endNamespaceDecls(null);
+            endAttributes();
+            out.text(data,false);
+            endElement();
+        }
+    }
+
+    public void leafElement( Name tagName, int data, String fieldName ) throws SAXException, IOException, XMLStreamException {
+        intData.reset(data);
+        leafElement(tagName,intData,fieldName);
+    }
+
+    // TODO: consider some of these in future if we expand the writer to use something other than SAX
+//    void leafElement( QName tagName, byte value, String fieldName ) throws SAXException;
+//    void leafElement( QName tagName, char value, String fieldName ) throws SAXException;
+//    void leafElement( QName tagName, short value, String fieldName ) throws SAXException;
+//    void leafElement( QName tagName, int value, String fieldName ) throws SAXException;
+//    void leafElement( QName tagName, long value, String fieldName ) throws SAXException;
+//    void leafElement( QName tagName, float value, String fieldName ) throws SAXException;
+//    void leafElement( QName tagName, double value, String fieldName ) throws SAXException;
+//    void leafElement( QName tagName, boolean value, String fieldName ) throws SAXException;
+
+
+    /**
+     * Marshalls text.
+     *
+     * <p>
+     * This method can be called after the {@link #endAttributes()}
+     * method to marshal texts inside elements.
+     * If the method is called more than once, those texts are considered
+     * as separated by whitespaces. For example,
+     *
+     * <pre>
+     * c.startElement("","foo");
+     * c.endAttributes();
+     * c.text("abc");
+     * c.text("def");
+     *   c.startElement("","bar");
+     *   c.endAttributes();
+     *   c.endElement();
+     * c.text("ghi");
+     * c.endElement();
+     * </pre>
+     *
+     * will generate <code>&lt;foo>abc def&lt;bar/>ghi&lt;/foo></code>.
+     */
+    public void text( String text, String fieldName ) throws SAXException, IOException, XMLStreamException {
+        // If the assertion fails, it must be a bug of xjc.
+        // right now, we are not expecting the text method to be called.
+        if(text==null) {
+            reportMissingObjectError(fieldName);
+            return;
+        }
+
+        out.text(text,textHasAlreadyPrinted);
+        textHasAlreadyPrinted = true;
+    }
+
+    /**
+     * The {@link #text(String, String)} method that takes {@link Pcdata}.
+     */
+    public void text( Pcdata text, String fieldName ) throws SAXException, IOException, XMLStreamException {
+        // If the assertion fails, it must be a bug of xjc.
+        // right now, we are not expecting the text method to be called.
+        if(text==null) {
+            reportMissingObjectError(fieldName);
+            return;
+        }
+
+        out.text(text,textHasAlreadyPrinted);
+        textHasAlreadyPrinted = true;
+    }
+
+    public void attribute(String uri, String local, String value) throws SAXException {
+        int prefix;
+        if(uri.length()==0) {
+            // default namespace. don't need prefix
+            prefix = -1;
+        } else {
+            prefix = nsContext.getPrefixIndex(uri);
+        }
+
+        try {
+            out.attribute(prefix,local,value);
+        } catch (IOException e) {
+            throw new SAXException2(e);
+        } catch (XMLStreamException e) {
+            throw new SAXException2(e);
+        }
+    }
+
+    public void attribute(Name name, CharSequence value) throws IOException, XMLStreamException {
+        // TODO: consider having the version that takes Pcdata.
+        // it's common for an element to have int attributes
+        out.attribute(name,value.toString());
+    }
+
+    public NamespaceContext2 getNamespaceContext() {
+        return nsContext;
+    }
+
+
+    public String onID( Object owner, String value ) {
+        objectsWithId.add(owner);
+        return value;
+    }
+
+    public String onIDREF( Object obj ) throws SAXException {
+        String id;
+        try {
+            id = getIdFromObject(obj);
+        } catch (JAXBException e) {
+            reportError(null,e);
+            return null; // recover by returning null
+        }
+        idReferencedObjects.add(obj);
+        if(id==null) {
+            reportError( new NotIdentifiableEventImpl(
+                ValidationEvent.ERROR,
+                Messages.NOT_IDENTIFIABLE.format(),
+                new ValidationEventLocatorImpl(obj) ) );
+        }
+        return id;
+    }
+
+
+    // TODO: think about the exception handling.
+    // I suppose we don't want to use SAXException. -kk
+
+    public void childAsRoot(Object obj) throws JAXBException, IOException, SAXException, XMLStreamException {
+        final JaxBeanInfo beanInfo = grammar.getBeanInfo(obj, true);
+
+        // since the same object will be reported to childAsRoot or
+        // childAsXsiType, don't make it a part of the collision check.
+        // but we do need to push it so that getXMIMEContentType will work.
+        cycleDetectionStack.pushNocheck(obj);
+
+        final boolean lookForLifecycleMethods = beanInfo.lookForLifecycleMethods();
+        if (lookForLifecycleMethods) {
+            fireBeforeMarshalEvents(beanInfo, obj);
+        }
+
+        beanInfo.serializeRoot(obj,this);
+
+        if (lookForLifecycleMethods) {
+            fireAfterMarshalEvents(beanInfo, obj);
+        }
+
+        cycleDetectionStack.pop();
+    }
+
+    private void pushObject(Object obj, String fieldName) throws SAXException {
+        if(cycleDetectionStack.push(obj)) {
+            // cycle detected
+            StringBuilder sb = new StringBuilder();
+            sb.append(obj);
+            int i=cycleDetectionStack.size()-1;
+            Object x;
+            do {
+                sb.append(" -> ");
+                x = cycleDetectionStack.get(--i);
+                sb.append(x);
+            } while(obj!=x);
+
+            reportError(new ValidationEventImpl(
+                ValidationEvent.ERROR,
+                Messages.CYCLE_IN_MARSHALLER.format(sb),
+                getCurrentLocation(fieldName),
+                null));
+        }
+    }
+
+    /**
+     * The equivalent of:
+     *
+     * <pre>
+     * childAsURIs(child, fieldName);
+     * endNamespaceDecls();
+     * childAsAttributes(child, fieldName);
+     * endAttributes();
+     * childAsBody(child, fieldName);
+     * </pre>
+     *
+     * This produces the given child object as the sole content of
+     * an element.
+     * Used to reduce the code size in the generated marshaller.
+     */
+    public final void childAsSoleContent( Object child, String fieldName) throws SAXException, IOException, XMLStreamException {
+        if(child==null) {
+            handleMissingObjectError(fieldName);
+        } else {
+            JaxBeanInfo beanInfo;
+            try {
+                beanInfo = grammar.getBeanInfo(child,true);
+            } catch (JAXBException e) {
+                reportError(fieldName,e);
+                // recover by ignore
+                endNamespaceDecls(null);
+                endAttributes();
+                return;
+            }
+
+            pushObject(child,fieldName);
+
+            final boolean lookForLifecycleMethods = beanInfo.lookForLifecycleMethods();
+            if (lookForLifecycleMethods) {
+                fireBeforeMarshalEvents(beanInfo, child);
+            }
+
+            beanInfo.serializeURIs(child,this);
+            endNamespaceDecls(child);
+            beanInfo.serializeAttributes(child,this);
+            endAttributes();
+            beanInfo.serializeBody(child,this);
+
+            if (lookForLifecycleMethods) {
+                fireAfterMarshalEvents(beanInfo, child);
+            }
+
+            cycleDetectionStack.pop();
+        }
+    }
+
+
+    // the version of childAsXXX where it produces @xsi:type if the expected type name
+    // and the actual type name differs.
+
+    /**
+     * This method is called when a type child object is found.
+     *
+     * <p>
+     * This method produces events of the following form:
+     * <pre>
+     * NSDECL* "endNamespaceDecls" ATTRIBUTE* "endAttributes" BODY
+     * </pre>
+     * optionally including @xsi:type if necessary.
+     *
+     * @param child
+     *      Object to be marshalled. The {@link JaxBeanInfo} for
+     *      this object must return a type name.
+     * @param expected
+     *      Expected type of the object.
+     * @param fieldName
+     *      property name of the parent objeect from which 'o' comes.
+     *      Used as a part of the error message in case anything goes wrong
+     *      with 'o'.
+     */
+    public final void childAsXsiType( Object child, String fieldName, JaxBeanInfo expected ) throws SAXException, IOException, XMLStreamException {
+        if(child==null) {
+            handleMissingObjectError(fieldName);
+        } else {
+            boolean asExpected = child.getClass()==expected.jaxbType;
+            JaxBeanInfo actual = expected;
+            QName actualTypeName = null;
+
+            pushObject(child,fieldName);
+
+            if((asExpected) && (actual.lookForLifecycleMethods())) {
+                fireBeforeMarshalEvents(actual, child);
+            }
+
+            if(!asExpected) {
+                try {
+                    actual = grammar.getBeanInfo(child,true);
+                    if (actual.lookForLifecycleMethods()) {
+                        fireBeforeMarshalEvents(actual, child);
+                    }
+                } catch (JAXBException e) {
+                    reportError(fieldName,e);
+                    endNamespaceDecls(null);
+                    endAttributes();
+                    return; // recover by ignore
+                }
+                if(actual==expected)
+                    asExpected = true;
+                else {
+                    actualTypeName = actual.getTypeName(child);
+                    if(actualTypeName==null) {
+                        reportError(new ValidationEventImpl(
+                                ValidationEvent.ERROR,
+                                Messages.SUBSTITUTED_BY_ANONYMOUS_TYPE.format(
+                                    expected.jaxbType.getName(),
+                                    child.getClass().getName(),
+                                    actual.jaxbType.getName()),
+                                getCurrentLocation(fieldName)));
+                        // recover by not printing @xsi:type
+                    } else {
+                        getNamespaceContext().declareNamespace(WellKnownNamespace.XML_SCHEMA_INSTANCE,"xsi",true);
+                        getNamespaceContext().declareNamespace(actualTypeName.getNamespaceURI(),null,false);
+                    }
+                }
+            }
+            actual.serializeURIs(child,this);
+            endNamespaceDecls(child);
+            if(!asExpected) {
+                attribute(WellKnownNamespace.XML_SCHEMA_INSTANCE,"type",
+                    DatatypeConverter.printQName(actualTypeName,getNamespaceContext()));
+            }
+            actual.serializeAttributes(child,this);
+            endAttributes();
+            actual.serializeBody(child,this);
+
+            if (actual.lookForLifecycleMethods()) {
+                fireAfterMarshalEvents(actual, child);
+            }
+
+            cycleDetectionStack.pop();
+        }
+    }
+
+    /**
+     * Invoke the afterMarshal api on the external listener (if it exists) and on the bean embedded
+     * afterMarshal api(if it exists).
+     *
+     * This method is called only after the callee has determined that beanInfo.lookForLifecycleMethods == true.
+     *
+     * @param beanInfo
+     * @param currentTarget
+     */
+    private void fireAfterMarshalEvents(final JaxBeanInfo beanInfo, Object currentTarget) {
+        // first invoke bean embedded listener
+        if (beanInfo.hasAfterMarshalMethod()) {
+            Method m = beanInfo.getLifecycleMethods().getAfterMarshal();
+            fireMarshalEvent(currentTarget, m);
+        }
+
+        // then invoke external listener before bean embedded listener
+        Marshaller.Listener externalListener = marshaller.getListener();
+        if (externalListener != null) {
+            externalListener.afterMarshal(currentTarget);
+        }
+
+    }
+
+    /**
+     * Invoke the beforeMarshal api on the external listener (if it exists) and on the bean embedded
+     * beforeMarshal api(if it exists).
+     *
+     * This method is called only after the callee has determined that beanInfo.lookForLifecycleMethods == true.
+     *
+     * @param beanInfo
+     * @param currentTarget
+     */
+    private void fireBeforeMarshalEvents(final JaxBeanInfo beanInfo, Object currentTarget) {
+        // first invoke bean embedded listener
+        if (beanInfo.hasBeforeMarshalMethod()) {
+            Method m = beanInfo.getLifecycleMethods().getBeforeMarshal();
+            fireMarshalEvent(currentTarget, m);
+        }
+
+        // then invoke external listener
+        Marshaller.Listener externalListener = marshaller.getListener();
+        if (externalListener != null) {
+            externalListener.beforeMarshal(currentTarget);
+        }
+    }
+
+    private void fireMarshalEvent(Object target, Method m) {
+        try {
+            m.invoke(target, marshaller);
+        } catch (Exception e) {
+            // this really only happens if there is a bug in the ri
+            throw new IllegalStateException(e);
+        }
+    }
+
+    public void attWildcardAsURIs(Map<QName,String> attributes, String fieldName) {
+        if(attributes==null)    return;
+        for( Map.Entry<QName,String> e : attributes.entrySet() ) {
+            QName n = e.getKey();
+            String nsUri = n.getNamespaceURI();
+            if(nsUri.length()>0) {
+                String p = n.getPrefix();
+                if(p.length()==0)   p=null;
+                nsContext.declareNsUri(nsUri, p, true);
+            }
+        }
+    }
+
+    public void attWildcardAsAttributes(Map<QName,String> attributes, String fieldName) throws SAXException {
+        if(attributes==null)    return;
+        for( Map.Entry<QName,String> e : attributes.entrySet() ) {
+            QName n = e.getKey();
+            attribute(n.getNamespaceURI(),n.getLocalPart(),e.getValue());
+        }
+    }
+
+    /**
+     * Short for the following call sequence:
+     *
+     * <pre>
+         getNamespaceContext().declareNamespace(WellKnownNamespace.XML_SCHEMA_INSTANCE,"xsi",true);
+         endNamespaceDecls();
+         attribute(WellKnownNamespace.XML_SCHEMA_INSTANCE,"nil","true");
+         endAttributes();
+     * </pre>
+     */
+    public final void writeXsiNilTrue() throws SAXException, IOException, XMLStreamException {
+        getNamespaceContext().declareNamespace(WellKnownNamespace.XML_SCHEMA_INSTANCE,"xsi",true);
+        endNamespaceDecls(null);
+        attribute(WellKnownNamespace.XML_SCHEMA_INSTANCE,"nil","true");
+        endAttributes();
+    }
+
+    public <E> void writeDom(E element, DomHandler<E, ?> domHandler, Object parentBean, String fieldName) throws SAXException {
+        Source source = domHandler.marshal(element,this);
+        if(contentHandlerAdapter==null)
+            contentHandlerAdapter = new ContentHandlerAdaptor(this);
+        try {
+            getIdentityTransformer().transform(source,new SAXResult(contentHandlerAdapter));
+        } catch (TransformerException e) {
+            reportError(fieldName,e);
+        }
+    }
+
+    public Transformer getIdentityTransformer() {
+        if(identityTransformer==null)
+            identityTransformer = JAXBContextImpl.createTransformer();
+        return identityTransformer;
+    }
+
+    public void setPrefixMapper(NamespacePrefixMapper prefixMapper) {
+        nsContext.setPrefixMapper(prefixMapper);
+    }
+
+    /**
+     * Reset this object to write to the specified output.
+     *
+     * @param schemaLocation
+     *      if non-null, this value is printed on the root element as xsi:schemaLocation
+     * @param noNsSchemaLocation
+     *      Similar to 'schemaLocation' but this one works for xsi:noNamespaceSchemaLocation
+     */
+    public void startDocument(XmlOutput out,boolean fragment,String schemaLocation,String noNsSchemaLocation) throws IOException, SAXException, XMLStreamException {
+        setThreadAffinity();
+        pushCoordinator();
+        nsContext.reset();
+        nse = nsContext.getCurrent();
+        if(attachmentMarshaller!=null && attachmentMarshaller.isXOPPackage())
+            out = new MTOMXmlOutput(out);
+        this.out = out;
+        objectsWithId.clear();
+        idReferencedObjects.clear();
+        textHasAlreadyPrinted = false;
+        seenRoot = false;
+        this.schemaLocation = schemaLocation;
+        this.noNsSchemaLocation = noNsSchemaLocation;
+        this.fragment = fragment;
+        this.inlineBinaryFlag = false;
+        this.expectedMimeType = null;
+        cycleDetectionStack.reset();
+
+        out.startDocument(this,fragment,knownUri2prefixIndexMap,nsContext);
+    }
+
+    public void endDocument() throws IOException, SAXException, XMLStreamException {
+        out.endDocument(fragment);
+    }
+
+    public void close() {
+        popCoordinator();
+        resetThreadAffinity();
+    }
+
+    /**
+     * This method can be called after {@link #startDocument} is called
+     * but before the marshalling begins, to set the currently in-scope namespace
+     * bindings.
+     *
+     * <p>
+     * This method is useful to avoid redundant namespace declarations when
+     * the marshalling is producing a sub-document.
+     */
+    public void addInscopeBinding(String nsUri,String prefix) {
+        nsContext.put(nsUri,prefix);
+    }
+
+    /**
+     * Gets the MIME type with which the binary content shall be printed.
+     *
+     * <p>
+     * This method shall be used from those {@link RuntimeBuiltinLeafInfo} that are
+     * bound to base64Binary.
+     *
+     * @see JAXBContextImpl#getXMIMEContentType(Object)
+     */
+    public String getXMIMEContentType() {
+        // xmime:contentType takes precedence
+        String v = grammar.getXMIMEContentType(cycleDetectionStack.peek());
+        if(v!=null)     return v;
+
+        // then look for the current in-scope @XmlMimeType
+        if(expectedMimeType!=null)
+            return expectedMimeType.toString();
+
+        return null;
+    }
+
+    private void startElement() {
+        nse = nse.push();
+
+        if( !seenRoot ) {
+            // seenRoot set to true in endAttributes
+            // first declare all known URIs
+            String[] knownUris = nameList.namespaceURIs;
+            for( int i=0; i<knownUris.length; i++ )
+                knownUri2prefixIndexMap[i] = nsContext.declareNsUri(knownUris[i], null, nameList.nsUriCannotBeDefaulted[i]);
+
+            // then declare user-specified namespace URIs.
+            // work defensively. we are calling an user-defined method.
+            String[] uris = nsContext.getPrefixMapper().getPreDeclaredNamespaceUris();
+            if( uris!=null ) {
+                for (String uri : uris) {
+                    if (uri != null)
+                        nsContext.declareNsUri(uri, null, false);
+                }
+            }
+            String[] pairs = nsContext.getPrefixMapper().getPreDeclaredNamespaceUris2();
+            if( pairs!=null ) {
+                for( int i=0; i<pairs.length; i+=2 ) {
+                    String prefix = pairs[i];
+                    String nsUri = pairs[i+1];
+                    if(prefix!=null && nsUri!=null)
+                        // in this case, we don't want the redundant binding consolidation
+                        // to happen (such as declaring the same namespace URI twice with
+                        // different prefixes.) Hence we call the put method directly.
+                        nsContext.put(nsUri,prefix);
+                }
+            }
+
+            if(schemaLocation!=null || noNsSchemaLocation!=null) {
+                nsContext.declareNsUri(WellKnownNamespace.XML_SCHEMA_INSTANCE,"xsi",true);
+            }
+        }
+
+        nsContext.collectionMode = true;
+        textHasAlreadyPrinted = false;
+    }
+
+    private MimeType expectedMimeType;
+
+    /**
+     * This method is used by {@link MimeTypedTransducer} to set the expected MIME type
+     * for the encapsulated {@link Transducer}.
+     */
+    public MimeType setExpectedMimeType(MimeType expectedMimeType) {
+        MimeType old = this.expectedMimeType;
+        this.expectedMimeType = expectedMimeType;
+        return old;
+    }
+
+    /**
+     * True to force inlining.
+     */
+    private boolean inlineBinaryFlag;
+
+    public boolean setInlineBinaryFlag(boolean value) {
+        boolean old = inlineBinaryFlag;
+        this.inlineBinaryFlag = value;
+        return old;
+    }
+
+    public boolean getInlineBinaryFlag() {
+        return inlineBinaryFlag;
+    }
+
+    /**
+     * Field used to support an {@link XmlSchemaType} annotation.
+     *
+     * <p>
+     * When we are marshalling a property with an effective {@link XmlSchemaType},
+     * this field is set to hold the QName of that type. The {@link Transducer} that
+     * actually converts a Java object into XML can look this property to decide
+     * how to marshal the value.
+     */
+    private QName schemaType;
+
+    public QName setSchemaType(QName st) {
+        QName old = schemaType;
+        schemaType = st;
+        return old;
+    }
+
+    public QName getSchemaType() {
+        return schemaType;
+    }
+
+    void reconcileID() throws SAXException {
+        // find objects that were not a part of the object graph
+        idReferencedObjects.removeAll(objectsWithId);
+
+        for( Object idObj : idReferencedObjects ) {
+            try {
+                String id = getIdFromObject(idObj);
+                reportError( new NotIdentifiableEventImpl(
+                    ValidationEvent.ERROR,
+                    Messages.DANGLING_IDREF.format(id),
+                    new ValidationEventLocatorImpl(idObj) ) );
+            } catch (JAXBException e) {
+                // this error should have been reported already. just ignore here.
+            }
+        }
+
+        // clear the garbage
+        idReferencedObjects.clear();
+        objectsWithId.clear();
+    }
+
+    public boolean handleError(Exception e) {
+        return handleError(e,cycleDetectionStack.peek(),null);
+    }
+
+    public boolean handleError(Exception e,Object source,String fieldName) {
+        return handleEvent(
+            new ValidationEventImpl(
+                ValidationEvent.ERROR,
+                e.getMessage(),
+                new ValidationEventLocatorExImpl(source,fieldName),
+                    e));
+    }
+
+    public boolean handleEvent(ValidationEvent event) {
+        try {
+            return marshaller.getEventHandler().handleEvent(event);
+        } catch (JAXBException e) {
+            // impossible
+            throw new Error(e);
+        }
+    }
+
+    private void reportMissingObjectError(String fieldName) throws SAXException {
+        reportError(new ValidationEventImpl(
+            ValidationEvent.ERROR,
+            Messages.MISSING_OBJECT.format(fieldName),
+                getCurrentLocation(fieldName),
+            new NullPointerException() ));
+    }
+
+    /**
+     * Called when a referenced object doesn't have an ID.
+     */
+    public void errorMissingId(Object obj) throws SAXException {
+        reportError( new ValidationEventImpl(
+            ValidationEvent.ERROR,
+            Messages.MISSING_ID.format(obj),
+            new ValidationEventLocatorImpl(obj)) );
+    }
+
+    public ValidationEventLocator getCurrentLocation(String fieldName) {
+        return new ValidationEventLocatorExImpl(cycleDetectionStack.peek(),fieldName);
+    }
+
+    protected ValidationEventLocator getLocation() {
+        return getCurrentLocation(null);
+    }
+
+    /**
+     * When called from within the realm of the marshaller, this method
+     * returns the current {@link XMLSerializer} in charge.
+     */
+    public static XMLSerializer getInstance() {
+        return (XMLSerializer)Coordinator._getInstance();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/C14nXmlOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/C14nXmlOutput.java
new file mode 100644
index 0000000..d093aad
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/C14nXmlOutput.java
@@ -0,0 +1,222 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.Arrays;
+import java.util.Collections;
+
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.istack.internal.FinalArrayList;
+
+/**
+ * {@link XmlOutput} that generates canonical XML.
+ *
+ * @see com.sun.xml.internal.bind.api.C14nSupport_ArchitectureDocument
+ * @author Kohsuke Kawaguchi
+ */
+public class C14nXmlOutput extends UTF8XmlOutput {
+    public C14nXmlOutput(OutputStream out, Encoded[] localNames, boolean namedAttributesAreOrdered) {
+        super(out, localNames);
+        this.namedAttributesAreOrdered = namedAttributesAreOrdered;
+
+        for( int i=0; i<staticAttributes.length; i++ )
+            staticAttributes[i] = new StaticAttribute();
+    }
+
+    /**
+     * Hosts statically known attributes.
+     *
+     * {@link StaticAttribute} instances are reused.
+     */
+    private StaticAttribute[] staticAttributes = new StaticAttribute[8];
+    private int len = 0;
+
+    /**
+     * Used to sort namespace declarations. Reused.
+     */
+    private int[] nsBuf = new int[8];
+
+    /**
+     * Hosts other attributes whose name are not statically known
+     * (AKA attribute wildcard.)
+     *
+     * As long as this map is empty, there's no need for sorting.
+     * see {@link com.sun.xml.internal.bind.api.C14nSupport_ArchitectureDocument} for more details.
+     */
+    private final FinalArrayList<DynamicAttribute> otherAttributes = new FinalArrayList<DynamicAttribute>();
+
+    /**
+     * True if {@link JAXBRIContext} is created with c14n support on,
+     * in which case all named attributes are sorted by the marshaller
+     * and we won't have to do it here.
+     */
+    private final boolean namedAttributesAreOrdered;
+
+    final class StaticAttribute implements Comparable<StaticAttribute> {
+        Name name;
+        String value;
+
+        public void set(Name name, String value) {
+            this.name = name;
+            this.value = value;
+        }
+
+        void write() throws IOException {
+            C14nXmlOutput.super.attribute(name,value);
+        }
+
+        DynamicAttribute toDynamicAttribute() {
+            int nsUriIndex = name.nsUriIndex;
+            int prefix;
+            if(nsUriIndex==-1)
+                prefix = -1;
+            else
+                prefix = nsUriIndex2prefixIndex[nsUriIndex];
+            return new DynamicAttribute(
+                prefix, name.localName, value );
+        }
+
+        public int compareTo(StaticAttribute that) {
+            return this.name.compareTo(that.name);
+        }
+
+    }
+
+    final class DynamicAttribute implements Comparable<DynamicAttribute> {
+        final int prefix;
+        final String localName;
+        final String value;
+
+        public DynamicAttribute(int prefix, String localName, String value) {
+            this.prefix = prefix;
+            this.localName = localName;
+            this.value = value;
+        }
+
+        private String getURI() {
+            if(prefix==-1)  return "";
+            else            return nsContext.getNamespaceURI(prefix);
+        }
+
+        public int compareTo(DynamicAttribute that) {
+            int r = this.getURI().compareTo(that.getURI());
+            if(r!=0)    return r;
+            return this.localName.compareTo(that.localName);
+        }
+    }
+
+    @Override
+    public void attribute(Name name, String value) throws IOException {
+        if(staticAttributes.length==len) {
+            // reallocate
+            int newLen = len*2;
+            StaticAttribute[] newbuf = new StaticAttribute[newLen];
+            System.arraycopy(staticAttributes,0,newbuf,0,len);
+            for(int i=len;i<newLen;i++)
+                staticAttributes[i] = new StaticAttribute();
+            staticAttributes = newbuf;
+        }
+
+        staticAttributes[len++].set(name,value);
+    }
+
+    @Override
+    public void attribute(int prefix, String localName, String value) throws IOException {
+        otherAttributes.add(new DynamicAttribute(prefix,localName,value));
+    }
+
+    @Override
+    public void endStartTag() throws IOException {
+        if(otherAttributes.isEmpty()) {
+            if(len!=0) {
+                // sort is expensive even for size 0 array,
+                // so it's worth checking len==0
+                if(!namedAttributesAreOrdered)
+                    Arrays.sort(staticAttributes,0,len);
+                // this is the common case
+                for( int i=0; i<len; i++ )
+                    staticAttributes[i].write();
+                len = 0;
+            }
+        } else {
+            // this is the exceptional case
+
+            // sort all the attributes, not just the other attributes
+            for( int i=0; i<len; i++ )
+                otherAttributes.add(staticAttributes[i].toDynamicAttribute());
+            len = 0;
+            Collections.sort(otherAttributes);
+
+            // write them all
+            int size = otherAttributes.size();
+            for( int i=0; i<size; i++ ) {
+                DynamicAttribute a = otherAttributes.get(i);
+                super.attribute(a.prefix,a.localName,a.value);
+            }
+            otherAttributes.clear();
+        }
+        super.endStartTag();
+    }
+
+    /**
+     * Write namespace declarations after sorting them.
+     */
+    @Override
+    protected void writeNsDecls(int base) throws IOException {
+        int count = nsContext.getCurrent().count();
+
+        if(count==0)
+            return; // quickly reject the most common case
+
+        if(count>nsBuf.length)
+            nsBuf = new int[count];
+
+        for( int i=count-1; i>=0; i-- )
+            nsBuf[i] = base+i;
+
+        // do a bubble sort. Hopefully # of ns decls are small enough to justify bubble sort.
+        // faster algorithm is more compliated to implement
+        for( int i=0; i<count; i++ ) {
+            for( int j=i+1; j<count; j++ ) {
+                String p = nsContext.getPrefix(nsBuf[i]);
+                String q = nsContext.getPrefix(nsBuf[j]);
+                if( p.compareTo(q) > 0 ) {
+                    // swap
+                    int t = nsBuf[j];
+                    nsBuf[j] = nsBuf[i];
+                    nsBuf[i] = t;
+                }
+            }
+        }
+
+        // write them out
+        for( int i=0; i<count; i++ )
+            writeNsDecl(nsBuf[i]);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/DOMOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/DOMOutput.java
new file mode 100644
index 0000000..13243a1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/DOMOutput.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import com.sun.xml.internal.bind.v2.runtime.AssociationMap;
+import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
+
+import org.w3c.dom.Node;
+import org.xml.sax.SAXException;
+
+
+/**
+ * {@link XmlOutput} implementation that does associative marshalling to DOM.
+ *
+ * <p>
+ * This is used for binder.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class DOMOutput extends SAXOutput {
+    private final AssociationMap assoc;
+
+    public DOMOutput(Node node, AssociationMap assoc) {
+        super(new SAX2DOMEx(node));
+        this.assoc = assoc;
+        assert assoc!=null;
+    }
+
+    private SAX2DOMEx getBuilder() {
+        return (SAX2DOMEx)out;
+    }
+
+    public void endStartTag() throws SAXException {
+        super.endStartTag();
+
+        Object op = nsContext.getCurrent().getOuterPeer();
+        if(op!=null)
+            assoc.addOuter( getBuilder().getCurrentElement(), op );
+
+        Object ip = nsContext.getCurrent().getInnerPeer();
+        if(ip!=null)
+            assoc.addInner( getBuilder().getCurrentElement(), ip );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/Encoded.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/Encoded.java
new file mode 100644
index 0000000..ae97528
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/Encoded.java
@@ -0,0 +1,198 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+
+/**
+ * Buffer for UTF-8 encoded string.
+ *
+ * See http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8 for the UTF-8 encoding.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Encoded {
+    public byte[] buf;
+
+    public int len;
+
+    public Encoded() {}
+
+    public Encoded(String text) {
+        set(text);
+    }
+
+    public void ensureSize(int size) {
+        if(buf==null || buf.length<size)
+            buf = new byte[size];
+    }
+
+    public final void set( String text ) {
+        int length = text.length();
+
+        ensureSize(length*3+1); // +1 for append
+
+        int ptr = 0;
+
+        for (int i = 0; i < length; i++) {
+            final char chr = text.charAt(i);
+            if (chr > 0x7F) {
+                if (chr > 0x7FF) {
+                    if(Character.MIN_HIGH_SURROGATE<=chr && chr<=Character.MAX_LOW_SURROGATE) {
+                        // surrogate
+                        int uc = (((chr & 0x3ff) << 10) | (text.charAt(++i) & 0x3ff)) + 0x10000;
+
+                        buf[ptr++] = (byte)(0xF0 | ((uc >> 18)));
+                        buf[ptr++] = (byte)(0x80 | ((uc >> 12) & 0x3F));
+                        buf[ptr++] = (byte)(0x80 | ((uc >> 6) & 0x3F));
+                        buf[ptr++] = (byte)(0x80 + (uc & 0x3F));
+                        continue;
+                    }
+                    buf[ptr++] = (byte)(0xE0 + (chr >> 12));
+                    buf[ptr++] = (byte)(0x80 + ((chr >> 6) & 0x3F));
+                } else {
+                    buf[ptr++] = (byte)(0xC0 + (chr >> 6));
+                }
+                buf[ptr++] = (byte)(0x80 + (chr & 0x3F));
+            } else {
+                buf[ptr++] = (byte)chr;
+            }
+        }
+
+        len = ptr;
+    }
+
+    /**
+     * Fill in the buffer by encoding the specified characters
+     * while escaping characters like &lt;
+     *
+     * @param isAttribute
+     *      if true, characters like \t, \r, and \n are also escaped.
+     */
+    public final void setEscape(String text, boolean isAttribute) {
+        int length = text.length();
+        ensureSize(length*6+1);     // in the worst case the text is like """""", so we need 6 bytes per char
+
+        int ptr = 0;
+
+        for (int i = 0; i < length; i++) {
+            final char chr = text.charAt(i);
+
+            int ptr1 = ptr;
+            if (chr > 0x7F) {
+                if (chr > 0x7FF) {
+                    if(Character.MIN_HIGH_SURROGATE<=chr && chr<=Character.MAX_LOW_SURROGATE) {
+                        // surrogate
+                        int uc = (((chr & 0x3ff) << 10) | (text.charAt(++i) & 0x3ff)) + 0x10000;
+
+                        buf[ptr++] = (byte)(0xF0 | ((uc >> 18)));
+                        buf[ptr++] = (byte)(0x80 | ((uc >> 12) & 0x3F));
+                        buf[ptr++] = (byte)(0x80 | ((uc >> 6) & 0x3F));
+                        buf[ptr++] = (byte)(0x80 + (uc & 0x3F));
+                        continue;
+                    }
+                    buf[ptr1++] = (byte)(0xE0 + (chr >> 12));
+                    buf[ptr1++] = (byte)(0x80 + ((chr >> 6) & 0x3F));
+                } else {
+                    buf[ptr1++] = (byte)(0xC0 + (chr >> 6));
+                }
+                buf[ptr1++] = (byte)(0x80 + (chr & 0x3F));
+            } else {
+                byte[] ent;
+
+                if((ent=attributeEntities[chr])!=null) {
+                    // the majority of the case is just printed as a char,
+                    // so it's very important to reject them as quickly as possible
+
+                    // check again to see if this really needs to be escaped
+                    if(isAttribute || entities[chr]!=null)
+                        ptr1 = writeEntity(ent,ptr1);
+                    else
+                        buf[ptr1++] = (byte)chr;
+                } else
+                    buf[ptr1++] = (byte)chr;
+            }
+            ptr = ptr1;
+        }
+        len = ptr;
+    }
+
+    private int writeEntity( byte[] entity, int ptr ) {
+        System.arraycopy(entity,0,buf,ptr,entity.length);
+        return ptr+entity.length;
+    }
+
+    /**
+     * Writes the encoded bytes to the given output stream.
+     */
+    public final void write(UTF8XmlOutput out) throws IOException {
+        out.write(buf,0,len);
+    }
+
+    /**
+     * Appends a new character to the end of the buffer.
+     * This assumes that you have enough space in the buffer.
+     */
+    public void append(char b) {
+        buf[len++] = (byte)b;
+    }
+
+    /**
+     * Reallocate the buffer to the exact size of the data
+     * to reduce the memory footprint.
+     */
+    public void compact() {
+        byte[] b = new byte[len];
+        System.arraycopy(buf,0,b,0,len);
+        buf = b;
+    }
+
+    /**
+     * UTF-8 encoded entities keyed by their character code.
+     * e.g., entities['&'] == AMP_ENTITY.
+     *
+     * In attributes we need to encode more characters.
+     */
+    private static final byte[][] entities = new byte[0x80][];
+    private static final byte[][] attributeEntities = new byte[0x80][];
+
+    static {
+        add('&',"&amp;",false);
+        add('<',"&lt;",false);
+        add('>',"&gt;",false);
+        add('"',"&quot;",false);
+        add('\t',"&#x9;",true);
+        add('\r',"&#xD;",false);
+        add('\n',"&#xA;",true);
+    }
+
+    private static void add(char c, String s, boolean attOnly) {
+        byte[] image = UTF8XmlOutput.toBytes(s);
+        attributeEntities[c] = image;
+        if(!attOnly)
+            entities[c] = image;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/FastInfosetStreamWriterOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/FastInfosetStreamWriterOutput.java
new file mode 100644
index 0000000..0424016
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/FastInfosetStreamWriterOutput.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Base64Data;
+import com.sun.xml.internal.fastinfoset.stax.StAXDocumentSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link XmlOutput} for {@link StAXDocumentSerializer}.
+ *
+ * @author Paul Sandoz.
+ */
+public final class FastInfosetStreamWriterOutput extends XMLStreamWriterOutput {
+    private final StAXDocumentSerializer fiout;
+
+    public FastInfosetStreamWriterOutput(StAXDocumentSerializer out) {
+        super(out);
+        this.fiout = out;
+    }
+
+    public void text(Pcdata value, boolean needsSeparatingWhitespace) throws XMLStreamException {
+        if(needsSeparatingWhitespace) {
+            fiout.writeCharacters(" ");
+        }
+
+        /*
+         * Check if the CharSequence is from a base64Binary data type
+         */
+        if (!(value instanceof Base64Data)) {
+            // Write out characters
+            fiout.writeCharacters(value.toString());
+        } else {
+            final Base64Data dataValue = (Base64Data)value;
+            // Write out the octets using the base64 encoding algorithm
+            fiout.writeOctets(dataValue.get(), 0, dataValue.getDataLen());
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/ForkXmlOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/ForkXmlOutput.java
new file mode 100644
index 0000000..f5e2df0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/ForkXmlOutput.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link XmlOutput} that writes to two {@link XmlOutput}s.
+ * @author Kohsuke Kawaguchi
+ */
+public final class ForkXmlOutput extends XmlOutputAbstractImpl {
+    private final XmlOutput lhs;
+    private final XmlOutput rhs;
+
+    public ForkXmlOutput(XmlOutput lhs, XmlOutput rhs) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    @Override
+    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws IOException, SAXException, XMLStreamException {
+        lhs.startDocument(serializer, fragment, nsUriIndex2prefixIndex, nsContext);
+        rhs.startDocument(serializer, fragment, nsUriIndex2prefixIndex, nsContext);
+    }
+
+    @Override
+    public void endDocument(boolean fragment) throws IOException, SAXException, XMLStreamException {
+        lhs.endDocument(fragment);
+        rhs.endDocument(fragment);
+    }
+
+    @Override
+    public void beginStartTag(Name name) throws IOException, XMLStreamException {
+        lhs.beginStartTag(name);
+        rhs.beginStartTag(name);
+    }
+
+    @Override
+    public void attribute(Name name, String value) throws IOException, XMLStreamException {
+        lhs.attribute(name, value);
+        rhs.attribute(name, value);
+    }
+
+    @Override
+    public void endTag(Name name) throws IOException, SAXException, XMLStreamException {
+        lhs.endTag(name);
+        rhs.endTag(name);
+    }
+
+    @Override
+    public void flush() throws IOException, XMLStreamException {
+        lhs.flush();
+        rhs.flush();
+    }
+
+    public void beginStartTag(int prefix, String localName) throws IOException, XMLStreamException {
+        lhs.beginStartTag(prefix,localName);
+        rhs.beginStartTag(prefix,localName);
+    }
+
+    public void attribute(int prefix, String localName, String value) throws IOException, XMLStreamException {
+        lhs.attribute(prefix,localName,value);
+        rhs.attribute(prefix,localName,value);
+    }
+
+    public void endStartTag() throws IOException, SAXException {
+        lhs.endStartTag();
+        rhs.endStartTag();
+    }
+
+    public void endTag(int prefix, String localName) throws IOException, SAXException, XMLStreamException {
+        lhs.endTag(prefix,localName);
+        rhs.endTag(prefix,localName);
+    }
+
+    public void text(String value, boolean needsSeparatingWhitespace) throws IOException, SAXException, XMLStreamException {
+        lhs.text(value,needsSeparatingWhitespace);
+        rhs.text(value,needsSeparatingWhitespace);
+    }
+
+    public void text(Pcdata value, boolean needsSeparatingWhitespace) throws IOException, SAXException, XMLStreamException {
+        lhs.text(value,needsSeparatingWhitespace);
+        rhs.text(value,needsSeparatingWhitespace);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/InPlaceDOMOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/InPlaceDOMOutput.java
new file mode 100644
index 0000000..6130d56
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/InPlaceDOMOutput.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import com.sun.xml.internal.bind.v2.runtime.AssociationMap;
+import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
+
+import org.w3c.dom.Node;
+import org.xml.sax.SAXException;
+
+/**
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class InPlaceDOMOutput extends SAXOutput {
+    private final AssociationMap assoc;
+
+    public InPlaceDOMOutput(Node node, AssociationMap assoc) {
+        super(new SAX2DOMEx(node));
+        this.assoc = assoc;
+        assert assoc!=null;
+    }
+
+    private SAX2DOMEx getBuilder() {
+        return (SAX2DOMEx)out;
+    }
+
+    public void endStartTag() throws SAXException {
+        super.endStartTag();
+
+        Object op = nsContext.getCurrent().getOuterPeer();
+        if(op!=null)
+            assoc.addOuter( getBuilder().getCurrentElement(), op );
+
+        Object ip = nsContext.getCurrent().getInnerPeer();
+        if(ip!=null)
+            assoc.addInner( getBuilder().getCurrentElement(), ip );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/IndentingUTF8XmlOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/IndentingUTF8XmlOutput.java
new file mode 100644
index 0000000..50707fc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/IndentingUTF8XmlOutput.java
@@ -0,0 +1,155 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+import java.io.OutputStream;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.runtime.Name;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link UTF8XmlOutput} with indentation.
+ *
+ * TODO: not sure if it's a good idea to move the indenting functionality to another class.
+ *
+ * Doesn't have to be final, but it helps the JVM.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class IndentingUTF8XmlOutput extends UTF8XmlOutput {
+
+    /**
+     * Null if the writer should perform no indentation.
+     *
+     * Otherwise this will keep the 8 copies of the string for indentation.
+     * (so that we can write 8 indentation at once.)
+     */
+    private final Encoded indent8;
+
+    /**
+     * Length of one indentation.
+     */
+    private final int unitLen;
+
+    private int depth = 0;
+
+    private boolean seenText = false;
+
+    /**
+     *
+     * @param indentStr
+     *      set to null for no indentation and optimal performance.
+     *      otherwise the string is used for indentation.
+     */
+    public IndentingUTF8XmlOutput(OutputStream out, String indentStr, Encoded[] localNames) {
+        super(out, localNames);
+
+        if(indentStr!=null) {
+            Encoded e = new Encoded(indentStr);
+            indent8 = new Encoded();
+            indent8.ensureSize(e.len*8);
+            unitLen = e.len;
+            for( int i=0; i<8; i++ )
+                System.arraycopy(e.buf, 0, indent8.buf, unitLen*i, unitLen);
+        } else {
+            this.indent8 = null;
+            this.unitLen = 0;
+        }
+    }
+
+    @Override
+    public void beginStartTag(int prefix, String localName) throws IOException {
+        indentStartTag();
+        super.beginStartTag(prefix, localName);
+    }
+
+    @Override
+    public void beginStartTag(Name name) throws IOException {
+        indentStartTag();
+        super.beginStartTag(name);
+    }
+
+    private void indentStartTag() throws IOException {
+        closeStartTag();
+        if(!seenText)
+            printIndent();
+        depth++;
+        seenText = false;
+    }
+
+    @Override
+    public void endTag(Name name) throws IOException {
+        indentEndTag();
+        super.endTag(name);
+    }
+
+    @Override
+    public void endTag(int prefix, String localName) throws IOException {
+        indentEndTag();
+        super.endTag(prefix, localName);
+    }
+
+    private void indentEndTag() throws IOException {
+        depth--;
+        if(!closeStartTagPending && !seenText)
+            printIndent();
+        seenText = false;
+    }
+
+    private void printIndent() throws IOException {
+        write('\n');
+        int i = depth%8;
+
+        write( indent8.buf, 0, i*unitLen );
+
+        i>>=3;  // really i /= 8;
+
+        for( ; i>0; i-- )
+            indent8.write(this);
+    }
+
+    @Override
+    public void text(String value, boolean needSP) throws IOException {
+        seenText = true;
+        super.text(value, needSP);
+    }
+
+    @Override
+    public void text(Pcdata value, boolean needSP) throws IOException {
+        seenText = true;
+        super.text(value, needSP);
+    }
+
+    @Override
+    public void endDocument(boolean fragment) throws IOException, SAXException, XMLStreamException {
+        write('\n');
+        super.endDocument(fragment);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/MTOMXmlOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/MTOMXmlOutput.java
new file mode 100644
index 0000000..6f913d2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/MTOMXmlOutput.java
@@ -0,0 +1,133 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Base64Data;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link XmlOutput} decorator that supports MTOM.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class MTOMXmlOutput extends XmlOutputAbstractImpl {
+
+    private final XmlOutput next;
+
+    /**
+     * Remembers the last namespace URI and local name so that we can pass them to
+     * {@link AttachmentMarshaller}.
+     */
+    private String nsUri,localName;
+
+    public MTOMXmlOutput(XmlOutput next) {
+        this.next = next;
+    }
+
+    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws IOException, SAXException, XMLStreamException {
+        super.startDocument(serializer,fragment,nsUriIndex2prefixIndex, nsContext);
+        next.startDocument(serializer, fragment, nsUriIndex2prefixIndex, nsContext);
+    }
+
+    public void endDocument(boolean fragment) throws IOException, SAXException, XMLStreamException {
+        next.endDocument(fragment);
+        super.endDocument(fragment);
+    }
+
+    public void beginStartTag(Name name) throws IOException, XMLStreamException {
+        next.beginStartTag(name);
+        this.nsUri = name.nsUri;
+        this.localName = name.localName;
+    }
+
+    public void beginStartTag(int prefix, String localName) throws IOException, XMLStreamException {
+        next.beginStartTag(prefix, localName);
+        this.nsUri = nsContext.getNamespaceURI(prefix);
+        this.localName = localName;
+    }
+
+    public void attribute( Name name, String value ) throws IOException, XMLStreamException {
+        next.attribute(name, value);
+    }
+
+    public void attribute( int prefix, String localName, String value ) throws IOException, XMLStreamException {
+        next.attribute(prefix, localName, value);
+    }
+
+    public void endStartTag() throws IOException, SAXException {
+        next.endStartTag();
+    }
+
+    public void endTag(Name name) throws IOException, SAXException, XMLStreamException {
+        next.endTag(name);
+    }
+
+    public void endTag(int prefix, String localName) throws IOException, SAXException, XMLStreamException {
+        next.endTag(prefix, localName);
+    }
+
+    public void text( String value, boolean needsSeparatingWhitespace ) throws IOException, SAXException, XMLStreamException {
+        next.text(value,needsSeparatingWhitespace);
+    }
+
+    public void text( Pcdata value, boolean needsSeparatingWhitespace ) throws IOException, SAXException, XMLStreamException {
+        if(value instanceof Base64Data && !serializer.getInlineBinaryFlag()) {
+            Base64Data b64d = (Base64Data) value;
+            String cid;
+            if(b64d.hasData())
+                cid = serializer.attachmentMarshaller.addMtomAttachment(
+                                b64d.get(),0,b64d.getDataLen(),b64d.getMimeType(),nsUri,localName);
+            else
+                cid = serializer.attachmentMarshaller.addMtomAttachment(
+                    b64d.getDataHandler(),nsUri,localName);
+
+            if(cid!=null) {
+                nsContext.getCurrent().push();
+                int prefix = nsContext.declareNsUri(WellKnownNamespace.XOP,"xop",false);
+                beginStartTag(prefix,"Include");
+                attribute(-1,"href",cid);
+                endStartTag();
+                endTag(prefix,"Include");
+                nsContext.getCurrent().pop();
+                return;
+            }
+        }
+        next.text(value, needsSeparatingWhitespace);
+    }
+
+    public void flush() throws IOException, XMLStreamException {
+        next.flush();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/NamespaceContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/NamespaceContextImpl.java
new file mode 100644
index 0000000..a4076d9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/NamespaceContextImpl.java
@@ -0,0 +1,529 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+import java.util.Collections;
+import java.util.Iterator;
+
+import javax.xml.XMLConstants;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.istack.internal.Nullable;
+import com.sun.xml.internal.bind.marshaller.NamespacePrefixMapper;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.NamespaceContext2;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Keeps track of in-scope namespace bindings for the marshaller.
+ *
+ * <p>
+ * This class is also used to keep track of tag names for each element
+ * for the marshaller (for the performance reason.)
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class NamespaceContextImpl implements NamespaceContext2 {
+    private final XMLSerializer owner;
+
+    private String[] prefixes = new String[4];
+    private String[] nsUris = new String[4];
+//    /**
+//     * True if the correponding namespace declaration is an authentic one that should be printed.
+//     *
+//     * False if it's a re-discovered in-scope namespace binding available at the ancestor elements
+//     * outside this marhsalling. The false value is used to incorporate the in-scope namespace binding
+//     * information from {@link #inscopeNamespaceContext}. When false, such a declaration does not need
+//     * to be printed, as it's already available in ancestors.
+//     */
+//    private boolean[] visible = new boolean[4];
+//
+//    /**
+//     * {@link NamespaceContext} that informs this {@link XMLSerializer} about the
+//     * in-scope namespace bindings of the ancestor elements outside this marshalling.
+//     *
+//     * <p>
+//     * This is used when the marshaller is marshalling into a subtree that has ancestor
+//     * elements created outside the JAXB marshaller.
+//     *
+//     * Its {@link NamespaceContext#getPrefix(String)} is used to discover in-scope namespace
+//     * binding,
+//     */
+//    private final NamespaceContext inscopeNamespaceContext;
+
+    /**
+     * Number of URIs declared. Identifies the valid portion of
+     * the {@link #prefixes} and {@link #nsUris} arrays.
+     */
+    private int size;
+
+    private Element current;
+
+    /**
+     * This is the {@link Element} whose prev==null.
+     * This element is used to hold the contextual namespace bindings
+     * that are assumed to be outside of the document we are marshalling.
+     * Specifically the xml prefix and any other user-specified bindings.
+     *
+     * @see NamespacePrefixMapper#getPreDeclaredNamespaceUris()
+     */
+    private final Element top;
+
+    /**
+     * Never null.
+     */
+    private NamespacePrefixMapper prefixMapper = defaultNamespacePrefixMapper;
+
+    /**
+     * True to allow new URIs to be declared. False otherwise.
+     */
+    public boolean collectionMode;
+
+
+    public NamespaceContextImpl(XMLSerializer owner) {
+        this.owner = owner;
+
+        current = top = new Element(this,null);
+        // register namespace URIs that are implicitly bound
+        put(XMLConstants.XML_NS_URI,XMLConstants.XML_NS_PREFIX);
+    }
+
+    public void setPrefixMapper( NamespacePrefixMapper mapper ) {
+        if(mapper==null)
+            mapper = defaultNamespacePrefixMapper;
+        this.prefixMapper = mapper;
+    }
+
+    public NamespacePrefixMapper getPrefixMapper() {
+        return prefixMapper;
+    }
+
+    public void reset() {
+        current = top;
+        size = 1;
+        collectionMode = false;
+    }
+
+    /**
+     * Returns the prefix index to the specified URI.
+     * This method allocates a new URI if necessary.
+     */
+    public int declareNsUri( String uri, String preferedPrefix, boolean requirePrefix ) {
+        preferedPrefix = prefixMapper.getPreferredPrefix(uri,preferedPrefix,requirePrefix);
+
+        if(uri.length()==0) {
+            for( int i=size-1; i>=0; i-- ) {
+                if(nsUris[i].length()==0)
+                    return i; // already declared
+                if(prefixes[i].length()==0) {
+                    // the default prefix is already taken.
+                    // move that URI to another prefix, then assign "" to the default prefix.
+                    assert current.defaultPrefixIndex==-1 && current.oldDefaultNamespaceUriIndex==-1;
+
+                    String oldUri = nsUris[i];
+                    String[] knownURIs = owner.nameList.namespaceURIs;
+
+                    if(current.baseIndex<=i) {
+                        // this default prefix is declared in this context. just reassign it
+
+                        nsUris[i] = "";
+
+                        int subst = put(oldUri,null);
+
+                        // update uri->prefix table if necessary
+                        for( int j=knownURIs.length-1; j>=0; j-- ) {
+                            if(knownURIs[j].equals(oldUri)) {
+                                owner.knownUri2prefixIndexMap[j] = subst;
+                                break;
+                            }
+                        }
+
+                        return i;
+                    } else {
+                        // first, if the previous URI assigned to "" is
+                        // a "known URI", remember what we've reallocated
+                        // so that we can fix it when this context pops.
+                        for( int j=knownURIs.length-1; j>=0; j-- ) {
+                            if(knownURIs[j].equals(oldUri)) {
+                                current.defaultPrefixIndex = i;
+                                current.oldDefaultNamespaceUriIndex = j;
+                                assert owner.knownUri2prefixIndexMap[j]==current.defaultPrefixIndex;
+                                // update the table to point to the prefix we'll declare
+                                owner.knownUri2prefixIndexMap[j] = size;
+                                break;
+                            }
+                        }
+
+                        put(nsUris[i],null);
+                        return put("", "");
+                    }
+                }
+            }
+
+            // "" isn't in use
+            return put("", "");
+        } else {
+            // check for the existing binding
+            for( int i=size-1; i>=0; i-- ) {
+                String p = prefixes[i];
+                if(nsUris[i].equals(uri)) {
+                    if(!requirePrefix || p.length()>0)
+                        return i;
+                    // declared but this URI is bound to empty. Look further
+                }
+                if(p.equals(preferedPrefix)) {
+                    // the suggested prefix is already taken. can't use it
+                    preferedPrefix = null;
+                }
+            }
+
+            if(preferedPrefix==null && requirePrefix)
+                // we know we can't bind to "", but we don't have any possible name at hand.
+                // generate it here to avoid this namespace to be bound to "".
+                preferedPrefix = makeUniquePrefix();
+
+            // haven't been declared. allocate a new one
+            // if the preferred prefix is already in use, it should have been set to null by this time
+            return put(uri, preferedPrefix);
+        }
+    }
+
+    /**
+     * {@inheritDoc}.
+     *
+     * @param prefix
+     *      if null, an unique prefix (including "") is allocated.
+     */
+    public int put(@NotNull String uri, @Nullable String prefix) {
+        if(size==nsUris.length) {
+            // reallocate
+            String[] u = new String[nsUris.length*2];
+            String[] p = new String[prefixes.length*2];
+            System.arraycopy(nsUris,0,u,0,nsUris.length);
+            System.arraycopy(prefixes,0,p,0,prefixes.length);
+            nsUris = u;
+            prefixes = p;
+        }
+        if(prefix==null) {
+            if(size==1)
+                prefix = "";    // if this is the first user namespace URI we see, use "".
+            else {
+                // otherwise make up an unique name
+                prefix = makeUniquePrefix();
+            }
+        }
+        nsUris[size] = uri;
+        prefixes[size] = prefix;
+
+        return size++;
+    }
+
+    private String makeUniquePrefix() {
+        String prefix;
+        prefix = new StringBuilder(5).append("ns").append(size).toString();
+        while(getNamespaceURI(prefix)!=null) {
+            prefix += '_';  // under a rare circumstance there might be existing 'nsNNN', so rename them
+        }
+        return prefix;
+    }
+
+
+    public Element getCurrent() {
+        return current;
+    }
+
+    /**
+     * Returns the prefix index of the specified URI.
+     * It is an error if the URI is not declared.
+     */
+    public int getPrefixIndex( String uri ) {
+        for( int i=size-1; i>=0; i-- ) {
+                if(nsUris[i].equals(uri))
+                    return i;
+        }
+        throw new IllegalStateException();
+    }
+
+    /**
+     * Gets the prefix from a prefix index.
+     *
+     * The behavior is undefined if the index is out of range.
+     */
+    public String getPrefix(int prefixIndex) {
+        return prefixes[prefixIndex];
+    }
+
+    public String getNamespaceURI(int prefixIndex) {
+        return nsUris[prefixIndex];
+    }
+
+    /**
+     * Gets the namespace URI that is bound to the specified prefix.
+     *
+     * @return null
+     *      if the prefix is unbound.
+     */
+    public String getNamespaceURI(String prefix) {
+        for( int i=size-1; i>=0; i-- )
+            if(prefixes[i].equals(prefix))
+                return nsUris[i];
+        return null;
+    }
+
+    /**
+     * Returns the prefix of the specified URI,
+     * or null if none exists.
+     */
+    public String getPrefix( String uri ) {
+        if(collectionMode) {
+            return declareNamespace(uri,null,false);
+        } else {
+            for( int i=size-1; i>=0; i-- )
+                if(nsUris[i].equals(uri))
+                    return prefixes[i];
+            return null;
+        }
+    }
+
+    public Iterator<String> getPrefixes(String uri) {
+        String prefix = getPrefix(uri);
+        if(prefix==null)
+            return Collections.<String>emptySet().iterator();
+        else
+            return Collections.singleton(uri).iterator();
+    }
+
+    public String declareNamespace(String namespaceUri, String preferedPrefix, boolean requirePrefix) {
+        int idx = declareNsUri(namespaceUri,preferedPrefix,requirePrefix);
+        return getPrefix(idx);
+    }
+
+    /**
+     * Number of total bindings declared.
+     */
+    public int count() {
+        return size;
+    }
+
+
+    /**
+     * This model of namespace declarations maintain the following invariants.
+     *
+     * <ul>
+     *  <li>If a non-empty prefix is declared, it will never be reassigned to different namespace URIs.
+     *  <li>
+     */
+    public final class Element {
+
+        public final NamespaceContextImpl context;
+
+        /**
+         * {@link Element}s form a doubly-linked list.
+         */
+        private final Element prev;
+        private Element next;
+
+        private int oldDefaultNamespaceUriIndex;
+        private int defaultPrefixIndex;
+
+
+        /**
+         * The numbe of prefixes declared by ancestor {@link Element}s.
+         */
+        private int baseIndex;
+
+        /**
+         * The depth of the {@link Element}.
+         *
+         * This value is equivalent as the result of the following computation.
+         *
+         * <pre>
+         * int depth() {
+         *   int i=-1;
+         *   for(Element e=this; e!=null;e=e.prev)
+         *     i++;
+         *   return i;
+         * }
+         * </pre>
+         */
+        private final int depth;
+
+
+
+        private int elementNamePrefix;
+        private String elementLocalName;
+
+        /**
+         * Tag name of this element.
+         * Either this field is used or the {@link #elementNamePrefix} and {@link #elementLocalName} pair.
+         */
+        private Name elementName;
+
+        /**
+         * Used for the binder. The JAXB object that corresponds to this element.
+         */
+        private Object outerPeer;
+        private Object innerPeer;
+
+
+        private Element(NamespaceContextImpl context,Element prev) {
+            this.context = context;
+            this.prev = prev;
+            this.depth = (prev==null) ? 0 : prev.depth+1;
+        }
+
+        /**
+         * Returns true if this {@link Element} represents the root element that
+         * we are marshalling.
+         */
+        public boolean isRootElement() {
+            return depth==1;
+        }
+
+        public Element push() {
+            if(next==null)
+                next = new Element(context,this);
+            next.onPushed();
+            return next;
+        }
+
+        public Element pop() {
+            if(oldDefaultNamespaceUriIndex>=0) {
+                // restore the old default namespace URI binding
+                context.owner.knownUri2prefixIndexMap[oldDefaultNamespaceUriIndex] = defaultPrefixIndex;
+            }
+            context.size = baseIndex;
+            context.current = prev;
+            return prev;
+        }
+
+        private void onPushed() {
+            oldDefaultNamespaceUriIndex = defaultPrefixIndex = -1;
+            baseIndex = context.size;
+            context.current = this;
+        }
+
+        public void setTagName( int prefix, String localName, Object outerPeer ) {
+            assert localName!=null;
+            this.elementNamePrefix = prefix;
+            this.elementLocalName = localName;
+            this.elementName = null;
+            this.outerPeer = outerPeer;
+        }
+
+        public void setTagName( Name tagName, Object outerPeer ) {
+            assert tagName!=null;
+            this.elementName = tagName;
+            this.outerPeer = outerPeer;
+        }
+
+        public void startElement(XmlOutput out, Object innerPeer) throws IOException, XMLStreamException {
+            this.innerPeer = innerPeer;
+            if(elementName!=null) {
+                out.beginStartTag(elementName);
+            } else {
+                out.beginStartTag(elementNamePrefix,elementLocalName);
+            }
+        }
+
+        public void endElement(XmlOutput out) throws IOException, SAXException, XMLStreamException {
+            if(elementName!=null) {
+                out.endTag(elementName);
+                elementName = null;
+            } else {
+                out.endTag(elementNamePrefix,elementLocalName);
+            }
+        }
+
+        /**
+         * Gets the number of bindings declared on this element.
+         */
+        public final int count() {
+            return context.size-baseIndex;
+        }
+
+        /**
+         * Gets the prefix declared in this context.
+         *
+         * @param idx
+         *      between 0 and {@link #count()}
+         */
+        public final String getPrefix(int idx) {
+            return context.prefixes[baseIndex+idx];
+        }
+
+        /**
+         * Gets the namespace URI declared in this context.
+         *
+         * @param idx
+         *      between 0 and {@link #count()}
+         */
+        public final String getNsUri(int idx) {
+            return context.nsUris[baseIndex+idx];
+        }
+
+        public int getBase() {
+            return baseIndex;
+        }
+
+        public Object getOuterPeer() {
+            return outerPeer;
+        }
+
+        public Object getInnerPeer() {
+            return innerPeer;
+        }
+
+        /**
+         * Gets the parent {@link Element}.
+         */
+        public Element getParent() {
+            return prev;
+        }
+    }
+
+
+    /**
+     * Default {@link NamespacePrefixMapper} implementation used when
+     * it is not specified by the user.
+     */
+    private static final NamespacePrefixMapper defaultNamespacePrefixMapper = new NamespacePrefixMapper() {
+        public String getPreferredPrefix(String namespaceUri, String suggestion, boolean requirePrefix) {
+            if( namespaceUri.equals(WellKnownNamespace.XML_SCHEMA_INSTANCE) )
+                return "xsi";
+            if( namespaceUri.equals(WellKnownNamespace.XML_SCHEMA) )
+                return "xs";
+            if( namespaceUri.equals(WellKnownNamespace.XML_MIME_URI) )
+                return "xmime";
+            return suggestion;
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/Pcdata.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/Pcdata.java
new file mode 100644
index 0000000..7258634
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/Pcdata.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+
+/**
+ * Text data in XML.
+ *
+ * <p>
+ * This class is used inside the marshaller/unmarshaller to
+ * send/receive text data.
+ *
+ * <p>
+ * On top of {@link CharSequence}, this class has an
+ * ability to write itself to the {@link XmlOutput}. This allows
+ * the implementation to choose the most efficient way possible
+ * when writing to XML (for example, it can skip the escaping
+ * of buffer copying.)
+ *
+ * TODO: visitor pattern support?
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Pcdata implements CharSequence {
+
+    /**
+     * Writes itself to {@link UTF8XmlOutput}.
+     *
+     * <p>
+     * This is the most performance critical path for the marshaller,
+     * so it warrants its own method.
+     */
+    public abstract void writeTo(UTF8XmlOutput output) throws IOException;
+
+    /**
+     * Writes itself to the character array.
+     *
+     * <p>
+     * This method is used by most other {@link XmlOutput}.
+     * The default implementation involves in one extra char[] copying.
+     *
+     * <p>
+     * The caller must provide a big enough buffer that can hold
+     * enough characters returned by the {@link #length()} method.
+     */
+    public void writeTo(char[] buf, int start) {
+        toString().getChars(0,length(),buf,start);
+    }
+
+    public abstract String toString();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/SAXOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/SAXOutput.java
new file mode 100644
index 0000000..111518a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/SAXOutput.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.util.AttributesImpl;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.ContentHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.LocatorImpl;
+
+/**
+ * {@link XmlOutput} implementation that writes to SAX {@link ContentHandler}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class SAXOutput extends XmlOutputAbstractImpl {
+    protected final ContentHandler out;
+
+    public SAXOutput(ContentHandler out) {
+        this.out = out;
+        out.setDocumentLocator(new LocatorImpl());
+    }
+
+    private String elementNsUri,elementLocalName,elementQName;
+
+    private char[] buf = new char[256];
+
+    private final AttributesImpl atts = new AttributesImpl();
+
+
+    // not called if we are generating fragments
+    @Override
+    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws SAXException, IOException, XMLStreamException {
+        super.startDocument(serializer, fragment,nsUriIndex2prefixIndex,nsContext);
+        if(!fragment)
+            out.startDocument();
+    }
+
+    public void endDocument(boolean fragment) throws SAXException, IOException, XMLStreamException {
+        if(!fragment)
+            out.endDocument();
+        super.endDocument(fragment);
+    }
+
+    public void beginStartTag(int prefix, String localName) {
+        elementNsUri = nsContext.getNamespaceURI(prefix);
+        elementLocalName = localName;
+        elementQName = getQName(prefix,localName);
+        atts.clear();
+    }
+
+    public void attribute(int prefix, String localName, String value) {
+        String qname;
+        String nsUri;
+        if(prefix==-1) {
+            nsUri = "";
+            qname = localName;
+        } else {
+            nsUri = nsContext.getNamespaceURI(prefix);
+            qname = nsContext.getPrefix(prefix)+':'+localName;
+        }
+        atts.addAttribute( nsUri, localName, qname, "CDATA", value );
+    }
+
+    public void endStartTag() throws SAXException {
+        NamespaceContextImpl.Element ns = nsContext.getCurrent();
+        if(ns!=null) {
+            int sz = ns.count();
+            for( int i=0; i<sz; i++ ) {
+                String p = ns.getPrefix(i);
+                String uri = ns.getNsUri(i);
+                if(uri.length()==0 && ns.getBase()==1)
+                    continue;   // no point in defining xmlns='' on the root
+                out.startPrefixMapping(p,uri);
+            }
+        }
+        out.startElement(elementNsUri,elementLocalName,elementQName,atts);
+    }
+
+    public void endTag(int prefix, String localName) throws SAXException {
+        out.endElement(
+            nsContext.getNamespaceURI(prefix),
+            localName,
+            getQName(prefix, localName)
+        );
+
+        NamespaceContextImpl.Element ns = nsContext.getCurrent();
+        if(ns!=null) {
+            int sz = ns.count();
+            for( int i=sz-1; i>=0; i-- ) {
+                String p = ns.getPrefix(i);
+                String uri = ns.getNsUri(i);
+                if(uri.length()==0 && ns.getBase()==1)
+                    continue;   // no point in definint xmlns='' on the root
+                out.endPrefixMapping(p);
+            }
+        }
+    }
+
+    private String getQName(int prefix, String localName) {
+        String qname;
+        String p = nsContext.getPrefix(prefix);
+        if(p.length()==0)
+            qname = localName;
+        else
+            qname = p+':'+localName;
+        return qname;
+    }
+
+    public void text(String value, boolean needsSP) throws IOException, SAXException, XMLStreamException {
+        int vlen = value.length();
+        if(buf.length<=vlen) {
+            buf = new char[Math.max(buf.length*2,vlen+1)];
+        }
+        if(needsSP) {
+            value.getChars(0,vlen,buf,1);
+            buf[0] = ' ';
+        } else {
+            value.getChars(0,vlen,buf,0);
+        }
+        out.characters(buf,0,vlen+(needsSP?1:0));
+    }
+
+    public void text(Pcdata value, boolean needsSP) throws IOException, SAXException, XMLStreamException {
+        int vlen = value.length();
+        if(buf.length<=vlen) {
+            buf = new char[Math.max(buf.length*2,vlen+1)];
+        }
+        if(needsSP) {
+            value.writeTo(buf,1);
+            buf[0] = ' ';
+        } else {
+            value.writeTo(buf,0);
+        }
+        out.characters(buf,0,vlen+(needsSP?1:0));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/UTF8XmlOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/UTF8XmlOutput.java
new file mode 100644
index 0000000..0bace85
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/UTF8XmlOutput.java
@@ -0,0 +1,401 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+import java.io.OutputStream;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link XmlOutput} implementation specialized for UTF-8.
+ *
+ * @author Kohsuke Kawaguchi
+ * @author Paul Sandoz
+ */
+public class UTF8XmlOutput extends XmlOutputAbstractImpl {
+    protected final OutputStream out;
+
+    /** prefixes encoded. */
+    private Encoded[] prefixes = new Encoded[8];
+
+    /**
+     * Of the {@link #prefixes}, number of filled entries.
+     * This is almost the same as {@link NamespaceContextImpl#count()},
+     * except that it allows us to handle contextual in-scope namespace bindings correctly.
+     */
+    private int prefixCount;
+
+    /** local names encoded in UTF-8. All entries are pre-filled. */
+    private final Encoded[] localNames;
+
+    /** Temporary buffer used to encode text. */
+    /*
+     * TODO
+     * The textBuffer could write directly to the _octetBuffer
+     * when encoding a string if Encoder is modified.
+     * This will avoid an additional memory copy.
+     */
+    private final Encoded textBuffer = new Encoded();
+
+    /** Buffer of octets for writing. */
+    // TODO: Obtain buffer size from property on the JAXB context
+    protected final byte[] octetBuffer = new byte[1024];
+
+    /** Index in buffer to write to. */
+    protected int octetBufferIndex;
+
+    /**
+     * Set to true to indicate that we need to write '>'
+     * to close a start tag. Deferring the write of this char
+     * allows us to write "/>" for empty elements.
+     */
+    protected boolean closeStartTagPending = false;
+
+    /**
+     *
+     * @param localNames
+     *      local names encoded in UTF-8.
+     */
+    public UTF8XmlOutput(OutputStream out, Encoded[] localNames) {
+        this.out = out;
+        this.localNames = localNames;
+        for( int i=0; i<prefixes.length; i++ )
+            prefixes[i] = new Encoded();
+    }
+
+    @Override
+    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws IOException, SAXException, XMLStreamException {
+        super.startDocument(serializer, fragment,nsUriIndex2prefixIndex,nsContext);
+
+        octetBufferIndex = 0;
+        if(!fragment) {
+            write(XML_DECL);
+        }
+    }
+
+    public void endDocument(boolean fragment) throws IOException, SAXException, XMLStreamException {
+        flushBuffer();
+        super.endDocument(fragment);
+    }
+
+    /**
+     * Writes '>' to close the start tag, if necessary.
+     */
+    protected final void closeStartTag() throws IOException {
+        if(closeStartTagPending) {
+            write('>');
+            closeStartTagPending = false;
+        }
+    }
+
+    public void beginStartTag(int prefix, String localName) throws IOException {
+        closeStartTag();
+        int base= pushNsDecls();
+        write('<');
+        writeName(prefix,localName);
+        writeNsDecls(base);
+    }
+
+    public void beginStartTag(Name name) throws IOException {
+        closeStartTag();
+        int base = pushNsDecls();
+        write('<');
+        writeName(name);
+        writeNsDecls(base);
+    }
+
+    private int pushNsDecls() {
+        int total = nsContext.count();
+        NamespaceContextImpl.Element ns = nsContext.getCurrent();
+
+        if(total > prefixes.length) {
+            // reallocate
+            int m = Math.max(total,prefixes.length*2);
+            Encoded[] buf = new Encoded[m];
+            System.arraycopy(prefixes,0,buf,0,prefixes.length);
+            for( int i=prefixes.length; i<buf.length; i++ )
+                buf[i] = new Encoded();
+            prefixes = buf;
+        }
+
+        int base = Math.min(prefixCount,ns.getBase());
+        int size = nsContext.count();
+        for( int i=base; i<size; i++ ) {
+            String p = nsContext.getPrefix(i);
+
+            Encoded e = prefixes[i];
+
+            if(p.length()==0) {
+                e.buf = EMPTY_BYTE_ARRAY;
+                e.len = 0;
+            } else {
+                e.set(p);
+                e.append(':');
+            }
+        }
+        prefixCount = size;
+        return base;
+    }
+
+    protected void writeNsDecls(int base) throws IOException {
+        NamespaceContextImpl.Element ns = nsContext.getCurrent();
+        int size = nsContext.count();
+
+        for( int i=ns.getBase(); i<size; i++ )
+            writeNsDecl(i);
+    }
+
+    /**
+     * Writes a single namespace declaration for the specified prefix.
+     */
+    protected final void writeNsDecl(int prefixIndex) throws IOException {
+        String p = nsContext.getPrefix(prefixIndex);
+
+        if(p.length()==0) {
+            if(nsContext.getCurrent().isRootElement()
+            && nsContext.getNamespaceURI(prefixIndex).length()==0)
+                return;     // no point in declaring xmlns="" on the root element
+            write(XMLNS_EQUALS);
+        } else {
+            Encoded e = prefixes[prefixIndex];
+            write(XMLNS_COLON);
+            write(e.buf,0,e.len-1); // skip the trailing ':'
+            write(EQUALS);
+        }
+        doText(nsContext.getNamespaceURI(prefixIndex),true);
+        write('\"');
+    }
+
+    private void writePrefix(int prefix) throws IOException {
+        prefixes[prefix].write(this);
+    }
+
+    private void writeName(Name name) throws IOException {
+        writePrefix(nsUriIndex2prefixIndex[name.nsUriIndex]);
+        localNames[name.localNameIndex].write(this);
+    }
+
+    private void writeName(int prefix, String localName) throws IOException {
+        writePrefix(prefix);
+        textBuffer.set(localName);
+        textBuffer.write(this);
+    }
+
+    @Override
+    public void attribute(Name name, String value) throws IOException {
+        write(' ');
+        if(name.nsUriIndex==-1) {
+            localNames[name.localNameIndex].write(this);
+        } else
+            writeName(name);
+        write(EQUALS);
+        doText(value,true);
+        write('\"');
+    }
+
+    public void attribute(int prefix, String localName, String value) throws IOException {
+        write(' ');
+        if(prefix==-1) {
+            textBuffer.set(localName);
+            textBuffer.write(this);
+        } else
+            writeName(prefix,localName);
+        write(EQUALS);
+        doText(value,true);
+        write('\"');
+    }
+
+    public void endStartTag() throws IOException {
+        closeStartTagPending = true;
+    }
+
+    @Override
+    public void endTag(Name name) throws IOException {
+        if(closeStartTagPending) {
+            write(EMPTY_TAG);
+            closeStartTagPending = false;
+        } else {
+            write(CLOSE_TAG);
+            writeName(name);
+            write('>');
+        }
+    }
+
+    public void endTag(int prefix, String localName) throws IOException {
+        if(closeStartTagPending) {
+            write(EMPTY_TAG);
+            closeStartTagPending = false;
+        } else {
+            write(CLOSE_TAG);
+            writeName(prefix,localName);
+            write('>');
+        }
+    }
+
+    public void text(String value, boolean needSP) throws IOException {
+        closeStartTag();
+        if(needSP)
+            write(' ');
+        doText(value,false);
+    }
+
+    public void text(Pcdata value, boolean needSP) throws IOException {
+        closeStartTag();
+        if(needSP)
+            write(' ');
+        value.writeTo(this);
+    }
+
+    private void doText(String value,boolean isAttribute) throws IOException {
+        textBuffer.setEscape(value,isAttribute);
+        textBuffer.write(this);
+    }
+
+    public final void text(int value) throws IOException {
+        closeStartTag();
+        /*
+         * TODO
+         * Change to use the octet buffer directly
+         */
+
+        // max is -2147483648 and 11 digits
+        boolean minus = (value<0);
+        textBuffer.ensureSize(11);
+        byte[] buf = textBuffer.buf;
+        int idx = 11;
+
+        do {
+            int r = value%10;
+            if(r<0) r = -r;
+            buf[--idx] = (byte)('0'|r);    // really measn 0x30+r but 0<=r<10, so bit-OR would do.
+            value /= 10;
+        } while(value!=0);
+
+        if(minus)   buf[--idx] = (byte)'-';
+
+        write(buf,idx,11-idx);
+    }
+
+    /**
+     * Writes the given byte[] as base64 encoded binary to the output.
+     *
+     * <p>
+     * Being defined on this class allows this method to access the buffer directly,
+     * which translates to a better performance.
+     */
+    public void text(byte[] data, int dataLen) throws IOException {
+        closeStartTag();
+
+        int start = 0;
+
+        while(dataLen>0) {
+            // how many bytes (in data) can we write without overflowing the buffer?
+            int batchSize = Math.min(((octetBuffer.length-octetBufferIndex)/4)*3,dataLen);
+
+            // write the batch
+            octetBufferIndex = DatatypeConverterImpl._printBase64Binary(data,start,batchSize,octetBuffer,octetBufferIndex);
+
+            if(batchSize<dataLen)
+                flushBuffer();
+
+            start += batchSize;
+            dataLen -= batchSize;
+
+        }
+    }
+
+//
+//
+// series of the write method that places bytes to the output
+// (by doing some buffering internal to this class)
+//
+
+    /**
+     * Writes one byte directly into the buffer.
+     *
+     * <p>
+     * This method can be used somewhat like the {@code text} method,
+     * but it doesn't perform character escaping.
+     */
+    public final void write(int i) throws IOException {
+        if (octetBufferIndex < octetBuffer.length) {
+            octetBuffer[octetBufferIndex++] = (byte)i;
+        } else {
+            out.write(octetBuffer);
+            octetBufferIndex = 1;
+            octetBuffer[0] = (byte)i;
+        }
+    }
+
+    protected final void write(byte[] b) throws IOException {
+        write(b, 0,  b.length);
+    }
+
+    protected final void write(byte[] b, int start, int length) throws IOException {
+        if ((octetBufferIndex + length) < octetBuffer.length) {
+            System.arraycopy(b, start, octetBuffer, octetBufferIndex, length);
+            octetBufferIndex += length;
+        } else {
+            out.write(octetBuffer, 0, octetBufferIndex);
+            out.write(b, start, length);
+            octetBufferIndex = 0;
+        }
+    }
+
+    protected final void flushBuffer() throws IOException {
+        out.write(octetBuffer, 0, octetBufferIndex);
+        octetBufferIndex = 0;
+    }
+
+    public void flush() throws IOException {
+        flushBuffer();
+        out.flush();
+    }
+
+
+
+    static byte[] toBytes(String s) {
+        byte[] buf = new byte[s.length()];
+        for( int i=s.length()-1; i>=0; i-- )
+            buf[i] = (byte)s.charAt(i);
+        return buf;
+    }
+
+    private static final byte[] XMLNS_EQUALS = toBytes(" xmlns=\"");
+    private static final byte[] XMLNS_COLON = toBytes(" xmlns:");
+    private static final byte[] EQUALS = toBytes("=\"");
+    private static final byte[] CLOSE_TAG = toBytes("</");
+    private static final byte[] EMPTY_TAG = toBytes("/>");
+    private static final byte[] EMPTY_BYTE_ARRAY = new byte[0];
+    private static final byte[] XML_DECL = toBytes("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XMLEventWriterOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XMLEventWriterOutput.java
new file mode 100644
index 0000000..c95f9c5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XMLEventWriterOutput.java
@@ -0,0 +1,130 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLEventFactory;
+import javax.xml.stream.XMLEventWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.events.Attribute;
+import javax.xml.stream.events.Characters;
+
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link XmlOutput} that writes to StAX {@link XMLEventWriter}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class XMLEventWriterOutput extends XmlOutputAbstractImpl {
+    private final XMLEventWriter out;
+    private final XMLEventFactory ef;
+
+    /** One whitespace. */
+    private final Characters sp;
+
+    public XMLEventWriterOutput(XMLEventWriter out) {
+        this.out = out;
+        ef = XMLEventFactory.newInstance();
+        sp = ef.createCharacters(" ");
+    }
+
+    // not called if we are generating fragments
+    @Override
+    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws IOException, SAXException, XMLStreamException {
+        super.startDocument(serializer, fragment,nsUriIndex2prefixIndex,nsContext);
+        if(!fragment)
+            out.add(ef.createStartDocument());
+    }
+
+    public void endDocument(boolean fragment) throws IOException, SAXException, XMLStreamException {
+        if(!fragment) {
+            out.add(ef.createEndDocument());
+            out.flush();
+        }
+        super.endDocument(fragment);
+    }
+
+    public void beginStartTag(int prefix, String localName) throws IOException, XMLStreamException {
+        out.add(
+            ef.createStartElement(
+                nsContext.getPrefix(prefix),
+                nsContext.getNamespaceURI(prefix),
+                localName));
+
+        NamespaceContextImpl.Element nse = nsContext.getCurrent();
+        if(nse.count()>0) {
+            for( int i=nse.count()-1; i>=0; i-- ) {
+                String uri = nse.getNsUri(i);
+                if(uri.length()==0 && nse.getBase()==1)
+                    continue;   // no point in definint xmlns='' on the root
+                out.add(ef.createNamespace(nse.getPrefix(i),uri));
+            }
+        }
+    }
+
+    public void attribute(int prefix, String localName, String value) throws IOException, XMLStreamException {
+        Attribute att;
+        if(prefix==-1)
+            att = ef.createAttribute(localName,value);
+        else
+            att = ef.createAttribute(
+                    nsContext.getPrefix(prefix),
+                    nsContext.getNamespaceURI(prefix),
+                    localName, value);
+
+        out.add(att);
+    }
+
+    public void endStartTag() throws IOException, SAXException {
+        // noop
+    }
+
+    public void endTag(int prefix, String localName) throws IOException, SAXException, XMLStreamException {
+        out.add(
+            ef.createEndElement(
+                nsContext.getPrefix(prefix),
+                nsContext.getNamespaceURI(prefix),
+                localName));
+    }
+
+    public void text(String value, boolean needsSeparatingWhitespace) throws IOException, SAXException, XMLStreamException {
+        if(needsSeparatingWhitespace)
+            out.add(sp);
+        out.add(ef.createCharacters(value));
+    }
+
+    public void text(Pcdata value, boolean needsSeparatingWhitespace) throws IOException, SAXException, XMLStreamException {
+        text(value.toString(),needsSeparatingWhitespace);
+    }
+
+    public void flush() throws IOException, XMLStreamException {
+        out.flush();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XMLStreamWriterOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XMLStreamWriterOutput.java
new file mode 100644
index 0000000..7004946
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XMLStreamWriterOutput.java
@@ -0,0 +1,194 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+import java.lang.reflect.Constructor;
+
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+
+import com.sun.xml.internal.bind.v2.runtime.MarshallerImpl;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link XmlOutput} that writes to StAX {@link XMLStreamWriter}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class XMLStreamWriterOutput extends XmlOutputAbstractImpl {
+
+    /**
+     * Creates a new {@link XmlOutput} from a {@link XMLStreamWriter}.
+     * This method recognizes an FI StAX writer.
+     */
+    public static XmlOutput create(XMLStreamWriter out) {
+        // try optimized path
+        if(out.getClass()==FI_STAX_WRITER_CLASS) {
+            try {
+                return FI_OUTPUT_CTOR.newInstance(out);
+            } catch (Exception e) {
+            }
+        }
+        if(STAXEX_WRITER_CLASS!=null && STAXEX_WRITER_CLASS.isAssignableFrom(out.getClass())) {
+            try {
+                return STAXEX_OUTPUT_CTOR.newInstance(out);
+            } catch (Exception e) {
+            }
+        }
+
+        // otherwise the normal writer.
+        return new XMLStreamWriterOutput(out);
+    }
+
+
+    private final XMLStreamWriter out;
+
+    private final char[] buf = new char[256];
+
+    protected XMLStreamWriterOutput(XMLStreamWriter out) {
+        this.out = out;
+    }
+
+    // not called if we are generating fragments
+    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws IOException, SAXException, XMLStreamException {
+        super.startDocument(serializer, fragment,nsUriIndex2prefixIndex,nsContext);
+        if(!fragment)
+            out.writeStartDocument();
+    }
+
+    public void endDocument(boolean fragment) throws IOException, SAXException, XMLStreamException {
+        if(!fragment) {
+            out.writeEndDocument();
+            out.flush();
+        }
+        super.endDocument(fragment);
+    }
+
+    public void beginStartTag(int prefix, String localName) throws IOException, XMLStreamException {
+        out.writeStartElement(
+            nsContext.getPrefix(prefix),
+            localName,
+            nsContext.getNamespaceURI(prefix));
+
+        NamespaceContextImpl.Element nse = nsContext.getCurrent();
+        if(nse.count()>0) {
+            for( int i=nse.count()-1; i>=0; i-- ) {
+                String uri = nse.getNsUri(i);
+                if(uri.length()==0 && nse.getBase()==1)
+                    continue;   // no point in definint xmlns='' on the root
+                out.writeNamespace(nse.getPrefix(i),uri);
+            }
+        }
+    }
+
+    public void attribute(int prefix, String localName, String value) throws IOException, XMLStreamException {
+        if(prefix==-1)
+            out.writeAttribute(localName,value);
+        else
+            out.writeAttribute(
+                    nsContext.getPrefix(prefix),
+                    nsContext.getNamespaceURI(prefix),
+                    localName, value);
+    }
+
+    public void endStartTag() throws IOException, SAXException {
+        // noop
+    }
+
+    public void endTag(int prefix, String localName) throws IOException, SAXException, XMLStreamException {
+        out.writeEndElement();
+    }
+
+    public void text(String value, boolean needsSeparatingWhitespace) throws IOException, SAXException, XMLStreamException {
+        if(needsSeparatingWhitespace)
+            out.writeCharacters(" ");
+        out.writeCharacters(value);
+    }
+
+    public void text(Pcdata value, boolean needsSeparatingWhitespace) throws IOException, SAXException, XMLStreamException {
+        if(needsSeparatingWhitespace)
+            out.writeCharacters(" ");
+
+        int len = value.length();
+        if(len <buf.length) {
+            value.writeTo(buf,0);
+            out.writeCharacters(buf,0,len);
+        } else {
+            out.writeCharacters(value.toString());
+        }
+    }
+
+
+    /**
+     * Reference to FI's XMLStreamWriter class, if FI can be loaded.
+     */
+    private static final Class FI_STAX_WRITER_CLASS = initFIStAXWriterClass();
+    private static final Constructor<? extends XmlOutput> FI_OUTPUT_CTOR = initFastInfosetOutputClass();
+
+    private static Class initFIStAXWriterClass() {
+        try {
+            return MarshallerImpl.class.getClassLoader().loadClass("com.sun.xml.internal.fastinfoset.stax.StAXDocumentSerializer");
+        } catch (Throwable e) {
+            return null;
+        }
+    }
+
+    private static Constructor<? extends XmlOutput> initFastInfosetOutputClass() {
+        try {
+            Class c = UnmarshallerImpl.class.getClassLoader().loadClass("com.sun.xml.internal.bind.v2.runtime.output.FastInfosetStreamWriterOutput");
+            return c.getConstructor(FI_STAX_WRITER_CLASS);
+        } catch (Throwable e) {
+            return null;
+        }
+    }
+
+    //
+    // StAX-ex
+    //
+    private static final Class STAXEX_WRITER_CLASS = initStAXExWriterClass();
+    private static final Constructor<? extends XmlOutput> STAXEX_OUTPUT_CTOR = initStAXExOutputClass();
+
+    private static Class initStAXExWriterClass() {
+        try {
+            return MarshallerImpl.class.getClassLoader().loadClass("org.jvnet.staxex.XMLStreamWriterEx");
+        } catch (Throwable e) {
+            return null;
+        }
+    }
+
+    private static Constructor<? extends XmlOutput> initStAXExOutputClass() {
+        try {
+            Class c = UnmarshallerImpl.class.getClassLoader().loadClass("com.sun.xml.internal.bind.v2.runtime.output.StAXExStreamWriterOutput");
+            return c.getConstructor(STAXEX_WRITER_CLASS);
+        } catch (Throwable e) {
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XmlOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XmlOutput.java
new file mode 100644
index 0000000..9132eb3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XmlOutput.java
@@ -0,0 +1,182 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+import java.io.OutputStream;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.NameList;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Well-formed XML writer.
+ *
+ * <p>
+ * Implementations of this interface is used to connect {@link XMLSerializer}
+ * to the actual target. This allows {@link XMLSerializer} to be API agnostic.
+ *
+ *
+ * <h2>Notes</h2>
+ * <p>
+ * {@link JAXBContext} assigns indices to URIs and local names
+ * that are statically known by using {@link NameList}.
+ * {@link XmlOutput} implementation can use these indices to improve
+ * the performance. For example, those namespace URI indices can be
+ * turned into prefixes quickly.
+ *
+ * <p>
+ * {@link XmlOutput} still allows arbitrary namepsace URIs / local names
+ * to be written.
+ *
+ * <p>
+ * The {@link NamespaceContextImpl} object, which is shared between {@link XmlOutput} and
+ * {@link XMLSerializer}, keeps track of the in-scope namespace bindings. By the time
+ * the {@link #beginStartTag} method is called, all the namespace bindings for the new
+ * element is already declared. Similarly, after the {@link #endTag} method is called,
+ * in-scope bindings will be removed. This book keeping is all done outside {@link XmlOutput}.
+ *
+ * <p>
+ * {@link XmlOutput} and {@link XMLSerializer} uses indices to
+ * reference prefixes/URIs to be written. {@link NamespaceContextImpl} can
+ * convert prefix indices to URIs and the string representations of prefixes.
+ * Binding from indices to URIs and prefixes do not change while indices
+ * are "in scope", so {@link XmlOutput} is again expected to take advantage of
+ * this to improve the perofmrnace.
+ *
+ * <p>
+ * prefix index 0 is reserved for "xml", and this binding is assumed to be always there.
+ * {@link NamespaceContextImpl} can handle this index correctly, but this binding will never
+ * be reported to {@link XmlOutput} through {@link #beginStartTag}.
+ *
+ * <p>
+ * One pecurilar behavior of a {@link NamespaceContextImpl} object is that it tries
+ * to define redundant xmlns="" on the root element. Implementations of {@link XmlOutput}
+ * is encouraged to check for this and avoid generating redundant namespace declarations.
+ *
+ *
+ *
+ * <h2>Call Sequence</h2>
+ * <p>
+ * {@link XMLSerializer} calls the writer methods in the following order:
+ *
+ * <pre>
+ * CALLSEQUENCE  :=  {@link #startDocument startDocument} ELEMENT {@link #endDocument endDocument}
+ *               |   ELEMENT   // for fragment
+ *
+ * ELEMENT       :=  {@link #beginStartTag beginStartTag} {@link #attribute attribute}* {@link #endStartTag endStartTag} CONTENTS {@link #endTag endTag}
+ *
+ * CONTENTS      :=  (ELEMENT | {@link #text text})*
+ * </pre>
+ *
+ * TODO: for FI, consider making attribute values from Strings to CharSequences.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface XmlOutput {
+//
+//
+// Contracts
+//
+//
+    /**
+     * Called at the very beginning.
+     *
+     * @param serializer
+     *      the {@link XMLSerializer} that coordinates this whole marshalling episode.
+     * @param fragment
+     *      true if we are marshalling a fragment.
+     */
+    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws IOException, SAXException, XMLStreamException;
+    /**
+     * Called at the very end.
+     *
+     * @param fragment
+     *      false if we are writing the whole document.
+     */
+    public void endDocument(boolean fragment) throws IOException, SAXException, XMLStreamException;
+
+    /**
+     * Writes a start tag.
+     *
+     * <p>
+     * At this point {@link NamespaceContextImpl} holds namespace declarations needed for this
+     * new element.
+     *
+     * <p>
+     * This method is used for writing tags that are indexed.
+     */
+    public void beginStartTag(Name name) throws IOException, XMLStreamException;
+
+    public void beginStartTag(int prefix, String localName) throws IOException, XMLStreamException;
+
+    public void attribute( Name name, String value ) throws IOException, XMLStreamException;
+
+    /**
+     * @param prefix
+     *      -1 if this attribute does not have a prefix
+     *      (this handling differs from that of elements.)
+     */
+    public void attribute( int prefix, String localName, String value ) throws IOException, XMLStreamException;
+
+    public void endStartTag() throws IOException, SAXException;
+
+    public void endTag(Name name) throws IOException, SAXException, XMLStreamException;
+
+    public void endTag(int prefix, String localName) throws IOException, SAXException, XMLStreamException;
+
+    /**
+     * Writes XML text with character escaping, if necessary.
+     *
+     * @param value
+     *      this string can contain characters that might need escaping
+     *      (such as '&amp;' or '>')
+     * @param needsSeparatingWhitespace
+     */
+    public void text( String value, boolean needsSeparatingWhitespace ) throws IOException, SAXException, XMLStreamException;
+
+    /**
+     * Writes XML text with character escaping, if necessary.
+     *
+     * @param value
+     *      this string can contain characters that might need escaping
+     *      (such as '&amp;' or '>')
+     * @param needsSeparatingWhitespace
+     */
+    public void text( Pcdata value, boolean needsSeparatingWhitespace ) throws IOException, SAXException, XMLStreamException;
+
+    /**
+     * Flush the output.
+     *
+     * @see OutputStream#flush()
+     */
+    public void flush() throws IOException, XMLStreamException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XmlOutputAbstractImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XmlOutputAbstractImpl.java
new file mode 100644
index 0000000..918e4a5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/XmlOutputAbstractImpl.java
@@ -0,0 +1,146 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.output;
+
+import java.io.IOException;
+import java.io.OutputStream;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Abstract implementation of {@link XmlOutput}
+ *
+ * Implements the optimal methods, where defer to
+ * the non-optimal methods.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class XmlOutputAbstractImpl implements XmlOutput {
+//
+//
+// Contracts
+//
+//
+    /**
+     * Called at the very beginning.
+     *
+     * @param serializer
+     *      the {@link XMLSerializer} that coordinates this whole marshalling episode.
+     * @param fragment
+     *      true if we are marshalling a fragment.
+     */
+    public void startDocument(XMLSerializer serializer, boolean fragment, int[] nsUriIndex2prefixIndex, NamespaceContextImpl nsContext) throws IOException, SAXException, XMLStreamException {
+        this.nsUriIndex2prefixIndex = nsUriIndex2prefixIndex;
+        this.nsContext = nsContext;
+        this.serializer = serializer;
+    }
+
+    /**
+     * Called at the very end.
+     *
+     * @param fragment
+     *      false if we are writing the whole document.
+     */
+    public void endDocument(boolean fragment) throws IOException, SAXException, XMLStreamException {
+        serializer = null;
+    }
+
+    /**
+     * Writes a start tag.
+     *
+     * <p>
+     * At this point {@link #nsContext} holds namespace declarations needed for this
+     * new element.
+     *
+     * <p>
+     * This method is used for writing tags that are indexed.
+     */
+    public void beginStartTag(Name name) throws IOException, XMLStreamException {
+        beginStartTag( nsUriIndex2prefixIndex[name.nsUriIndex], name.localName );
+    }
+
+    public abstract void beginStartTag(int prefix, String localName) throws IOException, XMLStreamException;
+
+    public void attribute( Name name, String value ) throws IOException, XMLStreamException {
+        short idx = name.nsUriIndex;
+        if(idx==-1)
+            attribute(-1,name.localName, value);
+        else
+            attribute( nsUriIndex2prefixIndex[idx], name.localName, value );
+    }
+    /**
+     * @param prefix
+     *      -1 if this attribute does not have a prefix
+     *      (this handling differs from that of elements.)
+     */
+    public abstract void attribute( int prefix, String localName, String value ) throws IOException, XMLStreamException;
+
+    public abstract void endStartTag() throws IOException, SAXException;
+
+    public void endTag(Name name) throws IOException, SAXException, XMLStreamException {
+        endTag( nsUriIndex2prefixIndex[name.nsUriIndex], name.localName);
+    }
+    public abstract void endTag(int prefix, String localName) throws IOException, SAXException, XMLStreamException;
+
+    /**
+     * Flush the output.
+     *
+     * @see OutputStream#flush()
+     */
+    public void flush() throws IOException, XMLStreamException {
+    }
+
+
+
+
+//
+//
+// Utilities for implementations
+//
+//
+    /**
+     * The conversion table from the namespace URI index to prefix index.
+     *
+     * This array is shared with {@link XMLSerializer} and
+     * is updated by it automatically.
+     *
+     * This allows {@link Name#nsUriIndex} to be converted to prefix index
+     * (for {@link NamespaceContextImpl}) quickly.
+     */
+    protected int[] nsUriIndex2prefixIndex;
+
+    /**
+     * Set by the marshaller before the start tag is written for the root element.
+     */
+    protected NamespaceContextImpl nsContext;
+
+    protected XMLSerializer serializer;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/package-info.java
new file mode 100644
index 0000000..2626f44
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/output/package-info.java
@@ -0,0 +1,29 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * Code that writes well-formed XML ({@link XmlOutput} and its implementations}.
+ */
+package com.sun.xml.internal.bind.v2.runtime.output;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/package.html b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/package.html
new file mode 100644
index 0000000..d599e94
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+Code that implements JAXBContext, Unmarshaller, and Marshaller.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayERProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayERProperty.java
new file mode 100644
index 0000000..366f70b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayERProperty.java
@@ -0,0 +1,179 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+import java.util.Collection;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.TagName;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Receiver;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Scope;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Commonality between {@link ArrayElementProperty} and {@link ArrayReferenceNodeProperty}.
+ *
+ * Mostly handles the unmarshalling of the wrapper element.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class ArrayERProperty<BeanT,ListT,ItemT> extends ArrayProperty<BeanT,ListT,ItemT> {
+
+    /**
+     * Wrapper tag name if any, or null.
+     */
+    protected final Name wrapperTagName;
+
+    /**
+     * True if the wrapper tag name is nillable.
+     * Always false if {@link #wrapperTagName}==null.
+     */
+    protected final boolean isWrapperNillable;
+
+    protected ArrayERProperty(JAXBContextImpl grammar, RuntimePropertyInfo prop, QName tagName, boolean isWrapperNillable) {
+        super(grammar,prop);
+        if(tagName==null)
+            this.wrapperTagName = null;
+        else
+            this.wrapperTagName = grammar.nameBuilder.createElementName(tagName);
+        this.isWrapperNillable = isWrapperNillable;
+    }
+
+
+    private static final class ItemsLoader extends Loader {
+        public ItemsLoader(QNameMap<ChildLoader> children) {
+            super(false);
+            this.children = children;
+        }
+
+        @Override
+        public void startElement(UnmarshallingContext.State state, TagName ea) {
+            state.getContext().startScope(1);
+            // inherit the target so that our children can access its target
+            state.target = state.prev.target;
+        }
+
+        private final QNameMap<ChildLoader> children;
+
+        @Override
+        public void childElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+            ChildLoader child = children.get(ea.uri,ea.local);
+            if(child!=null) {
+                state.loader = child.loader;
+                state.receiver = child.receiver;
+            } else {
+                super.childElement(state,ea);
+            }
+        }
+
+        @Override
+        public void leaveElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+            state.getContext().endScope(1);
+        }
+
+        @Override
+        public Collection<QName> getExpectedChildElements() {
+            return children.keySet();
+        }
+    }
+
+    public final void serializeBody(BeanT o, XMLSerializer w, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException {
+        ListT list = acc.get(o);
+
+        if(list!=null) {
+            if(wrapperTagName!=null) {
+                w.startElement(wrapperTagName,null);
+                w.endNamespaceDecls(list);
+                w.endAttributes();
+            }
+
+            serializeListBody(o,w,list);
+
+            if(wrapperTagName!=null)
+                w.endElement();
+        } else {
+            // list is null
+            if(isWrapperNillable) {
+                w.startElement(wrapperTagName,null);
+                w.writeXsiNilTrue();
+                w.endElement();
+            } // otherwise don't print the wrapper tag name
+        }
+    }
+
+    /**
+     * Serializses the items of the list.
+     * This method is invoked after the necessary wrapper tag is produced (if necessary.)
+     *
+     * @param list
+     *      always non-null.
+     */
+    protected abstract void serializeListBody(BeanT o, XMLSerializer w, ListT list) throws IOException, XMLStreamException, SAXException, AccessorException;
+
+    /**
+     * Creates the unmarshaller to unmarshal the body.
+     */
+    protected abstract void createBodyUnmarshaller(UnmarshallerChain chain, QNameMap<ChildLoader> loaders);
+
+
+    public final void buildChildElementUnmarshallers(UnmarshallerChain chain, QNameMap<ChildLoader> loaders) {
+        if(wrapperTagName!=null) {
+            UnmarshallerChain c = new UnmarshallerChain(chain.context);
+            QNameMap<ChildLoader> m = new QNameMap<ChildLoader>();
+            createBodyUnmarshaller(c,m);
+            loaders.put(wrapperTagName,new ChildLoader(new ItemsLoader(m),null));
+        } else {
+            createBodyUnmarshaller(chain,loaders);
+        }
+    }
+
+    /**
+     * {@link Receiver} that puts the child object into the {@link Scope} object.
+     */
+    protected final class ReceiverImpl implements Receiver {
+        private final int offset;
+
+        protected ReceiverImpl(int offset) {
+            this.offset = offset;
+        }
+
+        public void receive(UnmarshallingContext.State state, Object o) throws SAXException {
+            state.getContext().getScope(offset).add(acc,lister,o);
+        }
+    }}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementLeafProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementLeafProperty.java
new file mode 100644
index 0000000..271e9d2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementLeafProperty.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link ArrayProperty} that contains only one leaf type.
+ *
+ * <p>
+ * This class is optimized for the case where there's only one kind of types
+ * in the array and that type is a leaf type.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class ArrayElementLeafProperty<BeanT,ListT,ItemT> extends ArrayElementProperty<BeanT,ListT,ItemT> {
+
+    private final Transducer<ItemT> xducer;
+
+    public ArrayElementLeafProperty(JAXBContextImpl p, RuntimeElementPropertyInfo prop) {
+        super(p, prop);
+
+        // unless those are true, use the ArrayElementNodeProperty.
+        assert prop.getTypes().size()==1;
+//        assert prop.getTypes().get(0).getType().isLeaf(); // this assertion is incorrect in case it's IDREF
+
+        xducer = prop.getTypes().get(0).getTransducer();
+        assert xducer!=null;
+    }
+
+    public void serializeItem(JaxBeanInfo bi, ItemT item, XMLSerializer w) throws SAXException, AccessorException, IOException, XMLStreamException {
+        xducer.declareNamespace(item,w);
+        w.endNamespaceDecls(item);
+        w.endAttributes();
+        // this is leaf, so by definition there's no type substitution
+        // if there's, we'll be using ArrayElementNodeProperty
+        xducer.writeText(w,item,fieldName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementNodeProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementNodeProperty.java
new file mode 100644
index 0000000..858033f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementNodeProperty.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link ArrayProperty} that contains node values.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ArrayElementNodeProperty<BeanT,ListT,ItemT> extends ArrayElementProperty<BeanT,ListT,ItemT> {
+
+    public ArrayElementNodeProperty(JAXBContextImpl p, RuntimeElementPropertyInfo prop) {
+        super(p, prop);
+    }
+
+    public void serializeItem(JaxBeanInfo expected, ItemT item, XMLSerializer w) throws SAXException, IOException, XMLStreamException {
+        if(item==null) {
+            w.writeXsiNilTrue();
+        } else {
+            w.childAsXsiType(item,fieldName,expected);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementProperty.java
new file mode 100644
index 0000000..83bbb20
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayElementProperty.java
@@ -0,0 +1,244 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+import java.lang.reflect.Type;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.TypeRef;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeRef;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.RuntimeUtil;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.ListIterator;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Lister;
+import com.sun.xml.internal.bind.v2.runtime.reflect.NullSafeAccessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.DefaultValueLoaderDecorator;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Receiver;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.TextLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiNilLoader;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Property} implementation for multi-value property that maps to an element.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class ArrayElementProperty<BeanT,ListT,ItemT> extends ArrayERProperty<BeanT,ListT,ItemT> {
+
+    private final Map<Class,TagAndType> typeMap  = new HashMap<Class,TagAndType>();
+    /**
+     * Set by the constructor and reset in the {@link #wrapUp()} method.
+     */
+    private Map<TypeRef<Type,Class>,JaxBeanInfo> refs = new HashMap<TypeRef<Type, Class>, JaxBeanInfo>();
+    /**
+     * Set by the constructor and reset in the {@link #wrapUp()} method.
+     */
+    protected RuntimeElementPropertyInfo prop;
+
+    /**
+     * Tag name used when we see null in the collection. Can be null.
+     */
+    private final Name nillableTagName;
+
+    protected ArrayElementProperty(JAXBContextImpl grammar, RuntimeElementPropertyInfo prop) {
+        super(grammar, prop, prop.getXmlName(), prop.isCollectionNillable());
+        this.prop = prop;
+
+        List<? extends RuntimeTypeRef> types = prop.getTypes();
+
+        Name n = null;
+
+        for (RuntimeTypeRef typeRef : types) {
+            Class type = (Class)typeRef.getTarget().getType();
+            if(type.isPrimitive())
+                type = RuntimeUtil.primitiveToBox.get(type);
+
+            JaxBeanInfo beanInfo = grammar.getOrCreate(typeRef.getTarget());
+            TagAndType tt = new TagAndType(
+                                grammar.nameBuilder.createElementName(typeRef.getTagName()),
+                                beanInfo);
+            typeMap.put(type,tt);
+            refs.put(typeRef,beanInfo);
+            if(typeRef.isNillable() && n==null)
+                n = tt.tagName;
+        }
+
+        nillableTagName = n;
+    }
+
+    @Override
+    public void wrapUp() {
+        super.wrapUp();
+        refs = null;
+        prop = null;    // avoid keeping model objects live
+    }
+
+    protected void serializeListBody(BeanT beanT, XMLSerializer w, ListT list) throws IOException, XMLStreamException, SAXException, AccessorException {
+        ListIterator<ItemT> itr = lister.iterator(list, w);
+
+        boolean isIdref = itr instanceof Lister.IDREFSIterator; // UGLY
+
+        while(itr.hasNext()) {
+            try {
+                ItemT item = itr.next();
+                if (item != null) {
+                    Class itemType = item.getClass();
+                    if(isIdref)
+                        // This should be the only place where we need to be aware
+                        // that the iterator is iterating IDREFS.
+                        itemType = ((Lister.IDREFSIterator)itr).last().getClass();
+
+                    // normally, this returns non-null
+                    TagAndType tt = typeMap.get(itemType);
+                    while(tt==null && itemType!=null) {
+                        // otherwise we'll just have to try the slow way
+                        itemType = itemType.getSuperclass();
+                        tt = typeMap.get(itemType);
+                    }
+
+                    if(tt==null) {
+                        // item is not of the expected type.
+//                        w.reportError(new ValidationEventImpl(ValidationEvent.ERROR,
+//                            Messages.UNEXPECTED_JAVA_TYPE.format(
+//                                item.getClass().getName(),
+//                                getExpectedClassNameList()
+//                            ),
+//                            w.getCurrentLocation(fieldName)));
+//                        continue;
+
+                        // see the similar code in SingleElementNodeProperty.
+                        // for the purpose of simple type substitution, make it a non-error
+
+                        w.startElement(typeMap.values().iterator().next().tagName,null);
+                        w.childAsXsiType(item,fieldName,w.grammar.getBeanInfo(Object.class));
+                    } else {
+                        w.startElement(tt.tagName,null);
+                        serializeItem(tt.beanInfo,item,w);
+                    }
+
+                    w.endElement();
+                } else {
+                    if(nillableTagName!=null) {
+                        w.startElement(nillableTagName,null);
+                        w.writeXsiNilTrue();
+                        w.endElement();
+                    }
+                }
+            } catch (JAXBException e) {
+                w.reportError(fieldName,e);
+                // recover by ignoring this item
+            }
+        }
+    }
+
+    /**
+     * Serializes one item of the property.
+     */
+    protected abstract void serializeItem(JaxBeanInfo expected, ItemT item, XMLSerializer w) throws SAXException, AccessorException, IOException, XMLStreamException;
+
+
+    public void createBodyUnmarshaller(UnmarshallerChain chain, QNameMap<ChildLoader> loaders) {
+
+        // all items go to the same lister,
+        // so they should share the same offset.
+        int offset = chain.allocateOffset();
+        Receiver recv = new ReceiverImpl(offset);
+
+        for (RuntimeTypeRef typeRef : prop.getTypes()) {
+
+            Name tagName = chain.context.nameBuilder.createElementName(typeRef.getTagName());
+            Loader item = createItemUnmarshaller(chain,typeRef);
+
+            if(typeRef.isNillable())
+                item = new XsiNilLoader.Array(item);
+            if(typeRef.getDefaultValue()!=null)
+                item = new DefaultValueLoaderDecorator(item,typeRef.getDefaultValue());
+
+            loaders.put(tagName,new ChildLoader(item,recv));
+        }
+    }
+
+    public final PropertyKind getKind() {
+        return PropertyKind.ELEMENT;
+    }
+
+    /**
+     * Creates a loader handler that unmarshals the body of the item.
+     *
+     * <p>
+     * This will be sandwiched into <item> ... </item>.
+     *
+     * <p>
+     * When unmarshalling the body of item, the Pack of {@link Lister} is available
+     * as the handler state.
+     *
+     * @param chain
+     * @param typeRef
+     */
+    private Loader createItemUnmarshaller(UnmarshallerChain chain, RuntimeTypeRef typeRef) {
+        if(PropertyFactory.isLeaf(typeRef.getSource())) {
+            final Transducer xducer = typeRef.getTransducer();
+            return new TextLoader(xducer);
+        } else {
+            return refs.get(typeRef).getLoader(chain.context,true);
+        }
+    }
+
+    public Accessor getElementPropertyAccessor(String nsUri, String localName) {
+        if(wrapperTagName!=null) {
+            if(wrapperTagName.equals(nsUri,localName))
+                return acc;
+        } else {
+            for (TagAndType tt : typeMap.values()) {
+                if(tt.tagName.equals(nsUri,localName))
+                    // when we can't distinguish null and empty list, JAX-WS doesn't want to see
+                    // null (just like any user apps), but since we are providing a raw accessor,
+                    // which just grabs the value from the field, we wrap it so that it won't return
+                    // null.
+                    return new NullSafeAccessor<BeanT,ListT,Object>(acc,lister);
+            }
+        }
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayProperty.java
new file mode 100644
index 0000000..31df5d5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayProperty.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Lister;
+
+
+/**
+ * {@link Property} implementation for multi-value properties
+ * (including arrays and collections.)
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+abstract class ArrayProperty<BeanT,ListT,ItemT> extends PropertyImpl<BeanT> {
+    protected final Accessor<BeanT,ListT> acc;
+    protected final Lister<BeanT,ListT,ItemT,Object> lister;
+
+    protected ArrayProperty(JAXBContextImpl context, RuntimePropertyInfo prop) {
+        super(context,prop);
+
+        assert prop.isCollection();
+        lister = Lister.create(
+            Navigator.REFLECTION.erasure(prop.getRawType()),prop.id(),prop.getAdapter());
+        assert lister!=null;
+        acc = prop.getAccessor().optimize();
+        assert acc!=null;
+    }
+
+    public void reset(BeanT o) throws AccessorException {
+        lister.reset(o,acc);
+    }
+
+    public final String getIdValue(BeanT bean) {
+        // mutli-value property can't be ID
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayReferenceNodeProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayReferenceNodeProperty.java
new file mode 100644
index 0000000..8d5dea4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ArrayReferenceNodeProperty.java
@@ -0,0 +1,166 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.annotation.DomHandler;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeReferencePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.ListIterator;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Receiver;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.WildcardLoader;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class ArrayReferenceNodeProperty<BeanT,ListT,ItemT> extends ArrayERProperty<BeanT,ListT,ItemT> {
+
+    /**
+     * Expected element names and what class to unmarshal.
+     */
+    private final QNameMap<JaxBeanInfo> expectedElements = new QNameMap<JaxBeanInfo>();
+
+    private final boolean isMixed;
+
+    private final DomHandler domHandler;
+    private final WildcardMode wcMode;
+
+    public ArrayReferenceNodeProperty(JAXBContextImpl p, RuntimeReferencePropertyInfo prop) {
+        super(p, prop, prop.getXmlName(), prop.isCollectionNillable());
+
+        for (RuntimeElement e : prop.getElements()) {
+            JaxBeanInfo bi = p.getOrCreate(e);
+            expectedElements.put( e.getElementName().getNamespaceURI(),e.getElementName().getLocalPart(), bi );
+        }
+
+        isMixed = prop.isMixed();
+
+        if(prop.getWildcard()!=null) {
+            domHandler = (DomHandler) ClassFactory.create(prop.getDOMHandler());
+            wcMode = prop.getWildcard();
+        } else {
+            domHandler = null;
+            wcMode = null;
+        }
+    }
+
+    protected final void serializeListBody(BeanT o, XMLSerializer w, ListT list) throws IOException, XMLStreamException, SAXException {
+        ListIterator<ItemT> itr = lister.iterator(list, w);
+
+        while(itr.hasNext()) {
+            try {
+                ItemT item = itr.next();
+                if (item != null) {
+                    if(isMixed && item.getClass()==String.class) {
+                        w.text((String)item,null);
+                    } else {
+                        JaxBeanInfo bi = w.grammar.getBeanInfo(item,true);
+                        if(bi.jaxbType==Object.class && domHandler!=null)
+                            // even if 'v' is a DOM node, it always derive from Object,
+                            // so the getBeanInfo returns BeanInfo for Object
+                            w.writeDom(item,domHandler,o,fieldName);
+                        else
+                            bi.serializeRoot(item,w);
+                    }
+                }
+            } catch (JAXBException e) {
+                w.reportError(fieldName,e);
+                // recover by ignoring this item
+            }
+        }
+    }
+
+    public void createBodyUnmarshaller(UnmarshallerChain chain, QNameMap<ChildLoader> loaders) {
+        final int offset = chain.allocateOffset();
+
+        Receiver recv = new ReceiverImpl(offset);
+
+        for( QNameMap.Entry<JaxBeanInfo> n : expectedElements.entrySet() ) {
+            final JaxBeanInfo beanInfo = n.getValue();
+            loaders.put(n.nsUri,n.localName,new ChildLoader(beanInfo.getLoader(chain.context,true),recv));
+        }
+
+        if(isMixed) {
+            // handler for processing mixed contents.
+            loaders.put(TEXT_HANDLER,
+                new ChildLoader(new MixedTextoader(recv),null));
+        }
+
+        if(domHandler!=null) {
+            loaders.put(CATCH_ALL,
+                new ChildLoader(new WildcardLoader(domHandler,wcMode),recv));
+        }
+    }
+
+    private static final class MixedTextoader extends Loader {
+
+        private final Receiver recv;
+
+        public MixedTextoader(Receiver recv) {
+            super(true);
+            this.recv = recv;
+        }
+
+        public void text(UnmarshallingContext.State state, CharSequence text) throws SAXException {
+            recv.receive(state,text.toString());
+        }
+    }
+
+
+    public PropertyKind getKind() {
+        return PropertyKind.REFERENCE;
+    }
+
+    @Override
+    public Accessor getElementPropertyAccessor(String nsUri, String localName) {
+        // TODO: unwrap JAXBElement
+        if(wrapperTagName!=null) {
+            if(wrapperTagName.equals(nsUri,localName))
+                return acc;
+        } else {
+            if(expectedElements.containsKey(nsUri,localName))
+                return acc;
+        }
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/AttributeProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/AttributeProperty.java
new file mode 100644
index 0000000..4e9e5ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/AttributeProperty.java
@@ -0,0 +1,121 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+import com.sun.xml.internal.bind.v2.model.core.AttributePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeAttributePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Property} implementation for {@link AttributePropertyInfo}.
+ *
+ * <p>
+ * This one works for both leaves and nodes, scalars and arrays.
+ *
+ * <p>
+ * Implements {@link Comparable} so that it can be sorted lexicographically.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public final class AttributeProperty<BeanT> extends PropertyImpl<BeanT>
+    implements Comparable<AttributeProperty> {
+
+    /**
+     * Attribute name.
+     */
+    public final Name attName;
+
+    /**
+     * Heart of the conversion logic.
+     */
+    public final TransducedAccessor<BeanT> xacc;
+
+    private final Accessor acc;
+
+    public AttributeProperty(JAXBContextImpl p, RuntimeAttributePropertyInfo prop) {
+        super(p,prop);
+        this.attName = p.nameBuilder.createAttributeName(prop.getXmlName());
+        this.xacc = TransducedAccessor.get(prop);
+        this.acc = prop.getAccessor();   // we only use this for binder, so don't waste memory by optimizing
+    }
+
+    /**
+     * Marshals one attribute.
+     *
+     * @see JaxBeanInfo#serializeAttributes(Object, XMLSerializer)
+     */
+    public void serializeAttributes(BeanT o, XMLSerializer w) throws SAXException, AccessorException, IOException, XMLStreamException {
+        CharSequence value = xacc.print(o);
+        if(value!=null)
+            w.attribute(attName,value.toString());
+    }
+
+    public void serializeURIs(BeanT o, XMLSerializer w) throws AccessorException, SAXException {
+        xacc.declareNamespace(o,w);
+    }
+
+    public boolean hasSerializeURIAction() {
+        return xacc.useNamespace();
+    }
+
+    public void buildChildElementUnmarshallers(UnmarshallerChain chainElem, QNameMap<ChildLoader> handlers) {
+        throw new IllegalStateException();
+    }
+
+
+    public PropertyKind getKind() {
+        return PropertyKind.ATTRIBUTE;
+    }
+
+    public void reset(BeanT o) throws AccessorException {
+        acc.set(o,null);
+    }
+
+    public String getIdValue(BeanT bean) throws AccessorException, SAXException {
+        return xacc.print(bean).toString();
+    }
+
+    public int compareTo(AttributeProperty that) {
+        return this.attName.compareTo(that.attName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ListElementProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ListElementProperty.java
new file mode 100644
index 0000000..df50fe1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ListElementProperty.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+import com.sun.xml.internal.bind.v2.model.core.ElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeRef;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.ListTransducedAccessorImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.LeafPropertyLoader;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Property} implementation for {@link ElementPropertyInfo} whose
+ * {@link ElementPropertyInfo#isValueList()} is true.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ListElementProperty<BeanT,ListT,ItemT> extends ArrayProperty<BeanT,ListT,ItemT> {
+
+    private final Name tagName;
+    /**
+     * Converts all the values to a list and back.
+     */
+    private final TransducedAccessor<BeanT> xacc;
+
+    public ListElementProperty(JAXBContextImpl grammar, RuntimeElementPropertyInfo prop) {
+        super(grammar, prop);
+
+        assert prop.isValueList();
+        assert prop.getTypes().size()==1;   // required by the contract of isValueList
+        RuntimeTypeRef ref = prop.getTypes().get(0);
+
+        tagName = grammar.nameBuilder.createElementName(ref.getTagName());
+
+        // transducer for each item
+        Transducer xducer = ref.getTransducer();
+        // transduced accessor for the whole thing
+        xacc = new ListTransducedAccessorImpl(xducer,acc,lister);
+    }
+
+    public PropertyKind getKind() {
+        return PropertyKind.ELEMENT;
+    }
+
+    public void buildChildElementUnmarshallers(UnmarshallerChain chain, QNameMap<ChildLoader> handlers) {
+        handlers.put(tagName, new ChildLoader(new LeafPropertyLoader(xacc),null));
+    }
+
+    public void serializeBody(BeanT o, XMLSerializer w, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException {
+        ListT list = acc.get(o);
+
+        if(list!=null) {
+            if(xacc.useNamespace()) {
+                w.startElement(tagName,null);
+                xacc.declareNamespace(o,w);
+                w.endNamespaceDecls(list);
+                w.endAttributes();
+                xacc.writeText(w,o,fieldName);
+                w.endElement();
+            } else {
+                xacc.writeLeafElement(w, tagName, o, fieldName);
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Messages.java
new file mode 100644
index 0000000..de20059
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Messages.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources
+ */
+enum Messages {
+    UNSUBSTITUTABLE_TYPE, // 3 args
+    UNEXPECTED_JAVA_TYPE, // 2 args
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Messages.properties
new file mode 100644
index 0000000..5d044d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Messages.properties
@@ -0,0 +1,6 @@
+UNSUBSTITUTABLE_TYPE = \
+    type {0} is mapped to {1} but it cannot substitute {2} here
+
+UNEXPECTED_JAVA_TYPE = \
+    Java class {0} is not allowed in this property. Expected types are: {1}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Property.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Property.java
new file mode 100644
index 0000000..51e27b9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/Property.java
@@ -0,0 +1,129 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBElement;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+import org.xml.sax.SAXException;
+
+/**
+ * A JAXB property that constitutes a JAXB-bound bean.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface Property<BeanT> extends StructureLoaderBuilder {
+
+//    // is this method necessary? --> probably not
+//    RuntimePropertyInfo owner();
+
+    /**
+     * Resets the property value on the given object.
+     *
+     * <p>
+     * ... for example by setting 0 or null.
+     */
+    void reset( BeanT o ) throws AccessorException;
+
+    /**
+     * @see JaxBeanInfo#serializeBody(Object, XMLSerializer)
+     *
+     * @param outerPeer
+     *      used when this property is expected to print out an element
+     *      and that should be associated with this outer peer. normally null.
+     *      this is only used for {@link JaxBeanInfo} for {@link JAXBElement}s.
+     * @throws AccessorException
+     *      If thrown, caught by the caller and reported.
+     */
+    public void serializeBody(BeanT beanT, XMLSerializer target, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException;
+
+    /**
+     * @see JaxBeanInfo#serializeURIs(Object, XMLSerializer)
+     */
+    public void serializeURIs(BeanT beanT, XMLSerializer target) throws SAXException, AccessorException;
+
+    /**
+     * Returns true if
+     * {@link #serializeURIs(Object,XMLSerializer)} performs some meaningful action.
+     */
+    public boolean hasSerializeURIAction();
+
+//    /**
+//     * Builds the unmarshaller.
+//     *
+//     * @param grammar
+//     *      the context object to which this property ultimately belongs to.
+//     *      a property will only belong to one grammar, but to reduce the memory footprint
+//     *      we don't keep that information stored in {@link Property}, and instead we
+//     *      just pass the value as a parameter when needed.
+//     */
+//    Unmarshaller.Handler createUnmarshallerHandler(JAXBContextImpl grammar, Unmarshaller.Handler tail);
+
+    /**
+     * Gets the value of the property.
+     *
+     * This method is only used when the corresponding {@link PropertyInfo#id()} is {@link ID#ID},
+     * and therefore the return type is fixed to {@link String}.
+     */
+    String getIdValue(BeanT bean) throws AccessorException, SAXException;
+
+    /**
+     * Gets the Kind of property
+     * @return
+     *      always non-null.
+     */
+    PropertyKind getKind();
+
+
+    // UGLY HACK to support JAX-WS
+    // if other clients want to access those functionalities,
+    // we should design a better model
+    /**
+     * If this property is mapped to the specified element,
+     * return an accessor to it.
+     *
+     * @return
+     *      null if the property is not mapped to the specified element.
+     */
+    Accessor getElementPropertyAccessor(String nsUri,String localName);
+
+    /**
+     * Called at the end of the {@link JAXBContext} initialization phase
+     * to clean up any unnecessary references.
+     */
+    void wrapUp();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/PropertyFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/PropertyFactory.java
new file mode 100644
index 0000000..cdce8eb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/PropertyFactory.java
@@ -0,0 +1,155 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.lang.reflect.Constructor;
+import java.lang.reflect.InvocationTargetException;
+import java.util.Collection;
+
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeAttributePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeValuePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+
+/**
+ * Create {@link Property} objects.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class PropertyFactory {
+    private PropertyFactory() {}
+
+
+    /**
+     * Constructors of the {@link Property} implementation.
+     */
+    private static final Constructor<? extends Property>[] propImpls;
+
+    static {
+        Class<? extends Property>[] implClasses = new Class[] {
+            SingleElementLeafProperty.class,
+            null, // single reference leaf --- but there's no such thing as "reference leaf"
+            null, // no such thing as "map leaf"
+
+            ArrayElementLeafProperty.class,
+            null, // array reference leaf --- but there's no such thing as "reference leaf"
+            null, // no such thing as "map leaf"
+
+            SingleElementNodeProperty.class,
+            SingleReferenceNodeProperty.class,
+            SingleMapNodeProperty.class,
+
+            ArrayElementNodeProperty.class,
+            ArrayReferenceNodeProperty.class,
+            null, // map is always a single property (Map doesn't implement Collection)
+        };
+
+        propImpls = new Constructor[implClasses.length];
+        for( int i=0; i<propImpls.length; i++ ) {
+            if(implClasses[i]!=null)
+                // this pointless casting necessary for Mustang
+                propImpls[i] = (Constructor)implClasses[i].getConstructors()[0];
+        }
+    }
+
+    /**
+     * Creates/obtains a properly configured {@link Property}
+     * object from the given description.
+     */
+    public static Property create( JAXBContextImpl grammar, RuntimePropertyInfo info ) {
+
+        PropertyKind kind = info.kind();
+
+        switch(kind) {
+        case ATTRIBUTE:
+            return new AttributeProperty(grammar,(RuntimeAttributePropertyInfo)info);
+        case VALUE:
+            return new ValueProperty(grammar,(RuntimeValuePropertyInfo)info);
+        case ELEMENT:
+            if(((RuntimeElementPropertyInfo)info).isValueList())
+                return new ListElementProperty(grammar,(RuntimeElementPropertyInfo) info);
+            break;
+        case REFERENCE:
+        case MAP:
+            break;
+        default:
+            assert false;
+        }
+
+
+        boolean isCollection = info.isCollection();
+        boolean isLeaf = isLeaf(info);
+
+        Constructor<? extends Property> c = propImpls[(isLeaf?0:6)+(isCollection?3:0)+kind.propertyIndex];
+        try {
+            return c.newInstance( grammar, info );
+        } catch (InstantiationException e) {
+            throw new InstantiationError(e.getMessage());
+        } catch (IllegalAccessException e) {
+            throw new IllegalAccessError(e.getMessage());
+        } catch (InvocationTargetException e) {
+            Throwable t = e.getCause();
+            if(t instanceof Error)
+                throw (Error)t;
+            if(t instanceof RuntimeException)
+                throw (RuntimeException)t;
+
+            throw new AssertionError(t);
+        }
+    }
+
+    /**
+     * Look for the case that can be optimized as a leaf,
+     * which is a kind of type whose XML representation is just PCDATA.
+     */
+    static boolean isLeaf(RuntimePropertyInfo info) {
+        Collection<? extends RuntimeTypeInfo> types = info.ref();
+        if(types.size()!=1)     return false;
+
+        RuntimeTypeInfo rti = types.iterator().next();
+        if(!(rti instanceof RuntimeNonElement)) return false;
+
+        if(info.id()==ID.IDREF)
+            // IDREF is always handled as leaf -- Transducer maps IDREF String back to an object
+            return true;
+
+        if(((RuntimeNonElement)rti).getTransducer()==null)
+            // Transducer!=null means definitely binds to PCDATA.
+            // even if transducer==null, a referene might be IDREF,
+            // in which case it will still produce PCDATA in this reference.
+            return false;
+
+        if(!info.getIndividualType().equals(rti.getType()))
+            return false;
+
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/PropertyImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/PropertyImpl.java
new file mode 100644
index 0000000..e1fe1a4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/PropertyImpl.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+abstract class PropertyImpl<BeanT> implements Property<BeanT> {
+    /**
+     * Name of this field.
+     */
+    protected final String fieldName;
+
+    public PropertyImpl(JAXBContextImpl context, RuntimePropertyInfo prop) {
+        fieldName = prop.getName();
+    }
+
+    public void serializeBody(BeanT o, XMLSerializer w, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException {
+    }
+
+    public void serializeURIs(BeanT o, XMLSerializer w) throws SAXException, AccessorException {
+    }
+
+    public boolean hasSerializeURIAction() {
+        return false;
+    }
+
+    public Accessor getElementPropertyAccessor(String nsUri, String localName) {
+        // default implementation. should be overrided
+        return null;
+    }
+
+    public void wrapUp() {
+        // noop
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleElementLeafProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleElementLeafProperty.java
new file mode 100644
index 0000000..5afe698
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleElementLeafProperty.java
@@ -0,0 +1,117 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeRef;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.DefaultValueLoaderDecorator;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.LeafPropertyLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiNilLoader;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Property} that contains a leaf value.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class SingleElementLeafProperty<BeanT> extends PropertyImpl<BeanT> {
+
+    private final Name tagName;
+    private final boolean nillable;
+    private final Accessor acc;
+    private final String defaultValue;
+    private final TransducedAccessor<BeanT> xacc;
+
+    public SingleElementLeafProperty(JAXBContextImpl context, RuntimeElementPropertyInfo prop) {
+        super(context,prop);
+        RuntimeTypeRef ref = prop.getTypes().get(0);
+        tagName = context.nameBuilder.createElementName(ref.getTagName());
+        assert tagName!=null;
+        nillable = ref.isNillable();
+        defaultValue = ref.getDefaultValue();
+        this.acc = prop.getAccessor().optimize();
+
+        xacc = TransducedAccessor.get(ref);
+        assert xacc!=null;
+    }
+
+    public void reset(BeanT o) throws AccessorException {
+        acc.set(o,null);
+    }
+
+    public String getIdValue(BeanT bean) throws AccessorException, SAXException {
+        return xacc.print(bean).toString();
+    }
+
+    public void serializeBody(BeanT o, XMLSerializer w, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException {
+        boolean hasValue = xacc.hasValue(o);
+        if(hasValue) {
+            xacc.writeLeafElement(w, tagName, o, fieldName);
+        } else
+        if(nillable) {
+            w.startElement(tagName,null);
+            w.writeXsiNilTrue();
+            w.endElement();
+        }
+    }
+
+    public void buildChildElementUnmarshallers(UnmarshallerChain chain, QNameMap<ChildLoader> handlers) {
+        Loader l = new LeafPropertyLoader(xacc);
+        if(defaultValue!=null)
+            l = new DefaultValueLoaderDecorator(l,defaultValue);
+        if(nillable)
+            l = new XsiNilLoader.Single(l,acc);
+        handlers.put(tagName,new ChildLoader(l,null));
+    }
+
+
+    public PropertyKind getKind() {
+        return PropertyKind.ELEMENT;
+    }
+
+    @Override
+    public Accessor getElementPropertyAccessor(String nsUri, String localName) {
+        if(tagName.equals(nsUri,localName))
+            return acc;
+        else
+            return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleElementNodeProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleElementNodeProperty.java
new file mode 100644
index 0000000..5a58f5d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleElementNodeProperty.java
@@ -0,0 +1,177 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+import java.lang.reflect.Type;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.TypeRef;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeTypeRef;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiNilLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.DefaultValueLoaderDecorator;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiTypeLoader;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class SingleElementNodeProperty<BeanT,ValueT> extends PropertyImpl<BeanT> {
+
+    private final Accessor<BeanT,ValueT> acc;
+
+    private final boolean nillable;
+
+    private final QName[] acceptedElements;
+
+    private final Map<Class,TagAndType> typeNames = new HashMap<Class,TagAndType>();
+
+    private RuntimeElementPropertyInfo prop;
+
+    /**
+     * The tag name used to produce xsi:nil. The first one in the list.
+     */
+    private final Name nullTagName;
+
+    public SingleElementNodeProperty(JAXBContextImpl context, RuntimeElementPropertyInfo prop) {
+        super(context,prop);
+        acc = prop.getAccessor().optimize();
+        this.prop = prop;
+
+        QName nt = null;
+        boolean nil = false;
+
+        acceptedElements = new QName[prop.getTypes().size()];
+        for( int i=0; i<acceptedElements.length; i++ )
+            acceptedElements[i] = prop.getTypes().get(i).getTagName();
+
+        for (RuntimeTypeRef e : prop.getTypes()) {
+            JaxBeanInfo beanInfo = context.getOrCreate(e.getTarget());
+            if(nt==null)    nt = e.getTagName();
+            typeNames.put( beanInfo.jaxbType, new TagAndType(
+                context.nameBuilder.createElementName(e.getTagName()),beanInfo) );
+            nil |= e.isNillable();
+        }
+
+        nullTagName = context.nameBuilder.createElementName(nt);
+
+        nillable = nil;
+    }
+
+    public void wrapUp() {
+        super.wrapUp();
+        prop = null;
+    }
+
+    public void reset(BeanT bean) throws AccessorException {
+        acc.set(bean,null);
+    }
+
+    public String getIdValue(BeanT beanT) {
+        return null;
+    }
+
+    public void serializeBody(BeanT o, XMLSerializer w, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException {
+        ValueT v = acc.get(o);
+        if(v!=null) {
+            Class vtype = v.getClass();
+            TagAndType tt=typeNames.get(vtype); // quick way that usually works
+
+            if(tt==null) {// slow way that always works
+                for (Map.Entry<Class,TagAndType> e : typeNames.entrySet()) {
+                    if(e.getKey().isAssignableFrom(vtype)) {
+                        tt = e.getValue();
+                        break;
+                    }
+                }
+            }
+
+            if(tt==null) {
+                // actually this is an error, because the actual type was not a sub-type
+                // of any of the types specified in the annotations,
+                // but for the purpose of experimenting with simple type substitution,
+                // it's convenient to marshal this anyway (for example so that classes
+                // generated from simple types like String can be marshalled as expected.)
+                w.startElement(typeNames.values().iterator().next().tagName,null);
+                w.childAsXsiType(v,fieldName,w.grammar.getBeanInfo(Object.class));
+            } else {
+                w.startElement(tt.tagName,null);
+                w.childAsXsiType(v,fieldName,tt.beanInfo);
+            }
+            w.endElement();
+        } else
+        if(nillable) {
+            w.startElement(nullTagName,null);
+            w.writeXsiNilTrue();
+            w.endElement();
+        }
+    }
+
+    public void buildChildElementUnmarshallers(UnmarshallerChain chain, QNameMap<ChildLoader> handlers) {
+        JAXBContextImpl context = chain.context;
+
+        for (TypeRef<Type,Class> e : prop.getTypes()) {
+            JaxBeanInfo bi = context.getOrCreate((RuntimeTypeInfo) e.getTarget());
+            Loader l = bi.getLoader(context,true);
+            if(e.getDefaultValue()!=null)
+                l = new DefaultValueLoaderDecorator(l,e.getDefaultValue());
+            if(nillable)
+                l = new XsiNilLoader.Single(l,acc);
+            handlers.put( e.getTagName(), new ChildLoader(l,acc));
+        }
+    }
+
+    public PropertyKind getKind() {
+        return PropertyKind.ELEMENT;
+    }
+
+    @Override
+    public Accessor getElementPropertyAccessor(String nsUri, String localName) {
+        for( QName n : acceptedElements) {
+            if(n.getNamespaceURI().equals(nsUri) && n.getLocalPart().equals(localName))
+                return acc;
+        }
+        return null;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleMapNodeProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleMapNodeProperty.java
new file mode 100644
index 0000000..d9b84d7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleMapNodeProperty.java
@@ -0,0 +1,275 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.LinkedHashMap;
+import java.util.Map;
+import java.util.TreeMap;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.Arrays;
+import java.util.Set;
+
+import javax.xml.stream.XMLStreamException;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.nav.ReflectionNavigator;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeMapPropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.TagName;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Receiver;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiTypeLoader;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class SingleMapNodeProperty<BeanT,ValueT extends Map> extends PropertyImpl<BeanT> {
+
+    private final Accessor<BeanT,ValueT> acc;
+    /**
+     * The tag name that surrounds the whole property.
+     */
+    private final Name tagName;
+    /**
+     * The tag name that corresponds to the 'entry' element.
+     */
+    private final Name entryTag;
+    private final Name keyTag;
+    private final Name valueTag;
+
+    private final boolean nillable;
+
+    private JaxBeanInfo keyBeanInfo;
+    private JaxBeanInfo valueBeanInfo;
+
+    /**
+     * The implementation class for this property.
+     * If the property is null, we create an instance of this class.
+     */
+    private final Class<? extends ValueT> mapImplClass;
+
+    public SingleMapNodeProperty(JAXBContextImpl context, RuntimeMapPropertyInfo prop) {
+        super(context, prop);
+        acc = prop.getAccessor().optimize();
+        this.tagName = context.nameBuilder.createElementName(prop.getXmlName());
+        this.entryTag = context.nameBuilder.createElementName("","entry");
+        this.keyTag = context.nameBuilder.createElementName("","key");
+        this.valueTag = context.nameBuilder.createElementName("","value");
+        this.nillable = prop.isCollectionNillable();
+        this.keyBeanInfo = context.getOrCreate(prop.getKeyType());
+        this.valueBeanInfo = context.getOrCreate(prop.getValueType());
+
+        // infer the implementation class
+        Class<ValueT> sig = ReflectionNavigator.REFLECTION.erasure(prop.getRawType());
+        mapImplClass = ClassFactory.inferImplClass(sig,knownImplClasses);
+        // TODO: error check for mapImplClass==null
+        // what is the error reporting path for this part of the code?
+    }
+
+    private static final Class[] knownImplClasses = {
+        HashMap.class, TreeMap.class, LinkedHashMap.class
+    };
+
+    public void reset(BeanT bean) throws AccessorException {
+        acc.set(bean,null);
+    }
+
+
+    /**
+     * A Map property can never be ID.
+     */
+    public String getIdValue(BeanT bean) {
+        return null;
+    }
+
+    public PropertyKind getKind() {
+        return PropertyKind.MAP;
+    }
+
+    public void buildChildElementUnmarshallers(UnmarshallerChain chain, QNameMap<ChildLoader> handlers) {
+        keyLoader = keyBeanInfo.getLoader(chain.context,true);
+        valueLoader = valueBeanInfo.getLoader(chain.context,true);
+        handlers.put(tagName,new ChildLoader(itemsLoader,null));
+    }
+
+    private Loader keyLoader;
+    private Loader valueLoader;
+
+    /**
+     * Handles &lt;items> and &lt;/items>.
+     *
+     * The target will be set to a {@link Map}.
+     */
+    private final Loader itemsLoader = new Loader(false) {
+        @Override
+        public void startElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+            // create or obtain the Map object
+            try {
+                BeanT target = (BeanT)state.prev.target;
+                ValueT map = acc.get(target);
+                if(map==null) {
+                    map = ClassFactory.create(mapImplClass);
+                    acc.set(target,map);
+                }
+                map.clear();
+                state.target = map;
+            } catch (AccessorException e) {
+                // recover from error by setting a dummy Map that receives and discards the values
+                handleGenericException(e,true);
+                state.target = new HashMap();
+            }
+        }
+
+        @Override
+        public void childElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+            if(ea.matches(entryTag)) {
+                state.loader = entryLoader;
+            } else {
+                super.childElement(state,ea);
+            }
+        }
+
+        @Override
+        public Collection<QName> getExpectedChildElements() {
+            return Collections.singleton(entryTag.toQName());
+        }
+    };
+
+    /**
+     * Handles &lt;entry> and &lt;/entry>.
+     *
+     * The target will be set to a {@link Map}.
+     */
+    private final Loader entryLoader = new Loader(false) {
+        @Override
+        public void startElement(UnmarshallingContext.State state, TagName ea) {
+            state.target = new Object[2];  // this is inefficient
+        }
+
+        @Override
+        public void leaveElement(UnmarshallingContext.State state, TagName ea) {
+            Object[] keyValue = (Object[])state.target;
+            Map map = (Map) state.prev.target;
+            map.put(keyValue[0],keyValue[1]);
+        }
+
+        @Override
+        public void childElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+            if(ea.matches(keyTag)) {
+                state.loader = keyLoader;
+                state.receiver = keyReceiver;
+                return;
+            }
+            if(ea.matches(valueTag)) {
+                state.loader = valueLoader;
+                state.receiver = valueReceiver;
+                return;
+            }
+            super.childElement(state,ea);
+        }
+
+        @Override
+        public Collection<QName> getExpectedChildElements() {
+            return Arrays.asList(keyTag.toQName(),valueTag.toQName());
+        }
+    };
+
+    private static final class ReceiverImpl implements Receiver {
+        private final int index;
+        public ReceiverImpl(int index) {
+            this.index = index;
+        }
+        public void receive(UnmarshallingContext.State state, Object o) {
+            ((Object[])state.target)[index] = o;
+        }
+    }
+
+    private static final Receiver keyReceiver = new ReceiverImpl(0);
+    private static final Receiver valueReceiver = new ReceiverImpl(1);
+
+
+
+
+    public void serializeBody(BeanT o, XMLSerializer w, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException {
+        ValueT v = acc.get(o);
+        if(v!=null) {
+            bareStartTag(w,tagName,v);
+            for( Map.Entry e : (Set<Map.Entry>)v.entrySet() ) {
+                bareStartTag(w,entryTag,null);
+
+                Object key = e.getKey();
+                if(key!=null) {
+                    w.startElement(keyTag,key);
+                    w.childAsXsiType(key,fieldName,keyBeanInfo);
+                    w.endElement();
+                }
+
+                Object value = e.getValue();
+                if(value!=null) {
+                    w.startElement(valueTag,value);
+                    w.childAsXsiType(value,fieldName,valueBeanInfo);
+                    w.endElement();
+                }
+
+                w.endElement();
+            }
+            w.endElement();
+        } else
+        if(nillable) {
+            w.startElement(tagName,null);
+            w.writeXsiNilTrue();
+            w.endElement();
+        }
+    }
+
+    private void bareStartTag(XMLSerializer w, Name tagName, Object peer) throws IOException, XMLStreamException, SAXException {
+        w.startElement(tagName,peer);
+        w.endNamespaceDecls(peer);
+        w.endAttributes();
+    }
+
+    @Override
+    public Accessor getElementPropertyAccessor(String nsUri, String localName) {
+        if(tagName.equals(nsUri,localName))
+            return acc;
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleReferenceNodeProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleReferenceNodeProperty.java
new file mode 100644
index 0000000..2585e80
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/SingleReferenceNodeProperty.java
@@ -0,0 +1,151 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import java.io.IOException;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.annotation.DomHandler;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeElement;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeReferencePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.ElementBeanInfoImpl;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.WildcardLoader;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class SingleReferenceNodeProperty<BeanT,ValueT> extends PropertyImpl<BeanT> {
+
+    private final Accessor<BeanT,ValueT> acc;
+
+    private final QNameMap<JaxBeanInfo> expectedElements = new QNameMap<JaxBeanInfo>();
+
+    private final DomHandler domHandler;
+    private final WildcardMode wcMode;
+
+    public SingleReferenceNodeProperty(JAXBContextImpl p, RuntimeReferencePropertyInfo prop) {
+        super(p,prop);
+        acc = prop.getAccessor().optimize();
+
+        for (RuntimeElement e : prop.getElements()) {
+            expectedElements.put( e.getElementName(), p.getOrCreate(e) );
+        }
+
+        if(prop.getWildcard()!=null) {
+            domHandler = (DomHandler) ClassFactory.create(prop.getDOMHandler());
+            wcMode = prop.getWildcard();
+        } else {
+            domHandler = null;
+            wcMode = null;
+        }
+    }
+
+    public void reset(BeanT bean) throws AccessorException {
+        acc.set(bean,null);
+    }
+
+    public String getIdValue(BeanT beanT) {
+        return null;
+    }
+
+    public void serializeBody(BeanT o, XMLSerializer w, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException {
+        ValueT v = acc.get(o);
+        if(v!=null) {
+            try {
+                JaxBeanInfo bi = w.grammar.getBeanInfo(v,true);
+                if(bi.jaxbType==Object.class && domHandler!=null)
+                    // even if 'v' is a DOM node, it always derive from Object,
+                    // so the getBeanInfo returns BeanInfo for Object
+                    w.writeDom(v,domHandler,o,fieldName);
+                else
+                    bi.serializeRoot(v,w);
+            } catch (JAXBException e) {
+                w.reportError(fieldName,e);
+                // recover by ignoring this property
+            }
+        }
+    }
+
+    public void buildChildElementUnmarshallers(UnmarshallerChain chain, QNameMap<ChildLoader> handlers) {
+        for (QNameMap.Entry<JaxBeanInfo> n : expectedElements.entrySet())
+            handlers.put(n.nsUri,n.localName, new ChildLoader(n.getValue().getLoader(chain.context,true),acc));
+
+        if(domHandler!=null)
+            handlers.put(CATCH_ALL,new ChildLoader(new WildcardLoader(domHandler,wcMode),acc));
+
+    }
+
+    public PropertyKind getKind() {
+        return PropertyKind.REFERENCE;
+    }
+
+    @Override
+    public Accessor getElementPropertyAccessor(String nsUri, String localName) {
+        JaxBeanInfo bi = expectedElements.get(nsUri, localName);
+        if(bi!=null) {
+            if(bi instanceof ElementBeanInfoImpl) {
+                final ElementBeanInfoImpl ebi = (ElementBeanInfoImpl) bi;
+                // a JAXBElement. We need to handle JAXBElement for JAX-WS
+                return new Accessor<BeanT,Object>(ebi.expectedType) {
+                    public Object get(BeanT bean) throws AccessorException {
+                        ValueT r = acc.get(bean);
+                        if(r instanceof JAXBElement) {
+                            return ((JAXBElement)r).getValue();
+                        } else
+                            // this is sloppy programming, but hey...
+                            return r;
+                    }
+
+                    public void set(BeanT bean, Object value) throws AccessorException {
+                        if(value!=null) {
+                            value = ebi.createInstanceFromValue(value);
+                        }
+                        acc.set(bean,(ValueT)value);
+                    }
+                };
+            } else {
+                // a custom element type, like @XmlRootElement class Foo { ... }
+                return acc;
+            }
+        } else
+            return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/StructureLoaderBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/StructureLoaderBuilder.java
new file mode 100644
index 0000000..9169725
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/StructureLoaderBuilder.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.StructureLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ValuePropertyLoader;
+
+/**
+ * Component that contributes element unmarshallers into
+ * {@link StructureLoader}.
+ *
+ * TODO: think of a better name.
+ *
+ * @author Bhakti Mehta
+ */
+public interface StructureLoaderBuilder {
+    /**
+     * Every Property class has an implementation of buildChildElementUnmarshallers
+     * which will fill in the specified {@link QNameMap} by elements that are expected
+     * by this property.
+     */
+    void buildChildElementUnmarshallers(UnmarshallerChain chain, QNameMap<ChildLoader> handlers);
+
+    /**
+     * Magic {@link QName} used to store a handler for the text.
+     *
+     * <p>
+     * To support the mixed content model, {@link StructureLoader} can have
+     * at most one {@link ValuePropertyLoader} for processing text
+     * found amoung elements.
+     *
+     * This special text handler is put into the {@link QNameMap} parameter
+     * of the {@link #buildChildElementUnmarshallers} method by using
+     * this magic token as the key.
+     */
+    public static final QName TEXT_HANDLER = new QName("\u0000","text");
+
+    /**
+     * Magic {@link QName} used to store a handler for the rest of the elements.
+     *
+     * <p>
+     * To support the wildcard, {@link StructureLoader} can have
+     * at most one {@link Loader} for processing elements
+     * that didn't match any of the named elements.
+     *
+     * This special text handler is put into the {@link QNameMap} parameter
+     * of the {@link #buildChildElementUnmarshallers} method by using
+     * this magic token as the key.
+     */
+    public static final QName CATCH_ALL = new QName("\u0000","catchAll");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/TagAndType.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/TagAndType.java
new file mode 100644
index 0000000..589abea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/TagAndType.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+
+/**
+ * Pair of {@link QName} and {@link JaxBeanInfo}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class TagAndType {
+    final Name tagName;
+    final JaxBeanInfo beanInfo;
+    TagAndType(Name tagName, JaxBeanInfo beanInfo) {
+        this.tagName = tagName;
+        this.beanInfo = beanInfo;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/UnmarshallerChain.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/UnmarshallerChain.java
new file mode 100644
index 0000000..f0af637
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/UnmarshallerChain.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Scope;
+
+
+/**
+ * Pass around a 'ticket dispenser' when creating new
+ * unmarshallers. This controls the index of the slot
+ * allocated to the chain of handlers.
+
+ *
+ * <p>
+ * A ticket dispenser also maintains the offset for handlers
+ * to access state slots. A handler records this value when it's created.
+ *
+ *
+ */
+public final class UnmarshallerChain {
+    /**
+     * This offset allows child unmarshallers to have its own {@link Scope} without colliding with siblings.
+     */
+    private int offset = 0;
+
+    public final JAXBContextImpl context;
+
+    public UnmarshallerChain(JAXBContextImpl context) {
+        this.context = context;
+    }
+
+    /**
+     * Allocates a new {@link Scope} offset.
+     */
+    public int allocateOffset() {
+        return offset++;
+    }
+
+    /**
+     * Gets the number of total scope offset allocated.
+     */
+    public int getScopeSize() {
+        return offset;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ValueProperty.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ValueProperty.java
new file mode 100644
index 0000000..dddde4d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/property/ValueProperty.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.property;
+
+
+import java.io.IOException;
+
+import javax.xml.bind.annotation.XmlValue;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.core.PropertyKind;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeValuePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ChildLoader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.ValuePropertyLoader;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Property} implementation for {@link XmlValue} properties.
+ *
+ * <p>
+ * This one works for both leaves and nodes, scalars and arrays.
+ *
+ * @author Bhakti Mehta (bhakti.mehta@sun.com)
+ */
+public final class ValueProperty<BeanT> extends PropertyImpl<BeanT> {
+
+    /**
+     * Heart of the conversion logic.
+     */
+    private final TransducedAccessor<BeanT> xacc;
+    private final Accessor<BeanT,?> acc;
+
+
+    public ValueProperty(JAXBContextImpl grammar, RuntimeValuePropertyInfo prop) {
+        super(grammar,prop);
+        xacc = TransducedAccessor.get(prop);
+        acc = prop.getAccessor();   // we only use this for binder, so don't waste memory by optimizing
+    }
+
+    public final void serializeBody(BeanT o, XMLSerializer w, Object outerPeer) throws SAXException, AccessorException, IOException, XMLStreamException {
+        if(xacc.hasValue(o))
+            xacc.writeText(w,o,fieldName);
+    }
+
+    public void serializeURIs(BeanT o, XMLSerializer w) throws SAXException, AccessorException {
+        xacc.declareNamespace(o,w);
+    }
+
+    public boolean hasSerializeURIAction() {
+        return xacc.useNamespace();
+    }
+
+    public void buildChildElementUnmarshallers(UnmarshallerChain chainElem, QNameMap<ChildLoader> handlers) {
+        handlers.put(StructureLoaderBuilder.TEXT_HANDLER,
+                new ChildLoader(new ValuePropertyLoader(xacc),null));
+    }
+
+    public PropertyKind getKind() {
+        return PropertyKind.VALUE;
+    }
+
+    public void reset(BeanT o) throws AccessorException {
+        acc.set(o,null);
+    }
+
+    public String getIdValue(BeanT bean) throws AccessorException, SAXException {
+        return xacc.print(bean).toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Accessor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Accessor.java
new file mode 100644
index 0000000..a5c9e4c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Accessor.java
@@ -0,0 +1,426 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.lang.reflect.Modifier;
+import java.lang.reflect.Type;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+
+import com.sun.xml.internal.bind.Util;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.reflect.opt.OptimizedAccessorFactory;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Receiver;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Accesses a particular property of a bean.
+ *
+ * <p>
+ * This interface encapsulates the access to the actual data store.
+ * The intention is to generate implementations for a particular bean
+ * and a property to improve the performance.
+ *
+ * <p>
+ * Accessor can be used as a receiver. Upon receiving an object
+ * it sets that to the field.
+ *
+ * @see Accessor.FieldReflection
+ * @see TransducedAccessor
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class Accessor<BeanT,ValueT> implements Receiver {
+
+    public final Class<ValueT> valueType;
+
+    public Class<ValueT> getValueType() {
+        return valueType;
+    }
+
+    protected Accessor(Class<ValueT> valueType) {
+        this.valueType = valueType;
+    }
+
+    /**
+     * Returns the optimized version of the same accessor.
+     *
+     * @return
+     *      At least the implementation can return <tt>this</tt>.
+     */
+    public Accessor<BeanT,ValueT> optimize() {
+        return this;
+    }
+
+
+    /**
+     * Gets the value of the property of the given bean object.
+     *
+     * @param bean
+     *      must not be null.
+     * @throws AccessorException
+     *      if failed to set a value. For example, the getter method
+     *      may throw an exception.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract ValueT get(BeanT bean) throws AccessorException;
+
+    /**
+     * Sets the value of the property of the given bean object.
+     *
+     * @param bean
+     *      must not be null.
+     * @param value
+     *      the value to be set. Setting value to null means resetting
+     *      to the VM default value (even for primitive properties.)
+     * @throws AccessorException
+     *      if failed to set a value. For example, the setter method
+     *      may throw an exception.
+     *
+     * @since 2.0 EA1
+     */
+    public abstract void set(BeanT bean,ValueT value) throws AccessorException;
+
+
+    /**
+     * Sets the value without adapting the value.
+     *
+     * This ugly entry point is only used by JAX-WS.
+     * See {@link JAXBRIContext#getElementPropertyAccessor}
+     */
+    public Object getUnadapted(BeanT bean) throws AccessorException {
+        return get(bean);
+    }
+
+    /**
+     * Sets the value without adapting the value.
+     *
+     * This ugly entry point is only used by JAX-WS.
+     * See {@link JAXBRIContext#getElementPropertyAccessor}
+     */
+    public void setUnadapted(BeanT bean,Object value) throws AccessorException {
+        set(bean,(ValueT)value);
+    }
+
+    public void receive(UnmarshallingContext.State state, Object o) throws SAXException {
+        try {
+            set((BeanT)state.target,(ValueT)o);
+        } catch (AccessorException e) {
+            Loader.handleGenericException(e,true);
+        }
+    }
+
+    /**
+     * Wraps this  {@link Accessor} into another {@link Accessor}
+     * and performs the type adaption as necessary.
+     */
+    public final <T> Accessor<BeanT,T> adapt(Class<T> targetType, final Class<? extends XmlAdapter<T,ValueT>> adapter) {
+        return new AdaptedAccessor<BeanT,ValueT,T>(targetType, this, adapter);
+    }
+
+    public final <T> Accessor<BeanT,T> adapt(Adapter<Type,Class> adapter) {
+        return new AdaptedAccessor<BeanT,ValueT,T>(
+            (Class<T>)Navigator.REFLECTION.erasure(adapter.defaultType),
+            this,
+            adapter.adapterType);
+    }
+
+    /**
+     * Flag that will be set to true after issueing a warning
+     * about the lack of permission to access non-public fields.
+     */
+    private static boolean accessWarned = false;
+
+
+    /**
+     * {@link Accessor} that uses Java reflection to access a field.
+     */
+    public static class FieldReflection<BeanT,ValueT> extends Accessor<BeanT,ValueT> {
+        public final Field f;
+
+        private static final Logger logger = Util.getClassLogger();
+
+        // TODO: revisit. this is a security hole because this method can be used by anyone
+        // to enable access to a field.
+        public FieldReflection(Field f) {
+            super((Class<ValueT>)f.getType());
+            this.f = f;
+
+            int mod = f.getModifiers();
+            if(!Modifier.isPublic(mod) || Modifier.isFinal(mod) || !Modifier.isPublic(f.getDeclaringClass().getModifiers())) {
+                try {
+                    f.setAccessible(true);
+                } catch( SecurityException e ) {
+                    if(!accessWarned)
+                        // this happens when we don't have enough permission.
+                        logger.log( Level.WARNING, Messages.UNABLE_TO_ACCESS_NON_PUBLIC_FIELD.format(
+                            f.getDeclaringClass().getName(),
+                            f.getName()),
+                            e );
+                    accessWarned = true;
+                }
+            }
+        }
+
+        public ValueT get(BeanT bean) {
+            try {
+                return (ValueT)f.get(bean);
+            } catch (IllegalAccessException e) {
+                throw new IllegalAccessError(e.getMessage());
+            }
+        }
+
+        public void set(BeanT bean, ValueT value) {
+            try {
+                if(value==null)
+                    value = (ValueT)uninitializedValues.get(valueType);
+                f.set(bean,value);
+            } catch (IllegalAccessException e) {
+                throw new IllegalAccessError(e.getMessage());
+            }
+        }
+
+        @Override
+        public Accessor<BeanT,ValueT> optimize() {
+            Accessor<BeanT,ValueT> acc = OptimizedAccessorFactory.get(f);
+            if(acc!=null)
+                return acc;
+            else
+                return this;
+        }
+    }
+
+    /**
+     * Read-only access to {@link Field}. Used to handle a static field.
+     */
+    public static final class ReadOnlyFieldReflection<BeanT,ValueT> extends FieldReflection<BeanT,ValueT>{
+        public ReadOnlyFieldReflection(Field f) {
+            super(f);
+        }
+
+        public void set(BeanT bean, ValueT value) {
+            // noop
+        }
+
+        @Override
+        public Accessor<BeanT,ValueT> optimize() {
+            return this;
+        }
+    }
+
+
+    /**
+     * {@link Accessor} that uses Java reflection to access a getter and a setter.
+     */
+    public static class GetterSetterReflection<BeanT,ValueT> extends Accessor<BeanT,ValueT> {
+        public final Method getter;
+        public final Method setter;
+
+        private static final Logger logger = Util.getClassLogger();
+
+        public GetterSetterReflection(Method getter, Method setter) {
+            super(
+                (Class<ValueT>)( getter!=null ?
+                    getter.getReturnType() :
+                    setter.getParameterTypes()[0] ));
+            this.getter = getter;
+            this.setter = setter;
+
+            if(getter!=null)
+                makeAccessible(getter);
+            if(setter!=null)
+                makeAccessible(setter);
+        }
+
+        private void makeAccessible(Method m) {
+            if(!Modifier.isPublic(m.getModifiers()) || !Modifier.isPublic(m.getDeclaringClass().getModifiers())) {
+                try {
+                    m.setAccessible(true);
+                } catch( SecurityException e ) {
+                    if(!accessWarned)
+                        // this happens when we don't have enough permission.
+                        logger.log( Level.WARNING, Messages.UNABLE_TO_ACCESS_NON_PUBLIC_FIELD.format(
+                            m.getDeclaringClass().getName(),
+                            m.getName()),
+                            e );
+                    accessWarned = true;
+                }
+            }
+        }
+
+        public ValueT get(BeanT bean) throws AccessorException {
+            try {
+                return (ValueT)getter.invoke(bean);
+            } catch (IllegalAccessException e) {
+                throw new IllegalAccessError(e.getMessage());
+            } catch (InvocationTargetException e) {
+                throw handleInvocationTargetException(e);
+            }
+        }
+
+        public void set(BeanT bean, ValueT value) throws AccessorException {
+            try {
+                if(value==null)
+                    value = (ValueT)uninitializedValues.get(valueType);
+                setter.invoke(bean,value);
+            } catch (IllegalAccessException e) {
+                throw new IllegalAccessError(e.getMessage());
+            } catch (InvocationTargetException e) {
+                throw handleInvocationTargetException(e);
+            }
+        }
+
+        private AccessorException handleInvocationTargetException(InvocationTargetException e) {
+            // don't block a problem in the user code
+            Throwable t = e.getTargetException();
+            if(t instanceof RuntimeException)
+                throw (RuntimeException)t;
+            if(t instanceof Error)
+                throw (Error)t;
+
+            // otherwise it's a checked exception.
+            // I'm not sure how to handle this.
+            // we can throw a checked exception from here,
+            // but because get/set would be called from so many different places,
+            // the handling would be tedious.
+            return new AccessorException(t);
+        }
+
+        @Override
+        public Accessor<BeanT,ValueT> optimize() {
+            if(getter==null || setter==null)
+                // if we aren't complete, OptimizedAccessor won't always work
+                return this;
+
+            Accessor<BeanT,ValueT> acc = OptimizedAccessorFactory.get(getter,setter);
+            if(acc!=null)
+                return acc;
+            else
+                return this;
+        }
+    }
+
+    /**
+     * A version of {@link GetterSetterReflection} thaat doesn't have any setter.
+     *
+     * <p>
+     * This provides a user-friendly error message.
+     */
+    public static class GetterOnlyReflection<BeanT,ValueT> extends GetterSetterReflection<BeanT,ValueT> {
+        public GetterOnlyReflection(Method getter) {
+            super(getter,null);
+        }
+
+        @Override
+        public void set(BeanT bean, ValueT value) throws AccessorException {
+            throw new AccessorException(Messages.NO_SETTER.format(getter.toString()));
+        }
+    }
+
+    /**
+     * A version of {@link GetterSetterReflection} thaat doesn't have any getter.
+     *
+     * <p>
+     * This provides a user-friendly error message.
+     */
+    public static class SetterOnlyReflection<BeanT,ValueT> extends GetterSetterReflection<BeanT,ValueT> {
+        public SetterOnlyReflection(Method setter) {
+            super(null,setter);
+        }
+
+        @Override
+        public ValueT get(BeanT bean) throws AccessorException {
+            throw new AccessorException(Messages.NO_GETTER.format(setter.toString()));
+        }
+    }
+
+    /**
+     * Special {@link Accessor} used to recover from errors.
+     */
+    public static final Accessor ERROR = new Accessor(Object.class) {
+        public Object get(Object o) {
+            return null;
+        }
+
+        public void set(Object o, Object o1) {
+        }
+    };
+
+    /**
+     * {@link Accessor} for {@link JAXBElement#getValue()}.
+     */
+    public static final Accessor<JAXBElement,Object> JAXB_ELEMENT_VALUE = new Accessor<JAXBElement,Object>(Object.class) {
+        public Object get(JAXBElement jaxbElement) {
+            return jaxbElement.getValue();
+        }
+
+        public void set(JAXBElement jaxbElement, Object o) {
+            jaxbElement.setValue(o);
+        }
+    };
+
+    /**
+     * Uninitialized map keyed by their classes.
+     */
+    private static final Map<Class,Object> uninitializedValues = new HashMap<Class, Object>();
+
+    static {
+/*
+    static byte default_value_byte = 0;
+    static boolean default_value_boolean = false;
+    static char default_value_char = 0;
+    static float default_value_float = 0;
+    static double default_value_double = 0;
+    static int default_value_int = 0;
+    static long default_value_long = 0;
+    static short default_value_short = 0;
+*/
+        uninitializedValues.put(byte.class,Byte.valueOf((byte)0));
+        uninitializedValues.put(boolean.class,false);
+        uninitializedValues.put(char.class,Character.valueOf((char)0));
+        uninitializedValues.put(float.class,Float.valueOf(0));
+        uninitializedValues.put(double.class,Double.valueOf(0));
+        uninitializedValues.put(int.class,Integer.valueOf(0));
+        uninitializedValues.put(long.class,Long.valueOf(0));
+        uninitializedValues.put(short.class,Short.valueOf((short)0));
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/AdaptedAccessor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/AdaptedAccessor.java
new file mode 100644
index 0000000..80df7c3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/AdaptedAccessor.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.runtime.Coordinator;
+
+/**
+ * {@link Accessor} that adapts the value by using {@link Adapter}.
+ *
+ * @see Accessor#adapt
+ * @author Kohsuke Kawaguchi
+ */
+final class AdaptedAccessor<BeanT,InMemValueT,OnWireValueT> extends Accessor<BeanT,OnWireValueT> {
+    private final Accessor<BeanT,InMemValueT> core;
+    private final Class<? extends XmlAdapter<OnWireValueT,InMemValueT>> adapter;
+
+    /*pacakge*/ AdaptedAccessor(Class<OnWireValueT> targetType, Accessor<BeanT, InMemValueT> extThis, Class<? extends XmlAdapter<OnWireValueT, InMemValueT>> adapter) {
+        super(targetType);
+        this.core = extThis;
+        this.adapter = adapter;
+    }
+
+    public OnWireValueT get(BeanT bean) throws AccessorException {
+        InMemValueT v = core.get(bean);
+
+        XmlAdapter<OnWireValueT,InMemValueT> a = getAdapter();
+        try {
+            return a.marshal(v);
+        } catch (Exception e) {
+            throw new AccessorException(e);
+        }
+    }
+
+    public void set(BeanT bean, OnWireValueT o) throws AccessorException {
+        XmlAdapter<OnWireValueT, InMemValueT> a = getAdapter();
+        try {
+            core.set(bean,a.unmarshal(o));
+        } catch (Exception e) {
+            throw new AccessorException(e);
+        }
+    }
+
+    public Object getUnadapted(BeanT bean) throws AccessorException {
+        return core.getUnadapted(bean);
+    }
+
+    public void setUnadapted(BeanT bean, Object value) throws AccessorException {
+        core.setUnadapted(bean,value);
+    }
+
+    /**
+     * Sometimes Adapters are used directly by JAX-WS outside any
+     * {@link Coordinator}. Use this lazily-created cached
+     * {@link XmlAdapter} in such cases.
+     */
+    private XmlAdapter<OnWireValueT, InMemValueT> staticAdapter;
+
+    private XmlAdapter<OnWireValueT, InMemValueT> getAdapter() {
+        Coordinator coordinator = Coordinator._getInstance();
+        if(coordinator!=null)
+            return coordinator.getAdapter(adapter);
+        else {
+            synchronized(this) {
+                if(staticAdapter==null)
+                    staticAdapter = ClassFactory.create(adapter);
+            }
+            return staticAdapter;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/AdaptedLister.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/AdaptedLister.java
new file mode 100644
index 0000000..521120d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/AdaptedLister.java
@@ -0,0 +1,105 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.JAXBException;
+
+import com.sun.xml.internal.bind.v2.runtime.Coordinator;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.api.AccessorException;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Lister} that adapts individual item types.
+ */
+final class AdaptedLister<BeanT,PropT,InMemItemT,OnWireItemT,PackT> extends Lister<BeanT,PropT,OnWireItemT,PackT> {
+    private final Lister<BeanT,PropT,InMemItemT,PackT> core;
+    private final Class<? extends XmlAdapter<OnWireItemT,InMemItemT>> adapter;
+
+    /*package*/ AdaptedLister(
+        Lister<BeanT,PropT,InMemItemT,PackT> core,
+        Class<? extends XmlAdapter<OnWireItemT,InMemItemT>> adapter) {
+
+        this.core = core;
+        this.adapter = adapter;
+    }
+
+    private XmlAdapter<OnWireItemT,InMemItemT> getAdapter() {
+        return Coordinator._getInstance().getAdapter(adapter);
+    }
+
+    public ListIterator<OnWireItemT> iterator(PropT prop, XMLSerializer context) {
+        return new ListIteratorImpl( core.iterator(prop,context), context );
+    }
+
+    public PackT startPacking(BeanT bean, Accessor<BeanT, PropT> accessor) throws AccessorException {
+        return core.startPacking(bean,accessor);
+    }
+
+    public void addToPack(PackT pack, OnWireItemT item) throws AccessorException {
+        InMemItemT r;
+        try {
+            r = getAdapter().unmarshal(item);
+        } catch (Exception e) {
+            throw new AccessorException(e);
+        }
+        core.addToPack(pack,r);
+    }
+
+    public void endPacking(PackT pack, BeanT bean, Accessor<BeanT,PropT> accessor) throws AccessorException {
+        core.endPacking(pack,bean,accessor);
+    }
+
+    public void reset(BeanT bean, Accessor<BeanT, PropT> accessor) throws AccessorException {
+        core.reset(bean,accessor);
+    }
+
+    private final class ListIteratorImpl implements ListIterator<OnWireItemT> {
+        private final ListIterator<InMemItemT> core;
+        private final XMLSerializer serializer;
+
+        public ListIteratorImpl(ListIterator<InMemItemT> core,XMLSerializer serializer) {
+            this.core = core;
+            this.serializer = serializer;
+        }
+
+        public boolean hasNext() {
+            return core.hasNext();
+        }
+
+        public OnWireItemT next() throws SAXException, JAXBException {
+            InMemItemT next = core.next();
+            try {
+                return getAdapter().marshal(next);
+            } catch (Exception e) {
+                serializer.reportError(null,e);
+                return null; // recover this error by returning null
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/DefaultTransducedAccessor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/DefaultTransducedAccessor.java
new file mode 100644
index 0000000..ad55abe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/DefaultTransducedAccessor.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link TransducedAccessor} that prints to {@link String}.
+ *
+ * <p>
+ * The print method that works for {@link String} determines the dispatching
+ * of the {@link #writeText(XMLSerializer,Object,String)} and
+ * {@link #writeLeafElement(XMLSerializer, Name, Object, String)} methods,
+ * so those are implemented here.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class DefaultTransducedAccessor<T> extends TransducedAccessor<T> {
+
+    public abstract String print(T o) throws AccessorException, SAXException;
+
+    public void writeLeafElement(XMLSerializer w, Name tagName, T o, String fieldName) throws SAXException, AccessorException, IOException, XMLStreamException {
+        w.leafElement(tagName,print(o),fieldName);
+    }
+
+    public void writeText(XMLSerializer w, T o, String fieldName) throws AccessorException, SAXException, IOException, XMLStreamException {
+        w.text(print(o),fieldName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/ListIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/ListIterator.java
new file mode 100644
index 0000000..4a0fdea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/ListIterator.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import java.util.Iterator;
+
+import javax.xml.bind.JAXBException;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Almost like {@link Iterator} but can throw JAXB specific exceptions.
+ * @author Kohsuke Kawaguchi
+ */
+public interface ListIterator<E> {
+    /**
+     * Works like {@link Iterator#hasNext()}.
+     */
+    boolean hasNext();
+
+    /**
+     * Works like {@link Iterator#next()}.
+     *
+     * @throws SAXException
+     *      if an error is found, reported, and we were told to abort
+     * @throws JAXBException
+     *      if an error is found, reported, and we were told to abort
+     */
+    E next() throws SAXException, JAXBException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/ListTransducedAccessorImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/ListTransducedAccessorImpl.java
new file mode 100644
index 0000000..139585b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/ListTransducedAccessorImpl.java
@@ -0,0 +1,146 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import javax.xml.bind.JAXBException;
+
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link TransducedAccessor} for a list simple type.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ListTransducedAccessorImpl<BeanT,ListT,ItemT,PackT> extends DefaultTransducedAccessor<BeanT> {
+    /**
+     * {@link Transducer} for each item type.
+     */
+    private final Transducer<ItemT> xducer;
+    /**
+     * {@link Lister} for handling list of tokens.
+     */
+    private final Lister<BeanT,ListT,ItemT,PackT> lister;
+    /**
+     * {@link Accessor} to get/set the list.
+     */
+    private final Accessor<BeanT,ListT> acc;
+
+    public ListTransducedAccessorImpl(Transducer<ItemT> xducer, Accessor<BeanT,ListT> acc, Lister<BeanT,ListT,ItemT,PackT> lister) {
+        this.xducer = xducer;
+        this.lister = lister;
+        this.acc = acc;
+    }
+
+    public boolean useNamespace() {
+        return xducer.useNamespace();
+    }
+
+    public void declareNamespace(BeanT bean, XMLSerializer w) throws AccessorException, SAXException {
+        ListT list = acc.get(bean);
+
+        if(list!=null) {
+           ListIterator<ItemT> itr = lister.iterator(list, w);
+
+            while(itr.hasNext()) {
+                try {
+                    ItemT item = itr.next();
+                    if (item != null) {
+                        xducer.declareNamespace(item,w);
+                    }
+                } catch (JAXBException e) {
+                    w.reportError(null,e);
+                }
+            }
+        }
+    }
+
+    // TODO: this is inefficient, consider a redesign
+    // perhaps we should directly write to XMLSerializer,
+    // or maybe add more methods like writeLeafElement.
+    public String print(BeanT o) throws AccessorException, SAXException {
+        ListT list = acc.get(o);
+
+        if(list==null)
+            return null;
+
+        StringBuilder buf = new StringBuilder();
+        XMLSerializer w = XMLSerializer.getInstance();
+        ListIterator<ItemT> itr = lister.iterator(list, w);
+
+        while(itr.hasNext()) {
+            try {
+                ItemT item = itr.next();
+                if (item != null) {
+                    if(buf.length()>0)  buf.append(' ');
+                    buf.append(xducer.print(item));
+                }
+            } catch (JAXBException e) {
+                w.reportError(null,e);
+            }
+        }
+        return buf.toString();
+    }
+
+    private void processValue(BeanT bean, CharSequence s) throws AccessorException, SAXException {
+        PackT pack = lister.startPacking(bean,acc);
+
+        int idx = 0;
+        int len = s.length();
+
+        while(true) {
+            int p = idx;
+            while( p<len && !WhiteSpaceProcessor.isWhiteSpace(s.charAt(p)) )
+                p++;
+
+            CharSequence token = s.subSequence(idx,p);
+            if (!token.equals(""))
+                lister.addToPack(pack,xducer.parse(token));
+
+            if(p==len)      break;  // done
+
+            while( p<len && WhiteSpaceProcessor.isWhiteSpace(s.charAt(p)) )
+                p++;
+            if(p==len)      break;  // done
+
+            idx = p;
+        }
+
+        lister.endPacking(pack,bean,acc);
+    }
+
+    public void parse(BeanT bean, CharSequence lexical) throws AccessorException, SAXException {
+        processValue(bean,lexical);
+    }
+
+    public boolean hasValue(BeanT bean) throws AccessorException {
+        return acc.get(bean)!=null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Lister.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Lister.java
new file mode 100644
index 0000000..8b133f3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Lister.java
@@ -0,0 +1,459 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import java.lang.ref.WeakReference;
+import java.lang.reflect.Array;
+import java.lang.reflect.ParameterizedType;
+import java.lang.reflect.Type;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.WeakHashMap;
+import java.util.concurrent.Callable;
+
+import javax.xml.bind.JAXBException;
+
+import com.sun.istack.internal.SAXException2;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Patcher;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Used to list individual values of a multi-value property, and
+ * to pack individual values into a multi-value property.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class Lister<BeanT,PropT,ItemT,PackT> {
+
+    protected Lister() {}
+
+    /**
+     * Iterates values of a multi-value property.
+     *
+     * @param context
+     *      This parameter is used to support ID/IDREF handling.
+     */
+    public abstract ListIterator<ItemT> iterator(PropT multiValueProp, XMLSerializer context);
+
+    /**
+     * Setting values to a multi-value property starts by creating
+     * a transient object called "pack" from the current field.
+     */
+    public abstract PackT startPacking(BeanT bean, Accessor<BeanT, PropT> acc) throws AccessorException;
+
+    /**
+     * Once the {@link #startPacking} is called, you can
+     * add values to the pack by using this method.
+     */
+    public abstract void addToPack( PackT pack, ItemT newValue ) throws AccessorException;
+
+    /**
+     * Finally, call this method to
+     * wraps up the {@code pack}. This method may update the field of
+     * the given bean.
+     */
+    public abstract void endPacking( PackT pack, BeanT bean, Accessor<BeanT,PropT> acc ) throws AccessorException;
+
+    /**
+     * Clears the values of the property.
+     */
+    public abstract void reset(BeanT o,Accessor<BeanT,PropT> acc) throws AccessorException;
+
+
+    /**
+     * Gets a reference to the appropriate {@link Lister} object
+     * if the field is a multi-value field. Otherwise null.
+     *
+     * @param fieldType
+     *      the type of the field that stores the collection
+     * @param idness
+     *      ID-ness of the property.
+     * @param adapter
+     *      adapter to be used for individual items. can be null.
+     */
+    public static <BeanT,PropT,ItemT,PackT>
+        Lister<BeanT,PropT,ItemT,PackT> create(Type fieldType,ID idness, Adapter<Type,Class> adapter) {
+
+        Class rawType = Navigator.REFLECTION.erasure(fieldType);
+        Class itemType;
+
+        Lister l;
+        if( rawType.isArray() ) {
+            itemType = rawType.getComponentType();
+            l = getArrayLister(itemType);
+        } else
+        if( Collection.class.isAssignableFrom(rawType) ) {
+            Type bt = Navigator.REFLECTION.getBaseClass(fieldType,Collection.class);
+            if(bt instanceof ParameterizedType)
+                itemType = Navigator.REFLECTION.erasure(((ParameterizedType)bt).getActualTypeArguments()[0]);
+            else
+                itemType = Object.class;
+            l = new CollectionLister(getImplClass(rawType));
+        } else
+            return null;
+
+        if(idness==ID.IDREF)
+            l = new IDREFS(l,itemType);
+
+        if(adapter!=null)
+            l = new AdaptedLister(l,adapter.adapterType);
+
+        return l;
+    }
+
+    private static Class getImplClass(Class fieldType) {
+        return ClassFactory.inferImplClass(fieldType,ClassFactory.COLLECTION_IMPL_CLASSES);
+    }
+
+    /**
+     * Cache instances of {@link ArrayLister}s.
+     */
+    private static final Map<Class,WeakReference<Lister>> arrayListerCache =
+        Collections.synchronizedMap(new WeakHashMap<Class,WeakReference<Lister>>());
+
+    /**
+     * Creates a lister for array type.
+     */
+    private static Lister getArrayLister( Class componentType ) {
+        Lister l=null;
+        if(componentType.isPrimitive())
+            l = primitiveArrayListers.get(componentType);
+        else {
+            WeakReference<Lister> wr = arrayListerCache.get(componentType);
+            if(wr!=null)
+                l = wr.get();
+            if(l==null) {
+                l = new ArrayLister(componentType);
+                arrayListerCache.put(componentType,new WeakReference<Lister>(l));
+            }
+        }
+        assert l!=null;
+        return l;
+    }
+
+    /**
+     * {@link Lister} for an array.
+     *
+     * <p>
+     * Array packing is slower, but we expect this to be used less frequently than
+     * the {@link CollectionLister}.
+     */
+    private static final class ArrayLister<BeanT,ItemT> extends Lister<BeanT,ItemT[],ItemT,Pack<ItemT>> {
+
+        private final Class<ItemT> itemType;
+
+        public ArrayLister(Class<ItemT> itemType) {
+            this.itemType = itemType;
+        }
+
+        public ListIterator<ItemT> iterator(final ItemT[] objects, XMLSerializer context) {
+            return new ListIterator<ItemT>() {
+                int idx=0;
+                public boolean hasNext() {
+                    return idx<objects.length;
+                }
+
+                public ItemT next() {
+                    return objects[idx++];
+                }
+            };
+        }
+
+        public Pack startPacking(BeanT current, Accessor<BeanT, ItemT[]> acc) {
+            return new Pack<ItemT>(itemType);
+        }
+
+        public void addToPack(Pack<ItemT> objects, ItemT o) {
+            objects.add(o);
+        }
+
+        public void endPacking( Pack<ItemT> pack, BeanT bean, Accessor<BeanT,ItemT[]> acc ) throws AccessorException {
+            acc.set(bean,pack.build());
+        }
+
+        public void reset(BeanT o,Accessor<BeanT,ItemT[]> acc) throws AccessorException {
+            acc.set(o,(ItemT[])Array.newInstance(itemType,0));
+        }
+
+    }
+
+    public static final class Pack<ItemT> extends ArrayList<ItemT> {
+        private final Class<ItemT> itemType;
+
+        public Pack(Class<ItemT> itemType) {
+            this.itemType = itemType;
+        }
+
+        public ItemT[] build() {
+            return super.toArray( (ItemT[])Array.newInstance(itemType,size()) );
+        }
+    }
+
+    /**
+     * Listers for the primitive type arrays, keyed by their primitive Class object.
+     */
+    /*package*/ static final Map<Class,Lister> primitiveArrayListers = new HashMap<Class,Lister>();
+
+    static {
+        // register primitive array listers
+        PrimitiveArrayListerBoolean.register();
+        PrimitiveArrayListerByte.register();
+        PrimitiveArrayListerCharacter.register();
+        PrimitiveArrayListerDouble.register();
+        PrimitiveArrayListerFloat.register();
+        PrimitiveArrayListerInteger.register();
+        PrimitiveArrayListerLong.register();
+        PrimitiveArrayListerShort.register();
+    }
+
+    /**
+     * {@link Lister} for a collection
+     */
+    public static final class CollectionLister<BeanT,T extends Collection> extends Lister<BeanT,T,Object,T> {
+
+        /**
+         * Sometimes we need to create a new instance of a collection.
+         * This is such an implementation class.
+         */
+        private final Class<? extends T> implClass;
+
+        public CollectionLister(Class<? extends T> implClass) {
+            this.implClass = implClass;
+        }
+
+        public ListIterator iterator(T collection, XMLSerializer context) {
+            final Iterator itr = collection.iterator();
+            return new ListIterator() {
+                public boolean hasNext() {
+                    return itr.hasNext();
+                }
+                public Object next() {
+                    return itr.next();
+                }
+            };
+        }
+
+        public T startPacking(BeanT bean, Accessor<BeanT, T> acc) throws AccessorException {
+            T collection = acc.get(bean);
+            if(collection==null) {
+                collection = ClassFactory.create(implClass);
+            }
+            collection.clear();
+            return collection;
+        }
+
+        public void addToPack(T collection, Object o) {
+            collection.add(o);
+        }
+
+        public void endPacking( T collection, BeanT bean, Accessor<BeanT,T> acc ) throws AccessorException {
+            // this needs to be done in the endPacking, because
+            // sometimes the accessor uses an adapter, and the adapter needs to see
+            // the whole thing
+            acc.set(bean,collection);
+        }
+
+        public void reset(BeanT bean, Accessor<BeanT, T> acc) throws AccessorException {
+            acc.get(bean).clear();
+        }
+    }
+
+    /**
+     * {@link Lister} for IDREFS.
+     */
+    private static final class IDREFS<BeanT,PropT> extends Lister<BeanT,PropT,String,IDREFS<BeanT,PropT>.Pack> {
+        private final Lister<BeanT,PropT,Object,Object> core;
+        /**
+         * Expected type to which IDREF resolves to.
+         */
+        private final Class itemType;
+
+        public IDREFS(Lister core, Class itemType) {
+            this.core = core;
+            this.itemType = itemType;
+        }
+
+        public ListIterator<String> iterator(PropT prop, XMLSerializer context) {
+            final ListIterator i = core.iterator(prop,context);
+
+            return new IDREFSIterator(i, context);
+        }
+
+        public Pack startPacking(BeanT bean, Accessor<BeanT, PropT> acc) {
+            return new Pack(bean,acc);
+        }
+
+        public void addToPack(Pack pack, String item) {
+            pack.add(item);
+        }
+
+        public void endPacking(Pack pack, BeanT bean, Accessor<BeanT, PropT> acc) {
+        }
+
+        public void reset(BeanT bean, Accessor<BeanT, PropT> acc) throws AccessorException {
+            core.reset(bean,acc);
+        }
+
+        /**
+         * PackT for this lister.
+         */
+        private class Pack implements Patcher {
+            private final BeanT bean;
+            private final List<String> idrefs = new ArrayList<String>();
+            private final UnmarshallingContext context;
+            private final Accessor<BeanT,PropT> acc;
+
+            public Pack(BeanT bean, Accessor<BeanT,PropT> acc) {
+                this.bean = bean;
+                this.acc = acc;
+                this.context = UnmarshallingContext.getInstance();
+                context.addPatcher(this);
+            }
+
+            public void add(String item) {
+                idrefs.add(item);
+            }
+
+            /**
+             * Resolves IDREFS and fill in the actual array.
+             */
+            public void run() throws SAXException {
+                try {
+                    Object pack = core.startPacking(bean,acc);
+
+                    for( String id : idrefs ) {
+                        Callable callable = context.getObjectFromId(id,itemType);
+                        Object t;
+
+                        try {
+                            t = (callable!=null) ? callable.call() : null;
+                        } catch (SAXException e) {
+                            throw e;
+                        } catch (Exception e) {
+                            throw new SAXException2(e);
+                        }
+
+                        if(t==null) {
+                            context.errorUnresolvedIDREF(bean,id);
+                        } else {
+                            TODO.prototype(); // TODO: check if the type of t is proper.
+                            core.addToPack(pack,t);
+                        }
+                    }
+
+                    core.endPacking(pack,bean,acc);
+                } catch (AccessorException e) {
+                    context.handleError(e);
+                }
+            }
+        }
+    }
+
+    /**
+     * {@link Iterator} for IDREFS lister.
+     *
+     * <p>
+     * Only in ArrayElementProperty we need to get the actual
+     * referenced object. This is a kind of ugly way to make that work.
+     */
+    public static final class IDREFSIterator implements ListIterator<String> {
+        private final ListIterator i;
+        private final XMLSerializer context;
+        private Object last;
+
+        private IDREFSIterator(ListIterator i, XMLSerializer context) {
+            this.i = i;
+            this.context = context;
+        }
+
+        public boolean hasNext() {
+            return i.hasNext();
+        }
+
+        /**
+         * Returns the last referenced object (not just its ID)
+         */
+        public Object last() {
+            return last;
+        }
+
+        public String next() throws SAXException, JAXBException {
+            last = i.next();
+            String id = context.grammar.getBeanInfo(last,true).getId(last,context);
+            if(id==null) {
+                context.errorMissingId(last);
+            }
+            return id;
+        }
+    }
+
+    /**
+     * Special {@link Lister} used to recover from an error.
+     */
+    public static final Lister ERROR = new Lister() {
+        public ListIterator iterator(Object o, XMLSerializer context) {
+            return EMPTY_ITERATOR;
+        }
+
+        public Object startPacking(Object o, Accessor accessor) {
+            return null;
+        }
+
+        public void addToPack(Object o, Object o1) {
+        }
+
+        public void endPacking(Object o, Object o1, Accessor accessor) {
+        }
+
+        public void reset(Object o, Accessor accessor) {
+        }
+    };
+
+    private static final ListIterator EMPTY_ITERATOR = new ListIterator() {
+        public boolean hasNext() {
+            return false;
+        }
+
+        public Object next() {
+            throw new IllegalStateException();
+        }
+    };
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Messages.java
new file mode 100644
index 0000000..da1c89b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Messages.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Message resources
+ */
+enum Messages {
+    // Accessor
+    UNABLE_TO_ACCESS_NON_PUBLIC_FIELD,  // 2 args
+    UNASSIGNABLE_TYPE, // 2 args
+    NO_SETTER, // 1 arg
+    NO_GETTER, // 1 arg
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Messages.properties
new file mode 100644
index 0000000..a43f603
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/Messages.properties
@@ -0,0 +1,16 @@
+UNABLE_TO_ACCESS_NON_PUBLIC_FIELD = \
+    Unable to make {0}.{1} accessible.
+
+UNASSIGNABLE_TYPE = \
+    The type of the field is {0}, but the type of the object is {1}
+
+# these are normally developer error, so they should be verbose.
+NO_SETTER = \
+    The property has a getter "{0}" but no setter. \
+    For unmarshalling, please define setters. \
+    (Or if this is a collection property, make sure that the getter returns a collection instance.)
+
+NO_GETTER = \
+    The property has a setter "{0}" but no getter. \
+    For marshaller, please define getters.
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/NullSafeAccessor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/NullSafeAccessor.java
new file mode 100644
index 0000000..25abec3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/NullSafeAccessor.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+
+/**
+ * {@link Accessor} wrapper that replaces a null with an empty collection.
+ *
+ * <p>
+ * This is so that JAX-WS property accessor will work like an ordinary getter.
+ *
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class NullSafeAccessor<B,V,P> extends Accessor<B,V> {
+    private final Accessor<B,V> core;
+    private final Lister<B,V,?,P> lister;
+
+    public NullSafeAccessor(Accessor<B,V> core, Lister<B,V,?,P> lister) {
+        super(core.getValueType());
+        this.core = core;
+        this.lister = lister;
+    }
+
+    public V get(B bean) throws AccessorException {
+        V v = core.get(bean);
+        if(v==null) {
+            // creates a new object
+            P pack = lister.startPacking(bean,core);
+            lister.endPacking(pack,bean,core);
+            v = core.get(bean);
+        }
+        return v;
+    }
+
+    public void set(B bean, V value) throws AccessorException {
+        core.set(bean,value);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerBoolean.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerBoolean.java
new file mode 100644
index 0000000..12b046c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerBoolean.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+/**
+ * {@link Lister} for primitive type arrays.
+ *
+ * <p>
+ * B y t e ArrayLister is used as the master to generate the rest of the
+ * lister classes. Do not modify the generated copies.
+ */
+final class PrimitiveArrayListerBoolean<BeanT> extends Lister<BeanT,boolean[],Boolean,PrimitiveArrayListerBoolean.BooleanArrayPack> {
+
+    private PrimitiveArrayListerBoolean() {
+    }
+
+    /*package*/ static void register() {
+        Lister.primitiveArrayListers.put(Boolean.TYPE,new PrimitiveArrayListerBoolean());
+    }
+
+    public ListIterator<Boolean> iterator(final boolean[] objects, XMLSerializer context) {
+        return new ListIterator<Boolean>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<objects.length;
+            }
+
+            public Boolean next() {
+                return objects[idx++];
+            }
+        };
+    }
+
+    public BooleanArrayPack startPacking(BeanT current, Accessor<BeanT, boolean[]> acc) {
+        return new BooleanArrayPack();
+    }
+
+    public void addToPack(BooleanArrayPack objects, Boolean o) {
+        objects.add(o);
+    }
+
+    public void endPacking( BooleanArrayPack pack, BeanT bean, Accessor<BeanT,boolean[]> acc ) throws AccessorException {
+        acc.set(bean,pack.build());
+    }
+
+    public void reset(BeanT o,Accessor<BeanT,boolean[]> acc) throws AccessorException {
+        acc.set(o,new boolean[0]);
+    }
+
+    static final class BooleanArrayPack {
+        boolean[] buf = new boolean[16];
+        int size;
+
+        void add(Boolean b) {
+            if(buf.length==size) {
+                // realloc
+                boolean[] nb = new boolean[buf.length*2];
+                System.arraycopy(buf,0,nb,0,buf.length);
+                buf = nb;
+            }
+            buf[size++] = b;
+        }
+
+        boolean[] build() {
+            if(buf.length==size)
+                // if we are lucky enough
+                return buf;
+
+            boolean[] r = new boolean[size];
+            System.arraycopy(buf,0,r,0,size);
+            return r;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerByte.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerByte.java
new file mode 100644
index 0000000..dea07a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerByte.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+/**
+ * {@link Lister} for primitive type arrays.
+ *
+ * <p>
+ * B y t e ArrayLister is used as the master to generate the rest of the
+ * lister classes. Do not modify the generated copies.
+ */
+final class PrimitiveArrayListerByte<BeanT> extends Lister<BeanT,byte[],Byte,PrimitiveArrayListerByte.ByteArrayPack> {
+
+    private PrimitiveArrayListerByte() {
+    }
+
+    /*package*/ static void register() {
+        Lister.primitiveArrayListers.put(Byte.TYPE,new PrimitiveArrayListerByte());
+    }
+
+    public ListIterator<Byte> iterator(final byte[] objects, XMLSerializer context) {
+        return new ListIterator<Byte>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<objects.length;
+            }
+
+            public Byte next() {
+                return objects[idx++];
+            }
+        };
+    }
+
+    public ByteArrayPack startPacking(BeanT current, Accessor<BeanT, byte[]> acc) {
+        return new ByteArrayPack();
+    }
+
+    public void addToPack(ByteArrayPack objects, Byte o) {
+        objects.add(o);
+    }
+
+    public void endPacking( ByteArrayPack pack, BeanT bean, Accessor<BeanT,byte[]> acc ) throws AccessorException {
+        acc.set(bean,pack.build());
+    }
+
+    public void reset(BeanT o,Accessor<BeanT,byte[]> acc) throws AccessorException {
+        acc.set(o,new byte[0]);
+    }
+
+    static final class ByteArrayPack {
+        byte[] buf = new byte[16];
+        int size;
+
+        void add(Byte b) {
+            if(buf.length==size) {
+                // realloc
+                byte[] nb = new byte[buf.length*2];
+                System.arraycopy(buf,0,nb,0,buf.length);
+                buf = nb;
+            }
+            buf[size++] = b;
+        }
+
+        byte[] build() {
+            if(buf.length==size)
+                // if we are lucky enough
+                return buf;
+
+            byte[] r = new byte[size];
+            System.arraycopy(buf,0,r,0,size);
+            return r;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerCharacter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerCharacter.java
new file mode 100644
index 0000000..e2d2153
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerCharacter.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+/**
+ * {@link Lister} for primitive type arrays.
+ *
+ * <p>
+ * B y t e ArrayLister is used as the master to generate the rest of the
+ * lister classes. Do not modify the generated copies.
+ */
+final class PrimitiveArrayListerCharacter<BeanT> extends Lister<BeanT,char[],Character,PrimitiveArrayListerCharacter.CharacterArrayPack> {
+
+    private PrimitiveArrayListerCharacter() {
+    }
+
+    /*package*/ static void register() {
+        Lister.primitiveArrayListers.put(Character.TYPE,new PrimitiveArrayListerCharacter());
+    }
+
+    public ListIterator<Character> iterator(final char[] objects, XMLSerializer context) {
+        return new ListIterator<Character>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<objects.length;
+            }
+
+            public Character next() {
+                return objects[idx++];
+            }
+        };
+    }
+
+    public CharacterArrayPack startPacking(BeanT current, Accessor<BeanT, char[]> acc) {
+        return new CharacterArrayPack();
+    }
+
+    public void addToPack(CharacterArrayPack objects, Character o) {
+        objects.add(o);
+    }
+
+    public void endPacking( CharacterArrayPack pack, BeanT bean, Accessor<BeanT,char[]> acc ) throws AccessorException {
+        acc.set(bean,pack.build());
+    }
+
+    public void reset(BeanT o,Accessor<BeanT,char[]> acc) throws AccessorException {
+        acc.set(o,new char[0]);
+    }
+
+    static final class CharacterArrayPack {
+        char[] buf = new char[16];
+        int size;
+
+        void add(Character b) {
+            if(buf.length==size) {
+                // realloc
+                char[] nb = new char[buf.length*2];
+                System.arraycopy(buf,0,nb,0,buf.length);
+                buf = nb;
+            }
+            buf[size++] = b;
+        }
+
+        char[] build() {
+            if(buf.length==size)
+                // if we are lucky enough
+                return buf;
+
+            char[] r = new char[size];
+            System.arraycopy(buf,0,r,0,size);
+            return r;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerDouble.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerDouble.java
new file mode 100644
index 0000000..3f4257d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerDouble.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+/**
+ * {@link Lister} for primitive type arrays.
+ *
+ * <p>
+ * B y t e ArrayLister is used as the master to generate the rest of the
+ * lister classes. Do not modify the generated copies.
+ */
+final class PrimitiveArrayListerDouble<BeanT> extends Lister<BeanT,double[],Double,PrimitiveArrayListerDouble.DoubleArrayPack> {
+
+    private PrimitiveArrayListerDouble() {
+    }
+
+    /*package*/ static void register() {
+        Lister.primitiveArrayListers.put(Double.TYPE,new PrimitiveArrayListerDouble());
+    }
+
+    public ListIterator<Double> iterator(final double[] objects, XMLSerializer context) {
+        return new ListIterator<Double>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<objects.length;
+            }
+
+            public Double next() {
+                return objects[idx++];
+            }
+        };
+    }
+
+    public DoubleArrayPack startPacking(BeanT current, Accessor<BeanT, double[]> acc) {
+        return new DoubleArrayPack();
+    }
+
+    public void addToPack(DoubleArrayPack objects, Double o) {
+        objects.add(o);
+    }
+
+    public void endPacking( DoubleArrayPack pack, BeanT bean, Accessor<BeanT,double[]> acc ) throws AccessorException {
+        acc.set(bean,pack.build());
+    }
+
+    public void reset(BeanT o,Accessor<BeanT,double[]> acc) throws AccessorException {
+        acc.set(o,new double[0]);
+    }
+
+    static final class DoubleArrayPack {
+        double[] buf = new double[16];
+        int size;
+
+        void add(Double b) {
+            if(buf.length==size) {
+                // realloc
+                double[] nb = new double[buf.length*2];
+                System.arraycopy(buf,0,nb,0,buf.length);
+                buf = nb;
+            }
+            buf[size++] = b;
+        }
+
+        double[] build() {
+            if(buf.length==size)
+                // if we are lucky enough
+                return buf;
+
+            double[] r = new double[size];
+            System.arraycopy(buf,0,r,0,size);
+            return r;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerFloat.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerFloat.java
new file mode 100644
index 0000000..636c253
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerFloat.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+/**
+ * {@link Lister} for primitive type arrays.
+ *
+ * <p>
+ * B y t e ArrayLister is used as the master to generate the rest of the
+ * lister classes. Do not modify the generated copies.
+ */
+final class PrimitiveArrayListerFloat<BeanT> extends Lister<BeanT,float[],Float,PrimitiveArrayListerFloat.FloatArrayPack> {
+
+    private PrimitiveArrayListerFloat() {
+    }
+
+    /*package*/ static void register() {
+        Lister.primitiveArrayListers.put(Float.TYPE,new PrimitiveArrayListerFloat());
+    }
+
+    public ListIterator<Float> iterator(final float[] objects, XMLSerializer context) {
+        return new ListIterator<Float>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<objects.length;
+            }
+
+            public Float next() {
+                return objects[idx++];
+            }
+        };
+    }
+
+    public FloatArrayPack startPacking(BeanT current, Accessor<BeanT, float[]> acc) {
+        return new FloatArrayPack();
+    }
+
+    public void addToPack(FloatArrayPack objects, Float o) {
+        objects.add(o);
+    }
+
+    public void endPacking( FloatArrayPack pack, BeanT bean, Accessor<BeanT,float[]> acc ) throws AccessorException {
+        acc.set(bean,pack.build());
+    }
+
+    public void reset(BeanT o,Accessor<BeanT,float[]> acc) throws AccessorException {
+        acc.set(o,new float[0]);
+    }
+
+    static final class FloatArrayPack {
+        float[] buf = new float[16];
+        int size;
+
+        void add(Float b) {
+            if(buf.length==size) {
+                // realloc
+                float[] nb = new float[buf.length*2];
+                System.arraycopy(buf,0,nb,0,buf.length);
+                buf = nb;
+            }
+            buf[size++] = b;
+        }
+
+        float[] build() {
+            if(buf.length==size)
+                // if we are lucky enough
+                return buf;
+
+            float[] r = new float[size];
+            System.arraycopy(buf,0,r,0,size);
+            return r;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerInteger.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerInteger.java
new file mode 100644
index 0000000..99c3801
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerInteger.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+/**
+ * {@link Lister} for primitive type arrays.
+ *
+ * <p>
+ * B y t e ArrayLister is used as the master to generate the rest of the
+ * lister classes. Do not modify the generated copies.
+ */
+final class PrimitiveArrayListerInteger<BeanT> extends Lister<BeanT,int[],Integer,PrimitiveArrayListerInteger.IntegerArrayPack> {
+
+    private PrimitiveArrayListerInteger() {
+    }
+
+    /*package*/ static void register() {
+        Lister.primitiveArrayListers.put(Integer.TYPE,new PrimitiveArrayListerInteger());
+    }
+
+    public ListIterator<Integer> iterator(final int[] objects, XMLSerializer context) {
+        return new ListIterator<Integer>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<objects.length;
+            }
+
+            public Integer next() {
+                return objects[idx++];
+            }
+        };
+    }
+
+    public IntegerArrayPack startPacking(BeanT current, Accessor<BeanT, int[]> acc) {
+        return new IntegerArrayPack();
+    }
+
+    public void addToPack(IntegerArrayPack objects, Integer o) {
+        objects.add(o);
+    }
+
+    public void endPacking( IntegerArrayPack pack, BeanT bean, Accessor<BeanT,int[]> acc ) throws AccessorException {
+        acc.set(bean,pack.build());
+    }
+
+    public void reset(BeanT o,Accessor<BeanT,int[]> acc) throws AccessorException {
+        acc.set(o,new int[0]);
+    }
+
+    static final class IntegerArrayPack {
+        int[] buf = new int[16];
+        int size;
+
+        void add(Integer b) {
+            if(buf.length==size) {
+                // realloc
+                int[] nb = new int[buf.length*2];
+                System.arraycopy(buf,0,nb,0,buf.length);
+                buf = nb;
+            }
+            buf[size++] = b;
+        }
+
+        int[] build() {
+            if(buf.length==size)
+                // if we are lucky enough
+                return buf;
+
+            int[] r = new int[size];
+            System.arraycopy(buf,0,r,0,size);
+            return r;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerLong.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerLong.java
new file mode 100644
index 0000000..c6abaf9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerLong.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+/**
+ * {@link Lister} for primitive type arrays.
+ *
+ * <p>
+ * B y t e ArrayLister is used as the master to generate the rest of the
+ * lister classes. Do not modify the generated copies.
+ */
+final class PrimitiveArrayListerLong<BeanT> extends Lister<BeanT,long[],Long,PrimitiveArrayListerLong.LongArrayPack> {
+
+    private PrimitiveArrayListerLong() {
+    }
+
+    /*package*/ static void register() {
+        Lister.primitiveArrayListers.put(Long.TYPE,new PrimitiveArrayListerLong());
+    }
+
+    public ListIterator<Long> iterator(final long[] objects, XMLSerializer context) {
+        return new ListIterator<Long>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<objects.length;
+            }
+
+            public Long next() {
+                return objects[idx++];
+            }
+        };
+    }
+
+    public LongArrayPack startPacking(BeanT current, Accessor<BeanT, long[]> acc) {
+        return new LongArrayPack();
+    }
+
+    public void addToPack(LongArrayPack objects, Long o) {
+        objects.add(o);
+    }
+
+    public void endPacking( LongArrayPack pack, BeanT bean, Accessor<BeanT,long[]> acc ) throws AccessorException {
+        acc.set(bean,pack.build());
+    }
+
+    public void reset(BeanT o,Accessor<BeanT,long[]> acc) throws AccessorException {
+        acc.set(o,new long[0]);
+    }
+
+    static final class LongArrayPack {
+        long[] buf = new long[16];
+        int size;
+
+        void add(Long b) {
+            if(buf.length==size) {
+                // realloc
+                long[] nb = new long[buf.length*2];
+                System.arraycopy(buf,0,nb,0,buf.length);
+                buf = nb;
+            }
+            buf[size++] = b;
+        }
+
+        long[] build() {
+            if(buf.length==size)
+                // if we are lucky enough
+                return buf;
+
+            long[] r = new long[size];
+            System.arraycopy(buf,0,r,0,size);
+            return r;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerShort.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerShort.java
new file mode 100644
index 0000000..cc0ca43
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/PrimitiveArrayListerShort.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+
+/**
+ * {@link Lister} for primitive type arrays.
+ *
+ * <p>
+ * B y t e ArrayLister is used as the master to generate the rest of the
+ * lister classes. Do not modify the generated copies.
+ */
+final class PrimitiveArrayListerShort<BeanT> extends Lister<BeanT,short[],Short,PrimitiveArrayListerShort.ShortArrayPack> {
+
+    private PrimitiveArrayListerShort() {
+    }
+
+    /*package*/ static void register() {
+        Lister.primitiveArrayListers.put(Short.TYPE,new PrimitiveArrayListerShort());
+    }
+
+    public ListIterator<Short> iterator(final short[] objects, XMLSerializer context) {
+        return new ListIterator<Short>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<objects.length;
+            }
+
+            public Short next() {
+                return objects[idx++];
+            }
+        };
+    }
+
+    public ShortArrayPack startPacking(BeanT current, Accessor<BeanT, short[]> acc) {
+        return new ShortArrayPack();
+    }
+
+    public void addToPack(ShortArrayPack objects, Short o) {
+        objects.add(o);
+    }
+
+    public void endPacking( ShortArrayPack pack, BeanT bean, Accessor<BeanT,short[]> acc ) throws AccessorException {
+        acc.set(bean,pack.build());
+    }
+
+    public void reset(BeanT o,Accessor<BeanT,short[]> acc) throws AccessorException {
+        acc.set(o,new short[0]);
+    }
+
+    static final class ShortArrayPack {
+        short[] buf = new short[16];
+        int size;
+
+        void add(Short b) {
+            if(buf.length==size) {
+                // realloc
+                short[] nb = new short[buf.length*2];
+                System.arraycopy(buf,0,nb,0,buf.length);
+                buf = nb;
+            }
+            buf[size++] = b;
+        }
+
+        short[] build() {
+            if(buf.length==size)
+                // if we are lucky enough
+                return buf;
+
+            short[] r = new short[size];
+            System.arraycopy(buf,0,r,0,size);
+            return r;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/TransducedAccessor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/TransducedAccessor.java
new file mode 100644
index 0000000..bdaf784
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/TransducedAccessor.java
@@ -0,0 +1,339 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect;
+
+import java.io.IOException;
+import java.util.concurrent.Callable;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.annotation.XmlValue;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.istack.internal.Nullable;
+import com.sun.istack.internal.SAXException2;
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.model.core.ID;
+import com.sun.xml.internal.bind.v2.model.impl.RuntimeModelBuilder;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeNonElementRef;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.opt.OptimizedTransducedAccessorFactory;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Patcher;
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Accessor} and {@link Transducer} combined into one object.
+ *
+ * <p>
+ * This allows efficient conversions between primitive values and
+ * String without using boxing.
+ *
+ * <p>
+ * This abstraction only works for a single-value property.
+ *
+ * <p>
+ * An instance of {@link TransducedAccessor} implicitly holds a
+ * field of the {@code BeanT} that the accessors access.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class TransducedAccessor<BeanT> {
+
+    /**
+     * @see Transducer#useNamespace()
+     */
+    public boolean useNamespace() {
+        return false;
+    }
+
+    /**
+     * Obtain the value of the field and declares the namespace URIs used in
+     * the value.
+     *
+     * @see Transducer#declareNamespace(Object, XMLSerializer)
+     */
+    public void declareNamespace( BeanT o, XMLSerializer w ) throws AccessorException, SAXException {
+    }
+
+    /**
+     * Prints the responsible field of the given bean to the writer.
+     *
+     * <p>
+     * Use {@link XMLSerializer#getInstance()} to access to the namespace bindings
+     *
+     * @return
+     *      if the accessor didn't yield a value, return null.
+     */
+    public abstract @Nullable CharSequence print(@NotNull BeanT o) throws AccessorException, SAXException;
+
+    /**
+     * Parses the text value into the responsible field of the given bean.
+     *
+     * <p>
+     * Use {@link UnmarshallingContext#getInstance()} to access to the namespace bindings
+     *
+     * @throws AccessorException
+     *      if the transducer is used to parse an user bean that uses {@link XmlValue},
+     *      then this exception may occur when it tries to set the leaf value to the bean.
+     * @throws RuntimeException
+     *      if the lexical form is incorrect. The method may throw a RuntimeException,
+     *      but it shouldn't cause the entire unmarshalling to fail.
+     * @throws SAXException
+     *      if the parse method found an error, the error is reported, and then
+     *      the processing is aborted.
+     */
+    public abstract void parse(BeanT o, CharSequence lexical) throws AccessorException, SAXException;
+
+    /**
+     * Checks if the field has a value.
+     */
+    public abstract boolean hasValue(BeanT o) throws AccessorException;
+
+
+
+
+
+
+
+
+
+
+
+    /**
+     * Gets the {@link TransducedAccessor} appropriately configured for
+     * the given property.
+     *
+     * <p>
+     * This allows the implementation to use an optimized code.
+     */
+    public static <T> TransducedAccessor<T> get(RuntimeNonElementRef ref) {
+        Transducer xducer = RuntimeModelBuilder.createTransducer(ref);
+        RuntimePropertyInfo prop = ref.getSource();
+
+        if(prop.isCollection()) {
+            return new ListTransducedAccessorImpl(xducer,prop.getAccessor(),
+                    Lister.create(Navigator.REFLECTION.erasure(prop.getRawType()),prop.id(),
+                    prop.getAdapter()));
+        }
+
+        if(prop.id()==ID.IDREF)
+            return new IDREFTransducedAccessorImpl(prop.getAccessor());
+
+        if(xducer.isDefault()) {
+            TransducedAccessor xa = OptimizedTransducedAccessorFactory.get(prop);
+            if(xa!=null)    return xa;
+        }
+
+        if(xducer.useNamespace())
+            return new CompositeContextDependentTransducedAccessorImpl( xducer, prop.getAccessor() );
+        else
+            return new CompositeTransducedAccessorImpl( xducer, prop.getAccessor() );
+    }
+
+    /**
+     * Convenience method to write the value as a text inside an element
+     * without any attributes.
+     * Can be overridden for improved performance.
+     *
+     * <p>
+     * The callee assumes that there's an associated value in the field.
+     * No @xsi:type handling is expected.
+     */
+    public abstract void writeLeafElement(XMLSerializer w, Name tagName, BeanT o, String fieldName) throws SAXException, AccessorException, IOException, XMLStreamException;
+
+    /**
+     * Invokes one of the {@link XMLSerializer#text(String, String)} method
+     * with the representation of data bested suited for this transduced accessor.
+     */
+    public abstract void writeText(XMLSerializer w, BeanT o, String fieldName) throws AccessorException, SAXException, IOException, XMLStreamException;
+
+    static class CompositeContextDependentTransducedAccessorImpl<BeanT,ValueT> extends CompositeTransducedAccessorImpl<BeanT,ValueT> {
+        public CompositeContextDependentTransducedAccessorImpl(Transducer<ValueT> xducer, Accessor<BeanT,ValueT> acc) {
+            super(xducer, acc);
+            assert xducer.useNamespace();
+        }
+
+        public boolean useNamespace() {
+            return true;
+        }
+
+        public void declareNamespace(BeanT bean, XMLSerializer w) throws AccessorException {
+            ValueT o = acc.get(bean);
+            if(o!=null)
+                xducer.declareNamespace(o,w);
+        }
+
+        @Override
+        public void writeLeafElement(XMLSerializer w, Name tagName, BeanT o, String fieldName) throws SAXException, AccessorException, IOException, XMLStreamException {
+            w.startElement(tagName,null);
+            declareNamespace(o,w);
+            w.endNamespaceDecls(null);
+            w.endAttributes();
+            xducer.writeText(w,acc.get(o),fieldName);
+            w.endElement();
+        }
+    }
+
+
+    /**
+     * Implementation of {@link TransducedAccessor} that
+     * simply combines a {@link Transducer} and {@link Accessor}.
+     */
+    static class CompositeTransducedAccessorImpl<BeanT,ValueT> extends TransducedAccessor<BeanT> {
+        protected final Transducer<ValueT> xducer;
+        protected final Accessor<BeanT,ValueT> acc;
+
+        public CompositeTransducedAccessorImpl(Transducer<ValueT> xducer, Accessor<BeanT,ValueT> acc) {
+            this.xducer = xducer;
+            this.acc = acc.optimize();
+        }
+
+        public CharSequence print(BeanT bean) throws AccessorException {
+            ValueT o = acc.get(bean);
+            if(o==null)     return null;
+            return xducer.print(o);
+        }
+
+        public void parse(BeanT bean, CharSequence lexical) throws AccessorException, SAXException {
+            acc.set(bean,xducer.parse(lexical));
+        }
+
+        public boolean hasValue(BeanT bean) throws AccessorException {
+            return acc.getUnadapted(bean)!=null;
+        }
+
+        @Override
+        public void writeLeafElement(XMLSerializer w, Name tagName, BeanT o, String fieldName) throws SAXException, AccessorException, IOException, XMLStreamException {
+            xducer.writeLeafElement(w,tagName,acc.get(o),fieldName);
+        }
+
+        @Override
+        public void writeText(XMLSerializer w, BeanT o, String fieldName) throws AccessorException, SAXException, IOException, XMLStreamException {
+            xducer.writeText(w,acc.get(o),fieldName);
+        }
+    }
+
+    /**
+     * {@link TransducedAccessor} for IDREF.
+     *
+     * BeanT: the type of the bean that contains this the IDREF field.
+     * TargetT: the type of the bean pointed by IDREF.
+     */
+    private static final class IDREFTransducedAccessorImpl<BeanT,TargetT> extends DefaultTransducedAccessor<BeanT> {
+        private final Accessor<BeanT,TargetT> acc;
+        /**
+         * The object that an IDREF resolves to should be
+         * assignable to this type.
+         */
+        private final Class<TargetT> targetType;
+
+        public IDREFTransducedAccessorImpl(Accessor<BeanT, TargetT> acc) {
+            this.acc = acc;
+            this.targetType = acc.getValueType();
+        }
+
+        public String print(BeanT bean) throws AccessorException, SAXException {
+            TargetT target = acc.get(bean);
+            if(target==null)    return null;
+
+            XMLSerializer w = XMLSerializer.getInstance();
+            try {
+                String id = w.grammar.getBeanInfo(target,true).getId(target,w);
+                if(id==null)
+                    w.errorMissingId(target);
+                return id;
+            } catch (JAXBException e) {
+                w.reportError(null,e);
+                return null;
+            }
+        }
+
+        private void assign( BeanT bean, TargetT t, UnmarshallingContext context ) throws AccessorException {
+            if(!targetType.isInstance(t))
+                context.handleError(Messages.UNASSIGNABLE_TYPE.format(targetType,t.getClass()));
+            else
+                acc.set(bean,t);
+        }
+
+        public void parse(final BeanT bean, CharSequence lexical) throws AccessorException, SAXException {
+            final String idref = WhiteSpaceProcessor.trim(lexical).toString();
+            final UnmarshallingContext context = UnmarshallingContext.getInstance();
+
+            final Callable callable = context.getObjectFromId(idref,acc.valueType);
+            if(callable==null) {
+                context.errorUnresolvedIDREF(bean,idref);
+                return;
+            }
+
+            TargetT t;
+            try {
+                t = (TargetT)callable.call();
+            } catch (SAXException e) {// from callable.call
+                throw e;
+            } catch (RuntimeException e) {// from callable.call
+                throw e;
+            } catch (Exception e) {// from callable.call
+                throw new SAXException2(e);
+            }
+            if(t!=null) {
+                assign(bean,t,context);
+            } else {
+                // try again later
+                context.addPatcher(new Patcher() {
+                    public void run() throws SAXException {
+                        try {
+                            TargetT t = (TargetT)callable.call();
+                            if(t==null) {
+                                context.errorUnresolvedIDREF(bean,idref);
+                            } else {
+                                assign(bean,t,context);
+                            }
+                        } catch (AccessorException e) {
+                            context.handleError(e);
+                        } catch (SAXException e) {// from callable.call
+                            throw e;
+                        } catch (RuntimeException e) {// from callable.call
+                            throw e;
+                        } catch (Exception e) {// from callable.call
+                            throw new SAXException2(e);
+                        }
+                    }
+                });
+            }
+        }
+
+        public boolean hasValue(BeanT bean) throws AccessorException {
+            return acc.get(bean)!=null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/AccessorInjector.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/AccessorInjector.java
new file mode 100644
index 0000000..0690dfd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/AccessorInjector.java
@@ -0,0 +1,112 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import java.io.InputStream;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.sun.xml.internal.bind.Util;
+import com.sun.xml.internal.bind.v2.bytecode.ClassTailor;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+class AccessorInjector {
+
+    private static final Logger logger = Util.getClassLogger();
+
+    protected static final boolean noOptimize =
+        Util.getSystemProperty(ClassTailor.class.getName()+".noOptimize")!=null;
+
+    static {
+        if(noOptimize)
+            logger.info("The optimized code generation is disabled");
+    }
+
+    /**
+     * Loads the optimized class and returns it.
+     *
+     * @return null
+     *      if it fails for some reason.
+     */
+    public static final Class<?> prepare(
+        Class beanClass, String templateClassName, String newClassName, String... replacements ) {
+
+        if(noOptimize)
+            return null;
+
+        try {
+            ClassLoader cl = beanClass.getClassLoader();
+            if(cl==null)    return null;    // how do I inject classes to this "null" class loader? for now, back off.
+
+            Class c = Injector.find(cl,newClassName);
+            if(c==null) {
+                byte[] image = tailor(templateClassName,newClassName,replacements);
+//                try {
+//                    new FileOutputStream("debug.class").write(image);
+//                } catch (IOException e) {
+//                    e.printStackTrace();
+//                }
+                if(image==null)
+                    return null;
+                c = Injector.inject(cl,newClassName,image);
+            }
+            return c;
+        } catch(SecurityException e) {
+            // we don't have enough permission to do this
+            logger.log(Level.INFO,"Unable to create an optimized TransducedAccessor ",e);
+            return null;
+        }
+    }
+
+
+    /**
+     * Customizes a class file by replacing constant pools.
+     *
+     * @param templateClassName
+     *      The resouce that contains the template class file.
+     * @param replacements
+     *      A list of pair of strings that specify the substitution
+     *      {@code String[]{search_0, replace_0, search_1, replace_1, ..., search_n, replace_n }
+     *
+     *      The search strings found in the constant pool will be replaced by the corresponding
+     *      replacement string.
+     */
+    private static final byte[] tailor( String templateClassName, String newClassName, String... replacements ) {
+        InputStream resource;
+        if(CLASS_LOADER!=null)
+            resource = CLASS_LOADER.getResourceAsStream(templateClassName+".class");
+        else
+            resource = ClassLoader.getSystemResourceAsStream(templateClassName+".class");
+        if(resource==null)
+            return null;
+
+        return ClassTailor.tailor(resource,templateClassName,newClassName,replacements);
+    }
+
+    private static final ClassLoader CLASS_LOADER = AccessorInjector.class.getClassLoader();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Bean.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Bean.java
new file mode 100644
index 0000000..4aec754
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Bean.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+
+/**
+ * Used by {@link TransducedAccessor} templates.
+ *
+ * <p>
+ * Fields needs to have a distinctive name.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class Bean {
+    public boolean f_boolean;
+    public char f_char;
+    public byte f_byte;
+    public short f_short;
+    int f_int;
+    public long f_long;
+    public float f_float;
+    public double f_double;
+    /**
+     * Field of a reference type.
+     * We need a distinctive type so that it can be easily replaced.
+     */
+    public Ref f_ref;
+
+    public boolean get_boolean() { throw new UnsupportedOperationException(); }
+    public void set_boolean(boolean b) { throw new UnsupportedOperationException(); }
+
+    public char get_char() { throw new UnsupportedOperationException(); }
+    public void set_char(char b) { throw new UnsupportedOperationException(); }
+
+    public byte get_byte() { throw new UnsupportedOperationException(); }
+    public void set_byte(byte b) { throw new UnsupportedOperationException(); }
+
+    public short get_short() { throw new UnsupportedOperationException(); }
+    public void set_short(short b) { throw new UnsupportedOperationException(); }
+
+    public int get_int() { throw new UnsupportedOperationException(); }
+    public void set_int(int b) { throw new UnsupportedOperationException(); }
+
+    public long get_long() { throw new UnsupportedOperationException(); }
+    public void set_long(long b) { throw new UnsupportedOperationException(); }
+
+    public float get_float() { throw new UnsupportedOperationException(); }
+    public void set_float(float b) { throw new UnsupportedOperationException(); }
+
+    public double get_double() { throw new UnsupportedOperationException(); }
+    public void set_double(double b) { throw new UnsupportedOperationException(); }
+
+    public Ref get_ref() { throw new UnsupportedOperationException(); }
+    public void set_ref(Ref r) { throw new UnsupportedOperationException(); }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Const.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Const.java
new file mode 100644
index 0000000..feab106
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Const.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class Const {
+    static byte default_value_byte = 0;
+    static boolean default_value_boolean = false;
+    static char default_value_char = 0;
+    static float default_value_float = 0;
+    static double default_value_double = 0;
+    static int default_value_int = 0;
+    static long default_value_long = 0;
+    static short default_value_short = 0;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Boolean.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Boolean.java
new file mode 100644
index 0000000..09c0f07
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Boolean.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean fields.
+ *
+ * <p>
+ * All the FieldAccessors are generated from <code>FieldAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Boolean extends Accessor {
+    public FieldAccessor_Boolean() {
+        super(Boolean.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_boolean;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_boolean = value==null ? Const.default_value_boolean : (Boolean)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Byte.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Byte.java
new file mode 100644
index 0000000..fa2a415
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Byte.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for byte fields.
+ *
+ * <p>
+ * All the FieldAccessors are generated from <code>FieldAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Byte extends Accessor {
+    public FieldAccessor_Byte() {
+        super(Byte.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_byte;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_byte = value==null ? Const.default_value_byte : (Byte)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Character.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Character.java
new file mode 100644
index 0000000..d3c03a8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Character.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for char fields.
+ *
+ * <p>
+ * All the FieldAccessors are generated from <code>FieldAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Character extends Accessor {
+    public FieldAccessor_Character() {
+        super(Character.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_char;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_char = value==null ? Const.default_value_char : (Character)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Double.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Double.java
new file mode 100644
index 0000000..15417f6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Double.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for double fields.
+ *
+ * <p>
+ * All the FieldAccessors are generated from <code>FieldAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Double extends Accessor {
+    public FieldAccessor_Double() {
+        super(Double.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_double;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_double = value==null ? Const.default_value_double : (Double)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Float.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Float.java
new file mode 100644
index 0000000..885dbcc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Float.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for float fields.
+ *
+ * <p>
+ * All the FieldAccessors are generated from <code>FieldAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Float extends Accessor {
+    public FieldAccessor_Float() {
+        super(Float.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_float;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_float = value==null ? Const.default_value_float : (Float)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Integer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Integer.java
new file mode 100644
index 0000000..7676ea4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Integer.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for int fields.
+ *
+ * <p>
+ * All the FieldAccessors are generated from <code>FieldAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Integer extends Accessor {
+    public FieldAccessor_Integer() {
+        super(Integer.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_int;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_int = value==null ? Const.default_value_int : (Integer)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Long.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Long.java
new file mode 100644
index 0000000..7cf0a7a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Long.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for long fields.
+ *
+ * <p>
+ * All the FieldAccessors are generated from <code>FieldAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Long extends Accessor {
+    public FieldAccessor_Long() {
+        super(Long.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_long;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_long = value==null ? Const.default_value_long : (Long)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Ref.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Ref.java
new file mode 100644
index 0000000..d1beb11
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Ref.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for reference type fields.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Ref extends Accessor {
+    public FieldAccessor_Ref() {
+        super(Ref.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_ref;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_ref = (Ref)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Short.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Short.java
new file mode 100644
index 0000000..54a9e30
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/FieldAccessor_Short.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for short fields.
+ *
+ * <p>
+ * All the FieldAccessors are generated from <code>FieldAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FieldAccessor_Short extends Accessor {
+    public FieldAccessor_Short() {
+        super(Short.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).f_short;
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).f_short = value==null ? Const.default_value_short : (Short)value;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Injector.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Injector.java
new file mode 100644
index 0000000..91cc7e9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Injector.java
@@ -0,0 +1,170 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.lang.ref.WeakReference;
+import java.security.AccessController;
+import java.security.PrivilegedAction;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.WeakHashMap;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.sun.xml.internal.bind.Util;
+
+/**
+ * A {@link ClassLoader} used to "inject" optimized accessor classes
+ * into the VM.
+ *
+ * <p>
+ * Its parent class loader needs to be set to the one that can see the user
+ * class.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class Injector {
+
+    /**
+     * {@link Injector}s keyed by their parent {@link ClassLoader}.
+     *
+     * We only need one injector per one user class loader.
+     */
+    private static final Map<ClassLoader,WeakReference<Injector>> injectors =
+        Collections.synchronizedMap(new WeakHashMap<ClassLoader,WeakReference<Injector>>());
+
+    private static final Logger logger = Util.getClassLogger();
+
+    /**
+     * Injects a new class into the given class loader.
+     *
+     * @return null
+     *      if it fails to inject.
+     */
+    static Class inject( ClassLoader cl, String className, byte[] image ) {
+        Injector injector = get(cl);
+        if(injector!=null)
+            return injector.inject(className,image);
+        else
+            return null;
+    }
+
+    /**
+     * Returns the already injected class, or null.
+     */
+    static Class find( ClassLoader cl, String className ) {
+        Injector injector = get(cl);
+        if(injector!=null)
+            return injector.find(className);
+        else
+            return null;
+    }
+
+    /**
+     * Gets or creates an {@link Injector} for the given class loader.
+     *
+     * @return null
+     *      if it fails.
+     */
+    private static Injector get(ClassLoader cl) {
+        Injector injector = null;
+        WeakReference<Injector> wr = injectors.get(cl);
+        if(wr!=null)
+            injector = wr.get();
+        if(injector==null)
+            try {
+                injectors.put(cl,new WeakReference<Injector>(injector = new Injector(cl)));
+            } catch (SecurityException e) {
+                logger.log(Level.FINE,"Unable to set up a back-door for the injector",e);
+                return null;
+            }
+        return injector;
+    }
+
+    /**
+     * Injected classes keyed by their names.
+     */
+    private final Map<String,Class> classes = new HashMap<String,Class>();
+
+    private final ClassLoader parent;
+
+    private static final Method defineClass;
+    private static final Method resolveClass;
+
+    static {
+        try {
+            defineClass = ClassLoader.class.getDeclaredMethod("defineClass",String.class,byte[].class,Integer.TYPE,Integer.TYPE);
+            resolveClass = ClassLoader.class.getDeclaredMethod("resolveClass",Class.class);
+        } catch (NoSuchMethodException e) {
+            // impossible
+            throw new NoSuchMethodError(e.getMessage());
+        }
+        AccessController.doPrivileged(new PrivilegedAction<Void>() {
+            public Void run() {
+                // TODO: check security implication
+                // do these setAccessible allow anyone to call these methods freely?s
+                defineClass.setAccessible(true);
+                resolveClass.setAccessible(true);
+                return null;
+            }
+        });
+    }
+
+    private Injector(ClassLoader parent) {
+        this.parent = parent;
+        assert parent!=null;
+    }
+
+
+    private synchronized Class inject(String className, byte[] image) {
+        Class c = classes.get(className);
+        if(c==null) {
+            // we need to inject a class into the
+            try {
+                c = (Class)defineClass.invoke(parent,className.replace('/','.'),image,0,image.length);
+                resolveClass.invoke(parent,c);
+            } catch (IllegalAccessException e) {
+                logger.log(Level.FINE,"Unable to inject "+className,e);
+                return null;
+            } catch (InvocationTargetException e) {
+                logger.log(Level.FINE,"Unable to inject "+className,e);
+                return null;
+            } catch (SecurityException e) {
+                logger.log(Level.FINE,"Unable to inject "+className,e);
+                return null;
+            }
+            classes.put(className,c);
+        }
+        return c;
+    }
+
+    private synchronized Class find(String className) {
+        return classes.get(className);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Boolean.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Boolean.java
new file mode 100644
index 0000000..3de8d7a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Boolean.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean getter/setter.
+ *
+ * <p>
+ * All the MethodAccessors are generated from <code>MethodAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Boolean extends Accessor {
+    public MethodAccessor_Boolean() {
+        super(Boolean.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_boolean();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_boolean( value==null ? Const.default_value_boolean : (Boolean)value );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Byte.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Byte.java
new file mode 100644
index 0000000..4ad0028
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Byte.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean getter/setter.
+ *
+ * <p>
+ * All the MethodAccessors are generated from <code>MethodAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Byte extends Accessor {
+    public MethodAccessor_Byte() {
+        super(Byte.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_byte();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_byte( value==null ? Const.default_value_byte : (Byte)value );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Character.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Character.java
new file mode 100644
index 0000000..fe1acf5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Character.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean getter/setter.
+ *
+ * <p>
+ * All the MethodAccessors are generated from <code>MethodAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Character extends Accessor {
+    public MethodAccessor_Character() {
+        super(Character.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_char();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_char( value==null ? Const.default_value_char : (Character)value );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Double.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Double.java
new file mode 100644
index 0000000..3783ab9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Double.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean getter/setter.
+ *
+ * <p>
+ * All the MethodAccessors are generated from <code>MethodAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Double extends Accessor {
+    public MethodAccessor_Double() {
+        super(Double.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_double();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_double( value==null ? Const.default_value_double : (Double)value );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Float.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Float.java
new file mode 100644
index 0000000..1050933
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Float.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean getter/setter.
+ *
+ * <p>
+ * All the MethodAccessors are generated from <code>MethodAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Float extends Accessor {
+    public MethodAccessor_Float() {
+        super(Float.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_float();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_float( value==null ? Const.default_value_float : (Float)value );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Integer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Integer.java
new file mode 100644
index 0000000..f2178db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Integer.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean getter/setter.
+ *
+ * <p>
+ * All the MethodAccessors are generated from <code>MethodAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Integer extends Accessor {
+    public MethodAccessor_Integer() {
+        super(Integer.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_int();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_int( value==null ? Const.default_value_int : (Integer)value );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Long.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Long.java
new file mode 100644
index 0000000..6342218
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Long.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean getter/setter.
+ *
+ * <p>
+ * All the MethodAccessors are generated from <code>MethodAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Long extends Accessor {
+    public MethodAccessor_Long() {
+        super(Long.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_long();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_long( value==null ? Const.default_value_long : (Long)value );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Ref.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Ref.java
new file mode 100644
index 0000000..8135d7c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Ref.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for reference types getter/setter.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Ref extends Accessor {
+    public MethodAccessor_Ref() {
+        super(Ref.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_ref();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_ref((Ref)value);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Short.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Short.java
new file mode 100644
index 0000000..4e7d720
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/MethodAccessor_Short.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+/**
+ * Template {@link Accessor} for boolean getter/setter.
+ *
+ * <p>
+ * All the MethodAccessors are generated from <code>MethodAccessor_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class MethodAccessor_Short extends Accessor {
+    public MethodAccessor_Short() {
+        super(Short.class);
+    }
+
+    public Object get(Object bean) {
+        return ((Bean)bean).get_short();
+    }
+
+    public void set(Object bean, Object value) {
+        ((Bean)bean).set_short( value==null ? Const.default_value_short : (Short)value );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/OptimizedAccessorFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/OptimizedAccessorFactory.java
new file mode 100644
index 0000000..2dd7438
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/OptimizedAccessorFactory.java
@@ -0,0 +1,186 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.lang.reflect.Modifier;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.sun.xml.internal.bind.Util;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+import static com.sun.xml.internal.bind.v2.bytecode.ClassTailor.toVMClassName;
+import static com.sun.xml.internal.bind.v2.bytecode.ClassTailor.toVMTypeName;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class OptimizedAccessorFactory {
+    private OptimizedAccessorFactory() {} // no instanciation please
+
+    private static final Logger logger = Util.getClassLogger();
+
+
+    private static final String fieldTemplateName;
+    private static final String methodTemplateName;
+
+    static {
+        String s = FieldAccessor_Byte.class.getName();
+        fieldTemplateName = s.substring(0,s.length()-"Byte".length()).replace('.','/');
+
+        s = MethodAccessor_Byte.class.getName();
+        methodTemplateName = s.substring(0,s.length()-"Byte".length()).replace('.','/');
+    }
+
+    /**
+     * Gets the optimized {@link Accessor} that accesses the given getter/setter.
+     *
+     * @return null
+     *      if for some reason it fails to create an optimized version.
+     */
+    public static final <B,V> Accessor<B,V> get(Method getter, Method setter) {
+        // make sure the method signatures are what we expect
+        if(getter.getParameterTypes().length!=0)
+            return null;
+        Class<?>[] sparams = setter.getParameterTypes();
+        if(sparams.length!=1)
+            return null;
+        if(sparams[0]!=getter.getReturnType())
+            return null;
+        if(setter.getReturnType()!=Void.TYPE)
+            return null;
+        if(getter.getDeclaringClass()!=setter.getDeclaringClass())
+            return null;
+        if(Modifier.isPrivate(getter.getModifiers()) || Modifier.isPrivate(setter.getModifiers()))
+            // we can't access private fields
+            return null;
+
+
+        Class t = sparams[0];
+        String typeName = t.getName().replace('.','_');
+
+        String newClassName = toVMClassName(getter.getDeclaringClass())+"$JaxbAccessorM_"+getter.getName()+'_'+setter.getName()+'_'+typeName;
+
+        Class opt;
+
+        if(t.isPrimitive())
+            opt = AccessorInjector.prepare( getter.getDeclaringClass(),
+                methodTemplateName+t.getName(),
+                newClassName,
+                toVMClassName(Bean.class),
+                toVMClassName(getter.getDeclaringClass()),
+                "get_"+t.getName(),
+                getter.getName(),
+                "set_"+t.getName(),
+                setter.getName());
+        else
+            opt = AccessorInjector.prepare( getter.getDeclaringClass(),
+                methodTemplateName+"Ref",
+                newClassName,
+                toVMClassName(Bean.class),
+                toVMClassName(getter.getDeclaringClass()),
+                toVMClassName(Ref.class),
+                toVMClassName(t),
+                "()"+toVMTypeName(Ref.class),
+                "()"+toVMTypeName(t),
+                '('+toVMTypeName(Ref.class)+")V",
+                '('+toVMTypeName(t)+")V",
+                "get_ref",
+                getter.getName(),
+                "set_ref",
+                setter.getName());
+
+        if(opt==null)
+            return null;
+
+        Accessor<B,V> acc = instanciate(opt);
+        if(acc!=null)
+            logger.log(Level.FINE,"Using optimized Accessor for "+getter+" and "+setter);
+        return acc;
+    }
+
+
+    /**
+     * Gets the optimizd {@link Accessor} that accesses the given field.
+     *
+     * @return null
+     *      if for some reason it fails to create an optimized version.
+     */
+    public static final <B,V> Accessor<B,V> get(Field field) {
+        int mods = field.getModifiers();
+        if(Modifier.isPrivate(mods) || Modifier.isFinal(mods))
+            // we can't access private fields
+            return null;
+
+        String newClassName = toVMClassName(field.getDeclaringClass())+"$JaxbAccessorF_"+field.getName();
+
+        Class opt;
+
+        if(field.getType().isPrimitive())
+            opt = AccessorInjector.prepare( field.getDeclaringClass(),
+                fieldTemplateName+field.getType().getName(),
+                newClassName,
+                toVMClassName(Bean.class),
+                toVMClassName(field.getDeclaringClass()),
+                "f_"+field.getType().getName(),
+                field.getName() );
+        else
+            opt = AccessorInjector.prepare( field.getDeclaringClass(),
+                fieldTemplateName+"Ref",
+                newClassName,
+                toVMClassName(Bean.class),
+                toVMClassName(field.getDeclaringClass()),
+                toVMClassName(Ref.class),
+                toVMClassName(field.getType()),
+                toVMTypeName(Ref.class),
+                toVMTypeName(field.getType()),
+                "f_ref",
+                field.getName() );
+
+        if(opt==null)
+            return null;
+
+        Accessor<B,V> acc = instanciate(opt);
+        if(acc!=null)
+            logger.log(Level.FINE,"Using optimized Accessor for "+field);
+        return acc;
+    }
+
+    private static <B,V> Accessor<B,V> instanciate(Class opt) {
+        try {
+            return (Accessor<B,V>)opt.newInstance();
+        } catch (InstantiationException e) {
+            logger.log(Level.INFO,"failed to load an optimized Accessor",e);
+        } catch (IllegalAccessException e) {
+            logger.log(Level.INFO,"failed to load an optimized Accessor",e);
+        } catch (SecurityException e) {
+            logger.log(Level.INFO,"failed to load an optimized Accessor",e);
+        }
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/OptimizedTransducedAccessorFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/OptimizedTransducedAccessorFactory.java
new file mode 100644
index 0000000..cfe28e5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/OptimizedTransducedAccessorFactory.java
@@ -0,0 +1,167 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import java.lang.reflect.Field;
+import java.lang.reflect.Modifier;
+import java.lang.reflect.Type;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.sun.xml.internal.bind.Util;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimeClassInfo;
+import com.sun.xml.internal.bind.v2.model.runtime.RuntimePropertyInfo;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+
+import static com.sun.xml.internal.bind.v2.bytecode.ClassTailor.toVMClassName;
+
+/**
+ * Prepares optimized {@link TransducedAccessor} from templates.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class OptimizedTransducedAccessorFactory {
+    private OptimizedTransducedAccessorFactory() {} // no instanciation please
+
+    // http://java.sun.com/docs/books/vmspec/2nd-edition/html/ConstantPool.doc.html#75929
+    // "same runtime package"
+
+    private static final Logger logger = Util.getClassLogger();
+
+    private static final String fieldTemplateName;
+    private static final String methodTemplateName;
+
+    static {
+        String s = TransducedAccessor_field_Byte.class.getName();
+        fieldTemplateName = s.substring(0,s.length()-"Byte".length()).replace('.','/');
+
+        s = TransducedAccessor_method_Byte.class.getName();
+        methodTemplateName = s.substring(0,s.length()-"Byte".length()).replace('.','/');
+    }
+
+    /**
+     * Gets the optimizd {@link TransducedAccessor} if possible.
+     *
+     * @return null
+     *      if for some reason it fails to create an optimized version.
+     */
+    public static final TransducedAccessor get(RuntimePropertyInfo prop) {
+        Accessor acc = prop.getAccessor();
+
+        // consider using an optimized TransducedAccessor implementations.
+        Class opt=null;
+
+        TypeInfo<Type,Class> parent = prop.parent();
+        if(!(parent instanceof RuntimeClassInfo))
+            return null;
+
+        Class dc = ((RuntimeClassInfo)parent).getClazz();
+        String newClassName = toVMClassName(dc)+"_JaxbXducedAccessor_"+prop.getName();
+
+
+        if(acc instanceof Accessor.FieldReflection) {
+            // TODO: we also need to make sure that the default xducer is used.
+            Accessor.FieldReflection racc = (Accessor.FieldReflection) acc;
+            Field field = racc.f;
+
+            int mods = field.getModifiers();
+            if(Modifier.isPrivate(mods) || Modifier.isFinal(mods))
+                // we can't access private fields.
+                // TODO: think about how to improve this case
+                return null;
+
+            Class<?> t = field.getType();
+            if(t.isPrimitive())
+                opt = AccessorInjector.prepare( dc,
+                    fieldTemplateName+suffixMap.get(t),
+                    newClassName,
+                    toVMClassName(Bean.class),
+                    toVMClassName(dc),
+                    "f_"+t.getName(),
+                    field.getName() );
+        }
+
+        if(acc.getClass()==Accessor.GetterSetterReflection.class) {
+            Accessor.GetterSetterReflection gacc = (Accessor.GetterSetterReflection) acc;
+
+            if(gacc.getter==null || gacc.setter==null)
+                return null;    // incomplete
+
+            Class<?> t = gacc.getter.getReturnType();
+
+            if(Modifier.isPrivate(gacc.getter.getModifiers())
+            || Modifier.isPrivate(gacc.setter.getModifiers()))
+                // we can't access private methods.
+                return null;
+
+
+            if(t.isPrimitive())
+                opt = AccessorInjector.prepare( dc,
+                    methodTemplateName+suffixMap.get(t),
+                    newClassName,
+                    toVMClassName(Bean.class),
+                    toVMClassName(dc),
+                    "get_"+t.getName(),
+                    gacc.getter.getName(),
+                    "set_"+t.getName(),
+                    gacc.setter.getName());
+        }
+
+        if(opt==null)
+            return null;
+
+        logger.log(Level.FINE,"Using optimized TransducedAccessor for "+prop.displayName());
+
+
+        try {
+            return (TransducedAccessor)opt.newInstance();
+        } catch (InstantiationException e) {
+            logger.log(Level.INFO,"failed to load an optimized TransducedAccessor",e);
+        } catch (IllegalAccessException e) {
+            logger.log(Level.INFO,"failed to load an optimized TransducedAccessor",e);
+        } catch (SecurityException e) {
+            logger.log(Level.INFO,"failed to load an optimized TransducedAccessor",e);
+        }
+        return null;
+    }
+
+    private static final Map<Class,String> suffixMap = new HashMap<Class, String>();
+
+    static {
+        suffixMap.put(Byte.TYPE,"Byte");
+        suffixMap.put(Short.TYPE,"Short");
+        suffixMap.put(Integer.TYPE,"Integer");
+        suffixMap.put(Long.TYPE,"Long");
+        suffixMap.put(Boolean.TYPE,"Boolean");
+        suffixMap.put(Float.TYPE,"Float");
+        suffixMap.put(Double.TYPE,"Double");
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Ref.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Ref.java
new file mode 100644
index 0000000..0797785
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/Ref.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+
+/**
+ * Used by {@link TransducedAccessor} templates.
+ *
+ * @author Kohsuke Kawaguchi
+ * @see Bean
+ */
+final class Ref {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Boolean.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Boolean.java
new file mode 100644
index 0000000..c328dc9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Boolean.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a boolean field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_field_Boolean extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printBoolean( ((Bean)o).f_boolean );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).f_boolean=DatatypeConverterImpl._parseBoolean(lexical);
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Byte.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Byte.java
new file mode 100644
index 0000000..f5b8ad0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Byte.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a byte field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_field_Byte extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printByte( ((Bean)o).f_byte );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).f_byte=DatatypeConverterImpl._parseByte(lexical);
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Double.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Double.java
new file mode 100644
index 0000000..ed4eabf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Double.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a double field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_field_Double extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printDouble( ((Bean)o).f_double );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).f_double=DatatypeConverterImpl._parseDouble(lexical);
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Float.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Float.java
new file mode 100644
index 0000000..5a71a37
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Float.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a float field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_field_Float extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printFloat( ((Bean)o).f_float );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).f_float=DatatypeConverterImpl._parseFloat(lexical);
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Integer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Integer.java
new file mode 100644
index 0000000..a9c3036
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Integer.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Template {@link TransducedAccessor} for a byte field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_field_Integer extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printInt( ((Bean)o).f_int );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).f_int=DatatypeConverterImpl._parseInt(lexical);
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+
+    @Override
+    public void writeLeafElement(XMLSerializer w, Name tagName, Object o, String fieldName) throws SAXException, AccessorException, IOException, XMLStreamException {
+        w.leafElement(tagName, ((Bean)o).f_int, fieldName );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Long.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Long.java
new file mode 100644
index 0000000..f12e9b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Long.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a long field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_field_Long extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printLong( ((Bean)o).f_long );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).f_long=DatatypeConverterImpl._parseLong(lexical);
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Short.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Short.java
new file mode 100644
index 0000000..0ec9cd0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_field_Short.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a short field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_field_Short extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printShort( ((Bean)o).f_short );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).f_short=DatatypeConverterImpl._parseShort(lexical);
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Boolean.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Boolean.java
new file mode 100644
index 0000000..202c70e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Boolean.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a boolean field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_method_Boolean extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printBoolean( ((Bean)o).get_boolean() );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).set_boolean(DatatypeConverterImpl._parseBoolean(lexical));
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+//
+//    public void writeLeafElement(Object o, QName tagName, String fieldName, XMLSerializer w) throws SAXException, AccessorException {
+//        w.leafElement(tagName, ((Bean)o).get_boolean(), fieldName );
+//    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Byte.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Byte.java
new file mode 100644
index 0000000..73b6ac1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Byte.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a byte field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_method_Byte extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printByte( ((Bean)o).get_byte() );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).set_byte(DatatypeConverterImpl._parseByte(lexical));
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+//
+//    public void writeLeafElement(Object o, QName tagName, String fieldName, XMLSerializer w) throws SAXException, AccessorException {
+//        w.leafElement(tagName, ((Bean)o).get_byte(), fieldName );
+//    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Double.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Double.java
new file mode 100644
index 0000000..24334df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Double.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a double field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_method_Double extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printDouble( ((Bean)o).get_double() );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).set_double(DatatypeConverterImpl._parseDouble(lexical));
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+//
+//    public void writeLeafElement(Object o, QName tagName, String fieldName, XMLSerializer w) throws SAXException, AccessorException {
+//        w.leafElement(tagName, ((Bean)o).get_double(), fieldName );
+//    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Float.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Float.java
new file mode 100644
index 0000000..7aa7e0b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Float.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a float field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_method_Float extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printFloat( ((Bean)o).get_float() );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).set_float(DatatypeConverterImpl._parseFloat(lexical));
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+//
+//    public void writeLeafElement(Object o, QName tagName, String fieldName, XMLSerializer w) throws SAXException, AccessorException {
+//        w.leafElement(tagName, ((Bean)o).get_float(), fieldName );
+//    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Integer.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Integer.java
new file mode 100644
index 0000000..4f32c07
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Integer.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import java.io.IOException;
+
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.Name;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Template {@link TransducedAccessor} for a byte field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_method_Integer extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printInt( ((Bean)o).get_int() );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).set_int(DatatypeConverterImpl._parseInt(lexical));
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+
+    @Override
+    public void writeLeafElement(XMLSerializer w, Name tagName, Object o, String fieldName) throws SAXException, AccessorException, IOException, XMLStreamException {
+        w.leafElement(tagName, ((Bean)o).get_int(), fieldName );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Long.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Long.java
new file mode 100644
index 0000000..8bd50bb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Long.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a long field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_method_Long extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printLong( ((Bean)o).get_long() );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).set_long(DatatypeConverterImpl._parseLong(lexical));
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+//
+//    public void writeLeafElement(Object o, QName tagName, String fieldName, XMLSerializer w) throws SAXException, AccessorException {
+//        w.leafElement(tagName, ((Bean)o).get_long(), fieldName );
+//    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Short.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Short.java
new file mode 100644
index 0000000..f6c60a2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/TransducedAccessor_method_Short.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.reflect.opt;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.DefaultTransducedAccessor;
+
+/**
+ * Template {@link TransducedAccessor} for a short field.
+ *
+ * <p>
+ * All the TransducedAccessor_field are generated from <code>TransducedAccessor_field_B y t e</code>
+ *
+ * @author Kohsuke Kawaguchi
+ *
+ * @see TransducedAccessor#get
+ */
+public final class TransducedAccessor_method_Short extends DefaultTransducedAccessor {
+    public String print(Object o) {
+        return DatatypeConverterImpl._printShort( ((Bean)o).get_short() );
+    }
+
+    public void parse(Object o, CharSequence lexical) {
+        ((Bean)o).set_short(DatatypeConverterImpl._parseShort(lexical));
+    }
+
+    public boolean hasValue(Object o) {
+        return true;
+    }
+//
+//    public void writeLeafElement(Object o, QName tagName, String fieldName, XMLSerializer w) throws SAXException, AccessorException {
+//        w.leafElement(tagName, ((Bean)o).get_short(), fieldName );
+//    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/package.html b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/package.html
new file mode 100644
index 0000000..f571755
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/opt/package.html
@@ -0,0 +1,12 @@
+<html><body>
+Hosts optimized
+{@link com.sun.xml.internal.bind.v2.runtime.reflect.Accessor},
+{@link com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor}, and
+{@link com.sun.xml.internal.bind.v2.runtime.Transducer}.
+
+<h2>How it works</h2>
+<p>
+  Most of the classes in this package are "templates." At run-time,
+  A template class file is slightly modified to match the target Java Bean,
+  then it will be loaded into the VM.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/package.html b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/package.html
new file mode 100644
index 0000000..988a3f2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/reflect/package.html
@@ -0,0 +1,3 @@
+<html><body>
+  Abstraction around accessing data of actual objects.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/AttributesEx.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/AttributesEx.java
new file mode 100644
index 0000000..048a934
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/AttributesEx.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import org.xml.sax.Attributes;
+
+/**
+ * {@link Attributes} extension that allows attribute values
+ * to be exposed as {@link CharSequence}.
+ *
+ * <p>
+ * All namespace URIs and local names are assumed to be interned.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface AttributesEx extends Attributes {
+    /**
+     * The same as {@link #getValue(int)}
+     */
+    CharSequence getData(int idx);
+
+    /**
+     * The same as {@link #getValue(String,String)}
+     */
+    CharSequence getData(String nsUri,String localName);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/AttributesExImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/AttributesExImpl.java
new file mode 100644
index 0000000..335a0cb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/AttributesExImpl.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import com.sun.xml.internal.bind.util.AttributesImpl;
+
+/**
+ * {@link AttributesEx} implementation.
+ *
+ * TODO: proper implementation that holds CharSequence
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class AttributesExImpl extends AttributesImpl implements AttributesEx {
+    public CharSequence getData(int idx) {
+        return getValue(idx);
+    }
+
+    public CharSequence getData(String nsUri, String localName) {
+        return getValue(nsUri,localName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Base64Data.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Base64Data.java
new file mode 100644
index 0000000..08445bc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Base64Data.java
@@ -0,0 +1,290 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+
+import javax.activation.DataHandler;
+import javax.activation.DataSource;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.runtime.XMLSerializer;
+import com.sun.xml.internal.bind.v2.runtime.output.Pcdata;
+import com.sun.xml.internal.bind.v2.runtime.output.UTF8XmlOutput;
+import com.sun.xml.internal.bind.v2.util.ByteArrayOutputStreamEx;
+import com.sun.istack.internal.Nullable;
+
+/**
+ * Fed to unmarshaller when the 'text' data is actually
+ * a virtual image of base64 encoding of the binary data
+ * transferred on the wire.
+ *
+ * Used for the MTOM support.
+ *
+ * This object is mutable and the owner of this object can
+ * reuse it with new data.
+ *
+ * Also used by the marshaller to write out the binary data
+ * that could be possibly attached.
+ *
+ * @see XmlVisitor#text(CharSequence)
+ * @see XMLSerializer#text(Pcdata,String)
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Base64Data extends Pcdata {
+
+    // either dataHandler or (data,dataLen,mimeType?) must be present
+
+    private DataHandler dataHandler;
+
+    private byte[] data;
+    /**
+     * Length of the valid data in {@link #data}.
+     */
+    private int dataLen;
+    /**
+     * Optional MIME type of {@link #data}.
+     *
+     * Unused when {@link #dataHandler} is set.
+     * Use {@link DataHandler#getContentType()} in that case.
+     */
+    private @Nullable String mimeType;
+
+    /**
+     * Fills in the data object by a portion of the byte[].
+     *
+     * @param len
+     *      data[0] to data[len-1] are treated as the data.
+     */
+    public void set(byte[] data, int len, @Nullable String mimeType) {
+        this.data = data;
+        this.dataLen = len;
+        this.dataHandler = null;
+        this.mimeType = mimeType;
+    }
+
+    /**
+     * Fills in the data object by the byte[] of the exact length.
+     *
+     * @param data
+     *      this buffer may be owned directly by the unmarshaleld JAXB object.
+     */
+    public void set(byte[] data,@Nullable String mimeType) {
+        set(data,data.length,mimeType);
+    }
+
+    /**
+     * Fills in the data object by a {@link DataHandler}.
+     */
+    public void set(DataHandler data) {
+        assert data!=null;
+        this.dataHandler = data;
+        this.data = null;
+    }
+
+    /**
+     * Gets the raw data.
+     */
+    public DataHandler getDataHandler() {
+        if(dataHandler==null) {
+            dataHandler = new DataHandler(new DataSource() {
+                public String getContentType() {
+                    return getMimeType();
+                }
+
+                public InputStream getInputStream() {
+                    return new ByteArrayInputStream(data,0,dataLen);
+                }
+
+                public String getName() {
+                    return null;
+                }
+
+                public OutputStream getOutputStream() {
+                    throw new UnsupportedOperationException();
+                }
+            });
+        }
+
+        return dataHandler;
+    }
+
+    /**
+     * Gets the byte[] of the exact length.
+     */
+    public byte[] getExact() {
+        get();
+        if(dataLen!=data.length) {
+            byte[] buf = new byte[dataLen];
+            System.arraycopy(data,0,buf,0,dataLen);
+            data = buf;
+        }
+        return data;
+    }
+
+    /**
+     * Gets the data as an {@link InputStream}.
+     */
+    public InputStream getInputStream() throws IOException {
+        if(dataHandler!=null)
+            return dataHandler.getInputStream();
+        else
+            return new ByteArrayInputStream(data,0,dataLen);
+    }
+
+    /**
+     * Returns false if this object only has {@link DataHandler} and therefore
+     * {@link #get()} operation is likely going to be expensive.
+     */
+    public boolean hasData() {
+        return data!=null;
+    }
+
+    /**
+     * Gets the raw data. The size of the byte array maybe larger than the actual length.
+     */
+    public byte[] get() {
+        if(data==null) {
+            try {
+                ByteArrayOutputStreamEx baos = new ByteArrayOutputStreamEx(1024);
+                InputStream is = dataHandler.getDataSource().getInputStream();
+                baos.readFrom(is);
+                is.close();
+                data = baos.getBuffer();
+                dataLen = baos.size();
+            } catch (IOException e) {
+                // TODO: report the error to the unmarshaller
+                dataLen = 0;    // recover by assuming length-0 data
+            }
+        }
+        return data;
+    }
+
+    public int getDataLen() {
+        return dataLen;
+    }
+
+    public String getMimeType() {
+        if(mimeType==null)
+            return "application/octet-stream";
+        return mimeType;
+    }
+
+    /**
+     * Gets the number of characters needed to represent
+     * this binary data in the base64 encoding.
+     */
+    public int length() {
+        // for each 3 bytes you use 4 chars
+        // if the remainder is 1 or 2 there will be 4 more
+        get();  // fill in the buffer if necessary
+        return ((dataLen+2)/3)*4;
+    }
+
+    /**
+     * Encode this binary data in the base64 encoding
+     * and returns the character at the specified position.
+     */
+    public char charAt(int index) {
+        // we assume that the length() method is called before this method
+        // (otherwise how would the caller know that the index is valid?)
+        // so we assume that the byte[] is already populated
+
+        int offset = index%4;
+        int base = (index/4)*3;
+
+        byte b1,b2;
+
+        switch(offset) {
+        case 0:
+            return DatatypeConverterImpl.encode(data[base]>>2);
+        case 1:
+            if(base+1<dataLen)
+                b1 = data[base+1];
+            else
+                b1 = 0;
+            return DatatypeConverterImpl.encode(
+                        ((data[base]&0x3)<<4) |
+                        ((b1>>4)&0xF));
+        case 2:
+            if(base+1<dataLen) {
+                b1 = data[base+1];
+                if(base+2<dataLen)
+                    b2 = data[base+2];
+                else
+                    b2 = 0;
+
+                return DatatypeConverterImpl.encode(
+                            ((b1&0xF)<<2)|
+                            ((b2>>6)&0x3));
+            } else
+                return '=';
+        case 3:
+            if(base+2<dataLen)
+                return DatatypeConverterImpl.encode(data[base+2]&0x3F);
+            else
+                return '=';
+        }
+
+        throw new IllegalStateException();
+    }
+
+    /**
+     * Internally this is only used to split a text to a list,
+     * which doesn't happen that much for base64.
+     * So this method should be smaller than faster.
+     */
+    public CharSequence subSequence(int start, int end) {
+        StringBuilder buf = new StringBuilder();
+        get();  // fill in the buffer if we haven't done so
+        for( int i=start; i<end; i++ )
+            buf.append(charAt(i));
+        return buf;
+    }
+
+    /**
+     * Returns the base64 encoded string of this data.
+     */
+    public String toString() {
+        get();  // fill in the buffer
+        return DatatypeConverterImpl._printBase64Binary(data, 0, dataLen);
+    }
+
+    public void writeTo(char[] buf, int start) {
+        get();
+        DatatypeConverterImpl._printBase64Binary(data, 0, dataLen, buf, start);
+    }
+
+    public void writeTo(UTF8XmlOutput output) throws IOException {
+        // TODO: this is inefficient if the data source is note byte[] but DataHandler
+        get();
+        output.text(data,dataLen);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ChildLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ChildLoader.java
new file mode 100644
index 0000000..36223df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ChildLoader.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+/**
+ * Pair of {@link Loader} and {@link Receiver}.
+ *
+ * Used by {@link StructureLoader}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ChildLoader {
+    public final Loader loader;
+    public final Receiver receiver;
+
+    public ChildLoader(Loader loader, Receiver receiver) {
+        assert loader!=null;
+        this.loader = loader;
+        this.receiver = receiver;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DefaultIDResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DefaultIDResolver.java
new file mode 100644
index 0000000..1d52edd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DefaultIDResolver.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.util.HashMap;
+import java.util.concurrent.Callable;
+
+import com.sun.xml.internal.bind.IDResolver;
+
+/**
+ * Default implementation of {@link IDResolver}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class DefaultIDResolver extends IDResolver {
+    /** Records ID->Object map. */
+    private HashMap<String,Object> idmap = null;
+
+    public void startDocument() {
+        if(idmap!=null)
+            idmap.clear();
+    }
+
+    public void bind(String id, Object obj) {
+        if(idmap==null)     idmap = new HashMap<String,Object>();
+        idmap.put(id,obj);
+    }
+
+    public Callable resolve(final String id, Class targetType) {
+        return new Callable() {
+            public Object call() throws Exception {
+                if(idmap==null)     return null;
+                return idmap.get(id);
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DefaultValueLoaderDecorator.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DefaultValueLoaderDecorator.java
new file mode 100644
index 0000000..0febfe9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DefaultValueLoaderDecorator.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Decorates another {@link Loader} by setting a default value.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class DefaultValueLoaderDecorator extends Loader {
+    private final Loader l;
+    private final String defaultValue;
+
+    public DefaultValueLoaderDecorator(Loader l, String defaultValue) {
+        this.l = l;
+        this.defaultValue = defaultValue;
+    }
+
+    @Override
+    public void startElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        // install the default value, but don't override the one given by the parent loader
+        if(state.elementDefaultValue==null)
+            state.elementDefaultValue = defaultValue;
+
+        state.loader = l;
+        l.startElement(state,ea);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Discarder.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Discarder.java
new file mode 100644
index 0000000..d235699
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Discarder.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+
+
+/**
+ * {@link Loader} implementation that discards the whole sub-tree.
+ *
+ * Mostly used for recovering fom errors.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class Discarder extends Loader {
+    public static final Loader INSTANCE = new Discarder();
+
+    private Discarder() {
+        super(false);
+    }
+
+    @Override
+    public void childElement(UnmarshallingContext.State state, TagName ea) {
+        state.target = null;
+        // registering this allows the discarder to process the whole subtree.
+        state.loader = this;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DomLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DomLoader.java
new file mode 100644
index 0000000..841c7bf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/DomLoader.java
@@ -0,0 +1,161 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.bind.annotation.DomHandler;
+import javax.xml.transform.Result;
+import javax.xml.transform.sax.TransformerHandler;
+
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Loads a DOM.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class DomLoader<ResultT extends Result> extends Loader {
+
+    private final DomHandler<?,ResultT> dom;
+
+    /**
+     * Used to capture the state.
+     *
+     * This instance is created for each unmarshalling episode.
+     */
+    private final class State {
+        /** This handler will receive SAX events. */
+        private final TransformerHandler handler = JAXBContextImpl.createTransformerHandler();
+
+        /** {@link #handler} will produce this result. */
+        private final ResultT result;
+
+        // nest level of elements.
+        int depth = 1;
+
+        public State( UnmarshallingContext context ) throws SAXException {
+            result = dom.createUnmarshaller(context);
+
+            handler.setResult(result);
+
+            // emulate the start of documents
+            try {
+                handler.setDocumentLocator(context.getLocator());
+                handler.startDocument();
+                declarePrefixes( context, context.getAllDeclaredPrefixes() );
+            } catch( SAXException e ) {
+                context.handleError(e);
+                throw e;
+            }
+        }
+
+        public Object getElement() {
+            return dom.getElement(result);
+        }
+
+        private void declarePrefixes( UnmarshallingContext context, String[] prefixes ) throws SAXException {
+            for( int i=prefixes.length-1; i>=0; i-- ) {
+                String nsUri = context.getNamespaceURI(prefixes[i]);
+                if(nsUri==null)     throw new IllegalStateException("prefix \'"+prefixes[i]+"\' isn't bound");
+                handler.startPrefixMapping(prefixes[i],nsUri );
+            }
+        }
+
+        private void undeclarePrefixes( String[] prefixes ) throws SAXException {
+            for( int i=prefixes.length-1; i>=0; i-- )
+                handler.endPrefixMapping( prefixes[i] );
+        }
+    }
+
+    public DomLoader(DomHandler<?, ResultT> dom) {
+        super(true);
+        this.dom = dom;
+    }
+
+    public void startElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        UnmarshallingContext context = state.getContext();
+        if (state.target == null)
+            state.target = new State(context);
+
+        State s = (State) state.target;
+        try {
+            s.declarePrefixes(context, context.getNewlyDeclaredPrefixes());
+            s.handler.startElement(ea.uri, ea.local, ea.getQname(), ea.atts);
+        } catch (SAXException e) {
+            context.handleError(e);
+            throw e;
+        }
+    }
+
+
+    public void childElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        state.loader = this;
+        State s = (State) state.prev.target;
+        s.depth++;
+        state.target = s;
+    }
+
+    public void text(UnmarshallingContext.State state, CharSequence text) throws SAXException {
+        if(text.length()==0)
+            return;     // there's no point in creating an empty Text node in DOM.
+        try {
+            State s = (State) state.target;
+            s.handler.characters(text.toString().toCharArray(),0,text.length());
+        } catch( SAXException e ) {
+            state.getContext().handleError(e);
+            throw e;
+        }
+    }
+
+    public void leaveElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        State s = (State) state.target;
+        UnmarshallingContext context = state.getContext();
+
+        try {
+            s.handler.endElement(ea.uri, ea.local, ea.getQname());
+            s.undeclarePrefixes(context.getNewlyDeclaredPrefixes());
+        } catch( SAXException e ) {
+            context.handleError(e);
+            throw e;
+        }
+
+        if((--s.depth)==0) {
+            // emulate the end of the document
+            try {
+                s.undeclarePrefixes(context.getAllDeclaredPrefixes());
+                s.handler.endDocument();
+            } catch( SAXException e ) {
+                context.handleError(e);
+                throw e;
+            }
+
+            // we are done
+            state.target = s.getElement();
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/FastInfosetConnector.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/FastInfosetConnector.java
new file mode 100644
index 0000000..f2cc63a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/FastInfosetConnector.java
@@ -0,0 +1,204 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.stream.Location;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+import com.sun.xml.internal.fastinfoset.stax.StAXDocumentParser;
+
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import org.xml.sax.SAXException;
+
+/**
+ * Reads from FastInfoset StAX parser and feeds into JAXB Unmarshaller.
+ *
+ * @author Paul Sandoz.
+ */
+final class FastInfosetConnector extends StAXConnector {
+
+    // event source
+    private final StAXDocumentParser fastInfosetStreamReader;
+
+    // Flag set to true if there is octets instead of characters
+    boolean hasBase64Data = false;
+    // Flag set to true if the first chunk of CIIs
+    boolean firstCIIChunk = true;
+
+    // Buffer for octets
+    private Base64Data base64Data = new Base64Data();
+
+    // Buffer for characters
+    private StringBuilder buffer = new StringBuilder();
+
+    public FastInfosetConnector(StAXDocumentParser fastInfosetStreamReader,
+            XmlVisitor visitor) {
+        super(visitor);
+        fastInfosetStreamReader.setStringInterning(true);
+        this.fastInfosetStreamReader = fastInfosetStreamReader;
+    }
+
+    public void bridge() throws XMLStreamException {
+        try {
+            // remembers the nest level of elements to know when we are done.
+            int depth=0;
+
+            // if the parser is at the start tag, proceed to the first element
+            int event = fastInfosetStreamReader.getEventType();
+            if(event == XMLStreamConstants.START_DOCUMENT) {
+                // nextTag doesn't correctly handle DTDs
+                while( !fastInfosetStreamReader.isStartElement() )
+                    event = fastInfosetStreamReader.next();
+            }
+
+
+            if( event!=XMLStreamConstants.START_ELEMENT)
+                throw new IllegalStateException("The current event is not START_ELEMENT\n but " + event);
+
+            // TODO: we don't have to rely on this hack --- we can just emulate
+            // start/end prefix mappings. But for now, I'll rely on this hack.
+            handleStartDocument(fastInfosetStreamReader.getNamespaceContext());
+
+            OUTER:
+            while(true) {
+                // These are all of the events listed in the javadoc for
+                // XMLEvent.
+                // The spec only really describes 11 of them.
+                switch (event) {
+                    case XMLStreamConstants.START_ELEMENT :
+                        handleStartElement();
+                        depth++;
+                        break;
+                    case XMLStreamConstants.END_ELEMENT :
+                        depth--;
+                        handleEndElement();
+                        if(depth==0)    break OUTER;
+                        break;
+                    case XMLStreamConstants.CHARACTERS :
+                    case XMLStreamConstants.CDATA :
+                    case XMLStreamConstants.SPACE :
+                        handleCharacters();
+                        break;
+                    // otherwise simply ignore
+                }
+
+                event=fastInfosetStreamReader.next();
+            }
+
+            fastInfosetStreamReader.next();    // move beyond the end tag.
+
+            handleEndDocument();
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    protected Location getCurrentLocation() {
+        return fastInfosetStreamReader.getLocation();
+    }
+
+    protected String getCurrentQName() {
+        return fastInfosetStreamReader.getNameString();
+    }
+
+    private void handleStartElement() throws SAXException {
+        processText(true);
+
+        for (int i = 0; i < fastInfosetStreamReader.getNamespaceCount(); i++) {
+            visitor.startPrefixMapping(fastInfosetStreamReader.getNamespacePrefix(i),
+                    fastInfosetStreamReader.getNamespaceURI(i));
+        }
+
+        tagName.uri = fastInfosetStreamReader.getNamespaceURI();
+        tagName.local = fastInfosetStreamReader.getLocalName();
+        tagName.atts = fastInfosetStreamReader.getAttributesHolder();
+
+        visitor.startElement(tagName);
+    }
+
+    private void handleCharacters() {
+        if (predictor.expectText()) {
+            // If the first chunk of CIIs and character data is present
+            if (firstCIIChunk &&
+                    fastInfosetStreamReader.getTextAlgorithmBytes() == null) {
+                buffer.append(fastInfosetStreamReader.getTextCharacters(),
+                        fastInfosetStreamReader.getTextStart(),
+                        fastInfosetStreamReader.getTextLength());
+                firstCIIChunk = false;
+            // If the first chunk of CIIs and octet data is present
+            } else if (firstCIIChunk &&
+                    fastInfosetStreamReader.getTextAlgorithmIndex() == EncodingAlgorithmIndexes.BASE64) {
+                firstCIIChunk = false;
+                hasBase64Data = true;
+                // Clone the octets
+                base64Data.set(fastInfosetStreamReader.getTextAlgorithmBytesClone(),null);
+                return;
+            // If a subsequent sequential chunk of CIIs
+            } else {
+                // If the first chunk is octet data
+                if (hasBase64Data) {
+                    // Append base64 encoded octets to the character buffer
+                    buffer.append(base64Data);
+                    hasBase64Data = false;
+                }
+
+                // Append the second or subsequence chunk of CIIs to the buffer
+                buffer.append(fastInfosetStreamReader.getTextCharacters(),
+                        fastInfosetStreamReader.getTextStart(),
+                        fastInfosetStreamReader.getTextLength());
+            }
+
+        }
+    }
+
+    private void handleEndElement() throws SAXException {
+        processText(false);
+
+        tagName.uri = fastInfosetStreamReader.getNamespaceURI();
+        tagName.local = fastInfosetStreamReader.getLocalName();
+
+        visitor.endElement(tagName);
+
+        for (int i = fastInfosetStreamReader.getNamespaceCount() - 1; i >= 0; i--) {
+            visitor.endPrefixMapping(fastInfosetStreamReader.getNamespacePrefix(i));
+        }
+    }
+
+    private void processText(boolean ignorable) throws SAXException {
+        firstCIIChunk = true;
+        if(predictor.expectText() && (!ignorable || !WhiteSpaceProcessor.isWhiteSpace(buffer))) {
+            if (!hasBase64Data) {
+                visitor.text(buffer);
+            } else {
+                visitor.text(base64Data);
+                hasBase64Data = false;
+            }
+        }
+        buffer.setLength(0);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/IntArrayData.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/IntArrayData.java
new file mode 100644
index 0000000..091855d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/IntArrayData.java
@@ -0,0 +1,122 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.io.IOException;
+
+import com.sun.xml.internal.bind.v2.runtime.output.Pcdata;
+import com.sun.xml.internal.bind.v2.runtime.output.UTF8XmlOutput;
+
+/**
+ * Typed {@link CharSequence} for int[].
+ *
+ * <p>
+ * Fed to unmarshaller when the 'text' data is actually
+ * a virtual image of int array.
+ *
+ * <p>
+ * This class holds int[] as a triplet of (data,start,len)
+ * where 'start' and 'len' represents the start position of the
+ * data and the length.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class IntArrayData extends Pcdata {
+
+    private int[] data;
+    private int start;
+    private int len;
+
+    /**
+     * String representation of the data. Lazily computed.
+     */
+    private StringBuilder literal;
+
+
+    public IntArrayData(int[] data, int start, int len) {
+        set(data, start, len);
+    }
+
+    public IntArrayData() {
+    }
+
+    /**
+     * Sets the int[] data to this object.
+     *
+     * <p>
+     * This method doesn't make a copy for a performance reason.
+     * The caller is still free to modify the array it passed to this method,
+     * but he should do so with a care. The unmarshalling code isn't expecting
+     * the value to be changed while it's being routed.
+     */
+    public void set(int[] data, int start, int len) {
+        this.data = data;
+        this.start = start;
+        this.len = len;
+        this.literal = null;
+    }
+
+    public int length() {
+        return getLiteral().length();
+    }
+
+    public char charAt(int index) {
+        return getLiteral().charAt(index);
+    }
+
+    public CharSequence subSequence(int start, int end) {
+        return getLiteral().subSequence(start,end);
+    }
+
+    /**
+     * Computes the literal form from the data.
+     */
+    private StringBuilder getLiteral() {
+        if(literal!=null)   return literal;
+
+        literal = new StringBuilder();
+        int p = start;
+        for( int i=len; i>0; i-- ) {
+            if(literal.length()>0)  literal.append(' ');
+            literal.append(data[p++]);
+        }
+
+        return literal;
+    }
+
+    public String toString() {
+        return literal.toString();
+    }
+
+    public void writeTo(UTF8XmlOutput output) throws IOException {
+        int p = start;
+        for( int i=len; i>0; i-- ) {
+            if(i!=len)
+                output.write(' ');
+            output.text(data[p++]);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/IntData.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/IntData.java
new file mode 100644
index 0000000..59c67f9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/IntData.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.io.IOException;
+
+import com.sun.xml.internal.bind.v2.runtime.output.Pcdata;
+import com.sun.xml.internal.bind.v2.runtime.output.UTF8XmlOutput;
+
+/**
+ * {@link Pcdata} that represents a single integer.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class IntData extends Pcdata {
+    /**
+     * The int value that this {@link Pcdata} represents.
+     *
+     * Modifiable.
+     */
+    private int data;
+
+    /**
+     * Length of the {@link #data} in ASCII string.
+     * For example if data=-10, then length=3
+     */
+    private int length;
+
+    public void reset(int i) {
+        this.data = i;
+        if(i==Integer.MIN_VALUE)
+            length = 11;
+        else
+            length = (i < 0) ? stringSizeOfInt(-i) + 1 : stringSizeOfInt(i);
+    }
+
+    private final static int [] sizeTable = { 9, 99, 999, 9999, 99999, 999999, 9999999,
+                                     99999999, 999999999, Integer.MAX_VALUE };
+
+    // Requires positive x
+    private static int stringSizeOfInt(int x) {
+        for (int i=0; ; i++)
+            if (x <= sizeTable[i])
+                return i+1;
+    }
+
+    public String toString() {
+        return String.valueOf(data);
+    }
+
+
+    public int length() {
+        return length;
+    }
+
+    public char charAt(int index) {
+        return toString().charAt(index);
+    }
+
+    public CharSequence subSequence(int start, int end) {
+        return toString().substring(start,end);
+    }
+
+    public void writeTo(UTF8XmlOutput output) throws IOException {
+        output.text(data);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Intercepter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Intercepter.java
new file mode 100644
index 0000000..9f449e4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Intercepter.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Used solely by {@link com.sun.xml.internal.bind.v2.runtime.ElementBeanInfoImpl} to wrap
+ * the loaded value object into a JAXBElement object.
+ *
+ * UGLY HACK.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Intercepter {
+    /**
+     * Called when the child loader is deactivated.
+     *
+     * @param state
+     *      points to the parent's current state.
+     * @param o
+     *      object that was loaded. may be null.
+     */
+    Object intercept(UnmarshallingContext.State state, Object o) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/InterningXmlVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/InterningXmlVisitor.java
new file mode 100644
index 0000000..5b661c7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/InterningXmlVisitor.java
@@ -0,0 +1,154 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.namespace.NamespaceContext;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ * {@link XmlVisitor} decorator that interns all string tokens.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class InterningXmlVisitor implements XmlVisitor {
+    private final XmlVisitor next;
+
+    private final AttributesImpl attributes = new AttributesImpl();
+
+    public InterningXmlVisitor(XmlVisitor next) {
+        this.next = next;
+    }
+
+    public void startDocument(LocatorEx locator, NamespaceContext nsContext) throws SAXException {
+        next.startDocument(locator,nsContext);
+    }
+
+    public void endDocument() throws SAXException {
+        next.endDocument();
+    }
+
+    public void startElement(TagName tagName ) throws SAXException {
+        attributes.setAttributes(tagName.atts);
+        tagName.atts = attributes;
+        tagName.uri = intern(tagName.uri);
+        tagName.local = intern(tagName.local);
+        next.startElement(tagName);
+    }
+
+    public void endElement(TagName tagName ) throws SAXException {
+        tagName.uri = intern(tagName.uri);
+        tagName.local = intern(tagName.local);
+        next.endElement(tagName);
+    }
+
+    public void startPrefixMapping( String prefix, String nsUri ) throws SAXException {
+        next.startPrefixMapping(intern(prefix),intern(nsUri));
+    }
+
+    public void endPrefixMapping( String prefix ) throws SAXException {
+        next.endPrefixMapping(intern(prefix));
+    }
+
+    public void text( CharSequence pcdata ) throws SAXException {
+        next.text(pcdata);
+    }
+
+    public UnmarshallingContext getContext() {
+        return next.getContext();
+    }
+
+    public TextPredictor getPredictor() {
+        return next.getPredictor();
+    }
+
+    private static class AttributesImpl implements Attributes {
+        private Attributes core;
+
+        void setAttributes(Attributes att) {
+            this.core = att;
+        }
+
+        public int getIndex(String qName) {
+            return core.getIndex(qName);
+        }
+
+        public int getIndex(String uri, String localName) {
+            return core.getIndex(uri, localName);
+        }
+
+        public int getLength() {
+            return core.getLength();
+        }
+
+        public String getLocalName(int index) {
+            return intern(core.getLocalName(index));
+        }
+
+        public String getQName(int index) {
+            return intern(core.getQName(index));
+        }
+
+        public String getType(int index) {
+            return intern(core.getType(index));
+        }
+
+        public String getType(String qName) {
+            return intern(core.getType(qName));
+        }
+
+        public String getType(String uri, String localName) {
+            return intern(core.getType(uri, localName));
+        }
+
+        public String getURI(int index) {
+            return intern(core.getURI(index));
+        }
+
+        //
+        // since values may vary a lot,
+        // we don't (probably shouldn't) intern values.
+        //
+
+        public String getValue(int index) {
+            return core.getValue(index);
+        }
+
+        public String getValue(String qName) {
+            return core.getValue(qName);
+        }
+
+        public String getValue(String uri, String localName) {
+            return core.getValue(uri, localName);
+        }
+    }
+
+    private static String intern(String s) {
+        if(s==null)     return null;
+        else            return s.intern();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LeafPropertyLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LeafPropertyLoader.java
new file mode 100644
index 0000000..01ac54b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LeafPropertyLoader.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Unmarshals a text into a property of the parent element.
+ *
+ * @see ValuePropertyLoader
+ * @author Kohsuke Kawaguchi
+ */
+public class LeafPropertyLoader extends Loader {
+
+    private final TransducedAccessor xacc;
+
+    public LeafPropertyLoader(TransducedAccessor xacc) {
+        super(true);
+        this.xacc = xacc;
+    }
+
+    public void text(UnmarshallingContext.State state, CharSequence text) throws SAXException {
+        try {
+            xacc.parse(state.prev.target,text);
+        } catch (AccessorException e) {
+            handleGenericException(e,true);
+        } catch (RuntimeException e) {
+            handleParseConversionException(state,e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Loader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Loader.java
new file mode 100644
index 0000000..26e5e0a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Loader.java
@@ -0,0 +1,239 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.util.Collection;
+import java.util.Collections;
+
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class Loader {
+
+    // allow derived classes to change it later
+    protected boolean expectText;
+
+    protected Loader(boolean expectText) {
+        this.expectText = expectText;
+    }
+
+    protected Loader() {
+    }
+
+//
+//
+//
+// Contract
+//
+//
+//
+    /**
+     * Called when the loader is activated, which is when a new start tag is seen
+     * and when the parent designated this loader as the child loader.
+     *
+     * <p>
+     * The callee may change <tt>state.loader</tt> to designate another {@link Loader}
+     * for the processing. It's the responsibility of the callee to forward the startElement
+     * event in such a case.
+     *
+     * @param ea
+     *      info about the start tag. never null.
+     */
+    public void startElement(UnmarshallingContext.State state,TagName ea) throws SAXException {
+    }
+
+    /**
+     * Called when this loaderis an active loaderand we see a new child start tag.
+     *
+     * <p>
+     * The callee is expected to designate another loaderas a loaderthat processes
+     * this element, then it should also register a {@link Receiver}.
+     * The designated loaderwill become an active loader.
+     *
+     * <p>
+     * The default implementation reports an error saying an element is unexpected.
+     */
+    public void childElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        // notify the error, then recover by ignoring the whole element.
+        reportUnexpectedChildElement(ea, true);
+        state.loader = Discarder.INSTANCE;
+        state.receiver = null;
+    }
+
+    protected final void reportUnexpectedChildElement(TagName ea, boolean canRecover) throws SAXException {
+        reportError(Messages.UNEXPECTED_ELEMENT.format(ea.uri,ea.local,computeExpectedElements()), canRecover );
+    }
+
+    /**
+     * Returns a set of tag names expected as possible child elements in this context.
+     */
+    public Collection<QName> getExpectedChildElements() {
+        return Collections.emptyList();
+    }
+
+    /**
+     * Called when this loaderis an active loaderand we see a chunk of text.
+     *
+     * The runtime makes sure that adjacent characters (even those separated
+     * by comments, PIs, etc) are reported as one event.
+     * IOW, you won't see two text event calls in a row.
+     */
+    public void text(UnmarshallingContext.State state, CharSequence text) throws SAXException {
+        // make str printable
+        text = text.toString().replace('\r',' ').replace('\n',' ').replace('\t',' ').trim();
+        reportError(Messages.UNEXPECTED_TEXT.format(text), true );
+    }
+
+    /**
+     * True if this loader expects the {@link #text(UnmarshallingContext.State, CharSequence)} method
+     * to be called. False otherwise.
+     */
+    public final boolean expectText() {
+        return expectText;
+    }
+
+
+    /**
+     * Called when this loaderis an active loaderand we see an end tag.
+     */
+    public void leaveElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+    }
+
+
+
+
+
+
+
+
+
+
+//
+//
+//
+// utility methods
+//
+//
+//
+    /**
+     * Computes the names of possible root elements for a better error diagnosis.
+     */
+    private String computeExpectedElements() {
+        StringBuilder r = new StringBuilder();
+
+        for( QName n : getExpectedChildElements() ) {
+            if(r.length()!=0)   r.append(',');
+            r.append("<{").append(n.getNamespaceURI()).append('}').append(n.getLocalPart()).append('>');
+        }
+        if(r.length()==0) {
+            return "(none)";
+        }
+
+        return r.toString();
+    }
+
+    /**
+     * Fires the beforeUnmarshal event if necessary.
+     *
+     * @param state
+     *      state of the newly create child object.
+     */
+    protected final void fireBeforeUnmarshal(JaxBeanInfo beanInfo, Object child, UnmarshallingContext.State state) throws SAXException {
+        if(beanInfo.lookForLifecycleMethods()) {
+            UnmarshallingContext context = state.getContext();
+            Unmarshaller.Listener listener = context.parent.getListener();
+            if(beanInfo.hasBeforeUnmarshalMethod()) {
+                beanInfo.invokeBeforeUnmarshalMethod(context.parent, child, state.prev.target);
+            }
+            if(listener!=null) {
+                listener.beforeUnmarshal(child, state.prev.target);
+            }
+        }
+    }
+
+    /**
+     * Fires the afterUnmarshal event if necessary.
+     *
+     * @param state
+     *      state of the parent object
+     */
+    protected final void fireAfterUnmarshal(JaxBeanInfo beanInfo, Object child, UnmarshallingContext.State state) throws SAXException {
+        // fire the event callback
+        if(beanInfo.lookForLifecycleMethods()) {
+            UnmarshallingContext context = state.getContext();
+            Unmarshaller.Listener listener = context.parent.getListener();
+            if(beanInfo.hasAfterUnmarshalMethod()) {
+                beanInfo.invokeAfterUnmarshalMethod(context.parent, child, state.target);
+            }
+            if(listener!=null)
+                listener.afterUnmarshal(child, state.target);
+        }
+    }
+
+
+    /**
+     * Last resort when something goes terribly wrong within the unmarshaller.
+     */
+    protected static void handleGenericException(Exception e) throws SAXException {
+        handleGenericException(e,false);
+    }
+
+    public static void handleGenericException(Exception e, boolean canRecover) throws SAXException {
+        reportError(e.getMessage(), e, canRecover );
+    }
+
+
+    protected static void reportError(String msg, boolean canRecover) throws SAXException {
+        reportError(msg, null, canRecover );
+    }
+
+    public static void reportError(String msg, Exception nested, boolean canRecover) throws SAXException {
+        UnmarshallingContext context = UnmarshallingContext.getInstance();
+        context.handleEvent( new ValidationEventImpl(
+            canRecover? ValidationEvent.ERROR : ValidationEvent.FATAL_ERROR,
+            msg,
+            context.getLocator().getLocation(),
+            nested ), canRecover );
+    }
+
+    /**
+     * This method is called by the generated derived class
+     * when a datatype parse method throws an exception.
+     */
+    protected static void handleParseConversionException(UnmarshallingContext.State state, Exception e) throws SAXException {
+        // wrap it into a ParseConversionEvent and report it
+        state.getContext().handleError(e);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LocatorEx.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LocatorEx.java
new file mode 100644
index 0000000..1995e69
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LocatorEx.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.bind.ValidationEventLocator;
+
+import org.xml.sax.Locator;
+
+/**
+ * Object that returns the current location that the {@link XmlVisitor} is parsing.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface LocatorEx extends Locator {
+    /**
+     * Gets the current location in a {@link ValidationEventLocator} object.
+     */
+    ValidationEventLocator getLocation();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LocatorExWrapper.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LocatorExWrapper.java
new file mode 100644
index 0000000..d3a1c61
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/LocatorExWrapper.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.bind.ValidationEventLocator;
+import javax.xml.bind.helpers.ValidationEventLocatorImpl;
+
+import org.xml.sax.Locator;
+
+/**
+ * {@link LocatorEx} implemented by {@link Locator}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class LocatorExWrapper implements LocatorEx {
+    private final Locator locator;
+
+    public LocatorExWrapper(Locator locator) {
+        this.locator = locator;
+    }
+
+    public ValidationEventLocator getLocation() {
+        return new ValidationEventLocatorImpl(locator);
+    }
+
+    public String getPublicId() {
+        return locator.getPublicId();
+    }
+
+    public String getSystemId() {
+        return locator.getSystemId();
+    }
+
+    public int getLineNumber() {
+        return locator.getLineNumber();
+    }
+
+    public int getColumnNumber() {
+        return locator.getColumnNumber();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/MTOMDecorator.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/MTOMDecorator.java
new file mode 100644
index 0000000..ae38421
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/MTOMDecorator.java
@@ -0,0 +1,131 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.activation.DataHandler;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+import javax.xml.namespace.NamespaceContext;
+
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Decorator of {@link XmlVisitor} that performs XOP processing.
+ * Used to support MTOM.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class MTOMDecorator implements XmlVisitor {
+
+    private final XmlVisitor next;
+
+    private final AttachmentUnmarshaller au;
+
+    private UnmarshallerImpl parent;
+
+    private final Base64Data base64data = new Base64Data();
+
+    /**
+     * True if we are between the start and the end of xop:Include
+     */
+    private boolean inXopInclude;
+
+    /**
+     * UGLY HACK: we need to ignore the whitespace that follows
+     * the attached base64 image.
+     *
+     * This happens twice; once before &lt;/xop:Include>, another
+     * after &lt;/xop:Include>. The spec guarantees that
+     * no valid pcdata can follow &lt;/xop:Include>.
+     */
+    private boolean followXop;
+
+    public MTOMDecorator(UnmarshallerImpl parent,XmlVisitor next, AttachmentUnmarshaller au) {
+        this.parent = parent;
+        this.next = next;
+        this.au = au;
+    }
+
+    public void startDocument(LocatorEx loc, NamespaceContext nsContext) throws SAXException {
+        next.startDocument(loc,nsContext);
+    }
+
+    public void endDocument() throws SAXException {
+        next.endDocument();
+    }
+
+    public void startElement(TagName tagName) throws SAXException {
+        if(tagName.local=="Include" && tagName.uri==WellKnownNamespace.XOP) {
+            // found xop:Include
+            String href = tagName.atts.getValue("href");
+            DataHandler attachment = au.getAttachmentAsDataHandler(href);
+            if(attachment==null) {
+                // report an error and ignore
+                parent.getEventHandler().handleEvent(null);
+                // TODO
+            }
+            base64data.set(attachment);
+            next.text(base64data);
+            inXopInclude = true;
+            followXop = true;
+        } else
+            next.startElement(tagName);
+    }
+
+    public void endElement(TagName tagName) throws SAXException {
+        if(inXopInclude) {
+            // consume </xop:Include> by ourselves.
+            inXopInclude = false;
+            followXop = true;
+            return;
+        }
+        next.endElement(tagName);
+    }
+
+    public void startPrefixMapping(String prefix, String nsUri) throws SAXException {
+        next.startPrefixMapping(prefix,nsUri);
+    }
+
+    public void endPrefixMapping(String prefix) throws SAXException {
+        next.endPrefixMapping(prefix);
+    }
+
+    public void text( CharSequence pcdata ) throws SAXException {
+        if(!followXop)
+            next.text(pcdata);
+        else
+            followXop = false;
+    }
+
+    public UnmarshallingContext getContext() {
+        return next.getContext();
+    }
+
+    public TextPredictor getPredictor() {
+        return next.getPredictor();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Messages.java
new file mode 100644
index 0000000..f76b164
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Messages.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+enum Messages {
+    UNRESOLVED_IDREF, // 1 arg
+    UNEXPECTED_ELEMENT, // 3 args
+    UNEXPECTED_TEXT, // 1 arg
+    NOT_A_QNAME,    // 1 arg
+    UNRECOGNIZED_TYPE_NAME, // 1 arg
+    UNRECOGNIZED_TYPE_NAME_MAYBE, // 2 args
+    UNABLE_TO_CREATE_MAP, // 1 arg
+    ;
+
+    private static final ResourceBundle rb = ResourceBundle.getBundle(Messages.class.getName());
+
+    public String toString() {
+        return format();
+    }
+
+    public String format( Object... args ) {
+        return MessageFormat.format( rb.getString(name()), args );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Messages.properties
new file mode 100644
index 0000000..0a4db7e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Messages.properties
@@ -0,0 +1,23 @@
+NOT_A_QNAME = \
+    {0} is not a valid QName
+
+UNRECOGNIZED_TYPE_NAME = \
+    unrecognized type name: {0}
+
+UNRECOGNIZED_TYPE_NAME_MAYBE = \
+    unrecognized type name: {0}. Did you mean {1}?
+
+UNRESOLVED_IDREF = \
+    Undefined ID "{0}".
+
+UNEXPECTED_ELEMENT = \
+	unexpected element (uri:"{0}", local:"{1}"). Expected elements are {2}
+
+UNEXPECTED_TEXT = \
+    unexpected text "{0}"
+
+UNABLE_TO_CREATE_MAP = \
+    The type of the field is {0}, but JAXB doesn't know how to create an instance \
+    assignable to it. Create an instance in the constructor, or use a type that can \
+    be assignable from HashMap.
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Patcher.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Patcher.java
new file mode 100644
index 0000000..5167db9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Patcher.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public interface Patcher {
+    void run() throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ProxyLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ProxyLoader.java
new file mode 100644
index 0000000..1fb0126
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ProxyLoader.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link Loader} that delegates the processing to another {@link Loader}
+ * at {@link #startElement(UnmarshallingContext.State, TagName)}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class ProxyLoader extends Loader {
+    public ProxyLoader() {
+        super(false);
+    }
+
+    public final void startElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        Loader loader = selectLoader(state,ea);
+        state.loader = loader;
+        loader.startElement(state,ea);
+    }
+
+    /**
+     * Picks the loader to delegate to.
+     *
+     * @return never null.
+     */
+    protected abstract Loader selectLoader(UnmarshallingContext.State state, TagName ea) throws SAXException;
+
+    @Override
+    public final void leaveElement(UnmarshallingContext.State state, TagName ea) {
+        // this loader is used just to forward to another loader,
+        // so we should never get this event.
+        throw new IllegalStateException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Receiver.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Receiver.java
new file mode 100644
index 0000000..99c2e70
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Receiver.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Receives an object by a child {@link Loader}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface Receiver {
+    /**
+     * Called when the child loader is deactivated.
+     *
+     * @param state
+     *      points to the parent's current state.
+     * @param o
+     *      object that was loaded. may be null.
+     */
+    void receive(UnmarshallingContext.State state, Object o) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/SAXConnector.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/SAXConnector.java
new file mode 100644
index 0000000..d724792
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/SAXConnector.java
@@ -0,0 +1,161 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.UnmarshallerHandler;
+
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+/**
+ * Receives SAX events and convert them to our internal events.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class SAXConnector implements UnmarshallerHandler {
+
+    private LocatorEx loc;
+
+    /**
+     * SAX may fire consective characters event, but we don't allow it.
+     * so use this buffer to perform buffering.
+     */
+    private final StringBuilder buffer = new StringBuilder();
+
+
+    private final XmlVisitor next;
+    private final UnmarshallingContext context;
+    private final XmlVisitor.TextPredictor predictor;
+
+    private static final class TagNameImpl extends TagName {
+        String qname;
+        public String getQname() {
+            return qname;
+        }
+    }
+    private final TagNameImpl tagName = new TagNameImpl();
+
+
+    /**
+     *
+     * @param externalLocator
+     *      If the caller is producing SAX events from sources other than Unicode and angle brackets,
+     *      the caller can override the default SAX {@link Locator} object by this object
+     *      to provide better location information.
+     */
+    public SAXConnector(XmlVisitor next, LocatorEx externalLocator ) {
+        this.next = next;
+        this.context = next.getContext();
+        this.predictor = next.getPredictor();
+        this.loc = externalLocator;
+    }
+
+    public Object getResult() throws JAXBException, IllegalStateException {
+        return context.getResult();
+    }
+
+    public UnmarshallingContext getContext() {
+        return context;
+    }
+
+    public void setDocumentLocator(final Locator locator) {
+        if(loc!=null)
+            return; // we already have an external locator. ignore.
+
+        this.loc = new LocatorExWrapper(locator);
+    }
+
+    public void startDocument() throws SAXException {
+        next.startDocument(loc,null);
+    }
+
+    public void endDocument() throws SAXException {
+        next.endDocument();
+    }
+
+    public void startPrefixMapping(String prefix, String uri) throws SAXException {
+        next.startPrefixMapping(prefix,uri);
+    }
+
+    public void endPrefixMapping(String prefix) throws SAXException {
+        next.endPrefixMapping(prefix);
+    }
+
+    public void startElement(String uri, String local, String qname, Attributes atts) throws SAXException {
+        // work gracefully with misconfigured parsers that don't support namespaces
+        if( uri==null || uri.length()==0 )
+            uri="";
+        if( local==null || local.length()==0 )
+            local=qname;
+        if( qname==null || qname.length()==0 )
+            qname=local;
+
+        processText(true);
+
+        tagName.uri = uri;
+        tagName.local = local;
+        tagName.qname = qname;
+        tagName.atts = atts;
+        next.startElement(tagName);
+    }
+
+    public void endElement(String uri, String localName, String qName) throws SAXException {
+        processText(false);
+        tagName.uri = uri;
+        tagName.local = localName;
+        tagName.qname = qName;
+        next.endElement(tagName);
+    }
+
+
+    public final void characters( char[] buf, int start, int len ) {
+        if( predictor.expectText() )
+            buffer.append(buf,start,len);
+    }
+
+    public final void ignorableWhitespace( char[] buf, int start, int len ) {
+        characters(buf,start,len);
+    }
+
+    public void processingInstruction(String target, String data) {
+        // nop
+    }
+
+    public void skippedEntity(String name) {
+        // nop
+    }
+
+    private void processText( boolean ignorable ) throws SAXException {
+        if( predictor.expectText() && (!ignorable || !WhiteSpaceProcessor.isWhiteSpace(buffer)))
+            next.text(buffer);
+        buffer.setLength(0);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Scope.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Scope.java
new file mode 100644
index 0000000..b559136
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/Scope.java
@@ -0,0 +1,114 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Lister;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Holds the information about packing scope.
+ *
+ * <p>
+ * When no packing is started yet, all the fields should be set to null.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Scope<BeanT,PropT,ItemT,PackT> {
+
+    public final UnmarshallingContext context;
+
+    private BeanT bean;
+    private Accessor<BeanT,PropT> acc;
+    private PackT pack;
+    private Lister<BeanT,PropT,ItemT,PackT> lister;
+
+    Scope(UnmarshallingContext context) {
+        this.context = context;
+    }
+
+    /**
+     * Returns true if this scope object is filled by a packing in progress.
+     */
+    public boolean hasStarted() {
+        return bean!=null;
+    }
+
+    /**
+     * Initializes all the fields to null.
+     */
+    public void reset() {
+        if(bean==null) {
+            // already initialized
+            assert clean();
+            return;
+        }
+
+        bean = null;
+        acc = null;
+        pack = null;
+        lister = null;
+    }
+
+    /**
+     * Finishes up the current packing in progress (if any) and
+     * resets this object.
+     */
+    public void finish() throws AccessorException {
+        if(hasStarted()) {
+            lister.endPacking(pack,bean,acc);
+            reset();
+        }
+        assert clean();
+    }
+
+    private boolean clean() {
+        return bean==null && acc==null && pack==null && lister==null;
+    }
+
+    /**
+     * Adds a new item to this packing scope.
+     */
+    public void add( Accessor<BeanT,PropT> acc, Lister<BeanT,PropT,ItemT,PackT> lister, ItemT value) throws SAXException{
+        try {
+            if(!hasStarted()) {
+                this.bean = (BeanT)context.getCurrentState().target;
+                this.acc = acc;
+                this.lister = lister;
+                this.pack = lister.startPacking(bean,acc);
+            }
+
+            lister.addToPack(pack,value);
+        } catch (AccessorException e) {
+            Loader.handleGenericException(e,true);
+            // recover from this error by ignoring future items.
+            this.lister = Lister.ERROR;
+            this.acc = Accessor.ERROR;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXConnector.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXConnector.java
new file mode 100644
index 0000000..9378cbd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXConnector.java
@@ -0,0 +1,109 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.bind.ValidationEventLocator;
+import javax.xml.bind.helpers.ValidationEventLocatorImpl;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.Location;
+import javax.xml.stream.XMLStreamException;
+
+import org.xml.sax.SAXException;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class StAXConnector {
+    public abstract void bridge() throws XMLStreamException;
+
+
+    // event sink
+    protected final XmlVisitor visitor;
+
+    protected final UnmarshallingContext context;
+    protected final XmlVisitor.TextPredictor predictor;
+
+    private final class TagNameImpl extends TagName {
+        public String getQname() {
+            return StAXConnector.this.getCurrentQName();
+        }
+    }
+
+    protected final TagName tagName = new TagNameImpl();
+
+    protected StAXConnector(XmlVisitor visitor) {
+        this.visitor = visitor;
+        context = visitor.getContext();
+        predictor = visitor.getPredictor();
+    }
+
+    /**
+     * Gets the {@link Location}. Used for implementing the line number information.
+     * @return must not null.
+     */
+    protected abstract Location getCurrentLocation();
+
+    /**
+     * Gets the QName of the current element.
+     */
+    protected abstract String getCurrentQName();
+
+    protected final void handleStartDocument(NamespaceContext nsc) throws SAXException {
+        visitor.startDocument(new LocatorEx() {
+            public ValidationEventLocator getLocation() {
+                return new ValidationEventLocatorImpl(this);
+            }
+            public int getColumnNumber() {
+                return getCurrentLocation().getColumnNumber();
+            }
+            public int getLineNumber() {
+                return getCurrentLocation().getLineNumber();
+            }
+            public String getPublicId() {
+                return getCurrentLocation().getPublicId();
+            }
+            public String getSystemId() {
+                return getCurrentLocation().getSystemId();
+            }
+        },nsc);
+    }
+
+    protected final void handleEndDocument() throws SAXException {
+        visitor.endDocument();
+    }
+
+    protected static String fixNull(String s) {
+        if(s==null) return "";
+        else        return s;
+    }
+
+    protected final String getQName(String prefix, String localName) {
+        if(prefix==null || prefix.length()==0)
+            return localName;
+        else
+            return prefix + ':' + localName;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXEventConnector.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXEventConnector.java
new file mode 100644
index 0000000..e77f053
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXEventConnector.java
@@ -0,0 +1,285 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.Location;
+import javax.xml.stream.XMLEventReader;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.events.Attribute;
+import javax.xml.stream.events.Characters;
+import javax.xml.stream.events.EndElement;
+import javax.xml.stream.events.Namespace;
+import javax.xml.stream.events.StartElement;
+import javax.xml.stream.events.XMLEvent;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.AttributesImpl;
+
+/**
+ * This is a simple utility class that adapts StAX events from an
+ * {@link XMLEventReader} to unmarshaller events on a
+ * {@link XmlVisitor}, bridging between the two
+ * parser technologies.
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+final class StAXEventConnector extends StAXConnector {
+
+    // StAX event source
+    private final XMLEventReader staxEventReader;
+
+    /** Current event. */
+    private XMLEvent event;
+
+    /**
+     * Shared and reused {@link Attributes}.
+     */
+    private final AttributesImpl attrs = new AttributesImpl();
+
+    /**
+     * SAX may fire consective characters event, but we don't allow it.
+     * so use this buffer to perform buffering.
+     */
+    private final StringBuilder buffer = new StringBuilder();
+
+    private boolean seenText;
+
+    /**
+     * Construct a new StAX to SAX adapter that will convert a StAX event
+     * stream into a SAX event stream.
+     *
+     * @param staxCore
+     *                StAX event source
+     * @param visitor
+     *                sink
+     */
+    public StAXEventConnector(XMLEventReader staxCore, XmlVisitor visitor) {
+        super(visitor);
+        staxEventReader = staxCore;
+    }
+
+    public void bridge() throws XMLStreamException {
+
+        try {
+            // remembers the nest level of elements to know when we are done.
+            int depth=0;
+
+            event = staxEventReader.peek();
+
+            if( !event.isStartDocument() && !event.isStartElement() )
+                throw new IllegalStateException();
+
+            // if the parser is on START_DOCUMENT, skip ahead to the first element
+            do {
+                event = staxEventReader.nextEvent();
+            } while( !event.isStartElement() );
+
+            handleStartDocument(event.asStartElement().getNamespaceContext());
+
+            OUTER:
+            while(true) {
+                // These are all of the events listed in the javadoc for
+                // XMLEvent.
+                // The spec only really describes 11 of them.
+                switch (event.getEventType()) {
+                    case XMLStreamConstants.START_ELEMENT :
+                        handleStartElement(event.asStartElement());
+                        depth++;
+                        break;
+                    case XMLStreamConstants.END_ELEMENT :
+                        depth--;
+                        handleEndElement(event.asEndElement());
+                        if(depth==0)    break OUTER;
+                        break;
+                    case XMLStreamConstants.CHARACTERS :
+                    case XMLStreamConstants.CDATA :
+                    case XMLStreamConstants.SPACE :
+                        handleCharacters(event.asCharacters());
+                        break;
+                }
+
+
+                event=staxEventReader.nextEvent();
+            }
+
+            handleEndDocument();
+            event = null; // avoid keeping a stale reference
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    protected Location getCurrentLocation() {
+        return event.getLocation();
+    }
+
+    protected String getCurrentQName() {
+        QName qName;
+        if(event.isEndElement())
+            qName = event.asEndElement().getName();
+        else
+            qName = event.asStartElement().getName();
+        return getQName(qName.getPrefix(), qName.getLocalPart());
+    }
+
+
+    private void handleCharacters(Characters event) throws SAXException, XMLStreamException {
+        if(!predictor.expectText())
+            return;     // text isn't expected. simply skip
+
+        seenText = true;
+
+        // check the next event
+        XMLEvent next;
+        while(true) {
+            next = staxEventReader.peek();
+            if(!isIgnorable(next))
+                break;
+            staxEventReader.nextEvent();
+        }
+
+        if(isTag(next)) {
+            // this is by far the common case --- you have <foo>abc</foo> or <foo>abc<bar/>...</foo>
+            visitor.text(event.getData());
+            return;
+        }
+
+        // otherwise we have things like "abc<!-- test -->def".
+        // concatenate all text
+        buffer.append(event.getData());
+
+        while(true) {
+            while(true) {
+                next = staxEventReader.peek();
+                if(!isIgnorable(next))
+                    break;
+                staxEventReader.nextEvent();
+            }
+
+            if(isTag(next)) {
+                // found all adjacent text
+                visitor.text(buffer);
+                buffer.setLength(0);
+                return;
+            }
+
+            buffer.append(next.asCharacters().getData());
+            staxEventReader.nextEvent();    // consume
+        }
+    }
+
+    private boolean isTag(XMLEvent event) {
+        int eventType = event.getEventType();
+        return eventType==XMLEvent.START_ELEMENT || eventType==XMLEvent.END_ELEMENT;
+    }
+
+    private boolean isIgnorable(XMLEvent event) {
+        int eventType = event.getEventType();
+        return eventType==XMLEvent.COMMENT || eventType==XMLEvent.PROCESSING_INSTRUCTION;
+    }
+
+    private void handleEndElement(EndElement event) throws SAXException {
+        if(!seenText && predictor.expectText()) {
+            visitor.text("");
+        }
+
+        // fire endElement
+        QName qName = event.getName();
+        tagName.uri = fixNull(qName.getNamespaceURI());
+        tagName.local = qName.getLocalPart();
+        visitor.endElement(tagName);
+
+        // end namespace bindings
+        for( Iterator<Namespace> i = event.getNamespaces(); i.hasNext();) {
+            String prefix = fixNull(i.next().getPrefix());  // be defensive
+            visitor.endPrefixMapping(prefix);
+        }
+
+        seenText = false;
+    }
+
+    private void handleStartElement(StartElement event) throws SAXException {
+        // start namespace bindings
+        for (Iterator i = event.getNamespaces(); i.hasNext();) {
+            Namespace ns = (Namespace)i.next();
+            visitor.startPrefixMapping(
+                fixNull(ns.getPrefix()),
+                fixNull(ns.getNamespaceURI()));
+        }
+
+        // fire startElement
+        QName qName = event.getName();
+        tagName.uri = fixNull(qName.getNamespaceURI());
+        String localName = qName.getLocalPart();
+        tagName.uri = fixNull(qName.getNamespaceURI());
+        tagName.local = localName;
+        tagName.atts = getAttributes(event);
+        visitor.startElement(tagName);
+
+        seenText = false;
+    }
+
+
+
+    /**
+     * Get the attributes associated with the given START_ELEMENT StAXevent.
+     *
+     * @return the StAX attributes converted to an org.xml.sax.Attributes
+     */
+    private Attributes getAttributes(StartElement event) {
+        attrs.clear();
+
+        // in SAX, namespace declarations are not part of attributes by default.
+        // (there's a property to control that, but as far as we are concerned
+        // we don't use it.) So don't add xmlns:* to attributes.
+
+        // gather non-namespace attrs
+        for (Iterator i = event.getAttributes(); i.hasNext();) {
+            Attribute staxAttr = (Attribute)i.next();
+
+            QName name = staxAttr.getName();
+            String uri = fixNull(name.getNamespaceURI());
+            String localName = name.getLocalPart();
+            String prefix = name.getPrefix();
+            String qName;
+            if (prefix == null || prefix.length() == 0)
+                qName = localName;
+            else
+                qName = prefix + ':' + localName;
+            String type = staxAttr.getDTDType();
+            String value = staxAttr.getValue();
+
+            attrs.addAttribute(uri, localName, qName, type, value);
+        }
+
+        return attrs;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXStreamConnector.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXStreamConnector.java
new file mode 100644
index 0000000..959ad2d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StAXStreamConnector.java
@@ -0,0 +1,337 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.lang.reflect.Constructor;
+
+import javax.xml.stream.Location;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+
+import com.sun.xml.internal.bind.WhiteSpaceProcessor;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ * Reads XML from StAX {@link XMLStreamReader} and
+ * feeds events to {@link XmlVisitor}.
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ * @author Kohsuke Kawaguchi
+ */
+class StAXStreamConnector extends StAXConnector {
+
+    /**
+     * Creates a {@link StAXConnector} from {@link XMLStreamReader}.
+     *
+     * This method checks if the parser is FI parser and acts accordingly.
+     */
+    public static StAXConnector create(XMLStreamReader reader, XmlVisitor visitor) {
+        // try optimized codepath
+        if (reader.getClass()==FI_STAX_READER_CLASS && FI_CONNECTOR_CTOR!=null) {
+            try {
+                return FI_CONNECTOR_CTOR.newInstance(reader,visitor);
+            } catch (Exception t) {
+            }
+        }
+        if (STAX_EX_READER!=null && STAX_EX_READER.isAssignableFrom(reader.getClass())) {
+            try {
+                return STAX_EX_CONNECTOR_CTOR.newInstance(reader,visitor);
+            } catch (Exception t) {
+            }
+        }
+
+        // Quick hack until SJSXP fixes 6270116
+        boolean isZephyr = reader.getClass().getName().equals("com.sun.xml.internal.stream.XMLReaderImpl");
+        if(!isZephyr)
+            visitor = new InterningXmlVisitor(visitor);
+        return new StAXStreamConnector(reader,visitor);
+    }
+
+
+
+    // StAX event source
+    private final XMLStreamReader staxStreamReader;
+
+    /**
+     * SAX may fire consective characters event, but we don't allow it.
+     * so use this buffer to perform buffering.
+     */
+    protected final StringBuilder buffer = new StringBuilder();
+
+    /**
+     * Set to true if the text() event is reported, and therefore
+     * the following text() event should be suppressed.
+     */
+    protected boolean textReported = false;
+
+    protected StAXStreamConnector(XMLStreamReader staxStreamReader, XmlVisitor visitor) {
+        super(visitor);
+        this.staxStreamReader = staxStreamReader;
+    }
+
+    public void bridge() throws XMLStreamException {
+
+        try {
+            // remembers the nest level of elements to know when we are done.
+            int depth=0;
+
+            // if the parser is at the start tag, proceed to the first element
+            int event = staxStreamReader.getEventType();
+            if(event == XMLStreamConstants.START_DOCUMENT) {
+                // nextTag doesn't correctly handle DTDs
+                while( !staxStreamReader.isStartElement() )
+                    event = staxStreamReader.next();
+            }
+
+
+            if( event!=XMLStreamConstants.START_ELEMENT)
+                throw new IllegalStateException("The current event is not START_ELEMENT\n but " + event);
+
+            handleStartDocument(staxStreamReader.getNamespaceContext());
+
+            OUTER:
+            while(true) {
+                // These are all of the events listed in the javadoc for
+                // XMLEvent.
+                // The spec only really describes 11 of them.
+                switch (event) {
+                    case XMLStreamConstants.START_ELEMENT :
+                        handleStartElement();
+                        depth++;
+                        break;
+                    case XMLStreamConstants.END_ELEMENT :
+                        depth--;
+                        handleEndElement();
+                        if(depth==0)    break OUTER;
+                        break;
+                    case XMLStreamConstants.CHARACTERS :
+                    case XMLStreamConstants.CDATA :
+                    case XMLStreamConstants.SPACE :
+                        handleCharacters();
+                        break;
+                    // otherwise simply ignore
+                }
+
+                event=staxStreamReader.next();
+            }
+
+            staxStreamReader.next();    // move beyond the end tag.
+
+            handleEndDocument();
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    protected Location getCurrentLocation() {
+        return staxStreamReader.getLocation();
+    }
+
+    protected String getCurrentQName() {
+        return getQName(staxStreamReader.getPrefix(),staxStreamReader.getLocalName());
+    }
+
+    private void handleEndElement() throws SAXException {
+        processText(false);
+
+        // fire endElement
+        tagName.uri = fixNull(staxStreamReader.getNamespaceURI());
+        tagName.local = staxStreamReader.getLocalName();
+        visitor.endElement(tagName);
+
+        // end namespace bindings
+        int nsCount = staxStreamReader.getNamespaceCount();
+        for (int i = nsCount - 1; i >= 0; i--) {
+            visitor.endPrefixMapping(fixNull(staxStreamReader.getNamespacePrefix(i)));
+        }
+    }
+
+    private void handleStartElement() throws SAXException {
+        processText(true);
+
+        // start namespace bindings
+        int nsCount = staxStreamReader.getNamespaceCount();
+        for (int i = 0; i < nsCount; i++) {
+            visitor.startPrefixMapping(
+                fixNull(staxStreamReader.getNamespacePrefix(i)),
+                fixNull(staxStreamReader.getNamespaceURI(i)));
+        }
+
+        // fire startElement
+        tagName.uri = fixNull(staxStreamReader.getNamespaceURI());
+        tagName.local = staxStreamReader.getLocalName();
+        tagName.atts = attributes;
+
+        visitor.startElement(tagName);
+    }
+
+    /**
+     * Proxy of {@link Attributes} that read from {@link XMLStreamReader}.
+     */
+    private final Attributes attributes = new Attributes() {
+        public int getLength() {
+            return staxStreamReader.getAttributeCount();
+        }
+
+        public String getURI(int index) {
+            String uri = staxStreamReader.getAttributeNamespace(index);
+            if(uri==null)   return "";
+            return uri;
+        }
+
+        public String getLocalName(int index) {
+            return staxStreamReader.getAttributeLocalName(index);
+        }
+
+        public String getQName(int index) {
+            String prefix = staxStreamReader.getAttributePrefix(index);
+            if(prefix==null || prefix.length()==0)
+                return getLocalName(index);
+            else
+                return prefix + ':' + getLocalName(index);
+        }
+
+        public String getType(int index) {
+            return staxStreamReader.getAttributeType(index);
+        }
+
+        public String getValue(int index) {
+            return staxStreamReader.getAttributeValue(index);
+        }
+
+        public int getIndex(String uri, String localName) {
+            for( int i=getLength()-1; i>=0; i-- )
+                if( localName.equals(getLocalName(i)) && uri.equals(getURI(i)))
+                    return i;
+            return -1;
+        }
+
+        // this method sholdn't be used that often (if at all)
+        // so it's OK to be slow.
+        public int getIndex(String qName) {
+            for( int i=getLength()-1; i>=0; i-- ) {
+                if(qName.equals(getQName(i)))
+                    return i;
+            }
+            return -1;
+        }
+
+        public String getType(String uri, String localName) {
+            int index = getIndex(uri,localName);
+            if(index<0)     return null;
+            return getType(index);
+        }
+
+        public String getType(String qName) {
+            int index = getIndex(qName);
+            if(index<0)     return null;
+            return getType(index);
+        }
+
+        public String getValue(String uri, String localName) {
+            int index = getIndex(uri,localName);
+            if(index<0)     return null;
+            return getValue(index);
+        }
+
+        public String getValue(String qName) {
+            int index = getIndex(qName);
+            if(index<0)     return null;
+            return getValue(index);
+        }
+    };
+
+    protected void handleCharacters() throws XMLStreamException, SAXException {
+        if( predictor.expectText() )
+            buffer.append(
+                staxStreamReader.getTextCharacters(),
+                staxStreamReader.getTextStart(),
+                staxStreamReader.getTextLength() );
+    }
+
+    private void processText( boolean ignorable ) throws SAXException {
+        if( predictor.expectText() && (!ignorable || !WhiteSpaceProcessor.isWhiteSpace(buffer))) {
+            if(textReported) {
+                textReported = false;
+            } else {
+                visitor.text(buffer);
+            }
+        }
+        buffer.setLength(0);
+    }
+
+
+
+    /**
+     * Reference to FI's StAXReader class, if FI can be loaded.
+     */
+    private static final Class FI_STAX_READER_CLASS = initFIStAXReaderClass();
+    private static final Constructor<? extends StAXConnector> FI_CONNECTOR_CTOR = initFastInfosetConnectorClass();
+
+    private static Class initFIStAXReaderClass() {
+        try {
+            return UnmarshallerImpl.class.getClassLoader().loadClass("com.sun.xml.internal.fastinfoset.stax.StAXDocumentParser");
+        } catch (Throwable e) {
+            return null;
+        }
+    }
+
+    private static Constructor<? extends StAXConnector> initFastInfosetConnectorClass() {
+        try {
+            Class c = UnmarshallerImpl.class.getClassLoader().loadClass("com.sun.xml.internal.bind.v2.runtime.unmarshaller.FastInfosetConnector");
+            return c.getConstructor(FI_STAX_READER_CLASS,XmlVisitor.class);
+        } catch (Throwable e) {
+            return null;
+        }
+    }
+
+
+    //
+    // reference to StAXEx classes
+    //
+    private static final Class STAX_EX_READER = initStAXExReader();
+    private static final Constructor<? extends StAXConnector> STAX_EX_CONNECTOR_CTOR = initStAXExConnector();
+
+    private static Class initStAXExReader() {
+        try {
+            return UnmarshallerImpl.class.getClassLoader().loadClass("org.jvnet.staxex.XMLStreamReaderEx");
+        } catch (Throwable e) {
+            return null;
+        }
+    }
+
+    private static Constructor<? extends StAXConnector> initStAXExConnector() {
+        try {
+            Class c = UnmarshallerImpl.class.getClassLoader().loadClass("com.sun.xml.internal.bind.v2.runtime.unmarshaller.StAXExConnector");
+            return c.getConstructor(STAX_EX_READER,XmlVisitor.class);
+        } catch (Throwable e) {
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StructureLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StructureLoader.java
new file mode 100644
index 0000000..1aea12f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/StructureLoader.java
@@ -0,0 +1,260 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.runtime.ClassBeanInfoImpl;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+import com.sun.xml.internal.bind.v2.runtime.property.AttributeProperty;
+import com.sun.xml.internal.bind.v2.runtime.property.Property;
+import com.sun.xml.internal.bind.v2.runtime.property.StructureLoaderBuilder;
+import com.sun.xml.internal.bind.v2.runtime.property.UnmarshallerChain;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.v2.util.QNameMap;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ * Loads children of an element.
+ *
+ * <p>
+ * This loader works with a single {@link JaxBeanInfo} and handles
+ * attributes, child elements, or child text.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class StructureLoader extends Loader {
+    /**
+     * This map statically stores information of the
+     * unmarshaller loader and can be used while unmarshalling
+     * Since creating new QNames is expensive use this optimized
+     * version of the map
+     */
+    private final QNameMap<ChildLoader> childUnmarshallers = new QNameMap<ChildLoader>();
+
+    /**
+     * Loader that processes elements that didn't match anf of the {@link #childUnmarshallers}.
+     * Can be null.
+     */
+    private /*final*/ ChildLoader catchAll;
+
+    /**
+     * If we have a loader for processing text. Otherwise null.
+     */
+    private /*final*/ ChildLoader textHandler;
+
+    /**
+     * Unmarshallers for attribute values.
+     * May be null if no attribute is expected and {@link #attCatchAll}==null.
+     */
+    private /*final*/ QNameMap<TransducedAccessor> attUnmarshallers;
+
+    /**
+     * This will receive all the attributes
+     * that were not processed. Never be null.
+     */
+    private /*final*/ Accessor<Object,Map<QName,String>> attCatchAll;
+
+    private final JaxBeanInfo beanInfo;
+
+    /**
+     * The number of scopes this dispatcher needs to keep active.
+     */
+    private /*final*/ int frameSize;
+
+    // this class is potentially useful for general audience, not just for ClassBeanInfoImpl,
+    // but since right now that is the only user, we make the construction code very specific
+    // to ClassBeanInfoImpl. See rev.1.5 of this file for the original general purpose definition.
+    public StructureLoader(ClassBeanInfoImpl beanInfo) {
+        super(true);
+        this.beanInfo = beanInfo;
+    }
+
+    /**
+     * Completes the initialization.
+     *
+     * <p>
+     * To fix the cyclic reference issue, the main part of the initialization needs to be done
+     * after a {@link StructureLoader} is set to {@link ClassBeanInfoImpl#loader}.
+     */
+    public void init( JAXBContextImpl context, ClassBeanInfoImpl beanInfo, Accessor<?,Map<QName,String>> attWildcard) {
+        UnmarshallerChain chain = new UnmarshallerChain(context);
+        for (ClassBeanInfoImpl bi = beanInfo; bi != null; bi = bi.superClazz) {
+            for (int i = bi.properties.length - 1; i >= 0; i--) {
+                Property p = bi.properties[i];
+
+                switch(p.getKind()) {
+                case ATTRIBUTE:
+                    if(attUnmarshallers==null)
+                        attUnmarshallers = new QNameMap<TransducedAccessor>();
+                    AttributeProperty ap = (AttributeProperty) p;
+                    attUnmarshallers.put(ap.attName.toQName(),ap.xacc);
+                    break;
+                case ELEMENT:
+                case REFERENCE:
+                case MAP:
+                case VALUE:
+                    p.buildChildElementUnmarshallers(chain,childUnmarshallers);
+                    break;
+                }
+            }
+        }
+
+        this.frameSize = chain.getScopeSize();
+
+        textHandler = childUnmarshallers.get(StructureLoaderBuilder.TEXT_HANDLER);
+        catchAll = childUnmarshallers.get(StructureLoaderBuilder.CATCH_ALL);
+
+        if(attWildcard!=null) {
+            attCatchAll = (Accessor<Object,Map<QName,String>>) attWildcard;
+            // we use attUnmarshallers==null as a sign to skip the attribute processing
+            // altogether, so if we have an att wildcard we need to have an empty qname map.
+            if(attUnmarshallers==null)
+                attUnmarshallers = EMPTY;
+        } else {
+            attCatchAll = null;
+        }
+    }
+
+    @Override
+    public void startElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        UnmarshallingContext context = state.getContext();
+
+        // create the object to unmarshal
+        Object child;
+        assert !beanInfo.isImmutable();
+
+        // let's see if we can reuse the existing peer object
+        child = context.getInnerPeer();
+
+        if(child!=null && beanInfo.jaxbType!=child.getClass())
+            child = null;   // unexpected type.
+
+        if(child!=null)
+            beanInfo.reset(child,context);
+
+        if(child==null)
+            child = context.createInstance(beanInfo);
+
+        context.recordInnerPeer(child);
+
+        state.target = child;
+
+        fireBeforeUnmarshal(beanInfo, child, state);
+
+
+        context.startScope(frameSize);
+
+        if(attUnmarshallers!=null) {
+            Attributes atts = ea.atts;
+            for (int i = 0; i < atts.getLength(); i ++){
+                String auri = atts.getURI(i);
+                String alocal = atts.getLocalName(i);
+                String avalue = atts.getValue(i);
+                TransducedAccessor xacc = attUnmarshallers.get(auri,alocal);
+
+                try {
+                    if(xacc!=null) {
+                        xacc.parse(child,avalue);
+                    } else
+                    if(attCatchAll!=null) {
+                        String qname = atts.getQName(i);
+                        if(atts.getURI(i).equals(WellKnownNamespace.XML_SCHEMA_INSTANCE))
+                            continue;   // xsi:* attributes are meant to be processed by us, not by user apps.
+                        Object o = state.target;
+                        Map<QName,String> map = attCatchAll.get(o);
+                        if(map==null) {
+                            // TODO: use  ClassFactory.inferImplClass(sig,knownImplClasses)
+
+                            // if null, create a new map.
+                            if(attCatchAll.valueType.isAssignableFrom(HashMap.class))
+                                map = new HashMap<QName,String>();
+                            else {
+                                // we don't know how to create a map for this.
+                                // report an error and back out
+                                context.handleError(Messages.UNABLE_TO_CREATE_MAP.format(attCatchAll.valueType));
+                                return;
+                            }
+                            attCatchAll.set(o,map);
+                        }
+
+                        String prefix;
+                        int idx = qname.indexOf(':');
+                        if(idx<0)   prefix="";
+                        else        prefix=qname.substring(0,idx);
+
+                        map.put(new QName(auri,alocal,prefix),avalue);
+                    }
+                } catch (AccessorException e) {
+                   handleGenericException(e,true);
+                }
+            }
+        }
+    }
+
+    @Override
+    public void childElement(UnmarshallingContext.State state, TagName arg) throws SAXException {
+        ChildLoader child = childUnmarshallers.get(arg.uri,arg.local);
+        if(child==null) {
+            child = catchAll;
+            if(child==null) {
+                super.childElement(state,arg);
+                return;
+            }
+        }
+
+        state.loader = child.loader;
+        state.receiver = child.receiver;
+    }
+
+    @Override
+    public Collection<QName> getExpectedChildElements() {
+        return childUnmarshallers.keySet();
+    }
+
+    @Override
+    public void text(UnmarshallingContext.State state, CharSequence text) throws SAXException {
+        if(textHandler!=null)
+            textHandler.loader.text(state,text);
+    }
+
+    public void leaveElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        state.getContext().endScope(frameSize);
+        fireAfterUnmarshal(beanInfo, state.target, state.prev);
+    }
+
+    private static final QNameMap<TransducedAccessor> EMPTY = new QNameMap<TransducedAccessor>();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/TagName.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/TagName.java
new file mode 100644
index 0000000..c465be1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/TagName.java
@@ -0,0 +1,134 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.runtime.Name;
+
+import org.xml.sax.Attributes;
+
+/**
+ * Represents an XML tag name (and attributes for start tags.)
+ *
+ * <p>
+ * This object is used so reduce the number of method call parameters
+ * among unmarshallers.
+ *
+ * An instance of this is expected to be reused by the caller of
+ * {@link XmlVisitor}. Note that the rest of the unmarshaller may
+ * modify any of the fields while processing an event (such as to
+ * intern strings, replace attributes),
+ * so {@link XmlVisitor} should reset all fields for each use.
+ *
+ * <p>
+ * The 'qname' parameter, which holds the qualified name of the tag
+ * (such as 'foo:bar' or 'zot'), is not used in the typical unmarshalling
+ * route and it's also expensive to compute for some input.
+ * Thus this parameter is computed lazily.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@SuppressWarnings({"StringEquality"})
+public abstract class TagName {
+    /**
+     * URI of the attribute/element name.
+     *
+     * Can be empty, but never null. Interned.
+     */
+    public String uri;
+    /**
+     * Local part of the attribute/element name.
+     *
+     * Never be null. Interned.
+     */
+    public String local;
+
+    /**
+     * Used only for the enterElement event.
+     * Otherwise the value is undefined.
+     *
+     * This might be {@link AttributesEx}.
+     */
+    public Attributes atts;
+
+    public TagName() {
+    }
+
+    /**
+     * Checks if the given name pair matches this name.
+     */
+    public final boolean matches( String nsUri, String local ) {
+        return this.uri==nsUri && this.local==local;
+    }
+
+    /**
+     * Checks if the given name pair matches this name.
+     */
+    public final boolean matches( Name name ) {
+        return this.local==name.localName && this.uri==name.nsUri;
+    }
+
+//    /**
+//     * @return
+//     *      Can be empty but always non-null. NOT interned.
+//     */
+//    public final String getPrefix() {
+//        int idx = qname.indexOf(':');
+//        if(idx<0)   return "";
+//        else        return qname.substring(0,idx);
+//    }
+
+    public String toString() {
+        return '{'+uri+'}'+local;
+    }
+
+    /**
+     * Gets the qualified name of the tag.
+     *
+     * @return never null.
+     */
+    public abstract String getQname();
+
+    /**
+     * Gets the prefix. This is slow.
+     *
+     * @return can be "" but never null.
+     */
+    public String getPrefix() {
+        String qname = getQname();
+        int idx = qname.indexOf(':');
+        if(idx<0)   return "";
+        else        return qname.substring(0,idx);
+    }
+
+    /**
+     * Creates {@link QName}.
+     */
+    public QName createQName() {
+        return new QName(uri,local,getPrefix());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/TextLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/TextLoader.java
new file mode 100644
index 0000000..f499ec7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/TextLoader.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.runtime.Transducer;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Unmarshals a text into an object.
+ *
+ * <p>
+ * If the caller can use {@link LeafPropertyLoader}, that's usually faster.
+ *
+ * @see LeafPropertyLoader
+ * @see ValuePropertyLoader
+ * @author Kohsuke Kawaguchi
+ */
+public class TextLoader extends Loader {
+
+    private final Transducer xducer;
+
+    public TextLoader(Transducer xducer) {
+        super(true);
+        this.xducer = xducer;
+    }
+
+    public void text(UnmarshallingContext.State state, CharSequence text) throws SAXException {
+        try {
+            state.target = xducer.parse(text);
+        } catch (AccessorException e) {
+            handleGenericException(e,true);
+        } catch (RuntimeException e) {
+            handleParseConversionException(state,e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/UnmarshallerImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/UnmarshallerImpl.java
new file mode 100644
index 0000000..92acbea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/UnmarshallerImpl.java
@@ -0,0 +1,515 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.PropertyException;
+import javax.xml.bind.UnmarshalException;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.UnmarshallerHandler;
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+import javax.xml.bind.helpers.AbstractUnmarshallerImpl;
+import javax.xml.stream.XMLEventReader;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.events.XMLEvent;
+import javax.xml.transform.Source;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.sax.SAXSource;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.validation.Schema;
+
+import com.sun.xml.internal.bind.IDResolver;
+import com.sun.xml.internal.bind.unmarshaller.DOMScanner;
+import com.sun.xml.internal.bind.unmarshaller.InfosetScanner;
+import com.sun.xml.internal.bind.unmarshaller.Messages;
+import com.sun.xml.internal.bind.v2.runtime.AssociationMap;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.DefaultHandler;
+
+/**
+ * Default Unmarshaller implementation.
+ *
+ * <p>
+ * This class can be extended by the generated code to provide
+ * type-safe unmarshall methods.
+ *
+ * @author
+ *  <a href="mailto:kohsuke.kawaguchi@sun.com">Kohsuke KAWAGUCHI</a>
+ */
+public final class UnmarshallerImpl extends AbstractUnmarshallerImpl implements ValidationEventHandler
+{
+    /** Owning {@link JAXBContext} */
+    protected final JAXBContextImpl context;
+
+    /**
+     * schema which will be used to validate during calls to unmarshal
+     */
+    private Schema schema;
+
+
+    public final UnmarshallingContext coordinator;
+
+    /** Unmarshaller.Listener */
+    private Listener externalListener;
+
+    /**
+     * The attachment unmarshaller used to support MTOM and swaRef.
+     */
+    private AttachmentUnmarshaller attachmentUnmarshaller;
+    private IDResolver idResolver = new DefaultIDResolver();
+
+    public UnmarshallerImpl( JAXBContextImpl context, AssociationMap assoc ) {
+        this.context = context;
+        this.coordinator = new UnmarshallingContext( this, assoc );
+
+        try {
+            setEventHandler(this);
+        } catch (JAXBException e) {
+            throw new AssertionError(e);    // impossible
+        }
+    }
+
+    public UnmarshallerHandler getUnmarshallerHandler() {
+        return getUnmarshallerHandler(true,null);
+    }
+
+    private SAXConnector getUnmarshallerHandler( boolean intern, JaxBeanInfo expectedType ) {
+        XmlVisitor h = createUnmarshallerHandler(null,false,expectedType);
+        if(intern)
+            h = new InterningXmlVisitor(h);
+        return new SAXConnector(h,null);
+    }
+
+    /**
+     * Creates and configures a new unmarshalling pipe line.
+     * Depending on the setting, we put a validator as a filter.
+     *
+     * @return
+     *      A component that implements both {@link UnmarshallerHandler}
+     *      and {@link ValidationEventHandler}. All the parsing errors
+     *      should be reported to this error handler for the unmarshalling
+     *      process to work correctly.
+     *
+     *      Also, returned handler expects all the XML names to be interned.
+     *
+     */
+    public final XmlVisitor createUnmarshallerHandler(InfosetScanner scanner, boolean inplace, JaxBeanInfo expectedType ) {
+
+        coordinator.reset(scanner,inplace,expectedType,idResolver);
+        XmlVisitor unmarshaller = coordinator;
+
+        // delegate to JAXP 1.3 for validation if the client provided a schema
+        if (schema != null)
+            unmarshaller = new ValidatingUnmarshaller(schema,unmarshaller);
+
+        if(attachmentUnmarshaller!=null && attachmentUnmarshaller.isXOPPackage())
+            unmarshaller = new MTOMDecorator(this,unmarshaller,attachmentUnmarshaller);
+
+        return unmarshaller;
+    }
+
+    private static final DefaultHandler dummyHandler = new DefaultHandler();
+
+    public static boolean needsInterning( XMLReader reader ) {
+        // attempt to set it to true, which could fail
+        try {
+            reader.setFeature("http://xml.org/sax/features/string-interning",true);
+        } catch (SAXException e) {
+            // if it fails that's fine. we'll work around on our side
+        }
+
+        try {
+            if( reader.getFeature("http://xml.org/sax/features/string-interning") )
+                return false;   // no need for intern
+        } catch (SAXException e) {
+            // unrecognized/unsupported
+        }
+        // otherwise we need intern
+        return true;
+    }
+
+    protected Object unmarshal( XMLReader reader, InputSource source ) throws JAXBException {
+        return unmarshal0(reader,source,null);
+    }
+
+    protected <T> JAXBElement<T> unmarshal( XMLReader reader, InputSource source, Class<T> expectedType ) throws JAXBException {
+        if(expectedType==null)
+            throw new IllegalArgumentException();
+        return (JAXBElement)unmarshal0(reader,source,getBeanInfo(expectedType));
+    }
+    private Object unmarshal0( XMLReader reader, InputSource source, JaxBeanInfo expectedType ) throws JAXBException {
+
+        SAXConnector connector = getUnmarshallerHandler(needsInterning(reader),expectedType);
+
+        reader.setContentHandler(connector);
+        // saxErrorHandler will be set by the getUnmarshallerHandler method.
+        // configure XMLReader so that the error will be sent to it.
+        // This is essential for the UnmarshallerHandler to be able to abort
+        // unmarshalling when an error is found.
+        //
+        // Note that when this XMLReader is provided by the client code,
+        // it might be already configured to call a client error handler.
+        // This will clobber such handler, if any.
+        //
+        // Ryan noted that we might want to report errors to such a client
+        // error handler as well.
+        reader.setErrorHandler(coordinator);
+
+        try {
+            reader.parse(source);
+        } catch( IOException e ) {
+            throw new UnmarshalException(e);
+        } catch( SAXException e ) {
+            throw createUnmarshalException(e);
+        }
+
+        Object result = connector.getResult();
+
+        // avoid keeping unnecessary references too long to let the GC
+        // reclaim more memory.
+        // setting null upsets some parsers, so use a dummy instance instead.
+        reader.setContentHandler(dummyHandler);
+        reader.setErrorHandler(dummyHandler);
+
+        return result;
+    }
+
+    @Override
+    public <T> JAXBElement<T> unmarshal( Source source, Class<T> expectedType ) throws JAXBException {
+        if(source instanceof SAXSource) {
+            SAXSource ss = (SAXSource)source;
+
+            XMLReader reader = ss.getXMLReader();
+            if( reader == null )
+                reader = getXMLReader();
+
+            return unmarshal( reader, ss.getInputSource(), expectedType );
+        }
+        if(source instanceof StreamSource) {
+            return unmarshal( getXMLReader(), streamSourceToInputSource((StreamSource)source), expectedType );
+        }
+        if(source instanceof DOMSource)
+            return unmarshal( ((DOMSource)source).getNode(), expectedType );
+
+        // we don't handle other types of Source
+        throw new IllegalArgumentException();
+    }
+
+    public Object unmarshal0( Source source, JaxBeanInfo expectedType ) throws JAXBException {
+        if(source instanceof SAXSource) {
+            SAXSource ss = (SAXSource)source;
+
+            XMLReader reader = ss.getXMLReader();
+            if( reader == null )
+                reader = getXMLReader();
+
+            return unmarshal0( reader, ss.getInputSource(), expectedType );
+        }
+        if(source instanceof StreamSource) {
+            return unmarshal0( getXMLReader(), streamSourceToInputSource((StreamSource)source), expectedType );
+        }
+        if(source instanceof DOMSource)
+            return unmarshal0( ((DOMSource)source).getNode(), expectedType );
+
+        // we don't handle other types of Source
+        throw new IllegalArgumentException();
+    }
+
+
+    public final ValidationEventHandler getEventHandler() {
+        try {
+            return super.getEventHandler();
+        } catch (JAXBException e) {
+            // impossible
+            throw new AssertionError();
+        }
+    }
+
+    @Override
+    public <T> JAXBElement<T> unmarshal(Node node, Class<T> expectedType) throws JAXBException {
+        if(expectedType==null)
+            throw new IllegalArgumentException();
+        return (JAXBElement)unmarshal0(node,getBeanInfo(expectedType));
+    }
+
+    public final Object unmarshal( Node node ) throws JAXBException {
+        return unmarshal0(node,null);
+    }
+
+    // just to make the the test harness happy by making this method accessible
+    @Deprecated
+    public final Object unmarshal( SAXSource source ) throws JAXBException {
+        return super.unmarshal(source);
+    }
+
+    public final Object unmarshal0( Node node, JaxBeanInfo expectedType ) throws JAXBException {
+        try {
+            final DOMScanner scanner = new DOMScanner();
+
+            InterningXmlVisitor handler = new InterningXmlVisitor(createUnmarshallerHandler(null,false,expectedType));
+            scanner.setContentHandler(new SAXConnector(handler,scanner));
+
+            if(node instanceof Element)
+                scanner.scan((Element)node);
+            else
+            if(node instanceof Document)
+                scanner.scan((Document)node);
+            else
+                // no other type of input is supported
+                throw new IllegalArgumentException();
+
+            return handler.getContext().getResult();
+        } catch( SAXException e ) {
+            throw createUnmarshalException(e);
+        }
+    }
+
+    @Override
+    public Object unmarshal(XMLStreamReader reader) throws JAXBException {
+        return unmarshal0(reader,null);
+    }
+
+    @Override
+    public <T> JAXBElement<T> unmarshal(XMLStreamReader reader, Class<T> expectedType) throws JAXBException {
+        if(expectedType==null)
+            throw new IllegalArgumentException();
+        return (JAXBElement)unmarshal0(reader,getBeanInfo(expectedType));
+    }
+
+    public Object unmarshal0(XMLStreamReader reader, JaxBeanInfo expectedType) throws JAXBException {
+        if (reader == null) {
+            throw new IllegalArgumentException(
+                Messages.format(Messages.NULL_READER));
+        }
+
+        int eventType = reader.getEventType();
+        if (eventType != XMLStreamConstants.START_ELEMENT
+            && eventType != XMLStreamConstants.START_DOCUMENT) {
+            // TODO: convert eventType into event name
+            throw new IllegalStateException(
+                Messages.format(Messages.ILLEGAL_READER_STATE,eventType));
+        }
+
+        XmlVisitor h = createUnmarshallerHandler(null,false,expectedType);
+        StAXConnector connector=StAXStreamConnector.create(reader,h);
+
+        try {
+            connector.bridge();
+        } catch (XMLStreamException e) {
+            throw handleStreamException(e);
+        }
+
+        return h.getContext().getResult();
+    }
+
+    @Override
+    public <T> JAXBElement<T> unmarshal(XMLEventReader reader, Class<T> expectedType) throws JAXBException {
+        if(expectedType==null)
+            throw new IllegalArgumentException();
+        return (JAXBElement)unmarshal0(reader,getBeanInfo(expectedType));
+    }
+
+    @Override
+    public Object unmarshal(XMLEventReader reader) throws JAXBException {
+        return unmarshal0(reader,null);
+    }
+
+    private Object unmarshal0(XMLEventReader reader,JaxBeanInfo expectedType) throws JAXBException {
+        if (reader == null) {
+            throw new IllegalArgumentException(
+                    Messages.format(Messages.NULL_READER));
+        }
+
+        try {
+            XMLEvent event = reader.peek();
+
+            if (!event.isStartElement() && !event.isStartDocument()) {
+                // TODO: convert event into event name
+                throw new IllegalStateException(
+                    Messages.format(
+                        Messages.ILLEGAL_READER_STATE,event.getEventType()));
+            }
+
+            // Quick hack until SJSXP fixes 6270116
+            boolean isZephyr = reader.getClass().getName().equals("com.sun.xml.internal.stream.XMLReaderImpl");
+            XmlVisitor h = createUnmarshallerHandler(null,false,expectedType);
+            if(!isZephyr)
+                h = new InterningXmlVisitor(h);
+            new StAXEventConnector(reader,h).bridge();
+            return h.getContext().getResult();
+        } catch (XMLStreamException e) {
+            throw handleStreamException(e);
+        }
+    }
+
+    public Object unmarshal0( InputStream input, JaxBeanInfo expectedType ) throws JAXBException {
+        return unmarshal0(getXMLReader(),new InputSource(input),expectedType);
+    }
+
+    private static JAXBException handleStreamException(XMLStreamException e) {
+        // StAXStreamConnector wraps SAXException to XMLStreamException.
+        // XMLStreamException doesn't print its nested stack trace when it prints
+        // its stack trace, so if we wrap XMLStreamException in JAXBException,
+        // it becomes harder to find out the real problem.
+        // So we unwrap them here. But we don't want to unwrap too eagerly, because
+        // that could throw away some meaningful exception information.
+        Throwable ne = e.getNestedException();
+        if(ne instanceof JAXBException)
+            return (JAXBException)ne;
+        if(ne instanceof SAXException)
+            return new UnmarshalException(ne);
+        return new UnmarshalException(e);
+    }
+
+    public Object getProperty(String name) throws PropertyException {
+        if(name.equals(IDResolver.class.getName())) {
+            return idResolver;
+        }
+        return super.getProperty(name);
+    }
+
+    public void setProperty(String name, Object value) throws PropertyException {
+        if(name.equals(FACTORY)) {
+            coordinator.setFactories(value);
+            return;
+        }
+        if(name.equals(IDResolver.class.getName())) {
+            idResolver = (IDResolver)value;
+            return;
+        }
+        super.setProperty(name, value);
+    }
+
+    public static final String FACTORY = "com.sun.xml.internal.bind.ObjectFactory";
+
+    @Override
+    public void setSchema(Schema schema) {
+        this.schema = schema;
+    }
+
+    @Override
+    public Schema getSchema() {
+        return schema;
+    }
+
+    @Override
+    public AttachmentUnmarshaller getAttachmentUnmarshaller() {
+        return attachmentUnmarshaller;
+    }
+
+    @Override
+    public void setAttachmentUnmarshaller(AttachmentUnmarshaller au) {
+        this.attachmentUnmarshaller = au;
+    }
+
+    /**
+     * @deprecated since 2.0
+     */
+    @Override
+    public boolean isValidating() {
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * @deprecated since 2.0
+     */
+    @Override
+    public void setValidating(boolean validating) {
+        throw new UnsupportedOperationException();
+    }
+
+    @Override
+    public <A extends XmlAdapter> void setAdapter(Class<A> type, A adapter) {
+        if(type==null)
+            throw new IllegalArgumentException();
+        coordinator.putAdapter(type,adapter);
+    }
+
+    @Override
+    public <A extends XmlAdapter> A getAdapter(Class<A> type) {
+        if(type==null)
+            throw new IllegalArgumentException();
+        if(coordinator.containsAdapter(type))
+            // so as not to create a new instance when this method is called
+            return coordinator.getAdapter(type);
+        else
+            return null;
+    }
+
+    // opening up for public use
+    public UnmarshalException createUnmarshalException( SAXException e ) {
+        return super.createUnmarshalException(e);
+    }
+
+
+    /**
+     * Default error handling behavior fot {@link Unmarshaller}.
+     */
+    public boolean handleEvent(ValidationEvent event) {
+        return event.getSeverity()!=ValidationEvent.FATAL_ERROR;
+    }
+
+    private static InputSource streamSourceToInputSource( StreamSource ss ) {
+        InputSource is = new InputSource();
+        is.setSystemId( ss.getSystemId() );
+        is.setByteStream( ss.getInputStream() );
+        is.setCharacterStream( ss.getReader() );
+
+        return is;
+    }
+
+    public <T> JaxBeanInfo<T> getBeanInfo(Class<T> clazz) throws JAXBException {
+        return context.getBeanInfo(clazz,true);
+    }
+
+    @Override
+    public Listener getListener() {
+        return externalListener;
+    }
+
+    @Override
+    public void setListener(Listener listener) {
+        externalListener = listener;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/UnmarshallingContext.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/UnmarshallingContext.java
new file mode 100644
index 0000000..cef1283
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/UnmarshallingContext.java
@@ -0,0 +1,1098 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.concurrent.Callable;
+
+import javax.xml.XMLConstants;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.UnmarshalException;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.ValidationEventLocator;
+import javax.xml.bind.helpers.ValidationEventImpl;
+import javax.xml.bind.helpers.ValidationEventLocatorImpl;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.namespace.QName;
+
+import com.sun.istack.internal.NotNull;
+import com.sun.istack.internal.SAXParseException2;
+import com.sun.xml.internal.bind.IDResolver;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.unmarshaller.InfosetScanner;
+import com.sun.xml.internal.bind.v2.ClassFactory;
+import com.sun.xml.internal.bind.v2.runtime.AssociationMap;
+import com.sun.xml.internal.bind.v2.runtime.Coordinator;
+import com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.LocatorImpl;
+
+/**
+ * Center of the unmarshalling.
+ *
+ * <p>
+ * This object is responsible for coordinating {@link Loader}s to
+ * perform the whole unmarshalling.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class UnmarshallingContext extends Coordinator
+    implements NamespaceContext, ValidationEventHandler, ErrorHandler, XmlVisitor, XmlVisitor.TextPredictor {
+
+    /**
+     * Root state.
+     */
+    private final State root;
+
+    /**
+     * The currently active state.
+     */
+    private State current;
+
+    private @NotNull LocatorEx locator = DUMMY_INSTANCE;
+
+    /** Root object that is being unmarshalled. */
+    private Object result;
+
+    /**
+     * If non-null, this unmarshaller will unmarshal {@code JAXBElement<EXPECTEDTYPE>}
+     * regardless of the tag name, as opposed to deciding the root object by using
+     * the tag name.
+     *
+     * The property has a package-level access, because we cannot copy this value
+     * to {@link UnmarshallingContext} when it is created. The property
+     * on {@link Unmarshaller} could be changed after the handler is created.
+     */
+    private JaxBeanInfo expectedType;
+
+    /**
+     * Handles ID/IDREF.
+     */
+    private IDResolver idResolver;
+
+    /**
+     * This flag is set to true at the startDocument event
+     * and false at the endDocument event.
+     *
+     * Until the first document is unmarshalled, we don't
+     * want to return an object. So this variable is initialized
+     * to true.
+     */
+    private boolean isUnmarshalInProgress = true;
+    private boolean aborted = false;
+
+    public final UnmarshallerImpl parent;
+
+    /**
+     * If the unmarshaller is doing associative unmarshalling,
+     * this field is initialized to non-null.
+     */
+    private final AssociationMap assoc;
+
+    /**
+     * Indicates whether we are doing in-place unmarshalling
+     * or not.
+     *
+     * <p>
+     * This flag is unused when {@link #assoc}==null.
+     * If it's non-null, then <tt>true</tt> indicates
+     * that we are doing in-place associative unmarshalling.
+     * If <tt>false</tt>, then we are doing associative unmarshalling
+     * without object reuse.
+     */
+    private boolean isInplaceMode;
+
+    /**
+     * This object is consulted to get the element object for
+     * the current element event.
+     *
+     * This is used when we are building an association map.
+     */
+    private InfosetScanner scanner;
+
+    private Object currentElement;
+
+    /**
+     * @see XmlVisitor#startDocument(LocatorEx, NamespaceContext)
+     */
+    private NamespaceContext environmentNamespaceContext;
+
+
+    /**
+     * State information for each element.
+     */
+    public final class State {
+        /**
+         * Loader that owns this element.
+         */
+        public Loader loader;
+        /**
+         * Once {@link #loader} is completed, this receiver
+         * receives the result.
+         */
+        public Receiver receiver;
+
+        public Intercepter intercepter;
+
+
+        /**
+         * Object being unmarshalled by this {@link #loader}.
+         */
+        public Object target;
+
+        /**
+         * Hack for making JAXBElement unmarshalling work.
+         */
+        public Object backup;
+
+        /**
+         * Number of {@link UnmarshallingContext#nsBind}s declared thus far.
+         * (The value of {@link UnmarshallingContext#nsLen} when this state is pushed.
+         */
+        private int numNsDecl;
+
+        /**
+         * If this element has an element default value.
+         *
+         * This should be set by either a parent {@link Loader} when
+         * {@link Loader#childElement(State, TagName)} is called
+         * or by a child {@link Loader} when
+         * {@link Loader#startElement(State, TagName)} is called.
+         */
+        public String elementDefaultValue;
+
+        /**
+         * {@link State} for the parent element
+         *
+         * {@link State} objects form a doubly linked list.
+         */
+        public final State prev;
+        private State next;
+
+        /**
+         * Gets the context.
+         */
+        public UnmarshallingContext getContext() {
+            return UnmarshallingContext.this;
+        }
+
+        private State(State prev) {
+            this.prev = prev;
+            if(prev!=null)
+                prev.next = this;
+        }
+
+        private void push() {
+            if(next==null)
+                allocateMoreStates();
+            State n = next;
+            n.numNsDecl = nsLen;
+            current = n;
+        }
+
+        private void pop() {
+            assert prev!=null;
+            loader = null;
+            receiver = null;
+            intercepter = null;
+            elementDefaultValue = null;
+            target = null;
+            current = prev;
+        }
+    }
+
+    /**
+     * Stub to the user-specified factory method.
+     */
+    private static class Factory {
+        private final Object factorInstance;
+        private final Method method;
+
+        public Factory(Object factorInstance, Method method) {
+            this.factorInstance = factorInstance;
+            this.method = method;
+        }
+
+        public Object createInstance() throws SAXException {
+            try {
+                return method.invoke(factorInstance);
+            } catch (IllegalAccessException e) {
+                getInstance().handleError(e,false);
+            } catch (InvocationTargetException e) {
+                getInstance().handleError(e,false);
+            }
+            return null; // can never be executed
+        }
+    }
+
+
+    /**
+     * Creates a new unmarshaller.
+     *
+     * @param assoc
+     *      Must be both non-null when the unmarshaller does the
+     *      in-place unmarshalling. Otherwise must be both null.
+     */
+    public UnmarshallingContext( UnmarshallerImpl _parent, AssociationMap assoc) {
+        this.parent = _parent;
+        this.assoc = assoc;
+        this.root = this.current = new State(null);
+        allocateMoreStates();
+    }
+
+    public void reset(InfosetScanner scanner,boolean isInplaceMode, JaxBeanInfo expectedType, IDResolver idResolver) {
+        this.scanner = scanner;
+        this.isInplaceMode = isInplaceMode;
+        this.expectedType = expectedType;
+        this.idResolver = idResolver;
+    }
+
+    public JAXBContextImpl getJAXBContext() {
+        return parent.context;
+    }
+
+    public State getCurrentState() {
+        return current;
+    }
+
+    /**
+     * Allocates a few more {@link State}s.
+     *
+     * Allocating multiple {@link State}s at once allows those objects
+     * to be allocated near each other, which reduces the working set
+     * of CPU. It improves the chance the relevant data is in the cache.
+     */
+    private void allocateMoreStates() {
+        // this method should be used only when we run out of a state.
+        assert current.next==null;
+
+        State s = current;
+        for( int i=0; i<8; i++ )
+            s = new State(s);
+    }
+
+    /**
+     * User-specified factory methods.
+     */
+    private final Map<Class,Factory> factories = new HashMap<Class, Factory>();
+
+    public void setFactories(Object factoryInstances) {
+        factories.clear();
+        if(factoryInstances==null) {
+            return;
+        }
+        if(factoryInstances instanceof Object[]) {
+            for( Object factory : (Object[])factoryInstances ) {
+                // look for all the public methods inlcuding derived ones
+                addFactory(factory);
+            }
+        } else {
+            addFactory(factoryInstances);
+        }
+    }
+
+    private void addFactory(Object factory) {
+        for( Method m : factory.getClass().getMethods() ) {
+            // look for methods whose signature is T createXXX()
+            if(!m.getName().startsWith("create"))
+                continue;
+            if(m.getParameterTypes().length>0)
+                continue;
+
+            Class type = m.getReturnType();
+
+            factories.put(type,new Factory(factory,m));
+        }
+    }
+
+    public void startDocument(LocatorEx locator, NamespaceContext nsContext) throws SAXException {
+        this.locator = locator;
+        this.environmentNamespaceContext = nsContext;
+        // reset the object
+        result = null;
+        current = root;
+
+        patchersLen=0;
+        aborted = false;
+        isUnmarshalInProgress = true;
+        nsLen=0;
+
+        startPrefixMapping("",""); // by default, the default ns is bound to "".
+
+        setThreadAffinity();
+
+        if(expectedType!=null)
+            root.loader = EXPECTED_TYPE_ROOT_LOADER;
+        else
+            root.loader = DEFAULT_ROOT_LOADER;
+
+        idResolver.startDocument(this);
+    }
+
+    public void startElement(TagName tagName) throws SAXException {
+        pushCoordinator();
+        try {
+            _startElement(tagName);
+        } finally {
+            popCoordinator();
+        }
+    }
+
+    private void _startElement(TagName tagName) throws SAXException {
+
+        // remember the current element if we are interested in it.
+        // because the inner peer might not be found while we consume
+        // the enter element token, we need to keep this information
+        // longer than this callback. That's why we assign it to a field.
+        if( assoc!=null )
+            currentElement = scanner.getCurrentElement();
+
+        Loader h = current.loader;
+        current.push();
+
+        // tell the parent about the new child
+        h.childElement(current,tagName);
+        assert current.loader!=null;   // the childElement should register this
+        // and tell the new child that you are activated
+        current.loader.startElement(current,tagName);
+    }
+
+    public void text(CharSequence pcdata) throws SAXException {
+        State cur = current;
+        pushCoordinator();
+        try {
+            if(cur.elementDefaultValue!=null) {
+                if(pcdata.length()==0) {
+                    // send the default value into the unmarshaller instead
+                    pcdata = cur.elementDefaultValue;
+                }
+            }
+            cur.loader.text(cur,pcdata);
+        } finally {
+            popCoordinator();
+        }
+    }
+
+    public final void endElement(TagName tagName) throws SAXException {
+        pushCoordinator();
+        try {
+            State child = current;
+
+            // tell the child that your time is up
+            child.loader.leaveElement(child,tagName);
+
+            // child.pop will erase them so store them now
+            Object target = child.target;
+            Receiver recv = child.receiver;
+            Intercepter intercepter = child.intercepter;
+            child.pop();
+
+            // then let the parent know
+            if(intercepter!=null)
+                target = intercepter.intercept(current,target);
+            if(recv!=null)
+                recv.receive(current,target);
+        } finally {
+            popCoordinator();
+        }
+    }
+
+    public void endDocument() throws SAXException {
+        runPatchers();
+        idResolver.endDocument();
+
+        isUnmarshalInProgress = false;
+        currentElement = null;
+        locator = DUMMY_INSTANCE;
+        environmentNamespaceContext = null;
+
+        // at the successful completion, scope must be all closed
+        assert root==current;
+
+        resetThreadAffinity();
+    }
+
+    /**
+     * You should be always calling this through {@link TextPredictor}.
+     */
+    @Deprecated
+    public boolean expectText() {
+        return current.loader.expectText;
+    }
+
+    /**
+     * You should be always getting {@link TextPredictor} from {@link XmlVisitor}.
+     */
+    @Deprecated
+    public TextPredictor getPredictor() {
+        return this;
+    }
+
+    public UnmarshallingContext getContext() {
+        return this;
+    }
+
+    /**
+     * Gets the result of the unmarshalling
+     */
+    public Object getResult() throws UnmarshalException {
+        if(isUnmarshalInProgress)
+            throw new IllegalStateException();
+
+        if(!aborted)       return result;
+
+        // there was an error.
+        throw new UnmarshalException((String)null);
+    }
+
+    /**
+     * Creates a new instance of the specified class.
+     * In the unmarshaller, we need to check the user-specified factory class.
+     */
+    public Object createInstance( Class<?> clazz ) throws SAXException {
+        if(!factories.isEmpty()) {
+            Factory factory = factories.get(clazz);
+            if(factory!=null)
+                return factory.createInstance();
+        }
+        return ClassFactory.create(clazz);
+    }
+
+    /**
+     * Creates a new instance of the specified class.
+     * In the unmarshaller, we need to check the user-specified factory class.
+     */
+    public Object createInstance( JaxBeanInfo beanInfo ) throws SAXException {
+        if(!factories.isEmpty()) {
+            Factory factory = factories.get(beanInfo.jaxbType);
+            if(factory!=null)
+                return factory.createInstance();
+        }
+        try {
+            return beanInfo.createInstance(this);
+        } catch (IllegalAccessException e) {
+            Loader.reportError("Unable to create an instance of "+beanInfo.jaxbType.getName(),e,false);
+        } catch (InvocationTargetException e) {
+            Loader.reportError("Unable to create an instance of "+beanInfo.jaxbType.getName(),e,false);
+        } catch (InstantiationException e) {
+            Loader.reportError("Unable to create an instance of "+beanInfo.jaxbType.getName(),e,false);
+        }
+        return null;    // can never be here
+    }
+
+
+
+//
+//
+// error handling
+//
+//
+
+    /**
+     * Reports an error to the user, and asks if s/he wants
+     * to recover. If the canRecover flag is false, regardless
+     * of the client instruction, an exception will be thrown.
+     *
+     * Only if the flag is true and the user wants to recover from an error,
+     * the method returns normally.
+     *
+     * The thrown exception will be catched by the unmarshaller.
+     */
+    public void handleEvent(ValidationEvent event, boolean canRecover ) throws SAXException {
+        ValidationEventHandler eventHandler = parent.getEventHandler();
+
+        boolean recover = eventHandler.handleEvent(event);
+
+        // if the handler says "abort", we will not return the object
+        // from the unmarshaller.getResult()
+        if(!recover)    aborted = true;
+
+        if( !canRecover || !recover )
+            throw new SAXParseException2( event.getMessage(), locator,
+                new UnmarshalException(
+                    event.getMessage(),
+                    event.getLinkedException() ) );
+    }
+
+    public boolean handleEvent(ValidationEvent event) {
+        try {
+            // if the handler says "abort", we will not return the object.
+            boolean recover = parent.getEventHandler().handleEvent(event);
+            if(!recover)    aborted = true;
+            return recover;
+        } catch( RuntimeException re ) {
+            // if client event handler causes a runtime exception, then we
+            // have to return false.
+            return false;
+        }
+    }
+
+    /**
+     * Reports an exception found during the unmarshalling to the user.
+     * This method is a convenience method that calls into
+     * {@link #handleEvent(ValidationEvent, boolean)}
+     */
+    public void handleError(Exception e) throws SAXException {
+        handleError(e,true);
+    }
+
+    public void handleError(Exception e,boolean canRecover) throws SAXException {
+        handleEvent(new ValidationEventImpl(ValidationEvent.ERROR,e.getMessage(),locator.getLocation(),e),canRecover);
+    }
+
+    public void handleError(String msg) {
+        handleEvent(new ValidationEventImpl(ValidationEvent.ERROR,msg,locator.getLocation()));
+    }
+
+    protected ValidationEventLocator getLocation() {
+        return locator.getLocation();
+    }
+
+    /**
+     * Gets the current source location information in SAX {@link Locator}.
+     * <p>
+     * Sometimes the unmarshaller works against a different kind of XML source,
+     * making this information meaningless.
+     */
+    public LocatorEx getLocator() { return locator; }
+
+    /**
+     * Called when there's no corresponding ID value.
+     */
+    public void errorUnresolvedIDREF(Object bean, String idref) throws SAXException {
+        handleEvent( new ValidationEventImpl(
+            ValidationEvent.ERROR,
+            Messages.UNRESOLVED_IDREF.format(idref),
+            new ValidationEventLocatorImpl(bean)), true );
+    }
+
+
+//
+//
+// ID/IDREF related code
+//
+//
+    /**
+     * Submitted patchers in the order they've submitted.
+     * Many XML vocabulary doesn't use ID/IDREF at all, so we
+     * initialize it with null.
+     */
+    private Patcher[] patchers = null;
+    private int patchersLen = 0;
+
+    /**
+     * Adds a job that will be executed at the last of the unmarshalling.
+     * This method is used to support ID/IDREF feature, but it can be used
+     * for other purposes as well.
+     *
+     * @param   job
+     *      The run method of this object is called.
+     */
+    public void addPatcher( Patcher job ) {
+        // re-allocate buffer if necessary
+        if( patchers==null )
+            patchers = new Patcher[32];
+        if( patchers.length == patchersLen ) {
+            Patcher[] buf = new Patcher[patchersLen*2];
+            System.arraycopy(patchers,0,buf,0,patchersLen);
+            patchers = buf;
+        }
+        patchers[patchersLen++] = job;
+    }
+
+    /** Executes all the patchers. */
+    private void runPatchers() throws SAXException {
+        if( patchers!=null ) {
+            for( int i=0; i<patchersLen; i++ ) {
+                patchers[i].run();
+                patchers[i] = null; // free memory
+            }
+        }
+    }
+
+    /**
+     * Adds the object which is currently being unmarshalled
+     * to the ID table.
+     *
+     * @return
+     *      Returns the value passed as the parameter.
+     *      This is a hack, but this makes it easier for ID
+     *      transducer to do its job.
+     */
+    // TODO: what shall we do if the ID is already declared?
+    //
+    // throwing an exception is one way. Overwriting the previous one
+    // is another way. The latter allows us to process invalid documents,
+    // while the former makes it impossible to handle them.
+    //
+    // I prefer to be flexible in terms of invalid document handling,
+    // so chose not to throw an exception.
+    //
+    // I believe this is an implementation choice, not the spec issue.
+    // -kk
+    public String addToIdTable( String id ) throws SAXException {
+        // Hmm...
+        // in cases such as when ID is used as an attribute, or as @XmlValue
+        // the target wilil be current.target.
+        // but in some other cases, such as when ID is used as a child element
+        // or a value of JAXBElement, it's current.prev.target.
+        // I don't know if this detection logic is complete
+        Object o = current.target;
+        if(o==null)
+            o = current.prev.target;
+        idResolver.bind(id,o);
+        return id;
+    }
+
+    /**
+     * Looks up the ID table and gets associated object.
+     *
+     * <p>
+     * The exception thrown from {@link Callable#call()} means the unmarshaller should abort
+     * right away.
+     *
+     * @see IDResolver#resolve(String, Class)
+     */
+    public Callable getObjectFromId( String id, Class targetType ) throws SAXException {
+        return idResolver.resolve(id,targetType);
+    }
+
+//
+//
+// namespace binding maintainance
+//
+//
+    private String[] nsBind = new String[16];
+    private int nsLen=0;
+
+    public void startPrefixMapping( String prefix, String uri ) {
+        if(nsBind.length==nsLen) {
+            // expand the buffer
+            String[] n = new String[nsLen*2];
+            System.arraycopy(nsBind,0,n,0,nsLen);
+            nsBind=n;
+        }
+        nsBind[nsLen++] = prefix;
+        nsBind[nsLen++] = uri;
+    }
+    public void endPrefixMapping( String prefix ) {
+        nsLen-=2;
+    }
+    private String resolveNamespacePrefix( String prefix ) {
+        if(prefix.equals("xml"))
+            return "http://www.w3.org/XML/1998/namespace";
+
+        for( int i=nsLen-2; i>=0; i-=2 ) {
+            if(prefix.equals(nsBind[i]))
+                return nsBind[i+1];
+        }
+
+        if(environmentNamespaceContext!=null)
+            // temporary workaround until Zephyr fixes 6337180
+            return environmentNamespaceContext.getNamespaceURI(prefix.intern());
+
+        return null;
+    }
+
+    /**
+     * Returns a list of prefixes newly declared on the current element.
+     *
+     * @return
+     *      A possible zero-length array of prefixes. The default prefix
+     *      is represented by the empty string.
+     */
+    public String[] getNewlyDeclaredPrefixes() {
+        return getPrefixList( current.prev.numNsDecl );
+    }
+
+    /**
+     * Returns a list of all in-scope prefixes.
+     *
+     * @return
+     *      A possible zero-length array of prefixes. The default prefix
+     *      is represented by the empty string.
+     */
+    public String[] getAllDeclaredPrefixes() {
+        return getPrefixList( 2 );  // skip the default ""->"" mapping
+    }
+
+    private String[] getPrefixList( int startIndex ) {
+        int size = (current.numNsDecl - startIndex)/2;
+        String[] r = new String[size];
+        for( int i=0; i<r.length; i++ )
+            r[i] = nsBind[startIndex+i*2];
+        return r;
+    }
+
+
+    //
+    //  NamespaceContext2 implementation
+    //
+    public Iterator<String> getPrefixes(String uri) {
+        // TODO: could be implemented much faster
+        // wrap it into unmodifiable list so that the remove method
+        // will throw UnsupportedOperationException.
+        return Collections.unmodifiableList(
+            getAllPrefixesInList(uri)).iterator();
+    }
+
+    private List<String> getAllPrefixesInList(String uri) {
+        List<String> a = new ArrayList<String>();
+
+        if( uri==null )
+            throw new IllegalArgumentException();
+        if( uri.equals(XMLConstants.XML_NS_URI) ) {
+            a.add(XMLConstants.XML_NS_PREFIX);
+            return a;
+        }
+        if( uri.equals(XMLConstants.XMLNS_ATTRIBUTE_NS_URI) ) {
+            a.add(XMLConstants.XMLNS_ATTRIBUTE);
+            return a;
+        }
+
+        for( int i=nsLen-2; i>=0; i-=2 )
+            if(uri.equals(nsBind[i+1]))
+                if( getNamespaceURI(nsBind[i]).equals(nsBind[i+1]) )
+                    // make sure that this prefix is still effective.
+                    a.add(nsBind[i]);
+
+        return a;
+    }
+
+    public String getPrefix(String uri) {
+        if( uri==null )
+            throw new IllegalArgumentException();
+        if( uri.equals(XMLConstants.XML_NS_URI) )
+            return XMLConstants.XML_NS_PREFIX;
+        if( uri.equals(XMLConstants.XMLNS_ATTRIBUTE_NS_URI) )
+            return XMLConstants.XMLNS_ATTRIBUTE;
+
+        for( int i=nsLen-2; i>=0; i-=2 )
+            if(uri.equals(nsBind[i+1]))
+                if( getNamespaceURI(nsBind[i]).equals(nsBind[i+1]) )
+                    // make sure that this prefix is still effective.
+                    return nsBind[i];
+
+        if(environmentNamespaceContext!=null)
+            return environmentNamespaceContext.getPrefix(uri);
+
+        return null;
+    }
+
+    public String getNamespaceURI(String prefix) {
+        if (prefix == null)
+            throw new IllegalArgumentException();
+        if (prefix.equals(XMLConstants.XMLNS_ATTRIBUTE))
+            return XMLConstants.XMLNS_ATTRIBUTE_NS_URI;
+
+        return resolveNamespacePrefix(prefix);
+    }
+
+
+
+//
+//
+//
+// scope management
+//
+//
+//
+    private Scope[] scopes = new Scope[16];
+    /**
+     * Points to the top of the scope stack (=size-1).
+     */
+    private int scopeTop=0;
+
+    {
+        for( int i=0; i<scopes.length; i++ )
+            scopes[i] = new Scope(this);
+    }
+
+    /**
+     * Starts a new packing scope.
+     *
+     * <p>
+     * This method allocates a specified number of fresh {@link Scope} objects.
+     * They can be accessed by the {@link #getScope} method until the corresponding
+     * {@link #endScope} method is invoked.
+     *
+     * <p>
+     * A new scope will mask the currently active scope. Only one frame of {@link Scope}s
+     * can be accessed at any given time.
+     *
+     * @param frameSize
+     *      The # of slots to be allocated.
+     */
+    public void startScope(int frameSize) {
+        scopeTop += frameSize;
+
+        // reallocation
+        if(scopeTop>=scopes.length) {
+            Scope[] s = new Scope[Math.max(scopeTop+1,scopes.length*2)];
+            System.arraycopy(scopes,0,s,0,scopes.length);
+            for( int i=scopes.length; i<s.length; i++ )
+                s[i] = new Scope(this);
+            scopes = s;
+        }
+    }
+
+    /**
+     * Ends the current packing scope.
+     *
+     * <p>
+     * If any packing in progress will be finalized by this method.
+     *
+     * @param frameSize
+     *      The same size that gets passed to the {@link #startScope(int)}
+     *      method.
+     */
+    public void endScope(int frameSize) throws SAXException {
+        try {
+            for( ; frameSize>0; frameSize-- )
+                scopes[scopeTop--].finish();
+        } catch (AccessorException e) {
+            handleError(e);
+        }
+    }
+
+    /**
+     * Gets the currently active {@link Scope}.
+     *
+     * @param offset
+     *      a number between [0,frameSize)
+     *
+     * @return
+     *      always a valid {@link Scope} object.
+     */
+    public Scope getScope(int offset) {
+        return scopes[scopeTop-offset];
+    }
+
+
+
+//
+//
+//
+//
+//
+//
+//
+
+    private static final Loader DEFAULT_ROOT_LOADER = new DefaultRootLoader();
+    private static final Loader EXPECTED_TYPE_ROOT_LOADER = new ExpectedTypeRootLoader();
+
+    /**
+     * Root loader that uses the tag name and possibly its @xsi:type
+     * to decide how to start unmarshalling.
+     */
+    private static final class DefaultRootLoader extends Loader implements Receiver {
+        /**
+         * Receives the root element and determines how to start
+         * unmarshalling.
+         */
+        public void childElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+            JAXBContextImpl jaxbContext = state.getContext().getJAXBContext();
+
+            Loader loader = jaxbContext.selectRootLoader(state,ea);
+            if(loader!=null) {
+                state.loader = loader;
+                state.receiver = this;
+                return;
+            }
+
+            // the registry doesn't know about this element.
+            // try its xsi:type
+            JaxBeanInfo beanInfo = XsiTypeLoader.parseXsiType(state, ea);
+            if(beanInfo==null) {
+                // we don't even know its xsi:type
+                reportUnexpectedChildElement(ea,false);
+                return;
+            }
+
+            state.loader = beanInfo.getLoader(null,false);
+            state.prev.backup = new JAXBElement<Object>(ea.createQName(),Object.class,null);
+            state.receiver = this;
+        }
+
+        @Override
+        public Collection<QName> getExpectedChildElements() {
+            return getInstance().getJAXBContext().getValidRootNames();
+        }
+
+        public void receive(State state, Object o) {
+            if(state.backup!=null) {
+                ((JAXBElement<Object>)state.backup).setValue(o);
+                o = state.backup;
+            }
+            state.getContext().result = o;
+        }
+    }
+
+    /**
+     * Root loader that uses {@link UnmarshallingContext#expectedType}
+     * to decide how to start unmarshalling.
+     */
+    private static final class ExpectedTypeRootLoader extends Loader implements Receiver {
+        /**
+         * Receives the root element and determines how to start
+         * unmarshalling.
+         */
+        public void childElement(UnmarshallingContext.State state, TagName ea) {
+            UnmarshallingContext context = state.getContext();
+
+            // unmarshals the specified type
+            QName qn = new QName(ea.uri,ea.local);
+            state.prev.target = new JAXBElement(qn,context.expectedType.jaxbType,null,null);
+            state.receiver = this;
+            // this is bit wasteful, as in theory we should have each expectedType keep
+            // nillable version --- but that increases the combination from two to four,
+            // which adds the resident memory footprint. Since XsiNilLoader is small,
+            // I intentionally allocate a new instance freshly.
+            state.loader = new XsiNilLoader(context.expectedType.getLoader(null,true));
+        }
+
+        public void receive(State state, Object o) {
+            JAXBElement e = (JAXBElement)state.target;
+            e.setValue(o);
+            state.getContext().recordOuterPeer(e);
+            state.getContext().result = e;
+        }
+    }
+
+
+
+//
+// in-place unmarshalling related capabilities
+//
+    /**
+     * Notifies the context about the inner peer of the current element.
+     *
+     * <p>
+     * If the unmarshalling is building the association, the context
+     * will use this information. Otherwise it will be just ignored.
+     */
+    public void recordInnerPeer(Object innerPeer) {
+        if(assoc!=null)
+            assoc.addInner(currentElement,innerPeer);
+    }
+
+    /**
+     * Gets the inner peer JAXB object associated with the current element.
+     *
+     * @return
+     *      null if the current element doesn't have an inner peer,
+     *      or if we are not doing the in-place unmarshalling.
+     */
+    public Object getInnerPeer() {
+        if(assoc!=null && isInplaceMode)
+            return assoc.getInnerPeer(currentElement);
+        else
+            return null;
+    }
+
+    /**
+     * Notifies the context about the outer peer of the current element.
+     *
+     * <p>
+     * If the unmarshalling is building the association, the context
+     * will use this information. Otherwise it will be just ignored.
+     */
+    public void recordOuterPeer(Object outerPeer) {
+        if(assoc!=null)
+            assoc.addOuter(currentElement,outerPeer);
+    }
+
+    /**
+     * Gets the outer peer JAXB object associated with the current element.
+     *
+     * @return
+     *      null if the current element doesn't have an inner peer,
+     *      or if we are not doing the in-place unmarshalling.
+     */
+    public Object getOuterPeer() {
+        if(assoc!=null && isInplaceMode)
+            return assoc.getOuterPeer(currentElement);
+        else
+            return null;
+    }
+
+
+
+
+    /**
+     * Gets the xmime:contentType value for the current object.
+     *
+     * @see JAXBContextImpl#getXMIMEContentType(Object)
+     */
+    public String getXMIMEContentType() {
+        /*
+            this won't work when the class is like
+
+            class Foo {
+                @XmlValue Image img;
+            }
+
+            because the target will return Foo, not the class enclosing Foo
+            which will have xmime:contentType
+        */
+        Object t = current.target;
+        if(t==null)     return null;
+        return getJAXBContext().getXMIMEContentType(t);
+    }
+
+    /**
+     * When called from within the realm of the unmarshaller, this method
+     * returns the current {@link UnmarshallingContext} in charge.
+     */
+    public static UnmarshallingContext getInstance() {
+        return (UnmarshallingContext) Coordinator._getInstance();
+    }
+
+    private static final LocatorEx DUMMY_INSTANCE;
+
+    static {
+        LocatorImpl loc = new LocatorImpl();
+        loc.setPublicId(null);
+        loc.setSystemId(null);
+        loc.setLineNumber(-1);
+        loc.setColumnNumber(-1);
+        DUMMY_INSTANCE = new LocatorExWrapper(loc);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ValidatingUnmarshaller.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ValidatingUnmarshaller.java
new file mode 100644
index 0000000..dac6bd4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ValidatingUnmarshaller.java
@@ -0,0 +1,127 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.validation.Schema;
+import javax.xml.validation.ValidatorHandler;
+
+import com.sun.xml.internal.bind.v2.util.FatalAdapter;
+
+import org.xml.sax.SAXException;
+
+/**
+ * {@link XmlVisitor} decorator that validates the events by using JAXP validation API.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ValidatingUnmarshaller implements XmlVisitor, XmlVisitor.TextPredictor {
+
+    private final XmlVisitor next;
+    private final ValidatorHandler validator;
+
+    /**
+     * {@link TextPredictor} of the next {@link XmlVisitor}.
+     */
+    private final TextPredictor predictor;
+
+    private char[] buf = new char[256];
+
+    /**
+     * Creates a new instance of ValidatingUnmarshaller.
+     */
+    public ValidatingUnmarshaller( Schema schema, XmlVisitor next ) {
+        this.validator = schema.newValidatorHandler();
+        this.next = next;
+        this.predictor = next.getPredictor();
+        // if the user bothers to use a validator, make validation errors fatal
+        // so that it will abort unmarshalling.
+        validator.setErrorHandler(new FatalAdapter(getContext()));
+    }
+
+    public void startDocument(LocatorEx locator, NamespaceContext nsContext) throws SAXException {
+        // when nsContext is non-null, validator won't probably work correctly.
+        // should we warn?
+        validator.setDocumentLocator(locator);
+        validator.startDocument();
+        next.startDocument(locator,nsContext);
+    }
+
+    public void endDocument() throws SAXException {
+        validator.endDocument();
+        next.endDocument();
+    }
+
+    public void startElement(TagName tagName) throws SAXException {
+        validator.startElement(tagName.uri,tagName.local,tagName.getQname(),tagName.atts);
+        next.startElement(tagName);
+    }
+
+    public void endElement(TagName tagName ) throws SAXException {
+        validator.endElement(tagName.uri,tagName.local,tagName.getQname());
+        next.endElement(tagName);
+    }
+
+    public void startPrefixMapping(String prefix, String nsUri) throws SAXException {
+        validator.startPrefixMapping(prefix,nsUri);
+        next.startPrefixMapping(prefix,nsUri);
+    }
+
+    public void endPrefixMapping(String prefix) throws SAXException {
+        validator.endPrefixMapping(prefix);
+        next.endPrefixMapping(prefix);
+    }
+
+    public void text( CharSequence pcdata ) throws SAXException {
+        int len = pcdata.length();
+        if(buf.length<len) {
+            buf = new char[len];
+        }
+        for( int i=0;i<len; i++ )
+            buf[i] = pcdata.charAt(i);  // isn't this kinda slow?
+
+        validator.characters(buf,0,len);
+        if(predictor.expectText())
+            next.text(pcdata);
+    }
+
+    public UnmarshallingContext getContext() {
+        return next.getContext();
+    }
+
+    public TextPredictor getPredictor() {
+        return this;
+    }
+
+    // should be always invoked through TextPredictor
+    @Deprecated
+    public boolean expectText() {
+        // validator needs to make sure that there's no text
+        // even when it's not expected. So always have them
+        // send text, ignoring optimization hints from the unmarshaller
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ValuePropertyLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ValuePropertyLoader.java
new file mode 100644
index 0000000..ba8ad3f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/ValuePropertyLoader.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import com.sun.xml.internal.bind.v2.runtime.reflect.TransducedAccessor;
+import com.sun.xml.internal.bind.api.AccessorException;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Reads a text value and set to the current target.
+ *
+ * @see LeafPropertyLoader
+ * @author Kohsuke Kawaguchi
+ */
+public class ValuePropertyLoader extends Loader {
+
+    private final TransducedAccessor xacc;
+
+    public ValuePropertyLoader(TransducedAccessor xacc) {
+        super(true);
+        this.xacc = xacc;
+    }
+
+    public void text(UnmarshallingContext.State state, CharSequence text) throws SAXException {
+        try {
+            xacc.parse(state.target,text);
+        } catch (AccessorException e) {
+            handleGenericException(e,true);
+        } catch (RuntimeException e) {
+            handleParseConversionException(state,e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/WildcardLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/WildcardLoader.java
new file mode 100644
index 0000000..53340fc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/WildcardLoader.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.bind.annotation.DomHandler;
+
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Feed incoming events to {@link DomHandler} and builds a DOM tree.
+ *
+ * <p>
+ * Note that the SAXException returned by the ContentHandler is
+ * unreported. So we have to catch them and report it, then rethrow
+ * it if necessary.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class WildcardLoader extends ProxyLoader {
+
+    private final DomLoader dom;
+
+    private final WildcardMode mode;
+
+    public WildcardLoader(DomHandler dom, WildcardMode mode) {
+        this.dom = new DomLoader(dom);
+        this.mode = mode;
+    }
+
+    protected Loader selectLoader(UnmarshallingContext.State state, TagName ea) {
+        UnmarshallingContext context = state.getContext();
+
+        if(mode.allowTypedObject) {
+            Loader l = context.getJAXBContext().selectRootLoader(state,ea);
+            if(l!=null)
+                return l;
+        }
+        if(mode.allowDom)
+            return dom;
+
+        // simply discard.
+        return Discarder.INSTANCE;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XmlVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XmlVisitor.java
new file mode 100644
index 0000000..73b8a6d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XmlVisitor.java
@@ -0,0 +1,153 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.namespace.NamespaceContext;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Walks the XML document structure.
+ *
+ * Implemented by the unmarshaller and called by the API-specific connectors.
+ *
+ * <h2>Event Call Sequence</h2>
+ *
+ * The {@link XmlVisitor} expects the event callbacks in the following order:
+ * <pre>
+ * CALL SEQUENCE := startDocument ELEMENT endDocument
+ * ELEMENT       := startPrefixMapping ELEMENT endPrefixMapping
+ *               |  startElement BODY endElement
+ * BODY          := text? (ELEMENT text?)*
+ * </pre>
+ * Note in particular that text events may not be called in a row;
+ * consecutive characters (even those separated by PIs and comments)
+ * must be reported as one event, unlike SAX.
+ *
+ * <p>
+ * All namespace URIs, local names, and prefixes of element and attribute
+ * names must be interned. qnames need not be interned.
+ *
+ *
+ * <h2>Typed PCDATA</h2>
+ * For efficiency, JAXB RI defines a few {@link CharSequence} implementations
+ * that can be used as a parameter to the {@link #text(CharSequence)} method.
+ * For example, see {@link Base64Data}.
+ *
+ * <h2>Error Handling</h2>
+ * The visitor may throw {@link SAXException} to abort the unmarshalling process
+ * in the middle.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface XmlVisitor {
+    /**
+     * Notifies a start of the document.
+     *
+     * @param locator
+     *      This live object returns the location information as the parsing progresses.
+     *      must not be null.
+     * @param nsContext
+     *      Some broken XML APIs can't iterate all the in-scope namespace bindings,
+     *      which makes it impossible to emulate {@link #startPrefixMapping(String, String)} correctly
+     *      when unmarshalling a subtree. Connectors that use such an API can
+     *      pass in additional {@link NamespaceContext} object that knows about the
+     *      in-scope namespace bindings. Otherwise (and normally) it is null.
+     *
+     *      <p>
+     *      Ideally this object should be immutable and only represent the namespace URI bindings
+     *      in the context (those done above the element that JAXB started unmarshalling),
+     *      but it can also work even if it changes as the parsing progress (to include
+     *      namespaces declared on the current element being parsed.)
+     */
+    void startDocument(LocatorEx locator, NamespaceContext nsContext) throws SAXException;
+    void endDocument() throws SAXException;
+
+    /**
+     * Notifies a start tag of a new element.
+     *
+     * namespace URIs and local names must be interned.
+     */
+    void startElement(TagName tagName) throws SAXException;
+    void endElement(TagName tagName) throws SAXException;
+
+    /**
+     * Called before {@link #startElement} event to notify a new namespace binding.
+     */
+    void startPrefixMapping( String prefix, String nsUri ) throws SAXException;
+    /**
+     * Called after {@link #endElement} event to notify the end of a binding.
+     */
+    void endPrefixMapping( String prefix ) throws SAXException;
+
+    /**
+     * Text events.
+     *
+     * <p>
+     * The caller should consult {@link TextPredictor} to see
+     * if the unmarshaller is expecting any PCDATA. If the above is returning
+     * false, the caller is OK to skip any text in XML. The net effect is
+     * that we can ignore whitespaces quickly.
+     *
+     * @param pcdata
+     *      represents character data. This object can be mutable
+     *      (such as {@link StringBuilder}); it only needs to be fixed
+     *      while this method is executing.
+     */
+    void text( CharSequence pcdata ) throws SAXException;
+
+    /**
+     * Returns the {@link UnmarshallingContext} at the end of the chain.
+     *
+     * @return
+     *      always return the same object, so caching the result is recommended.
+     */
+    UnmarshallingContext getContext();
+
+    /**
+     * Gets the predictor that can be used for the caller to avoid
+     * calling {@link #text(CharSequence)} unnecessarily.
+     */
+    TextPredictor getPredictor();
+
+    interface TextPredictor {
+        /**
+         * Returns true if the visitor is expecting a text event as the next event.
+         *
+         * <p>
+         * This is primarily intended to be used for optimization to avoid buffering
+         * characters unnecessarily. If this method returns false and the connector
+         * sees whitespace it can safely skip it.
+         *
+         * <p>
+         * If this method returns true, all the whitespaces are considered significant
+         * and thus need to be reported as a {@link #text} event. Furthermore,
+         * if the element has no children (like &lt;foo/>), then it has to be reported
+         * an empty {@link #text} event.
+         */
+        boolean expectText();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XsiNilLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XsiNilLoader.java
new file mode 100644
index 0000000..9285e56
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XsiNilLoader.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.runtime.reflect.Accessor;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Looks for xsi:nil='true' and sets the target to null.
+ * Otherwise delegate to another handler.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class XsiNilLoader extends ProxyLoader {
+
+    private final Loader defaultLoader;
+
+    public XsiNilLoader(Loader defaultLoader) {
+        this.defaultLoader = defaultLoader;
+        assert defaultLoader!=null;
+    }
+
+    protected Loader selectLoader(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        int idx = ea.atts.getIndex(WellKnownNamespace.XML_SCHEMA_INSTANCE,"nil");
+
+        if(idx!=-1) {
+            String value = ea.atts.getValue(idx);
+            if(DatatypeConverterImpl._parseBoolean(value)) {
+                onNil(state);
+                return Discarder.INSTANCE;
+            }
+        }
+
+        return defaultLoader;
+    }
+
+    /**
+     * Called when xsi:nil='true' was found.
+     */
+    protected void onNil(UnmarshallingContext.State state) throws SAXException {
+    }
+
+
+
+    public static final class Single extends XsiNilLoader {
+        private final Accessor acc;
+        public Single(Loader l, Accessor acc) {
+            super(l);
+            this.acc = acc;
+        }
+
+        protected void onNil(UnmarshallingContext.State state) throws SAXException {
+            try {
+                acc.set(state.prev.target,null);
+            } catch (AccessorException e) {
+                handleGenericException(e,true);
+            }
+        }
+    }
+
+    public static final class Array extends XsiNilLoader {
+        public Array(Loader core) {
+            super(core);
+        }
+
+        protected void onNil(UnmarshallingContext.State state) {
+            // let the receiver add this to the lister
+            state.target = null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XsiTypeLoader.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XsiTypeLoader.java
new file mode 100644
index 0000000..0a3dd39
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/runtime/unmarshaller/XsiTypeLoader.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.runtime.unmarshaller;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.DatatypeConverterImpl;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import com.sun.xml.internal.bind.v2.runtime.JaxBeanInfo;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ * Looks at @xsi:type and forwards to the right {@link Loader}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class XsiTypeLoader extends Loader {
+
+    /**
+     * Use this when no @xsi:type was found.
+     */
+    private final JaxBeanInfo defaultBeanInfo;
+
+    public XsiTypeLoader(JaxBeanInfo defaultBeanInfo) {
+        super(true);
+        this.defaultBeanInfo = defaultBeanInfo;
+    }
+
+    public void startElement(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        JaxBeanInfo beanInfo = parseXsiType(state, ea);
+        if(beanInfo==null)
+            beanInfo = defaultBeanInfo;
+
+        Loader loader = beanInfo.getLoader(null,false);
+        state.loader = loader;
+        loader.startElement(state,ea);
+    }
+
+    /*pacakge*/ static JaxBeanInfo parseXsiType(UnmarshallingContext.State state, TagName ea) throws SAXException {
+        UnmarshallingContext context = state.getContext();
+        JaxBeanInfo beanInfo = null;
+
+        // look for @xsi:type
+        Attributes atts = ea.atts;
+        int idx = atts.getIndex(WellKnownNamespace.XML_SCHEMA_INSTANCE,"type");
+
+        if(idx>=0) {
+            // we'll consume the value only when it's a recognized value,
+            // so don't consume it just yet.
+            String value = atts.getValue(idx);
+
+            QName type = DatatypeConverterImpl._parseQName(value,context);
+            if(type==null) {
+                reportError(Messages.NOT_A_QNAME.format(value),true);
+            } else {
+                beanInfo = context.getJAXBContext().getGlobalType(type);
+                if(beanInfo==null) {
+                    String nearest = context.getJAXBContext().getNearestTypeName(type);
+                    if(nearest!=null)
+                        reportError(Messages.UNRECOGNIZED_TYPE_NAME_MAYBE.format(type,nearest),true);
+                    else
+                        reportError(Messages.UNRECOGNIZED_TYPE_NAME.format(type),true);
+                }
+                // TODO: resurrect the following check
+        //                    else
+        //                    if(!target.isAssignableFrom(actual)) {
+        //                        reportError(context,
+        //                            Messages.UNSUBSTITUTABLE_TYPE.format(value,actual.getName(),target.getName()),
+        //                            true);
+        //                        actual = targetBeanInfo;  // ditto
+        //                    }
+            }
+        }
+        return beanInfo;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/FoolProofResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/FoolProofResolver.java
new file mode 100644
index 0000000..75c9b2d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/FoolProofResolver.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.schemagen;
+
+import java.io.IOException;
+import java.util.logging.Logger;
+
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.transform.Result;
+
+import com.sun.xml.internal.bind.Util;
+
+/**
+ * {@link SchemaOutputResolver} that wraps the user-specified resolver
+ * and makes sure that it's following the contract.
+ *
+ * <p>
+ * This protects the rest of the {@link XmlSchemaGenerator} from client programming
+ * error.
+ */
+final class FoolProofResolver extends SchemaOutputResolver {
+    private static final Logger logger = Util.getClassLogger();
+    private final SchemaOutputResolver resolver;
+
+    public FoolProofResolver(SchemaOutputResolver resolver) {
+        assert resolver!=null;
+        this.resolver = resolver;
+    }
+
+    public Result createOutput(String namespaceUri, String suggestedFileName) throws IOException {
+        logger.entering(getClass().getName(),"createOutput",new Object[]{namespaceUri,suggestedFileName});
+        Result r = resolver.createOutput(namespaceUri,suggestedFileName);
+        if(r!=null) {
+            String sysId = r.getSystemId();
+            logger.finer("system ID = "+sysId);
+            if(sysId!=null) {
+                // TODO: make sure that the system Id is absolute
+
+                // don't use java.net.URI, because it doesn't allow some characters (like SP)
+                // which can legally used as file names.
+
+                // but don't use java.net.URL either, because it doesn't allow a made-up URI
+                // like kohsuke://foo/bar/zot
+            } else
+                throw new AssertionError("system ID cannot be null");
+        }
+        logger.exiting(getClass().getName(),"createOutput",r);
+        return r;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/Form.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/Form.java
new file mode 100644
index 0000000..dfb45b4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/Form.java
@@ -0,0 +1,112 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.schemagen;
+
+import javax.xml.bind.annotation.XmlNsForm;
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.LocalAttribute;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.LocalElement;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.Schema;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+
+/**
+ * Represents the form default value.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+enum Form {
+    QUALIFIED(XmlNsForm.QUALIFIED,true) {
+        void declare(String attName,Schema schema) {
+            schema._attribute(attName,"qualified");
+        }
+    },
+    UNQUALIFIED(XmlNsForm.UNQUALIFIED,false) {
+        void declare(String attName,Schema schema) {
+            // pointless, but required by the spec.
+            // people need to understand that @attributeFormDefault is a syntax sugar
+            schema._attribute(attName,"unqualified");
+        }
+    },
+    UNSET(XmlNsForm.UNSET,false) {
+        void declare(String attName,Schema schema) {
+        }
+    };
+
+    /**
+     * The same constant defined in the spec.
+     */
+    private final XmlNsForm xnf;
+
+    /**
+     * What's the effective value? UNSET means unqualified per XSD spec.)
+     */
+    public final boolean isEffectivelyQualified;
+
+    Form(XmlNsForm xnf, boolean effectivelyQualified) {
+        this.xnf = xnf;
+        this.isEffectivelyQualified = effectivelyQualified;
+    }
+
+    /**
+     * Writes the attribute on the generated &lt;schema> element.
+     */
+    abstract void declare(String attName, Schema schema);
+
+    /**
+     * Given the effective 'form' value, write (or suppress) the @form attribute
+     * on the generated XML.
+     */
+    public void writeForm(LocalElement e, QName tagName) {
+        _writeForm(e,tagName);
+    }
+
+    public void writeForm(LocalAttribute a, QName tagName) {
+        _writeForm(a,tagName);
+    }
+
+    private void _writeForm(TypedXmlWriter e, QName tagName) {
+        boolean qualified = tagName.getNamespaceURI().length()>0;
+
+        if(qualified && this!=QUALIFIED)
+            e._attribute("form","qualified");
+        else
+        if(!qualified && this==QUALIFIED)
+            e._attribute("form","unqualified");
+    }
+
+    /**
+     * Gets the constant the corresponds to the given {@link XmlNsForm}.
+     */
+    public static Form get(XmlNsForm xnf) {
+        for (Form v : values()) {
+            if(v.xnf==xnf)
+                return v;
+        }
+        throw new IllegalArgumentException();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/MultiMap.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/MultiMap.java
new file mode 100644
index 0000000..9e41737
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/MultiMap.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.schemagen;
+
+import java.util.TreeMap;
+import java.util.Map;
+
+/**
+ * A special {@link Map} that 'conceptually' stores a set of values for each key.
+ *
+ * <p>
+ * When multiple values are stored, however, this class doesn't let the caller
+ * see individual values, and instead it returns a specially designated "MANY" value,
+ * which is given as a parameter to the constructor.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class MultiMap<K extends Comparable<K>,V> extends TreeMap<K,V> {
+    private final V many;
+
+    public MultiMap(V many) {
+        this.many = many;
+    }
+
+    @Override
+    public V put(K key, V value) {
+        V old = super.put(key, value);
+        if(old!=null && !old.equals(value)) {
+            // different value stored
+            super.put(key,many);
+        }
+        return old;
+    }
+
+    @Override
+    public void putAll(Map<? extends K, ? extends V> map) {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/Util.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/Util.java
new file mode 100644
index 0000000..9a13e35
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/Util.java
@@ -0,0 +1,129 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.schemagen;
+
+
+/**
+ * TODO: JAX-WS dependes on this class - consider moving it somewhere more stable, Notify JAX-WS before modifying anything...
+ *
+ * Other miscellaneous utility methods.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class Util {
+    private Util() {}   // no instanciation please
+
+    /**
+     * Escape any characters that would cause the single arg constructor
+     * of java.net.URI to complain about illegal chars.
+     *
+     * @param s source string to be escaped
+     */
+    public static String escapeURI(String s) {
+        StringBuilder sb = new StringBuilder();
+        for( int i = 0; i < s.length(); i++ ) {
+            char c = s.charAt(i);
+            if(Character.isSpaceChar(c)) {
+                sb.append("%20");
+            } else {
+                sb.append(c);
+            }
+        }
+        return sb.toString();
+    }
+
+    /**
+     * Calculate the parent URI path of the given URI path.
+     *
+     * @param uriPath the uriPath (as returned by java.net.URI#getPath()
+     * @return the parent URI path of the given URI path
+     */
+    public static String getParentUriPath(String uriPath) {
+        int idx = uriPath.lastIndexOf('/');
+
+        if (uriPath.endsWith("/")) {
+            uriPath = uriPath.substring(0,idx); // trim trailing slash
+            idx = uriPath.lastIndexOf('/'); // move idx to parent context
+        }
+
+        return uriPath.substring(0, idx)+"/";
+    }
+
+    /**
+     * Calculate the normalized form of the given uriPath.
+     *
+     * For example:
+     *    /a/b/c/ -> /a/b/c/
+     *    /a/b/c  -> /a/b/
+     *    /a/     -> /a/
+     *    /a      -> /
+     *
+     * @param uriPath path of a URI (as returned by java.net.URI#getPath()
+     * @return the normalized uri path
+     */
+    public static String normalizeUriPath(String uriPath) {
+        if (uriPath.endsWith("/"))
+            return uriPath;
+
+        // the uri path should always have at least a leading slash,
+        // so no need to make sure that ( idx == -1 )
+        int idx = uriPath.lastIndexOf('/');
+        return uriPath.substring(0, idx+1);
+    }
+
+    /**
+     * determine if two Strings are equal ignoring case allowing null values
+     *
+     * @param s string 1
+     * @param t string 2
+     * @return true iff the given strings are equal ignoring case, false if they aren't
+     * equal or either of them are null.
+     */
+    public static boolean equalsIgnoreCase(String s, String t) {
+        if (s == t) return true;
+        if ((s != null) && (t != null)) {
+            return s.equalsIgnoreCase(t);
+        }
+        return false;
+    }
+
+    /**
+     * determine if two Strings are iqual allowing null values
+     *
+     * @param s string 1
+     * @param t string 2
+     * @return true iff the strings are equal, false if they aren't equal or either of
+     * them are null.
+     */
+    public static boolean equal(String s, String t) {
+        if (s == t) return true;
+        if ((s != null) && (t != null)) {
+            return s.equals(t);
+        }
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/XmlSchemaGenerator.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/XmlSchemaGenerator.java
new file mode 100644
index 0000000..1baa833
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/XmlSchemaGenerator.java
@@ -0,0 +1,1323 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.schemagen;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.Writer;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.LinkedHashSet;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeMap;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.activation.MimeType;
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Result;
+import javax.xml.transform.stream.StreamResult;
+
+import com.sun.istack.internal.Nullable;
+import com.sun.xml.internal.bind.Util;
+import com.sun.xml.internal.bind.api.CompositeStructure;
+import com.sun.xml.internal.bind.v2.TODO;
+import com.sun.xml.internal.bind.v2.WellKnownNamespace;
+import static com.sun.xml.internal.bind.v2.WellKnownNamespace.XML_SCHEMA;
+import com.sun.xml.internal.bind.v2.model.core.Adapter;
+import com.sun.xml.internal.bind.v2.model.core.ArrayInfo;
+import com.sun.xml.internal.bind.v2.model.core.AttributePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.ClassInfo;
+import com.sun.xml.internal.bind.v2.model.core.Element;
+import com.sun.xml.internal.bind.v2.model.core.ElementInfo;
+import com.sun.xml.internal.bind.v2.model.core.ElementPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.EnumConstant;
+import com.sun.xml.internal.bind.v2.model.core.EnumLeafInfo;
+import com.sun.xml.internal.bind.v2.model.core.MapPropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.NonElement;
+import com.sun.xml.internal.bind.v2.model.core.NonElementRef;
+import com.sun.xml.internal.bind.v2.model.core.PropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.ReferencePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfo;
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
+import com.sun.xml.internal.bind.v2.model.core.TypeRef;
+import com.sun.xml.internal.bind.v2.model.core.ValuePropertyInfo;
+import com.sun.xml.internal.bind.v2.model.core.WildcardMode;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.bind.v2.runtime.SwaRefAdapter;
+import static com.sun.xml.internal.bind.v2.schemagen.Util.*;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.Any;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.AttrDecls;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.ComplexExtension;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.ComplexType;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.ComplexTypeHost;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.ExplicitGroup;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.Import;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.List;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.LocalAttribute;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.LocalElement;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.Occurs;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.Schema;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.SimpleExtension;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.SimpleRestrictionModel;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.SimpleType;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.SimpleTypeHost;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.TopLevelAttribute;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.TopLevelElement;
+import com.sun.xml.internal.bind.v2.schemagen.xmlschema.TypeHost;
+import com.sun.xml.internal.txw2.TXW;
+import com.sun.xml.internal.txw2.TxwException;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.output.ResultFactory;
+
+/**
+ * Generates a set of W3C XML Schema documents from a set of Java classes.
+ *
+ * <p>
+ * A client must invoke methods in the following order:
+ * <ol>
+ *  <li>Create a new {@link XmlSchemaGenerator}
+ *  <li>Invoke {@link #add} methods, multiple times if necessary.
+ *  <li>Invoke {@link #write}
+ *  <li>Discard the {@link XmlSchemaGenerator}.
+ * </ol>
+ *
+ * @author Ryan Shoemaker
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public final class XmlSchemaGenerator<T,C,F,M> {
+
+    private static final Logger logger = Util.getClassLogger();
+
+    /**
+     * Java classes to be written, organized by their namespace.
+     *
+     * <p>
+     * We use a {@link TreeMap} here so that the suggested names will
+     * be consistent across JVMs.
+     *
+     * @see SchemaOutputResolver#createOutput(String, String)
+     */
+    private final Map<String,Namespace> namespaces = new TreeMap<String,Namespace>(NAMESPACE_COMPARATOR);
+
+    /** model navigator **/
+    private Navigator<T,C,F,M> navigator;
+
+    private final TypeInfoSet<T,C,F,M> types;
+
+    /**
+     * Representation for xs:string.
+     */
+    private final NonElement<T,C> stringType;
+
+    /**
+     * Represents xs:anyType.
+     */
+    private final NonElement<T,C> anyType;
+
+    public XmlSchemaGenerator( Navigator<T,C,F,M> navigator, TypeInfoSet<T,C,F,M> types ) {
+        this.navigator = navigator;
+        this.types = types;
+
+        this.stringType = types.getTypeInfo(navigator.ref(String.class));
+        this.anyType = types.getAnyTypeInfo();
+
+        // populate the object
+        for( ClassInfo<T,C> ci : types.beans().values() )
+            add(ci);
+        for( ElementInfo<T,C> ei1 : types.getElementMappings(null).values() )
+            add(ei1);
+        for( EnumLeafInfo<T,C> ei : types.enums().values() )
+            add(ei);
+        for( ArrayInfo<T,C> a : types.arrays().values())
+            add(a);
+    }
+
+    private Namespace getNamespace(String uri) {
+        Namespace n = namespaces.get(uri);
+        if(n==null)
+            namespaces.put(uri,n=new Namespace(uri));
+        return n;
+    }
+
+    /**
+     * Adds a new class to the list of classes to be written.
+     *
+     * <p>
+     * A {@link ClassInfo} may have two namespaces --- one for the element name
+     * and the other for the type name. If they are different, we put the same
+     * {@link ClassInfo} to two {@link Namespace}s.
+     */
+    public void add( ClassInfo<T,C> clazz ) {
+        assert clazz!=null;
+
+        String nsUri = null;
+
+        if(clazz.getClazz()==navigator.asDecl(CompositeStructure.class))
+            return; // this is a special class we introduced for JAX-WS that we *don't* want in the schema
+
+        if(clazz.isElement()) {
+            // put element -> type reference
+            nsUri = clazz.getElementName().getNamespaceURI();
+            Namespace ns = getNamespace(nsUri);
+            ns.classes.add(clazz);
+            ns.addDependencyTo(clazz.getTypeName());
+
+            // schedule writing this global element
+            add(clazz.getElementName(),false,clazz);
+        }
+
+        QName tn = clazz.getTypeName();
+        if(tn!=null) {
+            nsUri = tn.getNamespaceURI();
+        } else {
+            // anonymous type
+            if(nsUri==null)
+                return;
+        }
+
+        Namespace n = getNamespace(nsUri);
+        n.classes.add(clazz);
+
+        // search properties for foreign namespace references
+        for( PropertyInfo<T,C> p : clazz.getProperties()) {
+            n.processForeignNamespaces(p);
+            if (p instanceof AttributePropertyInfo) {
+                AttributePropertyInfo<T,C> ap = (AttributePropertyInfo<T,C>) p;
+                String aUri = ap.getXmlName().getNamespaceURI();
+                if(aUri.length()>0) {
+                    // global attribute
+                    getNamespace(aUri).addGlobalAttribute(ap);
+                    n.addDependencyTo(ap.getXmlName());
+                }
+            }
+            if (p instanceof ElementPropertyInfo) {
+                ElementPropertyInfo<T,C> ep = (ElementPropertyInfo<T,C>) p;
+                for (TypeRef<T,C> tref : ep.getTypes()) {
+                    String eUri = tref.getTagName().getNamespaceURI();
+                    if(eUri.length()>0 && !eUri.equals(n.uri)) {
+                        getNamespace(eUri).addGlobalElement(tref);
+                        n.addDependencyTo(tref.getTagName());
+                    }
+                }
+            }
+        }
+
+        // recurse on baseTypes to make sure that we can refer to them in the schema
+        ClassInfo<T,C> bc = clazz.getBaseClass();
+        if (bc != null)
+            add(bc);
+    }
+
+    /**
+     * Adds a new element to the list of elements to be written.
+     */
+    public void add( ElementInfo<T,C> elem ) {
+        assert elem!=null;
+
+        QName name = elem.getElementName();
+        Namespace n = getNamespace(name.getNamespaceURI());
+        n.elementDecls.put(name.getLocalPart(),n.new ElementWithType(true,elem.getContentType()));
+
+        // search for foreign namespace references
+        n.processForeignNamespaces(elem.getProperty());
+    }
+
+    public void add( EnumLeafInfo<T,C> envm ) {
+        assert envm!=null;
+
+        String nsUri = null;
+
+        if(envm.isElement()) {
+            // put element -> type reference
+            nsUri = envm.getElementName().getNamespaceURI();
+            Namespace ns = getNamespace(nsUri);
+            ns.enums.add(envm);
+            ns.addDependencyTo(envm.getTypeName());
+
+            // schedule writing this global element
+            add(envm.getElementName(),false,envm);
+        }
+
+        final QName typeName = envm.getTypeName();
+        if (typeName != null) {
+            nsUri = typeName.getNamespaceURI();
+        } else {
+            if(nsUri==null)
+                return; // anonymous type
+        }
+
+        Namespace n = getNamespace(nsUri);
+        n.enums.add(envm);
+
+        // search for foreign namespace references
+        n.addDependencyTo(envm.getBaseType().getTypeName());
+    }
+
+    public void add( ArrayInfo<T,C> a ) {
+        assert a!=null;
+
+        final String namespaceURI = a.getTypeName().getNamespaceURI();
+        Namespace n = getNamespace(namespaceURI);
+        n.arrays.add(a);
+
+        // search for foreign namespace references
+        n.addDependencyTo(a.getItemType().getTypeName());
+    }
+
+    /**
+     * Adds an additional element declaration.
+     *
+     * @param tagName
+     *      The name of the element declaration to be added.
+     * @param type
+     *      The type this element refers to.
+     *      Can be null, in which case the element refers to an empty anonymous complex type.
+     */
+    public void add( QName tagName, boolean isNillable, NonElement<T,C> type ) {
+
+        if(type!=null && type.getType()==navigator.ref(CompositeStructure.class))
+            return; // this is a special class we introduced for JAX-WS that we *don't* want in the schema
+
+
+        Namespace n = getNamespace(tagName.getNamespaceURI());
+        n.elementDecls.put(tagName.getLocalPart(), n.new ElementWithType(isNillable,type));
+
+        // search for foreign namespace references
+        if(type!=null)
+            n.addDependencyTo(type.getTypeName());
+    }
+
+    /**
+     * Write out the schema documents.
+     */
+    public void write(SchemaOutputResolver resolver) throws IOException {
+        if(resolver==null)
+            throw new IllegalArgumentException();
+
+        // make it fool-proof
+        resolver = new FoolProofResolver(resolver);
+
+        Map<Namespace,Result> out = new HashMap<Namespace,Result>();
+
+        // we create a Namespace object for the XML Schema namespace
+        // as a side-effect, but we don't want to generate it.
+        namespaces.remove(WellKnownNamespace.XML_SCHEMA);
+
+        // first create the outputs for all so that we can resolve references among
+        // schema files when we write
+        for( Namespace n : namespaces.values() ) {
+            final Result output = resolver.createOutput(n.uri,"schema"+(out.size()+1)+".xsd");
+            if(output!=null) {  // null result means no schema for that namespace
+                out.put(n,output);
+            }
+        }
+
+        // then write'em all
+        for( Namespace n : namespaces.values() ) {
+            Result result = out.get(n);
+            if(result!=null) {
+                n.writeTo( result, out );
+                if(result instanceof StreamResult) {
+                    OutputStream outputStream = ((StreamResult)result).getOutputStream();
+                    if(outputStream != null) {
+                        outputStream.close(); // fix for bugid: 6291301
+                    } else {
+                        final Writer writer = ((StreamResult)result).getWriter();
+                        if(writer != null) writer.close();
+                    }
+                }
+            }
+        }
+    }
+
+
+
+    /**
+     * Schema components are organized per namespace.
+     */
+    private class Namespace {
+        final String uri;
+
+        /**
+         * Other {@link Namespace}s that this namespace depends on.
+         */
+        private final Set<Namespace> depends = new LinkedHashSet<Namespace>();
+
+        /**
+         * If this schema refers to components from this schema by itself.
+         */
+        private boolean selfReference;
+
+        /**
+         * List of classes in this namespace.
+         */
+        private final Set<ClassInfo<T,C>> classes = new LinkedHashSet<ClassInfo<T,C>>();
+
+        /**
+         * Set of enums in this namespace
+         */
+        private final Set<EnumLeafInfo<T,C>> enums = new LinkedHashSet<EnumLeafInfo<T,C>>();
+
+        /**
+         * Set of arrays in this namespace
+         */
+        private final Set<ArrayInfo<T,C>> arrays = new LinkedHashSet<ArrayInfo<T,C>>();
+
+        /**
+         * Global attribute declarations keyed by their local names.
+         */
+        private final MultiMap<String,NonElement<T,C>> attributeDecls = new MultiMap<String,NonElement<T,C>>(stringType);
+
+        /**
+         * Global element declarations to be written, keyed by their local names.
+         */
+        private final MultiMap<String,ElementDeclaration> elementDecls =
+                new MultiMap<String,ElementDeclaration>(new ElementWithType(true,anyType));
+
+        private Form attributeFormDefault;
+        private Form elementFormDefault;
+
+        public Namespace(String uri) {
+            this.uri = uri;
+            assert !XmlSchemaGenerator.this.namespaces.containsKey(uri);
+            XmlSchemaGenerator.this.namespaces.put(uri,this);
+        }
+
+        /**
+         * Process the given PropertyInfo looking for references to namespaces that
+         * are foreign to the given namespace.  Any foreign namespace references
+         * found are added to the given namespaces dependency list and an &lt;import>
+         * is generated for it.
+         *
+         * @param p the PropertyInfo
+         */
+        private void processForeignNamespaces(PropertyInfo<T, C> p) {
+            // TODO: missing the correct handling of anonymous type,
+            // which requires recursive checks
+            for( TypeInfo<T, C> t : p.ref()) {
+                if(t instanceof Element) {
+                    addDependencyTo(((Element)t).getElementName());
+                }
+                if(t instanceof NonElement) {
+                    addDependencyTo(((NonElement)t).getTypeName());
+                }
+            }
+        }
+
+        private void addDependencyTo(@Nullable QName qname) {
+            // even though the Element interface says getElementName() returns non-null,
+            // ClassInfo always implements Element (even if an instance of ClassInfo might not be an Element).
+            // so this check is still necessary
+            if(qname==null)   return;
+
+            String nsUri = qname.getNamespaceURI();
+
+            if(nsUri.equals(XML_SCHEMA))
+                // no need to explicitly refer to XSD namespace
+                return;
+
+            if(nsUri.equals(uri)) {
+                selfReference = true;
+                return;
+            }
+
+            // found a type in a foreign namespace, so make sure we generate an import for it
+            depends.add(getNamespace(nsUri));
+        }
+
+        /**
+         * Writes the schema document to the specified result.
+         */
+        private void writeTo(Result result, Map<Namespace,Result> out) throws IOException {
+            try {
+                Schema schema = TXW.create(Schema.class,ResultFactory.createSerializer(result));
+
+                // additional namespace declarations to be made.
+                Map<String, String> xmlNs = types.getXmlNs(uri);
+
+                for (Map.Entry<String, String> e : xmlNs.entrySet()) {
+                    schema._namespace(e.getValue(),e.getKey());
+                }
+
+                attributeFormDefault = Form.get(types.getAttributeFormDefault(uri));
+                attributeFormDefault.declare("attributeFormDefault",schema);
+
+                elementFormDefault = Form.get(types.getElementFormDefault(uri));
+                // TODO: if elementFormDefault is UNSET, figure out the right default value to use
+                elementFormDefault.declare("elementFormDefault",schema);
+
+
+                // declare XML Schema namespace to be xs, but allow the user to override it.
+                // if 'xs' is used for other things, we'll just let TXW assign a random prefix
+                if(!xmlNs.containsValue(WellKnownNamespace.XML_SCHEMA)
+                && !xmlNs.containsKey("xs"))
+                    schema._namespace(WellKnownNamespace.XML_SCHEMA,"xs");
+                schema.version("1.0");
+
+                if(uri.length()!=0)
+                    schema.targetNamespace(uri);
+
+                // declare prefixes for them at this level, so that we can avoid redundant
+                // namespace declarations
+                for (Namespace ns : depends) {
+                    schema._namespace(ns.uri);
+                }
+
+                if(selfReference && uri.length()!=0) {
+                    // use common 'tns' prefix for the own namespace
+                    // if self-reference is needed
+                    schema._namespace(uri,"tns");
+                }
+
+                schema._pcdata(newline);
+
+                // refer to other schemas
+                for( Namespace n : depends ) {
+                    Import imp = schema._import();
+                    if(n.uri.length()!=0)
+                        imp.namespace(n.uri);
+                    imp.schemaLocation(relativize(out.get(n).getSystemId(),result.getSystemId()));
+                    schema._pcdata(newline);
+                }
+
+                // then write each component
+                for (Map.Entry<String,ElementDeclaration> e : elementDecls.entrySet()) {
+                    e.getValue().writeTo(e.getKey(),schema);
+                    schema._pcdata(newline);
+                }
+                for (ClassInfo<T, C> c : classes) {
+                    if (c.getTypeName()==null) {
+                        // don't generate anything if it's an anonymous type
+                        continue;
+                    }
+                    if(uri.equals(c.getTypeName().getNamespaceURI()))
+                        writeClass(c, schema);
+                    schema._pcdata(newline);
+                }
+                for (EnumLeafInfo<T, C> e : enums) {
+                    if (e.getTypeName()==null) {
+                        // don't generate anything if it's an anonymous type
+                        continue;
+                    }
+                    if(uri.equals(e.getTypeName().getNamespaceURI()))
+                        writeEnum(e,schema);
+                    schema._pcdata(newline);
+                }
+                for (ArrayInfo<T, C> a : arrays) {
+                    writeArray(a,schema);
+                    schema._pcdata(newline);
+                }
+                for (Map.Entry<String,NonElement<T,C>> e : attributeDecls.entrySet()) {
+                    TopLevelAttribute a = schema.attribute();
+                    a.name(e.getKey());
+                    writeTypeRef(a,e.getValue(),"type");
+                    schema._pcdata(newline);
+                }
+
+                // close the schema
+                schema.commit();
+            } catch( TxwException e ) {
+                logger.log(Level.INFO,e.getMessage(),e);
+                throw new IOException(e.getMessage());
+            }
+        }
+
+        /**
+         * Writes a type attribute (if the referenced type is a global type)
+         * or writes out the definition of the anonymous type in place (if the referenced
+         * type is not a global type.)
+         *
+         * Also provides processing for ID/IDREF, MTOM @xmime, and swa:ref
+         *
+         * ComplexTypeHost and SimpleTypeHost don't share an api for creating
+         * and attribute in a type-safe way, so we will compromise for now and
+         * use _attribute().
+         */
+        private void writeTypeRef(TypeHost th, NonElementRef<T, C> typeRef, String refAttName) {
+            // ID / IDREF handling
+            switch(typeRef.getSource().id()) {
+            case ID:
+                th._attribute(refAttName, new QName(WellKnownNamespace.XML_SCHEMA, "ID"));
+                return;
+            case IDREF:
+                th._attribute(refAttName, new QName(WellKnownNamespace.XML_SCHEMA, "IDREF"));
+                return;
+            case NONE:
+                // no ID/IDREF, so continue on and generate the type
+                break;
+            default:
+                throw new IllegalStateException();
+            }
+
+            // MTOM handling
+            MimeType mimeType = typeRef.getSource().getExpectedMimeType();
+            if( mimeType != null ) {
+                th._attribute(new QName(WellKnownNamespace.XML_MIME_URI, "expectedContentTypes", "xmime"), mimeType.toString());
+            }
+
+            // ref:swaRef handling
+            if(generateSwaRefAdapter(typeRef)) {
+                th._attribute(refAttName, new QName(WellKnownNamespace.SWA_URI, "swaRef", "ref"));
+                return;
+            }
+
+            // type name override
+            if(typeRef.getSource().getSchemaType()!=null) {
+                th._attribute(refAttName,typeRef.getSource().getSchemaType());
+                return;
+            }
+
+
+            // normal type generation
+            writeTypeRef(th, typeRef.getTarget(), refAttName);
+        }
+
+        /**
+         * Examine the specified element ref and determine if a swaRef attribute needs to be generated
+         * @param typeRef
+         */
+        private boolean generateSwaRefAdapter(NonElementRef<T,C> typeRef) {
+            final Adapter<T,C> adapter = typeRef.getSource().getAdapter();
+            if (adapter == null) return false;
+            final Object o = navigator.asDecl(SwaRefAdapter.class);
+            if (o == null) return false;
+            return (o.equals(adapter.adapterType));
+        }
+
+        /**
+         * Writes a type attribute (if the referenced type is a global type)
+         * or writes out the definition of the anonymous type in place (if the referenced
+         * type is not a global type.)
+         *
+         * @param th
+         *      the TXW interface to which the attribute will be written.
+         * @param type
+         *      type to be referenced.
+         * @param refAttName
+         *      The name of the attribute used when referencing a type by QName.
+         */
+        private void writeTypeRef(TypeHost th, NonElement<T,C> type, String refAttName) {
+            if(type.getTypeName()==null) {
+                if(type instanceof ClassInfo) {
+                    writeClass( (ClassInfo<T,C>)type, th );
+                } else {
+                    writeEnum( (EnumLeafInfo<T,C>)type, (SimpleTypeHost)th);
+                }
+            } else {
+                th._attribute(refAttName,type.getTypeName());
+            }
+        }
+
+        /**
+         * writes the schema definition for the given array class
+         */
+        private void writeArray(ArrayInfo<T, C> a, Schema schema) {
+            ComplexType ct = schema.complexType().name(a.getTypeName().getLocalPart());
+            ct._final("#all");
+            LocalElement le = ct.sequence().element().name("item");
+            le.type(a.getItemType().getTypeName());
+            le.minOccurs(0).maxOccurs("unbounded");
+            le.nillable(true);
+            ct.commit();
+        }
+
+        /**
+         * writes the schema definition for the specified type-safe enum in the given TypeHost
+         */
+        private void writeEnum(EnumLeafInfo<T, C> e, SimpleTypeHost th) {
+            SimpleType st = th.simpleType();
+            writeName(e,st);
+
+            SimpleRestrictionModel base = st.restriction();
+            writeTypeRef(base, e.getBaseType(), "base");
+
+            for (EnumConstant c : e.getConstants()) {
+                base.enumeration().value(c.getLexicalValue());
+            }
+            st.commit();
+        }
+
+        /**
+         * Writes the schema definition for the specified class to the schema writer.
+         *
+         * @param c the class info
+         * @param parent the writer of the parent element into which the type will be defined
+         */
+        private void writeClass(ClassInfo<T,C> c, TypeHost parent) {
+            // special handling for value properties
+            if (containsValueProp(c)) {
+                if (c.getProperties().size() == 1) {
+                    // [RESULT 2 - simpleType if the value prop is the only prop]
+                    //
+                    // <simpleType name="foo">
+                    //   <xs:restriction base="xs:int"/>
+                    // </>
+                    ValuePropertyInfo<T,C> vp = (ValuePropertyInfo<T,C>)c.getProperties().get(0);
+                    SimpleType st = ((SimpleTypeHost)parent).simpleType();
+                    writeName(c, st);
+                    if(vp.isCollection()) {
+                        writeTypeRef(st.list(),vp.getTarget(),"itemType");
+                    } else {
+                        writeTypeRef(st.restriction(),vp.getTarget(),"base");
+                    }
+                    return;
+                } else {
+                    // [RESULT 1 - complexType with simpleContent]
+                    //
+                    // <complexType name="foo">
+                    //   <simpleContent>
+                    //     <extension base="xs:int"/>
+                    //       <attribute name="b" type="xs:boolean"/>
+                    //     </>
+                    //   </>
+                    // </>
+                    // ...
+                    //   <element name="f" type="foo"/>
+                    // ...
+                    ComplexType ct = ((ComplexTypeHost)parent).complexType();
+                    writeName(c,ct);
+                    if(c.isFinal())
+                        ct._final("extension restriction");
+
+                    SimpleExtension se = ct.simpleContent().extension();
+                    se.block(); // because we might have attribute before value
+                    for (PropertyInfo<T,C> p : c.getProperties()) {
+                        switch (p.kind()) {
+                        case ATTRIBUTE:
+                            handleAttributeProp((AttributePropertyInfo<T,C>)p,se);
+                            break;
+                        case VALUE:
+                            TODO.checkSpec("what if vp.isCollection() == true?");
+                            ValuePropertyInfo vp = (ValuePropertyInfo) p;
+                            se.base(vp.getTarget().getTypeName());
+                            break;
+                        case ELEMENT:   // error
+                        case REFERENCE: // error
+                        default:
+                            assert false;
+                            throw new IllegalStateException();
+                        }
+                    }
+                    se.commit();
+                }
+                TODO.schemaGenerator("figure out what to do if bc != null");
+                TODO.checkSpec("handle sec 8.9.5.2, bullet #4");
+                // Java types containing value props can only contain properties of type
+                // ValuePropertyinfo and AttributePropertyInfo which have just been handled,
+                // so return.
+                return;
+            }
+
+            // we didn't fall into the special case for value props, so we
+            // need to initialize the ct.
+            // generate the complexType
+            ComplexType ct = ((ComplexTypeHost)parent).complexType();
+            writeName(c,ct);
+            if(c.isFinal())
+                ct._final("extension restriction");
+            if(c.isAbstract())
+                ct._abstract(true);
+
+            // hold the ct open in case we need to generate @mixed below...
+            ct.block();
+
+            // either <sequence> or <all>
+            ExplicitGroup compositor = null;
+
+            // only necessary if this type has a base class we need to extend from
+            AttrDecls contentModel = ct;
+
+            // if there is a base class, we need to generate an extension in the schema
+            final ClassInfo<T,C> bc = c.getBaseClass();
+            if (bc != null) {
+                ComplexExtension ce = ct.complexContent().extension();
+                contentModel = ce;
+
+                ce.base(bc.getTypeName());
+                // TODO: what if the base type is anonymous?
+                // ordered props go in a sequence, unordered go in an all
+                if( c.isOrdered() ) {
+                    compositor = ce.sequence();
+                } else {
+                    compositor = ce.all();
+                }
+            }
+
+            // iterate over the properties
+            if (c.hasProperties()) {
+                if( compositor == null ) { // if there is no extension base, create a top level seq
+                    // ordered props go in a sequence, unordered go in an all
+                    if( c.isOrdered() ) {
+                        compositor = ct.sequence();
+                    } else {
+                        compositor = ct.all();
+                    }
+                }
+
+                // block writing the compositor because we might need to
+                // write some out of order attributes to handle min/maxOccurs
+                compositor.block();
+
+                for (PropertyInfo<T,C> p : c.getProperties()) {
+                    // handling for <complexType @mixed='true' ...>
+                    if(p instanceof ReferencePropertyInfo && ((ReferencePropertyInfo)p).isMixed()) {
+                        ct.mixed(true);
+                    }
+                    writeProperty(p, contentModel, compositor);
+                }
+
+                compositor.commit();
+            }
+
+            // look for wildcard attributes
+            if( c.hasAttributeWildcard()) {
+                // TODO: not type safe
+                contentModel.anyAttribute().namespace("##other").processContents("skip");
+            }
+
+            // finally commit the ct
+            ct.commit();
+        }
+
+        /**
+         * Writes the name attribute if it's named.
+         */
+        private void writeName(NonElement<T,C> c, TypedXmlWriter xw) {
+            QName tn = c.getTypeName();
+            if(tn!=null)
+                xw._attribute("name",tn.getLocalPart());  // named
+        }
+
+        private boolean containsValueProp(ClassInfo<T, C> c) {
+            for (PropertyInfo p : c.getProperties()) {
+                if (p instanceof ValuePropertyInfo) return true;
+            }
+            return false;
+        }
+
+        /**
+         * write the schema definition(s) for the specified property
+         */
+        private void writeProperty(PropertyInfo<T,C> p, AttrDecls attr, ExplicitGroup compositor) {
+            switch(p.kind()) {
+            case ELEMENT:
+                handleElementProp((ElementPropertyInfo<T,C>)p, compositor);
+                break;
+            case ATTRIBUTE:
+                handleAttributeProp((AttributePropertyInfo<T,C>)p, attr);
+                break;
+            case REFERENCE:
+                handleReferenceProp((ReferencePropertyInfo<T,C>)p, compositor);
+                break;
+            case MAP:
+                handleMapProp((MapPropertyInfo<T,C>)p, compositor);
+                break;
+            case VALUE:
+                // value props handled above in writeClass()
+                assert false;
+                throw new IllegalStateException();
+                // break();
+            default:
+                assert false;
+                throw new IllegalStateException();
+            }
+        }
+
+        /**
+         * Generate the proper schema fragment for the given element property into the
+         * specified schema compositor.
+         *
+         * The element property may or may not represent a collection and it may or may
+         * not be wrapped.
+         *
+         * @param ep the element property
+         * @param compositor the schema compositor (sequence or all)
+         */
+        private void handleElementProp(ElementPropertyInfo<T,C> ep, ExplicitGroup compositor) {
+            QName ename = ep.getXmlName();
+            Occurs occurs = null;
+
+            if (ep.isValueList()) {
+                TypeRef<T,C> t = ep.getTypes().get(0);
+                LocalElement e = compositor.element();
+
+                QName tn = t.getTagName();
+                e.name(tn.getLocalPart());
+                List lst = e.simpleType().list();
+                writeTypeRef(lst,t, "itemType");
+                elementFormDefault.writeForm(e,tn);
+                return;
+            }
+
+            if (ep.isCollection()) {
+                if (ename != null) { // wrapped collection
+                    LocalElement e = compositor.element();
+                    if(ename.getNamespaceURI().length()>0) {
+                        if (!ename.getNamespaceURI().equals(this.uri)) {
+                            // TODO: we need to generate the corresponding element declaration for this
+                            // table 8-25: Property/field element wrapper with ref attribute
+                            e.ref(new QName(ename.getNamespaceURI(), ename.getLocalPart()));
+                            return;
+                        }
+                    }
+                    elementFormDefault.writeForm(e,ename);
+
+                    ComplexType p = e.name(ename.getLocalPart()).complexType();
+                    if(ep.isCollectionNillable()) {
+                        e.nillable(true);
+                    } else {
+                        e.minOccurs(0);
+                    }
+                    if (ep.getTypes().size() == 1) {
+                        compositor = p.sequence();
+                    } else {
+                        compositor = p.choice();
+                        occurs = compositor;
+                    }
+                } else { // unwrapped collection
+                    if (ep.getTypes().size() > 1) {
+                        compositor = compositor.choice();
+                        occurs = compositor;
+                    }
+                }
+            } else {
+                if (ep.getTypes().size() > 1) {
+                    compositor = compositor.choice();
+                    occurs = compositor;
+                }
+            }
+
+
+            // fill in the content model
+            for (TypeRef<T,C> t : ep.getTypes()) {
+                LocalElement e = compositor.element();
+                if (occurs == null) occurs = e;
+                QName tn = t.getTagName();
+
+                if(canBeDirectElementRef(t,tn) || (!tn.getNamespaceURI().equals(uri) && tn.getNamespaceURI().length()>0)) {
+                    e.ref(tn);
+                } else {
+                    e.name(tn.getLocalPart());
+                    writeTypeRef(e,t, "type");
+                    elementFormDefault.writeForm(e,tn);
+                }
+
+                if (t.isNillable()) {
+                    e.nillable(true);
+                }
+                if(t.getDefaultValue()!=null)
+                    e._default(t.getDefaultValue());
+            }
+
+            if (ep.isCollection())
+                occurs.maxOccurs("unbounded");
+
+            if (!ep.isRequired())
+                // see Spec table 8-13
+                occurs.minOccurs(0);
+            // else minOccurs defaults to 1
+        }
+
+        /**
+         * Checks if we can collapse
+         * &lt;element name='foo' type='t' /> to &lt;element ref='foo' />.
+         *
+         * This is possible if we already have such declaration to begin with.
+         */
+        private boolean canBeDirectElementRef(TypeRef<T, C> t, QName tn) {
+            if(t.isNillable() || t.getDefaultValue()!=null)
+                // can't put those attributes on <element ref>
+                return false;
+
+            if(t.getTarget() instanceof Element) {
+                Element te = (Element) t.getTarget();
+                QName targetTagName = te.getElementName();
+                return targetTagName!=null && targetTagName.equals(tn);
+            }
+
+            return false;
+        }
+
+
+        /**
+         * Generate an attribute for the specified property on the specified complexType
+         *
+         * @param ap the attribute
+         * @param attr the schema definition to which the attribute will be added
+         */
+        private void handleAttributeProp(AttributePropertyInfo<T,C> ap, AttrDecls attr) {
+            // attr is either a top-level ComplexType or a ComplexExtension
+            //
+            // [RESULT]
+            //
+            // <complexType ...>
+            //   <...>...</>
+            //   <attribute name="foo" type="xs:int"/>
+            // </>
+            //
+            // or
+            //
+            // <complexType ...>
+            //   <complexContent>
+            //     <extension ...>
+            //       <...>...</>
+            //     </>
+            //   </>
+            //   <attribute name="foo" type="xs:int"/>
+            // </>
+            //
+            // or it could also be an in-lined type (attr ref)
+            //
+            LocalAttribute localAttribute = attr.attribute();
+
+            final String attrURI = ap.getXmlName().getNamespaceURI();
+            if (attrURI.equals("") || attrURI.equals(uri)) {
+                localAttribute.name(ap.getXmlName().getLocalPart());
+
+                TypeHost th; String refAtt;
+                if( ap.isCollection() ) {
+                    th = localAttribute.simpleType().list();
+                    refAtt = "itemType";
+                } else {
+                    th = localAttribute;
+                    refAtt = "type";
+                }
+                writeTypeRef(th, ap, refAtt);
+
+                attributeFormDefault.writeForm(localAttribute,ap.getXmlName());
+            } else { // generate an attr ref
+                localAttribute.ref(ap.getXmlName());
+            }
+
+            if(ap.isRequired()) {
+                // TODO: not type safe
+                localAttribute.use("required");
+            }
+        }
+
+        /**
+         * Generate the proper schema fragment for the given reference property into the
+         * specified schema compositor.
+         *
+         * The reference property may or may not refer to a collection and it may or may
+         * not be wrapped.
+         *
+         * @param rp
+         * @param compositor
+         */
+        private void handleReferenceProp(ReferencePropertyInfo<T,C> rp, ExplicitGroup compositor) {
+            QName ename = rp.getXmlName();
+            Occurs occurs = null;
+
+            if (rp.isCollection()) {
+                if (ename != null) { // wrapped collection
+                    LocalElement e = compositor.element();
+                    ComplexType p = e.name(ename.getLocalPart()).complexType();
+                    elementFormDefault.writeForm(e,ename);
+                    if(rp.isCollectionNillable())
+                        e.nillable(true);
+                    if (rp.getElements().size() == 1) {
+                        compositor = p.sequence();
+                    } else {
+                        compositor = p.choice();
+                        occurs = compositor;
+                    }
+                } else { // unwrapped collection
+                    if (rp.getElements().size() > 1) {
+                        compositor = compositor.choice();
+                        occurs = compositor;
+                    }
+                }
+            }
+
+            // fill in content model
+            TODO.checkSpec("should we loop in the case of a non-collection ep?");
+            for (Element<T,C> e : rp.getElements()) {
+                LocalElement eref = compositor.element();
+                if (occurs == null) occurs = eref;
+
+                QName en = e.getElementName();
+                if(e.getScope()!=null) {
+                    // scoped. needs to be inlined
+                    boolean qualified = en.getNamespaceURI().equals(uri);
+                    boolean unqualified = en.getNamespaceURI().equals("");
+                    if(qualified || unqualified) {
+                        // can be inlined indeed
+
+                        // write form="..." if necessary
+                        if(unqualified) {
+                            if(elementFormDefault.isEffectivelyQualified)
+                                eref.form("unqualified");
+                        } else {
+                            if(!elementFormDefault.isEffectivelyQualified)
+                                eref.form("qualified");
+                        }
+
+                        eref.name(en.getLocalPart());
+
+                        // write out type reference
+                        if(e instanceof ClassInfo) {
+                            writeTypeRef(eref,(ClassInfo<T,C>)e,"type");
+                        } else {
+                            writeTypeRef(eref,((ElementInfo<T,C>)e).getContentType(),"type");
+                        }
+                        continue;
+                    }
+                }
+                eref.ref(en);
+            }
+
+            WildcardMode wc = rp.getWildcard();
+            if( wc != null ) {
+                Any any = compositor.any();
+                final String pcmode = getProcessContentsModeName(wc);
+                if( pcmode != null ) any.processContents(pcmode);
+                TODO.schemaGenerator("generate @namespace ???");
+                if( occurs == null ) occurs = any;
+            }
+
+            if(rp.isCollection())
+                occurs.maxOccurs("unbounded");
+
+        }
+
+        /**
+         * Generate the proper schema fragment for the given map property into the
+         * specified schema compositor.
+         *
+         * @param mp the map property
+         * @param compositor the schema compositor (sequence or all)
+         */
+        private void handleMapProp(MapPropertyInfo<T,C> mp, ExplicitGroup compositor) {
+            QName ename = mp.getXmlName();
+
+            LocalElement e = compositor.element();
+            elementFormDefault.writeForm(e,ename);
+            if(mp.isCollectionNillable())
+                e.nillable(true);
+            ComplexType p = e.name(ename.getLocalPart()).complexType();
+
+            // TODO: entry, key, and value are always unqualified. that needs to be fixed, too.
+            // TODO: we need to generate the corresponding element declaration, if they are qualified
+            e = p.sequence().element();
+            e.name("entry").minOccurs(0).maxOccurs("unbounded");
+
+            ExplicitGroup seq = e.complexType().sequence();
+            writeKeyOrValue(seq, "key", mp.getKeyType());
+            writeKeyOrValue(seq, "value", mp.getValueType());
+        }
+
+        private void writeKeyOrValue(ExplicitGroup seq, String tagName, NonElement<T, C> typeRef) {
+            LocalElement key = seq.element().name(tagName);
+            key.minOccurs(0);
+            writeTypeRef(key, typeRef, "type");
+        }
+
+        public void addGlobalAttribute(AttributePropertyInfo<T,C> ap) {
+            attributeDecls.put( ap.getXmlName().getLocalPart(), ap.getTarget() );
+            addDependencyTo(ap.getTarget().getTypeName());
+        }
+
+        public void addGlobalElement(TypeRef<T,C> tref) {
+            elementDecls.put( tref.getTagName().getLocalPart(), new ElementWithType(false,tref.getTarget()) );
+            addDependencyTo(tref.getTarget().getTypeName());
+        }
+
+        /**
+         * Represents a global element declaration to be written.
+         *
+         * <p>
+         * Because multiple properties can name the same global element even if
+         * they have different Java type, the schema generator first needs to
+         * walk through the model and decide what to generate for the given
+         * element declaration.
+         *
+         * <p>
+         * This class represents what will be written, and its {@link #equals(Object)}
+         * method is implemented in such a way that two identical declarations
+         * are considered as the same.
+         */
+        abstract class ElementDeclaration {
+            /**
+             * Returns true if two {@link ElementDeclaration}s are representing
+             * the same schema fragment.
+             */
+            public abstract boolean equals(Object o);
+            public abstract int hashCode();
+
+            /**
+             * Generates the declaration.
+             */
+            public abstract void writeTo(String localName, Schema schema);
+        }
+
+        /**
+         * {@link ElementDeclaration} that refers to a {@link NonElement}.
+         */
+        class ElementWithType extends ElementDeclaration {
+            private final boolean nillable;
+            private final NonElement<T,C> type;
+
+            public ElementWithType(boolean nillable,NonElement<T, C> type) {
+                this.type = type;
+                this.nillable = nillable;
+            }
+
+            public void writeTo(String localName, Schema schema) {
+                TopLevelElement e = schema.element().name(localName);
+                if(nillable)
+                    e.nillable(true);
+                if(type!=null) {
+                    writeTypeRef(e,type, "type");
+                } else {
+                    e.complexType();    // refer to the nested empty complex type
+                }
+                e.commit();
+            }
+
+            public boolean equals(Object o) {
+                if (this == o) return true;
+                if (o == null || getClass() != o.getClass()) return false;
+
+                final ElementWithType that = (ElementWithType) o;
+                return type.equals(that.type);
+            }
+
+            public int hashCode() {
+                return type.hashCode();
+            }
+        }
+    }
+
+
+    /**
+     * return the string representation of the processContents mode of the
+     * give wildcard, or null if it is the schema default "strict"
+     *
+     */
+    private static String getProcessContentsModeName(WildcardMode wc) {
+        switch(wc) {
+        case LAX:
+        case SKIP:
+            return wc.name().toLowerCase();
+        case STRICT:
+            return null;
+        default:
+            throw new IllegalStateException();
+        }
+    }
+
+
+    /**
+     * TODO: JAX-WS dependency on this method - consider moving this method into com.sun.tools.internal.jxc.util.Util
+     *
+     * Relativizes a URI by using another URI (base URI.)
+     *
+     * <p>
+     * For example, {@code relative("http://www.sun.com/abc/def","http://www.sun.com/pqr/stu") => "../abc/def"}
+     *
+     * <p>
+     * This method only works on hierarchical URI's, not opaque URI's (refer to the
+     * <a href="http://java.sun.com/j2se/1.5.0/docs/api/java/net/URI.html">java.net.URI</a>
+     * javadoc for complete definitions of these terms.
+     *
+     * <p>
+     * This method will not normalize the relative URI.
+     *
+     * @return the relative URI or the original URI if a relative one could not be computed
+     */
+    protected static String relativize(String uri, String baseUri) {
+        try {
+            assert uri!=null;
+
+            if(baseUri==null)   return uri;
+
+            URI theUri = new URI(escapeURI(uri));
+            URI theBaseUri = new URI(escapeURI(baseUri));
+
+            if (theUri.isOpaque() || theBaseUri.isOpaque())
+                return uri;
+
+            if (!equalsIgnoreCase(theUri.getScheme(), theBaseUri.getScheme()) ||
+                    !equal(theUri.getAuthority(), theBaseUri.getAuthority()))
+                return uri;
+
+            String uriPath = theUri.getPath();
+            String basePath = theBaseUri.getPath();
+
+            // normalize base path
+            if (!basePath.endsWith("/")) {
+                basePath = normalizeUriPath(basePath);
+            }
+
+            if( uriPath.equals(basePath))
+                return ".";
+
+            String relPath = calculateRelativePath(uriPath, basePath);
+
+            if (relPath == null)
+                return uri; // recursion found no commonality in the two uris at all
+            StringBuffer relUri = new StringBuffer();
+            relUri.append(relPath);
+            if (theUri.getQuery() != null)
+                relUri.append('?').append(theUri.getQuery());
+            if (theUri.getFragment() != null)
+                relUri.append('#').append(theUri.getFragment());
+
+            return relUri.toString();
+        } catch (URISyntaxException e) {
+            throw new InternalError("Error escaping one of these uris:\n\t"+uri+"\n\t"+baseUri);
+        }
+    }
+
+    private static String calculateRelativePath(String uri, String base) {
+        if (base == null) {
+            return null;
+        }
+        if (uri.startsWith(base)) {
+            return uri.substring(base.length());
+        } else {
+            return "../" + calculateRelativePath(uri, getParentUriPath(base));
+        }
+    }
+
+    /**
+     * JAX-RPC wants the namespaces to be sorted in the reverse order
+     * so that the empty namespace "" comes to the very end. Don't ask me why.
+     */
+    private static final Comparator<String> NAMESPACE_COMPARATOR = new Comparator<String>() {
+        public int compare(String lhs, String rhs) {
+            return -lhs.compareTo(rhs);
+        }
+    };
+
+    private static final String newline = "\n";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/package-info.java
new file mode 100644
index 0000000..fd1ef80
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/package-info.java
@@ -0,0 +1,34 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * Schema generator.
+ *
+ * This package hosts the code that generates schemas from
+ * {@link TypeInfoSet} (without the user interface.)
+ */
+package com.sun.xml.internal.bind.v2.schemagen;
+
+import com.sun.xml.internal.bind.v2.model.core.TypeInfoSet;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Annotated.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Annotated.java
new file mode 100644
index 0000000..531fd89
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Annotated.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface Annotated
+    extends TypedXmlWriter
+{
+
+
+    @XmlElement
+    public Annotation annotation();
+
+    @XmlAttribute
+    public Annotated id(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Annotation.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Annotation.java
new file mode 100644
index 0000000..8a25134
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Annotation.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("annotation")
+public interface Annotation
+    extends TypedXmlWriter
+{
+
+
+    @XmlElement
+    public Appinfo appinfo();
+
+    @XmlElement
+    public Documentation documentation();
+
+    @XmlAttribute
+    public Annotation id(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Any.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Any.java
new file mode 100644
index 0000000..dc7e4a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Any.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("any")
+public interface Any
+    extends Occurs, Wildcard, TypedXmlWriter
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Appinfo.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Appinfo.java
new file mode 100644
index 0000000..f225649
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Appinfo.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("appinfo")
+public interface Appinfo
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public Appinfo source(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/AttrDecls.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/AttrDecls.java
new file mode 100644
index 0000000..555e0e1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/AttrDecls.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface AttrDecls
+    extends TypedXmlWriter
+{
+
+
+    @XmlElement
+    public LocalAttribute attribute();
+
+    @XmlElement
+    public Wildcard anyAttribute();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/AttributeType.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/AttributeType.java
new file mode 100644
index 0000000..3c0f3bf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/AttributeType.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+public interface AttributeType
+    extends SimpleTypeHost, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public AttributeType type(QName value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexContent.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexContent.java
new file mode 100644
index 0000000..a6a1f2c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexContent.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("complexContent")
+public interface ComplexContent
+    extends Annotated, TypedXmlWriter
+{
+
+
+    @XmlElement
+    public ComplexExtension extension();
+
+    @XmlElement
+    public ComplexRestriction restriction();
+
+    @XmlAttribute
+    public ComplexContent mixed(boolean value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexExtension.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexExtension.java
new file mode 100644
index 0000000..827b9c8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexExtension.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("extension")
+public interface ComplexExtension
+    extends AttrDecls, ExtensionType, TypeDefParticle, TypedXmlWriter
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexRestriction.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexRestriction.java
new file mode 100644
index 0000000..fd93634
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexRestriction.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("restriction")
+public interface ComplexRestriction
+    extends Annotated, AttrDecls, TypeDefParticle, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public ComplexRestriction base(QName value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexType.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexType.java
new file mode 100644
index 0000000..1045eb8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexType.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("complexType")
+public interface ComplexType
+    extends Annotated, ComplexTypeModel, TypedXmlWriter
+{
+
+
+    @XmlAttribute("final")
+    public ComplexType _final(String[] value);
+
+    @XmlAttribute("final")
+    public ComplexType _final(String value);
+
+    @XmlAttribute
+    public ComplexType block(String[] value);
+
+    @XmlAttribute
+    public ComplexType block(String value);
+
+    @XmlAttribute("abstract")
+    public ComplexType _abstract(boolean value);
+
+    @XmlAttribute
+    public ComplexType name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexTypeHost.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexTypeHost.java
new file mode 100644
index 0000000..86c3656
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexTypeHost.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface ComplexTypeHost
+    extends TypeHost, TypedXmlWriter
+{
+
+
+    @XmlElement
+    public ComplexType complexType();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexTypeModel.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexTypeModel.java
new file mode 100644
index 0000000..7398a20
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ComplexTypeModel.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface ComplexTypeModel
+    extends AttrDecls, TypeDefParticle, TypedXmlWriter
+{
+
+
+    @XmlElement
+    public SimpleContent simpleContent();
+
+    @XmlElement
+    public ComplexContent complexContent();
+
+    @XmlAttribute
+    public ComplexTypeModel mixed(boolean value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Documentation.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Documentation.java
new file mode 100644
index 0000000..c150fa1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Documentation.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("documentation")
+public interface Documentation
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public Documentation source(String value);
+
+    @XmlAttribute(ns = "http://www.w3.org/XML/1998/namespace")
+    public Documentation lang(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Element.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Element.java
new file mode 100644
index 0000000..6503af7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Element.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+public interface Element
+    extends Annotated, ComplexTypeHost, FixedOrDefault, SimpleTypeHost, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public Element type(QName value);
+
+    @XmlAttribute
+    public Element block(String[] value);
+
+    @XmlAttribute
+    public Element block(String value);
+
+    @XmlAttribute
+    public Element nillable(boolean value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ExplicitGroup.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ExplicitGroup.java
new file mode 100644
index 0000000..0c8de44
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ExplicitGroup.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+
+public interface ExplicitGroup
+    extends Annotated, NestedParticle, Occurs, TypedXmlWriter
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ExtensionType.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ExtensionType.java
new file mode 100644
index 0000000..290171f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/ExtensionType.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+public interface ExtensionType
+    extends Annotated, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public ExtensionType base(QName value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/FixedOrDefault.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/FixedOrDefault.java
new file mode 100644
index 0000000..e9199d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/FixedOrDefault.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+public interface FixedOrDefault
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute("default")
+    public FixedOrDefault _default(String value);
+
+    @XmlAttribute
+    public FixedOrDefault fixed(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Import.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Import.java
new file mode 100644
index 0000000..533a9c3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Import.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("import")
+public interface Import
+    extends Annotated, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public Import namespace(String value);
+
+    @XmlAttribute
+    public Import schemaLocation(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/List.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/List.java
new file mode 100644
index 0000000..6dd3dca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/List.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("list")
+public interface List
+    extends Annotated, SimpleTypeHost, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public List itemType(QName value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/LocalAttribute.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/LocalAttribute.java
new file mode 100644
index 0000000..9ee57e8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/LocalAttribute.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("attribute")
+public interface LocalAttribute
+    extends Annotated, AttributeType, FixedOrDefault, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public LocalAttribute form(String value);
+
+    @XmlAttribute
+    public LocalAttribute name(String value);
+
+    @XmlAttribute
+    public LocalAttribute ref(QName value);
+
+    @XmlAttribute
+    public LocalAttribute use(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/LocalElement.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/LocalElement.java
new file mode 100644
index 0000000..5c91404
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/LocalElement.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("element")
+public interface LocalElement
+    extends Element, Occurs, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public LocalElement form(String value);
+
+    @XmlAttribute
+    public LocalElement name(String value);
+
+    @XmlAttribute
+    public LocalElement ref(QName value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/NestedParticle.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/NestedParticle.java
new file mode 100644
index 0000000..ee88be0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/NestedParticle.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface NestedParticle
+    extends TypedXmlWriter
+{
+
+
+    @XmlElement
+    public LocalElement element();
+
+    @XmlElement
+    public Any any();
+
+    @XmlElement
+    public ExplicitGroup sequence();
+
+    @XmlElement
+    public ExplicitGroup choice();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/NoFixedFacet.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/NoFixedFacet.java
new file mode 100644
index 0000000..c72efb7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/NoFixedFacet.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+public interface NoFixedFacet
+    extends Annotated, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public NoFixedFacet value(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Occurs.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Occurs.java
new file mode 100644
index 0000000..d81692c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Occurs.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+public interface Occurs
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public Occurs minOccurs(int value);
+
+    @XmlAttribute
+    public Occurs maxOccurs(String value);
+
+    @XmlAttribute
+    public Occurs maxOccurs(int value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Redefinable.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Redefinable.java
new file mode 100644
index 0000000..a947074
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Redefinable.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+
+public interface Redefinable
+    extends ComplexTypeHost, SimpleTypeHost, TypedXmlWriter
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Schema.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Schema.java
new file mode 100644
index 0000000..a3e4685
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Schema.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("schema")
+public interface Schema
+    extends SchemaTop, TypedXmlWriter
+{
+
+
+    @XmlElement
+    public Annotation annotation();
+
+    @XmlElement("import")
+    public Import _import();
+
+    @XmlAttribute
+    public Schema targetNamespace(String value);
+
+    @XmlAttribute(ns = "http://www.w3.org/XML/1998/namespace")
+    public Schema lang(String value);
+
+    @XmlAttribute
+    public Schema id(String value);
+
+    @XmlAttribute
+    public Schema elementFormDefault(String value);
+
+    @XmlAttribute
+    public Schema attributeFormDefault(String value);
+
+    @XmlAttribute
+    public Schema blockDefault(String[] value);
+
+    @XmlAttribute
+    public Schema blockDefault(String value);
+
+    @XmlAttribute
+    public Schema finalDefault(String[] value);
+
+    @XmlAttribute
+    public Schema finalDefault(String value);
+
+    @XmlAttribute
+    public Schema version(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SchemaTop.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SchemaTop.java
new file mode 100644
index 0000000..42c2b53
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SchemaTop.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface SchemaTop
+    extends Redefinable, TypedXmlWriter
+{
+
+
+    @XmlElement
+    public TopLevelAttribute attribute();
+
+    @XmlElement
+    public TopLevelElement element();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleContent.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleContent.java
new file mode 100644
index 0000000..2eea5b4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleContent.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("simpleContent")
+public interface SimpleContent
+    extends Annotated, TypedXmlWriter
+{
+
+
+    @XmlElement
+    public SimpleExtension extension();
+
+    @XmlElement
+    public SimpleRestriction restriction();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleDerivation.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleDerivation.java
new file mode 100644
index 0000000..f57e62a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleDerivation.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface SimpleDerivation
+    extends TypedXmlWriter
+{
+
+
+    @XmlElement
+    public SimpleRestriction restriction();
+
+    @XmlElement
+    public Union union();
+
+    @XmlElement
+    public List list();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleExtension.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleExtension.java
new file mode 100644
index 0000000..3ef40ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleExtension.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("extension")
+public interface SimpleExtension
+    extends AttrDecls, ExtensionType, TypedXmlWriter
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleRestriction.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleRestriction.java
new file mode 100644
index 0000000..d74c58b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleRestriction.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("restriction")
+public interface SimpleRestriction
+    extends Annotated, AttrDecls, SimpleRestrictionModel, TypedXmlWriter
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleRestrictionModel.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleRestrictionModel.java
new file mode 100644
index 0000000..46291f4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleRestrictionModel.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface SimpleRestrictionModel
+    extends SimpleTypeHost, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public SimpleRestrictionModel base(QName value);
+
+    @XmlElement
+    public NoFixedFacet enumeration();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleType.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleType.java
new file mode 100644
index 0000000..14ffb04
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleType.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("simpleType")
+public interface SimpleType
+    extends Annotated, SimpleDerivation, TypedXmlWriter
+{
+
+
+    @XmlAttribute("final")
+    public SimpleType _final(String[] value);
+
+    @XmlAttribute("final")
+    public SimpleType _final(String value);
+
+    @XmlAttribute
+    public SimpleType name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleTypeHost.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleTypeHost.java
new file mode 100644
index 0000000..ed8d783
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/SimpleTypeHost.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface SimpleTypeHost
+    extends TypeHost, TypedXmlWriter
+{
+
+
+    @XmlElement
+    public SimpleType simpleType();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TopLevelAttribute.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TopLevelAttribute.java
new file mode 100644
index 0000000..8bbaba8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TopLevelAttribute.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("attribute")
+public interface TopLevelAttribute
+    extends Annotated, AttributeType, FixedOrDefault, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public TopLevelAttribute name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TopLevelElement.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TopLevelElement.java
new file mode 100644
index 0000000..3f48b1e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TopLevelElement.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("element")
+public interface TopLevelElement
+    extends Element, TypedXmlWriter
+{
+
+
+    @XmlAttribute("final")
+    public TopLevelElement _final(String[] value);
+
+    @XmlAttribute("final")
+    public TopLevelElement _final(String value);
+
+    @XmlAttribute("abstract")
+    public TopLevelElement _abstract(boolean value);
+
+    @XmlAttribute
+    public TopLevelElement substitutionGroup(QName value);
+
+    @XmlAttribute
+    public TopLevelElement name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TypeDefParticle.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TypeDefParticle.java
new file mode 100644
index 0000000..e0073d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TypeDefParticle.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+public interface TypeDefParticle
+    extends TypedXmlWriter
+{
+
+
+    @XmlElement
+    public ExplicitGroup all();
+
+    @XmlElement
+    public ExplicitGroup sequence();
+
+    @XmlElement
+    public ExplicitGroup choice();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TypeHost.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TypeHost.java
new file mode 100644
index 0000000..3d86b37
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/TypeHost.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+
+public interface TypeHost
+    extends TypedXmlWriter
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Union.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Union.java
new file mode 100644
index 0000000..492d322
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Union.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+@XmlElement("union")
+public interface Union
+    extends Annotated, SimpleTypeHost, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public Union memberTypes(QName[] value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Wildcard.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Wildcard.java
new file mode 100644
index 0000000..16f85fa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/Wildcard.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+public interface Wildcard
+    extends Annotated, TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public Wildcard processContents(String value);
+
+    @XmlAttribute
+    public Wildcard namespace(String value);
+
+    @XmlAttribute
+    public Wildcard namespace(String[] value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/package-info.java
new file mode 100644
index 0000000..7dbae08
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/package-info.java
@@ -0,0 +1,27 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+@com.sun.xml.internal.txw2.annotation.XmlNamespace("http://www.w3.org/2001/XMLSchema")
+package com.sun.xml.internal.bind.v2.schemagen.xmlschema;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/package.html b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/package.html
new file mode 100644
index 0000000..d5ec73f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+XML Schema writer generated by TXW.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/xmlschema-for-jaxb.rng b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/xmlschema-for-jaxb.rng
new file mode 100644
index 0000000..e6ad1df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/schemagen/xmlschema/xmlschema-for-jaxb.rng
@@ -0,0 +1,1554 @@
+<?xml version="1.0"?>
+<grammar xmlns="http://relaxng.org/ns/structure/1.0"
+      datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes"
+      ns="http://www.w3.org/2001/XMLSchema"
+      xmlns:xs="http://www.w3.org/2001/XMLSchema"
+      xmlns:doc="http://www.jenitennison.com/doc"
+      xmlns:txw="http://java.sun.com/txw">
+
+<doc:p>
+  RELAX NG schema for XML Schema by <doc:link 
+  href="mailto:mail@jenitennison.com">Jeni Tennison</doc:link>. Based on 
+  <doc:link href="http://www.w3.org/TR/2001/REC-xmlschema-1-20010502/">XML 
+  Schema Part I: Structures Recommendation</doc:link> and <doc:link 
+  href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/">XML Schema Part 
+  II: Datatypes</doc:link>.
+</doc:p>
+<doc:changes date="2001-11-24">
+  <doc:p>
+    Amended to comply with 10 August 2001 Tutorial.
+  </doc:p>
+  <doc:change>Removed key attributes.</doc:change>
+  <doc:change>Replaced not element with except elements.</doc:change>
+  <doc:change>
+    Replaced multiple consecutive optional attributes to use the 
+    zeroOrMore/choice pattern.
+  </doc:change>
+  <doc:change>
+    Removed interleave elements inside list elements (which are no longer 
+    permitted).
+  </doc:change>
+</doc:changes>
+
+<define name="openAttrs" txw:mode="inherit">
+  <doc:p>
+    This allows any number of attributes that are not in the XML Schema 
+    namespace or are in no namespace.  This is somewhat more complicated than 
+    the XML Schema anyAttribute equivalent. 
+  </doc:p>
+  <!-- KK don't care -->
+  <empty/>
+  <!--zeroOrMore>
+    <attribute>
+      <anyName>
+        <except>
+          <nsName />
+          <nsName ns="" />
+          <name>xml:lang</name>
+        </except>
+      </anyName>
+      <text />
+    </attribute>
+  </zeroOrMore-->
+</define>
+
+<define name="annotated" txw:mode="inherit">
+  <doc:p>
+    This allows any number of attributes that are not in the XML Schema 
+    namespace or are in no namespace, an optional id attribute of type ID, 
+    and an optional annotation element.  This is used as the basis for many 
+    element content models.
+  </doc:p>
+  <ref name="openAttrs" />
+  <optional>
+    <attribute name="id">
+      <data type="ID" />
+    </attribute>
+  </optional>
+  <optional>
+    <ref name="annotation" />
+  </optional>
+</define>
+
+<define name="schemaTop" txw:mode="inline">
+  <doc:p>
+    This gives the content model of the top level of the schema.
+  </doc:p>
+  <choice>
+    <ref name="redefinable" />
+    <ref name="topLevelElement" />
+    <ref name="topLevelAttribute" />
+    <!--ref name="notation" /-->
+  </choice>
+</define>
+
+<define name="redefinable" txw:mode="inline">
+  <doc:p>
+    This gives the components that can be redefined within the redefine 
+    element.  They also occur at the top level of the schema.
+  </doc:p>
+  <choice>
+    <ref name="simpleTypeHost" />
+    <ref name="complexTypeHost" />
+    <!--ref name="namedGroup" />
+    <ref name="namedAttributeGroup" /-->
+  </choice>
+</define>
+
+<define name="formChoice">
+  <doc:p>
+    This gives the values for the various form attributes: 
+    elementFormDefault and attributeFormDefault on the schema element, and
+    the form attributes on the element and attribute elements.
+  </doc:p>
+  <choice>
+    <value>qualified</value>
+    <value>unqualified</value>
+  </choice>
+</define>
+
+<!-- KK: merge the two -->
+<define name="reducedDerivationControl">
+  <doc:p>
+    This gives the values that can be taken in the lists used to control
+    derivation by extension or restriction (this is 'reduced' derivation
+    because some derivation can involve substitution).  This RELAX NG schema, 
+    like the XML Schema Recommendation here, allows the keywords 'extension' and 
+    'restriction' to be repeated any number of times.
+  </doc:p>
+  <list>
+    <oneOrMore>
+      <choice>
+        <value>extension</value>
+        <value>restriction</value>
+      </choice>
+    </oneOrMore>
+  </list>
+</define>
+
+<define name="derivationSet">
+  <doc:p>
+    This specifies the possible values for attributes that control derivation.
+  </doc:p>
+  <choice>
+    <value>#all</value>
+    <ref name="reducedDerivationControl" />
+  </choice>
+</define>
+
+<start>
+  <doc:p>
+    This is the beginning point for the schema, and defines the schema 
+    element.
+  </doc:p>
+  <element name="schema" 
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-schema">
+    <ref name="openAttrs" />
+    <zeroOrMore>
+      <choice>
+        <attribute name="version">
+          <data type="token" />
+        </attribute>
+        <attribute name="finalDefault">
+          <ref name="derivationSet" />
+        </attribute>
+        <attribute name="blockDefault">
+          <ref name="blockSet" />
+        </attribute>
+        <attribute name="attributeFormDefault">
+          <ref name="formChoice" />
+        </attribute>
+        <attribute name="elementFormDefault">
+          <ref name="formChoice" />
+        </attribute>
+        <attribute name="id">
+          <data type="ID" />
+        </attribute>
+        <attribute name="xml:lang">
+          <data type="language" />
+        </attribute>
+        <attribute name="targetNamespace">
+          <data type="anyURI" />
+        </attribute>
+      </choice>
+    </zeroOrMore>
+    <zeroOrMore>
+      <choice>
+        <!--ref name="include" /-->
+        <ref name="import" />
+        <!--ref name="redefine" /-->
+        <ref name="annotation" />
+      </choice>
+    </zeroOrMore>
+    <zeroOrMore>
+      <choice>
+        <ref name="schemaTop" />
+        <ref name="annotation" />
+      </choice>
+    </zeroOrMore>
+  </element>
+</start>
+
+<define name="allNNI">
+  <doc:p>
+    This gives the value type for the maxOccurs attribute, which may be a 
+    non-negative number or the keyword 'unbounded'.
+  </doc:p>
+  <choice>
+    <data type="nonNegativeInteger" />
+    <value type="token">unbounded</value>
+  </choice>
+</define>
+
+<define name="occurs" txw:mode="inherit">
+  <doc:p>
+    This specifies the occurs attributes, minOccurs and maxOccurs, as they 
+    are normally used.
+  </doc:p>
+  <zeroOrMore>
+    <choice>
+      <attribute name="minOccurs">
+        <data type="nonNegativeInteger" />
+      </attribute>
+      <attribute name="maxOccurs">
+        <ref name="allNNI" />
+      </attribute>
+    </choice>
+  </zeroOrMore>
+</define>
+
+<define name="typeDefParticle" txw:mode="inline">
+  <doc:p>
+    This gives the possible content of complex types.
+  </doc:p>
+  <choice>
+    <!--ref name="groupRef" /-->
+    <ref name="all" />
+    <ref name="choice" />
+    <ref name="sequence" />
+  </choice>
+</define>
+
+<define name="nestedParticle" txw:mode="inline">
+  <doc:p>
+    This gives the particles that can make up a model group.
+  </doc:p>
+  <choice>
+    <ref name="localElement" />
+    <!--ref name="groupRef" /-->
+    <ref name="choice" />
+    <ref name="sequence" />
+    <ref name="any" />
+  </choice>
+</define>
+
+<define name="fixedOrDefault" txw:mode="inline">
+  <doc:p>
+    This specifies the relationship between fixed and default attributes on 
+    element and attribute elements - if one is present, then the other cannot 
+    be.  This is a constraint that cannot be specified using XML Schema.
+  </doc:p>
+  <choice>
+    <empty />
+    <attribute name="fixed" />
+    <attribute name="default" />
+  </choice>
+</define>
+
+<define name="attributeType" txw:mode="inherit">
+  <doc:p>
+    This specifies the relationship between the type attribute and the 
+    simpleType element child of attribute elements - if one is present, then 
+    the other cannot be, although it is possible for neither to be allowed.
+  </doc:p>
+  <choice>
+    <empty />
+    <attribute name="type">
+      <data type="QName" />
+    </attribute>
+    <ref name="simpleTypeHost" />
+  </choice>
+</define>
+
+<define name="localAttribute">
+  <doc:p>
+    This describes attribute elements when used in a local context.  They 
+    have an optional use attribute, possibly a fixed or default attribute, 
+    and then can either have a ref attribute (referring to a top-level 
+    attribute) or a name attribute with an optional form attribute and 
+    specifying an attribute type.
+  </doc:p>
+  <element name="attribute" 
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-attribute">
+    <ref name="annotated" />
+    <optional>
+      <attribute name="use">
+        <choice>
+          <value type="token">optional</value>
+          <value type="token">prohibited</value>
+          <value type="token">required</value>
+        </choice>
+      </attribute>
+    </optional>
+    <ref name="fixedOrDefault" />
+    <choice>
+      <attribute name="ref">
+        <data type="QName" />
+      </attribute>
+      <group>
+        <attribute name="name">
+          <data type="NCName" />
+        </attribute>
+        <optional>
+          <attribute name="form">
+            <ref name="formChoice" />
+          </attribute>
+        </optional>        
+        <ref name="attributeType" />
+      </group>
+    </choice>
+  </element>
+</define>
+
+<define name="topLevelAttribute">
+  <doc:p>
+    This describes attribute elements when used at the top level of the 
+    schema.  They must have a name, may have a fixed or default attribute, 
+    and specify their type through a type attribute or child simpleType 
+    element.  The name attribute of each attribute element that appears at 
+    the top level of the schema is unique.
+  </doc:p>
+  <element name="attribute"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-attribute">
+    <ref name="annotated" />
+    <attribute name="name">
+      <data type="NCName" />
+    </attribute>
+    <ref name="fixedOrDefault" />
+    <ref name="attributeType" />
+  </element>
+</define>
+
+<define name="attrDecls" txw:mode="inherit">
+  <doc:p>
+    This gives the model group for specifying the attributes in a complex 
+    type, an extension or restriction.
+  </doc:p>
+  <zeroOrMore>
+    <choice>
+      <ref name="localAttribute" />
+      <!--ref name="attributeGroupRef" /-->
+    </choice>
+  </zeroOrMore>
+  <optional>
+    <ref name="anyAttribute" />
+  </optional>
+</define>
+
+<define name="anyAttribute">
+  <doc:p>
+    This specifies the anyAttribute wildcard.
+  </doc:p>
+  <element name="anyAttribute"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-anyAttribute">
+    <ref name="wildcard" />
+  </element>
+</define>
+
+<define name="complexTypeModel" txw:mode="inherit">
+  <doc:p>
+    This specifies the content of a complexType element.  As children, it can 
+    have a simpleContent, a complexContent or a model group.  Only if it has 
+    one of the latter two, may it have a mixed attribute.  This latter 
+    constraint is something that cannot be specified in XML Schema.
+  </doc:p>
+  <choice>
+    <ref name="simpleContent" />
+    <group>
+      <optional>
+        <attribute name="mixed">
+          <data type="boolean" />
+        </attribute>
+      </optional>
+      <choice>
+        <ref name="complexContent" />
+        <group>
+          <optional>
+            <ref name="typeDefParticle" />
+          </optional>
+          <ref name="attrDecls" />
+        </group>
+      </choice>
+    </group>
+  </choice>
+</define>
+
+<define name="complexTypeHost" txw:mode="inherit">
+  <ref name="typeHost" />
+  <ref name="complexType" />
+</define>
+
+<define name="typeHost" txw:mode="inherit"><empty/><empty/></define>
+
+<define name="complexType" txw:mode="inherit">
+  <element name="complexType"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-complexType">
+    <doc:p>
+      This specifies the basic content of a complexType element.
+    </doc:p>
+    <ref name="annotated" />
+    <ref name="complexTypeModel" />
+    <optional>
+      <attribute name="name">
+        <data type="NCName" />
+      </attribute>
+    </optional>
+    <zeroOrMore>
+      <choice>
+        <attribute name="abstract">
+          <data type="boolean" />
+        </attribute>
+        <attribute name="block">
+          <ref name="derivationSet" />
+        </attribute>
+        <attribute name="final">
+          <ref name="derivationSet" />
+        </attribute>
+      </choice>
+    </zeroOrMore>
+  </element>
+</define>
+
+<define name="complexRestriction">
+  <doc:p>
+    This describes a restriction element within a complexContent element 
+    (i.e. one that restricts a complex type).  It has a base attribute, may 
+    contain a model group and may contain attribute declarations of various 
+    sorts.
+  </doc:p>
+  <element name="restriction"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-complexContent::restriction">
+    <ref name="annotated" />
+    <attribute name="base">
+      <data type="QName" />
+    </attribute>
+    <optional>
+      <ref name="typeDefParticle" />
+    </optional>
+    <ref name="attrDecls" />
+  </element>
+</define>
+
+<define name="extensionType">
+  <doc:p>
+    This specifies the basic model for an extension element: adding a 
+    required base attribute to the model used for most components.
+  </doc:p>
+  <ref name="annotated" />
+  <attribute name="base">
+    <data type="QName" />
+  </attribute>
+</define>
+
+<define name="complexExtension">
+  <doc:p>
+    This describes an extension element within a complexContent element 
+    (i.e. one that restricts a complex type).  It may contain a model group 
+    and may contain attribute declarations of various sorts.
+  </doc:p>
+  <element name="extension"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-complexContent::extension">
+    <ref name="extensionType" />
+    <optional>
+      <ref name="typeDefParticle" />
+    </optional>
+    <ref name="attrDecls" />
+  </element>
+</define>
+
+<define name="complexContent">
+  <doc:p>
+    This describes a complexContent element.  It may have a mixed attribute, 
+    and either a restriction or extension element as content.
+  </doc:p>
+  <element name="complexContent"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-complexContent">
+    <ref name="annotated" />
+    <optional>
+      <attribute name="mixed">
+        <data type="boolean" />
+      </attribute>
+    </optional>
+    <choice>
+      <ref name="complexRestriction" />
+      <ref name="complexExtension" />
+    </choice>
+  </element>
+</define>
+
+<define name="simpleRestriction">
+  <doc:p>
+    This describes a restriction element that appears within a simpleContent 
+    or simpleType element (i.e. one that restricts a simple type).  Its 
+    content follows the simple restriction model that is detailed below, and 
+    may include attribute declarations.
+  </doc:p>
+  <element name="restriction"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-simpleContent::restriction">
+    <ref name="annotated" />
+    <ref name="simpleRestrictionModel" />
+    <ref name="attrDecls" />
+  </element>
+</define>
+
+<define name="simpleExtension">
+  <doc:p>
+    This describes an extension element that appears within a simpleContent 
+    element (i.e. one that extends a simple type).  Like other extensions, it 
+    has a base type, but it can only be used to add attributes.
+  </doc:p>
+  <element name="extension"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-simpleContent::extension">
+    <ref name="extensionType" />
+    <ref name="attrDecls" />
+  </element>
+</define>
+
+<define name="simpleContent">
+  <doc:p>
+    This describes a simpleContent element, whose content can either hold a 
+    restriction or extension element.
+  </doc:p>
+  <element name="simpleContent"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-simpleContent">
+    <ref name="annotated" />
+    <choice>
+      <ref name="simpleRestriction" />
+      <ref name="simpleExtension" />
+    </choice>
+  </element>
+</define>
+
+<define name="blockSet">
+  <doc:p>
+    This gives the possible values for block attributes on element elements, 
+    which includes substitution amongst the list of possible values.  This 
+    RELAX NG schema, like the XML Schema Recommendation, allows each of the 
+    keywords 'extension', 'restriction' and 'substitution' to occur more than 
+    once within the list.
+  </doc:p>
+  <choice>
+    <value type="token">#all</value>
+    <list>
+      <oneOrMore>
+        <choice>
+          <value>extension</value>
+          <value>restriction</value>
+          <value>substitution</value>
+        </choice>
+      </oneOrMore>
+    </list>
+  </choice>
+</define>
+
+<define name="element" txw:mode="inherit">
+  <doc:p>
+    This describes the basic content model of an element element.  It is 
+    annotated, may have a fixed or default attribute, and may have nillable 
+    and/or block attributes.  Its type may be specified through a type 
+    attribute, a local simple type or a local complex type - the choice 
+    between these methods is something that cannot be indicated with XML 
+    Schema.  This content is optionally followed by some identify constraints.
+  </doc:p>
+  <ref name="annotated" />
+  <ref name="fixedOrDefault" />
+  <zeroOrMore>
+    <choice>
+      <attribute name="nillable">
+        <data type="boolean" />
+      </attribute>
+      <attribute name="block">
+        <ref name="blockSet" />
+      </attribute>
+    </choice>
+  </zeroOrMore>
+  <choice>
+    <empty />
+    <attribute name="type">
+      <data type="QName" />
+    </attribute>
+    <ref name="simpleTypeHost" />
+    <ref name="complexTypeHost" />
+  </choice>
+  <!--zeroOrMore>
+    <ref name="identityConstraint" />
+  </zeroOrMore-->
+</define>
+
+<define name="topLevelElement">
+  <doc:p>
+    This describes an element element that appears at the top level of the 
+    schema.  On top of the basic content for an element element, it has to 
+    have a name, which is a unique identifier in the element symbol space.  It 
+    may have substitutionGroup, abstract and/or final attributes.
+  </doc:p>
+  <element name="element"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-element">
+    <ref name="element" />
+    <attribute name="name">
+      <data type="NCName" />
+    </attribute>
+    <zeroOrMore>
+      <choice>
+        <attribute name="substitutionGroup">
+          <data type="QName" />
+        </attribute>
+        <attribute name="abstract">
+          <data type="boolean" />
+        </attribute>
+        <attribute name="final">
+          <ref name="derivationSet" />
+        </attribute>
+      </choice>
+    </zeroOrMore>
+  </element>
+</define>
+
+<define name="localElement">
+  <doc:p>
+    This describes an element element that appears locally, within a 
+    complexType or group element.  It may have minOccurs and/or maxOccurs 
+    attributes.  If it has a ref attribute, then that&apos;s all it can 
+    have.  Otherwise, it must have a name and specifies its type in the same 
+    way as the basic element content model described above.  It may in this 
+    case also have a form element.  These constraints on local elements 
+    cannot be described within XML Schema.
+  </doc:p>
+  <element name="element"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-element">
+    <ref name="occurs" />
+    <choice>
+      <attribute name="ref">
+        <data type="QName" />
+      </attribute>
+      <group>
+        <ref name="element" />
+        <attribute name="name">
+          <data type="NCName" />
+        </attribute>
+        <optional>
+          <attribute name="form">
+            <ref name="formChoice" />
+          </attribute>
+        </optional>
+      </group>
+    </choice>
+  </element>
+</define>
+
+<!--define name="namedGroup">
+  <doc:p>
+    This describes an group element that appears at the top level of the 
+    schema.  It must have a name attribute, and must have one of an all, 
+    choice or sequence element child.
+  </doc:p>
+  <element name="group"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-group">
+    <ref name="annotated" />
+    <attribute name="name">
+      <data type="NCName" />
+    </attribute>
+    <choice>
+      <element name="all">
+        <ref name="simpleExplicitGroup" />  <!- - RS - relaxed all content model - ->
+      </element>
+      <element name="choice">
+        <ref name="simpleExplicitGroup" />
+      </element>
+      <element name="sequence">
+        <ref name="simpleExplicitGroup" />
+      </element>
+    </choice>
+  </element>
+</define-->
+
+<!--define name="groupRef">
+  <doc:p>
+    This describes group element that occurs locally, referring to a 
+    top-level named group.  It may have occurrence attributes, and must have 
+    a ref attribute.
+  </doc:p>
+  <element name="group"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-group">
+    <ref name="annotated" />
+    <ref name="occurs" />
+    <attribute name="ref">
+      <data type="QName" />
+    </attribute>
+  </element>
+</define-->
+
+<define name="explicitGroup" txw:mode="inherit">
+  <doc:p>
+    This gives the content of a model group (not a group element) in the 
+    normal run of things.  It has occurrence attributes and any number of 
+    particles within it.
+  </doc:p>
+  <ref name="annotated" />
+  <ref name="occurs" />
+  <zeroOrMore>
+    <ref name="nestedParticle" />
+  </zeroOrMore>
+</define>
+
+<define name="simpleExplicitGroup">
+  <doc:p>
+    This gives the content of a model group (not a group element) within a 
+    named group - it differs from the above in that it doesn&apos;t have any 
+    occurrence attributes.
+  </doc:p>
+  <ref name="annotated" />
+  <zeroOrMore>
+    <ref name="nestedParticle" />
+  </zeroOrMore>
+</define>
+
+<define name="all">
+  <doc:p>
+    This describes an all element that appears outside a named group (i.e. as 
+    the content of a complexType element).  It has the standard model for an 
+    all element, but adds minOccurs and maxOccurs attributes which can only 
+    take certain values.
+  </doc:p>
+  <element name="all"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-all">
+    <ref name="explicitGroup" />
+  </element>
+</define>
+
+<define name="choice">
+  <doc:p>
+    This describes a choice element that appears outside a named group.
+  </doc:p>
+  <element name="choice"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-choice">
+    <ref name="explicitGroup" />
+  </element>
+</define>
+
+<define name="sequence">
+  <doc:p>
+    This describes a sequence element that appears outside a named group.
+  </doc:p>
+  <element name="sequence"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-sequence">
+    <ref name="explicitGroup" />
+  </element>
+</define>
+
+<define name="wildcard" txw:mode="inherit">
+  <doc:p>
+    This describes a wildcard element (i.e. any or anyAttribute).  The 
+    namespace attribute can take a list URIs interspersed with the keywords 
+    '##targetNamespace' and/or '##local'.  This RELAX NG schema, like the XML 
+    Schema Recommendation, allows the keywords to be specified more than once 
+    each within the list, if they&apos;re given.  This model also specifies the 
+    processContents attribute.
+  </doc:p>
+  <ref name="annotated" />
+  <zeroOrMore>
+    <choice>
+      <attribute name="namespace">
+        <choice>
+          <value type="token">##any</value>
+          <value type="token">##other</value>
+          <list>
+            <zeroOrMore>
+              <choice>
+                <data type="anyURI" />
+                <value>##targetNamespace</value>
+                <value>##local</value>
+              </choice>
+            </zeroOrMore>
+          </list>
+        </choice>
+      </attribute>
+      <attribute name="processContents">
+        <choice>
+          <value type="token">lax</value>
+          <value type="token">skip</value>
+          <value type="token">strict</value>
+        </choice>
+      </attribute>
+    </choice>
+  </zeroOrMore>
+</define>
+
+<define name="any">
+  <doc:p>
+    This describes an any element as a wildcard.
+  </doc:p>
+  <element name="any"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-any">
+    <ref name="wildcard" />
+    <ref name="occurs" />
+  </element>
+</define>
+
+<!--define name="namedAttributeGroup">
+  <doc:p>
+    This describes an attributeGroup element as it appears at the top level 
+    of the schema.  It must have a name attribute, and then contains 
+    attribute declarations.
+  </doc:p>
+  <element name="attributeGroup"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-attributeGroup">
+    <ref name="annotated" />
+    <attribute name="name">
+      <data type="NCName" />
+    </attribute>
+    <ref name="attrDecls" />
+  </element>
+</define-->
+
+<!--define name="attributeGroupRef">
+  <doc:p>
+    This describes an attributeGroup element as it appears within a complex 
+    type.  It must have a ref attribute.
+  </doc:p>
+  <element name="attributeGroup"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-attributeGroup">
+    <ref name="annotated" />
+    <attribute name="ref">
+      <data type="QName" />
+    </attribute>
+  </element>
+</define-->
+
+<!--define name="include">
+  <doc:p>
+    This describes an include element, which must have a schemaLocation 
+    attribute.
+  </doc:p>
+  <element name="include"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-include">
+    <ref name="annotated" />
+    <attribute name="schemaLocation">
+      <data type="anyURI" />
+    </attribute>
+  </element>
+</define-->
+
+<!--define name="redefine">
+  <doc:p>
+    This describes a redefine element, which must have a schemaLocation 
+    attribute and can then contain any mix of annotations and redefinable 
+    components.
+  </doc:p>
+  <element name="redefine"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-redefine">
+    <ref name="openAttrs" />
+    <optional>
+      <attribute name="id">
+        <data type="ID" />
+      </attribute>
+    </optional>
+    <attribute name="schemaLocation">
+      <data type="anyURI" />
+    </attribute>
+    <zeroOrMore>
+      <choice>
+        <ref name="annotation" />
+        <ref name="redefinable" />
+      </choice>
+    </zeroOrMore>
+  </element>
+</define-->
+
+<define name="import">
+  <doc:p>
+    This describes an import element that&apos;s used when its parent schema 
+    element specifies a targetNamespace.  In these cases, the namespace 
+    attribute on the import element is optional.
+  </doc:p>
+  <element name="import"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-import">
+	  <ref name="annotated" />
+	  <optional>
+	    <attribute name="schemaLocation">
+	      <data type="anyURI" />
+	    </attribute>
+	  </optional>
+    <optional>
+      <attribute name="namespace">
+        <data type="anyURI" />
+      </attribute>
+    </optional>
+  </element>
+</define>
+
+<!--define name="selector">
+  <doc:p>
+    This describes a selector element.  The xpath attribute is a simplified 
+    XPath - the regular expression given here is the one from the XML Schema 
+    for XML Schema.
+  </doc:p>
+  <element name="selector"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-selector">
+    <ref name="annotated" />
+    <attribute name="xpath">
+      <data type="token">
+        <param name="pattern">(\.//)?(((child::)?((\i\c*:)?(\i\c*|\*)))|\.)(/(((child::)?((\i\c*:)?(\i\c*|\*)))|\.))*(\|(\.//)?(((child::)?((\i\c*:)?(\i\c*|\*)))|\.)(/(((child::)?((\i\c*:)?(\i\c*|\*)))|\.))*)*</param>
+      </data>
+    </attribute>
+  </element>
+</define>
+
+<define name="field">
+  <doc:p>
+    This describes a field element.  The xpath attribute is a simplified 
+    XPath - the regular expression given here is the one from the XML Schema 
+    for XML Schema.
+  </doc:p>
+  <element name="field"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-field">
+    <ref name="annotated" />
+    <attribute name="xpath">
+      <data type="token">
+        <param name="pattern">(\.//)?((((child::)?((\i\c*:)?(\i\c*|\*)))|\.)/)*((((child::)?((\i\c*:)?(\i\c*|\*)))|\.)|((attribute::|@)((\i\c*:)?(\i\c*|\*))))(\|(\.//)?((((child::)?((\i\c*:)?(\i\c*|\*)))|\.)/)*((((child::)?((\i\c*:)?(\i\c*|\*)))|\.)|((attribute::|@)((\i\c*:)?(\i\c*|\*)))))*</param>
+      </data>
+    </attribute>
+  </element>
+</define>
+
+<define name="keybase" txw:mode="inherit">
+  <doc:p>
+    This gives the basic content for identity constraints - a name attribute 
+    that uniquely identifies the identity constraint, a selector element and 
+    one or more field elements.
+  </doc:p>
+  <ref name="annotated" />
+  <attribute name="name">
+    <data type="NCName" />
+  </attribute>
+  <ref name="selector" />
+  <oneOrMore>
+    <ref name="field" />
+  </oneOrMore>
+</define>
+
+<define name="identityConstraint" txw:mode="inline">
+  <doc:p>
+    This gives a model group for the three identity constraint elements, used 
+    within the content of element elements.
+  </doc:p>
+  <choice>
+    <ref name="unique" />
+    <ref name="key" />
+    <ref name="keyref" />
+  </choice>
+</define>
+
+<define name="unique">
+  <doc:p>
+    This describes a unique element.
+  </doc:p>
+  <element name="unique"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-unique">
+    <ref name="keybase" />
+  </element>  
+</define>
+
+<define name="key">
+  <doc:p>
+    This describes a key element.
+  </doc:p>
+  <element name="key"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-key">
+    <ref name="keybase" />
+  </element>
+</define>
+
+<define name="keyref">
+  <doc:p>
+    This describes a keyref element.
+  </doc:p>
+  <element name="keyref"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-keyref">
+    <ref name="keybase" />
+    <attribute name="refer">
+      <data type="QName" />
+    </attribute>
+  </element>
+</define-->
+
+<!--define name="notation">
+  <doc:p>
+    This describes a notation element.  The names of notation elements are 
+    unique in the notation symbol space.  The public attribute is required, 
+    and the system attribute is optional.
+  </doc:p>
+  <element name="notation"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-notation">
+    <ref name="annotated" />
+    <attribute name="name">
+      <data type="NCName" />
+    </attribute>
+    <attribute name="public">
+      <data type="token" />
+    </attribute>
+    <optional>
+      <attribute name="system">
+        <data type="anyURI" />
+      </attribute>
+    </optional>
+  </element>
+</define-->
+
+<define name="appinfoContent">
+  <doc:p>
+    This is designed to describe the content of the appinfo elements in the 
+    schema.  At the moment this allows any mixed content without validation.  
+    Note that this is fairly complex compared to the XML Schema equivalent, 
+    which would be a single any element.
+  </doc:p>
+  <ref name="anyContent" />
+</define>
+
+<define name="anyContent">
+  <empty/>  <!-- KK don't care -->
+  <!--mixed>
+    <zeroOrMore>
+      <element>
+        <anyName />
+        <zeroOrMore>
+          <attribute>
+            <anyName />
+          </attribute>
+        </zeroOrMore>
+        <ref name="anyContent" />
+        <empty />
+      </element>
+    </zeroOrMore>
+  </mixed-->
+</define>
+
+<define name="appinfo">
+  <doc:p>
+    This describes an appinfo element.  It has an optional source attribute 
+    and can currently contain anything at all.
+  </doc:p>
+  <element name="appinfo"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-appinfo">
+    <optional>
+      <attribute name="source">
+        <data type="anyURI" />
+      </attribute>
+    </optional>
+    <ref name="appinfoContent" />
+  </element>
+</define>
+
+<define name="documentationContent">
+  <doc:p>
+    This is designed to describe the content of the documentation elements in 
+    the schema.  At the moment this allows any mixed content without 
+    validation.  Note that this is fairly complex compared to the XML Schema 
+    equivalent, which would be a single any element.
+  </doc:p>
+  <ref name="anyContent" />
+</define>
+
+<define name="documentation">
+  <doc:p>
+    This describes a documentation element.  It has optional source 
+    and xml:lang attributes and can currently contain anything at all.
+  </doc:p>
+  <element name="documentation"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-documentation">
+    <zeroOrMore>
+      <choice>
+        <attribute name="source">
+          <data type="anyURI" />
+        </attribute>
+        <attribute name="xml:lang">
+          <data type="language" />
+        </attribute>
+      </choice>
+    </zeroOrMore>
+    <ref name="documentationContent" />
+  </element>
+</define>
+
+<define name="annotation">
+  <doc:p>
+    This describes an annotation element.  It can have any attributes, may 
+    have an id attribute, and contains any number of documentation or appinfo 
+    elements.
+  </doc:p>
+  <element name="annotation"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-annotation">
+    <ref name="openAttrs" />
+    <optional>
+      <attribute name="id">
+        <data type="ID" />
+      </attribute>
+    </optional>
+    <zeroOrMore>
+      <choice>
+        <ref name="documentation" />
+        <ref name="appinfo" />
+      </choice>
+    </zeroOrMore>
+  </element>
+</define>
+
+<define name="simpleDerivation" txw:mode="inline">
+  <doc:p>
+    This gives the various types of derivation of simple types.
+  </doc:p>
+  <choice>
+    <ref name="simpleRestriction" />
+    <ref name="list" />
+    <ref name="union" />
+  </choice>
+</define>
+
+<define name="simpleDerivationSet">
+  <doc:p>
+    This specifies the values of the final attribute for simple types.  This 
+    RELAX NG schema for XML Schema, like the XML Schema Recommendation, allows 
+    the keywords 'list', 'union' and 'restriction' to appear more than once 
+    within the list.
+  </doc:p>
+  <choice>
+    <value type="token">#all</value>
+    <list>
+      <zeroOrMore>
+        <choice>
+          <value>list</value>
+          <value>union</value>
+          <value>restriction</value>
+        </choice>
+      </zeroOrMore>
+    </list>
+  </choice>
+</define>
+
+<define name="simpleTypeHost" txw:mode="inherit">
+  <ref name="typeHost" />
+  <ref name="simpleType" />
+</define>
+
+<define name="simpleType" txw:mode="inherit">
+  <doc:p>
+    This gives the basic content of a simple type.
+  </doc:p>
+  <element name="simpleType"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-simpleType">
+    <ref name="annotated" />
+    <ref name="simpleDerivation" />
+    <optional>
+      <attribute name="name">
+        <data type="NCName" />
+      </attribute>
+    </optional>
+    <optional>
+      <attribute name="final">
+        <ref name="simpleDerivationSet" />
+      </attribute>
+    </optional>
+  </element>
+</define>
+
+<!--define name="rangeFacets" txw:mode="inherit">
+  <doc:p>
+    This describes the relationship between the various range facets.  Only 
+    one of minExclusive and minInclusive can be present, and only one of 
+    maxExclusive and maxInclusive can be present.  This is a constraint that 
+    can&apos;t easily be expressed using XML Schema.  This RELAX NG schema 
+    for XML Schema is a little more restrictive than the XML Schema 
+    Recommendation in that it also forces there to be a maximum of one of 
+    each of these types of facets.
+  </doc:p>
+  <interleave>
+    <optional>
+      <choice>
+        <ref name="minExclusive" />
+        <ref name="minInclusive" />
+      </choice>
+    </optional>    
+    <optional>
+      <choice>
+        <ref name="maxExclusive" />
+        <ref name="maxInclusive" />
+      </choice>
+    </optional>
+  </interleave>
+</define>
+
+<define name="digitFacets" txw:mode="inherit">
+  <doc:p>
+    This specifies optional totalDigits and fractionDigits elements.  This 
+    RELAX NG schema for XML Schema is a little more restrictive than the XML 
+    Schema Recommendation in that it also forces there to be a maximum of one 
+    of each of these types of facets.
+  </doc:p>
+  <optional>
+    <ref name="totalDigits" />
+  </optional>
+  <optional>
+    <ref name="fractionDigits" />
+  </optional>
+</define>
+
+<define name="lengthFacets" txw:mode="inherit">
+  <doc:p>
+    This specifies optional length, minLength and maxLength elements.  This 
+    RELAX NG schema for XML Schema is a little more restrictive than the XML 
+    Schema Recommendation in that it also forces there to be a maximum of one 
+    of each of these types of facets, and says that if a length element is 
+    given, then neither minLength nor maxLength should be present.
+  </doc:p>
+  <choice>
+    <ref name="length" />
+    <interleave>
+      <optional>
+        <ref name="minLength" />
+      </optional>
+      <optional>
+        <ref name="maxLength" />        
+      </optional>
+    </interleave>
+  </choice>
+</define>
+
+<define name="commonFacets" txw:mode="inherit">
+  <doc:p>
+    This specifies zero or more enumeration or pattern elements and an 
+    optional whiteSpace element.  This RELAX NG schema for XML Schema is a 
+    little more restrictive than the XML Schema Recommendation in that it 
+    also forces there to be a maximum of one whiteSpace element within the 
+    facets.  Note that the whiteSpace facet is constrained to have a value of 
+    'collapse'.
+  </doc:p>
+  <zeroOrMore>
+    <ref name="enumeration" />
+  </zeroOrMore>
+  <optional>
+    <ref name="whiteSpaceCollapse" />
+  </optional>
+  <zeroOrMore>
+    <ref name="pattern" />
+  </zeroOrMore>
+</define-->
+
+<define name="simpleRestrictionModel">
+  <doc:p>
+    This specifies the types of facets that are valid in restrictions on the 
+    built-in data types.  This can only perform rudimentary checking, but 
+    should be enough in most circumstances.  Note that for xs:anySimpleType 
+    and xs:string, the whiteSpace facet can take any value, for 
+    xs:normalizedString it can be 'replace' or 'collapse', and for all other 
+    built-in types it has to be 'collapse'.
+  </doc:p>
+  <choice>
+    <attribute name="base">
+      <data type="QName" />
+    </attribute>
+    <ref name="simpleTypeHost" />
+  </choice>
+  <interleave>
+    <!--ref name="rangeFacets" />
+    <ref name="digitFacets" />
+    <ref name="lengthFacets" />
+    <optional>
+      <ref name="whiteSpace" />
+    </optional-->
+    <zeroOrMore>
+      <ref name="enumeration" />
+    </zeroOrMore>
+    <!--zeroOrMore>
+      <ref name="pattern" />
+    </zeroOrMore-->
+  </interleave>
+</define>
+
+<define name="list">
+  <doc:p>
+    This describes a list element.  It can either specify a local simple type 
+    or have a itemType attribute.  This constraint cannot be expressed in XML 
+    Schema.
+  </doc:p>
+  <element name="list"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-list">
+    <ref name="annotated" />
+    <choice>      
+      <ref name="simpleTypeHost" />
+      <attribute name="itemType">
+        <data type="QName" />
+      </attribute>
+    </choice>
+  </element>
+</define>
+
+<define name="union">
+  <doc:p>
+    This describes a union element.  If the memberTypes attribute is missing 
+    or empty, then it must contain one or more simpleType elements; if 
+    it&apos;s present, then it can contain simpleType elements or list simple 
+    types in the memberTypes attribute.  This constraint cannot be expressed 
+    in XML Schema.
+  </doc:p>
+  <element name="union"
+        doc:href="http://www.w3.org/TR/xmlschema-1/#element-union">
+    <ref name="annotated" />
+    <choice>
+      <group>
+        <attribute name="memberTypes">
+          <list>
+            <oneOrMore>
+              <data type="QName" />
+            </oneOrMore>
+          </list>
+        </attribute>
+        <zeroOrMore>
+          <ref name="simpleTypeHost" />
+        </zeroOrMore>
+      </group>
+      <group>
+        <optional>
+          <attribute name="memberTypes">
+            <empty />
+          </attribute>
+        </optional>
+        <oneOrMore>
+          <ref name="simpleTypeHost" />
+        </oneOrMore>
+      </group>
+    </choice>
+  </element>
+</define>
+
+<define name="facet" txw:mode="inherit">
+  <doc:p>
+    This is the basic content of a facet.  It has an optional fixed attribute.
+  </doc:p>
+  <ref name="annotated" />
+  <optional>
+    <attribute name="fixed">
+      <data type="boolean" />
+    </attribute>
+  </optional>
+</define>
+
+<define name="noFixedFacet" txw:mode="inherit">
+  <doc:p>
+    This is the content of a facet that cannot be fixed (enumeration or 
+    pattern).  It has a value attribute that can take any kind of value.
+  </doc:p>
+  <ref name="annotated" />
+  <attribute name="value" />
+</define>
+
+<!--define name="rangeFacet">
+  <doc:p>
+    This is the content of a range facet.  The value must be one of the data 
+    types shown (as these are the only types of data that accept ranges).  I 
+    haven&apos;t gone so far as to indicate the data type of the value 
+    attribute of a range facet according to the base type as this would be 
+    very complicated (although it would be possible in RELAX NG).
+  </doc:p>
+  <ref name="facet" />
+  <attribute name="value">
+    <choice>
+      <data type="decimal" />
+      <data type="float" />
+      <data type="double" />
+      <data type="duration" />
+      <data type="dateTime" />
+      <data type="time" />
+      <data type="date" />
+      <data type="gYearMonth" />
+      <data type="gYear" />
+      <data type="gMonthDay" />
+      <data type="gMonth" />
+      <data type="gDay" />
+    </choice>
+  </attribute>
+</define>
+
+<define name="minExclusive">
+  <doc:p>
+    This describes a minExclusive element.
+  </doc:p>
+  <element name="minExclusive"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-minExclusive">
+    <ref name="rangeFacet" />
+  </element>
+</define>
+
+<define name="minInclusive">
+  <doc:p>
+    This describes a minInclusive element.
+  </doc:p>
+  <element name="minInclusive"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-minInclusive">
+    <ref name="rangeFacet" />
+  </element>
+</define>
+
+<define name="maxExclusive">
+  <doc:p>
+    This describes a maxExclusive element.
+  </doc:p>
+  <element name="maxExclusive"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-maxExclusive">
+    <ref name="rangeFacet" />
+  </element>
+</define>
+
+<define name="maxInclusive">
+  <doc:p>
+    This describes a maxInclusive element.
+  </doc:p>
+  <element name="maxInclusive"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-maxInclusive">
+    <ref name="rangeFacet" />
+  </element>
+</define>
+
+<define name="numFacet">
+  <doc:p>
+    This is the content of a numerical facet.
+  </doc:p>
+  <ref name="facet" />
+  <attribute name="value">
+    <data type="nonNegativeInteger" />
+  </attribute>
+</define>
+
+<define name="totalDigits">
+  <doc:p>
+    This describes a totalDigits element.  The value attribute must take a 
+    positive integer.
+  </doc:p>
+  <element name="totalDigits"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-totalDigits">
+    <ref name="facet" />
+    <attribute name="value">
+      <data type="positiveInteger" />
+    </attribute>
+  </element>
+</define>
+
+<define name="fractionDigits">
+  <doc:p>
+    This describes a fractionDigits element.
+  </doc:p>
+  <element name="fractionDigits"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-fractionDigits">
+    <ref name="numFacet" />
+  </element>
+</define>
+
+<define name="length">
+  <doc:p>
+    This describes a length element.
+  </doc:p>
+  <element name="length"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-length">
+    <ref name="numFacet" />
+  </element>
+</define>
+
+<define name="minLength">
+  <doc:p>
+    This describes a minLength element.
+  </doc:p>
+  <element name="minLength"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-minLength">
+    <ref name="numFacet" />
+  </element>
+</define>
+
+<define name="maxLength">
+  <doc:p>
+    This describes a maxLength element.
+  </doc:p>
+  <element name="maxLength"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-maxLength">
+    <ref name="numFacet" />
+  </element>
+</define-->
+
+<define name="enumeration">
+  <doc:p>
+    This describes an enumeration element.
+  </doc:p>
+  <element name="enumeration"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-enumeration">
+    <ref name="noFixedFacet" />
+  </element>
+</define>
+
+<!--define name="whiteSpace">
+  <doc:p>
+    This describes a whiteSpace element that can take any of the permitted 
+    values.
+  </doc:p>
+  <element name="whiteSpace"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-whiteSpace">
+    <ref name="facet" />
+    <attribute name="value">
+      <choice>
+        <value type="token">preserve</value>
+        <value type="token">replace</value>
+        <value type="token">collapse</value>
+      </choice>
+    </attribute>
+  </element>
+</define>
+
+<define name="whiteSpaceReplaceOrCollapse">
+  <doc:p>
+    This describes a whiteSpace element that can only take the values 
+    'replace' or 'collapse'.
+  </doc:p>
+  <element name="whiteSpace"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-whiteSpace">
+    <ref name="facet" />
+    <attribute name="value">
+      <choice>
+        <value type="token">replace</value>
+        <value type="token">collapse</value>
+      </choice>
+    </attribute>
+  </element>
+</define>
+
+<define name="whiteSpaceCollapse">
+  <doc:p>
+    This describes a whiteSpace element that can only take the value 
+    'collapse'.
+  </doc:p>
+  <element name="whiteSpace"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-whiteSpace">
+    <ref name="facet" />
+    <attribute name="value">
+      <value type="token">collapse</value>
+    </attribute>
+  </element>
+</define>
+
+<define name="pattern">
+  <doc:p>
+    This describes a pattern element.
+  </doc:p>
+  <element name="pattern"
+        doc:href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/datatypes.html#element-pattern">
+    <ref name="noFixedFacet" />
+  </element>
+</define-->
+
+</grammar>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/ByteArrayOutputStreamEx.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/ByteArrayOutputStreamEx.java
new file mode 100644
index 0000000..6107524
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/ByteArrayOutputStreamEx.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.util;
+
+import java.io.ByteArrayOutputStream;
+import java.io.InputStream;
+import java.io.IOException;
+
+import com.sun.xml.internal.bind.v2.runtime.unmarshaller.Base64Data;
+
+/**
+ * {@link ByteArrayOutputStream} with access to its raw buffer.
+ */
+public final class ByteArrayOutputStreamEx extends ByteArrayOutputStream {
+    public ByteArrayOutputStreamEx() {
+    }
+
+    public ByteArrayOutputStreamEx(int size) {
+        super(size);
+    }
+
+    public void set(Base64Data dt,String mimeType) {
+        dt.set(buf,count,mimeType);
+    }
+
+    public byte[] getBuffer() {
+        return buf;
+    }
+
+    /**
+     * Reads the given {@link InputStream} completely into the buffer.
+     */
+    public void readFrom(InputStream is) throws IOException {
+        while(true) {
+            if(count==buf.length) {
+                // realllocate
+                byte[] data = new byte[buf.length*2];
+                System.arraycopy(buf,0,data,0,buf.length);
+                buf = data;
+            }
+
+            int sz = is.read(buf,count,buf.length-count);
+            if(sz<0)     return;
+            count += sz;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/CollisionCheckStack.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/CollisionCheckStack.java
new file mode 100644
index 0000000..67f14b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/CollisionCheckStack.java
@@ -0,0 +1,169 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.util;
+
+import java.util.AbstractList;
+import java.util.Arrays;
+import java.util.List;
+import java.util.Stack;
+
+/**
+ * {@link Stack}-like data structure that allows the following efficient operations:
+ *
+ * <ol>
+ * <li>Push/pop operation.
+ * <li>Duplicate check. When an object that's already in the stack is pushed,
+ *     this class will tell you so.
+ * </ol>
+ *
+ * <p>
+ * Object equality is their identity equality.
+ *
+ * <p>
+ * This class implements {@link List} for accessing items in the stack,
+ * but {@link List} methods that alter the stack is not supported.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class CollisionCheckStack<E> extends AbstractList<E> {
+    private Object[] data;
+    private int[] next;
+    private int size = 0;
+
+    // for our purpose, there isn't much point in resizing this as we don't expect
+    // the stack to grow that much.
+    private final int[] initialHash;
+
+    public CollisionCheckStack() {
+        initialHash = new int[17];
+        data = new Object[16];
+        next = new int[16];
+    }
+
+    /**
+     * Pushes a new object to the stack.
+     *
+     * @return
+     *      true if this object has already been pushed
+     */
+    public boolean push(E o) {
+        if(data.length==size)
+            expandCapacity();
+
+        data[size] = o;
+        int hash = hash(o);
+        boolean r = findDuplicate(o, hash);
+        next[size] = initialHash[hash];
+        initialHash[hash] = size+1;
+        size++;
+        return r;
+    }
+
+    /**
+     * Pushes a new object to the stack without making it participate
+     * with the collision check.
+     */
+    public void pushNocheck(E o) {
+        if(data.length==size)
+            expandCapacity();
+        data[size] = o;
+        next[size] = -1;
+        size++;
+    }
+
+    @Override
+    public E get(int index) {
+        return (E)data[index];
+    }
+
+    @Override
+    public int size() {
+        return size;
+    }
+
+    private int hash(Object o) {
+        return System.identityHashCode(o) % initialHash.length;
+    }
+
+    /**
+     * Pops an object from the stack
+     */
+    public E pop() {
+        size--;
+        Object o = data[size];
+        data[size] = null;  // keeping references too long == memory leak
+        int n = next[size];
+        if(n<0) {
+            // pushed by nocheck. no need to update hash
+        } else {
+            int hash = hash(o);
+            assert initialHash[hash]==size+1;
+            initialHash[hash] = n;
+        }
+        return (E)o;
+    }
+
+    /**
+     * Returns the top of the stack.
+     */
+    public E peek() {
+        return (E)data[size-1];
+    }
+
+    private boolean findDuplicate(E o, int hash) {
+        int p = initialHash[hash];
+        while(p!=0) {
+            p--;
+            Object existing = data[p];
+            if(existing==o)     return true;
+            p = next[p];
+        }
+        return false;
+    }
+
+    private void expandCapacity() {
+        int oldSize = data.length;
+        int newSize = oldSize * 2;
+        Object[] d = new Object[newSize];
+        int[] n = new int[newSize];
+
+        System.arraycopy(data,0,d,0,oldSize);
+        System.arraycopy(next,0,n,0,oldSize);
+
+        data = d;
+        next = n;
+    }
+
+    /**
+     * Clears all the contents in the stack.
+     */
+    public void reset() {
+        if(size>0) {
+            size = 0;
+            Arrays.fill(initialHash,0);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/DataSourceSource.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/DataSourceSource.java
new file mode 100644
index 0000000..5c981a5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/DataSourceSource.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.util;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.io.Reader;
+
+import javax.activation.DataHandler;
+import javax.activation.DataSource;
+import javax.activation.MimeType;
+import javax.activation.MimeTypeParseException;
+import javax.xml.transform.Source;
+import javax.xml.transform.stream.StreamSource;
+
+/**
+ * {@link Source} implementation backed by {@link DataHandler}.
+ *
+ * <p>
+ * This implementation allows the same {@link Source} to be used
+ * mutliple times.
+ *
+ * <p>
+ * {@link Source} isn't really pluggable. As a consequence,
+ * this implementation is clunky --- weak against unexpected
+ * usage of the class.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class DataSourceSource extends StreamSource {
+    private final DataSource source;
+
+    /**
+     * If null, default to the encoding declaration
+     */
+    private final String charset;
+
+    public DataSourceSource(DataHandler dh) throws MimeTypeParseException {
+        this(dh.getDataSource());
+    }
+
+    public DataSourceSource(DataSource source) throws MimeTypeParseException {
+        this.source = source;
+
+        String ct = source.getContentType();
+        if(ct==null) {
+            charset = null;
+        } else {
+            MimeType mimeType = new MimeType(ct);
+            this.charset = mimeType.getParameter("charset");
+        }
+    }
+
+    @Override
+    public void setReader(Reader reader) {
+        throw new UnsupportedOperationException();
+    }
+
+    @Override
+    public void setInputStream(InputStream inputStream) {
+        throw new UnsupportedOperationException();
+    }
+
+    @Override
+    public Reader getReader() {
+        try {
+            if(charset==null)   return null;
+            else                return new InputStreamReader(source.getInputStream(),charset);
+        } catch (IOException e) {
+            // argh
+            throw new RuntimeException(e);
+        }
+    }
+
+    @Override
+    public InputStream getInputStream() {
+        try {
+            if(charset==null)   return source.getInputStream();
+            else                return null;
+        } catch (IOException e) {
+            // argh
+            throw new RuntimeException(e);
+        }
+    }
+
+    public DataSource getDataSource() {
+        return source;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/EditDistance.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/EditDistance.java
new file mode 100644
index 0000000..6da0668
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/EditDistance.java
@@ -0,0 +1,112 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.util;
+
+/**
+ * Computes the string edit distance.
+ *
+ * <p>
+ * Refer to a computer science text book for the definition
+ * of the "string edit distance".
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class EditDistance {
+
+    /**
+     * Computes the edit distance between two strings.
+     *
+     * <p>
+     * The complexity is O(nm) where n=a.length() and m=b.length().
+     */
+    public static int editDistance( String a, String b ) {
+        return new EditDistance(a,b).calc();
+    }
+
+    /**
+     * Finds the string in the <code>group</code> closest to
+     * <code>key</code> and returns it.
+     *
+     * @return null if group.length==0.
+     */
+    public static String findNearest( String key, String[] group ) {
+        int c = Integer.MAX_VALUE;
+        String r = null;
+
+        for( int i=0; i<group.length; i++ ) {
+            int ed = editDistance(key,group[i]);
+            if( c>ed ) {
+                c = ed;
+                r = group[i];
+            }
+        }
+        return r;
+    }
+
+    /** cost vector. */
+    private int[] cost;
+    /** back buffer. */
+    private int[] back;
+
+    /** Two strings to be compared. */
+    private final String a,b;
+
+    private EditDistance( String a, String b ) {
+        this.a=a;
+        this.b=b;
+        cost = new int[a.length()+1];
+        back = new int[a.length()+1]; // back buffer
+
+        for( int i=0; i<=a.length(); i++ )
+            cost[i] = i;
+    }
+
+    /**
+     * Swaps two buffers.
+     */
+    private void flip() {
+        int[] t = cost;
+        cost = back;
+        back = t;
+    }
+
+    private int min(int a,int b,int c) {
+        return Math.min(a,Math.min(b,c));
+    }
+
+    private int calc() {
+        for( int j=0; j<b.length(); j++ ) {
+            flip();
+            cost[0] = j+1;
+            for( int i=0; i<a.length(); i++ ) {
+                int match = (a.charAt(i)==b.charAt(j))?0:1;
+                cost[i+1] = min( back[i]+match, cost[i]+1, back[i+1]+1 );
+            }
+        }
+        return cost[a.length()];
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/FatalAdapter.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/FatalAdapter.java
new file mode 100644
index 0000000..5e7d5c2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/FatalAdapter.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.util;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.SAXException;
+
+/**
+ * Maps an error to a fatal error.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class FatalAdapter implements ErrorHandler {
+    private final ErrorHandler core;
+
+    public FatalAdapter(ErrorHandler handler) {
+        this.core = handler;
+    }
+
+    public void warning (SAXParseException exception) throws SAXException {
+        core.warning(exception);
+    }
+
+    public void error (SAXParseException exception) throws SAXException {
+        core.fatalError(exception);
+    }
+
+    public void fatalError (SAXParseException exception) throws SAXException {
+        core.fatalError(exception);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/FlattenIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/FlattenIterator.java
new file mode 100644
index 0000000..02a3db9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/FlattenIterator.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.util;
+
+import java.util.Iterator;
+import java.util.Map;
+import java.util.NoSuchElementException;
+
+/**
+ * {@link Iterator} that walks over a map of maps.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since 2.0
+ */
+public final class FlattenIterator<T> implements Iterator<T> {
+
+    private final Iterator<? extends Map<?,? extends T>> parent;
+    private Iterator<? extends T> child = null;
+    private T next;
+
+    public FlattenIterator( Iterable<? extends Map<?,? extends T>> core ) {
+        this.parent = core.iterator();
+    }
+
+
+    public void remove() {
+        throw new UnsupportedOperationException();
+    }
+
+    public boolean hasNext() {
+        getNext();
+        return next!=null;
+    }
+
+    public T next() {
+        T r = next;
+        next = null;
+        if(r==null)
+            throw new NoSuchElementException();
+        return r;
+    }
+
+    private void getNext() {
+        if(next!=null)  return;
+
+        if(child!=null && child.hasNext()) {
+            next = child.next();
+            return;
+        }
+        // child is empty
+        if(parent.hasNext()) {
+            child = parent.next().values().iterator();
+            getNext();
+        }
+        // else
+        //      no more object
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/QNameMap.java b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/QNameMap.java
new file mode 100644
index 0000000..92855b2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/bind/v2/util/QNameMap.java
@@ -0,0 +1,475 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.bind.v2.util;
+import java.util.AbstractSet;
+import java.util.Iterator;
+import java.util.NoSuchElementException;
+import java.util.Set;
+import java.util.Map;
+import java.util.Collection;
+import java.util.HashSet;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.bind.v2.runtime.Name;
+
+/**
+ * Map keyed by {@link QName}.
+ *
+ * This specialized map allows a look up operation without constructing
+ * a new QName instance, for a performance reason. This {@link Map} assumes
+ * that both namespace URI and local name are {@link String#intern() intern}ed.
+ *
+ * @since JAXB 2.0
+ */
+public final class QNameMap<V> {
+    /**
+     * The default initial capacity - MUST be a power of two.
+     */
+    private static final int DEFAULT_INITIAL_CAPACITY = 16;
+
+    /**
+     * The maximum capacity, used if a higher value is implicitly specified
+     * by either of the constructors with arguments.
+     * MUST be a power of two <= 1<<30.
+     */
+    private static final int MAXIMUM_CAPACITY = 1 << 30;
+
+    /**
+     * The table, resized as necessary. Length MUST Always be a power of two.
+     */
+    transient Entry<V>[] table = new Entry[DEFAULT_INITIAL_CAPACITY];
+
+    /**
+     * The number of key-value mappings contained in this identity hash map.
+     */
+    transient int size;
+
+    /**
+     * The next size value at which to resize . Taking it as
+     * MAXIMUM_CAPACITY
+     * @serial
+     */
+    private int threshold;
+
+    /**
+     * The load factor used when none specified in constructor.
+     **/
+    private static final float DEFAULT_LOAD_FACTOR = 0.75f;
+
+
+
+    /**
+     * Gives an entrySet view of this map
+     */
+    private Set<Entry<V>> entrySet = null;
+
+    public QNameMap() {
+        threshold = (int)(DEFAULT_INITIAL_CAPACITY * DEFAULT_LOAD_FACTOR);
+        table = new Entry[DEFAULT_INITIAL_CAPACITY];
+
+    }
+
+    /**
+     * Associates the specified value with the specified keys in this map.
+     * If the map previously contained a mapping for this key, the old
+     * value is replaced.
+     *
+     * @param namespaceUri First key with which the specified value is to be associated.
+     * @param localname Second key with which the specified value is to be associated.
+     * @param value value to be associated with the specified key.
+     *
+     */
+    public void put(String namespaceUri,String localname, V value ) {
+        //keys cannot be null
+        assert localname !=null;
+        assert namespaceUri !=null;
+        // keys must be interned
+        assert localname == localname.intern();
+        assert namespaceUri == namespaceUri.intern();
+
+        int hash = hash(localname);
+        int i = indexFor(hash, table.length);
+
+        for (Entry<V> e = table[i]; e != null; e = e.next) {
+            if (e.hash == hash && localname == e.localName && namespaceUri==e.nsUri) {
+                e.value = value;
+                return;
+            }
+        }
+
+        addEntry(hash, namespaceUri,localname, value, i);
+
+    }
+
+    public void put(QName name, V value ) {
+        put(name.getNamespaceURI(),name.getLocalPart(),value);
+    }
+
+    public void put(Name name, V value ) {
+        put(name.nsUri,name.localName,value);
+    }
+
+    /**
+     * Returns the value to which the specified keys are mapped in this QNameMap,
+     * or <tt>null</tt> if the map contains no mapping for this key.
+     *
+     * @param   nsUri the namespaceUri key whose associated value is to be returned.
+     * @param   localPart the localPart key whose associated value is to be returned.
+     * @return  the value to which this map maps the specified set of keya, or
+     *          <tt>null</tt> if the map contains no mapping for this set of keys.
+     * @see #put(String,String, Object)
+     */
+    public V get( String nsUri, String localPart ) {
+        Entry<V> e = getEntry(nsUri,localPart);
+        if(e==null) return null;
+        else        return e.value;
+    }
+
+    public V get( QName name ) {
+        return get(name.getNamespaceURI(),name.getLocalPart());
+    }
+
+    /**
+     * Returns the number of keys-value mappings in this map.
+     *
+     * @return the number of keys-value mappings in this map.
+     */
+    public int size() {
+        return size;
+    }
+
+    /**
+     * Copies all of the mappings from the specified map to this map
+     * These mappings will replace any mappings that
+     * this map had for any of the keys currently in the specified map.
+     *
+     * @param map mappings to be stored in this map.
+     *
+     */
+    public QNameMap<V> putAll(QNameMap<? extends V> map) {
+        int numKeysToBeAdded = map.size();
+        if (numKeysToBeAdded == 0)
+            return this;
+
+
+        if (numKeysToBeAdded > threshold) {
+            int targetCapacity = numKeysToBeAdded;
+            if (targetCapacity > MAXIMUM_CAPACITY)
+                targetCapacity = MAXIMUM_CAPACITY;
+            int newCapacity = table.length;
+            while (newCapacity < targetCapacity)
+                newCapacity <<= 1;
+            if (newCapacity > table.length)
+                resize(newCapacity);
+        }
+
+        for( Entry<? extends V> e : map.entrySet() )
+            put(e.nsUri,e.localName,e.getValue());
+        return this;
+    }
+
+
+    /**
+     * Returns a hash value for the specified object.The hash value is computed
+     * for the localName.
+     */
+    private static int hash(String x) {
+        int h = x.hashCode();
+
+        h += ~(h << 9);
+        h ^=  (h >>> 14);
+        h +=  (h << 4);
+        h ^=  (h >>> 10);
+        return h;
+    }
+
+    /**
+     * Returns index for hash code h.
+     */
+    private static int indexFor(int h, int length) {
+        return h & (length-1);
+    }
+
+    /**
+     * Add a new entry with the specified keys, value and hash code to
+     * the specified bucket.  It is the responsibility of this
+     * method to resize the table if appropriate.
+     *
+     */
+    private void addEntry(int hash, String nsUri, String localName, V value, int bucketIndex) {
+        Entry<V> e = table[bucketIndex];
+        table[bucketIndex] = new Entry<V>(hash, nsUri, localName, value, e);
+        if (size++ >= threshold)
+            resize(2 * table.length);
+    }
+
+
+    /**
+     * Rehashes the contents of this map into a new array with a
+     * larger capacity.  This method is called automatically when the
+     * number of keys in this map reaches its threshold.
+     */
+    private void resize(int newCapacity) {
+        Entry[] oldTable = table;
+        int oldCapacity = oldTable.length;
+        if (oldCapacity == MAXIMUM_CAPACITY) {
+            threshold = Integer.MAX_VALUE;
+            return;
+        }
+
+        Entry[] newTable = new Entry[newCapacity];
+        transfer(newTable);
+        table = newTable;
+        threshold = newCapacity;
+    }
+
+    /**
+     * Transfer all entries from current table to newTable.
+     */
+    private void transfer(Entry<V>[] newTable) {
+        Entry<V>[] src = table;
+        int newCapacity = newTable.length;
+        for (int j = 0; j < src.length; j++) {
+            Entry<V> e = src[j];
+            if (e != null) {
+                src[j] = null;
+                do {
+                    Entry<V> next = e.next;
+                    int i = indexFor(e.hash, newCapacity);
+                    e.next = newTable[i];
+                    newTable[i] = e;
+                    e = next;
+                } while (e != null);
+            }
+        }
+    }
+
+    /**
+     * Returns one random item in the map.
+     * If this map is empty, return null.
+     *
+     * <p>
+     * This method is useful to obtain the value from a map that only contains one element.
+     */
+    public Entry<V> getOne() {
+        for( Entry<V> e : table ) {
+            if(e!=null)
+                return e;
+        }
+        return null;
+    }
+
+    public Collection<QName> keySet() {
+        Set<QName> r = new HashSet<QName>();
+        for (Entry<V> e : entrySet()) {
+            r.add(e.createQName());
+        }
+        return r;
+    }
+
+    private abstract class HashIterator<E> implements Iterator<E> {
+        Entry<V> next;  // next entry to return
+        int index;              // current slot
+
+        HashIterator() {
+            Entry<V>[] t = table;
+            int i = t.length;
+            Entry<V> n = null;
+            if (size != 0) { // advance to first entry
+                while (i > 0 && (n = t[--i]) == null)
+                    ;
+            }
+            next = n;
+            index = i;
+        }
+
+        public boolean hasNext() {
+            return next != null;
+        }
+
+        Entry<V> nextEntry() {
+            Entry<V> e = next;
+            if (e == null)
+                throw new NoSuchElementException();
+
+            Entry<V> n = e.next;
+            Entry<V>[] t = table;
+            int i = index;
+            while (n == null && i > 0)
+                n = t[--i];
+            index = i;
+            next = n;
+            return e;
+        }
+
+        public void remove() {
+            throw new UnsupportedOperationException();
+        }
+    }
+
+    public boolean containsKey(String nsUri,String localName) {
+        return getEntry(nsUri,localName)!=null;
+    }
+
+
+    /**
+     * Returns true if this map is empty.
+     */
+    public boolean isEmpty() {
+        return size == 0;
+    }
+
+
+    public static final class Entry<V>  {
+        /** The namespace URI. */
+        public final String nsUri;
+
+        /** The localPart. */
+        public final String localName;
+
+        V value;
+        final int hash;
+        Entry<V> next;
+
+        /**
+         * Create new entry.
+         */
+        Entry(int h, String nsUri, String localName, V v, Entry<V> n) {
+            value = v;
+            next = n;
+            this.nsUri = nsUri;
+            this.localName = localName;
+            hash = h;
+        }
+
+        /**
+         * Creates a new QName object from {@link #nsUri} and {@link #localName}.
+         */
+        public QName createQName() {
+            return new QName(nsUri,localName);
+        }
+
+        public V getValue() {
+            return value;
+        }
+
+        public V setValue(V newValue) {
+            V oldValue = value;
+            value = newValue;
+            return oldValue;
+        }
+
+        public boolean equals(Object o) {
+            if (!(o instanceof Entry))
+                return false;
+            Entry e = (Entry)o;
+            String k1 = nsUri;
+            String k2 = e.nsUri;
+            String k3 = localName;
+            String k4 = e.localName;
+            if (k1 == k2 || (k1 != null && k1.equals(k2)) &&
+                    (k3 == k4 ||(k3 !=null && k3.equals(k4)))) {
+                Object v1 = getValue();
+                Object v2 = e.getValue();
+                if (v1 == v2 || (v1 != null && v1.equals(v2)))
+                    return true;
+            }
+            return false;
+        }
+
+        public int hashCode() {
+            return ( localName.hashCode()) ^
+                    (value==null   ? 0 : value.hashCode());
+        }
+
+        public String toString() {
+            return '"'+nsUri +"\",\"" +localName + "\"=" + getValue();
+        }
+    }
+
+    public Set<Entry<V>> entrySet() {
+        Set<Entry<V>> es = entrySet;
+        return es != null ? es : (entrySet = new EntrySet());
+    }
+
+    private Iterator<Entry<V>> newEntryIterator() {
+        return new EntryIterator();
+    }
+
+    private class EntryIterator extends HashIterator<Entry<V>> {
+        public Entry<V> next() {
+            return nextEntry();
+        }
+    }
+    private class EntrySet extends AbstractSet<Entry<V>> {
+        public Iterator<Entry<V>> iterator() {
+            return newEntryIterator();
+        }
+        public boolean contains(Object o) {
+            if (!(o instanceof Entry))
+                return false;
+            Entry<V> e = (Entry<V>) o;
+            Entry<V> candidate = getEntry(e.nsUri,e.localName);
+            return candidate != null && candidate.equals(e);
+        }
+        public boolean remove(Object o) {
+            throw new UnsupportedOperationException();
+        }
+        public int size() {
+            return size;
+        }
+    }
+
+    private Entry<V> getEntry(String nsUri,String localName) {
+        // strings must be interned
+        assert nsUri==nsUri.intern();
+        assert localName==localName.intern();
+
+        int hash = hash(localName);
+        int i = indexFor(hash, table.length);
+        Entry<V> e = table[i];
+        while (e != null && !(localName == e.localName && nsUri == e.nsUri))
+            e = e.next;
+        return e;
+    }
+
+    public String toString() {
+        StringBuilder buf = new StringBuilder();
+        buf.append('{');
+
+        for( Entry<V> e : entrySet() ) {
+            if(buf.length()>1)
+                buf.append(',');
+            buf.append('[');
+            buf.append(e);
+            buf.append(']');
+        }
+
+        buf.append('}');
+        return buf.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDEventListener.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDEventListener.java
new file mode 100644
index 0000000..8ce5b54
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDEventListener.java
@@ -0,0 +1,344 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+import java.util.EventListener;
+
+/**
+ * All DTD parsing events are signaled through this interface.
+ */
+public interface DTDEventListener extends EventListener {
+
+    public void setDocumentLocator(Locator loc);
+
+    /**
+     * Receive notification of a Processing Instruction.
+     * Processing instructions contain information meaningful
+     * to the application.
+     *
+     * @param target The target of the proceessing instruction
+     *               which should have meaning to the application.
+     * @param data   The instruction itself which should contain
+     *               valid XML characters.
+     * @throws SAXException
+     */
+    public void processingInstruction(String target, String data)
+            throws SAXException;
+
+    /**
+     * Receive notification of a Notation Declaration.
+     * Notation declarations are used by elements and entities
+     * for identifying embedded non-XML data.
+     *
+     * @param name     The notation name, referred to by entities and
+     *                 elements.
+     * @param publicId The public identifier
+     * @param systemId The system identifier
+     */
+    public void notationDecl(String name, String publicId, String systemId)
+            throws SAXException;
+
+    /**
+     * Receive notification of an unparsed entity declaration.
+     * Unparsed entities are non-XML data.
+     *
+     * @param name         The name of the unparsed entity.
+     * @param publicId     The public identifier
+     * @param systemId     The system identifier
+     * @param notationName The associated notation
+     */
+    public void unparsedEntityDecl(String name, String publicId,
+                                   String systemId, String notationName)
+            throws SAXException;
+
+    /**
+     * Receive notification of a internal general entity declaration event.
+     *
+     * @param name  The internal general entity name.
+     * @param value The value of the entity, which may include unexpanded
+     *              entity references.  Character references will have been
+     *              expanded.
+     * @throws SAXException
+     * @see #externalGeneralEntityDecl(String, String, String)
+     */
+    public void internalGeneralEntityDecl(String name, String value)
+            throws SAXException;
+
+    /**
+     * Receive notification of an external parsed general entity
+     * declaration event.
+     * <p/>
+     * <p>If a system identifier is present, and it is a relative URL, the
+     * parser will have resolved it fully before passing it through this
+     * method to a listener.</p>
+     *
+     * @param name     The entity name.
+     * @param publicId The entity's public identifier, or null if
+     *                 none was given.
+     * @param systemId The entity's system identifier.
+     * @throws SAXException
+     * @see #unparsedEntityDecl(String, String, String, String)
+     */
+    public void externalGeneralEntityDecl(String name, String publicId,
+                                          String systemId)
+            throws SAXException;
+
+    /**
+     * Receive notification of a internal parameter entity declaration
+     * event.
+     *
+     * @param name  The internal parameter entity name.
+     * @param value The value of the entity, which may include unexpanded
+     *              entity references.  Character references will have been
+     *              expanded.
+     * @throws SAXException
+     * @see #externalParameterEntityDecl(String, String, String)
+     */
+    public void internalParameterEntityDecl(String name, String value)
+            throws SAXException;
+
+    /**
+     * Receive notification of an external parameter entity declaration
+     * event.
+     * <p/>
+     * <p>If a system identifier is present, and it is a relative URL, the
+     * parser will have resolved it fully before passing it through this
+     * method to a listener.</p>
+     *
+     * @param name     The parameter entity name.
+     * @param publicId The entity's public identifier, or null if
+     *                 none was given.
+     * @param systemId The entity's system identifier.
+     * @throws SAXException
+     * @see #unparsedEntityDecl(String, String, String, String)
+     */
+    public void externalParameterEntityDecl(String name, String publicId,
+                                            String systemId)
+            throws SAXException;
+
+    /**
+     * Receive notification of the beginning of the DTD.
+     *
+     * @param in Current input entity.
+     * @see #endDTD()
+     */
+    public void startDTD(InputEntity in)
+            throws SAXException;
+
+    /**
+     * Receive notification of the end of a DTD.  The parser will invoke
+     * this method only once.
+     *
+     * @throws SAXException
+     * @see #startDTD(InputEntity)
+     */
+    public void endDTD()
+            throws SAXException;
+
+    /**
+     * Receive notification that a comment has been read.
+     * <p/>
+     * <P> Note that processing instructions are the mechanism designed
+     * to hold information for consumption by applications, not comments.
+     * XML systems may rely on applications being able to access information
+     * found in processing instructions; this is not true of comments, which
+     * are typically discarded.
+     *
+     * @param text the text within the comment delimiters.
+     * @throws SAXException
+     */
+    public void comment(String text)
+            throws SAXException;
+
+    /**
+     * Receive notification of character data.
+     * <p/>
+     * <p>The Parser will call this method to report each chunk of
+     * character data.  SAX parsers may return all contiguous character
+     * data in a single chunk, or they may split it into several
+     * chunks; however, all of the characters in any single event
+     * must come from the same external entity, so that the Locator
+     * provides useful information.</p>
+     * <p/>
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     * <p/>
+     * <p>Note that some parsers will report whitespace using the
+     * ignorableWhitespace() method rather than this one (validating
+     * parsers must do so).</p>
+     *
+     * @param ch     The characters from the DTD.
+     * @param start  The start position in the array.
+     * @param length The number of characters to read from the array.
+     * @throws SAXException
+     * @see #ignorableWhitespace(char[], int, int)
+     */
+    public void characters(char ch[], int start, int length)
+            throws SAXException;
+
+
+    /**
+     * Receive notification of ignorable whitespace in element content.
+     * <p/>
+     * <p>Validating Parsers must use this method to report each chunk
+     * of ignorable whitespace (see the W3C XML 1.0 recommendation,
+     * section 2.10): non-validating parsers may also use this method
+     * if they are capable of parsing and using content models.</p>
+     * <p/>
+     * <p>SAX parsers may return all contiguous whitespace in a single
+     * chunk, or they may split it into several chunks; however, all of
+     * the characters in any single event must come from the same
+     * external entity, so that the Locator provides useful
+     * information.</p>
+     * <p/>
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * @param ch     The characters from the DTD.
+     * @param start  The start position in the array.
+     * @param length The number of characters to read from the array.
+     * @throws SAXException
+     * @see #characters(char[], int, int)
+     */
+    public void ignorableWhitespace(char ch[], int start, int length)
+            throws SAXException;
+
+    /**
+     * Receive notification that a CDATA section is beginning.  Data in a
+     * CDATA section is is reported through the appropriate event, either
+     * <em>characters()</em> or <em>ignorableWhitespace</em>.
+     *
+     * @throws SAXException
+     * @see #endCDATA()
+     */
+    public void startCDATA() throws SAXException;
+
+
+    /**
+     * Receive notification that the CDATA section finished.
+     *
+     * @throws SAXException
+     * @see #startCDATA()
+     */
+    public void endCDATA() throws SAXException;
+
+
+    public void fatalError(SAXParseException e)
+            throws SAXException;
+
+    public void error(SAXParseException e) throws SAXException;
+
+    public void warning(SAXParseException err) throws SAXException;
+
+    public final short CONTENT_MODEL_EMPTY = 0;
+    public final short CONTENT_MODEL_ANY = 1;
+    public final short CONTENT_MODEL_MIXED = 2;
+    public final short CONTENT_MODEL_CHILDREN = 3;
+
+    /**
+     * receives notification that parsing of content model is beginning.
+     *
+     * @param elementName      name of the element whose content model is going to be defined.
+     * @param contentModelType {@link #CONTENT_MODEL_EMPTY}
+     *                         this element has EMPTY content model. This notification
+     *                         will be immediately followed by the corresponding endContentModel.
+     *                         {@link #CONTENT_MODEL_ANY}
+     *                         this element has ANY content model. This notification
+     *                         will be immediately followed by the corresponding endContentModel.
+     *                         {@link #CONTENT_MODEL_MIXED}
+     *                         this element has mixed content model. #PCDATA will not be reported.
+     *                         each child element will be reported by mixedElement method.
+     *                         {@link #CONTENT_MODEL_CHILDREN}
+     *                         this elemen has child content model. The actual content model will
+     *                         be reported by childElement, startModelGroup, endModelGroup, and
+     *                         connector methods. Possible call sequences are:
+     *                         <p/>
+     *                         START := MODEL_GROUP
+     *                         MODEL_GROUP := startModelGroup TOKEN (connector TOKEN)* endModelGroup
+     *                         TOKEN := childElement
+     *                         | MODEL_GROUP
+     */
+    public void startContentModel(String elementName, short contentModelType) throws SAXException;
+
+    /**
+     * receives notification that parsing of content model is finished.
+     */
+    public void endContentModel(String elementName, short contentModelType) throws SAXException;
+
+    public final short USE_NORMAL = 0;
+    public final short USE_IMPLIED = 1;
+    public final short USE_FIXED = 2;
+    public final short USE_REQUIRED = 3;
+
+    /**
+     * For each entry in an ATTLIST declaration,
+     * this event will be fired.
+     * <p/>
+     * <p/>
+     * DTD allows the same attributes to be declared more than
+     * once, and in that case the first one wins. I think
+     * this method will be only fired for the first one,
+     * but I need to check.
+     */
+    public void attributeDecl(String elementName, String attributeName, String attributeType,
+                              String[] enumeration, short attributeUse, String defaultValue) throws SAXException;
+
+    public void childElement(String elementName, short occurence) throws SAXException;
+
+    /**
+     * receives notification of child element of mixed content model.
+     * this method is called for each child element.
+     *
+     * @see #startContentModel(String, short)
+     */
+    public void mixedElement(String elementName) throws SAXException;
+
+    public void startModelGroup() throws SAXException;
+
+    public void endModelGroup(short occurence) throws SAXException;
+
+    public final short CHOICE = 0;
+    public final short SEQUENCE = 1;
+
+    /**
+     * Connectors in one model group is guaranteed to be the same.
+     * <p/>
+     * <p/>
+     * IOW, you'll never see an event sequence like (a|b,c)
+     *
+     * @return {@link #CHOICE} or {@link #SEQUENCE}.
+     */
+    public void connector(short connectorType) throws SAXException;
+
+    public final short OCCURENCE_ZERO_OR_MORE = 0;
+    public final short OCCURENCE_ONE_OR_MORE = 1;
+    public final short OCCURENCE_ZERO_OR_ONE = 2;
+    public final short OCCURENCE_ONCE = 3;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDHandlerBase.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDHandlerBase.java
new file mode 100644
index 0000000..d169040
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDHandlerBase.java
@@ -0,0 +1,120 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+/**
+ * do-nothing implementation of DTDEventHandler.
+ */
+public class DTDHandlerBase implements DTDEventListener {
+
+    public void processingInstruction(String target, String data)
+            throws SAXException {
+    }
+
+    public void setDocumentLocator(Locator loc) {
+    }
+
+    public void fatalError(SAXParseException e) throws SAXException {
+        throw e;
+    }
+
+    public void error(SAXParseException e) throws SAXException {
+        throw e;
+    }
+
+    public void warning(SAXParseException err) throws SAXException {
+    }
+
+    public void notationDecl(String name, String publicId, String systemId) throws SAXException {
+    }
+
+    public void unparsedEntityDecl(String name, String publicId,
+                                   String systemId, String notationName) throws SAXException {
+    }
+
+    public void endDTD() throws SAXException {
+    }
+
+    public void externalGeneralEntityDecl(String n, String p, String s) throws SAXException {
+    }
+
+    public void internalGeneralEntityDecl(String n, String v) throws SAXException {
+    }
+
+    public void externalParameterEntityDecl(String n, String p, String s) throws SAXException {
+    }
+
+    public void internalParameterEntityDecl(String n, String v) throws SAXException {
+    }
+
+    public void startDTD(InputEntity in) throws SAXException {
+    }
+
+    public void comment(String n) throws SAXException {
+    }
+
+    public void characters(char ch[], int start, int length) throws SAXException {
+    }
+
+    public void ignorableWhitespace(char ch[], int start, int length) throws SAXException {
+    }
+
+    public void startCDATA() throws SAXException {
+    }
+
+    public void endCDATA() throws SAXException {
+    }
+
+
+    public void startContentModel(String elementName, short contentModelType) throws SAXException {
+    }
+
+    public void endContentModel(String elementName, short contentModelType) throws SAXException {
+    }
+
+    public void attributeDecl(String elementName, String attributeName, String attributeType,
+                              String[] enumeration, short attributeUse, String defaultValue) throws SAXException {
+    }
+
+    public void childElement(String elementName, short occurence) throws SAXException {
+    }
+
+    public void mixedElement(String elementName) throws SAXException {
+    }
+
+    public void startModelGroup() throws SAXException {
+    }
+
+    public void endModelGroup(short occurence) throws SAXException {
+    }
+
+    public void connector(short connectorType) throws SAXException {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDParser.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDParser.java
new file mode 100644
index 0000000..505ccb4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/DTDParser.java
@@ -0,0 +1,2350 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.dtdparser;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.util.Locale;
+import java.util.Set;
+import java.util.Vector;
+
+/**
+ * This implements parsing of XML 1.0 DTDs.
+ * <p/>
+ * This conforms to the portion of the XML 1.0 specification related
+ * to the external DTD subset.
+ * <p/>
+ * For multi-language applications (such as web servers using XML
+ * processing to create dynamic content), a method supports choosing
+ * a locale for parser diagnostics which is both understood by the
+ * message recipient and supported by the parser.
+ * <p/>
+ * This parser produces a stream of parse events.  It supports some
+ * features (exposing comments, CDATA sections, and entity references)
+ * which are not required to be reported by conformant XML processors.
+ *
+ * @author David Brownell
+ * @author Janet Koenig
+ * @author Kohsuke KAWAGUCHI
+ */
+public class DTDParser {
+    public final static String TYPE_CDATA = "CDATA";
+    public final static String TYPE_ID = "ID";
+    public final static String TYPE_IDREF = "IDREF";
+    public final static String TYPE_IDREFS = "IDREFS";
+    public final static String TYPE_ENTITY = "ENTITY";
+    public final static String TYPE_ENTITIES = "ENTITIES";
+    public final static String TYPE_NMTOKEN = "NMTOKEN";
+    public final static String TYPE_NMTOKENS = "NMTOKENS";
+    public final static String TYPE_NOTATION = "NOTATION";
+    public final static String TYPE_ENUMERATION = "ENUMERATION";
+
+
+    // stack of input entities being merged
+    private InputEntity in;
+
+    // temporaries reused during parsing
+    private StringBuffer strTmp;
+    private char nameTmp [];
+    private NameCache nameCache;
+    private char charTmp [] = new char[2];
+
+    // temporary DTD parsing state
+    private boolean doLexicalPE;
+
+    // DTD state, used during parsing
+//    private SimpleHashtable    elements = new SimpleHashtable (47);
+    protected final Set declaredElements = new java.util.HashSet();
+    private SimpleHashtable params = new SimpleHashtable(7);
+
+    // exposed to package-private subclass
+    Hashtable notations = new Hashtable(7);
+    SimpleHashtable entities = new SimpleHashtable(17);
+
+    private SimpleHashtable ids = new SimpleHashtable();
+
+    // listeners for DTD parsing events
+    private DTDEventListener dtdHandler;
+
+    private EntityResolver resolver;
+    private Locale locale;
+
+    // string constants -- use these copies so "==" works
+    // package private
+    static final String strANY = "ANY";
+    static final String strEMPTY = "EMPTY";
+
+    /**
+     * Used by applications to request locale for diagnostics.
+     *
+     * @param l The locale to use, or null to use system defaults
+     *          (which may include only message IDs).
+     */
+    public void setLocale(Locale l) throws SAXException {
+
+        if (l != null && !messages.isLocaleSupported(l.toString())) {
+            throw new SAXException(messages.getMessage(locale,
+                    "P-078", new Object[]{l}));
+        }
+        locale = l;
+    }
+
+    /**
+     * Returns the diagnostic locale.
+     */
+    public Locale getLocale() {
+        return locale;
+    }
+
+    /**
+     * Chooses a client locale to use for diagnostics, using the first
+     * language specified in the list that is supported by this parser.
+     * That locale is then set using <a href="#setLocale(java.util.Locale)">
+     * setLocale()</a>.  Such a list could be provided by a variety of user
+     * preference mechanisms, including the HTTP <em>Accept-Language</em>
+     * header field.
+     *
+     * @param languages Array of language specifiers, ordered with the most
+     *                  preferable one at the front.  For example, "en-ca" then "fr-ca",
+     *                  followed by "zh_CN".  Both RFC 1766 and Java styles are supported.
+     * @return The chosen locale, or null.
+     * @see MessageCatalog
+     */
+    public Locale chooseLocale(String languages [])
+            throws SAXException {
+
+        Locale l = messages.chooseLocale(languages);
+
+        if (l != null) {
+            setLocale(l);
+        }
+        return l;
+    }
+
+    /**
+     * Lets applications control entity resolution.
+     */
+    public void setEntityResolver(EntityResolver r) {
+
+        resolver = r;
+    }
+
+    /**
+     * Returns the object used to resolve entities
+     */
+    public EntityResolver getEntityResolver() {
+
+        return resolver;
+    }
+
+    /**
+     * Used by applications to set handling of DTD parsing events.
+     */
+    public void setDtdHandler(DTDEventListener handler) {
+        dtdHandler = handler;
+        if (handler != null)
+            handler.setDocumentLocator(new Locator() {
+                public String getPublicId() {
+                    return DTDParser.this.getPublicId();
+                }
+
+                public String getSystemId() {
+                    return DTDParser.this.getSystemId();
+                }
+
+                public int getLineNumber() {
+                    return DTDParser.this.getLineNumber();
+                }
+
+                public int getColumnNumber() {
+                    return DTDParser.this.getColumnNumber();
+                }
+            });
+    }
+
+    /**
+     * Returns the handler used to for DTD parsing events.
+     */
+    public DTDEventListener getDtdHandler() {
+        return dtdHandler;
+    }
+
+    /**
+     * Parse a DTD.
+     */
+    public void parse(InputSource in)
+            throws IOException, SAXException {
+        init();
+        parseInternal(in);
+    }
+
+    /**
+     * Parse a DTD.
+     */
+    public void parse(String uri)
+            throws IOException, SAXException {
+        InputSource in;
+
+        init();
+        // System.out.println ("parse (\"" + uri + "\")");
+        in = resolver.resolveEntity(null, uri);
+
+        // If custom resolver punts resolution to parser, handle it ...
+        if (in == null) {
+            in = Resolver.createInputSource(new java.net.URL(uri), false);
+
+            // ... or if custom resolver doesn't correctly construct the
+            // input entity, patch it up enough so relative URIs work, and
+            // issue a warning to minimize later confusion.
+        } else if (in.getSystemId() == null) {
+            warning("P-065", null);
+            in.setSystemId(uri);
+        }
+
+        parseInternal(in);
+    }
+
+    // makes sure the parser is reset to "before a document"
+    private void init() {
+        in = null;
+
+        // alloc temporary data used in parsing
+        strTmp = new StringBuffer();
+        nameTmp = new char[20];
+        nameCache = new NameCache();
+
+        // reset doc info
+//        isInAttribute = false;
+
+        doLexicalPE = false;
+
+        entities.clear();
+        notations.clear();
+        params.clear();
+        //    elements.clear ();
+        declaredElements.clear();
+
+        // initialize predefined references ... re-interpreted later
+        builtin("amp", "&#38;");
+        builtin("lt", "&#60;");
+        builtin("gt", ">");
+        builtin("quot", "\"");
+        builtin("apos", "'");
+
+        if (locale == null)
+            locale = Locale.getDefault();
+        if (resolver == null)
+            resolver = new Resolver();
+        if (dtdHandler == null)
+            dtdHandler = new DTDHandlerBase();
+    }
+
+    private void builtin(String entityName, String entityValue) {
+        InternalEntity entity;
+        entity = new InternalEntity(entityName, entityValue.toCharArray());
+        entities.put(entityName, entity);
+    }
+
+
+    ////////////////////////////////////////////////////////////////
+    //
+    // parsing is by recursive descent, code roughly
+    // following the BNF rules except tweaked for simple
+    // lookahead.  rules are more or less in numeric order,
+    // except where code sharing suggests other structures.
+    //
+    // a classic benefit of recursive descent parsers:  it's
+    // relatively easy to get diagnostics that make sense.
+    //
+    ////////////////////////////////////////////////////////////////
+
+
+    private void parseInternal(InputSource input)
+            throws IOException, SAXException {
+
+        if (input == null)
+            fatal("P-000");
+
+        try {
+            in = InputEntity.getInputEntity(dtdHandler, locale);
+            in.init(input, null, null, false);
+
+            dtdHandler.startDTD(in);
+
+            // [30] extSubset ::= TextDecl? extSubsetDecl
+            // [31] extSubsetDecl ::= ( markupdecl | conditionalSect
+            //        | PEReference | S )*
+            //    ... same as [79] extPE, which is where the code is
+
+            ExternalEntity externalSubset = new ExternalEntity(in);
+            externalParameterEntity(externalSubset);
+
+            if (!in.isEOF()) {
+                fatal("P-001", new Object[]
+                {Integer.toHexString(((int) getc()))});
+            }
+            afterRoot();
+            dtdHandler.endDTD();
+
+        } catch (EndOfInputException e) {
+            if (!in.isDocument()) {
+                String name = in.getName();
+                do {    // force a relevant URI and line number
+                    in = in.pop();
+                } while (in.isInternal());
+                fatal("P-002", new Object[]{name});
+            } else {
+                fatal("P-003", null);
+            }
+        } catch (RuntimeException e) {
+            // Don't discard location that triggered the exception
+            // ## Should properly wrap exception
+            System.err.print("Internal DTD parser error: "); // ##
+            e.printStackTrace();
+            throw new SAXParseException(e.getMessage() != null
+                    ? e.getMessage() : e.getClass().getName(),
+                    getPublicId(), getSystemId(),
+                    getLineNumber(), getColumnNumber());
+
+        } finally {
+            // recycle temporary data used during parsing
+            strTmp = null;
+            nameTmp = null;
+            nameCache = null;
+
+            // ditto input sources etc
+            if (in != null) {
+                in.close();
+                in = null;
+            }
+
+            // get rid of all DTD info ... some of it would be
+            // useful for editors etc, investigate later.
+
+            params.clear();
+            entities.clear();
+            notations.clear();
+            declaredElements.clear();
+//        elements.clear();
+            ids.clear();
+        }
+    }
+
+    void afterRoot() throws SAXException {
+        // Make sure all IDREFs match declared ID attributes.  We scan
+        // after the document element is parsed, since XML allows forward
+        // references, and only now can we know if they're all resolved.
+
+        for (Enumeration e = ids.keys();
+             e.hasMoreElements();
+                ) {
+            String id = (String) e.nextElement();
+            Boolean value = (Boolean) ids.get(id);
+            if (Boolean.FALSE == value)
+                error("V-024", new Object[]{id});
+        }
+    }
+
+
+    // role is for diagnostics
+    private void whitespace(String roleId)
+            throws IOException, SAXException {
+
+        // [3] S ::= (#x20 | #x9 | #xd | #xa)+
+        if (!maybeWhitespace()) {
+            fatal("P-004", new Object[]
+            {messages.getMessage(locale, roleId)});
+        }
+    }
+
+    // S?
+    private boolean maybeWhitespace()
+            throws IOException, SAXException {
+
+        if (!doLexicalPE)
+            return in.maybeWhitespace();
+
+        // see getc() for the PE logic -- this lets us splice
+        // expansions of PEs in "anywhere".  getc() has smarts,
+        // so for external PEs we don't bypass it.
+
+        // XXX we can marginally speed PE handling, and certainly
+        // be cleaner (hence potentially more correct), by using
+        // the observations that expanded PEs only start and stop
+        // where whitespace is allowed.  getc wouldn't need any
+        // "lexical" PE expansion logic, and no other method needs
+        // to handle termination of PEs.  (parsing of literals would
+        // still need to pop entities, but not parsing of references
+        // in content.)
+
+        char c = getc();
+        boolean saw = false;
+
+        while (c == ' ' || c == '\t' || c == '\n' || c == '\r') {
+            saw = true;
+
+            // this gracefully ends things when we stop playing
+            // with internal parameters.  caller should have a
+            // grammar rule allowing whitespace at end of entity.
+            if (in.isEOF() && !in.isInternal())
+                return saw;
+            c = getc();
+        }
+        ungetc();
+        return saw;
+    }
+
+    private String maybeGetName()
+            throws IOException, SAXException {
+
+        NameCacheEntry entry = maybeGetNameCacheEntry();
+        return (entry == null) ? null : entry.name;
+    }
+
+    private NameCacheEntry maybeGetNameCacheEntry()
+            throws IOException, SAXException {
+
+        // [5] Name ::= (Letter|'_'|':') (Namechar)*
+        char c = getc();
+
+        if (!XmlChars.isLetter(c) && c != ':' && c != '_') {
+            ungetc();
+            return null;
+        }
+        return nameCharString(c);
+    }
+
+    // Used when parsing enumerations
+    private String getNmtoken()
+            throws IOException, SAXException {
+
+        // [7] Nmtoken ::= (Namechar)+
+        char c = getc();
+        if (!XmlChars.isNameChar(c))
+            fatal("P-006", new Object[]{new Character(c)});
+        return nameCharString(c).name;
+    }
+
+    // n.b. this gets used when parsing attribute values (for
+    // internal references) so we can't use strTmp; it's also
+    // a hotspot for CPU and memory in the parser (called at least
+    // once for each element) so this has been optimized a bit.
+
+    private NameCacheEntry nameCharString(char c)
+            throws IOException, SAXException {
+
+        int i = 1;
+
+        nameTmp[0] = c;
+        for (; ;) {
+            if ((c = in.getNameChar()) == 0)
+                break;
+            if (i >= nameTmp.length) {
+                char tmp [] = new char[nameTmp.length + 10];
+                System.arraycopy(nameTmp, 0, tmp, 0, nameTmp.length);
+                nameTmp = tmp;
+            }
+            nameTmp[i++] = c;
+        }
+        return nameCache.lookupEntry(nameTmp, i);
+    }
+
+    //
+    // much similarity between parsing entity values in DTD
+    // and attribute values (in DTD or content) ... both follow
+    // literal parsing rules, newline canonicalization, etc
+    //
+    // leaves value in 'strTmp' ... either a "replacement text" (4.5),
+    // or else partially normalized attribute value (the first bit
+    // of 3.3.3's spec, without the "if not CDATA" bits).
+    //
+    private void parseLiteral(boolean isEntityValue)
+            throws IOException, SAXException {
+
+        // [9] EntityValue ::=
+        //    '"' ([^"&%] | Reference | PEReference)* '"'
+        //    |    "'" ([^'&%] | Reference | PEReference)* "'"
+        // [10] AttValue ::=
+        //    '"' ([^"&]  | Reference             )* '"'
+        //    |    "'" ([^'&]  | Reference             )* "'"
+        char quote = getc();
+        char c;
+        InputEntity source = in;
+
+        if (quote != '\'' && quote != '"') {
+            fatal("P-007");
+        }
+
+        // don't report entity expansions within attributes,
+        // they're reported "fully expanded" via SAX
+//    isInAttribute = !isEntityValue;
+
+        // get value into strTmp
+        strTmp = new StringBuffer();
+
+        // scan, allowing entity push/pop wherever ...
+        // expanded entities can't terminate the literal!
+        for (; ;) {
+            if (in != source && in.isEOF()) {
+                // we don't report end of parsed entities
+                // within attributes (no SAX hooks)
+                in = in.pop();
+                continue;
+            }
+            if ((c = getc()) == quote && in == source) {
+                break;
+            }
+
+            //
+            // Basically the "reference in attribute value"
+            // row of the chart in section 4.4 of the spec
+            //
+            if (c == '&') {
+                String entityName = maybeGetName();
+
+                if (entityName != null) {
+                    nextChar(';', "F-020", entityName);
+
+                    // 4.4 says:  bypass these here ... we'll catch
+                    // forbidden refs to unparsed entities on use
+                    if (isEntityValue) {
+                        strTmp.append('&');
+                        strTmp.append(entityName);
+                        strTmp.append(';');
+                        continue;
+                    }
+                    expandEntityInLiteral(entityName, entities, isEntityValue);
+
+
+                    // character references are always included immediately
+                } else if ((c = getc()) == '#') {
+                    int tmp = parseCharNumber();
+
+                    if (tmp > 0xffff) {
+                        tmp = surrogatesToCharTmp(tmp);
+                        strTmp.append(charTmp[0]);
+                        if (tmp == 2)
+                            strTmp.append(charTmp[1]);
+                    } else
+                        strTmp.append((char) tmp);
+                } else
+                    fatal("P-009");
+                continue;
+
+            }
+
+            // expand parameter entities only within entity value literals
+            if (c == '%' && isEntityValue) {
+                String entityName = maybeGetName();
+
+                if (entityName != null) {
+                    nextChar(';', "F-021", entityName);
+                    expandEntityInLiteral(entityName, params, isEntityValue);
+                    continue;
+                } else
+                    fatal("P-011");
+            }
+
+            // For attribute values ...
+            if (!isEntityValue) {
+                // 3.3.3 says whitespace normalizes to space...
+                if (c == ' ' || c == '\t' || c == '\n' || c == '\r') {
+                    strTmp.append(' ');
+                    continue;
+                }
+
+                // "<" not legal in parsed literals ...
+                if (c == '<')
+                    fatal("P-012");
+            }
+
+            strTmp.append(c);
+        }
+//    isInAttribute = false;
+    }
+
+    // does a SINGLE expansion of the entity (often reparsed later)
+    private void expandEntityInLiteral(String name, SimpleHashtable table,
+                                       boolean isEntityValue)
+            throws IOException, SAXException {
+
+        Object entity = table.get(name);
+
+        if (entity instanceof InternalEntity) {
+            InternalEntity value = (InternalEntity) entity;
+            pushReader(value.buf, name, !value.isPE);
+
+        } else if (entity instanceof ExternalEntity) {
+            if (!isEntityValue)    // must be a PE ...
+                fatal("P-013", new Object[]{name});
+            // XXX if this returns false ...
+            pushReader((ExternalEntity) entity);
+
+        } else if (entity == null) {
+            //
+            // Note:  much confusion about whether spec requires such
+            // errors to be fatal in many cases, but none about whether
+            // it allows "normal" errors to be unrecoverable!
+            //
+            fatal((table == params) ? "V-022" : "P-014",
+                    new Object[]{name});
+        }
+    }
+
+    // [11] SystemLiteral ::= ('"' [^"]* '"') | ("'" [^']* "'")
+    // for PUBLIC and SYSTEM literals, also "<?xml ...type='literal'?>'
+
+    // NOTE:  XML spec should explicitly say that PE ref syntax is
+    // ignored in PIs, comments, SystemLiterals, and Pubid Literal
+    // values ... can't process the XML spec's own DTD without doing
+    // that for comments.
+
+    private String getQuotedString(String type, String extra)
+            throws IOException, SAXException {
+
+        // use in.getc to bypass PE processing
+        char quote = in.getc();
+
+        if (quote != '\'' && quote != '"')
+            fatal("P-015", new Object[]{
+                messages.getMessage(locale, type, new Object[]{extra})
+            });
+
+        char c;
+
+        strTmp = new StringBuffer();
+        while ((c = in.getc()) != quote)
+            strTmp.append((char) c);
+        return strTmp.toString();
+    }
+
+
+    private String parsePublicId() throws IOException, SAXException {
+
+        // [12] PubidLiteral ::= ('"' PubidChar* '"') | ("'" PubidChar* "'")
+        // [13] PubidChar ::= #x20|#xd|#xa|[a-zA-Z0-9]|[-'()+,./:=?;!*#@$_%]
+        String retval = getQuotedString("F-033", null);
+        for (int i = 0; i < retval.length(); i++) {
+            char c = retval.charAt(i);
+            if (" \r\n-'()+,./:=?;!*#@$_%0123456789".indexOf(c) == -1
+                    && !(c >= 'A' && c <= 'Z')
+                    && !(c >= 'a' && c <= 'z'))
+                fatal("P-016", new Object[]{new Character(c)});
+        }
+        strTmp = new StringBuffer();
+        strTmp.append(retval);
+        return normalize(false);
+    }
+
+    // [14] CharData ::= [^<&]* - ([^<&]* ']]>' [^<&]*)
+    // handled by:  InputEntity.parsedContent()
+
+    private boolean maybeComment(boolean skipStart)
+            throws IOException, SAXException {
+
+        // [15] Comment ::= '<!--'
+        //        ( (Char - '-') | ('-' (Char - '-'))*
+        //        '-->'
+        if (!in.peek(skipStart ? "!--" : "<!--", null))
+            return false;
+
+        boolean savedLexicalPE = doLexicalPE;
+        boolean saveCommentText;
+
+        doLexicalPE = false;
+        saveCommentText = false;
+        if (saveCommentText)
+            strTmp = new StringBuffer();
+
+        oneComment:
+        for (; ;) {
+            try {
+                // bypass PE expansion, but permit PEs
+                // to complete ... valid docs won't care.
+                for (; ;) {
+                    int c = getc();
+                    if (c == '-') {
+                        c = getc();
+                        if (c != '-') {
+                            if (saveCommentText)
+                                strTmp.append('-');
+                            ungetc();
+                            continue;
+                        }
+                        nextChar('>', "F-022", null);
+                        break oneComment;
+                    }
+                    if (saveCommentText)
+                        strTmp.append((char) c);
+                }
+            } catch (EndOfInputException e) {
+                //
+                // This is fatal EXCEPT when we're processing a PE...
+                // in which case a validating processor reports an error.
+                // External PEs are easy to detect; internal ones we
+                // infer by being an internal entity outside an element.
+                //
+                if (in.isInternal()) {
+                    error("V-021", null);
+                }
+                fatal("P-017");
+            }
+        }
+        doLexicalPE = savedLexicalPE;
+        if (saveCommentText)
+            dtdHandler.comment(strTmp.toString());
+        return true;
+    }
+
+    private boolean maybePI(boolean skipStart)
+            throws IOException, SAXException {
+
+        // [16] PI ::= '<?' PITarget
+        //        (S (Char* - (Char* '?>' Char*)))?
+        //        '?>'
+        // [17] PITarget ::= Name - (('X'|'x')('M'|'m')('L'|'l')
+        boolean savedLexicalPE = doLexicalPE;
+
+        if (!in.peek(skipStart ? "?" : "<?", null))
+            return false;
+        doLexicalPE = false;
+
+        String target = maybeGetName();
+
+        if (target == null) {
+            fatal("P-018");
+        }
+        if ("xml".equals(target)) {
+            fatal("P-019");
+        }
+        if ("xml".equalsIgnoreCase(target)) {
+            fatal("P-020", new Object[]{target});
+        }
+
+        if (maybeWhitespace()) {
+            strTmp = new StringBuffer();
+            try {
+                for (; ;) {
+                    // use in.getc to bypass PE processing
+                    char c = in.getc();
+                    //Reached the end of PI.
+                    if (c == '?' && in.peekc('>'))
+                        break;
+                    strTmp.append(c);
+                }
+            } catch (EndOfInputException e) {
+                fatal("P-021");
+            }
+            dtdHandler.processingInstruction(target, strTmp.toString());
+        } else {
+            if (!in.peek("?>", null)) {
+                fatal("P-022");
+            }
+            dtdHandler.processingInstruction(target, "");
+        }
+
+        doLexicalPE = savedLexicalPE;
+        return true;
+    }
+
+    // [18] CDSect ::= CDStart CData CDEnd
+    // [19] CDStart ::= '<![CDATA['
+    // [20] CData ::= (Char* - (Char* ']]>' Char*))
+    // [21] CDEnd ::= ']]>'
+    //
+    //    ... handled by InputEntity.unparsedContent()
+
+    // collapsing several rules together ...
+    // simpler than attribute literals -- no reference parsing!
+    private String maybeReadAttribute(String name, boolean must)
+            throws IOException, SAXException {
+
+        // [24] VersionInfo ::= S 'version' Eq \'|\" versionNum \'|\"
+        // [80] EncodingDecl ::= S 'encoding' Eq \'|\" EncName \'|\"
+        // [32] SDDecl ::=  S 'standalone' Eq \'|\" ... \'|\"
+        if (!maybeWhitespace()) {
+            if (!must) {
+                return null;
+            }
+            fatal("P-024", new Object[]{name});
+            // NOTREACHED
+        }
+
+        if (!peek(name)) {
+            if (must) {
+                fatal("P-024", new Object[]{name});
+            } else {
+                // To ensure that the whitespace is there so that when we
+                // check for the next attribute we assure that the
+                // whitespace still exists.
+                ungetc();
+                return null;
+            }
+        }
+
+        // [25] Eq ::= S? '=' S?
+        maybeWhitespace();
+        nextChar('=', "F-023", null);
+        maybeWhitespace();
+
+        return getQuotedString("F-035", name);
+    }
+
+    private void readVersion(boolean must, String versionNum)
+            throws IOException, SAXException {
+
+        String value = maybeReadAttribute("version", must);
+
+        // [26] versionNum ::= ([a-zA-Z0-9_.:]| '-')+
+
+        if (must && value == null)
+            fatal("P-025", new Object[]{versionNum});
+        if (value != null) {
+            int length = value.length();
+            for (int i = 0; i < length; i++) {
+                char c = value.charAt(i);
+                if (!((c >= '0' && c <= '9')
+                        || c == '_' || c == '.'
+                        || (c >= 'a' && c <= 'z')
+                        || (c >= 'A' && c <= 'Z')
+                        || c == ':' || c == '-')
+                )
+                    fatal("P-026", new Object[]{value});
+            }
+        }
+        if (value != null && !value.equals(versionNum))
+            error("P-027", new Object[]{versionNum, value});
+    }
+
+    // common code used by most markup declarations
+    // ... S (Q)Name ...
+    private String getMarkupDeclname(String roleId, boolean qname)
+            throws IOException, SAXException {
+
+        String name;
+
+        whitespace(roleId);
+        name = maybeGetName();
+        if (name == null)
+            fatal("P-005", new Object[]
+            {messages.getMessage(locale, roleId)});
+        return name;
+    }
+
+    private boolean maybeMarkupDecl()
+            throws IOException, SAXException {
+
+        // [29] markupdecl ::= elementdecl | Attlistdecl
+        //           | EntityDecl | NotationDecl | PI | Comment
+        return maybeElementDecl()
+                || maybeAttlistDecl()
+                || maybeEntityDecl()
+                || maybeNotationDecl()
+                || maybePI(false)
+                || maybeComment(false);
+    }
+
+    private static final String XmlLang = "xml:lang";
+
+    private boolean isXmlLang(String value) {
+
+        // [33] LanguageId ::= Langcode ('-' Subcode)*
+        // [34] Langcode ::= ISO639Code | IanaCode | UserCode
+        // [35] ISO639Code ::= [a-zA-Z] [a-zA-Z]
+        // [36] IanaCode ::= [iI] '-' SubCode
+        // [37] UserCode ::= [xX] '-' SubCode
+        // [38] SubCode ::= [a-zA-Z]+
+
+        // the ISO and IANA codes (and subcodes) are registered,
+        // but that's neither a WF nor a validity constraint.
+
+        int nextSuffix;
+        char c;
+
+        if (value.length() < 2)
+            return false;
+        c = value.charAt(1);
+        if (c == '-') {        // IANA, or user, code
+            c = value.charAt(0);
+            if (!(c == 'i' || c == 'I' || c == 'x' || c == 'X'))
+                return false;
+            nextSuffix = 1;
+        } else if ((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')) {
+            // 2 letter ISO code, or error
+            c = value.charAt(0);
+            if (!((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')))
+                return false;
+            nextSuffix = 2;
+        } else
+            return false;
+
+        // here "suffix" ::= '-' [a-zA-Z]+ suffix*
+        while (nextSuffix < value.length()) {
+            c = value.charAt(nextSuffix);
+            if (c != '-')
+                break;
+            while (++nextSuffix < value.length()) {
+                c = value.charAt(nextSuffix);
+                if (!((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')))
+                    break;
+            }
+        }
+        return value.length() == nextSuffix && c != '-';
+    }
+
+
+    //
+    // CHAPTER 3:  Logical Structures
+    //
+
+    /**
+     * To validate, subclassers should at this time make sure that
+     * values are of the declared types:<UL>
+     * <LI> ID and IDREF(S) values are Names
+     * <LI> NMTOKEN(S) are Nmtokens
+     * <LI> ENUMERATION values match one of the tokens
+     * <LI> NOTATION values match a notation name
+     * <LI> ENTITIY(IES) values match an unparsed external entity
+     * </UL>
+     * <p/>
+     * <P> Separately, make sure IDREF values match some ID
+     * provided in the document (in the afterRoot method).
+     */
+/*    void validateAttributeSyntax (Attribute attr, String value)
+         throws DTDParseException {
+        // ID, IDREF(S) ... values are Names
+        if (Attribute.ID == attr.type()) {
+            if (!XmlNames.isName (value))
+                error ("V-025", new Object [] { value });
+
+            Boolean             b = (Boolean) ids.getNonInterned (value);
+            if (b == null || b.equals (Boolean.FALSE))
+                ids.put (value.intern (), Boolean.TRUE);
+            else
+                error ("V-026", new Object [] { value });
+
+        } else if (Attribute.IDREF == attr.type()) {
+            if (!XmlNames.isName (value))
+                error ("V-027", new Object [] { value });
+
+            Boolean             b = (Boolean) ids.getNonInterned (value);
+            if (b == null)
+                ids.put (value.intern (), Boolean.FALSE);
+
+        } else if (Attribute.IDREFS == attr.type()) {
+            StringTokenizer     tokenizer = new StringTokenizer (value);
+            Boolean             b;
+            boolean             sawValue = false;
+
+            while (tokenizer.hasMoreTokens ()) {
+                value = tokenizer.nextToken ();
+                if (!XmlNames.isName (value))
+                    error ("V-027", new Object [] { value });
+                b = (Boolean) ids.getNonInterned (value);
+                if (b == null)
+                    ids.put (value.intern (), Boolean.FALSE);
+                sawValue = true;
+            }
+            if (!sawValue)
+                error ("V-039", null);
+
+
+        // NMTOKEN(S) ... values are Nmtoken(s)
+        } else if (Attribute.NMTOKEN == attr.type()) {
+            if (!XmlNames.isNmtoken (value))
+                error ("V-028", new Object [] { value });
+
+        } else if (Attribute.NMTOKENS == attr.type()) {
+            StringTokenizer     tokenizer = new StringTokenizer (value);
+            boolean             sawValue = false;
+
+            while (tokenizer.hasMoreTokens ()) {
+                value = tokenizer.nextToken ();
+                if (!XmlNames.isNmtoken (value))
+                    error ("V-028", new Object [] { value });
+                sawValue = true;
+            }
+            if (!sawValue)
+                error ("V-032", null);
+
+        // ENUMERATION ... values match one of the tokens
+        } else if (Attribute.ENUMERATION == attr.type()) {
+            for (int i = 0; i < attr.values().length; i++)
+                if (value.equals (attr.values()[i]))
+                    return;
+            error ("V-029", new Object [] { value });
+
+        // NOTATION values match a notation name
+        } else if (Attribute.NOTATION == attr.type()) {
+            //
+            // XXX XML 1.0 spec should probably list references to
+            // externally defined notations in standalone docs as
+            // validity errors.  Ditto externally defined unparsed
+            // entities; neither should show up in attributes, else
+            // one needs to read the external declarations in order
+            // to make sense of the document (exactly what tagging
+            // a doc as "standalone" intends you won't need to do).
+            //
+            for (int i = 0; i < attr.values().length; i++)
+                if (value.equals (attr.values()[i]))
+                    return;
+            error ("V-030", new Object [] { value });
+
+        // ENTITY(IES) values match an unparsed entity(ies)
+        } else if (Attribute.ENTITY == attr.type()) {
+            // see note above re standalone
+            if (!isUnparsedEntity (value))
+                error ("V-031", new Object [] { value });
+
+        } else if (Attribute.ENTITIES == attr.type()) {
+            StringTokenizer     tokenizer = new StringTokenizer (value);
+            boolean             sawValue = false;
+
+            while (tokenizer.hasMoreTokens ()) {
+                value = tokenizer.nextToken ();
+                // see note above re standalone
+                if (!isUnparsedEntity (value))
+                    error ("V-031", new Object [] { value });
+                sawValue = true;
+            }
+            if (!sawValue)
+                error ("V-040", null);
+
+        } else if (Attribute.CDATA != attr.type())
+            throw new InternalError (attr.type());
+    }
+*/
+/*
+    private boolean isUnparsedEntity (String name)
+    {
+        Object e = entities.getNonInterned (name);
+        if (e == null || !(e instanceof ExternalEntity))
+            return false;
+        return ((ExternalEntity)e).notation != null;
+    }
+*/
+    private boolean maybeElementDecl()
+            throws IOException, SAXException {
+
+        // [45] elementDecl ::= '<!ELEMENT' S Name S contentspec S? '>'
+        // [46] contentspec ::= 'EMPTY' | 'ANY' | Mixed | children
+        InputEntity start = peekDeclaration("!ELEMENT");
+
+        if (start == null)
+            return false;
+
+        // n.b. for content models where inter-element whitespace is
+        // ignorable, we mark that fact here.
+        String name = getMarkupDeclname("F-015", true);
+//    Element        element = (Element) elements.get (name);
+//    boolean        declEffective = false;
+
+/*
+    if (element != null) {
+        if (element.contentModel() != null) {
+            error ("V-012", new Object [] { name });
+        } // else <!ATTLIST name ...> came first
+    } else {
+        element = new Element(name);
+        elements.put (element.name(), element);
+        declEffective = true;
+    }
+*/
+        if (declaredElements.contains(name))
+            error("V-012", new Object[]{name});
+        else {
+            declaredElements.add(name);
+//        declEffective = true;
+        }
+
+        short modelType;
+        whitespace("F-000");
+        if (peek(strEMPTY)) {
+///        // leave element.contentModel as null for this case.
+            dtdHandler.startContentModel(name, modelType = DTDEventListener.CONTENT_MODEL_EMPTY);
+        } else if (peek(strANY)) {
+///        element.setContentModel(new StringModel(StringModelType.ANY));
+            dtdHandler.startContentModel(name, modelType = DTDEventListener.CONTENT_MODEL_ANY);
+        } else {
+            modelType = getMixedOrChildren(name);
+        }
+
+        dtdHandler.endContentModel(name, modelType);
+
+        maybeWhitespace();
+        char c = getc();
+        if (c != '>')
+            fatal("P-036", new Object[]{name, new Character(c)});
+        if (start != in)
+            error("V-013", null);
+
+///        dtdHandler.elementDecl(element);
+
+        return true;
+    }
+
+    // We're leaving the content model as a regular expression;
+    // it's an efficient natural way to express such things, and
+    // libraries often interpret them.  No whitespace in the
+    // model we store, though!
+
+    /**
+     * returns content model type.
+     */
+    private short getMixedOrChildren(String elementName/*Element element*/)
+            throws IOException, SAXException {
+
+        InputEntity start;
+
+        // [47] children ::= (choice|seq) ('?'|'*'|'+')?
+        strTmp = new StringBuffer();
+
+        nextChar('(', "F-028", elementName);
+        start = in;
+        maybeWhitespace();
+        strTmp.append('(');
+
+        short modelType;
+        if (peek("#PCDATA")) {
+            strTmp.append("#PCDATA");
+            dtdHandler.startContentModel(elementName, modelType = DTDEventListener.CONTENT_MODEL_MIXED);
+            getMixed(elementName, start);
+        } else {
+            dtdHandler.startContentModel(elementName, modelType = DTDEventListener.CONTENT_MODEL_CHILDREN);
+            getcps(elementName, start);
+        }
+
+        return modelType;
+    }
+
+    // '(' S? already consumed
+    // matching ')' must be in "start" entity if validating
+    private void getcps(/*Element element,*/String elementName, InputEntity start)
+            throws IOException, SAXException {
+
+        // [48] cp ::= (Name|choice|seq) ('?'|'*'|'+')?
+        // [49] choice ::= '(' S? cp (S? '|' S? cp)* S? ')'
+        // [50] seq    ::= '(' S? cp (S? ',' S? cp)* S? ')'
+        boolean decided = false;
+        char type = 0;
+//        ContentModel       retval, temp, current;
+
+//        retval = temp = current = null;
+
+        dtdHandler.startModelGroup();
+
+        do {
+            String tag;
+
+            tag = maybeGetName();
+            if (tag != null) {
+                strTmp.append(tag);
+//                temp = new ElementModel(tag);
+//                getFrequency((RepeatableContent)temp);
+///->
+                dtdHandler.childElement(tag, getFrequency());
+///<-
+            } else if (peek("(")) {
+                InputEntity next = in;
+                strTmp.append('(');
+                maybeWhitespace();
+//                temp = getcps(element, next);
+//                getFrequency(temp);
+///->
+                getcps(elementName, next);
+///                getFrequency();        <- this looks like a bug
+///<-
+            } else
+                fatal((type == 0) ? "P-039" :
+                        ((type == ',') ? "P-037" : "P-038"),
+                        new Object[]{new Character(getc())});
+
+            maybeWhitespace();
+            if (decided) {
+                char c = getc();
+
+//                if (current != null) {
+//                    current.addChild(temp);
+//                }
+                if (c == type) {
+                    strTmp.append(type);
+                    maybeWhitespace();
+                    reportConnector(type);
+                    continue;
+                } else if (c == '\u0029') {    // rparen
+                    ungetc();
+                    continue;
+                } else {
+                    fatal((type == 0) ? "P-041" : "P-040",
+                            new Object[]{
+                                new Character(c),
+                                new Character(type)
+                            });
+                }
+            } else {
+                type = getc();
+                switch (type) {
+                case '|':
+                case ',':
+                    reportConnector(type);
+                    break;
+                default:
+//                        retval = temp;
+                    ungetc();
+                    continue;
+                }
+//                retval = (ContentModel)current;
+                decided = true;
+//                current.addChild(temp);
+                strTmp.append(type);
+            }
+            maybeWhitespace();
+        } while (!peek(")"));
+
+        if (in != start)
+            error("V-014", new Object[]{elementName});
+        strTmp.append(')');
+
+        dtdHandler.endModelGroup(getFrequency());
+//        return retval;
+    }
+
+    private void reportConnector(char type) throws SAXException {
+        switch (type) {
+        case '|':
+            dtdHandler.connector(DTDEventListener.CHOICE);    ///<-
+            return;
+        case ',':
+            dtdHandler.connector(DTDEventListener.SEQUENCE); ///<-
+            return;
+        default:
+            throw new Error();    //assertion failed.
+        }
+    }
+
+    private short getFrequency()
+            throws IOException, SAXException {
+
+        final char c = getc();
+
+        if (c == '?') {
+            strTmp.append(c);
+            return DTDEventListener.OCCURENCE_ZERO_OR_ONE;
+            //        original.setRepeat(Repeat.ZERO_OR_ONE);
+        } else if (c == '+') {
+            strTmp.append(c);
+            return DTDEventListener.OCCURENCE_ONE_OR_MORE;
+            //        original.setRepeat(Repeat.ONE_OR_MORE);
+        } else if (c == '*') {
+            strTmp.append(c);
+            return DTDEventListener.OCCURENCE_ZERO_OR_MORE;
+            //        original.setRepeat(Repeat.ZERO_OR_MORE);
+        } else {
+            ungetc();
+            return DTDEventListener.OCCURENCE_ONCE;
+        }
+    }
+
+    // '(' S? '#PCDATA' already consumed
+    // matching ')' must be in "start" entity if validating
+    private void getMixed(String elementName, /*Element element,*/ InputEntity start)
+            throws IOException, SAXException {
+
+        // [51] Mixed ::= '(' S? '#PCDATA' (S? '|' S? Name)* S? ')*'
+        //        | '(' S? '#PCDATA'                   S? ')'
+        maybeWhitespace();
+        if (peek("\u0029*") || peek("\u0029")) {
+            if (in != start)
+                error("V-014", new Object[]{elementName});
+            strTmp.append(')');
+//            element.setContentModel(new StringModel(StringModelType.PCDATA));
+            return;
+        }
+
+        ArrayList l = new ArrayList();
+//    l.add(new StringModel(StringModelType.PCDATA));
+
+
+        while (peek("|")) {
+            String name;
+
+            strTmp.append('|');
+            maybeWhitespace();
+
+            doLexicalPE = true;
+            name = maybeGetName();
+            if (name == null)
+                fatal("P-042", new Object[]
+                {elementName, Integer.toHexString(getc())});
+            if (l.contains(name)) {
+                error("V-015", new Object[]{name});
+            } else {
+                l.add(name);
+                dtdHandler.mixedElement(name);
+            }
+            strTmp.append(name);
+            maybeWhitespace();
+        }
+
+        if (!peek("\u0029*"))    // right paren
+            fatal("P-043", new Object[]
+            {elementName, new Character(getc())});
+        if (in != start)
+            error("V-014", new Object[]{elementName});
+        strTmp.append(')');
+//        ChoiceModel cm = new ChoiceModel((Collection)l);
+//    cm.setRepeat(Repeat.ZERO_OR_MORE);
+//       element.setContentModel(cm);
+    }
+
+    private boolean maybeAttlistDecl()
+            throws IOException, SAXException {
+
+        // [52] AttlistDecl ::= '<!ATTLIST' S Name AttDef* S? '>'
+        InputEntity start = peekDeclaration("!ATTLIST");
+
+        if (start == null)
+            return false;
+
+        String elementName = getMarkupDeclname("F-016", true);
+//    Element    element = (Element) elements.get (name);
+
+//    if (element == null) {
+//        // not yet declared -- no problem.
+//        element = new Element(name);
+//        elements.put(name, element);
+//    }
+
+        while (!peek(">")) {
+
+            // [53] AttDef ::= S Name S AttType S DefaultDecl
+            // [54] AttType ::= StringType | TokenizedType | EnumeratedType
+
+            // look for global attribute definitions, don't expand for now...
+            maybeWhitespace();
+            char c = getc();
+            if (c == '%') {
+                String entityName = maybeGetName();
+                if (entityName != null) {
+                    nextChar(';', "F-021", entityName);
+                    whitespace("F-021");
+                    continue;
+                } else
+                    fatal("P-011");
+            }
+
+            ungetc();
+            // look for attribute name otherwise
+            String attName = maybeGetName();
+            if (attName == null) {
+                fatal("P-044", new Object[]{new Character(getc())});
+            }
+            whitespace("F-001");
+
+///        Attribute    a = new Attribute (name);
+
+            String typeName;
+            Vector values = null;    // notation/enumeration values
+
+            // Note:  use the type constants from Attribute
+            // so that "==" may be used (faster)
+
+            // [55] StringType ::= 'CDATA'
+            if (peek(TYPE_CDATA))
+///            a.setType(Attribute.CDATA);
+                typeName = TYPE_CDATA;
+
+            // [56] TokenizedType ::= 'ID' | 'IDREF' | 'IDREFS'
+            //        | 'ENTITY' | 'ENTITIES'
+            //        | 'NMTOKEN' | 'NMTOKENS'
+            // n.b. if "IDREFS" is there, both "ID" and "IDREF"
+            // match peekahead ... so this order matters!
+            else if (peek(TYPE_IDREFS))
+                typeName = TYPE_IDREFS;
+            else if (peek(TYPE_IDREF))
+                typeName = TYPE_IDREF;
+            else if (peek(TYPE_ID)) {
+                typeName = TYPE_ID;
+// TODO: should implement this error check?
+///        if (element.id() != null) {
+///                    error ("V-016", new Object [] { element.id() });
+///        } else
+///            element.setId(name);
+            } else if (peek(TYPE_ENTITY))
+                typeName = TYPE_ENTITY;
+            else if (peek(TYPE_ENTITIES))
+                typeName = TYPE_ENTITIES;
+            else if (peek(TYPE_NMTOKENS))
+                typeName = TYPE_NMTOKENS;
+            else if (peek(TYPE_NMTOKEN))
+                typeName = TYPE_NMTOKEN;
+
+            // [57] EnumeratedType ::= NotationType | Enumeration
+            // [58] NotationType ::= 'NOTATION' S '(' S? Name
+            //        (S? '|' S? Name)* S? ')'
+            else if (peek(TYPE_NOTATION)) {
+                typeName = TYPE_NOTATION;
+                whitespace("F-002");
+                nextChar('(', "F-029", null);
+                maybeWhitespace();
+
+                values = new Vector();
+                do {
+                    String name;
+                    if ((name = maybeGetName()) == null)
+                        fatal("P-068");
+                    // permit deferred declarations
+                    if (notations.get(name) == null)
+                        notations.put(name, name);
+                    values.addElement(name);
+                    maybeWhitespace();
+                    if (peek("|"))
+                        maybeWhitespace();
+                } while (!peek(")"));
+///            a.setValues(new String [v.size ()]);
+///            for (int i = 0; i < v.size (); i++)
+///                a.setValue(i, (String)v.elementAt(i));
+
+                // [59] Enumeration ::= '(' S? Nmtoken (S? '|' Nmtoken)* S? ')'
+            } else if (peek("(")) {
+///            a.setType(Attribute.ENUMERATION);
+                typeName = TYPE_ENUMERATION;
+
+                maybeWhitespace();
+
+///            Vector v = new Vector ();
+                values = new Vector();
+                do {
+                    String name = getNmtoken();
+///                v.addElement (name);
+                    values.addElement(name);
+                    maybeWhitespace();
+                    if (peek("|"))
+                        maybeWhitespace();
+                } while (!peek(")"));
+///            a.setValues(new String [v.size ()]);
+///            for (int i = 0; i < v.size (); i++)
+///                a.setValue(i, (String)v.elementAt(i));
+            } else {
+                fatal("P-045",
+                        new Object[]{attName, new Character(getc())});
+                typeName = null;
+            }
+
+            short attributeUse;
+            String defaultValue = null;
+
+            // [60] DefaultDecl ::= '#REQUIRED' | '#IMPLIED'
+            //        | (('#FIXED' S)? AttValue)
+            whitespace("F-003");
+            if (peek("#REQUIRED"))
+                attributeUse = DTDEventListener.USE_REQUIRED;
+///            a.setIsRequired(true);
+            else if (peek("#FIXED")) {
+///            if (a.type() == Attribute.ID)
+                if (typeName == TYPE_ID)
+                    error("V-017", new Object[]{attName});
+///            a.setIsFixed(true);
+                attributeUse = DTDEventListener.USE_FIXED;
+                whitespace("F-004");
+                parseLiteral(false);
+///            if (a.type() != Attribute.CDATA)
+///                a.setDefaultValue(normalize(false));
+///            else
+///                a.setDefaultValue(strTmp.toString());
+
+                if (typeName == TYPE_CDATA)
+                    defaultValue = normalize(false);
+                else
+                    defaultValue = strTmp.toString();
+
+// TODO: implement this check
+///            if (a.type() != Attribute.CDATA)
+///                validateAttributeSyntax (a, a.defaultValue());
+            } else if (!peek("#IMPLIED")) {
+                attributeUse = DTDEventListener.USE_IMPLIED;
+
+///            if (a.type() == Attribute.ID)
+                if (typeName == TYPE_ID)
+                    error("V-018", new Object[]{attName});
+                parseLiteral(false);
+///            if (a.type() != Attribute.CDATA)
+///                a.setDefaultValue(normalize(false));
+///            else
+///                a.setDefaultValue(strTmp.toString());
+                if (typeName == TYPE_CDATA)
+                    defaultValue = normalize(false);
+                else
+                    defaultValue = strTmp.toString();
+
+// TODO: implement this check
+///            if (a.type() != Attribute.CDATA)
+///                validateAttributeSyntax (a, a.defaultValue());
+            } else {
+                // TODO: this looks like an fatal error.
+                attributeUse = DTDEventListener.USE_NORMAL;
+            }
+
+            if (XmlLang.equals(attName)
+                    && defaultValue/* a.defaultValue()*/ != null
+                    && !isXmlLang(defaultValue/*a.defaultValue()*/))
+                error("P-033", new Object[]{defaultValue /*a.defaultValue()*/});
+
+// TODO: isn't it an error to specify the same attribute twice?
+///        if (!element.attributes().contains(a)) {
+///            element.addAttribute(a);
+///            dtdHandler.attributeDecl(a);
+///        }
+
+            String[] v = (values != null) ? (String[]) values.toArray(new String[0]) : null;
+            dtdHandler.attributeDecl(elementName, attName, typeName, v, attributeUse, defaultValue);
+            maybeWhitespace();
+        }
+        if (start != in)
+            error("V-013", null);
+        return true;
+    }
+
+    // used when parsing literal attribute values,
+    // or public identifiers.
+    //
+    // input in strTmp
+    private String normalize(boolean invalidIfNeeded) {
+
+        // this can allocate an extra string...
+
+        String s = strTmp.toString();
+        String s2 = s.trim();
+        boolean didStrip = false;
+
+        if (s != s2) {
+            s = s2;
+            s2 = null;
+            didStrip = true;
+        }
+        strTmp = new StringBuffer();
+        for (int i = 0; i < s.length(); i++) {
+            char c = s.charAt(i);
+            if (!XmlChars.isSpace(c)) {
+                strTmp.append(c);
+                continue;
+            }
+            strTmp.append(' ');
+            while (++i < s.length() && XmlChars.isSpace(s.charAt(i)))
+                didStrip = true;
+            i--;
+        }
+        if (didStrip)
+            return strTmp.toString();
+        else
+            return s;
+    }
+
+    private boolean maybeConditionalSect()
+            throws IOException, SAXException {
+
+        // [61] conditionalSect ::= includeSect | ignoreSect
+
+        if (!peek("<!["))
+            return false;
+
+        String keyword;
+        InputEntity start = in;
+
+        maybeWhitespace();
+
+        if ((keyword = maybeGetName()) == null)
+            fatal("P-046");
+        maybeWhitespace();
+        nextChar('[', "F-030", null);
+
+        // [62] includeSect ::= '<![' S? 'INCLUDE' S? '['
+        //                extSubsetDecl ']]>'
+        if ("INCLUDE".equals(keyword)) {
+            for (; ;) {
+                while (in.isEOF() && in != start)
+                    in = in.pop();
+                if (in.isEOF()) {
+                    error("V-020", null);
+                }
+                if (peek("]]>"))
+                    break;
+
+                doLexicalPE = false;
+                if (maybeWhitespace())
+                    continue;
+                if (maybePEReference())
+                    continue;
+                doLexicalPE = true;
+                if (maybeMarkupDecl() || maybeConditionalSect())
+                    continue;
+
+                fatal("P-047");
+            }
+
+            // [63] ignoreSect ::= '<![' S? 'IGNORE' S? '['
+            //            ignoreSectcontents ']]>'
+            // [64] ignoreSectcontents ::= Ignore ('<!['
+            //            ignoreSectcontents ']]>' Ignore)*
+            // [65] Ignore ::= Char* - (Char* ('<![' | ']]>') Char*)
+        } else if ("IGNORE".equals(keyword)) {
+            int nestlevel = 1;
+            // ignoreSectcontents
+            doLexicalPE = false;
+            while (nestlevel > 0) {
+                char c = getc();    // will pop input entities
+                if (c == '<') {
+                    if (peek("!["))
+                        nestlevel++;
+                } else if (c == ']') {
+                    if (peek("]>"))
+                        nestlevel--;
+                } else
+                    continue;
+            }
+        } else
+            fatal("P-048", new Object[]{keyword});
+        return true;
+    }
+
+
+    //
+    // CHAPTER 4:  Physical Structures
+    //
+
+    // parse decimal or hex numeric character reference
+    private int parseCharNumber()
+            throws IOException, SAXException {
+
+        char c;
+        int retval = 0;
+
+        // n.b. we ignore overflow ...
+        if (getc() != 'x') {
+            ungetc();
+            for (; ;) {
+                c = getc();
+                if (c >= '0' && c <= '9') {
+                    retval *= 10;
+                    retval += (c - '0');
+                    continue;
+                }
+                if (c == ';')
+                    return retval;
+                fatal("P-049");
+            }
+        } else
+            for (; ;) {
+                c = getc();
+                if (c >= '0' && c <= '9') {
+                    retval <<= 4;
+                    retval += (c - '0');
+                    continue;
+                }
+                if (c >= 'a' && c <= 'f') {
+                    retval <<= 4;
+                    retval += 10 + (c - 'a');
+                    continue;
+                }
+                if (c >= 'A' && c <= 'F') {
+                    retval <<= 4;
+                    retval += 10 + (c - 'A');
+                    continue;
+                }
+                if (c == ';')
+                    return retval;
+                fatal("P-050");
+            }
+    }
+
+    // parameter is a UCS-4 character ... i.e. not just 16 bit UNICODE,
+    // though still subject to the 'Char' construct in XML
+    private int surrogatesToCharTmp(int ucs4)
+            throws SAXException {
+
+        if (ucs4 <= 0xffff) {
+            if (XmlChars.isChar(ucs4)) {
+                charTmp[0] = (char) ucs4;
+                return 1;
+            }
+        } else if (ucs4 <= 0x0010ffff) {
+            // we represent these as UNICODE surrogate pairs
+            ucs4 -= 0x10000;
+            charTmp[0] = (char) (0xd800 | ((ucs4 >> 10) & 0x03ff));
+            charTmp[1] = (char) (0xdc00 | (ucs4 & 0x03ff));
+            return 2;
+        }
+        fatal("P-051", new Object[]{Integer.toHexString(ucs4)});
+        // NOTREACHED
+        return -1;
+    }
+
+    private boolean maybePEReference()
+            throws IOException, SAXException {
+
+        // This is the SYNTACTIC version of this construct.
+        // When processing external entities, there is also
+        // a LEXICAL version; see getc() and doLexicalPE.
+
+        // [69] PEReference ::= '%' Name ';'
+        if (!in.peekc('%'))
+            return false;
+
+        String name = maybeGetName();
+        Object entity;
+
+        if (name == null)
+            fatal("P-011");
+        nextChar(';', "F-021", name);
+        entity = params.get(name);
+
+        if (entity instanceof InternalEntity) {
+            InternalEntity value = (InternalEntity) entity;
+            pushReader(value.buf, name, false);
+
+        } else if (entity instanceof ExternalEntity) {
+            pushReader((ExternalEntity) entity);
+            externalParameterEntity((ExternalEntity) entity);
+
+        } else if (entity == null) {
+            error("V-022", new Object[]{name});
+        }
+        return true;
+    }
+
+    private boolean maybeEntityDecl()
+            throws IOException, SAXException {
+
+        // [70] EntityDecl ::= GEDecl | PEDecl
+        // [71] GEDecl ::= '<!ENTITY' S       Name S EntityDef S? '>'
+        // [72] PEDecl ::= '<!ENTITY' S '%' S Name S PEDEF     S? '>'
+        // [73] EntityDef ::= EntityValue | (ExternalID NDataDecl?)
+        // [74] PEDef     ::= EntityValue |  ExternalID
+        //
+        InputEntity start = peekDeclaration("!ENTITY");
+
+        if (start == null)
+            return false;
+
+        String entityName;
+        SimpleHashtable defns;
+        ExternalEntity externalId;
+        boolean doStore;
+
+        // PE expansion gets selectively turned off several places:
+        // in ENTITY declarations (here), in comments, in PIs.
+
+        // Here, we allow PE entities to be declared, and allows
+        // literals to include PE refs without the added spaces
+        // required with their expansion in markup decls.
+
+        doLexicalPE = false;
+        whitespace("F-005");
+        if (in.peekc('%')) {
+            whitespace("F-006");
+            defns = params;
+        } else
+            defns = entities;
+
+        ungetc();    // leave some whitespace
+        doLexicalPE = true;
+        entityName = getMarkupDeclname("F-017", false);
+        whitespace("F-007");
+        externalId = maybeExternalID();
+
+        //
+        // first definition sticks ... e.g. internal subset PEs are used
+        // to override DTD defaults.  It's also an "error" to incorrectly
+        // redefine builtin internal entities, but since reporting such
+        // errors is optional we only give warnings ("just in case") for
+        // non-parameter entities.
+        //
+        doStore = (defns.get(entityName) == null);
+        if (!doStore && defns == entities)
+            warning("P-054", new Object[]{entityName});
+
+        // internal entities
+        if (externalId == null) {
+            char value [];
+            InternalEntity entity;
+
+            doLexicalPE = false;        // "ab%bar;cd" -maybe-> "abcd"
+            parseLiteral(true);
+            doLexicalPE = true;
+            if (doStore) {
+                value = new char[strTmp.length()];
+                if (value.length != 0)
+                    strTmp.getChars(0, value.length, value, 0);
+                entity = new InternalEntity(entityName, value);
+                entity.isPE = (defns == params);
+                entity.isFromInternalSubset = false;
+                defns.put(entityName, entity);
+                if (defns == entities)
+                    dtdHandler.internalGeneralEntityDecl(entityName,
+                            new String(value));
+            }
+
+            // external entities (including unparsed)
+        } else {
+            // [76] NDataDecl ::= S 'NDATA' S Name
+            if (defns == entities && maybeWhitespace()
+                    && peek("NDATA")) {
+                externalId.notation = getMarkupDeclname("F-018", false);
+
+                // flag undeclared notation for checking after
+                // the DTD is fully processed
+                if (notations.get(externalId.notation) == null)
+                    notations.put(externalId.notation, Boolean.TRUE);
+            }
+            externalId.name = entityName;
+            externalId.isPE = (defns == params);
+            externalId.isFromInternalSubset = false;
+            if (doStore) {
+                defns.put(entityName, externalId);
+                if (externalId.notation != null)
+                    dtdHandler.unparsedEntityDecl(entityName,
+                            externalId.publicId, externalId.systemId,
+                            externalId.notation);
+                else if (defns == entities)
+                    dtdHandler.externalGeneralEntityDecl(entityName,
+                            externalId.publicId, externalId.systemId);
+            }
+        }
+        maybeWhitespace();
+        nextChar('>', "F-031", entityName);
+        if (start != in)
+            error("V-013", null);
+        return true;
+    }
+
+    private ExternalEntity maybeExternalID()
+            throws IOException, SAXException {
+
+        // [75] ExternalID ::= 'SYSTEM' S SystemLiteral
+        //        | 'PUBLIC' S' PubidLiteral S Systemliteral
+        String temp = null;
+        ExternalEntity retval;
+
+        if (peek("PUBLIC")) {
+            whitespace("F-009");
+            temp = parsePublicId();
+        } else if (!peek("SYSTEM"))
+            return null;
+
+        retval = new ExternalEntity(in);
+        retval.publicId = temp;
+        whitespace("F-008");
+        retval.systemId = parseSystemId();
+        return retval;
+    }
+
+    private String parseSystemId()
+            throws IOException, SAXException {
+
+        String uri = getQuotedString("F-034", null);
+        int temp = uri.indexOf(':');
+
+        // resolve relative URIs ... must do it here since
+        // it's relative to the source file holding the URI!
+
+        // "new java.net.URL (URL, string)" conforms to RFC 1630,
+        // but we can't use that except when the URI is a URL.
+        // The entity resolver is allowed to handle URIs that are
+        // not URLs, so we pass URIs through with scheme intact
+        if (temp == -1 || uri.indexOf('/') < temp) {
+            String baseURI;
+
+            baseURI = in.getSystemId();
+            if (baseURI == null)
+                fatal("P-055", new Object[]{uri});
+            if (uri.length() == 0)
+                uri = ".";
+            baseURI = baseURI.substring(0, baseURI.lastIndexOf('/') + 1);
+            if (uri.charAt(0) != '/')
+                uri = baseURI + uri;
+            else {
+                // XXX slashes at the beginning of a relative URI are
+                // a special case we don't handle.
+                throw new InternalError();
+            }
+
+            // letting other code map any "/xxx/../" or "/./" to "/",
+            // since all URIs must handle it the same.
+        }
+        // check for fragment ID in URI
+        if (uri.indexOf('#') != -1)
+            error("P-056", new Object[]{uri});
+        return uri;
+    }
+
+    private void maybeTextDecl()
+            throws IOException, SAXException {
+
+        // [77] TextDecl ::= '<?xml' VersionInfo? EncodingDecl S? '?>'
+        if (peek("<?xml")) {
+            readVersion(false, "1.0");
+            readEncoding(true);
+            maybeWhitespace();
+            if (!peek("?>"))
+                fatal("P-057");
+        }
+    }
+
+    private void externalParameterEntity(ExternalEntity next)
+            throws IOException, SAXException {
+
+        //
+        // Reap the intended benefits of standalone declarations:
+        // don't deal with external parameter entities, except to
+        // validate the standalone declaration.
+        //
+
+        // n.b. "in external parameter entities" (and external
+        // DTD subset, same grammar) parameter references can
+        // occur "within" markup declarations ... expansions can
+        // cross syntax rules.  Flagged here; affects getc().
+
+        // [79] ExtPE ::= TextDecl? extSubsetDecl
+        // [31] extSubsetDecl ::= ( markupdecl | conditionalSect
+        //        | PEReference | S )*
+        InputEntity pe;
+
+        // XXX if this returns false ...
+
+        pe = in;
+        maybeTextDecl();
+        while (!pe.isEOF()) {
+            // pop internal PEs (and whitespace before/after)
+            if (in.isEOF()) {
+                in = in.pop();
+                continue;
+            }
+            doLexicalPE = false;
+            if (maybeWhitespace())
+                continue;
+            if (maybePEReference())
+                continue;
+            doLexicalPE = true;
+            if (maybeMarkupDecl() || maybeConditionalSect())
+                continue;
+            break;
+        }
+        // if (in != pe) throw new InternalError("who popped my PE?");
+        if (!pe.isEOF())
+            fatal("P-059", new Object[]{in.getName()});
+    }
+
+    private void readEncoding(boolean must)
+            throws IOException, SAXException {
+
+        // [81] EncName ::= [A-Za-z] ([A-Za-z0-9._] | '-')*
+        String name = maybeReadAttribute("encoding", must);
+
+        if (name == null)
+            return;
+        for (int i = 0; i < name.length(); i++) {
+            char c = name.charAt(i);
+            if ((c >= 'A' && c <= 'Z')
+                    || (c >= 'a' && c <= 'z'))
+                continue;
+            if (i != 0
+                    && ((c >= '0' && c <= '9')
+                    || c == '-'
+                    || c == '_'
+                    || c == '.'
+                    ))
+                continue;
+            fatal("P-060", new Object[]{new Character(c)});
+        }
+
+        //
+        // This should be the encoding in use, and it's even an error for
+        // it to be anything else (in certain cases that are impractical to
+        // to test, and may even be insufficient).  So, we do the best we
+        // can, and warn if things look suspicious.  Note that Java doesn't
+        // uniformly expose the encodings, and that the names it uses
+        // internally are nonstandard.  Also, that the XML spec allows
+        // such "errors" not to be reported at all.
+        //
+        String currentEncoding = in.getEncoding();
+
+        if (currentEncoding != null
+                && !name.equalsIgnoreCase(currentEncoding))
+            warning("P-061", new Object[]{name, currentEncoding});
+    }
+
+    private boolean maybeNotationDecl()
+            throws IOException, SAXException {
+
+        // [82] NotationDecl ::= '<!NOTATION' S Name S
+        //        (ExternalID | PublicID) S? '>'
+        // [83] PublicID ::= 'PUBLIC' S PubidLiteral
+        InputEntity start = peekDeclaration("!NOTATION");
+
+        if (start == null)
+            return false;
+
+        String name = getMarkupDeclname("F-019", false);
+        ExternalEntity entity = new ExternalEntity(in);
+
+        whitespace("F-011");
+        if (peek("PUBLIC")) {
+            whitespace("F-009");
+            entity.publicId = parsePublicId();
+            if (maybeWhitespace()) {
+                if (!peek(">"))
+                    entity.systemId = parseSystemId();
+                else
+                    ungetc();
+            }
+        } else if (peek("SYSTEM")) {
+            whitespace("F-008");
+            entity.systemId = parseSystemId();
+        } else
+            fatal("P-062");
+        maybeWhitespace();
+        nextChar('>', "F-032", name);
+        if (start != in)
+            error("V-013", null);
+        if (entity.systemId != null && entity.systemId.indexOf('#') != -1)
+            error("P-056", new Object[]{entity.systemId});
+
+        Object value = notations.get(name);
+        if (value != null && value instanceof ExternalEntity)
+            warning("P-063", new Object[]{name});
+
+        else {
+            notations.put(name, entity);
+            dtdHandler.notationDecl(name, entity.publicId,
+                    entity.systemId);
+        }
+        return true;
+    }
+
+
+    ////////////////////////////////////////////////////////////////
+    //
+    //    UTILITIES
+    //
+    ////////////////////////////////////////////////////////////////
+
+    private char getc() throws IOException, SAXException {
+
+        if (!doLexicalPE) {
+            char c = in.getc();
+            return c;
+        }
+
+        //
+        // External parameter entities get funky processing of '%param;'
+        // references.  It's not clearly defined in the XML spec; but it
+        // boils down to having those refs be _lexical_ in most cases to
+        // include partial syntax productions.  It also needs selective
+        // enabling; "<!ENTITY % foo ...>" must work, for example, and
+        // if "bar" is an empty string PE, "ab%bar;cd" becomes "abcd"
+        // if it's expanded in a literal, else "ab  cd".  PEs also do
+        // not expand within comments or PIs, and external PEs are only
+        // allowed to have markup decls (and so aren't handled lexically).
+        //
+        // This PE handling should be merged into maybeWhitespace, where
+        // it can be dealt with more consistently.
+        //
+        // Also, there are some validity constraints in this area.
+        //
+        char c;
+
+        while (in.isEOF()) {
+            if (in.isInternal() || (doLexicalPE && !in.isDocument()))
+                in = in.pop();
+            else {
+                fatal("P-064", new Object[]{in.getName()});
+            }
+        }
+        if ((c = in.getc()) == '%' && doLexicalPE) {
+            // PE ref ::= '%' name ';'
+            String name = maybeGetName();
+            Object entity;
+
+            if (name == null)
+                fatal("P-011");
+            nextChar(';', "F-021", name);
+            entity = params.get(name);
+
+            // push a magic "entity" before and after the
+            // real one, so ungetc() behaves uniformly
+            pushReader(" ".toCharArray(), null, false);
+            if (entity instanceof InternalEntity)
+                pushReader(((InternalEntity) entity).buf, name, false);
+            else if (entity instanceof ExternalEntity)
+            // PEs can't be unparsed!
+            // XXX if this returns false ...
+                pushReader((ExternalEntity) entity);
+            else if (entity == null)
+            // see note in maybePEReference re making this be nonfatal.
+                fatal("V-022");
+            else
+                throw new InternalError();
+            pushReader(" ".toCharArray(), null, false);
+            return in.getc();
+        }
+        return c;
+    }
+
+    private void ungetc() {
+
+        in.ungetc();
+    }
+
+    private boolean peek(String s)
+            throws IOException, SAXException {
+
+        return in.peek(s, null);
+    }
+
+    // Return the entity starting the specified declaration
+    // (for validating declaration nesting) else null.
+
+    private InputEntity peekDeclaration(String s)
+            throws IOException, SAXException {
+
+        InputEntity start;
+
+        if (!in.peekc('<'))
+            return null;
+        start = in;
+        if (in.peek(s, null))
+            return start;
+        in.ungetc();
+        return null;
+    }
+
+    private void nextChar(char c, String location, String near)
+            throws IOException, SAXException {
+
+        while (in.isEOF() && !in.isDocument())
+            in = in.pop();
+        if (!in.peekc(c))
+            fatal("P-008", new Object[]
+            {new Character(c),
+             messages.getMessage(locale, location),
+             (near == null ? "" : ('"' + near + '"'))});
+    }
+
+
+    private void pushReader(char buf [], String name, boolean isGeneral)
+            throws SAXException {
+
+        InputEntity r = InputEntity.getInputEntity(dtdHandler, locale);
+        r.init(buf, name, in, !isGeneral);
+        in = r;
+    }
+
+    private boolean pushReader(ExternalEntity next)
+            throws IOException, SAXException {
+
+        InputEntity r = InputEntity.getInputEntity(dtdHandler, locale);
+        InputSource s;
+        try {
+            s = next.getInputSource(resolver);
+        } catch (IOException e) {
+            String msg =
+                    "unable to open the external entity from :" + next.systemId;
+            if (next.publicId != null)
+                msg += " (public id:" + next.publicId + ")";
+
+            SAXParseException spe = new SAXParseException(msg,
+                    getPublicId(), getSystemId(), getLineNumber(), getColumnNumber(), e);
+            dtdHandler.fatalError(spe);
+            throw e;
+        }
+
+        r.init(s, next.name, in, next.isPE);
+        in = r;
+        return true;
+    }
+
+    public String getPublicId() {
+
+        return (in == null) ? null : in.getPublicId();
+    }
+
+    public String getSystemId() {
+
+        return (in == null) ? null : in.getSystemId();
+    }
+
+    public int getLineNumber() {
+
+        return (in == null) ? -1 : in.getLineNumber();
+    }
+
+    public int getColumnNumber() {
+
+        return (in == null) ? -1 : in.getColumnNumber();
+    }
+
+    // error handling convenience routines
+
+    private void warning(String messageId, Object parameters [])
+            throws SAXException {
+
+        SAXParseException e = new SAXParseException(messages.getMessage(locale, messageId, parameters),
+                getPublicId(), getSystemId(), getLineNumber(), getColumnNumber());
+
+        dtdHandler.warning(e);
+    }
+
+    void error(String messageId, Object parameters [])
+            throws SAXException {
+
+        SAXParseException e = new SAXParseException(messages.getMessage(locale, messageId, parameters),
+                getPublicId(), getSystemId(), getLineNumber(), getColumnNumber());
+
+        dtdHandler.error(e);
+    }
+
+    private void fatal(String messageId) throws SAXException {
+
+        fatal(messageId, null);
+    }
+
+    private void fatal(String messageId, Object parameters [])
+            throws SAXException {
+
+        SAXParseException e = new SAXParseException(messages.getMessage(locale, messageId, parameters),
+                getPublicId(), getSystemId(), getLineNumber(), getColumnNumber());
+
+        dtdHandler.fatalError(e);
+
+        throw e;
+    }
+
+    //
+    // Map char arrays to strings ... cuts down both on memory and
+    // CPU usage for element/attribute/other names that are reused.
+    //
+    // Documents typically repeat names a lot, so we more or less
+    // intern all the strings within the document; since some strings
+    // are repeated in multiple documents (e.g. stylesheets) we go
+    // a bit further, and intern globally.
+    //
+    static class NameCache {
+        //
+        // Unless we auto-grow this, the default size should be a
+        // reasonable bit larger than needed for most XML files
+        // we've yet seen (and be prime).  If it's too small, the
+        // penalty is just excess cache collisions.
+        //
+        NameCacheEntry hashtable [] = new NameCacheEntry[541];
+
+        //
+        // Usually we just want to get the 'symbol' for these chars
+        //
+        String lookup(char value [], int len) {
+
+            return lookupEntry(value, len).name;
+        }
+
+        //
+        // Sometimes we need to scan the chars in the resulting
+        // string, so there's an accessor which exposes them.
+        // (Mostly for element end tags.)
+        //
+        NameCacheEntry lookupEntry(char value [], int len) {
+
+            int index = 0;
+            NameCacheEntry entry;
+
+            // hashing to get index
+            for (int i = 0; i < len; i++)
+                index = index * 31 + value[i];
+            index &= 0x7fffffff;
+            index %= hashtable.length;
+
+            // return entry if one's there ...
+            for (entry = hashtable[index];
+                 entry != null;
+                 entry = entry.next) {
+                if (entry.matches(value, len))
+                    return entry;
+            }
+
+            // else create new one
+            entry = new NameCacheEntry();
+            entry.chars = new char[len];
+            System.arraycopy(value, 0, entry.chars, 0, len);
+            entry.name = new String(entry.chars);
+            //
+            // NOTE:  JDK 1.1 has a fixed size string intern table,
+            // with non-GC'd entries.  It can panic here; that's a
+            // JDK problem, use 1.2 or later with many identifiers.
+            //
+            entry.name = entry.name.intern();        // "global" intern
+            entry.next = hashtable[index];
+            hashtable[index] = entry;
+            return entry;
+        }
+    }
+
+    static class NameCacheEntry {
+
+        String name;
+        char chars [];
+        NameCacheEntry next;
+
+        boolean matches(char value [], int len) {
+
+            if (chars.length != len)
+                return false;
+            for (int i = 0; i < len; i++)
+                if (value[i] != chars[i])
+                    return false;
+            return true;
+        }
+    }
+
+    //
+    // Message catalog for diagnostics.
+    //
+    static final Catalog messages = new Catalog();
+
+    static final class Catalog extends MessageCatalog {
+
+        Catalog() {
+            super(DTDParser.class);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/EndOfInputException.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/EndOfInputException.java
new file mode 100644
index 0000000..b88256b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/EndOfInputException.java
@@ -0,0 +1,31 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import java.io.IOException;
+
+class EndOfInputException extends IOException {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/EntityDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/EntityDecl.java
new file mode 100644
index 0000000..cb1944e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/EntityDecl.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+/**
+ * Base class for entity declarations as used by the parser.
+ *
+ * @author David Brownell
+ * @author Janet Koenig
+ */
+class EntityDecl {
+    String name;        // <!ENTITY name ... >
+
+    boolean isFromInternalSubset;
+    boolean isPE;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/ExternalEntity.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/ExternalEntity.java
new file mode 100644
index 0000000..64a9cc1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/ExternalEntity.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+import java.io.IOException;
+import java.net.URL;
+
+final class ExternalEntity extends EntityDecl {
+    String systemId;    // resolved URI (not relative)
+    String publicId;    // "-//xyz//....//en"
+    String notation;
+
+    public ExternalEntity(InputEntity in) {
+    }
+
+    public InputSource getInputSource(EntityResolver r)
+            throws IOException, SAXException {
+
+        InputSource retval;
+
+        retval = r.resolveEntity(publicId, systemId);
+        // SAX sez if null is returned, use the URI directly
+        if (retval == null)
+            retval = Resolver.createInputSource(new URL(systemId), false);
+        return retval;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/InputEntity.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/InputEntity.java
new file mode 100644
index 0000000..f0098d1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/InputEntity.java
@@ -0,0 +1,989 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+import java.io.CharConversionException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.io.Reader;
+import java.io.UnsupportedEncodingException;
+import java.net.URL;
+import java.util.Locale;
+
+/**
+ * This is how the parser talks to its input entities, of all kinds.
+ * The entities are in a stack.
+ * <p/>
+ * <P> For internal entities, the character arrays are referenced here,
+ * and read from as needed (they're read-only).  External entities have
+ * mutable buffers, that are read into as needed.
+ * <p/>
+ * <P> <em>Note:</em> This maps CRLF (and CR) to LF without regard for
+ * whether it's in an external (parsed) entity or not.  The XML 1.0 spec
+ * is inconsistent in explaining EOL handling; this is the sensible way.
+ *
+ * @author David Brownell
+ * @author Janet Koenig
+ */
+public class InputEntity {
+    private int start, finish;
+    private char buf [];
+    private int lineNumber = 1;
+    private boolean returnedFirstHalf = false;
+    private boolean maybeInCRLF = false;
+
+    // name of entity (never main document or unnamed DTD PE)
+    private String name;
+
+    private InputEntity next;
+
+    // for system and public IDs in diagnostics
+    private InputSource input;
+
+    // this is a buffer; some buffers can be replenished.
+    private Reader reader;
+    private boolean isClosed;
+
+    private DTDEventListener errHandler;
+    private Locale locale;
+
+    private StringBuffer rememberedText;
+    private int startRemember;
+
+    // record if this is a PE, so endParsedEntity won't be called
+    private boolean isPE;
+
+    // InputStreamReader throws an internal per-read exception, so
+    // we minimize reads.  We also add a byte to compensate for the
+    // "ungetc" byte we keep, so that our downstream reads are as
+    // nicely sized as we can make them.
+    final private static int BUFSIZ = 8 * 1024 + 1;
+
+    final private static char newline [] = {'\n'};
+
+    public static InputEntity getInputEntity(DTDEventListener h, Locale l) {
+        InputEntity retval = new InputEntity();
+        retval.errHandler = h;
+        retval.locale = l;
+        return retval;
+    }
+
+    private InputEntity() {
+    }
+
+    //
+    // predicate:  return true iff this is an internal entity reader,
+    // and so may safely be "popped" as needed.  external entities have
+    // syntax to uphold; internal parameter entities have at most validity
+    // constraints to monitor.  also, only external entities get decent
+    // location diagnostics.
+    //
+    public boolean isInternal() {
+        return reader == null;
+    }
+
+    //
+    // predicate:  return true iff this is the toplevel document
+    //
+    public boolean isDocument() {
+        return next == null;
+    }
+
+    //
+    // predicate:  return true iff this is a PE expansion (so that
+    // LexicalEventListner.endParsedEntity won't be called)
+    //
+    public boolean isParameterEntity() {
+        return isPE;
+    }
+
+    //
+    // return name of current entity
+    //
+    public String getName() {
+        return name;
+    }
+
+    //
+    // use this for an external parsed entity
+    //
+    public void init(InputSource in, String name, InputEntity stack,
+                     boolean isPE)
+            throws IOException, SAXException {
+
+        input = in;
+        this.isPE = isPE;
+        reader = in.getCharacterStream();
+
+        if (reader == null) {
+            InputStream bytes = in.getByteStream();
+
+            if (bytes == null)
+                reader = XmlReader.createReader(new URL(in.getSystemId())
+                        .openStream());
+            else if (in.getEncoding() != null)
+                reader = XmlReader.createReader(in.getByteStream(),
+                        in.getEncoding());
+            else
+                reader = XmlReader.createReader(in.getByteStream());
+        }
+        next = stack;
+        buf = new char[BUFSIZ];
+        this.name = name;
+        checkRecursion(stack);
+    }
+
+    //
+    // use this for an internal parsed entity; buffer is readonly
+    //
+    public void init(char b [], String name, InputEntity stack, boolean isPE)
+            throws SAXException {
+
+        next = stack;
+        buf = b;
+        finish = b.length;
+        this.name = name;
+        this.isPE = isPE;
+        checkRecursion(stack);
+    }
+
+    private void checkRecursion(InputEntity stack)
+            throws SAXException {
+
+        if (stack == null)
+            return;
+        for (stack = stack.next; stack != null; stack = stack.next) {
+            if (stack.name != null && stack.name.equals(name))
+                fatal("P-069", new Object[]{name});
+        }
+    }
+
+    public InputEntity pop() throws IOException {
+
+        // caller has ensured there's nothing left to read
+        close();
+        return next;
+    }
+
+    /**
+     * returns true iff there's no more data to consume ...
+     */
+    public boolean isEOF() throws IOException, SAXException {
+
+        // called to ensure WF-ness of included entities and to pop
+        // input entities appropriately ... EOF is not always legal.
+        if (start >= finish) {
+            fillbuf();
+            return start >= finish;
+        } else
+            return false;
+    }
+
+    /**
+     * Returns the name of the encoding in use, else null; the name
+     * returned is in as standard a form as we can get.
+     */
+    public String getEncoding() {
+
+        if (reader == null)
+            return null;
+        if (reader instanceof XmlReader)
+            return ((XmlReader) reader).getEncoding();
+
+        // XXX prefer a java2std() call to normalize names...
+
+        if (reader instanceof InputStreamReader)
+            return ((InputStreamReader) reader).getEncoding();
+        return null;
+    }
+
+
+    /**
+     * returns the next name char, or NUL ... faster than getc(),
+     * and the common "name or nmtoken must be next" case won't
+     * need ungetc().
+     */
+    public char getNameChar() throws IOException, SAXException {
+
+        if (finish <= start)
+            fillbuf();
+        if (finish > start) {
+            char c = buf[start++];
+            if (XmlChars.isNameChar(c))
+                return c;
+            start--;
+        }
+        return 0;
+    }
+
+    /**
+     * gets the next Java character -- might be part of an XML
+     * text character represented by a surrogate pair, or be
+     * the end of the entity.
+     */
+    public char getc() throws IOException, SAXException {
+
+        if (finish <= start)
+            fillbuf();
+        if (finish > start) {
+            char c = buf[start++];
+
+            // [2] Char ::= #x0009 | #x000A | #x000D
+            //            | [#x0020-#xD7FF]
+            //            | [#xE000-#xFFFD]
+            // plus surrogate _pairs_ representing [#x10000-#x10ffff]
+            if (returnedFirstHalf) {
+                if (c >= 0xdc00 && c <= 0xdfff) {
+                    returnedFirstHalf = false;
+                    return c;
+                } else
+                    fatal("P-070", new Object[]{Integer.toHexString(c)});
+            }
+            if ((c >= 0x0020 && c <= 0xD7FF)
+                    || c == 0x0009
+                    // no surrogates!
+                    || (c >= 0xE000 && c <= 0xFFFD))
+                return c;
+
+            //
+            // CRLF and CR are both line ends; map both to LF, and
+            // keep line count correct.
+            //
+            else if (c == '\r' && !isInternal()) {
+                maybeInCRLF = true;
+                c = getc();
+                if (c != '\n')
+                    ungetc();
+                maybeInCRLF = false;
+
+                lineNumber++;
+                return '\n';
+
+            } else if (c == '\n' || c == '\r') { // LF, or 2nd char in CRLF
+                if (!isInternal() && !maybeInCRLF)
+                    lineNumber++;
+                return c;
+            }
+
+            // surrogates...
+            if (c >= 0xd800 && c < 0xdc00) {
+                returnedFirstHalf = true;
+                return c;
+            }
+
+            fatal("P-071", new Object[]{Integer.toHexString(c)});
+        }
+        throw new EndOfInputException();
+    }
+
+
+    /**
+     * lookahead one character
+     */
+    public boolean peekc(char c) throws IOException, SAXException {
+
+        if (finish <= start)
+            fillbuf();
+        if (finish > start) {
+            if (buf[start] == c) {
+                start++;
+                return true;
+            } else
+                return false;
+        }
+        return false;
+    }
+
+
+    /**
+     * two character pushback is guaranteed
+     */
+    public void ungetc() {
+
+        if (start == 0)
+            throw new InternalError("ungetc");
+        start--;
+
+        if (buf[start] == '\n' || buf[start] == '\r') {
+            if (!isInternal())
+                lineNumber--;
+        } else if (returnedFirstHalf)
+            returnedFirstHalf = false;
+    }
+
+
+    /**
+     * optional grammatical whitespace (discarded)
+     */
+    public boolean maybeWhitespace()
+            throws IOException, SAXException {
+
+        char c;
+        boolean isSpace = false;
+        boolean sawCR = false;
+
+        // [3] S ::= #20 | #09 | #0D | #0A
+        for (; ;) {
+            if (finish <= start)
+                fillbuf();
+            if (finish <= start)
+                return isSpace;
+
+            c = buf[start++];
+            if (c == 0x20 || c == 0x09 || c == '\n' || c == '\r') {
+                isSpace = true;
+
+                //
+                // CR, LF are line endings ... CLRF is one, not two!
+                //
+                if ((c == '\n' || c == '\r') && !isInternal()) {
+                    if (!(c == '\n' && sawCR)) {
+                        lineNumber++;
+                        sawCR = false;
+                    }
+                    if (c == '\r')
+                        sawCR = true;
+                }
+            } else {
+                start--;
+                return isSpace;
+            }
+        }
+    }
+
+
+    /**
+     * normal content; whitespace in markup may be handled
+     * specially if the parser uses the content model.
+     * <p/>
+     * <P> content terminates with markup delimiter characters,
+     * namely ampersand (&amp;amp;) and left angle bracket (&amp;lt;).
+     * <p/>
+     * <P> the document handler's characters() method is called
+     * on all the content found
+     */
+    public boolean parsedContent(DTDEventListener docHandler
+                                 /*ElementValidator validator*/)
+            throws IOException, SAXException {
+
+        // [14] CharData ::= [^<&]* - ([^<&]* ']]>' [^<&]*)
+
+        int first;        // first char to return
+        int last;        // last char to return
+        boolean sawContent;    // sent any chars?
+        char c;
+
+        // deliver right out of the buffer, until delimiter, EOF,
+        // or error, refilling as we go
+        for (first = last = start, sawContent = false; ; last++) {
+
+            // buffer empty?
+            if (last >= finish) {
+                if (last > first) {
+//            validator.text ();
+                    docHandler.characters(buf, first, last - first);
+                    sawContent = true;
+                    start = last;
+                }
+                if (isEOF())    // calls fillbuf
+                    return sawContent;
+                first = start;
+                last = first - 1;    // incremented in loop
+                continue;
+            }
+
+            c = buf[last];
+
+            //
+            // pass most chars through ASAP; this inlines the code of
+            // [2] !XmlChars.isChar(c) leaving only characters needing
+            // special treatment ... line ends, surrogates, and:
+            //    0x0026 == '&'
+            //    0x003C == '<'
+            //    0x005D == ']'
+            // Comparisons ordered for speed on 'typical' text
+            //
+            if ((c > 0x005D && c <= 0xD7FF)    // a-z and more
+                    || (c < 0x0026 && c >= 0x0020)    // space & punct
+                    || (c > 0x003C && c < 0x005D)    // A-Z & punct
+                    || (c > 0x0026 && c < 0x003C)    // 0-9 & punct
+                    || c == 0x0009
+                    || (c >= 0xE000 && c <= 0xFFFD)
+            )
+                continue;
+
+            // terminate on markup delimiters
+            if (c == '<' || c == '&')
+                break;
+
+            // count lines
+            if (c == '\n') {
+                if (!isInternal())
+                    lineNumber++;
+                continue;
+            }
+
+            // External entities get CR, CRLF --> LF mapping
+            // Internal ones got it already, and we can't repeat
+            // else we break char ref handling!!
+            if (c == '\r') {
+                if (isInternal())
+                    continue;
+
+                docHandler.characters(buf, first, last - first);
+                docHandler.characters(newline, 0, 1);
+                sawContent = true;
+                lineNumber++;
+                if (finish > (last + 1)) {
+                    if (buf[last + 1] == '\n')
+                        last++;
+                } else {    // CR at end of buffer
+// XXX case not yet handled:  CRLF here will look like two lines
+                }
+                first = start = last + 1;
+                continue;
+            }
+
+            // ']]>' is a WF error -- must fail if we see it
+            if (c == ']') {
+                switch (finish - last) {
+                // for suspicious end-of-buffer cases, get more data
+                // into the buffer to rule out this sequence.
+                case 2:
+                    if (buf[last + 1] != ']')
+                        continue;
+                    // FALLTHROUGH
+
+                case 1:
+                    if (reader == null || isClosed)
+                        continue;
+                    if (last == first)
+                        throw new InternalError("fillbuf");
+                    last--;
+                    if (last > first) {
+//            validator.text ();
+                        docHandler.characters(buf, first, last - first);
+                        sawContent = true;
+                        start = last;
+                    }
+                    fillbuf();
+                    first = last = start;
+                    continue;
+
+                    // otherwise any "]]>" would be buffered, and we can
+                    // see right away if that's what we have
+                default:
+                    if (buf[last + 1] == ']' && buf[last + 2] == '>')
+                        fatal("P-072", null);
+                    continue;
+                }
+            }
+
+            // correctly paired surrogates are OK
+            if (c >= 0xd800 && c <= 0xdfff) {
+                if ((last + 1) >= finish) {
+                    if (last > first) {
+//            validator.text ();
+                        docHandler.characters(buf, first, last - first);
+                        sawContent = true;
+                        start = last + 1;
+                    }
+                    if (isEOF()) {    // calls fillbuf
+                        fatal("P-081",
+                                new Object[]{Integer.toHexString(c)});
+                    }
+                    first = start;
+                    last = first;
+                    continue;
+                }
+                if (checkSurrogatePair(last))
+                    last++;
+                else {
+                    last--;
+                    // also terminate on surrogate pair oddities
+                    break;
+                }
+                continue;
+            }
+
+            fatal("P-071", new Object[]{Integer.toHexString(c)});
+        }
+        if (last == first)
+            return sawContent;
+//    validator.text ();
+        docHandler.characters(buf, first, last - first);
+        start = last;
+        return true;
+    }
+
+
+    /**
+     * CDATA -- character data, terminated by "]]>" and optionally
+     * including unescaped markup delimiters (ampersand and left angle
+     * bracket).  This should otherwise be exactly like character data,
+     * modulo differences in error report details.
+     * <p/>
+     * <P> The document handler's characters() or ignorableWhitespace()
+     * methods are invoked on all the character data found
+     *
+     * @param docHandler               gets callbacks for character data
+     * @param ignorableWhitespace      if true, whitespace characters will
+     *                                 be reported using docHandler.ignorableWhitespace(); implicitly,
+     *                                 non-whitespace characters will cause validation errors
+     * @param whitespaceInvalidMessage if true, ignorable whitespace
+     *                                 causes a validity error report as well as a callback
+     */
+    public boolean unparsedContent(DTDEventListener docHandler,
+                                   /*ElementValidator validator,*/
+                                   boolean ignorableWhitespace,
+                                   String whitespaceInvalidMessage)
+            throws IOException, SAXException {
+
+        // [18] CDSect ::= CDStart CData CDEnd
+        // [19] CDStart ::= '<![CDATA['
+        // [20] CData ::= (Char* - (Char* ']]>' Char*))
+        // [21] CDEnd ::= ']]>'
+
+        // caller peeked the leading '<' ...
+        if (!peek("![CDATA[", null))
+            return false;
+        docHandler.startCDATA();
+
+        // only a literal ']]>' stops this ...
+        int last;
+
+        for (; ;) {        // until ']]>' seen
+            boolean done = false;
+            char c;
+
+            // don't report ignorable whitespace as "text" for
+            // validation purposes.
+            boolean white = ignorableWhitespace;
+
+            for (last = start; last < finish; last++) {
+                c = buf[last];
+
+                //
+                // Reject illegal characters.
+                //
+                if (!XmlChars.isChar(c)) {
+                    white = false;
+                    if (c >= 0xd800 && c <= 0xdfff) {
+                        if (checkSurrogatePair(last)) {
+                            last++;
+                            continue;
+                        } else {
+                            last--;
+                            break;
+                        }
+                    }
+                    fatal("P-071", new Object[]
+                    {Integer.toHexString(buf[last])});
+                }
+                if (c == '\n') {
+                    if (!isInternal())
+                        lineNumber++;
+                    continue;
+                }
+                if (c == '\r') {
+                    // As above, we can't repeat CR/CRLF --> LF mapping
+                    if (isInternal())
+                        continue;
+
+                    if (white) {
+                        if (whitespaceInvalidMessage != null)
+                            errHandler.error(new SAXParseException(DTDParser.messages.getMessage(locale,
+                                    whitespaceInvalidMessage), null));
+                        docHandler.ignorableWhitespace(buf, start,
+                                last - start);
+                        docHandler.ignorableWhitespace(newline, 0, 1);
+                    } else {
+//            validator.text ();
+                        docHandler.characters(buf, start, last - start);
+                        docHandler.characters(newline, 0, 1);
+                    }
+                    lineNumber++;
+                    if (finish > (last + 1)) {
+                        if (buf[last + 1] == '\n')
+                            last++;
+                    } else {    // CR at end of buffer
+// XXX case not yet handled ... as above
+                    }
+                    start = last + 1;
+                    continue;
+                }
+                if (c != ']') {
+                    if (c != ' ' && c != '\t')
+                        white = false;
+                    continue;
+                }
+                if ((last + 2) < finish) {
+                    if (buf[last + 1] == ']' && buf[last + 2] == '>') {
+                        done = true;
+                        break;
+                    }
+                    white = false;
+                    continue;
+                } else {
+                    //last--;
+                    break;
+                }
+            }
+            if (white) {
+                if (whitespaceInvalidMessage != null)
+                    errHandler.error(new SAXParseException(DTDParser.messages.getMessage(locale,
+                            whitespaceInvalidMessage), null));
+                docHandler.ignorableWhitespace(buf, start, last - start);
+            } else {
+//        validator.text ();
+                docHandler.characters(buf, start, last - start);
+            }
+            if (done) {
+                start = last + 3;
+                break;
+            }
+            start = last;
+            if (isEOF())
+                fatal("P-073", null);
+        }
+        docHandler.endCDATA();
+        return true;
+    }
+
+    // return false to backstep at end of buffer)
+    private boolean checkSurrogatePair(int offset)
+            throws SAXException {
+
+        if ((offset + 1) >= finish)
+            return false;
+
+        char c1 = buf[offset++];
+        char c2 = buf[offset];
+
+        if ((c1 >= 0xd800 && c1 < 0xdc00) && (c2 >= 0xdc00 && c2 <= 0xdfff))
+            return true;
+        fatal("P-074", new Object[]{
+            Integer.toHexString(c1 & 0x0ffff),
+            Integer.toHexString(c2 & 0x0ffff)
+        });
+        return false;
+    }
+
+
+    /**
+     * whitespace in markup (flagged to app, discardable)
+     * <p/>
+     * <P> the document handler's ignorableWhitespace() method
+     * is called on all the whitespace found
+     */
+    public boolean ignorableWhitespace(DTDEventListener handler)
+            throws IOException, SAXException {
+
+        char c;
+        boolean isSpace = false;
+        int first;
+
+        // [3] S ::= #20 | #09 | #0D | #0A
+        for (first = start; ;) {
+            if (finish <= start) {
+                if (isSpace)
+                    handler.ignorableWhitespace(buf, first, start - first);
+                fillbuf();
+                first = start;
+            }
+            if (finish <= start)
+                return isSpace;
+
+            c = buf[start++];
+            switch (c) {
+            case '\n':
+                if (!isInternal())
+                    lineNumber++;
+// XXX handles Macintosh line endings wrong
+                // fallthrough
+            case 0x09:
+            case 0x20:
+                isSpace = true;
+                continue;
+
+            case '\r':
+                isSpace = true;
+                if (!isInternal())
+                    lineNumber++;
+                handler.ignorableWhitespace(buf, first,
+                        (start - 1) - first);
+                handler.ignorableWhitespace(newline, 0, 1);
+                if (start < finish && buf[start] == '\n')
+                    ++start;
+                first = start;
+                continue;
+
+            default:
+                ungetc();
+                if (isSpace)
+                    handler.ignorableWhitespace(buf, first, start - first);
+                return isSpace;
+            }
+        }
+    }
+
+    /**
+     * returns false iff 'next' string isn't as provided,
+     * else skips that text and returns true.
+     * <p/>
+     * <P> NOTE:  two alternative string representations are
+     * both passed in, since one is faster.
+     */
+    public boolean peek(String next, char chars [])
+            throws IOException, SAXException {
+
+        int len;
+        int i;
+
+        if (chars != null)
+            len = chars.length;
+        else
+            len = next.length();
+
+        // buffer should hold the whole thing ... give it a
+        // chance for the end-of-buffer case and cope with EOF
+        // by letting fillbuf compact and fill
+        if (finish <= start || (finish - start) < len)
+            fillbuf();
+
+        // can't peek past EOF
+        if (finish <= start)
+            return false;
+
+        // compare the string; consume iff it matches
+        if (chars != null) {
+            for (i = 0; i < len && (start + i) < finish; i++) {
+                if (buf[start + i] != chars[i])
+                    return false;
+            }
+        } else {
+            for (i = 0; i < len && (start + i) < finish; i++) {
+                if (buf[start + i] != next.charAt(i))
+                    return false;
+            }
+        }
+
+        // if the first fillbuf didn't get enough data, give
+        // fillbuf another chance to read
+        if (i < len) {
+            if (reader == null || isClosed)
+                return false;
+
+            //
+            // This diagnostic "knows" that the only way big strings would
+            // fail to be peeked is where it's a symbol ... e.g. for an
+            // </EndTag> construct.  That knowledge could also be applied
+            // to get rid of the symbol length constraint, since having
+            // the wrong symbol is a fatal error anyway ...
+            //
+            if (len > buf.length)
+                fatal("P-077", new Object[]{new Integer(buf.length)});
+
+            fillbuf();
+            return peek(next, chars);
+        }
+
+        start += len;
+        return true;
+    }
+
+
+    //
+    // Support for reporting the internal DTD subset, so <!DOCTYPE...>
+    // declarations can be recreated.  This is collected as a single
+    // string; such subsets are normally small, and many applications
+    // don't even care about this.
+    //
+    public void startRemembering() {
+
+        if (startRemember != 0)
+            throw new InternalError();
+        startRemember = start;
+    }
+
+    public String rememberText() {
+
+        String retval;
+
+        // If the internal subset crossed a buffer boundary, we
+        // created a temporary buffer.
+        if (rememberedText != null) {
+            rememberedText.append(buf, startRemember,
+                    start - startRemember);
+            retval = rememberedText.toString();
+        } else
+            retval = new String(buf, startRemember,
+                    start - startRemember);
+
+        startRemember = 0;
+        rememberedText = null;
+        return retval;
+    }
+
+    private InputEntity getTopEntity() {
+
+        InputEntity current = this;
+
+        // don't report locations within internal entities!
+
+        while (current != null && current.input == null)
+            current = current.next;
+        return current == null ? this : current;
+    }
+
+    /**
+     * Returns the public ID of this input source, if known
+     */
+    public String getPublicId() {
+
+        InputEntity where = getTopEntity();
+        if (where == this)
+            return input.getPublicId();
+        return where.getPublicId();
+    }
+
+    /**
+     * Returns the system ID of this input source, if known
+     */
+    public String getSystemId() {
+
+        InputEntity where = getTopEntity();
+        if (where == this)
+            return input.getSystemId();
+        return where.getSystemId();
+    }
+
+    /**
+     * Returns the current line number in this input source
+     */
+    public int getLineNumber() {
+
+        InputEntity where = getTopEntity();
+        if (where == this)
+            return lineNumber;
+        return where.getLineNumber();
+    }
+
+    /**
+     * returns -1; maintaining column numbers hurts performance
+     */
+    public int getColumnNumber() {
+
+        return -1;        // not maintained (speed)
+    }
+
+
+    //
+    // n.b. for non-EOF end-of-buffer cases, reader should return
+    // at least a handful of bytes so various lookaheads behave.
+    //
+    // two character pushback exists except at first; characters
+    // represented by surrogate pairs can't be pushed back (they'd
+    // only be in character data anyway).
+    //
+    // DTD exception thrown on char conversion problems; line number
+    // will be low, as a rule.
+    //
+    private void fillbuf() throws IOException, SAXException {
+
+        // don't touched fixed buffers, that'll usually
+        // change entity values (and isn't needed anyway)
+        // likewise, ignore closed streams
+        if (reader == null || isClosed)
+            return;
+
+        // if remembering DTD text, copy!
+        if (startRemember != 0) {
+            if (rememberedText == null)
+                rememberedText = new StringBuffer(buf.length);
+            rememberedText.append(buf, startRemember,
+                    start - startRemember);
+        }
+
+        boolean extra = (finish > 0) && (start > 0);
+        int len;
+
+        if (extra)        // extra pushback
+            start--;
+        len = finish - start;
+
+        System.arraycopy(buf, start, buf, 0, len);
+        start = 0;
+        finish = len;
+
+        try {
+            len = buf.length - len;
+            len = reader.read(buf, finish, len);
+        } catch (UnsupportedEncodingException e) {
+            fatal("P-075", new Object[]{e.getMessage()});
+        } catch (CharConversionException e) {
+            fatal("P-076", new Object[]{e.getMessage()});
+        }
+        if (len >= 0)
+            finish += len;
+        else
+            close();
+        if (extra)        // extra pushback
+            start++;
+
+        if (startRemember != 0)
+        // assert extra == true
+            startRemember = 1;
+    }
+
+    public void close() {
+
+        try {
+            if (reader != null && !isClosed)
+                reader.close();
+            isClosed = true;
+        } catch (IOException e) {
+            /* NOTHING */
+        }
+    }
+
+
+    private void fatal(String messageId, Object params [])
+            throws SAXException {
+
+        SAXParseException x = new SAXParseException(DTDParser.messages.getMessage(locale, messageId, params), null);
+
+        // not continuable ... e.g. WF errors
+        close();
+        errHandler.fatalError(x);
+        throw x;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/InternalEntity.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/InternalEntity.java
new file mode 100644
index 0000000..0116b96
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/InternalEntity.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+
+final class InternalEntity extends EntityDecl {
+    InternalEntity(String name, char value []) {
+        this.name = name;
+        this.buf = value;
+    }
+
+    char buf [];
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/MessageCatalog.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/MessageCatalog.java
new file mode 100644
index 0000000..f29d0c6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/MessageCatalog.java
@@ -0,0 +1,515 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import java.io.InputStream;
+import java.text.FieldPosition;
+import java.text.MessageFormat;
+import java.util.Hashtable;
+import java.util.Locale;
+import java.util.MissingResourceException;
+import java.util.ResourceBundle;
+
+
+/**
+ * This class provides support for multi-language string lookup, as needed
+ * to localize messages from applications supporting multiple languages
+ * at the same time.  One class of such applications is network services,
+ * such as HTTP servers, which talk to clients who may not be from the
+ * same locale as the server.  This class supports a form of negotiation
+ * for the language used in presenting a message from some package, where
+ * both user (client) preferences and application (server) support are
+ * accounted for when choosing locales and formatting messages.
+ * <p/>
+ * <P> Each package should have a singleton package-private message catalog
+ * class.  This ensures that the correct class loader will always be used to
+ * access message resources, and minimizes use of memory: <PRE>
+ * package <em>some.package</em>;
+ * <p/>
+ * // "foo" might be public
+ * class foo {
+ * ...
+ * // package private
+ * static final Catalog messages = new Catalog ();
+ * static final class Catalog extends MessageCatalog {
+ * Catalog () { super (Catalog.class); }
+ * }
+ * ...
+ * }
+ * </PRE>
+ * <p/>
+ * <P> Messages for a known client could be generated using code
+ * something like this:  <PRE>
+ * String clientLanguages [];
+ * Locale clientLocale;
+ * String clientMessage;
+ * <p/>
+ * // client languages will probably be provided by client,
+ * // e.g. by an HTTP/1.1 "Accept-Language" header.
+ * clientLanguages = new String [] { "en-ca", "fr-ca", "ja", "zh" };
+ * clientLocale = foo.messages.chooseLocale (clientLanguages);
+ * clientMessage = foo.messages.getMessage (clientLocale,
+ * "fileCount",
+ * new Object [] { new Integer (numberOfFiles) }
+ * );
+ * </PRE>
+ * <p/>
+ * <P> At this time, this class does not include functionality permitting
+ * messages to be passed around and localized after-the-fact.  The consequence
+ * of this is that the locale for messages must be passed down through layers
+ * which have no normal reason to support such passdown, or else the system
+ * default locale must be used instead of the one the client needs.
+ * <p/>
+ * <P> <hr> The following guidelines should be used when constructiong
+ * multi-language applications:  <OL>
+ * <p/>
+ * <LI> Always use <a href=#chooseLocale>chooseLocale</a> to select the
+ * locale you pass to your <code>getMessage</code> call.  This lets your
+ * applications use IETF standard locale names, and avoids needless
+ * use of system defaults.
+ * <p/>
+ * <LI> The localized messages for a given package should always go in
+ * a separate <em>resources</em> sub-package.  There are security
+ * implications; see below.
+ * <p/>
+ * <LI> Make sure that a language name is included in each bundle name,
+ * so that the developer's locale will not be inadvertently used. That
+ * is, don't create defaults like <em>resources/Messages.properties</em>
+ * or <em>resources/Messages.class</em>, since ResourceBundle will choose
+ * such defaults rather than giving software a chance to choose a more
+ * appropriate language for its messages.  Your message bundles should
+ * have names like <em>Messages_en.properties</em> (for the "en", or
+ * English, language) or <em>Messages_ja.class</em> ("ja" indicates the
+ * Japanese language).
+ * <p/>
+ * <LI> Only use property files for messages in languages which can
+ * be limited to the ISO Latin/1 (8859-1) characters supported by the
+ * property file format.  (This is mostly Western European languages.)
+ * Otherwise, subclass ResourceBundle to provide your messages; it is
+ * simplest to subclass <code>java.util.ListResourceBundle</code>.
+ * <p/>
+ * <LI> Never use another package's message catalog or resource bundles.
+ * It should not be possible for a change internal to one package (such
+ * as eliminating or improving messages) to break another package.
+ * <p/>
+ * </OL>
+ * <p/>
+ * <P> The "resources" sub-package can be treated separately from the
+ * package with which it is associated.  That main package may be sealed
+ * and possibly signed, preventing other software from adding classes to
+ * the package which would be able to access methods and data which are
+ * not designed to be publicly accessible.  On the other hand, resources
+ * such as localized messages are often provided after initial product
+ * shipment, without a full release cycle for the product.  Such files
+ * (text and class files) need to be added to some package.  Since they
+ * should not be added to the main package, the "resources" subpackage is
+ * used without risking the security or integrity of that main package
+ * as distributed in its JAR file.
+ *
+ * @author David Brownell
+ * @see java.util.Locale
+ * @see java.util.ListResourceBundle
+ * @see java.text.MessageFormat
+ */
+// leave this as "abstract" -- each package needs its own subclass,
+// else it's not always going to be using the right class loader.
+abstract public class MessageCatalog {
+    private String bundleName;
+
+    /**
+     * Create a message catalog for use by classes in the same package
+     * as the specified class.  This uses <em>Messages</em> resource
+     * bundles in the <em>resources</em> sub-package of class passed as
+     * a parameter.
+     *
+     * @param packageMember Class whose package has localized messages
+     */
+    protected MessageCatalog(Class packageMember) {
+        this(packageMember, "Messages");
+    }
+
+    /**
+     * Create a message catalog for use by classes in the same package
+     * as the specified class.  This uses the specified resource
+     * bundle name in the <em>resources</em> sub-package of class passed
+     * as a parameter; for example, <em>resources.Messages</em>.
+     *
+     * @param packageMember Class whose package has localized messages
+     * @param bundle        Name of a group of resource bundles
+     */
+    private MessageCatalog(Class packageMember, String bundle) {
+        int index;
+
+        bundleName = packageMember.getName();
+        index = bundleName.lastIndexOf('.');
+        if (index == -1)    // "ClassName"
+            bundleName = "";
+        else            // "some.package.ClassName"
+            bundleName = bundleName.substring(0, index) + ".";
+        bundleName = bundleName + "resources." + bundle;
+    }
+
+
+    /**
+     * Get a message localized to the specified locale, using the message ID
+     * and package name if no message is available.  The locale is normally
+     * that of the client of a service, chosen with knowledge that both the
+     * client and this server support that locale.  There are two error
+     * cases:  first, when the specified locale is unsupported or null, the
+     * default locale is used if possible; second, when no bundle supports
+     * that locale, the message ID and package name are used.
+     *
+     * @param locale    The locale of the message to use.  If this is null,
+     *                  the default locale will be used.
+     * @param messageId The ID of the message to use.
+     * @return The message, localized as described above.
+     */
+    public String getMessage(Locale locale,
+                             String messageId) {
+        ResourceBundle bundle;
+
+        // cope with unsupported locale...
+        if (locale == null)
+            locale = Locale.getDefault();
+
+        try {
+            bundle = ResourceBundle.getBundle(bundleName, locale);
+        } catch (MissingResourceException e) {
+            bundle = ResourceBundle.getBundle(bundleName, Locale.ENGLISH);
+        }
+        return bundle.getString(messageId);
+    }
+
+
+    /**
+     * Format a message localized to the specified locale, using the message
+     * ID with its package name if none is available.  The locale is normally
+     * the client of a service, chosen with knowledge that both the client
+     * server support that locale.  There are two error cases:  first, if the
+     * specified locale is unsupported or null, the default locale is used if
+     * possible; second, when no bundle supports that locale, the message ID
+     * and package name are used.
+     *
+     * @param locale     The locale of the message to use.  If this is null,
+     *                   the default locale will be used.
+     * @param messageId  The ID of the message format to use.
+     * @param parameters Used when formatting the message.  Objects in
+     *                   this list are turned to strings if they are not Strings, Numbers,
+     *                   or Dates (that is, if MessageFormat would treat them as errors).
+     * @return The message, localized as described above.
+     * @see java.text.MessageFormat
+     */
+    public String getMessage(Locale locale,
+                             String messageId,
+                             Object parameters []) {
+        if (parameters == null)
+            return getMessage(locale, messageId);
+
+        // since most messages won't be tested (sigh), be friendly to
+        // the inevitable developer errors of passing random data types
+        // to the message formatting code.
+        for (int i = 0; i < parameters.length; i++) {
+            if (!(parameters[i] instanceof String)
+                    && !(parameters[i] instanceof Number)
+                    && !(parameters[i] instanceof java.util.Date)) {
+                if (parameters[i] == null)
+                    parameters[i] = "(null)";
+                else
+                    parameters[i] = parameters[i].toString();
+            }
+        }
+
+        // similarly, cope with unsupported locale...
+        if (locale == null)
+            locale = Locale.getDefault();
+
+        // get the appropriately localized MessageFormat object
+        ResourceBundle bundle;
+        MessageFormat format;
+
+        try {
+            bundle = ResourceBundle.getBundle(bundleName, locale);
+        } catch (MissingResourceException e) {
+            bundle = ResourceBundle.getBundle(bundleName, Locale.ENGLISH);
+            /*String retval;
+
+            retval = packagePrefix (messageId);
+            for (int i = 0; i < parameters.length; i++) {
+            retval += ' ';
+            retval += parameters [i];
+            }
+            return retval;*/
+        }
+        format = new MessageFormat(bundle.getString(messageId));
+        format.setLocale(locale);
+
+        // return the formatted message
+        StringBuffer result = new StringBuffer();
+
+        result = format.format(parameters, result, new FieldPosition(0));
+        return result.toString();
+    }
+
+
+    /**
+     * Chooses a client locale to use, using the first language specified in
+     * the list that is supported by this catalog.  If none of the specified
+     * languages is supported, a null value is returned.  Such a list of
+     * languages might be provided in an HTTP/1.1 "Accept-Language" header
+     * field, or through some other content negotiation mechanism.
+     * <p/>
+     * <P> The language specifiers recognized are RFC 1766 style ("fr" for
+     * all French, "fr-ca" for Canadian French), although only the strict
+     * ISO subset (two letter language and country specifiers) is currently
+     * supported.  Java-style locale strings ("fr_CA") are also supported.
+     *
+     * @param languages Array of language specifiers, ordered with the most
+     *                  preferable one at the front.  For example, "en-ca" then "fr-ca",
+     *                  followed by "zh_CN".
+     * @return The most preferable supported locale, or null.
+     * @see java.util.Locale
+     */
+    public Locale chooseLocale(String languages []) {
+        if ((languages = canonicalize(languages)) != null) {
+            for (int i = 0; i < languages.length; i++)
+                if (isLocaleSupported(languages[i]))
+                    return getLocale(languages[i]);
+        }
+        return null;
+    }
+
+
+    //
+    // Canonicalizes the RFC 1766 style language strings ("en-in") to
+    // match standard Java usage ("en_IN"), removing strings that don't
+    // use two character ISO language and country codes.   Avoids all
+    // memory allocations possible, so that if the strings passed in are
+    // just lowercase ISO codes (a common case) the input is returned.
+    //
+    private String[] canonicalize(String languages []) {
+        boolean didClone = false;
+        int trimCount = 0;
+
+        if (languages == null)
+            return languages;
+
+        for (int i = 0; i < languages.length; i++) {
+            String lang = languages[i];
+            int len = lang.length();
+
+            // no RFC1766 extensions allowed; "zh" and "zh-tw" (etc) are OK
+            // as are regular locale names with no variant ("de_CH").
+            if (!(len == 2 || len == 5)) {
+                if (!didClone) {
+                    languages = (String[]) languages.clone();
+                    didClone = true;
+                }
+                languages[i] = null;
+                trimCount++;
+                continue;
+            }
+
+            // language code ... if already lowercase, we change nothing
+            if (len == 2) {
+                lang = lang.toLowerCase();
+                if (lang != languages[i]) {
+                    if (!didClone) {
+                        languages = (String[]) languages.clone();
+                        didClone = true;
+                    }
+                    languages[i] = lang;
+                }
+                continue;
+            }
+
+            // language_country ... fixup case, force "_"
+            char buf [] = new char[5];
+
+            buf[0] = Character.toLowerCase(lang.charAt(0));
+            buf[1] = Character.toLowerCase(lang.charAt(1));
+            buf[2] = '_';
+            buf[3] = Character.toUpperCase(lang.charAt(3));
+            buf[4] = Character.toUpperCase(lang.charAt(4));
+            if (!didClone) {
+                languages = (String[]) languages.clone();
+                didClone = true;
+            }
+            languages[i] = new String(buf);
+        }
+
+        // purge any shadows of deleted RFC1766 extended language codes
+        if (trimCount != 0) {
+            String temp [] = new String[languages.length - trimCount];
+            int i;
+
+            for (i = 0, trimCount = 0; i < temp.length; i++) {
+                while (languages[i + trimCount] == null)
+                    trimCount++;
+                temp[i] = languages[i + trimCount];
+            }
+            languages = temp;
+        }
+        return languages;
+    }
+
+
+    //
+    // Returns a locale object supporting the specified locale, using
+    // a small cache to speed up some common languages and reduce the
+    // needless allocation of memory.
+    //
+    private Locale getLocale(String localeName) {
+        String language, country;
+        int index;
+
+        index = localeName.indexOf('_');
+        if (index == -1) {
+            //
+            // Special case the builtin JDK languages
+            //
+            if (localeName.equals("de"))
+                return Locale.GERMAN;
+            if (localeName.equals("en"))
+                return Locale.ENGLISH;
+            if (localeName.equals("fr"))
+                return Locale.FRENCH;
+            if (localeName.equals("it"))
+                return Locale.ITALIAN;
+            if (localeName.equals("ja"))
+                return Locale.JAPANESE;
+            if (localeName.equals("ko"))
+                return Locale.KOREAN;
+            if (localeName.equals("zh"))
+                return Locale.CHINESE;
+
+            language = localeName;
+            country = "";
+        } else {
+            if (localeName.equals("zh_CN"))
+                return Locale.SIMPLIFIED_CHINESE;
+            if (localeName.equals("zh_TW"))
+                return Locale.TRADITIONAL_CHINESE;
+
+            //
+            // JDK also has constants for countries:  en_GB, en_US, en_CA,
+            // fr_FR, fr_CA, de_DE, ja_JP, ko_KR.  We don't use those.
+            //
+            language = localeName.substring(0, index);
+            country = localeName.substring(index + 1);
+        }
+
+        return new Locale(language, country);
+    }
+
+
+    //
+    // cache for isLanguageSupported(), below ... key is a language
+    // or locale name, value is a Boolean
+    //
+    private Hashtable cache = new Hashtable(5);
+
+
+    /**
+     * Returns true iff the specified locale has explicit language support.
+     * For example, the traditional Chinese locale "zh_TW" has such support
+     * if there are message bundles suffixed with either "zh_TW" or "zh".
+     * <p/>
+     * <P> This method is used to bypass part of the search path mechanism
+     * of the <code>ResourceBundle</code> class, specifically the parts which
+     * force use of default locales and bundles.  Such bypassing is required
+     * in order to enable use of a client's preferred languages.  Following
+     * the above example, if a client prefers "zh_TW" but can also accept
+     * "ja", this method would be used to detect that there are no "zh_TW"
+     * resource bundles and hence that "ja" messages should be used.  This
+     * bypasses the ResourceBundle mechanism which will return messages in
+     * some other locale (picking some hard-to-anticipate default) instead
+     * of reporting an error and letting the client choose another locale.
+     *
+     * @param localeName A standard Java locale name, using two character
+     *                   language codes optionally suffixed by country codes.
+     * @return True iff the language of that locale is supported.
+     * @see java.util.Locale
+     */
+    public boolean isLocaleSupported(String localeName) {
+        //
+        // Use previous results if possible.  We expect that the codebase
+        // is immutable, so we never worry about changing the cache.
+        //
+        Boolean value = (Boolean) cache.get(localeName);
+
+        if (value != null)
+            return value.booleanValue();
+
+        //
+        // Try "language_country_variant", then "language_country",
+        // then finally "language" ... assuming the longest locale name
+        // is passed.  If not, we'll try fewer options.
+        //
+        ClassLoader loader = null;
+
+        for (; ;) {
+            String name = bundleName + "_" + localeName;
+
+            // look up classes ...
+            try {
+                Class.forName(name);
+                cache.put(localeName, Boolean.TRUE);
+                return true;
+            } catch (Exception e) {
+            }
+
+            // ... then property files (only for ISO Latin/1 messages)
+            InputStream in;
+
+            if (loader == null)
+                loader = getClass().getClassLoader();
+
+            name = name.replace('.', '/');
+            name = name + ".properties";
+            if (loader == null)
+                in = ClassLoader.getSystemResourceAsStream(name);
+            else
+                in = loader.getResourceAsStream(name);
+            if (in != null) {
+                cache.put(localeName, Boolean.TRUE);
+                return true;
+            }
+
+            int index = localeName.indexOf('_');
+
+            if (index > 0)
+                localeName = localeName.substring(0, index);
+            else
+                break;
+        }
+
+        //
+        // If we got this far, we failed.  Remember for later.
+        //
+        cache.put(localeName, Boolean.FALSE);
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/Resolver.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/Resolver.java
new file mode 100644
index 0000000..848d5d7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/Resolver.java
@@ -0,0 +1,447 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.net.URL;
+import java.net.URLConnection;
+import java.util.Hashtable;
+
+/**
+ * This entity resolver class provides a number of utilities which can help
+ * managment of external parsed entities in XML.  These are commonly used
+ * to hold markup declarations that are to be used as part of a Document
+ * Type Declaration (DTD), or to hold text marked up with XML.
+ * <p/>
+ * <P> Features include: <UL>
+ * <p/>
+ * <LI> Static factory methods are provided for constructing SAX InputSource
+ * objects from Files, URLs, or MIME objects.  This eliminates a class of
+ * error-prone coding in applications.
+ * <p/>
+ * <LI> Character encodings for XML documents are correctly supported: <UL>
+ * <p/>
+ * <LI> The encodings defined in the RFCs for MIME content types
+ * (2046 for general MIME, and 2376 for XML in particular), are
+ * supported, handling <em>charset=...</em> attributes and accepting
+ * content types which are known to be safe for use with XML;
+ * <p/>
+ * <LI> The character encoding autodetection algorithm identified
+ * in the XML specification is used, and leverages all of
+ * the JDK 1.1 (and later) character encoding support.
+ * <p/>
+ * <LI> The use of MIME typing may optionally be disabled, forcing the
+ * use of autodetection, to support web servers which don't correctly
+ * report MIME types for XML.  For example, they may report text that
+ * is encoded in EUC-JP as being US-ASCII text, leading to fatal
+ * errors during parsing.
+ * <p/>
+ * <LI> The InputSource objects returned by this class always
+ * have a <code>java.io.Reader</code> available as the "character
+ * stream" property.
+ * <p/>
+ * </UL>
+ * <p/>
+ * <LI> Catalog entries can map public identifiers to Java resources or
+ * to local URLs.  These are used to reduce network dependencies and loads,
+ * and will often be used for external DTD components.  For example, packages
+ * shipping DTD files as resources in JAR files can eliminate network traffic
+ * when accessing them, and sites may provide local caches of common DTDs.
+ * Note that no particular catalog syntax is supported by this class, only
+ * the notion of a set of entries.
+ * <p/>
+ * </UL>
+ * <p/>
+ * <P> Subclasses can perform tasks such as supporting new URI schemes for
+ * URIs which are not URLs, such as URNs (see RFC 2396) or for accessing
+ * MIME entities which are part of a <em>multipart/related</em> group
+ * (see RFC 2387).  They may also be used to support particular catalog
+ * syntaxes, such as the <a href="http://www.oasis-open.org/html/a401.htm">
+ * SGML/Open Catalog (SOCAT)</a> which supports the SGML notion of "Formal
+ * Public Identifiers (FPIs).
+ *
+ * @author David Brownell
+ * @author Janet Koenig
+ */
+public class Resolver implements EntityResolver {
+    private boolean ignoringMIME;
+
+    // table mapping public IDs to (local) URIs
+    private Hashtable id2uri;
+
+    // tables mapping public IDs to resources and classloaders
+    private Hashtable id2resource;
+    private Hashtable id2loader;
+
+    //
+    // table of MIME content types (less attributes!) known
+    // to be mostly "OK" to use with XML MIME entities.  the
+    // idea is to rule out obvious braindamage ("image/jpg")
+    // not the subtle stuff ("text/html") that might actually
+    // be (or become) safe.
+    //
+    private static final String types [] = {
+        "application/xml",
+        "text/xml",
+        "text/plain",
+        "text/html", // commonly mis-inferred
+        "application/x-netcdf", // this is often illegal XML
+        "content/unknown"
+    };
+
+    /**
+     * Constructs a resolver.
+     */
+    public Resolver() {
+    }
+
+    /**
+     * Returns an input source, using the MIME type information and URL
+     * scheme to statically determine the correct character encoding if
+     * possible and otherwise autodetecting it.  MIME carefully specifies
+     * the character encoding defaults, and how attributes of the content
+     * type can change it.  XML further specifies two mandatory encodings
+     * (UTF-8 and UTF-16), and includes an XML declaration which can be
+     * used to internally label most documents encoded using US-ASCII
+     * supersets (such as Shift_JIS, EUC-JP, ISO-2022-*, ISO-8859-*, and
+     * more).
+     * <p/>
+     * <P> This method can be used to access XML documents which do not
+     * have URIs (such as servlet input streams, or most JavaMail message
+     * entities) and to support access methods such as HTTP POST or PUT.
+     * (URLs normally return content using the GET method.)
+     * <p/>
+     * <P> <em> The caller should set the system ID in order for relative URIs
+     * found in this document to be interpreted correctly.</em> In some cases,
+     * a custom resolver will need to be used; for example, documents
+     * may be grouped in a single MIME "multipart/related" bundle, and
+     * relative URLs would refer to other documents in that bundle.
+     *
+     * @param contentType The MIME content type for the source for which
+     *                    an InputSource is desired, such as <em>text/xml;charset=utf-8</em>.
+     * @param stream      The input byte stream for the input source.
+     * @param checkType   If true, this verifies that the content type is known
+     *                    to support XML documents, such as <em>application/xml</em>.
+     * @param scheme      Unless this is "file", unspecified MIME types
+     *                    default to US-ASCII.  Files are always autodetected since most
+     *                    file systems discard character encoding information.
+     */
+    public static InputSource createInputSource(String contentType,
+                                                InputStream stream,
+                                                boolean checkType,
+                                                String scheme) throws IOException {
+        InputSource retval;
+        String charset = null;
+
+        if (contentType != null) {
+            int index;
+
+            contentType = contentType.toLowerCase();
+            index = contentType.indexOf(';');
+            if (index != -1) {
+                String attributes;
+
+                attributes = contentType.substring(index + 1);
+                contentType = contentType.substring(0, index);
+
+                // use "charset=..." if it's available
+                index = attributes.indexOf("charset");
+                if (index != -1) {
+                    attributes = attributes.substring(index + 7);
+                    // strip out subsequent attributes
+                    if ((index = attributes.indexOf(';')) != -1)
+                        attributes = attributes.substring(0, index);
+                    // find start of value
+                    if ((index = attributes.indexOf('=')) != -1) {
+                        attributes = attributes.substring(index + 1);
+                        // strip out rfc822 comments
+                        if ((index = attributes.indexOf('(')) != -1)
+                            attributes = attributes.substring(0, index);
+                        // double quotes are optional
+                        if ((index = attributes.indexOf('"')) != -1) {
+                            attributes = attributes.substring(index + 1);
+                            attributes = attributes.substring(0,
+                                    attributes.indexOf('"'));
+                        }
+                        charset = attributes.trim();
+                        // XXX "\;", "\)" etc were mishandled above
+                    }
+                }
+            }
+
+            //
+            // Check MIME type.
+            //
+            if (checkType) {
+                boolean isOK = false;
+                for (int i = 0; i < types.length; i++)
+                    if (types[i].equals(contentType)) {
+                        isOK = true;
+                        break;
+                    }
+                if (!isOK)
+                    throw new IOException("Not XML: " + contentType);
+            }
+
+            //
+            // "text/*" MIME types have hard-wired character set
+            // defaults, as specified in the RFCs.  For XML, we
+            // ignore the system "file.encoding" property since
+            // autodetection is more correct.
+            //
+            if (charset == null) {
+                contentType = contentType.trim();
+                if (contentType.startsWith("text/")) {
+                    if (!"file".equalsIgnoreCase(scheme))
+                        charset = "US-ASCII";
+                }
+                // "application/*" has no default
+            }
+        }
+
+        retval = new InputSource(XmlReader.createReader(stream, charset));
+        retval.setByteStream(stream);
+        retval.setEncoding(charset);
+        return retval;
+    }
+
+
+    /**
+     * Creates an input source from a given URI.
+     *
+     * @param uri       the URI (system ID) for the entity
+     * @param checkType if true, the MIME content type for the entity
+     *                  is checked for document type and character set encoding.
+     */
+    static public InputSource createInputSource(URL uri, boolean checkType)
+            throws IOException {
+
+        URLConnection conn = uri.openConnection();
+        InputSource retval;
+
+        if (checkType) {
+            String contentType = conn.getContentType();
+            retval = createInputSource(contentType, conn.getInputStream(),
+                    false, uri.getProtocol());
+        } else {
+            retval = new InputSource(XmlReader.createReader(conn.getInputStream()));
+        }
+        retval.setSystemId(conn.getURL().toString());
+        return retval;
+    }
+
+
+    /**
+     * Creates an input source from a given file, autodetecting
+     * the character encoding.
+     */
+    static public InputSource createInputSource(File file)
+            throws IOException {
+        InputSource retval;
+        String path;
+
+        retval = new InputSource(XmlReader.createReader(new FileInputStream(file)));
+
+        // On JDK 1.2 and later, simplify this:
+        //    "path = file.toURL ().toString ()".
+        path = file.getAbsolutePath();
+        if (File.separatorChar != '/')
+            path = path.replace(File.separatorChar, '/');
+        if (!path.startsWith("/"))
+            path = "/" + path;
+        if (!path.endsWith("/") && file.isDirectory())
+            path = path + "/";
+
+        retval.setSystemId("file:" + path);
+        return retval;
+    }
+
+
+    /**
+     * <b>SAX:</b>
+     * Resolve the given entity into an input source.  If the name can't
+     * be mapped to a preferred form of the entity, the URI is used.  To
+     * resolve the entity, first a local catalog mapping names to URIs is
+     * consulted.  If no mapping is found there, a catalog mapping names
+     * to java resources is consulted.  Finally, if neither mapping found
+     * a copy of the entity, the specified URI is used.
+     * <p/>
+     * <P> When a URI is used, <a href="#createInputSource">
+     * createInputSource</a> is used to correctly deduce the character
+     * encoding used by this entity.  No MIME type checking is done.
+     *
+     * @param name Used to find alternate copies of the entity, when
+     *             this value is non-null; this is the XML "public ID".
+     * @param uri  Used when no alternate copy of the entity is found;
+     *             this is the XML "system ID", normally a URI.
+     */
+    public InputSource resolveEntity(String name, String uri)
+            throws IOException {
+        InputSource retval;
+        String mappedURI = name2uri(name);
+        InputStream stream;
+
+        // prefer explicit URI mappings, then bundled resources...
+        if (mappedURI == null && (stream = mapResource(name)) != null) {
+            uri = "java:resource:" + (String) id2resource.get(name);
+            retval = new InputSource(XmlReader.createReader(stream));
+
+            // ...and treat all URIs the same (as URLs for now).
+        } else {
+            URL url;
+            URLConnection conn;
+
+            if (mappedURI != null)
+                uri = mappedURI;
+            else if (uri == null)
+                return null;
+
+            url = new URL(uri);
+            conn = url.openConnection();
+            uri = conn.getURL().toString();
+            // System.out.println ("++ URI: " + url);
+            if (ignoringMIME)
+                retval = new InputSource(XmlReader.createReader(conn.getInputStream()));
+            else {
+                String contentType = conn.getContentType();
+                retval = createInputSource(contentType,
+                        conn.getInputStream(),
+                        false, url.getProtocol());
+            }
+        }
+        retval.setSystemId(uri);
+        retval.setPublicId(name);
+        return retval;
+    }
+
+
+    /**
+     * Returns true if this resolver is ignoring MIME types in the documents
+     * it returns, to work around bugs in how servers have reported the
+     * documents' MIME types.
+     */
+    public boolean isIgnoringMIME() {
+        return ignoringMIME;
+    }
+
+    /**
+     * Tells the resolver whether to ignore MIME types in the documents it
+     * retrieves.  Many web servers incorrectly assign text documents a
+     * default character encoding, even when that is incorrect.  For example,
+     * all HTTP text documents default to use ISO-8859-1 (used for Western
+     * European languages), and other MIME sources default text documents
+     * to use US-ASCII (a seven bit encoding).  For XML documents which
+     * include text encoding declarations (as most should do), these server
+     * bugs can be worked around by ignoring the MIME type entirely.
+     */
+    public void setIgnoringMIME(boolean value) {
+        ignoringMIME = value;
+    }
+
+
+    // maps the public ID to an alternate URI, if one is registered
+    private String name2uri(String publicId) {
+        if (publicId == null || id2uri == null)
+            return null;
+        return (String) id2uri.get(publicId);
+    }
+
+
+    /**
+     * Registers the given public ID as corresponding to a particular
+     * URI, typically a local copy.  This URI will be used in preference
+     * to ones provided as system IDs in XML entity declarations.  This
+     * mechanism would most typically be used for Document Type Definitions
+     * (DTDs), where the public IDs are formally managed and versioned.
+     *
+     * @param publicId The managed public ID being mapped
+     * @param uri      The URI of the preferred copy of that entity
+     */
+    public void registerCatalogEntry(String publicId,
+                                     String uri) {
+        if (id2uri == null)
+            id2uri = new Hashtable(17);
+        id2uri.put(publicId, uri);
+    }
+
+
+    // return the resource as a stream
+    private InputStream mapResource(String publicId) {
+        // System.out.println ("++ PUBLIC: " + publicId);
+        if (publicId == null || id2resource == null)
+            return null;
+
+        String resourceName = (String) id2resource.get(publicId);
+        ClassLoader loader = null;
+
+        if (resourceName == null)
+            return null;
+        // System.out.println ("++ Resource: " + resourceName);
+
+        if (id2loader != null)
+            loader = (ClassLoader) id2loader.get(publicId);
+        // System.out.println ("++ Loader: " + loader);
+        if (loader == null)
+            return ClassLoader.getSystemResourceAsStream(resourceName);
+        return loader.getResourceAsStream(resourceName);
+    }
+
+    /**
+     * Registers a given public ID as corresponding to a particular Java
+     * resource in a given class loader, typically distributed with a
+     * software package.  This resource will be preferred over system IDs
+     * included in XML documents.  This mechanism should most typically be
+     * used for Document Type Definitions (DTDs), where the public IDs are
+     * formally managed and versioned.
+     * <p/>
+     * <P> If a mapping to a URI has been provided, that mapping takes
+     * precedence over this one.
+     *
+     * @param publicId     The managed public ID being mapped
+     * @param resourceName The name of the Java resource
+     * @param loader       The class loader holding the resource, or null if
+     *                     it is a system resource.
+     */
+    public void registerCatalogEntry(String publicId,
+                                     String resourceName,
+                                     ClassLoader loader) {
+        if (id2resource == null)
+            id2resource = new Hashtable(17);
+        id2resource.put(publicId, resourceName);
+
+        if (loader != null) {
+            if (id2loader == null)
+                id2loader = new Hashtable(17);
+            id2loader.put(publicId, loader);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/SimpleHashtable.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/SimpleHashtable.java
new file mode 100644
index 0000000..fa5e1e8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/SimpleHashtable.java
@@ -0,0 +1,284 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import java.util.Enumeration;
+
+
+// This could be replaced by Collections class unless we want
+// to be able to run on JDK 1.1
+
+
+/**
+ * This class implements a special purpose hashtable.  It works like a
+ * normal <code>java.util.Hashtable</code> except that: <OL>
+ * <p/>
+ * <LI> Keys to "get" are strings which are known to be interned,
+ * so that "==" is used instead of "String.equals".  (Interning
+ * could be document-relative instead of global.)
+ * <p/>
+ * <LI> It's not synchronized, since it's to be used only by
+ * one thread at a time.
+ * <p/>
+ * <LI> The keys () enumerator allocates no memory, with live
+ * updates to the data disallowed.
+ * <p/>
+ * <LI> It's got fewer bells and whistles:  fixed threshold and
+ * load factor, no JDK 1.2 collection support, only keys can be
+ * enumerated, things can't be removed, simpler inheritance; more.
+ * <p/>
+ * </OL>
+ * <p/>
+ * <P> The overall result is that it's less expensive to use these in
+ * performance-critical locations, in terms both of CPU and memory,
+ * than <code>java.util.Hashtable</code> instances.  In this package
+ * it makes a significant difference when normalizing attributes,
+ * which is done for each start-element construct.
+ *
+ */
+final class SimpleHashtable implements Enumeration {
+    // entries ...
+    private Entry table[];
+
+    // currently enumerated key
+    private Entry current = null;
+    private int currentBucket = 0;
+
+    private int count;
+    private int threshold;
+
+    private static final float loadFactor = 0.75f;
+
+
+    /**
+     * Constructs a new, empty hashtable with the specified initial
+     * capacity.
+     *
+     * @param initialCapacity the initial capacity of the hashtable.
+     */
+    public SimpleHashtable(int initialCapacity) {
+        if (initialCapacity < 0)
+            throw new IllegalArgumentException("Illegal Capacity: " +
+                    initialCapacity);
+        if (initialCapacity == 0)
+            initialCapacity = 1;
+        table = new Entry[initialCapacity];
+        threshold = (int) (initialCapacity * loadFactor);
+    }
+
+    /**
+     * Constructs a new, empty hashtable with a default capacity.
+     */
+    public SimpleHashtable() {
+        this(11);
+    }
+
+    /**
+     */
+    public void clear() {
+        count = 0;
+        currentBucket = 0;
+        current = null;
+        for (int i = 0; i < table.length; i++)
+            table[i] = null;
+    }
+
+    /**
+     * Returns the number of keys in this hashtable.
+     *
+     * @return the number of keys in this hashtable.
+     */
+    public int size() {
+        return count;
+    }
+
+    /**
+     * Returns an enumeration of the keys in this hashtable.
+     *
+     * @return an enumeration of the keys in this hashtable.
+     * @see Enumeration
+     */
+    public Enumeration keys() {
+        currentBucket = 0;
+        current = null;
+        return this;
+    }
+
+    /**
+     * Used to view this as an enumeration; returns true if there
+     * are more keys to be enumerated.
+     */
+    public boolean hasMoreElements() {
+        if (current != null)
+            return true;
+        while (currentBucket < table.length) {
+            current = table[currentBucket++];
+            if (current != null)
+                return true;
+        }
+        return false;
+    }
+
+    /**
+     * Used to view this as an enumeration; returns the next key
+     * in the enumeration.
+     */
+    public Object nextElement() {
+        Object retval;
+
+        if (current == null)
+            throw new IllegalStateException();
+        retval = current.key;
+        current = current.next;
+        return retval;
+    }
+
+
+    /**
+     * Returns the value to which the specified key is mapped in this hashtable.
+     */
+    public Object get(String key) {
+        Entry tab[] = table;
+        int hash = key.hashCode();
+        int index = (hash & 0x7FFFFFFF) % tab.length;
+        for (Entry e = tab[index]; e != null; e = e.next) {
+            if ((e.hash == hash) && (e.key == key))
+                return e.value;
+        }
+        return null;
+    }
+
+    /**
+     * Returns the value to which the specified key is mapped in this
+     * hashtable ... the key isn't necessarily interned, though.
+     */
+    public Object getNonInterned(String key) {
+        Entry tab[] = table;
+        int hash = key.hashCode();
+        int index = (hash & 0x7FFFFFFF) % tab.length;
+        for (Entry e = tab[index]; e != null; e = e.next) {
+            if ((e.hash == hash) && e.key.equals(key))
+                return e.value;
+        }
+        return null;
+    }
+
+    /**
+     * Increases the capacity of and internally reorganizes this
+     * hashtable, in order to accommodate and access its entries more
+     * efficiently.  This method is called automatically when the
+     * number of keys in the hashtable exceeds this hashtable's capacity
+     * and load factor.
+     */
+    private void rehash() {
+        int oldCapacity = table.length;
+        Entry oldMap[] = table;
+
+        int newCapacity = oldCapacity * 2 + 1;
+        Entry newMap[] = new Entry[newCapacity];
+
+        threshold = (int) (newCapacity * loadFactor);
+        table = newMap;
+
+        /*
+        System.out.println("rehash old=" + oldCapacity
+            + ", new=" + newCapacity
+            + ", thresh=" + threshold
+            + ", count=" + count);
+        */
+
+        for (int i = oldCapacity; i-- > 0;) {
+            for (Entry old = oldMap[i]; old != null;) {
+                Entry e = old;
+                old = old.next;
+
+                int index = (e.hash & 0x7FFFFFFF) % newCapacity;
+                e.next = newMap[index];
+                newMap[index] = e;
+            }
+        }
+    }
+
+    /**
+     * Maps the specified <code>key</code> to the specified
+     * <code>value</code> in this hashtable. Neither the key nor the
+     * value can be <code>null</code>.
+     * <p/>
+     * <P>The value can be retrieved by calling the <code>get</code> method
+     * with a key that is equal to the original key.
+     */
+    public Object put(Object key, Object value) {
+        // Make sure the value is not null
+        if (value == null) {
+            throw new NullPointerException();
+        }
+
+        // Makes sure the key is not already in the hashtable.
+        Entry tab[] = table;
+        int hash = key.hashCode();
+        int index = (hash & 0x7FFFFFFF) % tab.length;
+        for (Entry e = tab[index]; e != null; e = e.next) {
+            // if ((e.hash == hash) && e.key.equals(key)) {
+            if ((e.hash == hash) && (e.key == key)) {
+                Object old = e.value;
+                e.value = value;
+                return old;
+            }
+        }
+
+        if (count >= threshold) {
+            // Rehash the table if the threshold is exceeded
+            rehash();
+
+            tab = table;
+            index = (hash & 0x7FFFFFFF) % tab.length;
+        }
+
+        // Creates the new entry.
+        Entry e = new Entry(hash, key, value, tab[index]);
+        tab[index] = e;
+        count++;
+        return null;
+    }
+
+
+    /**
+     * Hashtable collision list.
+     */
+    private static class Entry {
+        int hash;
+        Object key;
+        Object value;
+        Entry next;
+
+        protected Entry(int hash, Object key, Object value, Entry next) {
+            this.hash = hash;
+            this.key = key;
+            this.value = value;
+            this.next = next;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlChars.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlChars.java
new file mode 100644
index 0000000..227cecd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlChars.java
@@ -0,0 +1,386 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+
+/**
+ * Methods in this class are used to determine whether characters may
+ * appear in certain roles in XML documents.  Such methods are used
+ * both to parse and to create such documents.
+ *
+ * @author David Brownell
+ */
+public class XmlChars {
+    // can't construct instances
+    private XmlChars() {
+    }
+
+    /**
+     * Returns true if the argument, a UCS-4 character code, is valid in
+     * XML documents.  Unicode characters fit into the low sixteen
+     * bits of a UCS-4 character, and pairs of Unicode <em>surrogate
+     * characters</em> can be combined to encode UCS-4 characters in
+     * documents containing only Unicode.  (The <code>char</code> datatype
+     * in the Java Programming Language represents Unicode characters,
+     * including unpaired surrogates.)
+     * <p/>
+     * <P> In XML, UCS-4 characters can also be encoded by the use of
+     * <em>character references</em> such as <b>&amp;#x12345678;</b>, which
+     * happens to refer to a character that is disallowed in XML documents.
+     * UCS-4 characters allowed in XML documents can be expressed with
+     * one or two Unicode characters.
+     *
+     * @param ucs4char The 32-bit UCS-4 character being tested.
+     */
+    static public boolean isChar(int ucs4char) {
+        // [2] Char ::= #x0009 | #x000A | #x000D
+        //            | [#x0020-#xD7FF]
+        //    ... surrogates excluded!
+        //            | [#xE000-#xFFFD]
+        //             | [#x10000-#x10ffff]
+        return ((ucs4char >= 0x0020 && ucs4char <= 0xD7FF)
+                || ucs4char == 0x000A || ucs4char == 0x0009
+                || ucs4char == 0x000D
+                || (ucs4char >= 0xE000 && ucs4char <= 0xFFFD)
+                || (ucs4char >= 0x10000 && ucs4char <= 0x10ffff));
+    }
+
+    /**
+     * Returns true if the character is allowed to be a non-initial
+     * character in names according to the XML recommendation.
+     *
+     * @see #isNCNameChar(char)
+     * @see #isLetter(char)
+     */
+    public static boolean isNameChar(char c) {
+        // [4] NameChar ::= Letter | Digit | '.' | '_' | ':'
+        //            | CombiningChar | Extender
+
+        if (isLetter2(c))
+            return true;
+        else if (c == '>')
+            return false;
+        else if (c == '.' || c == '-' || c == '_' || c == ':'
+                || isExtender(c))
+            return true;
+        else
+            return false;
+    }
+
+    /**
+     * Returns true if the character is allowed to be a non-initial
+     * character in unscoped names according to the rules of the XML
+     * Namespaces proposed recommendation.  Except for precluding
+     * the colon (used to separate names from their scopes) these
+     * characters are just as allowed by the XML recommendation.
+     *
+     * @see #isNameChar(char)
+     * @see #isLetter(char)
+     */
+    public static boolean isNCNameChar(char c) {
+        // [NC 5] NCNameChar ::= Letter | Digit | '.' | '_'
+        //            | CombiningChar | Extender
+        return c != ':' && isNameChar(c);
+    }
+
+    /**
+     * Returns true if the character is allowed where XML supports
+     * whitespace characters, false otherwise.
+     */
+    public static boolean isSpace(char c) {
+        return c == ' ' || c == '\t' || c == '\n' || c == '\r';
+    }
+
+
+    /*
+     * NOTE:  java.lang.Character.getType() values are:
+     *
+     * UNASSIGNED                    = 0,
+     *
+     * UPPERCASE_LETTER            = 1,    // Lu
+     * LOWERCASE_LETTER            = 2,    // Ll
+     * TITLECASE_LETTER            = 3,    // Lt
+     * MODIFIER_LETTER             = 4,    // Lm
+     * OTHER_LETTER                = 5,    // Lo
+     * NON_SPACING_MARK            = 6,    // Mn
+     * ENCLOSING_MARK              = 7,    // Me
+     * COMBINING_SPACING_MARK      = 8,    // Mc
+     * DECIMAL_DIGIT_NUMBER        = 9,    // Nd
+     * LETTER_NUMBER               = 10,   // Nl
+     * OTHER_NUMBER                = 11,   // No
+     * SPACE_SEPARATOR             = 12,   // Zs
+     * LINE_SEPARATOR              = 13,   // Zl
+     * PARAGRAPH_SEPARATOR         = 14,   // Zp
+     * CONTROL                     = 15,   // Cc
+     * FORMAT                      = 16,   // Cf
+     *                         // 17 reserved for proposed Ci category
+     * PRIVATE_USE                 = 18,   // Co
+     * SURROGATE                   = 19,   // Cs
+     * DASH_PUNCTUATION            = 20,   // Pd
+     * START_PUNCTUATION           = 21,   // Ps
+     * END_PUNCTUATION             = 22,   // Pe
+     * CONNECTOR_PUNCTUATION       = 23,   // Pc
+     * OTHER_PUNCTUATION           = 24,   // Po
+     * MATH_SYMBOL                 = 25,   // Sm
+     * CURRENCY_SYMBOL             = 26,   // Sc
+     * MODIFIER_SYMBOL             = 27,   // Sk
+     * OTHER_SYMBOL                = 28;   // So
+     */
+
+    /**
+     * Returns true if the character is an XML "letter".  XML Names must
+     * start with Letters or a few other characters, but other characters
+     * in names must only satisfy the <em>isNameChar</em> predicate.
+     *
+     * @see #isNameChar(char)
+     * @see #isNCNameChar(char)
+     */
+    public static boolean isLetter(char c) {
+        // [84] Letter ::= BaseChar | Ideographic
+        // [85] BaseChar ::= ... too much to repeat
+        // [86] Ideographic ::= ... too much to repeat
+
+        //
+        // Optimize the typical case.
+        //
+        if (c >= 'a' && c <= 'z')
+            return true;
+        if (c == '/')
+            return false;
+        if (c >= 'A' && c <= 'Z')
+            return true;
+
+        //
+        // Since the tables are too ridiculous to use in code,
+        // we're using the footnotes here to drive this test.
+        //
+        switch (Character.getType(c)) {
+        // app. B footnote says these are 'name start'
+        // chars' ...
+        case Character.LOWERCASE_LETTER:        // Ll
+        case Character.UPPERCASE_LETTER:        // Lu
+        case Character.OTHER_LETTER:            // Lo
+        case Character.TITLECASE_LETTER:        // Lt
+        case Character.LETTER_NUMBER:            // Nl
+
+            // OK, here we just have some exceptions to check...
+            return !isCompatibilityChar(c)
+                    // per "5.14 of Unicode", rule out some combiners
+                    && !(c >= 0x20dd && c <= 0x20e0);
+
+        default:
+            // check for some exceptions:  these are "alphabetic"
+            return ((c >= 0x02bb && c <= 0x02c1)
+                    || c == 0x0559 || c == 0x06e5 || c == 0x06e6);
+        }
+    }
+
+    //
+    // XML 1.0 discourages "compatibility" characters in names; these
+    // were defined to permit passing through some information stored in
+    // older non-Unicode character sets.  These always have alternative
+    // representations in Unicode, e.g. using combining chars.
+    //
+    private static boolean isCompatibilityChar(char c) {
+        // the numerous comparisions here seem unavoidable,
+        // but the switch can reduce the number which must
+        // actually be executed.
+
+        switch ((c >> 8) & 0x0ff) {
+        case 0x00:
+            // ISO Latin/1 has a few compatibility characters
+            return c == 0x00aa || c == 0x00b5 || c == 0x00ba;
+
+        case 0x01:
+            // as do Latin Extended A and (parts of) B
+            return (c >= 0x0132 && c <= 0x0133)
+                    || (c >= 0x013f && c <= 0x0140)
+                    || c == 0x0149
+                    || c == 0x017f
+                    || (c >= 0x01c4 && c <= 0x01cc)
+                    || (c >= 0x01f1 && c <= 0x01f3);
+
+        case 0x02:
+            // some spacing modifiers
+            return (c >= 0x02b0 && c <= 0x02b8)
+                    || (c >= 0x02e0 && c <= 0x02e4);
+
+        case 0x03:
+            return c == 0x037a;            // Greek
+
+        case 0x05:
+            return c == 0x0587;            // Armenian
+
+        case 0x0e:
+            return c >= 0x0edc && c <= 0x0edd;    // Laotian
+
+        case 0x11:
+            // big chunks of Hangul Jamo are all "compatibility"
+            return c == 0x1101
+                    || c == 0x1104
+                    || c == 0x1108
+                    || c == 0x110a
+                    || c == 0x110d
+                    || (c >= 0x1113 && c <= 0x113b)
+                    || c == 0x113d
+                    || c == 0x113f
+                    || (c >= 0x1141 && c <= 0x114b)
+                    || c == 0x114d
+                    || c == 0x114f
+                    || (c >= 0x1151 && c <= 0x1153)
+                    || (c >= 0x1156 && c <= 0x1158)
+                    || c == 0x1162
+                    || c == 0x1164
+                    || c == 0x1166
+                    || c == 0x1168
+                    || (c >= 0x116a && c <= 0x116c)
+                    || (c >= 0x116f && c <= 0x1171)
+                    || c == 0x1174
+                    || (c >= 0x1176 && c <= 0x119d)
+                    || (c >= 0x119f && c <= 0x11a2)
+                    || (c >= 0x11a9 && c <= 0x11aa)
+                    || (c >= 0x11ac && c <= 0x11ad)
+                    || (c >= 0x11b0 && c <= 0x11b6)
+                    || c == 0x11b9
+                    || c == 0x11bb
+                    || (c >= 0x11c3 && c <= 0x11ea)
+                    || (c >= 0x11ec && c <= 0x11ef)
+                    || (c >= 0x11f1 && c <= 0x11f8)
+                    ;
+
+        case 0x20:
+            return c == 0x207f;            // superscript
+
+        case 0x21:
+            return
+                    // various letterlike symbols
+                    c == 0x2102
+                    || c == 0x2107
+                    || (c >= 0x210a && c <= 0x2113)
+                    || c == 0x2115
+                    || (c >= 0x2118 && c <= 0x211d)
+                    || c == 0x2124
+                    || c == 0x2128
+                    || (c >= 0x212c && c <= 0x212d)
+                    || (c >= 0x212f && c <= 0x2138)
+
+                    // most Roman numerals (less 1K, 5K, 10K)
+                    || (c >= 0x2160 && c <= 0x217f)
+                    ;
+
+        case 0x30:
+            // some Hiragana
+            return c >= 0x309b && c <= 0x309c;
+
+        case 0x31:
+            // all Hangul Compatibility Jamo
+            return c >= 0x3131 && c <= 0x318e;
+
+        case 0xf9:
+        case 0xfa:
+        case 0xfb:
+        case 0xfc:
+        case 0xfd:
+        case 0xfe:
+        case 0xff:
+            // the whole "compatibility" area is for that purpose!
+            return true;
+
+        default:
+            // most of Unicode isn't flagged as being for compatibility
+            return false;
+        }
+    }
+
+    // guts of isNameChar/isNCNameChar
+    private static boolean isLetter2(char c) {
+        // [84] Letter ::= BaseChar | Ideographic
+        // [85] BaseChar ::= ... too much to repeat
+        // [86] Ideographic ::= ... too much to repeat
+        // [87] CombiningChar ::= ... too much to repeat
+
+        //
+        // Optimize the typical case.
+        //
+        if (c >= 'a' && c <= 'z')
+            return true;
+        if (c == '>')
+            return false;
+        if (c >= 'A' && c <= 'Z')
+            return true;
+
+        //
+        // Since the tables are too ridiculous to use in code,
+        // we're using the footnotes here to drive this test.
+        //
+        switch (Character.getType(c)) {
+        // app. B footnote says these are 'name start'
+        // chars' ...
+        case Character.LOWERCASE_LETTER:        // Ll
+        case Character.UPPERCASE_LETTER:        // Lu
+        case Character.OTHER_LETTER:            // Lo
+        case Character.TITLECASE_LETTER:        // Lt
+        case Character.LETTER_NUMBER:            // Nl
+            // ... and these are name characters 'other
+            // than name start characters'
+        case Character.COMBINING_SPACING_MARK:    // Mc
+        case Character.ENCLOSING_MARK:        // Me
+        case Character.NON_SPACING_MARK:        // Mn
+        case Character.MODIFIER_LETTER:        // Lm
+        case Character.DECIMAL_DIGIT_NUMBER:        // Nd
+
+            // OK, here we just have some exceptions to check...
+            return !isCompatibilityChar(c)
+                    // per "5.14 of Unicode", rule out some combiners
+                    && !(c >= 0x20dd && c <= 0x20e0);
+
+        default:
+            // added a character ...
+            return c == 0x0387;
+        }
+    }
+
+    private static boolean isDigit(char c) {
+        // [88] Digit ::= ...
+
+        //
+        // java.lang.Character.isDigit is correct from the XML point
+        // of view except that it allows "fullwidth" digits.
+        //
+        return Character.isDigit(c)
+                && !((c >= 0xff10) && (c <= 0xff19));
+    }
+
+    private static boolean isExtender(char c) {
+        // [89] Extender ::= ...
+        return c == 0x00b7 || c == 0x02d0 || c == 0x02d1 || c == 0x0387
+                || c == 0x0640 || c == 0x0e46 || c == 0x0ec6
+                || c == 0x3005 || (c >= 0x3031 && c <= 0x3035)
+                || (c >= 0x309d && c <= 0x309e)
+                || (c >= 0x30fc && c <= 0x30fe)
+                ;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlNames.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlNames.java
new file mode 100644
index 0000000..823d532
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlNames.java
@@ -0,0 +1,146 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+
+/**
+ * This class contains static methods used to determine whether identifiers
+ * may appear in certain roles in XML documents.  Such methods are used
+ * both to parse and to create such documents.
+ *
+ * @author David Brownell
+ */
+public class XmlNames {
+    private XmlNames() {
+    }
+
+
+    /**
+     * Returns true if the value is a legal XML name.
+     *
+     * @param value the string being tested
+     */
+    public static boolean isName(String value) {
+        if (value == null)
+            return false;
+
+        char c = value.charAt(0);
+        if (!XmlChars.isLetter(c) && c != '_' && c != ':')
+            return false;
+        for (int i = 1; i < value.length(); i++)
+            if (!XmlChars.isNameChar(value.charAt(i)))
+                return false;
+        return true;
+    }
+
+    /**
+     * Returns true if the value is a legal "unqualified" XML name, as
+     * defined in the XML Namespaces proposed recommendation.
+     * These are normal XML names, except that they may not contain
+     * a "colon" character.
+     *
+     * @param value the string being tested
+     */
+    public static boolean isUnqualifiedName(String value) {
+        if (value == null || value.length() == 0)
+            return false;
+
+        char c = value.charAt(0);
+        if (!XmlChars.isLetter(c) && c != '_')
+            return false;
+        for (int i = 1; i < value.length(); i++)
+            if (!XmlChars.isNCNameChar(value.charAt(i)))
+                return false;
+        return true;
+    }
+
+    /**
+     * Returns true if the value is a legal "qualified" XML name, as defined
+     * in the XML Namespaces proposed recommendation.  Qualified names are
+     * composed of an optional prefix (an unqualified name), followed by a
+     * colon, and a required "local part" (an unqualified name).  Prefixes are
+     * declared, and correspond to particular URIs which scope the "local
+     * part" of the name.  (This method cannot check whether the prefix of a
+     * name has been declared.)
+     *
+     * @param value the string being tested
+     */
+    public static boolean isQualifiedName(String value) {
+        if (value == null)
+            return false;
+
+        // [6] QName ::= (Prefix ':')? LocalPart
+        // [7] Prefix ::= NCName
+        // [8] LocalPart ::= NCName
+
+        int first = value.indexOf(':');
+
+        // no Prefix, only check LocalPart
+        if (first <= 0)
+            return isUnqualifiedName(value);
+
+        // Prefix exists, check everything
+
+        int last = value.lastIndexOf(':');
+        if (last != first)
+            return false;
+
+        return isUnqualifiedName(value.substring(0, first))
+                && isUnqualifiedName(value.substring(first + 1));
+    }
+
+    /**
+     * This method returns true if the identifier is a "name token"
+     * as defined in the XML specification.  Like names, these
+     * may only contain "name characters"; however, they do not need
+     * to have letters as their initial characters.  Attribute values
+     * defined to be of type NMTOKEN(S) must satisfy this predicate.
+     *
+     * @param token the string being tested
+     */
+    public static boolean isNmtoken(String token) {
+        int length = token.length();
+
+        for (int i = 0; i < length; i++)
+            if (!XmlChars.isNameChar(token.charAt(i)))
+                return false;
+        return true;
+    }
+
+
+    /**
+     * This method returns true if the identifier is a "name token" as
+     * defined by the XML Namespaces proposed recommendation.
+     * These are like XML "name tokens" but they may not contain the
+     * "colon" character.
+     *
+     * @param token the string being tested
+     * @see #isNmtoken
+     */
+    public static boolean isNCNmtoken(String token) {
+        return isNmtoken(token) && token.indexOf(':') < 0;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlReader.java b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlReader.java
new file mode 100644
index 0000000..8d11693
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/XmlReader.java
@@ -0,0 +1,783 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.dtdparser;
+
+import java.io.ByteArrayInputStream;
+import java.io.CharConversionException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.io.PushbackInputStream;
+import java.io.Reader;
+import java.util.Hashtable;
+
+
+// NOTE:  Add I18N support to this class when JDK gets the ability to
+// defer selection of locale for exception messages ... use the same
+// technique for both.
+
+
+/**
+ * This handles several XML-related tasks that normal java.io Readers
+ * don't support, inluding use of IETF standard encoding names and
+ * automatic detection of most XML encodings.  The former is needed
+ * for interoperability; the latter is needed to conform with the XML
+ * spec.  This class also optimizes reading some common encodings by
+ * providing low-overhead unsynchronized Reader support.
+ * <p/>
+ * <P> Note that the autodetection facility should be used only on
+ * data streams which have an unknown character encoding.  For example,
+ * it should never be used on MIME text/xml entities.
+ * <p/>
+ * <P> Note that XML processors are only required to support UTF-8 and
+ * UTF-16 character encodings.  Autodetection permits the underlying Java
+ * implementation to provide support for many other encodings, such as
+ * US-ASCII, ISO-8859-5, Shift_JIS, EUC-JP, and ISO-2022-JP.
+ *
+ * @author David Brownell
+ * @author Janet Koenig
+ */
+// package private
+final class XmlReader extends Reader {
+    private static final int MAXPUSHBACK = 512;
+
+    private Reader in;
+    private String assignedEncoding;
+    private boolean closed;
+
+    //
+    // This class always delegates I/O to a reader, which gets
+    // its data from the very beginning of the XML text.  It needs
+    // to use a pushback stream since (a) autodetection can read
+    // partial UTF-8 characters which need to be fully processed,
+    // (b) the "Unicode" readers swallow characters that they think
+    // are byte order marks, so tests fail if they don't see the
+    // real byte order mark.
+    //
+    // It's got do this efficiently:  character I/O is solidly on the
+    // critical path.  (So keep buffer length over 2 Kbytes to avoid
+    // excess buffering. Many URL handlers stuff a BufferedInputStream
+    // between here and the real data source, and larger buffers keep
+    // that from slowing you down.)
+    //
+
+    /**
+     * Constructs the reader from an input stream, autodetecting
+     * the encoding to use according to the heuristic specified
+     * in the XML 1.0 recommendation.
+     *
+     * @param in the input stream from which the reader is constructed
+     * @throws IOException on error, such as unrecognized encoding
+     */
+    public static Reader createReader(InputStream in) throws IOException {
+        return new XmlReader(in);
+    }
+
+    /**
+     * Creates a reader supporting the given encoding, mapping
+     * from standard encoding names to ones that understood by
+     * Java where necessary.
+     *
+     * @param in       the input stream from which the reader is constructed
+     * @param encoding the IETF standard name of the encoding to use;
+     *                 if null, autodetection is used.
+     * @throws IOException on error, including unrecognized encoding
+     */
+    public static Reader createReader(InputStream in, String encoding)
+            throws IOException {
+        if (encoding == null)
+            return new XmlReader(in);
+        if ("UTF-8".equalsIgnoreCase(encoding)
+                || "UTF8".equalsIgnoreCase(encoding))
+            return new Utf8Reader(in);
+        if ("US-ASCII".equalsIgnoreCase(encoding)
+                || "ASCII".equalsIgnoreCase(encoding))
+            return new AsciiReader(in);
+        if ("ISO-8859-1".equalsIgnoreCase(encoding)
+        // plus numerous aliases ...
+        )
+            return new Iso8859_1Reader(in);
+
+        //
+        // What we really want is an administerable resource mapping
+        // encoding names/aliases to classnames.  For example a property
+        // file resource, "readers/mapping.props", holding and a set
+        // of readers in that (sub)package... defaulting to this call
+        // only if no better choice is available.
+        //
+        return new InputStreamReader(in, std2java(encoding));
+    }
+
+    //
+    // JDK doesn't know all of the standard encoding names, and
+    // in particular none of the EBCDIC ones IANA defines (and
+    // which IBM encourages).
+    //
+    static private final Hashtable charsets = new Hashtable(31);
+
+    static {
+        charsets.put("UTF-16", "Unicode");
+        charsets.put("ISO-10646-UCS-2", "Unicode");
+
+        // NOTE: no support for ISO-10646-UCS-4 yet.
+
+        charsets.put("EBCDIC-CP-US", "cp037");
+        charsets.put("EBCDIC-CP-CA", "cp037");
+        charsets.put("EBCDIC-CP-NL", "cp037");
+        charsets.put("EBCDIC-CP-WT", "cp037");
+
+        charsets.put("EBCDIC-CP-DK", "cp277");
+        charsets.put("EBCDIC-CP-NO", "cp277");
+        charsets.put("EBCDIC-CP-FI", "cp278");
+        charsets.put("EBCDIC-CP-SE", "cp278");
+
+        charsets.put("EBCDIC-CP-IT", "cp280");
+        charsets.put("EBCDIC-CP-ES", "cp284");
+        charsets.put("EBCDIC-CP-GB", "cp285");
+        charsets.put("EBCDIC-CP-FR", "cp297");
+
+        charsets.put("EBCDIC-CP-AR1", "cp420");
+        charsets.put("EBCDIC-CP-HE", "cp424");
+        charsets.put("EBCDIC-CP-BE", "cp500");
+        charsets.put("EBCDIC-CP-CH", "cp500");
+
+        charsets.put("EBCDIC-CP-ROECE", "cp870");
+        charsets.put("EBCDIC-CP-YU", "cp870");
+        charsets.put("EBCDIC-CP-IS", "cp871");
+        charsets.put("EBCDIC-CP-AR2", "cp918");
+
+        // IANA also defines two that JDK 1.2 doesn't handle:
+        //    EBCDIC-CP-GR        --> CP423
+        //    EBCDIC-CP-TR        --> CP905
+    }
+
+    // returns an encoding name supported by JDK >= 1.1.6
+    // for some cases required by the XML spec
+    private static String std2java(String encoding) {
+        String temp = encoding.toUpperCase();
+        temp = (String) charsets.get(temp);
+        return temp != null ? temp : encoding;
+    }
+
+    /**
+     * Returns the standard name of the encoding in use
+     */
+    public String getEncoding() {
+        return assignedEncoding;
+    }
+
+    private XmlReader(InputStream stream) throws IOException {
+        super(stream);
+
+        PushbackInputStream pb;
+        byte buf [];
+        int len;
+
+        if (stream instanceof PushbackInputStream)
+            pb = (PushbackInputStream) stream;
+        else
+            pb = new PushbackInputStream(stream, MAXPUSHBACK);
+
+        //
+        // See if we can figure out the character encoding used
+        // in this file by peeking at the first few bytes.
+        //
+        buf = new byte[4];
+        len = pb.read(buf);
+        if (len > 0)
+            pb.unread(buf, 0, len);
+
+        if (len == 4)
+            switch (buf[0] & 0x0ff) {
+            case 0:
+                // 00 3c 00 3f == illegal UTF-16 big-endian
+                if (buf[1] == 0x3c && buf[2] == 0x00 && buf[3] == 0x3f) {
+                    setEncoding(pb, "UnicodeBig");
+                    return;
+                }
+                // else it's probably UCS-4
+                break;
+
+            case '<':      // 0x3c: the most common cases!
+                switch (buf[1] & 0x0ff) {
+                // First character is '<'; could be XML without
+                // an XML directive such as "<hello>", "<!-- ...",
+                // and so on.
+                default:
+                    break;
+
+                    // 3c 00 3f 00 == illegal UTF-16 little endian
+                case 0x00:
+                    if (buf[2] == 0x3f && buf[3] == 0x00) {
+                        setEncoding(pb, "UnicodeLittle");
+                        return;
+                    }
+                    // else probably UCS-4
+                    break;
+
+                    // 3c 3f 78 6d == ASCII and supersets '<?xm'
+                case '?':
+                    if (buf[2] != 'x' || buf[3] != 'm')
+                        break;
+                    //
+                    // One of several encodings could be used:
+                    // Shift-JIS, ASCII, UTF-8, ISO-8859-*, etc
+                    //
+                    useEncodingDecl(pb, "UTF8");
+                    return;
+                }
+                break;
+
+                // 4c 6f a7 94 ... some EBCDIC code page
+            case 0x4c:
+                if (buf[1] == 0x6f
+                        && (0x0ff & buf[2]) == 0x0a7
+                        && (0x0ff & buf[3]) == 0x094) {
+                    useEncodingDecl(pb, "CP037");
+                    return;
+                }
+                // whoops, treat as UTF-8
+                break;
+
+                // UTF-16 big-endian
+            case 0xfe:
+                if ((buf[1] & 0x0ff) != 0xff)
+                    break;
+                setEncoding(pb, "UTF-16");
+                return;
+
+                // UTF-16 little-endian
+            case 0xff:
+                if ((buf[1] & 0x0ff) != 0xfe)
+                    break;
+                setEncoding(pb, "UTF-16");
+                return;
+
+                // default ... no XML declaration
+            default:
+                break;
+            }
+
+        //
+        // If all else fails, assume XML without a declaration, and
+        // using UTF-8 encoding.
+        //
+        setEncoding(pb, "UTF-8");
+    }
+
+    /*
+     * Read the encoding decl on the stream, knowing that it should
+     * be readable using the specified encoding (basically, ASCII or
+     * EBCDIC).  The body of the document may use a wider range of
+     * characters than the XML/Text decl itself, so we switch to use
+     * the specified encoding as soon as we can.  (ASCII is a subset
+     * of UTF-8, ISO-8859-*, ISO-2022-JP, EUC-JP, and more; EBCDIC
+     * has a variety of "code pages" that have these characters as
+     * a common subset.)
+     */
+    private void useEncodingDecl(PushbackInputStream pb, String encoding)
+            throws IOException {
+        byte buffer [] = new byte[MAXPUSHBACK];
+        int len;
+        Reader r;
+        int c;
+
+        //
+        // Buffer up a bunch of input, and set up to read it in
+        // the specified encoding ... we can skip the first four
+        // bytes since we know that "<?xm" was read to determine
+        // what encoding to use!
+        //
+        len = pb.read(buffer, 0, buffer.length);
+        pb.unread(buffer, 0, len);
+        r = new InputStreamReader(new ByteArrayInputStream(buffer, 4, len),
+                encoding);
+
+        //
+        // Next must be "l" (and whitespace) else we conclude
+        // error and choose UTF-8.
+        //
+        if ((c = r.read()) != 'l') {
+            setEncoding(pb, "UTF-8");
+            return;
+        }
+
+        //
+        // Then, we'll skip any
+        //     S version="..."     [or single quotes]
+        // bit and get any subsequent
+        //     S encoding="..."     [or single quotes]
+        //
+        // We put an arbitrary size limit on how far we read; lots
+        // of space will break this algorithm.
+        //
+        StringBuffer buf = new StringBuffer();
+        StringBuffer keyBuf = null;
+        String key = null;
+        boolean sawEq = false;
+        char quoteChar = 0;
+        boolean sawQuestion = false;
+
+        XmlDecl:
+        for (int i = 0; i < MAXPUSHBACK - 5; ++i) {
+            if ((c = r.read()) == -1)
+                break;
+
+            // ignore whitespace before/between "key = 'value'"
+            if (c == ' ' || c == '\t' || c == '\n' || c == '\r')
+                continue;
+
+            // ... but require at least a little!
+            if (i == 0)
+                break;
+
+            // terminate the loop ASAP
+            if (c == '?')
+                sawQuestion = true;
+            else if (sawQuestion) {
+                if (c == '>')
+                    break;
+                sawQuestion = false;
+            }
+
+            // did we get the "key =" bit yet?
+            if (key == null || !sawEq) {
+                if (keyBuf == null) {
+                    if (Character.isWhitespace((char) c))
+                        continue;
+                    keyBuf = buf;
+                    buf.setLength(0);
+                    buf.append((char) c);
+                    sawEq = false;
+                } else if (Character.isWhitespace((char) c)) {
+                    key = keyBuf.toString();
+                } else if (c == '=') {
+                    if (key == null)
+                        key = keyBuf.toString();
+                    sawEq = true;
+                    keyBuf = null;
+                    quoteChar = 0;
+                } else
+                    keyBuf.append((char) c);
+                continue;
+            }
+
+            // space before quoted value
+            if (Character.isWhitespace((char) c))
+                continue;
+            if (c == '"' || c == '\'') {
+                if (quoteChar == 0) {
+                    quoteChar = (char) c;
+                    buf.setLength(0);
+                    continue;
+                } else if (c == quoteChar) {
+                    if ("encoding".equals(key)) {
+                        assignedEncoding = buf.toString();
+
+                        // [81] Encname ::= [A-Za-z] ([A-Za-z0-9._]|'-')*
+                        for (i = 0; i < assignedEncoding.length(); i++) {
+                            c = assignedEncoding.charAt(i);
+                            if ((c >= 'A' && c <= 'Z')
+                                    || (c >= 'a' && c <= 'z'))
+                                continue;
+                            if (i == 0)
+                                break XmlDecl;
+                            if (i > 0 && (c == '-'
+                                    || (c >= '0' && c <= '9')
+                                    || c == '.' || c == '_'))
+                                continue;
+                            // map illegal names to UTF-8 default
+                            break XmlDecl;
+                        }
+
+                        setEncoding(pb, assignedEncoding);
+                        return;
+
+                    } else {
+                        key = null;
+                        continue;
+                    }
+                }
+            }
+            buf.append((char) c);
+        }
+
+        setEncoding(pb, "UTF-8");
+    }
+
+    private void setEncoding(InputStream stream, String encoding)
+            throws IOException {
+        assignedEncoding = encoding;
+        in = createReader(stream, encoding);
+    }
+
+    /**
+     * Reads the number of characters read into the buffer, or -1 on EOF.
+     */
+    public int read(char buf [], int off, int len) throws IOException {
+        int val;
+
+        if (closed)
+            return -1;        // throw new IOException ("closed");
+        val = in.read(buf, off, len);
+        if (val == -1)
+            close();
+        return val;
+    }
+
+    /**
+     * Reads a single character.
+     */
+    public int read() throws IOException {
+        int val;
+
+        if (closed)
+            throw new IOException("closed");
+        val = in.read();
+        if (val == -1)
+            close();
+        return val;
+    }
+
+    /**
+     * Returns true iff the reader supports mark/reset.
+     */
+    public boolean markSupported() {
+        return in == null ? false : in.markSupported();
+    }
+
+    /**
+     * Sets a mark allowing a limited number of characters to
+     * be "peeked", by reading and then resetting.
+     *
+     * @param value how many characters may be "peeked".
+     */
+    public void mark(int value) throws IOException {
+        if (in != null) in.mark(value);
+    }
+
+    /**
+     * Resets the current position to the last marked position.
+     */
+    public void reset() throws IOException {
+        if (in != null) in.reset();
+    }
+
+    /**
+     * Skips a specified number of characters.
+     */
+    public long skip(long value) throws IOException {
+        return in == null ? 0 : in.skip(value);
+    }
+
+    /**
+     * Returns true iff input characters are known to be ready.
+     */
+    public boolean ready() throws IOException {
+        return in == null ? false : in.ready();
+    }
+
+    /**
+     * Closes the reader.
+     */
+    public void close() throws IOException {
+        if (closed)
+            return;
+        in.close();
+        in = null;
+        closed = true;
+    }
+
+    //
+    // Delegating to a converter module will always be slower than
+    // direct conversion.  Use a similar approach for any other
+    // readers that need to be particularly fast; only block I/O
+    // speed matters to this package.  For UTF-16, separate readers
+    // for big and little endian streams make a difference, too;
+    // fewer conditionals in the critical path!
+    //
+    static abstract class BaseReader extends Reader {
+        protected InputStream instream;
+        protected byte buffer [];
+        protected int start, finish;
+
+        BaseReader(InputStream stream) {
+            super(stream);
+
+            instream = stream;
+            buffer = new byte[8192];
+        }
+
+        public boolean ready() throws IOException {
+            return instream == null
+                    || (finish - start) > 0
+                    || instream.available() != 0;
+        }
+
+        // caller shouldn't read again
+        public void close() throws IOException {
+            if (instream != null) {
+                instream.close();
+                start = finish = 0;
+                buffer = null;
+                instream = null;
+            }
+        }
+    }
+
+    //
+    // We want this reader, to make the default encoding be as fast
+    // as we can make it.  JDK's "UTF8" (not "UTF-8" till JDK 1.2)
+    // InputStreamReader works, but 20+% slower speed isn't OK for
+    // the default/primary encoding.
+    //
+    static final class Utf8Reader extends BaseReader {
+        // 2nd half of UTF-8 surrogate pair
+        private char nextChar;
+
+        Utf8Reader(InputStream stream) {
+            super(stream);
+        }
+
+        public int read(char buf [], int offset, int len) throws IOException {
+            int i = 0, c = 0;
+
+            if (len <= 0)
+                return 0;
+
+            // Consume remaining half of any surrogate pair immediately
+            if (nextChar != 0) {
+                buf[offset + i++] = nextChar;
+                nextChar = 0;
+            }
+
+            while (i < len) {
+                // stop or read data if needed
+                if (finish <= start) {
+                    if (instream == null) {
+                        c = -1;
+                        break;
+                    }
+                    start = 0;
+                    finish = instream.read(buffer, 0, buffer.length);
+                    if (finish <= 0) {
+                        this.close();
+                        c = -1;
+                        break;
+                    }
+                }
+
+                //
+                // RFC 2279 describes UTF-8; there are six encodings.
+                // Each encoding takes a fixed number of characters
+                // (1-6 bytes) and is flagged by a bit pattern in the
+                // first byte.  The five and six byte-per-character
+                // encodings address characters which are disallowed
+                // in XML documents, as do some four byte ones.
+                //
+
+                //
+                // Single byte == ASCII.  Common; optimize.
+                //
+                c = buffer[start] & 0x0ff;
+                if ((c & 0x80) == 0x00) {
+                    // 0x0000 <= c <= 0x007f
+                    start++;
+                    buf[offset + i++] = (char) c;
+                    continue;
+                }
+
+                //
+                // Multibyte chars -- check offsets optimistically,
+                // ditto the "10xx xxxx" format for subsequent bytes
+                //
+                int off = start;
+
+                try {
+                    // 2 bytes
+                    if ((buffer[off] & 0x0E0) == 0x0C0) {
+                        c = (buffer[off++] & 0x1f) << 6;
+                        c += buffer[off++] & 0x3f;
+
+                        // 0x0080 <= c <= 0x07ff
+
+                        // 3 bytes
+                    } else if ((buffer[off] & 0x0F0) == 0x0E0) {
+                        c = (buffer[off++] & 0x0f) << 12;
+                        c += (buffer[off++] & 0x3f) << 6;
+                        c += buffer[off++] & 0x3f;
+
+                        // 0x0800 <= c <= 0xffff
+
+                        // 4 bytes
+                    } else if ((buffer[off] & 0x0f8) == 0x0F0) {
+                        c = (buffer[off++] & 0x07) << 18;
+                        c += (buffer[off++] & 0x3f) << 12;
+                        c += (buffer[off++] & 0x3f) << 6;
+                        c += buffer[off++] & 0x3f;
+
+                        // 0x0001 0000  <= c  <= 0x001f ffff
+
+                        // Unicode supports c <= 0x0010 ffff ...
+                        if (c > 0x0010ffff)
+                            throw new CharConversionException("UTF-8 encoding of character 0x00"
+                                    + Integer.toHexString(c)
+                                    + " can't be converted to Unicode.");
+
+                        // Convert UCS-4 char to surrogate pair (UTF-16)
+                        c -= 0x10000;
+                        nextChar = (char) (0xDC00 + (c & 0x03ff));
+                        c = 0xD800 + (c >> 10);
+
+                        // 5 and 6 byte versions are XML WF errors, but
+                        // typically come from mislabeled encodings
+                    } else
+                        throw new CharConversionException("Unconvertible UTF-8 character"
+                                + " beginning with 0x"
+                                + Integer.toHexString(buffer[start] & 0xff));
+
+                } catch (ArrayIndexOutOfBoundsException e) {
+                    // off > length && length >= buffer.length
+                    c = 0;
+                }
+
+                //
+                // if the buffer held only a partial character,
+                // compact it and try to read the rest of the
+                // character.  worst case involves three
+                // single-byte reads -- quite rare.
+                //
+                if (off > finish) {
+                    System.arraycopy(buffer, start,
+                            buffer, 0, finish - start);
+                    finish -= start;
+                    start = 0;
+                    off = instream.read(buffer, finish,
+                            buffer.length - finish);
+                    if (off < 0) {
+                        this.close();
+                        throw new CharConversionException("Partial UTF-8 char");
+                    }
+                    finish += off;
+                    continue;
+                }
+
+                //
+                // check the format of the non-initial bytes
+                //
+                for (start++; start < off; start++) {
+                    if ((buffer[start] & 0xC0) != 0x80) {
+                        this.close();
+                        throw new CharConversionException("Malformed UTF-8 char -- "
+                                + "is an XML encoding declaration missing?");
+                    }
+                }
+
+                //
+                // If this needed a surrogate pair, consume ASAP
+                //
+                buf[offset + i++] = (char) c;
+                if (nextChar != 0 && i < len) {
+                    buf[offset + i++] = nextChar;
+                    nextChar = 0;
+                }
+            }
+            if (i > 0)
+                return i;
+            return (c == -1) ? -1 : 0;
+        }
+    }
+
+    //
+    // We want ASCII and ISO-8859 Readers since they're the most common
+    // encodings in the US and Europe, and we don't want performance
+    // regressions for them.  They're also easy to implement efficiently,
+    // since they're bitmask subsets of UNICODE.
+    //
+    // XXX haven't benchmarked these readers vs what we get out of JDK.
+    //
+    static final class AsciiReader extends BaseReader {
+        AsciiReader(InputStream in) {
+            super(in);
+        }
+
+        public int read(char buf [], int offset, int len) throws IOException {
+            int i, c;
+
+            if (instream == null)
+                return -1;
+
+            for (i = 0; i < len; i++) {
+                if (start >= finish) {
+                    start = 0;
+                    finish = instream.read(buffer, 0, buffer.length);
+                    if (finish <= 0) {
+                        if (finish <= 0)
+                            this.close();
+                        break;
+                    }
+                }
+                c = buffer[start++];
+                if ((c & 0x80) != 0)
+                    throw new CharConversionException("Illegal ASCII character, 0x"
+                            + Integer.toHexString(c & 0xff));
+                buf[offset + i] = (char) c;
+            }
+            if (i == 0 && finish <= 0)
+                return -1;
+            return i;
+        }
+    }
+
+    static final class Iso8859_1Reader extends BaseReader {
+        Iso8859_1Reader(InputStream in) {
+            super(in);
+        }
+
+        public int read(char buf [], int offset, int len) throws IOException {
+            int i;
+
+            if (instream == null)
+                return -1;
+
+            for (i = 0; i < len; i++) {
+                if (start >= finish) {
+                    start = 0;
+                    finish = instream.read(buffer, 0, buffer.length);
+                    if (finish <= 0) {
+                        if (finish <= 0)
+                            this.close();
+                        break;
+                    }
+                }
+                buf[offset + i] = (char) (0x0ff & buffer[start++]);
+            }
+            if (i == 0 && finish <= 0)
+                return -1;
+            return i;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/package.html b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/package.html
new file mode 100644
index 0000000..a1f0908
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/package.html
@@ -0,0 +1,3 @@
+<HTML><BODY>
+<P>   scan DTD stream and generates appropriate events.</P>
+</BODY></HTML>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/resources/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/resources/Messages.properties
new file mode 100644
index 0000000..f419068
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/dtdparser/resources/Messages.properties
@@ -0,0 +1,238 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+#
+# English diagnostic messages (and fragments) for Sun's XML parser.
+#
+# P-NNN ... parser messages
+# F-NNN ... message fragments (sometimes associated with more
+#		than one message, but usually just with one)
+# V-NNN ... validation related messages
+#
+# Most messages can be produced in only one way.
+#
+
+
+#
+# Generic parsing messages, not specific to validation
+#
+P-000 = No parser input source!
+P-001 = Illegal character at end of document, &#x{0};
+P-002 = Expansion of entity "&{0};" is not well formed
+P-003 = Premature end of input
+P-004 = Missing whitespace {0}
+P-005 = Only whitespace allowed {0}
+
+	#
+	# unadorned "missing whitespace", with P-004 only
+	#
+	F-000 = after element name declaration
+	F-001 = between attribute name and type
+	F-002 = after NOTATION type name
+	F-003 = between attribute type and default value
+	F-004 = after #FIXED
+	F-005 = after <!ENTITY declaration
+	F-006 = after % in parameter entity declaration
+	F-007 = after entity name
+	F-008 = before SYSTEM literal URI
+	F-009 = after PUBLIC keyword
+	# F-010 ... identifier can be reused
+	F-011 = after notation name
+	# F-012 ... identifier can be reused
+	# F-013 ... identifier can be reused
+
+	#
+	# in declaration, in "S Name", with P-004 and P-005
+	#
+	F-014 = before name in <!DOCTYPE declaration
+	F-015 = before name in <!ELEMENT declaration
+	F-016 = before name in <!ATTLIST declaration
+	F-017 = before name in <!ENTITY declaration
+	F-018 = before NDATA notation name in <!ENTITY declaration
+	F-019 = before name in <!NOTATION declaration
+
+P-006 = Name tokens must not start with "{0}" characters
+P-007 = Value must be quoted
+P-008 = Next character must be "{0}" {1} {2}
+
+	F-020 = terminating reference to entity
+	F-021 = terminating reference to parameter entity
+	F-022 = terminating comment
+	F-023 = in XML Declaration
+	F-024 = terminating internal DTD subset
+	F-025 = terminating <!DOCTYPE ...> declaration
+	F-026 = after attribute name
+	F-027 = terminating element
+	F-028 = starting content model for element
+	F-029 = starting list of attribute NOTATIONS
+	F-030 = beginning condition DTD subset
+	F-031 = terminating <!ENTITY ...> declaration
+	F-032 = terminating <!NOTATION ...> declaration
+
+P-009 = Illegal character or entity reference syntax
+
+P-010 = Only external parameter entities may use "%{0};" in entity values
+P-011 = Illegal parameter entity reference syntax
+P-012 = Use "&lt;" for "<" in attribute values
+P-013 = Illegal reference to external entity "&{0};" in attribute
+P-014 = Reference to undefined entity "&{0};"
+P-015 = Expecting quoted value for {0}
+	
+	F-033 = PUBLIC identifier
+	F-034 = SYSTEM identifier
+	F-035 = attribute value {0}
+
+P-016 = Illegal character in PUBLIC identifier:  "{0}"
+P-017 = End of entity while processing comment
+P-018 = Processing instruction target is missing
+P-019 = XML declaration may only begin entities
+
+P-020 = Illegal processing instruction target:  "{0}"
+P-021 = End of input inside processing instruction
+P-022 = Illegal processing instruction name, or missing whitespace
+P-023 = Illegal character "&#x{0};" ({1}) at end of XML Declaration
+P-024 = Expected "{0}=..."
+P-025 = XML version "{0}" should be declared
+P-026 = Illegal XML version string "{0}"
+P-027 = XML version "{0}" is recognized, but not "{1}"
+P-028 = Internal DTD subset must not have "<![..." constructs
+P-029 = Standalone declaration must be "yes" or "no", not "{0}"
+
+P-030 = Whitespace required before attributes
+P-031 = Attribute names must not start with "{0}" characters
+P-032 = Attribute "{0}" already appeared in this tag
+P-033 = Illegal xml:lang value "{0}"
+P-034 = Expected "</{0}>" to terminate element starting on line {1}
+P-035 = End of entity not allowed; an end tag is missing
+P-036 = ">" must terminate <!ELEMENT {0} ...> declaration, not "{1}"
+P-037 = Sequence content model must not contain "{0}"
+P-038 = Choice content model must not contain "{0}"
+P-039 = No content model may contain "{0}"
+
+P-040 = Need right parenthesis or "{1}" in content model, not "{0}"
+P-041 = Need right parenthesis, ",", or "|" in content model, not "{0}"
+P-042 = Illegal mixed content model for "{0}", next char = &#x{1};
+P-043 = Mixed content model for "{0}" must end with ")*", not "{1}"
+P-044 = Either an attribute declaration or ">" is expected, not "{0}"
+P-045 = Illegal type (starts with "{1}") for attribute "{0}"
+P-046 = Need keyword in conditional DTD section
+P-047 = Unterminated conditional DTD section
+P-048 = Only INCLUDE and IGNORE are allowed, not "{0}"
+P-049 = Illegal decimal character reference
+
+P-050 = Illegal hexadecimal character reference
+P-051 = Illegal XML character &#x{0};
+P-052 = Internal entity "&{0};" has characters after content
+P-053 = Unparsed entities such as "&{0};" must not be included
+P-054 = Using original entity definition for "&{0};"
+P-055 = Relative URI "{0}"; can not be resolved without a document URI
+P-056 = URI "{0}" has a fragment ID
+P-057 = Need "?>" to terminate XML declaration
+P-058 = External entity "&{0};" has characters after content
+P-059 = External parameter entity "%{0};" has characters after markup
+
+P-060 = Illegal character "{0}" in encoding name
+P-061 = Declared encoding "{0}" does not match actual one "{1}"; \
+	this might not be an error
+P-062 = Notation must be PUBLIC or SYSTEM
+P-063 = Using first definition of notation "{0}"
+P-064 = Premature end of parameter entity "%{0};"
+P-065 = Entity Resolver did not provide SYSTEM id; may affect relative URIs
+# P-066 ... ID available
+P-067 = Document root element is missing
+P-068 = Notation name is required
+P-069 = Expansion of entity "{0}" is recursive
+
+P-070 = Malformed second part of surrogate pair:  &#x{0};
+P-071 = Illegal XML character:  &#x{0};
+P-072 = Character data cannot have "]]>"
+P-073 = EOF while parsing <![CDATA[ section
+P-074 = Illegal Unicode surrogate pair:  &#x{0}; &#x{1};
+P-075 = Unsupported encoding: "{0}" (line number may be too low)
+P-076 = Character conversion error: "{0}" (line number may be too low)
+P-077 = Maximum symbol length ({0} characters) exceeded
+P-078 = No messages for locale "{0}" are available
+P-079 = The content beginning "<{1}" is not legal markup \
+	Perhaps the "{1}" (&#{0};) character should be a letter
+
+P-080 = Parameter entity references must not appear within \
+	markup declarations in the internal DTD subset
+P-081 = Incomplete Unicode surrogate pair:  &#x{0}
+
+#
+# Validation messages, won't normally show up unless validation is
+# being performed.  Note that V-022 relates to a spec bug:  there
+# are both a WFC and VC on undefined PEs.  If that's a WVC violation
+# there's no need for the VC, ever; and "standalone" would then affect
+# WF-ness.  For the moment this assumes it's to be a VC not a WFC
+#
+V-000 =	Validation is disabled
+V-001 = Valid documents must have a <!DOCTYPE declaration
+V-002 = This document is standalone, so it must not refer to "&{0};"
+V-003 = Undeclared notation "{0}" is used by an <!ENTITY...> declaration
+V-004 = Undeclared notation "{0}" is used by an <!ATTLIST...> declaration
+V-005 = Element type "{0}" is not declared
+V-006 = Root element type is "{0}", but was declared to be "{1}"
+V-007 = Attribute "{0}" is not declared for element "{1}"
+V-008 = Attribute "{0}" of element "{1}" must only have value "{2}"
+V-009 = Attribute value for "{0}" is #REQUIRED
+
+V-010 = This document is standalone, \
+	so attribute "{0}" must not be defaulted
+V-011 = This document is standalone, \
+	so element "{0}" must not have ignorable whitespace
+V-012 = Element "{0}" was already declared
+V-013 = Parameter entities must not contain partial declarations
+V-014 = Parameter entity nesting error in content model for "{0}"
+V-015 = Mixed content model repeats element "{0}"
+V-016 = This element already has an ID attribute, "{0}"
+V-017 = ID attribute "{0}" must not be #FIXED
+V-018 = ID attribute "{0}" must not be defaulted
+V-019 = This document is standalone; this attribute needs to be pre-normalized
+
+V-020 = Parameter entities must not contain partial conditional DTD sections
+V-021 = Parameter entities must not contain partial comments
+V-022 = Reference to undefined parameter entity "%{0};"
+V-023 = This document is standalone; this ignorable CDATA whitespace is forbidden
+V-024 = No element has an ID attribute with value "{0}"
+V-025 = ID values must be XML names; "{0}" is not a name
+V-026 = Another element already has an ID attribute with value "{0}"
+V-027 = IDREF/IDREFS values must be XML names; "{0}" is not a name
+V-028 = NMTOKEN/NMTOKENS values must be XML name tokens; "{0}" is not one
+V-029 = Value "{0}" is not one of the enumerated values for this attribute
+
+V-030 = Attribute value "{0}" does not name a notation
+V-031 = Attribute value "{0}" does not name an unparsed entity
+V-032 = NMTOKENS attributes must have at least one value
+V-033 = EMPTY content models must have no content
+V-034 = Element "{0}" does not allow "{1}" -- {2}
+V-035 = Element "{0}" allows no further input; "{1}" is not allowed
+V-036 = Element "{0}" does not allow "{1}" here
+V-037 = Element "{0}" does not allow text
+V-038 = Element "{0}" requires additional elements
+V-039 = IDREFS attributes must have at least one value
+
+V-040 = ENTITIES attributes must have at least one value
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/AbstractResourceBundle.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/AbstractResourceBundle.java
new file mode 100644
index 0000000..17fa432
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/AbstractResourceBundle.java
@@ -0,0 +1,186 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+/*
+ * ====================================================================
+ *
+ * This code is subject to the freebxml License, Version 1.1
+ *
+ * Copyright (c) 2001 - 2005 freebxml.org.  All rights reserved.
+ *
+ * $Header: /cvs/fi/FastInfoset/src/com/sun/xml/internal/fastinfoset/AbstractResourceBundle.java,v 1.2 2005/05/17 20:53:19 joehw Exp $
+ * ====================================================================
+ */
+package com.sun.xml.internal.fastinfoset;
+
+import java.text.MessageFormat;
+import java.util.Enumeration;
+import java.util.Locale;
+import java.util.ResourceBundle;
+
+
+/**
+ * This class contains methods common to all *ResourceBundle classes
+ *
+ * @author  Paul Sterk / Sun Microsystems
+ */
+public abstract class AbstractResourceBundle extends ResourceBundle {
+
+    public static final String LOCALE = "com.sun.xml.internal.fastinfoset.locale";
+    static String _bundleName = null;
+
+    public static String getBundleName() {
+        return _bundleName;
+    }
+    public void setBundleName(String name) {
+        _bundleName = name;
+    }
+    /**
+     * Gets 'key' from ResourceBundle and format mesage using 'args'.
+     *
+     * @param key String key for message.
+     * @param args Array of arguments for message.
+     * @return String formatted message.
+     */
+    public String getString(String key, Object args[]) {
+        String pattern = getBundle().getString(key);
+        return MessageFormat.format(pattern, args);
+    }
+
+    /**
+     * Gets 'key' from ResourceBundle and format mesage using 'args'.
+     *
+     * @param key String key for message.
+     * @param args Array of arguments for message.
+     * @param locale Locale in which to perform key lookup.
+     * @return String formatted message.
+     */
+    public String getString(String key, Object args[], Locale locale) {
+        String pattern = null;
+        if (locale == null) {
+            pattern = getBundle().getString(key);
+        } else {
+            pattern = getBundle(_bundleName, locale).getString(key);
+        }
+        return MessageFormat.format(pattern, args);
+    }
+
+    /**
+     * Parse a locale string, return corresponding Locale instance.
+     *
+     * @param localeString
+     * Name for the locale of interest.  If null, use VM default locale.
+     * @return New Locale instance.
+     */
+    public static Locale parseLocale(String localeString) {
+        Locale locale = null;
+        if (localeString == null) {
+            locale = Locale.getDefault();
+        } else {
+            try {
+                String[] args = localeString.split("_");
+                if (args.length == 1) {
+                    locale = new Locale(args[0]);
+                } else if (args.length == 2) {
+                    locale = new Locale(args[0], args[1]);
+                } else if (args.length == 3) {
+                    locale = new Locale(args[0], args[1], args[2]);
+                }
+            } catch (Throwable t) {
+                locale = Locale.getDefault();
+            }
+        }
+        return locale;
+    }
+
+    /**
+     * Subclasses of this class must implement this method so that the
+     * correct resource bundle is passed to methods in this class
+     *
+     * @return
+     *  A java.util.ResourceBundle from the subsclass. Methods in this class
+     *  will use this reference.
+     */
+    public abstract ResourceBundle getBundle();
+
+
+    /**
+     * Since we are changing the ResourceBundle extension point, must
+     * implement handleGetObject() using delegate getBundle().  Uses
+     * getObject() call to work around protected access to
+     * ResourceBundle.handleGetObject().  Happily, this means parent tree
+     * of delegate bundle is searched for a match.
+     *
+     * Implements java.util.ResourceBundle.handleGetObject; inherits that
+     * javadoc information.
+     *
+     * @see java.util.ResourceBundle#handleGetObject(String)
+     */
+    protected Object handleGetObject(String key) {
+       return getBundle().getObject(key);
+    }
+
+    /**
+     * Since we are changing the ResourceBundle extension point, must
+     * implement getKeys() using delegate getBundle().
+     *
+     * Implements java.util.ResourceBundle.getKeys; inherits that javadoc
+     * information.
+     *
+     * @see java.util.ResourceBundle#getKeys()
+     */
+    public final Enumeration getKeys() {
+       return getBundle().getKeys();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/CommonResourceBundle.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/CommonResourceBundle.java
new file mode 100644
index 0000000..d9fe20d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/CommonResourceBundle.java
@@ -0,0 +1,121 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+package com.sun.xml.internal.fastinfoset;
+
+import java.util.Locale;
+import java.util.ResourceBundle;
+
+/** Resource bundle implementation for localized messages.
+ */
+public class CommonResourceBundle extends AbstractResourceBundle {
+
+    public static final String BASE_NAME = "com.sun.xml.internal.fastinfoset.resources.ResourceBundle";
+    private static CommonResourceBundle instance = null;
+    private static Locale locale = null;
+    private ResourceBundle bundle = null;
+
+    protected CommonResourceBundle() {
+        // Load the resource bundle of default locale
+        bundle = ResourceBundle.getBundle(BASE_NAME);
+    }
+
+    protected CommonResourceBundle(Locale locale) {
+        // Load the resource bundle of specified locale
+        bundle = ResourceBundle.getBundle(BASE_NAME, locale);
+    }
+
+    public static CommonResourceBundle getInstance() {
+        if (instance == null) {
+            synchronized (CommonResourceBundle.class) {
+                if (instance == null) {
+                    instance = new CommonResourceBundle();
+                    //**need to know where to get the locale
+                    //String localeString = CommonProperties.getInstance()
+                    //                  .getProperty("omar.common.locale");
+                    String localeString = null;
+                    locale = parseLocale(localeString);
+                }
+            }
+        }
+
+        return instance;
+    }
+
+    public static CommonResourceBundle getInstance(Locale locale) {
+        if (instance == null) {
+            synchronized (CommonResourceBundle.class) {
+                if (instance == null) {
+                    instance = new CommonResourceBundle(locale);
+                }
+            }
+        } else {
+            synchronized (CommonResourceBundle.class) {
+                if (CommonResourceBundle.locale != locale) {
+                    instance = new CommonResourceBundle(locale);
+                }
+            }
+        }
+        return instance;
+    }
+
+
+    public ResourceBundle getBundle() {
+        return bundle;
+    }
+    public ResourceBundle getBundle(Locale locale) {
+        return ResourceBundle.getBundle(BASE_NAME, locale);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Decoder.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Decoder.java
new file mode 100644
index 0000000..c4722ce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Decoder.java
@@ -0,0 +1,1868 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+package com.sun.xml.internal.fastinfoset;
+
+import com.sun.xml.internal.fastinfoset.alphabet.BuiltInRestrictedAlphabets;
+import com.sun.xml.internal.fastinfoset.org.apache.xerces.util.XMLChar;
+import com.sun.xml.internal.fastinfoset.util.CharArray;
+import com.sun.xml.internal.fastinfoset.util.CharArrayArray;
+import com.sun.xml.internal.fastinfoset.util.CharArrayString;
+import com.sun.xml.internal.fastinfoset.util.ContiguousCharArrayArray;
+import com.sun.xml.internal.fastinfoset.util.DuplicateAttributeVerifier;
+import com.sun.xml.internal.fastinfoset.util.PrefixArray;
+import com.sun.xml.internal.fastinfoset.util.QualifiedNameArray;
+import com.sun.xml.internal.fastinfoset.util.StringArray;
+import com.sun.xml.internal.fastinfoset.vocab.ParserVocabulary;
+import java.io.EOFException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetParser;
+
+/**
+ * Abstract decoder for developing concrete encoders.
+ *
+ * Concrete implementations extending Decoder will utilize methods on Decoder
+ * to decode XML infoset according to the Fast Infoset standard. It is the
+ * responsibility of the concrete implementation to ensure that methods are
+ * invoked in the correct order to correctly decode a valid fast infoset
+ * document.
+ *
+ * <p>
+ * This class extends org.sax.xml.DefaultHandler so that concrete SAX
+ * implementations can be used with javax.xml.parsers.SAXParser and the parse
+ * methods that take org.sax.xml.DefaultHandler as a parameter.
+ *
+ * <p>
+ * Buffering of octets that are read from an {@link java.io.InputStream} is
+ * supported in a similar manner to a {@link java.io.BufferedInputStream}.
+ * Combining buffering with decoding enables better performance.
+ *
+ * <p>
+ * More than one fast infoset document may be decoded from the
+ * {@link java.io.InputStream}.
+ */
+public abstract class Decoder implements FastInfosetParser {
+
+    /**
+     * String interning system property.
+     */
+    public static final String STRING_INTERNING_SYSTEM_PROPERTY =
+        "com.sun.xml.internal.fastinfoset.parser.string-interning";
+
+    /**
+     * Internal buffer size interning system property.
+     */
+    public static final String BUFFER_SIZE_SYSTEM_PROPERTY =
+        "com.sun.xml.internal.fastinfoset.parser.buffer-size";
+
+    private static boolean _stringInterningSystemDefault = false;
+
+    private static int _bufferSizeSystemDefault = 1024;
+
+    static {
+        String p = System.getProperty(STRING_INTERNING_SYSTEM_PROPERTY,
+            Boolean.toString(_stringInterningSystemDefault));
+        _stringInterningSystemDefault = Boolean.valueOf(p).booleanValue();
+
+        p = System.getProperty(BUFFER_SIZE_SYSTEM_PROPERTY,
+            Integer.toString(_bufferSizeSystemDefault));
+        try {
+            int i = Integer.valueOf(p).intValue();
+            if (i > 0) {
+                _bufferSizeSystemDefault = i;
+            }
+        } catch (NumberFormatException e) {
+        }
+    }
+
+    /**
+     * True if string interning is performed by the decoder.
+     */
+    private boolean _stringInterning = _stringInterningSystemDefault;
+
+    /**
+     * The input stream from which the fast infoset document is being read.
+     */
+    private InputStream _s;
+
+    /**
+     * The map of URIs to referenced vocabularies.
+     */
+    private Map _externalVocabularies;
+
+    /**
+     * True if the vocabulary is internally created by decoder.
+     */
+    private boolean _vIsInternal;
+
+    /**
+     * The list of Notation Information Items that are part of the
+     * Document Information Item.
+     */
+    protected List _notations;
+
+    /**
+     * The list of Unparsed Entity Information Items that are part of the
+     * Document Information Item.
+     */
+    protected List _unparsedEntities;
+
+    /**
+     * The map of URIs to registered encoding algorithms.
+     */
+    protected Map _registeredEncodingAlgorithms = new HashMap();
+
+    /**
+     * The vocabulary used for decoding.
+     */
+    protected ParserVocabulary _v;
+
+    /**
+     * The prefix table of the vocabulary.
+     */
+    protected PrefixArray _prefixTable;
+
+    /**
+     * The element name table of the vocabulary.
+     */
+    protected QualifiedNameArray _elementNameTable;
+
+    /**
+     * The attribute name table of the vocabulary.
+     */
+    protected QualifiedNameArray _attributeNameTable;
+
+    /**
+     * The character content chunk table of the vocabulary.
+     */
+    protected ContiguousCharArrayArray _characterContentChunkTable;
+
+    /**
+     * The attribute value table of the vocabulary.
+     */
+    protected StringArray _attributeValueTable;
+
+    /**
+     * The current octet that is being read
+     */
+    protected int _b;
+
+    /**
+     * True if an information item is terminated.
+     */
+    protected boolean _terminate;
+
+    /**
+     * True if two information item are terminated in direct sequence.
+     */
+    protected boolean _doubleTerminate;
+
+    /**
+     * True if an entry is required to be added to a table
+     */
+    protected boolean _addToTable;
+
+    /**
+     * The vocabulary table index to an indexed non identifying string.
+     */
+    protected int _integer;
+
+    /**
+     * The vocabulary table index of identifying string or the identifier of
+     * an encoding algorithm or restricted alphabet.
+     */
+    protected int _identifier;
+
+    /**
+     * The size of the internal buffer.
+     */
+    protected int _bufferSize = _bufferSizeSystemDefault;
+
+    /**
+     * The internal buffer used for decoding.
+     */
+    protected byte[] _octetBuffer = new byte[_bufferSizeSystemDefault];
+
+    /**
+     * A mark into the internal buffer used for decoding encoded algorithm
+     * or restricted alphabet data.
+     */
+    protected int _octetBufferStart;
+
+    /**
+     * The offset into the buffer to read the next byte.
+     */
+    protected int _octetBufferOffset;
+
+    /**
+     * The end of the buffer.
+     */
+    protected int _octetBufferEnd;
+
+    /**
+     * The length of some octets in the buffer that are to be read.
+     */
+    protected int _octetBufferLength;
+
+    /**
+     * The internal buffer of characters.
+     */
+    protected char[] _charBuffer = new char[512];
+
+    /**
+     * The length of characters in the buffer of characters.
+     */
+    protected int _charBufferLength;
+
+    /**
+     * Helper class that checks for duplicate attribute information items.
+     */
+    protected DuplicateAttributeVerifier _duplicateAttributeVerifier = new DuplicateAttributeVerifier();
+
+    /**
+     * Default constructor for the Decoder.
+     */
+    protected Decoder() {
+        _v = new ParserVocabulary();
+        _prefixTable = _v.prefix;
+        _elementNameTable = _v.elementName;
+        _attributeNameTable = _v.attributeName;
+        _characterContentChunkTable = _v.characterContentChunk;
+        _attributeValueTable = _v.attributeValue;
+        _vIsInternal = true;
+    }
+
+
+    // FastInfosetParser interface
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setStringInterning(boolean stringInterning) {
+        _stringInterning = stringInterning;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public boolean getStringInterning() {
+        return _stringInterning;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setBufferSize(int bufferSize) {
+        if (_bufferSize > _octetBuffer.length) {
+            _bufferSize = bufferSize;
+        }
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public int getBufferSize() {
+        return _bufferSize;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setRegisteredEncodingAlgorithms(Map algorithms) {
+        _registeredEncodingAlgorithms = algorithms;
+        if (_registeredEncodingAlgorithms == null) {
+            _registeredEncodingAlgorithms = new HashMap();
+        }
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public Map getRegisteredEncodingAlgorithms() {
+        return _registeredEncodingAlgorithms;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setExternalVocabularies(Map referencedVocabualries) {
+        if (referencedVocabualries != null) {
+            // Clone the input map
+            _externalVocabularies = new HashMap();
+            _externalVocabularies.putAll(referencedVocabualries);
+        } else {
+            _externalVocabularies = null;
+        }
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public Map getExternalVocabularies() {
+        return _externalVocabularies;
+    }
+
+    // End FastInfosetParser interface
+
+
+    /**
+     * Reset the decoder for reuse decoding another XML infoset.
+     */
+    public void reset() {
+        _terminate = _doubleTerminate = false;
+    }
+
+    /**
+     * Set the ParserVocabulary to be used for decoding.
+     *
+     * @param v the vocabulary to be used for decoding.
+     */
+    public void setVocabulary(ParserVocabulary v) {
+        _v = v;
+        _prefixTable = _v.prefix;
+        _elementNameTable = _v.elementName;
+        _attributeNameTable = _v.attributeName;
+        _characterContentChunkTable = _v.characterContentChunk;
+        _attributeValueTable = _v.attributeValue;
+        _vIsInternal = false;
+    }
+
+    /**
+     * Set the InputStream to decode the fast infoset document.
+     *
+     * @param s the InputStream where the fast infoset document is decoded from.
+     */
+    public void setInputStream(InputStream s) {
+        _s = s;
+        _octetBufferOffset = 0;
+        _octetBufferEnd = 0;
+        if (_vIsInternal == true) {
+            _v.clear();
+        }
+    }
+
+    protected final void decodeDII() throws FastInfosetException, IOException {
+        final int b = read();
+        if (b == EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG) {
+            decodeInitialVocabulary();
+        } else if (b != 0) {
+            throw new IOException(CommonResourceBundle.getInstance().
+                getString("message.optinalValues"));
+        }
+    }
+
+    protected final void decodeAdditionalData() throws FastInfosetException, IOException {
+        for (int i = 0; i < decodeNumberOfItemsOfSequence(); i++) {
+            String URI = decodeNonEmptyOctetStringOnSecondBitAsUtf8String();
+
+            decodeNonEmptyOctetStringLengthOnSecondBit();
+            ensureOctetBufferSize();
+            _octetBufferStart = _octetBufferOffset;
+            _octetBufferOffset += _octetBufferLength;
+        }
+    }
+
+    protected final void decodeInitialVocabulary() throws FastInfosetException, IOException {
+        // First 5 optionals of 13 bit optional field
+        int b = read();
+        // Next 8 optionals of 13 bit optional field
+        int b2 = read();
+
+        // Optimize for the most common case
+        if (b == EncodingConstants.INITIAL_VOCABULARY_EXTERNAL_VOCABULARY_FLAG && b2 == 0) {
+            decodeExternalVocabularyURI();
+            return;
+        }
+
+        if ((b & EncodingConstants.INITIAL_VOCABULARY_EXTERNAL_VOCABULARY_FLAG) > 0) {
+            decodeExternalVocabularyURI();
+        }
+
+        if ((b & EncodingConstants.INITIAL_VOCABULARY_RESTRICTED_ALPHABETS_FLAG) > 0) {
+            decodeTableItems(_v.restrictedAlphabet);
+        }
+
+        if ((b & EncodingConstants.INITIAL_VOCABULARY_ENCODING_ALGORITHMS_FLAG) > 0) {
+            decodeTableItems(_v.encodingAlgorithm);
+        }
+
+        if ((b & EncodingConstants.INITIAL_VOCABULARY_PREFIXES_FLAG) > 0) {
+            decodeTableItems(_v.prefix);
+        }
+
+        if ((b & EncodingConstants.INITIAL_VOCABULARY_NAMESPACE_NAMES_FLAG) > 0) {
+            decodeTableItems(_v.namespaceName);
+        }
+
+        if ((b2 & EncodingConstants.INITIAL_VOCABULARY_LOCAL_NAMES_FLAG) > 0) {
+            decodeTableItems(_v.localName);
+        }
+
+        if ((b2 & EncodingConstants.INITIAL_VOCABULARY_OTHER_NCNAMES_FLAG) > 0) {
+            decodeTableItems(_v.otherNCName);
+        }
+
+        if ((b2 & EncodingConstants.INITIAL_VOCABULARY_OTHER_URIS_FLAG) > 0) {
+            decodeTableItems(_v.otherURI);
+        }
+
+        if ((b2 & EncodingConstants.INITIAL_VOCABULARY_ATTRIBUTE_VALUES_FLAG) > 0) {
+            decodeTableItems(_v.attributeValue);
+        }
+
+        if ((b2 & EncodingConstants.INITIAL_VOCABULARY_CONTENT_CHARACTER_CHUNKS_FLAG) > 0) {
+            decodeTableItems(_v.characterContentChunk);
+        }
+
+        if ((b2 & EncodingConstants.INITIAL_VOCABULARY_OTHER_STRINGS_FLAG) > 0) {
+            decodeTableItems(_v.otherString);
+        }
+
+        if ((b2 & EncodingConstants.INITIAL_VOCABULARY_ELEMENT_NAME_SURROGATES_FLAG) > 0) {
+            decodeTableItems(_v.elementName, false);
+        }
+
+        if ((b2 & EncodingConstants.INITIAL_VOCABULARY_ATTRIBUTE_NAME_SURROGATES_FLAG) > 0) {
+            decodeTableItems(_v.attributeName, true);
+        }
+    }
+
+    private void decodeExternalVocabularyURI() throws FastInfosetException, IOException {
+        if (_externalVocabularies == null) {
+            throw new IOException(CommonResourceBundle.
+                    getInstance().getString("message.noExternalVocabularies"));
+        }
+
+        String externalVocabularyURI =
+                decodeNonEmptyOctetStringOnSecondBitAsUtf8String();
+
+        Object o = _externalVocabularies.get(externalVocabularyURI);
+        if (o instanceof ParserVocabulary) {
+            _v.setReferencedVocabulary(externalVocabularyURI,
+                    (ParserVocabulary)o, false);
+        } else if (o instanceof com.sun.xml.internal.org.jvnet.fastinfoset.ExternalVocabulary) {
+            com.sun.xml.internal.org.jvnet.fastinfoset.ExternalVocabulary v =
+                    (com.sun.xml.internal.org.jvnet.fastinfoset.ExternalVocabulary)o;
+            ParserVocabulary pv = new ParserVocabulary(v.vocabulary);
+
+            _externalVocabularies.put(externalVocabularyURI, pv);
+            _v.setReferencedVocabulary(externalVocabularyURI,
+                    pv, false);
+        } else {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().
+                    getString("message.externalVocabularyNotRegistered",
+                    new Object[]{externalVocabularyURI}));
+        }
+    }
+
+    private void decodeTableItems(StringArray array) throws FastInfosetException, IOException {
+        for (int i = 0; i < decodeNumberOfItemsOfSequence(); i++) {
+            array.add(decodeNonEmptyOctetStringOnSecondBitAsUtf8String());
+        }
+    }
+
+    private void decodeTableItems(PrefixArray array) throws FastInfosetException, IOException {
+        for (int i = 0; i < decodeNumberOfItemsOfSequence(); i++) {
+            array.add(decodeNonEmptyOctetStringOnSecondBitAsUtf8String());
+        }
+    }
+
+    private void decodeTableItems(ContiguousCharArrayArray array) throws FastInfosetException, IOException {
+        for (int i = 0; i < decodeNumberOfItemsOfSequence(); i++) {
+            switch(decodeNonIdentifyingStringOnFirstBit()) {
+                case NISTRING_STRING:
+                    array.add(_charBuffer, _charBufferLength);
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.illegalState"));
+            }
+        }
+    }
+
+    private void decodeTableItems(CharArrayArray array) throws FastInfosetException, IOException {
+        for (int i = 0; i < decodeNumberOfItemsOfSequence(); i++) {
+            switch(decodeNonIdentifyingStringOnFirstBit()) {
+                case NISTRING_STRING:
+                    array.add(new CharArray(_charBuffer, 0, _charBufferLength, true));
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.illegalState"));
+            }
+        }
+    }
+
+    private void decodeTableItems(QualifiedNameArray array, boolean isAttribute) throws FastInfosetException, IOException {
+        for (int i = 0; i < decodeNumberOfItemsOfSequence(); i++) {
+            final int b = read();
+
+            String prefix = "";
+            int prefixIndex = -1;
+            if ((b & EncodingConstants.NAME_SURROGATE_PREFIX_FLAG) > 0) {
+                prefixIndex = decodeIntegerIndexOnSecondBit();
+                prefix = _v.prefix.get(prefixIndex);
+            }
+
+            String namespaceName = "";
+            int namespaceNameIndex = -1;
+            if ((b & EncodingConstants.NAME_SURROGATE_NAME_FLAG) > 0) {
+                namespaceNameIndex = decodeIntegerIndexOnSecondBit();
+                namespaceName = _v.prefix.get(prefixIndex);
+            }
+
+            if (namespaceName == "" && prefix != "") {
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.missingNamespace"));
+            }
+
+            final int localNameIndex = decodeIntegerIndexOnSecondBit();
+            final String localName = _v.localName.get(localNameIndex);
+
+            QualifiedName qualifiedName = new QualifiedName(prefix, namespaceName, localName,
+                    prefixIndex, namespaceNameIndex, localNameIndex,
+                    _charBuffer);
+            if (isAttribute) {
+                qualifiedName.createAttributeValues(_duplicateAttributeVerifier.MAP_SIZE);
+            }
+            array.add(qualifiedName);
+        }
+    }
+
+    private int decodeNumberOfItemsOfSequence() throws IOException {
+        final int b = read();
+        if (b < 128) {
+            return b;
+        } else {
+            return ((b & 0x0F) << 16) | (read() << 8) | read();
+        }
+    }
+
+    protected final void decodeNotations() throws FastInfosetException, IOException {
+        if (_notations == null) {
+            _notations = new ArrayList();
+        } else {
+            _notations.clear();
+        }
+
+        int b = read();
+        while ((b & EncodingConstants.NOTATIONS_MASK) == EncodingConstants.NOTATIONS) {
+            String name = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+
+            String system_identifier = ((_b & EncodingConstants.NOTATIONS_SYSTEM_IDENTIFIER_FLAG) > 0)
+                ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+            String public_identifier = ((_b & EncodingConstants.NOTATIONS_PUBLIC_IDENTIFIER_FLAG) > 0)
+                ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+
+            Notation notation = new Notation(name, system_identifier, public_identifier);
+            _notations.add(notation);
+
+            b = read();
+        }
+        if (b != EncodingConstants.TERMINATOR) {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IIsNotTerminatedCorrectly"));
+        }
+    }
+
+    protected final void decodeUnparsedEntities() throws FastInfosetException, IOException {
+        if (_unparsedEntities == null) {
+            _unparsedEntities = new ArrayList();
+        } else {
+            _unparsedEntities.clear();
+        }
+
+        int b = read();
+        while ((b & EncodingConstants.UNPARSED_ENTITIES_MASK) == EncodingConstants.UNPARSED_ENTITIES) {
+            String name = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+            String system_identifier = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI);
+
+            String public_identifier = ((_b & EncodingConstants.UNPARSED_ENTITIES_PUBLIC_IDENTIFIER_FLAG) > 0)
+                ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+
+            String notation_name = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+
+            UnparsedEntity unparsedEntity = new UnparsedEntity(name, system_identifier, public_identifier, notation_name);
+            _unparsedEntities.add(unparsedEntity);
+
+            b = read();
+        }
+        if (b != EncodingConstants.TERMINATOR) {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.unparsedEntities"));
+        }
+    }
+
+    protected final String decodeCharacterEncodingScheme() throws FastInfosetException, IOException {
+        return decodeNonEmptyOctetStringOnSecondBitAsUtf8String();
+    }
+
+    protected final String decodeVersion() throws FastInfosetException, IOException {
+        switch(decodeNonIdentifyingStringOnFirstBit()) {
+            case NISTRING_STRING:
+                final String data = new String(_charBuffer, 0, _charBufferLength);
+                if (_addToTable) {
+                    _v.otherString.add(new CharArrayString(data));
+                }
+                return data;
+            case NISTRING_ENCODING_ALGORITHM:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingNotSupported"));
+            case NISTRING_INDEX:
+                return _v.otherString.get(_integer).toString();
+            case NISTRING_EMPTY_STRING:
+            default:
+                return "";
+        }
+    }
+
+    protected final QualifiedName decodeEIIIndexMedium() throws FastInfosetException, IOException {
+        final int i = (((_b & EncodingConstants.INTEGER_3RD_BIT_MEDIUM_MASK) << 8) | read())
+            + EncodingConstants.INTEGER_3RD_BIT_SMALL_LIMIT;
+        return _v.elementName._array[i];
+    }
+
+    protected final QualifiedName decodeEIIIndexLarge() throws FastInfosetException, IOException {
+        int i;
+        if ((_b & EncodingConstants.INTEGER_3RD_BIT_LARGE_LARGE_FLAG) == 0x20) {
+            // EII large index
+            i = (((_b & EncodingConstants.INTEGER_3RD_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                + EncodingConstants.INTEGER_3RD_BIT_MEDIUM_LIMIT;
+        } else {
+            // EII large large index
+            i = (((read() & EncodingConstants.INTEGER_3RD_BIT_LARGE_LARGE_MASK) << 16) | (read() << 8) | read())
+                + EncodingConstants.INTEGER_3RD_BIT_LARGE_LIMIT;
+        }
+        return _v.elementName._array[i];
+    }
+
+    protected final QualifiedName decodeLiteralQualifiedName(int state) throws FastInfosetException, IOException {
+        switch (state) {
+            // no prefix, no namespace
+            case 0:
+                return new QualifiedName(
+                        "",
+                        "",
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        -1,
+                        -1,
+                        _identifier,
+                        null);
+            // no prefix, namespace
+            case 1:
+                return new QualifiedName(
+                        "",
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsNamespaceName(false),
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        -1,
+                        _namespaceNameIndex,
+                        _identifier,
+                        null);
+            // prefix, no namespace
+            case 2:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.qNameMissingNamespaceName"));
+            // prefix, namespace
+            case 3:
+                return new QualifiedName(
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsPrefix(true),
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsNamespaceName(true),
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        _prefixIndex,
+                        _namespaceNameIndex,
+                        _identifier,
+                        _charBuffer);
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingEII"));
+        }
+    }
+
+    protected static final int NISTRING_STRING              = 0;
+    protected static final int NISTRING_INDEX               = 1;
+    protected static final int NISTRING_ENCODING_ALGORITHM  = 2;
+    protected static final int NISTRING_EMPTY_STRING        = 3;
+
+    /*
+     * C.14
+     * decodeNonIdentifyingStringOnFirstBit
+     */
+    protected final int decodeNonIdentifyingStringOnFirstBit() throws FastInfosetException, IOException {
+        final int b = read();
+        switch(DecoderStateTables.NISTRING[b]) {
+            case DecoderStateTables.NISTRING_UTF8_SMALL_LENGTH:
+                _addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK) + 1;
+                decodeUtf8StringAsCharBuffer();
+                return NISTRING_STRING;
+            case DecoderStateTables.NISTRING_UTF8_MEDIUM_LENGTH:
+                _addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                decodeUtf8StringAsCharBuffer();
+                return NISTRING_STRING;
+            case DecoderStateTables.NISTRING_UTF8_LARGE_LENGTH:
+            {
+                _addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                final int length = (read() << 24) |
+                    (read() << 16) |
+                    (read() << 8) |
+                    read();
+                _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                decodeUtf8StringAsCharBuffer();
+                return NISTRING_STRING;
+            }
+            case DecoderStateTables.NISTRING_UTF16_SMALL_LENGTH:
+                _addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK) + 1;
+                decodeUtf16StringAsCharBuffer();
+                return NISTRING_STRING;
+            case DecoderStateTables.NISTRING_UTF16_MEDIUM_LENGTH:
+                _addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                decodeUtf16StringAsCharBuffer();
+                return NISTRING_STRING;
+            case DecoderStateTables.NISTRING_UTF16_LARGE_LENGTH:
+            {
+                _addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                final int length = (read() << 24) |
+                    (read() << 16) |
+                    (read() << 8) |
+                    read();
+                _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                decodeUtf16StringAsCharBuffer();
+                return NISTRING_STRING;
+            }
+            case DecoderStateTables.NISTRING_RA:
+            {
+                _addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                // Decode resitricted alphabet integer
+                _identifier = (b & 0x0F) << 4;
+                final int b2 = read();
+                _identifier |= (b2 & 0xF0) >> 4;
+
+                decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(b2);
+
+                decodeRestrictedAlphabetAsCharBuffer();
+                return NISTRING_STRING;
+            }
+            case DecoderStateTables.NISTRING_EA:
+            {
+                _addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                // Decode encoding algorithm integer
+                _identifier = (b & 0x0F) << 4;
+                final int b2 = read();
+                _identifier |= (b2 & 0xF0) >> 4;
+
+                decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(b2);
+                return NISTRING_ENCODING_ALGORITHM;
+            }
+            case DecoderStateTables.NISTRING_INDEX_SMALL:
+                _integer = b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK;
+                return NISTRING_INDEX;
+            case DecoderStateTables.NISTRING_INDEX_MEDIUM:
+                _integer = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                return NISTRING_INDEX;
+            case DecoderStateTables.NISTRING_INDEX_LARGE:
+                _integer = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                return NISTRING_INDEX;
+            case DecoderStateTables.NISTRING_EMPTY:
+                return NISTRING_EMPTY_STRING;
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingNonIdentifyingString"));
+        }
+    }
+
+    protected final void decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(int b) throws FastInfosetException, IOException {
+        // Remove top 4 bits of restricted alphabet or encoding algorithm integer
+        b &= 0x0F;
+        // Reuse UTF8 length states
+        switch(DecoderStateTables.NISTRING[b]) {
+            case DecoderStateTables.NISTRING_UTF8_SMALL_LENGTH:
+                _octetBufferLength = b + 1;
+                break;
+            case DecoderStateTables.NISTRING_UTF8_MEDIUM_LENGTH:
+                _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                break;
+            case DecoderStateTables.NISTRING_UTF8_LARGE_LENGTH:
+                final int length = (read() << 24) |
+                    (read() << 16) |
+                    (read() << 8) |
+                    read();
+                _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                break;
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingOctets"));
+        }
+        ensureOctetBufferSize();
+        _octetBufferStart = _octetBufferOffset;
+        _octetBufferOffset += _octetBufferLength;
+    }
+
+    protected final void decodeOctetsOnSeventhBitOfNonIdentifyingStringOnThirdBit(int b) throws FastInfosetException, IOException {
+        // Remove top 6 bits of restricted alphabet or encoding algorithm integer
+        switch (b & 0x03) {
+            // Small length
+            case 0:
+                _octetBufferLength = 1;
+                break;
+            // Small length
+            case 1:
+                _octetBufferLength = 2;
+                break;
+            // Medium length
+            case 2:
+                _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT;
+                break;
+            // Large length
+            case 3:
+                _octetBufferLength = (read() << 24) |
+                    (read() << 16) |
+                    (read() << 8) |
+                    read();
+                _octetBufferLength += EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT;
+                break;
+        }
+
+        ensureOctetBufferSize();
+        _octetBufferStart = _octetBufferOffset;
+        _octetBufferOffset += _octetBufferLength;
+    }
+
+    /*
+     * C.13
+     */
+    protected final String decodeIdentifyingNonEmptyStringOnFirstBit(StringArray table) throws FastInfosetException, IOException {
+        final int b = read();
+        switch(DecoderStateTables.ISTRING[b]) {
+            case DecoderStateTables.ISTRING_SMALL_LENGTH:
+            {
+                _octetBufferLength = b + 1;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _identifier = table.add(s) - 1;
+                return s;
+            }
+            case DecoderStateTables.ISTRING_MEDIUM_LENGTH:
+            {
+                _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_SMALL_LIMIT;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _identifier = table.add(s) - 1;
+                return s;
+            }
+            case DecoderStateTables.ISTRING_LARGE_LENGTH:
+            {
+                final int length = (read() << 24) |
+                    (read() << 16) |
+                    (read() << 8) |
+                    read();
+                _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_LIMIT;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _identifier = table.add(s) - 1;
+                return s;
+            }
+            case DecoderStateTables.ISTRING_INDEX_SMALL:
+                _identifier = b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK;
+                return table._array[_identifier];
+            case DecoderStateTables.ISTRING_INDEX_MEDIUM:
+                _identifier = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                return table._array[_identifier];
+            case DecoderStateTables.ISTRING_INDEX_LARGE:
+                _identifier = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                return table._array[_identifier];
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingIdentifyingString"));
+        }
+    }
+
+    protected int _prefixIndex;
+
+    /*
+     * C.13
+     */
+    protected final String decodeIdentifyingNonEmptyStringOnFirstBitAsPrefix(boolean namespaceNamePresent) throws FastInfosetException, IOException {
+        final int b = read();
+        switch(DecoderStateTables.ISTRING_PREFIX_NAMESPACE[b]) {
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_LENGTH_3:
+            {
+                _octetBufferLength = EncodingConstants.XML_NAMESPACE_PREFIX_LENGTH;
+                decodeUtf8StringAsCharBuffer();
+
+                if (_charBuffer[0] == 'x' &&
+                        _charBuffer[1] == 'm' &&
+                        _charBuffer[2] == 'l') {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.prefixIllegal"));
+                }
+
+                final String s = (_stringInterning) ? new String(_charBuffer, 0, _charBufferLength).intern() :
+                    new String(_charBuffer, 0, _charBufferLength);
+                _prefixIndex = _v.prefix.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_LENGTH_5:
+            {
+                _octetBufferLength = EncodingConstants.XMLNS_NAMESPACE_PREFIX_LENGTH;
+                decodeUtf8StringAsCharBuffer();
+
+                if (_charBuffer[0] == 'x' &&
+                        _charBuffer[1] == 'm' &&
+                        _charBuffer[2] == 'l' &&
+                        _charBuffer[3] == 'n' &&
+                        _charBuffer[4] == 's') {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.xmlns"));
+                }
+
+                final String s = (_stringInterning) ? new String(_charBuffer, 0, _charBufferLength).intern() :
+                    new String(_charBuffer, 0, _charBufferLength);
+                _prefixIndex = _v.prefix.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_SMALL_LENGTH:
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_LENGTH_29:
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_LENGTH_36:
+            {
+                _octetBufferLength = b + 1;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _prefixIndex = _v.prefix.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_MEDIUM_LENGTH:
+            {
+                _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_SMALL_LIMIT;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _prefixIndex = _v.prefix.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_LARGE_LENGTH:
+            {
+                final int length = (read() << 24) |
+                    (read() << 16) |
+                    (read() << 8) |
+                    read();
+                _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_LIMIT;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _prefixIndex = _v.prefix.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_INDEX_ZERO:
+                if (namespaceNamePresent) {
+                    _prefixIndex = 0;
+                    // Peak at next byte and check the index of the XML namespace name
+                    if (DecoderStateTables.ISTRING_PREFIX_NAMESPACE[peak()]
+                            != DecoderStateTables.ISTRING_PREFIX_NAMESPACE_INDEX_ZERO) {
+                        throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.wrongNamespaceName"));
+                    }
+                    return EncodingConstants.XML_NAMESPACE_PREFIX;
+                } else {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.missingNamespaceName"));
+                }
+            case DecoderStateTables.ISTRING_INDEX_SMALL:
+                _prefixIndex = b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK;
+                return _v.prefix._array[_prefixIndex - 1];
+            case DecoderStateTables.ISTRING_INDEX_MEDIUM:
+                _prefixIndex = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                return _v.prefix._array[_prefixIndex - 1];
+            case DecoderStateTables.ISTRING_INDEX_LARGE:
+                _prefixIndex = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                return _v.prefix._array[_prefixIndex - 1];
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingIdentifyingStringForPrefix"));
+        }
+    }
+
+    /*
+     * C.13
+     */
+    protected final String decodeIdentifyingNonEmptyStringIndexOnFirstBitAsPrefix(boolean namespaceNamePresent) throws FastInfosetException, IOException {
+        final int b = read();
+        switch(DecoderStateTables.ISTRING_PREFIX_NAMESPACE[b]) {
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_INDEX_ZERO:
+                if (namespaceNamePresent) {
+                    _prefixIndex = 0;
+                    // Peak at next byte and check the index of the XML namespace name
+                    if (DecoderStateTables.ISTRING_PREFIX_NAMESPACE[peak()]
+                            != DecoderStateTables.ISTRING_PREFIX_NAMESPACE_INDEX_ZERO) {
+                        throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.wrongNamespaceName"));
+                    }
+                    return EncodingConstants.XML_NAMESPACE_PREFIX;
+                } else {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.missingNamespaceName"));
+                }
+            case DecoderStateTables.ISTRING_INDEX_SMALL:
+                _prefixIndex = b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK;
+                return _v.prefix._array[_prefixIndex - 1];
+            case DecoderStateTables.ISTRING_INDEX_MEDIUM:
+                _prefixIndex = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                return _v.prefix._array[_prefixIndex - 1];
+            case DecoderStateTables.ISTRING_INDEX_LARGE:
+                _prefixIndex = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                return _v.prefix._array[_prefixIndex - 1];
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingIdentifyingStringForPrefix"));
+        }
+    }
+
+    protected int _namespaceNameIndex;
+
+    /*
+     * C.13
+     */
+    protected final String decodeIdentifyingNonEmptyStringOnFirstBitAsNamespaceName(boolean prefixPresent) throws FastInfosetException, IOException {
+        final int b = read();
+        switch(DecoderStateTables.ISTRING_PREFIX_NAMESPACE[b]) {
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_LENGTH_3:
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_LENGTH_5:
+            case DecoderStateTables.ISTRING_SMALL_LENGTH:
+            {
+                _octetBufferLength = b + 1;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _namespaceNameIndex = _v.namespaceName.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_LENGTH_29:
+            {
+                _octetBufferLength = EncodingConstants.XMLNS_NAMESPACE_NAME_LENGTH;
+                decodeUtf8StringAsCharBuffer();
+
+                if (compareCharsWithCharBufferFromEndToStart(EncodingConstants.XMLNS_NAMESPACE_NAME_CHARS)) {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.xmlnsConnotBeBoundToPrefix"));
+                }
+
+                final String s = (_stringInterning) ? new String(_charBuffer, 0, _charBufferLength).intern() :
+                    new String(_charBuffer, 0, _charBufferLength);
+                _namespaceNameIndex = _v.namespaceName.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_LENGTH_36:
+            {
+                _octetBufferLength = EncodingConstants.XML_NAMESPACE_NAME_LENGTH;
+                decodeUtf8StringAsCharBuffer();
+
+                if (compareCharsWithCharBufferFromEndToStart(EncodingConstants.XML_NAMESPACE_NAME_CHARS)) {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.illegalNamespaceName"));
+                }
+
+                final String s = (_stringInterning) ? new String(_charBuffer, 0, _charBufferLength).intern() :
+                    new String(_charBuffer, 0, _charBufferLength);
+                _namespaceNameIndex = _v.namespaceName.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_MEDIUM_LENGTH:
+            {
+                _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_SMALL_LIMIT;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _namespaceNameIndex = _v.namespaceName.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_LARGE_LENGTH:
+            {
+                final int length = (read() << 24) |
+                    (read() << 16) |
+                    (read() << 8) |
+                    read();
+                _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_LIMIT;
+                final String s = (_stringInterning) ? decodeUtf8StringAsString().intern() : decodeUtf8StringAsString();
+                _namespaceNameIndex = _v.namespaceName.add(s);
+                return s;
+            }
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_INDEX_ZERO:
+                if (prefixPresent) {
+                    _namespaceNameIndex = 0;
+                    return EncodingConstants.XML_NAMESPACE_NAME;
+                } else {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.namespaceWithoutPrefix"));
+                }
+            case DecoderStateTables.ISTRING_INDEX_SMALL:
+                _namespaceNameIndex = b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK;
+                return _v.namespaceName._array[_namespaceNameIndex - 1];
+            case DecoderStateTables.ISTRING_INDEX_MEDIUM:
+                _namespaceNameIndex = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                return _v.namespaceName._array[_namespaceNameIndex - 1];
+            case DecoderStateTables.ISTRING_INDEX_LARGE:
+                _namespaceNameIndex = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                return _v.namespaceName._array[_namespaceNameIndex - 1];
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingForNamespaceName"));
+        }
+    }
+
+    /*
+     * C.13
+     */
+    protected final String decodeIdentifyingNonEmptyStringIndexOnFirstBitAsNamespaceName(boolean prefixPresent) throws FastInfosetException, IOException {
+        final int b = read();
+        switch(DecoderStateTables.ISTRING_PREFIX_NAMESPACE[b]) {
+            case DecoderStateTables.ISTRING_PREFIX_NAMESPACE_INDEX_ZERO:
+                if (prefixPresent) {
+                    _namespaceNameIndex = 0;
+                    return EncodingConstants.XML_NAMESPACE_NAME;
+                } else {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.namespaceWithoutPrefix"));
+                }
+            case DecoderStateTables.ISTRING_INDEX_SMALL:
+                _namespaceNameIndex = b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK;
+                return _v.namespaceName._array[_namespaceNameIndex - 1];
+            case DecoderStateTables.ISTRING_INDEX_MEDIUM:
+                _namespaceNameIndex = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                return _v.namespaceName._array[_namespaceNameIndex - 1];
+            case DecoderStateTables.ISTRING_INDEX_LARGE:
+                _namespaceNameIndex = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                return _v.namespaceName._array[_namespaceNameIndex - 1];
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingForNamespaceName"));
+        }
+    }
+
+    private boolean compareCharsWithCharBufferFromEndToStart(char[] c) {
+        int i = _charBufferLength ;
+        while (--i >= 0) {
+            if (c[i] != _charBuffer[i]) {
+                return false;
+            }
+        }
+        return true;
+    }
+
+    /*
+     * C.22
+     */
+    protected final String decodeNonEmptyOctetStringOnSecondBitAsUtf8String() throws FastInfosetException, IOException {
+        decodeNonEmptyOctetStringOnSecondBitAsUtf8CharArray();
+        return new String(_charBuffer, 0, _charBufferLength);
+    }
+
+    /*
+     * C.22
+     */
+    protected final void decodeNonEmptyOctetStringOnSecondBitAsUtf8CharArray() throws FastInfosetException, IOException {
+        decodeNonEmptyOctetStringLengthOnSecondBit();
+        decodeUtf8StringAsCharBuffer();
+    }
+
+    /*
+     * C.22
+     */
+    protected final void decodeNonEmptyOctetStringLengthOnSecondBit() throws FastInfosetException, IOException {
+        final int b = read();
+        switch(DecoderStateTables.ISTRING[b]) {
+            case DecoderStateTables.ISTRING_SMALL_LENGTH:
+                _octetBufferLength = b + 1;
+                break;
+            case DecoderStateTables.ISTRING_MEDIUM_LENGTH:
+                _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_SMALL_LIMIT;
+                break;
+            case DecoderStateTables.ISTRING_LARGE_LENGTH:
+            {
+                final int length = (read() << 24) |
+                    (read() << 16) |
+                    (read() << 8) |
+                    read();
+                _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_LIMIT;
+                break;
+            }
+            case DecoderStateTables.ISTRING_INDEX_SMALL:
+            case DecoderStateTables.ISTRING_INDEX_MEDIUM:
+            case DecoderStateTables.ISTRING_INDEX_LARGE:
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingNonEmptyOctet"));
+        }
+    }
+
+    /*
+     * C.25
+     */
+    protected final int decodeIntegerIndexOnSecondBit() throws FastInfosetException, IOException {
+        final int b = read();
+        switch(DecoderStateTables.ISTRING[b]) {
+            case DecoderStateTables.ISTRING_INDEX_SMALL:
+                return b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK;
+            case DecoderStateTables.ISTRING_INDEX_MEDIUM:
+                return (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+            case DecoderStateTables.ISTRING_INDEX_LARGE:
+                return (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+            case DecoderStateTables.ISTRING_SMALL_LENGTH:
+            case DecoderStateTables.ISTRING_MEDIUM_LENGTH:
+            case DecoderStateTables.ISTRING_LARGE_LENGTH:
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingIndexOnSecondBit"));
+        }
+    }
+
+    protected final void decodeHeader() throws FastInfosetException, IOException {
+        if (!_isFastInfosetDocument()) {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.notFIDocument"));
+        }
+    }
+
+    protected final void decodeRestrictedAlphabetAsCharBuffer() throws FastInfosetException, IOException {
+        if (_identifier <= EncodingConstants.RESTRICTED_ALPHABET_BUILTIN_END) {
+            decodeFourBitAlphabetOctetsAsCharBuffer(BuiltInRestrictedAlphabets.table[_identifier]);
+            // decodeAlphabetOctetsAsCharBuffer(BuiltInRestrictedAlphabets.table[_identifier]);
+        } else if (_identifier >= EncodingConstants.RESTRICTED_ALPHABET_APPLICATION_START) {
+            CharArray ca = _v.restrictedAlphabet.get(_identifier - EncodingConstants.RESTRICTED_ALPHABET_APPLICATION_START);
+            if (ca == null) {
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.alphabetNotPresent", new Object[]{new Integer(_identifier)}));
+            }
+            decodeAlphabetOctetsAsCharBuffer(ca.ch);
+        } else {
+            // Reserved built-in algorithms for future use
+            // TODO should use sax property to decide if event will be
+            // reported, allows for support through handler if required.
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.alphabetIdentifiersReserved"));
+        }
+    }
+
+    protected final String decodeRestrictedAlphabetAsString() throws FastInfosetException, IOException {
+        decodeRestrictedAlphabetAsCharBuffer();
+        return new String(_charBuffer, 0, _charBufferLength);
+    }
+
+    protected final String decodeRAOctetsAsString(char[] restrictedAlphabet) throws FastInfosetException, IOException {
+        decodeAlphabetOctetsAsCharBuffer(null);
+        return new String(_charBuffer, 0, _charBufferLength);
+    }
+
+    protected final void decodeFourBitAlphabetOctetsAsCharBuffer(char[] restrictedAlphabet) throws FastInfosetException, IOException {
+        _charBufferLength = 0;
+        final int characters = _octetBufferLength / 2;
+        if (_charBuffer.length < characters) {
+            _charBuffer = new char[characters];
+        }
+
+        int v = 0;
+        for (int i = 0; i < _octetBufferLength - 1; i++) {
+            v = _octetBuffer[_octetBufferStart++] & 0xFF;
+            _charBuffer[_charBufferLength++] = restrictedAlphabet[v >> 4];
+            _charBuffer[_charBufferLength++] = restrictedAlphabet[v & 0x0F];
+        }
+        v = _octetBuffer[_octetBufferStart++] & 0xFF;
+        _charBuffer[_charBufferLength++] = restrictedAlphabet[v >> 4];
+        v &= 0x0F;
+        if (v != 0x0F) {
+            _charBuffer[_charBufferLength++] = restrictedAlphabet[v & 0x0F];
+        }
+    }
+
+    protected final void decodeAlphabetOctetsAsCharBuffer(char[] restrictedAlphabet) throws FastInfosetException, IOException {
+        if (restrictedAlphabet.length < 2) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.alphabetMustContain2orMoreChars"));
+        }
+
+        int bitsPerCharacter = 1;
+        while ((1 << bitsPerCharacter) <= restrictedAlphabet.length) {
+            bitsPerCharacter++;
+        }
+        final int terminatingValue = (1 << bitsPerCharacter) - 1;
+
+        int characters = (_octetBufferLength << 3) / bitsPerCharacter;
+        if (characters == 0) {
+            throw new IOException("");
+        }
+
+        _charBufferLength = 0;
+        if (_charBuffer.length < characters) {
+            _charBuffer = new char[characters];
+        }
+
+        resetBits();
+        for (int i = 0; i < characters; i++) {
+            int value = readBits(bitsPerCharacter);
+            if (bitsPerCharacter < 8 && value == terminatingValue) {
+                int octetPosition = (i * bitsPerCharacter) >>> 3;
+                if (octetPosition != _octetBufferLength - 1) {
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.alphabetIncorrectlyTerminated"));
+                }
+                break;
+            }
+            _charBuffer[_charBufferLength++] = restrictedAlphabet[value];
+        }
+    }
+
+    private int _bitsLeftInOctet;
+
+    private void resetBits() {
+        _bitsLeftInOctet = 0;
+    }
+
+    private int readBits(int bits) throws IOException {
+        int value = 0;
+        while (bits > 0) {
+            if (_bitsLeftInOctet == 0) {
+                _b = _octetBuffer[_octetBufferStart++] & 0xFF;
+                _bitsLeftInOctet = 8;
+            }
+            int bit = ((_b & (1 << --_bitsLeftInOctet)) > 0) ? 1 : 0;
+            value |= (bit << --bits);
+        }
+
+        return value;
+    }
+
+    protected final void decodeUtf8StringAsCharBuffer() throws IOException {
+        ensureOctetBufferSize();
+        decodeUtf8StringIntoCharBuffer();
+    }
+
+    protected final String decodeUtf8StringAsString() throws IOException {
+        decodeUtf8StringAsCharBuffer();
+        return new String(_charBuffer, 0, _charBufferLength);
+    }
+
+    protected final void decodeUtf16StringAsCharBuffer() throws IOException {
+        ensureOctetBufferSize();
+        decodeUtf16StringIntoCharBuffer();
+    }
+
+    protected final String decodeUtf16StringAsString() throws IOException {
+        decodeUtf16StringAsCharBuffer();
+        return new String(_charBuffer, 0, _charBufferLength);
+    }
+
+    private void ensureOctetBufferSize() throws IOException {
+        if (_octetBufferEnd < (_octetBufferOffset + _octetBufferLength)) {
+            final int octetsInBuffer = _octetBufferEnd - _octetBufferOffset;
+
+            if (_octetBuffer.length < _octetBufferLength) {
+                // Length to read is too large, resize the buffer
+                byte[] newOctetBuffer = new byte[_octetBufferLength];
+                // Move partially read octets to the start of the buffer
+                System.arraycopy(_octetBuffer, _octetBufferOffset, newOctetBuffer, 0, octetsInBuffer);
+                _octetBuffer = newOctetBuffer;
+            } else {
+                // Move partially read octets to the start of the buffer
+                System.arraycopy(_octetBuffer, _octetBufferOffset, _octetBuffer, 0, octetsInBuffer);
+            }
+            _octetBufferOffset = 0;
+
+            // Read as many octets as possible to fill the buffer
+            final int octetsRead = _s.read(_octetBuffer, octetsInBuffer, _octetBuffer.length - octetsInBuffer);
+            if (octetsRead < 0) {
+                throw new EOFException("Unexpeceted EOF");
+            }
+            _octetBufferEnd = octetsInBuffer + octetsRead;
+
+            // Check if the number of octets that have been read is not enough
+            // This can happen when underlying non-blocking is used to read
+            if (_octetBufferEnd < _octetBufferLength) {
+                repeatedRead();
+            }
+        }
+    }
+
+    private void repeatedRead() throws IOException {
+        // Check if the number of octets that have been read is not enough
+        while (_octetBufferEnd < _octetBufferLength) {
+            // Read as many octets as possible to fill the buffer
+            final int octetsRead = _s.read(_octetBuffer, _octetBufferEnd, _octetBuffer.length - _octetBufferEnd);
+            if (octetsRead < 0) {
+                throw new EOFException("Unexpeceted EOF");
+            }
+            _octetBufferEnd += octetsRead;
+        }
+    }
+
+    protected final void decodeUtf8StringIntoCharBuffer() throws IOException {
+        if (_charBuffer.length < _octetBufferLength) {
+            _charBuffer = new char[_octetBufferLength];
+        }
+
+        _charBufferLength = 0;
+        final int end = _octetBufferLength + _octetBufferOffset;
+        int b1;
+        while (end != _octetBufferOffset) {
+            b1 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+            if (DecoderStateTables.UTF8[b1] == DecoderStateTables.UTF8_ONE_BYTE) {
+                _charBuffer[_charBufferLength++] = (char) b1;
+            } else {
+                decodeTwoToFourByteUtf8Character(b1, end);
+            }
+        }
+    }
+
+    private void decodeTwoToFourByteUtf8Character(int b1, int end) throws IOException {
+        switch(DecoderStateTables.UTF8[b1]) {
+            case DecoderStateTables.UTF8_TWO_BYTES:
+            {
+                // Decode byte 2
+                if (end == _octetBufferOffset) {
+                    decodeUtf8StringLengthTooSmall();
+                }
+                final int b2 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+                if ((b2 & 0xC0) != 0x80) {
+                    decodeUtf8StringIllegalState();
+                }
+
+                // Character guaranteed to be in [0x20, 0xD7FF] range
+                // since a character encoded in two bytes will be in the
+                // range [0x80, 0x1FFF]
+                _charBuffer[_charBufferLength++] = (char) (
+                    ((b1 & 0x1F) << 6)
+                    | (b2 & 0x3F));
+                break;
+            }
+            case DecoderStateTables.UTF8_THREE_BYTES:
+                final char c = decodeUtf8ThreeByteChar(end, b1);
+                if (XMLChar.isContent(c)) {
+                    _charBuffer[_charBufferLength++] = c;
+                    break;
+                } else {
+                    decodeUtf8StringIllegalState();
+                }
+            case DecoderStateTables.UTF8_FOUR_BYTES:
+            {
+                final int supplemental = decodeUtf8FourByteChar(end, b1);
+                if (XMLChar.isContent(supplemental)) {
+                    _charBuffer[_charBufferLength++] = _utf8_highSurrogate;
+                    _charBuffer[_charBufferLength++] = _utf8_lowSurrogate;
+                } else {
+                    decodeUtf8StringIllegalState();
+                }
+                break;
+            }
+            default:
+                decodeUtf8StringIllegalState();
+        }
+    }
+
+    protected final void decodeUtf8NCNameIntoCharBuffer() throws IOException {
+        _charBufferLength = 0;
+        if (_charBuffer.length < _octetBufferLength) {
+            _charBuffer = new char[_octetBufferLength];
+        }
+
+        final int end = _octetBufferLength + _octetBufferOffset;
+
+        int b1 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+        if (DecoderStateTables.UTF8_NCNAME[b1] == DecoderStateTables.UTF8_NCNAME_NCNAME) {
+            _charBuffer[_charBufferLength++] = (char) b1;
+        } else {
+            decodeUtf8NCNameStartTwoToFourByteCharacters(b1, end);
+        }
+
+        while (end != _octetBufferOffset) {
+            b1 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+            if (DecoderStateTables.UTF8_NCNAME[b1] < DecoderStateTables.UTF8_TWO_BYTES) {
+                _charBuffer[_charBufferLength++] = (char) b1;
+            } else {
+                decodeUtf8NCNameTwoToFourByteCharacters(b1, end);
+            }
+        }
+    }
+
+    private void decodeUtf8NCNameStartTwoToFourByteCharacters(int b1, int end) throws IOException {
+        switch(DecoderStateTables.UTF8_NCNAME[b1]) {
+            case DecoderStateTables.UTF8_TWO_BYTES:
+            {
+                // Decode byte 2
+                if (end == _octetBufferOffset) {
+                    decodeUtf8StringLengthTooSmall();
+                }
+                final int b2 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+                if ((b2 & 0xC0) != 0x80) {
+                    decodeUtf8StringIllegalState();
+                }
+
+                final char c = (char) (
+                    ((b1 & 0x1F) << 6)
+                    | (b2 & 0x3F));
+                if (XMLChar.isNCNameStart(c)) {
+                    _charBuffer[_charBufferLength++] = c;
+                    break;
+                } else {
+                    decodeUtf8NCNameIllegalState();
+                }
+            }
+            case DecoderStateTables.UTF8_THREE_BYTES:
+                final char c = decodeUtf8ThreeByteChar(end, b1);
+                if (XMLChar.isNCNameStart(c)) {
+                    _charBuffer[_charBufferLength++] = c;
+                    break;
+                } else {
+                    decodeUtf8NCNameIllegalState();
+                }
+                break;
+            case DecoderStateTables.UTF8_FOUR_BYTES:
+            {
+                final int supplemental = decodeUtf8FourByteChar(end, b1);
+                if (XMLChar.isNCNameStart(supplemental)) {
+                    _charBuffer[_charBufferLength++] = _utf8_highSurrogate;
+                    _charBuffer[_charBufferLength++] = _utf8_lowSurrogate;
+                } else {
+                    decodeUtf8NCNameIllegalState();
+                }
+                break;
+            }
+            case DecoderStateTables.UTF8_NCNAME_NCNAME_CHAR:
+            default:
+                decodeUtf8NCNameIllegalState();
+        }
+
+    }
+
+    private void decodeUtf8NCNameTwoToFourByteCharacters(int b1, int end) throws IOException {
+        switch(DecoderStateTables.UTF8_NCNAME[b1]) {
+            case DecoderStateTables.UTF8_TWO_BYTES:
+            {
+                // Decode byte 2
+                if (end == _octetBufferOffset) {
+                    decodeUtf8StringLengthTooSmall();
+                }
+                final int b2 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+                if ((b2 & 0xC0) != 0x80) {
+                    decodeUtf8StringIllegalState();
+                }
+
+                final char c = (char) (
+                    ((b1 & 0x1F) << 6)
+                    | (b2 & 0x3F));
+                if (XMLChar.isNCName(c)) {
+                    _charBuffer[_charBufferLength++] = c;
+                    break;
+                } else {
+                    decodeUtf8NCNameIllegalState();
+                }
+            }
+            case DecoderStateTables.UTF8_THREE_BYTES:
+                final char c = decodeUtf8ThreeByteChar(end, b1);
+                if (XMLChar.isNCName(c)) {
+                    _charBuffer[_charBufferLength++] = c;
+                    break;
+                } else {
+                    decodeUtf8NCNameIllegalState();
+                }
+                break;
+            case DecoderStateTables.UTF8_FOUR_BYTES:
+            {
+                final int supplemental = decodeUtf8FourByteChar(end, b1);
+                if (XMLChar.isNCName(supplemental)) {
+                    _charBuffer[_charBufferLength++] = _utf8_highSurrogate;
+                    _charBuffer[_charBufferLength++] = _utf8_lowSurrogate;
+                } else {
+                    decodeUtf8NCNameIllegalState();
+                }
+                break;
+            }
+            default:
+                decodeUtf8NCNameIllegalState();
+        }
+    }
+
+    private char decodeUtf8ThreeByteChar(int end, int b1) throws IOException {
+        // Decode byte 2
+        if (end == _octetBufferOffset) {
+            decodeUtf8StringLengthTooSmall();
+        }
+        final int b2 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+        if ((b2 & 0xC0) != 0x80
+            || (b1 == 0xED && b2 >= 0xA0)
+            || ((b1 & 0x0F) == 0 && (b2 & 0x20) == 0)) {
+            decodeUtf8StringIllegalState();
+        }
+
+        // Decode byte 3
+        if (end == _octetBufferOffset) {
+            decodeUtf8StringLengthTooSmall();
+        }
+        final int b3 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+        if ((b3 & 0xC0) != 0x80) {
+            decodeUtf8StringIllegalState();
+        }
+
+        return (char) (
+            (b1 & 0x0F) << 12
+            | (b2 & 0x3F) << 6
+            | (b3 & 0x3F));
+    }
+
+    private char _utf8_highSurrogate;
+    private char _utf8_lowSurrogate;
+
+    private int decodeUtf8FourByteChar(int end, int b1) throws IOException {
+        // Decode byte 2
+        if (end == _octetBufferOffset) {
+            decodeUtf8StringLengthTooSmall();
+        }
+        final int b2 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+        if ((b2 & 0xC0) != 0x80
+            || ((b2 & 0x30) == 0 && (b1 & 0x07) == 0)) {
+            decodeUtf8StringIllegalState();
+        }
+
+        // Decode byte 3
+        if (end == _octetBufferOffset) {
+            decodeUtf8StringLengthTooSmall();
+        }
+        final int b3 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+        if ((b3 & 0xC0) != 0x80) {
+            decodeUtf8StringIllegalState();
+        }
+
+        // Decode byte 4
+        if (end == _octetBufferOffset) {
+            decodeUtf8StringLengthTooSmall();
+        }
+        final int b4 = _octetBuffer[_octetBufferOffset++] & 0xFF;
+        if ((b4 & 0xC0) != 0x80) {
+            decodeUtf8StringIllegalState();
+        }
+
+        final int uuuuu = ((b1 << 2) & 0x001C) | ((b2 >> 4) & 0x0003);
+        if (uuuuu > 0x10) {
+            decodeUtf8StringIllegalState();
+        }
+        final int wwww = uuuuu - 1;
+
+        _utf8_highSurrogate = (char) (0xD800 |
+             ((wwww << 6) & 0x03C0) | ((b2 << 2) & 0x003C) |
+             ((b3 >> 4) & 0x0003));
+        _utf8_lowSurrogate = (char) (0xDC00 | ((b3 << 6) & 0x03C0) | (b4 & 0x003F));
+
+        return XMLChar.supplemental(_utf8_highSurrogate, _utf8_lowSurrogate);
+    }
+
+    private void decodeUtf8StringLengthTooSmall() throws IOException {
+        throw new IOException(CommonResourceBundle.getInstance().getString("message.deliminatorTooSmall"));
+    }
+
+    private void decodeUtf8StringIllegalState() throws IOException {
+        throw new IOException(CommonResourceBundle.getInstance().getString("message.UTF8Encoded"));
+    }
+
+    private void decodeUtf8NCNameIllegalState() throws IOException {
+        throw new IOException(CommonResourceBundle.getInstance().getString("message.UTF8EncodedNCName"));
+    }
+
+    private void decodeUtf16StringIntoCharBuffer() throws IOException {
+        _charBufferLength = _octetBufferLength / 2;
+        if (_charBuffer.length < _charBufferLength) {
+            _charBuffer = new char[_charBufferLength];
+        }
+
+        for (int i = 0; i < _charBufferLength; i++) {
+            final char c = (char)((read() << 8) | read());
+            // TODO check c is a valid Char character
+            _charBuffer[i] = c;
+        }
+
+    }
+
+    protected String createQualifiedNameString(char[] first, String second) {
+        final int l1 = first.length;
+        final int l2 = second.length();
+        final int total = l1 + l2 + 1;
+        if (total < _charBuffer.length) {
+            System.arraycopy(first, 0, _charBuffer, 0, l1);
+            _charBuffer[l1] = ':';
+            second.getChars(0, l2, _charBuffer, l1 + 1);
+            return new String(_charBuffer, 0, total);
+        } else {
+            StringBuffer b = new StringBuffer(new String(first));
+            b.append(':');
+            b.append(second);
+            return b.toString();
+        }
+    }
+
+    protected final int read() throws IOException {
+        if (_octetBufferOffset < _octetBufferEnd) {
+            return _octetBuffer[_octetBufferOffset++] & 0xFF;
+        } else {
+            _octetBufferEnd = _s.read(_octetBuffer);
+            if (_octetBufferEnd < 0) {
+                throw new EOFException(CommonResourceBundle.getInstance().getString("message.EOF"));
+            }
+
+            _octetBufferOffset = 1;
+            return _octetBuffer[0] & 0xFF;
+        }
+    }
+
+    protected final int peak() throws IOException {
+        if (_octetBufferOffset < _octetBufferEnd) {
+            return _octetBuffer[_octetBufferOffset] & 0xFF;
+        } else {
+            _octetBufferEnd = _s.read(_octetBuffer);
+            if (_octetBufferEnd < 0) {
+                throw new EOFException(CommonResourceBundle.getInstance().getString("message.EOF"));
+            }
+
+            _octetBufferOffset = 0;
+            return _octetBuffer[0] & 0xFF;
+        }
+    }
+
+    protected class EncodingAlgorithmInputStream extends InputStream {
+
+        public int read() throws IOException {
+            if (_octetBufferStart < _octetBufferOffset) {
+                return (_octetBuffer[_octetBufferStart++] & 0xFF);
+            } else {
+                return -1;
+            }
+        }
+
+        public int read(byte b[]) throws IOException {
+            return read(b, 0, b.length);
+        }
+
+        public int read(byte b[], int off, int len) throws IOException {
+            if (b == null) {
+                throw new NullPointerException();
+            } else if ((off < 0) || (off > b.length) || (len < 0) ||
+                       ((off + len) > b.length) || ((off + len) < 0)) {
+                throw new IndexOutOfBoundsException();
+            } else if (len == 0) {
+                return 0;
+            }
+
+            final int newOctetBufferStart = _octetBufferStart + len;
+            if (newOctetBufferStart < _octetBufferOffset) {
+                System.arraycopy(_octetBuffer, _octetBufferStart, b, off, len);
+                _octetBufferStart = newOctetBufferStart;
+                return len;
+            } else if (_octetBufferStart < _octetBufferOffset) {
+                final int bytesToRead = _octetBufferOffset - _octetBufferStart;
+                System.arraycopy(_octetBuffer, _octetBufferStart, b, off, bytesToRead);
+                _octetBufferStart += bytesToRead;
+                return bytesToRead;
+            } else {
+                return -1;
+            }
+        }
+    }
+
+    protected final boolean _isFastInfosetDocument() throws IOException {
+        // Fill up the octet buffer
+        peak();
+
+        _octetBufferLength = EncodingConstants.BINARY_HEADER.length;
+        ensureOctetBufferSize();
+        _octetBufferOffset += _octetBufferLength;
+
+        // Check for binary header
+        if (_octetBuffer[0] != EncodingConstants.BINARY_HEADER[0] ||
+                _octetBuffer[1] != EncodingConstants.BINARY_HEADER[1] ||
+                _octetBuffer[2] != EncodingConstants.BINARY_HEADER[2] ||
+                _octetBuffer[3] != EncodingConstants.BINARY_HEADER[3]) {
+
+            // Check for each form of XML declaration
+            for (int i = 0; i < EncodingConstants.XML_DECLARATION_VALUES.length; i++) {
+                _octetBufferLength = EncodingConstants.XML_DECLARATION_VALUES[i].length - _octetBufferOffset;
+                ensureOctetBufferSize();
+                _octetBufferOffset += _octetBufferLength;
+
+                // Check XML declaration
+                if (arrayEquals(_octetBuffer, 0,
+                        EncodingConstants.XML_DECLARATION_VALUES[i],
+                        EncodingConstants.XML_DECLARATION_VALUES[i].length)) {
+                    _octetBufferLength = EncodingConstants.BINARY_HEADER.length;
+                    ensureOctetBufferSize();
+
+                    // Check for binary header
+                    if (_octetBuffer[_octetBufferOffset++] != EncodingConstants.BINARY_HEADER[0] ||
+                            _octetBuffer[_octetBufferOffset++] != EncodingConstants.BINARY_HEADER[1] ||
+                            _octetBuffer[_octetBufferOffset++] != EncodingConstants.BINARY_HEADER[2] ||
+                            _octetBuffer[_octetBufferOffset++] != EncodingConstants.BINARY_HEADER[3]) {
+                        return false;
+                    } else {
+                        // Fast Infoset document with XML declaration and binary header
+                        return true;
+                    }
+                }
+            }
+
+            return false;
+        }
+
+        // Fast Infoset document with binary header
+        return true;
+    }
+
+    private boolean arrayEquals(byte[] b1, int offset, byte[] b2, int length) {
+        for (int i = 0; i < length; i++) {
+            if (b1[offset + i] != b2[i]) {
+                return false;
+            }
+        }
+
+        return true;
+    }
+
+    static public boolean isFastInfosetDocument(InputStream s) throws IOException {
+        // TODO
+        // Check for <?xml declaration with 'finf' encoding
+
+        final byte[] header = new byte[4];
+        s.read(header);
+        if (header[0] != EncodingConstants.BINARY_HEADER[0] ||
+                header[1] != EncodingConstants.BINARY_HEADER[1] ||
+                header[2] != EncodingConstants.BINARY_HEADER[2] ||
+                header[3] != EncodingConstants.BINARY_HEADER[3]) {
+            return false;
+        }
+
+        // TODO
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/DecoderStateTables.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/DecoderStateTables.java
new file mode 100644
index 0000000..f720df6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/DecoderStateTables.java
@@ -0,0 +1,821 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset;
+
+public class DecoderStateTables {
+    private static int RANGE_INDEX_END      = 0;
+    private static int RANGE_INDEX_VALUE    = 1;
+
+    public final static int STATE_ILLEGAL                   = 255;
+    public final static int STATE_UNSUPPORTED               = 254;
+
+    // EII child states
+    public final static int EII_NO_AIIS_INDEX_SMALL         = 0;
+    public final static int EII_AIIS_INDEX_SMALL            = 1;
+    public final static int EII_INDEX_MEDIUM                = 2;
+    public final static int EII_INDEX_LARGE                 = 3;
+    public final static int EII_NAMESPACES                  = 4;
+    public final static int EII_LITERAL                     = 5;
+    public final static int CII_UTF8_SMALL_LENGTH           = 6;
+    public final static int CII_UTF8_MEDIUM_LENGTH          = 7;
+    public final static int CII_UTF8_LARGE_LENGTH           = 8;
+    public final static int CII_UTF16_SMALL_LENGTH          = 9;
+    public final static int CII_UTF16_MEDIUM_LENGTH         = 10;
+    public final static int CII_UTF16_LARGE_LENGTH          = 11;
+    public final static int CII_RA                          = 12;
+    public final static int CII_EA                          = 13;
+    public final static int CII_INDEX_SMALL                 = 14;
+    public final static int CII_INDEX_MEDIUM                = 15;
+    public final static int CII_INDEX_LARGE                 = 16;
+    public final static int CII_INDEX_LARGE_LARGE           = 17;
+    public final static int COMMENT_II                      = 18;
+    public final static int PROCESSING_INSTRUCTION_II       = 19;
+    public final static int DOCUMENT_TYPE_DECLARATION_II    = 20;
+    public final static int UNEXPANDED_ENTITY_REFERENCE_II  = 21;
+    public final static int TERMINATOR_SINGLE               = 22;
+    public final static int TERMINATOR_DOUBLE               = 23;
+
+    public static final int[] DII = new int[256];
+
+    private static int[][] DII_RANGES = {
+        // EII
+
+        // %00000000 to %00011111  EII no attributes small index
+        { 0x1F, EII_NO_AIIS_INDEX_SMALL },
+
+        // %00100000 to %00100111  EII medium index
+        { 0x27, EII_INDEX_MEDIUM },
+
+        // %00101000 to %00101111  EII large index
+        // %00110000  EII very large index
+        // %00101000 to %00110000
+        { 0x30, EII_INDEX_LARGE },
+
+        // %00110001 to %00110111  ILLEGAL
+        { 0x37, STATE_ILLEGAL },
+
+        // %00111000  EII namespaces
+        { 0x38, EII_NAMESPACES },
+
+        // %00111001 to %00111011  ILLEGAL
+        { 0x3B, STATE_ILLEGAL },
+
+        // %00111100  EII literal (no prefix, no namespace)
+        { 0x3C, EII_LITERAL },
+
+        // %00111101  EII literal (no prefix, namespace)
+        { 0x3D, EII_LITERAL },
+
+        // %00111110  ILLEGAL
+        { 0x3E, STATE_ILLEGAL },
+
+        // %00111111  EII literal (prefix, namespace)
+        { 0x3F, EII_LITERAL },
+
+        // %01000000 to %01011111  EII attributes small index
+        { 0x5F, EII_AIIS_INDEX_SMALL },
+
+        // %01100000 to %01100111  EII medium index
+        { 0x67, EII_INDEX_MEDIUM },
+
+        // %01101000 to %01101111  EII large index
+        // %01110000  EII very large index
+        // %01101000 to %01110000
+        { 0x70, EII_INDEX_LARGE },
+
+        // %01110001 to %01110111  ILLEGAL
+        { 0x77, STATE_ILLEGAL },
+
+        // %01111000  EII attributes namespaces
+        { 0x78, EII_NAMESPACES },
+
+        // %01111001 to %01111011  ILLEGAL
+        { 0x7B, STATE_ILLEGAL },
+
+        // %01111100  EII attributes literal (no prefix, no namespace)
+        { 0x7C, EII_LITERAL },
+
+        // %01111101  EII attributes literal (no prefix, namespace)
+        { 0x7D, EII_LITERAL },
+
+        // %01111110  ILLEGAL
+        { 0x7E, STATE_ILLEGAL },
+
+        // %01111111  EII attributes literal (prefix, namespace)
+        { 0x7F, EII_LITERAL },
+
+        // %10000000 to %11000011
+        { 0xC3, STATE_ILLEGAL },
+
+        // %11000100 to %11000111
+        { 0xC7, DOCUMENT_TYPE_DECLARATION_II },
+
+        // %11001000 to %1110000
+        { 0xE0, STATE_ILLEGAL },
+
+        // %11100001 processing instruction
+        { 0xE1, PROCESSING_INSTRUCTION_II },
+
+        // %11100010 comment
+        { 0xE2, COMMENT_II},
+
+        // %111000011 to %11101111
+        { 0xEF, STATE_ILLEGAL },
+
+        // Terminators
+
+        // %11110000  single terminator
+        { 0xF0, TERMINATOR_SINGLE },
+
+        // %11110000 to %11111110 ILLEGAL
+        { 0xFE, STATE_ILLEGAL },
+
+        // %11111111  double terminator
+        { 0xFF, TERMINATOR_DOUBLE }
+    };
+
+    public static final int[] EII = new int[256];
+
+    private static int[][] EII_RANGES = {
+        // EII
+
+        // %00000000 to %00011111  EII no attributes small index
+        { 0x1F, EII_NO_AIIS_INDEX_SMALL },
+
+        // %00100000 to %00100111  EII medium index
+        { 0x27, EII_INDEX_MEDIUM },
+
+        // %00101000 to %00101111  EII large index
+        // %00110000  EII very large index
+        // %00101000 to %00110000
+        { 0x30, EII_INDEX_LARGE },
+
+        // %00110001 to %00110111  ILLEGAL
+        { 0x37, STATE_ILLEGAL },
+
+        // %00111000  EII namespaces
+        { 0x38, EII_NAMESPACES },
+
+        // %00111001 to %00111011  ILLEGAL
+        { 0x3B, STATE_ILLEGAL },
+
+        // %00111100  EII literal (no prefix, no namespace)
+        { 0x3C, EII_LITERAL },
+
+        // %00111101  EII literal (no prefix, namespace)
+        { 0x3D, EII_LITERAL },
+
+        // %00111110  ILLEGAL
+        { 0x3E, STATE_ILLEGAL },
+
+        // %00111111  EII literal (prefix, namespace)
+        { 0x3F, EII_LITERAL },
+
+        // %01000000 to %01011111  EII attributes small index
+        { 0x5F, EII_AIIS_INDEX_SMALL },
+
+        // %01100000 to %01100111  EII medium index
+        { 0x67, EII_INDEX_MEDIUM },
+
+        // %01101000 to %01101111  EII large index
+        // %01110000  EII very large index
+        // %01101000 to %01110000
+        { 0x70, EII_INDEX_LARGE },
+
+        // %01110001 to %01110111  ILLEGAL
+        { 0x77, STATE_ILLEGAL },
+
+        // %01111000  EII attributes namespaces
+        { 0x78, EII_NAMESPACES },
+
+        // %01111001 to %01111011  ILLEGAL
+        { 0x7B, STATE_ILLEGAL },
+
+        // %01111100  EII attributes literal (no prefix, no namespace)
+        { 0x7C, EII_LITERAL },
+
+        // %01111101  EII attributes literal (no prefix, namespace)
+        { 0x7D, EII_LITERAL },
+
+        // %01111110  ILLEGAL
+        { 0x7E, STATE_ILLEGAL },
+
+        // %01111111  EII attributes literal (prefix, namespace)
+        { 0x7F, EII_LITERAL },
+
+        // CII
+
+        // UTF-8 string
+
+        // %10000000 to %10000001  CII UTF-8 no add to table small length
+        { 0x81, CII_UTF8_SMALL_LENGTH },
+
+        // %10000010  CII UTF-8 no add to table medium length
+        { 0x82, CII_UTF8_MEDIUM_LENGTH },
+
+        // %10000011  CII UTF-8 no add to table large length
+        { 0x83, CII_UTF8_LARGE_LENGTH },
+
+        // UTF-16 string
+
+        // %10000100 to %10000101  CII UTF-16 no add to table small length
+        { 0x85, CII_UTF16_SMALL_LENGTH },
+
+        // %10000110  CII UTF-16 no add to table medium length
+        { 0x86, CII_UTF16_MEDIUM_LENGTH },
+
+        // %10000111  CII UTF-16 no add to table large length
+        { 0x87, CII_UTF16_LARGE_LENGTH },
+
+        // Resitricted alphabet
+
+        // %10001000 to %10001011  CII RA no add to table
+        { 0x8B, CII_RA },
+
+        // Encoding algorithm
+
+        // %10001100 to %10001111  CII EA no add to table
+        { 0x8F, CII_EA },
+
+        // UTF-8 string, add to table
+
+        // %10010000 to %10010001  CII add to table small length
+        { 0x91, CII_UTF8_SMALL_LENGTH },
+
+        // %10010010  CII add to table medium length
+        { 0x92, CII_UTF8_MEDIUM_LENGTH },
+
+        // %10010011  CII add to table large length
+        { 0x93, CII_UTF8_LARGE_LENGTH },
+
+        // UTF-16 string, add to table
+
+        // %10010100 to %10010101  CII UTF-16 add to table small length
+        { 0x95, CII_UTF16_SMALL_LENGTH },
+
+        // %10010110  CII UTF-16 add to table medium length
+        { 0x96, CII_UTF16_MEDIUM_LENGTH },
+
+        // %10010111  CII UTF-16 add to table large length
+        { 0x97, CII_UTF16_LARGE_LENGTH },
+
+        // Restricted alphabet, add to table
+
+        // %10011000 to %10011011  CII RA add to table
+        { 0x9B, CII_RA },
+
+        // Encoding algorithm, add to table
+
+        // %10011100 to %10011111  CII EA add to table
+        { 0x9F, CII_EA },
+
+        // Index
+
+        // %10100000 to %10101111  CII small index
+        { 0xAF, CII_INDEX_SMALL },
+
+        // %10110000 to %10110011  CII medium index
+        { 0xB3, CII_INDEX_MEDIUM },
+
+        // %10110100 to %10110111  CII large index
+        { 0xB7, CII_INDEX_LARGE },
+
+        // %10111000  CII very large index
+        { 0xB8, CII_INDEX_LARGE_LARGE },
+
+        // %10111001 to %11000111  ILLEGAL
+        { 0xC7, STATE_ILLEGAL },
+
+        // %11001000 to %11001011
+        { 0xCB, UNEXPANDED_ENTITY_REFERENCE_II },
+
+        // %11001100 to %11100000  ILLEGAL
+        { 0xE0, STATE_ILLEGAL },
+
+        // %11100001 processing instruction
+        { 0xE1, PROCESSING_INSTRUCTION_II },
+
+        // %11100010 comment
+        { 0xE2, COMMENT_II},
+
+        // %111000011 to %11101111
+        { 0xEF, STATE_ILLEGAL },
+
+        // Terminators
+
+        // %11110000  single terminator
+        { 0xF0, TERMINATOR_SINGLE },
+
+        // %11110000 to %11111110 ILLEGAL
+        { 0xFE, STATE_ILLEGAL },
+
+        // %11111111  double terminator
+        { 0xFF, TERMINATOR_DOUBLE }
+    };
+
+
+    // AII states
+    public final static int AII_INDEX_SMALL                 = 0;
+    public final static int AII_INDEX_MEDIUM                = 1;
+    public final static int AII_INDEX_LARGE                 = 2;
+    public final static int AII_LITERAL                     = 3;
+    public final static int AII_TERMINATOR_SINGLE           = 4;
+    public final static int AII_TERMINATOR_DOUBLE           = 5;
+
+    public static final int[] AII = new int[256];
+
+    private static int[][] AII_RANGES = {
+        // %00000000 to %00111111  AII small index
+        { 0x3F, AII_INDEX_SMALL },
+
+        // %01000000 to %01011111  AII medium index
+        { 0x5F, AII_INDEX_MEDIUM },
+
+        // %01100000 to %01101111  AII large index
+        { 0x6F, AII_INDEX_LARGE },
+
+        // %01110000 to %01110111  ILLEGAL
+        { 0x77, STATE_ILLEGAL },
+
+        // %01111000  AII literal (no prefix, no namespace)
+        // %01111001  AII literal (no prefix, namespace)
+        { 0x79, AII_LITERAL },
+
+        // %01111010  ILLEGAL
+        { 0x7A, STATE_ILLEGAL },
+
+        // %01111011  AII literal (prefix, namespace)
+        { 0x7B, AII_LITERAL },
+
+        // %10000000 to %11101111  ILLEGAL
+        { 0xEF, STATE_ILLEGAL },
+
+        // Terminators
+
+        // %11110000  single terminator
+        { 0xF0, AII_TERMINATOR_SINGLE },
+
+        // %11110000 to %11111110 ILLEGAL
+        { 0xFE, STATE_ILLEGAL },
+
+        // %11111111  double terminator
+        { 0xFF, AII_TERMINATOR_DOUBLE }
+    };
+
+
+    // AII value states
+    public final static int NISTRING_UTF8_SMALL_LENGTH     = 0;
+    public final static int NISTRING_UTF8_MEDIUM_LENGTH    = 1;
+    public final static int NISTRING_UTF8_LARGE_LENGTH     = 2;
+    public final static int NISTRING_UTF16_SMALL_LENGTH    = 3;
+    public final static int NISTRING_UTF16_MEDIUM_LENGTH   = 4;
+    public final static int NISTRING_UTF16_LARGE_LENGTH    = 5;
+    public final static int NISTRING_RA                    = 6;
+    public final static int NISTRING_EA                    = 7;
+    public final static int NISTRING_INDEX_SMALL           = 8;
+    public final static int NISTRING_INDEX_MEDIUM          = 9;
+    public final static int NISTRING_INDEX_LARGE           = 10;
+    public final static int NISTRING_EMPTY                 = 11;
+
+    public static final int[] NISTRING = new int[256];
+
+    private static int[][] NISTRING_RANGES = {
+        // UTF-8 string
+
+        // %00000000 to %00000111  UTF-8 no add to table small length
+        { 0x07, NISTRING_UTF8_SMALL_LENGTH },
+
+        // %00001000  UTF-8 no add to table medium length
+        { 0x08, NISTRING_UTF8_MEDIUM_LENGTH },
+
+        // %00001001 to %00001011 ILLEGAL
+        { 0x0B, STATE_ILLEGAL },
+
+        // %00001100  UTF-8 no add to table large length
+        { 0x0C, NISTRING_UTF8_LARGE_LENGTH },
+
+        // %00001101 to %00001111 ILLEGAL
+        { 0x0F, STATE_ILLEGAL },
+
+        // UTF-16 string
+
+        // %00010000 to %00010111  UTF-16 no add to table small length
+        { 0x17, NISTRING_UTF16_SMALL_LENGTH },
+
+        // %00001000  UTF-16 no add to table medium length
+        { 0x18, NISTRING_UTF16_MEDIUM_LENGTH },
+
+        // %00011001 to %00011011 ILLEGAL
+        { 0x1B, STATE_ILLEGAL },
+
+        // %00011100  UTF-16 no add to table large length
+        { 0x1C, NISTRING_UTF16_LARGE_LENGTH },
+
+        // %00011101 to %00011111 ILLEGAL
+        { 0x1F, STATE_ILLEGAL },
+
+        // Restricted alphabet
+
+        // %00100000 to %00101111  RA no add to table small length
+        { 0x2F, NISTRING_RA },
+
+        // Encoding algorithm
+
+        // %00110000 to %00111111  EA no add to table
+        { 0x3F, NISTRING_EA },
+
+        // UTF-8 string, add to table
+
+        // %01000000 to %01000111  UTF-8 add to table small length
+        { 0x47, NISTRING_UTF8_SMALL_LENGTH },
+
+        // %01001000  UTF-8 add to table medium length
+        { 0x48, NISTRING_UTF8_MEDIUM_LENGTH },
+
+        // %01001001 to %01001011 ILLEGAL
+        { 0x4B, STATE_ILLEGAL },
+
+        // %01001100  UTF-8 add to table large length
+        { 0x4C, NISTRING_UTF8_LARGE_LENGTH },
+
+        // %01001101 to %01001111 ILLEGAL
+        { 0x4F, STATE_ILLEGAL },
+
+        // UTF-16 string, add to table
+
+        // %01010000 to %01010111  UTF-16 add to table small length
+        { 0x57, NISTRING_UTF16_SMALL_LENGTH },
+
+        // %01001000  UTF-16 add to table medium length
+        { 0x58, NISTRING_UTF16_MEDIUM_LENGTH },
+
+        // %01011001 to %01011011 ILLEGAL
+        { 0x5B, STATE_ILLEGAL },
+
+        // %01011100  UTF-16 add to table large length
+        { 0x5C, NISTRING_UTF16_LARGE_LENGTH },
+
+        // %01011101 to %01011111 ILLEGAL
+        { 0x5F, STATE_ILLEGAL },
+
+        // Restricted alphabet, add to table
+
+        // %01100000 to %01101111  RA no add to table small length
+        { 0x6F, NISTRING_RA },
+
+        // Encoding algorithm, add to table
+
+        // %01110000 to %01111111  EA add to table
+        { 0x7F, NISTRING_EA },
+
+        // Index
+
+        // %10000000 to %10111111 index small
+        { 0xBF, NISTRING_INDEX_SMALL },
+
+        // %11000000 to %11011111 index medium
+        { 0xDF, NISTRING_INDEX_MEDIUM },
+
+        // %11100000 to %11101111 index large
+        { 0xEF, NISTRING_INDEX_LARGE },
+
+        // %11110000 to %11111110 ILLEGAL
+        { 0xFE, STATE_ILLEGAL },
+
+        // %11111111 Empty value
+        { 0xFF, NISTRING_EMPTY },
+    };
+
+
+    public final static int ISTRING_SMALL_LENGTH        = 0;
+    public final static int ISTRING_MEDIUM_LENGTH       = 1;
+    public final static int ISTRING_LARGE_LENGTH        = 2;
+    public final static int ISTRING_INDEX_SMALL         = 3;
+    public final static int ISTRING_INDEX_MEDIUM        = 4;
+    public final static int ISTRING_INDEX_LARGE         = 5;
+
+    public static final int[] ISTRING = new int[256];
+
+    private static int[][] ISTRING_RANGES = {
+        // %00000000 to %00111111 small length
+        { 0x3F, ISTRING_SMALL_LENGTH },
+
+        // %01000000 medium length
+        { 0x40, ISTRING_MEDIUM_LENGTH },
+
+        // %01000001 to %01011111 ILLEGAL
+        { 0x5F, STATE_ILLEGAL },
+
+        // %01100000 large length
+        { 0x60, ISTRING_LARGE_LENGTH },
+
+        // %01100001 to %01111111 ILLEGAL
+        { 0x7F, STATE_ILLEGAL },
+
+        // %10000000 to %10111111 index small
+        { 0xBF, ISTRING_INDEX_SMALL },
+
+        // %11000000 to %11011111 index medium
+        { 0xDF, ISTRING_INDEX_MEDIUM },
+
+        // %11100000 to %11101111 index large
+        { 0xEF, ISTRING_INDEX_LARGE },
+
+        // %11110000 to %11111111 ILLEGAL
+        { 0xFF, STATE_ILLEGAL },
+    };
+
+
+    public final static int ISTRING_PREFIX_NAMESPACE_LENGTH_3   = 6;
+    public final static int ISTRING_PREFIX_NAMESPACE_LENGTH_5   = 7;
+    public final static int ISTRING_PREFIX_NAMESPACE_LENGTH_29  = 8;
+    public final static int ISTRING_PREFIX_NAMESPACE_LENGTH_36  = 9;
+    public final static int ISTRING_PREFIX_NAMESPACE_INDEX_ZERO = 10;
+
+    public static final int[] ISTRING_PREFIX_NAMESPACE = new int[256];
+
+    private static int[][] ISTRING_PREFIX_NAMESPACE_RANGES = {
+        // %00000000 to %00000001 small length
+        { 0x01, ISTRING_SMALL_LENGTH },
+
+        // %00000010 small length
+        { 0x02, ISTRING_PREFIX_NAMESPACE_LENGTH_3 },
+
+        // %00000011 small length
+        { 0x03, ISTRING_SMALL_LENGTH },
+
+        // %00000100 small length
+        { 0x04, ISTRING_PREFIX_NAMESPACE_LENGTH_5 },
+
+        // %00011011 small length
+        { 0x1B, ISTRING_SMALL_LENGTH },
+
+        // %00011100 small length
+        { 0x1C, ISTRING_PREFIX_NAMESPACE_LENGTH_29 },
+
+        // %00100010 small length
+        { 0x22, ISTRING_SMALL_LENGTH },
+
+        // %00100011 small length
+        { 0x23, ISTRING_PREFIX_NAMESPACE_LENGTH_36 },
+
+        // %00000101 to %00111111 small length
+        { 0x3F, ISTRING_SMALL_LENGTH },
+
+
+
+
+        // %01000000 medium length
+        { 0x40, ISTRING_MEDIUM_LENGTH },
+
+        // %01000001 to %01011111 ILLEGAL
+        { 0x5F, STATE_ILLEGAL },
+
+        // %01100000 large length
+        { 0x60, ISTRING_LARGE_LENGTH },
+
+        // %01100001 to %01111111 ILLEGAL
+        { 0x7F, STATE_ILLEGAL },
+
+        // %10000000 index small, 0
+        { 0x80, ISTRING_PREFIX_NAMESPACE_INDEX_ZERO },
+
+        // %10000000 to %10111111 index small
+        { 0xBF, ISTRING_INDEX_SMALL },
+
+        // %11000000 to %11011111 index medium
+        { 0xDF, ISTRING_INDEX_MEDIUM },
+
+        // %11100000 to %11101111 index large
+        { 0xEF, ISTRING_INDEX_LARGE },
+
+        // %11110000 to %11111111 ILLEGAL
+        { 0xFF, STATE_ILLEGAL },
+    };
+
+    // UTF-8 states
+    public final static int UTF8_NCNAME_NCNAME         = 0;
+    public final static int UTF8_NCNAME_NCNAME_CHAR    = 1;
+    public final static int UTF8_TWO_BYTES             = 2;
+    public final static int UTF8_THREE_BYTES           = 3;
+    public final static int UTF8_FOUR_BYTES            = 4;
+
+    public static final int[] UTF8_NCNAME = new int[256];
+
+    private static int[][] UTF8_NCNAME_RANGES = {
+
+        // Basic Latin
+
+        // %00000000 to %00101100
+        { 0x2C, STATE_ILLEGAL },
+
+        // '-' '.'
+        // %%00101101 to %00101110 [#x002D-#x002E]
+        { 0x2E, UTF8_NCNAME_NCNAME_CHAR },
+
+        // %00101111
+        { 0x2F, STATE_ILLEGAL },
+
+        // [0-9]
+        // %0011000 to %00111001  [#x0030-#x0039]
+        { 0x39, UTF8_NCNAME_NCNAME_CHAR },
+
+        // %01000000
+        { 0x40, STATE_ILLEGAL },
+
+        // [A-Z]
+        // %01000001 to %01011010 [#x0041-#x005A]
+        { 0x5A, UTF8_NCNAME_NCNAME },
+
+        // %01011110
+        { 0x5E, STATE_ILLEGAL },
+
+        // '_'
+        // %01011111 [#x005F]
+        { 0x5F, UTF8_NCNAME_NCNAME },
+
+        // %01100000
+        { 0x60, STATE_ILLEGAL },
+
+        // [a-z]
+        // %01100001 to %01111010 [#x0061-#x007A]
+        { 0x7A, UTF8_NCNAME_NCNAME },
+
+        // %01111011 to %01111111
+        { 0x7F, STATE_ILLEGAL },
+
+
+        // Two bytes
+
+        // %10000000 to %11000001
+        { 0xC1, STATE_ILLEGAL },
+
+        // %11000010 to %11011111
+        { 0xDF, UTF8_TWO_BYTES },
+
+
+        // Three bytes
+
+        // %11100000 to %11101111
+        { 0xEF, UTF8_THREE_BYTES },
+
+
+        // Four bytes
+
+        // %11110000 to %11110111
+        { 0xF7, UTF8_FOUR_BYTES },
+
+
+        // %11111000 to %11111111
+        { 0xFF, STATE_ILLEGAL }
+    };
+
+    public final static int UTF8_ONE_BYTE              = 1;
+
+    public static final int[] UTF8 = new int[256];
+
+    private static int[][] UTF8_RANGES = {
+
+        // Basic Latin
+
+        // %00000000 to %00001000
+        { 0x08, STATE_ILLEGAL },
+
+        // CHARACTER TABULATION, LINE FEED
+        // %%00001001 to %00001010 [#x0009-#x000A]
+        { 0x0A, UTF8_ONE_BYTE },
+
+        // %00001011 to %00001100
+        { 0x0C, STATE_ILLEGAL },
+
+        // CARRIAGE RETURN
+        // %00001101 [#x000D]
+        { 0x0D, UTF8_ONE_BYTE },
+
+        // %00001110 to %00011111
+        { 0x1F, STATE_ILLEGAL },
+
+        // %0010000 to %01111111
+        { 0x7F, UTF8_ONE_BYTE },
+
+
+        // Two bytes
+
+        // %10000000 to %11000001
+        { 0xC1, STATE_ILLEGAL },
+
+        // %11000010 to %11011111
+        { 0xDF, UTF8_TWO_BYTES },
+
+
+        // Three bytes
+
+        // %11100000 to %11101111
+        { 0xEF, UTF8_THREE_BYTES },
+
+
+        // Four bytes
+
+        // %11110000 to %11110111
+        { 0xF7, UTF8_FOUR_BYTES },
+
+
+        // %11111000 to %11111111
+        { 0xFF, STATE_ILLEGAL }
+    };
+
+    private static void constructTable(int[] table, int[][] ranges) {
+        int start = 0x00;
+        for (int range = 0; range < ranges.length; range++) {
+            int end = ranges[range][RANGE_INDEX_END];
+            int value = ranges[range][RANGE_INDEX_VALUE];
+            for (int i = start; i<= end; i++) {
+                table[i] = value;
+            }
+            start = end + 1;
+        }
+    }
+
+    static {
+        // EII
+        constructTable(DII, DII_RANGES);
+
+        // EII
+        constructTable(EII, EII_RANGES);
+
+        // AII
+        constructTable(AII, AII_RANGES);
+
+        // AII Value
+        constructTable(NISTRING, NISTRING_RANGES);
+
+        // Identifying string
+        constructTable(ISTRING, ISTRING_RANGES);
+
+        // Identifying string
+        constructTable(ISTRING_PREFIX_NAMESPACE, ISTRING_PREFIX_NAMESPACE_RANGES);
+
+        // UTF-8 NCNAME states
+        constructTable(UTF8_NCNAME, UTF8_NCNAME_RANGES);
+
+        // UTF-8 states
+        constructTable(UTF8, UTF8_RANGES);
+    }
+
+    private DecoderStateTables() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Encoder.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Encoder.java
new file mode 100644
index 0000000..8027ea0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Encoder.java
@@ -0,0 +1,2155 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+package com.sun.xml.internal.fastinfoset;
+
+import com.sun.xml.internal.fastinfoset.algorithm.BuiltInEncodingAlgorithm;
+import com.sun.xml.internal.fastinfoset.algorithm.BuiltInEncodingAlgorithmFactory;
+import com.sun.xml.internal.fastinfoset.org.apache.xerces.util.XMLChar;
+import com.sun.xml.internal.fastinfoset.util.CharArrayIntMap;
+import com.sun.xml.internal.fastinfoset.util.KeyIntMap;
+import com.sun.xml.internal.fastinfoset.util.LocalNameQualifiedNamesMap;
+import com.sun.xml.internal.fastinfoset.util.StringIntMap;
+import com.sun.xml.internal.fastinfoset.vocab.SerializerVocabulary;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.HashMap;
+import java.util.Map;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithm;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import com.sun.xml.internal.org.jvnet.fastinfoset.ExternalVocabulary;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSerializer;
+import org.xml.sax.helpers.DefaultHandler;
+
+/**
+ * Abstract encoder for developing concrete encoders.
+ *
+ * Concrete implementations extending Encoder will utilize methods on Encoder
+ * to encode XML infoset according to the Fast Infoset standard. It is the
+ * responsibility of the concrete implementation to ensure that methods are
+ * invoked in the correct order to produce a valid fast infoset document.
+ *
+ * <p>
+ * This class extends org.sax.xml.DefaultHandler so that concrete SAX
+ * implementations can be used with javax.xml.parsers.SAXParser and the parse
+ * methods that take org.sax.xml.DefaultHandler as a parameter.
+ *
+ * <p>
+ * Buffering of octets that are written to an {@link java.io.OutputStream} is
+ * supported in a similar manner to a {@link java.io.BufferedOutputStream}.
+ * Combining buffering with encoding enables better performance.
+ *
+ * <p>
+ * More than one fast infoset document may be encoded to the
+ * {@link java.io.OutputStream}.
+ *
+ */
+public abstract class Encoder extends DefaultHandler implements FastInfosetSerializer {
+
+    /**
+     * Character encoding scheme system property for the encoding
+     * of content and attribute values.
+     */
+    public static final String CHARACTER_ENCODING_SCHEME_SYSTEM_PROPERTY =
+        "com.sun.xml.internal.fastinfoset.serializer.character-encoding-scheme";
+
+    /**
+     * Default character encoding scheme system property for the encoding
+     * of content and attribute values.
+     */
+    protected static String _characterEncodingSchemeSystemDefault = UTF_8;
+
+    static {
+        // Initiate the default character encoding schema from the system
+        // property
+        String p = System.getProperty(CHARACTER_ENCODING_SCHEME_SYSTEM_PROPERTY,
+            _characterEncodingSchemeSystemDefault);
+        if (p.equals(UTF_16BE)) {
+            _characterEncodingSchemeSystemDefault = UTF_16BE;
+        }
+    }
+
+    /**
+     * True if comments shall be ignored.
+     */
+    private boolean _ignoreComments;
+
+    /**
+     * True if procesing instructions shall be ignored.
+     */
+    private boolean _ignoreProcessingInstructions;
+
+    /**
+     * True if white space characters for text content shall be ignored.
+     */
+    private boolean _ignoreWhiteSpaceTextContent;
+
+    /**
+     * True, if the local name string is used as the key to find the
+     * associated set of qualified names.
+     * <p>
+     * False,  if the <prefix>:<local name> string is used as the key
+     * to find the associated set of qualified names.
+     */
+    private boolean _useLocalNameAsKeyForQualifiedNameLookup;
+
+    /**
+     * True if strings for text content and attribute values will be
+     * UTF-8 encoded otherwise they will be UTF-16 encoded.
+     */
+    private boolean _encodingStringsAsUtf8 = true;
+
+    /**
+     * Encoding constant generated from the string encoding.
+     */
+    private int _nonIdentifyingStringOnThirdBitCES;
+
+    /**
+     * Encoding constant generated from the string encoding.
+     */
+    private int _nonIdentifyingStringOnFirstBitCES;
+
+    /**
+     * The map of URIs to algorithms.
+     */
+    private Map _registeredEncodingAlgorithms = new HashMap();
+
+    /**
+     * The vocabulary that is used by the encoder
+     */
+    protected SerializerVocabulary _v;
+
+    /**
+     * True if the vocubulary is internal to the encoder
+     */
+    private boolean _vIsInternal;
+
+    /**
+     * True if terminatation of an information item is required
+     */
+    protected boolean _terminate = false;
+
+    /**
+     * The current octet that is to be written.
+     */
+    protected int _b;
+
+    /**
+     * The {@link java.io.OutputStream} that the encoded XML infoset (the
+     * fast infoset document) is written to.
+     */
+    protected OutputStream _s;
+
+    /**
+     * The internal buffer of characters used for the UTF-8 or UTF-16 encoding
+     * of characters.
+     */
+    protected char[] _charBuffer = new char[512];
+
+    /**
+     * The internal buffer of bytes.
+     */
+    protected byte[] _octetBuffer = new byte[1024];
+
+    /**
+     * The current position in the internal buffer.
+     */
+    protected int _octetBufferIndex;
+
+    /**
+     * The current mark in the internal buffer.
+     *
+     * <p>
+     * If the value of the mark is < 0 then the mark is not set.
+     */
+    protected int _markIndex = -1;
+
+    /**
+     * The limit on the size of [normalized value] of Attribute Information
+     * Items that will be indexed.
+     */
+    protected int attributeValueSizeConstraint = FastInfosetSerializer.ATTRIBUTE_VALUE_SIZE_CONSTRAINT;
+
+    /**
+     * The limit on the size of character content chunks
+     * of Character Information Items or Comment Information Items that
+     * will be indexed.
+     */
+    protected int characterContentChunkSizeContraint = FastInfosetSerializer.CHARACTER_CONTENT_CHUNK_SIZE_CONSTRAINT;
+
+
+    /**
+     * Default constructor for the Encoder.
+     */
+    protected Encoder() {
+        setCharacterEncodingScheme(_characterEncodingSchemeSystemDefault);
+    }
+
+    protected Encoder(boolean useLocalNameAsKeyForQualifiedNameLookup) {
+        setCharacterEncodingScheme(_characterEncodingSchemeSystemDefault);
+        _useLocalNameAsKeyForQualifiedNameLookup = useLocalNameAsKeyForQualifiedNameLookup;
+    }
+
+
+    // FastInfosetSerializer interface
+
+    /**
+     * {@inheritDoc}
+     */
+    public final void setIgnoreComments(boolean ignoreComments) {
+        _ignoreComments = ignoreComments;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public final boolean getIgnoreComments() {
+        return _ignoreComments;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public final void setIgnoreProcesingInstructions(boolean
+            ignoreProcesingInstructions) {
+        _ignoreProcessingInstructions = ignoreProcesingInstructions;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public final boolean getIgnoreProcesingInstructions() {
+        return _ignoreProcessingInstructions;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public final void setIgnoreWhiteSpaceTextContent(boolean ignoreWhiteSpaceTextContent) {
+        _ignoreWhiteSpaceTextContent = ignoreWhiteSpaceTextContent;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public final boolean getIgnoreWhiteSpaceTextContent() {
+        return _ignoreWhiteSpaceTextContent;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setCharacterEncodingScheme(String characterEncodingScheme) {
+        if (characterEncodingScheme.equals(UTF_16BE)) {
+            _encodingStringsAsUtf8 = false;
+            _nonIdentifyingStringOnThirdBitCES = EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_UTF_16_FLAG;
+            _nonIdentifyingStringOnFirstBitCES = EncodingConstants.NISTRING_UTF_16_FLAG;
+        } else {
+            _encodingStringsAsUtf8 = true;
+            _nonIdentifyingStringOnThirdBitCES = EncodingConstants.CHARACTER_CHUNK;
+            _nonIdentifyingStringOnFirstBitCES = 0;
+        }
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public String getCharacterEncodingScheme() {
+        return (_encodingStringsAsUtf8) ? UTF_8 : UTF_16BE;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setRegisteredEncodingAlgorithms(Map algorithms) {
+        _registeredEncodingAlgorithms = algorithms;
+        if (_registeredEncodingAlgorithms == null) {
+            _registeredEncodingAlgorithms = new HashMap();
+        }
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public Map getRegisteredEncodingAlgorithms() {
+        return _registeredEncodingAlgorithms;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setCharacterContentChunkSizeLimit(int size) {
+        if (size < 0 ) {
+            size = 0;
+        }
+
+        characterContentChunkSizeContraint = size;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public int getCharacterContentChunkSizeLimit() {
+        return characterContentChunkSizeContraint;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setAttributeValueSizeLimit(int size) {
+        if (size < 0 ) {
+            size = 0;
+        }
+
+        attributeValueSizeConstraint = size;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public int getAttributeValueSizeLimit() {
+        return attributeValueSizeConstraint;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public void setExternalVocabulary(ExternalVocabulary v) {
+        // Create internal serializer vocabulary
+        _v = new SerializerVocabulary();
+        // Set the external vocabulary
+        SerializerVocabulary ev = new SerializerVocabulary(v.vocabulary,
+                _useLocalNameAsKeyForQualifiedNameLookup);
+        _v.setExternalVocabulary(v.URI,
+                ev, false);
+
+        _vIsInternal = true;
+    }
+
+    // End of FastInfosetSerializer interface
+
+    /**
+     * Reset the encoder for reuse encoding another XML infoset.
+     */
+    public void reset() {
+        _terminate = false;
+    }
+
+    /**
+     * Set the OutputStream to encode the XML infoset to a
+     * fast infoset document.
+     *
+     * @param s the OutputStream where the fast infoset document is written to.
+     */
+    public void setOutputStream(OutputStream s) {
+        _octetBufferIndex = 0;
+        _markIndex = -1;
+        _s = s;
+    }
+
+    /**
+     * Set the SerializerVocabulary to be used for encoding.
+     *
+     * @param vocabulary the vocabulary to be used for encoding.
+     */
+    public void setVocabulary(SerializerVocabulary vocabulary) {
+        _v = vocabulary;
+        _vIsInternal = false;
+    }
+
+    /**
+     * Encode the header of a fast infoset document.
+     *
+     * @param encodeXmlDecl true if the XML declaration should be encoded.
+     */
+    protected final void encodeHeader(boolean encodeXmlDecl) throws IOException {
+        if (encodeXmlDecl) {
+            _s.write(EncodingConstants.XML_DECLARATION_VALUES[0]);
+        }
+        _s.write(EncodingConstants.BINARY_HEADER);
+    }
+
+    /**
+     * Encode the initial vocabulary of a fast infoset document.
+     *
+     */
+    protected final void encodeInitialVocabulary() throws IOException {
+        if (_v == null) {
+            _v = new SerializerVocabulary();
+            _vIsInternal = true;
+        } else if (_vIsInternal) {
+            _v.clear();
+        }
+
+        if (_v.hasInitialVocabulary()) {
+            _b = EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG;
+            write(_b);
+
+            SerializerVocabulary initialVocabulary = _v.getReadOnlyVocabulary();
+
+            // TODO check for contents of vocabulary to assign bits
+            if (initialVocabulary.hasExternalVocabulary()) {
+                _b = EncodingConstants.INITIAL_VOCABULARY_EXTERNAL_VOCABULARY_FLAG;
+                write(_b);
+                write(0);
+            }
+
+            if (initialVocabulary.hasExternalVocabulary()) {
+                encodeNonEmptyOctetStringOnSecondBit(_v.getExternalVocabularyURI().toString());
+            }
+
+            // TODO check for contents of vocabulary to encode values
+        } else if (_v.hasExternalVocabulary()) {
+            _b = EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG;
+            write(_b);
+
+            _b = EncodingConstants.INITIAL_VOCABULARY_EXTERNAL_VOCABULARY_FLAG;
+            write(_b);
+            write(0);
+
+            encodeNonEmptyOctetStringOnSecondBit(_v.getExternalVocabularyURI().toString());
+        } else {
+            write(0);
+        }
+    }
+
+    /**
+     * Encode the termination of the Document Information Item.
+     *
+     */
+    protected final void encodeDocumentTermination() throws IOException {
+        encodeElementTermination();
+        encodeTermination();
+        _flush();
+        _s.flush();
+    }
+
+    /**
+     * Encode the termination of an Element Information Item.
+     *
+     */
+    protected final void encodeElementTermination() throws IOException {
+        _terminate = true;
+        switch (_b) {
+            case EncodingConstants.TERMINATOR:
+                _b = EncodingConstants.DOUBLE_TERMINATOR;
+                break;
+            case EncodingConstants.DOUBLE_TERMINATOR:
+                write(EncodingConstants.DOUBLE_TERMINATOR);
+            default:
+                _b = EncodingConstants.TERMINATOR;
+        }
+    }
+
+    /**
+     * Encode a termination if required.
+     *
+     */
+    protected final void encodeTermination() throws IOException {
+        if (_terminate) {
+            write(_b);
+            _terminate = false;
+        }
+    }
+
+    /**
+     * Encode a Attribute Information Item that is a namespace declaration.
+     *
+     * @param prefix the prefix of the namespace declaration,
+     * if "" then there is no prefix for the namespace declaration.
+     * @param uri the URI of the namespace declaration,
+     * if "" then there is no URI for the namespace declaration.
+     */
+    protected final void encodeNamespaceAttribute(String prefix, String uri) throws IOException {
+        _b = EncodingConstants.NAMESPACE_ATTRIBUTE;
+        if (prefix != "") {
+            _b |= EncodingConstants.NAMESPACE_ATTRIBUTE_PREFIX_FLAG;
+        }
+        if (uri != "") {
+            _b |= EncodingConstants.NAMESPACE_ATTRIBUTE_NAME_FLAG;
+        }
+
+        // NOTE a prefix with out a namespace name is an undeclaration
+        // of the namespace bound to the prefix
+        // TODO needs to investigate how the startPrefixMapping works in
+        // relation to undeclaration
+
+        write(_b);
+
+        if (prefix != "") {
+            encodeIdentifyingNonEmptyStringOnFirstBit(prefix, _v.prefix);
+        }
+        if (uri != "") {
+            encodeIdentifyingNonEmptyStringOnFirstBit(uri, _v.namespaceName);
+        }
+    }
+
+    /**
+     * Encode a chunk of Character Information Items.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     * @throws ArrayIndexOutOfBoundsException.
+     */
+    protected final void encodeCharacters(char[] ch, int offset, int length) throws IOException {
+        final boolean addToTable = (length < characterContentChunkSizeContraint) ? true : false;
+        encodeNonIdentifyingStringOnThirdBit(ch, offset, length, _v.characterContentChunk, addToTable, true);
+    }
+
+    /**
+     * Encode a chunk of Character Information Items.
+     *
+     * If the array of characters is to be indexed (as determined by
+     * {@link Encoder#characterContentChunkSizeContraint}) then the array is not cloned
+     * when adding the array to the vocabulary.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     * @throws ArrayIndexOutOfBoundsException.
+     */
+    protected final void encodeCharactersNoClone(char[] ch, int offset, int length) throws IOException {
+        final boolean addToTable = (length < characterContentChunkSizeContraint) ? true : false;
+        encodeNonIdentifyingStringOnThirdBit(ch, offset, length, _v.characterContentChunk, addToTable, false);
+    }
+
+    /**
+     * Encode a chunk of Character Information Items using a restricted
+     * alphabet that results in the encoding of a character in 4 bits
+     * (or two characters per octet).
+     *
+     * @param id the restricted alphabet identifier.
+     * @param table the table mapping characters to 4 bit values.
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     * @throws ArrayIndexOutOfBoundsException.
+     */
+    protected final void encodeFourBitCharacters(int id, int[] table, char[] ch, int offset, int length) throws FastInfosetException, IOException {
+        // This procedure assumes that id <= 64
+        _b = (length < characterContentChunkSizeContraint) ?
+            EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_RESTRICTED_ALPHABET_FLAG | EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG :
+            EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_RESTRICTED_ALPHABET_FLAG;
+        write (_b);
+
+        // Encode bottom 6 bits of enoding algorithm id
+        _b = id << 2;
+
+        encodeNonEmptyFourBitCharacterStringOnSeventhBit(table, ch, offset, length);
+    }
+
+    /**
+     * Encode a chunk of Character Information Items using a restricted
+     * alphabet table.
+     *
+     * @param alphabet the alphabet defining the mapping between characters and
+     *        integer values.
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     * @throws ArrayIndexOutOfBoundsException.
+     * @throws FastInfosetException if the alphabet is not present in the
+     *         vocabulary.
+     */
+    protected final void encodeAlphabetCharacters(String alphabet, char[] ch, int offset, int length) throws FastInfosetException, IOException {
+        int id = _v.restrictedAlphabet.get(alphabet);
+        if (id == KeyIntMap.NOT_PRESENT) {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.restrictedAlphabetNotPresent"));
+        }
+        id += EncodingConstants.RESTRICTED_ALPHABET_APPLICATION_START;
+
+        _b = (length < characterContentChunkSizeContraint) ?
+            EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_RESTRICTED_ALPHABET_FLAG | EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG :
+            EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_RESTRICTED_ALPHABET_FLAG;
+        _b |= (id & 0xC0) >> 6;
+        write (_b);
+
+        // Encode bottom 6 bits of enoding algorithm id
+        _b = (id & 0x3F) << 2;
+
+        encodeNonEmptyNBitCharacterStringOnSeventhBit(alphabet, ch, offset, length);
+    }
+
+    /**
+     * Encode a Processing Instruction Information Item.
+     *
+     * @param target the target of the processing instruction.
+     * @param data the data of the processing instruction.
+     */
+    protected final void encodeProcessingInstruction(String target, String data) throws IOException {
+        write(EncodingConstants.PROCESSING_INSTRUCTION);
+
+        // Target
+        encodeIdentifyingNonEmptyStringOnFirstBit(target, _v.otherNCName);
+
+        // Data
+        boolean addToTable = (data.length() < characterContentChunkSizeContraint) ? true : false;
+        encodeNonIdentifyingStringOnFirstBit(data, _v.otherString, addToTable);
+    }
+
+    /**
+     * Encode a Comment Information Item.
+     *
+     * @param ch the array of characters that is as comment.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     * @throws ArrayIndexOutOfBoundsException.
+     */
+    protected final void encodeComment(char[] ch, int offset, int length) throws IOException {
+        write(EncodingConstants.COMMENT);
+
+        boolean addToTable = (length < characterContentChunkSizeContraint) ? true : false;
+        encodeNonIdentifyingStringOnFirstBit(ch, offset, length, _v.otherString, addToTable, true);
+    }
+
+    /**
+     * Encode a Comment Information Item.
+     *
+     * If the array of characters that is a comment is to be indexed (as
+     * determined by {@link Encoder#characterContentChunkSizeContraint}) then
+     * the array is not cloned when adding the array to the vocabulary.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     * @throws ArrayIndexOutOfBoundsException.
+     */
+    protected final void encodeCommentNoClone(char[] ch, int offset, int length) throws IOException {
+        write(EncodingConstants.COMMENT);
+
+        boolean addToTable = (length < characterContentChunkSizeContraint) ? true : false;
+        encodeNonIdentifyingStringOnFirstBit(ch, offset, length, _v.otherString, addToTable, false);
+    }
+
+    /**
+     * Encode a qualified name of an Element Informaiton Item on the third bit
+     * of an octet.
+     * Implementation of clause C.18 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * <p>
+     * The index of the qualified name will be encoded if the name is present
+     * in the vocabulary otherwise the qualified name will be encoded literally
+     * (see {@link #encodeLiteralElementQualifiedNameOnThirdBit}).
+     *
+     * @param namespaceURI the namespace URI of the qualified name.
+     * @param prefix the prefix of the qualified name.
+     * @param localName the local name of the qualified name.
+     */
+    protected final void encodeElementQualifiedNameOnThirdBit(String namespaceURI, String prefix, String localName) throws IOException {
+        LocalNameQualifiedNamesMap.Entry entry = _v.elementName.obtainEntry(localName);
+        if (entry._valueIndex > 0) {
+            QualifiedName[] names = entry._value;
+            for (int i = 0; i < entry._valueIndex; i++) {
+                if ((prefix == names[i].prefix || prefix.equals(names[i].prefix))
+                        && (namespaceURI == names[i].namespaceName || namespaceURI.equals(names[i].namespaceName))) {
+                    encodeNonZeroIntegerOnThirdBit(names[i].index);
+                    return;
+                }
+            }
+        }
+
+        encodeLiteralElementQualifiedNameOnThirdBit(namespaceURI, prefix,
+                localName, entry);
+    }
+
+    /**
+     * Encode a literal qualified name of an Element Informaiton Item on the
+     * third bit of an octet.
+     * Implementation of clause C.18 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param namespaceURI the namespace URI of the qualified name.
+     * @param prefix the prefix of the qualified name.
+     * @param localName the local name of the qualified name.
+     */
+    protected final void encodeLiteralElementQualifiedNameOnThirdBit(String namespaceURI, String prefix, String localName,
+            LocalNameQualifiedNamesMap.Entry entry) throws IOException {
+        QualifiedName name = new QualifiedName(prefix, namespaceURI, localName, "", _v.elementName.getNextIndex());
+        entry.addQualifiedName(name);
+
+        int namespaceURIIndex = KeyIntMap.NOT_PRESENT;
+        int prefixIndex = KeyIntMap.NOT_PRESENT;
+        if (namespaceURI != "") {
+            namespaceURIIndex = _v.namespaceName.get(namespaceURI);
+            if (namespaceURIIndex == KeyIntMap.NOT_PRESENT) {
+                throw new IOException(CommonResourceBundle.getInstance().getString("message.namespaceURINotIndexed", new Object[]{namespaceURI}));
+            }
+
+            if (prefix != "") {
+                prefixIndex = _v.prefix.get(prefix);
+                if (prefixIndex == KeyIntMap.NOT_PRESENT) {
+                    throw new IOException(CommonResourceBundle.getInstance().getString("message.prefixNotIndexed", new Object[]{prefix}));
+                }
+            }
+        }
+
+        int localNameIndex = _v.localName.obtainIndex(localName);
+
+        _b |= EncodingConstants.ELEMENT_LITERAL_QNAME_FLAG;
+        if (namespaceURIIndex >= 0) {
+            _b |= EncodingConstants.LITERAL_QNAME_NAMESPACE_NAME_FLAG;
+            if (prefixIndex >= 0) {
+                _b |= EncodingConstants.LITERAL_QNAME_PREFIX_FLAG;
+            }
+        }
+        write(_b);
+
+        if (namespaceURIIndex >= 0) {
+            if (prefixIndex >= 0) {
+                encodeNonZeroIntegerOnSecondBitFirstBitOne(prefixIndex);
+            }
+            encodeNonZeroIntegerOnSecondBitFirstBitOne(namespaceURIIndex);
+        }
+
+        if (localNameIndex >= 0) {
+            encodeNonZeroIntegerOnSecondBitFirstBitOne(localNameIndex);
+        } else {
+            encodeNonEmptyOctetStringOnSecondBit(localName);
+        }
+    }
+
+    /**
+     * Encode a qualified name of an Attribute Informaiton Item on the third bit
+     * of an octet.
+     * Implementation of clause C.17 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * <p>
+     * The index of the qualified name will be encoded if the name is present
+     * in the vocabulary otherwise the qualified name will be encoded literally
+     * (see {@link #encodeLiteralAttributeQualifiedNameOnSecondBit}).
+     *
+     * @param namespaceURI the namespace URI of the qualified name.
+     * @param prefix the prefix of the qualified name.
+     * @param localName the local name of the qualified name.
+     */
+    protected final void encodeAttributeQualifiedNameOnSecondBit(String namespaceURI, String prefix, String localName) throws IOException {
+        LocalNameQualifiedNamesMap.Entry entry = _v.attributeName.obtainEntry(localName);
+        if (entry._valueIndex > 0) {
+            QualifiedName[] names = entry._value;
+            for (int i = 0; i < entry._valueIndex; i++) {
+                if ((prefix == names[i].prefix || prefix.equals(names[i].prefix))
+                        && (namespaceURI == names[i].namespaceName || namespaceURI.equals(names[i].namespaceName))) {
+                    encodeNonZeroIntegerOnSecondBitFirstBitZero(names[i].index);
+                    return;
+                }
+            }
+        }
+
+        encodeLiteralAttributeQualifiedNameOnSecondBit(namespaceURI, prefix,
+                localName, entry);
+    }
+
+    /**
+     * Encode a literal qualified name of an Attribute Informaiton Item on the
+     * third bit of an octet.
+     * Implementation of clause C.17 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param namespaceURI the namespace URI of the qualified name.
+     * @param prefix the prefix of the qualified name.
+     * @param localName the local name of the qualified name.
+     */
+    protected final boolean encodeLiteralAttributeQualifiedNameOnSecondBit(String namespaceURI, String prefix, String localName,
+                LocalNameQualifiedNamesMap.Entry entry) throws IOException {
+        int namespaceURIIndex = KeyIntMap.NOT_PRESENT;
+        int prefixIndex = KeyIntMap.NOT_PRESENT;
+        if (namespaceURI != "") {
+            namespaceURIIndex = _v.namespaceName.get(namespaceURI);
+            if (namespaceURIIndex == KeyIntMap.NOT_PRESENT) {
+                if (namespaceURI == EncodingConstants.XMLNS_NAMESPACE_NAME ||
+                        namespaceURI.equals(EncodingConstants.XMLNS_NAMESPACE_NAME)) {
+                    return false;
+                } else {
+                    throw new IOException(CommonResourceBundle.getInstance().getString("message.namespaceURINotIndexed", new Object[]{namespaceURI}));
+                }
+            }
+
+            if (prefix != "") {
+                prefixIndex = _v.prefix.get(prefix);
+                if (prefixIndex == KeyIntMap.NOT_PRESENT) {
+                    throw new IOException(CommonResourceBundle.getInstance().getString("message.prefixNotIndexed", new Object[]{prefix}));
+                }
+            }
+        }
+
+        int localNameIndex = _v.localName.obtainIndex(localName);
+
+        QualifiedName name = new QualifiedName(prefix, namespaceURI, localName, "", _v.attributeName.getNextIndex());
+        entry.addQualifiedName(name);
+
+        _b = EncodingConstants.ATTRIBUTE_LITERAL_QNAME_FLAG;
+        if (namespaceURI != "") {
+            _b |= EncodingConstants.LITERAL_QNAME_NAMESPACE_NAME_FLAG;
+            if (prefix != "") {
+                _b |= EncodingConstants.LITERAL_QNAME_PREFIX_FLAG;
+            }
+        }
+
+        write(_b);
+
+        if (namespaceURIIndex >= 0) {
+            if (prefixIndex >= 0) {
+                encodeNonZeroIntegerOnSecondBitFirstBitOne(prefixIndex);
+            }
+            encodeNonZeroIntegerOnSecondBitFirstBitOne(namespaceURIIndex);
+        } else if (namespaceURI != "") {
+            // XML prefix and namespace name
+            encodeNonEmptyOctetStringOnSecondBit("xml");
+            encodeNonEmptyOctetStringOnSecondBit("http://www.w3.org/XML/1998/namespace");
+        }
+
+        if (localNameIndex >= 0) {
+            encodeNonZeroIntegerOnSecondBitFirstBitOne(localNameIndex);
+        } else {
+            encodeNonEmptyOctetStringOnSecondBit(localName);
+        }
+
+        return true;
+    }
+
+    /**
+     * Encode a non identifying string on the first bit of an octet.
+     * Implementation of clause C.14 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param s the string to encode
+     * @param map the vocabulary table of strings to indexes.
+     * @param addToTable true if the string should be added to the vocabulary
+     *                   table (if not already present in the table).
+     */
+    protected final void encodeNonIdentifyingStringOnFirstBit(String s, StringIntMap map, boolean addToTable) throws IOException {
+        if (s == null || s.length() == 0) {
+            // C.26 an index (first bit '1') with seven '1' bits for an empty string
+            write(0xFF);
+        } else {
+            if (addToTable) {
+                int index = map.obtainIndex(s);
+                if (index == KeyIntMap.NOT_PRESENT) {
+                    _b = EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG | _nonIdentifyingStringOnFirstBitCES;
+                    encodeNonEmptyCharacterStringOnFifthBit(s);
+                } else {
+                    encodeNonZeroIntegerOnSecondBitFirstBitOne(index);
+                }
+            } else {
+                _b = _nonIdentifyingStringOnFirstBitCES;
+                encodeNonEmptyCharacterStringOnFifthBit(s);
+            }
+        }
+    }
+
+    /**
+     * Encode a non identifying string on the first bit of an octet.
+     * Implementation of clause C.14 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param s the string to encode
+     * @param map the vocabulary table of character arrays to indexes.
+     * @param addToTable true if the string should be added to the vocabulary
+     *                   table (if not already present in the table).
+     */
+    protected final void encodeNonIdentifyingStringOnFirstBit(String s, CharArrayIntMap map, boolean addToTable) throws IOException {
+        if (s == null || s.length() == 0) {
+            // C.26 an index (first bit '1') with seven '1' bits for an empty string
+            write(0xFF);
+        } else {
+            if (addToTable) {
+                final char[] ch = s.toCharArray();
+                final int length = s.length();
+                int index = map.obtainIndex(ch, 0, length, false);
+                if (index == KeyIntMap.NOT_PRESENT) {
+                    _b = EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG | _nonIdentifyingStringOnFirstBitCES;
+                    encodeNonEmptyCharacterStringOnFifthBit(ch, 0, length);
+                } else {
+                    encodeNonZeroIntegerOnSecondBitFirstBitOne(index);
+                }
+            } else {
+                _b = _nonIdentifyingStringOnFirstBitCES;
+                encodeNonEmptyCharacterStringOnFifthBit(s);
+            }
+        }
+    }
+
+    /**
+     * Encode a non identifying string on the first bit of an octet.
+     * Implementation of clause C.14 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     * @param map the vocabulary table of character arrays to indexes.
+     * @param addToTable true if the string should be added to the vocabulary
+     *                   table (if not already present in the table).
+     * @param clone true if the array of characters should be cloned if added
+     *              to the vocabulary table.
+     */
+    protected final void encodeNonIdentifyingStringOnFirstBit(char[] ch, int offset, int length, CharArrayIntMap map,
+            boolean addToTable, boolean clone) throws IOException {
+        if (length == 0) {
+            // C.26 an index (first bit '1') with seven '1' bits for an empty string
+            write(0xFF);
+        } else {
+            if (addToTable) {
+                int index = map.obtainIndex(ch, offset, length, clone);
+                if (index == KeyIntMap.NOT_PRESENT) {
+                    _b = EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG | _nonIdentifyingStringOnFirstBitCES;
+                    encodeNonEmptyCharacterStringOnFifthBit(ch, offset, length);
+                } else {
+                    encodeNonZeroIntegerOnSecondBitFirstBitOne(index);
+                }
+            } else {
+                _b = _nonIdentifyingStringOnFirstBitCES;
+                encodeNonEmptyCharacterStringOnFifthBit(ch, offset, length);
+            }
+        }
+    }
+
+    /**
+     * Encode a non identifying string on the first bit of an octet as binary
+     * data using an encoding algorithm.
+     * Implementation of clause C.14 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param URI the encoding algorithm URI. If the URI == null then the
+     *            encoding algorithm identifier takes precendence.
+     * @param id the encoding algorithm identifier.
+     * @param data the data to be encoded using an encoding algorithm.
+     * @throws EncodingAlgorithmException if the encoding algorithm URI is not
+     *         present in the vocabulary, or the encoding algorithm identifier
+     *         is not with the required range.
+     */
+    protected final void encodeNonIdentifyingStringOnFirstBit(String URI, int id, Object data) throws FastInfosetException, IOException {
+        if (URI != null) {
+            id = _v.encodingAlgorithm.get(URI);
+            if (id == KeyIntMap.NOT_PRESENT) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.EncodingAlgorithmURI", new Object[]{URI}));
+            }
+            id += EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START;
+
+            EncodingAlgorithm ea = (EncodingAlgorithm)_registeredEncodingAlgorithms.get(URI);
+            if (ea != null) {
+                encodeAIIObjectAlgorithmData(id, data, ea);
+            } else {
+                if (data instanceof byte[]) {
+                    byte[] d = (byte[])data;
+                    encodeAIIOctetAlgorithmData(id, d, 0, d.length);
+                } else {
+                    throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.nullEncodingAlgorithmURI"));
+                }
+            }
+        } else if (id <= EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            BuiltInEncodingAlgorithm a = BuiltInEncodingAlgorithmFactory.table[id];
+            int length = 0;
+            switch(id) {
+                case EncodingAlgorithmIndexes.HEXADECIMAL:
+                    length = ((byte[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.BASE64:
+                    length = ((byte[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.SHORT:
+                    length = ((short[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.INT:
+                    length = ((int[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.LONG:
+                    length = ((long[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.BOOLEAN:
+                    length = ((boolean[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.FLOAT:
+                    length = ((float[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.DOUBLE:
+                    length = ((double[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.UUID:
+                    length = ((long[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.CDATA:
+                    throw new UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.CDATA"));
+                default:
+                    throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.UnsupportedBuiltInAlgorithm", new Object[]{new Integer(id)}));
+            }
+            encodeAIIBuiltInAlgorithmData(id, data, 0, length);
+        } else if (id >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            if (data instanceof byte[]) {
+                byte[] d = (byte[])data;
+                encodeAIIOctetAlgorithmData(id, d, 0, d.length);
+            } else {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.nullEncodingAlgorithmURI"));
+            }
+        } else {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.identifiers10to31Reserved"));
+        }
+    }
+
+    /**
+     * Encode the [normalized value] of an Attribute Information Item using
+     * using an encoding algorithm.
+     * Implementation of clause C.14 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param id the encoding algorithm identifier.
+     * @param d the data, as an array of bytes, to be encoded.
+     * @param offset the offset into the array of bytes.
+     * @param length the length of bytes.
+     */
+    protected final void encodeAIIOctetAlgorithmData(int id, byte[] d, int offset, int length) throws IOException {
+        // Encode identification and top four bits of encoding algorithm id
+        write (EncodingConstants.NISTRING_ENCODING_ALGORITHM_FLAG |
+                ((id & 0xF0) >> 4));
+
+        // Encode bottom 4 bits of enoding algorithm id
+        _b = (id & 0x0F) << 4;
+
+        // Encode the length
+        encodeNonZeroOctetStringLengthOnFifthBit(length);
+
+        write(d, offset, length);
+    }
+
+    /**
+     * Encode the [normalized value] of an Attribute Information Item using
+     * using an encoding algorithm.
+     * Implementation of clause C.14 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param id the encoding algorithm identifier.
+     * @param data the data to be encoded using an encoding algorithm.
+     * @param ea the encoding algorithm to use to encode the data into an
+     *           array of bytes.
+     */
+    protected final void encodeAIIObjectAlgorithmData(int id, Object data, EncodingAlgorithm ea) throws FastInfosetException, IOException {
+        // Encode identification and top four bits of encoding algorithm id
+        write (EncodingConstants.NISTRING_ENCODING_ALGORITHM_FLAG |
+                ((id & 0xF0) >> 4));
+
+        // Encode bottom 4 bits of enoding algorithm id
+        _b = (id & 0x0F) << 4;
+
+        _encodingBufferOutputStream.reset();
+        ea.encodeToOutputStream(data, _encodingBufferOutputStream);
+        encodeNonZeroOctetStringLengthOnFifthBit(_encodingBufferIndex);
+        write(_encodingBuffer, _encodingBufferIndex);
+    }
+
+    /**
+     * Encode the [normalized value] of an Attribute Information Item using
+     * using a built in encoding algorithm.
+     * Implementation of clause C.14 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param id the built in encoding algorithm identifier.
+     * @param data the data to be encoded using an encoding algorithm. The data
+     *        represents an array of items specified by the encoding algorithm
+     *        identifier
+     * @param offset the offset into the array of bytes.
+     * @param length the length of bytes.
+     */
+    protected final void encodeAIIBuiltInAlgorithmData(int id, Object data, int offset, int length) throws IOException {
+        // Encode identification and top four bits of encoding algorithm id
+        write (EncodingConstants.NISTRING_ENCODING_ALGORITHM_FLAG |
+                ((id & 0xF0) >> 4));
+
+        // Encode bottom 4 bits of enoding algorithm id
+        _b = (id & 0x0F) << 4;
+
+        final int octetLength = BuiltInEncodingAlgorithmFactory.table[id].
+                    getOctetLengthFromPrimitiveLength(length);
+
+        encodeNonZeroOctetStringLengthOnFifthBit(octetLength);
+
+        ensureSize(octetLength);
+        BuiltInEncodingAlgorithmFactory.table[id].
+                encodeToBytes(data, offset, length, _octetBuffer, _octetBufferIndex);
+        _octetBufferIndex += octetLength;
+    }
+
+    /**
+     * Encode a non identifying string on the third bit of an octet.
+     * Implementation of clause C.15 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     * @param map the vocabulary table of character arrays to indexes.
+     * @param addToTable true if the array of characters should be added to the vocabulary
+     *                   table (if not already present in the table).
+     * @param clone true if the array of characters should be cloned if added
+     *              to the vocabulary table.
+     */
+    protected final void encodeNonIdentifyingStringOnThirdBit(char[] ch, int offset, int length,
+            CharArrayIntMap map, boolean addToTable, boolean clone) throws IOException {
+        // length cannot be zero since sequence of CIIs has to be > 0
+
+        if (addToTable) {
+            int index = map.obtainIndex(ch, offset, length, clone);
+            if (index == KeyIntMap.NOT_PRESENT) {
+                _b = EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG |
+                        _nonIdentifyingStringOnThirdBitCES;
+                encodeNonEmptyCharacterStringOnSeventhBit(ch, offset, length);
+            } else {
+                _b = EncodingConstants.CHARACTER_CHUNK | 0x20;
+                encodeNonZeroIntegerOnFourthBit(index);
+            }
+        } else {
+            _b = _nonIdentifyingStringOnThirdBitCES;
+            encodeNonEmptyCharacterStringOnSeventhBit(ch, offset, length);
+        }
+    }
+
+    /**
+     * Encode a non identifying string on the third bit of an octet as binary
+     * data using an encoding algorithm.
+     * Implementation of clause C.15 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param URI the encoding algorithm URI. If the URI == null then the
+     *            encoding algorithm identifier takes precendence.
+     * @param id the encoding algorithm identifier.
+     * @param data the data to be encoded using an encoding algorithm.
+     * @throws EncodingAlgorithmException if the encoding algorithm URI is not
+     *         present in the vocabulary, or the encoding algorithm identifier
+     *         is not with the required range.
+     */
+    protected final void encodeNonIdentifyingStringOnThirdBit(String URI, int id, Object data) throws FastInfosetException, IOException {
+        if (URI != null) {
+            id = _v.encodingAlgorithm.get(URI);
+            if (id == KeyIntMap.NOT_PRESENT) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.EncodingAlgorithmURI", new Object[]{URI}));
+            }
+            id += EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START;
+
+            EncodingAlgorithm ea = (EncodingAlgorithm)_registeredEncodingAlgorithms.get(URI);
+            if (ea != null) {
+                encodeCIIObjectAlgorithmData(id, data, ea);
+            } else {
+                if (data instanceof byte[]) {
+                    byte[] d = (byte[])data;
+                    encodeCIIOctetAlgorithmData(id, d, 0, d.length);
+                } else {
+                    throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.nullEncodingAlgorithmURI"));
+                }
+            }
+        } else if (id <= EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            int length = 0;
+            switch(id) {
+                case EncodingAlgorithmIndexes.HEXADECIMAL:
+                    length = ((byte[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.BASE64:
+                    length = ((byte[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.SHORT:
+                    length = ((short[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.INT:
+                    length = ((int[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.LONG:
+                    length = ((int[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.BOOLEAN:
+                    length = ((boolean[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.FLOAT:
+                    length = ((float[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.DOUBLE:
+                    length = ((double[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.UUID:
+                    length = ((int[])data).length;
+                    break;
+                case EncodingAlgorithmIndexes.CDATA:
+                    throw new UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.CDATA"));
+                default:
+                    throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.UnsupportedBuiltInAlgorithm", new Object[]{new Integer(id)}));
+            }
+            encodeCIIBuiltInAlgorithmData(id, data, 0, length);
+        } else if (id >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            if (data instanceof byte[]) {
+                byte[] d = (byte[])data;
+                encodeCIIOctetAlgorithmData(id, d, 0, d.length);
+            } else {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.nullEncodingAlgorithmURI"));
+            }
+        } else {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.identifiers10to31Reserved"));
+        }
+    }
+
+    /**
+     * Encode a non identifying string on the third bit of an octet as binary
+     * data using an encoding algorithm.
+     * Implementation of clause C.15 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param URI the encoding algorithm URI. If the URI == null then the
+     *            encoding algorithm identifier takes precendence.
+     * @param id the encoding algorithm identifier.
+     * @param d the data, as an array of bytes, to be encoded.
+     * @param offset the offset into the array of bytes.
+     * @param length the length of bytes.
+     * @throws EncodingAlgorithmException if the encoding algorithm URI is not
+     *         present in the vocabulary.
+     */
+    protected final void encodeNonIdentifyingStringOnThirdBit(String URI, int id, byte[] d, int offset, int length) throws FastInfosetException, IOException {
+        if (URI != null) {
+            id = _v.encodingAlgorithm.get(URI);
+            if (id == KeyIntMap.NOT_PRESENT) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.EncodingAlgorithmURI", new Object[]{URI}));
+            }
+            id += EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START;
+        }
+
+        encodeCIIOctetAlgorithmData(id, d, offset, length);
+    }
+
+    /**
+     * Encode a chunk of Character Information Items using
+     * using an encoding algorithm.
+     * Implementation of clause C.15 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param id the encoding algorithm identifier.
+     * @param d the data, as an array of bytes, to be encoded.
+     * @param offset the offset into the array of bytes.
+     * @param length the length of bytes.
+     */
+    protected final void encodeCIIOctetAlgorithmData(int id, byte[] d, int offset, int length) throws IOException {
+        // Encode identification and top two bits of encoding algorithm id
+        write (EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_ENCODING_ALGORITHM_FLAG |
+                ((id & 0xC0) >> 6));
+
+        // Encode bottom 6 bits of enoding algorithm id
+        _b = (id & 0x3F) << 2;
+
+        // Encode the length
+        encodeNonZeroOctetStringLengthOnSenventhBit(length);
+
+        write(d, offset, length);
+    }
+
+    /**
+     * Encode a chunk of Character Information Items using
+     * using an encoding algorithm.
+     * Implementation of clause C.15 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param id the encoding algorithm identifier.
+     * @param data the data to be encoded using an encoding algorithm.
+     * @param ea the encoding algorithm to use to encode the data into an
+     *           array of bytes.
+     */
+    protected final void encodeCIIObjectAlgorithmData(int id, Object data, EncodingAlgorithm ea) throws FastInfosetException, IOException {
+        // Encode identification and top two bits of encoding algorithm id
+        write (EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_ENCODING_ALGORITHM_FLAG |
+                ((id & 0xC0) >> 6));
+
+        // Encode bottom 6 bits of enoding algorithm id
+        _b = (id & 0x3F) << 2;
+
+        _encodingBufferOutputStream.reset();
+        ea.encodeToOutputStream(data, _encodingBufferOutputStream);
+        encodeNonZeroOctetStringLengthOnSenventhBit(_encodingBufferIndex);
+        write(_encodingBuffer, _encodingBufferIndex);
+    }
+
+    /**
+     * Encode a chunk of Character Information Items using
+     * using an encoding algorithm.
+     * Implementation of clause C.15 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param id the built in encoding algorithm identifier.
+     * @param data the data to be encoded using an encoding algorithm. The data
+     *        represents an array of items specified by the encoding algorithm
+     *        identifier
+     * @param offset the offset into the array of bytes.
+     * @param length the length of bytes.
+     */
+    protected final void encodeCIIBuiltInAlgorithmData(int id, Object data, int offset, int length) throws FastInfosetException, IOException {
+        // Encode identification and top two bits of encoding algorithm id
+        write (EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_ENCODING_ALGORITHM_FLAG |
+                ((id & 0xC0) >> 6));
+
+        // Encode bottom 6 bits of enoding algorithm id
+        _b = (id & 0x3F) << 2;
+
+        final int octetLength = BuiltInEncodingAlgorithmFactory.table[id].
+                    getOctetLengthFromPrimitiveLength(length);
+
+        encodeNonZeroOctetStringLengthOnSenventhBit(octetLength);
+
+        ensureSize(octetLength);
+        BuiltInEncodingAlgorithmFactory.table[id].
+                encodeToBytes(data, offset, length, _octetBuffer, _octetBufferIndex);
+        _octetBufferIndex += octetLength;
+    }
+
+    /**
+     * Encode a chunk of Character Information Items using
+     * using the CDATA built in encoding algorithm.
+     * Implementation of clause C.15 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     */
+    protected final void encodeCIIBuiltInAlgorithmDataAsCDATA(char[] ch, int offset, int length) throws FastInfosetException, IOException {
+        // Encode identification and top two bits of encoding algorithm id
+        write (EncodingConstants.CHARACTER_CHUNK | EncodingConstants.CHARACTER_CHUNK_ENCODING_ALGORITHM_FLAG);
+
+        // Encode bottom 6 bits of enoding algorithm id
+        _b = EncodingAlgorithmIndexes.CDATA << 2;
+
+
+        length = encodeUTF8String(ch, offset, length);
+        encodeNonZeroOctetStringLengthOnSenventhBit(length);
+        write(_encodingBuffer, length);
+    }
+
+    /**
+     * Encode a non empty identifying string on the first bit of an octet.
+     * Implementation of clause C.13 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param s the identifying string.
+     * @param map the vocabulary table to use to determin the index of the
+     *        identifying string
+     */
+    protected final void encodeIdentifyingNonEmptyStringOnFirstBit(String s, StringIntMap map) throws IOException {
+        int index = map.obtainIndex(s);
+        if (index == KeyIntMap.NOT_PRESENT) {
+            // _b = 0;
+            encodeNonEmptyOctetStringOnSecondBit(s);
+        } else {
+            // _b = 0x80;
+            encodeNonZeroIntegerOnSecondBitFirstBitOne(index);
+        }
+    }
+
+    /**
+     * Encode a non empty string on the second bit of an octet using the UTF-8
+     * encoding.
+     * Implementation of clause C.22 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param s the string.
+     */
+    protected final void encodeNonEmptyOctetStringOnSecondBit(String s) throws IOException {
+        final int length = encodeUTF8String(s);
+        encodeNonZeroOctetStringLengthOnSecondBit(length);
+        write(_encodingBuffer, length);
+    }
+
+    /**
+     * Encode the length of a UTF-8 encoded string on the second bit of an octet.
+     * Implementation of clause C.22 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param length the length to encode.
+     */
+    protected final void encodeNonZeroOctetStringLengthOnSecondBit(int length) throws IOException {
+        if (length < EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_SMALL_LIMIT) {
+            // [1, 64]
+            write(length - 1);
+        } else if (length < EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_LIMIT) {
+            // [65, 320]
+            write(EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_FLAG); // 010 00000
+            write(length - EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_SMALL_LIMIT);
+        } else {
+            // [321, 4294967296]
+            write(EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_LARGE_FLAG); // 0110 0000
+            length -= EncodingConstants.OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_LIMIT;
+            write(length >>> 24);
+            write((length >> 16) & 0xFF);
+            write((length >> 8) & 0xFF);
+            write(length & 0xFF);
+        }
+    }
+
+    /**
+     * Encode a non empty string on the fifth bit of an octet using the UTF-8
+     * or UTF-16 encoding.
+     * Implementation of clause C.23 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param s the string.
+     */
+    protected final void encodeNonEmptyCharacterStringOnFifthBit(String s) throws IOException {
+        final int length = (_encodingStringsAsUtf8) ? encodeUTF8String(s) : encodeUtf16String(s);
+        encodeNonZeroOctetStringLengthOnFifthBit(length);
+        write(_encodingBuffer, length);
+    }
+
+    /**
+     * Encode a non empty string on the fifth bit of an octet using the UTF-8
+     * or UTF-16 encoding.
+     * Implementation of clause C.23 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     */
+    protected final void encodeNonEmptyCharacterStringOnFifthBit(char[] ch, int offset, int length) throws IOException {
+        length = (_encodingStringsAsUtf8) ? encodeUTF8String(ch, offset, length) : encodeUtf16String(ch, offset, length);
+        encodeNonZeroOctetStringLengthOnFifthBit(length);
+        write(_encodingBuffer, length);
+    }
+
+    /**
+     * Encode the length of a UTF-8 or UTF-16 encoded string on the fifth bit
+     * of an octet.
+     * Implementation of clause C.23 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param length the length to encode.
+     */
+    protected final void encodeNonZeroOctetStringLengthOnFifthBit(int length) throws IOException {
+        if (length < EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT) {
+            // [1, 8]
+            write(_b | (length - 1));
+        } else if (length < EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT) {
+            // [9, 264]
+            write(_b | EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_FLAG); // 000010 00
+            write(length - EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT);
+        } else {
+            // [265, 4294967296]
+            write(_b | EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_LARGE_FLAG); // 000011 00
+            length -= EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+            write(length >>> 24);
+            write((length >> 16) & 0xFF);
+            write((length >> 8) & 0xFF);
+            write(length & 0xFF);
+        }
+    }
+
+    /**
+     * Encode a non empty string on the seventh bit of an octet using the UTF-8
+     * or UTF-16 encoding.
+     * Implementation of clause C.24 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     */
+    protected final void encodeNonEmptyCharacterStringOnSeventhBit(char[] ch, int offset, int length) throws IOException {
+        length = (_encodingStringsAsUtf8) ? encodeUTF8String(ch, offset, length) : encodeUtf16String(ch, offset, length);
+        encodeNonZeroOctetStringLengthOnSenventhBit(length);
+        write(_encodingBuffer, length);
+    }
+
+    /**
+     * Encode a non empty string on the seventh bit of an octet using a restricted
+     * alphabet that results in the encoding of a character in 4 bits
+     * (or two characters per octet).
+     * Implementation of clause C.24 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param table the table mapping characters to 4 bit values.
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     */
+    protected final void encodeNonEmptyFourBitCharacterStringOnSeventhBit(int[] table, char[] ch, int offset, int length) throws FastInfosetException, IOException {
+        final int octetPairLength = length / 2;
+        final int octetSingleLength = length % 2;
+
+        // Encode the length
+        encodeNonZeroOctetStringLengthOnSenventhBit(octetPairLength + octetSingleLength);
+
+        ensureSize(octetPairLength + octetSingleLength);
+        // Encode all pairs
+        int v = 0;
+        for (int i = 0; i < octetPairLength; i++) {
+            v = (table[ch[offset++]] << 4) | table[ch[offset++]];
+            if (v < 0) {
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.characterOutofAlphabetRange"));
+            }
+            _octetBuffer[_octetBufferIndex++] = (byte)v;
+        }
+        // Encode single character at end with termination bits
+        if (octetSingleLength == 1) {
+            v = (table[ch[offset]] << 4) | 0x0F;
+            if (v < 0) {
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.characterOutofAlphabetRange"));
+            }
+            _octetBuffer[_octetBufferIndex++] = (byte)v;
+        }
+    }
+
+    /**
+     * Encode a non empty string on the seventh bit of an octet using a restricted
+     * alphabet table.
+     * Implementation of clause C.24 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param alphabet the alphabet defining the mapping between characters and
+     *        integer values.
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     */
+    protected final void encodeNonEmptyNBitCharacterStringOnSeventhBit(String alphabet, char[] ch, int offset, int length) throws FastInfosetException, IOException {
+        int bitsPerCharacter = 1;
+        while ((1 << bitsPerCharacter) <= alphabet.length()) {
+            bitsPerCharacter++;
+        }
+        final int terminatingValue = (1 << bitsPerCharacter) - 1;
+
+        final int bits = length * bitsPerCharacter;
+        final int octets = bits / 8;
+        final int bitsOfLastOctet = bits % 8;
+        final int totalOctets = octets + ((bitsOfLastOctet > 0) ? 1 : 0);
+
+        // Encode the length
+        encodeNonZeroOctetStringLengthOnSenventhBit(totalOctets);
+
+        resetBits();
+        ensureSize(totalOctets);
+        int v = 0;
+        for (int i = 0; i < length; i++) {
+            final char c = ch[offset + i];
+            // This is grotesquely slow, need to use hash table of character to int value
+            for (v = 0; v < alphabet.length(); v++) {
+                if (c == alphabet.charAt(v)) {
+                    break;
+                }
+            }
+            if (v == alphabet.length()) {
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.characterOutofAlphabetRange"));
+            }
+            writeBits(bitsPerCharacter, v);
+        }
+
+        if (bitsOfLastOctet > 0) {
+            _b |= (1 << (8 - bitsOfLastOctet)) - 1;
+            write(_b);
+        }
+    }
+
+    private int _bitsLeftInOctet;
+
+    private final void resetBits() {
+        _bitsLeftInOctet = 8;
+        _b = 0;
+    }
+
+    private final void writeBits(int bits, int v) throws IOException {
+        while (bits > 0) {
+            final int bit = (v & (1 << --bits)) > 0 ? 1 : 0;
+            _b |= bit << (--_bitsLeftInOctet);
+            if (_bitsLeftInOctet == 0) {
+                write(_b);
+                _bitsLeftInOctet = 8;
+                _b = 0;
+            }
+        }
+    }
+
+    /**
+     * Encode the length of a encoded string on the seventh bit
+     * of an octet.
+     * Implementation of clause C.24 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param length the length to encode.
+     */
+    protected final void encodeNonZeroOctetStringLengthOnSenventhBit(int length) throws IOException {
+        if (length < EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT) {
+            // [1, 2]
+            write(_b | (length - 1));
+        } else if (length < EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT) {
+            // [3, 258]
+            write(_b | EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_FLAG); // 00000010
+            write(length - EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT);
+        } else {
+            // [259, 4294967296]
+            write(_b | EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_LARGE_FLAG); // 00000011
+            length -= EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT;
+            write(length >>> 24);
+            write((length >> 16) & 0xFF);
+            write((length >> 8) & 0xFF);
+            write(length & 0xFF);
+        }
+    }
+
+    /**
+     * Encode a non zero integer on the second bit of an octet, setting
+     * the first bit to 1.
+     * Implementation of clause C.24 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * <p>
+     * The first bit of the first octet is set, as specified in clause C.13 of
+     * ITU-T Rec. X.891 | ISO/IEC 24824-1
+     *
+     * @param i The integer to encode, which is a member of the interval
+     *          [0, 1048575]. In the specification the interval is [1, 1048576]
+     *
+     */
+    protected final void encodeNonZeroIntegerOnSecondBitFirstBitOne(int i) throws IOException {
+        if (i < EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT) {
+            // [1, 64] ( [0, 63] ) 6 bits
+            write(0x80 | i);
+        } else if (i < EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT) {
+            // [65, 8256] ( [64, 8255] ) 13 bits
+            i -= EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+            _b = (0x80 | EncodingConstants.INTEGER_2ND_BIT_MEDIUM_FLAG) | (i >> 8); // 010 00000
+            // _b = 0xC0 | (i >> 8); // 010 00000
+            write(_b);
+            write(i & 0xFF);
+        } else {
+            // [8257, 1048576] ( [8256, 1048575] ) 20 bits
+            i -= EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+            _b = (0x80 | EncodingConstants.INTEGER_2ND_BIT_LARGE_FLAG) | (i >> 16); // 0110 0000
+            // _b = 0xE0 | (i >> 16); // 0110 0000
+            write(_b);
+            write((i >> 8) & 0xFF);
+            write(i & 0xFF);
+        }
+    }
+
+    /**
+     * Encode a non zero integer on the second bit of an octet, setting
+     * the first bit to 0.
+     * Implementation of clause C.25 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * <p>
+     * The first bit of the first octet is set, as specified in clause C.13 of
+     * ITU-T Rec. X.891 | ISO/IEC 24824-1
+     *
+     * @param i The integer to encode, which is a member of the interval
+     *          [0, 1048575]. In the specification the interval is [1, 1048576]
+     *
+     */
+    protected final void encodeNonZeroIntegerOnSecondBitFirstBitZero(int i) throws IOException {
+        if (i < EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT) {
+            // [1, 64] ( [0, 63] ) 6 bits
+            write(i);
+        } else if (i < EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT) {
+            // [65, 8256] ( [64, 8255] ) 13 bits
+            i -= EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+            _b = EncodingConstants.INTEGER_2ND_BIT_MEDIUM_FLAG | (i >> 8); // 010 00000
+            write(_b);
+            write(i & 0xFF);
+        } else {
+            // [8257, 1048576] ( [8256, 1048575] ) 20 bits
+            i -= EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+            _b = EncodingConstants.INTEGER_2ND_BIT_LARGE_FLAG | (i >> 16); // 0110 0000
+            write(_b);
+            write((i >> 8) & 0xFF);
+            write(i & 0xFF);
+        }
+    }
+
+    /**
+     * Encode a non zero integer on the third bit of an octet.
+     * Implementation of clause C.27 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param i The integer to encode, which is a member of the interval
+     *          [0, 1048575]. In the specification the interval is [1, 1048576]
+     *
+     */
+    protected final void encodeNonZeroIntegerOnThirdBit(int i) throws IOException {
+        if (i < EncodingConstants.INTEGER_3RD_BIT_SMALL_LIMIT) {
+            // [1, 32] ( [0, 31] ) 5 bits
+            write(_b | i);
+        } else if (i < EncodingConstants.INTEGER_3RD_BIT_MEDIUM_LIMIT) {
+            // [33, 2080] ( [32, 2079] ) 11 bits
+            i -= EncodingConstants.INTEGER_3RD_BIT_SMALL_LIMIT;
+            _b |= EncodingConstants.INTEGER_3RD_BIT_MEDIUM_FLAG | (i >> 8); // 00100 000
+            write(_b);
+            write(i & 0xFF);
+        } else if (i < EncodingConstants.INTEGER_3RD_BIT_LARGE_LIMIT) {
+            // [2081, 526368] ( [2080, 526367] ) 19 bits
+            i -= EncodingConstants.INTEGER_3RD_BIT_MEDIUM_LIMIT;
+            _b |= EncodingConstants.INTEGER_3RD_BIT_LARGE_FLAG | (i >> 16); // 00101 000
+            write(_b);
+            write((i >> 8) & 0xFF);
+            write(i & 0xFF);
+        } else {
+            // [526369, 1048576] ( [526368, 1048575] ) 20 bits
+            i -= EncodingConstants.INTEGER_3RD_BIT_LARGE_LIMIT;
+            _b |= EncodingConstants.INTEGER_3RD_BIT_LARGE_LARGE_FLAG; // 00110 000
+            write(_b);
+            write(i >> 16);
+            write((i >> 8) & 0xFF);
+            write(i & 0xFF);
+        }
+    }
+
+    /**
+     * Encode a non zero integer on the fourth bit of an octet.
+     * Implementation of clause C.28 of ITU-T Rec. X.891 | ISO/IEC 24824-1.
+     *
+     * @param i The integer to encode, which is a member of the interval
+     *          [0, 1048575]. In the specification the interval is [1, 1048576]
+     *
+     */
+    protected final void encodeNonZeroIntegerOnFourthBit(int i) throws IOException {
+        if (i < EncodingConstants.INTEGER_4TH_BIT_SMALL_LIMIT) {
+            // [1, 16] ( [0, 15] ) 4 bits
+            write(_b | i);
+        } else if (i < EncodingConstants.INTEGER_4TH_BIT_MEDIUM_LIMIT) {
+            // [17, 1040] ( [16, 1039] ) 10 bits
+            i -= EncodingConstants.INTEGER_4TH_BIT_SMALL_LIMIT;
+            _b |= EncodingConstants.INTEGER_4TH_BIT_MEDIUM_FLAG | (i >> 8); // 000 100 00
+            write(_b);
+            write(i & 0xFF);
+        } else if (i < EncodingConstants.INTEGER_4TH_BIT_LARGE_LIMIT) {
+            // [1041, 263184] ( [1040, 263183] ) 18 bits
+            i -= EncodingConstants.INTEGER_4TH_BIT_MEDIUM_LIMIT;
+            _b |= EncodingConstants.INTEGER_4TH_BIT_LARGE_FLAG | (i >> 16); // 000 101 00
+            write(_b);
+            write((i >> 8) & 0xFF);
+            write(i & 0xFF);
+        } else {
+            // [263185, 1048576] ( [263184, 1048575] ) 20 bits
+            i -= EncodingConstants.INTEGER_4TH_BIT_LARGE_LIMIT;
+            _b |= EncodingConstants.INTEGER_4TH_BIT_LARGE_LARGE_FLAG; // 000 110 00
+            write(_b);
+            write(i >> 16);
+            write((i >> 8) & 0xFF);
+            write(i & 0xFF);
+        }
+    }
+
+    /**
+     * Encode a non empty string using the UTF-8 encoding.
+     *
+     * @param b the current octet that is being written.
+     * @param s the string to be UTF-8 encoded.
+     * @param constants the array of constants to use when encoding to determin
+     *        how the length of the UTF-8 encoded string is encoded.
+     */
+    protected final void encodeNonEmptyUTF8StringAsOctetString(int b, String s, int[] constants) throws IOException {
+        final char[] ch = s.toCharArray();
+        encodeNonEmptyUTF8StringAsOctetString(b, ch, 0, ch.length, constants);
+    }
+
+    /**
+     * Encode a non empty string using the UTF-8 encoding.
+     *
+     * @param b the current octet that is being written.
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     *        how the length of the UTF-8 encoded string is encoded.
+     * @param constants the array of constants to use when encoding to determin
+     *        how the length of the UTF-8 encoded string is encoded.
+     */
+    protected final void encodeNonEmptyUTF8StringAsOctetString(int b, char ch[], int offset, int length, int[] constants) throws IOException {
+        length = encodeUTF8String(ch, offset, length);
+        encodeNonZeroOctetStringLength(b, length, constants);
+        write(_encodingBuffer, length);
+    }
+
+    /**
+     * Encode the length of non empty UTF-8 encoded string.
+     *
+     * @param b the current octet that is being written.
+     * @param length the length of the UTF-8 encoded string.
+     *        how the length of the UTF-8 encoded string is encoded.
+     * @param constants the array of constants to use when encoding to determin
+     *        how the length of the UTF-8 encoded string is encoded.
+     */
+    protected final void encodeNonZeroOctetStringLength(int b, int length, int[] constants) throws IOException {
+        if (length < constants[EncodingConstants.OCTET_STRING_LENGTH_SMALL_LIMIT]) {
+            write(b | (length - 1));
+        } else if (length < constants[EncodingConstants.OCTET_STRING_LENGTH_MEDIUM_LIMIT]) {
+            write(b | constants[EncodingConstants.OCTET_STRING_LENGTH_MEDIUM_FLAG]);
+            write(length - constants[EncodingConstants.OCTET_STRING_LENGTH_SMALL_LIMIT]);
+        } else {
+            write(b | constants[EncodingConstants.OCTET_STRING_LENGTH_LARGE_FLAG]);
+            length -= constants[EncodingConstants.OCTET_STRING_LENGTH_MEDIUM_LIMIT];
+            write(length >>> 24);
+            write((length >> 16) & 0xFF);
+            write((length >> 8) & 0xFF);
+            write(length & 0xFF);
+        }
+    }
+
+    /**
+     * Encode a non zero integer.
+     *
+     * @param b the current octet that is being written.
+     * @param i the non zero integer.
+     * @param constants the array of constants to use when encoding to determin
+     *        how the non zero integer is encoded.
+     */
+    protected final void encodeNonZeroInteger(int b, int i, int[] constants) throws IOException {
+        if (i < constants[EncodingConstants.INTEGER_SMALL_LIMIT]) {
+            write(b | i);
+        } else if (i < constants[EncodingConstants.INTEGER_MEDIUM_LIMIT]) {
+            i -= constants[EncodingConstants.INTEGER_SMALL_LIMIT];
+            write(b | constants[EncodingConstants.INTEGER_MEDIUM_FLAG] | (i >> 8));
+            write(i & 0xFF);
+        } else if (i < constants[EncodingConstants.INTEGER_LARGE_LIMIT]) {
+            i -= constants[EncodingConstants.INTEGER_MEDIUM_LIMIT];
+            write(b | constants[EncodingConstants.INTEGER_LARGE_FLAG] | (i >> 16));
+            write((i >> 8) & 0xFF);
+            write(i & 0xFF);
+        } else if (i < EncodingConstants.INTEGER_MAXIMUM_SIZE) {
+            i -= constants[EncodingConstants.INTEGER_LARGE_LIMIT];
+            write(b | constants[EncodingConstants.INTEGER_LARGE_LARGE_FLAG]);
+            write(i >> 16);
+            write((i >> 8) & 0xFF);
+            write(i & 0xFF);
+        } else {
+            throw new IOException(CommonResourceBundle.getInstance().getString("message.integerMaxSize", new Object[]{new Integer(EncodingConstants.INTEGER_MAXIMUM_SIZE)}));
+        }
+    }
+
+    /**
+     * Mark the current position in the buffered stream.
+     */
+    protected final void mark() throws IOException {
+        _markIndex = _octetBufferIndex;
+    }
+
+    /**
+     * Reset the marked position in the buffered stream.
+     */
+    protected final void resetMark() throws IOException {
+        _markIndex = -1;
+    }
+
+    /**
+     * Write a byte to the buffered stream.
+     */
+    protected final void write(int i) throws IOException {
+        if (_octetBufferIndex < _octetBuffer.length) {
+            _octetBuffer[_octetBufferIndex++] = (byte)i;
+        } else {
+            if (_markIndex == -1) {
+                _s.write(_octetBuffer);
+                _octetBufferIndex = 1;
+                _octetBuffer[0] = (byte)i;
+            } else {
+                resize(_octetBuffer.length * 3 / 2);
+                _octetBuffer[_octetBufferIndex++] = (byte)i;
+            }
+        }
+    }
+
+    /**
+     * Write an array of bytes to the buffered stream.
+     *
+     * @param b the array of bytes.
+     * @param length the length of bytes.
+     */
+    protected final void write(byte[] b, int length) throws IOException {
+        write(b, 0,  length);
+    }
+
+    /**
+     * Write an array of bytes to the buffered stream.
+     *
+     * @param b the array of bytes.
+     * @param offset the offset into the array of bytes.
+     * @param length the length of bytes.
+     */
+    protected final void write(byte[] b, int offset, int length) throws IOException {
+        if ((_octetBufferIndex + length) < _octetBuffer.length) {
+            System.arraycopy(b, offset, _octetBuffer, _octetBufferIndex, length);
+            _octetBufferIndex += length;
+        } else {
+            if (_markIndex == -1) {
+                _s.write(_octetBuffer, 0, _octetBufferIndex);
+                _s.write(b, offset, length);
+                _octetBufferIndex = 0;
+            } else {
+                resize((_octetBuffer.length + length) * 3 / 2 + 1);
+                System.arraycopy(b, offset, _octetBuffer, _octetBufferIndex, length);
+                _octetBufferIndex += length;
+            }
+        }
+    }
+
+    private void ensureSize(int length) {
+        if ((_octetBufferIndex + length) > _octetBuffer.length) {
+            resize((_octetBufferIndex + length) * 3 / 2 + 1);
+        }
+    }
+
+    private void resize(int length) {
+        byte[] b = new byte[length];
+        System.arraycopy(_octetBuffer, 0, b, 0, _octetBufferIndex);
+        _octetBuffer = b;
+    }
+
+    private void _flush() throws IOException {
+        if (_octetBufferIndex > 0) {
+            _s.write(_octetBuffer, 0, _octetBufferIndex);
+            _octetBufferIndex = 0;
+        }
+    }
+
+
+    private EncodingBufferOutputStream _encodingBufferOutputStream = new EncodingBufferOutputStream();
+
+    private byte[] _encodingBuffer = new byte[512];
+
+    private int _encodingBufferIndex;
+
+    private class EncodingBufferOutputStream extends OutputStream {
+
+        public void write(int b) throws IOException {
+            if (_encodingBufferIndex < _encodingBuffer.length) {
+                _encodingBuffer[_encodingBufferIndex++] = (byte)b;
+            } else {
+                byte newbuf[] = new byte[Math.max(_encodingBuffer.length << 1, _encodingBufferIndex)];
+                System.arraycopy(_encodingBuffer, 0, newbuf, 0, _encodingBufferIndex);
+                _encodingBuffer = newbuf;
+
+                _encodingBuffer[_encodingBufferIndex++] = (byte)b;
+            }
+        }
+
+        public void write(byte b[], int off, int len) throws IOException {
+            if ((off < 0) || (off > b.length) || (len < 0) ||
+                ((off + len) > b.length) || ((off + len) < 0)) {
+                throw new IndexOutOfBoundsException();
+            } else if (len == 0) {
+                return;
+            }
+            final int newoffset = _encodingBufferIndex + len;
+            if (newoffset > _encodingBuffer.length) {
+                byte newbuf[] = new byte[Math.max(_encodingBuffer.length << 1, newoffset)];
+                System.arraycopy(_encodingBuffer, 0, newbuf, 0, _encodingBufferIndex);
+                _encodingBuffer = newbuf;
+            }
+            System.arraycopy(b, off, _encodingBuffer, _encodingBufferIndex, len);
+            _encodingBufferIndex = newoffset;
+        }
+
+        public int getLength() {
+            return _encodingBufferIndex;
+        }
+
+        public void reset() {
+            _encodingBufferIndex = 0;
+        }
+    }
+
+    /**
+     * Encode a string using the UTF-8 encoding.
+     *
+     * @param s the string to encode.
+     */
+    protected final int encodeUTF8String(String s) throws IOException {
+        final int length = s.length();
+        if (length < _charBuffer.length) {
+            s.getChars(0, length, _charBuffer, 0);
+            return encodeUTF8String(_charBuffer, 0, length);
+        } else {
+            char[] ch = s.toCharArray();
+            return encodeUTF8String(ch, 0, length);
+        }
+    }
+
+    private void ensureEncodingBufferSizeForUtf8String(int length) {
+        final int newLength = 4 * length;
+        if (_encodingBuffer.length < newLength) {
+            _encodingBuffer = new byte[newLength];
+        }
+    }
+
+    /**
+     * Encode a string using the UTF-8 encoding.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     */
+    protected final int encodeUTF8String(char[] ch, int offset, int length) throws IOException {
+        int bpos = 0;
+
+        // Make sure buffer is large enough
+        ensureEncodingBufferSizeForUtf8String(length);
+
+        final int end = offset + length;
+        int c;
+        while (end != offset) {
+            c = ch[offset++];
+            if (c < 0x80) {
+                // 1 byte, 7 bits
+                _encodingBuffer[bpos++] = (byte) c;
+            } else if (c < 0x800) {
+                // 2 bytes, 11 bits
+                _encodingBuffer[bpos++] =
+                    (byte) (0xC0 | (c >> 6));    // first 5
+                _encodingBuffer[bpos++] =
+                    (byte) (0x80 | (c & 0x3F));  // second 6
+            } else if (c <= '\uFFFF') {
+                if (!XMLChar.isHighSurrogate(c) && !XMLChar.isLowSurrogate(c)) {
+                    // 3 bytes, 16 bits
+                    _encodingBuffer[bpos++] =
+                        (byte) (0xE0 | (c >> 12));   // first 4
+                    _encodingBuffer[bpos++] =
+                        (byte) (0x80 | ((c >> 6) & 0x3F));  // second 6
+                    _encodingBuffer[bpos++] =
+                        (byte) (0x80 | (c & 0x3F));  // third 6
+                } else {
+                    // 4 bytes, high and low surrogate
+                    encodeCharacterAsUtf8FourByte(c, ch, offset, end, bpos);
+                    bpos += 4;
+                    offset++;
+                }
+            }
+        }
+
+        return bpos;
+    }
+
+    private void encodeCharacterAsUtf8FourByte(int c, char[] ch, int chpos, int chend, int bpos) throws IOException {
+        if (chpos == chend) {
+            throw new IOException("");
+        }
+
+        final char d = ch[chpos];
+        if (!XMLChar.isLowSurrogate(d)) {
+            throw new IOException("");
+        }
+
+        final int uc = (((c & 0x3ff) << 10) | (d & 0x3ff)) + 0x10000;
+        if (uc < 0 || uc >= 0x200000) {
+            throw new IOException("");
+        }
+
+        _encodingBuffer[bpos++] = (byte)(0xF0 | ((uc >> 18)));
+        _encodingBuffer[bpos++] = (byte)(0x80 | ((uc >> 12) & 0x3F));
+        _encodingBuffer[bpos++] = (byte)(0x80 | ((uc >> 6) & 0x3F));
+        _encodingBuffer[bpos++] = (byte)(0x80 | (uc & 0x3F));
+    }
+
+    /**
+     * Encode a string using the UTF-16 encoding.
+     *
+     * @param s the string to encode.
+     */
+    protected final int encodeUtf16String(String s) throws IOException {
+        final int length = s.length();
+        if (length < _charBuffer.length) {
+            s.getChars(0, length, _charBuffer, 0);
+            return encodeUtf16String(_charBuffer, 0, length);
+        } else {
+            char[] ch = s.toCharArray();
+            return encodeUtf16String(ch, 0, length);
+        }
+    }
+
+    private void ensureEncodingBufferSizeForUtf16String(int length) {
+        final int newLength = 2 * length;
+        if (_encodingBuffer.length < newLength) {
+            _encodingBuffer = new byte[newLength];
+        }
+    }
+
+    /**
+     * Encode a string using the UTF-16 encoding.
+     *
+     * @param ch the array of characters.
+     * @param offset the offset into the array of characters.
+     * @param length the length of characters.
+     */
+    protected final int encodeUtf16String(char[] ch, int offset, int length) throws IOException {
+        int byteLength = 0;
+
+        // Make sure buffer is large enough
+        ensureEncodingBufferSizeForUtf16String(length);
+
+        final int n = offset + length;
+        for (int i = offset; i < n; i++) {
+            final int c = (int) ch[i];
+            _encodingBuffer[byteLength++] = (byte)(c >> 8);
+            _encodingBuffer[byteLength++] = (byte)(c & 0xFF);
+        }
+
+        return byteLength;
+    }
+
+    /**
+     * Obtain the prefix from a qualified name.
+     *
+     * @param qName the qualified name
+     * @return the prefix, or "" if there is no prefix.
+     */
+    public static String getPrefixFromQualifiedName(String qName) {
+        int i = qName.indexOf(':');
+        String prefix = "";
+        if (i != -1) {
+            prefix = qName.substring(0, i);
+        }
+        return prefix;
+    }
+
+    /**
+     * Check if character array contains characters that are all white space.
+     *
+     * @param ch the character array
+     * @param start the starting character index into the array to check from
+     * @param length the number of characters to check
+     * @return true if all characters are white space, false otherwise
+     */
+    public static boolean isWhiteSpace(final char[] ch, int start, final int length) {
+        if (!XMLChar.isSpace(ch[start])) return false;
+
+        final int end = start + length;
+        start++;
+        while(start < end && XMLChar.isSpace(ch[start++]));
+        return start == end;
+    }
+
+    /**
+     * Check if a String contains characters that are all white space.
+     *
+     * @param s the string
+     * @return true if all characters are white space, false otherwise
+     */
+    public static boolean isWhiteSpace(String s) {
+        if (!XMLChar.isSpace(s.charAt(0))) return false;
+
+        final int end = s.length();
+        int start = 1;
+        while(start < end && XMLChar.isSpace(s.charAt(start++)));
+        return start == end;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/EncodingConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/EncodingConstants.java
new file mode 100644
index 0000000..db3e426
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/EncodingConstants.java
@@ -0,0 +1,370 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset;
+
+import java.io.UnsupportedEncodingException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.RestrictedAlphabet;
+
+public final class EncodingConstants {
+    static {
+        initiateCharacterTables();
+        initiateXMLDeclarationValues();
+    }
+
+    public static final String XML_NAMESPACE_PREFIX = "xml";
+    public static final int XML_NAMESPACE_PREFIX_LENGTH = XML_NAMESPACE_PREFIX.length();
+    public static final String XML_NAMESPACE_NAME = "http://www.w3.org/XML/1998/namespace";
+    public static final int XML_NAMESPACE_NAME_LENGTH = XML_NAMESPACE_NAME.length();
+    public static final char[] XML_NAMESPACE_NAME_CHARS = XML_NAMESPACE_NAME.toCharArray();
+
+    public static final String XMLNS_NAMESPACE_PREFIX = "xmlns";
+    public static final int XMLNS_NAMESPACE_PREFIX_LENGTH = XMLNS_NAMESPACE_PREFIX.length();
+    public static final char[] XMLNS_NAMESPACE_PREFIX_CHARS = XMLNS_NAMESPACE_PREFIX.toCharArray();
+    public static final String XMLNS_NAMESPACE_NAME = "http://www.w3.org/2000/xmlns/";
+    public static final int XMLNS_NAMESPACE_NAME_LENGTH = XMLNS_NAMESPACE_NAME.length();
+    public static final char[] XMLNS_NAMESPACE_NAME_CHARS = XMLNS_NAMESPACE_NAME.toCharArray();
+
+    public static final QualifiedName DEFAULT_NAMESPACE_DECLARATION = new QualifiedName(
+            "",
+            EncodingConstants.XMLNS_NAMESPACE_NAME,
+            EncodingConstants.XMLNS_NAMESPACE_PREFIX,
+            EncodingConstants.XMLNS_NAMESPACE_PREFIX);
+
+    public static final int DOCUMENT_ADDITIONAL_DATA_FLAG = 0x40; // 01000000
+    public static final int DOCUMENT_INITIAL_VOCABULARY_FLAG = 0x20; // 00100000
+    public static final int DOCUMENT_NOTATIONS_FLAG = 0x10; // 00010000
+    public static final int DOCUMENT_UNPARSED_ENTITIES_FLAG = 0x08; // 00001000
+    public static final int DOCUMENT_CHARACTER_ENCODING_SCHEME = 0x04; // 00000100
+    public static final int DOCUMENT_STANDALONE_FLAG = 0x02; // 00000010
+    public static final int DOCUMENT_VERSION_FLAG = 0x01; // 00000001
+
+    public static final int INITIAL_VOCABULARY_EXTERNAL_VOCABULARY_FLAG = 0x10; // 00010000
+    public static final int INITIAL_VOCABULARY_RESTRICTED_ALPHABETS_FLAG = 0x08; // 00001000
+    public static final int INITIAL_VOCABULARY_ENCODING_ALGORITHMS_FLAG = 0x04; // 00000100
+    public static final int INITIAL_VOCABULARY_PREFIXES_FLAG = 0x02; // 00000010
+    public static final int INITIAL_VOCABULARY_NAMESPACE_NAMES_FLAG = 0x01; // 00000001
+    public static final int INITIAL_VOCABULARY_LOCAL_NAMES_FLAG = 0x80; // 1000000
+    public static final int INITIAL_VOCABULARY_OTHER_NCNAMES_FLAG = 0x40; // 01000000
+    public static final int INITIAL_VOCABULARY_OTHER_URIS_FLAG = 0x20; // 00100000
+    public static final int INITIAL_VOCABULARY_ATTRIBUTE_VALUES_FLAG = 0x10; // 00010000
+    public static final int INITIAL_VOCABULARY_CONTENT_CHARACTER_CHUNKS_FLAG = 0x08; // 00001000
+    public static final int INITIAL_VOCABULARY_OTHER_STRINGS_FLAG = 0x04; // 00000100
+    public static final int INITIAL_VOCABULARY_ELEMENT_NAME_SURROGATES_FLAG = 0x02; // 0000010
+    public static final int INITIAL_VOCABULARY_ATTRIBUTE_NAME_SURROGATES_FLAG = 0x01; // 00000001
+
+    public static final int NAME_SURROGATE_PREFIX_FLAG = 0x02;
+    public static final int NAME_SURROGATE_NAME_FLAG = 0x01;
+
+    public static final int NOTATIONS = 0xC0; // 110000
+    public static final int NOTATIONS_MASK = 0xFC; // 6 bits
+    public static final int NOTATIONS_SYSTEM_IDENTIFIER_FLAG = 0x02;
+    public static final int NOTATIONS_PUBLIC_IDENTIFIER_FLAG = 0x01;
+
+    public static final int UNPARSED_ENTITIES = 0xD0; // 1101000
+    public static final int UNPARSED_ENTITIES_MASK = 0xFE; // 7 bits
+    public static final int UNPARSED_ENTITIES_PUBLIC_IDENTIFIER_FLAG = 0x01;
+
+    public static final int PROCESSING_INSTRUCTION = 0xE1; // 11100001
+    public static final int PROCESSING_INSTRUCTION_MASK = 0xFF; // 8 bits
+
+    public static final int COMMENT = 0xE2; // 11100010
+    public static final int COMMENT_MASK = 0xFF; // 8 bits
+
+    public static final int DOCUMENT_TYPE_DECLARATION = 0xC4; // 110001
+    public static final int DOCUMENT_TYPE_DECLARATION_MASK = 0xFC; // 6 bits
+    public static final int DOCUMENT_TYPE_SYSTEM_IDENTIFIER_FLAG = 0x02;
+    public static final int DOCUMENT_TYPE_PUBLIC_IDENTIFIER_FLAG = 0x01;
+
+    public static final int ELEMENT = 0x00; // 0
+    public static final int ELEMENT_ATTRIBUTE_FLAG = 0x40; // 01000000
+    public static final int ELEMENT_NAMESPACES_FLAG = 0x38; // 00111000
+    public static final int ELEMENT_LITERAL_QNAME_FLAG = 0x3C; // 00111100
+
+    public static final int NAMESPACE_ATTRIBUTE = 0xCC; // 110011 00
+    public static final int NAMESPACE_ATTRIBUTE_MASK = 0xFC; // 6 bits
+    public static final int NAMESPACE_ATTRIBUTE_PREFIX_NAME_MASK = 0x03; // 2 bits
+    public static final int NAMESPACE_ATTRIBUTE_PREFIX_FLAG = 0x02;
+    public static final int NAMESPACE_ATTRIBUTE_NAME_FLAG = 0x01;
+
+    public static final int ATTRIBUTE_LITERAL_QNAME_FLAG = 0x78; // 01111000
+
+    public static final int LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK = 0x03;
+    public static final int LITERAL_QNAME_PREFIX_FLAG = 0x02;
+    public static final int LITERAL_QNAME_NAMESPACE_NAME_FLAG = 0x01;
+
+    public static final int CHARACTER_CHUNK = 0x80; // 10
+    public static final int CHARACTER_CHUNK_ADD_TO_TABLE_FLAG = 0x10; // 00010000
+    public static final int CHARACTER_CHUNK_UTF_8_FLAG = 0x00; // 00000000
+    public static final int CHARACTER_CHUNK_UTF_16_FLAG = 0x04; // 00000100
+    public static final int CHARACTER_CHUNK_RESTRICTED_ALPHABET_FLAG = 0x08; // 00001000
+    public static final int CHARACTER_CHUNK_ENCODING_ALGORITHM_FLAG = 0x0C; // 00001100
+
+    public static final int UNEXPANDED_ENTITY_REFERENCE = 0xC8; // 110010
+    public static final int UNEXPANDED_ENTITY_REFERENCE_MASK = 0xFC; // 6 bits
+    public static final int UNEXPANDED_ENTITY_SYSTEM_IDENTIFIER_FLAG = 0x02;
+    public static final int UNEXPANDED_ENTITY_PUBLIC_IDENTIFIER_FLAG = 0x01;
+
+    public static final int NISTRING_ADD_TO_TABLE_FLAG = 0x40; // 01000000
+    public static final int NISTRING_UTF_8_FLAG = 0x00; // 00000000
+    public static final int NISTRING_UTF_16_FLAG = 0x10; // 00010000
+    public static final int NISTRING_RESTRICTED_ALPHABET_FLAG = 0x20; // 00100000
+    public static final int NISTRING_ENCODING_ALGORITHM_FLAG = 0x30; // 00110000
+
+    public static final int TERMINATOR = 0xF0;
+    public static final int DOUBLE_TERMINATOR = 0xFF;
+
+
+    public static final int ENCODING_ALGORITHM_BUILTIN_END = 9;
+    public static final int ENCODING_ALGORITHM_APPLICATION_START = 32;
+    public static final int ENCODING_ALGORITHM_APPLICATION_MAX = 255;
+
+    public static final int RESTRICTED_ALPHABET_BUILTIN_END = 1;
+    public static final int RESTRICTED_ALPHABET_APPLICATION_START = 32;
+    public static final int RESTRICTED_ALPHABET_APPLICATION_MAX = 255;
+
+    // Octet string length contants
+
+    public static final int OCTET_STRING_LENGTH_SMALL_LIMIT = 0;
+    public static final int OCTET_STRING_LENGTH_MEDIUM_LIMIT = 1;
+    public static final int OCTET_STRING_LENGTH_MEDIUM_FLAG = 2;
+    public static final int OCTET_STRING_LENGTH_LARGE_FLAG = 3;
+
+    public static final long OCTET_STRING_MAXIMUM_LENGTH = 4294967296L;
+
+    /*
+     * C.22
+     */
+    public static final int OCTET_STRING_LENGTH_2ND_BIT_SMALL_LIMIT = 65;
+    public static final int OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_LIMIT = 321;
+    public static final int OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_FLAG = 0x40;
+    public static final int OCTET_STRING_LENGTH_2ND_BIT_LARGE_FLAG = 0x60;
+    public static final int OCTET_STRING_LENGTH_2ND_BIT_SMALL_MASK = 0x1F;
+
+    public static final int[] OCTET_STRING_LENGTH_2ND_BIT_VALUES = {
+        OCTET_STRING_LENGTH_2ND_BIT_SMALL_LIMIT,
+        OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_LIMIT,
+        OCTET_STRING_LENGTH_2ND_BIT_MEDIUM_FLAG,
+        OCTET_STRING_LENGTH_2ND_BIT_LARGE_FLAG
+    };
+
+    /*
+     * C.23
+     */
+    public static final int OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT = 9;
+    public static final int OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT = 265;
+    public static final int OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_FLAG = 0x08;
+    public static final int OCTET_STRING_LENGTH_5TH_BIT_LARGE_FLAG = 0x0C;
+    public static final int OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK = 0x07;
+
+    public static final int[] OCTET_STRING_LENGTH_5TH_BIT_VALUES = {
+        OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT,
+        OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT,
+        OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_FLAG,
+        OCTET_STRING_LENGTH_5TH_BIT_LARGE_FLAG
+    };
+
+    /*
+     * C.24
+     */
+    public static final int OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT = 3;
+    public static final int OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT = 259;
+    public static final int OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_FLAG = 0x02;
+    public static final int OCTET_STRING_LENGTH_7TH_BIT_LARGE_FLAG = 0x03;
+    public static final int OCTET_STRING_LENGTH_7TH_BIT_SMALL_MASK = 0x01;
+
+    public static final int[] OCTET_STRING_LENGTH_7TH_BIT_VALUES = {
+        OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT,
+        OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT,
+        OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_FLAG,
+        OCTET_STRING_LENGTH_7TH_BIT_LARGE_FLAG
+    };
+
+
+    // Integer
+
+    public static final int INTEGER_SMALL_LIMIT = 0;
+    public static final int INTEGER_MEDIUM_LIMIT = 1;
+    public static final int INTEGER_LARGE_LIMIT = 2;
+    public static final int INTEGER_MEDIUM_FLAG = 3;
+    public static final int INTEGER_LARGE_FLAG = 4;
+    public static final int INTEGER_LARGE_LARGE_FLAG = 5;
+
+    public static final int INTEGER_MAXIMUM_SIZE = 1048576;
+
+    /*
+     * C.25
+     */
+    public static final int INTEGER_2ND_BIT_SMALL_LIMIT = 64;
+    public static final int INTEGER_2ND_BIT_MEDIUM_LIMIT = 8256;
+    public static final int INTEGER_2ND_BIT_LARGE_LIMIT = INTEGER_MAXIMUM_SIZE;
+    public static final int INTEGER_2ND_BIT_MEDIUM_FLAG = 0x40;
+    public static final int INTEGER_2ND_BIT_LARGE_FLAG = 0x60;
+    public static final int INTEGER_2ND_BIT_SMALL_MASK = 0x3F;
+    public static final int INTEGER_2ND_BIT_MEDIUM_MASK = 0x1F;
+    public static final int INTEGER_2ND_BIT_LARGE_MASK = 0x0F;
+
+    public static final int[] INTEGER_2ND_BIT_VALUES = {
+        INTEGER_2ND_BIT_SMALL_LIMIT,
+        INTEGER_2ND_BIT_MEDIUM_LIMIT,
+        INTEGER_2ND_BIT_LARGE_LIMIT,
+        INTEGER_2ND_BIT_MEDIUM_FLAG,
+        INTEGER_2ND_BIT_LARGE_FLAG,
+        -1
+    };
+
+    /*
+     * C.27
+     */
+    public static final int INTEGER_3RD_BIT_SMALL_LIMIT = 32;
+    public static final int INTEGER_3RD_BIT_MEDIUM_LIMIT = 2080;
+    public static final int INTEGER_3RD_BIT_LARGE_LIMIT = 526368;
+    public static final int INTEGER_3RD_BIT_MEDIUM_FLAG = 0x20;
+    public static final int INTEGER_3RD_BIT_LARGE_FLAG = 0x28;
+    public static final int INTEGER_3RD_BIT_LARGE_LARGE_FLAG = 0x30;
+    public static final int INTEGER_3RD_BIT_SMALL_MASK = 0x1F;
+    public static final int INTEGER_3RD_BIT_MEDIUM_MASK = 0x07;
+    public static final int INTEGER_3RD_BIT_LARGE_MASK = 0x07;
+    public static final int INTEGER_3RD_BIT_LARGE_LARGE_MASK = 0x0F;
+
+    public static final int[] INTEGER_3RD_BIT_VALUES = {
+        INTEGER_3RD_BIT_SMALL_LIMIT,
+        INTEGER_3RD_BIT_MEDIUM_LIMIT,
+        INTEGER_3RD_BIT_LARGE_LIMIT,
+        INTEGER_3RD_BIT_MEDIUM_FLAG,
+        INTEGER_3RD_BIT_LARGE_FLAG,
+        INTEGER_3RD_BIT_LARGE_LARGE_FLAG
+    };
+
+    /*
+     * C.28
+     */
+    public static final int INTEGER_4TH_BIT_SMALL_LIMIT = 16;
+    public static final int INTEGER_4TH_BIT_MEDIUM_LIMIT = 1040;
+    public static final int INTEGER_4TH_BIT_LARGE_LIMIT = 263184;
+    public static final int INTEGER_4TH_BIT_MEDIUM_FLAG = 0x10;
+    public static final int INTEGER_4TH_BIT_LARGE_FLAG = 0x14;
+    public static final int INTEGER_4TH_BIT_LARGE_LARGE_FLAG = 0x18;
+    public static final int INTEGER_4TH_BIT_SMALL_MASK = 0x0F;
+    public static final int INTEGER_4TH_BIT_MEDIUM_MASK = 0x03;
+    public static final int INTEGER_4TH_BIT_LARGE_MASK = 0x03;
+
+    public static final int[] INTEGER_4TH_BIT_VALUES = {
+        INTEGER_4TH_BIT_SMALL_LIMIT,
+        INTEGER_4TH_BIT_MEDIUM_LIMIT,
+        INTEGER_4TH_BIT_LARGE_LIMIT,
+        INTEGER_4TH_BIT_MEDIUM_FLAG,
+        INTEGER_4TH_BIT_LARGE_FLAG,
+        INTEGER_4TH_BIT_LARGE_LARGE_FLAG
+    };
+
+
+    public static int[] NUMERIC_CHARACTERS_TABLE;
+
+    public static int[] DATE_TIME_CHARACTERS_TABLE;
+
+    private static void initiateCharacterTables() {
+        NUMERIC_CHARACTERS_TABLE = new int[maxCharacter(RestrictedAlphabet.NUMERIC_CHARACTERS) + 1];
+        DATE_TIME_CHARACTERS_TABLE = new int[maxCharacter(RestrictedAlphabet.DATE_TIME_CHARACTERS) + 1];
+
+        for (int i = 0; i < NUMERIC_CHARACTERS_TABLE.length ; i++) {
+            NUMERIC_CHARACTERS_TABLE[i] = -1;
+        }
+        for (int i = 0; i < DATE_TIME_CHARACTERS_TABLE.length ; i++) {
+            DATE_TIME_CHARACTERS_TABLE[i] = -1;
+        }
+
+        for (int i = 0; i < RestrictedAlphabet.NUMERIC_CHARACTERS.length() ; i++) {
+            NUMERIC_CHARACTERS_TABLE[RestrictedAlphabet.NUMERIC_CHARACTERS.charAt(i)] = i;
+        }
+        for (int i = 0; i < RestrictedAlphabet.DATE_TIME_CHARACTERS.length() ; i++) {
+            DATE_TIME_CHARACTERS_TABLE[RestrictedAlphabet.DATE_TIME_CHARACTERS.charAt(i)] = i;
+        }
+    }
+
+    private static int maxCharacter(String alphabet) {
+        int c = 0;
+        for (int i = 0; i < alphabet.length() ; i++) {
+            if (c < alphabet.charAt(i)) {
+                c = alphabet.charAt(i);
+            }
+        }
+
+        return c;
+    }
+
+    public static final byte[] BINARY_HEADER = {(byte)0xE0, 0, 0, 1};
+
+    public static byte[][] XML_DECLARATION_VALUES;
+
+    private static void initiateXMLDeclarationValues() {
+
+        XML_DECLARATION_VALUES = new byte[9][];
+
+        try {
+            XML_DECLARATION_VALUES[0] = "<?xml encoding='finf'?>".getBytes("UTF-8");
+            XML_DECLARATION_VALUES[1] = "<?xml version='1.0' encoding='finf'?>".getBytes("UTF-8");
+            XML_DECLARATION_VALUES[2] = "<?xml version='1.1' encoding='finf'?>".getBytes("UTF-8");
+            XML_DECLARATION_VALUES[3] = "<?xml encoding='finf' standalone='no'?>".getBytes("UTF-8");
+            XML_DECLARATION_VALUES[4] = "<?xml encoding='finf' standalone='yes'?>".getBytes("UTF-8");
+            XML_DECLARATION_VALUES[5] = "<?xml version='1.0' encoding='finf' standalone='no'?>".getBytes("UTF-8");
+            XML_DECLARATION_VALUES[6] = "<?xml version='1.1' encoding='finf' standalone='no'?>".getBytes("UTF-8");
+            XML_DECLARATION_VALUES[7] = "<?xml version='1.0' encoding='finf' standalone='yes'?>".getBytes("UTF-8");
+            XML_DECLARATION_VALUES[8] = "<?xml version='1.1' encoding='finf' standalone='yes'?>".getBytes("UTF-8");
+        } catch (UnsupportedEncodingException e) {
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Notation.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Notation.java
new file mode 100644
index 0000000..71de72a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/Notation.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset;
+
+public class Notation {
+    public final String name;
+    public final String systemIdentifier;
+    public final String publicIdentifier;
+
+    /** Creates a new instance of Notation */
+    public Notation(String _name, String _systemIdentifier, String _publicIdentifier) {
+        name = _name;
+        systemIdentifier = _systemIdentifier;
+        publicIdentifier = _publicIdentifier;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/QualifiedName.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/QualifiedName.java
new file mode 100644
index 0000000..8f8d22a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/QualifiedName.java
@@ -0,0 +1,214 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset;
+
+import javax.xml.namespace.QName;
+
+public class QualifiedName {
+    public final String prefix;
+    public final String namespaceName;
+    public final String localName;
+    public String qName;
+    public final int index;
+    public final int prefixIndex;
+    public final int namespaceNameIndex;
+    public final int localNameIndex;
+    public int attributeId;
+    public int attributeHash;
+    private QName qNameObject;
+
+    public QualifiedName(String prefix, String namespaceName, String localName, String qName) {
+        this.prefix = prefix;
+        this.namespaceName = namespaceName;
+        this.localName = localName;
+        this.qName = qName;
+        this.index = -1;
+        this.prefixIndex = 0;
+        this.namespaceNameIndex = 0;
+        this.localNameIndex = -1;
+    }
+
+    public QualifiedName(String prefix, String namespaceName, String localName, String qName, int index) {
+        this.prefix = prefix;
+        this.namespaceName = namespaceName;
+        this.localName = localName;
+        this.qName = qName;
+        this.index = index;
+        this.prefixIndex = 0;
+        this.namespaceNameIndex = 0;
+        this.localNameIndex = -1;
+    }
+
+    public QualifiedName(String prefix, String namespaceName, String localName, String qName, int index,
+            int prefixIndex, int namespaceNameIndex, int localNameIndex) {
+        this.prefix = prefix;
+        this.namespaceName = namespaceName;
+        this.localName = localName;
+        this.qName = qName;
+        this.index = index;
+        this.prefixIndex = prefixIndex + 1;
+        this.namespaceNameIndex = namespaceNameIndex + 1;
+        this.localNameIndex = localNameIndex;
+    }
+
+    public QualifiedName(String prefix, String namespaceName, String localName) {
+        this.prefix = prefix;
+        this.namespaceName = namespaceName;
+        this.localName = localName;
+        this.qName = createQNameString(prefix, localName);
+        this.index = -1;
+        this.prefixIndex = 0;
+        this.namespaceNameIndex = 0;
+        this.localNameIndex = -1;
+    }
+
+    public QualifiedName(String prefix, String namespaceName, String localName,
+            int prefixIndex, int namespaceNameIndex, int localNameIndex,
+            char[] charBuffer) {
+        this.prefix = prefix;
+        this.namespaceName = namespaceName;
+        this.localName = localName;
+
+        if (charBuffer != null) {
+            final int l1 = prefix.length();
+            final int l2 = localName.length();
+            final int total = l1 + l2 + 1;
+            if (total < charBuffer.length) {
+                prefix.getChars(0, l1, charBuffer, 0);
+                charBuffer[l1] = ':';
+                localName.getChars(0, l2, charBuffer, l1 + 1);
+                this.qName = new String(charBuffer, 0, total);
+            } else {
+                this.qName = createQNameString(prefix, localName);
+            }
+        } else {
+            this.qName = this.localName;
+        }
+
+        this.prefixIndex = prefixIndex + 1;
+        this.namespaceNameIndex = namespaceNameIndex + 1;
+        this.localNameIndex = localNameIndex;
+        this.index = -1;
+    }
+
+    public QualifiedName(String prefix, String namespaceName, String localName, int index) {
+        this.prefix = prefix;
+        this.namespaceName = namespaceName;
+        this.localName = localName;
+        this.qName = createQNameString(prefix, localName);
+        this.index = index;
+        this.prefixIndex = 0;
+        this.namespaceNameIndex = 0;
+        this.localNameIndex = -1;
+    }
+
+    public QualifiedName(String prefix, String namespaceName, String localName, int index,
+            int prefixIndex, int namespaceNameIndex, int localNameIndex) {
+        this.prefix = prefix;
+        this.namespaceName = namespaceName;
+        this.localName = localName;
+        this.qName = createQNameString(prefix, localName);
+        this.index = index;
+        this.prefixIndex = prefixIndex + 1;
+        this.namespaceNameIndex = namespaceNameIndex + 1;
+        this.localNameIndex = localNameIndex;
+    }
+
+    // Qualified Name as a Namespace Name
+    public QualifiedName(String prefix, String namespaceName) {
+        this.prefix = prefix;
+        this.namespaceName = namespaceName;
+        this.localName = "";
+        this.qName = "";
+        this.index = -1;
+        this.prefixIndex = 0;
+        this.namespaceNameIndex = 0;
+        this.localNameIndex = -1;
+    }
+
+    public final QName getQName() {
+        if (qNameObject == null) {
+            qNameObject = new QName(namespaceName, localName, prefix);
+        }
+
+        return qNameObject;
+    }
+
+    public final String getQNameString() {
+        if (this.qName != "") {
+            return this.qName;
+        }
+
+        return this.qName = createQNameString(prefix, localName);
+    }
+
+    public final void createAttributeValues(int size) {
+        attributeId = localNameIndex | (namespaceNameIndex << 20);
+        attributeHash = localNameIndex % size;
+    }
+
+    private final String createQNameString(String p, String l) {
+        if (p != null && p != "") {
+            final StringBuffer b = new StringBuffer(p);
+            b.append(':');
+            b.append(l);
+            return b.toString();
+        } else {
+            return l;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/UnparsedEntity.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/UnparsedEntity.java
new file mode 100644
index 0000000..adaf428
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/UnparsedEntity.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset;
+
+public class UnparsedEntity extends Notation {
+    public final String notationName;
+
+    /** Creates a new instance of UnparsedEntityDeclaration */
+    public UnparsedEntity(String _name, String _systemIdentifier, String _publicIdentifier, String _notationName) {
+        super(_name, _systemIdentifier, _publicIdentifier);
+        notationName = _notationName;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BASE64EncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BASE64EncodingAlgorithm.java
new file mode 100644
index 0000000..57d5eb3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BASE64EncodingAlgorithm.java
@@ -0,0 +1,264 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class BASE64EncodingAlgorithm extends BuiltInEncodingAlgorithm {
+
+    protected static final char encodeBase64[] = {
+        'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M',
+        'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z',
+        'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm',
+        'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
+        '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '+', '/'
+    };
+
+    protected static final int decodeBase64[] = {
+        /*'+'*/ 62,
+        -1, -1, -1,
+        /*'/'*/ 63,
+        /*'0'*/ 52,
+        /*'1'*/ 53,
+        /*'2'*/ 54,
+        /*'3'*/ 55,
+        /*'4'*/ 56,
+        /*'5'*/ 57,
+        /*'6'*/ 58,
+        /*'7'*/ 59,
+        /*'8'*/ 60,
+        /*'9'*/ 61,
+        -1, -1, -1, -1, -1, -1, -1,
+        /*'A'*/ 0,
+        /*'B'*/ 1,
+        /*'C'*/ 2,
+        /*'D'*/ 3,
+        /*'E'*/ 4,
+        /*'F'*/ 5,
+        /*'G'*/ 6,
+        /*'H'*/ 7,
+        /*'I'*/ 8,
+        /*'J'*/ 9,
+        /*'K'*/ 10,
+        /*'L'*/ 11,
+        /*'M'*/ 12,
+        /*'N'*/ 13,
+        /*'O'*/ 14,
+        /*'P'*/ 15,
+        /*'Q'*/ 16,
+        /*'R'*/ 17,
+        /*'S'*/ 18,
+        /*'T'*/ 19,
+        /*'U'*/ 20,
+        /*'V'*/ 21,
+        /*'W'*/ 22,
+        /*'X'*/ 23,
+        /*'Y'*/ 24,
+        /*'Z'*/ 25,
+        -1, -1, -1, -1, -1, -1,
+        /*'a'*/ 26,
+        /*'b'*/ 27,
+        /*'c'*/ 28,
+        /*'d'*/ 29,
+        /*'e'*/ 30,
+        /*'f'*/ 31,
+        /*'g'*/ 32,
+        /*'h'*/ 33,
+        /*'i'*/ 34,
+        /*'j'*/ 35,
+        /*'k'*/ 36,
+        /*'l'*/ 37,
+        /*'m'*/ 38,
+        /*'n'*/ 39,
+        /*'o'*/ 40,
+        /*'p'*/ 41,
+        /*'q'*/ 42,
+        /*'r'*/ 43,
+        /*'s'*/ 44,
+        /*'t'*/ 45,
+        /*'u'*/ 46,
+        /*'v'*/ 47,
+        /*'w'*/ 48,
+        /*'x'*/ 49,
+        /*'y'*/ 50,
+        /*'z'*/ 51
+    };
+
+    public final Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException {
+        final byte[] data = new byte[length];
+        System.arraycopy(b, start, data, 0, length);
+        return data;
+    }
+
+    public final Object decodeFromInputStream(InputStream s) throws IOException {
+        throw new UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.notImplemented"));
+    }
+
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws IOException {
+        if (!(data instanceof byte[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotByteArray"));
+        }
+
+        s.write((byte[])data);
+    }
+
+    public final Object convertFromCharacters(char[] ch, int start, int length) {
+        if (length == 0) {
+            return new byte[0];
+        }
+
+        StringBuffer encodedValue = removeWhitespace(ch, start, length);
+        int encodedLength = encodedValue.length();
+        if (encodedLength == 0) {
+            return new byte[0];
+        }
+
+        int blockCount = encodedLength / 4;
+        int partialBlockLength = 3;
+
+        if (encodedValue.charAt(encodedLength - 1) == '=') {
+            --partialBlockLength;
+            if (encodedValue.charAt(encodedLength - 2) == '=') {
+                --partialBlockLength;
+            }
+        }
+
+        int valueLength = (blockCount - 1) * 3 + partialBlockLength;
+        byte[] value = new byte[valueLength];
+
+        int idx = 0;
+        int encodedIdx = 0;
+        for (int i = 0; i < blockCount; ++i) {
+            int x1 = decodeBase64[encodedValue.charAt(encodedIdx++) - '+'];
+            int x2 = decodeBase64[encodedValue.charAt(encodedIdx++) - '+'];
+            int x3 = decodeBase64[encodedValue.charAt(encodedIdx++) - '+'];
+            int x4 = decodeBase64[encodedValue.charAt(encodedIdx++) - '+'];
+
+            value[idx++] = (byte) ((x1 << 2) | (x2 >> 4));
+            if (idx < valueLength) {
+                value[idx++] = (byte) (((x2 & 0x0f) << 4) | (x3 >> 2));
+            }
+            if (idx < valueLength) {
+                value[idx++] = (byte) (((x3 & 0x03) << 6) | x4);
+            }
+        }
+
+        return value;
+    }
+
+    public final void convertToCharacters(Object data, StringBuffer s) {
+        if (data == null) {
+            return;
+        }
+        final byte[] value = (byte[]) data;
+        if (value.length == 0) {
+            return;
+        }
+
+        final int partialBlockLength = value.length % 3;
+        final int blockCount = (partialBlockLength != 0) ?
+            value.length / 3 + 1 :
+            value.length / 3;
+
+        final int encodedLength = blockCount * 4;
+        s.ensureCapacity(encodedLength);
+
+        int idx = 0;
+        for (int i = 0; i < blockCount; ++i) {
+            int b1 = value[idx++] & 0xFF;
+            int b2 = (idx < value.length) ? value[idx++] & 0xFF : 0;
+            int b3 = (idx < value.length) ? value[idx++] & 0xFF : 0;
+
+            s.append(encodeBase64[b1 >> 2]);
+
+            s.append(encodeBase64[((b1 & 0x03) << 4) | (b2 >> 4)]);
+
+            s.append(encodeBase64[((b2 & 0x0f) << 2) | (b3 >> 6)]);
+
+            s.append(encodeBase64[b3 & 0x3f]);
+        }
+
+        switch (partialBlockLength) {
+            case 1 :
+                s.setCharAt(encodedLength - 1, '=');
+                s.setCharAt(encodedLength - 2, '=');
+                break;
+            case 2 :
+                s.setCharAt(encodedLength - 1, '=');
+                break;
+        }
+    }
+
+
+
+    public final int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        return octetLength;
+    }
+
+    public int getOctetLengthFromPrimitiveLength(int primitiveLength) {
+        return primitiveLength;
+    }
+
+    public final void encodeToBytes(Object array, int astart, int alength, byte[] b, int start) {
+        System.arraycopy((byte[])array, astart, b, start, alength);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BooleanEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BooleanEncodingAlgorithm.java
new file mode 100644
index 0000000..7b050d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BooleanEncodingAlgorithm.java
@@ -0,0 +1,300 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+
+import java.io.EOFException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.nio.CharBuffer;
+import java.util.ArrayList;
+import java.util.List;
+
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+/**
+ *
+ * An encoder for handling boolean values.  Suppports the builtin BOOLEAN encoder.
+ *
+ * @author Alan Hudson
+ * @author Paul Sandoz
+ *
+ */
+public class BooleanEncodingAlgorithm extends BuiltInEncodingAlgorithm {
+
+    /** Table for setting a particular bit of a byte */
+    private static final int[] BIT_TABLE = {
+        1 << 7,
+        1 << 6,
+        1 << 5,
+        1 << 4,
+        1 << 3,
+        1 << 2,
+        1 << 1,
+        1 << 0};
+
+    public int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        // Cannot determine the number of boolean values from just the octet length
+        throw new UnsupportedOperationException();
+    }
+
+    public int getOctetLengthFromPrimitiveLength(int primitiveLength) {
+        if (primitiveLength < 5) {
+            return 1;
+        } else {
+            final int div = primitiveLength / 8;
+            return (div == 0) ? 2 : 1 + div;
+        }
+    }
+
+    public final Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException {
+        final int blength = getPrimtiveLengthFromOctetLength(length, b[start]);
+        boolean[] data = new boolean[blength];
+
+        decodeFromBytesToBooleanArray(data, 0, blength, b, start, length);
+        return data;
+    }
+
+    public final Object decodeFromInputStream(InputStream s) throws IOException {
+        final List booleanList = new ArrayList();
+
+        int value = s.read();
+        if (value == -1) {
+            throw new EOFException();
+        }
+        final int unusedBits = (value >> 4) & 0xFF;
+
+        int bitPosition = 4;
+        int bitPositionEnd = 8;
+        int valueNext = 0;
+        do {
+            valueNext = s.read();
+            if (valueNext == -1) {
+                bitPositionEnd -= unusedBits;
+            }
+
+            while(bitPosition < bitPositionEnd) {
+                booleanList.add(
+                        new Boolean((value & BIT_TABLE[bitPosition++]) > 0));
+            }
+
+            value = valueNext;
+        } while (value != -1);
+
+        return generateArrayFromList(booleanList);
+    }
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws IOException {
+        if (!(data instanceof boolean[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotBoolean"));
+        }
+
+        boolean array[] = (boolean[])data;
+        final int alength = array.length;
+
+        final int mod = (alength + 4) % 8;
+        final int unusedBits = (mod == 0) ? 0 : 8 - mod;
+
+        int bitPosition = 4;
+        int value = unusedBits << 4;
+        int astart = 0;
+        while (astart < alength) {
+            if (array[astart++]) {
+                value |= BIT_TABLE[bitPosition];
+            }
+
+            if (++bitPosition == 8) {
+                s.write(value);
+                bitPosition = value = 0;
+            }
+        }
+
+        if (bitPosition != 8) {
+            s.write(value);
+        }
+    }
+
+    public final Object convertFromCharacters(char[] ch, int start, int length) {
+        if (length == 0) {
+            return new boolean[0];
+        }
+
+        final CharBuffer cb = CharBuffer.wrap(ch, start, length);
+        final List booleanList = new ArrayList();
+
+        matchWhiteSpaceDelimnatedWords(cb,
+            new WordListener() {
+                public void word(int start, int end) {
+                    if (cb.charAt(start) == 't') {
+                        booleanList.add(Boolean.TRUE);
+                    } else {
+                        booleanList.add(Boolean.FALSE);
+                    }
+                }
+            }
+        );
+
+        return generateArrayFromList(booleanList);
+    }
+
+    public final void convertToCharacters(Object data, StringBuffer s) {
+        if (data == null) {
+            return;
+        }
+
+        final boolean[] value = (boolean[]) data;
+        if (value.length == 0) {
+            return;
+        }
+
+        // Insure conservately as all false
+        s.ensureCapacity(value.length * 5);
+
+        final int end = value.length - 1;
+        for (int i = 0; i <= end; i++) {
+            if (value[i]) {
+                s.append("true");
+            } else {
+                s.append("false");
+            }
+            if (i != end) {
+                s.append(' ');
+            }
+        }
+    }
+
+    public int getPrimtiveLengthFromOctetLength(int octetLength, int firstOctet) throws EncodingAlgorithmException {
+        final int unusedBits = (firstOctet >> 4) & 0xFF;
+        if (octetLength == 1) {
+           if (unusedBits > 3) {
+               throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.unusedBits4"));
+           }
+           return 4 - unusedBits;
+        } else {
+           if (unusedBits > 7) {
+               throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.unusedBits8"));
+           }
+           return octetLength * 8 - 4 - unusedBits;
+        }
+    }
+
+    public final void decodeFromBytesToBooleanArray(boolean[] bdata, int bstart, int blength, byte[] b, int start, int length) {
+        int value = b[start++] & 0xFF;
+        int bitPosition = 4;
+        final int bend = bstart + blength;
+        while (bstart < bend) {
+            if (bitPosition == 8) {
+                value = b[start++] & 0xFF;
+                bitPosition = 0;
+            }
+
+            bdata[bstart++] = (value & BIT_TABLE[bitPosition++]) > 0;
+        }
+    }
+
+    public void encodeToBytes(Object array, int astart, int alength, byte[] b, int start) {
+        if (!(array instanceof boolean[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotBoolean"));
+        }
+
+        encodeToBytesFromBooleanArray((boolean[])array, astart, alength, b, start);
+    }
+
+    public void encodeToBytesFromBooleanArray(boolean[] array, int astart, int alength, byte[] b, int start) {
+        final int mod = (alength + 4) % 8;
+        final int unusedBits = (mod == 0) ? 0 : 8 - mod;
+
+        int bitPosition = 4;
+        int value = unusedBits << 4;
+        final int aend = astart + alength;
+        while (astart < aend) {
+            if (array[astart++]) {
+                value |= BIT_TABLE[bitPosition];
+            }
+
+            if (++bitPosition == 8) {
+                b[start++] = (byte)value;
+                bitPosition = value = 0;
+            }
+        }
+
+        if (bitPosition > 0) {
+            b[start] = (byte)value;
+        }
+    }
+
+
+    /**
+     *
+     * Generate a boolean array from a list of Booleans.
+     *
+     * @param array The array
+     *
+     */
+    private final boolean[] generateArrayFromList(List array) {
+        boolean[] bdata = new boolean[array.size()];
+        for (int i = 0; i < bdata.length; i++) {
+            bdata[i] = ((Boolean)array.get(i)).booleanValue();
+        }
+
+        return bdata;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithm.java
new file mode 100644
index 0000000..e0918fd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithm.java
@@ -0,0 +1,110 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.nio.CharBuffer;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithm;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+
+public abstract class BuiltInEncodingAlgorithm implements EncodingAlgorithm {
+    protected final static Pattern SPACE_PATTERN = Pattern.compile("\\s");
+
+    public abstract int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException;
+
+    public abstract int getOctetLengthFromPrimitiveLength(int primitiveLength);
+
+    public abstract void encodeToBytes(Object array, int astart, int alength, byte[] b, int start);
+
+    public interface WordListener {
+        public void word(int start, int end);
+    }
+
+    public void matchWhiteSpaceDelimnatedWords(CharBuffer cb, WordListener wl) {
+        Matcher m = SPACE_PATTERN.matcher(cb);
+        int i = 0;
+        int s = 0;
+        while(m.find()) {
+            s = m.start();
+            if (s != i) {
+                wl.word(i, s);
+            }
+            i = m.end();
+        }
+        wl.word(i, cb.length());
+    }
+
+    public StringBuffer removeWhitespace(char[] ch, int start, int length) {
+        StringBuffer buf = new StringBuffer();
+        int firstNonWS = 0;
+        int idx = 0;
+        for (; idx < length; ++idx) {
+            if (Character.isWhitespace(ch[idx + start])) {
+                if (firstNonWS < idx) {
+                    buf.append(ch, firstNonWS + start, idx - firstNonWS);
+                }
+                firstNonWS = idx + 1;
+            }
+        }
+        if (firstNonWS < idx) {
+            buf.append(ch, firstNonWS + start, idx - firstNonWS);
+        }
+        return buf;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithmFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithmFactory.java
new file mode 100644
index 0000000..f0482d2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithmFactory.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+
+public final class BuiltInEncodingAlgorithmFactory {
+
+    public final static BuiltInEncodingAlgorithm[] table =
+            new BuiltInEncodingAlgorithm[EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END + 1];
+
+    public final static HexadecimalEncodingAlgorithm hexadecimalEncodingAlgorithm = new HexadecimalEncodingAlgorithm();
+
+    public final static BASE64EncodingAlgorithm base64EncodingAlgorithm = new BASE64EncodingAlgorithm();
+
+    public final static BooleanEncodingAlgorithm booleanEncodingAlgorithm = new BooleanEncodingAlgorithm();
+
+    public final static ShortEncodingAlgorithm shortEncodingAlgorithm = new ShortEncodingAlgorithm();
+
+    public final static IntEncodingAlgorithm intEncodingAlgorithm = new IntEncodingAlgorithm();
+
+    public final static LongEncodingAlgorithm longEncodingAlgorithm = new LongEncodingAlgorithm();
+
+    public final static FloatEncodingAlgorithm floatEncodingAlgorithm = new FloatEncodingAlgorithm();
+
+    public final static DoubleEncodingAlgorithm doubleEncodingAlgorithm = new DoubleEncodingAlgorithm();
+
+    public final static UUIDEncodingAlgorithm uuidEncodingAlgorithm = new UUIDEncodingAlgorithm();
+
+    static {
+        table[EncodingAlgorithmIndexes.HEXADECIMAL] = hexadecimalEncodingAlgorithm;
+        table[EncodingAlgorithmIndexes.BASE64] = base64EncodingAlgorithm;
+        table[EncodingAlgorithmIndexes.SHORT] = shortEncodingAlgorithm;
+        table[EncodingAlgorithmIndexes.INT] = intEncodingAlgorithm;
+        table[EncodingAlgorithmIndexes.LONG] = longEncodingAlgorithm;
+        table[EncodingAlgorithmIndexes.BOOLEAN] = booleanEncodingAlgorithm;
+        table[EncodingAlgorithmIndexes.FLOAT] = floatEncodingAlgorithm;
+        table[EncodingAlgorithmIndexes.DOUBLE] = doubleEncodingAlgorithm;
+        table[EncodingAlgorithmIndexes.UUID] = uuidEncodingAlgorithm;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithmState.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithmState.java
new file mode 100644
index 0000000..d84ccca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/BuiltInEncodingAlgorithmState.java
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+public class BuiltInEncodingAlgorithmState {
+
+    public static final int INITIAL_LENGTH = 8;
+
+    public boolean[] booleanArray = new boolean[INITIAL_LENGTH];
+
+    public short[] shortArray = new short[INITIAL_LENGTH];
+
+    public int[] intArray = new int[INITIAL_LENGTH];
+
+    public long[] longArray = new long[INITIAL_LENGTH];
+
+    public float[] floatArray = new float[INITIAL_LENGTH];
+
+    public double[] doubleArray = new double[INITIAL_LENGTH];
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/DoubleEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/DoubleEncodingAlgorithm.java
new file mode 100644
index 0000000..a509793
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/DoubleEncodingAlgorithm.java
@@ -0,0 +1,242 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.io.EOFException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.nio.CharBuffer;
+import java.util.ArrayList;
+import java.util.List;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+
+public class DoubleEncodingAlgorithm extends IEEE754FloatingPointEncodingAlgorithm {
+
+    public final int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        if (octetLength % DOUBLE_SIZE != 0) {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().
+                    getString("message.lengthIsNotMultipleOfDouble", new Object[]{new Integer(DOUBLE_SIZE)}));
+        }
+
+        return octetLength / DOUBLE_SIZE;
+    }
+
+    public int getOctetLengthFromPrimitiveLength(int primitiveLength) {
+        return primitiveLength * DOUBLE_SIZE;
+    }
+
+    public final Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException {
+        double[] data = new double[getPrimtiveLengthFromOctetLength(length)];
+        decodeFromBytesToDoubleArray(data, 0, b, start, length);
+
+        return data;
+    }
+
+    public final Object decodeFromInputStream(InputStream s) throws IOException {
+        return decodeFromInputStreamToDoubleArray(s);
+    }
+
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws IOException {
+        if (!(data instanceof double[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotDouble"));
+        }
+
+        final double[] fdata = (double[])data;
+
+        encodeToOutputStreamFromDoubleArray(fdata, s);
+    }
+
+    public final Object convertFromCharacters(char[] ch, int start, int length) {
+        final CharBuffer cb = CharBuffer.wrap(ch, start, length);
+        final List doubleList = new ArrayList();
+
+        matchWhiteSpaceDelimnatedWords(cb,
+                new WordListener() {
+            public void word(int start, int end) {
+                String fStringValue = cb.subSequence(start, end).toString();
+                doubleList.add(Float.valueOf(fStringValue));
+            }
+        }
+        );
+
+        return generateArrayFromList(doubleList);
+    }
+
+    public final void convertToCharacters(Object data, StringBuffer s) {
+        if (!(data instanceof double[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotDouble"));
+        }
+
+        final double[] fdata = (double[])data;
+
+        convertToCharactersFromDoubleArray(fdata, s);
+    }
+
+
+    public final void decodeFromBytesToDoubleArray(double[] data, int fstart, byte[] b, int start, int length) {
+        final int size = length / DOUBLE_SIZE;
+        for (int i = 0; i < size; i++) {
+            final long bits =
+                    ((long)(b[start++] & 0xFF) << 56) |
+                    ((long)(b[start++] & 0xFF) << 48) |
+                    ((long)(b[start++] & 0xFF) << 40) |
+                    ((long)(b[start++] & 0xFF) << 32) |
+                    ((long)(b[start++] & 0xFF) << 24) |
+                    ((long)(b[start++] & 0xFF) << 16) |
+                    ((long)(b[start++] & 0xFF) << 8) |
+                    (long)(b[start++] & 0xFF);
+            data[fstart++] = Double.longBitsToDouble(bits);
+        }
+    }
+
+    public final double[] decodeFromInputStreamToDoubleArray(InputStream s) throws IOException {
+        final List doubleList = new ArrayList();
+        final byte[] b = new byte[DOUBLE_SIZE];
+
+        while (true) {
+            int n = s.read(b);
+            if (n != DOUBLE_SIZE) {
+                if (n == -1) {
+                    break;
+                }
+
+                while(n != DOUBLE_SIZE) {
+                    final int m = s.read(b, n, DOUBLE_SIZE - n);
+                    if (m == -1) {
+                        throw new EOFException();
+                    }
+                    n += m;
+                }
+            }
+
+            final int bits =
+                    ((b[0] & 0xFF) << 56) |
+                    ((b[1] & 0xFF) << 48) |
+                    ((b[2] & 0xFF) << 40) |
+                    ((b[3] & 0xFF) << 32) |
+                    ((b[4] & 0xFF) << 24) |
+                    ((b[5] & 0xFF) << 16) |
+                    ((b[6] & 0xFF) << 8) |
+                    (b[7] & 0xFF);
+
+            doubleList.add(new Double(Double.longBitsToDouble(bits)));
+        }
+
+        return generateArrayFromList(doubleList);
+    }
+
+
+    public final void encodeToOutputStreamFromDoubleArray(double[] fdata, OutputStream s) throws IOException {
+        for (int i = 0; i < fdata.length; i++) {
+            final long bits = Double.doubleToLongBits(fdata[i]);
+            s.write((int)((bits >>> 56) & 0xFF));
+            s.write((int)((bits >>> 48) & 0xFF));
+            s.write((int)((bits >>> 40) & 0xFF));
+            s.write((int)((bits >>> 32) & 0xFF));
+            s.write((int)((bits >>> 24) & 0xFF));
+            s.write((int)((bits >>> 16) & 0xFF));
+            s.write((int)((bits >>>  8) & 0xFF));
+            s.write((int)(bits & 0xFF));
+        }
+    }
+
+    public final void encodeToBytes(Object array, int astart, int alength, byte[] b, int start) {
+        encodeToBytesFromDoubleArray((double[])array, astart, alength, b, start);
+    }
+
+    public final void encodeToBytesFromDoubleArray(double[] fdata, int fstart, int flength, byte[] b, int start) {
+        final int fend = fstart + flength;
+        for (int i = fstart; i < fend; i++) {
+            final long bits = Double.doubleToLongBits(fdata[i]);
+            b[start++] = (byte)((bits >>> 56) & 0xFF);
+            b[start++] = (byte)((bits >>> 48) & 0xFF);
+            b[start++] = (byte)((bits >>> 40) & 0xFF);
+            b[start++] = (byte)((bits >>> 32) & 0xFF);
+            b[start++] = (byte)((bits >>> 24) & 0xFF);
+            b[start++] = (byte)((bits >>> 16) & 0xFF);
+            b[start++] = (byte)((bits >>>  8) & 0xFF);
+            b[start++] = (byte)(bits & 0xFF);
+        }
+    }
+
+
+    public final void convertToCharactersFromDoubleArray(double[] fdata, StringBuffer s) {
+        final int end = fdata.length - 1;
+        for (int i = 0; i <= end; i++) {
+            s.append(Double.toString(fdata[i]));
+            if (i != end) {
+                s.append(' ');
+            }
+        }
+    }
+
+
+    public final double[] generateArrayFromList(List array) {
+        double[] fdata = new double[array.size()];
+        for (int i = 0; i < fdata.length; i++) {
+            fdata[i] = ((Double)array.get(i)).doubleValue();
+        }
+
+        return fdata;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/FloatEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/FloatEncodingAlgorithm.java
new file mode 100644
index 0000000..7a6ec05
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/FloatEncodingAlgorithm.java
@@ -0,0 +1,223 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.io.EOFException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.nio.CharBuffer;
+import java.util.ArrayList;
+import java.util.List;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+
+public class FloatEncodingAlgorithm extends IEEE754FloatingPointEncodingAlgorithm {
+
+    public final int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        if (octetLength % FLOAT_SIZE != 0) {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().
+                    getString("message.lengthNotMultipleOfFloat", new Object[]{new Integer(FLOAT_SIZE)}));
+        }
+
+        return octetLength / FLOAT_SIZE;
+    }
+
+    public int getOctetLengthFromPrimitiveLength(int primitiveLength) {
+        return primitiveLength * FLOAT_SIZE;
+    }
+
+    public final Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException {
+        float[] data = new float[getPrimtiveLengthFromOctetLength(length)];
+        decodeFromBytesToFloatArray(data, 0, b, start, length);
+
+        return data;
+    }
+
+    public final Object decodeFromInputStream(InputStream s) throws IOException {
+        return decodeFromInputStreamToFloatArray(s);
+    }
+
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws IOException {
+        if (!(data instanceof float[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotFloat"));
+        }
+
+        final float[] fdata = (float[])data;
+
+        encodeToOutputStreamFromFloatArray(fdata, s);
+    }
+
+    public final Object convertFromCharacters(char[] ch, int start, int length) {
+        final CharBuffer cb = CharBuffer.wrap(ch, start, length);
+        final List floatList = new ArrayList();
+
+        matchWhiteSpaceDelimnatedWords(cb,
+                new WordListener() {
+            public void word(int start, int end) {
+                String fStringValue = cb.subSequence(start, end).toString();
+                floatList.add(Float.valueOf(fStringValue));
+            }
+        }
+        );
+
+        return generateArrayFromList(floatList);
+    }
+
+    public final void convertToCharacters(Object data, StringBuffer s) {
+        if (!(data instanceof float[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotFloat"));
+        }
+
+        final float[] fdata = (float[])data;
+
+        convertToCharactersFromFloatArray(fdata, s);
+    }
+
+
+    public final void decodeFromBytesToFloatArray(float[] data, int fstart, byte[] b, int start, int length) {
+        final int size = length / FLOAT_SIZE;
+        for (int i = 0; i < size; i++) {
+            final int bits = ((b[start++] & 0xFF) << 24) |
+                    ((b[start++] & 0xFF) << 16) |
+                    ((b[start++] & 0xFF) << 8) |
+                    (b[start++] & 0xFF);
+            data[fstart++] = Float.intBitsToFloat(bits);
+        }
+    }
+
+    public final float[] decodeFromInputStreamToFloatArray(InputStream s) throws IOException {
+        final List floatList = new ArrayList();
+        final byte[] b = new byte[FLOAT_SIZE];
+
+        while (true) {
+            int n = s.read(b);
+            if (n != 4) {
+                if (n == -1) {
+                    break;
+                }
+
+                while(n != 4) {
+                    final int m = s.read(b, n, FLOAT_SIZE - n);
+                    if (m == -1) {
+                        throw new EOFException();
+                    }
+                    n += m;
+                }
+            }
+
+            final int bits = ((b[0] & 0xFF) << 24) |
+                    ((b[1] & 0xFF) << 16) |
+                    ((b[2] & 0xFF) << 8) |
+                    (b[3] & 0xFF);
+            floatList.add(new Float(Float.intBitsToFloat(bits)));
+        }
+
+        return generateArrayFromList(floatList);
+    }
+
+
+    public final void encodeToOutputStreamFromFloatArray(float[] fdata, OutputStream s) throws IOException {
+        for (int i = 0; i < fdata.length; i++) {
+            final int bits = Float.floatToIntBits(fdata[i]);
+            s.write((bits >>> 24) & 0xFF);
+            s.write((bits >>> 16) & 0xFF);
+            s.write((bits >>> 8) & 0xFF);
+            s.write(bits & 0xFF);
+        }
+    }
+
+    public final void encodeToBytes(Object array, int astart, int alength, byte[] b, int start) {
+        encodeToBytesFromFloatArray((float[])array, astart, alength, b, start);
+    }
+
+    public final void encodeToBytesFromFloatArray(float[] fdata, int fstart, int flength, byte[] b, int start) {
+        final int fend = fstart + flength;
+        for (int i = fstart; i < fend; i++) {
+            final int bits = Float.floatToIntBits(fdata[i]);
+            b[start++] = (byte)((bits >>> 24) & 0xFF);
+            b[start++] = (byte)((bits >>> 16) & 0xFF);
+            b[start++] = (byte)((bits >>>  8) & 0xFF);
+            b[start++] = (byte)(bits & 0xFF);
+        }
+    }
+
+
+    public final void convertToCharactersFromFloatArray(float[] fdata, StringBuffer s) {
+        final int end = fdata.length - 1;
+        for (int i = 0; i <= end; i++) {
+            s.append(Float.toString(fdata[i]));
+            if (i != end) {
+                s.append(' ');
+            }
+        }
+    }
+
+
+    public final float[] generateArrayFromList(List array) {
+        float[] fdata = new float[array.size()];
+        for (int i = 0; i < fdata.length; i++) {
+            fdata[i] = ((Float)array.get(i)).floatValue();
+        }
+
+        return fdata;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/HexadecimalEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/HexadecimalEncodingAlgorithm.java
new file mode 100644
index 0000000..4748d2e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/HexadecimalEncodingAlgorithm.java
@@ -0,0 +1,168 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class HexadecimalEncodingAlgorithm extends BuiltInEncodingAlgorithm {
+    private static final char NIBBLE_TO_HEXADECIMAL_TABLE[] =
+        {   '0','1','2','3','4','5','6','7',
+            '8','9','A','B','B','D','E','F' };
+
+    private static final int HEXADECIMAL_TO_NIBBLE_TABLE[] = {
+        /*'0'*/ 0,
+        /*'1'*/ 1,
+        /*'2'*/ 2,
+        /*'3'*/ 3,
+        /*'4'*/ 4,
+        /*'5'*/ 5,
+        /*'6'*/ 6,
+        /*'7'*/ 7,
+        /*'8'*/ 8,
+        /*'9'*/ 9, -1, -1, -1, -1, -1, -1, -1,
+        /*'A'*/ 10,
+        /*'B'*/ 11,
+        /*'C'*/ 12,
+        /*'D'*/ 13,
+        /*'E'*/ 14,
+        /*'F'*/ 15,
+        /*'G'-'Z'*/-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
+        /*'[' - '`'*/ -1, -1, -1, -1, -1, -1,
+        /*'a'*/ 10,
+        /*'b'*/ 11,
+        /*'c'*/ 12,
+        /*'d'*/ 13,
+        /*'e'*/ 14,
+        /*'f'*/ 15 };
+
+    public final Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException {
+        final byte[] data = new byte[length];
+        System.arraycopy(b, start, data, 0, length);
+        return data;
+    }
+
+    public final Object decodeFromInputStream(InputStream s) throws IOException {
+        throw new UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.notImplemented"));
+    }
+
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws IOException {
+        if (!(data instanceof byte[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotByteArray"));
+        }
+
+        s.write((byte[])data);
+    }
+
+    public final Object convertFromCharacters(char[] ch, int start, int length) {
+        if (length == 0) {
+            return new byte[0];
+        }
+
+        StringBuffer encodedValue = removeWhitespace(ch, start, length);
+        int encodedLength = encodedValue.length();
+        if (encodedLength == 0) {
+            return new byte[0];
+        }
+
+        int valueLength = encodedValue.length() / 2;
+        byte[] value = new byte[valueLength];
+
+        int encodedIdx = 0;
+        for (int i = 0; i < valueLength; ++i) {
+            int nibble1 = HEXADECIMAL_TO_NIBBLE_TABLE[encodedValue.charAt(encodedIdx++) - '0'];
+            int nibble2 = HEXADECIMAL_TO_NIBBLE_TABLE[encodedValue.charAt(encodedIdx++) - '0'];
+            value[i] = (byte) ((nibble1 << 4) | nibble2);
+        }
+
+        return value;
+    }
+
+    public final void convertToCharacters(Object data, StringBuffer s) {
+        if (data == null) {
+            return;
+        }
+        final byte[] value = (byte[]) data;
+        if (value.length == 0) {
+            return;
+        }
+
+        s.ensureCapacity(value.length * 2);
+        for (int i = 0; i < value.length; ++i) {
+            s.append(NIBBLE_TO_HEXADECIMAL_TABLE[(value[i] >>> 4) & 0xf]);
+            s.append(NIBBLE_TO_HEXADECIMAL_TABLE[value[i] & 0xf]);
+        }
+    }
+
+
+
+    public final int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        return octetLength * 2;
+    }
+
+    public int getOctetLengthFromPrimitiveLength(int primitiveLength) {
+        return primitiveLength / 2;
+    }
+
+    public final void encodeToBytes(Object array, int astart, int alength, byte[] b, int start) {
+        System.arraycopy((byte[])array, astart, b, start, alength);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IEEE754FloatingPointEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IEEE754FloatingPointEncodingAlgorithm.java
new file mode 100644
index 0000000..5d98a61
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IEEE754FloatingPointEncodingAlgorithm.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+public abstract class IEEE754FloatingPointEncodingAlgorithm extends BuiltInEncodingAlgorithm {
+    public final static int FLOAT_SIZE  = 4;
+    public final static int DOUBLE_SIZE = 8;
+
+    public final static int FLOAT_MAX_CHARACTER_SIZE    = 14;
+    public final static int DOUBLE_MAX_CHARACTER_SIZE   = 24;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IntEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IntEncodingAlgorithm.java
new file mode 100644
index 0000000..5a6f49b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IntEncodingAlgorithm.java
@@ -0,0 +1,222 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.io.EOFException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.nio.CharBuffer;
+import java.util.ArrayList;
+import java.util.List;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+
+public class IntEncodingAlgorithm extends IntegerEncodingAlgorithm {
+
+    public final int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        if (octetLength % INT_SIZE != 0) {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().
+                    getString("message.lengthNotMultipleOfInt", new Object[]{new Integer(INT_SIZE)}));
+        }
+
+        return octetLength / INT_SIZE;
+    }
+
+    public int getOctetLengthFromPrimitiveLength(int primitiveLength) {
+        return primitiveLength * INT_SIZE;
+    }
+
+    public final Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException {
+        int[] data = new int[getPrimtiveLengthFromOctetLength(length)];
+        decodeFromBytesToIntArray(data, 0, b, start, length);
+
+        return data;
+    }
+
+    public final Object decodeFromInputStream(InputStream s) throws IOException {
+        return decodeFromInputStreamToIntArray(s);
+    }
+
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws IOException {
+        if (!(data instanceof int[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotIntArray"));
+        }
+
+        final int[] idata = (int[])data;
+
+        encodeToOutputStreamFromIntArray(idata, s);
+    }
+
+
+    public final Object convertFromCharacters(char[] ch, int start, int length) {
+        final CharBuffer cb = CharBuffer.wrap(ch, start, length);
+        final List integerList = new ArrayList();
+
+        matchWhiteSpaceDelimnatedWords(cb,
+                new WordListener() {
+            public void word(int start, int end) {
+                String iStringValue = cb.subSequence(start, end).toString();
+                integerList.add(Integer.valueOf(iStringValue));
+            }
+        }
+        );
+
+        return generateArrayFromList(integerList);
+    }
+
+    public final void convertToCharacters(Object data, StringBuffer s) {
+        if (!(data instanceof int[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotIntArray"));
+        }
+
+        final int[] idata = (int[])data;
+
+        convertToCharactersFromIntArray(idata, s);
+    }
+
+
+    public final void decodeFromBytesToIntArray(int[] idata, int istart, byte[] b, int start, int length) {
+        final int size = length / INT_SIZE;
+        for (int i = 0; i < size; i++) {
+            idata[istart++] = ((b[start++] & 0xFF) << 24) |
+                    ((b[start++] & 0xFF) << 16) |
+                    ((b[start++] & 0xFF) << 8) |
+                    (b[start++] & 0xFF);
+        }
+    }
+
+    public final int[] decodeFromInputStreamToIntArray(InputStream s) throws IOException {
+        final List integerList = new ArrayList();
+        final byte[] b = new byte[INT_SIZE];
+
+        while (true) {
+            int n = s.read(b);
+            if (n != 4) {
+                if (n == -1) {
+                    break;
+                }
+
+                while(n != 4) {
+                    final int m = s.read(b, n, INT_SIZE - n);
+                    if (m == -1) {
+                        throw new EOFException();
+                    }
+                    n += m;
+                }
+            }
+
+            final int i = ((b[0] & 0xFF) << 24) |
+                    ((b[1] & 0xFF) << 16) |
+                    ((b[2] & 0xFF) << 8) |
+                    (b[3] & 0xFF);
+            integerList.add(new Integer(i));
+        }
+
+        return generateArrayFromList(integerList);
+    }
+
+
+    public final void encodeToOutputStreamFromIntArray(int[] idata, OutputStream s) throws IOException {
+        for (int i = 0; i < idata.length; i++) {
+            final int bits = idata[i];
+            s.write((bits >>> 24) & 0xFF);
+            s.write((bits >>> 16) & 0xFF);
+            s.write((bits >>> 8) & 0xFF);
+            s.write(bits & 0xFF);
+        }
+    }
+
+    public final void encodeToBytes(Object array, int astart, int alength, byte[] b, int start) {
+        encodeToBytesFromIntArray((int[])array, astart, alength, b, start);
+    }
+
+    public final void encodeToBytesFromIntArray(int[] idata, int istart, int ilength, byte[] b, int start) {
+        final int iend = istart + ilength;
+        for (int i = istart; i < iend; i++) {
+            final int bits = idata[i];
+            b[start++] = (byte)((bits >>> 24) & 0xFF);
+            b[start++] = (byte)((bits >>> 16) & 0xFF);
+            b[start++] = (byte)((bits >>>  8) & 0xFF);
+            b[start++] = (byte)(bits & 0xFF);
+        }
+    }
+
+
+    public final void convertToCharactersFromIntArray(int[] idata, StringBuffer s) {
+        final int end = idata.length - 1;
+        for (int i = 0; i <= end; i++) {
+            s.append(Integer.toString(idata[i]));
+            if (i != end) {
+                s.append(' ');
+            }
+        }
+    }
+
+
+    public final int[] generateArrayFromList(List array) {
+        int[] idata = new int[array.size()];
+        for (int i = 0; i < idata.length; i++) {
+            idata[i] = ((Integer)array.get(i)).intValue();
+        }
+
+        return idata;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IntegerEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IntegerEncodingAlgorithm.java
new file mode 100644
index 0000000..38b0794
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/IntegerEncodingAlgorithm.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+public abstract class IntegerEncodingAlgorithm extends BuiltInEncodingAlgorithm {
+    public final static int SHORT_SIZE  = 2;
+    public final static int INT_SIZE    = 4;
+    public final static int LONG_SIZE   = 8;
+
+    public final static int SHORT_MAX_CHARACTER_SIZE    = 6;
+    public final static int INT_MAX_CHARACTER_SIZE      = 11;
+    public final static int LONG_MAX_CHARACTER_SIZE     = 20;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/LongEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/LongEncodingAlgorithm.java
new file mode 100644
index 0000000..cb3f930
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/LongEncodingAlgorithm.java
@@ -0,0 +1,239 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.io.EOFException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.nio.CharBuffer;
+import java.util.ArrayList;
+import java.util.List;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+public class LongEncodingAlgorithm extends IntegerEncodingAlgorithm {
+
+    public int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        if (octetLength % LONG_SIZE != 0) {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().
+                    getString("message.lengthNotMultipleOfLong", new Object[]{new Integer(LONG_SIZE)}));
+        }
+
+        return octetLength / LONG_SIZE;
+    }
+
+    public int getOctetLengthFromPrimitiveLength(int primitiveLength) {
+        return primitiveLength * LONG_SIZE;
+    }
+
+    public final Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException {
+        long[] data = new long[getPrimtiveLengthFromOctetLength(length)];
+        decodeFromBytesToLongArray(data, 0, b, start, length);
+
+        return data;
+    }
+
+    public final Object decodeFromInputStream(InputStream s) throws IOException {
+        return decodeFromInputStreamToIntArray(s);
+    }
+
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws IOException {
+        if (!(data instanceof long[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotLongArray"));
+        }
+
+        final long[] ldata = (long[])data;
+
+        encodeToOutputStreamFromLongArray(ldata, s);
+    }
+
+
+    public Object convertFromCharacters(char[] ch, int start, int length) {
+        final CharBuffer cb = CharBuffer.wrap(ch, start, length);
+        final List longList = new ArrayList();
+
+        matchWhiteSpaceDelimnatedWords(cb,
+                new WordListener() {
+            public void word(int start, int end) {
+                String lStringValue = cb.subSequence(start, end).toString();
+                longList.add(Long.valueOf(lStringValue));
+            }
+        }
+        );
+
+        return generateArrayFromList(longList);
+    }
+
+    public void convertToCharacters(Object data, StringBuffer s) {
+        if (!(data instanceof long[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotLongArray"));
+        }
+
+        final long[] ldata = (long[])data;
+
+        convertToCharactersFromLongArray(ldata, s);
+    }
+
+
+    public final void decodeFromBytesToLongArray(long[] ldata, int istart, byte[] b, int start, int length) {
+        final int size = length / LONG_SIZE;
+        for (int i = 0; i < size; i++) {
+            ldata[istart++] =
+                    ((long)(b[start++] & 0xFF) << 56) |
+                    ((long)(b[start++] & 0xFF) << 48) |
+                    ((long)(b[start++] & 0xFF) << 40) |
+                    ((long)(b[start++] & 0xFF) << 32) |
+                    ((long)(b[start++] & 0xFF) << 24) |
+                    ((long)(b[start++] & 0xFF) << 16) |
+                    ((long)(b[start++] & 0xFF) << 8) |
+                    (long)(b[start++] & 0xFF);
+        }
+    }
+
+    public final long[] decodeFromInputStreamToIntArray(InputStream s) throws IOException {
+        final List longList = new ArrayList();
+        final byte[] b = new byte[LONG_SIZE];
+
+        while (true) {
+            int n = s.read(b);
+            if (n != LONG_SIZE) {
+                if (n == -1) {
+                    break;
+                }
+
+                while(n != LONG_SIZE) {
+                    final int m = s.read(b, n, LONG_SIZE - n);
+                    if (m == -1) {
+                        throw new EOFException();
+                    }
+                    n += m;
+                }
+            }
+
+            final int l =
+                    ((b[0] & 0xFF) << 56) |
+                    ((b[1] & 0xFF) << 48) |
+                    ((b[2] & 0xFF) << 40) |
+                    ((b[3] & 0xFF) << 32) |
+                    ((b[4] & 0xFF) << 24) |
+                    ((b[5] & 0xFF) << 16) |
+                    ((b[6] & 0xFF) << 8) |
+                    (b[7] & 0xFF);
+            longList.add(new Long(l));
+        }
+
+        return generateArrayFromList(longList);
+    }
+
+
+    public final void encodeToOutputStreamFromLongArray(long[] ldata, OutputStream s) throws IOException {
+        for (int i = 0; i < ldata.length; i++) {
+            final long bits = ldata[i];
+            s.write((int)((bits >>> 56) & 0xFF));
+            s.write((int)((bits >>> 48) & 0xFF));
+            s.write((int)((bits >>> 40) & 0xFF));
+            s.write((int)((bits >>> 32) & 0xFF));
+            s.write((int)((bits >>> 24) & 0xFF));
+            s.write((int)((bits >>> 16) & 0xFF));
+            s.write((int)((bits >>> 8) & 0xFF));
+            s.write((int)(bits & 0xFF));
+        }
+    }
+
+    public final void encodeToBytes(Object array, int astart, int alength, byte[] b, int start) {
+        encodeToBytesFromLongArray((long[])array, astart, alength, b, start);
+    }
+
+    public final void encodeToBytesFromLongArray(long[] ldata, int lstart, int llength, byte[] b, int start) {
+        final int lend = lstart + llength;
+        for (int i = lstart; i < lend; i++) {
+            final long bits = ldata[i];
+            b[start++] = (byte)((bits >>> 56) & 0xFF);
+            b[start++] = (byte)((bits >>> 48) & 0xFF);
+            b[start++] = (byte)((bits >>> 40) & 0xFF);
+            b[start++] = (byte)((bits >>> 32) & 0xFF);
+            b[start++] = (byte)((bits >>> 24) & 0xFF);
+            b[start++] = (byte)((bits >>> 16) & 0xFF);
+            b[start++] = (byte)((bits >>>  8) & 0xFF);
+            b[start++] = (byte)(bits & 0xFF);
+        }
+    }
+
+
+    public final void convertToCharactersFromLongArray(long[] ldata, StringBuffer s) {
+        final int end = ldata.length - 1;
+        for (int i = 0; i <= end; i++) {
+            s.append(Long.toString(ldata[i]));
+            if (i != end) {
+                s.append(' ');
+            }
+        }
+    }
+
+
+    public final long[] generateArrayFromList(List array) {
+        long[] ldata = new long[array.size()];
+        for (int i = 0; i < ldata.length; i++) {
+            ldata[i] = ((Long)array.get(i)).longValue();
+        }
+
+        return ldata;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/ShortEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/ShortEncodingAlgorithm.java
new file mode 100644
index 0000000..c328fce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/ShortEncodingAlgorithm.java
@@ -0,0 +1,219 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.io.EOFException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.nio.CharBuffer;
+import java.util.ArrayList;
+import java.util.List;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+/**
+ * An encoder for handling Short values.  Suppports the builtin SHORT encoder.
+ *
+ * @author Alan Hudson
+ * @author Paul Sandoz
+ */
+public class ShortEncodingAlgorithm extends IntegerEncodingAlgorithm {
+
+    public final int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        if (octetLength % SHORT_SIZE != 0) {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().
+                    getString("message.lengthNotMultipleOfShort", new Object[]{new Integer(SHORT_SIZE)}));
+        }
+
+        return octetLength / SHORT_SIZE;
+    }
+
+    public int getOctetLengthFromPrimitiveLength(int primitiveLength) {
+        return primitiveLength * SHORT_SIZE;
+    }
+
+    public final Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException {
+        short[] data = new short[getPrimtiveLengthFromOctetLength(length)];
+        decodeFromBytesToShortArray(data, 0, b, start, length);
+
+        return data;
+    }
+
+    public final Object decodeFromInputStream(InputStream s) throws IOException {
+        return decodeFromInputStreamToShortArray(s);
+    }
+
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws IOException {
+        if (!(data instanceof short[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotShortArray"));
+        }
+
+        final short[] idata = (short[])data;
+
+        encodeToOutputStreamFromShortArray(idata, s);
+    }
+
+
+    public final Object convertFromCharacters(char[] ch, int start, int length) {
+        final CharBuffer cb = CharBuffer.wrap(ch, start, length);
+        final List shortList = new ArrayList();
+
+        matchWhiteSpaceDelimnatedWords(cb,
+                new WordListener() {
+            public void word(int start, int end) {
+                String iStringValue = cb.subSequence(start, end).toString();
+                shortList.add(Short.valueOf(iStringValue));
+            }
+        }
+        );
+
+        return generateArrayFromList(shortList);
+    }
+
+    public final void convertToCharacters(Object data, StringBuffer s) {
+        if (!(data instanceof short[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotShortArray"));
+        }
+
+        final short[] idata = (short[])data;
+
+        convertToCharactersFromShortArray(idata, s);
+    }
+
+
+    public final void decodeFromBytesToShortArray(short[] sdata, int istart, byte[] b, int start, int length) {
+        final int size = length / SHORT_SIZE;
+        for (int i = 0; i < size; i++) {
+            sdata[istart++] = (short) (((b[start++] & 0xFF) << 8) |
+                    (b[start++] & 0xFF));
+        }
+    }
+
+    public final short[] decodeFromInputStreamToShortArray(InputStream s) throws IOException {
+        final List shortList = new ArrayList();
+        final byte[] b = new byte[SHORT_SIZE];
+
+        while (true) {
+            int n = s.read(b);
+            if (n != 2) {
+                if (n == -1) {
+                    break;
+                }
+
+                while(n != 2) {
+                    final int m = s.read(b, n, SHORT_SIZE - n);
+                    if (m == -1) {
+                        throw new EOFException();
+                    }
+                    n += m;
+                }
+            }
+
+            final int i = ((b[0] & 0xFF) << 8) |
+                    (b[1] & 0xFF);
+            shortList.add(new Short((short)i));
+        }
+
+        return generateArrayFromList(shortList);
+    }
+
+
+    public final void encodeToOutputStreamFromShortArray(short[] idata, OutputStream s) throws IOException {
+        for (int i = 0; i < idata.length; i++) {
+            final int bits = idata[i];
+            s.write((bits >>> 8) & 0xFF);
+            s.write(bits & 0xFF);
+        }
+    }
+
+    public final void encodeToBytes(Object array, int astart, int alength, byte[] b, int start) {
+        encodeToBytesFromShortArray((short[])array, astart, alength, b, start);
+    }
+
+    public final void encodeToBytesFromShortArray(short[] sdata, int istart, int ilength, byte[] b, int start) {
+        final int iend = istart + ilength;
+        for (int i = istart; i < iend; i++) {
+            final short bits = sdata[i];
+            b[start++] = (byte)((bits >>> 8) & 0xFF);
+            b[start++] = (byte)(bits & 0xFF);
+        }
+    }
+
+
+    public final void convertToCharactersFromShortArray(short[] sdata, StringBuffer s) {
+        final int end = sdata.length - 1;
+        for (int i = 0; i <= end; i++) {
+            s.append(Short.toString(sdata[i]));
+            if (i != end) {
+                s.append(' ');
+            }
+        }
+    }
+
+
+    public final short[] generateArrayFromList(List array) {
+        short[] sdata = new short[array.size()];
+        for (int i = 0; i < sdata.length; i++) {
+            sdata[i] = ((Short)array.get(i)).shortValue();
+        }
+
+        return sdata;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/UUIDEncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/UUIDEncodingAlgorithm.java
new file mode 100644
index 0000000..a4e0796
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/algorithm/UUIDEncodingAlgorithm.java
@@ -0,0 +1,146 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.algorithm;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.nio.CharBuffer;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class UUIDEncodingAlgorithm extends LongEncodingAlgorithm {
+
+    public final int getPrimtiveLengthFromOctetLength(int octetLength) throws EncodingAlgorithmException {
+        if (octetLength % (LONG_SIZE * 2) != 0) {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().
+                    getString("message.lengthNotMultipleOfUUID",new Object[]{new Integer(LONG_SIZE * 2)}));
+        }
+
+        return octetLength / LONG_SIZE;
+    }
+
+    public final Object convertFromCharacters(char[] ch, int start, int length) {
+        final CharBuffer cb = CharBuffer.wrap(ch, start, length);
+        final List longList = new ArrayList();
+
+        matchWhiteSpaceDelimnatedWords(cb,
+                new WordListener() {
+            public void word(int start, int end) {
+                String uuidValue = cb.subSequence(start, end).toString();
+                fromUUIDString(uuidValue);
+                longList.add(new Long(_msb));
+                longList.add(new Long(_lsb));
+            }
+        }
+        );
+
+        return generateArrayFromList(longList);
+    }
+
+    public final void convertToCharacters(Object data, StringBuffer s) {
+        if (!(data instanceof long[])) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.dataNotLongArray"));
+        }
+
+        final long[] ldata = (long[])data;
+
+        final int end = ldata.length - 1;
+        for (int i = 0; i <= end; i += 2) {
+            s.append(toUUIDString(ldata[i], ldata[i + 1]));
+            if (i != end) {
+                s.append(' ');
+            }
+        }
+    }
+
+
+    private long _msb;
+    private long _lsb;
+
+    final void fromUUIDString(String name) {
+        String[] components = name.split("-");
+        if (components.length != 5)
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.invalidUUID", new Object[]{name}));
+
+        for (int i=0; i<5; i++)
+            components[i] = "0x"+components[i];
+
+        _msb = Long.parseLong(components[0], 16);
+        _msb <<= 16;
+        _msb |= Long.parseLong(components[1], 16);
+        _msb <<= 16;
+        _msb |= Long.parseLong(components[2], 16);
+
+        _lsb = Long.parseLong(components[3], 16);
+        _lsb <<= 48;
+        _lsb |= Long.parseLong(components[4], 16);
+    }
+
+    final String toUUIDString(long msb, long lsb) {
+        return (digits(msb >> 32, 8) + "-" +
+                digits(msb >> 16, 4) + "-" +
+                digits(msb, 4) + "-" +
+                digits(lsb >> 48, 4) + "-" +
+                digits(lsb, 12));
+    }
+
+    final String digits(long val, int digits) {
+        long hi = 1L << (digits * 4);
+        return Long.toHexString(hi | (val & (hi - 1))).substring(1);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/alphabet/BuiltInRestrictedAlphabets.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/alphabet/BuiltInRestrictedAlphabets.java
new file mode 100644
index 0000000..18e19e4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/alphabet/BuiltInRestrictedAlphabets.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.alphabet;
+
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.org.jvnet.fastinfoset.RestrictedAlphabet;
+
+public final class BuiltInRestrictedAlphabets {
+    public final static char[][] table =
+            new char[EncodingConstants.RESTRICTED_ALPHABET_BUILTIN_END + 1][];
+
+    static {
+        table[RestrictedAlphabet.NUMERIC_CHARACTERS_INDEX] = RestrictedAlphabet.NUMERIC_CHARACTERS.toCharArray();
+        table[RestrictedAlphabet.DATE_TIME_CHARACTERS_INDEX] = RestrictedAlphabet.DATE_TIME_CHARACTERS.toCharArray();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/dom/DOMDocumentParser.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/dom/DOMDocumentParser.java
new file mode 100644
index 0000000..3076dcb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/dom/DOMDocumentParser.java
@@ -0,0 +1,1029 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.dom;
+
+import com.sun.xml.internal.fastinfoset.Decoder;
+import com.sun.xml.internal.fastinfoset.DecoderStateTables;
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.algorithm.BuiltInEncodingAlgorithmFactory;
+import com.sun.xml.internal.fastinfoset.util.CharArray;
+import com.sun.xml.internal.fastinfoset.util.CharArrayString;
+import java.io.IOException;
+import java.io.InputStream;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithm;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import org.w3c.dom.Attr;
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+/**
+ * The Fast Infoset DOM parser.
+ * <p>
+ * Instantiate this parser to parse a fast infoset document in accordance
+ * with the DOM API.
+ *
+ */
+public class DOMDocumentParser extends Decoder {
+    protected Document _document;
+
+    protected Node _currentNode;
+
+    protected Element _currentElement;
+
+    protected Attr[] _namespaceAttributes = new Attr[16];
+
+    protected int _namespaceAttributesIndex;
+
+    protected int[] _namespacePrefixes = new int[16];
+
+    protected int _namespacePrefixesIndex;
+
+    /**
+     * Parse a fast infoset document into a {@link Document} instance.
+     * <p>
+     * {@link Node}s will be created and appended to the {@link Document}
+     * instance.
+     *
+     * @param d the {@link Document} instance.
+     * @param s the input stream containing the fast infoset document.
+     */
+    public void parse(Document d, InputStream s) throws FastInfosetException, IOException {
+        _currentNode = _document = d;
+        _namespaceAttributesIndex = 0;
+
+        parse(s);
+    }
+
+    protected final void parse(InputStream s) throws FastInfosetException, IOException {
+        setInputStream(s);
+        parse();
+    }
+
+    protected void resetOnError() {
+        _namespacePrefixesIndex = 0;
+
+        if (_v == null) {
+            _prefixTable.clearCompletely();
+        }
+        _duplicateAttributeVerifier.clear();
+    }
+
+    protected final void parse() throws FastInfosetException, IOException {
+        try {
+            reset();
+            decodeHeader();
+            processDII();
+        } catch (RuntimeException e) {
+            resetOnError();
+            // Wrap runtime exception
+            throw new FastInfosetException(e);
+        } catch (FastInfosetException e) {
+            resetOnError();
+            throw e;
+        } catch (IOException e) {
+            resetOnError();
+            throw e;
+        }
+    }
+
+    protected final void processDII() throws FastInfosetException, IOException {
+        _b = read();
+        if (_b > 0) {
+            processDIIOptionalProperties();
+        }
+
+        // Decode one Document Type II, Comment IIs, PI IIs and one EII
+        boolean firstElementHasOccured = false;
+        boolean documentTypeDeclarationOccured = false;
+        while(!_terminate || !firstElementHasOccured) {
+            _b = read();
+            switch(DecoderStateTables.DII[_b]) {
+                case DecoderStateTables.EII_NO_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[_b], false);
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.EII_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[_b & EncodingConstants.INTEGER_3RD_BIT_SMALL_MASK], true);
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.EII_INDEX_MEDIUM:
+                    processEII(decodeEIIIndexMedium(), (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.EII_INDEX_LARGE:
+                    processEII(decodeEIIIndexLarge(), (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.EII_LITERAL:
+                {
+                    final QualifiedName qn = processLiteralQualifiedName(
+                                _b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                    _elementNameTable.add(qn);
+                    processEII(qn, (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    firstElementHasOccured = true;
+                    break;
+                }
+                case DecoderStateTables.EII_NAMESPACES:
+                    processEIIWithNamespaces();
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.DOCUMENT_TYPE_DECLARATION_II:
+                {
+                    if (documentTypeDeclarationOccured) {
+                        throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.secondOccurenceOfDTDII"));
+                    }
+                    documentTypeDeclarationOccured = true;
+
+                    String system_identifier = ((_b & EncodingConstants.DOCUMENT_TYPE_SYSTEM_IDENTIFIER_FLAG) > 0)
+                        ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : null;
+                    String public_identifier = ((_b & EncodingConstants.DOCUMENT_TYPE_PUBLIC_IDENTIFIER_FLAG) > 0)
+                        ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : null;
+
+                    _b = read();
+                    while (_b == EncodingConstants.PROCESSING_INSTRUCTION) {
+                        switch(decodeNonIdentifyingStringOnFirstBit()) {
+                            case NISTRING_STRING:
+                                final String data = new String(_charBuffer, 0, _charBufferLength);
+                                if (_addToTable) {
+                                    _v.otherString.add(new CharArray(_charBuffer, 0, _charBufferLength, true));
+                                }
+                                break;
+                            case NISTRING_ENCODING_ALGORITHM:
+                                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.processingIIWithEncodingAlgorithm"));
+                            case NISTRING_INDEX:
+                                break;
+                            case NISTRING_EMPTY_STRING:
+                                break;
+                        }
+                        _b = read();
+                    }
+                    if ((_b & EncodingConstants.TERMINATOR) != EncodingConstants.TERMINATOR) {
+                        throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.processingInstructionIIsNotTerminatedCorrectly"));
+                    }
+                    if (_b == EncodingConstants.DOUBLE_TERMINATOR) {
+                        _terminate = true;
+                    }
+
+                    _notations.clear();
+                    _unparsedEntities.clear();
+                    /*
+                     * TODO
+                     * Report All events associated with DTD, PIs, notations etc
+                     */
+                    break;
+                }
+                case DecoderStateTables.COMMENT_II:
+                    processCommentII();
+                    break;
+                case DecoderStateTables.PROCESSING_INSTRUCTION_II:
+                    processProcessingII();
+                    break;
+                case DecoderStateTables.TERMINATOR_DOUBLE:
+                    _doubleTerminate = true;
+                case DecoderStateTables.TERMINATOR_SINGLE:
+                    _terminate = true;
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingDII"));
+            }
+        }
+
+        // Decode any remaining Comment IIs, PI IIs
+        while(!_terminate) {
+            _b = read();
+            switch(DecoderStateTables.DII[_b]) {
+                case DecoderStateTables.COMMENT_II:
+                    processCommentII();
+                    break;
+                case DecoderStateTables.PROCESSING_INSTRUCTION_II:
+                    processProcessingII();
+                    break;
+                case DecoderStateTables.TERMINATOR_DOUBLE:
+                    _doubleTerminate = true;
+                case DecoderStateTables.TERMINATOR_SINGLE:
+                    _terminate = true;
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingDII"));
+            }
+        }
+
+    }
+
+    protected final void processDIIOptionalProperties() throws FastInfosetException, IOException {
+        // Optimize for the most common case
+        if (_b == EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG) {
+            decodeInitialVocabulary();
+            return;
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_ADDITIONAL_DATA_FLAG) > 0) {
+            decodeAdditionalData();
+            /*
+             * TODO
+             * how to report the additional data?
+             */
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG) > 0) {
+            decodeInitialVocabulary();
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_NOTATIONS_FLAG) > 0) {
+            decodeNotations();
+            // TODO Report notations
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_UNPARSED_ENTITIES_FLAG) > 0) {
+            decodeUnparsedEntities();
+            // TODO Report unparsed entities
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_CHARACTER_ENCODING_SCHEME) > 0) {
+            String version = decodeCharacterEncodingScheme();
+            /*
+             * TODO
+             * how to report the character encoding scheme?
+             */
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_STANDALONE_FLAG) > 0) {
+            boolean standalone = (read() > 0) ? true : false ;
+            /*
+             * TODO
+             * how to report the standalone flag?
+             */
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_VERSION_FLAG) > 0) {
+            String version = decodeVersion();
+            /*
+             * TODO
+             * how to report the document version?
+             */
+        }
+    }
+
+    protected final void processEII(QualifiedName name, boolean hasAttributes) throws FastInfosetException, IOException {
+        if (_prefixTable._currentInScope[name.prefixIndex] != name.namespaceNameIndex) {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.qnameOfEIINotInScope"));
+        }
+
+        final Node parentCurrentNode = _currentNode;
+
+        _currentNode = _currentElement = createElement(name.namespaceName, name.qName, name.localName);
+
+        if (_namespaceAttributesIndex > 0) {
+            for (int i = 0; i < _namespaceAttributesIndex; i++) {
+                _currentElement.setAttributeNode(_namespaceAttributes[i]);
+                _namespaceAttributes[i] = null;
+            }
+            _namespaceAttributesIndex = 0;
+        }
+
+        if (hasAttributes) {
+            processAIIs();
+        }
+
+        parentCurrentNode.appendChild(_currentElement);
+
+        while(!_terminate) {
+            _b = read();
+            switch(DecoderStateTables.EII[_b]) {
+                case DecoderStateTables.EII_NO_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[_b], false);
+                    break;
+                case DecoderStateTables.EII_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[_b & EncodingConstants.INTEGER_3RD_BIT_SMALL_MASK], true);
+                    break;
+                case DecoderStateTables.EII_INDEX_MEDIUM:
+                    processEII(decodeEIIIndexMedium(), (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    break;
+                case DecoderStateTables.EII_INDEX_LARGE:
+                    processEII(decodeEIIIndexLarge(), (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    break;
+                case DecoderStateTables.EII_LITERAL:
+                {
+                    final QualifiedName qn = processLiteralQualifiedName(
+                                _b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                    _elementNameTable.add(qn);
+                    processEII(qn, (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    break;
+                }
+                case DecoderStateTables.EII_NAMESPACES:
+                    processEIIWithNamespaces();
+                    break;
+                case DecoderStateTables.CII_UTF8_SMALL_LENGTH:
+                {
+                    _octetBufferLength = (_b & EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_MASK)
+                        + 1;
+                    String v = decodeUtf8StringAsString();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    _currentNode.appendChild(_document.createTextNode(v));
+                    break;
+                }
+                case DecoderStateTables.CII_UTF8_MEDIUM_LENGTH:
+                {
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT;
+                    String v = decodeUtf8StringAsString();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    _currentNode.appendChild(_document.createTextNode(v));
+                    break;
+                }
+                case DecoderStateTables.CII_UTF8_LARGE_LENGTH:
+                {
+                    _octetBufferLength = (read() << 24) |
+                        (read() << 16) |
+                        (read() << 8) |
+                        read();
+                    _octetBufferLength += EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT;
+                    String v = decodeUtf8StringAsString();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    _currentNode.appendChild(_document.createTextNode(v));
+                    break;
+                }
+                case DecoderStateTables.CII_UTF16_SMALL_LENGTH:
+                {
+                    _octetBufferLength = (_b & EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_MASK)
+                        + 1;
+                    String v = decodeUtf16StringAsString();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    _currentNode.appendChild(_document.createTextNode(v));
+                    break;
+                }
+                case DecoderStateTables.CII_UTF16_MEDIUM_LENGTH:
+                {
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT;
+                    String v = decodeUtf16StringAsString();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    _currentNode.appendChild(_document.createTextNode(v));
+                    break;
+                }
+                case DecoderStateTables.CII_UTF16_LARGE_LENGTH:
+                {
+                    _octetBufferLength = (read() << 24) |
+                        (read() << 16) |
+                        (read() << 8) |
+                        read();
+                    _octetBufferLength += EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT;
+                    String v = decodeUtf16StringAsString();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    _currentNode.appendChild(_document.createTextNode(v));
+                    break;
+                }
+                case DecoderStateTables.CII_RA:
+                {
+                    final boolean addToTable = (_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0;
+
+                    // Decode resitricted alphabet integer
+                    _identifier = (_b & 0x02) << 6;
+                    _b = read();
+                    _identifier |= (_b & 0xFC) >> 2;
+
+                    decodeOctetsOnSeventhBitOfNonIdentifyingStringOnThirdBit(_b);
+
+                    String v = decodeRestrictedAlphabetAsString();
+                    if (addToTable) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    _currentNode.appendChild(_document.createTextNode(v));
+                    break;
+                }
+                case DecoderStateTables.CII_EA:
+                {
+                    if ((_b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.addToTableNotSupported"));
+                    }
+
+                    // Decode encoding algorithm integer
+                    _identifier = (_b & 0x02) << 6;
+                    _b = read();
+                    _identifier |= (_b & 0xFC) >> 2;
+
+                    decodeOctetsOnSeventhBitOfNonIdentifyingStringOnThirdBit(_b);
+                    final String s = convertEncodingAlgorithmDataToCharacters(false);
+                    _currentNode.appendChild(_document.createTextNode(s));
+                    break;
+                }
+                case DecoderStateTables.CII_INDEX_SMALL:
+                {
+                    final String s = _characterContentChunkTable.getString(_b & EncodingConstants.INTEGER_4TH_BIT_SMALL_MASK);
+
+                    _currentNode.appendChild(_document.createTextNode(s));
+                    break;
+                }
+                case DecoderStateTables.CII_INDEX_MEDIUM:
+                {
+                    final int index = (((_b & EncodingConstants.INTEGER_4TH_BIT_MEDIUM_MASK) << 8) | read())
+                        + EncodingConstants.INTEGER_4TH_BIT_SMALL_LIMIT;
+                    final String s = _characterContentChunkTable.getString(index);
+
+                    _currentNode.appendChild(_document.createTextNode(s));
+                    break;
+                }
+                case DecoderStateTables.CII_INDEX_LARGE:
+                {
+                    int index = ((_b & EncodingConstants.INTEGER_4TH_BIT_LARGE_MASK) << 16) |
+                        (read() << 8) |
+                        read();
+                    index += EncodingConstants.INTEGER_4TH_BIT_MEDIUM_LIMIT;
+                    final String s = _characterContentChunkTable.getString(index);
+
+                    _currentNode.appendChild(_document.createTextNode(s));
+                    break;
+                }
+                case DecoderStateTables.CII_INDEX_LARGE_LARGE:
+                {
+                    int index = (read() << 16) |
+                        (read() << 8) |
+                        read();
+                    index += EncodingConstants.INTEGER_4TH_BIT_LARGE_LIMIT;
+                    final String s = _characterContentChunkTable.getString(index);
+
+                    _currentNode.appendChild(_document.createTextNode(s));
+                    break;
+                }
+                case DecoderStateTables.COMMENT_II:
+                    processCommentII();
+                    break;
+                case DecoderStateTables.PROCESSING_INSTRUCTION_II:
+                    processProcessingII();
+                    break;
+                case DecoderStateTables.UNEXPANDED_ENTITY_REFERENCE_II:
+                {
+                    String entity_reference_name = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+
+                    String system_identifier = ((_b & EncodingConstants.UNEXPANDED_ENTITY_SYSTEM_IDENTIFIER_FLAG) > 0)
+                        ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : null;
+                    String public_identifier = ((_b & EncodingConstants.UNEXPANDED_ENTITY_PUBLIC_IDENTIFIER_FLAG) > 0)
+                        ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : null;
+
+                    // TODO create Node
+                    break;
+                }
+                case DecoderStateTables.TERMINATOR_DOUBLE:
+                    _doubleTerminate = true;
+                case DecoderStateTables.TERMINATOR_SINGLE:
+                    _terminate = true;
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingEII"));
+            }
+        }
+
+        _terminate = _doubleTerminate;
+        _doubleTerminate = false;
+
+        _currentNode = parentCurrentNode;
+    }
+
+    protected final void processEIIWithNamespaces() throws FastInfosetException, IOException {
+        final boolean hasAttributes = (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0;
+
+        if (++_prefixTable._declarationId == Integer.MAX_VALUE) {
+            _prefixTable.clearDeclarationIds();
+        }
+
+        String prefix;
+        Attr a = null;
+        final int start = _namespacePrefixesIndex;
+        int b = read();
+        while ((b & EncodingConstants.NAMESPACE_ATTRIBUTE_MASK) == EncodingConstants.NAMESPACE_ATTRIBUTE) {
+            if (_namespaceAttributesIndex == _namespaceAttributes.length) {
+                final Attr[] newNamespaceAttributes = new Attr[_namespaceAttributesIndex * 3 / 2 + 1];
+                System.arraycopy(_namespaceAttributes, 0, newNamespaceAttributes, 0, _namespaceAttributesIndex);
+                _namespaceAttributes = newNamespaceAttributes;
+            }
+
+            if (_namespacePrefixesIndex == _namespacePrefixes.length) {
+                final int[] namespaceAIIs = new int[_namespacePrefixesIndex * 3 / 2 + 1];
+                System.arraycopy(_namespacePrefixes, 0, namespaceAIIs, 0, _namespacePrefixesIndex);
+                _namespacePrefixes = namespaceAIIs;
+            }
+
+
+            switch (b & EncodingConstants.NAMESPACE_ATTRIBUTE_PREFIX_NAME_MASK) {
+                // no prefix, no namespace
+                // Undeclaration of default namespace
+                case 0:
+                    a = createAttribute(
+                            EncodingConstants.XMLNS_NAMESPACE_NAME,
+                            EncodingConstants.XMLNS_NAMESPACE_PREFIX,
+                            EncodingConstants.XMLNS_NAMESPACE_PREFIX);
+                    a.setValue ("");
+
+                    _prefixIndex = _namespaceNameIndex = _namespacePrefixes[_namespacePrefixesIndex++] = -1;
+                    break;
+                // no prefix, namespace
+                // Declaration of default namespace
+                case 1:
+                    a = createAttribute(
+                            EncodingConstants.XMLNS_NAMESPACE_NAME,
+                            EncodingConstants.XMLNS_NAMESPACE_PREFIX,
+                            EncodingConstants.XMLNS_NAMESPACE_PREFIX);
+                    a.setValue (decodeIdentifyingNonEmptyStringOnFirstBitAsNamespaceName(false));
+
+                    _prefixIndex = _namespacePrefixes[_namespacePrefixesIndex++] = -1;
+                    break;
+                // prefix, no namespace
+                // Undeclaration of namespace
+                case 2:
+                    prefix = decodeIdentifyingNonEmptyStringOnFirstBitAsPrefix(false);
+                    a = createAttribute(
+                            EncodingConstants.XMLNS_NAMESPACE_NAME,
+                            createQualifiedNameString(EncodingConstants.XMLNS_NAMESPACE_PREFIX_CHARS, prefix),
+                            prefix);
+                    a.setValue ("");
+
+                    _namespaceNameIndex = -1;
+                    _namespacePrefixes[_namespacePrefixesIndex++] = _prefixIndex;
+                    break;
+                // prefix, namespace
+                // Declaration of prefixed namespace
+                case 3:
+                    prefix = decodeIdentifyingNonEmptyStringOnFirstBitAsPrefix(true);
+                    a = createAttribute(
+                            EncodingConstants.XMLNS_NAMESPACE_NAME,
+                            createQualifiedNameString(EncodingConstants.XMLNS_NAMESPACE_PREFIX_CHARS, prefix),
+                            prefix);
+                    a.setValue (decodeIdentifyingNonEmptyStringOnFirstBitAsNamespaceName(true));
+
+                    _namespacePrefixes[_namespacePrefixesIndex++] = _prefixIndex;
+                    break;
+            }
+
+            _prefixTable.pushScope(_prefixIndex, _namespaceNameIndex);
+
+            _namespaceAttributes[_namespaceAttributesIndex++] = a;
+
+            b = read();
+        }
+        if (b != EncodingConstants.TERMINATOR) {
+            throw new IOException(CommonResourceBundle.getInstance().getString("message.EIInamespaceNameNotTerminatedCorrectly"));
+        }
+        final int end = _namespacePrefixesIndex;
+
+        _b = read();
+        switch(DecoderStateTables.EII[_b]) {
+            case DecoderStateTables.EII_NO_AIIS_INDEX_SMALL:
+                processEII(_elementNameTable._array[_b], hasAttributes);
+                break;
+            case DecoderStateTables.EII_INDEX_MEDIUM:
+                processEII(decodeEIIIndexMedium(), hasAttributes);
+                break;
+            case DecoderStateTables.EII_INDEX_LARGE:
+                processEII(decodeEIIIndexLarge(), hasAttributes);
+                break;
+            case DecoderStateTables.EII_LITERAL:
+            {
+                final QualifiedName qn = processLiteralQualifiedName(
+                            _b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                _elementNameTable.add(qn);
+                processEII(qn, hasAttributes);
+                break;
+            }
+            default:
+                throw new IOException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingEIIAfterAIIs"));
+        }
+
+        for (int i = start; i < end; i++) {
+            _prefixTable.popScope(_namespacePrefixes[i]);
+        }
+        _namespacePrefixesIndex = start;
+
+    }
+
+    protected final QualifiedName processLiteralQualifiedName(int state) throws FastInfosetException, IOException {
+        switch (state) {
+            // no prefix, no namespace
+            case 0:
+                return new QualifiedName(
+                        null,
+                        null,
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        -1,
+                        -1,
+                        _identifier,
+                        null);
+            // no prefix, namespace
+            case 1:
+                return new QualifiedName(
+                        null,
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsNamespaceName(false),
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        -1,
+                        _namespaceNameIndex,
+                        _identifier,
+                        null);
+            // prefix, no namespace
+            case 2:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.qNameMissingNamespaceName"));
+            // prefix, namespace
+            case 3:
+                return new QualifiedName(
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsPrefix(true),
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsNamespaceName(true),
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        _prefixIndex,
+                        _namespaceNameIndex,
+                        _identifier,
+                        _charBuffer);
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingEII"));
+        }
+    }
+
+    protected final void processAIIs() throws FastInfosetException, IOException {
+        QualifiedName name;
+        int b;
+        String value;
+
+        if (++_duplicateAttributeVerifier._currentIteration == Integer.MAX_VALUE) {
+            _duplicateAttributeVerifier.clear();
+        }
+
+        do {
+            // AII qualified name
+            b = read();
+            switch (DecoderStateTables.AII[b]) {
+                case DecoderStateTables.AII_INDEX_SMALL:
+                    name = _attributeNameTable._array[b];
+                    break;
+                case DecoderStateTables.AII_INDEX_MEDIUM:
+                {
+                    final int i = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                        + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                    name = _attributeNameTable._array[i];
+                    break;
+                }
+                case DecoderStateTables.AII_INDEX_LARGE:
+                {
+                    final int i = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                        + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                    name = _attributeNameTable._array[i];
+                    break;
+                }
+                case DecoderStateTables.AII_LITERAL:
+                    name = processLiteralQualifiedName(
+                            b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                    name.createAttributeValues(_duplicateAttributeVerifier.MAP_SIZE);
+                    _attributeNameTable.add(name);
+                    break;
+                case DecoderStateTables.AII_TERMINATOR_DOUBLE:
+                    _doubleTerminate = true;
+                case DecoderStateTables.AII_TERMINATOR_SINGLE:
+                    _terminate = true;
+                    // AIIs have finished break out of loop
+                    continue;
+                default:
+                    throw new IOException(CommonResourceBundle.getInstance().getString("message.decodingAIIs"));
+            }
+
+            if (name.prefixIndex > 0 && _prefixTable._currentInScope[name.prefixIndex] != name.namespaceNameIndex) {
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.AIIqNameNotInScope"));
+            }
+
+            _duplicateAttributeVerifier.checkForDuplicateAttribute(name.attributeHash, name.attributeId);
+
+            Attr a = createAttribute(
+                        name.namespaceName,
+                        name.qName,
+                        name.localName);
+
+            // [normalized value] of AII
+
+            b = read();
+            switch(DecoderStateTables.NISTRING[b]) {
+                case DecoderStateTables.NISTRING_UTF8_SMALL_LENGTH:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK) + 1;
+                    value = decodeUtf8StringAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_UTF8_MEDIUM_LENGTH:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                    value = decodeUtf8StringAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_UTF8_LARGE_LENGTH:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    final int length = (read() << 24) |
+                        (read() << 16) |
+                        (read() << 8) |
+                        read();
+                    _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                    value = decodeUtf8StringAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_UTF16_SMALL_LENGTH:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK) + 1;
+                    value = decodeUtf16StringAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_UTF16_MEDIUM_LENGTH:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                    value = decodeUtf16StringAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_UTF16_LARGE_LENGTH:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    final int length = (read() << 24) |
+                        (read() << 16) |
+                        (read() << 8) |
+                        read();
+                    _octetBufferLength = length + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                    value = decodeUtf16StringAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_RA:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    // Decode resitricted alphabet integer
+                    _identifier = (b & 0x0F) << 4;
+                    b = read();
+                    _identifier |= (b & 0xF0) >> 4;
+
+                    decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(b);
+
+                    value = decodeRestrictedAlphabetAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_EA:
+                {
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.addToTableNotSupported"));
+                    }
+
+                    _identifier = (b & 0x0F) << 4;
+                    b = read();
+                    _identifier |= (b & 0xF0) >> 4;
+
+                    decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(b);
+                    value = convertEncodingAlgorithmDataToCharacters(true);
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_INDEX_SMALL:
+                    value = _attributeValueTable._array[b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK];
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                case DecoderStateTables.NISTRING_INDEX_MEDIUM:
+                {
+                    final int index = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                        + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                    value = _attributeValueTable._array[index];
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_INDEX_LARGE:
+                {
+                    final int index = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                        + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                    value = _attributeValueTable._array[index];
+
+                    a.setValue(value);
+                    _currentElement.setAttributeNode(a);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_EMPTY:
+                    a.setValue("");
+                    _currentElement.setAttributeNode(a);
+                    break;
+                default:
+                    throw new IOException(CommonResourceBundle.getInstance().getString("message.decodingAIIValue"));
+            }
+
+        } while (!_terminate);
+
+        // Reset duplication attribute verfifier
+        _duplicateAttributeVerifier._poolCurrent = _duplicateAttributeVerifier._poolHead;
+
+        _terminate = _doubleTerminate;
+        _doubleTerminate = false;
+    }
+
+    protected final void processCommentII() throws FastInfosetException, IOException {
+        switch(decodeNonIdentifyingStringOnFirstBit()) {
+            case NISTRING_STRING:
+            {
+                final String s = new String(_charBuffer, 0, _charBufferLength);
+                if (_addToTable) {
+                    _v.otherString.add(new CharArrayString(s, false));
+                }
+
+                _currentNode.appendChild(_document.createComment(s));
+                break;
+            }
+            case NISTRING_ENCODING_ALGORITHM:
+                throw new IOException(CommonResourceBundle.getInstance().getString("message.commentIIAlgorithmNotSupported"));
+            case NISTRING_INDEX:
+            {
+                final String s = _v.otherString.get(_integer).toString();
+
+                _currentNode.appendChild(_document.createComment(s));
+                break;
+            }
+            case NISTRING_EMPTY_STRING:
+                _currentNode.appendChild(_document.createComment(""));
+                break;
+        }
+    }
+
+    protected final void processProcessingII() throws FastInfosetException, IOException {
+        final String target = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+
+        switch(decodeNonIdentifyingStringOnFirstBit()) {
+            case NISTRING_STRING:
+            {
+                final String data = new String(_charBuffer, 0, _charBufferLength);
+                if (_addToTable) {
+                    _v.otherString.add(new CharArrayString(data, false));
+                }
+
+                _currentNode.appendChild (_document.createProcessingInstruction (target, data));
+                break;
+            }
+            case NISTRING_ENCODING_ALGORITHM:
+                throw new IOException(CommonResourceBundle.getInstance().getString("message.processingIIWithEncodingAlgorithm"));
+            case NISTRING_INDEX:
+            {
+                final String data = _v.otherString.get(_integer).toString();
+
+                _currentNode.appendChild (_document.createProcessingInstruction (target, data));
+                break;
+            }
+            case NISTRING_EMPTY_STRING:
+                _currentNode.appendChild (_document.createProcessingInstruction (target, ""));
+                break;
+        }
+    }
+
+    protected Element createElement(String namespaceName, String qName, String localName) {
+        return _document.createElementNS(namespaceName, qName);
+    }
+
+    protected Attr createAttribute(String namespaceName, String qName, String localName) {
+        return _document.createAttributeNS(namespaceName, qName);
+    }
+
+    protected String convertEncodingAlgorithmDataToCharacters(boolean isAttributeValue) throws FastInfosetException, IOException {
+        StringBuffer buffer = new StringBuffer();
+        if (_identifier < EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            Object array = BuiltInEncodingAlgorithmFactory.table[_identifier].
+                decodeFromBytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+            BuiltInEncodingAlgorithmFactory.table[_identifier].convertToCharacters(array,  buffer);
+        } else if (_identifier == EncodingAlgorithmIndexes.CDATA) {
+            if (!isAttributeValue) {
+                // Set back buffer position to start of encoded string
+                _octetBufferOffset -= _octetBufferLength;
+                return decodeUtf8StringAsString();
+            }
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.CDATAAlgorithmNotSupported"));
+        } else if (_identifier >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            final String URI = _v.encodingAlgorithm.get(_identifier - EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START);
+            final EncodingAlgorithm ea = (EncodingAlgorithm)_registeredEncodingAlgorithms.get(URI);
+            if (ea != null) {
+                final Object data = ea.decodeFromBytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+                ea.convertToCharacters(data, buffer);
+            } else {
+                throw new EncodingAlgorithmException(
+                        CommonResourceBundle.getInstance().getString("message.algorithmDataCannotBeReported"));
+            }
+        }
+        return buffer.toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/dom/DOMDocumentSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/dom/DOMDocumentSerializer.java
new file mode 100644
index 0000000..8b8e35c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/dom/DOMDocumentSerializer.java
@@ -0,0 +1,364 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.dom;
+
+import com.sun.xml.internal.fastinfoset.Encoder;
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.util.LocalNameQualifiedNamesMap;
+import java.io.IOException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import org.w3c.dom.Document;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+
+/**
+ * The Fast Infoset DOM serializer.
+ * <p>
+ * Instantiate this serializer to serialize a fast infoset document in accordance
+ * with the DOM API.
+ *
+ */
+public class DOMDocumentSerializer extends Encoder {
+
+    /**
+     * Serialize a {@link Node}.
+     *
+     * @param n the node to serialize.
+     */
+    public final void serialize(Node n) throws IOException {
+        switch (n.getNodeType()) {
+            case Node.DOCUMENT_NODE:
+                serialize((Document)n);
+            case Node.ELEMENT_NODE:
+                serializeElementAsDocument(n);
+                break;
+            case Node.COMMENT_NODE:
+                serializeComment(n);
+                break;
+            case Node.PROCESSING_INSTRUCTION_NODE:
+                serializeProcessingInstruction(n);
+                break;
+        }
+    }
+
+    /**
+     * Serialize a {@link Document}.
+     *
+     * @param d the document to serialize.
+     */
+    public final void serialize(Document d) throws IOException {
+        reset();
+        encodeHeader(false);
+        encodeInitialVocabulary();
+
+        final NodeList nl = d.getChildNodes();
+        for (int i = 0; i < nl.getLength(); i++) {
+            final Node n = nl.item(i);
+            switch (n.getNodeType()) {
+                case Node.ELEMENT_NODE:
+                    serializeElement(n);
+                    break;
+                case Node.COMMENT_NODE:
+                    serializeComment(n);
+                    break;
+                case Node.PROCESSING_INSTRUCTION_NODE:
+                    serializeProcessingInstruction(n);
+                    break;
+            }
+        }
+        encodeDocumentTermination();
+    }
+
+    protected final void serializeElementAsDocument(Node e) throws IOException {
+        reset();
+        encodeHeader(false);
+        encodeInitialVocabulary();
+
+        serializeElement(e);
+
+        encodeDocumentTermination();
+    }
+
+
+    protected Node[] _namespaceAttributes = new Node[4];
+    protected Node[] _attributes = new Node[32];
+
+    protected final void serializeElement(Node e) throws IOException {
+        encodeTermination();
+
+        int namespaceAttributesSize = 0;
+        int attributesSize = 0;
+        if (e.hasAttributes()) {
+            /*
+             * Split the attribute nodes into namespace attributes
+             * or normal attributes.
+             */
+            final NamedNodeMap nnm = e.getAttributes();
+            for (int i = 0; i < nnm.getLength(); i++) {
+                final Node a = nnm.item(i);
+                final String namespaceURI = a.getNamespaceURI();
+                if (namespaceURI != null && namespaceURI.equals("http://www.w3.org/2000/xmlns/")) {
+                    if (namespaceAttributesSize == _namespaceAttributes.length) {
+                        final Node[] attributes = new Node[namespaceAttributesSize * 3 / 2 + 1];
+                        System.arraycopy(_namespaceAttributes, 0, attributes, 0, namespaceAttributesSize);
+                        _namespaceAttributes = attributes;
+                    }
+                    _namespaceAttributes[namespaceAttributesSize++] = a;
+                } else {
+                    if (attributesSize == _attributes.length) {
+                        final Node[] attributes = new Node[attributesSize * 3 / 2 + 1];
+                        System.arraycopy(_attributes, 0, attributes, 0, attributesSize);
+                        _attributes = attributes;
+                    }
+                    _attributes[attributesSize++] = a;
+                }
+            }
+        }
+
+        if (namespaceAttributesSize > 0) {
+            if (attributesSize > 0) {
+                write(EncodingConstants.ELEMENT | EncodingConstants.ELEMENT_NAMESPACES_FLAG |
+                        EncodingConstants.ELEMENT_ATTRIBUTE_FLAG);
+            } else {
+                write(EncodingConstants.ELEMENT | EncodingConstants.ELEMENT_NAMESPACES_FLAG);
+            }
+
+            // Serialize the namespace attributes
+            for (int i = 0; i < namespaceAttributesSize; i++) {
+                final Node a = _namespaceAttributes[i];
+                _namespaceAttributes[i] = null;
+                String prefix = a.getLocalName();
+                if (prefix == "xmlns" || prefix.equals("xmlns")) {
+                    prefix = "";
+                }
+                final String uri = a.getNodeValue();
+                encodeNamespaceAttribute(prefix, uri);
+            }
+
+            write(EncodingConstants.TERMINATOR);
+            _b = 0;
+        } else {
+            _b = (attributesSize > 0) ? EncodingConstants.ELEMENT | EncodingConstants.ELEMENT_ATTRIBUTE_FLAG :
+                EncodingConstants.ELEMENT;
+        }
+
+        String namespaceURI = e.getNamespaceURI();
+        namespaceURI = (namespaceURI == null) ? "" : namespaceURI;
+        encodeElement(namespaceURI, e.getNodeName(), e.getLocalName());
+
+        if (attributesSize > 0) {
+            // Serialize the attributes
+            for (int i = 0; i < attributesSize; i++) {
+                final Node a = _attributes[i];
+                _attributes[i] = null;
+                namespaceURI = a.getNamespaceURI();
+                namespaceURI = (namespaceURI == null) ? "" : namespaceURI;
+                encodeAttribute(namespaceURI, a.getNodeName(), a.getLocalName());
+
+                final String value = a.getNodeValue();
+                final boolean addToTable = (value.length() < attributeValueSizeConstraint) ? true : false;
+                encodeNonIdentifyingStringOnFirstBit(value, _v.attributeValue, addToTable);
+            }
+
+            _b = EncodingConstants.TERMINATOR;
+            _terminate = true;
+        }
+
+        if (e.hasChildNodes()) {
+            // Serialize the children
+            final NodeList nl = e.getChildNodes();
+            for (int i = 0; i < nl.getLength(); i++) {
+                final Node n = nl.item(i);
+                switch (n.getNodeType()) {
+                    case Node.ELEMENT_NODE:
+                        serializeElement(n);
+                        break;
+                    case Node.TEXT_NODE:
+                        serializeText(n);
+                        break;
+                    case Node.CDATA_SECTION_NODE:
+                        serializeCDATA(n);
+                        break;
+                    case Node.COMMENT_NODE:
+                        serializeComment(n);
+                        break;
+                    case Node.PROCESSING_INSTRUCTION_NODE:
+                        serializeProcessingInstruction(n);
+                        break;
+                }
+            }
+        }
+        encodeElementTermination();
+    }
+
+    protected final void serializeText(Node t) throws IOException {
+        final String text = t.getNodeValue();
+
+        final int length = (text != null) ? text.length() : 0;
+        if (length == 0) {
+            return;
+        } else if (length < _charBuffer.length) {
+            text.getChars(0, length, _charBuffer, 0);
+            if (getIgnoreWhiteSpaceTextContent() &&
+                    isWhiteSpace(_charBuffer, 0, length)) return;
+
+            encodeTermination();
+            encodeCharacters(_charBuffer, 0, length);
+        } else {
+            final char ch[] = text.toCharArray();
+            if (getIgnoreWhiteSpaceTextContent() &&
+                    isWhiteSpace(ch, 0, length)) return;
+
+            encodeTermination();
+            encodeCharactersNoClone(ch, 0, length);
+        }
+    }
+
+    protected final void serializeCDATA(Node t) throws IOException {
+        final String text = t.getNodeValue();
+
+        final int length = (text != null) ? text.length() : 0;
+        if (length == 0) {
+            return;
+        } else {
+            final char ch[] = text.toCharArray();
+            if (getIgnoreWhiteSpaceTextContent() &&
+                    isWhiteSpace(ch, 0, length)) return;
+
+            encodeTermination();
+            try {
+                encodeCIIBuiltInAlgorithmDataAsCDATA(ch, 0, length);
+            } catch (FastInfosetException e) {
+                throw new IOException("");
+            }
+        }
+    }
+
+    protected final void serializeComment(Node c) throws IOException {
+        if (getIgnoreComments()) return;
+
+        encodeTermination();
+
+        final String comment = c.getNodeValue();
+
+        final int length = (comment != null) ? comment.length() : 0;
+        if (length == 0) {
+            encodeComment(_charBuffer, 0, 0);
+        } else if (length < _charBuffer.length) {
+            comment.getChars(0, length, _charBuffer, 0);
+            encodeComment(_charBuffer, 0, length);
+        } else {
+            final char ch[] = comment.toCharArray();
+            encodeCommentNoClone(ch, 0, length);
+        }
+    }
+
+    protected final void serializeProcessingInstruction(Node pi) throws IOException {
+        if (getIgnoreProcesingInstructions()) return;
+
+        encodeTermination();
+
+        final String target = pi.getNodeName();
+        final String data = pi.getNodeValue();
+        encodeProcessingInstruction(target, data);
+    }
+
+    protected final void encodeElement(String namespaceURI, String qName, String localName) throws IOException {
+        LocalNameQualifiedNamesMap.Entry entry = _v.elementName.obtainEntry(qName);
+        if (entry._valueIndex > 0) {
+            final QualifiedName[] names = entry._value;
+            for (int i = 0; i < entry._valueIndex; i++) {
+                if ((namespaceURI == names[i].namespaceName || namespaceURI.equals(names[i].namespaceName))) {
+                    encodeNonZeroIntegerOnThirdBit(names[i].index);
+                    return;
+                }
+            }
+        }
+
+        // Was DOM node created using an NS-aware call?
+        if (localName != null) {
+            encodeLiteralElementQualifiedNameOnThirdBit(namespaceURI, getPrefixFromQualifiedName(qName),
+                    localName, entry);
+        }
+        else {
+            encodeLiteralElementQualifiedNameOnThirdBit(namespaceURI, "", qName, entry);
+        }
+    }
+
+    protected final void encodeAttribute(String namespaceURI, String qName, String localName) throws IOException {
+        LocalNameQualifiedNamesMap.Entry entry = _v.attributeName.obtainEntry(qName);
+        if (entry._valueIndex > 0) {
+            final QualifiedName[] names = entry._value;
+            for (int i = 0; i < entry._valueIndex; i++) {
+                if ((namespaceURI == names[i].namespaceName || namespaceURI.equals(names[i].namespaceName))) {
+                    encodeNonZeroIntegerOnSecondBitFirstBitZero(names[i].index);
+                    return;
+                }
+            }
+        }
+
+        // Was DOM node created using an NS-aware call?
+        if (localName != null) {
+            encodeLiteralAttributeQualifiedNameOnSecondBit(namespaceURI, getPrefixFromQualifiedName(qName),
+                    localName, entry);
+        }
+        else {
+            encodeLiteralAttributeQualifiedNameOnSecondBit(namespaceURI, "", qName, entry);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/org/apache/xerces/util/XMLChar.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/org/apache/xerces/util/XMLChar.java
new file mode 100644
index 0000000..1cd39fa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/org/apache/xerces/util/XMLChar.java
@@ -0,0 +1,1094 @@
+/*
+ * reserved comment block
+ * DO NOT REMOVE OR ALTER!
+ */
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+/*
+ * The Apache Software License, Version 1.1
+ *
+ *
+ * Copyright (c) 1999-2004 The Apache Software Foundation.  All rights
+ * reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in
+ *    the documentation and/or other materials provided with the
+ *    distribution.
+ *
+ * 3. The end-user documentation included with the redistribution,
+ *    if any, must include the following acknowledgment:
+ *       "This product includes software developed by the
+ *        Apache Software Foundation (http://www.apache.org/)."
+ *    Alternately, this acknowledgment may appear in the software itself,
+ *    if and wherever such third-party acknowledgments normally appear.
+ *
+ * 4. The names "Xerces" and "Apache Software Foundation" must
+ *    not be used to endorse or promote products derived from this
+ *    software without prior written permission. For written
+ *    permission, please contact apache@apache.org.
+ *
+ * 5. Products derived from this software may not be called "Apache",
+ *    nor may "Apache" appear in their name, without prior written
+ *    permission of the Apache Software Foundation.
+ *
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
+ * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+ * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ * ====================================================================
+ *
+ * This software consists of voluntary contributions made by many
+ * individuals on behalf of the Apache Software Foundation and was
+ * originally based on software copyright (c) 1999, International
+ * Business Machines, Inc., http://www.apache.org.  For more
+ * information on the Apache Software Foundation, please see
+ * <http://www.apache.org/>.
+ */
+
+package com.sun.xml.internal.fastinfoset.org.apache.xerces.util;
+
+import java.util.Arrays;
+
+/**
+ * This class defines the basic XML character properties. The data
+ * in this class can be used to verify that a character is a valid
+ * XML character or if the character is a space, name start, or name
+ * character.
+ * <p>
+ * A series of convenience methods are supplied to ease the burden
+ * of the developer. Because inlining the checks can improve per
+ * character performance, the tables of character properties are
+ * public. Using the character as an index into the <code>CHARS</code>
+ * array and applying the appropriate mask flag (e.g.
+ * <code>MASK_VALID</code>), yields the same results as calling the
+ * convenience methods. There is one exception: check the comments
+ * for the <code>isValid</code> method for details.
+ *
+ * @author Glenn Marcy, IBM
+ * @author Andy Clark, IBM
+ * @author Eric Ye, IBM
+ * @author Arnaud  Le Hors, IBM
+ * @author Michael Glavassevich, IBM
+ * @author Rahul Srivastava, Sun Microsystems Inc.
+ *
+ */
+public class XMLChar {
+
+    //
+    // Constants
+    //
+
+    /** Character flags. */
+    private static final byte[] CHARS = new byte[1 << 16];
+
+    /** Valid character mask. */
+    public static final int MASK_VALID = 0x01;
+
+    /** Space character mask. */
+    public static final int MASK_SPACE = 0x02;
+
+    /** Name start character mask. */
+    public static final int MASK_NAME_START = 0x04;
+
+    /** Name character mask. */
+    public static final int MASK_NAME = 0x08;
+
+    /** Pubid character mask. */
+    public static final int MASK_PUBID = 0x10;
+
+    /**
+     * Content character mask. Special characters are those that can
+     * be considered the start of markup, such as '&lt;' and '&amp;'.
+     * The various newline characters are considered special as well.
+     * All other valid XML characters can be considered content.
+     * <p>
+     * This is an optimization for the inner loop of character scanning.
+     */
+    public static final int MASK_CONTENT = 0x20;
+
+    /** NCName start character mask. */
+    public static final int MASK_NCNAME_START = 0x40;
+
+    /** NCName character mask. */
+    public static final int MASK_NCNAME = 0x80;
+
+    //
+    // Static initialization
+    //
+
+    static {
+
+        // Initializing the Character Flag Array
+        // Code generated by: XMLCharGenerator.
+
+        CHARS[9] = 35;
+        CHARS[10] = 19;
+        CHARS[13] = 19;
+        CHARS[32] = 51;
+        CHARS[33] = 49;
+        CHARS[34] = 33;
+        Arrays.fill(CHARS, 35, 38, (byte) 49 ); // Fill 3 of value (byte) 49
+        CHARS[38] = 1;
+        Arrays.fill(CHARS, 39, 45, (byte) 49 ); // Fill 6 of value (byte) 49
+        Arrays.fill(CHARS, 45, 47, (byte) -71 ); // Fill 2 of value (byte) -71
+        CHARS[47] = 49;
+        Arrays.fill(CHARS, 48, 58, (byte) -71 ); // Fill 10 of value (byte) -71
+        CHARS[58] = 61;
+        CHARS[59] = 49;
+        CHARS[60] = 1;
+        CHARS[61] = 49;
+        CHARS[62] = 33;
+        Arrays.fill(CHARS, 63, 65, (byte) 49 ); // Fill 2 of value (byte) 49
+        Arrays.fill(CHARS, 65, 91, (byte) -3 ); // Fill 26 of value (byte) -3
+        Arrays.fill(CHARS, 91, 93, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[93] = 1;
+        CHARS[94] = 33;
+        CHARS[95] = -3;
+        CHARS[96] = 33;
+        Arrays.fill(CHARS, 97, 123, (byte) -3 ); // Fill 26 of value (byte) -3
+        Arrays.fill(CHARS, 123, 183, (byte) 33 ); // Fill 60 of value (byte) 33
+        CHARS[183] = -87;
+        Arrays.fill(CHARS, 184, 192, (byte) 33 ); // Fill 8 of value (byte) 33
+        Arrays.fill(CHARS, 192, 215, (byte) -19 ); // Fill 23 of value (byte) -19
+        CHARS[215] = 33;
+        Arrays.fill(CHARS, 216, 247, (byte) -19 ); // Fill 31 of value (byte) -19
+        CHARS[247] = 33;
+        Arrays.fill(CHARS, 248, 306, (byte) -19 ); // Fill 58 of value (byte) -19
+        Arrays.fill(CHARS, 306, 308, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 308, 319, (byte) -19 ); // Fill 11 of value (byte) -19
+        Arrays.fill(CHARS, 319, 321, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 321, 329, (byte) -19 ); // Fill 8 of value (byte) -19
+        CHARS[329] = 33;
+        Arrays.fill(CHARS, 330, 383, (byte) -19 ); // Fill 53 of value (byte) -19
+        CHARS[383] = 33;
+        Arrays.fill(CHARS, 384, 452, (byte) -19 ); // Fill 68 of value (byte) -19
+        Arrays.fill(CHARS, 452, 461, (byte) 33 ); // Fill 9 of value (byte) 33
+        Arrays.fill(CHARS, 461, 497, (byte) -19 ); // Fill 36 of value (byte) -19
+        Arrays.fill(CHARS, 497, 500, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 500, 502, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 502, 506, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 506, 536, (byte) -19 ); // Fill 30 of value (byte) -19
+        Arrays.fill(CHARS, 536, 592, (byte) 33 ); // Fill 56 of value (byte) 33
+        Arrays.fill(CHARS, 592, 681, (byte) -19 ); // Fill 89 of value (byte) -19
+        Arrays.fill(CHARS, 681, 699, (byte) 33 ); // Fill 18 of value (byte) 33
+        Arrays.fill(CHARS, 699, 706, (byte) -19 ); // Fill 7 of value (byte) -19
+        Arrays.fill(CHARS, 706, 720, (byte) 33 ); // Fill 14 of value (byte) 33
+        Arrays.fill(CHARS, 720, 722, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 722, 768, (byte) 33 ); // Fill 46 of value (byte) 33
+        Arrays.fill(CHARS, 768, 838, (byte) -87 ); // Fill 70 of value (byte) -87
+        Arrays.fill(CHARS, 838, 864, (byte) 33 ); // Fill 26 of value (byte) 33
+        Arrays.fill(CHARS, 864, 866, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 866, 902, (byte) 33 ); // Fill 36 of value (byte) 33
+        CHARS[902] = -19;
+        CHARS[903] = -87;
+        Arrays.fill(CHARS, 904, 907, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[907] = 33;
+        CHARS[908] = -19;
+        CHARS[909] = 33;
+        Arrays.fill(CHARS, 910, 930, (byte) -19 ); // Fill 20 of value (byte) -19
+        CHARS[930] = 33;
+        Arrays.fill(CHARS, 931, 975, (byte) -19 ); // Fill 44 of value (byte) -19
+        CHARS[975] = 33;
+        Arrays.fill(CHARS, 976, 983, (byte) -19 ); // Fill 7 of value (byte) -19
+        Arrays.fill(CHARS, 983, 986, (byte) 33 ); // Fill 3 of value (byte) 33
+        CHARS[986] = -19;
+        CHARS[987] = 33;
+        CHARS[988] = -19;
+        CHARS[989] = 33;
+        CHARS[990] = -19;
+        CHARS[991] = 33;
+        CHARS[992] = -19;
+        CHARS[993] = 33;
+        Arrays.fill(CHARS, 994, 1012, (byte) -19 ); // Fill 18 of value (byte) -19
+        Arrays.fill(CHARS, 1012, 1025, (byte) 33 ); // Fill 13 of value (byte) 33
+        Arrays.fill(CHARS, 1025, 1037, (byte) -19 ); // Fill 12 of value (byte) -19
+        CHARS[1037] = 33;
+        Arrays.fill(CHARS, 1038, 1104, (byte) -19 ); // Fill 66 of value (byte) -19
+        CHARS[1104] = 33;
+        Arrays.fill(CHARS, 1105, 1117, (byte) -19 ); // Fill 12 of value (byte) -19
+        CHARS[1117] = 33;
+        Arrays.fill(CHARS, 1118, 1154, (byte) -19 ); // Fill 36 of value (byte) -19
+        CHARS[1154] = 33;
+        Arrays.fill(CHARS, 1155, 1159, (byte) -87 ); // Fill 4 of value (byte) -87
+        Arrays.fill(CHARS, 1159, 1168, (byte) 33 ); // Fill 9 of value (byte) 33
+        Arrays.fill(CHARS, 1168, 1221, (byte) -19 ); // Fill 53 of value (byte) -19
+        Arrays.fill(CHARS, 1221, 1223, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 1223, 1225, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 1225, 1227, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 1227, 1229, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 1229, 1232, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 1232, 1260, (byte) -19 ); // Fill 28 of value (byte) -19
+        Arrays.fill(CHARS, 1260, 1262, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 1262, 1270, (byte) -19 ); // Fill 8 of value (byte) -19
+        Arrays.fill(CHARS, 1270, 1272, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 1272, 1274, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 1274, 1329, (byte) 33 ); // Fill 55 of value (byte) 33
+        Arrays.fill(CHARS, 1329, 1367, (byte) -19 ); // Fill 38 of value (byte) -19
+        Arrays.fill(CHARS, 1367, 1369, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[1369] = -19;
+        Arrays.fill(CHARS, 1370, 1377, (byte) 33 ); // Fill 7 of value (byte) 33
+        Arrays.fill(CHARS, 1377, 1415, (byte) -19 ); // Fill 38 of value (byte) -19
+        Arrays.fill(CHARS, 1415, 1425, (byte) 33 ); // Fill 10 of value (byte) 33
+        Arrays.fill(CHARS, 1425, 1442, (byte) -87 ); // Fill 17 of value (byte) -87
+        CHARS[1442] = 33;
+        Arrays.fill(CHARS, 1443, 1466, (byte) -87 ); // Fill 23 of value (byte) -87
+        CHARS[1466] = 33;
+        Arrays.fill(CHARS, 1467, 1470, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[1470] = 33;
+        CHARS[1471] = -87;
+        CHARS[1472] = 33;
+        Arrays.fill(CHARS, 1473, 1475, (byte) -87 ); // Fill 2 of value (byte) -87
+        CHARS[1475] = 33;
+        CHARS[1476] = -87;
+        Arrays.fill(CHARS, 1477, 1488, (byte) 33 ); // Fill 11 of value (byte) 33
+        Arrays.fill(CHARS, 1488, 1515, (byte) -19 ); // Fill 27 of value (byte) -19
+        Arrays.fill(CHARS, 1515, 1520, (byte) 33 ); // Fill 5 of value (byte) 33
+        Arrays.fill(CHARS, 1520, 1523, (byte) -19 ); // Fill 3 of value (byte) -19
+        Arrays.fill(CHARS, 1523, 1569, (byte) 33 ); // Fill 46 of value (byte) 33
+        Arrays.fill(CHARS, 1569, 1595, (byte) -19 ); // Fill 26 of value (byte) -19
+        Arrays.fill(CHARS, 1595, 1600, (byte) 33 ); // Fill 5 of value (byte) 33
+        CHARS[1600] = -87;
+        Arrays.fill(CHARS, 1601, 1611, (byte) -19 ); // Fill 10 of value (byte) -19
+        Arrays.fill(CHARS, 1611, 1619, (byte) -87 ); // Fill 8 of value (byte) -87
+        Arrays.fill(CHARS, 1619, 1632, (byte) 33 ); // Fill 13 of value (byte) 33
+        Arrays.fill(CHARS, 1632, 1642, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 1642, 1648, (byte) 33 ); // Fill 6 of value (byte) 33
+        CHARS[1648] = -87;
+        Arrays.fill(CHARS, 1649, 1720, (byte) -19 ); // Fill 71 of value (byte) -19
+        Arrays.fill(CHARS, 1720, 1722, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 1722, 1727, (byte) -19 ); // Fill 5 of value (byte) -19
+        CHARS[1727] = 33;
+        Arrays.fill(CHARS, 1728, 1743, (byte) -19 ); // Fill 15 of value (byte) -19
+        CHARS[1743] = 33;
+        Arrays.fill(CHARS, 1744, 1748, (byte) -19 ); // Fill 4 of value (byte) -19
+        CHARS[1748] = 33;
+        CHARS[1749] = -19;
+        Arrays.fill(CHARS, 1750, 1765, (byte) -87 ); // Fill 15 of value (byte) -87
+        Arrays.fill(CHARS, 1765, 1767, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 1767, 1769, (byte) -87 ); // Fill 2 of value (byte) -87
+        CHARS[1769] = 33;
+        Arrays.fill(CHARS, 1770, 1774, (byte) -87 ); // Fill 4 of value (byte) -87
+        Arrays.fill(CHARS, 1774, 1776, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 1776, 1786, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 1786, 2305, (byte) 33 ); // Fill 519 of value (byte) 33
+        Arrays.fill(CHARS, 2305, 2308, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[2308] = 33;
+        Arrays.fill(CHARS, 2309, 2362, (byte) -19 ); // Fill 53 of value (byte) -19
+        Arrays.fill(CHARS, 2362, 2364, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[2364] = -87;
+        CHARS[2365] = -19;
+        Arrays.fill(CHARS, 2366, 2382, (byte) -87 ); // Fill 16 of value (byte) -87
+        Arrays.fill(CHARS, 2382, 2385, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2385, 2389, (byte) -87 ); // Fill 4 of value (byte) -87
+        Arrays.fill(CHARS, 2389, 2392, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2392, 2402, (byte) -19 ); // Fill 10 of value (byte) -19
+        Arrays.fill(CHARS, 2402, 2404, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 2404, 2406, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2406, 2416, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 2416, 2433, (byte) 33 ); // Fill 17 of value (byte) 33
+        Arrays.fill(CHARS, 2433, 2436, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[2436] = 33;
+        Arrays.fill(CHARS, 2437, 2445, (byte) -19 ); // Fill 8 of value (byte) -19
+        Arrays.fill(CHARS, 2445, 2447, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2447, 2449, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 2449, 2451, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2451, 2473, (byte) -19 ); // Fill 22 of value (byte) -19
+        CHARS[2473] = 33;
+        Arrays.fill(CHARS, 2474, 2481, (byte) -19 ); // Fill 7 of value (byte) -19
+        CHARS[2481] = 33;
+        CHARS[2482] = -19;
+        Arrays.fill(CHARS, 2483, 2486, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2486, 2490, (byte) -19 ); // Fill 4 of value (byte) -19
+        Arrays.fill(CHARS, 2490, 2492, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[2492] = -87;
+        CHARS[2493] = 33;
+        Arrays.fill(CHARS, 2494, 2501, (byte) -87 ); // Fill 7 of value (byte) -87
+        Arrays.fill(CHARS, 2501, 2503, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2503, 2505, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 2505, 2507, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2507, 2510, (byte) -87 ); // Fill 3 of value (byte) -87
+        Arrays.fill(CHARS, 2510, 2519, (byte) 33 ); // Fill 9 of value (byte) 33
+        CHARS[2519] = -87;
+        Arrays.fill(CHARS, 2520, 2524, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 2524, 2526, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[2526] = 33;
+        Arrays.fill(CHARS, 2527, 2530, (byte) -19 ); // Fill 3 of value (byte) -19
+        Arrays.fill(CHARS, 2530, 2532, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 2532, 2534, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2534, 2544, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 2544, 2546, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 2546, 2562, (byte) 33 ); // Fill 16 of value (byte) 33
+        CHARS[2562] = -87;
+        Arrays.fill(CHARS, 2563, 2565, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2565, 2571, (byte) -19 ); // Fill 6 of value (byte) -19
+        Arrays.fill(CHARS, 2571, 2575, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 2575, 2577, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 2577, 2579, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2579, 2601, (byte) -19 ); // Fill 22 of value (byte) -19
+        CHARS[2601] = 33;
+        Arrays.fill(CHARS, 2602, 2609, (byte) -19 ); // Fill 7 of value (byte) -19
+        CHARS[2609] = 33;
+        Arrays.fill(CHARS, 2610, 2612, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[2612] = 33;
+        Arrays.fill(CHARS, 2613, 2615, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[2615] = 33;
+        Arrays.fill(CHARS, 2616, 2618, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 2618, 2620, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[2620] = -87;
+        CHARS[2621] = 33;
+        Arrays.fill(CHARS, 2622, 2627, (byte) -87 ); // Fill 5 of value (byte) -87
+        Arrays.fill(CHARS, 2627, 2631, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 2631, 2633, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 2633, 2635, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2635, 2638, (byte) -87 ); // Fill 3 of value (byte) -87
+        Arrays.fill(CHARS, 2638, 2649, (byte) 33 ); // Fill 11 of value (byte) 33
+        Arrays.fill(CHARS, 2649, 2653, (byte) -19 ); // Fill 4 of value (byte) -19
+        CHARS[2653] = 33;
+        CHARS[2654] = -19;
+        Arrays.fill(CHARS, 2655, 2662, (byte) 33 ); // Fill 7 of value (byte) 33
+        Arrays.fill(CHARS, 2662, 2674, (byte) -87 ); // Fill 12 of value (byte) -87
+        Arrays.fill(CHARS, 2674, 2677, (byte) -19 ); // Fill 3 of value (byte) -19
+        Arrays.fill(CHARS, 2677, 2689, (byte) 33 ); // Fill 12 of value (byte) 33
+        Arrays.fill(CHARS, 2689, 2692, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[2692] = 33;
+        Arrays.fill(CHARS, 2693, 2700, (byte) -19 ); // Fill 7 of value (byte) -19
+        CHARS[2700] = 33;
+        CHARS[2701] = -19;
+        CHARS[2702] = 33;
+        Arrays.fill(CHARS, 2703, 2706, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[2706] = 33;
+        Arrays.fill(CHARS, 2707, 2729, (byte) -19 ); // Fill 22 of value (byte) -19
+        CHARS[2729] = 33;
+        Arrays.fill(CHARS, 2730, 2737, (byte) -19 ); // Fill 7 of value (byte) -19
+        CHARS[2737] = 33;
+        Arrays.fill(CHARS, 2738, 2740, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[2740] = 33;
+        Arrays.fill(CHARS, 2741, 2746, (byte) -19 ); // Fill 5 of value (byte) -19
+        Arrays.fill(CHARS, 2746, 2748, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[2748] = -87;
+        CHARS[2749] = -19;
+        Arrays.fill(CHARS, 2750, 2758, (byte) -87 ); // Fill 8 of value (byte) -87
+        CHARS[2758] = 33;
+        Arrays.fill(CHARS, 2759, 2762, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[2762] = 33;
+        Arrays.fill(CHARS, 2763, 2766, (byte) -87 ); // Fill 3 of value (byte) -87
+        Arrays.fill(CHARS, 2766, 2784, (byte) 33 ); // Fill 18 of value (byte) 33
+        CHARS[2784] = -19;
+        Arrays.fill(CHARS, 2785, 2790, (byte) 33 ); // Fill 5 of value (byte) 33
+        Arrays.fill(CHARS, 2790, 2800, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 2800, 2817, (byte) 33 ); // Fill 17 of value (byte) 33
+        Arrays.fill(CHARS, 2817, 2820, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[2820] = 33;
+        Arrays.fill(CHARS, 2821, 2829, (byte) -19 ); // Fill 8 of value (byte) -19
+        Arrays.fill(CHARS, 2829, 2831, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2831, 2833, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 2833, 2835, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2835, 2857, (byte) -19 ); // Fill 22 of value (byte) -19
+        CHARS[2857] = 33;
+        Arrays.fill(CHARS, 2858, 2865, (byte) -19 ); // Fill 7 of value (byte) -19
+        CHARS[2865] = 33;
+        Arrays.fill(CHARS, 2866, 2868, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 2868, 2870, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2870, 2874, (byte) -19 ); // Fill 4 of value (byte) -19
+        Arrays.fill(CHARS, 2874, 2876, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[2876] = -87;
+        CHARS[2877] = -19;
+        Arrays.fill(CHARS, 2878, 2884, (byte) -87 ); // Fill 6 of value (byte) -87
+        Arrays.fill(CHARS, 2884, 2887, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2887, 2889, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 2889, 2891, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 2891, 2894, (byte) -87 ); // Fill 3 of value (byte) -87
+        Arrays.fill(CHARS, 2894, 2902, (byte) 33 ); // Fill 8 of value (byte) 33
+        Arrays.fill(CHARS, 2902, 2904, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 2904, 2908, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 2908, 2910, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[2910] = 33;
+        Arrays.fill(CHARS, 2911, 2914, (byte) -19 ); // Fill 3 of value (byte) -19
+        Arrays.fill(CHARS, 2914, 2918, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 2918, 2928, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 2928, 2946, (byte) 33 ); // Fill 18 of value (byte) 33
+        Arrays.fill(CHARS, 2946, 2948, (byte) -87 ); // Fill 2 of value (byte) -87
+        CHARS[2948] = 33;
+        Arrays.fill(CHARS, 2949, 2955, (byte) -19 ); // Fill 6 of value (byte) -19
+        Arrays.fill(CHARS, 2955, 2958, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2958, 2961, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[2961] = 33;
+        Arrays.fill(CHARS, 2962, 2966, (byte) -19 ); // Fill 4 of value (byte) -19
+        Arrays.fill(CHARS, 2966, 2969, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2969, 2971, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[2971] = 33;
+        CHARS[2972] = -19;
+        CHARS[2973] = 33;
+        Arrays.fill(CHARS, 2974, 2976, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 2976, 2979, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2979, 2981, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 2981, 2984, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2984, 2987, (byte) -19 ); // Fill 3 of value (byte) -19
+        Arrays.fill(CHARS, 2987, 2990, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 2990, 2998, (byte) -19 ); // Fill 8 of value (byte) -19
+        CHARS[2998] = 33;
+        Arrays.fill(CHARS, 2999, 3002, (byte) -19 ); // Fill 3 of value (byte) -19
+        Arrays.fill(CHARS, 3002, 3006, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3006, 3011, (byte) -87 ); // Fill 5 of value (byte) -87
+        Arrays.fill(CHARS, 3011, 3014, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 3014, 3017, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[3017] = 33;
+        Arrays.fill(CHARS, 3018, 3022, (byte) -87 ); // Fill 4 of value (byte) -87
+        Arrays.fill(CHARS, 3022, 3031, (byte) 33 ); // Fill 9 of value (byte) 33
+        CHARS[3031] = -87;
+        Arrays.fill(CHARS, 3032, 3047, (byte) 33 ); // Fill 15 of value (byte) 33
+        Arrays.fill(CHARS, 3047, 3056, (byte) -87 ); // Fill 9 of value (byte) -87
+        Arrays.fill(CHARS, 3056, 3073, (byte) 33 ); // Fill 17 of value (byte) 33
+        Arrays.fill(CHARS, 3073, 3076, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[3076] = 33;
+        Arrays.fill(CHARS, 3077, 3085, (byte) -19 ); // Fill 8 of value (byte) -19
+        CHARS[3085] = 33;
+        Arrays.fill(CHARS, 3086, 3089, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[3089] = 33;
+        Arrays.fill(CHARS, 3090, 3113, (byte) -19 ); // Fill 23 of value (byte) -19
+        CHARS[3113] = 33;
+        Arrays.fill(CHARS, 3114, 3124, (byte) -19 ); // Fill 10 of value (byte) -19
+        CHARS[3124] = 33;
+        Arrays.fill(CHARS, 3125, 3130, (byte) -19 ); // Fill 5 of value (byte) -19
+        Arrays.fill(CHARS, 3130, 3134, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3134, 3141, (byte) -87 ); // Fill 7 of value (byte) -87
+        CHARS[3141] = 33;
+        Arrays.fill(CHARS, 3142, 3145, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[3145] = 33;
+        Arrays.fill(CHARS, 3146, 3150, (byte) -87 ); // Fill 4 of value (byte) -87
+        Arrays.fill(CHARS, 3150, 3157, (byte) 33 ); // Fill 7 of value (byte) 33
+        Arrays.fill(CHARS, 3157, 3159, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 3159, 3168, (byte) 33 ); // Fill 9 of value (byte) 33
+        Arrays.fill(CHARS, 3168, 3170, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 3170, 3174, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3174, 3184, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 3184, 3202, (byte) 33 ); // Fill 18 of value (byte) 33
+        Arrays.fill(CHARS, 3202, 3204, (byte) -87 ); // Fill 2 of value (byte) -87
+        CHARS[3204] = 33;
+        Arrays.fill(CHARS, 3205, 3213, (byte) -19 ); // Fill 8 of value (byte) -19
+        CHARS[3213] = 33;
+        Arrays.fill(CHARS, 3214, 3217, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[3217] = 33;
+        Arrays.fill(CHARS, 3218, 3241, (byte) -19 ); // Fill 23 of value (byte) -19
+        CHARS[3241] = 33;
+        Arrays.fill(CHARS, 3242, 3252, (byte) -19 ); // Fill 10 of value (byte) -19
+        CHARS[3252] = 33;
+        Arrays.fill(CHARS, 3253, 3258, (byte) -19 ); // Fill 5 of value (byte) -19
+        Arrays.fill(CHARS, 3258, 3262, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3262, 3269, (byte) -87 ); // Fill 7 of value (byte) -87
+        CHARS[3269] = 33;
+        Arrays.fill(CHARS, 3270, 3273, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[3273] = 33;
+        Arrays.fill(CHARS, 3274, 3278, (byte) -87 ); // Fill 4 of value (byte) -87
+        Arrays.fill(CHARS, 3278, 3285, (byte) 33 ); // Fill 7 of value (byte) 33
+        Arrays.fill(CHARS, 3285, 3287, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 3287, 3294, (byte) 33 ); // Fill 7 of value (byte) 33
+        CHARS[3294] = -19;
+        CHARS[3295] = 33;
+        Arrays.fill(CHARS, 3296, 3298, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 3298, 3302, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3302, 3312, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 3312, 3330, (byte) 33 ); // Fill 18 of value (byte) 33
+        Arrays.fill(CHARS, 3330, 3332, (byte) -87 ); // Fill 2 of value (byte) -87
+        CHARS[3332] = 33;
+        Arrays.fill(CHARS, 3333, 3341, (byte) -19 ); // Fill 8 of value (byte) -19
+        CHARS[3341] = 33;
+        Arrays.fill(CHARS, 3342, 3345, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[3345] = 33;
+        Arrays.fill(CHARS, 3346, 3369, (byte) -19 ); // Fill 23 of value (byte) -19
+        CHARS[3369] = 33;
+        Arrays.fill(CHARS, 3370, 3386, (byte) -19 ); // Fill 16 of value (byte) -19
+        Arrays.fill(CHARS, 3386, 3390, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3390, 3396, (byte) -87 ); // Fill 6 of value (byte) -87
+        Arrays.fill(CHARS, 3396, 3398, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 3398, 3401, (byte) -87 ); // Fill 3 of value (byte) -87
+        CHARS[3401] = 33;
+        Arrays.fill(CHARS, 3402, 3406, (byte) -87 ); // Fill 4 of value (byte) -87
+        Arrays.fill(CHARS, 3406, 3415, (byte) 33 ); // Fill 9 of value (byte) 33
+        CHARS[3415] = -87;
+        Arrays.fill(CHARS, 3416, 3424, (byte) 33 ); // Fill 8 of value (byte) 33
+        Arrays.fill(CHARS, 3424, 3426, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 3426, 3430, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3430, 3440, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 3440, 3585, (byte) 33 ); // Fill 145 of value (byte) 33
+        Arrays.fill(CHARS, 3585, 3631, (byte) -19 ); // Fill 46 of value (byte) -19
+        CHARS[3631] = 33;
+        CHARS[3632] = -19;
+        CHARS[3633] = -87;
+        Arrays.fill(CHARS, 3634, 3636, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 3636, 3643, (byte) -87 ); // Fill 7 of value (byte) -87
+        Arrays.fill(CHARS, 3643, 3648, (byte) 33 ); // Fill 5 of value (byte) 33
+        Arrays.fill(CHARS, 3648, 3654, (byte) -19 ); // Fill 6 of value (byte) -19
+        Arrays.fill(CHARS, 3654, 3663, (byte) -87 ); // Fill 9 of value (byte) -87
+        CHARS[3663] = 33;
+        Arrays.fill(CHARS, 3664, 3674, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 3674, 3713, (byte) 33 ); // Fill 39 of value (byte) 33
+        Arrays.fill(CHARS, 3713, 3715, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[3715] = 33;
+        CHARS[3716] = -19;
+        Arrays.fill(CHARS, 3717, 3719, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 3719, 3721, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[3721] = 33;
+        CHARS[3722] = -19;
+        Arrays.fill(CHARS, 3723, 3725, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[3725] = -19;
+        Arrays.fill(CHARS, 3726, 3732, (byte) 33 ); // Fill 6 of value (byte) 33
+        Arrays.fill(CHARS, 3732, 3736, (byte) -19 ); // Fill 4 of value (byte) -19
+        CHARS[3736] = 33;
+        Arrays.fill(CHARS, 3737, 3744, (byte) -19 ); // Fill 7 of value (byte) -19
+        CHARS[3744] = 33;
+        Arrays.fill(CHARS, 3745, 3748, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[3748] = 33;
+        CHARS[3749] = -19;
+        CHARS[3750] = 33;
+        CHARS[3751] = -19;
+        Arrays.fill(CHARS, 3752, 3754, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 3754, 3756, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[3756] = 33;
+        Arrays.fill(CHARS, 3757, 3759, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[3759] = 33;
+        CHARS[3760] = -19;
+        CHARS[3761] = -87;
+        Arrays.fill(CHARS, 3762, 3764, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 3764, 3770, (byte) -87 ); // Fill 6 of value (byte) -87
+        CHARS[3770] = 33;
+        Arrays.fill(CHARS, 3771, 3773, (byte) -87 ); // Fill 2 of value (byte) -87
+        CHARS[3773] = -19;
+        Arrays.fill(CHARS, 3774, 3776, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 3776, 3781, (byte) -19 ); // Fill 5 of value (byte) -19
+        CHARS[3781] = 33;
+        CHARS[3782] = -87;
+        CHARS[3783] = 33;
+        Arrays.fill(CHARS, 3784, 3790, (byte) -87 ); // Fill 6 of value (byte) -87
+        Arrays.fill(CHARS, 3790, 3792, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 3792, 3802, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 3802, 3864, (byte) 33 ); // Fill 62 of value (byte) 33
+        Arrays.fill(CHARS, 3864, 3866, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 3866, 3872, (byte) 33 ); // Fill 6 of value (byte) 33
+        Arrays.fill(CHARS, 3872, 3882, (byte) -87 ); // Fill 10 of value (byte) -87
+        Arrays.fill(CHARS, 3882, 3893, (byte) 33 ); // Fill 11 of value (byte) 33
+        CHARS[3893] = -87;
+        CHARS[3894] = 33;
+        CHARS[3895] = -87;
+        CHARS[3896] = 33;
+        CHARS[3897] = -87;
+        Arrays.fill(CHARS, 3898, 3902, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3902, 3904, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 3904, 3912, (byte) -19 ); // Fill 8 of value (byte) -19
+        CHARS[3912] = 33;
+        Arrays.fill(CHARS, 3913, 3946, (byte) -19 ); // Fill 33 of value (byte) -19
+        Arrays.fill(CHARS, 3946, 3953, (byte) 33 ); // Fill 7 of value (byte) 33
+        Arrays.fill(CHARS, 3953, 3973, (byte) -87 ); // Fill 20 of value (byte) -87
+        CHARS[3973] = 33;
+        Arrays.fill(CHARS, 3974, 3980, (byte) -87 ); // Fill 6 of value (byte) -87
+        Arrays.fill(CHARS, 3980, 3984, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 3984, 3990, (byte) -87 ); // Fill 6 of value (byte) -87
+        CHARS[3990] = 33;
+        CHARS[3991] = -87;
+        CHARS[3992] = 33;
+        Arrays.fill(CHARS, 3993, 4014, (byte) -87 ); // Fill 21 of value (byte) -87
+        Arrays.fill(CHARS, 4014, 4017, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 4017, 4024, (byte) -87 ); // Fill 7 of value (byte) -87
+        CHARS[4024] = 33;
+        CHARS[4025] = -87;
+        Arrays.fill(CHARS, 4026, 4256, (byte) 33 ); // Fill 230 of value (byte) 33
+        Arrays.fill(CHARS, 4256, 4294, (byte) -19 ); // Fill 38 of value (byte) -19
+        Arrays.fill(CHARS, 4294, 4304, (byte) 33 ); // Fill 10 of value (byte) 33
+        Arrays.fill(CHARS, 4304, 4343, (byte) -19 ); // Fill 39 of value (byte) -19
+        Arrays.fill(CHARS, 4343, 4352, (byte) 33 ); // Fill 9 of value (byte) 33
+        CHARS[4352] = -19;
+        CHARS[4353] = 33;
+        Arrays.fill(CHARS, 4354, 4356, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[4356] = 33;
+        Arrays.fill(CHARS, 4357, 4360, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[4360] = 33;
+        CHARS[4361] = -19;
+        CHARS[4362] = 33;
+        Arrays.fill(CHARS, 4363, 4365, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[4365] = 33;
+        Arrays.fill(CHARS, 4366, 4371, (byte) -19 ); // Fill 5 of value (byte) -19
+        Arrays.fill(CHARS, 4371, 4412, (byte) 33 ); // Fill 41 of value (byte) 33
+        CHARS[4412] = -19;
+        CHARS[4413] = 33;
+        CHARS[4414] = -19;
+        CHARS[4415] = 33;
+        CHARS[4416] = -19;
+        Arrays.fill(CHARS, 4417, 4428, (byte) 33 ); // Fill 11 of value (byte) 33
+        CHARS[4428] = -19;
+        CHARS[4429] = 33;
+        CHARS[4430] = -19;
+        CHARS[4431] = 33;
+        CHARS[4432] = -19;
+        Arrays.fill(CHARS, 4433, 4436, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 4436, 4438, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 4438, 4441, (byte) 33 ); // Fill 3 of value (byte) 33
+        CHARS[4441] = -19;
+        Arrays.fill(CHARS, 4442, 4447, (byte) 33 ); // Fill 5 of value (byte) 33
+        Arrays.fill(CHARS, 4447, 4450, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[4450] = 33;
+        CHARS[4451] = -19;
+        CHARS[4452] = 33;
+        CHARS[4453] = -19;
+        CHARS[4454] = 33;
+        CHARS[4455] = -19;
+        CHARS[4456] = 33;
+        CHARS[4457] = -19;
+        Arrays.fill(CHARS, 4458, 4461, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 4461, 4463, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 4463, 4466, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 4466, 4468, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[4468] = 33;
+        CHARS[4469] = -19;
+        Arrays.fill(CHARS, 4470, 4510, (byte) 33 ); // Fill 40 of value (byte) 33
+        CHARS[4510] = -19;
+        Arrays.fill(CHARS, 4511, 4520, (byte) 33 ); // Fill 9 of value (byte) 33
+        CHARS[4520] = -19;
+        Arrays.fill(CHARS, 4521, 4523, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[4523] = -19;
+        Arrays.fill(CHARS, 4524, 4526, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 4526, 4528, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 4528, 4535, (byte) 33 ); // Fill 7 of value (byte) 33
+        Arrays.fill(CHARS, 4535, 4537, (byte) -19 ); // Fill 2 of value (byte) -19
+        CHARS[4537] = 33;
+        CHARS[4538] = -19;
+        CHARS[4539] = 33;
+        Arrays.fill(CHARS, 4540, 4547, (byte) -19 ); // Fill 7 of value (byte) -19
+        Arrays.fill(CHARS, 4547, 4587, (byte) 33 ); // Fill 40 of value (byte) 33
+        CHARS[4587] = -19;
+        Arrays.fill(CHARS, 4588, 4592, (byte) 33 ); // Fill 4 of value (byte) 33
+        CHARS[4592] = -19;
+        Arrays.fill(CHARS, 4593, 4601, (byte) 33 ); // Fill 8 of value (byte) 33
+        CHARS[4601] = -19;
+        Arrays.fill(CHARS, 4602, 7680, (byte) 33 ); // Fill 3078 of value (byte) 33
+        Arrays.fill(CHARS, 7680, 7836, (byte) -19 ); // Fill 156 of value (byte) -19
+        Arrays.fill(CHARS, 7836, 7840, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 7840, 7930, (byte) -19 ); // Fill 90 of value (byte) -19
+        Arrays.fill(CHARS, 7930, 7936, (byte) 33 ); // Fill 6 of value (byte) 33
+        Arrays.fill(CHARS, 7936, 7958, (byte) -19 ); // Fill 22 of value (byte) -19
+        Arrays.fill(CHARS, 7958, 7960, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 7960, 7966, (byte) -19 ); // Fill 6 of value (byte) -19
+        Arrays.fill(CHARS, 7966, 7968, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 7968, 8006, (byte) -19 ); // Fill 38 of value (byte) -19
+        Arrays.fill(CHARS, 8006, 8008, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 8008, 8014, (byte) -19 ); // Fill 6 of value (byte) -19
+        Arrays.fill(CHARS, 8014, 8016, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 8016, 8024, (byte) -19 ); // Fill 8 of value (byte) -19
+        CHARS[8024] = 33;
+        CHARS[8025] = -19;
+        CHARS[8026] = 33;
+        CHARS[8027] = -19;
+        CHARS[8028] = 33;
+        CHARS[8029] = -19;
+        CHARS[8030] = 33;
+        Arrays.fill(CHARS, 8031, 8062, (byte) -19 ); // Fill 31 of value (byte) -19
+        Arrays.fill(CHARS, 8062, 8064, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 8064, 8117, (byte) -19 ); // Fill 53 of value (byte) -19
+        CHARS[8117] = 33;
+        Arrays.fill(CHARS, 8118, 8125, (byte) -19 ); // Fill 7 of value (byte) -19
+        CHARS[8125] = 33;
+        CHARS[8126] = -19;
+        Arrays.fill(CHARS, 8127, 8130, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 8130, 8133, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[8133] = 33;
+        Arrays.fill(CHARS, 8134, 8141, (byte) -19 ); // Fill 7 of value (byte) -19
+        Arrays.fill(CHARS, 8141, 8144, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 8144, 8148, (byte) -19 ); // Fill 4 of value (byte) -19
+        Arrays.fill(CHARS, 8148, 8150, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 8150, 8156, (byte) -19 ); // Fill 6 of value (byte) -19
+        Arrays.fill(CHARS, 8156, 8160, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 8160, 8173, (byte) -19 ); // Fill 13 of value (byte) -19
+        Arrays.fill(CHARS, 8173, 8178, (byte) 33 ); // Fill 5 of value (byte) 33
+        Arrays.fill(CHARS, 8178, 8181, (byte) -19 ); // Fill 3 of value (byte) -19
+        CHARS[8181] = 33;
+        Arrays.fill(CHARS, 8182, 8189, (byte) -19 ); // Fill 7 of value (byte) -19
+        Arrays.fill(CHARS, 8189, 8400, (byte) 33 ); // Fill 211 of value (byte) 33
+        Arrays.fill(CHARS, 8400, 8413, (byte) -87 ); // Fill 13 of value (byte) -87
+        Arrays.fill(CHARS, 8413, 8417, (byte) 33 ); // Fill 4 of value (byte) 33
+        CHARS[8417] = -87;
+        Arrays.fill(CHARS, 8418, 8486, (byte) 33 ); // Fill 68 of value (byte) 33
+        CHARS[8486] = -19;
+        Arrays.fill(CHARS, 8487, 8490, (byte) 33 ); // Fill 3 of value (byte) 33
+        Arrays.fill(CHARS, 8490, 8492, (byte) -19 ); // Fill 2 of value (byte) -19
+        Arrays.fill(CHARS, 8492, 8494, (byte) 33 ); // Fill 2 of value (byte) 33
+        CHARS[8494] = -19;
+        Arrays.fill(CHARS, 8495, 8576, (byte) 33 ); // Fill 81 of value (byte) 33
+        Arrays.fill(CHARS, 8576, 8579, (byte) -19 ); // Fill 3 of value (byte) -19
+        Arrays.fill(CHARS, 8579, 12293, (byte) 33 ); // Fill 3714 of value (byte) 33
+        CHARS[12293] = -87;
+        CHARS[12294] = 33;
+        CHARS[12295] = -19;
+        Arrays.fill(CHARS, 12296, 12321, (byte) 33 ); // Fill 25 of value (byte) 33
+        Arrays.fill(CHARS, 12321, 12330, (byte) -19 ); // Fill 9 of value (byte) -19
+        Arrays.fill(CHARS, 12330, 12336, (byte) -87 ); // Fill 6 of value (byte) -87
+        CHARS[12336] = 33;
+        Arrays.fill(CHARS, 12337, 12342, (byte) -87 ); // Fill 5 of value (byte) -87
+        Arrays.fill(CHARS, 12342, 12353, (byte) 33 ); // Fill 11 of value (byte) 33
+        Arrays.fill(CHARS, 12353, 12437, (byte) -19 ); // Fill 84 of value (byte) -19
+        Arrays.fill(CHARS, 12437, 12441, (byte) 33 ); // Fill 4 of value (byte) 33
+        Arrays.fill(CHARS, 12441, 12443, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 12443, 12445, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 12445, 12447, (byte) -87 ); // Fill 2 of value (byte) -87
+        Arrays.fill(CHARS, 12447, 12449, (byte) 33 ); // Fill 2 of value (byte) 33
+        Arrays.fill(CHARS, 12449, 12539, (byte) -19 ); // Fill 90 of value (byte) -19
+        CHARS[12539] = 33;
+        Arrays.fill(CHARS, 12540, 12543, (byte) -87 ); // Fill 3 of value (byte) -87
+        Arrays.fill(CHARS, 12543, 12549, (byte) 33 ); // Fill 6 of value (byte) 33
+        Arrays.fill(CHARS, 12549, 12589, (byte) -19 ); // Fill 40 of value (byte) -19
+        Arrays.fill(CHARS, 12589, 19968, (byte) 33 ); // Fill 7379 of value (byte) 33
+        Arrays.fill(CHARS, 19968, 40870, (byte) -19 ); // Fill 20902 of value (byte) -19
+        Arrays.fill(CHARS, 40870, 44032, (byte) 33 ); // Fill 3162 of value (byte) 33
+        Arrays.fill(CHARS, 44032, 55204, (byte) -19 ); // Fill 11172 of value (byte) -19
+        Arrays.fill(CHARS, 55204, 55296, (byte) 33 ); // Fill 92 of value (byte) 33
+        Arrays.fill(CHARS, 57344, 65534, (byte) 33 ); // Fill 8190 of value (byte) 33
+
+    } // <clinit>()
+
+    //
+    // Public static methods
+    //
+
+    /**
+     * Returns true if the specified character is a supplemental character.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isSupplemental(int c) {
+        return (c >= 0x10000 && c <= 0x10FFFF);
+    }
+
+    /**
+     * Returns true the supplemental character corresponding to the given
+     * surrogates.
+     *
+     * @param h The high surrogate.
+     * @param l The low surrogate.
+     */
+    public static int supplemental(char h, char l) {
+        return (h - 0xD800) * 0x400 + (l - 0xDC00) + 0x10000;
+    }
+
+    /**
+     * Returns the high surrogate of a supplemental character
+     *
+     * @param c The supplemental character to "split".
+     */
+    public static char highSurrogate(int c) {
+        return (char) (((c - 0x00010000) >> 10) + 0xD800);
+    }
+
+    /**
+     * Returns the low surrogate of a supplemental character
+     *
+     * @param c The supplemental character to "split".
+     */
+    public static char lowSurrogate(int c) {
+        return (char) (((c - 0x00010000) & 0x3FF) + 0xDC00);
+    }
+
+    /**
+     * Returns whether the given character is a high surrogate
+     *
+     * @param c The character to check.
+     */
+    public static boolean isHighSurrogate(int c) {
+        return (0xD800 <= c && c <= 0xDBFF);
+    }
+
+    /**
+     * Returns whether the given character is a low surrogate
+     *
+     * @param c The character to check.
+     */
+    public static boolean isLowSurrogate(int c) {
+        return (0xDC00 <= c && c <= 0xDFFF);
+    }
+
+
+    /**
+     * Returns true if the specified character is valid. This method
+     * also checks the surrogate character range from 0x10000 to 0x10FFFF.
+     * <p>
+     * If the program chooses to apply the mask directly to the
+     * <code>CHARS</code> array, then they are responsible for checking
+     * the surrogate character range.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isValid(int c) {
+        return (c < 0x10000 && (CHARS[c] & MASK_VALID) != 0) ||
+               (0x10000 <= c && c <= 0x10FFFF);
+    } // isValid(int):boolean
+
+    /**
+     * Returns true if the specified character is invalid.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isInvalid(int c) {
+        return !isValid(c);
+    } // isInvalid(int):boolean
+
+    /**
+     * Returns true if the specified character can be considered content.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isContent(int c) {
+        return (c < 0x10000 && (CHARS[c] & MASK_CONTENT) != 0) ||
+               (0x10000 <= c && c <= 0x10FFFF);
+    } // isContent(int):boolean
+
+    /**
+     * Returns true if the specified character can be considered markup.
+     * Markup characters include '&lt;', '&amp;', and '%'.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isMarkup(int c) {
+        return c == '<' || c == '&' || c == '%';
+    } // isMarkup(int):boolean
+
+    /**
+     * Returns true if the specified character is a space character
+     * as defined by production [3] in the XML 1.0 specification.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isSpace(int c) {
+        return c <= 0x20 && (CHARS[c] & MASK_SPACE) != 0;
+    } // isSpace(int):boolean
+
+    /**
+     * Returns true if the specified character is a valid name start
+     * character as defined by production [5] in the XML 1.0
+     * specification.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isNameStart(int c) {
+        return c < 0x10000 && (CHARS[c] & MASK_NAME_START) != 0;
+    } // isNameStart(int):boolean
+
+    /**
+     * Returns true if the specified character is a valid name
+     * character as defined by production [4] in the XML 1.0
+     * specification.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isName(int c) {
+        return c < 0x10000 && (CHARS[c] & MASK_NAME) != 0;
+    } // isName(int):boolean
+
+    /**
+     * Returns true if the specified character is a valid NCName start
+     * character as defined by production [4] in Namespaces in XML
+     * recommendation.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isNCNameStart(int c) {
+        return c < 0x10000 && (CHARS[c] & MASK_NCNAME_START) != 0;
+    } // isNCNameStart(int):boolean
+
+    /**
+     * Returns true if the specified character is a valid NCName
+     * character as defined by production [5] in Namespaces in XML
+     * recommendation.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isNCName(int c) {
+        return c < 0x10000 && (CHARS[c] & MASK_NCNAME) != 0;
+    } // isNCName(int):boolean
+
+    /**
+     * Returns true if the specified character is a valid Pubid
+     * character as defined by production [13] in the XML 1.0
+     * specification.
+     *
+     * @param c The character to check.
+     */
+    public static boolean isPubid(int c) {
+        return c < 0x10000 && (CHARS[c] & MASK_PUBID) != 0;
+    } // isPubid(int):boolean
+
+    /*
+     * [5] Name ::= (Letter | '_' | ':') (NameChar)*
+     */
+    /**
+     * Check to see if a string is a valid Name according to [5]
+     * in the XML 1.0 Recommendation
+     *
+     * @param name string to check
+     * @return true if name is a valid Name
+     */
+    public static boolean isValidName(String name) {
+        if (name.length() == 0)
+            return false;
+        char ch = name.charAt(0);
+        if( isNameStart(ch) == false)
+           return false;
+        for (int i = 1; i < name.length(); i++ ) {
+           ch = name.charAt(i);
+           if( isName( ch ) == false ){
+              return false;
+           }
+        }
+        return true;
+    } // isValidName(String):boolean
+
+
+    /*
+     * from the namespace rec
+     * [4] NCName ::= (Letter | '_') (NCNameChar)*
+     */
+    /**
+     * Check to see if a string is a valid NCName according to [4]
+     * from the XML Namespaces 1.0 Recommendation
+     *
+     * @param ncName string to check
+     * @return true if name is a valid NCName
+     */
+    public static boolean isValidNCName(String ncName) {
+        if (ncName.length() == 0)
+            return false;
+        char ch = ncName.charAt(0);
+        if( isNCNameStart(ch) == false)
+           return false;
+        for (int i = 1; i < ncName.length(); i++ ) {
+           ch = ncName.charAt(i);
+           if( isNCName( ch ) == false ){
+              return false;
+           }
+        }
+        return true;
+    } // isValidNCName(String):boolean
+
+    /*
+     * [7] Nmtoken ::= (NameChar)+
+     */
+    /**
+     * Check to see if a string is a valid Nmtoken according to [7]
+     * in the XML 1.0 Recommendation
+     *
+     * @param nmtoken string to check
+     * @return true if nmtoken is a valid Nmtoken
+     */
+    public static boolean isValidNmtoken(String nmtoken) {
+        if (nmtoken.length() == 0)
+            return false;
+        for (int i = 0; i < nmtoken.length(); i++ ) {
+           char ch = nmtoken.charAt(i);
+           if(  ! isName( ch ) ){
+              return false;
+           }
+        }
+        return true;
+    } // isValidName(String):boolean
+
+
+
+
+
+    // encodings
+
+    /**
+     * Returns true if the encoding name is a valid IANA encoding.
+     * This method does not verify that there is a decoder available
+     * for this encoding, only that the characters are valid for an
+     * IANA encoding name.
+     *
+     * @param ianaEncoding The IANA encoding name.
+     */
+    public static boolean isValidIANAEncoding(String ianaEncoding) {
+        if (ianaEncoding != null) {
+            int length = ianaEncoding.length();
+            if (length > 0) {
+                char c = ianaEncoding.charAt(0);
+                if ((c >= 'A' && c <= 'Z') || (c >= 'a' && c <= 'z')) {
+                    for (int i = 1; i < length; i++) {
+                        c = ianaEncoding.charAt(i);
+                        if ((c < 'A' || c > 'Z') && (c < 'a' || c > 'z') &&
+                            (c < '0' || c > '9') && c != '.' && c != '_' &&
+                            c != '-') {
+                            return false;
+                        }
+                    }
+                    return true;
+                }
+            }
+        }
+        return false;
+    } // isValidIANAEncoding(String):boolean
+
+    /**
+     * Returns true if the encoding name is a valid Java encoding.
+     * This method does not verify that there is a decoder available
+     * for this encoding, only that the characters are valid for an
+     * Java encoding name.
+     *
+     * @param javaEncoding The Java encoding name.
+     */
+    public static boolean isValidJavaEncoding(String javaEncoding) {
+        if (javaEncoding != null) {
+            int length = javaEncoding.length();
+            if (length > 0) {
+                for (int i = 1; i < length; i++) {
+                    char c = javaEncoding.charAt(i);
+                    if ((c < 'A' || c > 'Z') && (c < 'a' || c > 'z') &&
+                        (c < '0' || c > '9') && c != '.' && c != '_' &&
+                        c != '-') {
+                        return false;
+                    }
+                }
+                return true;
+            }
+        }
+        return false;
+    } // isValidIANAEncoding(String):boolean
+
+
+} // class XMLChar
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/resources/ResourceBundle.properties b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/resources/ResourceBundle.properties
new file mode 100644
index 0000000..a250f51
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/resources/ResourceBundle.properties
@@ -0,0 +1,181 @@
+# Sample ResourceBundle properties file
+message.optinalValues = Optional values (other than initial vocabulary) of DII not supported
+message.noExternalVocabularies=No external vocabularies registered
+message.externalVocabularyNotRegistered=External vocabulary referenced by "{0}" is not registered"
+
+message.illegalState=Illegal state for decoding of EncodedCharacterString
+message.missingNamespace=Name surrogate prefix is present when namespace name is absent
+message.IIsNotTerminatedCorrectly=Notation IIs not terminated correctly
+message.unparsedEntities=Unparsed entities not terminated correctly
+message.decodingNotSupported=Document version with encoding algorithm decoding not supported
+message.qNameMissingNamespaceName=Literal qualified name with prefix but no namespace name
+message.decodingEII=Illegal state when decoding literal qualified name of EII
+
+message.decodingNonIdentifyingString=Illegal state whendecoding non identifying string
+message.decodingOctets=Illegal state when decoding octets
+message.decodingIdentifyingString=Illegal state when decoding identifying string on first bit
+message.prefixIllegal=The literal identifying string for the \"xml\" prefix is illegal
+message.xmlns=The prefix \"xmlns\" cannot be bound to any namespace explicitly
+message.wrongNamespaceName=\"xml\" prefix  with a namespace name other than XML namespace name
+message.missingNamespaceName=\"xml\" prefix without an XML namespace name
+message.decodingIdentifyingStringForPrefix=Illegal state when decoding identifying string for prefix on first bit
+message.xmlnsConnotBeBoundToPrefix=The namespace \"http://www.w3.org/2000/xmlns/\" cannot be bound to any prfix explicitly
+message.illegalNamespaceName=The literal identifying string for the \"http://www.w3.org/XML/1998/namespace\" namespace name is illegal
+message.namespaceWithoutPrefix=The XML namespace is not allowed without the XML prefix
+message.decodingForNamespaceName=Illegal state when decoding identifying string for namespace name on first bit
+message.decodingNonEmptyOctet=Illegal state when decoding non empty octet string on second bit
+message.decodingIndexOnSecondBit=Illegal state when decoding index on second bit
+message.notFIDocument=Input stream is not a fast infoset document
+message.alphabetNotPresent=Restricted alphabet not present for identifier {0}
+message.alphabetIdentifiersReserved=Restricted alphabet identifiers 2 up to and including 31 are reserved for future use
+message.alphabetMustContain2orMoreChars=Restricted Alphabet must contain 2 or more characters
+message.alphabetIncorrectlyTerminated=Restricted alphabet incorrectly terminated
+message.fullBytesNotRead=Full bytes not read
+message.deliminatorTooSmall=Length deliminator too small
+message.UTF8Encoded=Illegal state for UTF-8 encoded string
+message.UTF8EncodedNCName=Illegal state for UTF-8 encoded NCName
+message.EOF=Unexpeceted EOF
+
+#encoder
+message.restrictedAlphabetNotPresent=Restricted alphabet not present in restricted alphabet table
+message.namespaceURINotIndexed=namespace URI of local name not indexed\: {0}
+message.prefixNotIndexed=prefix of local name not indexed\: {0}
+message.EncodingAlgorithmURI=Encoding algorithm URI '{0}' not a member of the encoding algorithm table
+message.nullEncodingAlgorithmURI=Null encoding algorithm URI present with data that is not byte[]
+message.CDATA=CDATA
+message.UnsupportedBuiltInAlgorithm=Unsupported built-in encoding algorithm\: {0}
+
+message.identifiers10to31Reserved=Encoding algorithm identifiers 10 up to and including 31 are reserved for future use
+message.characterOutofAlphabetRange=Character(s) not in restricted alphabet range
+message.integerMaxSize=Integer > {0}
+
+
+#com.sun.xml.internal.fastinfoset.algorithm
+message.notImplemented=Not implemented
+message.dataNotByteArray='data' not an instance of byte[]
+message.dataNotBoolean='data' not an instance of boolean[]
+message.unusedBits4=The number of unused bits is too large (should be < 4)
+message.unusedBits8=The number of unused bits is too large (should be < 8)
+message.lengthIsNotMultipleOfDouble='length' is not a multiple of {0} bytes correspond to the size of the IEEE 754 floating-point \"single format\"
+message.dataNotDouble='data' not an instance of double[]
+message.lengthNotMultipleOfFloat='length' is not a multiple of {0} bytes correspond to the size of the IEEE 754 floating-point \"single format\"
+message.dataNotFloat='data' not an instance of float[]
+message.lengthNotMultipleOfInt='length' is not a multiple of {0} bytes correspond to the size of the 'int' primitive type
+message.dataNotIntArray='data' not an instance of int[]
+message.lengthNotMultipleOfLong='length' is not a multiple of {0} bytes correspond to the size of the 'long' primitive type
+message.dataNotLongArray='data' not an instance of long[]
+message.lengthNotMultipleOfShort='length' is not a multiple of {0} bytes correspond to the size of the 'short' primitive type
+message.dataNotShortArray='data' not an instance of short[]
+message.lengthNotMultipleOfUUID='length' is not a multiple of {0} bytes correspond to the size of the 'UUID' primitive type
+message.invalidUUID=Invalid UUID string\: {0}
+
+#com.sun.xml.internal.fastinfoset.dom
+
+
+
+message.algorithmDataCannotBeReported=Document contains application-defined encoding algorithm data that cannot be reported
+
+message.CDATAAlgorithmNotSupported=CDATA encoding algorithm not supported for attribute values
+
+message.commentIIAlgorithmNotSupported=Comment II with encoding algorithm decoding not supported
+
+message.decodingAIIValue=Illegal state when decoding AII value
+
+message.AIIqNameNotInScope=Qualified name of AII not in scope
+
+message.decodingAIIs=Illegal state when decoding AIIs
+
+message.IllegalStateDecodingEIIAfterAIIs=Illegal state when decoding EII after the namespace AIIs
+
+message.EIInamespaceNameNotTerminatedCorrectly=Namespace names of EII not terminated correctly
+
+message.IllegalStateDecodingEII=Illegal state when decoding a child of an EII
+
+message.addToTableNotSupported=Add to table not supported for Encoding algorithms
+
+message.qnameOfEIINotInScope=Qualified name of EII not in scope
+
+message.IllegalStateDecodingDII=Illegal state when decoding a child of a DII
+
+message.processingInstructionIIsNotTerminatedCorrectly=Processing instruction IIs of Document Type Declaraion II not terminated correctly
+
+message.processingIIWithEncodingAlgorithm=Processing II with encoding algorithm decoding not supported
+
+message.secondOccurenceOfDTDII=A second occurence of a Document Type Declaration II is present
+
+#com.sun.xml.internal.fastinfoset.sax
+message.URINotPresent=URI not present for encoding algorithm identifier {0}
+message.algorithmNotRegistered=Encoding algorithm not registered for URI {0}
+message.featureNotSupported=Feature not supported\: {0}
+message.propertyNotRecognized=Property not recognized\: 
+message.inputSource=InputSource must include a byte stream or a system ID
+message.qNameOfEIINotInScope=Qualified name of EII not in scope
+message.unsupportedAlgorithm=Unsupported built-in encoding algorithm\: {0}
+message.processingInstructionTargetIsEmpty=processingInstruction\: Target is empty
+
+#com.sun.xml.internal.fastinfoset.stax
+message.StAX2SAXReader=StAX2SAXReader does not support event {0}
+
+message.noMoreEvents=No more events to report (EOF).
+message.eventTypeNotMatch=Event type {0} specified did not match with current parser event
+message.namespaceURINotMatch=Namespace URI {0} specified did not match with current namespace URI
+message.localNameNotMatch=LocalName {0} specified did not match with current local name
+message.mustBeOnSTARTELEMENT=parser must be on START_ELEMENT to read next text
+message.unexpectedEOF=unexpected end of document when reading element text content
+
+message.getElementTextExpectTextOnly=getElementText() function expects text only element but START_ELEMENT was encountered.
+message.unexpectedEventType=Unexpected event type {0}
+message.expectedStartOrEnd=expected start or end tag
+message.nullPrefix=Prefix cannot be null.
+message.invalidCallingGetAttributeValue=Method getAttributeValue() called in invalid state
+
+message.invalidCallingGetNamespaceCount=Method getNamespaceCount() called in invalid state
+message.invalidCallingGetNamespacePrefix=Method getNamespacePrefix() called in invalid state
+message.InvalidStateForText=Invalid state for text
+message.invalidCallingGetName=Method getName() called in invalid state
+message.invalidCallingGetLocalName=Method getLocalName() called in invalid state
+message.invalidCallingGetNamespaceURI=Method getNamespaceURI() called in invalid state
+message.invalidCallingGetPrefix=Method getPrefix() called in invalid state
+message.invalidCallingGetPITarget=Method getPITarget() called in invalid state
+message.invalidCallingGetPIData=Method getPIData() called in invalid state
+
+
+message.mustBeOnSTART_ELEMENT=parser must be on START_ELEMENT to read next text.
+message.END_ELEMENTnotFound=Can not find END_ELEMENT.
+message.startOrEndNotFound=Can not find start or end element.
+message.noMoreItems=no more items to return
+message.nullPropertyName=Property name can not be null.
+
+message.validationNotSupported=This implementation does not support validation
+message.externalEntities=This implementation does not resolve external entities 
+message.propertyNotSupported=Property {0} is not supported
+message.noElement=No element.
+message.nullXMLEventAllocator=XMLEvent Allocator may not be null
+
+message.nullEventReader=Event reader can not be null
+message.eventTypeNotSupported=Event type\: {0} not supported.
+message.URIUnbound=URI ''{0}'' is unbound for this attribute
+message.attributeWritingNotAllowed=Current state does not allow attribute writing
+
+#com.sun.xml.internal.fastinfoset.stax.event
+message.charactersCast=cannnot cast {0} to Characters
+message.endElementCase=cannnot cast {0} to EndElement
+message.startElementCase=cannnot cast {0} to StartElement
+message.nullReader=Reader cannot be null
+
+#com.sun.xml.internal.fastinfoset.tools
+message.AttributeValueHolderExpected=Object o is not an AttributeValueHolder
+message.optinalFileNotSpecified=An optional input file and optional output file must be specified
+
+#com.sun.xml.internal.fastinfoset.util
+
+message.illegalClass=Illegal class\: {0}
+message.arrayMaxCapacity=Array has reached maximum capacity
+message.maxNumberOfCharacters=Maximum number of characters is reached
+message.duplicateAttribute=Duplicate attribute present
+message.emptyIterator=The Iterator is empty.
+message.illegalInitialCapacity=Illegal initial capacity\: {0}
+message.illegalLoadFactor=Illegal load factor\: {0}
+message.duplicateNamespaceAttribute=Duplicate namespace attribute entry
+message.readonlyList=The list is read-only. Content can not be changed.
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/AttributesHolder.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/AttributesHolder.java
new file mode 100644
index 0000000..ed99ad6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/AttributesHolder.java
@@ -0,0 +1,314 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.sax;
+
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.algorithm.BuiltInEncodingAlgorithmFactory;
+import java.io.IOException;
+import java.util.Map;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithm;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+
+import com.sun.xml.internal.org.jvnet.fastinfoset.sax.EncodingAlgorithmAttributes;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class AttributesHolder implements EncodingAlgorithmAttributes {
+    private static final int DEFAULT_CAPACITY = 8;
+
+    private Map _registeredEncodingAlgorithms;
+
+    private int _attributeCount;
+
+    private QualifiedName[] _names;
+    private String[] _values;
+
+    private String[] _algorithmURIs;
+    private int[] _algorithmIds;
+    private Object[] _algorithmData;
+
+    public AttributesHolder() {
+        _names = new QualifiedName[DEFAULT_CAPACITY];
+        _values = new String[DEFAULT_CAPACITY];
+
+        _algorithmURIs = new String[DEFAULT_CAPACITY];
+        _algorithmIds = new int[DEFAULT_CAPACITY];
+        _algorithmData = new Object[DEFAULT_CAPACITY];
+    }
+
+    public AttributesHolder(Map registeredEncodingAlgorithms) {
+        this();
+        _registeredEncodingAlgorithms = registeredEncodingAlgorithms;
+    }
+
+    // org.xml.sax.Attributes
+
+    public final int getLength() {
+        return _attributeCount;
+    }
+
+    public final String getLocalName(int index) {
+        return _names[index].localName;
+    }
+
+    public final String getQName(int index) {
+        return _names[index].getQNameString();
+    }
+
+    public final String getType(int index) {
+        return "CDATA";
+    }
+
+    public final String getURI(int index) {
+        return _names[index].namespaceName;
+    }
+
+    public final String getValue(int index) {
+        final String value = _values[index];
+        if (value != null) {
+            return value;
+        }
+
+        if (_algorithmData[index] == null || _registeredEncodingAlgorithms == null) {
+            return null;
+        }
+
+        try {
+            return _values[index] = convertEncodingAlgorithmDataToString(
+                    _algorithmIds[index],
+                    _algorithmURIs[index],
+                    _algorithmData[index]).toString();
+        } catch (IOException e) {
+            return null;
+        } catch (FastInfosetException e) {
+            return null;
+        }
+    }
+
+    public final int getIndex(String qName) {
+        int i = qName.indexOf(':');
+        String prefix = "";
+        String localName = qName;
+        if (i >= 0) {
+            prefix = qName.substring(0, i);
+            localName = qName.substring(i + 1);
+        }
+
+        for (i = 0; i < _attributeCount; i++) {
+            QualifiedName name = _names[i];
+            if (localName.equals(name.localName) &&
+                prefix.equals(name.prefix)) {
+                return i;
+            }
+        }
+        return -1;
+    }
+
+    public final String getType(String qName) {
+        int index = getIndex(qName);
+        if (index >= 0) {
+            return "CDATA";
+        } else {
+            return null;
+        }
+    }
+
+    public final String getValue(String qName) {
+        int index = getIndex(qName);
+        if (index >= 0) {
+            return _values[index];
+        } else {
+            return null;
+        }
+    }
+
+    public final int getIndex(String uri, String localName) {
+        for (int i = 0; i < _attributeCount; i++) {
+            QualifiedName name = _names[i];
+            if (localName.equals(name.localName) &&
+                uri.equals(name.namespaceName)) {
+                return i;
+            }
+        }
+        return -1;
+    }
+
+    public final String getType(String uri, String localName) {
+        int index = getIndex(uri, localName);
+        if (index >= 0) {
+            return "CDATA";
+        } else {
+            return null;
+        }
+    }
+
+    public final String getValue(String uri, String localName) {
+        int index = getIndex(uri, localName);
+        if (index >= 0) {
+            return _values[index];
+        } else {
+            return null;
+        }
+    }
+
+    public final void clear() {
+        for (int i = 0; i < _attributeCount; i++) {
+            _values[i] = null;
+            _algorithmData[i] = null;
+        }
+        _attributeCount = 0;
+    }
+
+    // EncodingAlgorithmAttributes
+
+    public final String getAlgorithmURI(int index) {
+        return _algorithmURIs[index];
+    }
+
+    public final int getAlgorithmIndex(int index) {
+        return _algorithmIds[index];
+    }
+
+    public final Object getAlgorithmData(int index) {
+        return _algorithmData[index];
+    }
+
+
+    // -----
+
+    public final void addAttribute(QualifiedName name, String value) {
+        if (_attributeCount == _names.length) {
+            resize();
+        }
+        _names[_attributeCount] = name;
+        _values[_attributeCount++] = value;
+    }
+
+    public final void addAttributeWithAlgorithmData(QualifiedName name, String URI, int id, Object data) {
+        if (_attributeCount == _names.length) {
+            resize();
+        }
+        _names[_attributeCount] = name;
+        _values[_attributeCount] = null;
+
+        _algorithmURIs[_attributeCount] = URI;
+        _algorithmIds[_attributeCount] = id;
+        _algorithmData[_attributeCount++] = data;
+    }
+
+    public final QualifiedName getQualifiedName(int index) {
+        return _names[index];
+    }
+
+    public final String getPrefix(int index) {
+        return _names[index].prefix;
+    }
+
+    private final void resize() {
+        final int newLength = _attributeCount * 3 / 2 + 1;
+
+        QualifiedName[] names = new QualifiedName[newLength];
+        String[] values = new String[newLength];
+
+        String[] algorithmURIs = new String[newLength];
+        int[] algorithmIds = new int[newLength];
+        Object[] algorithmData = new Object[newLength];
+
+        System.arraycopy(_names, 0, names, 0, _attributeCount);
+        System.arraycopy(_values, 0, values, 0, _attributeCount);
+
+        System.arraycopy(_algorithmURIs, 0, algorithmURIs, 0, _attributeCount);
+        System.arraycopy(_algorithmIds, 0, algorithmIds, 0, _attributeCount);
+        System.arraycopy(_algorithmData, 0, algorithmData, 0, _attributeCount);
+
+        _names = names;
+        _values = values;
+
+        _algorithmURIs = algorithmURIs;
+        _algorithmIds = algorithmIds;
+        _algorithmData = algorithmData;
+    }
+
+    private final StringBuffer convertEncodingAlgorithmDataToString(int identifier, String URI, Object data) throws FastInfosetException, IOException {
+        EncodingAlgorithm ea = null;
+        if (identifier < EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            ea = BuiltInEncodingAlgorithmFactory.table[identifier];
+        } else if (identifier == EncodingAlgorithmIndexes.CDATA) {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.CDATAAlgorithmNotSupported"));
+        } else if (identifier >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            if (URI == null) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.URINotPresent") + identifier);
+            }
+
+            ea = (EncodingAlgorithm)_registeredEncodingAlgorithms.get(URI);
+            if (ea == null) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.algorithmNotRegistered") + URI);
+            }
+        } else {
+            // Reserved built-in algorithms for future use
+            // TODO should use sax property to decide if event will be
+            // reported, allows for support through handler if required.
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.identifiers10to31Reserved"));
+        }
+
+        final StringBuffer sb = new StringBuffer();
+        ea.convertToCharacters(data, sb);
+        return sb;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/Features.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/Features.java
new file mode 100644
index 0000000..014da1b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/Features.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.sax;
+
+public class Features {
+    public static final String NAMESPACES_FEATURE =
+        "http://xml.org/sax/features/namespaces";
+    public static final String NAMESPACE_PREFIXES_FEATURE =
+        "http://xml.org/sax/features/namespace-prefixes";
+    public static final String STRING_INTERNING_FEATURE =
+        "http://xml.org/sax/features/string-interning";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/Properties.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/Properties.java
new file mode 100644
index 0000000..f8108b2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/Properties.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.sax;
+
+public class Properties {
+    public static final String LEXICAL_HANDLER_PROPERTY =
+            "http://xml.org/sax/properties/lexical-handler";
+    public static final String DTD_DECLARATION_HANDLER_PROPERTY =
+            "http://xml.org/sax/properties/declaration-handler";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SAXDocumentParser.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SAXDocumentParser.java
new file mode 100644
index 0000000..f8192b1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SAXDocumentParser.java
@@ -0,0 +1,1565 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.sax;
+
+import com.sun.xml.internal.fastinfoset.Decoder;
+import com.sun.xml.internal.fastinfoset.DecoderStateTables;
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.algorithm.BuiltInEncodingAlgorithmFactory;
+import com.sun.xml.internal.fastinfoset.algorithm.BuiltInEncodingAlgorithmState;
+import com.sun.xml.internal.org.jvnet.fastinfoset.sax.EncodingAlgorithmContentHandler;
+import com.sun.xml.internal.org.jvnet.fastinfoset.sax.FastInfosetReader;
+import com.sun.xml.internal.org.jvnet.fastinfoset.sax.PrimitiveTypeContentHandler;
+import com.sun.xml.internal.fastinfoset.util.CharArray;
+import com.sun.xml.internal.fastinfoset.util.CharArrayString;
+import java.io.IOException;
+import java.io.InputStream;
+import java.net.URL;
+import java.util.Map;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithm;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.DTDHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXNotRecognizedException;
+import org.xml.sax.SAXNotSupportedException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.DefaultHandler;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+import org.xml.sax.ext.DeclHandler;
+
+/**
+ * The Fast Infoset SAX parser.
+ * <p>
+ * Instantiate this parser to parse a fast infoset document in accordance
+ * with the SAX API.
+ *
+ * <p>
+ * More than one fast infoset document may be decoded from the
+ * {@link java.io.InputStream}.
+ */
+public class SAXDocumentParser extends Decoder implements FastInfosetReader {
+
+    /*
+     * Empty lexical handler used by default to report
+     * lexical-based events
+     */
+    private static final class LexicalHandlerImpl implements LexicalHandler {
+        public void comment(char[] ch, int start, int end) { }
+
+        public void startDTD(String name, String publicId, String systemId) { }
+        public void endDTD() { }
+
+        public void startEntity(String name) { }
+        public void endEntity(String name) { }
+
+        public void startCDATA() { }
+        public void endCDATA() { }
+    };
+
+    /*
+     * Empty DTD declaration handler used by default to report
+     * DTD declaration-based events
+     */
+    private static final class DeclHandlerImpl implements DeclHandler {
+        public void elementDecl(String name, String model) throws SAXException {
+        }
+
+        public void attributeDecl(String eName, String aName,
+                String type, String mode, String value) throws SAXException {
+        }
+
+        public void internalEntityDecl(String name,
+                String value) throws SAXException {
+        }
+
+        public void externalEntityDecl(String name,
+                String publicId, String systemId) throws SAXException {
+        }
+    }
+
+    /**
+     * SAX Namespace attributes features
+     */
+    protected boolean _namespacePrefixesFeature = false;
+
+    /**
+     * Reference to entity resolver.
+     */
+    protected EntityResolver _entityResolver;
+
+    /**
+     * Reference to dtd handler.
+     */
+    protected DTDHandler _dtdHandler;
+
+    /**
+     * Reference to content handler.
+     */
+    protected ContentHandler _contentHandler;
+
+    /**
+     * Reference to error handler.
+     */
+    protected ErrorHandler _errorHandler;
+
+    /**
+     * Reference to lexical handler.
+     */
+    protected LexicalHandler _lexicalHandler;
+
+    /**
+     * Reference to DTD declaration handler.
+     */
+    protected DeclHandler _declHandler;
+
+    protected EncodingAlgorithmContentHandler _algorithmHandler;
+
+    protected PrimitiveTypeContentHandler _primitiveHandler;
+
+    protected BuiltInEncodingAlgorithmState builtInAlgorithmState =
+            new BuiltInEncodingAlgorithmState();
+
+    protected AttributesHolder _attributes;
+
+    protected int[] _namespacePrefixes = new int[16];
+
+    protected int _namespacePrefixesIndex;
+
+    protected boolean _clearAttributes = false;
+
+    /** Creates a new instance of DocumetParser2 */
+    public SAXDocumentParser() {
+        DefaultHandler handler = new DefaultHandler();
+        _attributes = new AttributesHolder(_registeredEncodingAlgorithms);
+
+        _entityResolver = handler;
+        _dtdHandler = handler;
+        _contentHandler = handler;
+        _errorHandler = handler;
+        _lexicalHandler = new LexicalHandlerImpl();
+        _declHandler = new DeclHandlerImpl();
+    }
+
+    protected void resetOnError() {
+        _clearAttributes = false;
+        _attributes.clear();
+        _namespacePrefixesIndex = 0;
+
+        if (_v != null) {
+            _v.prefix.clearCompletely();
+        }
+        _duplicateAttributeVerifier.clear();
+    }
+
+    // XMLReader interface
+
+    public boolean getFeature(String name)
+    throws SAXNotRecognizedException, SAXNotSupportedException {
+        if (name.equals(Features.NAMESPACES_FEATURE)) {
+            return true;
+        } else if (name.equals(Features.NAMESPACE_PREFIXES_FEATURE)) {
+            return _namespacePrefixesFeature;
+        } else if (name.equals(Features.STRING_INTERNING_FEATURE) ||
+                name.equals(FastInfosetReader.STRING_INTERNING_PROPERTY)) {
+            return getStringInterning();
+        } else {
+            throw new SAXNotRecognizedException(
+                    CommonResourceBundle.getInstance().getString("message.featureNotSupported") + name);
+        }
+    }
+
+    public void setFeature(String name, boolean value)
+    throws SAXNotRecognizedException, SAXNotSupportedException {
+        if (name.equals(Features.NAMESPACES_FEATURE)) {
+            if (value == false) {
+                throw new SAXNotSupportedException(name + ":" + value);
+            }
+        } else if (name.equals(Features.NAMESPACE_PREFIXES_FEATURE)) {
+            _namespacePrefixesFeature = value;
+        } else if (name.equals(Features.STRING_INTERNING_FEATURE) ||
+                name.equals(FastInfosetReader.STRING_INTERNING_PROPERTY)) {
+            setStringInterning(value);
+        } else {
+            throw new SAXNotRecognizedException(
+                    CommonResourceBundle.getInstance().getString("message.featureNotSupported") + name);
+        }
+    }
+
+    public Object getProperty(String name)
+    throws SAXNotRecognizedException, SAXNotSupportedException {
+        if (name.equals(Properties.LEXICAL_HANDLER_PROPERTY)) {
+            return getLexicalHandler();
+        } else if (name.equals(Properties.DTD_DECLARATION_HANDLER_PROPERTY)) {
+            return getDeclHandler();
+        } else if (name.equals(FastInfosetReader.EXTERNAL_VOCABULARIES_PROPERTY)) {
+            return getExternalVocabularies();
+        } else if (name.equals(FastInfosetReader.REGISTERED_ENCODING_ALGORITHMS_PROPERTY)) {
+            return getRegisteredEncodingAlgorithms();
+        } else if (name.equals(FastInfosetReader.ENCODING_ALGORITHM_CONTENT_HANDLER_PROPERTY)) {
+            return getEncodingAlgorithmContentHandler();
+        } else if (name.equals(FastInfosetReader.PRIMITIVE_TYPE_CONTENT_HANDLER_PROPERTY)) {
+            return getPrimitiveTypeContentHandler();
+        } else {
+            throw new SAXNotRecognizedException(CommonResourceBundle.getInstance().
+                    getString("message.propertyNotRecognized", new Object[]{name}));
+        }
+    }
+
+    public void setProperty(String name, Object value)
+    throws SAXNotRecognizedException, SAXNotSupportedException {
+        if (name.equals(Properties.LEXICAL_HANDLER_PROPERTY)) {
+            if (value instanceof LexicalHandler) {
+                setLexicalHandler((LexicalHandler)value);
+            } else {
+                throw new SAXNotSupportedException(Properties.LEXICAL_HANDLER_PROPERTY);
+            }
+        } else if (name.equals(Properties.DTD_DECLARATION_HANDLER_PROPERTY)) {
+            if (value instanceof DeclHandler) {
+                setDeclHandler((DeclHandler)value);
+            } else {
+                throw new SAXNotSupportedException(Properties.LEXICAL_HANDLER_PROPERTY);
+            }
+        } else if (name.equals(FastInfosetReader.EXTERNAL_VOCABULARIES_PROPERTY)) {
+            if (value instanceof Map) {
+                setExternalVocabularies((Map)value);
+            } else {
+                throw new SAXNotSupportedException(FastInfosetReader.EXTERNAL_VOCABULARIES_PROPERTY);
+            }
+        } else if (name.equals(FastInfosetReader.REGISTERED_ENCODING_ALGORITHMS_PROPERTY)) {
+            if (value instanceof Map) {
+                setRegisteredEncodingAlgorithms((Map)value);
+            } else {
+                throw new SAXNotSupportedException(FastInfosetReader.REGISTERED_ENCODING_ALGORITHMS_PROPERTY);
+            }
+        } else if (name.equals(FastInfosetReader.ENCODING_ALGORITHM_CONTENT_HANDLER_PROPERTY)) {
+            if (value instanceof EncodingAlgorithmContentHandler) {
+                setEncodingAlgorithmContentHandler((EncodingAlgorithmContentHandler)value);
+            } else {
+                throw new SAXNotSupportedException(FastInfosetReader.ENCODING_ALGORITHM_CONTENT_HANDLER_PROPERTY);
+            }
+        } else if (name.equals(FastInfosetReader.PRIMITIVE_TYPE_CONTENT_HANDLER_PROPERTY)) {
+            if (value instanceof PrimitiveTypeContentHandler) {
+                setPrimitiveTypeContentHandler((PrimitiveTypeContentHandler)value);
+            } else {
+                throw new SAXNotSupportedException(FastInfosetReader.PRIMITIVE_TYPE_CONTENT_HANDLER_PROPERTY);
+            }
+        } else if (name.equals(FastInfosetReader.BUFFER_SIZE_PROPERTY)) {
+            if (value instanceof Integer) {
+                setBufferSize(((Integer)value).intValue());
+            } else {
+                throw new SAXNotSupportedException(FastInfosetReader.BUFFER_SIZE_PROPERTY);
+            }
+        } else {
+            throw new SAXNotRecognizedException(CommonResourceBundle.getInstance().
+                    getString("message.propertyNotRecognized", new Object[]{name}));
+        }
+    }
+
+    public void setEntityResolver(EntityResolver resolver) {
+        _entityResolver = resolver;
+    }
+
+    public EntityResolver getEntityResolver() {
+        return _entityResolver;
+    }
+
+    public void setDTDHandler(DTDHandler handler) {
+        _dtdHandler = handler;
+    }
+
+    public DTDHandler getDTDHandler() {
+        return _dtdHandler;
+    }
+    public void setContentHandler(ContentHandler handler) {
+        _contentHandler = handler;
+    }
+
+    public ContentHandler getContentHandler() {
+        return _contentHandler;
+    }
+
+    public void setErrorHandler(ErrorHandler handler) {
+        _errorHandler = handler;
+    }
+
+    public ErrorHandler getErrorHandler() {
+        return _errorHandler;
+    }
+
+    public void parse(InputSource input) throws IOException, SAXException {
+        try {
+            InputStream s = input.getByteStream();
+            if (s == null) {
+                String systemId = input.getSystemId();
+                if (systemId == null) {
+                    throw new SAXException(CommonResourceBundle.getInstance().getString("message.inputSource"));
+                }
+                parse(systemId);
+            } else {
+                parse(s);
+            }
+        } catch (FastInfosetException e) {
+            e.printStackTrace();
+            throw new SAXException(e);
+        }
+    }
+
+    public void parse(String systemId) throws IOException, SAXException {
+        try {
+            systemId = SystemIdResolver.getAbsoluteURI(systemId);
+            parse(new URL(systemId).openStream());
+        } catch (FastInfosetException e) {
+            e.printStackTrace();
+            throw new SAXException(e);
+        }
+    }
+
+
+
+
+    // FastInfosetReader
+
+    public final void parse(InputStream s) throws IOException, FastInfosetException, SAXException {
+        setInputStream(s);
+        parse();
+    }
+
+    public void setLexicalHandler(LexicalHandler handler) {
+        _lexicalHandler = handler;
+    }
+
+    public LexicalHandler getLexicalHandler() {
+        return _lexicalHandler;
+    }
+
+    public void setDeclHandler(DeclHandler handler) {
+        _declHandler = handler;
+    }
+
+    public DeclHandler getDeclHandler() {
+        return _declHandler;
+    }
+
+    public void setEncodingAlgorithmContentHandler(EncodingAlgorithmContentHandler handler) {
+        _algorithmHandler = handler;
+    }
+
+    public EncodingAlgorithmContentHandler getEncodingAlgorithmContentHandler() {
+        return _algorithmHandler;
+    }
+
+    public void setPrimitiveTypeContentHandler(PrimitiveTypeContentHandler handler) {
+        _primitiveHandler = handler;
+    }
+
+    public PrimitiveTypeContentHandler getPrimitiveTypeContentHandler() {
+        return _primitiveHandler;
+    }
+
+
+
+
+    public final void parse() throws FastInfosetException, IOException {
+        if (_octetBuffer.length < _bufferSize) {
+            _octetBuffer = new byte[_bufferSize];
+        }
+
+        try {
+            reset();
+            decodeHeader();
+            processDII();
+        } catch (RuntimeException e) {
+            try {
+                _errorHandler.fatalError(new SAXParseException(e.getClass().getName(), null, e));
+            } catch (Exception ee) {
+            }
+            resetOnError();
+            // Wrap runtime exception
+            throw new FastInfosetException(e);
+        } catch (FastInfosetException e) {
+            try {
+                _errorHandler.fatalError(new SAXParseException(e.getClass().getName(), null, e));
+            } catch (Exception ee) {
+            }
+            resetOnError();
+            throw e;
+        } catch (IOException e) {
+            try {
+                _errorHandler.fatalError(new SAXParseException(e.getClass().getName(), null, e));
+            } catch (Exception ee) {
+            }
+            resetOnError();
+            throw e;
+        }
+    }
+
+    protected final void processDII() throws FastInfosetException, IOException {
+        try {
+            _contentHandler.startDocument();
+        } catch (SAXException e) {
+            throw new FastInfosetException("processDII", e);
+        }
+
+        _b = read();
+        if (_b > 0) {
+            processDIIOptionalProperties();
+        }
+
+        // Decode one Document Type II, Comment IIs, PI IIs and one EII
+        boolean firstElementHasOccured = false;
+        boolean documentTypeDeclarationOccured = false;
+        while(!_terminate || !firstElementHasOccured) {
+            _b = read();
+            switch(DecoderStateTables.DII[_b]) {
+                case DecoderStateTables.EII_NO_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[_b], false);
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.EII_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[_b & EncodingConstants.INTEGER_3RD_BIT_SMALL_MASK], true);
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.EII_INDEX_MEDIUM:
+                    processEII(decodeEIIIndexMedium(), (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.EII_INDEX_LARGE:
+                    processEII(decodeEIIIndexLarge(), (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.EII_LITERAL:
+                {
+                    final QualifiedName qn = decodeLiteralQualifiedName(
+                                _b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                    _elementNameTable.add(qn);
+                    processEII(qn, (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    firstElementHasOccured = true;
+                    break;
+                }
+                case DecoderStateTables.EII_NAMESPACES:
+                    processEIIWithNamespaces();
+                    firstElementHasOccured = true;
+                    break;
+                case DecoderStateTables.DOCUMENT_TYPE_DECLARATION_II:
+                {
+                    if (documentTypeDeclarationOccured) {
+                        throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.secondOccurenceOfDTDII"));
+                    }
+                    documentTypeDeclarationOccured = true;
+
+                    String system_identifier = ((_b & EncodingConstants.DOCUMENT_TYPE_SYSTEM_IDENTIFIER_FLAG) > 0)
+                    ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+                    String public_identifier = ((_b & EncodingConstants.DOCUMENT_TYPE_PUBLIC_IDENTIFIER_FLAG) > 0)
+                    ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+
+                    _b = read();
+                    while (_b == EncodingConstants.PROCESSING_INSTRUCTION) {
+                        switch(decodeNonIdentifyingStringOnFirstBit()) {
+                            case NISTRING_STRING:
+                                final String data = new String(_charBuffer, 0, _charBufferLength);
+                                if (_addToTable) {
+                                    _v.otherString.add(new CharArray(_charBuffer, 0, _charBufferLength, true));
+                                }
+                                break;
+                            case NISTRING_ENCODING_ALGORITHM:
+                                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.processingIIWithEncodingAlgorithm"));
+                            case NISTRING_INDEX:
+                                break;
+                            case NISTRING_EMPTY_STRING:
+                                break;
+                        }
+                        _b = read();
+                    }
+                    if ((_b & EncodingConstants.TERMINATOR) != EncodingConstants.TERMINATOR) {
+                        throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.processingInstructionIIsNotTerminatedCorrectly"));
+                    }
+                    if (_b == EncodingConstants.DOUBLE_TERMINATOR) {
+                        _terminate = true;
+                    }
+
+                    _notations.clear();
+                    _unparsedEntities.clear();
+                    /*
+                     * TODO
+                     * Report All events associated with DTD, PIs, notations etc
+                     */
+                    break;
+                }
+                case DecoderStateTables.COMMENT_II:
+                    processCommentII();
+                    break;
+                case DecoderStateTables.PROCESSING_INSTRUCTION_II:
+                    processProcessingII();
+                    break;
+                case DecoderStateTables.TERMINATOR_DOUBLE:
+                    _doubleTerminate = true;
+                case DecoderStateTables.TERMINATOR_SINGLE:
+                    _terminate = true;
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingDII"));
+            }
+        }
+
+        // Decode any remaining Comment IIs, PI IIs
+        while(!_terminate) {
+            _b = read();
+            switch(DecoderStateTables.DII[_b]) {
+                case DecoderStateTables.COMMENT_II:
+                    processCommentII();
+                    break;
+                case DecoderStateTables.PROCESSING_INSTRUCTION_II:
+                    processProcessingII();
+                    break;
+                case DecoderStateTables.TERMINATOR_DOUBLE:
+                    _doubleTerminate = true;
+                case DecoderStateTables.TERMINATOR_SINGLE:
+                    _terminate = true;
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingDII"));
+            }
+        }
+
+        try {
+            _contentHandler.endDocument();
+        } catch (SAXException e) {
+            throw new FastInfosetException("processDII", e);
+        }
+    }
+
+    protected final void processDIIOptionalProperties() throws FastInfosetException, IOException {
+        // Optimize for the most common case
+        if (_b == EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG) {
+            decodeInitialVocabulary();
+            return;
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_ADDITIONAL_DATA_FLAG) > 0) {
+            decodeAdditionalData();
+            /*
+             * TODO
+             * how to report the additional data?
+             */
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG) > 0) {
+            decodeInitialVocabulary();
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_NOTATIONS_FLAG) > 0) {
+            decodeNotations();
+            /*
+                try {
+                    _dtdHandler.notationDecl(name, public_identifier, system_identifier);
+                } catch (SAXException e) {
+                    throw new IOException("NotationsDeclarationII");
+                }
+             */
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_UNPARSED_ENTITIES_FLAG) > 0) {
+            decodeUnparsedEntities();
+            /*
+                try {
+                    _dtdHandler.unparsedEntityDecl(name, public_identifier, system_identifier, notation_name);
+                } catch (SAXException e) {
+                    throw new IOException("UnparsedEntitiesII");
+                }
+             */
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_CHARACTER_ENCODING_SCHEME) > 0) {
+            String characterEncodingScheme = decodeCharacterEncodingScheme();
+            /*
+             * TODO
+             * how to report the character encoding scheme?
+             */
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_STANDALONE_FLAG) > 0) {
+            boolean standalone = (read() > 0) ? true : false ;
+            /*
+             * TODO
+             * how to report the standalone flag?
+             */
+        }
+
+        if ((_b & EncodingConstants.DOCUMENT_VERSION_FLAG) > 0) {
+            String version = decodeVersion();
+            /*
+             * TODO
+             * how to report the standalone flag?
+             */
+        }
+    }
+
+    protected final void processEII(QualifiedName name, boolean hasAttributes) throws FastInfosetException, IOException {
+        if (_prefixTable._currentInScope[name.prefixIndex] != name.namespaceNameIndex) {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.qNameOfEIINotInScope"));
+        }
+
+        if (hasAttributes) {
+            processAIIs();
+        }
+
+        try {
+            _contentHandler.startElement(name.namespaceName, name.localName, name.qName, _attributes);
+        } catch (SAXException e) {
+            e.printStackTrace();
+            throw new FastInfosetException("processEII", e);
+        }
+
+        if (_clearAttributes) {
+            _attributes.clear();
+            _clearAttributes = false;
+        }
+
+        while(!_terminate) {
+            _b = read();
+            switch(DecoderStateTables.EII[_b]) {
+                case DecoderStateTables.EII_NO_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[_b], false);
+                    break;
+                case DecoderStateTables.EII_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[_b & EncodingConstants.INTEGER_3RD_BIT_SMALL_MASK], true);
+                    break;
+                case DecoderStateTables.EII_INDEX_MEDIUM:
+                    processEII(decodeEIIIndexMedium(), (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    break;
+                case DecoderStateTables.EII_INDEX_LARGE:
+                    processEII(decodeEIIIndexLarge(), (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    break;
+                case DecoderStateTables.EII_LITERAL:
+                {
+                    final QualifiedName qn = decodeLiteralQualifiedName(
+                                _b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                    _elementNameTable.add(qn);
+                    processEII(qn, (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    break;
+                }
+                case DecoderStateTables.EII_NAMESPACES:
+                    processEIIWithNamespaces();
+                    break;
+                case DecoderStateTables.CII_UTF8_SMALL_LENGTH:
+                    _octetBufferLength = (_b & EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_MASK)
+                    + 1;
+                    decodeUtf8StringAsCharBuffer();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    try {
+                        _contentHandler.characters(_charBuffer, 0, _charBufferLength);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                case DecoderStateTables.CII_UTF8_MEDIUM_LENGTH:
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT;
+                    decodeUtf8StringAsCharBuffer();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    try {
+                        _contentHandler.characters(_charBuffer, 0, _charBufferLength);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                case DecoderStateTables.CII_UTF8_LARGE_LENGTH:
+                    _octetBufferLength = ((read() << 24) |
+                            (read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT;
+                    decodeUtf8StringAsCharBuffer();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    try {
+                        _contentHandler.characters(_charBuffer, 0, _charBufferLength);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                case DecoderStateTables.CII_UTF16_SMALL_LENGTH:
+                    _octetBufferLength = (_b & EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_MASK)
+                    + 1;
+                    decodeUtf16StringAsCharBuffer();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    try {
+                        _contentHandler.characters(_charBuffer, 0, _charBufferLength);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                case DecoderStateTables.CII_UTF16_MEDIUM_LENGTH:
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT;
+                    decodeUtf16StringAsCharBuffer();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    try {
+                        _contentHandler.characters(_charBuffer, 0, _charBufferLength);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                case DecoderStateTables.CII_UTF16_LARGE_LENGTH:
+                    _octetBufferLength = ((read() << 24) |
+                            (read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT;
+                    decodeUtf16StringAsCharBuffer();
+                    if ((_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    try {
+                        _contentHandler.characters(_charBuffer, 0, _charBufferLength);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                case DecoderStateTables.CII_RA:
+                {
+                    final boolean addToTable = (_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0;
+
+                    // Decode resitricted alphabet integer
+                    _identifier = (_b & 0x02) << 6;
+                    _b = read();
+                    _identifier |= (_b & 0xFC) >> 2;
+
+                    decodeOctetsOnSeventhBitOfNonIdentifyingStringOnThirdBit(_b);
+
+                    decodeRestrictedAlphabetAsCharBuffer();
+
+                    if (addToTable) {
+                        _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                    }
+
+                    try {
+                        _contentHandler.characters(_charBuffer, 0, _charBufferLength);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                }
+                case DecoderStateTables.CII_EA:
+                {
+                    if ((_b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.addToTableNotSupported"));
+                    }
+
+                    // Decode encoding algorithm integer
+                    _identifier = (_b & 0x02) << 6;
+                    _b = read();
+                    _identifier |= (_b & 0xFC) >> 2;
+
+                    decodeOctetsOnSeventhBitOfNonIdentifyingStringOnThirdBit(_b);
+
+                    processCIIEncodingAlgorithm();
+                    break;
+                }
+                case DecoderStateTables.CII_INDEX_SMALL:
+                {
+                    final int index = _b & EncodingConstants.INTEGER_4TH_BIT_SMALL_MASK;
+                    try {
+                        _contentHandler.characters(_characterContentChunkTable._array,
+                                _characterContentChunkTable._offset[index],
+                                _characterContentChunkTable._length[index]);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                }
+                case DecoderStateTables.CII_INDEX_MEDIUM:
+                {
+                    final int index = (((_b & EncodingConstants.INTEGER_4TH_BIT_MEDIUM_MASK) << 8) | read())
+                            + EncodingConstants.INTEGER_4TH_BIT_SMALL_LIMIT;
+                    try {
+                        _contentHandler.characters(_characterContentChunkTable._array,
+                                _characterContentChunkTable._offset[index],
+                                _characterContentChunkTable._length[index]);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                }
+                case DecoderStateTables.CII_INDEX_LARGE:
+                {
+                    final int index = (((_b & EncodingConstants.INTEGER_4TH_BIT_LARGE_MASK) << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.INTEGER_4TH_BIT_MEDIUM_LIMIT;
+
+                    try {
+                        _contentHandler.characters(_characterContentChunkTable._array,
+                                _characterContentChunkTable._offset[index],
+                                _characterContentChunkTable._length[index]);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                }
+                case DecoderStateTables.CII_INDEX_LARGE_LARGE:
+                {
+                    final int index = ((read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.INTEGER_4TH_BIT_LARGE_LIMIT;
+
+                    try {
+                        _contentHandler.characters(_characterContentChunkTable._array,
+                                _characterContentChunkTable._offset[index],
+                                _characterContentChunkTable._length[index]);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processCII", e);
+                    }
+                    break;
+                }
+                case DecoderStateTables.COMMENT_II:
+                    processCommentII();
+                    break;
+                case DecoderStateTables.PROCESSING_INSTRUCTION_II:
+                    processProcessingII();
+                    break;
+                case DecoderStateTables.UNEXPANDED_ENTITY_REFERENCE_II:
+                {
+                    String entity_reference_name = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+
+                    String system_identifier = ((_b & EncodingConstants.UNEXPANDED_ENTITY_SYSTEM_IDENTIFIER_FLAG) > 0)
+                    ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+                    String public_identifier = ((_b & EncodingConstants.UNEXPANDED_ENTITY_PUBLIC_IDENTIFIER_FLAG) > 0)
+                    ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+
+                    try {
+                        /*
+                         * TODO
+                         * Need to verify if the skippedEntity method:
+                         * http://java.sun.com/j2se/1.4.2/docs/api/org/xml/sax/ContentHandler.html#skippedEntity(java.lang.String)
+                         * is the correct method to call. It appears so but a more extensive
+                         * check is necessary.
+                         */
+                        _contentHandler.skippedEntity(entity_reference_name);
+                    } catch (SAXException e) {
+                        throw new FastInfosetException("processUnexpandedEntityReferenceII", e);
+                    }
+                    break;
+                }
+                case DecoderStateTables.TERMINATOR_DOUBLE:
+                    _doubleTerminate = true;
+                case DecoderStateTables.TERMINATOR_SINGLE:
+                    _terminate = true;
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingEII"));
+            }
+        }
+
+        _terminate = _doubleTerminate;
+        _doubleTerminate = false;
+
+        try {
+            _contentHandler.endElement(name.namespaceName, name.localName, name.qName);
+        } catch (SAXException e) {
+            throw new FastInfosetException("processEII", e);
+        }
+    }
+
+    protected final void processEIIWithNamespaces() throws FastInfosetException, IOException {
+        final boolean hasAttributes = (_b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0;
+
+        _clearAttributes = (_namespacePrefixesFeature) ? true : false;
+
+        if (++_prefixTable._declarationId == Integer.MAX_VALUE) {
+            _prefixTable.clearDeclarationIds();
+        }
+
+        String prefix = "", namespaceName = "";
+        final int start = _namespacePrefixesIndex;
+        int b = read();
+        while ((b & EncodingConstants.NAMESPACE_ATTRIBUTE_MASK) == EncodingConstants.NAMESPACE_ATTRIBUTE) {
+            if (_namespacePrefixesIndex == _namespacePrefixes.length) {
+                final int[] namespaceAIIs = new int[_namespacePrefixesIndex * 3 / 2 + 1];
+                System.arraycopy(_namespacePrefixes, 0, namespaceAIIs, 0, _namespacePrefixesIndex);
+                _namespacePrefixes = namespaceAIIs;
+            }
+
+            switch (b & EncodingConstants.NAMESPACE_ATTRIBUTE_PREFIX_NAME_MASK) {
+                // no prefix, no namespace
+                // Undeclaration of default namespace
+                case 0:
+                    prefix = namespaceName = "";
+                    _namespaceNameIndex = _prefixIndex = _namespacePrefixes[_namespacePrefixesIndex++] = -1;
+                    break;
+                // no prefix, namespace
+                // Declaration of default namespace
+                case 1:
+                    prefix = "";
+                    namespaceName = decodeIdentifyingNonEmptyStringOnFirstBitAsNamespaceName(false);
+
+                    _prefixIndex = _namespacePrefixes[_namespacePrefixesIndex++] = -1;
+                    break;
+                // prefix, no namespace
+                // Undeclaration of namespace
+                case 2:
+                    prefix = decodeIdentifyingNonEmptyStringOnFirstBitAsPrefix(false);
+                    namespaceName = "";
+
+                    _namespaceNameIndex = -1;
+                    _namespacePrefixes[_namespacePrefixesIndex++] = _prefixIndex;
+                    break;
+                // prefix, namespace
+                // Declaration of prefixed namespace
+                case 3:
+                    prefix = decodeIdentifyingNonEmptyStringOnFirstBitAsPrefix(true);
+                    namespaceName = decodeIdentifyingNonEmptyStringOnFirstBitAsNamespaceName(true);
+
+                    _namespacePrefixes[_namespacePrefixesIndex++] = _prefixIndex;
+                    break;
+            }
+
+            _prefixTable.pushScope(_prefixIndex, _namespaceNameIndex);
+
+            if (_namespacePrefixesFeature) {
+                // Add the namespace delcaration as an attribute
+                if (prefix != "") {
+                    _attributes.addAttribute(new QualifiedName(
+                            EncodingConstants.XMLNS_NAMESPACE_PREFIX,
+                            EncodingConstants.XMLNS_NAMESPACE_NAME,
+                            prefix),
+                            namespaceName);
+                } else {
+                    _attributes.addAttribute(EncodingConstants.DEFAULT_NAMESPACE_DECLARATION,
+                            namespaceName);
+                }
+            }
+
+            try {
+                _contentHandler.startPrefixMapping(prefix, namespaceName);
+            } catch (SAXException e) {
+                throw new IOException("processStartNamespaceAII");
+            }
+
+            b = read();
+        }
+        if (b != EncodingConstants.TERMINATOR) {
+            throw new IOException(CommonResourceBundle.getInstance().getString("message.EIInamespaceNameNotTerminatedCorrectly"));
+        }
+        final int end = _namespacePrefixesIndex;
+
+        _b = read();
+        switch(DecoderStateTables.EII[_b]) {
+            case DecoderStateTables.EII_NO_AIIS_INDEX_SMALL:
+                processEII(_elementNameTable._array[_b], hasAttributes);
+                break;
+            case DecoderStateTables.EII_INDEX_MEDIUM:
+                processEII(decodeEIIIndexMedium(), hasAttributes);
+                break;
+            case DecoderStateTables.EII_INDEX_LARGE:
+                processEII(decodeEIIIndexLarge(), hasAttributes);
+                break;
+            case DecoderStateTables.EII_LITERAL:
+            {
+                final QualifiedName qn = decodeLiteralQualifiedName(
+                            _b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                _elementNameTable.add(qn);
+                processEII(qn, hasAttributes);
+                break;
+            }
+            default:
+                throw new IOException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingEIIAfterAIIs"));
+        }
+
+        try {
+            for (int i = end - 1; i >= start; i--) {
+                final int prefixIndex = _namespacePrefixes[i];
+                _prefixTable.popScope(prefixIndex);
+                prefix = (prefixIndex > 0) ? _prefixTable.get(prefixIndex - 1) :
+                        (prefixIndex == -1) ? "" : EncodingConstants.XML_NAMESPACE_PREFIX;
+                _contentHandler.endPrefixMapping(prefix);
+            }
+            _namespacePrefixesIndex = start;
+        } catch (SAXException e) {
+            throw new IOException("processStartNamespaceAII");
+        }
+    }
+
+    protected final void processAIIs() throws FastInfosetException, IOException {
+        QualifiedName name;
+        int b;
+        String value;
+
+        _clearAttributes = true;
+
+        if (++_duplicateAttributeVerifier._currentIteration == Integer.MAX_VALUE) {
+            _duplicateAttributeVerifier.clear();
+        }
+
+        do {
+            // AII qualified name
+            b = read();
+            switch (DecoderStateTables.AII[b]) {
+                case DecoderStateTables.AII_INDEX_SMALL:
+                    name = _attributeNameTable._array[b];
+                    break;
+                case DecoderStateTables.AII_INDEX_MEDIUM:
+                {
+                    final int i = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                            + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                    name = _attributeNameTable._array[i];
+                    break;
+                }
+                case DecoderStateTables.AII_INDEX_LARGE:
+                {
+                    final int i = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                            + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                    name = _attributeNameTable._array[i];
+                    break;
+                }
+                case DecoderStateTables.AII_LITERAL:
+                    name = decodeLiteralQualifiedName(
+                            b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                    name.createAttributeValues(_duplicateAttributeVerifier.MAP_SIZE);
+                    _attributeNameTable.add(name);
+                    break;
+                case DecoderStateTables.AII_TERMINATOR_DOUBLE:
+                    _doubleTerminate = true;
+                case DecoderStateTables.AII_TERMINATOR_SINGLE:
+                    _terminate = true;
+                    // AIIs have finished break out of loop
+                    continue;
+                default:
+                    throw new IOException(CommonResourceBundle.getInstance().getString("message.decodingAIIs"));
+            }
+
+            if (name.prefixIndex > 0 && _prefixTable._currentInScope[name.prefixIndex] != name.namespaceNameIndex) {
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.AIIqNameNotInScope"));
+            }
+
+            _duplicateAttributeVerifier.checkForDuplicateAttribute(name.attributeHash, name.attributeId);
+
+            // [normalized value] of AII
+
+            b = read();
+            switch(DecoderStateTables.NISTRING[b]) {
+                case DecoderStateTables.NISTRING_UTF8_SMALL_LENGTH:
+                    _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK) + 1;
+                    value = decodeUtf8StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF8_MEDIUM_LENGTH:
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                    value = decodeUtf8StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF8_LARGE_LENGTH:
+                    _octetBufferLength = ((read() << 24) |
+                            (read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                    value = decodeUtf8StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF16_SMALL_LENGTH:
+                    _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK) + 1;
+                    value = decodeUtf16StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF16_MEDIUM_LENGTH:
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                    value = decodeUtf16StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF16_LARGE_LENGTH:
+                    _octetBufferLength = ((read() << 24) |
+                            (read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                    value = decodeUtf16StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_RA:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    // Decode resitricted alphabet integer
+                    _identifier = (b & 0x0F) << 4;
+                    b = read();
+                    _identifier |= (b & 0xF0) >> 4;
+
+                    decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(b);
+
+                    value = decodeRestrictedAlphabetAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_EA:
+                {
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.addToTableNotSupported"));
+                    }
+
+                    _identifier = (b & 0x0F) << 4;
+                    b = read();
+                    _identifier |= (b & 0xF0) >> 4;
+
+                    decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(b);
+
+                    processAIIEncodingAlgorithm(name);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_INDEX_SMALL:
+                    _attributes.addAttribute(name,
+                            _attributeValueTable._array[b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK]);
+                    break;
+                case DecoderStateTables.NISTRING_INDEX_MEDIUM:
+                {
+                    final int index = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+
+                    _attributes.addAttribute(name,
+                            _attributeValueTable._array[index]);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_INDEX_LARGE:
+                {
+                    final int index = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+
+                    _attributes.addAttribute(name,
+                            _attributeValueTable._array[index]);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_EMPTY:
+                    _attributes.addAttribute(name, "");
+                    break;
+                default:
+                    throw new IOException(CommonResourceBundle.getInstance().getString("message.decodingAIIValue"));
+            }
+
+        } while (!_terminate);
+
+        // Reset duplication attribute verfifier
+        _duplicateAttributeVerifier._poolCurrent = _duplicateAttributeVerifier._poolHead;
+
+        _terminate = _doubleTerminate;
+        _doubleTerminate = false;
+    }
+
+    protected final void processCommentII() throws FastInfosetException, IOException {
+        switch(decodeNonIdentifyingStringOnFirstBit()) {
+            case NISTRING_STRING:
+                if (_addToTable) {
+                    _v.otherString.add(new CharArray(_charBuffer, 0, _charBufferLength, true));
+                }
+
+                try {
+                    _lexicalHandler.comment(_charBuffer, 0, _charBufferLength);
+                } catch (SAXException e) {
+                    throw new FastInfosetException("processCommentII", e);
+                }
+                break;
+            case NISTRING_ENCODING_ALGORITHM:
+                throw new IOException(CommonResourceBundle.getInstance().getString("message.commentIIAlgorithmNotSupported"));
+            case NISTRING_INDEX:
+                final CharArray ca = _v.otherString.get(_integer);
+
+                try {
+                    _lexicalHandler.comment(ca.ch, ca.start, ca.length);
+                } catch (SAXException e) {
+                    throw new FastInfosetException("processCommentII", e);
+                }
+                break;
+            case NISTRING_EMPTY_STRING:
+                try {
+                    _lexicalHandler.comment(_charBuffer, 0, 0);
+                } catch (SAXException e) {
+                    throw new FastInfosetException("processCommentII", e);
+                }
+                break;
+        }
+    }
+
+    protected final void processProcessingII() throws FastInfosetException, IOException {
+        final String target = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+
+        switch(decodeNonIdentifyingStringOnFirstBit()) {
+            case NISTRING_STRING:
+                final String data = new String(_charBuffer, 0, _charBufferLength);
+                if (_addToTable) {
+                    _v.otherString.add(new CharArrayString(data));
+                }
+                try {
+                    _contentHandler.processingInstruction(target, data);
+                } catch (SAXException e) {
+                    throw new FastInfosetException("processProcessingII", e);
+                }
+                break;
+            case NISTRING_ENCODING_ALGORITHM:
+                throw new IOException(CommonResourceBundle.getInstance().getString("message.processingIIWithEncodingAlgorithm"));
+            case NISTRING_INDEX:
+                try {
+                    _contentHandler.processingInstruction(target, _v.otherString.get(_integer).toString());
+                } catch (SAXException e) {
+                    throw new FastInfosetException("processProcessingII", e);
+                }
+                break;
+            case NISTRING_EMPTY_STRING:
+                try {
+                    _contentHandler.processingInstruction(target, "");
+                } catch (SAXException e) {
+                    throw new FastInfosetException("processProcessingII", e);
+                }
+                break;
+        }
+    }
+
+    protected final void processCIIEncodingAlgorithm() throws FastInfosetException, IOException {
+        if (_identifier < EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            if (_primitiveHandler != null) {
+                processCIIBuiltInEncodingAlgorithmAsPrimitive();
+            } else if (_algorithmHandler != null) {
+                Object array = processBuiltInEncodingAlgorithmAsObject();
+
+                try {
+                    _algorithmHandler.object(null, _identifier, array);
+                } catch (SAXException e) {
+                    throw new FastInfosetException(e);
+                }
+            } else {
+                StringBuffer buffer = new StringBuffer();
+                processBuiltInEncodingAlgorithmAsCharacters(buffer);
+
+                try {
+                    _contentHandler.characters(buffer.toString().toCharArray(), 0, buffer.length());
+                } catch (SAXException e) {
+                    throw new FastInfosetException(e);
+                }
+            }
+        } else if (_identifier == EncodingAlgorithmIndexes.CDATA) {
+                // Set back buffer position to start of encoded string
+                _octetBufferOffset -= _octetBufferLength;
+                decodeUtf8StringIntoCharBuffer();
+
+                try {
+                    _lexicalHandler.startCDATA();
+                    _contentHandler.characters(_charBuffer, 0, _charBufferLength);
+                    _lexicalHandler.endCDATA();
+                } catch (SAXException e) {
+                    throw new FastInfosetException(e);
+                }
+        } else if (_identifier >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START && _algorithmHandler != null) {
+            final String URI = _v.encodingAlgorithm.get(_identifier - EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START);
+            if (URI == null) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().
+                        getString("message.URINotPresent", new Object[]{new Integer(_identifier)}));
+            }
+
+            final EncodingAlgorithm ea = (EncodingAlgorithm)_registeredEncodingAlgorithms.get(URI);
+            if (ea != null) {
+                final Object data = ea.decodeFromBytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+                try {
+                    _algorithmHandler.object(URI, _identifier, data);
+                } catch (SAXException e) {
+                    throw new FastInfosetException(e);
+                }
+            } else {
+                try {
+                    _algorithmHandler.octets(URI, _identifier, _octetBuffer, _octetBufferStart, _octetBufferLength);
+                } catch (SAXException e) {
+                    throw new FastInfosetException(e);
+                }
+            }
+        } else if (_identifier >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            // TODO should have property to ignore
+            throw new EncodingAlgorithmException(
+                    CommonResourceBundle.getInstance().getString("message.algorithmDataCannotBeReported"));
+        } else {
+            // Reserved built-in algorithms for future use
+            // TODO should use sax property to decide if event will be
+            // reported, allows for support through handler if required.
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.identifiers10to31Reserved"));
+        }
+    }
+
+    protected final void processCIIBuiltInEncodingAlgorithmAsPrimitive() throws FastInfosetException, IOException {
+        try {
+            int length;
+            switch(_identifier) {
+                case EncodingAlgorithmIndexes.HEXADECIMAL:
+                    _primitiveHandler.bytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+                    break;
+                case EncodingAlgorithmIndexes.BASE64:
+                    _primitiveHandler.bytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+                    break;
+                case EncodingAlgorithmIndexes.SHORT:
+                    length = BuiltInEncodingAlgorithmFactory.shortEncodingAlgorithm.
+                            getPrimtiveLengthFromOctetLength(_octetBufferLength);
+                    if (length > builtInAlgorithmState.shortArray.length) {
+                        final short[] array = new short[length * 3 / 2 + 1];
+                        System.arraycopy(builtInAlgorithmState.shortArray, 0,
+                                array, 0, builtInAlgorithmState.shortArray.length);
+                        builtInAlgorithmState.shortArray = array;
+                    }
+
+                    BuiltInEncodingAlgorithmFactory.shortEncodingAlgorithm.
+                            decodeFromBytesToShortArray(builtInAlgorithmState.shortArray, 0,
+                            _octetBuffer, _octetBufferStart, _octetBufferLength);
+                    _primitiveHandler.shorts(builtInAlgorithmState.shortArray, 0, length);
+                    break;
+                case EncodingAlgorithmIndexes.INT:
+                    length = BuiltInEncodingAlgorithmFactory.intEncodingAlgorithm.
+                            getPrimtiveLengthFromOctetLength(_octetBufferLength);
+                    if (length > builtInAlgorithmState.intArray.length) {
+                        final int[] array = new int[length * 3 / 2 + 1];
+                        System.arraycopy(builtInAlgorithmState.intArray, 0,
+                                array, 0, builtInAlgorithmState.intArray.length);
+                        builtInAlgorithmState.intArray = array;
+                    }
+
+                    BuiltInEncodingAlgorithmFactory.intEncodingAlgorithm.
+                            decodeFromBytesToIntArray(builtInAlgorithmState.intArray, 0,
+                            _octetBuffer, _octetBufferStart, _octetBufferLength);
+                    _primitiveHandler.ints(builtInAlgorithmState.intArray, 0, length);
+                    break;
+                case EncodingAlgorithmIndexes.LONG:
+                    length = BuiltInEncodingAlgorithmFactory.longEncodingAlgorithm.
+                            getPrimtiveLengthFromOctetLength(_octetBufferLength);
+                    if (length > builtInAlgorithmState.longArray.length) {
+                        final long[] array = new long[length * 3 / 2 + 1];
+                        System.arraycopy(builtInAlgorithmState.longArray, 0,
+                                array, 0, builtInAlgorithmState.longArray.length);
+                        builtInAlgorithmState.longArray = array;
+                    }
+
+                    BuiltInEncodingAlgorithmFactory.longEncodingAlgorithm.
+                            decodeFromBytesToLongArray(builtInAlgorithmState.longArray, 0,
+                            _octetBuffer, _octetBufferStart, _octetBufferLength);
+                    _primitiveHandler.longs(builtInAlgorithmState.longArray, 0, length);
+                    break;
+                case EncodingAlgorithmIndexes.BOOLEAN:
+                    length = BuiltInEncodingAlgorithmFactory.booleanEncodingAlgorithm.
+                            getPrimtiveLengthFromOctetLength(_octetBufferLength, _octetBuffer[_octetBufferStart] & 0xFF);
+                    if (length > builtInAlgorithmState.booleanArray.length) {
+                        final boolean[] array = new boolean[length * 3 / 2 + 1];
+                        System.arraycopy(builtInAlgorithmState.booleanArray, 0,
+                                array, 0, builtInAlgorithmState.booleanArray.length);
+                        builtInAlgorithmState.booleanArray = array;
+                    }
+
+                    BuiltInEncodingAlgorithmFactory.booleanEncodingAlgorithm.
+                            decodeFromBytesToBooleanArray(
+                            builtInAlgorithmState.booleanArray, 0, length,
+                            _octetBuffer, _octetBufferStart, _octetBufferLength);
+                    _primitiveHandler.booleans(builtInAlgorithmState.booleanArray, 0, length);
+                    break;
+                case EncodingAlgorithmIndexes.FLOAT:
+                    length = BuiltInEncodingAlgorithmFactory.floatEncodingAlgorithm.
+                            getPrimtiveLengthFromOctetLength(_octetBufferLength);
+                    if (length > builtInAlgorithmState.floatArray.length) {
+                        final float[] array = new float[length * 3 / 2 + 1];
+                        System.arraycopy(builtInAlgorithmState.floatArray, 0,
+                                array, 0, builtInAlgorithmState.floatArray.length);
+                        builtInAlgorithmState.floatArray = array;
+                    }
+
+                    BuiltInEncodingAlgorithmFactory.floatEncodingAlgorithm.
+                            decodeFromBytesToFloatArray(builtInAlgorithmState.floatArray, 0,
+                            _octetBuffer, _octetBufferStart, _octetBufferLength);
+                    _primitiveHandler.floats(builtInAlgorithmState.floatArray, 0, length);
+                    break;
+                case EncodingAlgorithmIndexes.DOUBLE:
+                    length = BuiltInEncodingAlgorithmFactory.doubleEncodingAlgorithm.
+                            getPrimtiveLengthFromOctetLength(_octetBufferLength);
+                    if (length > builtInAlgorithmState.doubleArray.length) {
+                        final double[] array = new double[length * 3 / 2 + 1];
+                        System.arraycopy(builtInAlgorithmState.doubleArray, 0,
+                                array, 0, builtInAlgorithmState.doubleArray.length);
+                        builtInAlgorithmState.doubleArray = array;
+                    }
+
+                    BuiltInEncodingAlgorithmFactory.doubleEncodingAlgorithm.
+                            decodeFromBytesToDoubleArray(builtInAlgorithmState.doubleArray, 0,
+                            _octetBuffer, _octetBufferStart, _octetBufferLength);
+                    _primitiveHandler.doubles(builtInAlgorithmState.doubleArray, 0, length);
+                    break;
+                case EncodingAlgorithmIndexes.UUID:
+                    length = BuiltInEncodingAlgorithmFactory.uuidEncodingAlgorithm.
+                            getPrimtiveLengthFromOctetLength(_octetBufferLength);
+                    if (length > builtInAlgorithmState.longArray.length) {
+                        final long[] array = new long[length * 3 / 2 + 1];
+                        System.arraycopy(builtInAlgorithmState.longArray, 0,
+                                array, 0, builtInAlgorithmState.longArray.length);
+                        builtInAlgorithmState.longArray = array;
+                    }
+
+                    BuiltInEncodingAlgorithmFactory.uuidEncodingAlgorithm.
+                            decodeFromBytesToLongArray(builtInAlgorithmState.longArray, 0,
+                            _octetBuffer, _octetBufferStart, _octetBufferLength);
+                    _primitiveHandler.uuids(builtInAlgorithmState.longArray, 0, length);
+                    break;
+                case EncodingAlgorithmIndexes.CDATA:
+                    throw new UnsupportedOperationException("CDATA");
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().
+                            getString("message.unsupportedAlgorithm", new Object[]{new Integer(_identifier)}));
+            }
+        } catch (SAXException e) {
+            throw new FastInfosetException(e);
+        }
+    }
+
+
+    protected final void processAIIEncodingAlgorithm(QualifiedName name) throws FastInfosetException, IOException {
+        if (_identifier < EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            if (_primitiveHandler != null || _algorithmHandler != null) {
+                Object data = processBuiltInEncodingAlgorithmAsObject();
+                _attributes.addAttributeWithAlgorithmData(name, null, _identifier, data);
+            } else {
+                StringBuffer buffer = new StringBuffer();
+                processBuiltInEncodingAlgorithmAsCharacters(buffer);
+                _attributes.addAttribute(name, buffer.toString());
+            }
+        } else if (_identifier >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START && _algorithmHandler != null) {
+            final String URI = _v.encodingAlgorithm.get(_identifier - EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START);
+            if (URI == null) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().
+                        getString("message.URINotPresent", new Object[]{new Integer(_identifier)}));
+            }
+
+            final EncodingAlgorithm ea = (EncodingAlgorithm)_registeredEncodingAlgorithms.get(URI);
+            if (ea != null) {
+                final Object data = ea.decodeFromBytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+                _attributes.addAttributeWithAlgorithmData(name, URI, _identifier, data);
+            } else {
+                final byte[] data = new byte[_octetBufferLength];
+                System.arraycopy(_octetBuffer, _octetBufferStart, data, 0, _octetBufferLength);
+                _attributes.addAttributeWithAlgorithmData(name, URI, _identifier, data);
+            }
+        } else if (_identifier >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            // TODO should have property to ignore
+            throw new EncodingAlgorithmException(
+                    CommonResourceBundle.getInstance().getString("message.algorithmDataCannotBeReported"));
+        } else if (_identifier == EncodingAlgorithmIndexes.CDATA) {
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.CDATAAlgorithmNotSupported"));
+        } else {
+            // Reserved built-in algorithms for future use
+            // TODO should use sax property to decide if event will be
+            // reported, allows for support through handler if required.
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.identifiers10to31Reserved"));
+        }
+    }
+
+    protected final void processBuiltInEncodingAlgorithmAsCharacters(StringBuffer buffer) throws FastInfosetException, IOException {
+        // TODO not very efficient, need to reuse buffers
+        Object array = BuiltInEncodingAlgorithmFactory.table[_identifier].
+                decodeFromBytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+
+        BuiltInEncodingAlgorithmFactory.table[_identifier].convertToCharacters(array,  buffer);
+    }
+
+    protected final Object processBuiltInEncodingAlgorithmAsObject() throws FastInfosetException, IOException {
+        return BuiltInEncodingAlgorithmFactory.table[_identifier].
+                decodeFromBytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SAXDocumentSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SAXDocumentSerializer.java
new file mode 100644
index 0000000..effce51
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SAXDocumentSerializer.java
@@ -0,0 +1,563 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.sax;
+
+import com.sun.xml.internal.fastinfoset.Encoder;
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.org.jvnet.fastinfoset.sax.FastInfosetWriter;
+import com.sun.xml.internal.fastinfoset.util.LocalNameQualifiedNamesMap;
+import java.io.IOException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.RestrictedAlphabet;
+import com.sun.xml.internal.org.jvnet.fastinfoset.sax.EncodingAlgorithmAttributes;
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+/**
+ * The Fast Infoset SAX serializer.
+ * <p>
+ * Instantiate this serializer to serialize a fast infoset document in accordance
+ * with the SAX API.
+ * <p>
+ * This utilizes the SAX API in a reverse manner to that of parsing. It is the
+ * responsibility of the client to call the appropriate event methods on the
+ * SAX handlers, and to ensure that such a sequence of methods calls results
+ * in the production well-formed fast infoset documents. The
+ * SAXDocumentSerializer performs no well-formed checks.
+ *
+ * <p>
+ * More than one fast infoset document may be encoded to the
+ * {@link java.io.OutputStream}.
+ */
+public class SAXDocumentSerializer extends Encoder implements FastInfosetWriter {
+    protected boolean _elementHasNamespaces = false;
+
+    protected boolean _charactersAsCDATA = false;
+
+    public SAXDocumentSerializer() {
+    }
+
+
+    public void reset() {
+        super.reset();
+
+        _elementHasNamespaces = false;
+        _charactersAsCDATA = false;
+    }
+
+    // ContentHandler
+
+    public final void startDocument() throws SAXException {
+        try {
+            reset();
+            encodeHeader(false);
+            encodeInitialVocabulary();
+        } catch (IOException e) {
+            throw new SAXException("startDocument", e);
+        }
+    }
+
+    public final void endDocument() throws SAXException {
+        try {
+            encodeDocumentTermination();
+        } catch (IOException e) {
+            throw new SAXException("endDocument", e);
+        }
+    }
+
+    public final void startPrefixMapping(String prefix, String uri) throws SAXException {
+        try {
+            if (_elementHasNamespaces == false) {
+                encodeTermination();
+
+                // Mark the current buffer position to flag attributes if necessary
+                mark();
+                _elementHasNamespaces = true;
+
+                // Write out Element byte with namespaces
+                write(EncodingConstants.ELEMENT | EncodingConstants.ELEMENT_NAMESPACES_FLAG);
+            }
+
+            encodeNamespaceAttribute(prefix, uri);
+        } catch (IOException e) {
+            throw new SAXException("startElement", e);
+        }
+    }
+
+    public final void startElement(String namespaceURI, String localName, String qName, Attributes atts) throws SAXException {
+        // TODO consider using buffer for encoding of attributes, then pre-counting is not necessary
+        final int attributeCount = (atts != null && atts.getLength() > 0)
+                ? countAttributes(atts) : 0;
+        try {
+            if (_elementHasNamespaces) {
+                _elementHasNamespaces = false;
+
+                if (attributeCount > 0) {
+                    // Flag the marked byte with attributes
+                    _octetBuffer[_markIndex] |= EncodingConstants.ELEMENT_ATTRIBUTE_FLAG;
+                }
+                resetMark();
+
+                write(EncodingConstants.TERMINATOR);
+
+                _b = 0;
+            } else {
+                encodeTermination();
+
+                _b = EncodingConstants.ELEMENT;
+                if (attributeCount > 0) {
+                    _b |= EncodingConstants.ELEMENT_ATTRIBUTE_FLAG;
+                }
+            }
+
+            encodeElement(namespaceURI, qName, localName);
+
+            if (attributeCount > 0) {
+                boolean addToTable;
+                String value;
+                if (atts instanceof EncodingAlgorithmAttributes) {
+                    final EncodingAlgorithmAttributes eAtts = (EncodingAlgorithmAttributes)atts;
+                    for (int i = 0; i < eAtts.getLength(); i++) {
+                        if (encodeAttribute(atts.getURI(i), atts.getQName(i), atts.getLocalName(i))) {
+                            final Object data = eAtts.getAlgorithmData(i);
+                            // If data is null then there is no algorithm data
+                            if (data == null) {
+                                value = eAtts.getValue(i);
+                                addToTable = (value.length() < attributeValueSizeConstraint) ? true : false;
+                                encodeNonIdentifyingStringOnFirstBit(value, _v.attributeValue, addToTable);
+                            } else {
+                                encodeNonIdentifyingStringOnFirstBit(eAtts.getAlgorithmURI(i),
+                                        eAtts.getAlgorithmIndex(i), data);
+                            }
+                        }
+                    }
+                } else {
+                    for (int i = 0; i < atts.getLength(); i++) {
+                        if (encodeAttribute(atts.getURI(i), atts.getQName(i), atts.getLocalName(i))) {
+                            value = atts.getValue(i);
+                            addToTable = (value.length() < attributeValueSizeConstraint) ? true : false;
+                            encodeNonIdentifyingStringOnFirstBit(value, _v.attributeValue, addToTable);
+                        }
+                    }
+                }
+                _b = EncodingConstants.TERMINATOR;
+                _terminate = true;
+            }
+        } catch (IOException e) {
+            throw new SAXException("startElement", e);
+        } catch (FastInfosetException e) {
+            throw new SAXException("startElement", e);
+        }
+    }
+
+    public final int countAttributes(Attributes atts) {
+        // Count attributes ignoring any in the XMLNS namespace
+        // Note, such attributes may be produced when transforming from a DOM node
+        int count = 0;
+        for (int i = 0; i < atts.getLength(); i++) {
+            final String uri = atts.getURI(i);
+            if (uri == "http://www.w3.org/2000/xmlns/" || uri.equals("http://www.w3.org/2000/xmlns/")) {
+                continue;
+            }
+            count++;
+        }
+        return count;
+    }
+
+    public final void endElement(String namespaceURI, String localName, String qName) throws SAXException {
+        try {
+            encodeElementTermination();
+        } catch (IOException e) {
+            throw new SAXException("startElement", e);
+        }
+    }
+
+    public final void characters(char[] ch, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        if (getIgnoreWhiteSpaceTextContent() &&
+                isWhiteSpace(ch, start, length)) return;
+
+        try {
+            encodeTermination();
+
+            if (!_charactersAsCDATA) {
+                encodeCharacters(ch, start, length);
+            } else {
+                encodeCIIBuiltInAlgorithmDataAsCDATA(ch, start, length);
+            }
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public final void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
+        if (getIgnoreWhiteSpaceTextContent()) return;
+
+        characters(ch, start, length);
+    }
+
+    public final void processingInstruction(String target, String data) throws SAXException {
+        try {
+            if (getIgnoreProcesingInstructions()) return;
+
+            if (target == "") {
+                throw new SAXException(CommonResourceBundle.getInstance().
+                        getString("message.processingInstructionTargetIsEmpty"));
+            }
+            encodeTermination();
+
+            encodeProcessingInstruction(target, data);
+        } catch (IOException e) {
+            throw new SAXException("processingInstruction", e);
+        }
+    }
+
+    public final void setDocumentLocator(org.xml.sax.Locator locator) {
+    }
+
+    public final void skippedEntity(String name) throws SAXException {
+    }
+
+
+
+    // LexicalHandler
+
+    public final void comment(char[] ch, int start, int length) throws SAXException {
+        try {
+            if (getIgnoreComments()) return;
+
+            encodeTermination();
+
+            encodeComment(ch, start, length);
+        } catch (IOException e) {
+            throw new SAXException("startElement", e);
+        }
+    }
+
+    public final void startCDATA() throws SAXException {
+        _charactersAsCDATA = true;
+    }
+
+    public final void endCDATA() throws SAXException {
+        _charactersAsCDATA = false;
+    }
+
+    public final void startDTD(String name, String publicId, String systemId) throws SAXException {
+    }
+
+    public final void endDTD() throws SAXException {
+    }
+
+    public final void startEntity(String name) throws SAXException {
+    }
+
+    public final void endEntity(String name) throws SAXException {
+    }
+
+
+    // EncodingAlgorithmContentHandler
+
+    public final void octets(String URI, int id, byte[] b, int start, int length)  throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeNonIdentifyingStringOnThirdBit(URI, id, b, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public final void object(String URI, int id, Object data)  throws SAXException {
+        try {
+            encodeTermination();
+
+            encodeNonIdentifyingStringOnThirdBit(URI, id, data);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    // PrimitiveTypeContentHandler
+
+    public final void bytes(byte[] b, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeCIIOctetAlgorithmData(EncodingAlgorithmIndexes.BASE64, b, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public final void shorts(short[] s, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeCIIBuiltInAlgorithmData(EncodingAlgorithmIndexes.SHORT, s, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public final void ints(int[] i, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeCIIBuiltInAlgorithmData(EncodingAlgorithmIndexes.INT, i, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public final void longs(long[] l, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeCIIBuiltInAlgorithmData(EncodingAlgorithmIndexes.LONG, l, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public final void booleans(boolean[] b, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeCIIBuiltInAlgorithmData(EncodingAlgorithmIndexes.BOOLEAN, b, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public final void floats(float[] f, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeCIIBuiltInAlgorithmData(EncodingAlgorithmIndexes.FLOAT, f, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public final void doubles(double[] d, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeCIIBuiltInAlgorithmData(EncodingAlgorithmIndexes.DOUBLE, d, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void uuids(long[] msblsb, int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeCIIBuiltInAlgorithmData(EncodingAlgorithmIndexes.UUID, msblsb, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    // RestrictedAlphabetContentHandler
+
+    public void numericCharacters(char ch[], int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeFourBitCharacters(RestrictedAlphabet.NUMERIC_CHARACTERS_INDEX, EncodingConstants.NUMERIC_CHARACTERS_TABLE, ch, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void dateTimeCharacters(char ch[], int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeFourBitCharacters(RestrictedAlphabet.DATE_TIME_CHARACTERS_INDEX, EncodingConstants.DATE_TIME_CHARACTERS_TABLE, ch, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void alphabetCharacters(String alphabet, char ch[], int start, int length) throws SAXException {
+        if (length <= 0) {
+            return;
+        }
+
+        try {
+            encodeTermination();
+
+            encodeAlphabetCharacters(alphabet, ch, start, length);
+        } catch (IOException e) {
+            throw new SAXException(e);
+        } catch (FastInfosetException e) {
+            throw new SAXException(e);
+        }
+    }
+
+
+
+    protected final void encodeElement(String namespaceURI, String qName, String localName) throws IOException {
+        LocalNameQualifiedNamesMap.Entry entry = _v.elementName.obtainEntry(qName);
+        if (entry._valueIndex > 0) {
+            QualifiedName[] names = entry._value;
+            for (int i = 0; i < entry._valueIndex; i++) {
+                if ((namespaceURI == names[i].namespaceName || namespaceURI.equals(names[i].namespaceName))) {
+                    encodeNonZeroIntegerOnThirdBit(names[i].index);
+                    return;
+                }
+            }
+        }
+
+        encodeLiteralElementQualifiedNameOnThirdBit(namespaceURI, getPrefixFromQualifiedName(qName),
+                localName, entry);
+    }
+
+    protected final boolean encodeAttribute(String namespaceURI, String qName, String localName) throws IOException {
+        LocalNameQualifiedNamesMap.Entry entry = _v.attributeName.obtainEntry(qName);
+        if (entry._valueIndex > 0) {
+            QualifiedName[] names = entry._value;
+            for (int i = 0; i < entry._valueIndex; i++) {
+                if ((namespaceURI == names[i].namespaceName || namespaceURI.equals(names[i].namespaceName))) {
+                    encodeNonZeroIntegerOnSecondBitFirstBitZero(names[i].index);
+                    return true;
+                }
+            }
+        }
+
+        return encodeLiteralAttributeQualifiedNameOnSecondBit(namespaceURI, getPrefixFromQualifiedName(qName),
+                localName, entry);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SystemIdResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SystemIdResolver.java
new file mode 100644
index 0000000..d242d94
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/sax/SystemIdResolver.java
@@ -0,0 +1,202 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.sax;
+
+import java.io.*;
+
+public class SystemIdResolver {
+
+    public SystemIdResolver() {
+    }
+
+    public static String getAbsoluteURIFromRelative(String localPath) {
+        if (localPath == null || localPath.length() == 0) {
+            return "";
+        }
+
+        String absolutePath = localPath;
+        if (!isAbsolutePath(localPath)) {
+            try {
+                absolutePath = getAbsolutePathFromRelativePath(localPath);
+            }
+            catch (SecurityException se) {
+                return "file:" + localPath;
+            }
+        }
+
+        String urlString;
+        if (null != absolutePath) {
+            urlString = absolutePath.startsWith(File.separator) ?
+                ("file://" + absolutePath) :
+                ("file:///" + absolutePath);
+        }
+        else {
+            urlString = "file:" + localPath;
+        }
+
+        return replaceChars(urlString);
+    }
+
+    private static String getAbsolutePathFromRelativePath(String relativePath) {
+        return new File(relativePath).getAbsolutePath();
+    }
+
+    public static boolean isAbsoluteURI(String systemId) {
+        if (systemId == null) {
+            return false;
+        }
+
+        if (isWindowsAbsolutePath(systemId)) {
+            return false;
+        }
+
+        final int fragmentIndex = systemId.indexOf('#');
+        final int queryIndex = systemId.indexOf('?');
+        final int slashIndex = systemId.indexOf('/');
+        final int colonIndex = systemId.indexOf(':');
+
+        int index = systemId.length() -1;
+        if (fragmentIndex > 0) {
+            index = fragmentIndex;
+        }
+        if (queryIndex > 0 && queryIndex < index) {
+            index = queryIndex;
+        }
+        if (slashIndex > 0 && slashIndex <index) {
+            index = slashIndex;
+        }
+        return (colonIndex > 0) && (colonIndex < index);
+    }
+
+    public static boolean isAbsolutePath(String systemId) {
+        if(systemId == null)
+            return false;
+        final File file = new File(systemId);
+        return file.isAbsolute();
+
+    }
+
+    private static boolean isWindowsAbsolutePath(String systemId) {
+        if(!isAbsolutePath(systemId))
+            return false;
+        if (systemId.length() > 2
+        && systemId.charAt(1) == ':'
+        && Character.isLetter(systemId.charAt(0))
+        && (systemId.charAt(2) == '\\' || systemId.charAt(2) == '/'))
+            return true;
+        else
+            return false;
+    }
+
+    private static String replaceChars(String str) {
+        StringBuffer buf = new StringBuffer(str);
+        int length = buf.length();
+        for (int i = 0; i < length; i++) {
+            char currentChar = buf.charAt(i);
+            // Replace space with "%20"
+            if (currentChar == ' ') {
+                buf.setCharAt(i, '%');
+                buf.insert(i+1, "20");
+                length = length + 2;
+                i = i + 2;
+            }
+            // Replace backslash with forward slash
+            else if (currentChar == '\\') {
+                buf.setCharAt(i, '/');
+            }
+        }
+
+        return buf.toString();
+    }
+
+    public static String getAbsoluteURI(String systemId) {
+        String absoluteURI = systemId;
+        if (isAbsoluteURI(systemId)) {
+            if (systemId.startsWith("file:")) {
+                String str = systemId.substring(5);
+
+                if (str != null && str.startsWith("/")) {
+                    if (str.startsWith("///") || !str.startsWith("//")) {
+                        int secondColonIndex = systemId.indexOf(':', 5);
+                        if (secondColonIndex > 0) {
+                            String localPath = systemId.substring(secondColonIndex-1);
+                            try {
+                                if (!isAbsolutePath(localPath))
+                                    absoluteURI = systemId.substring(0, secondColonIndex-1) +
+                                    getAbsolutePathFromRelativePath(localPath);
+                            }
+                            catch (SecurityException se) {
+                                return systemId;
+                            }
+                        }
+                    }
+                }
+                else {
+                    return getAbsoluteURIFromRelative(systemId.substring(5));
+                }
+
+                return replaceChars(absoluteURI);
+            }
+            else  {
+                return systemId;
+            }
+        }
+        else {
+            return getAbsoluteURIFromRelative(systemId);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/EventLocation.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/EventLocation.java
new file mode 100644
index 0000000..3731c41
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/EventLocation.java
@@ -0,0 +1,151 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax;
+
+import javax.xml.stream.Location;
+
+
+public class EventLocation implements Location{
+    String _systemId = null;
+    String _publicId = null;
+    int _column = -1;
+    int _line = -1;
+    int _charOffset = -1;
+
+    EventLocation() {
+    }
+
+    //explicitly create a nil location
+    public static Location getNilLocation() {
+        return new EventLocation();
+    }
+    /**
+    * Return the line number where the current event ends,
+    * returns -1 if none is available.
+    * @return the current line number
+    */
+    public int getLineNumber(){
+        return _line;
+    }
+    /**
+    * Return the column number where the current event ends,
+    * returns -1 if none is available.
+    * @return the current column number
+    */
+    public int getColumnNumber() {
+        return _column;
+    }
+
+  /**
+   * Return the byte or character offset into the input source this location
+   * is pointing to. If the input source is a file or a byte stream then
+   * this is the byte offset into that stream, but if the input source is
+   * a character media then the offset is the character offset.
+   * Returns -1 if there is no offset available.
+   * @return the current offset
+   */
+    public int getCharacterOffset(){
+        return _charOffset;
+    }
+
+    /**
+    * Returns the public ID of the XML
+    * @return the public ID, or null if not available
+    */
+    public String getPublicId(){
+        return _publicId;
+    }
+
+  /**
+   * Returns the system ID of the XML
+   * @return the system ID, or null if not available
+   */
+    public String getSystemId(){
+        return _systemId;
+    }
+
+    public void setLineNumber(int line) {
+        _line = line;
+    }
+    public void setColumnNumber(int col) {
+        _column = col;
+    }
+    public void setCharacterOffset(int offset) {
+        _charOffset = offset;
+    }
+    public void setPublicId(String id) {
+        _publicId = id;
+    }
+    public void setSystemId(String id) {
+        _systemId = id;
+    }
+
+    public String toString(){
+        StringBuffer sbuffer = new StringBuffer() ;
+        sbuffer.append("Line number = " + _line);
+        sbuffer.append("\n") ;
+        sbuffer.append("Column number = " + _column);
+        sbuffer.append("\n") ;
+        sbuffer.append("System Id = " + _systemId);
+        sbuffer.append("\n") ;
+        sbuffer.append("Public Id = " + _publicId);
+        sbuffer.append("\n") ;
+        sbuffer.append("CharacterOffset = " + _charOffset);
+        sbuffer.append("\n") ;
+        return sbuffer.toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXDocumentParser.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXDocumentParser.java
new file mode 100644
index 0000000..912be44
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXDocumentParser.java
@@ -0,0 +1,1660 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax;
+
+import com.sun.xml.internal.fastinfoset.Decoder;
+import com.sun.xml.internal.fastinfoset.DecoderStateTables;
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.algorithm.BuiltInEncodingAlgorithmFactory;
+import com.sun.xml.internal.fastinfoset.sax.AttributesHolder;
+import com.sun.xml.internal.fastinfoset.util.CharArray;
+import com.sun.xml.internal.fastinfoset.util.CharArrayString;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.Iterator;
+import java.util.NoSuchElementException;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.namespace.QName;
+import javax.xml.stream.Location;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithm;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+import com.sun.xml.internal.fastinfoset.org.apache.xerces.util.XMLChar;
+
+/**
+ * The Fast Infoset StAX parser.
+ * <p>
+ * Instantiate this parser to parse a fast infoset document in accordance
+ * with the StAX API.
+ *
+ * <p>
+ * More than one fast infoset document may be decoded from the
+ * {@link java.io.InputStream}.
+ */
+public class StAXDocumentParser extends Decoder implements XMLStreamReader {
+    protected static final int INTERNAL_STATE_START_DOCUMENT = 0;
+    protected static final int INTERNAL_STATE_START_ELEMENT_TERMINATE = 1;
+    protected static final int INTERNAL_STATE_SINGLE_TERMINATE_ELEMENT_WITH_NAMESPACES = 2;
+    protected static final int INTERNAL_STATE_DOUBLE_TERMINATE_ELEMENT = 3;
+    protected static final int INTERNAL_STATE_END_DOCUMENT = 4;
+    protected static final int INTERNAL_STATE_VOID = -1;
+
+    protected int _internalState;
+
+    /**
+     * Current event
+     */
+    protected int _eventType;
+
+    /**
+     * Stack of qualified names and namespaces
+     */
+    protected QualifiedName[] _qNameStack = new QualifiedName[32];
+    protected int[] _namespaceAIIsStartStack = new int[32];
+    protected int[] _namespaceAIIsEndStack = new int[32];
+    protected int _stackCount = -1;
+
+    protected String[] _namespaceAIIsPrefix = new String[32];
+    protected String[] _namespaceAIIsNamespaceName = new String[32];
+    protected int[] _namespaceAIIsPrefixIndex = new int[32];
+    protected int _namespaceAIIsIndex;
+
+    /**
+     * Namespaces associated with START_ELEMENT or END_ELEMENT
+     */
+    protected int _currentNamespaceAIIsStart;
+    protected int _currentNamespaceAIIsEnd;
+
+    /**
+     * Qualified name associated with START_ELEMENT or END_ELEMENT.
+     */
+    protected QualifiedName _qualifiedName;
+
+    /**
+     * List of attributes
+     */
+    protected AttributesHolder _attributes = new AttributesHolder();
+
+    protected boolean _clearAttributes = false;
+
+    /**
+     * Characters associated with event.
+     */
+    protected char[] _characters;
+    protected int _charactersOffset;
+
+    protected String _algorithmURI;
+    protected int _algorithmId;
+    protected byte[] _algorithmData;
+    protected int _algorithmDataOffset;
+    protected int _algorithmDataLength;
+
+    /**
+     * State for processing instruction
+     */
+    protected String _piTarget;
+    protected String _piData;
+
+    protected NamespaceContextImpl _nsContext = new NamespaceContextImpl();
+
+    protected String _characterEncodingScheme;
+
+    protected StAXManager _manager;
+
+    public StAXDocumentParser() {
+        reset();
+    }
+
+    public StAXDocumentParser(InputStream s) {
+        this();
+        setInputStream(s);
+    }
+
+    public StAXDocumentParser(InputStream s, StAXManager manager) {
+        this(s);
+        _manager = manager;
+    }
+
+    public void setInputStream(InputStream s) {
+        super.setInputStream(s);
+        reset();
+    }
+
+    public void reset() {
+        super.reset();
+        if (_internalState != INTERNAL_STATE_START_DOCUMENT &&
+            _internalState != INTERNAL_STATE_END_DOCUMENT) {
+
+            for (int i = _namespaceAIIsIndex - 1; i >= 0; i--) {
+                _prefixTable.popScopeWithPrefixEntry(_namespaceAIIsPrefixIndex[i]);
+            }
+
+            _stackCount = -1;
+
+            _namespaceAIIsIndex = 0;
+            _characters = null;
+            _algorithmData = null;
+        }
+
+        _characterEncodingScheme = "UTF-8";
+        _eventType = START_DOCUMENT;
+        _internalState = INTERNAL_STATE_START_DOCUMENT;
+    }
+
+    protected void resetOnError() {
+        super.reset();
+
+        if (_v != null) {
+            _prefixTable.clearCompletely();
+        }
+        _duplicateAttributeVerifier.clear();
+
+        _stackCount = -1;
+
+        _namespaceAIIsIndex = 0;
+        _characters = null;
+        _algorithmData = null;
+
+        _eventType = START_DOCUMENT;
+        _internalState = INTERNAL_STATE_START_DOCUMENT;
+    }
+
+    // -- XMLStreamReader Interface -------------------------------------------
+
+    public Object getProperty(java.lang.String name)
+            throws java.lang.IllegalArgumentException {
+        if (_manager != null) {
+            return _manager.getProperty(name);
+        }
+        return null;
+    }
+
+    public int next() throws XMLStreamException {
+        try {
+            if (_internalState != INTERNAL_STATE_VOID) {
+                switch (_internalState) {
+                    case INTERNAL_STATE_START_DOCUMENT:
+                        decodeHeader();
+                        processDII();
+
+                        _internalState = INTERNAL_STATE_VOID;
+                        break;
+                    case INTERNAL_STATE_START_ELEMENT_TERMINATE:
+                        if (_currentNamespaceAIIsEnd > 0) {
+                            for (int i = _currentNamespaceAIIsEnd - 1; i >= _currentNamespaceAIIsStart; i--) {
+                                _prefixTable.popScopeWithPrefixEntry(_namespaceAIIsPrefixIndex[i]);
+                            }
+                            _namespaceAIIsIndex = _currentNamespaceAIIsStart;
+                        }
+
+                        // Pop information off the stack
+                        popStack();
+
+                        _internalState = INTERNAL_STATE_VOID;
+                        return _eventType = END_ELEMENT;
+                    case INTERNAL_STATE_SINGLE_TERMINATE_ELEMENT_WITH_NAMESPACES:
+                        // Undeclare namespaces
+                        for (int i = _currentNamespaceAIIsEnd - 1; i >= _currentNamespaceAIIsStart; i--) {
+                            _prefixTable.popScopeWithPrefixEntry(_namespaceAIIsPrefixIndex[i]);
+                        }
+                        _namespaceAIIsIndex = _currentNamespaceAIIsStart;
+                        _internalState = INTERNAL_STATE_VOID;
+                        break;
+                    case INTERNAL_STATE_DOUBLE_TERMINATE_ELEMENT:
+                        // Undeclare namespaces
+                        if (_currentNamespaceAIIsEnd > 0) {
+                            for (int i = _currentNamespaceAIIsEnd - 1; i >= _currentNamespaceAIIsStart; i--) {
+                                _prefixTable.popScopeWithPrefixEntry(_namespaceAIIsPrefixIndex[i]);
+                            }
+                            _namespaceAIIsIndex = _currentNamespaceAIIsStart;
+                        }
+
+                        if (_stackCount == -1) {
+                            _internalState = INTERNAL_STATE_END_DOCUMENT;
+                            return _eventType = END_DOCUMENT;
+                        }
+
+                        // Pop information off the stack
+                        popStack();
+
+                        _internalState = (_currentNamespaceAIIsEnd > 0) ?
+                                INTERNAL_STATE_SINGLE_TERMINATE_ELEMENT_WITH_NAMESPACES :
+                                INTERNAL_STATE_VOID;
+                        return _eventType = END_ELEMENT;
+                    case INTERNAL_STATE_END_DOCUMENT:
+                        throw new NoSuchElementException(CommonResourceBundle.getInstance().getString("message.noMoreEvents"));
+                }
+            }
+
+            // Reset internal state
+            _characters = null;
+            _algorithmData = null;
+            _currentNamespaceAIIsEnd = 0;
+
+            // Process information item
+            final int b = read();
+            switch(DecoderStateTables.EII[b]) {
+                case DecoderStateTables.EII_NO_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[b], false);
+                    return _eventType;
+                case DecoderStateTables.EII_AIIS_INDEX_SMALL:
+                    processEII(_elementNameTable._array[b & EncodingConstants.INTEGER_3RD_BIT_SMALL_MASK], true);
+                    return _eventType;
+                case DecoderStateTables.EII_INDEX_MEDIUM:
+                    processEII(processEIIIndexMedium(b), (b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    return _eventType;
+                case DecoderStateTables.EII_INDEX_LARGE:
+                    processEII(processEIIIndexLarge(b), (b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    return _eventType;
+                case DecoderStateTables.EII_LITERAL:
+                {
+                    final QualifiedName qn = processLiteralQualifiedName(
+                                b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                    _elementNameTable.add(qn);
+                    processEII(qn, (b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    return _eventType;
+                }
+                case DecoderStateTables.EII_NAMESPACES:
+                    processEIIWithNamespaces((b & EncodingConstants.ELEMENT_ATTRIBUTE_FLAG) > 0);
+                    return _eventType;
+                case DecoderStateTables.CII_UTF8_SMALL_LENGTH:
+                    _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_MASK)
+                            + 1;
+                    processUtf8CharacterString(b);
+                    return _eventType = CHARACTERS;
+                case DecoderStateTables.CII_UTF8_MEDIUM_LENGTH:
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT;
+                    processUtf8CharacterString(b);
+                    return _eventType = CHARACTERS;
+                case DecoderStateTables.CII_UTF8_LARGE_LENGTH:
+                    _octetBufferLength = ((read() << 24) |
+                            (read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT;
+                    processUtf8CharacterString(b);
+                    return _eventType = CHARACTERS;
+                case DecoderStateTables.CII_UTF16_SMALL_LENGTH:
+                    _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_MASK)
+                    + 1;
+                    processUtf16CharacterString(b);
+                    return _eventType = CHARACTERS;
+                case DecoderStateTables.CII_UTF16_MEDIUM_LENGTH:
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_SMALL_LIMIT;
+                    processUtf16CharacterString(b);
+                    return _eventType = CHARACTERS;
+                case DecoderStateTables.CII_UTF16_LARGE_LENGTH:
+                    _octetBufferLength = ((read() << 24) |
+                            (read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.OCTET_STRING_LENGTH_7TH_BIT_MEDIUM_LIMIT;
+                    processUtf16CharacterString(b);
+                    return _eventType = CHARACTERS;
+                case DecoderStateTables.CII_RA:
+                {
+                    final boolean addToTable = (_b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0;
+
+                    _identifier = (b & 0x02) << 6;
+                    final int b2 = read();
+                    _identifier |= (b2 & 0xFC) >> 2;
+
+                    decodeOctetsOnSeventhBitOfNonIdentifyingStringOnThirdBit(b2);
+
+                    decodeRestrictedAlphabetAsCharBuffer();
+
+                    if (addToTable) {
+                        _charactersOffset = _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+                        _characters = _characterContentChunkTable._array;
+                    } else {
+                        _characters = _charBuffer;
+                        _charactersOffset = 0;
+                    }
+                    return _eventType = CHARACTERS;
+                }
+                case DecoderStateTables.CII_EA:
+                {
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.addToTableNotSupported"));
+                    }
+
+                    // Decode encoding algorithm integer
+                    _algorithmId = (b & 0x02) << 6;
+                    final int b2 = read();
+                    _algorithmId |= (b2 & 0xFC) >> 2;
+
+                    decodeOctetsOnSeventhBitOfNonIdentifyingStringOnThirdBit(b2);
+                    processCIIEncodingAlgorithm();
+
+                    return _eventType = CHARACTERS;
+                }
+                case DecoderStateTables.CII_INDEX_SMALL:
+                {
+                    final int index = b & EncodingConstants.INTEGER_4TH_BIT_SMALL_MASK;
+                    _characterContentChunkTable._cachedIndex = index;
+
+                    _characters = _characterContentChunkTable._array;
+                    _charactersOffset = _characterContentChunkTable._offset[index];
+                    _charBufferLength = _characterContentChunkTable._length[index];
+                    return _eventType = CHARACTERS;
+                }
+                case DecoderStateTables.CII_INDEX_MEDIUM:
+                {
+                    final int index = (((b & EncodingConstants.INTEGER_4TH_BIT_MEDIUM_MASK) << 8) | read())
+                            + EncodingConstants.INTEGER_4TH_BIT_SMALL_LIMIT;
+                    _characterContentChunkTable._cachedIndex = index;
+
+                    _characters = _characterContentChunkTable._array;
+                    _charactersOffset = _characterContentChunkTable._offset[index];
+                    _charBufferLength = _characterContentChunkTable._length[index];
+                    return _eventType = CHARACTERS;
+                }
+                case DecoderStateTables.CII_INDEX_LARGE:
+                {
+                    final int index = (((b & EncodingConstants.INTEGER_4TH_BIT_LARGE_MASK) << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.INTEGER_4TH_BIT_MEDIUM_LIMIT;
+                    _characterContentChunkTable._cachedIndex = index;
+
+                    _characters = _characterContentChunkTable._array;
+                    _charactersOffset = _characterContentChunkTable._offset[index];
+                    _charBufferLength = _characterContentChunkTable._length[index];
+                    return _eventType = CHARACTERS;
+                }
+                case DecoderStateTables.CII_INDEX_LARGE_LARGE:
+                {
+                    final int index = ((read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.INTEGER_4TH_BIT_LARGE_LIMIT;
+                    _characterContentChunkTable._cachedIndex = index;
+
+                    _characters = _characterContentChunkTable._array;
+                    _charactersOffset = _characterContentChunkTable._offset[index];
+                    _charBufferLength = _characterContentChunkTable._length[index];
+                    return _eventType = CHARACTERS;
+                }
+                case DecoderStateTables.COMMENT_II:
+                    processCommentII();
+                    return _eventType;
+                case DecoderStateTables.PROCESSING_INSTRUCTION_II:
+                    processProcessingII();
+                    return _eventType;
+                case DecoderStateTables.UNEXPANDED_ENTITY_REFERENCE_II:
+                {
+                    processUnexpandedEntityReference(b);
+                    // Skip the reference
+                    return next();
+                }
+                case DecoderStateTables.TERMINATOR_DOUBLE:
+                    if (_stackCount != -1) {
+                        // Pop information off the stack
+                        popStack();
+
+                        _internalState = INTERNAL_STATE_DOUBLE_TERMINATE_ELEMENT;
+                        return _eventType = END_ELEMENT;
+                    }
+
+                    _internalState = INTERNAL_STATE_END_DOCUMENT;
+                    return _eventType = END_DOCUMENT;
+                case DecoderStateTables.TERMINATOR_SINGLE:
+                    if (_stackCount != -1) {
+                        // Pop information off the stack
+                        popStack();
+
+                        if (_currentNamespaceAIIsEnd > 0) {
+                            _internalState = INTERNAL_STATE_SINGLE_TERMINATE_ELEMENT_WITH_NAMESPACES;
+                        }
+                        return _eventType = END_ELEMENT;
+                    }
+
+                    _internalState = INTERNAL_STATE_END_DOCUMENT;
+                    return _eventType = END_DOCUMENT;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingEII"));
+            }
+        } catch (IOException e) {
+            resetOnError();
+            e.printStackTrace();
+            throw new XMLStreamException(e);
+        } catch (FastInfosetException e) {
+            resetOnError();
+            e.printStackTrace();
+            throw new XMLStreamException(e);
+        } catch (RuntimeException e) {
+            resetOnError();
+            e.printStackTrace();
+            throw e;
+        }
+    }
+
+    private final void processUtf8CharacterString(final int b) throws IOException {
+        decodeUtf8StringAsCharBuffer();
+        if ((b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+            _charactersOffset = _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+            _characters = _characterContentChunkTable._array;
+        } else {
+            _characters = _charBuffer;
+            _charactersOffset = 0;
+        }
+    }
+
+    private final void processUtf16CharacterString(final int b) throws IOException {
+        decodeUtf16StringAsCharBuffer();
+        if ((b & EncodingConstants.CHARACTER_CHUNK_ADD_TO_TABLE_FLAG) > 0) {
+            _charactersOffset = _characterContentChunkTable.add(_charBuffer, _charBufferLength);
+            _characters = _characterContentChunkTable._array;
+        } else {
+            _characters = _charBuffer;
+            _charactersOffset = 0;
+        }
+    }
+
+    private final void popStack() {
+        // Pop information off the stack
+        _qualifiedName = _qNameStack[_stackCount];
+        _currentNamespaceAIIsStart = _namespaceAIIsStartStack[_stackCount];
+        _currentNamespaceAIIsEnd = _namespaceAIIsEndStack[_stackCount];
+        _qNameStack[_stackCount--] = null;
+    }
+
+    /** Test if the current event is of the given type and if the namespace and name match the current namespace and name of the current event.
+     * If the namespaceURI is null it is not checked for equality, if the localName is null it is not checked for equality.
+     * @param type the event type
+     * @param namespaceURI the uri of the event, may be null
+     * @param localName the localName of the event, may be null
+     * @throws XMLStreamException if the required values are not matched.
+     */
+    public final void require(int type, String namespaceURI, String localName)
+    throws XMLStreamException {
+        if( type != _eventType)
+            throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.eventTypeNotMatch", new Object[]{getEventTypeString(type)}));
+        if( namespaceURI != null && !namespaceURI.equals(getNamespaceURI()) )
+            throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.namespaceURINotMatch", new Object[]{namespaceURI}));
+        if(localName != null && !localName.equals(getLocalName()))
+            throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.localNameNotMatch", new Object[]{localName}));
+
+        return;
+    }
+
+    /** Reads the content of a text-only element. Precondition:
+     * the current event is START_ELEMENT. Postcondition:
+     * The current event is the corresponding END_ELEMENT.
+     * @throws XMLStreamException if the current event is not a START_ELEMENT or if
+     * a non text element is encountered
+     */
+    public final String getElementText() throws XMLStreamException {
+
+        if(getEventType() != START_ELEMENT) {
+            throw new XMLStreamException(
+                    CommonResourceBundle.getInstance().getString("message.mustBeOnSTARTELEMENT"), getLocation());
+        }
+        //current is StartElement, move to the next
+        int eventType = next();
+        return getElementText(true);
+    }
+    /**
+     * @param startElementRead flag if start element has already been read
+     */
+    public final String getElementText(boolean startElementRead) throws XMLStreamException {
+        if (!startElementRead) {
+            throw new XMLStreamException(
+                    CommonResourceBundle.getInstance().getString("message.mustBeOnSTARTELEMENT"), getLocation());
+        }
+        int eventType = getEventType();
+        StringBuffer content = new StringBuffer();
+        while(eventType != END_ELEMENT ) {
+            if(eventType == CHARACTERS
+                    || eventType == CDATA
+                    || eventType == SPACE
+                    || eventType == ENTITY_REFERENCE) {
+                content.append(getText());
+            } else if(eventType == PROCESSING_INSTRUCTION
+                    || eventType == COMMENT) {
+                // skipping
+            } else if(eventType == END_DOCUMENT) {
+                throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.unexpectedEOF"));
+            } else if(eventType == START_ELEMENT) {
+                throw new XMLStreamException(
+                        CommonResourceBundle.getInstance().getString("message.getElementTextExpectTextOnly"), getLocation());
+            } else {
+                throw new XMLStreamException(
+                        CommonResourceBundle.getInstance().getString("message.unexpectedEventType")+ getEventTypeString(eventType), getLocation());
+            }
+            eventType = next();
+        }
+        return content.toString();
+    }
+
+    /** Skips any white space (isWhiteSpace() returns true), COMMENT,
+     * or PROCESSING_INSTRUCTION,
+     * until a START_ELEMENT or END_ELEMENT is reached.
+     * If other than white space characters, COMMENT, PROCESSING_INSTRUCTION, START_ELEMENT, END_ELEMENT
+     * are encountered, an exception is thrown. This method should
+     * be used when processing element-only content seperated by white space.
+     * This method should
+     * be used when processing element-only content because
+     * the parser is not able to recognize ignorable whitespace if
+     * then DTD is missing or not interpreted.
+     * @return the event type of the element read
+     * @throws XMLStreamException if the current event is not white space
+     */
+    public final int nextTag() throws XMLStreamException {
+        int eventType = next();
+        return nextTag(true);
+    }
+    /** if the current tag has already read, such as in the case EventReader's
+     * peek() has been called, the current cursor should not move before the loop
+     */
+    public final int nextTag(boolean currentTagRead) throws XMLStreamException {
+        int eventType = getEventType();
+        if (!currentTagRead) {
+            eventType = next();
+        }
+        while((eventType == CHARACTERS && isWhiteSpace()) // skip whitespace
+        || (eventType == CDATA && isWhiteSpace())
+        || eventType == SPACE
+                || eventType == PROCESSING_INSTRUCTION
+                || eventType == COMMENT) {
+            eventType = next();
+        }
+        if (eventType != START_ELEMENT && eventType != END_ELEMENT) {
+            throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.expectedStartOrEnd"), getLocation());
+        }
+        return eventType;
+    }
+
+    public final boolean hasNext() throws XMLStreamException {
+        return (_eventType != END_DOCUMENT);
+    }
+
+    public void close() throws XMLStreamException {
+    }
+
+    public final String getNamespaceURI(String prefix) {
+        String namespace = getNamespaceDecl(prefix);
+        if (namespace == null) {
+            if (prefix == null) {
+                throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.nullPrefix"));
+            }
+            return null;  // unbound
+        }
+        return namespace;
+    }
+
+    public final boolean isStartElement() {
+        return (_eventType == START_ELEMENT);
+    }
+
+    public final boolean isEndElement() {
+        return (_eventType == END_ELEMENT);
+    }
+
+    public final boolean isCharacters() {
+        return (_eventType == CHARACTERS);
+    }
+
+    /**
+     *  Returns true if the cursor points to a character data event that consists of all whitespace
+     *  Application calling this method needs to cache the value and avoid calling this method again
+     *  for the same event.
+     * @return true if the cursor points to all whitespace, false otherwise
+     */
+    public final boolean isWhiteSpace() {
+        if(isCharacters() || (_eventType == CDATA)){
+            char [] ch = this.getTextCharacters();
+            int start = this.getTextStart();
+            int length = this.getTextLength();
+            for (int i=start; i< length;i++){
+                if(!XMLChar.isSpace(ch[i])){
+                    return false;
+                }
+            }
+            return true;
+        }
+        return false;
+    }
+
+    public final String getAttributeValue(String namespaceURI, String localName) {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+
+        if (localName == null)
+            throw new IllegalArgumentException();
+
+        // Search for the attributes in _attributes
+        if (namespaceURI != null) {
+            for (int i = 0; i < _attributes.getLength(); i++) {
+                if (_attributes.getLocalName(i).equals(localName) &&
+                        _attributes.getURI(i).equals(namespaceURI)) {
+                    return _attributes.getValue(i);
+                }
+            }
+        } else {
+            for (int i = 0; i < _attributes.getLength(); i++) {
+                if (_attributes.getLocalName(i).equals(localName)) {
+                    return _attributes.getValue(i);
+                }
+            }
+        }
+
+        return null;
+    }
+
+    public final int getAttributeCount() {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+
+        return _attributes.getLength();
+    }
+
+    public final javax.xml.namespace.QName getAttributeName(int index) {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+        return _attributes.getQualifiedName(index).getQName();
+    }
+
+    public final String getAttributeNamespace(int index) {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+
+        return _attributes.getURI(index);
+    }
+
+    public final String getAttributeLocalName(int index) {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+        return _attributes.getLocalName(index);
+    }
+
+    public final String getAttributePrefix(int index) {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+        return _attributes.getPrefix(index);
+    }
+
+    public final String getAttributeType(int index) {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+        return _attributes.getType(index);
+    }
+
+    public final String getAttributeValue(int index) {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+        return _attributes.getValue(index);
+    }
+
+    public final boolean isAttributeSpecified(int index) {
+        return false;   // non-validating parser
+    }
+
+    public final int getNamespaceCount() {
+        if (_eventType == START_ELEMENT || _eventType == END_ELEMENT) {
+            return (_currentNamespaceAIIsEnd > 0) ? (_currentNamespaceAIIsEnd - _currentNamespaceAIIsStart) : 0;
+        } else {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetNamespaceCount"));
+        }
+    }
+
+    public final String getNamespacePrefix(int index) {
+        if (_eventType == START_ELEMENT || _eventType == END_ELEMENT) {
+            return _namespaceAIIsPrefix[_currentNamespaceAIIsStart + index];
+        } else {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetNamespacePrefix"));
+        }
+    }
+
+    public final String getNamespaceURI(int index) {
+        if (_eventType == START_ELEMENT || _eventType == END_ELEMENT) {
+            return _namespaceAIIsNamespaceName[_currentNamespaceAIIsStart + index];
+        } else {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetNamespacePrefix"));
+        }
+    }
+
+    public final NamespaceContext getNamespaceContext() {
+        return _nsContext;
+    }
+
+    public final int getEventType() {
+        return _eventType;
+    }
+
+    public final String getText() {
+        if (_characters == null) {
+            checkTextState();
+        }
+
+        if (_characters == _characterContentChunkTable._array) {
+            return _characterContentChunkTable.getString(_characterContentChunkTable._cachedIndex);
+        } else {
+            return new String(_characters, _charactersOffset, _charBufferLength);
+        }
+    }
+
+    public final char[] getTextCharacters() {
+        if (_characters == null) {
+            checkTextState();
+        }
+
+        return _characters;
+    }
+
+    public final int getTextStart() {
+        if (_characters == null) {
+            checkTextState();
+        }
+
+        return _charactersOffset;
+    }
+
+    public final int getTextLength() {
+        if (_characters == null) {
+            checkTextState();
+        }
+
+        return _charBufferLength;
+    }
+
+    public final int getTextCharacters(int sourceStart, char[] target,
+            int targetStart, int length) throws XMLStreamException {
+        if (_characters == null) {
+            checkTextState();
+        }
+
+        try {
+            System.arraycopy(_characters, sourceStart, target,
+                    targetStart, length);
+            return length;
+        } catch (IndexOutOfBoundsException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    protected final void checkTextState() {
+        if (_algorithmData == null) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.InvalidStateForText"));
+        }
+
+        try {
+            convertEncodingAlgorithmDataToCharacters();
+        } catch (Exception e) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.InvalidStateForText"));
+        }
+    }
+
+    public final String getEncoding() {
+        return _characterEncodingScheme;
+    }
+
+    public final boolean hasText() {
+        return (_characters != null);
+    }
+
+    public final Location getLocation() {
+        //location should be created in next()
+        //returns a nil location for now
+        return EventLocation.getNilLocation();
+    }
+
+    public final QName getName() {
+        if (_eventType == START_ELEMENT || _eventType == END_ELEMENT) {
+            return _qualifiedName.getQName();
+        } else {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetName"));
+        }
+    }
+
+    public final String getLocalName() {
+        if (_eventType == START_ELEMENT || _eventType == END_ELEMENT) {
+            return _qualifiedName.localName;
+        } else {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetLocalName"));
+        }
+    }
+
+    public final boolean hasName() {
+        return (_eventType == START_ELEMENT || _eventType == END_ELEMENT);
+    }
+
+    public final String getNamespaceURI() {
+        if (_eventType == START_ELEMENT || _eventType == END_ELEMENT) {
+            return _qualifiedName.namespaceName;
+        } else {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetNamespaceURI"));
+        }
+    }
+
+    public final String getPrefix() {
+        if (_eventType == START_ELEMENT || _eventType == END_ELEMENT) {
+            return _qualifiedName.prefix;
+        } else {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetPrefix"));
+        }
+    }
+
+    public final String getVersion() {
+        return null;
+    }
+
+    public final boolean isStandalone() {
+        return false;
+    }
+
+    public final boolean standaloneSet() {
+        return false;
+    }
+
+    public final String getCharacterEncodingScheme() {
+        return null;
+    }
+
+    public final String getPITarget() {
+        if (_eventType != PROCESSING_INSTRUCTION) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetPITarget"));
+        }
+
+        return _piTarget;
+    }
+
+    public final String getPIData() {
+        if (_eventType != PROCESSING_INSTRUCTION) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetPIData"));
+        }
+
+        return _piData;
+    }
+
+
+
+
+    public final String getNameString() {
+        if (_eventType == START_ELEMENT || _eventType == END_ELEMENT) {
+            return _qualifiedName.getQNameString();
+        } else {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetName"));
+        }
+    }
+
+    public final String getAttributeNameString(int index) {
+        if (_eventType != START_ELEMENT) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.invalidCallingGetAttributeValue"));
+        }
+        return _attributes.getQualifiedName(index).getQNameString();
+    }
+
+
+    public final String getTextAlgorithmURI() {
+        return _algorithmURI;
+    }
+
+    public final int getTextAlgorithmIndex() {
+        return _algorithmId;
+    }
+
+    public final byte[] getTextAlgorithmBytes() {
+        return _algorithmData;
+    }
+
+    public final byte[] getTextAlgorithmBytesClone() {
+        if (_algorithmData == null) {
+            return null;
+        }
+
+        byte[] algorithmData = new byte[_algorithmDataLength];
+        System.arraycopy(_algorithmData, _algorithmDataOffset, algorithmData, 0, _algorithmDataLength);
+        return algorithmData;
+    }
+
+    public final int getTextAlgorithmStart() {
+        return _algorithmDataOffset;
+    }
+
+    public final int getTextAlgorithmLength() {
+        return _algorithmDataLength;
+    }
+
+    public final int getTextAlgorithmBytes(int sourceStart, byte[] target,
+            int targetStart, int length) throws XMLStreamException {
+        try {
+            System.arraycopy(_algorithmData, sourceStart, target,
+                    targetStart, length);
+            return length;
+        } catch (IndexOutOfBoundsException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+
+
+    //
+
+    protected final void processDII() throws FastInfosetException, IOException {
+        final int b = read();
+        if (b > 0) {
+            processDIIOptionalProperties(b);
+        }
+    }
+
+    protected final void processDIIOptionalProperties(int b) throws FastInfosetException, IOException {
+        // Optimize for the most common case
+        if (b == EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG) {
+            decodeInitialVocabulary();
+            return;
+        }
+
+        if ((b & EncodingConstants.DOCUMENT_ADDITIONAL_DATA_FLAG) > 0) {
+            decodeAdditionalData();
+            /*
+             * TODO
+             * how to report the additional data?
+             */
+        }
+
+        if ((b & EncodingConstants.DOCUMENT_INITIAL_VOCABULARY_FLAG) > 0) {
+            decodeInitialVocabulary();
+        }
+
+        if ((b & EncodingConstants.DOCUMENT_NOTATIONS_FLAG) > 0) {
+            decodeNotations();
+            /*
+                try {
+                    _dtdHandler.notationDecl(name, public_identifier, system_identifier);
+                } catch (SAXException e) {
+                    throw new IOException("NotationsDeclarationII");
+                }
+             */
+        }
+
+        if ((b & EncodingConstants.DOCUMENT_UNPARSED_ENTITIES_FLAG) > 0) {
+            decodeUnparsedEntities();
+            /*
+                try {
+                    _dtdHandler.unparsedEntityDecl(name, public_identifier, system_identifier, notation_name);
+                } catch (SAXException e) {
+                    throw new IOException("UnparsedEntitiesII");
+                }
+             */
+        }
+
+        if ((b & EncodingConstants.DOCUMENT_CHARACTER_ENCODING_SCHEME) > 0) {
+            _characterEncodingScheme = decodeCharacterEncodingScheme();
+        }
+
+        if ((b & EncodingConstants.DOCUMENT_STANDALONE_FLAG) > 0) {
+            boolean standalone = (read() > 0) ? true : false ;
+            /*
+             * TODO
+             * how to report the standalone flag?
+             */
+        }
+
+        if ((b & EncodingConstants.DOCUMENT_VERSION_FLAG) > 0) {
+            String version = decodeVersion();
+            /*
+             * TODO
+             * how to report the standalone flag?
+             */
+        }
+    }
+
+
+    protected final void resizeNamespaceAIIs() {
+        final String[] namespaceAIIsPrefix = new String[_namespaceAIIsIndex * 2];
+        System.arraycopy(_namespaceAIIsPrefix, 0, namespaceAIIsPrefix, 0, _namespaceAIIsIndex);
+        _namespaceAIIsPrefix = namespaceAIIsPrefix;
+
+        final String[] namespaceAIIsNamespaceName = new String[_namespaceAIIsIndex * 2];
+        System.arraycopy(_namespaceAIIsNamespaceName, 0, namespaceAIIsNamespaceName, 0, _namespaceAIIsIndex);
+        _namespaceAIIsNamespaceName = namespaceAIIsNamespaceName;
+
+        final int[] namespaceAIIsPrefixIndex = new int[_namespaceAIIsIndex * 2];
+        System.arraycopy(_namespaceAIIsPrefixIndex, 0, namespaceAIIsPrefixIndex, 0, _namespaceAIIsIndex);
+        _namespaceAIIsPrefixIndex = namespaceAIIsPrefixIndex;
+    }
+
+    protected final void processEIIWithNamespaces(boolean hasAttributes) throws FastInfosetException, IOException {
+        if (++_prefixTable._declarationId == Integer.MAX_VALUE) {
+            _prefixTable.clearDeclarationIds();
+        }
+
+        _currentNamespaceAIIsStart = _namespaceAIIsIndex;
+        String prefix = "", namespaceName = "";
+        int b = read();
+        while ((b & EncodingConstants.NAMESPACE_ATTRIBUTE_MASK) == EncodingConstants.NAMESPACE_ATTRIBUTE) {
+            if (_namespaceAIIsIndex == _namespaceAIIsPrefix.length) {
+                resizeNamespaceAIIs();
+            }
+
+            switch (b & EncodingConstants.NAMESPACE_ATTRIBUTE_PREFIX_NAME_MASK) {
+                // no prefix, no namespace
+                // Undeclaration of default namespace
+                case 0:
+                    prefix = namespaceName =
+                            _namespaceAIIsPrefix[_namespaceAIIsIndex] =
+                            _namespaceAIIsNamespaceName[_namespaceAIIsIndex] = "";
+
+                    _namespaceNameIndex = _prefixIndex = _namespaceAIIsPrefixIndex[_namespaceAIIsIndex++] = -1;
+                    break;
+                // no prefix, namespace
+                // Declaration of default namespace
+                case 1:
+                    prefix = _namespaceAIIsPrefix[_namespaceAIIsIndex] = "";
+                    namespaceName = _namespaceAIIsNamespaceName[_namespaceAIIsIndex] =
+                            decodeIdentifyingNonEmptyStringOnFirstBitAsNamespaceName(false);
+
+                    _prefixIndex = _namespaceAIIsPrefixIndex[_namespaceAIIsIndex++] = -1;
+                    break;
+                // prefix, no namespace
+                // Undeclaration of namespace
+                case 2:
+                    prefix = _namespaceAIIsPrefix[_namespaceAIIsIndex] =
+                            decodeIdentifyingNonEmptyStringOnFirstBitAsPrefix(false);
+                    namespaceName = _namespaceAIIsNamespaceName[_namespaceAIIsIndex] = "";
+
+                    _namespaceNameIndex = -1;
+                    _namespaceAIIsPrefixIndex[_namespaceAIIsIndex++] = _prefixIndex;
+                    break;
+                // prefix, namespace
+                // Declaration of prefixed namespace
+                case 3:
+                    prefix = _namespaceAIIsPrefix[_namespaceAIIsIndex] =
+                            decodeIdentifyingNonEmptyStringOnFirstBitAsPrefix(true);
+                    namespaceName = _namespaceAIIsNamespaceName[_namespaceAIIsIndex] =
+                            decodeIdentifyingNonEmptyStringOnFirstBitAsNamespaceName(true);
+
+                    _namespaceAIIsPrefixIndex[_namespaceAIIsIndex++] = _prefixIndex;
+                    break;
+            }
+
+            // Push namespace declarations onto the stack
+            _prefixTable.pushScopeWithPrefixEntry(prefix, namespaceName, _prefixIndex, _namespaceNameIndex);
+
+            b = read();
+        }
+        if (b != EncodingConstants.TERMINATOR) {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.EIInamespaceNameNotTerminatedCorrectly"));
+        }
+        _currentNamespaceAIIsEnd = _namespaceAIIsIndex;
+
+        b = read();
+        switch(DecoderStateTables.EII[b]) {
+            case DecoderStateTables.EII_NO_AIIS_INDEX_SMALL:
+                processEII(_elementNameTable._array[b], hasAttributes);
+                break;
+            case DecoderStateTables.EII_INDEX_MEDIUM:
+                processEII(processEIIIndexMedium(b), hasAttributes);
+                break;
+            case DecoderStateTables.EII_INDEX_LARGE:
+                processEII(processEIIIndexLarge(b), hasAttributes);
+                break;
+            case DecoderStateTables.EII_LITERAL:
+            {
+                final QualifiedName qn = processLiteralQualifiedName(
+                            b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                _elementNameTable.add(qn);
+                processEII(qn, hasAttributes);
+                break;
+            }
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.IllegalStateDecodingEIIAfterAIIs"));
+        }
+    }
+
+    protected final void processEII(QualifiedName name, boolean hasAttributes) throws FastInfosetException, IOException {
+        if (_prefixTable._currentInScope[name.prefixIndex] != name.namespaceNameIndex) {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.qnameOfEIINotInScope"));
+        }
+
+        _eventType = START_ELEMENT;
+        _qualifiedName = name;
+
+        if (_clearAttributes) {
+            _attributes.clear();
+            _clearAttributes = false;
+        }
+
+        if (hasAttributes) {
+            processAIIs();
+        }
+
+        // Push element holder onto the stack
+        _stackCount++;
+        if (_stackCount == _qNameStack.length) {
+            QualifiedName[] qNameStack = new QualifiedName[_qNameStack.length * 2];
+            System.arraycopy(_qNameStack, 0, qNameStack, 0, _qNameStack.length);
+            _qNameStack = qNameStack;
+
+            int[] namespaceAIIsStartStack = new int[_namespaceAIIsStartStack.length * 2];
+            System.arraycopy(_namespaceAIIsStartStack, 0, namespaceAIIsStartStack, 0, _namespaceAIIsStartStack.length);
+            _namespaceAIIsStartStack = namespaceAIIsStartStack;
+
+            int[] namespaceAIIsEndStack = new int[_namespaceAIIsEndStack.length * 2];
+            System.arraycopy(_namespaceAIIsEndStack, 0, namespaceAIIsEndStack, 0, _namespaceAIIsEndStack.length);
+            _namespaceAIIsEndStack = namespaceAIIsEndStack;
+        }
+        _qNameStack[_stackCount] = _qualifiedName;
+        _namespaceAIIsStartStack[_stackCount] = _currentNamespaceAIIsStart;
+        _namespaceAIIsEndStack[_stackCount] = _currentNamespaceAIIsEnd;
+    }
+
+    protected final void processAIIs() throws FastInfosetException, IOException {
+        QualifiedName name;
+        int b;
+        String value;
+
+        if (++_duplicateAttributeVerifier._currentIteration == Integer.MAX_VALUE) {
+            _duplicateAttributeVerifier.clear();
+        }
+
+        _clearAttributes = true;
+        boolean terminate = false;
+        do {
+            // AII qualified name
+            b = read();
+            switch (DecoderStateTables.AII[b]) {
+                case DecoderStateTables.AII_INDEX_SMALL:
+                    name = _attributeNameTable._array[b];
+                    break;
+                case DecoderStateTables.AII_INDEX_MEDIUM:
+                {
+                    final int i = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                            + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+                    name = _attributeNameTable._array[i];
+                    break;
+                }
+                case DecoderStateTables.AII_INDEX_LARGE:
+                {
+                    final int i = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                            + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+                    name = _attributeNameTable._array[i];
+                    break;
+                }
+                case DecoderStateTables.AII_LITERAL:
+                    name = processLiteralQualifiedName(
+                            b & EncodingConstants.LITERAL_QNAME_PREFIX_NAMESPACE_NAME_MASK);
+                    name.createAttributeValues(_duplicateAttributeVerifier.MAP_SIZE);
+                    _attributeNameTable.add(name);
+                    break;
+                case DecoderStateTables.AII_TERMINATOR_DOUBLE:
+                    _internalState = INTERNAL_STATE_START_ELEMENT_TERMINATE;
+                case DecoderStateTables.AII_TERMINATOR_SINGLE:
+                    terminate = true;
+                    // AIIs have finished break out of loop
+                    continue;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingAIIs"));
+            }
+
+            // [normalized value] of AII
+
+            if (name.prefixIndex > 0 && _prefixTable._currentInScope[name.prefixIndex] != name.namespaceNameIndex) {
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.AIIqNameNotInScope"));
+            }
+
+            _duplicateAttributeVerifier.checkForDuplicateAttribute(name.attributeHash, name.attributeId);
+
+            b = read();
+            switch(DecoderStateTables.NISTRING[b]) {
+                case DecoderStateTables.NISTRING_UTF8_SMALL_LENGTH:
+                    _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK) + 1;
+                    value = decodeUtf8StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF8_MEDIUM_LENGTH:
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                    value = decodeUtf8StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF8_LARGE_LENGTH:
+                    _octetBufferLength = ((read() << 24) |
+                            (read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                    value = decodeUtf8StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF16_SMALL_LENGTH:
+                    _octetBufferLength = (b & EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_MASK) + 1;
+                    value = decodeUtf16StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF16_MEDIUM_LENGTH:
+                    _octetBufferLength = read() + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_SMALL_LIMIT;
+                    value = decodeUtf16StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_UTF16_LARGE_LENGTH:
+                    _octetBufferLength = ((read() << 24) |
+                            (read() << 16) |
+                            (read() << 8) |
+                            read())
+                            + EncodingConstants.OCTET_STRING_LENGTH_5TH_BIT_MEDIUM_LIMIT;
+                    value = decodeUtf16StringAsString();
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                case DecoderStateTables.NISTRING_RA:
+                {
+                    final boolean addToTable = (b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0;
+                    // Decode resitricted alphabet integer
+                    _identifier = (b & 0x0F) << 4;
+                    b = read();
+                    _identifier |= (b & 0xF0) >> 4;
+
+                    decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(b);
+
+                    value = decodeRestrictedAlphabetAsString();
+                    if (addToTable) {
+                        _attributeValueTable.add(value);
+                    }
+
+                    _attributes.addAttribute(name, value);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_EA:
+                {
+                    if ((b & EncodingConstants.NISTRING_ADD_TO_TABLE_FLAG) > 0) {
+                        throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.addToTableNotSupported"));
+                    }
+
+                    // Decode encoding algorithm integer
+                    _identifier = (b & 0x0F) << 4;
+                    b = read();
+                    _identifier |= (b & 0xF0) >> 4;
+
+                    decodeOctetsOnFifthBitOfNonIdentifyingStringOnFirstBit(b);
+                    processAIIEncodingAlgorithm(name);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_INDEX_SMALL:
+                    _attributes.addAttribute(name,
+                            _attributeValueTable._array[b & EncodingConstants.INTEGER_2ND_BIT_SMALL_MASK]);
+                    break;
+                case DecoderStateTables.NISTRING_INDEX_MEDIUM:
+                {
+                    final int index = (((b & EncodingConstants.INTEGER_2ND_BIT_MEDIUM_MASK) << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_SMALL_LIMIT;
+
+                    _attributes.addAttribute(name,
+                            _attributeValueTable._array[index]);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_INDEX_LARGE:
+                {
+                    final int index = (((b & EncodingConstants.INTEGER_2ND_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                    + EncodingConstants.INTEGER_2ND_BIT_MEDIUM_LIMIT;
+
+                    _attributes.addAttribute(name,
+                            _attributeValueTable._array[index]);
+                    break;
+                }
+                case DecoderStateTables.NISTRING_EMPTY:
+                    _attributes.addAttribute(name, "");
+                    break;
+                default:
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingAIIValue"));
+            }
+
+        } while (!terminate);
+
+        // Reset duplication attribute verfifier
+        _duplicateAttributeVerifier._poolCurrent = _duplicateAttributeVerifier._poolHead;
+    }
+
+    protected final QualifiedName processEIIIndexMedium(int b) throws FastInfosetException, IOException {
+        final int i = (((b & EncodingConstants.INTEGER_3RD_BIT_MEDIUM_MASK) << 8) | read())
+            + EncodingConstants.INTEGER_3RD_BIT_SMALL_LIMIT;
+        return _elementNameTable._array[i];
+    }
+
+    protected final QualifiedName processEIIIndexLarge(int b) throws FastInfosetException, IOException {
+        int i;
+        if ((b & EncodingConstants.INTEGER_3RD_BIT_LARGE_LARGE_FLAG) == 0x20) {
+            // EII large index
+            i = (((b & EncodingConstants.INTEGER_3RD_BIT_LARGE_MASK) << 16) | (read() << 8) | read())
+                + EncodingConstants.INTEGER_3RD_BIT_MEDIUM_LIMIT;
+        } else {
+            // EII large large index
+            i = (((read() & EncodingConstants.INTEGER_3RD_BIT_LARGE_LARGE_MASK) << 16) | (read() << 8) | read())
+                + EncodingConstants.INTEGER_3RD_BIT_LARGE_LIMIT;
+        }
+        return _elementNameTable._array[i];
+    }
+
+    protected final QualifiedName processLiteralQualifiedName(int state) throws FastInfosetException, IOException {
+        switch (state) {
+            // no prefix, no namespace
+            case 0:
+                return new QualifiedName(
+                        "",
+                        "",
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        "",
+                        0,
+                        -1,
+                        -1,
+                        _identifier);
+            // no prefix, namespace
+            case 1:
+                return new QualifiedName(
+                        "",
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsNamespaceName(false),
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        "",
+                        0,
+                        -1,
+                        _namespaceNameIndex,
+                        _identifier);
+            // prefix, no namespace
+            case 2:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.qNameMissingNamespaceName"));
+            // prefix, namespace
+            case 3:
+                return new QualifiedName(
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsPrefix(true),
+                        decodeIdentifyingNonEmptyStringIndexOnFirstBitAsNamespaceName(true),
+                        decodeIdentifyingNonEmptyStringOnFirstBit(_v.localName),
+                        "",
+                        0,
+                        _prefixIndex,
+                        _namespaceNameIndex,
+                        _identifier);
+            default:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.decodingEII"));
+        }
+    }
+
+    protected final void processCommentII() throws FastInfosetException, IOException {
+        _eventType = COMMENT;
+
+        switch(decodeNonIdentifyingStringOnFirstBit()) {
+            case NISTRING_STRING:
+                if (_addToTable) {
+                    _v.otherString.add(new CharArray(_charBuffer, 0, _charBufferLength, true));
+                }
+
+                _characters = _charBuffer;
+                _charactersOffset = 0;
+                break;
+            case NISTRING_ENCODING_ALGORITHM:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.commentIIAlgorithmNotSupported"));
+            case NISTRING_INDEX:
+                final CharArray ca = _v.otherString.get(_integer);
+
+                _characters = ca.ch;
+                _charactersOffset = ca.start;
+                _charBufferLength = ca.length;
+                break;
+            case NISTRING_EMPTY_STRING:
+                _characters = _charBuffer;
+                _charactersOffset = 0;
+                _charBufferLength = 0;
+                break;
+        }
+    }
+
+    protected final void processProcessingII() throws FastInfosetException, IOException {
+        _eventType = PROCESSING_INSTRUCTION;
+
+        _piTarget = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+
+        switch(decodeNonIdentifyingStringOnFirstBit()) {
+            case NISTRING_STRING:
+                _piData = new String(_charBuffer, 0, _charBufferLength);
+                if (_addToTable) {
+                    _v.otherString.add(new CharArrayString(_piData));
+                }
+                break;
+            case NISTRING_ENCODING_ALGORITHM:
+                throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.processingIIWithEncodingAlgorithm"));
+            case NISTRING_INDEX:
+                _piData = _v.otherString.get(_integer).toString();
+                break;
+            case NISTRING_EMPTY_STRING:
+                _piData = "";
+                break;
+        }
+    }
+
+    protected final void processUnexpandedEntityReference(final int b) throws FastInfosetException, IOException {
+        _eventType = ENTITY_REFERENCE;
+
+        /*
+         * TODO
+         * How does StAX report such events?
+         */
+        String entity_reference_name = decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherNCName);
+
+        String system_identifier = ((b & EncodingConstants.UNEXPANDED_ENTITY_SYSTEM_IDENTIFIER_FLAG) > 0)
+        ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+        String public_identifier = ((b & EncodingConstants.UNEXPANDED_ENTITY_PUBLIC_IDENTIFIER_FLAG) > 0)
+        ? decodeIdentifyingNonEmptyStringOnFirstBit(_v.otherURI) : "";
+    }
+
+    protected final void processCIIEncodingAlgorithm() throws FastInfosetException, IOException {
+        _algorithmData = _octetBuffer;
+        _algorithmDataOffset = _octetBufferStart;
+        _algorithmDataLength = _octetBufferLength;
+
+        if (_algorithmId >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            _algorithmURI = _v.encodingAlgorithm.get(_algorithmId - EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START);
+            if (_algorithmURI == null) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.URINotPresent", new Object[]{new Integer(_identifier)}));
+            }
+        } else if (_algorithmId > EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            // Reserved built-in algorithms for future use
+            // TODO should use sax property to decide if event will be
+            // reported, allows for support through handler if required.
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.identifiers10to31Reserved"));
+        }
+    }
+
+    protected final void processAIIEncodingAlgorithm(QualifiedName name) throws FastInfosetException, IOException {
+        String URI = null;
+        if (_identifier >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            URI = _v.encodingAlgorithm.get(_identifier - EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START);
+            if (URI == null) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.URINotPresent", new Object[]{new Integer(_identifier)}));
+            }
+        } else if (_identifier >= EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            if (_identifier == EncodingAlgorithmIndexes.CDATA) {
+                throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.CDATAAlgorithmNotSupported"));
+            }
+
+            // Reserved built-in algorithms for future use
+            // TODO should use sax property to decide if event will be
+            // reported, allows for support through handler if required.
+            throw new EncodingAlgorithmException(CommonResourceBundle.getInstance().getString("message.identifiers10to31Reserved"));
+        }
+
+        final byte[] data = new byte[_octetBufferLength];
+        System.arraycopy(_octetBuffer, _octetBufferStart, data, 0, _octetBufferLength);
+        _attributes.addAttributeWithAlgorithmData(name, URI, _identifier, data);
+    }
+
+    protected final void convertEncodingAlgorithmDataToCharacters() throws FastInfosetException, IOException {
+        StringBuffer buffer = new StringBuffer();
+        if (_algorithmId < EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            Object array = BuiltInEncodingAlgorithmFactory.table[_algorithmId].
+                decodeFromBytes(_algorithmData, _algorithmDataOffset, _algorithmDataLength);
+            BuiltInEncodingAlgorithmFactory.table[_algorithmId].convertToCharacters(array,  buffer);
+        } else if (_algorithmId == EncodingAlgorithmIndexes.CDATA) {
+            _octetBufferOffset -= _octetBufferLength;
+            decodeUtf8StringIntoCharBuffer();
+
+            _characters = _charBuffer;
+            _charactersOffset = 0;
+            return;
+        } else if (_algorithmId >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            final EncodingAlgorithm ea = (EncodingAlgorithm)_registeredEncodingAlgorithms.get(_algorithmURI);
+            if (ea != null) {
+                final Object data = ea.decodeFromBytes(_octetBuffer, _octetBufferStart, _octetBufferLength);
+                ea.convertToCharacters(data, buffer);
+            } else {
+                throw new EncodingAlgorithmException(
+                        CommonResourceBundle.getInstance().getString("message.algorithmDataCannotBeReported"));
+            }
+        }
+
+        _characters = new char[buffer.length()];
+        buffer.getChars(0, buffer.length(), _characters, 0);
+        _charactersOffset = 0;
+        _charBufferLength = _characters.length;
+    }
+
+    protected class NamespaceContextImpl implements NamespaceContext {
+        public final String getNamespaceURI(String prefix) {
+            return _prefixTable.getNamespaceFromPrefix(prefix);
+        }
+
+        public final String getPrefix(String namespaceURI) {
+            return _prefixTable.getPrefixFromNamespace(namespaceURI);
+        }
+
+        public final Iterator getPrefixes(String namespaceURI) {
+            return _prefixTable.getPrefixesFromNamespace(namespaceURI);
+        }
+    }
+
+    public final String getNamespaceDecl(String prefix) {
+        return _prefixTable.getNamespaceFromPrefix(prefix);
+    }
+
+    public final String getURI(String prefix) {
+        return getNamespaceDecl(prefix);
+    }
+
+    public final Iterator getPrefixes() {
+        return _prefixTable.getPrefixes();
+    }
+
+    public final AttributesHolder getAttributesHolder() {
+        return _attributes;
+    }
+
+    public final void setManager(StAXManager manager) {
+        _manager = manager;
+    }
+
+    final static String getEventTypeString(int eventType) {
+        switch (eventType){
+            case START_ELEMENT:
+                return "START_ELEMENT";
+            case END_ELEMENT:
+                return "END_ELEMENT";
+            case PROCESSING_INSTRUCTION:
+                return "PROCESSING_INSTRUCTION";
+            case CHARACTERS:
+                return "CHARACTERS";
+            case COMMENT:
+                return "COMMENT";
+            case START_DOCUMENT:
+                return "START_DOCUMENT";
+            case END_DOCUMENT:
+                return "END_DOCUMENT";
+            case ENTITY_REFERENCE:
+                return "ENTITY_REFERENCE";
+            case ATTRIBUTE:
+                return "ATTRIBUTE";
+            case DTD:
+                return "DTD";
+            case CDATA:
+                return "CDATA";
+        }
+        return "UNKNOWN_EVENT_TYPE";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXDocumentSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXDocumentSerializer.java
new file mode 100644
index 0000000..69667d7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXDocumentSerializer.java
@@ -0,0 +1,672 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax;
+
+import com.sun.xml.internal.fastinfoset.Encoder;
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.util.EmptyStackException;
+import java.util.Enumeration;
+import java.util.Iterator;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import org.xml.sax.helpers.NamespaceSupport;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+/**
+ * The Fast Infoset StAX serializer.
+ * <p>
+ * Instantiate this serializer to serialize a fast infoset document in accordance
+ * with the StAX API.
+ *
+ * <p>
+ * More than one fast infoset document may be encoded to the
+ * {@link java.io.OutputStream}.
+ */
+public class StAXDocumentSerializer extends Encoder implements XMLStreamWriter {
+    protected StAXManager _manager;
+
+    protected String _encoding;
+    /**
+     * Local name of current element.
+     */
+    protected String _currentLocalName;
+
+    /**
+     * Namespace of current element.
+     */
+    protected String _currentUri;
+
+    /**
+     * Prefix of current element.
+     */
+    protected String _currentPrefix;
+
+   /**
+     * This flag indicates when there is a pending start element event.
+     */
+    protected boolean _inStartElement = false;
+
+    /**
+     * This flag indicates if the current element is empty.
+     */
+    protected boolean _isEmptyElement = false;
+
+    /**
+     * List of attributes qnames and values defined in the current element.
+     */
+    protected String[] _attributesArray = new String[4 * 16];
+    protected int _attributesArrayIndex = 0;
+
+    /**
+     * Mapping between uris and prefixes.
+     */
+    protected NamespaceSupport _nsSupport = new NamespaceSupport();
+
+    protected boolean[] _nsSupportContextStack = new boolean[32];
+    protected int _stackCount = -1;
+
+    protected NamespaceContext _nsContext = new NamespaceContextImpl();
+
+    /**
+     * List of namespaces defined in the current element.
+     */
+    protected String[] _namespacesArray = new String[2 * 8];
+    protected int _namespacesArrayIndex = 0;
+
+    public StAXDocumentSerializer() {
+        super(true);
+    }
+
+    public StAXDocumentSerializer(OutputStream outputStream) {
+        super(true);
+        setOutputStream(outputStream);
+    }
+
+    public StAXDocumentSerializer(OutputStream outputStream, StAXManager manager) {
+        super(true);
+        setOutputStream(outputStream);
+        _manager = manager;
+    }
+
+    public void reset() {
+        super.reset();
+
+        _attributesArrayIndex = 0;
+        _namespacesArrayIndex = 0;
+        _nsSupport.reset();
+        _stackCount = -1;
+
+        _currentUri = _currentPrefix = null;
+        _currentLocalName = null;
+
+        _inStartElement = _isEmptyElement = false;
+    }
+
+    // -- XMLStreamWriter Interface -------------------------------------------
+
+    public void writeStartDocument() throws XMLStreamException {
+        writeStartDocument("finf", "1.0");
+    }
+
+    public void writeStartDocument(String version) throws XMLStreamException {
+        writeStartDocument("finf", version);
+    }
+
+    public void writeStartDocument(String encoding, String version)
+        throws XMLStreamException
+    {
+        reset();
+
+        try {
+            encodeHeader(false);
+            encodeInitialVocabulary();
+        } catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    public void writeEndDocument() throws XMLStreamException {
+        // Need to flush a pending empty element?
+        if (_inStartElement) {
+//            encodeTerminationAndCurrentElement();
+        }
+
+        try {
+            // TODO
+            // Use nsSupport to terminate all elements not terminated
+            // by writeEndElement
+
+
+            encodeDocumentTermination();
+        }
+        catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    public void close() throws XMLStreamException {
+        reset();
+    }
+
+    public void flush() throws XMLStreamException {
+        try {
+            _s.flush();
+        }
+        catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    public void writeStartElement(String localName)
+        throws XMLStreamException
+    {
+        // TODO is it necessary for FI to obtain the default namespace in scope?
+        writeStartElement("", localName, "");
+    }
+
+    public void writeStartElement(String namespaceURI, String localName)
+        throws XMLStreamException
+    {
+        writeStartElement(getPrefix(namespaceURI), localName, namespaceURI);
+    }
+
+    public void writeStartElement(String prefix, String localName,
+        String namespaceURI) throws XMLStreamException
+    {
+        encodeTerminationAndCurrentElement(false);
+
+        _inStartElement = true;
+        _isEmptyElement = false;
+
+        _currentLocalName = localName;
+        _currentPrefix = prefix;
+        _currentUri = namespaceURI;
+
+        _stackCount++;
+        if (_stackCount == _nsSupportContextStack.length) {
+            boolean[] nsSupportContextStack = new boolean[_stackCount * 2];
+            System.arraycopy(_nsSupportContextStack, 0, nsSupportContextStack, 0, _nsSupportContextStack.length);
+            _nsSupportContextStack = nsSupportContextStack;
+        }
+
+        _nsSupportContextStack[_stackCount] = false;
+        // _nsSupport.pushContext();
+    }
+
+    public void writeEmptyElement(String localName)
+        throws XMLStreamException
+    {
+        writeEmptyElement("", localName, "");
+    }
+
+    public void writeEmptyElement(String namespaceURI, String localName)
+        throws XMLStreamException
+    {
+        writeEmptyElement(getPrefix(namespaceURI), localName, namespaceURI);
+    }
+
+    public void writeEmptyElement(String prefix, String localName,
+        String namespaceURI) throws XMLStreamException
+    {
+        encodeTerminationAndCurrentElement(false);
+
+        _isEmptyElement = _inStartElement = true;
+
+        _currentLocalName = localName;
+        _currentPrefix = prefix;
+        _currentUri = namespaceURI;
+
+        _stackCount++;
+        if (_stackCount == _nsSupportContextStack.length) {
+            boolean[] nsSupportContextStack = new boolean[_stackCount * 2];
+            System.arraycopy(_nsSupportContextStack, 0, nsSupportContextStack, 0, _nsSupportContextStack.length);
+            _nsSupportContextStack = nsSupportContextStack;
+        }
+
+        _nsSupportContextStack[_stackCount] = false;
+        //_nsSupport.pushContext();
+    }
+
+    public void writeEndElement() throws XMLStreamException {
+        if (_inStartElement) {
+            encodeTerminationAndCurrentElement(false);
+        }
+
+        try {
+            encodeElementTermination();
+            if (_nsSupportContextStack[_stackCount--] == true) {
+                _nsSupport.popContext();
+            }
+        }
+        catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+        catch (EmptyStackException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+
+    public void writeAttribute(String localName, String value)
+        throws XMLStreamException
+    {
+        writeAttribute("", "", localName, value);
+    }
+
+    public void writeAttribute(String namespaceURI, String localName,
+        String value) throws XMLStreamException
+    {
+        String prefix = "";
+
+        // Find prefix for attribute, ignoring default namespace
+        if (namespaceURI.length() > 0) {
+            prefix = _nsSupport.getPrefix(namespaceURI);
+
+            // Undeclared prefix or ignorable default ns?
+            if (prefix == null || prefix.length() == 0) {
+                // Workaround for BUG in SAX NamespaceSupport helper
+                // which incorrectly defines namespace declaration URI
+                if (namespaceURI == EncodingConstants.XMLNS_NAMESPACE_NAME ||
+                        namespaceURI.equals(EncodingConstants.XMLNS_NAMESPACE_NAME)) {
+                    // TODO
+                    // Need to check carefully the rule for the writing of
+                    // namespaces in StAX. Is it safe to ignore such
+                    // attributes, as declarations will be made using the
+                    // writeNamespace method
+                    return;
+                }
+                throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.URIUnbound", new Object[]{namespaceURI}));
+            }
+        }
+        writeAttribute(prefix, namespaceURI, localName, value);
+    }
+
+    public void writeAttribute(String prefix, String namespaceURI,
+        String localName, String value) throws XMLStreamException
+    {
+        if (!_inStartElement) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.attributeWritingNotAllowed"));
+        }
+
+        // TODO
+        // Need to check carefully the rule for the writing of
+        // namespaces in StAX. Is it safe to ignore such
+        // attributes, as declarations will be made using the
+        // writeNamespace method
+        if (namespaceURI == EncodingConstants.XMLNS_NAMESPACE_NAME ||
+                namespaceURI.equals(EncodingConstants.XMLNS_NAMESPACE_NAME)) {
+            return;
+        }
+
+        if (_attributesArrayIndex == _attributesArray.length) {
+            final String[] attributesArray = new String[_attributesArrayIndex * 2];
+            System.arraycopy(_attributesArray, 0, attributesArray, 0, _attributesArrayIndex);
+            _attributesArray = attributesArray;
+        }
+
+        _attributesArray[_attributesArrayIndex++] = namespaceURI;
+        _attributesArray[_attributesArrayIndex++] = prefix;
+        _attributesArray[_attributesArrayIndex++] = localName;
+        _attributesArray[_attributesArrayIndex++] = value;
+    }
+
+    public void writeNamespace(String prefix, String namespaceURI)
+        throws XMLStreamException
+    {
+        if (prefix == null || prefix.length() == 0 || prefix.equals(EncodingConstants.XMLNS_NAMESPACE_PREFIX)) {
+            writeDefaultNamespace(namespaceURI);
+        }
+        else {
+            if (!_inStartElement) {
+                throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.attributeWritingNotAllowed"));
+            }
+
+            if (_namespacesArrayIndex == _namespacesArray.length) {
+                final String[] namespacesArray = new String[_namespacesArrayIndex * 2];
+                System.arraycopy(_namespacesArray, 0, namespacesArray, 0, _namespacesArrayIndex);
+                _namespacesArray = namespacesArray;
+            }
+
+            _namespacesArray[_namespacesArrayIndex++] = prefix;
+            _namespacesArray[_namespacesArrayIndex++] = namespaceURI;
+        }
+    }
+
+    public void writeDefaultNamespace(String namespaceURI)
+        throws XMLStreamException
+    {
+        if (!_inStartElement) {
+            throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.attributeWritingNotAllowed"));
+        }
+
+        if (_namespacesArrayIndex == _namespacesArray.length) {
+            final String[] namespacesArray = new String[_namespacesArrayIndex * 2];
+            System.arraycopy(_namespacesArray, 0, namespacesArray, 0, _namespacesArrayIndex);
+            _namespacesArray = namespacesArray;
+        }
+
+        _namespacesArray[_namespacesArrayIndex++] = "";
+        _namespacesArray[_namespacesArrayIndex++] = namespaceURI;
+    }
+
+    public void writeComment(String data) throws XMLStreamException {
+        try {
+            if (getIgnoreComments()) return;
+
+            encodeTerminationAndCurrentElement(true);
+
+            // TODO: avoid array copy here
+            encodeComment(data.toCharArray(), 0, data.length());
+        }
+        catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    public void writeProcessingInstruction(String target)
+        throws XMLStreamException
+    {
+        writeProcessingInstruction(target, "");
+    }
+
+    public void writeProcessingInstruction(String target, String data)
+        throws XMLStreamException
+    {
+        try {
+            if (getIgnoreProcesingInstructions()) return;
+
+            encodeTerminationAndCurrentElement(true);
+
+            encodeProcessingInstruction(target, data);
+        }
+        catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    public void writeCData(String data) throws XMLStreamException {
+        throw new UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.notImplemented"));
+   }
+
+    public void writeDTD(String dtd) throws XMLStreamException {
+        throw new UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.notImplemented"));
+    }
+
+    public void writeEntityRef(String name) throws XMLStreamException {
+        throw new UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.notImplemented"));
+    }
+
+    public void writeCharacters(String text) throws XMLStreamException {
+         try {
+            final int length = text.length();
+            if (length == 0) {
+                return;
+            } else if (length < _charBuffer.length) {
+                if (getIgnoreWhiteSpaceTextContent() &&
+                        isWhiteSpace(text)) return;
+
+                // Warning: this method must be called before any state
+                // is modified, such as the _charBuffer contents,
+                // so the characters of text cannot be copied to _charBuffer
+                // before this call
+                encodeTerminationAndCurrentElement(true);
+
+                text.getChars(0, length, _charBuffer, 0);
+                encodeCharacters(_charBuffer, 0, length);
+            } else {
+                final char ch[] = text.toCharArray();
+                if (getIgnoreWhiteSpaceTextContent() &&
+                        isWhiteSpace(ch, 0, length)) return;
+
+                encodeTerminationAndCurrentElement(true);
+
+                encodeCharactersNoClone(ch, 0, length);
+            }
+        }
+        catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    public void writeCharacters(char[] text, int start, int len)
+        throws XMLStreamException
+    {
+         try {
+            if (len <= 0) {
+                return;
+            }
+
+            if (getIgnoreWhiteSpaceTextContent() &&
+                    isWhiteSpace(text, start, len)) return;
+
+            encodeTerminationAndCurrentElement(true);
+
+            encodeCharacters(text, start, len);
+        }
+        catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    public String getPrefix(String uri) throws XMLStreamException {
+        return _nsSupport.getPrefix(uri);
+    }
+
+    public void setPrefix(String prefix, String uri)
+        throws XMLStreamException
+    {
+        if (_stackCount > -1 && _nsSupportContextStack[_stackCount] == false) {
+            _nsSupportContextStack[_stackCount] = true;
+            _nsSupport.pushContext();
+        }
+
+        _nsSupport.declarePrefix(prefix, uri);
+    }
+
+    public void setDefaultNamespace(String uri) throws XMLStreamException {
+        setPrefix("", uri);
+    }
+
+    /**
+     * Sets the current namespace context for prefix and uri bindings.
+     * This context becomes the root namespace context for writing and
+     * will replace the current root namespace context.  Subsequent calls
+     * to setPrefix and setDefaultNamespace will bind namespaces using
+     * the context passed to the method as the root context for resolving
+     * namespaces.  This method may only be called once at the start of
+     * the document.  It does not cause the namespaces to be declared.
+     * If a namespace URI to prefix mapping is found in the namespace
+     * context it is treated as declared and the prefix may be used
+     * by the StreamWriter.
+     * @param context the namespace context to use for this writer, may not be null
+     * @throws XMLStreamException
+     */
+    public void setNamespaceContext(NamespaceContext context)
+        throws XMLStreamException
+    {
+        throw new UnsupportedOperationException("setNamespaceContext");
+    }
+
+    public NamespaceContext getNamespaceContext() {
+        return _nsContext;
+    }
+
+    public Object getProperty(java.lang.String name)
+        throws IllegalArgumentException
+    {
+        if (_manager != null) {
+            return _manager.getProperty(name);
+        }
+        return null;
+    }
+
+    public void setManager(StAXManager manager) {
+        _manager = manager;
+    }
+
+    public void setEncoding(String encoding) {
+        _encoding = encoding;
+    }
+
+    protected class NamespaceContextImpl implements NamespaceContext {
+        public final String getNamespaceURI(String prefix) {
+            return _nsSupport.getURI(prefix);
+        }
+
+        public final String getPrefix(String namespaceURI) {
+            return _nsSupport.getPrefix(namespaceURI);
+        }
+
+        public final Iterator getPrefixes(String namespaceURI) {
+            final Enumeration e = _nsSupport.getPrefixes(namespaceURI);
+
+            return new Iterator() {
+                    public boolean hasNext() {
+                        return e.hasMoreElements();
+                    }
+
+                    public Object next() {
+                        return e.nextElement();
+                    }
+
+                    public void remove() {
+                        throw new UnsupportedOperationException();
+                    }
+                };
+        }
+    }
+
+    public void writeOctets(byte[] b, int start, int len)
+        throws XMLStreamException
+    {
+         try {
+            if (len == 0) {
+                return;
+            }
+
+            encodeTerminationAndCurrentElement(true);
+
+            encodeCIIOctetAlgorithmData(EncodingAlgorithmIndexes.BASE64, b, start, len);
+        }
+        catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    protected void encodeTerminationAndCurrentElement(boolean terminateAfter) throws XMLStreamException {
+        try {
+            encodeTermination();
+
+            if (_inStartElement) {
+
+                _b = EncodingConstants.ELEMENT;
+                if (_attributesArrayIndex > 0) {
+                    _b |= EncodingConstants.ELEMENT_ATTRIBUTE_FLAG;
+                }
+
+                // Encode namespace decls associated with this element
+                if (_namespacesArrayIndex > 0) {
+                    write(_b | EncodingConstants.ELEMENT_NAMESPACES_FLAG);
+                    for (int i = 0; i < _namespacesArrayIndex;) {
+                        encodeNamespaceAttribute(_namespacesArray[i++], _namespacesArray[i++]);
+                    }
+                    _namespacesArrayIndex = 0;
+
+                    write(EncodingConstants.TERMINATOR);
+
+                    _b = 0;
+                }
+
+                // Encode element and its attributes
+                encodeElementQualifiedNameOnThirdBit(_currentUri, _currentPrefix, _currentLocalName);
+
+                for (int i = 0; i < _attributesArrayIndex;) {
+                    encodeAttributeQualifiedNameOnSecondBit(
+                            _attributesArray[i++], _attributesArray[i++], _attributesArray[i++]);
+
+                    final String value = _attributesArray[i];
+                    _attributesArray[i++] = null;
+                    final boolean addToTable = (value.length() < attributeValueSizeConstraint) ? true : false;
+                    encodeNonIdentifyingStringOnFirstBit(value, _v.attributeValue, addToTable);
+
+                    _b = EncodingConstants.TERMINATOR;
+                    _terminate = true;
+                }
+                _attributesArrayIndex = 0;
+                _inStartElement = false;
+
+                if (_isEmptyElement) {
+                    encodeElementTermination();
+                    if (_nsSupportContextStack[_stackCount--] == true) {
+                        _nsSupport.popContext();
+                    }
+
+                    _isEmptyElement = false;
+                }
+
+                if (terminateAfter) {
+                    encodeTermination();
+                }
+            }
+        } catch (IOException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXManager.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXManager.java
new file mode 100644
index 0000000..c37b371
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/StAXManager.java
@@ -0,0 +1,156 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax;
+
+import java.util.HashMap;
+import javax.xml.stream.XMLInputFactory;
+import javax.xml.stream.XMLOutputFactory;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class StAXManager {
+    protected static final String STAX_NOTATIONS = "javax.xml.stream.notations";
+    protected static final String STAX_ENTITIES = "javax.xml.stream.entities";
+
+    HashMap features = new HashMap();
+
+    public static final int CONTEXT_READER = 1;
+    public static final int CONTEXT_WRITER = 2;
+
+
+    /** Creates a new instance of StAXManager */
+    public StAXManager() {
+    }
+
+    public StAXManager(int context) {
+        switch(context){
+            case CONTEXT_READER:{
+                initConfigurableReaderProperties();
+                break;
+            }
+            case CONTEXT_WRITER:{
+                initWriterProps();
+                break;
+            }
+        }
+    }
+
+    public StAXManager(StAXManager manager){
+
+        HashMap properties = manager.getProperties();
+        features.putAll(properties);
+    }
+
+    private HashMap getProperties(){
+        return features ;
+    }
+
+    private void initConfigurableReaderProperties(){
+        //spec v1.0 default values
+        features.put(XMLInputFactory.IS_NAMESPACE_AWARE, Boolean.TRUE);
+        features.put(XMLInputFactory.IS_VALIDATING, Boolean.FALSE);
+        features.put(XMLInputFactory.IS_REPLACING_ENTITY_REFERENCES, Boolean.TRUE);
+        features.put(XMLInputFactory.IS_SUPPORTING_EXTERNAL_ENTITIES, Boolean.TRUE);
+        features.put(XMLInputFactory.IS_COALESCING, Boolean.FALSE);
+        features.put(XMLInputFactory.SUPPORT_DTD, Boolean.FALSE);
+        features.put(XMLInputFactory.REPORTER, null);
+        features.put(XMLInputFactory.RESOLVER, null);
+        features.put(XMLInputFactory.ALLOCATOR, null);
+        features.put(STAX_NOTATIONS,null );
+    }
+
+    private void initWriterProps(){
+        features.put(XMLOutputFactory.IS_REPAIRING_NAMESPACES , Boolean.FALSE);
+    }
+
+    /**
+     * public void reset(){
+     * features.clear() ;
+     * }
+     */
+    public boolean containsProperty(String property){
+        return features.containsKey(property) ;
+    }
+
+    public Object getProperty(String name){
+        checkProperty(name);
+        return features.get(name);
+    }
+
+    public void setProperty(String name, Object value){
+        checkProperty(name);
+        if (name.equals(XMLInputFactory.IS_VALIDATING) &&
+                Boolean.TRUE.equals(value)){
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.validationNotSupported") +
+                    CommonResourceBundle.getInstance().getString("support_validation"));
+        } else if (name.equals(XMLInputFactory.IS_SUPPORTING_EXTERNAL_ENTITIES) &&
+                Boolean.TRUE.equals(value)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.externalEntities") +
+                    CommonResourceBundle.getInstance().getString("resolve_external_entities_"));
+        }
+        features.put(name,value);
+
+    }
+
+    public void checkProperty(String name) {
+        if (!features.containsKey(name))
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.propertyNotSupported", new Object[]{name}));
+    }
+
+    public String toString(){
+        return features.toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/AttributeBase.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/AttributeBase.java
new file mode 100644
index 0000000..b2b6d41
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/AttributeBase.java
@@ -0,0 +1,166 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.events.Attribute;
+
+import com.sun.xml.internal.fastinfoset.stax.events.Util;
+
+
+public class AttributeBase extends EventBase implements Attribute
+
+{
+    //an Attribute consists of a qualified name and value
+    private QName _QName;
+    private String _value;
+
+    private String _attributeType = null;
+    //A flag indicating whether this attribute was actually specified in the start-tag
+    //of its element or was defaulted from the schema.
+    private boolean _specified = false;
+
+    public AttributeBase(){
+        super(ATTRIBUTE);
+    }
+
+    public AttributeBase(String name, String value) {
+        super(ATTRIBUTE);
+        _QName = new QName(name);
+        _value = value;
+    }
+
+    public AttributeBase(QName qname, String value) {
+        _QName = qname;
+        _value = value;
+    }
+
+    public AttributeBase(String prefix, String localName, String value) {
+        this(prefix, null,localName, value, null);
+    }
+
+    public AttributeBase(String prefix, String namespaceURI, String localName,
+                        String value, String attributeType) {
+        if (prefix == null) prefix = "";
+        _QName = new QName(namespaceURI, localName,prefix);
+        _value = value;
+        _attributeType = (attributeType == null) ? "CDATA":attributeType;
+    }
+
+
+    public void setName(QName name){
+        _QName = name ;
+    }
+
+  /**
+   * Returns the QName for this attribute
+   */
+    public QName getName() {
+        return _QName;
+    }
+
+    public void setValue(String value){
+        _value = value;
+    }
+
+    public String getLocalName() {
+        return _QName.getLocalPart();
+    }
+  /**
+   * Gets the normalized value of this attribute
+   */
+    public String getValue() {
+        return _value;
+    }
+
+    public void setAttributeType(String attributeType){
+        _attributeType = attributeType ;
+    }
+
+    /**
+   * Gets the type of this attribute, default is
+   * the String "CDATA"
+   * @return the type as a String, default is "CDATA"
+   */
+    public String getDTDType() {
+        return _attributeType;
+    }
+
+
+  /**
+   * A flag indicating whether this attribute was actually
+   * specified in the start-tag of its element, or was defaulted from the schema.
+   * @return returns true if this was specified in the start element
+   */
+    public boolean isSpecified() {
+        return _specified ;
+    }
+
+    public void setSpecified(boolean isSpecified){
+        _specified = isSpecified ;
+    }
+
+
+    public String toString() {
+        String prefix = _QName.getPrefix();
+        if (!Util.isEmptyString(prefix))
+            return prefix + ":" + _QName.getLocalPart() + "='" + _value + "'";
+
+        return _QName.getLocalPart() + "='" + _value + "'";
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/CharactersEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/CharactersEvent.java
new file mode 100644
index 0000000..1f39b7a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/CharactersEvent.java
@@ -0,0 +1,169 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+import com.sun.xml.internal.fastinfoset.org.apache.xerces.util.XMLChar;
+import javax.xml.stream.events.Characters;
+
+import com.sun.xml.internal.fastinfoset.stax.events.Util;
+
+public class CharactersEvent extends EventBase implements Characters {
+    private String _text;
+    private boolean isCData=false;
+    private boolean isSpace=false;
+    private boolean isIgnorable=false;
+    private boolean needtoCheck = true;
+
+    public CharactersEvent() {
+        super(CHARACTERS);
+    }
+    /**
+     *
+     * @param data Character Data.
+     */
+    public CharactersEvent(String data) {
+        super(CHARACTERS);
+        _text = data;
+    }
+
+    /**
+     *
+     * @param data Character Data.
+     * @param isCData true if is CData
+     */
+    public CharactersEvent(String data, boolean isCData) {
+        super(CHARACTERS);
+        _text = data;
+        this.isCData = isCData;
+    }
+
+  /**
+   * Get the character data of this event
+   */
+   public String getData() {
+        return _text;
+    }
+
+    public void setData(String data){
+        _text = data;
+    }
+
+    /**
+     *
+     * @return boolean returns true if the data is CData
+     */
+    public boolean isCData() {
+        return isCData;
+    }
+
+    /**
+     *
+     * @return String return the String representation of this event.
+     */
+    public String toString() {
+        if(isCData)
+            return "<![CDATA[" + _text + "]]>";
+        else
+            return _text;
+    }
+
+    /**
+     * Return true if this is ignorableWhiteSpace.  If
+     * this event is ignorableWhiteSpace its event type will
+     * be SPACE.
+     * @return boolean true if this is ignorableWhiteSpace.
+     */
+    public boolean isIgnorableWhiteSpace() {
+        return isIgnorable;
+    }
+
+    /**
+     * Returns true if this set of Characters are all whitespace.  Whitspace inside a document
+     * is reported as CHARACTERS.  This method allows checking of CHARACTERS events to see
+     * if they are composed of only whitespace characters
+     * @return boolean true if this set of Characters are all whitespace
+     */
+    public boolean isWhiteSpace() {
+        //no synchronization checks made.
+        if(needtoCheck){
+            checkWhiteSpace();
+            needtoCheck = false;
+        }
+        return isSpace;
+    }
+
+    public void setSpace(boolean isSpace) {
+        this.isSpace = isSpace;
+        needtoCheck = false;
+    }
+    public void setIgnorable(boolean isIgnorable){
+        this.isIgnorable = isIgnorable;
+        setEventType(SPACE);
+    }
+    private void checkWhiteSpace(){
+        //refer to xerces XMLChar
+        if(!Util.isEmptyString(_text)){
+            isSpace = true;
+            for(int i=0;i<_text.length();i++){
+                if(!XMLChar.isSpace(_text.charAt(i))){
+                    isSpace = false;
+                    break;
+                }
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/CommentEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/CommentEvent.java
new file mode 100644
index 0000000..4731425
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/CommentEvent.java
@@ -0,0 +1,94 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+
+import javax.xml.stream.events.Comment;
+
+public class CommentEvent extends EventBase implements Comment {
+
+    /* String data for this event */
+    private String _text;
+
+    public CommentEvent() {
+        super(COMMENT);
+    }
+
+    public CommentEvent(String text) {
+        this();
+        _text = text;
+    }
+
+
+    /**
+     * @return String String representation of this event
+     */
+    public String toString() {
+        return "<!--" + _text + "-->";
+    }
+
+  /**
+   * Return the string data of the comment, returns empty string if it
+   * does not exist
+   */
+    public String getText() {
+        return _text ;
+    }
+
+    public void setText(String text) {
+        _text = text;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/DTDEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/DTDEvent.java
new file mode 100644
index 0000000..e95c24b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/DTDEvent.java
@@ -0,0 +1,139 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import java.util.List;
+
+import javax.xml.stream.events.DTD;
+import javax.xml.stream.events.EntityDeclaration;
+import javax.xml.stream.events.NotationDeclaration;
+
+/**
+ * DTDEvent. Notations and Entities are not used
+ */
+public class DTDEvent extends EventBase implements DTD{
+
+    private String _dtd;
+    private List _notations;
+    private List _entities;
+
+    /** Creates a new instance of DTDEvent */
+    public DTDEvent() {
+        setEventType(DTD);
+    }
+
+    public DTDEvent(String dtd){
+        setEventType(DTD);
+        _dtd = dtd;
+    }
+
+   /**
+   * Returns the entire Document Type Declaration as a string, including
+   * the internal DTD subset.
+   * This may be null if there is not an internal subset.
+   * If it is not null it must return the entire
+   * Document Type Declaration which matches the doctypedecl
+   * production in the XML 1.0 specification
+   */
+   public String getDocumentTypeDeclaration() {
+        return _dtd;
+    }
+   public void setDTD(String dtd){
+        _dtd = dtd;
+    }
+
+   /**
+   * Return a List containing the general entities,
+   * both external and internal, declared in the DTD.
+   * This list must contain EntityDeclaration events.
+   * @see EntityDeclaration
+   * @return an unordered list of EntityDeclaration events
+   */
+    public List getEntities() {
+        return _entities;
+    }
+
+   /**
+   * Return a List containing the notations declared in the DTD.
+   * This list must contain NotationDeclaration events.
+   * @see NotationDeclaration
+   * @return an unordered list of NotationDeclaration events
+   */
+   public List getNotations() {
+        return _notations;
+    }
+
+    /**
+     *Returns an implementation defined representation of the DTD.
+     * This method may return null if no representation is available.
+     *
+     */
+    public Object getProcessedDTD() {
+        return null;
+    }
+
+    public void setEntities(List entites){
+        _entities = entites;
+    }
+
+    public void setNotations(List notations){
+        _notations = notations;
+    }
+
+    public String toString(){
+        return _dtd ;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EmptyIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EmptyIterator.java
new file mode 100644
index 0000000..4413d88
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EmptyIterator.java
@@ -0,0 +1,78 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+import java.util.Iterator;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+public class EmptyIterator implements Iterator {
+    public static final EmptyIterator instance = new EmptyIterator();
+    /** Creates a new instance of EmptyIterator */
+    private EmptyIterator() {
+    }
+    public static EmptyIterator getInstance() {
+        return instance;
+    }
+    public boolean hasNext() {
+        return false;
+    }
+    public Object next() {
+        return null;
+    }
+    public void remove() {
+         throw new  UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.emptyIterator"));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EndDocumentEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EndDocumentEvent.java
new file mode 100644
index 0000000..ead84b1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EndDocumentEvent.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+import javax.xml.stream.events.EndDocument;
+
+
+public class EndDocumentEvent extends EventBase implements EndDocument {
+
+    public EndDocumentEvent() {
+        super(END_DOCUMENT);
+    }
+
+    public String toString() {
+        return "<? EndDocument ?>";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EndElementEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EndElementEvent.java
new file mode 100644
index 0000000..ccb75cc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EndElementEvent.java
@@ -0,0 +1,154 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.events.EndElement;
+import javax.xml.stream.events.Namespace;
+
+import com.sun.xml.internal.fastinfoset.stax.events.EmptyIterator;
+
+
+public class EndElementEvent extends EventBase implements EndElement {
+
+    List _namespaces = null;
+    QName _qname ;
+
+    public void reset() {
+        if (_namespaces != null) _namespaces.clear();
+    }
+
+    public EndElementEvent() {
+        setEventType(END_ELEMENT);
+    }
+
+    public EndElementEvent(String namespaceURI, String localpart, String prefix) {
+        _qname = getQName(namespaceURI,localpart,prefix);
+        setEventType(END_ELEMENT);
+    }
+
+    public EndElementEvent(QName qname) {
+        _qname = qname;
+        setEventType(END_ELEMENT);
+    }
+
+  /**
+   * Get the name of this event
+   * @return the qualified name of this event
+   */
+    public QName getName() {
+        return _qname;
+    }
+
+    public void setName(QName qname) {
+        _qname = qname;
+    }
+
+
+    /** Returns an Iterator of namespaces that have gone out
+     * of scope.  Returns an empty iterator if no namespaces have gone
+     * out of scope.
+     * @return an Iterator over Namespace interfaces, or an
+     * empty iterator
+     */
+    public Iterator getNamespaces() {
+        if(_namespaces != null)
+            return _namespaces.iterator();
+        return EmptyIterator.getInstance();
+    }
+
+    public void addNamespace(Namespace namespace){
+        if (_namespaces == null) {
+            _namespaces = new ArrayList();
+        }
+        _namespaces.add(namespace);
+    }
+
+    public String toString() {
+        StringBuffer sb = new StringBuffer();
+        sb.append("</").append(nameAsString());
+        Iterator namespaces = getNamespaces();
+        while(namespaces.hasNext()) {
+            sb.append(" ").append(namespaces.next().toString());
+        }
+        sb.append(">");
+        return sb.toString();
+    }
+
+
+    private String nameAsString() {
+        if("".equals(_qname.getNamespaceURI()))
+            return _qname.getLocalPart();
+        if(_qname.getPrefix() != null)
+            return "['" + _qname.getNamespaceURI() + "']:" + _qname.getPrefix() + ":" + _qname.getLocalPart();
+        else
+            return "['" + _qname.getNamespaceURI() + "']:" + _qname.getLocalPart();
+    }
+    private QName getQName(String uri, String localPart, String prefix){
+        QName qn = null;
+        if(prefix != null && uri != null)
+            qn = new QName(uri, localPart, prefix);
+        else if(prefix == null && uri != null)
+            qn = new QName(uri, localPart);
+        else if(prefix == null && uri == null)
+            qn = new QName(localPart);
+        return qn;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EntityDeclarationImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EntityDeclarationImpl.java
new file mode 100644
index 0000000..bb7df06
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EntityDeclarationImpl.java
@@ -0,0 +1,146 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import javax.xml.stream.events.EntityDeclaration;
+
+
+public class EntityDeclarationImpl extends EventBase implements EntityDeclaration {
+    private String _publicId;
+    private String _systemId;
+    private String _baseURI;
+    private String _entityName;
+    private String _replacement;
+    private String _notationName;
+
+    /** Creates a new instance of EntityDeclarationImpl */
+    public EntityDeclarationImpl() {
+        init();
+    }
+
+    public EntityDeclarationImpl(String entityName , String replacement){
+        init();
+        _entityName = entityName;
+        _replacement = replacement;
+    }
+
+    /**
+    * The entity's public identifier, or null if none was given
+    * @return the public ID for this declaration or null
+    */
+    public String getPublicId(){
+        return _publicId;
+    }
+
+    /**
+    * The entity's system identifier.
+    * @return the system ID for this declaration or null
+    */
+    public String getSystemId(){
+        return _systemId;
+    }
+
+    /**
+    * The entity's name
+    * @return the name, may not be null
+    */
+    public String getName(){
+        return _entityName;
+    }
+
+    /**
+    * The name of the associated notation.
+    * @return the notation name
+    */
+    public String getNotationName() {
+        return _notationName;
+    }
+
+    /**
+    * The replacement text of the entity.
+    * This method will only return non-null
+    * if this is an internal entity.
+    * @return null or the replacment text
+    */
+    public String getReplacementText() {
+        return _replacement;
+    }
+
+    /**
+    * Get the base URI for this reference
+    * or null if this information is not available
+    * @return the base URI or null
+    */
+    public String getBaseURI() {
+        return _baseURI;
+    }
+
+    public void setName(String entityName){
+        _entityName = entityName;
+    }
+
+    public void setReplacementText(String replacement){
+        _replacement = replacement;
+    }
+
+    public void setNotationName(String notationName){
+        _notationName = notationName;
+    }
+
+    protected void init(){
+        setEventType(ENTITY_DECLARATION);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EntityReferenceEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EntityReferenceEvent.java
new file mode 100644
index 0000000..b52b950
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EntityReferenceEvent.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+import javax.xml.stream.events.EntityDeclaration;
+import javax.xml.stream.events.EntityReference;
+
+
+public class EntityReferenceEvent extends EventBase implements EntityReference {
+    private EntityDeclaration _entityDeclaration ;
+    private String _entityName;
+
+    public EntityReferenceEvent() {
+        init();
+    }
+
+    public EntityReferenceEvent(String entityName , EntityDeclaration entityDeclaration) {
+        init();
+        _entityName = entityName;
+        _entityDeclaration = entityDeclaration;
+    }
+
+  /**
+   * The name of the entity
+   * @return the entity's name, may not be null
+   */
+    public String getName() {
+        return _entityName;
+    }
+
+  /**
+   * Return the declaration of this entity.
+   */
+    public EntityDeclaration getDeclaration(){
+        return _entityDeclaration ;
+    }
+
+    public void setName(String name){
+        _entityName = name;
+    }
+
+    public void setDeclaration(EntityDeclaration declaration) {
+        _entityDeclaration = declaration ;
+    }
+
+    public String toString() {
+        String text = _entityDeclaration.getReplacementText();
+        if(text == null)
+            text = "";
+        return "&" + getName() + ";='" + text + "'";
+    }
+
+    protected void init() {
+        setEventType(ENTITY_REFERENCE);
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EventBase.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EventBase.java
new file mode 100644
index 0000000..9e8e443
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/EventBase.java
@@ -0,0 +1,249 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+import javax.xml.stream.Location;
+import javax.xml.stream.events.XMLEvent;
+import javax.xml.stream.events.Characters;
+import javax.xml.stream.events.EndElement;
+import javax.xml.stream.events.StartElement;
+import javax.xml.namespace.QName;
+import java.io.Writer;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+public abstract class EventBase implements XMLEvent {
+
+    /* Event type this event corresponds to */
+    protected int _eventType;
+    protected Location _location = null;
+
+    public EventBase() {
+
+    }
+
+    public EventBase(int eventType) {
+        _eventType = eventType;
+    }
+
+    /**
+    * Returns an integer code for this event.
+    */
+    public int getEventType() {
+        return _eventType;
+    }
+
+    protected void setEventType(int eventType){
+        _eventType = eventType;
+    }
+
+
+    public boolean isStartElement() {
+        return _eventType == START_ELEMENT;
+    }
+
+    public boolean isEndElement() {
+        return _eventType == END_ELEMENT;
+    }
+
+    public boolean isEntityReference() {
+        return _eventType == ENTITY_REFERENCE;
+    }
+
+    public boolean isProcessingInstruction() {
+        return _eventType == PROCESSING_INSTRUCTION;
+    }
+
+    public boolean isStartDocument() {
+        return _eventType == START_DOCUMENT;
+    }
+
+    public boolean isEndDocument() {
+        return _eventType == END_DOCUMENT;
+    }
+
+  /**
+   * Return the location of this event.  The Location
+   * returned from this method is non-volatile and
+   * will retain its information.
+   * @see javax.xml.stream.Location
+   */
+    public Location getLocation(){
+        return _location;
+    }
+
+    public void setLocation(Location loc){
+        _location = loc;
+    }
+    public String getSystemId() {
+        if(_location == null )
+            return "";
+        else
+            return _location.getSystemId();
+    }
+
+    /** Returns this event as Characters, may result in
+     * a class cast exception if this event is not Characters.
+     */
+    public Characters asCharacters() {
+        if (isCharacters()) {
+            return (Characters)this;
+        } else
+            throw new ClassCastException(CommonResourceBundle.getInstance().getString("message.charactersCast", new Object[]{getEventTypeString()}));
+    }
+
+    /** Returns this event as an end  element event, may result in
+     * a class cast exception if this event is not a end element.
+     */
+    public EndElement asEndElement() {
+        if (isEndElement()) {
+            return (EndElement)this;
+        } else
+            throw new ClassCastException(CommonResourceBundle.getInstance().getString("message.endElementCase", new Object[]{getEventTypeString()}));
+    }
+
+  /**
+   * Returns this event as a start element event, may result in
+   * a class cast exception if this event is not a start element.
+   */
+    public StartElement asStartElement() {
+        if (isStartElement()) {
+            return (StartElement)this;
+        } else
+            throw new ClassCastException(CommonResourceBundle.getInstance().getString("message.startElementCase", new Object[]{getEventTypeString()}));
+    }
+
+    /**
+    * This method is provided for implementations to provide
+    * optional type information about the associated event.
+    * It is optional and will return null if no information
+    * is available.
+    */
+    public QName getSchemaType() {
+        return null;
+    }
+
+    /** A utility function to check if this event is an Attribute.
+     * @see javax.xml.stream.events.Attribute
+     */
+    public boolean isAttribute() {
+        return _eventType == ATTRIBUTE;
+    }
+
+    /** A utility function to check if this event is Characters.
+     * @see javax.xml.stream.events.Characters
+     */
+    public boolean isCharacters() {
+        return _eventType == CHARACTERS;
+    }
+
+    /** A utility function to check if this event is a Namespace.
+     * @see javax.xml.stream.events.Namespace
+     */
+    public boolean isNamespace() {
+        return _eventType == NAMESPACE;
+    }
+
+
+    /**
+    * This method will write the XMLEvent as per the XML 1.0 specification as Unicode characters.
+    * No indentation or whitespace should be outputted.
+    *
+    * Any user defined event type SHALL have this method
+    * called when being written to on an output stream.
+    * Built in Event types MUST implement this method,
+    * but implementations MAY choose not call these methods
+    * for optimizations reasons when writing out built in
+    * Events to an output stream.
+    * The output generated MUST be equivalent in terms of the
+    * infoset expressed.
+    *
+    * @param writer The writer that will output the data
+    * @throws XMLStreamException if there is a fatal error writing the event
+    */
+    public void writeAsEncodedUnicode(Writer writer) throws javax.xml.stream.XMLStreamException {
+    }
+
+    private String getEventTypeString() {
+        switch (_eventType){
+            case START_ELEMENT:
+                return "StartElementEvent";
+            case END_ELEMENT:
+                return "EndElementEvent";
+            case PROCESSING_INSTRUCTION:
+                return "ProcessingInstructionEvent";
+            case CHARACTERS:
+                return "CharacterEvent";
+            case COMMENT:
+                return "CommentEvent";
+            case START_DOCUMENT:
+                return "StartDocumentEvent";
+            case END_DOCUMENT:
+                return "EndDocumentEvent";
+            case ENTITY_REFERENCE:
+                return "EntityReferenceEvent";
+            case ATTRIBUTE:
+                return "AttributeBase";
+            case DTD:
+                return "DTDEvent";
+            case CDATA:
+                return "CDATA";
+        }
+        return "UNKNOWN_EVENT_TYPE";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/NamespaceBase.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/NamespaceBase.java
new file mode 100644
index 0000000..76b9f2b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/NamespaceBase.java
@@ -0,0 +1,129 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.events.Namespace;
+
+import com.sun.xml.internal.fastinfoset.stax.events.Util;
+
+public class NamespaceBase extends AttributeBase implements Namespace{
+    //J2SE1.5.0 javax.xml.XMLConstants
+    static final String DEFAULT_NS_PREFIX = "";
+    static final String XML_NS_URI = "http://www.w3.org/XML/1998/namespace";
+    static final String XML_NS_PREFIX = "xml";
+    static final String XMLNS_ATTRIBUTE_NS_URI = "http://www.w3.org/2000/xmlns/";
+    static final String XMLNS_ATTRIBUTE = "xmlns";
+    static final String W3C_XML_SCHEMA_NS_URI = "http://www.w3.org/2001/XMLSchema";
+    static final String W3C_XML_SCHEMA_INSTANCE_NS_URI = "http://www.w3.org/2001/XMLSchema-instance";
+
+    //is this namespace default declaration?
+    private boolean defaultDeclaration = false;
+
+    /** a namespace attribute has a form: xmlns:NCName="URI reference" */
+    public NamespaceBase(String namespaceURI) {
+        super(XMLNS_ATTRIBUTE, "", namespaceURI);
+        setEventType(NAMESPACE);
+    }
+
+  /**
+   * Create a new Namespace
+   * @param prefix prefix of a namespace is the local name for an attribute
+   * @param namespaceURI the uri reference of a namespace is the value for an attribute
+   */
+    public NamespaceBase(String prefix, String namespaceURI){
+        super(XMLNS_ATTRIBUTE, prefix, namespaceURI);
+        setEventType(NAMESPACE);
+        if (Util.isEmptyString(prefix)) {
+            defaultDeclaration=true;
+        }
+    }
+
+    void setPrefix(String prefix){
+        if(prefix == null)
+            setName(new QName(XMLNS_ATTRIBUTE_NS_URI,DEFAULT_NS_PREFIX,XMLNS_ATTRIBUTE));
+        else// new QName(uri, localpart, prefix)
+            setName(new QName(XMLNS_ATTRIBUTE_NS_URI,prefix,XMLNS_ATTRIBUTE));
+    }
+
+    public String getPrefix() {
+        if (defaultDeclaration) return "";
+        return super.getLocalName();
+    }
+
+
+  /**
+   * set Namespace URI reference (xmlns:prefix = "uri")
+   * @param uri the uri reference of a namespace is the value for an attribute
+   */
+    void setNamespaceURI(String uri) {
+        setValue(uri);
+    }
+    public String getNamespaceURI() {
+        return getValue();
+    }
+
+
+    public boolean isNamespace(){
+        return true;
+    }
+
+    public boolean isDefaultNamespaceDeclaration() {
+        return defaultDeclaration;
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/ProcessingInstructionEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/ProcessingInstructionEvent.java
new file mode 100644
index 0000000..f8b95a7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/ProcessingInstructionEvent.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.events.ProcessingInstruction;
+
+
+public class ProcessingInstructionEvent extends EventBase implements ProcessingInstruction {
+
+    private String targetName;
+    private String _data;
+
+    public ProcessingInstructionEvent() {
+        init();
+    }
+
+    public ProcessingInstructionEvent(String targetName, String data) {
+        this.targetName = targetName;
+        _data = data;
+        init();
+    }
+
+    protected void init() {
+        setEventType(XMLStreamConstants.PROCESSING_INSTRUCTION);
+    }
+
+    public String getTarget() {
+        return targetName;
+    }
+
+    public void setTarget(String targetName) {
+        this.targetName = targetName;
+    }
+
+    public void setData(String data) {
+        _data = data;
+    }
+
+    public String getData() {
+        return _data;
+    }
+
+    public String toString() {
+        if(_data != null && targetName != null)
+            return "<?" + targetName + " " + _data + "?>";
+        if(targetName != null)
+            return "<?" + targetName + "?>";
+        if(_data != null)
+            return "<?" + _data + "?>";
+        else
+            return "<??>";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/ReadIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/ReadIterator.java
new file mode 100644
index 0000000..a943b3a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/ReadIterator.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import java.util.Iterator;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class ReadIterator implements Iterator {
+
+    Iterator iterator = EmptyIterator.getInstance();
+
+    public ReadIterator(){
+    }
+
+    public ReadIterator(Iterator iterator){
+        if (iterator != null) {
+            this.iterator = iterator;
+        }
+    }
+
+    public boolean hasNext() {
+        return iterator.hasNext();
+    }
+
+    public Object next() {
+        return iterator.next();
+    }
+
+    public void remove() {
+        throw new  UnsupportedOperationException(CommonResourceBundle.getInstance().getString("message.readonlyList"));
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventAllocator.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventAllocator.java
new file mode 100644
index 0000000..5ca5067
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventAllocator.java
@@ -0,0 +1,264 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.events.Namespace;
+import javax.xml.stream.events.XMLEvent;
+import javax.xml.stream.util.XMLEventAllocator;
+import javax.xml.stream.util.XMLEventConsumer;
+
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+/**
+ * This class provides the same functionality as StAXEventAllocatorBase, but without
+ * using EventFactory and creating a new object for each call.
+ *
+ * It seems to be good idea using static components. Unfortunately, EventReader's peek
+ * and next methods require that multiple instances being created.
+ *
+ */
+public class StAXEventAllocator implements XMLEventAllocator {
+    StartElementEvent startElement = new StartElementEvent();
+    EndElementEvent endElement = new EndElementEvent();
+    CharactersEvent characters = new CharactersEvent();
+    CharactersEvent cData = new CharactersEvent("",true);
+    CharactersEvent space = new CharactersEvent();
+    CommentEvent comment = new CommentEvent();
+    EntityReferenceEvent entity = new EntityReferenceEvent();
+    ProcessingInstructionEvent pi = new ProcessingInstructionEvent();
+    StartDocumentEvent startDoc = new StartDocumentEvent();
+    EndDocumentEvent endDoc = new EndDocumentEvent();
+    DTDEvent dtd = new DTDEvent();
+
+    /** Creates a new instance of StAXEventAllocator */
+    public StAXEventAllocator() {
+    }
+    public XMLEventAllocator newInstance() {
+        return new StAXEventAllocator();
+    }
+
+  /**
+   * This method allocates an event given the current state of the XMLStreamReader.
+   * If this XMLEventAllocator does not have a one-to-one mapping between reader state
+   * and events this method will return null.
+   * @param streamReader The XMLStreamReader to allocate from
+   * @return the event corresponding to the current reader state
+   */
+    public XMLEvent allocate(XMLStreamReader streamReader) throws XMLStreamException {
+        if(streamReader == null )
+            throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.nullReader"));
+        return getXMLEvent(streamReader);
+    }
+
+  /**
+   * This method allocates an event or set of events given the current state of
+   * the XMLStreamReader and adds the event or set of events to the consumer that
+   * was passed in.
+   * @param streamReader The XMLStreamReader to allocate from
+   * @param consumer The XMLEventConsumer to add to.
+   */
+    public void allocate(XMLStreamReader streamReader, XMLEventConsumer consumer) throws XMLStreamException {
+        consumer.add(getXMLEvent(streamReader));
+
+    }
+    // ---------------------end of methods defined by XMLEventAllocator-----------------//
+
+
+    XMLEvent getXMLEvent(XMLStreamReader reader){
+        EventBase event = null;
+        int eventType = reader.getEventType();
+
+        switch(eventType){
+
+            case XMLEvent.START_ELEMENT:
+            {
+                startElement.reset();
+                startElement.setName(new QName(reader.getNamespaceURI(),
+                                   reader.getLocalName(), reader.getPrefix()));
+
+                addAttributes(startElement,reader);
+                addNamespaces(startElement, reader);
+                //need to fix it along with the Reader
+                //setNamespaceContext(startElement,reader);
+                event = startElement;
+                break;
+            }
+            case XMLEvent.END_ELEMENT:
+            {
+                endElement.reset();
+                endElement.setName(new QName(reader.getNamespaceURI(),
+                                 reader.getLocalName(),reader.getPrefix()));
+                addNamespaces(endElement,reader);
+                event = endElement ;
+                break;
+            }
+            case XMLEvent.PROCESSING_INSTRUCTION:
+            {
+                pi.setTarget(reader.getPITarget());
+                pi.setData(reader.getPIData());
+                event = pi;
+                break;
+            }
+            case XMLEvent.CHARACTERS:
+            {
+                characters.setData(reader.getText());
+                event = characters;
+                /**
+                if (reader.isWhiteSpace()) {
+                    space.setData(reader.getText());
+                    space.setSpace(true);
+                    event = space;
+                }
+                else {
+                    characters.setData(reader.getText());
+                    event = characters;
+                }
+                 */
+                break;
+            }
+            case XMLEvent.COMMENT:
+            {
+                comment.setText(reader.getText());
+                event = comment;
+                break;
+            }
+            case XMLEvent.START_DOCUMENT:
+            {
+                startDoc.reset();
+                String encoding = reader.getEncoding();
+                String version = reader.getVersion();
+                if (encoding != null)
+                    startDoc.setEncoding(encoding);
+                if (version != null)
+                    startDoc.setVersion(version);
+                startDoc.setStandalone(reader.isStandalone());
+                if(reader.getCharacterEncodingScheme() != null){
+                    startDoc.setDeclaredEncoding(true);
+                }else{
+                    startDoc.setDeclaredEncoding(false);
+                }
+                event = startDoc ;
+                break;
+            }
+            case XMLEvent.END_DOCUMENT:{
+                event = endDoc;
+                break;
+            }
+            case XMLEvent.ENTITY_REFERENCE:{
+                entity.setName(reader.getLocalName());
+                entity.setDeclaration(new EntityDeclarationImpl(reader.getLocalName(),reader.getText()));
+                event = entity;
+                break;
+
+            }
+            case XMLEvent.ATTRIBUTE:{
+                event = null ;
+                break;
+            }
+            case XMLEvent.DTD:{
+                dtd.setDTD(reader.getText());
+                event = dtd;
+                break;
+            }
+            case XMLEvent.CDATA:{
+                cData.setData(reader.getText());
+                event = cData;
+                break;
+            }
+            case XMLEvent.SPACE:{
+                space.setData(reader.getText());
+                space.setSpace(true);
+                event = space;
+                break;
+            }
+        }
+        event.setLocation(reader.getLocation());
+        return event ;
+    }
+
+    //use event.addAttribute instead of addAttributes to avoid creating another list
+    protected void addAttributes(StartElementEvent event,XMLStreamReader reader){
+        AttributeBase attr = null;
+        for(int i=0; i<reader.getAttributeCount() ;i++){
+            attr =  new AttributeBase(reader.getAttributeName(i), reader.getAttributeValue(i));
+            attr.setAttributeType(reader.getAttributeType(i));
+            attr.setSpecified(reader.isAttributeSpecified(i));
+            event.addAttribute(attr);
+        }
+    }
+
+    //add namespaces to StartElement/EndElement
+    protected void addNamespaces(StartElementEvent event,XMLStreamReader reader){
+        Namespace namespace = null;
+        for(int i=0; i<reader.getNamespaceCount(); i++){
+            namespace =  new NamespaceBase(reader.getNamespacePrefix(i), reader.getNamespaceURI(i));
+            event.addNamespace(namespace);
+        }
+    }
+
+    protected void addNamespaces(EndElementEvent event,XMLStreamReader reader){
+        Namespace namespace = null;
+        for(int i=0; i<reader.getNamespaceCount(); i++){
+            namespace =  new NamespaceBase(reader.getNamespacePrefix(i), reader.getNamespaceURI(i));
+            event.addNamespace(namespace);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventAllocatorBase.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventAllocatorBase.java
new file mode 100644
index 0000000..d12c460
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventAllocatorBase.java
@@ -0,0 +1,253 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import javax.xml.stream.XMLEventFactory;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.events.Namespace;
+import javax.xml.stream.events.XMLEvent;
+import javax.xml.stream.util.XMLEventAllocator;
+import javax.xml.stream.util.XMLEventConsumer;
+
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+/**
+ * allows a user to register a way to allocate events given an XMLStreamReader.
+ * The XMLEventAllocator can be set on an XMLInputFactory
+ * using the property "javax.xml.stream.allocator"
+ *
+ * This base class uses EventFactory to create events as recommended in the JavaDoc of XMLEventAllocator.
+ * However, creating new object per each event reduces performance. The implementation of
+ * EventReader therefore will set the Allocator to StAXEventAllocator which implements the
+ * Allocate methods without creating new objects.
+ *
+ * The spec for the first Allocate method states that it must NOT modify the state of the Reader
+ * while the second MAY. For consistency, both Allocate methods in this implementation will
+ * NOT modify the state.
+ *
+ */
+public class StAXEventAllocatorBase implements XMLEventAllocator {
+    XMLEventFactory factory;
+
+    /** Creates a new instance of XMLEventAllocator */
+    public StAXEventAllocatorBase() {
+        if (System.getProperty("javax.xml.stream.XMLEventFactory")==null) {
+            System.setProperty("javax.xml.stream.XMLEventFactory",
+                       "com.sun.xml.internal.fastinfoset.stax.factory.StAXEventFactory");
+        }
+        factory = XMLEventFactory.newInstance();
+    }
+
+    // ---------------------methods defined by XMLEventAllocator-----------------//
+
+  /**
+   * This method creates an instance of the XMLEventAllocator. This
+   * allows the XMLInputFactory to allocate a new instance per reader.
+   */
+    public XMLEventAllocator newInstance() {
+        return new StAXEventAllocatorBase();
+    }
+
+  /**
+   * This method allocates an event given the current state of the XMLStreamReader.
+   * If this XMLEventAllocator does not have a one-to-one mapping between reader state
+   * and events this method will return null.
+   * @param streamReader The XMLStreamReader to allocate from
+   * @return the event corresponding to the current reader state
+   */
+    public XMLEvent allocate(XMLStreamReader streamReader) throws XMLStreamException {
+        if(streamReader == null )
+            throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.nullReader"));
+        return getXMLEvent(streamReader);
+    }
+
+  /**
+   * This method allocates an event or set of events given the current state of
+   * the XMLStreamReader and adds the event or set of events to the consumer that
+   * was passed in.
+   * @param streamReader The XMLStreamReader to allocate from
+   * @param consumer The XMLEventConsumer to add to.
+   */
+    public void allocate(XMLStreamReader streamReader, XMLEventConsumer consumer) throws XMLStreamException {
+        consumer.add(getXMLEvent(streamReader));
+
+    }
+    // ---------------------end of methods defined by XMLEventAllocator-----------------//
+
+
+    XMLEvent getXMLEvent(XMLStreamReader reader){
+        XMLEvent event = null;
+        //returns the current event
+        int eventType = reader.getEventType();
+        //this needs to be set before creating events
+        factory.setLocation(reader.getLocation());
+        switch(eventType){
+
+            case XMLEvent.START_ELEMENT:
+            {
+                StartElementEvent startElement = (StartElementEvent)factory.createStartElement(reader.getPrefix(),
+                                    reader.getNamespaceURI(), reader.getLocalName());
+
+                addAttributes(startElement,reader);
+                addNamespaces(startElement, reader);
+                //need to fix it along with the Reader
+                //setNamespaceContext(startElement,reader);
+                event = startElement;
+                break;
+            }
+            case XMLEvent.END_ELEMENT:
+            {
+                EndElementEvent endElement = (EndElementEvent)factory.createEndElement(
+                        reader.getPrefix(), reader.getNamespaceURI(), reader.getLocalName());
+                addNamespaces(endElement,reader);
+                event = endElement ;
+                break;
+            }
+            case XMLEvent.PROCESSING_INSTRUCTION:
+            {
+                event = factory.createProcessingInstruction(reader.getPITarget(),reader.getPIData());
+                break;
+            }
+            case XMLEvent.CHARACTERS:
+            {
+                if (reader.isWhiteSpace())
+                  event = factory.createSpace(reader.getText());
+                else
+                  event = factory.createCharacters(reader.getText());
+
+                break;
+            }
+            case XMLEvent.COMMENT:
+            {
+                event = factory.createComment(reader.getText());
+                break;
+            }
+            case XMLEvent.START_DOCUMENT:
+            {
+                StartDocumentEvent docEvent = (StartDocumentEvent)factory.createStartDocument(
+                        reader.getVersion(), reader.getEncoding(), reader.isStandalone());
+                if(reader.getCharacterEncodingScheme() != null){
+                    docEvent.setDeclaredEncoding(true);
+                }else{
+                    docEvent.setDeclaredEncoding(false);
+                }
+                event = docEvent ;
+                break;
+            }
+            case XMLEvent.END_DOCUMENT:{
+                EndDocumentEvent endDocumentEvent = new EndDocumentEvent() ;
+                event = endDocumentEvent ;
+                break;
+            }
+            case XMLEvent.ENTITY_REFERENCE:{
+                event = factory.createEntityReference(reader.getLocalName(),
+                        new EntityDeclarationImpl(reader.getLocalName(),reader.getText()));
+                break;
+
+            }
+            case XMLEvent.ATTRIBUTE:{
+                event = null ;
+                break;
+            }
+            case XMLEvent.DTD:{
+                event = factory.createDTD(reader.getText());
+                break;
+            }
+            case XMLEvent.CDATA:{
+                event = factory.createCData(reader.getText());
+                break;
+            }
+            case XMLEvent.SPACE:{
+                event = factory.createSpace(reader.getText());
+                break;
+            }
+        }
+        return event ;
+    }
+
+    //use event.addAttribute instead of addAttributes to avoid creating another list
+    protected void addAttributes(StartElementEvent event,XMLStreamReader streamReader){
+        AttributeBase attr = null;
+        for(int i=0; i<streamReader.getAttributeCount() ;i++){
+            attr = (AttributeBase)factory.createAttribute(streamReader.getAttributeName(i),
+                                    streamReader.getAttributeValue(i));
+            attr.setAttributeType(streamReader.getAttributeType(i));
+            attr.setSpecified(streamReader.isAttributeSpecified(i));
+            event.addAttribute(attr);
+        }
+    }
+
+    //add namespaces to StartElement/EndElement
+    protected void addNamespaces(StartElementEvent event,XMLStreamReader streamReader){
+        Namespace namespace = null;
+        for(int i=0; i<streamReader.getNamespaceCount(); i++){
+            namespace = factory.createNamespace(streamReader.getNamespacePrefix(i),
+                                streamReader.getNamespaceURI(i));
+            event.addNamespace(namespace);
+        }
+    }
+    protected void addNamespaces(EndElementEvent event,XMLStreamReader streamReader){
+        Namespace namespace = null;
+        for(int i=0; i<streamReader.getNamespaceCount(); i++){
+            namespace = factory.createNamespace(streamReader.getNamespacePrefix(i),
+                                streamReader.getNamespaceURI(i));
+            event.addNamespace(namespace);
+        }
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventReader.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventReader.java
new file mode 100644
index 0000000..4cf1be0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventReader.java
@@ -0,0 +1,207 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import com.sun.xml.internal.fastinfoset.stax.*;
+import java.util.NoSuchElementException;
+import javax.xml.stream.XMLInputFactory;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.events.XMLEvent;
+import javax.xml.stream.util.XMLEventAllocator;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+
+public class StAXEventReader implements javax.xml.stream.XMLEventReader{
+    protected XMLStreamReader _streamReader ;
+    protected XMLEventAllocator _eventAllocator;
+    private XMLEvent _currentEvent;     //the current event
+    private XMLEvent[] events = new XMLEvent[3];
+    private int size = 3;
+    private int currentIndex = 0;
+    private boolean hasEvent = false;   //true when current event exists, false initially & at end
+
+    //only constructor will do because we delegate everything to underlying XMLStreamReader
+    public StAXEventReader(XMLStreamReader reader) throws  XMLStreamException {
+        _streamReader = reader ;
+        _eventAllocator = (XMLEventAllocator)reader.getProperty(XMLInputFactory.ALLOCATOR);
+        if(_eventAllocator == null){
+            _eventAllocator = new StAXEventAllocatorBase();
+        }
+        //initialize
+        if (_streamReader.hasNext())
+        {
+            _streamReader.next();
+            _currentEvent =_eventAllocator.allocate(_streamReader);
+            events[0] = _currentEvent;
+            hasEvent = true;
+        } else {
+            throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.noElement"));
+        }
+    }
+
+    public boolean hasNext() {
+        return hasEvent;
+    }
+
+    public XMLEvent nextEvent() throws XMLStreamException {
+        XMLEvent event = null;
+        XMLEvent nextEvent = null;
+        if (hasEvent)
+        {
+            event = events[currentIndex];
+            events[currentIndex] = null;
+            if (_streamReader.hasNext())
+            {
+                //advance and read the next
+                _streamReader.next();
+                nextEvent = _eventAllocator.allocate(_streamReader);
+                if (++currentIndex==size)
+                    currentIndex = 0;
+                events[currentIndex] = nextEvent;
+                hasEvent = true;
+            } else {
+                _currentEvent = null;
+                hasEvent = false;
+            }
+            return event;
+        }
+        else{
+            throw new NoSuchElementException();
+        }
+    }
+
+    public void remove(){
+        //stream reader is read-only.
+        throw new java.lang.UnsupportedOperationException();
+    }
+
+
+    public void close() throws XMLStreamException {
+        _streamReader.close();
+    }
+
+    /** Reads the content of a text-only element. Precondition:
+     * the current event is START_ELEMENT. Postcondition:
+     * The current event is the corresponding END_ELEMENT.
+     * @throws XMLStreamException if the current event is not a START_ELEMENT
+     * or if a non text element is encountered
+     */
+    public String getElementText() throws XMLStreamException {
+        if(!hasEvent) {
+            throw new NoSuchElementException();
+        }
+
+        if(!_currentEvent.isStartElement()) {
+            StAXDocumentParser parser = (StAXDocumentParser)_streamReader;
+            return parser.getElementText(true);
+        } else {
+            return _streamReader.getElementText();
+        }
+    }
+
+    /** Get the value of a feature/property from the underlying implementation
+     * @param name The name of the property
+     * @return The value of the property
+     * @throws IllegalArgumentException if the property is not supported
+     */
+    public Object getProperty(java.lang.String name) throws java.lang.IllegalArgumentException {
+        return _streamReader.getProperty(name) ;
+    }
+
+    /** Skips any insignificant space events until a START_ELEMENT or
+     * END_ELEMENT is reached. If anything other than space characters are
+     * encountered, an exception is thrown. This method should
+     * be used when processing element-only content because
+     * the parser is not able to recognize ignorable whitespace if
+     * the DTD is missing or not interpreted.
+     * @throws XMLStreamException if anything other than space characters are encountered
+     */
+    public XMLEvent nextTag() throws XMLStreamException {
+        if(!hasEvent) {
+            throw new NoSuchElementException();
+        }
+        StAXDocumentParser parser = (StAXDocumentParser)_streamReader;
+        parser.nextTag(true);
+        return _eventAllocator.allocate(_streamReader);
+    }
+
+    //XMLEventReader extends Iterator;
+    public Object next() {
+        try{
+            return nextEvent();
+        }catch(XMLStreamException streamException){
+            return null;
+        }
+    }
+
+    public XMLEvent peek() throws XMLStreamException{
+        if (!hasEvent)
+             throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.noElement"));
+        _currentEvent = events[currentIndex];
+        return _currentEvent;
+    }
+
+    public void setAllocator(XMLEventAllocator allocator) {
+        if (allocator == null)
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.nullXMLEventAllocator"));
+
+        _eventAllocator = allocator;
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventWriter.java
new file mode 100644
index 0000000..628d641
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXEventWriter.java
@@ -0,0 +1,268 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import java.util.Iterator;
+import javax.xml.namespace.QName;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.XMLEventWriter;
+import javax.xml.stream.XMLEventReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.events.*;
+import com.sun.xml.internal.fastinfoset.stax.events.Util;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class StAXEventWriter implements XMLEventWriter {
+
+    private XMLStreamWriter _streamWriter ;
+    /**
+     *
+     * @param streamWriter
+     */
+    public StAXEventWriter(XMLStreamWriter streamWriter){
+        _streamWriter = streamWriter;
+    }
+
+    /**
+    * Writes any cached events to the underlying output mechanism
+    * @throws XMLStreamException
+    */
+    public void flush() throws XMLStreamException {
+        _streamWriter.flush();
+    }
+    /**
+    * Frees any resources associated with this stream
+    * @throws XMLStreamException
+    */
+    public void close() throws javax.xml.stream.XMLStreamException {
+        _streamWriter.close();
+    }
+
+    /**
+     *
+     * @param eventReader
+     * @throws XMLStreamException
+     */
+    public void add(XMLEventReader eventReader) throws XMLStreamException {
+        if(eventReader == null) throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.nullEventReader"));
+        while(eventReader.hasNext()){
+            add(eventReader.nextEvent());
+        }
+    }
+
+    /**
+    * Add an event to the output stream
+    * Adding a START_ELEMENT will open a new namespace scope that
+    * will be closed when the corresponding END_ELEMENT is written.
+    *
+    * @param event
+    * @throws XMLStreamException
+    */
+    public void add(XMLEvent event) throws XMLStreamException {
+        int type = event.getEventType();
+        switch(type){
+            case XMLEvent.DTD:{
+                DTD dtd = (DTD)event ;
+                _streamWriter.writeDTD(dtd.getDocumentTypeDeclaration());
+                break;
+            }
+            case XMLEvent.START_DOCUMENT :{
+                StartDocument startDocument = (StartDocument)event ;
+                _streamWriter.writeStartDocument(startDocument.getCharacterEncodingScheme(), startDocument.getVersion());
+                break;
+            }
+            case XMLEvent.START_ELEMENT :{
+                StartElement startElement = event.asStartElement() ;
+                QName qname = startElement.getName();
+                _streamWriter.writeStartElement(qname.getPrefix(), qname.getLocalPart(), qname.getNamespaceURI());
+
+                Iterator iterator = startElement.getNamespaces();
+                while(iterator.hasNext()){
+                    Namespace namespace = (Namespace)iterator.next();
+                    _streamWriter.writeNamespace(namespace.getPrefix(), namespace.getNamespaceURI());
+                }
+
+                Iterator attributes = startElement.getAttributes();
+                while(attributes.hasNext()){
+                    Attribute attribute = (Attribute)attributes.next();
+                    QName name = attribute.getName();
+                    _streamWriter.writeAttribute(name.getPrefix(), name.getNamespaceURI(),
+                                                name.getLocalPart(),attribute.getValue());
+                }
+                break;
+            }
+            case XMLEvent.NAMESPACE:{
+                Namespace namespace = (Namespace)event;
+                _streamWriter.writeNamespace(namespace.getPrefix(), namespace.getNamespaceURI());
+                break ;
+            }
+            case XMLEvent.COMMENT: {
+                Comment comment = (Comment)event ;
+                _streamWriter.writeComment(comment.getText());
+                break;
+            }
+            case XMLEvent.PROCESSING_INSTRUCTION:{
+                ProcessingInstruction processingInstruction = (ProcessingInstruction)event ;
+                _streamWriter.writeProcessingInstruction(processingInstruction.getTarget(), processingInstruction.getData());
+                break;
+            }
+            case XMLEvent.CHARACTERS:{
+                Characters characters = event.asCharacters();
+                //check if the CHARACTERS are CDATA
+                if(characters.isCData()){
+                    _streamWriter.writeCData(characters.getData());
+                }
+                else{
+                    _streamWriter.writeCharacters(characters.getData());
+                }
+                break;
+            }
+            case XMLEvent.ENTITY_REFERENCE:{
+                EntityReference entityReference = (EntityReference)event ;
+                _streamWriter.writeEntityRef(entityReference.getName());
+                break;
+            }
+            case XMLEvent.ATTRIBUTE:{
+                Attribute attribute = (Attribute)event;
+                QName qname = attribute.getName();
+                _streamWriter.writeAttribute(qname.getPrefix(), qname.getNamespaceURI(), qname.getLocalPart(),attribute.getValue());
+                break;
+            }
+            case XMLEvent.CDATA:{
+                //there is no separate CDATA datatype but CDATA event can be reported
+                //by using vendor specific CDATA property.
+                Characters characters = (Characters)event;
+                if(characters.isCData()){
+                    _streamWriter.writeCData(characters.getData());
+                }
+                break;
+            }
+
+            case XMLEvent.END_ELEMENT:{
+                _streamWriter.writeEndElement();
+                break;
+            }
+            case XMLEvent.END_DOCUMENT:{
+                _streamWriter.writeEndDocument();
+                break;
+            }
+            default:
+                throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.eventTypeNotSupported", new Object[]{Util.getEventTypeString(type)}));
+            //throw new XMLStreamException("Unknown Event type = " + type);
+        };
+
+    }
+
+    /**
+    * Gets the prefix the uri is bound to
+    * @param uri the uri to look up
+    * @throws XMLStreamException
+    */
+    public String getPrefix(String uri) throws XMLStreamException {
+        return _streamWriter.getPrefix(uri);
+    }
+
+
+    /**
+    * Returns the current namespace context.
+    * @return the current namespace context
+    */
+    public NamespaceContext getNamespaceContext() {
+        return _streamWriter.getNamespaceContext();
+    }
+
+
+    /**
+    * Binds a URI to the default namespace
+    * This URI is bound
+    * in the scope of the current START_ELEMENT / END_ELEMENT pair.
+    * If this method is called before a START_ELEMENT has been written
+    * the uri is bound in the root scope.
+    * @param uri the uri to bind to the default namespace
+    * @throws XMLStreamException
+    */
+    public void setDefaultNamespace(String uri) throws XMLStreamException {
+        _streamWriter.setDefaultNamespace(uri);
+    }
+
+    /**
+    * Sets the current namespace context for prefix and uri bindings.
+    * This context becomes the root namespace context for writing and
+    * will replace the current root namespace context.  Subsequent calls
+    * to setPrefix and setDefaultNamespace will bind namespaces using
+    * the context passed to the method as the root context for resolving
+    * namespaces.
+    * @param namespaceContext the namespace context to use for this writer
+    * @throws XMLStreamException
+    */
+    public void setNamespaceContext(NamespaceContext namespaceContext) throws XMLStreamException {
+        _streamWriter.setNamespaceContext(namespaceContext);
+    }
+    /**
+    * Sets the prefix the uri is bound to.  This prefix is bound
+    * in the scope of the current START_ELEMENT / END_ELEMENT pair.
+    * If this method is called before a START_ELEMENT has been written
+    * the prefix is bound in the root scope.
+    * @param prefix the prefix to bind to the uri
+    * @param uri the uri to bind to the prefix
+    * @throws XMLStreamException
+    */
+    public void setPrefix(String prefix, String uri) throws XMLStreamException {
+        _streamWriter.setPrefix(prefix, uri);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXFilteredEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXFilteredEvent.java
new file mode 100644
index 0000000..cd21dda
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StAXFilteredEvent.java
@@ -0,0 +1,142 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * StAXFilteredEvent.java
+ *
+ * Created on January 12, 2005, 4:46 PM
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import javax.xml.stream.events.XMLEvent;
+import javax.xml.stream.EventFilter;
+import javax.xml.stream.events.Characters;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLEventReader;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class StAXFilteredEvent implements XMLEventReader {
+    private XMLEventReader eventReader;
+    private EventFilter _filter;
+
+    /** Creates a new instance of StAXFilteredEvent */
+    public StAXFilteredEvent() {
+    }
+
+    public StAXFilteredEvent(XMLEventReader reader, EventFilter filter) throws XMLStreamException
+    {
+        eventReader = reader;
+        _filter = filter;
+    }
+
+    public void setEventReader(XMLEventReader reader) {
+        eventReader = reader;
+    }
+
+    public void setFilter(EventFilter filter) {
+        _filter = filter;
+    }
+
+    public Object next() {
+        try {
+            return nextEvent();
+        } catch (XMLStreamException e) {
+            return null;
+        }
+    }
+
+    public XMLEvent nextEvent() throws XMLStreamException
+    {
+        if (hasNext())
+            return eventReader.nextEvent();
+        return null;
+    }
+
+    public String getElementText() throws XMLStreamException
+    {
+        StringBuffer buffer = new StringBuffer();
+        XMLEvent e = nextEvent();
+        if (!e.isStartElement())
+            throw new XMLStreamException(
+            CommonResourceBundle.getInstance().getString("message.mustBeOnSTART_ELEMENT"));
+
+        while(hasNext()) {
+            e = nextEvent();
+            if(e.isStartElement())
+                throw new XMLStreamException(
+                CommonResourceBundle.getInstance().getString("message.getElementTextExpectTextOnly"));
+            if(e.isCharacters())
+                buffer.append(((Characters) e).getData());
+            if(e.isEndElement())
+                return buffer.toString();
+        }
+        throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.END_ELEMENTnotFound"));
+    }
+
+    public XMLEvent nextTag() throws XMLStreamException {
+        while(hasNext()) {
+            XMLEvent e = nextEvent();
+            if (e.isStartElement() || e.isEndElement())
+                return e;
+        }
+        throw new XMLStreamException(CommonResourceBundle.getInstance().getString("message.startOrEndNotFound"));
+    }
+
+
+    public boolean hasNext()
+    {
+        try {
+            while(eventReader.hasNext()) {
+                if (_filter.accept(eventReader.peek())) return true;
+                eventReader.nextEvent();
+            }
+            return false;
+        } catch (XMLStreamException e) {
+            return false;
+        }
+    }
+
+    public void remove() {
+        throw new UnsupportedOperationException();
+    }
+
+    public XMLEvent peek() throws XMLStreamException
+    {
+        if (hasNext())
+            return eventReader.peek();
+        return null;
+    }
+
+    public void close() throws XMLStreamException
+    {
+        eventReader.close();
+    }
+
+    public Object getProperty(String name) {
+        return eventReader.getProperty(name);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StartDocumentEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StartDocumentEvent.java
new file mode 100644
index 0000000..cd70c06
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StartDocumentEvent.java
@@ -0,0 +1,203 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.events.StartDocument;
+
+import com.sun.xml.internal.fastinfoset.stax.events.XMLConstants;
+
+public class StartDocumentEvent extends EventBase implements StartDocument {
+
+    protected String _systemId;
+    protected String _encoding = XMLConstants.ENCODING; //default
+    protected boolean _standalone = true;
+    protected String _version = XMLConstants.XMLVERSION;
+    private boolean _encodingSet = false;
+    private boolean _standaloneSet = false;
+
+    public void reset() {
+        _encoding = XMLConstants.ENCODING;
+        _standalone = true;
+        _version = XMLConstants.XMLVERSION;
+        _encodingSet = false;
+        _standaloneSet=false;
+    }
+    public StartDocumentEvent() {
+        this(null ,null);
+    }
+
+    public StartDocumentEvent(String encoding){
+        this(encoding, null);
+    }
+
+    public StartDocumentEvent(String encoding, String version){
+        if (encoding != null) {
+            _encoding = encoding;
+            _encodingSet = true;
+        }
+        if (version != null)
+            _version = version;
+        setEventType(XMLStreamConstants.START_DOCUMENT);
+    }
+
+
+    // ------------------- methods defined in StartDocument -------------------------
+    /**
+    * Returns the system ID of the XML data
+    * @return the system ID, defaults to ""
+    */
+    public String getSystemId() {
+        return super.getSystemId();
+    }
+
+    /**
+    * Returns the encoding style of the XML data
+    * @return the character encoding, defaults to "UTF-8"
+    */
+    public String getCharacterEncodingScheme() {
+        return _encoding;
+    }
+    /**
+    * Returns true if CharacterEncodingScheme was set in
+    * the encoding declaration of the document
+    */
+    public boolean encodingSet() {
+        return _encodingSet;
+    }
+
+
+  /**
+   * Returns if this XML is standalone
+   * @return the standalone state of XML, defaults to "no"
+   */
+    public boolean isStandalone() {
+        return _standalone;
+    }
+    /**
+    * Returns true if the standalone attribute was set in
+    * the encoding declaration of the document.
+    */
+    public boolean standaloneSet() {
+        return _standaloneSet;
+    }
+
+  /**
+   * Returns the version of XML of this XML stream
+   * @return the version of XML, defaults to "1.0"
+   */
+    public String getVersion() {
+        return _version;
+    }
+    // ------------------- end of methods defined in StartDocument -------------------------
+
+    public void setStandalone(boolean standalone) {
+        _standaloneSet = true;
+        _standalone = standalone;
+    }
+
+    public void setStandalone(String s) {
+        _standaloneSet = true;
+        if(s == null) {
+            _standalone = true;
+            return;
+        }
+        if(s.equals("yes"))
+            _standalone = true;
+        else
+            _standalone = false;
+    }
+
+
+    public void setEncoding(String encoding) {
+        _encoding = encoding;
+        _encodingSet = true;
+    }
+
+    void setDeclaredEncoding(boolean value){
+        _encodingSet = value;
+    }
+
+    public void setVersion(String s) {
+        _version = s;
+    }
+
+    void clear() {
+        _encoding = "UTF-8";
+        _standalone = true;
+        _version = "1.0";
+        _encodingSet = false;
+        _standaloneSet = false;
+    }
+
+    public String toString() {
+        String s = "<?xml version=\"" + _version + "\"";
+        s = s + " encoding='" + _encoding + "'";
+        if(_standaloneSet) {
+            if(_standalone)
+                s = s + " standalone='yes'?>";
+            else
+                s = s + " standalone='no'?>";
+        } else {
+            s = s + "?>";
+        }
+        return s;
+    }
+
+    public boolean isStartDocument() {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StartElementEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StartElementEvent.java
new file mode 100644
index 0000000..d7b8f2f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/StartElementEvent.java
@@ -0,0 +1,288 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.events ;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.events.Attribute;
+import javax.xml.stream.events.Namespace;
+import javax.xml.stream.events.StartElement;
+
+import com.sun.xml.internal.fastinfoset.stax.events.EmptyIterator;
+import com.sun.xml.internal.fastinfoset.stax.events.ReadIterator;
+
+public class StartElementEvent extends EventBase implements StartElement {
+
+    private Map _attributes;
+    private List _namespaces;
+    private NamespaceContext _context = null;
+    private QName _qname;
+
+    public void reset() {
+        if (_attributes != null) _attributes.clear();
+        if (_namespaces != null) _namespaces.clear();
+        if (_context != null) _context = null;
+    }
+
+    public StartElementEvent() {
+        init();
+    }
+
+    public StartElementEvent(String prefix, String uri, String localpart) {
+        init();
+        if (uri == null) uri = "";
+        if (prefix == null) prefix ="";
+        _qname = new QName(uri, localpart, prefix);
+        setEventType(START_ELEMENT);
+    }
+
+    public StartElementEvent(QName qname) {
+        init();
+        _qname = qname;
+    }
+
+    public StartElementEvent(StartElement startelement) {
+        this(startelement.getName());
+        addAttributes(startelement.getAttributes());
+        addNamespaces(startelement.getNamespaces());
+    }
+
+    protected void init() {
+        setEventType(XMLStreamConstants.START_ELEMENT);
+        _attributes = new HashMap();
+        _namespaces = new ArrayList();
+    }
+
+    // ---------------------methods defined by StartElement-----------------//
+    /**
+    * Get the name of this event
+    * @return the qualified name of this event
+    */
+    public QName getName() {
+        return _qname;
+    }
+    /**
+    * Returns an Iterator of non-namespace declared attributes
+    * returns an empty iterator if there are no attributes.  The
+    * iterator must contain only implementations of the javax.xml.stream.Attribute
+    * interface.   Attributes are fundamentally unordered and may not be reported
+    * in any order.
+    *
+    * @return a readonly Iterator over Attribute interfaces, or an
+    * empty iterator
+    */
+    public Iterator getAttributes() {
+        if(_attributes != null){
+            Collection coll = _attributes.values();
+            return new ReadIterator(coll.iterator());
+        }
+        return EmptyIterator.getInstance();
+    }
+
+  /**
+   * Returns an Iterator of namespaces declared on this element.
+   * This Iterator does not contain previously declared namespaces
+   * unless they appear on the current START_ELEMENT.
+   * Therefore this list may contain redeclared namespaces and duplicate namespace
+   * declarations. Use the getNamespaceContext() method to get the
+   * current context of namespace declarations.
+   *
+   * <p>The iterator must contain only implementations of the
+   * javax.xml.stream.Namespace interface.
+   *
+   * <p>A Namespace is an Attribute.  One
+   * can iterate over a list of namespaces as a list of attributes.
+   * However this method returns only the list of namespaces
+   * declared on this START_ELEMENT and does not
+   * include the attributes declared on this START_ELEMENT.
+   *
+   * @return a readonly Iterator over Namespace interfaces, or an
+   * empty iterator if there are no namespaces.
+   *
+   */
+    public Iterator getNamespaces() {
+        if(_namespaces != null){
+            return new ReadIterator(_namespaces.iterator());
+        }
+        return EmptyIterator.getInstance();
+    }
+
+  /**
+   * Returns the attribute referred to by this name
+   * @param qname the qname of the desired name
+   * @return the attribute corresponding to the name value or null
+   */
+    public Attribute getAttributeByName(QName qname) {
+        if(qname == null)
+            return null;
+        return (Attribute)_attributes.get(qname);
+    }
+
+    /** Gets a read-only namespace context. If no context is
+     * available this method will return an empty namespace context.
+     * The NamespaceContext contains information about all namespaces
+     * in scope for this StartElement.
+     *
+     * @return the current namespace context
+     */
+    public NamespaceContext getNamespaceContext() {
+        return _context;
+    }
+// ---------------------end of methods defined by StartElement-----------------//
+
+    public void setName(QName qname) {
+        this._qname = qname;
+    }
+
+
+    public String getNamespace(){
+        return _qname.getNamespaceURI();
+    }
+
+    /**
+    * Gets the value that the prefix is bound to in the
+    * context of this element.  Returns null if
+    * the prefix is not bound in this context
+    * @param prefix the prefix to lookup
+    * @return the uri bound to the prefix or null
+    */
+    public String getNamespaceURI(String prefix) {
+        //first check if the URI was supplied when creating this startElement event
+        if( getNamespace() != null ) return getNamespace();
+        //else check the namespace context
+        if(_context != null)
+            return _context.getNamespaceURI(prefix);
+        return null;
+    }
+
+    public String toString() {
+        String s = "<" + nameAsString();
+
+        if(_attributes != null){
+            Iterator it = this.getAttributes();
+            Attribute attr = null;
+            while(it.hasNext()){
+                attr = (Attribute)it.next();
+                s = s + " " + attr.toString();
+            }
+        }
+
+        if(_namespaces != null){
+            Iterator it = _namespaces.iterator();
+            Namespace attr = null;
+            while(it.hasNext()){
+                attr = (Namespace)it.next();
+                s = s + " " + attr.toString();
+            }
+        }
+        s = s + ">";
+        return s;
+    }
+
+    /** Return this event as String
+     * @return String Event returned as string.
+     */
+    public String nameAsString() {
+        if("".equals(_qname.getNamespaceURI()))
+            return _qname.getLocalPart();
+        if(_qname.getPrefix() != null)
+            return "['" + _qname.getNamespaceURI() + "']:" + _qname.getPrefix() + ":" + _qname.getLocalPart();
+        else
+            return "['" + _qname.getNamespaceURI() + "']:" + _qname.getLocalPart();
+    }
+
+
+    public void setNamespaceContext(NamespaceContext context) {
+        _context = context;
+    }
+
+    public void addAttribute(Attribute attr){
+        _attributes.put(attr.getName(),attr);
+    }
+
+    public void addAttributes(Iterator attrs){
+        if(attrs != null) {
+            while(attrs.hasNext()){
+                Attribute attr = (Attribute)attrs.next();
+                _attributes.put(attr.getName(),attr);
+            }
+        }
+    }
+
+    public void addNamespace(Namespace namespace){
+        if(namespace != null) {
+            _namespaces.add(namespace);
+        }
+    }
+
+    public void addNamespaces(Iterator namespaces){
+        if(namespaces != null) {
+            while(namespaces.hasNext()){
+                Namespace namespace = (Namespace)namespaces.next();
+                _namespaces.add(namespace);
+            }
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/Util.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/Util.java
new file mode 100644
index 0000000..e53e7e7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/Util.java
@@ -0,0 +1,103 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+import javax.xml.stream.XMLStreamConstants;
+
+/** A Utility class for the StAX Events implementation.
+ */
+public class Util {
+
+    /**
+     * A string is empty if it's null or contains nothing
+     *
+     * @param s The string to check.
+     */
+    public static boolean isEmptyString(String s) {
+        if (s != null && !s.equals(""))
+            return false;
+        else
+            return true;
+    }
+
+    public final static String getEventTypeString(int eventType) {
+        switch (eventType){
+            case XMLStreamConstants.START_ELEMENT:
+                return "START_ELEMENT";
+            case XMLStreamConstants.END_ELEMENT:
+                return "END_ELEMENT";
+            case XMLStreamConstants.PROCESSING_INSTRUCTION:
+                return "PROCESSING_INSTRUCTION";
+            case XMLStreamConstants.CHARACTERS:
+                return "CHARACTERS";
+            case XMLStreamConstants.COMMENT:
+                return "COMMENT";
+            case XMLStreamConstants.START_DOCUMENT:
+                return "START_DOCUMENT";
+            case XMLStreamConstants.END_DOCUMENT:
+                return "END_DOCUMENT";
+            case XMLStreamConstants.ENTITY_REFERENCE:
+                return "ENTITY_REFERENCE";
+            case XMLStreamConstants.ATTRIBUTE:
+                return "ATTRIBUTE";
+            case XMLStreamConstants.DTD:
+                return "DTD";
+            case XMLStreamConstants.CDATA:
+                return "CDATA";
+        }
+        return "UNKNOWN_EVENT_TYPE";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/XMLConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/XMLConstants.java
new file mode 100644
index 0000000..3d1e4af
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/events/XMLConstants.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.stax.events;
+
+
+public class XMLConstants {
+
+   public static final String ENCODING = "UTF-8";
+   public static final String XMLVERSION = "1.0";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXEventFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXEventFactory.java
new file mode 100644
index 0000000..2878360
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXEventFactory.java
@@ -0,0 +1,371 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.stax.factory;
+
+import javax.xml.namespace.QName;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.Location;
+import javax.xml.stream.XMLEventFactory;
+import javax.xml.stream.events.*;
+import java.util.Iterator;
+import com.sun.xml.internal.fastinfoset.stax.events.*;
+
+
+public class StAXEventFactory extends XMLEventFactory {
+    Location location = null;
+
+    /** Creates a new instance of StAXEventFactory */
+    public StAXEventFactory() {
+    }
+    /**
+    * This method allows setting of the Location on each event that
+    * is created by this factory.  The values are copied by value into
+    * the events created by this factory.  To reset the location
+    * information set the location to null.
+    * @param location the location to set on each event created
+    */
+    public void setLocation(Location location) {
+        this.location = location;
+    }
+
+  /**
+   * Create a new Attribute
+   * @param prefix the prefix of this attribute, may not be null
+   * @param namespaceURI the attribute value is set to this value, may not be null
+   * @param localName the local name of the XML name of the attribute, localName cannot be null
+   * @param value the attribute value to set, may not be null
+   * @return the Attribute with specified values
+   */
+    public Attribute createAttribute(String prefix, String namespaceURI, String localName, String value) {
+        AttributeBase attr =  new AttributeBase(prefix, namespaceURI, localName, value, null);
+        if(location != null)attr.setLocation(location);
+        return attr;
+    }
+
+  /**
+   * Create a new Attribute
+   * @param localName the local name of the XML name of the attribute, localName cannot be null
+   * @param value the attribute value to set, may not be null
+   * @return the Attribute with specified values
+   */
+    public Attribute createAttribute(String localName, String value) {
+        AttributeBase attr =  new AttributeBase(localName, value);
+        if(location != null)attr.setLocation(location);
+        return attr;
+    }
+
+    public Attribute createAttribute(QName name, String value) {
+        AttributeBase attr =  new AttributeBase(name, value);
+        if(location != null)attr.setLocation(location);
+        return attr;
+    }
+
+  /**
+   * Create a new default Namespace
+   * @param namespaceURI the default namespace uri
+   * @return the Namespace with the specified value
+   */
+    public Namespace createNamespace(String namespaceURI) {
+        NamespaceBase event =  new NamespaceBase(namespaceURI);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+  /**
+   * Create a new Namespace
+   * @param prefix the prefix of this namespace, may not be null
+   * @param namespaceURI the attribute value is set to this value, may not be null
+   * @return the Namespace with the specified values
+   */
+    public Namespace createNamespace(String prefix, String namespaceURI) {
+        NamespaceBase event =  new NamespaceBase(prefix, namespaceURI);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+  /**
+   * Create a new StartElement.
+   * @param name the qualified name of the attribute, may not be null
+   * @param attributes an optional unordered set of objects that
+   * implement Attribute to add to the new StartElement, may be null
+   * @param namespaces an optional unordered set of objects that
+   * implement Namespace to add to the new StartElement, may be null
+   * @return an instance of the requested StartElement
+   */
+    public StartElement createStartElement(QName name, Iterator attributes, Iterator namespaces) {
+        return createStartElement(name.getPrefix(), name.getNamespaceURI(), name.getLocalPart(), attributes, namespaces);
+    }
+
+    public StartElement createStartElement(String prefix, String namespaceUri, String localName) {
+        StartElementEvent event =  new StartElementEvent(prefix, namespaceUri, localName);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+    public StartElement createStartElement(String prefix, String namespaceUri, String localName, Iterator attributes, Iterator namespaces) {
+        return createStartElement(prefix, namespaceUri, localName, attributes, namespaces, null);
+    }
+
+    public StartElement createStartElement(String prefix, String namespaceUri, String localName, Iterator attributes, Iterator namespaces, NamespaceContext context) {
+        StartElementEvent elem =  new StartElementEvent(prefix, namespaceUri, localName);
+        elem.addAttributes(attributes);
+        elem.addNamespaces(namespaces);
+        elem.setNamespaceContext(context);
+        if(location != null)elem.setLocation(location);
+        return elem;
+    }
+
+  /**
+   * Create a new EndElement
+   * @param name the qualified name of the EndElement
+   * @param namespaces an optional unordered set of objects that
+   * implement Namespace that have gone out of scope, may be null
+   * @return an instance of the requested EndElement
+   */
+    public EndElement createEndElement(QName name, Iterator namespaces) {
+        return createEndElement(name.getPrefix(), name.getNamespaceURI(), name.getLocalPart(), namespaces);
+    }
+
+  /**
+   * Create a new EndElement
+   * @param namespaceUri the uri of the QName of the new StartElement
+   * @param localName the local name of the QName of the new StartElement
+   * @param prefix the prefix of the QName of the new StartElement
+   * @return an instance of the requested EndElement
+   */
+    public EndElement createEndElement(String prefix, String namespaceUri, String localName) {
+        EndElementEvent event =  new EndElementEvent(prefix, namespaceUri, localName);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+  /**
+   * Create a new EndElement
+   * @param namespaceUri the uri of the QName of the new StartElement
+   * @param localName the local name of the QName of the new StartElement
+   * @param prefix the prefix of the QName of the new StartElement
+   * @param namespaces an unordered set of objects that implement
+   * Namespace that have gone out of scope, may be null
+   * @return an instance of the requested EndElement
+   */
+    public EndElement createEndElement(String prefix, String namespaceUri, String localName, Iterator namespaces) {
+
+        EndElementEvent event =  new EndElementEvent(prefix, namespaceUri, localName);
+        if(namespaces!=null){
+            while(namespaces.hasNext())
+                event.addNamespace((Namespace)namespaces.next());
+        }
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+  /**
+   * Create a Characters event, this method does not check if the content
+   * is all whitespace.  To create a space event use #createSpace(String)
+   * @param content the string to create
+   * @return a Characters event
+   */
+    public Characters createCharacters(String content) {
+        CharactersEvent charEvent =  new CharactersEvent(content);
+        if(location != null)charEvent.setLocation(location);
+        return charEvent;
+    }
+
+  /**
+   * Create a Characters event with the CData flag set to true
+   * @param content the string to create
+   * @return a Characters event
+   */
+    public Characters createCData(String content) {
+        CharactersEvent charEvent =  new CharactersEvent(content, true);
+        if(location != null)charEvent.setLocation(location);
+        return charEvent;
+    }
+
+   /**
+   * Create a Characters event with the isSpace flag set to true
+   * @param content the content of the space to create
+   * @return a Characters event
+   */
+    public Characters createSpace(String content) {
+        CharactersEvent event =  new CharactersEvent(content);
+        event.setSpace(true);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+    /**
+    * Create an ignorable space
+    * @param content the space to create
+    * @return a Characters event
+    */
+    public Characters createIgnorableSpace(String content) {
+        CharactersEvent event =  new CharactersEvent(content, false);
+        event.setSpace(true);
+        event.setIgnorable(true);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+  /**
+   * Creates a new instance of a StartDocument event
+   * @return a StartDocument event
+   */
+    public StartDocument createStartDocument() {
+        StartDocumentEvent event = new StartDocumentEvent();
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+  /**
+   * Creates a new instance of a StartDocument event
+   *
+   * @param encoding the encoding style
+   * @return a StartDocument event
+   */
+    public StartDocument createStartDocument(String encoding) {
+        StartDocumentEvent event =  new StartDocumentEvent(encoding);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+  /**
+   * Creates a new instance of a StartDocument event
+   *
+   * @param encoding the encoding style
+   * @param version the XML version
+   * @return a StartDocument event
+   */
+    public StartDocument createStartDocument(String encoding, String version) {
+        StartDocumentEvent event =  new StartDocumentEvent(encoding, version);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+  /**
+   * Creates a new instance of a StartDocument event
+   *
+   * @param encoding the encoding style
+   * @param version the XML version
+   * @param standalone the status of standalone may be set to "true" or "false"
+   * @return a StartDocument event
+   */
+    public StartDocument createStartDocument(String encoding, String version, boolean standalone) {
+        StartDocumentEvent event =  new StartDocumentEvent(encoding, version);
+        event.setStandalone(standalone);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+    public EndDocument createEndDocument() {
+        EndDocumentEvent event =new EndDocumentEvent();
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+    /** Creates a new instance of a EntityReference event
+    *
+    * @param name The name of the reference
+    * @param entityDeclaration the declaration for the event
+    * @return an EntityReference event
+    */
+    public EntityReference createEntityReference(String name, EntityDeclaration entityDeclaration) {
+        EntityReferenceEvent event =  new EntityReferenceEvent(name, entityDeclaration);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+    /**
+    * Create a comment
+    * @param text The text of the comment
+    * a Comment event
+    */
+    public Comment createComment(String text) {
+        CommentEvent charEvent =  new CommentEvent(text);
+        if(location != null)charEvent.setLocation(location);
+        return charEvent;
+    }
+
+    /**
+    * Create a document type definition event
+    * This string contains the entire document type declaration that matches
+    * the doctypedecl in the XML 1.0 specification
+    * @param dtd the text of the document type definition
+    * @return a DTD event
+    */
+    public DTD createDTD(String dtd) {
+        DTDEvent dtdEvent = new DTDEvent(dtd);
+        if(location != null)dtdEvent.setLocation(location);
+        return dtdEvent;
+    }
+
+
+    /**
+    * Create a processing instruction
+    * @param target The target of the processing instruction
+    * @param data The text of the processing instruction
+    * @return a ProcessingInstruction event
+    */
+    public ProcessingInstruction createProcessingInstruction(String target, String data) {
+        ProcessingInstructionEvent event =  new ProcessingInstructionEvent(target, data);
+        if(location != null)event.setLocation(location);
+        return event;
+    }
+
+
+
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXInputFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXInputFactory.java
new file mode 100644
index 0000000..3709beb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXInputFactory.java
@@ -0,0 +1,285 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.stax.factory;
+
+import com.sun.xml.internal.fastinfoset.stax.*;
+import com.sun.xml.internal.fastinfoset.stax.events.StAXEventReader;
+import com.sun.xml.internal.fastinfoset.stax.events.StAXFilteredEvent;
+import com.sun.xml.internal.fastinfoset.stax.util.StAXFilteredParser;
+import com.sun.xml.internal.fastinfoset.tools.XML_SAX_FI;
+
+import java.io.InputStream;
+import java.io.Reader;
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.BufferedInputStream;
+import java.io.BufferedOutputStream;
+
+import javax.xml.stream.*;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.util.XMLEventAllocator ;
+import javax.xml.transform.Source;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class StAXInputFactory extends XMLInputFactory {
+    //List of supported properties and default values.
+    private StAXManager _manager = new StAXManager(StAXManager.CONTEXT_READER) ;
+
+    public StAXInputFactory() {
+    }
+
+    public static XMLInputFactory newInstance() {
+        return XMLInputFactory.newInstance();
+    }
+
+  /**
+   * Create a new XMLStreamReader from a reader
+   * @param xmlfile the XML data to read from
+   * @throws XMLStreamException
+   */
+    public XMLStreamReader createXMLStreamReader(Reader xmlfile) throws XMLStreamException {
+        return getXMLStreamReader(xmlfile);
+    }
+
+    public XMLStreamReader createXMLStreamReader(InputStream s) throws XMLStreamException {
+        return new StAXDocumentParser(s, _manager);
+    }
+
+    public XMLStreamReader createXMLStreamReader(String systemId, Reader xmlfile) throws XMLStreamException {
+        return getXMLStreamReader(xmlfile);
+    }
+
+    public XMLStreamReader createXMLStreamReader(Source source) throws XMLStreamException {
+        return null;
+    }
+
+    public XMLStreamReader createXMLStreamReader(String systemId, InputStream inputstream) throws XMLStreamException {
+        return createXMLStreamReader(inputstream);
+    }
+
+
+    public XMLStreamReader createXMLStreamReader(InputStream inputstream, String encoding) throws XMLStreamException {
+        return createXMLStreamReader(inputstream);
+    }
+
+
+    XMLStreamReader getXMLStreamReader(String systemId, InputStream inputstream, String encoding)
+        throws XMLStreamException{
+        return createXMLStreamReader(inputstream);
+
+    }
+
+    /**
+     * @param inputstream
+     * @throws XMLStreamException
+     * @return
+     */
+    XMLStreamReader getXMLStreamReader(Reader xmlfile)
+        throws XMLStreamException{
+
+        ByteArrayOutputStream byteStream = new ByteArrayOutputStream();
+        BufferedOutputStream bufferedStream = new BufferedOutputStream(byteStream);
+        StAXDocumentParser sr = null;
+        try {
+            XML_SAX_FI convertor = new XML_SAX_FI();
+            convertor.convert(xmlfile, bufferedStream);
+
+            ByteArrayInputStream byteInputStream = new ByteArrayInputStream(byteStream.toByteArray());
+            InputStream document = new BufferedInputStream(byteInputStream);
+            sr = new StAXDocumentParser();
+            sr.setInputStream(document);
+            sr.setManager(_manager);
+            return sr;
+            //return new StAXDocumentParser(document, _manager);
+        } catch (Exception e) {
+            return null;
+        }
+
+    }
+
+
+    /**
+     * @param inputstream
+     * @throws XMLStreamException
+     * @return XMLEventReader
+     */
+    public XMLEventReader createXMLEventReader(InputStream inputstream) throws XMLStreamException {
+        return new StAXEventReader(createXMLStreamReader(inputstream));
+    }
+
+    public XMLEventReader createXMLEventReader(Reader reader) throws XMLStreamException {
+        return new StAXEventReader(createXMLStreamReader(reader));
+    }
+
+    public XMLEventReader createXMLEventReader(Source source) throws XMLStreamException {
+        return new StAXEventReader(createXMLStreamReader(source));
+    }
+
+    public XMLEventReader createXMLEventReader(String systemId, InputStream inputstream) throws XMLStreamException {
+        return new StAXEventReader(createXMLStreamReader(systemId, inputstream));
+    }
+
+    public XMLEventReader createXMLEventReader(java.io.InputStream stream, String encoding) throws XMLStreamException {
+        return new StAXEventReader(createXMLStreamReader(stream, encoding));
+    }
+
+    public XMLEventReader createXMLEventReader(String systemId, Reader reader) throws XMLStreamException {
+        return new StAXEventReader(createXMLStreamReader(systemId, reader));
+    }
+
+    /** Create a new XMLEventReader from an XMLStreamReader.  After being used
+     * to construct the XMLEventReader instance returned from this method
+     * the XMLStreamReader must not be used.
+     * @param streamReader the XMLStreamReader to read from (may not be modified)
+     * @return a new XMLEventReader
+     * @throws XMLStreamException
+     */
+    public XMLEventReader createXMLEventReader(XMLStreamReader streamReader) throws XMLStreamException {
+        return new StAXEventReader(streamReader);
+    }
+
+    public XMLEventAllocator getEventAllocator() {
+        return (XMLEventAllocator)getProperty(XMLInputFactory.ALLOCATOR);
+    }
+
+    public XMLReporter getXMLReporter() {
+        return (XMLReporter)_manager.getProperty(XMLInputFactory.REPORTER);
+    }
+
+    public XMLResolver getXMLResolver() {
+        Object object = _manager.getProperty(XMLInputFactory.RESOLVER);
+        return (XMLResolver)object;
+        //return (XMLResolver)_manager.getProperty(XMLInputFactory.RESOLVER);
+    }
+
+    public void setXMLReporter(XMLReporter xmlreporter) {
+        _manager.setProperty(XMLInputFactory.REPORTER, xmlreporter);
+    }
+
+    public void setXMLResolver(XMLResolver xmlresolver) {
+        _manager.setProperty(XMLInputFactory.RESOLVER, xmlresolver);
+    }
+
+    /** Create a filtered event reader that wraps the filter around the event reader
+     * @param reader the event reader to wrap
+     * @param filter the filter to apply to the event reader
+     * @throws XMLStreamException
+     */
+    public XMLEventReader createFilteredReader(XMLEventReader reader, EventFilter filter) throws XMLStreamException {
+        return new StAXFilteredEvent(reader, filter);
+    }
+
+    /** Create a filtered reader that wraps the filter around the reader
+     * @param reader the reader to filter
+     * @param filter the filter to apply to the reader
+     * @throws XMLStreamException
+     */
+    public XMLStreamReader createFilteredReader(XMLStreamReader reader, StreamFilter filter) throws XMLStreamException {
+
+        if( reader != null && filter != null )
+            return new StAXFilteredParser(reader,filter);
+
+        return null;
+    }
+
+
+
+    /** Get the value of a feature/property from the underlying implementation
+     * @param name The name of the property (may not be null)
+     * @return The value of the property
+     * @throws IllegalArgumentException if the property is not supported
+     */
+    public Object getProperty(String name) throws IllegalArgumentException {
+        if(name == null){
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.nullPropertyName"));
+        }
+        if(_manager.containsProperty(name))
+            return _manager.getProperty(name);
+        throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.propertyNotSupported", new Object[]{name}));
+    }
+
+    /** Query the set of Properties that this factory supports.
+     *
+     * @param name The name of the property (may not be null)
+     * @return true if the property is supported and false otherwise
+     */
+    public boolean isPropertySupported(String name) {
+        if(name == null)
+            return false ;
+        else
+            return _manager.containsProperty(name);
+    }
+
+    /** Set a user defined event allocator for events
+     * @param allocator the user defined allocator
+     */
+    public void setEventAllocator(XMLEventAllocator allocator) {
+        _manager.setProperty(XMLInputFactory.ALLOCATOR, allocator);
+    }
+
+    /** Allows the user to set specific feature/property on the underlying implementation. The underlying implementation
+     * is not required to support every setting of every property in the specification and may use IllegalArgumentException
+     * to signal that an unsupported property may not be set with the specified value.
+     * @param name The name of the property (may not be null)
+     * @param value The value of the property
+     * @throws IllegalArgumentException if the property is not supported
+     */
+    public void setProperty(String name, Object value) throws IllegalArgumentException {
+        _manager.setProperty(name,value);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXOutputFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXOutputFactory.java
new file mode 100644
index 0000000..2098688
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/factory/StAXOutputFactory.java
@@ -0,0 +1,166 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.stax.factory;
+
+import com.sun.xml.internal.fastinfoset.stax.*;
+import com.sun.xml.internal.fastinfoset.stax.events.StAXEventWriter;
+import javax.xml.transform.Result;
+import javax.xml.stream.XMLOutputFactory ;
+import javax.xml.stream.XMLEventWriter;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.transform.stream.StreamResult;
+import java.io.File;
+import java.io.FileWriter;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.Writer;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class StAXOutputFactory extends XMLOutputFactory {
+
+    //List of supported properties and default values.
+    private StAXManager _manager = null ;
+
+    /** Creates a new instance of StAXOutputFactory */
+    public StAXOutputFactory() {
+        _manager = new StAXManager(StAXManager.CONTEXT_WRITER);
+    }
+
+    public XMLEventWriter createXMLEventWriter(Result result) throws XMLStreamException {
+        return new StAXEventWriter(createXMLStreamWriter(result));
+    }
+
+    public XMLEventWriter createXMLEventWriter(Writer writer) throws XMLStreamException {
+        return new StAXEventWriter(createXMLStreamWriter(writer));
+    }
+
+    public XMLEventWriter createXMLEventWriter(OutputStream outputStream) throws XMLStreamException {
+        return new StAXEventWriter(createXMLStreamWriter(outputStream));
+    }
+
+    public XMLEventWriter createXMLEventWriter(OutputStream outputStream, String encoding) throws XMLStreamException {
+        return new StAXEventWriter(createXMLStreamWriter(outputStream, encoding));
+    }
+
+    public XMLStreamWriter createXMLStreamWriter(Result result) throws XMLStreamException {
+        if(result instanceof StreamResult){
+            StreamResult streamResult = (StreamResult)result;
+            if( streamResult.getWriter() != null){
+                return createXMLStreamWriter(streamResult.getWriter());
+            }else if(streamResult.getOutputStream() != null ){
+                return createXMLStreamWriter(streamResult.getOutputStream());
+            }else if(streamResult.getSystemId()!= null){
+                try{
+                    FileWriter writer = new FileWriter(new File(streamResult.getSystemId()));
+                    return createXMLStreamWriter(writer);
+                }catch(IOException ie){
+                    throw new XMLStreamException(ie);
+                }
+            }
+        }
+        else if(result instanceof Result){
+            try{
+                //xxx: should we be using FileOutputStream - nb.
+                FileWriter writer = new FileWriter(new File(result.getSystemId()));
+                return createXMLStreamWriter(writer);
+            }catch(IOException ie){
+                throw new XMLStreamException(ie);
+            }
+        }
+        throw new java.lang.UnsupportedOperationException();
+    }
+
+    /** this is assumed that user wants to write the file in xml format
+     *
+     */
+    public XMLStreamWriter createXMLStreamWriter(Writer writer) throws XMLStreamException {
+        throw new java.lang.UnsupportedOperationException();
+    }
+
+    public XMLStreamWriter createXMLStreamWriter(OutputStream outputStream) throws XMLStreamException {
+        return new StAXDocumentSerializer(outputStream, new StAXManager(_manager));
+    }
+
+    public XMLStreamWriter createXMLStreamWriter(OutputStream outputStream, String encoding) throws XMLStreamException {
+        StAXDocumentSerializer serializer = new StAXDocumentSerializer(outputStream, new StAXManager(_manager));
+        serializer.setEncoding(encoding);
+        return serializer;
+    }
+
+    public Object getProperty(String name) throws java.lang.IllegalArgumentException {
+        if(name == null){
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.propertyNotSupported", new Object[]{name}));
+        }
+        if(_manager.containsProperty(name))
+            return _manager.getProperty(name);
+        throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.propertyNotSupported", new Object[]{name}));
+    }
+
+    public boolean isPropertySupported(String name) {
+        if(name == null)
+            return false ;
+        else
+            return _manager.containsProperty(name);
+    }
+
+    public void setProperty(String name, Object value) throws java.lang.IllegalArgumentException {
+        _manager.setProperty(name,value);
+
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/util/StAXFilteredParser.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/util/StAXFilteredParser.java
new file mode 100644
index 0000000..589260a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/util/StAXFilteredParser.java
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.util;
+
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.StreamFilter;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+public class StAXFilteredParser extends StAXParserWrapper {
+    private StreamFilter _filter;
+
+    /** Creates a new instance of StAXFilteredParser */
+    public StAXFilteredParser() {
+    }
+    public StAXFilteredParser(XMLStreamReader reader, StreamFilter filter) {
+        super(reader);
+        _filter = filter;
+    }
+
+    public void setFilter(StreamFilter filter) {
+        _filter = filter;
+    }
+
+    public int next() throws XMLStreamException
+    {
+        if (hasNext())
+            return super.next();
+        throw new IllegalStateException(CommonResourceBundle.getInstance().getString("message.noMoreItems"));
+    }
+
+    public boolean hasNext() throws XMLStreamException
+    {
+        while (super.hasNext()) {
+            if (_filter.accept(getReader())) return true;
+            super.next();
+        }
+        return false;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/util/StAXParserWrapper.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/util/StAXParserWrapper.java
new file mode 100644
index 0000000..ca8ff1b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/stax/util/StAXParserWrapper.java
@@ -0,0 +1,264 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.stax.util;
+
+import javax.xml.namespace.QName;
+import javax.xml.namespace.NamespaceContext;
+
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.Location;
+import javax.xml.stream.XMLStreamException;
+
+
+public class StAXParserWrapper implements XMLStreamReader{
+    private XMLStreamReader _reader;
+
+    /** Creates a new instance of StAXParserWrapper */
+    public StAXParserWrapper() {
+    }
+
+    public StAXParserWrapper(XMLStreamReader reader) {
+        _reader = reader;
+    }
+    public void setReader(XMLStreamReader reader) {
+        _reader = reader;
+    }
+    public XMLStreamReader getReader() {
+        return _reader;
+    }
+
+    public int next() throws XMLStreamException
+    {
+        return _reader.next();
+    }
+
+    public int nextTag() throws XMLStreamException
+    {
+        return _reader.nextTag();
+    }
+
+    public String getElementText() throws XMLStreamException
+    {
+        return _reader.getElementText();
+    }
+
+    public void require(int type, String namespaceURI, String localName) throws XMLStreamException
+    {
+        _reader.require(type,namespaceURI,localName);
+    }
+
+    public boolean hasNext() throws XMLStreamException
+    {
+        return _reader.hasNext();
+    }
+
+    public void close() throws XMLStreamException
+    {
+        _reader.close();
+    }
+
+    public String getNamespaceURI(String prefix)
+    {
+        return _reader.getNamespaceURI(prefix);
+    }
+
+    public NamespaceContext getNamespaceContext() {
+        return _reader.getNamespaceContext();
+    }
+
+    public boolean isStartElement() {
+        return _reader.isStartElement();
+    }
+
+    public boolean isEndElement() {
+        return _reader.isEndElement();
+    }
+
+    public boolean isCharacters() {
+    return _reader.isCharacters();
+    }
+
+    public boolean isWhiteSpace() {
+        return _reader.isWhiteSpace();
+    }
+
+    public QName getAttributeName(int index) {
+        return _reader.getAttributeName(index);
+    }
+
+    public int getTextCharacters(int sourceStart, char[] target, int targetStart,
+                               int length) throws XMLStreamException
+    {
+        return _reader.getTextCharacters(sourceStart, target, targetStart, length);
+    }
+
+    public String getAttributeValue(String namespaceUri,
+                                  String localName)
+    {
+        return _reader.getAttributeValue(namespaceUri,localName);
+    }
+    public int getAttributeCount() {
+        return _reader.getAttributeCount();
+    }
+    public String getAttributePrefix(int index) {
+        return _reader.getAttributePrefix(index);
+    }
+    public String getAttributeNamespace(int index) {
+        return _reader.getAttributeNamespace(index);
+    }
+    public String getAttributeLocalName(int index) {
+        return _reader.getAttributeLocalName(index);
+    }
+    public String getAttributeType(int index) {
+        return _reader.getAttributeType(index);
+    }
+    public String getAttributeValue(int index) {
+        return _reader.getAttributeValue(index);
+    }
+    public boolean isAttributeSpecified(int index) {
+        return _reader.isAttributeSpecified(index);
+    }
+
+    public int getNamespaceCount() {
+        return _reader.getNamespaceCount();
+    }
+    public String getNamespacePrefix(int index) {
+        return _reader.getNamespacePrefix(index);
+    }
+    public String getNamespaceURI(int index) {
+        return _reader.getNamespaceURI(index);
+    }
+
+    public int getEventType() {
+        return _reader.getEventType();
+    }
+
+    public String getText() {
+        return _reader.getText();
+    }
+
+    public char[] getTextCharacters() {
+        return _reader.getTextCharacters();
+    }
+
+    public int getTextStart() {
+        return _reader.getTextStart();
+    }
+
+    public int getTextLength() {
+        return _reader.getTextLength();
+    }
+
+    public String getEncoding() {
+        return _reader.getEncoding();
+    }
+
+    public boolean hasText() {
+        return _reader.hasText();
+    }
+
+    public Location getLocation() {
+        return _reader.getLocation();
+    }
+
+    public QName getName() {
+        return _reader.getName();
+    }
+
+    public String getLocalName() {
+        return _reader.getLocalName();
+    }
+
+    public boolean hasName() {
+        return _reader.hasName();
+    }
+
+    public String getNamespaceURI() {
+        return _reader.getNamespaceURI();
+    }
+
+    public String getPrefix() {
+        return _reader.getPrefix();
+    }
+
+    public String getVersion() {
+        return _reader.getVersion();
+    }
+
+    public boolean isStandalone() {
+        return _reader.isStandalone();
+    }
+
+    public boolean standaloneSet() {
+        return _reader.standaloneSet();
+    }
+
+    public String getCharacterEncodingScheme() {
+        return _reader.getCharacterEncodingScheme();
+    }
+
+    public String getPITarget() {
+        return _reader.getPITarget();
+    }
+
+    public String getPIData() {
+        return _reader.getPIData();
+    }
+
+    public Object getProperty(String name) {
+        return _reader.getProperty(name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_DOM_Or_XML_DOM_SAX_SAXEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_DOM_Or_XML_DOM_SAX_SAXEvent.java
new file mode 100644
index 0000000..1cc95b1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_DOM_Or_XML_DOM_SAX_SAXEvent.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.Decoder;
+import com.sun.xml.internal.fastinfoset.dom.DOMDocumentParser;
+import java.io.BufferedInputStream;
+import java.io.InputStream;
+import java.io.OutputStream;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.sax.SAXResult;
+import org.w3c.dom.Document;
+
+public class FI_DOM_Or_XML_DOM_SAX_SAXEvent extends TransformInputOutput {
+
+    public void parse(InputStream document, OutputStream events) throws Exception {
+        if (!document.markSupported()) {
+            document = new BufferedInputStream(document);
+        }
+
+        document.mark(4);
+        boolean isFastInfosetDocument = Decoder.isFastInfosetDocument(document);
+        document.reset();
+
+        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+        dbf.setNamespaceAware(true);
+        DocumentBuilder db = dbf.newDocumentBuilder();
+
+        Document d;
+        if (isFastInfosetDocument) {
+            d = db.newDocument();
+            DOMDocumentParser ddp = new DOMDocumentParser();
+            ddp.parse(d, document);
+        } else {
+            d = db.parse(document);
+        }
+
+        SAXEventSerializer ses = new SAXEventSerializer(events);
+
+        TransformerFactory tf = TransformerFactory.newInstance();
+        Transformer t = tf.newTransformer();
+        t.transform(new DOMSource(d), new SAXResult(ses));
+    }
+
+    public static void main(String[] args) throws Exception {
+        FI_DOM_Or_XML_DOM_SAX_SAXEvent p = new FI_DOM_Or_XML_DOM_SAX_SAXEvent();
+        p.parse(args);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_Or_XML_SAX_DOM_SAX_SAXEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_Or_XML_SAX_DOM_SAX_SAXEvent.java
new file mode 100644
index 0000000..ed3a04a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_Or_XML_SAX_DOM_SAX_SAXEvent.java
@@ -0,0 +1,104 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.Decoder;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSource;
+import java.io.BufferedInputStream;
+import java.io.InputStream;
+import java.io.OutputStream;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.sax.SAXResult;
+import javax.xml.transform.stream.StreamSource;
+
+public class FI_SAX_Or_XML_SAX_DOM_SAX_SAXEvent extends TransformInputOutput {
+
+    public FI_SAX_Or_XML_SAX_DOM_SAX_SAXEvent() {
+    }
+
+    public void parse(InputStream document, OutputStream events) throws Exception {
+        if (!document.markSupported()) {
+            document = new BufferedInputStream(document);
+        }
+
+        document.mark(4);
+        boolean isFastInfosetDocument = Decoder.isFastInfosetDocument(document);
+        document.reset();
+
+        TransformerFactory tf = TransformerFactory.newInstance();
+        Transformer t = tf.newTransformer();
+        DOMResult dr = new DOMResult();
+
+        if (isFastInfosetDocument) {
+            t.transform(new FastInfosetSource(document), dr);
+        } else {
+            t.transform(new StreamSource(document), dr);
+        }
+
+        SAXEventSerializer ses = new SAXEventSerializer(events);
+        t.transform(new DOMSource(dr.getNode()), new SAXResult(ses));
+    }
+
+    public static void main(String[] args) throws Exception {
+        FI_SAX_Or_XML_SAX_DOM_SAX_SAXEvent p = new FI_SAX_Or_XML_SAX_DOM_SAX_SAXEvent();
+        p.parse(args);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_Or_XML_SAX_SAXEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_Or_XML_SAX_SAXEvent.java
new file mode 100644
index 0000000..8c10474
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_Or_XML_SAX_SAXEvent.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.Decoder;
+import com.sun.xml.internal.fastinfoset.sax.SAXDocumentParser;
+import com.sun.xml.internal.fastinfoset.sax.Properties;
+import java.io.BufferedInputStream;
+import java.io.InputStream;
+import java.io.OutputStream;
+import javax.xml.parsers.SAXParser;
+import javax.xml.parsers.SAXParserFactory;
+
+public class FI_SAX_Or_XML_SAX_SAXEvent extends TransformInputOutput {
+
+    public FI_SAX_Or_XML_SAX_SAXEvent() {
+    }
+
+    public void parse(InputStream document, OutputStream events) throws Exception {
+        if (!document.markSupported()) {
+            document = new BufferedInputStream(document);
+        }
+
+        document.mark(4);
+        boolean isFastInfosetDocument = Decoder.isFastInfosetDocument(document);
+        document.reset();
+
+        if (isFastInfosetDocument) {
+            SAXDocumentParser parser = new SAXDocumentParser();
+            SAXEventSerializer ses = new SAXEventSerializer(events);
+            parser.setContentHandler(ses);
+            parser.setProperty(Properties.LEXICAL_HANDLER_PROPERTY, ses);
+            parser.parse(document);
+        } else {
+            SAXParserFactory parserFactory = SAXParserFactory.newInstance();
+            parserFactory.setNamespaceAware(true);
+            SAXParser parser = parserFactory.newSAXParser();
+            SAXEventSerializer ses = new SAXEventSerializer(events);
+            parser.setProperty(Properties.LEXICAL_HANDLER_PROPERTY, ses);
+            parser.parse(document, ses);
+        }
+    }
+
+    public static void main(String[] args) throws Exception {
+        FI_SAX_Or_XML_SAX_SAXEvent p = new FI_SAX_Or_XML_SAX_SAXEvent();
+        p.parse(args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_XML.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_XML.java
new file mode 100644
index 0000000..29043a6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_SAX_XML.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSource;
+import java.io.InputStream;
+import java.io.OutputStream;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.stream.StreamResult;
+
+public class FI_SAX_XML extends TransformInputOutput {
+
+    public FI_SAX_XML() {
+    }
+
+    public void parse(InputStream finf, OutputStream xml) throws Exception {
+        Transformer tx = TransformerFactory.newInstance().newTransformer();
+        tx.transform(new FastInfosetSource(finf), new StreamResult(xml));
+    }
+
+    public static void main(String[] args) throws Exception {
+        FI_SAX_XML p = new FI_SAX_XML();
+        p.parse(args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_StAX_SAX_Or_XML_SAX_SAXEvent.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_StAX_SAX_Or_XML_SAX_SAXEvent.java
new file mode 100644
index 0000000..577ea3d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/FI_StAX_SAX_Or_XML_SAX_SAXEvent.java
@@ -0,0 +1,105 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.Decoder;
+import com.sun.xml.internal.fastinfoset.sax.Properties;
+import com.sun.xml.internal.fastinfoset.stax.StAXDocumentParser;
+import java.io.BufferedInputStream;
+import java.io.InputStream;
+import java.io.OutputStream;
+import javax.xml.parsers.SAXParser;
+import javax.xml.parsers.SAXParserFactory;
+import com.sun.xml.internal.fastinfoset.tools.StAX2SAXReader;
+
+public class FI_StAX_SAX_Or_XML_SAX_SAXEvent extends TransformInputOutput {
+
+    public FI_StAX_SAX_Or_XML_SAX_SAXEvent() {
+    }
+
+    public void parse(InputStream document, OutputStream events) throws Exception {
+        if (!document.markSupported()) {
+            document = new BufferedInputStream(document);
+        }
+
+        document.mark(4);
+        boolean isFastInfosetDocument = Decoder.isFastInfosetDocument(document);
+        document.reset();
+
+        if (isFastInfosetDocument) {
+            StAXDocumentParser parser = new StAXDocumentParser();
+            parser.setInputStream(document);
+            SAXEventSerializer ses = new SAXEventSerializer(events);
+            StAX2SAXReader reader = new StAX2SAXReader(parser, ses);
+            reader.setLexicalHandler(ses);
+            reader.adapt();
+        } else {
+            SAXParserFactory parserFactory = SAXParserFactory.newInstance();
+            parserFactory.setNamespaceAware(true);
+            SAXParser parser = parserFactory.newSAXParser();
+            SAXEventSerializer ses = new SAXEventSerializer(events);
+            parser.setProperty(Properties.LEXICAL_HANDLER_PROPERTY, ses);
+            parser.parse(document, ses);
+        }
+    }
+
+    public static void main(String[] args) throws Exception {
+        FI_StAX_SAX_Or_XML_SAX_SAXEvent p = new FI_StAX_SAX_Or_XML_SAX_SAXEvent();
+        p.parse(args);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/PrintTable.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/PrintTable.java
new file mode 100644
index 0000000..299dbd6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/PrintTable.java
@@ -0,0 +1,157 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import java.io.File;
+
+import javax.xml.parsers.SAXParser;
+import javax.xml.parsers.SAXParserFactory;
+
+import com.sun.xml.internal.fastinfoset.tools.VocabularyGenerator;
+import com.sun.xml.internal.fastinfoset.util.CharArrayArray;
+import com.sun.xml.internal.fastinfoset.util.ContiguousCharArrayArray;
+import com.sun.xml.internal.fastinfoset.util.PrefixArray;
+import com.sun.xml.internal.fastinfoset.util.QualifiedNameArray;
+import com.sun.xml.internal.fastinfoset.util.StringArray;
+import com.sun.xml.internal.fastinfoset.vocab.ParserVocabulary;
+
+
+public class PrintTable {
+
+    /** Creates a new instance of PrintTable */
+    public PrintTable() {
+    }
+
+    public static void printVocabulary(ParserVocabulary vocabulary) {
+        printArray("Attribute Name Table", vocabulary.attributeName);
+        printArray("Attribute Value Table", vocabulary.attributeValue);
+        printArray("Character Content Chunk Table", vocabulary.characterContentChunk);
+        printArray("Element Name Table", vocabulary.elementName);
+        printArray("Local Name Table", vocabulary.localName);
+        printArray("Namespace Name Table", vocabulary.namespaceName);
+        printArray("Other NCName Table", vocabulary.otherNCName);
+        printArray("Other String Table", vocabulary.otherString);
+        printArray("Other URI Table", vocabulary.otherURI);
+        printArray("Prefix Table", vocabulary.prefix);
+    }
+
+    public static void printArray(String title, StringArray a) {
+        System.out.println(title);
+
+        for (int i = 0; i < a.getSize(); i++) {
+            System.out.println("" + (i + 1) + ": " + a.getArray()[i]);
+        }
+    }
+
+    public static void printArray(String title, PrefixArray a) {
+        System.out.println(title);
+
+        for (int i = 0; i < a.getSize(); i++) {
+            System.out.println("" + (i + 1) + ": " + a.getArray()[i]);
+        }
+    }
+
+    public static void printArray(String title, CharArrayArray a) {
+        System.out.println(title);
+
+        for (int i = 0; i < a.getSize(); i++) {
+            System.out.println("" + (i + 1) + ": " + a.getArray()[i]);
+        }
+    }
+
+    public static void printArray(String title, ContiguousCharArrayArray a) {
+        System.out.println(title);
+
+        for (int i = 0; i < a.getSize(); i++) {
+            System.out.println("" + (i + 1) + ": " + a.getString(i));
+        }
+    }
+
+    public static void printArray(String title, QualifiedNameArray a) {
+        System.out.println(title);
+
+        for (int i = 0; i < a.getSize(); i++) {
+            QualifiedName name = a.getArray()[i];
+            System.out.println("" + (name.index + 1) + ": " +
+                    "{" + name.namespaceName + "}" +
+                    name.prefix + ":" + name.localName);
+        }
+    }
+
+    /**
+     * @param args the command line arguments
+     */
+    public static void main(String[] args) {
+        try {
+            SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
+            saxParserFactory.setNamespaceAware(true);
+
+            SAXParser saxParser = saxParserFactory.newSAXParser();
+
+            ParserVocabulary referencedVocabulary = new ParserVocabulary();
+
+            VocabularyGenerator vocabularyGenerator = new VocabularyGenerator(referencedVocabulary);
+            File f = new File(args[0]);
+            saxParser.parse(f, vocabularyGenerator);
+
+            printVocabulary(referencedVocabulary);
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/SAX2StAXWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/SAX2StAXWriter.java
new file mode 100644
index 0000000..c658402
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/SAX2StAXWriter.java
@@ -0,0 +1,225 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import java.util.ArrayList;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+import org.xml.sax.Attributes;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.DefaultHandler;
+
+public class SAX2StAXWriter extends DefaultHandler implements LexicalHandler {
+
+    /**
+     * XML stream writer where events are pushed.
+     */
+    XMLStreamWriter _writer;
+
+    /**
+     * List of namespace decl for upcoming element.
+     */
+    ArrayList _namespaces = new ArrayList();
+
+    public SAX2StAXWriter(XMLStreamWriter writer) {
+        _writer = writer;
+    }
+
+    public XMLStreamWriter getWriter() {
+        return _writer;
+    }
+
+    public void startDocument() throws SAXException {
+        try {
+            _writer.writeStartDocument();
+        }
+        catch (XMLStreamException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void endDocument() throws SAXException {
+        try {
+            _writer.writeEndDocument();
+            _writer.flush();
+        }
+        catch (XMLStreamException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void characters(char[] ch, int start, int length)
+        throws SAXException
+    {
+        try {
+            _writer.writeCharacters(ch, start, length);
+        }
+        catch (XMLStreamException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void startElement(String namespaceURI, String localName,
+        String qName, Attributes atts) throws SAXException
+    {
+        try {
+            int k = qName.indexOf(':');
+            String prefix = (k > 0) ? qName.substring(0, k) : "";
+            _writer.writeStartElement(prefix, localName, namespaceURI);
+
+            int length = _namespaces.size();
+            for (int i = 0; i < length; i++) {
+                QualifiedName nsh = (QualifiedName) _namespaces.get(i);
+                _writer.writeNamespace(nsh.prefix, nsh.namespaceName);
+            }
+            _namespaces.clear();
+
+            length = atts.getLength();
+            for (int i = 0; i < length; i++) {
+                _writer.writeAttribute(atts.getURI(i),
+                                       atts.getLocalName(i),
+                                       atts.getValue(i));
+            }
+        }
+        catch (XMLStreamException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void endElement(String namespaceURI, String localName,
+        String qName) throws SAXException
+    {
+        try {
+            _writer.writeEndElement();
+        }
+        catch (XMLStreamException e) {
+            e.printStackTrace();
+            throw new SAXException(e);
+        }
+    }
+
+    public void startPrefixMapping(String prefix, String uri)
+        throws SAXException
+    {
+        try {
+            _writer.setPrefix(prefix, uri);
+            _namespaces.add(new QualifiedName(prefix, uri));
+        }
+        catch (XMLStreamException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void endPrefixMapping(String prefix) throws SAXException {
+    }
+
+    public void ignorableWhitespace(char[] ch, int start, int length)
+        throws SAXException
+    {
+        characters(ch, start, length);
+    }
+
+    public void processingInstruction(String target, String data)
+        throws SAXException
+    {
+        try {
+            _writer.writeProcessingInstruction(target, data);
+        }
+        catch (XMLStreamException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void setDocumentLocator(Locator locator) {
+    }
+
+    public void skippedEntity(String name) throws SAXException {
+    }
+
+    public void comment(char[] ch, int start, int length)
+        throws SAXException
+    {
+        try {
+            _writer.writeComment(new String(ch, start, length));
+        }
+        catch (XMLStreamException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void endCDATA() throws SAXException {
+    }
+
+    public void endDTD() throws SAXException {
+    }
+
+    public void endEntity(String name) throws SAXException {
+    }
+
+    public void startCDATA() throws SAXException {
+    }
+
+    public void startDTD(String name, String publicId, String systemId) throws SAXException {
+    }
+
+    public void startEntity(String name) throws SAXException {
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/SAXEventSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/SAXEventSerializer.java
new file mode 100644
index 0000000..4c416be
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/SAXEventSerializer.java
@@ -0,0 +1,436 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Stack;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.DefaultHandler;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class SAXEventSerializer extends DefaultHandler
+        implements LexicalHandler {
+
+    private Writer _writer;
+    private boolean _charactersAreCDATA;
+    private StringBuffer _characters;
+
+    private Stack _namespaceStack = new Stack();
+    protected List _namespaceAttributes;
+
+    public SAXEventSerializer(OutputStream s) throws IOException {
+        _writer = new OutputStreamWriter(s);
+        _charactersAreCDATA = false;
+    }
+
+    // -- ContentHandler interface ---------------------------------------
+
+    public void startDocument() throws SAXException {
+        try {
+            _writer.write("<sax xmlns=\"http://www.sun.com/xml/sax-events\">\n");
+            _writer.write("<startDocument/>\n");
+            _writer.flush();
+        }
+        catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void endDocument() throws SAXException {
+        try {
+            _writer.write("<endDocument/>\n");
+            _writer.write("</sax>");
+            _writer.flush();
+            _writer.close();
+        }
+        catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    public void startPrefixMapping(String prefix, String uri)
+        throws SAXException
+    {
+        if (_namespaceAttributes == null) {
+            _namespaceAttributes = new ArrayList();
+        }
+
+        String qName = (prefix == "") ? "xmlns" : "xmlns" + prefix;
+        AttributeValueHolder attribute = new AttributeValueHolder(
+                qName,
+                prefix,
+                uri,
+                null,
+                null);
+        _namespaceAttributes.add(attribute);
+    }
+
+    public void endPrefixMapping(String prefix)
+        throws SAXException
+    {
+        /*
+        try {
+            outputCharacters();
+
+            _writer.write("<endPrefixMapping prefix=\"" +
+                prefix + "\"/>\n");
+            _writer.flush();
+        }
+        catch (IOException e) {
+            throw new SAXException(e);
+        }
+         */
+    }
+
+    public void startElement(String uri, String localName,
+            String qName, Attributes attributes)
+        throws SAXException
+    {
+        try {
+            outputCharacters();
+
+            if (_namespaceAttributes != null) {
+
+                AttributeValueHolder[] attrsHolder = new AttributeValueHolder[0];
+                attrsHolder = (AttributeValueHolder[])_namespaceAttributes.toArray(attrsHolder);
+
+                // Sort attributes
+                quicksort(attrsHolder, 0, attrsHolder.length - 1);
+
+                for (int i = 0; i < attrsHolder.length; i++) {
+                    _writer.write("<startPrefixMapping prefix=\"" +
+                        attrsHolder[i].localName + "\" uri=\"" + attrsHolder[i].uri + "\"/>\n");
+                    _writer.flush();
+                }
+
+                _namespaceStack.push(attrsHolder);
+                _namespaceAttributes = null;
+            } else {
+                _namespaceStack.push(null);
+            }
+
+            AttributeValueHolder[] attrsHolder =
+                new AttributeValueHolder[attributes.getLength()];
+            for (int i = 0; i < attributes.getLength(); i++) {
+                attrsHolder[i] = new AttributeValueHolder(
+                    attributes.getQName(i),
+                    attributes.getLocalName(i),
+                    attributes.getURI(i),
+                    attributes.getType(i),
+                    attributes.getValue(i));
+            }
+
+            // Sort attributes
+            quicksort(attrsHolder, 0, attrsHolder.length - 1);
+
+            int attributeCount = 0;
+            for (int i = 0; i < attrsHolder.length; i++) {
+                if (attrsHolder[i].uri.equals("http://www.w3.org/2000/xmlns/")) {
+                    // Ignore XMLNS attributes
+                    continue;
+                }
+                attributeCount++;
+            }
+
+            if (attributeCount == 0) {
+                _writer.write("<startElement uri=\"" + uri
+                    + "\" localName=\"" + localName + "\" qName=\""
+                    + qName + "\"/>\n");
+                return;
+            }
+
+            _writer.write("<startElement uri=\"" + uri
+                + "\" localName=\"" + localName + "\" qName=\""
+                + qName + "\">\n");
+
+            // Serialize attributes as children
+            for (int i = 0; i < attrsHolder.length; i++) {
+                if (attrsHolder[i].uri.equals("http://www.w3.org/2000/xmlns/")) {
+                    // Ignore XMLNS attributes
+                    continue;
+                }
+                _writer.write(
+                    "  <attribute qName=\"" + attrsHolder[i].qName +
+                    "\" localName=\"" + attrsHolder[i].localName +
+                    "\" uri=\"" + attrsHolder[i].uri +
+                    // "\" type=\"" + attrsHolder[i].type +
+                    "\" value=\"" + attrsHolder[i].value +
+                    "\"/>\n");
+            }
+
+            _writer.write("</startElement>\n");
+            _writer.flush();
+        }
+        catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void endElement(String uri, String localName, String qName)
+            throws SAXException
+    {
+        try {
+            outputCharacters();
+
+            _writer.write("<endElement uri=\"" + uri
+                + "\" localName=\"" + localName + "\" qName=\""
+                + qName + "\"/>\n");
+            _writer.flush();
+
+            // Write out the end prefix here rather than waiting
+            // for the explicit events
+            AttributeValueHolder[] attrsHolder = (AttributeValueHolder[])_namespaceStack.pop();
+            if (attrsHolder != null) {
+                for (int i = 0; i < attrsHolder.length; i++) {
+                    _writer.write("<endPrefixMapping prefix=\"" +
+                        attrsHolder[i].localName  + "\"/>\n");
+                    _writer.flush();
+                }
+            }
+
+        }
+        catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void characters(char[] ch, int start, int length)
+            throws SAXException
+    {
+        if (length == 0) {
+            return;
+        }
+
+        if (_characters == null) {
+            _characters = new StringBuffer();
+        }
+
+        // Coalesce multiple character events
+        _characters.append(ch, start, length);
+
+        /*
+        try {
+            _writer.write("<characters>" +
+                (_charactersAreCDATA ? "<![CDATA[" : "") +
+                new String(ch, start, length) +
+                (_charactersAreCDATA ? "]]>" : "") +
+                "</characters>\n");
+            _writer.flush();
+        }
+        catch (IOException e) {
+            throw new SAXException(e);
+        }
+         */
+    }
+
+    private void outputCharacters() throws SAXException {
+        if (_characters == null) {
+            return;
+        }
+
+        try {
+            _writer.write("<characters>" +
+                (_charactersAreCDATA ? "<![CDATA[" : "") +
+                _characters +
+                (_charactersAreCDATA ? "]]>" : "") +
+                "</characters>\n");
+            _writer.flush();
+
+            _characters = null;
+        } catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void ignorableWhitespace(char[] ch, int start, int length)
+            throws SAXException
+    {
+        // Report ignorable ws as characters (assumes validation off)
+        characters(ch, start, length);
+    }
+
+    public void processingInstruction(String target, String data)
+            throws SAXException
+    {
+        try {
+            outputCharacters();
+
+            _writer.write("<processingInstruction target=\"" + target
+                + "\" data=\"" + data + "\"/>\n");
+            _writer.flush();
+        }
+        catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    // -- LexicalHandler interface ---------------------------------------
+
+    public void startDTD(String name, String publicId, String systemId)
+            throws SAXException {
+        // Not implemented
+    }
+
+    public void endDTD()
+            throws SAXException {
+        // Not implemented
+    }
+
+    public void startEntity(String name)
+            throws SAXException {
+        // Not implemented
+    }
+
+    public void endEntity(String name)
+            throws SAXException {
+        // Not implemented
+    }
+
+    public void startCDATA()
+            throws SAXException {
+        _charactersAreCDATA = true;
+    }
+
+    public void endCDATA()
+            throws SAXException {
+        _charactersAreCDATA = false;
+    }
+
+    public void comment(char[] ch, int start, int length)
+            throws SAXException
+    {
+        try {
+            outputCharacters();
+
+            _writer.write("<comment>" +
+                new String(ch, start, length) +
+                "</comment>\n");
+            _writer.flush();
+        }
+        catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    // -- Utility methods ------------------------------------------------
+
+    private void quicksort(AttributeValueHolder[] attrs, int p, int r) {
+        while (p < r) {
+            final int q = partition(attrs, p, r);
+            quicksort(attrs, p, q);
+            p = q + 1;
+        }
+    }
+
+    private int partition(AttributeValueHolder[] attrs, int p, int r) {
+        AttributeValueHolder x = attrs[(p + r) >>> 1];
+        int i = p - 1;
+        int j = r + 1;
+        while (true) {
+            while (x.compareTo(attrs[--j]) < 0);
+            while (x.compareTo(attrs[++i]) > 0);
+            if (i < j) {
+                final AttributeValueHolder t = attrs[i];
+                attrs[i] = attrs[j];
+                attrs[j] = t;
+            }
+            else {
+                return j;
+            }
+        }
+    }
+
+    public static class AttributeValueHolder implements Comparable {
+        public final String qName;
+        public final String localName;
+        public final String uri;
+        public final String type;
+        public final String value;
+
+        public AttributeValueHolder(String qName,
+            String localName,
+            String uri,
+            String type,
+            String value)
+        {
+            this.qName = qName;
+            this.localName = localName;
+            this.uri = uri;
+            this.type = type;
+            this.value = value;
+        }
+
+        public int compareTo(Object o) {
+            try {
+                return qName.compareTo(((AttributeValueHolder) o).qName);
+            }
+            catch (Exception e) {
+                throw new RuntimeException(CommonResourceBundle.getInstance().getString("message.AttributeValueHolderExpected"));
+            }
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/StAX2SAXReader.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/StAX2SAXReader.java
new file mode 100644
index 0000000..e641b36
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/StAX2SAXReader.java
@@ -0,0 +1,200 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.AttributesImpl;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class StAX2SAXReader {
+
+    /**
+     * Content handler where events are pushed.
+     */
+    ContentHandler _handler;
+
+    /**
+     * Lexical handler to report lexical events.
+     */
+    LexicalHandler _lexicalHandler;
+
+    /**
+     * XML stream reader where events are pulled.
+     */
+    XMLStreamReader _reader;
+
+    public StAX2SAXReader(XMLStreamReader reader, ContentHandler handler) {
+        _handler = handler;
+        _reader = reader;
+    }
+
+    public StAX2SAXReader(XMLStreamReader reader) {
+        _reader = reader;
+    }
+
+    public void setContentHandler(ContentHandler handler) {
+        _handler = handler;
+    }
+
+    public void setLexicalHandler(LexicalHandler lexicalHandler) {
+        _lexicalHandler = lexicalHandler;
+    }
+
+    public void adapt() throws XMLStreamException, SAXException {
+        QName qname;
+        String prefix, localPart;
+        AttributesImpl attrs = new AttributesImpl();
+        char[] buffer;
+        int nsc;
+        int nat;
+
+        _handler.startDocument();
+
+        try {
+
+            while (_reader.hasNext()) {
+                int event = _reader.next();
+
+
+                switch(event) {
+                case  XMLStreamConstants.START_ELEMENT: {
+                    // Report namespace events first
+                    nsc = _reader.getNamespaceCount();
+                    for (int i = 0; i < nsc; i++) {
+                        _handler.startPrefixMapping(_reader.getNamespacePrefix(i),
+                            _reader.getNamespaceURI(i));
+                    }
+
+                    // Collect list of attributes
+                    attrs.clear();
+                    nat = _reader.getAttributeCount();
+                    for (int i = 0; i < nat; i++) {
+                        QName q = _reader.getAttributeName(i);
+                        String qName = _reader.getAttributePrefix(i);
+                        if (qName == null || qName == "") {
+                            qName = q.getLocalPart();
+                        } else {
+                            qName = qName + ":" +  q.getLocalPart();
+                        }
+                        attrs.addAttribute(_reader.getAttributeNamespace(i),
+                                           q.getLocalPart(),
+                                           qName,
+                                           _reader.getAttributeType(i),
+                                           _reader.getAttributeValue(i));
+                    }
+
+                    // Report start element
+                    qname = _reader.getName();
+                    prefix = qname.getPrefix();
+                    localPart = qname.getLocalPart();
+
+                    _handler.startElement(_reader.getNamespaceURI(),
+                                          localPart,
+                                          (prefix.length() > 0) ?
+                                              (prefix + ":" + localPart) : localPart,
+                                          attrs);
+                    break;
+                }
+                case  XMLStreamConstants.END_ELEMENT: {
+                    // Report end element
+                    qname = _reader.getName();
+                    prefix = qname.getPrefix();
+                    localPart = qname.getLocalPart();
+
+                    _handler.endElement(_reader.getNamespaceURI(),
+                                        localPart,
+                                        (prefix.length() > 0) ?
+                                            (prefix + ":" + localPart) : localPart);
+
+                    // Report end namespace events
+                    nsc = _reader.getNamespaceCount();
+                    for (int i = 0; i < nsc; i++) {
+                        _handler.endPrefixMapping(_reader.getNamespacePrefix(i));
+                    }
+                    break;
+                }
+                case XMLStreamConstants.CHARACTERS:
+                    _handler.characters(_reader.getTextCharacters(), _reader.getTextStart(), _reader.getTextLength());
+                    break;
+                case XMLStreamConstants.COMMENT:
+                    _lexicalHandler.comment(_reader.getTextCharacters(), _reader.getTextStart(), _reader.getTextLength());
+                    break;
+                case XMLStreamConstants.PROCESSING_INSTRUCTION:
+                    _handler.processingInstruction(_reader.getPITarget(), _reader.getPIData());
+                    break;
+                case XMLStreamConstants.END_DOCUMENT:
+                    break;
+                default:
+                    throw new RuntimeException(CommonResourceBundle.getInstance().getString("message.StAX2SAXReader", new Object[]{new Integer(event)}));
+                } // switch
+            }
+        }
+        catch (XMLStreamException e) {
+            _handler.endDocument();     // flush whatever we have
+            throw e;
+        }
+
+        _handler.endDocument();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/TransformInputOutput.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/TransformInputOutput.java
new file mode 100644
index 0000000..dee0db0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/TransformInputOutput.java
@@ -0,0 +1,93 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import java.io.BufferedInputStream;
+import java.io.BufferedOutputStream;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.InputStream;
+import java.io.OutputStream;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public abstract class TransformInputOutput {
+
+    /** Creates a new instance of TransformInputOutput */
+    public TransformInputOutput() {
+    }
+
+    public void parse(String[] args) throws Exception {
+        InputStream in = null;
+        OutputStream out = null;
+        if (args.length == 0) {
+            in = new BufferedInputStream(System.in);
+            out = new BufferedOutputStream(System.out);
+        } else if (args.length == 1) {
+            in = new BufferedInputStream(new FileInputStream(args[0]));
+            out = new BufferedOutputStream(System.out);
+        } else if (args.length == 2) {
+            in = new BufferedInputStream(new FileInputStream(args[0]));
+            out = new BufferedOutputStream(new FileOutputStream(args[1]));
+        } else {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.optinalFileNotSpecified"));
+        }
+
+        parse(in, out);
+    }
+
+    abstract void parse(InputStream in, OutputStream out) throws Exception;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/VocabularyGenerator.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/VocabularyGenerator.java
new file mode 100644
index 0000000..36c62de
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/VocabularyGenerator.java
@@ -0,0 +1,316 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.util.CharArray;
+import com.sun.xml.internal.fastinfoset.util.DuplicateAttributeVerifier;
+import com.sun.xml.internal.fastinfoset.util.KeyIntMap;
+import com.sun.xml.internal.fastinfoset.util.LocalNameQualifiedNamesMap;
+import com.sun.xml.internal.fastinfoset.util.PrefixArray;
+import com.sun.xml.internal.fastinfoset.util.QualifiedNameArray;
+import com.sun.xml.internal.fastinfoset.util.StringArray;
+import com.sun.xml.internal.fastinfoset.util.StringIntMap;
+import com.sun.xml.internal.fastinfoset.vocab.ParserVocabulary;
+import com.sun.xml.internal.fastinfoset.vocab.SerializerVocabulary;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.DefaultHandler;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+import java.util.Set;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSerializer;
+
+public class VocabularyGenerator extends DefaultHandler implements LexicalHandler {
+
+    protected SerializerVocabulary _serializerVocabulary;
+    protected ParserVocabulary _parserVocabulary;
+    protected com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary _v;
+
+    protected int attributeValueSizeConstraint = FastInfosetSerializer.ATTRIBUTE_VALUE_SIZE_CONSTRAINT;
+
+    protected int characterContentChunkSizeContraint = FastInfosetSerializer.CHARACTER_CONTENT_CHUNK_SIZE_CONSTRAINT;
+
+    /** Creates a new instance of VocabularyGenerator */
+    public VocabularyGenerator() {
+        _serializerVocabulary = new SerializerVocabulary();
+        _parserVocabulary = new ParserVocabulary();
+
+        _v = new com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary();
+    }
+
+    public VocabularyGenerator(SerializerVocabulary serializerVocabulary) {
+        _serializerVocabulary = serializerVocabulary;
+        _parserVocabulary = new ParserVocabulary();
+
+        _v = new com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary();
+    }
+
+    public VocabularyGenerator(ParserVocabulary parserVocabulary) {
+        _serializerVocabulary = new SerializerVocabulary();
+        _parserVocabulary = parserVocabulary;
+
+        _v = new com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary();
+    }
+
+    /** Creates a new instance of VocabularyGenerator */
+    public VocabularyGenerator(SerializerVocabulary serializerVocabulary, ParserVocabulary parserVocabulary) {
+        _serializerVocabulary = serializerVocabulary;
+        _parserVocabulary = parserVocabulary;
+
+        _v = new com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary();
+    }
+
+    public com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary getVocabulary() {
+        return _v;
+    }
+
+    public void setCharacterContentChunkSizeLimit(int size) {
+        if (size < 0 ) {
+            size = 0;
+        }
+
+        characterContentChunkSizeContraint = size;
+    }
+
+    public int getCharacterContentChunkSizeLimit() {
+        return characterContentChunkSizeContraint;
+    }
+
+    public void setAttributeValueSizeLimit(int size) {
+        if (size < 0 ) {
+            size = 0;
+        }
+
+        attributeValueSizeConstraint = size;
+    }
+
+    public int getAttributeValueSizeLimit() {
+        return attributeValueSizeConstraint;
+    }
+
+    // ContentHandler
+
+    public void startDocument() throws SAXException {
+    }
+
+    public void endDocument() throws SAXException {
+    }
+
+    public void startPrefixMapping(String prefix, String uri) throws SAXException {
+        addToTable(prefix, _v.prefixes, _serializerVocabulary.prefix, _parserVocabulary.prefix);
+        addToTable(uri, _v.namespaceNames, _serializerVocabulary.namespaceName, _parserVocabulary.namespaceName);
+    }
+
+    public void endPrefixMapping(String prefix) throws SAXException {
+    }
+
+    public void startElement(String namespaceURI, String localName, String qName, Attributes atts) throws SAXException {
+        addToNameTable(namespaceURI, qName, localName,
+                _v.elements, _serializerVocabulary.elementName, _parserVocabulary.elementName, false);
+
+        for (int a = 0; a < atts.getLength(); a++) {
+            addToNameTable(atts.getURI(a), atts.getQName(a), atts.getLocalName(a),
+                    _v.attributes, _serializerVocabulary.attributeName, _parserVocabulary.attributeName, true);
+
+            String value = atts.getValue(a);
+            if (value.length() < attributeValueSizeConstraint) {
+                addToTable(value, _v.attributeValues, _serializerVocabulary.attributeValue, _parserVocabulary.attributeValue);
+            }
+        }
+    }
+
+    public void endElement(String namespaceURI, String localName, String qName) throws SAXException {
+    }
+
+    public void characters(char[] ch, int start, int length) throws SAXException {
+        if (length < characterContentChunkSizeContraint) {
+            addToCharArrayTable(new CharArray(ch, start, length, true));
+        }
+    }
+
+    public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
+    }
+
+    public void processingInstruction(String target, String data) throws SAXException {
+    }
+
+    public void setDocumentLocator(org.xml.sax.Locator locator) {
+    }
+
+    public void skippedEntity(String name) throws SAXException {
+    }
+
+
+
+    // LexicalHandler
+
+    public void comment(char[] ch, int start, int length) throws SAXException {
+    }
+
+    public void startCDATA() throws SAXException {
+    }
+
+    public void endCDATA() throws SAXException {
+    }
+
+    public void startDTD(String name, String publicId, String systemId) throws SAXException {
+    }
+
+    public void endDTD() throws SAXException {
+    }
+
+    public void startEntity(String name) throws SAXException {
+    }
+
+    public void endEntity(String name) throws SAXException {
+    }
+
+
+    public void addToTable(String s, Set v, StringIntMap m, StringArray a) {
+        if (s == "") {
+            return;
+        }
+
+        if (m.obtainIndex(s) == KeyIntMap.NOT_PRESENT) {
+            a.add(s);
+        }
+
+        v.add(s);
+    }
+
+    public void addToTable(String s, Set v, StringIntMap m, PrefixArray a) {
+        if (s == "") {
+            return;
+        }
+
+        if (m.obtainIndex(s) == KeyIntMap.NOT_PRESENT) {
+            a.add(s);
+        }
+
+        v.add(s);
+    }
+
+    public void addToCharArrayTable(CharArray c) {
+        if (_serializerVocabulary.characterContentChunk.obtainIndex(c.ch, c.start, c.length, false) == KeyIntMap.NOT_PRESENT) {
+            _parserVocabulary.characterContentChunk.add(c.ch, c.length);
+        }
+
+        _v.characterContentChunks.add(c.toString());
+    }
+
+    public void addToNameTable(String namespaceURI, String qName, String localName,
+            Set v, LocalNameQualifiedNamesMap m, QualifiedNameArray a,
+            boolean isAttribute) throws SAXException {
+        LocalNameQualifiedNamesMap.Entry entry = m.obtainEntry(qName);
+        if (entry._valueIndex > 0) {
+            QualifiedName[] names = entry._value;
+            for (int i = 0; i < entry._valueIndex; i++) {
+                if ((namespaceURI == names[i].namespaceName || namespaceURI.equals(names[i].namespaceName))) {
+                    return;
+                }
+            }
+        }
+
+        String prefix = getPrefixFromQualifiedName(qName);
+
+        int namespaceURIIndex = -1;
+        int prefixIndex = -1;
+        int localNameIndex = -1;
+        if (namespaceURI != "") {
+            namespaceURIIndex = _serializerVocabulary.namespaceName.get(namespaceURI);
+            if (namespaceURIIndex == KeyIntMap.NOT_PRESENT) {
+                throw new SAXException(CommonResourceBundle.getInstance().
+                        getString("message.namespaceURINotIndexed", new Object[]{new Integer(namespaceURIIndex)}));
+            }
+
+            if (prefix != "") {
+                prefixIndex = _serializerVocabulary.prefix.get(prefix);
+                if (prefixIndex == KeyIntMap.NOT_PRESENT) {
+                    throw new SAXException(CommonResourceBundle.getInstance().
+                            getString("message.prefixNotIndexed", new Object[]{new Integer(prefixIndex)}));
+                }
+            }
+        }
+
+        localNameIndex = _serializerVocabulary.localName.obtainIndex(localName);
+        if (localNameIndex == KeyIntMap.NOT_PRESENT) {
+            _parserVocabulary.localName.add(localName);
+            localNameIndex = _parserVocabulary.localName.getSize() - 1;
+        }
+        QualifiedName name = new QualifiedName(prefix, namespaceURI, localName, m.getNextIndex(),
+                prefixIndex, namespaceURIIndex, localNameIndex);
+        if (isAttribute) {
+            name.createAttributeValues(DuplicateAttributeVerifier.MAP_SIZE);
+        }
+        entry.addQualifiedName(name);
+        a.add(name);
+
+        v.add(name.getQName());
+    }
+
+    public static String getPrefixFromQualifiedName(String qName) {
+        int i = qName.indexOf(':');
+        String prefix = "";
+        if (i != -1) {
+            prefix = qName.substring(0, i);
+        }
+        return prefix;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_DOM_FI.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_DOM_FI.java
new file mode 100644
index 0000000..d1b4ab1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_DOM_FI.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.dom.DOMDocumentSerializer;
+import java.io.InputStream;
+import java.io.OutputStream;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import org.w3c.dom.Document;
+
+public class XML_DOM_FI extends TransformInputOutput {
+
+    public XML_DOM_FI() {
+    }
+
+    public void parse(InputStream document, OutputStream finf) throws Exception {
+        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+        dbf.setNamespaceAware(true);
+        DocumentBuilder db = dbf.newDocumentBuilder();
+        Document d = db.parse(document);
+
+        DOMDocumentSerializer s = new DOMDocumentSerializer();
+        s.setOutputStream(finf);
+        s.serialize(d);
+    }
+
+    public static void main(String[] args) throws Exception {
+        XML_DOM_FI p = new XML_DOM_FI();
+        p.parse(args);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_DOM_SAX_FI.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_DOM_SAX_FI.java
new file mode 100644
index 0000000..d50276a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_DOM_SAX_FI.java
@@ -0,0 +1,92 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetResult;
+import java.io.InputStream;
+import java.io.OutputStream;
+
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.dom.DOMSource;
+
+import org.w3c.dom.Document;
+
+public class XML_DOM_SAX_FI extends TransformInputOutput {
+
+    public XML_DOM_SAX_FI() {
+    }
+
+    public void parse(InputStream document, OutputStream finf) throws Exception {
+        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+        dbf.setNamespaceAware(true);
+        DocumentBuilder db = dbf.newDocumentBuilder();
+        Document d = db.parse(document);
+
+        TransformerFactory tf = TransformerFactory.newInstance();
+        Transformer t = tf.newTransformer();
+        t.transform(new DOMSource(d), new FastInfosetResult(finf));
+    }
+
+    public static void main(String[] args) throws Exception {
+        XML_DOM_SAX_FI p = new XML_DOM_SAX_FI();
+        p.parse(args);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_SAX_FI.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_SAX_FI.java
new file mode 100644
index 0000000..4377c17
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_SAX_FI.java
@@ -0,0 +1,110 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.sax.SAXDocumentSerializer;
+import java.io.InputStream;
+import java.io.OutputStream;
+import javax.xml.parsers.SAXParser;
+import javax.xml.parsers.SAXParserFactory;
+import java.io.Reader;
+import org.xml.sax.InputSource;
+
+public class XML_SAX_FI extends TransformInputOutput {
+
+    public XML_SAX_FI() {
+    }
+
+    public void parse(InputStream xml, OutputStream finf) throws Exception {
+        SAXParser saxParser = getParser();
+        SAXDocumentSerializer documentSerializer = getSerializer(finf);
+
+        saxParser.setProperty("http://xml.org/sax/properties/lexical-handler", documentSerializer);
+        saxParser.parse(xml, documentSerializer);
+    }
+
+    public void convert(Reader reader, OutputStream finf) throws Exception {
+        InputSource is = new InputSource(reader);
+
+        SAXParser saxParser = getParser();
+        SAXDocumentSerializer documentSerializer = getSerializer(finf);
+
+        saxParser.setProperty("http://xml.org/sax/properties/lexical-handler", documentSerializer);
+        saxParser.parse(is, documentSerializer);
+    }
+
+    private SAXParser getParser() {
+        SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
+        saxParserFactory.setNamespaceAware(true);
+        try {
+            return saxParserFactory.newSAXParser();
+        } catch (Exception e)
+        {
+            return null;
+        }
+    }
+
+    private SAXDocumentSerializer getSerializer(OutputStream finf) {
+        SAXDocumentSerializer documentSerializer = new SAXDocumentSerializer();
+        documentSerializer.setOutputStream(finf);
+        return documentSerializer;
+    }
+    public static void main(String[] args) throws Exception {
+        XML_SAX_FI s = new XML_SAX_FI();
+        s.parse(args);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_SAX_StAX_FI.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_SAX_StAX_FI.java
new file mode 100644
index 0000000..81a6f2b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/tools/XML_SAX_StAX_FI.java
@@ -0,0 +1,92 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.tools;
+
+import com.sun.xml.internal.fastinfoset.stax.StAXDocumentSerializer;
+import java.io.InputStream;
+import java.io.OutputStream;
+import javax.xml.parsers.SAXParser;
+import javax.xml.parsers.SAXParserFactory;
+import com.sun.xml.internal.fastinfoset.tools.SAX2StAXWriter;
+
+public class XML_SAX_StAX_FI extends TransformInputOutput {
+
+    public XML_SAX_StAX_FI() {
+    }
+
+    public void parse(InputStream xml, OutputStream finf) throws Exception {
+        StAXDocumentSerializer documentSerializer = new StAXDocumentSerializer();
+        documentSerializer.setOutputStream(finf);
+
+        SAX2StAXWriter saxTostax = new SAX2StAXWriter(documentSerializer);
+
+        SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
+        saxParserFactory.setNamespaceAware(true);
+        SAXParser saxParser = saxParserFactory.newSAXParser();
+
+        saxParser.setProperty("http://xml.org/sax/properties/lexical-handler", saxTostax);
+        saxParser.parse(xml, saxTostax);
+        xml.close();
+        finf.close();
+    }
+
+    public static void main(String[] args) throws Exception {
+        XML_SAX_StAX_FI s = new XML_SAX_StAX_FI();
+        s.parse(args);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArray.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArray.java
new file mode 100644
index 0000000..0d199d7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArray.java
@@ -0,0 +1,185 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+public class CharArray implements CharSequence {
+    public char[] ch;
+    public int start;
+    public int length;
+
+    protected int _hash;
+
+    protected CharArray() {
+    }
+
+    public CharArray(char[] _ch, int _start, int _length, boolean copy) {
+        set(_ch, _start, _length, copy);
+    }
+
+    public final void set(char[] _ch, int _start, int _length, boolean copy) {
+        if (copy) {
+            ch = new char[_length];
+            start = 0;
+            length = _length;
+            System.arraycopy(_ch, _start, ch, 0, _length);
+        } else {
+            ch = _ch;
+            start = _start;
+            length = _length;
+        }
+        _hash = 0;
+    }
+
+    public final void cloneArray() {
+        char[] _ch = new char[length];
+        System.arraycopy(ch, start, _ch, 0, length);
+        ch = _ch;
+        start = 0;
+    }
+
+    public String toString() {
+        return new String(ch, start, length);
+    }
+
+    public int hashCode() {
+        if (_hash == 0) {
+            // Same hash code algorithm as used for String
+            // s[0]*31^(n-1) + s[1]*31^(n-2) + ... + s[n-1]
+            for (int i = start; i < start + length; i++) {
+                _hash = 31*_hash + ch[i];
+            }
+        }
+        return _hash;
+    }
+
+    public static final int hashCode(char[] ch, int start, int length) {
+        int hash = 0;
+        for (int i = start; i < start + length; i++) {
+            hash = 31*hash + ch[i];
+        }
+
+        return hash;
+    }
+
+    public final boolean equalsCharArray(CharArray cha) {
+        if (this == cha) {
+            return true;
+        }
+
+        if (length == cha.length) {
+            int n = length;
+            int i = start;
+            int j = cha.start;
+            while (n-- != 0) {
+                if (ch[i++] != cha.ch[j++])
+                    return false;
+            }
+            return true;
+        }
+
+        return false;
+    }
+
+    public final boolean equalsCharArray(char[] ch, int start, int length) {
+        if (this.length == length) {
+            int n = this.length;
+            int i = this.start;
+            int j = start;
+            while (n-- != 0) {
+                if (this.ch[i++] != ch[j++])
+                    return false;
+            }
+            return true;
+        }
+
+        return false;
+    }
+
+    public boolean equals(Object obj) {
+        if (this == obj) {
+            return true;
+        }
+        if (obj instanceof CharArray) {
+            CharArray cha = (CharArray)obj;
+            if (length == cha.length) {
+                int n = length;
+                int i = start;
+                int j = cha.start;
+                while (n-- != 0) {
+                    if (ch[i++] != cha.ch[j++])
+                        return false;
+                }
+                return true;
+            }
+        }
+        return false;
+    }
+
+    // CharSequence interface
+
+    public final int length() {
+        return length;
+    }
+
+    public final char charAt(int index) {
+        return ch[start + index];
+    }
+
+    public final CharSequence subSequence(int start, int end) {
+        return new CharArray(ch, this.start + start, end - start, false);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayArray.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayArray.java
new file mode 100644
index 0000000..d223b06
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayArray.java
@@ -0,0 +1,140 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class CharArrayArray extends ValueArray {
+
+    private CharArray[] _array;
+
+    private CharArrayArray _readOnlyArray;
+
+    public CharArrayArray(int initialCapacity, int maximumCapacity) {
+        _array = new CharArray[initialCapacity];
+        _maximumCapacity = maximumCapacity;
+    }
+
+    public CharArrayArray() {
+        this(DEFAULT_CAPACITY, MAXIMUM_CAPACITY);
+    }
+
+    public final void clear() {
+        for (int i = 0; i < _size; i++) {
+            _array[i] = null;
+        }
+        _size = 0;
+    }
+
+    public final CharArray[] getArray() {
+        return _array;
+    }
+
+    public final void setReadOnlyArray(ValueArray readOnlyArray, boolean clear) {
+        if (!(readOnlyArray instanceof CharArrayArray)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.illegalClass", new Object[]{readOnlyArray}));
+        }
+
+        setReadOnlyArray((CharArrayArray)readOnlyArray, clear);
+    }
+
+    public final void setReadOnlyArray(CharArrayArray readOnlyArray, boolean clear) {
+        if (readOnlyArray != null) {
+            _readOnlyArray = readOnlyArray;
+            _readOnlyArraySize = readOnlyArray.getSize();
+
+            if (clear) {
+                clear();
+            }
+        }
+    }
+
+    public final CharArray get(int i) {
+        if (_readOnlyArray == null) {
+            return _array[i];
+        } else {
+            if (i < _readOnlyArraySize) {
+               return _readOnlyArray.get(i);
+            } else {
+                return _array[i - _readOnlyArraySize];
+            }
+        }
+   }
+
+    public final void add(CharArray s) {
+        if (_size == _array.length) {
+            resize();
+        }
+
+       _array[_size++] = s;
+    }
+
+    protected final void resize() {
+        if (_size == _maximumCapacity) {
+            throw new ValueArrayResourceException(CommonResourceBundle.getInstance().getString("message.arrayMaxCapacity"));
+        }
+
+        int newSize = _size * 3 / 2 + 1;
+        if (newSize > _maximumCapacity) {
+            newSize = _maximumCapacity;
+        }
+
+        final CharArray[] newArray = new CharArray[newSize];
+        System.arraycopy(_array, 0, newArray, 0, _size);
+        _array = newArray;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayIntMap.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayIntMap.java
new file mode 100644
index 0000000..a2aba6c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayIntMap.java
@@ -0,0 +1,227 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class CharArrayIntMap extends KeyIntMap {
+
+    private CharArrayIntMap _readOnlyMap;
+
+    static class Entry extends BaseEntry {
+        final char[] _ch;
+        final int _start;
+        final int _length;
+        Entry _next;
+
+        public Entry(char[] ch, int start, int length, int hash, int value, Entry next) {
+            super(hash, value);
+            _ch = ch;
+            _start = start;
+            _length = length;
+            _next = next;
+        }
+
+        public final boolean equalsCharArray(char[] ch, int start, int length) {
+            if (_length == length) {
+                int n = _length;
+                int i = _start;
+                int j = start;
+                while (n-- != 0) {
+                    if (_ch[i++] != ch[j++])
+                        return false;
+                }
+                return true;
+            }
+
+            return false;
+        }
+
+    }
+
+    private Entry[] _table;
+
+    public CharArrayIntMap(int initialCapacity, float loadFactor) {
+        super(initialCapacity, loadFactor);
+
+        _table = new Entry[_capacity];
+    }
+
+    public CharArrayIntMap(int initialCapacity) {
+        this(initialCapacity, DEFAULT_LOAD_FACTOR);
+    }
+
+    public CharArrayIntMap() {
+        this(DEFAULT_INITIAL_CAPACITY, DEFAULT_LOAD_FACTOR);
+    }
+
+    public final void clear() {
+        for (int i = 0; i < _table.length; i++) {
+            _table[i] = null;
+        }
+        _size = 0;
+    }
+
+    public final void setReadOnlyMap(KeyIntMap readOnlyMap, boolean clear) {
+        if (!(readOnlyMap instanceof CharArrayIntMap)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalClass", new Object[]{readOnlyMap}));
+        }
+
+        setReadOnlyMap((CharArrayIntMap)readOnlyMap, clear);
+    }
+
+    public final void setReadOnlyMap(CharArrayIntMap readOnlyMap, boolean clear) {
+        _readOnlyMap = readOnlyMap;
+        if (_readOnlyMap != null) {
+            _readOnlyMapSize = _readOnlyMap.size();
+
+            if (clear) {
+                clear();
+            }
+        }  else {
+            _readOnlyMapSize = 0;
+        }
+    }
+
+    public final int obtainIndex(char[] ch, int start, int length, boolean clone) {
+        final int hash = hashHash(CharArray.hashCode(ch, start, length));
+
+        if (_readOnlyMap != null) {
+            final int index = _readOnlyMap.get(ch, start, length, hash);
+            if (index != -1) {
+                return index;
+            }
+        }
+
+        final int tableIndex = indexFor(hash, _table.length);
+        for (Entry e = _table[tableIndex]; e != null; e = e._next) {
+            if (e._hash == hash && e.equalsCharArray(ch, start, length)) {
+                return e._value;
+            }
+        }
+
+        if (clone) {
+            char[] chClone = new char[length];
+            System.arraycopy(ch, start, chClone, 0, length);
+
+            ch = chClone;
+            start = 0;
+        }
+
+        addEntry(ch, start, length, hash, _size + _readOnlyMapSize, tableIndex);
+        return NOT_PRESENT;
+    }
+
+    private final int get(char[] ch, int start, int length, int hash) {
+        if (_readOnlyMap != null) {
+            final int i = _readOnlyMap.get(ch, start, length, hash);
+            if (i != -1) {
+                return i;
+            }
+        }
+
+        final int tableIndex = indexFor(hash, _table.length);
+        for (Entry e = _table[tableIndex]; e != null; e = e._next) {
+            if (e._hash == hash && e.equalsCharArray(ch, start, length)) {
+                return e._value;
+            }
+        }
+
+        return -1;
+    }
+
+    private final void addEntry(char[] ch, int start, int length, int hash, int value, int bucketIndex) {
+        Entry e = _table[bucketIndex];
+        _table[bucketIndex] = new Entry(ch, start, length, hash, value, e);
+        if (_size++ >= _threshold) {
+            resize(2 * _table.length);
+        }
+    }
+
+    private final void resize(int newCapacity) {
+        _capacity = newCapacity;
+        Entry[] oldTable = _table;
+        int oldCapacity = oldTable.length;
+        if (oldCapacity == MAXIMUM_CAPACITY) {
+            _threshold = Integer.MAX_VALUE;
+            return;
+        }
+
+        Entry[] newTable = new Entry[_capacity];
+        transfer(newTable);
+        _table = newTable;
+        _threshold = (int)(_capacity * _loadFactor);
+    }
+
+    private final void transfer(Entry[] newTable) {
+        Entry[] src = _table;
+        int newCapacity = newTable.length;
+        for (int j = 0; j < src.length; j++) {
+            Entry e = src[j];
+            if (e != null) {
+                src[j] = null;
+                do {
+                    Entry next = e._next;
+                    int i = indexFor(e._hash, newCapacity);
+                    e._next = newTable[i];
+                    newTable[i] = e;
+                    e = next;
+                } while (e != null);
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayString.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayString.java
new file mode 100644
index 0000000..ff8196c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/CharArrayString.java
@@ -0,0 +1,106 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+public class CharArrayString extends CharArray {
+    protected String _s;
+
+    public CharArrayString(String s) {
+        this(s, true);
+    }
+
+    public CharArrayString(String s, boolean createArray) {
+        _s = s;
+        if (createArray) {
+            ch = _s.toCharArray();
+            start = 0;
+            length = ch.length;
+        }
+    }
+
+    public String toString() {
+        return _s;
+    }
+
+    public int hashCode() {
+        return _s.hashCode();
+    }
+
+    public boolean equals(Object obj) {
+        if (this == obj) {
+            return true;
+        }
+        if (obj instanceof CharArrayString) {
+            CharArrayString chas = (CharArrayString)obj;
+            return _s.equals(chas._s);
+        } else if (obj instanceof CharArray) {
+            CharArray cha = (CharArray)obj;
+            if (length == cha.length) {
+                int n = length;
+                int i = start;
+                int j = cha.start;
+                while (n-- != 0) {
+                    if (ch[i++] != cha.ch[j++])
+                        return false;
+                }
+                return true;
+            }
+        }
+        return false;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ContiguousCharArrayArray.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ContiguousCharArrayArray.java
new file mode 100644
index 0000000..e575960
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ContiguousCharArrayArray.java
@@ -0,0 +1,236 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class ContiguousCharArrayArray extends ValueArray {
+    public static final int INITIAL_CHARACTER_SIZE = 512;
+    public static final int MAXIMUM_CHARACTER_SIZE = Integer.MAX_VALUE;
+
+    protected int _maximumCharacterSize;
+
+    public int[] _offset;
+    public int[] _length;
+
+    public char[] _array;
+    public int _arrayIndex;
+    public int _readOnlyArrayIndex;
+
+    private String[] _cachedStrings;
+
+    public int _cachedIndex;
+
+    private ContiguousCharArrayArray _readOnlyArray;
+
+    public ContiguousCharArrayArray(int initialCapacity, int maximumCapacity,
+            int initialCharacterSize, int maximumCharacterSize) {
+        _offset = new int[initialCapacity];
+        _length = new int[initialCapacity];
+        _array = new char[initialCharacterSize];
+        _maximumCapacity = maximumCapacity;
+        _maximumCharacterSize = maximumCharacterSize;
+    }
+
+    public ContiguousCharArrayArray() {
+        this(DEFAULT_CAPACITY, MAXIMUM_CAPACITY,
+                INITIAL_CHARACTER_SIZE, MAXIMUM_CHARACTER_SIZE);
+    }
+
+    public final void clear() {
+        _arrayIndex = _readOnlyArrayIndex;
+        _size = _readOnlyArraySize;
+
+        if (_cachedStrings != null) {
+            for (int i = _readOnlyArraySize; i < _cachedStrings.length; i++) {
+                _cachedStrings[i] = null;
+            }
+        }
+    }
+
+    public final int getArrayIndex() {
+        return _arrayIndex;
+    }
+
+    public final void setReadOnlyArray(ValueArray readOnlyArray, boolean clear) {
+        if (!(readOnlyArray instanceof ContiguousCharArrayArray)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().getString("message.illegalClass", new Object[]{readOnlyArray}));
+        }
+
+        setReadOnlyArray((ContiguousCharArrayArray)readOnlyArray, clear);
+    }
+
+    public final void setReadOnlyArray(ContiguousCharArrayArray readOnlyArray, boolean clear) {
+        if (readOnlyArray != null) {
+            _readOnlyArray = readOnlyArray;
+            _readOnlyArraySize = readOnlyArray.getSize();
+            _readOnlyArrayIndex = readOnlyArray.getArrayIndex();
+
+            if (clear) {
+                clear();
+            }
+
+            _array = getCompleteCharArray();
+            _offset = getCompleteOffsetArray();
+            _length = getCompleteLengthArray();
+            _size = _readOnlyArraySize;
+        }
+    }
+
+    public final char[] getCompleteCharArray() {
+        if (_readOnlyArray == null) {
+            return _array;
+        } else {
+            final char[] ra = _readOnlyArray.getCompleteCharArray();
+            final char[] a = new char[_readOnlyArrayIndex + _array.length];
+            System.arraycopy(ra, 0, a, 0, _readOnlyArrayIndex);
+            return a;
+        }
+    }
+
+    public final int[] getCompleteOffsetArray() {
+        if (_readOnlyArray == null) {
+            return _offset;
+        } else {
+            final int[] ra = _readOnlyArray.getCompleteOffsetArray();
+            final int[] a = new int[_readOnlyArraySize + _offset.length];
+            System.arraycopy(ra, 0, a, 0, _readOnlyArraySize);
+            return a;
+        }
+    }
+
+    public final int[] getCompleteLengthArray() {
+        if (_readOnlyArray == null) {
+            return _length;
+        } else {
+            final int[] ra = _readOnlyArray.getCompleteOffsetArray();
+            final int[] a = new int[_readOnlyArraySize + _length.length];
+            System.arraycopy(ra, 0, a, 0, _readOnlyArraySize);
+            return a;
+        }
+    }
+
+    public final String getString(int i) {
+        if (_cachedStrings != null && i < _cachedStrings.length) {
+            final String s = _cachedStrings[i];
+            return (s != null) ? s : (_cachedStrings[i] = new String(_array, _offset[i], _length[i]));
+        }
+
+        final String[] newCachedStrings = new String[_offset.length];
+        if (_cachedStrings != null && i >= _cachedStrings.length) {
+            System.arraycopy(_cachedStrings, 0, newCachedStrings, 0, _cachedStrings.length);
+        }
+        _cachedStrings = newCachedStrings;
+
+        return _cachedStrings[i] = new String(_array, _offset[i], _length[i]);
+    }
+
+    public final int add(char[] c, int l) {
+        if (_size == _offset.length) {
+            resize();
+        }
+
+        final int oldArrayIndex = _arrayIndex;
+        final int arrayIndex = oldArrayIndex + l;
+
+        _cachedIndex = _size;
+        _offset[_size] = oldArrayIndex;
+        _length[_size++] = l;
+
+        if (arrayIndex >= _array.length) {
+            resizeArray(arrayIndex);
+        }
+
+        System.arraycopy(c, 0, _array, oldArrayIndex, l);
+
+        _arrayIndex = arrayIndex;
+        return oldArrayIndex;
+    }
+
+    protected final void resize() {
+        if (_size == _maximumCapacity) {
+            throw new ValueArrayResourceException(CommonResourceBundle.getInstance().getString("message.arrayMaxCapacity"));
+        }
+
+        int newSize = _size * 3 / 2 + 1;
+        if (newSize > _maximumCapacity) {
+            newSize = _maximumCapacity;
+        }
+
+        final int[] offset = new int[newSize];
+        System.arraycopy(_offset, 0, offset, 0, _size);
+        _offset = offset;
+
+        final int[] length = new int[newSize];
+        System.arraycopy(_length, 0, length, 0, _size);
+        _length = length;
+    }
+
+    protected final void resizeArray(int requestedSize) {
+        if (_arrayIndex == _maximumCharacterSize) {
+            throw new ValueArrayResourceException(CommonResourceBundle.getInstance().getString("message.maxNumberOfCharacters"));
+        }
+
+        int newSize = requestedSize * 3 / 2 + 1;
+        if (newSize > _maximumCharacterSize) {
+            newSize = _maximumCharacterSize;
+        }
+
+        final char[] array = new char[newSize];
+        System.arraycopy(_array, 0, array, 0, _arrayIndex);
+        _array = array;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/DuplicateAttributeVerifier.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/DuplicateAttributeVerifier.java
new file mode 100644
index 0000000..9111ef2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/DuplicateAttributeVerifier.java
@@ -0,0 +1,123 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+
+public class DuplicateAttributeVerifier {
+    public static final int MAP_SIZE = 256;
+
+    public int _currentIteration;
+
+    private static class Entry {
+        private int iteration;
+        private int value;
+
+        private Entry hashNext;
+
+        private Entry poolNext;
+    }
+
+    private Entry[] _map;
+
+    public final Entry _poolHead;
+    public Entry _poolCurrent;
+    private Entry _poolTail;
+
+
+    public DuplicateAttributeVerifier() {
+        _poolTail = _poolHead = new Entry();
+    }
+
+    public final void clear() {
+        _currentIteration = 0;
+
+        Entry e = _poolHead;
+        while (e != null) {
+            e.iteration = 0;
+            e = e.poolNext;
+        }
+
+        reset();
+    }
+
+    public final void reset() {
+        _poolCurrent = _poolHead;
+        if (_map == null) {
+            _map = new Entry[MAP_SIZE];
+        }
+    }
+
+    private final void increasePool(int capacity) {
+        if (_map == null) {
+            _map = new Entry[MAP_SIZE];
+            _poolCurrent = _poolHead;
+        } else {
+            final Entry tail = _poolTail;
+            for (int i = 0; i < capacity; i++) {
+                final Entry e = new Entry();
+                _poolTail.poolNext = e;
+                _poolTail = e;
+            }
+
+            _poolCurrent = tail.poolNext;
+        }
+    }
+
+    public final void checkForDuplicateAttribute(int hash, int value) throws FastInfosetException {
+        if (_poolCurrent == null) {
+            increasePool(16);
+        }
+
+        // Get next free entry
+        final Entry newEntry = _poolCurrent;
+        _poolCurrent = _poolCurrent.poolNext;
+
+        final Entry head = _map[hash];
+        if (head == null || head.iteration < _currentIteration) {
+            newEntry.hashNext = null;
+            _map[hash] = newEntry;
+            newEntry.iteration = _currentIteration;
+            newEntry.value = value;
+        } else {
+            Entry e = head;
+            do {
+                if (e.value == value) {
+                    reset();
+                    throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.duplicateAttribute"));
+                }
+            } while ((e = e.hashNext) != null);
+
+            newEntry.hashNext = head;
+            _map[hash] = newEntry;
+            newEntry.iteration = _currentIteration;
+            newEntry.value = value;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/FixedEntryStringIntMap.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/FixedEntryStringIntMap.java
new file mode 100644
index 0000000..a8ef866
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/FixedEntryStringIntMap.java
@@ -0,0 +1,137 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class FixedEntryStringIntMap extends StringIntMap {
+
+    private Entry _fixedEntry;
+
+    public FixedEntryStringIntMap(String fixedEntry, int initialCapacity, float loadFactor) {
+        super(initialCapacity, loadFactor);
+
+        // Add the fixed entry
+        final int hash = hashHash(fixedEntry.hashCode());
+        final int tableIndex = indexFor(hash, _table.length);
+        _table[tableIndex] = _fixedEntry = new Entry(fixedEntry, hash, 0, null);
+        if (_size++ >= _threshold) {
+            resize(2 * _table.length);
+        }
+    }
+
+    public FixedEntryStringIntMap(String fixedEntry, int initialCapacity) {
+        this(fixedEntry, initialCapacity, DEFAULT_LOAD_FACTOR);
+    }
+
+    public FixedEntryStringIntMap(String fixedEntry) {
+        this(fixedEntry, DEFAULT_INITIAL_CAPACITY, DEFAULT_LOAD_FACTOR);
+    }
+
+    public final void clear() {
+        for (int i = 0; i < _table.length; i++) {
+            _table[i] = null;
+        }
+        if (_fixedEntry != null) {
+            final int tableIndex = indexFor(_fixedEntry._hash, _table.length);
+            _table[tableIndex] = _fixedEntry;
+            _fixedEntry._next = null;
+            _size = 1;
+        }
+    }
+
+    public final void setReadOnlyMap(KeyIntMap readOnlyMap, boolean clear) {
+        if (!(readOnlyMap instanceof FixedEntryStringIntMap)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalClass", new Object[]{readOnlyMap}));
+        }
+
+        setReadOnlyMap((FixedEntryStringIntMap)readOnlyMap, clear);
+    }
+
+    public final void setReadOnlyMap(FixedEntryStringIntMap readOnlyMap, boolean clear) {
+        _readOnlyMap = readOnlyMap;
+        if (_readOnlyMap != null) {
+            readOnlyMap.removeFixedEntry();
+            _readOnlyMapSize = readOnlyMap.size();
+            if (clear) {
+                clear();
+            }
+        }  else {
+            _readOnlyMapSize = 0;
+        }
+    }
+
+    private final void removeFixedEntry() {
+        if (_fixedEntry != null) {
+            final int tableIndex = indexFor(_fixedEntry._hash, _table.length);
+            final Entry firstEntry = _table[tableIndex];
+            if (firstEntry == _fixedEntry) {
+                _table[tableIndex] = _fixedEntry._next;
+            } else {
+                Entry previousEntry = firstEntry;
+                while (previousEntry._next != _fixedEntry) {
+                    previousEntry = previousEntry._next;
+                }
+                previousEntry._next = _fixedEntry._next;
+            }
+
+            _fixedEntry = null;
+            _size--;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/KeyIntMap.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/KeyIntMap.java
new file mode 100644
index 0000000..f81fd00
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/KeyIntMap.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public abstract class KeyIntMap {
+    public static final int NOT_PRESENT = -1;
+
+    /**
+     * The default initial capacity - MUST be a power of two.
+     */
+    static final int DEFAULT_INITIAL_CAPACITY = 16;
+
+    /**
+     * The maximum capacity, used if a higher value is implicitly specified
+     * by either of the constructors with arguments.
+     * MUST be a power of two <= 1<<30.
+     */
+    static final int MAXIMUM_CAPACITY = 1 << 20;
+
+    /**
+     * The load factor used when none specified in constructor.
+     **/
+    static final float DEFAULT_LOAD_FACTOR = 0.75f;
+
+    int _readOnlyMapSize;
+
+    /**
+     * The number of key-value mappings contained in this identity hash map.
+     */
+    int _size;
+
+    int _capacity;
+
+    /**
+     * The next size value at which to resize (capacity * load factor).
+     */
+    int _threshold;
+
+    /**
+     * The load factor for the hash table.
+     */
+    final float _loadFactor;
+
+    static class BaseEntry {
+        final int _hash;
+        final int _value;
+
+        public BaseEntry(int hash, int value) {
+            _hash = hash;
+            _value = value;
+        }
+    }
+
+    public KeyIntMap(int initialCapacity, float loadFactor) {
+        if (initialCapacity < 0)
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalInitialCapacity", new Object[]{new Integer(initialCapacity)}));
+        if (initialCapacity > MAXIMUM_CAPACITY)
+            initialCapacity = MAXIMUM_CAPACITY;
+        if (loadFactor <= 0 || Float.isNaN(loadFactor))
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalLoadFactor", new Object[]{new Float(loadFactor)}));
+
+        // Find a power of 2 >= initialCapacity
+        if (initialCapacity != DEFAULT_INITIAL_CAPACITY) {
+            _capacity = 1;
+            while (_capacity < initialCapacity)
+                _capacity <<= 1;
+
+            _loadFactor = loadFactor;
+            _threshold = (int)(_capacity * _loadFactor);
+        } else {
+            _capacity = DEFAULT_INITIAL_CAPACITY;
+            _loadFactor = DEFAULT_LOAD_FACTOR;
+            _threshold = (int)(DEFAULT_INITIAL_CAPACITY * DEFAULT_LOAD_FACTOR);
+        }
+    }
+
+    public KeyIntMap(int initialCapacity) {
+        this(initialCapacity, DEFAULT_LOAD_FACTOR);
+    }
+
+    public KeyIntMap() {
+        _capacity = DEFAULT_INITIAL_CAPACITY;
+        _loadFactor = DEFAULT_LOAD_FACTOR;
+        _threshold = (int)(DEFAULT_INITIAL_CAPACITY * DEFAULT_LOAD_FACTOR);
+    }
+
+    public final int size() {
+        return _size + _readOnlyMapSize;
+    }
+
+    public abstract void clear();
+
+    public abstract void setReadOnlyMap(KeyIntMap readOnlyMap, boolean clear);
+
+
+    public static final int hashHash(int h) {
+        h += ~(h << 9);
+        h ^=  (h >>> 14);
+        h +=  (h << 4);
+        h ^=  (h >>> 10);
+        return h;
+    }
+
+    public static final int indexFor(int h, int length) {
+        return h & (length-1);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/LocalNameQualifiedNamesMap.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/LocalNameQualifiedNamesMap.java
new file mode 100644
index 0000000..b91fd4a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/LocalNameQualifiedNamesMap.java
@@ -0,0 +1,242 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class LocalNameQualifiedNamesMap extends KeyIntMap {
+
+    private LocalNameQualifiedNamesMap _readOnlyMap;
+
+    private int _index;
+
+    public static class Entry {
+        final String _key;
+        final int _hash;
+        public QualifiedName[] _value;
+        public int _valueIndex;
+        Entry _next;
+
+        public Entry(String key, int hash, Entry next) {
+            _key = key;
+            _hash = hash;
+            _next = next;
+            _value = new QualifiedName[1];
+        }
+
+        public void addQualifiedName(QualifiedName name) {
+            if (_valueIndex < _value.length) {
+                _value[_valueIndex++] = name;
+            } else if (_valueIndex == _value.length) {
+                QualifiedName[] newValue = new QualifiedName[_valueIndex * 3 / 2 + 1];
+                System.arraycopy(_value, 0, newValue, 0, _valueIndex);
+                _value = newValue;
+                _value[_valueIndex++] = name;
+            }
+        }
+    }
+
+    private Entry[] _table;
+
+    public LocalNameQualifiedNamesMap(int initialCapacity, float loadFactor) {
+        super(initialCapacity, loadFactor);
+
+        _table = new Entry[_capacity];
+    }
+
+    public LocalNameQualifiedNamesMap(int initialCapacity) {
+        this(initialCapacity, DEFAULT_LOAD_FACTOR);
+    }
+
+    public LocalNameQualifiedNamesMap() {
+        this(DEFAULT_INITIAL_CAPACITY, DEFAULT_LOAD_FACTOR);
+    }
+
+    public final void clear() {
+        for (int i = 0; i < _table.length; i++) {
+            _table[i] = null;
+        }
+        _size = 0;
+
+        if (_readOnlyMap != null) {
+            _index = _readOnlyMap.getIndex();
+        } else {
+            _index = 0;
+        }
+    }
+
+    public final void setReadOnlyMap(KeyIntMap readOnlyMap, boolean clear) {
+        if (!(readOnlyMap instanceof LocalNameQualifiedNamesMap)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalClass", new Object[]{readOnlyMap}));
+        }
+
+        setReadOnlyMap((LocalNameQualifiedNamesMap)readOnlyMap, clear);
+    }
+
+    public final void setReadOnlyMap(LocalNameQualifiedNamesMap readOnlyMap, boolean clear) {
+        _readOnlyMap = readOnlyMap;
+        if (_readOnlyMap != null) {
+            _readOnlyMapSize = _readOnlyMap.size();
+            _index = _readOnlyMap.getIndex();
+            if (clear) {
+                clear();
+            }
+        }  else {
+            _readOnlyMapSize = 0;
+            _index = 0;
+        }
+    }
+
+    public final int getNextIndex() {
+        return _index++;
+    }
+
+    public final int getIndex() {
+        return _index;
+
+    }
+
+    public final Entry obtainEntry(String key) {
+        final int hash = hashHash(key.hashCode());
+
+        if (_readOnlyMap != null) {
+            final Entry entry = _readOnlyMap.getEntry(key, hash);
+            if (entry != null) {
+                return entry;
+            }
+        }
+
+        final int tableIndex = indexFor(hash, _table.length);
+        for (Entry e = _table[tableIndex]; e != null; e = e._next) {
+            if (e._hash == hash && eq(key, e._key)) {
+                return e;
+            }
+        }
+
+        return addEntry(key, hash, tableIndex);
+    }
+
+    private final Entry getEntry(String key, int hash) {
+        if (_readOnlyMap != null) {
+            final Entry entry = _readOnlyMap.getEntry(key, hash);
+            if (entry != null) {
+                return entry;
+            }
+        }
+
+        final int tableIndex = indexFor(hash, _table.length);
+        for (Entry e = _table[tableIndex]; e != null; e = e._next) {
+            if (e._hash == hash && eq(key, e._key)) {
+                return e;
+            }
+        }
+
+        return null;
+    }
+
+
+    private final Entry addEntry(String key, int hash, int bucketIndex) {
+        Entry e = _table[bucketIndex];
+        _table[bucketIndex] = new Entry(key, hash, e);
+        e = _table[bucketIndex];
+        if (_size++ >= _threshold) {
+            resize(2 * _table.length);
+        }
+
+        return e;
+    }
+
+    private final void resize(int newCapacity) {
+        _capacity = newCapacity;
+        Entry[] oldTable = _table;
+        int oldCapacity = oldTable.length;
+        if (oldCapacity == MAXIMUM_CAPACITY) {
+            _threshold = Integer.MAX_VALUE;
+            return;
+        }
+
+        Entry[] newTable = new Entry[_capacity];
+        transfer(newTable);
+        _table = newTable;
+        _threshold = (int)(_capacity * _loadFactor);
+    }
+
+    private final void transfer(Entry[] newTable) {
+        Entry[] src = _table;
+        int newCapacity = newTable.length;
+        for (int j = 0; j < src.length; j++) {
+            Entry e = src[j];
+            if (e != null) {
+                src[j] = null;
+                do {
+                    Entry next = e._next;
+                    int i = indexFor(e._hash, newCapacity);
+                    e._next = newTable[i];
+                    newTable[i] = e;
+                    e = next;
+                } while (e != null);
+            }
+        }
+    }
+
+    private final boolean eq(String x, String y) {
+        return x == y || x.equals(y);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/PrefixArray.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/PrefixArray.java
new file mode 100644
index 0000000..beac788b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/PrefixArray.java
@@ -0,0 +1,537 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+import java.util.Iterator;
+import java.util.NoSuchElementException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+
+public class PrefixArray extends ValueArray {
+    public static final int PREFIX_MAP_SIZE = 64;
+
+    private int _initialCapacity;
+
+    public String[] _array;
+
+    private PrefixArray _readOnlyArray;
+
+    private static class PrefixEntry {
+        private PrefixEntry next;
+        private int prefixId;
+    }
+
+    private PrefixEntry[] _prefixMap = new PrefixEntry[PREFIX_MAP_SIZE];
+
+    private PrefixEntry _prefixPool;
+
+    private static class NamespaceEntry {
+        private NamespaceEntry next;
+        private int declarationId;
+        private int namespaceIndex;
+
+        private String prefix;
+        private String namespaceName;
+        private int prefixEntryIndex;
+    }
+
+    private NamespaceEntry _namespacePool;
+
+    private NamespaceEntry[] _inScopeNamespaces;
+
+    public int[] _currentInScope;
+
+    public int _declarationId;
+
+    public PrefixArray(int initialCapacity, int maximumCapacity) {
+        _initialCapacity = initialCapacity;
+        _maximumCapacity = maximumCapacity;
+
+        _array = new String[initialCapacity];
+        // Sizes of _inScopeNamespaces and _currentInScope need to be two
+        // greater than _array because 0 represents the empty string and
+        // 1 represents the xml prefix
+        _inScopeNamespaces = new NamespaceEntry[initialCapacity + 2];
+        _currentInScope = new int[initialCapacity + 2];
+
+        increaseNamespacePool(initialCapacity);
+        increasePrefixPool(initialCapacity);
+
+        initializeEntries();
+    }
+
+    public PrefixArray() {
+        this(DEFAULT_CAPACITY, MAXIMUM_CAPACITY);
+    }
+
+    private final void initializeEntries() {
+        _inScopeNamespaces[0] = _namespacePool;
+        _namespacePool = _namespacePool.next;
+        _inScopeNamespaces[0].next = null;
+        _inScopeNamespaces[0].prefix = "";
+        _inScopeNamespaces[0].namespaceName = "";
+        _inScopeNamespaces[0].namespaceIndex = _currentInScope[0] = 0;
+
+        int index = KeyIntMap.indexFor(KeyIntMap.hashHash(_inScopeNamespaces[0].prefix.hashCode()), _prefixMap.length);
+        _prefixMap[index] = _prefixPool;
+        _prefixPool = _prefixPool.next;
+        _prefixMap[index].next = null;
+        _prefixMap[index].prefixId = 0;
+
+
+        _inScopeNamespaces[1] = _namespacePool;
+        _namespacePool = _namespacePool.next;
+        _inScopeNamespaces[1].next = null;
+        _inScopeNamespaces[1].prefix = EncodingConstants.XML_NAMESPACE_PREFIX;
+        _inScopeNamespaces[1].namespaceName = EncodingConstants.XML_NAMESPACE_NAME;
+        _inScopeNamespaces[1].namespaceIndex = _currentInScope[1] = 1;
+
+        index = KeyIntMap.indexFor(KeyIntMap.hashHash(_inScopeNamespaces[1].prefix.hashCode()), _prefixMap.length);
+        if (_prefixMap[index] == null) {
+            _prefixMap[index] = _prefixPool;
+            _prefixPool = _prefixPool.next;
+            _prefixMap[index].next = null;
+        } else {
+            final PrefixEntry e = _prefixMap[index];
+            _prefixMap[index] = _prefixPool;
+            _prefixPool = _prefixPool.next;
+            _prefixMap[index].next = e;
+        }
+        _prefixMap[index].prefixId = 1;
+    }
+
+    private final void increaseNamespacePool(int capacity) {
+        if (_namespacePool == null) {
+            _namespacePool = new NamespaceEntry();
+        }
+
+        for (int i = 0; i < capacity; i++) {
+            NamespaceEntry ne = new NamespaceEntry();
+            ne.next = _namespacePool;
+            _namespacePool = ne;
+        }
+    }
+
+    private final void increasePrefixPool(int capacity) {
+        if (_prefixPool == null) {
+            _prefixPool = new PrefixEntry();
+        }
+
+        for (int i = 0; i < capacity; i++) {
+            PrefixEntry pe = new PrefixEntry();
+            pe.next = _prefixPool;
+            _prefixPool = pe;
+        }
+    }
+
+    public int countNamespacePool() {
+        int i = 0;
+        NamespaceEntry e = _namespacePool;
+        while (e != null) {
+            i++;
+            e = e.next;
+        }
+        return i;
+    }
+
+    public int countPrefixPool() {
+        int i = 0;
+        PrefixEntry e = _prefixPool;
+        while (e != null) {
+            i++;
+            e = e.next;
+        }
+        return i;
+    }
+
+    public final void clear() {
+        for (int i = _readOnlyArraySize; i < _size; i++) {
+            _array[i] = null;
+        }
+        _size = _readOnlyArraySize;
+    }
+
+    public final void clearCompletely() {
+        _prefixPool = null;
+        _namespacePool = null;
+
+        for (int i = 0; i < _size + 2; i++) {
+            _currentInScope[i] = 0;
+            _inScopeNamespaces[i] = null;
+        }
+
+        for (int i = 0; i < _prefixMap.length; i++) {
+            _prefixMap[i] = null;
+        }
+
+        increaseNamespacePool(_initialCapacity);
+        increasePrefixPool(_initialCapacity);
+
+        initializeEntries();
+
+        _declarationId = 0;
+
+        clear();
+    }
+
+    public final String[] getArray() {
+        return _array;
+    }
+
+    public final void setReadOnlyArray(ValueArray readOnlyArray, boolean clear) {
+        if (!(readOnlyArray instanceof PrefixArray)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalClass", new Object[]{readOnlyArray}));
+        }
+
+        setReadOnlyArray((PrefixArray)readOnlyArray, clear);
+    }
+
+    public final void setReadOnlyArray(PrefixArray readOnlyArray, boolean clear) {
+        if (readOnlyArray != null) {
+            _readOnlyArray = readOnlyArray;
+            _readOnlyArraySize = readOnlyArray.getSize();
+
+            clearCompletely();
+
+            // Resize according to size of read only arrays
+            _inScopeNamespaces = new NamespaceEntry[_readOnlyArraySize + _inScopeNamespaces.length];
+            _currentInScope = new int[_readOnlyArraySize + _currentInScope.length];
+            // Intialize first two entries
+            initializeEntries();
+
+            if (clear) {
+                clear();
+            }
+
+            _array = getCompleteArray();
+            _size = _readOnlyArraySize;
+        }
+    }
+
+    public final String[] getCompleteArray() {
+        if (_readOnlyArray == null) {
+            return _array;
+        } else {
+            final String[] ra = _readOnlyArray.getCompleteArray();
+            final String[] a = new String[_readOnlyArraySize + _array.length];
+            System.arraycopy(ra, 0, a, 0, _readOnlyArraySize);
+            return a;
+        }
+    }
+
+    public final String get(int i) {
+        return _array[i];
+   }
+
+    public final int add(String s) {
+        if (_size == _array.length) {
+            resize();
+        }
+
+       _array[_size++] = s;
+       return _size;
+    }
+
+    protected final void resize() {
+        if (_size == _maximumCapacity) {
+            throw new ValueArrayResourceException(CommonResourceBundle.getInstance().getString("message.arrayMaxCapacity"));
+        }
+
+        int newSize = _size * 3 / 2 + 1;
+        if (newSize > _maximumCapacity) {
+            newSize = _maximumCapacity;
+        }
+
+        final String[] newArray = new String[newSize];
+        System.arraycopy(_array, 0, newArray, 0, _size);
+        _array = newArray;
+
+        newSize += _readOnlyArraySize;
+        final NamespaceEntry[] newInScopeNamespaces = new NamespaceEntry[newSize + 2];
+        System.arraycopy(_inScopeNamespaces, 0, newInScopeNamespaces, 0, _readOnlyArraySize + _size + 2);
+        _inScopeNamespaces = newInScopeNamespaces;
+
+        final int[] newCurrentInScope = new int[newSize + 2];
+        System.arraycopy(_currentInScope, 0, newCurrentInScope, 0, _readOnlyArraySize + _size + 2);
+        _currentInScope = newCurrentInScope;
+    }
+
+    public final void clearDeclarationIds() {
+        for (int i = 0; i < _size; i++) {
+            final NamespaceEntry e = _inScopeNamespaces[i];
+            if (e != null) {
+                e.declarationId = 0;
+            }
+        }
+
+        _declarationId = 1;
+    }
+
+    public final void pushScope(int prefixIndex, int namespaceIndex) throws FastInfosetException {
+        if (_namespacePool == null) {
+            increaseNamespacePool(16);
+        }
+
+        final NamespaceEntry e = _namespacePool;
+        _namespacePool = e.next;
+
+        final NamespaceEntry current = _inScopeNamespaces[++prefixIndex];
+        if (current == null) {
+            e.declarationId = _declarationId;
+            e.namespaceIndex = _currentInScope[prefixIndex] = ++namespaceIndex;
+            e.next = null;
+
+            _inScopeNamespaces[prefixIndex] = e;
+        } else if (current.declarationId < _declarationId) {
+            e.declarationId = _declarationId;
+            e.namespaceIndex = _currentInScope[prefixIndex] = ++namespaceIndex;
+            e.next = current;
+
+            current.declarationId = 0;
+            _inScopeNamespaces[prefixIndex] = e;
+        } else {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.duplicateNamespaceAttribute"));
+        }
+    }
+
+    public final void pushScopeWithPrefixEntry(String prefix, String namespaceName,
+            int prefixIndex, int namespaceIndex) throws FastInfosetException {
+        if (_namespacePool == null) {
+            increaseNamespacePool(16);
+        }
+        if (_prefixPool == null) {
+            increasePrefixPool(16);
+        }
+
+        final NamespaceEntry e = _namespacePool;
+        _namespacePool = e.next;
+
+        final NamespaceEntry current = _inScopeNamespaces[++prefixIndex];
+        if (current == null) {
+            e.declarationId = _declarationId;
+            e.namespaceIndex = _currentInScope[prefixIndex] = ++namespaceIndex;
+            e.next = null;
+
+            _inScopeNamespaces[prefixIndex] = e;
+        } else if (current.declarationId < _declarationId) {
+            e.declarationId = _declarationId;
+            e.namespaceIndex = _currentInScope[prefixIndex] = ++namespaceIndex;
+            e.next = current;
+
+            current.declarationId = 0;
+            _inScopeNamespaces[prefixIndex] = e;
+        } else {
+            throw new FastInfosetException(CommonResourceBundle.getInstance().getString("message.duplicateNamespaceAttribute"));
+        }
+
+        final PrefixEntry p = _prefixPool;
+        _prefixPool = _prefixPool.next;
+        p.prefixId = prefixIndex;
+
+        e.prefix = prefix;
+        e.namespaceName = namespaceName;
+        e.prefixEntryIndex = KeyIntMap.indexFor(KeyIntMap.hashHash(prefix.hashCode()), _prefixMap.length);
+
+        final PrefixEntry pCurrent = _prefixMap[e.prefixEntryIndex];
+        p.next = pCurrent;
+        _prefixMap[e.prefixEntryIndex] = p;
+    }
+
+    public final void popScope(int prefixIndex) {
+        final NamespaceEntry e = _inScopeNamespaces[++prefixIndex];
+        _inScopeNamespaces[prefixIndex] = e.next;
+        _currentInScope[prefixIndex] = (e.next != null) ? e.next.namespaceIndex : 0;
+
+        e.next = _namespacePool;
+        _namespacePool = e;
+    }
+
+    public final void popScopeWithPrefixEntry(int prefixIndex) {
+        final NamespaceEntry e = _inScopeNamespaces[++prefixIndex];
+
+        _inScopeNamespaces[prefixIndex] = e.next;
+        _currentInScope[prefixIndex] = (e.next != null) ? e.next.namespaceIndex : 0;
+
+        e.prefix = e.namespaceName = null;
+        e.next = _namespacePool;
+        _namespacePool = e;
+
+        PrefixEntry current = _prefixMap[e.prefixEntryIndex];
+        if (current.prefixId == prefixIndex) {
+            _prefixMap[e.prefixEntryIndex] = current.next;
+            current.next = _prefixPool;
+            _prefixPool = current;
+        } else {
+            PrefixEntry prev = current;
+            current = current.next;
+            while (current != null) {
+                if (current.prefixId == prefixIndex) {
+                    prev.next = current.next;
+                    current.next = _prefixPool;
+                    _prefixPool = current;
+                    break;
+                }
+                prev = current;
+                current = current.next;
+            }
+        }
+    }
+
+    public final String getNamespaceFromPrefix(String prefix) {
+        final int index = KeyIntMap.indexFor(KeyIntMap.hashHash(prefix.hashCode()), _prefixMap.length);
+        PrefixEntry pe = _prefixMap[index];
+        while (pe != null) {
+            final NamespaceEntry ne = _inScopeNamespaces[pe.prefixId];
+            if (prefix == ne.prefix || prefix.equals(ne.prefix)) {
+                return ne.namespaceName;
+            }
+            pe = pe.next;
+        }
+
+        return null;
+    }
+
+    public final String getPrefixFromNamespace(String namespaceName) {
+        int position = 0;
+        while (++position < _size + 2) {
+            final NamespaceEntry ne = _inScopeNamespaces[position];
+            if (ne != null && namespaceName.equals(ne.namespaceName)) {
+                return ne.prefix;
+            }
+        }
+
+        return null;
+    }
+
+    public final Iterator getPrefixes() {
+        return new Iterator() {
+            int _position = 1;
+            NamespaceEntry _ne = _inScopeNamespaces[_position];
+
+            public boolean hasNext() {
+                return _ne != null;
+            }
+
+            public Object next() {
+                if (_position == _size + 2) {
+                    throw new NoSuchElementException();
+                }
+
+                final String prefix = _ne.prefix;
+                moveToNext();
+                return prefix;
+            }
+
+            public void remove() {
+                throw new UnsupportedOperationException();
+            }
+
+            private final void moveToNext() {
+                while (++_position < _size + 2) {
+                    _ne = _inScopeNamespaces[_position];
+                    if (_ne != null) {
+                        return;
+                    }
+                }
+                _ne = null;
+            }
+
+        };
+    }
+
+    public final Iterator getPrefixesFromNamespace(final String namespaceName) {
+        return new Iterator() {
+            String _namespaceName = namespaceName;
+            int _position = 0;
+            NamespaceEntry _ne;
+
+            {
+                moveToNext();
+            }
+
+            public boolean hasNext() {
+                return _ne != null;
+            }
+
+            public Object next() {
+                if (_position == _size + 2) {
+                    throw new NoSuchElementException();
+                }
+
+                final String prefix = _ne.prefix;
+                moveToNext();
+                return prefix;
+            }
+
+            public void remove() {
+                throw new UnsupportedOperationException();
+            }
+
+            private final void moveToNext() {
+                while (++_position < _size + 2) {
+                    _ne = _inScopeNamespaces[_position];
+                    if (_ne != null && _namespaceName.equals(_ne.namespaceName)) {
+                        return;
+                    }
+                }
+                _ne = null;
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/QualifiedNameArray.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/QualifiedNameArray.java
new file mode 100644
index 0000000..8f77810
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/QualifiedNameArray.java
@@ -0,0 +1,149 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class QualifiedNameArray extends ValueArray {
+
+    public QualifiedName[] _array;
+
+    private QualifiedNameArray _readOnlyArray;
+
+    public QualifiedNameArray(int initialCapacity, int maximumCapacity) {
+        _array = new QualifiedName[initialCapacity];
+        _maximumCapacity = maximumCapacity;
+    }
+
+    public QualifiedNameArray() {
+        this(DEFAULT_CAPACITY, MAXIMUM_CAPACITY);
+    }
+
+    public final void clear() {
+        for (int i = _readOnlyArraySize; i < _size; i++) {
+            _array[i] = null;
+        }
+        _size = _readOnlyArraySize;
+    }
+
+    public final QualifiedName[] getArray() {
+        return _array;
+    }
+
+    public final void setReadOnlyArray(ValueArray readOnlyArray, boolean clear) {
+        if (!(readOnlyArray instanceof QualifiedNameArray)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalClass", new Object[]{readOnlyArray}));
+        }
+
+        setReadOnlyArray((QualifiedNameArray)readOnlyArray, clear);
+    }
+
+    public final void setReadOnlyArray(QualifiedNameArray readOnlyArray, boolean clear) {
+        if (readOnlyArray != null) {
+            _readOnlyArray = readOnlyArray;
+            _readOnlyArraySize = readOnlyArray.getSize();
+
+            if (clear) {
+                clear();
+            }
+
+            _array = getCompleteArray();
+            _size = _readOnlyArraySize;
+        }
+    }
+
+    public final QualifiedName[] getCompleteArray() {
+        if (_readOnlyArray == null) {
+            return _array;
+        } else {
+            final QualifiedName[] ra = _readOnlyArray.getCompleteArray();
+            final QualifiedName[] a = new QualifiedName[_readOnlyArraySize + _array.length];
+            System.arraycopy(ra, 0, a, 0, _readOnlyArraySize);
+            return a;
+        }
+    }
+
+    public final QualifiedName get(int i) {
+        return _array[i];
+    }
+
+    public final void add(QualifiedName s) {
+        if (_size == _array.length) {
+            resize();
+        }
+
+       _array[_size++] = s;
+    }
+
+    protected final void resize() {
+        if (_size == _maximumCapacity) {
+            throw new ValueArrayResourceException(CommonResourceBundle.getInstance().getString("message.arrayMaxCapacity"));
+        }
+
+        int newSize = _size * 3 / 2 + 1;
+        if (newSize > _maximumCapacity) {
+            newSize = _maximumCapacity;
+        }
+
+        final QualifiedName[] newArray = new QualifiedName[newSize];
+        System.arraycopy(_array, 0, newArray, 0, _size);
+        _array = newArray;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/StringArray.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/StringArray.java
new file mode 100644
index 0000000..99c2a91
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/StringArray.java
@@ -0,0 +1,147 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class StringArray extends ValueArray {
+
+    public String[] _array;
+
+    private StringArray _readOnlyArray;
+
+    public StringArray(int initialCapacity, int maximumCapacity) {
+        _array = new String[initialCapacity];
+        _maximumCapacity = maximumCapacity;
+    }
+
+    public StringArray() {
+        this(DEFAULT_CAPACITY, MAXIMUM_CAPACITY);
+    }
+
+    public final void clear() {
+        for (int i = _readOnlyArraySize; i < _size; i++) {
+            _array[i] = null;
+        }
+        _size = _readOnlyArraySize;
+    }
+
+    public final String[] getArray() {
+        return _array;
+    }
+
+    public final void setReadOnlyArray(ValueArray readOnlyArray, boolean clear) {
+        if (!(readOnlyArray instanceof StringArray)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalClass", new Object[]{readOnlyArray}));
+        }
+
+        setReadOnlyArray((StringArray)readOnlyArray, clear);
+    }
+
+    public final void setReadOnlyArray(StringArray readOnlyArray, boolean clear) {
+        if (readOnlyArray != null) {
+            _readOnlyArray = readOnlyArray;
+            _readOnlyArraySize = readOnlyArray.getSize();
+
+            if (clear) {
+                clear();
+            }
+
+            _array = getCompleteArray();
+            _size = _readOnlyArraySize;
+        }
+    }
+
+    public final String[] getCompleteArray() {
+        if (_readOnlyArray == null) {
+            return _array;
+        } else {
+            final String[] ra = _readOnlyArray.getCompleteArray();
+            final String[] a = new String[_readOnlyArraySize + _array.length];
+            System.arraycopy(ra, 0, a, 0, _readOnlyArraySize);
+            return a;
+        }
+    }
+
+    public final String get(int i) {
+        return _array[i];
+    }
+
+    public final int add(String s) {
+        if (_size == _array.length) {
+            resize();
+        }
+
+       _array[_size++] = s;
+       return _size;
+    }
+
+    protected final void resize() {
+        if (_size == _maximumCapacity) {
+            throw new ValueArrayResourceException(CommonResourceBundle.getInstance().getString("message.arrayMaxCapacity"));
+        }
+
+        int newSize = _size * 3 / 2 + 1;
+        if (newSize > _maximumCapacity) {
+            newSize = _maximumCapacity;
+        }
+
+        final String[] newArray = new String[newSize];
+        System.arraycopy(_array, 0, newArray, 0, _size);
+        _array = newArray;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/StringIntMap.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/StringIntMap.java
new file mode 100644
index 0000000..b81ea10
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/StringIntMap.java
@@ -0,0 +1,215 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+
+public class StringIntMap extends KeyIntMap {
+
+    protected StringIntMap _readOnlyMap;
+
+    protected static class Entry extends BaseEntry {
+        final String _key;
+        Entry _next;
+
+        public Entry(String key, int hash, int value, Entry next) {
+            super(hash, value);
+            _key = key;
+            _next = next;
+        }
+    }
+
+    protected Entry[] _table;
+
+    public StringIntMap(int initialCapacity, float loadFactor) {
+        super(initialCapacity, loadFactor);
+
+        _table = new Entry[_capacity];
+    }
+
+    public StringIntMap(int initialCapacity) {
+        this(initialCapacity, DEFAULT_LOAD_FACTOR);
+    }
+
+    public StringIntMap() {
+        this(DEFAULT_INITIAL_CAPACITY, DEFAULT_LOAD_FACTOR);
+    }
+
+    public void clear() {
+        for (int i = 0; i < _table.length; i++) {
+            _table[i] = null;
+        }
+        _size = 0;
+    }
+
+    public void setReadOnlyMap(KeyIntMap readOnlyMap, boolean clear) {
+        if (!(readOnlyMap instanceof StringIntMap)) {
+            throw new IllegalArgumentException(CommonResourceBundle.getInstance().
+                    getString("message.illegalClass", new Object[]{readOnlyMap}));
+        }
+
+        setReadOnlyMap((StringIntMap)readOnlyMap, clear);
+    }
+
+    public final void setReadOnlyMap(StringIntMap readOnlyMap, boolean clear) {
+        _readOnlyMap = readOnlyMap;
+        if (_readOnlyMap != null) {
+            _readOnlyMapSize = _readOnlyMap.size();
+
+            if (clear) {
+                clear();
+            }
+        }  else {
+            _readOnlyMapSize = 0;
+        }
+    }
+
+    public final int obtainIndex(String key) {
+        final int hash = hashHash(key.hashCode());
+
+        if (_readOnlyMap != null) {
+            final int index = _readOnlyMap.get(key, hash);
+            if (index != -1) {
+                return index;
+            }
+        }
+
+        final int tableIndex = indexFor(hash, _table.length);
+        for (Entry e = _table[tableIndex]; e != null; e = e._next) {
+            if (e._hash == hash && eq(key, e._key)) {
+                return e._value;
+            }
+        }
+
+        addEntry(key, hash, _size + _readOnlyMapSize, tableIndex);
+        return NOT_PRESENT;
+    }
+
+    public final void add(String key) {
+        final int hash = hashHash(key.hashCode());
+        final int tableIndex = indexFor(hash, _table.length);
+        addEntry(key, hash, _size + _readOnlyMapSize, tableIndex);
+    }
+
+    public final int get(String key) {
+        return get(key, hashHash(key.hashCode()));
+    }
+
+    private final int get(String key, int hash) {
+        if (_readOnlyMap != null) {
+            final int i = _readOnlyMap.get(key, hash);
+            if (i != -1) {
+                return i;
+            }
+        }
+
+        final int tableIndex = indexFor(hash, _table.length);
+        for (Entry e = _table[tableIndex]; e != null; e = e._next) {
+            if (e._hash == hash && eq(key, e._key)) {
+                return e._value;
+            }
+        }
+
+        return -1;
+    }
+
+
+    private final void addEntry(String key, int hash, int value, int bucketIndex) {
+        Entry e = _table[bucketIndex];
+        _table[bucketIndex] = new Entry(key, hash, value, e);
+        if (_size++ >= _threshold) {
+            resize(2 * _table.length);
+        }
+    }
+
+    protected final void resize(int newCapacity) {
+        _capacity = newCapacity;
+        Entry[] oldTable = _table;
+        int oldCapacity = oldTable.length;
+        if (oldCapacity == MAXIMUM_CAPACITY) {
+            _threshold = Integer.MAX_VALUE;
+            return;
+        }
+
+        Entry[] newTable = new Entry[_capacity];
+        transfer(newTable);
+        _table = newTable;
+        _threshold = (int)(_capacity * _loadFactor);
+    }
+
+    private final void transfer(Entry[] newTable) {
+        Entry[] src = _table;
+        int newCapacity = newTable.length;
+        for (int j = 0; j < src.length; j++) {
+            Entry e = src[j];
+            if (e != null) {
+                src[j] = null;
+                do {
+                    Entry next = e._next;
+                    int i = indexFor(e._hash, newCapacity);
+                    e._next = newTable[i];
+                    newTable[i] = e;
+                    e = next;
+                } while (e != null);
+            }
+        }
+    }
+
+    private final boolean eq(String x, String y) {
+        return x == y || x.equals(y);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ValueArray.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ValueArray.java
new file mode 100644
index 0000000..728a9b8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ValueArray.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.util;
+
+public abstract class ValueArray {
+    public static final int DEFAULT_CAPACITY = 10;
+    public static final int MAXIMUM_CAPACITY = Integer.MAX_VALUE;
+
+    protected int _size;
+
+    protected int _readOnlyArraySize;
+
+    protected int _maximumCapacity;
+
+    public int getSize() {
+        return _size;
+    }
+
+    public int getMaximumCapacity() {
+        return _maximumCapacity;
+    }
+
+    public void setMaximumCapacity(int maximumCapacity) {
+        _maximumCapacity = maximumCapacity;
+    }
+
+    public abstract void setReadOnlyArray(ValueArray array, boolean clear);
+
+    public abstract void clear();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ValueArrayResourceException.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ValueArrayResourceException.java
new file mode 100644
index 0000000..41c7571
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/util/ValueArrayResourceException.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.util;
+
+public class ValueArrayResourceException extends RuntimeException {
+
+    public ValueArrayResourceException() {
+    }
+
+    public ValueArrayResourceException(String message) {
+        super(message);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/ParserVocabulary.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/ParserVocabulary.java
new file mode 100644
index 0000000..ab6f90c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/ParserVocabulary.java
@@ -0,0 +1,329 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.vocab;
+
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.util.CharArray;
+import com.sun.xml.internal.fastinfoset.util.CharArrayArray;
+import com.sun.xml.internal.fastinfoset.util.ContiguousCharArrayArray;
+import com.sun.xml.internal.fastinfoset.util.DuplicateAttributeVerifier;
+import com.sun.xml.internal.fastinfoset.util.FixedEntryStringIntMap;
+import com.sun.xml.internal.fastinfoset.util.KeyIntMap;
+import com.sun.xml.internal.fastinfoset.util.PrefixArray;
+import com.sun.xml.internal.fastinfoset.util.QualifiedNameArray;
+import com.sun.xml.internal.fastinfoset.util.StringArray;
+import com.sun.xml.internal.fastinfoset.util.StringIntMap;
+import com.sun.xml.internal.fastinfoset.util.ValueArray;
+import java.util.Iterator;
+import javax.xml.namespace.QName;
+
+public class ParserVocabulary extends Vocabulary {
+    public static final String IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS_PEOPERTY =
+        "com.sun.xml.internal.fastinfoset.vocab.ParserVocabulary.IdentifyingStringTable.maximumItems";
+    public static final String NON_IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS_PEOPERTY =
+        "com.sun.xml.internal.fastinfoset.vocab.ParserVocabulary.NonIdentifyingStringTable.maximumItems";
+    public static final String NON_IDENTIFYING_STRING_TABLE_MAXIMUM_CHARACTERS_PEOPERTY =
+        "com.sun.xml.internal.fastinfoset.vocab.ParserVocabulary.NonIdentifyingStringTable.maximumCharacters";
+
+    protected static int IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS;
+    protected static int NON_IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS;
+    protected static int NON_IDENTIFYING_STRING_TABLE_MAXIMUM_CHARACTERS;
+
+    static {
+        IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS =
+                getIntegerValueFromProperty(IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS_PEOPERTY);
+        NON_IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS =
+                getIntegerValueFromProperty(NON_IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS_PEOPERTY);
+        NON_IDENTIFYING_STRING_TABLE_MAXIMUM_CHARACTERS =
+                getIntegerValueFromProperty(NON_IDENTIFYING_STRING_TABLE_MAXIMUM_CHARACTERS_PEOPERTY);
+    }
+
+    private static int getIntegerValueFromProperty(String property) {
+        String value = System.getProperty(property);
+        if (value == null) {
+            return Integer.MAX_VALUE;
+        }
+
+        try {
+            return Math.max(Integer.parseInt(value), ValueArray.DEFAULT_CAPACITY);
+        } catch (NumberFormatException e) {
+            return Integer.MAX_VALUE;
+        }
+    }
+
+    public final CharArrayArray restrictedAlphabet = new CharArrayArray(ValueArray.DEFAULT_CAPACITY, 256);
+    public final StringArray encodingAlgorithm = new StringArray(ValueArray.DEFAULT_CAPACITY, 256);
+
+    public final StringArray namespaceName;
+    public final PrefixArray prefix;
+    public final StringArray localName;
+    public final StringArray otherNCName ;
+    public final StringArray otherURI;
+    public final StringArray attributeValue;
+    public final CharArrayArray otherString;
+
+    public final ContiguousCharArrayArray characterContentChunk;
+
+    public final QualifiedNameArray elementName;
+    public final QualifiedNameArray attributeName;
+
+    public final ValueArray[] tables = new ValueArray[12];
+
+    protected SerializerVocabulary _readOnlyVocabulary;
+
+    /** Creates a new instance of ParserVocabulary */
+    public ParserVocabulary() {
+        namespaceName = new StringArray(ValueArray.DEFAULT_CAPACITY, IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+        prefix = new PrefixArray(ValueArray.DEFAULT_CAPACITY, IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+        localName = new StringArray(ValueArray.DEFAULT_CAPACITY, IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+        otherNCName = new StringArray(ValueArray.DEFAULT_CAPACITY, IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+        otherURI = new StringArray(ValueArray.DEFAULT_CAPACITY, IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+        attributeValue = new StringArray(ValueArray.DEFAULT_CAPACITY, NON_IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+        otherString = new CharArrayArray(ValueArray.DEFAULT_CAPACITY, NON_IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+
+        characterContentChunk = new ContiguousCharArrayArray(ValueArray.DEFAULT_CAPACITY,
+                NON_IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS,
+                ContiguousCharArrayArray.INITIAL_CHARACTER_SIZE,
+                NON_IDENTIFYING_STRING_TABLE_MAXIMUM_CHARACTERS);
+
+        elementName = new QualifiedNameArray(ValueArray.DEFAULT_CAPACITY, IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+        attributeName = new QualifiedNameArray(ValueArray.DEFAULT_CAPACITY, IDENTIFYING_STRING_TABLE_MAXIMUM_ITEMS);
+
+        tables[RESTRICTED_ALPHABET] = restrictedAlphabet;
+        tables[ENCODING_ALGORITHM] = encodingAlgorithm;
+        tables[PREFIX] = prefix;
+        tables[NAMESPACE_NAME] = namespaceName;
+        tables[LOCAL_NAME] = localName;
+        tables[OTHER_NCNAME] = otherNCName;
+        tables[OTHER_URI] = otherURI;
+        tables[ATTRIBUTE_VALUE] = attributeValue;
+        tables[OTHER_STRING] = otherString;
+        tables[CHARACTER_CONTENT_CHUNK] = characterContentChunk;
+        tables[ELEMENT_NAME] = elementName;
+        tables[ATTRIBUTE_NAME] = attributeName;
+    }
+
+
+    public ParserVocabulary(com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary v) {
+        this();
+
+        convertVocabulary(v);
+    }
+
+    void setReadOnlyVocabulary(ParserVocabulary readOnlyVocabulary, boolean clear) {
+        for (int i = 0; i < tables.length; i++) {
+            tables[i].setReadOnlyArray(readOnlyVocabulary.tables[i], clear);
+        }
+    }
+
+    public void setInitialVocabulary(ParserVocabulary initialVocabulary, boolean clear) {
+        setExternalVocabularyURI(null);
+        setInitialReadOnlyVocabulary(true);
+        setReadOnlyVocabulary(initialVocabulary, clear);
+    }
+
+    public void setReferencedVocabulary(String referencedVocabularyURI, ParserVocabulary referencedVocabulary, boolean clear) {
+        if (!referencedVocabularyURI.equals(getExternalVocabularyURI())) {
+            setInitialReadOnlyVocabulary(false);
+            setExternalVocabularyURI(referencedVocabularyURI);
+            setReadOnlyVocabulary(referencedVocabulary, clear);
+        }
+    }
+
+    public void clear() {
+        for (int i = 0; i < tables.length; i++) {
+            tables[i].clear();
+        }
+    }
+
+    private void convertVocabulary(com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary v) {
+        final StringIntMap prefixMap = new FixedEntryStringIntMap(
+                EncodingConstants.XML_NAMESPACE_PREFIX, 8);
+        final StringIntMap namespaceNameMap = new FixedEntryStringIntMap(
+                EncodingConstants.XML_NAMESPACE_NAME, 8);
+        final StringIntMap localNameMap = new StringIntMap();
+
+        addToTable(v.restrictedAlphabets.iterator(), restrictedAlphabet);
+        addToTable(v.encodingAlgorithms.iterator(), encodingAlgorithm);
+        addToTable(v.prefixes.iterator(), prefix, prefixMap);
+        addToTable(v.namespaceNames.iterator(), namespaceName, namespaceNameMap);
+        addToTable(v.localNames.iterator(), localName, localNameMap);
+        addToTable(v.otherNCNames.iterator(), otherNCName);
+        addToTable(v.otherURIs.iterator(), otherURI);
+        addToTable(v.attributeValues.iterator(), attributeValue);
+        addToTable(v.otherStrings.iterator(), otherString);
+        addToTable(v.characterContentChunks.iterator(), characterContentChunk);
+        addToTable(v.elements.iterator(), elementName, false,
+                prefixMap, namespaceNameMap, localNameMap);
+        addToTable(v.attributes.iterator(), attributeName, true,
+                prefixMap, namespaceNameMap, localNameMap);
+    }
+
+    private void addToTable(Iterator i, StringArray a) {
+        while (i.hasNext()) {
+            addToTable((String)i.next(), a, null);
+        }
+    }
+
+    private void addToTable(Iterator i, StringArray a, StringIntMap m) {
+        while (i.hasNext()) {
+            addToTable((String)i.next(), a, m);
+        }
+    }
+
+    private void addToTable(String s, StringArray a, StringIntMap m) {
+        if (s.length() == 0) {
+            return;
+        }
+
+        if (m != null) m.obtainIndex(s);
+        a.add(s);
+    }
+
+    private void addToTable(Iterator i, PrefixArray a, StringIntMap m) {
+        while (i.hasNext()) {
+            addToTable((String)i.next(), a, m);
+        }
+    }
+
+    private void addToTable(String s, PrefixArray a, StringIntMap m) {
+        if (s.length() == 0) {
+            return;
+        }
+
+        if (m != null) m.obtainIndex(s);
+        a.add(s);
+    }
+
+    private void addToTable(Iterator i, ContiguousCharArrayArray a) {
+        while (i.hasNext()) {
+            addToTable((String)i.next(), a);
+        }
+    }
+
+    private void addToTable(String s, ContiguousCharArrayArray a) {
+        if (s.length() == 0) {
+            return;
+        }
+
+        char[] c = s.toCharArray();
+        a.add(c, c.length);
+    }
+
+    private void addToTable(Iterator i, CharArrayArray a) {
+        while (i.hasNext()) {
+            addToTable((String)i.next(), a);
+        }
+    }
+
+    private void addToTable(String s, CharArrayArray a) {
+        if (s.length() == 0) {
+            return;
+        }
+
+        char[] c = s.toCharArray();
+        a.add(new CharArray(c, 0, c.length, false));
+    }
+
+    private void addToTable(Iterator i, QualifiedNameArray a,
+            boolean isAttribute,
+            StringIntMap prefixMap, StringIntMap namespaceNameMap,
+            StringIntMap localNameMap) {
+        while (i.hasNext()) {
+            addToNameTable((QName)i.next(), a, isAttribute,
+                    prefixMap, namespaceNameMap, localNameMap);
+        }
+    }
+
+    private void addToNameTable(QName n, QualifiedNameArray a,
+            boolean isAttribute,
+            StringIntMap prefixMap, StringIntMap namespaceNameMap,
+            StringIntMap localNameMap) {
+        int namespaceURIIndex = -1;
+        int prefixIndex = -1;
+        if (n.getNamespaceURI().length() > 0) {
+            namespaceURIIndex = namespaceNameMap.obtainIndex(n.getNamespaceURI());
+            if (namespaceURIIndex == KeyIntMap.NOT_PRESENT) {
+                namespaceURIIndex = namespaceName.getSize();
+                namespaceName.add(n.getNamespaceURI());
+            }
+
+            if (n.getPrefix().length() > 0) {
+                prefixIndex = prefixMap.obtainIndex(n.getPrefix());
+                if (prefixIndex == KeyIntMap.NOT_PRESENT) {
+                    prefixIndex = prefix.getSize();
+                    prefix.add(n.getPrefix());
+                }
+            }
+        }
+
+        int localNameIndex = localNameMap.obtainIndex(n.getLocalPart());
+        if (localNameIndex == KeyIntMap.NOT_PRESENT) {
+            localNameIndex = localName.getSize();
+            localName.add(n.getLocalPart());
+        }
+
+        QualifiedName name = new QualifiedName(n.getPrefix(), n.getNamespaceURI(), n.getLocalPart(),
+                a.getSize(),
+                prefixIndex, namespaceURIIndex, localNameIndex);
+        if (isAttribute) {
+            name.createAttributeValues(DuplicateAttributeVerifier.MAP_SIZE);
+        }
+        a.add(name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/SerializerVocabulary.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/SerializerVocabulary.java
new file mode 100644
index 0000000..943374b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/SerializerVocabulary.java
@@ -0,0 +1,233 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.fastinfoset.vocab;
+
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.QualifiedName;
+import com.sun.xml.internal.fastinfoset.util.CharArrayIntMap;
+import com.sun.xml.internal.fastinfoset.util.FixedEntryStringIntMap;
+import com.sun.xml.internal.fastinfoset.util.KeyIntMap;
+import com.sun.xml.internal.fastinfoset.util.LocalNameQualifiedNamesMap;
+import com.sun.xml.internal.fastinfoset.util.StringIntMap;
+import java.util.Iterator;
+import javax.xml.namespace.QName;
+
+public class SerializerVocabulary extends Vocabulary {
+    public final StringIntMap restrictedAlphabet;
+    public final StringIntMap encodingAlgorithm;
+
+    public final StringIntMap namespaceName;
+    public final StringIntMap prefix;
+    public final StringIntMap localName;
+    public final StringIntMap otherNCName;
+    public final StringIntMap otherURI;
+    public final StringIntMap attributeValue;
+    public final CharArrayIntMap otherString;
+
+    public final CharArrayIntMap characterContentChunk;
+
+    public final LocalNameQualifiedNamesMap elementName;
+    public final LocalNameQualifiedNamesMap attributeName;
+
+    public final KeyIntMap[] tables = new KeyIntMap[12];
+
+    protected boolean _useLocalNameAsKey;
+
+    protected SerializerVocabulary _readOnlyVocabulary;
+
+    public SerializerVocabulary() {
+        tables[RESTRICTED_ALPHABET] = restrictedAlphabet = new StringIntMap(4);
+        tables[ENCODING_ALGORITHM] = encodingAlgorithm = new StringIntMap(4);
+        tables[PREFIX] = prefix = new FixedEntryStringIntMap(EncodingConstants.XML_NAMESPACE_PREFIX, 8);
+        tables[NAMESPACE_NAME] = namespaceName = new FixedEntryStringIntMap(EncodingConstants.XML_NAMESPACE_NAME, 8);
+        tables[LOCAL_NAME] = localName = new StringIntMap();
+        tables[OTHER_NCNAME] = otherNCName = new StringIntMap(4);
+        tables[OTHER_URI] = otherURI = new StringIntMap(4);
+        tables[ATTRIBUTE_VALUE] = attributeValue = new StringIntMap();
+        tables[OTHER_STRING] = otherString = new CharArrayIntMap(4);
+        tables[CHARACTER_CONTENT_CHUNK] = characterContentChunk = new CharArrayIntMap();
+        tables[ELEMENT_NAME] = elementName = new LocalNameQualifiedNamesMap();
+        tables[ATTRIBUTE_NAME] = attributeName = new LocalNameQualifiedNamesMap();
+    }
+
+    public SerializerVocabulary(com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary v,
+            boolean useLocalNameAsKey) {
+        this();
+
+        _useLocalNameAsKey = useLocalNameAsKey;
+        convertVocabulary(v);
+    }
+
+    public SerializerVocabulary getReadOnlyVocabulary() {
+        return _readOnlyVocabulary;
+    }
+
+    protected void setReadOnlyVocabulary(SerializerVocabulary readOnlyVocabulary,
+            boolean clear) {
+        for (int i = 0; i < tables.length; i++) {
+            tables[i].setReadOnlyMap(readOnlyVocabulary.tables[i], clear);
+        }
+    }
+
+    public void setInitialVocabulary(SerializerVocabulary initialVocabulary,
+            boolean clear) {
+        setExternalVocabularyURI(null);
+        setInitialReadOnlyVocabulary(true);
+        setReadOnlyVocabulary(initialVocabulary, clear);
+    }
+
+    public void setExternalVocabulary(String externalVocabularyURI,
+            SerializerVocabulary externalVocabulary, boolean clear) {
+        setInitialReadOnlyVocabulary(false);
+        setExternalVocabularyURI(externalVocabularyURI);
+        setReadOnlyVocabulary(externalVocabulary, clear);
+    }
+
+    public void clear() {
+        for (int i = 0; i < tables.length; i++) {
+            tables[i].clear();
+        }
+    }
+
+    private void convertVocabulary(com.sun.xml.internal.org.jvnet.fastinfoset.Vocabulary v) {
+        addToTable(v.restrictedAlphabets.iterator(), restrictedAlphabet);
+        addToTable(v.encodingAlgorithms.iterator(), encodingAlgorithm);
+        addToTable(v.prefixes.iterator(), prefix);
+        addToTable(v.namespaceNames.iterator(), namespaceName);
+        addToTable(v.localNames.iterator(), localName);
+        addToTable(v.otherNCNames.iterator(), otherNCName);
+        addToTable(v.otherURIs.iterator(), otherURI);
+        addToTable(v.attributeValues.iterator(), attributeValue);
+        addToTable(v.otherStrings.iterator(), otherString);
+        addToTable(v.characterContentChunks.iterator(), characterContentChunk);
+        addToTable(v.elements.iterator(), elementName);
+        addToTable(v.attributes.iterator(), attributeName);
+    }
+
+    private void addToTable(Iterator i, StringIntMap m) {
+        while (i.hasNext()) {
+            addToTable((String)i.next(), m);
+        }
+    }
+
+    private void addToTable(String s, StringIntMap m) {
+        if (s.length() == 0) {
+            return;
+        }
+
+        m.obtainIndex(s);
+    }
+
+    private void addToTable(Iterator i, CharArrayIntMap m) {
+        while (i.hasNext()) {
+            addToTable((String)i.next(), m);
+        }
+    }
+
+    private void addToTable(String s, CharArrayIntMap m) {
+        if (s.length() == 0) {
+            return;
+        }
+
+        char[] c = s.toCharArray();
+        m.obtainIndex(c, 0, c.length, false);
+    }
+
+    private void addToTable(Iterator i, LocalNameQualifiedNamesMap m) {
+        while (i.hasNext()) {
+            addToNameTable((QName)i.next(), m);
+        }
+    }
+
+    private void addToNameTable(QName n, LocalNameQualifiedNamesMap m) {
+        int namespaceURIIndex = -1;
+        int prefixIndex = -1;
+        if (n.getNamespaceURI().length() > 0) {
+            namespaceURIIndex = namespaceName.obtainIndex(n.getNamespaceURI());
+            if (namespaceURIIndex == KeyIntMap.NOT_PRESENT) {
+                namespaceURIIndex = namespaceName.get(n.getNamespaceURI());
+            }
+
+            if (n.getPrefix().length() > 0) {
+                prefixIndex = prefix.obtainIndex(n.getPrefix());
+                if (prefixIndex == KeyIntMap.NOT_PRESENT) {
+                    prefixIndex = prefix.get(n.getPrefix());
+                }
+            }
+        }
+
+        int localNameIndex = localName.obtainIndex(n.getLocalPart());
+        if (localNameIndex == KeyIntMap.NOT_PRESENT) {
+            localNameIndex = localName.get(n.getLocalPart());
+        }
+
+        QualifiedName name = new QualifiedName(n.getPrefix(), n.getNamespaceURI(), n.getLocalPart(),
+                m.getNextIndex(),
+                prefixIndex, namespaceURIIndex, localNameIndex);
+
+        LocalNameQualifiedNamesMap.Entry entry = null;
+        if (_useLocalNameAsKey) {
+            entry = m.obtainEntry(n.getLocalPart());
+        } else {
+            String qName = (prefixIndex == -1)
+                ? n.getLocalPart()
+                : n.getPrefix() + ":" + n.getLocalPart();
+            entry = m.obtainEntry(qName);
+        }
+
+        entry.addQualifiedName(name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/Vocabulary.java b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/Vocabulary.java
new file mode 100644
index 0000000..9e43a3f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/fastinfoset/vocab/Vocabulary.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.fastinfoset.vocab;
+
+
+public abstract class Vocabulary {
+    public static final int RESTRICTED_ALPHABET = 0;
+    public static final int ENCODING_ALGORITHM = 1;
+    public static final int PREFIX = 2;
+    public static final int NAMESPACE_NAME = 3;
+    public static final int LOCAL_NAME = 4;
+    public static final int OTHER_NCNAME = 5;
+    public static final int OTHER_URI = 6;
+    public static final int ATTRIBUTE_VALUE = 7;
+    public static final int OTHER_STRING = 8;
+    public static final int CHARACTER_CONTENT_CHUNK = 9;
+    public static final int ELEMENT_NAME = 10;
+    public static final int ATTRIBUTE_NAME = 11;
+
+    protected boolean _hasInitialReadOnlyVocabulary;
+
+    protected String _referencedVocabularyURI;
+
+    public boolean hasInitialVocabulary() {
+        return _hasInitialReadOnlyVocabulary;
+    }
+
+    protected void setInitialReadOnlyVocabulary(boolean hasInitialReadOnlyVocabulary) {
+        _hasInitialReadOnlyVocabulary = hasInitialReadOnlyVocabulary;
+    }
+
+    public boolean hasExternalVocabulary() {
+        return _referencedVocabularyURI != null;
+    }
+
+    public String getExternalVocabularyURI() {
+        return _referencedVocabularyURI;
+    }
+
+    protected void setExternalVocabularyURI(String referencedVocabularyURI) {
+        _referencedVocabularyURI = referencedVocabularyURI;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/SOAPExceptionImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/SOAPExceptionImpl.java
new file mode 100644
index 0000000..b403bf4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/SOAPExceptionImpl.java
@@ -0,0 +1,201 @@
+/*
+ * $Id: SOAPExceptionImpl.java,v 1.3 2006/01/27 12:49:17 vj135062 Exp $
+ * $Revision: 1.3 $
+ * $Date: 2006/01/27 12:49:17 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj;
+
+import java.io.PrintStream;
+import java.io.PrintWriter;
+
+import javax.xml.soap.SOAPException;
+
+/**
+ * An exception that signals that a SOAP exception has occurred. A
+ * <code>SOAPExceptionImpl</code> object may contain a <code>String</code>
+ * that gives the reason for the exception, an embedded
+ * <code>Throwable</code> object, or both. This class provides methods
+ * for retrieving reason messages and for retrieving the embedded
+ * <code>Throwable</code> object.
+ *
+ * <P> Typical reasons for throwing a <code>SOAPExceptionImpl</code>
+ * object are problems such as difficulty setting a header, not being
+ * able to send a message, and not being able to get a connection with
+ * the provider.  Reasons for embedding a <code>Throwable</code>
+ * object include problems such as input/output errors or a parsing
+ * problem, such as an error in parsing a header.
+ */
+public class SOAPExceptionImpl extends SOAPException {
+    private Throwable cause;
+
+    /**
+     * Constructs a <code>SOAPExceptionImpl</code> object with no
+     * reason or embedded <code>Throwable</code> object.
+     */
+    public SOAPExceptionImpl() {
+        super();
+        this.cause = null;
+    }
+
+    /**
+     * Constructs a <code>SOAPExceptionImpl</code> object with the given
+     * <code>String</code> as the reason for the exception being thrown.
+     *
+     * @param reason a description of what caused the exception
+     */
+    public SOAPExceptionImpl(String reason) {
+        super(reason);
+        this.cause = null;
+    }
+
+    /**
+     * Constructs a <code>SOAPExceptionImpl</code> object with the given
+     * <code>String</code> as the reason for the exception being thrown
+     * and the given <code>Throwable</code> object as an embedded
+     * exception.
+     *
+     * @param reason a description of what caused the exception
+     * @param cause a <code>Throwable</code> object that is to
+     *        be embedded in this <code>SOAPExceptionImpl</code> object
+     */
+    public SOAPExceptionImpl(String reason, Throwable cause) {
+       super (reason);
+       initCause(cause);
+    }
+
+    /**
+     * Constructs a <code>SOAPExceptionImpl</code> object initialized
+     * with the given <code>Throwable</code> object.
+     */
+    public SOAPExceptionImpl(Throwable cause) {
+        super (cause.toString());
+        initCause(cause);
+    }
+
+    /**
+     * Returns the detail message for this <code>SOAPExceptionImpl</code>
+     * object.
+     * <P>
+     * If there is an embedded <code>Throwable</code> object, and if the
+     * <code>SOAPExceptionImpl</code> object has no detail message of its
+     * own, this method will return the detail message from the embedded
+     * <code>Throwable</code> object.
+     *
+     * @return the error or warning message for this
+     *         <code>SOAPExceptionImpl</code> or, if it has none, the
+     *         message of the embedded <code>Throwable</code> object,
+     *         if there is one
+     */
+    public String getMessage() {
+        String message = super.getMessage ();
+        if (message == null && cause != null) {
+            return cause.getMessage();
+        } else {
+            return message;
+        }
+    }
+
+    /**
+     * Returns the <code>Throwable</code> object embedded in this
+     * <code>SOAPExceptionImpl</code> if there is one. Otherwise, this method
+     * returns <code>null</code>.
+     *
+     * @return the embedded <code>Throwable</code> object or <code>null</code>
+     *         if there is none
+     */
+
+    public Throwable getCause() {
+        return cause;
+    }
+
+    /**
+     * Initializes the <code>cause</code> field of this <code>SOAPExceptionImpl</code>
+     * object with the given <code>Throwable</code> object.
+     * <P>
+     * This method can be called at most once.  It is generally called from
+     * within the constructor or immediately after the constructor has
+     * returned a new <code>SOAPExceptionImpl</code> object.
+     * If this <code>SOAPExceptionImpl</code> object was created with the
+     * constructor {@link #SOAPExceptionImpl(Throwable)} or
+     * {@link #SOAPExceptionImpl(String,Throwable)}, meaning that its
+     * <code>cause</code> field already has a value, this method cannot be
+     * called even once.
+     *
+     * @param  cause the <code>Throwable</code> object that caused this
+     *         <code>SOAPExceptionImpl</code> object to be thrown.  The value of this
+     *         parameter is saved for later retrieval by the
+     *         {@link #getCause()} method.  A <tt>null</tt> value is
+     *         permitted and indicates that the cause is nonexistent or
+     *         unknown.
+     * @return  a reference to this <code>SOAPExceptionImpl</code> instance
+     * @throws IllegalArgumentException if <code>cause</code> is this
+     *         <code>Throwable</code> object.  (A <code>Throwable</code> object
+     *         cannot be its own cause.)
+     * @throws IllegalStateException if this <code>SOAPExceptionImpl</code> object
+     *         was created with {@link #SOAPExceptionImpl(Throwable)} or
+     *         {@link #SOAPExceptionImpl(String,Throwable)}, or this
+     *         method has already been called on this <code>SOAPExceptionImpl</code>
+     *         object
+     */
+    public synchronized Throwable initCause(Throwable cause)
+    {
+        if(this.cause != null) {
+            throw new IllegalStateException("Can't override cause");
+        }
+        if(cause == this) {
+            throw new IllegalArgumentException("Self-causation not permitted");
+        }
+        this.cause = cause;
+
+        return this;
+    }
+
+    public void printStackTrace() {
+        super.printStackTrace();
+        if (cause != null) {
+            System.err.println("\nCAUSE:\n");
+            cause.printStackTrace();
+        }
+    }
+
+    public void printStackTrace(PrintStream s) {
+        super.printStackTrace(s);
+        if (cause != null) {
+            s.println("\nCAUSE:\n");
+            cause.printStackTrace(s);
+        }
+    }
+
+    public void printStackTrace(PrintWriter s) {
+        super.printStackTrace(s);
+        if (cause != null) {
+            s.println("\nCAUSE:\n");
+            cause.printStackTrace(s);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/HttpSOAPConnection.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/HttpSOAPConnection.java
new file mode 100644
index 0000000..a9f0535
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/HttpSOAPConnection.java
@@ -0,0 +1,724 @@
+/*
+ * $Id: HttpSOAPConnection.java,v 1.41 2006/01/27 12:49:17 vj135062 Exp $
+ * $Revision: 1.41 $
+ * $Date: 2006/01/27 12:49:17 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.client.p2p;
+
+import java.io.*;
+import java.lang.reflect.Method;
+import java.net.*;
+import java.security.*;
+import java.util.Iterator;
+import java.util.StringTokenizer;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.util.*;
+
+/**
+ * This represents a "connection" to the simple HTTP-based provider.
+ *
+ * @author Anil Vijendran (akv@eng.sun.com)
+ * @author Rajiv Mordani (rajiv.mordani@sun.com)
+ * @author Manveen Kaur (manveen.kaur@sun.com)
+ *
+ */
+public class HttpSOAPConnection extends SOAPConnection {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.HTTP_CONN_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.client.p2p.LocalStrings");
+
+    public static String defaultProxyHost = null;
+    public static int defaultProxyPort = -1;
+
+    MessageFactory messageFactory = null;
+
+    boolean closed = false;
+
+    public HttpSOAPConnection() throws SOAPException {
+        proxyHost = defaultProxyHost;
+        proxyPort = defaultProxyPort;
+
+        try {
+            messageFactory = MessageFactory.newInstance(SOAPConstants.DYNAMIC_SOAP_PROTOCOL);
+        } catch (Exception ex) {
+            log.log(Level.SEVERE, "SAAJ0001.p2p.cannot.create.msg.factory", ex);
+            throw new SOAPExceptionImpl("Unable to create message factory", ex);
+        }
+    }
+
+    public void close() throws SOAPException {
+        if (closed) {
+            log.severe("SAAJ0002.p2p.close.already.closed.conn");
+            throw new SOAPExceptionImpl("Connection already closed");
+        }
+
+        messageFactory = null;
+        closed = true;
+    }
+
+    public SOAPMessage call(SOAPMessage message, Object endPoint)
+        throws SOAPException {
+        if (closed) {
+            log.severe("SAAJ0003.p2p.call.already.closed.conn");
+            throw new SOAPExceptionImpl("Connection is closed");
+        }
+
+        Class urlEndpointClass = null;
+
+        try {
+            urlEndpointClass = Class.forName("javax.xml.messaging.URLEndpoint");
+        } catch (Exception ex) {
+            //Do nothing. URLEndpoint is available only when JAXM is there.
+            log.finest("SAAJ0090.p2p.endpoint.available.only.for.JAXM");
+        }
+
+        if (urlEndpointClass != null) {
+            if (urlEndpointClass.isInstance(endPoint)) {
+                String url = null;
+
+                try {
+                    Method m = urlEndpointClass.getMethod("getURL", (Class[])null);
+                    url = (String) m.invoke(endPoint, (Object[])null);
+                } catch (Exception ex) {
+                    // TBD -- exception chaining
+                    log.log(Level.SEVERE,"SAAJ0004.p2p.internal.err",ex);
+                    throw new SOAPExceptionImpl(
+                        "Internal error: " + ex.getMessage());
+                }
+                try {
+                    endPoint = new URL(url);
+                } catch (MalformedURLException mex) {
+                    log.log(Level.SEVERE,"SAAJ0005.p2p.", mex);
+                    throw new SOAPExceptionImpl("Bad URL: " + mex.getMessage());
+                }
+            }
+        }
+
+        if (endPoint instanceof java.lang.String) {
+            try {
+                endPoint = new URL((String) endPoint);
+            } catch (MalformedURLException mex) {
+                log.log(Level.SEVERE, "SAAJ0006.p2p.bad.URL", mex);
+                throw new SOAPExceptionImpl("Bad URL: " + mex.getMessage());
+            }
+        }
+
+        if (endPoint instanceof URL)
+            try {
+                PriviledgedPost pp =
+                    new PriviledgedPost(this, message, (URL) endPoint);
+                SOAPMessage response =
+                    (SOAPMessage) AccessController.doPrivileged(pp);
+
+                return response;
+            } catch (Exception ex) {
+                // TBD -- chaining?
+                throw new SOAPExceptionImpl(ex);
+            } else {
+            log.severe("SAAJ0007.p2p.bad.endPoint.type");
+            throw new SOAPExceptionImpl("Bad endPoint type " + endPoint);
+        }
+    }
+
+    static class PriviledgedPost implements PrivilegedExceptionAction {
+
+        HttpSOAPConnection c;
+        SOAPMessage message;
+        URL endPoint;
+
+        PriviledgedPost(
+            HttpSOAPConnection c,
+            SOAPMessage message,
+            URL endPoint) {
+            this.c = c;
+            this.message = message;
+            this.endPoint = endPoint;
+        }
+
+        public Object run() throws Exception {
+            return c.post(message, endPoint);
+        }
+    }
+
+    // TBD
+    //    Fix this to do things better.
+
+    private String proxyHost = null;
+
+    static class PriviledgedSetProxyAction implements PrivilegedExceptionAction {
+
+        String proxyHost = null;
+        int proxyPort = 0;
+
+        PriviledgedSetProxyAction(String host, int port) {
+            this.proxyHost = host;
+            this.proxyPort = port;
+        }
+
+        public Object run() throws Exception {
+            System.setProperty("http.proxyHost", proxyHost);
+            System.setProperty("http.proxyPort", new Integer(proxyPort).toString());
+            log.log(Level.FINE, "SAAJ0050.p2p.proxy.host",
+                    new String[] { proxyHost });
+            log.log(Level.FINE, "SAAJ0051.p2p.proxy.port",
+                    new String[] { new Integer(proxyPort).toString() });
+            return proxyHost;
+        }
+    }
+
+
+    public void setProxy(String host, int port) {
+        try {
+            proxyPort = port;
+            PriviledgedSetProxyAction ps = new PriviledgedSetProxyAction(host, port);
+            proxyHost = (String) AccessController.doPrivileged(ps);
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+    }
+
+    public String getProxyHost() {
+        return proxyHost;
+    }
+
+    private int proxyPort = -1;
+
+    public int getProxyPort() {
+        return proxyPort;
+    }
+
+    SOAPMessage post(SOAPMessage message, URL endPoint) throws SOAPException {
+        boolean isFailure = false;
+
+        URL url = null;
+        HttpURLConnection httpConnection = null;
+
+        int responseCode = 0;
+        try {
+            if (endPoint.getProtocol().equals("https"))
+                //if(!setHttps)
+                initHttps();
+            // Process the URL
+            JaxmURI uri = new JaxmURI(endPoint.toString());
+            String userInfo = uri.getUserinfo();
+
+            url = endPoint;
+
+            if (dL > 0)
+                d("uri: " + userInfo + " " + url + " " + uri);
+
+            // TBD
+            //    Will deal with https later.
+            if (!url.getProtocol().equalsIgnoreCase("http")
+                && !url.getProtocol().equalsIgnoreCase("https")) {
+                log.severe("SAAJ0052.p2p.protocol.mustbe.http.or.https");
+                throw new IllegalArgumentException(
+                    "Protocol "
+                        + url.getProtocol()
+                        + " not supported in URL "
+                        + url);
+            }
+            httpConnection = (HttpURLConnection) createConnection(url);
+
+            httpConnection.setRequestMethod("POST");
+
+            httpConnection.setDoOutput(true);
+            httpConnection.setDoInput(true);
+            httpConnection.setUseCaches(false);
+            HttpURLConnection.setFollowRedirects(true);
+
+            if (message.saveRequired())
+                message.saveChanges();
+
+            MimeHeaders headers = message.getMimeHeaders();
+
+            Iterator it = headers.getAllHeaders();
+            boolean hasAuth = false; // true if we find explicit Auth header
+            while (it.hasNext()) {
+                MimeHeader header = (MimeHeader) it.next();
+
+                String[] values = headers.getHeader(header.getName());
+
+                if (values.length == 1)
+                    httpConnection.setRequestProperty(
+                        header.getName(),
+                        header.getValue());
+                else {
+                    StringBuffer concat = new StringBuffer();
+                    int i = 0;
+                    while (i < values.length) {
+                        if (i != 0)
+                            concat.append(',');
+                        concat.append(values[i]);
+                        i++;
+                    }
+
+                    httpConnection.setRequestProperty(
+                        header.getName(),
+                        concat.toString());
+                }
+
+                if ("Authorization".equals(header.getName())) {
+                    hasAuth = true;
+                    log.fine("SAAJ0091.p2p.https.auth.in.POST.true");
+                }
+            }
+
+            if (!hasAuth && userInfo != null) {
+                initAuthUserInfo(httpConnection, userInfo);
+            }
+
+            OutputStream out = httpConnection.getOutputStream();
+            message.writeTo(out);
+
+            out.flush();
+            out.close();
+
+            httpConnection.connect();
+
+            try {
+
+                responseCode = httpConnection.getResponseCode();
+
+                // let HTTP_INTERNAL_ERROR (500) through because it is used for SOAP faults
+                if (responseCode == HttpURLConnection.HTTP_INTERNAL_ERROR) {
+                    isFailure = true;
+                }
+                //else if (responseCode != HttpURLConnection.HTTP_OK)
+                //else if (!(responseCode >= HttpURLConnection.HTTP_OK && responseCode < 207))
+                else if ((responseCode / 100) != 2) {
+                    log.log(Level.SEVERE,
+                            "SAAJ0008.p2p.bad.response",
+                            new String[] {httpConnection.getResponseMessage()});
+                    throw new SOAPExceptionImpl(
+                        "Bad response: ("
+                            + responseCode
+                            + httpConnection.getResponseMessage());
+
+                }
+            } catch (IOException e) {
+                // on JDK1.3.1_01, we end up here, but then getResponseCode() succeeds!
+                responseCode = httpConnection.getResponseCode();
+                if (responseCode == HttpURLConnection.HTTP_INTERNAL_ERROR) {
+                    isFailure = true;
+                } else {
+                    throw e;
+                }
+
+            }
+
+        } catch (SOAPException ex) {
+            throw ex;
+        } catch (Exception ex) {
+            log.severe("SAAJ0009.p2p.msg.send.failed");
+            throw new SOAPExceptionImpl("Message send failed", ex);
+        }
+
+        SOAPMessage response = null;
+        if (responseCode == HttpURLConnection.HTTP_OK || isFailure) {
+            try {
+                MimeHeaders headers = new MimeHeaders();
+
+                String key, value;
+
+                // Header field 0 is the status line so we skip it.
+
+                int i = 1;
+
+                while (true) {
+                    key = httpConnection.getHeaderFieldKey(i);
+                    value = httpConnection.getHeaderField(i);
+
+                    if (key == null && value == null)
+                        break;
+
+                    if (key != null) {
+                        StringTokenizer values =
+                            new StringTokenizer(value, ",");
+                        while (values.hasMoreTokens())
+                            headers.addHeader(key, values.nextToken().trim());
+                    }
+                    i++;
+                }
+
+                InputStream httpIn =
+                    (isFailure
+                        ? httpConnection.getErrorStream()
+                        : httpConnection.getInputStream());
+
+                byte[] bytes = readFully(httpIn);
+
+                int length =
+                    httpConnection.getContentLength() == -1
+                        ? bytes.length
+                        : httpConnection.getContentLength();
+
+                // If no reply message is returned,
+                // content-Length header field value is expected to be zero.
+                if (length == 0) {
+                    response = null;
+                    log.warning("SAAJ0014.p2p.content.zero");
+                } else {
+                    ByteInputStream in = new ByteInputStream(bytes, length);
+                    response = messageFactory.createMessage(headers, in);
+                }
+
+                httpIn.close();
+                httpConnection.disconnect();
+
+            } catch (SOAPException ex) {
+                throw ex;
+            } catch (Exception ex) {
+                log.log(Level.SEVERE,"SAAJ0010.p2p.cannot.read.resp", ex);
+                throw new SOAPExceptionImpl(
+                    "Unable to read response: " + ex.getMessage());
+            }
+        }
+        return response;
+    }
+
+    // Object identifies where the request should be sent.
+    // It is required to support objects of type String and java.net.URL.
+
+    public SOAPMessage get(Object endPoint) throws SOAPException {
+        if (closed) {
+            log.severe("SAAJ0011.p2p.get.already.closed.conn");
+            throw new SOAPExceptionImpl("Connection is closed");
+        }
+        Class urlEndpointClass = null;
+
+        try {
+            urlEndpointClass = Class.forName("javax.xml.messaging.URLEndpoint");
+        } catch (Exception ex) {
+            //Do nothing. URLEndpoint is available only when JAXM is there.
+        }
+
+        if (urlEndpointClass != null) {
+            if (urlEndpointClass.isInstance(endPoint)) {
+                String url = null;
+
+                try {
+                    Method m = urlEndpointClass.getMethod("getURL", (Class[])null);
+                    url = (String) m.invoke(endPoint, (Object[])null);
+                } catch (Exception ex) {
+                    log.severe("SAAJ0004.p2p.internal.err");
+                    throw new SOAPExceptionImpl(
+                        "Internal error: " + ex.getMessage());
+                }
+                try {
+                    endPoint = new URL(url);
+                } catch (MalformedURLException mex) {
+                    log.severe("SAAJ0005.p2p.");
+                    throw new SOAPExceptionImpl("Bad URL: " + mex.getMessage());
+                }
+            }
+        }
+
+        if (endPoint instanceof java.lang.String) {
+            try {
+                endPoint = new URL((String) endPoint);
+            } catch (MalformedURLException mex) {
+                log.severe("SAAJ0006.p2p.bad.URL");
+                throw new SOAPExceptionImpl("Bad URL: " + mex.getMessage());
+            }
+        }
+
+        if (endPoint instanceof URL)
+            try {
+                PriviledgedGet pg = new PriviledgedGet(this, (URL) endPoint);
+                SOAPMessage response =
+                    (SOAPMessage) AccessController.doPrivileged(pg);
+
+                return response;
+            } catch (Exception ex) {
+                throw new SOAPExceptionImpl(ex);
+            } else
+            throw new SOAPExceptionImpl("Bad endPoint type " + endPoint);
+    }
+
+    static class PriviledgedGet implements PrivilegedExceptionAction {
+
+        HttpSOAPConnection c;
+        URL endPoint;
+
+        PriviledgedGet(HttpSOAPConnection c, URL endPoint) {
+            this.c = c;
+            this.endPoint = endPoint;
+        }
+
+        public Object run() throws Exception {
+            return c.get(endPoint);
+        }
+    }
+
+    SOAPMessage get(URL endPoint) throws SOAPException {
+        boolean isFailure = false;
+
+        URL url = null;
+        HttpURLConnection httpConnection = null;
+
+        int responseCode = 0;
+        try {
+            /// Is https GET allowed??
+            if (endPoint.getProtocol().equals("https"))
+                initHttps();
+            // Process the URL
+            JaxmURI uri = new JaxmURI(endPoint.toString());
+            String userInfo = uri.getUserinfo();
+
+            url = endPoint;
+
+            if (dL > 0)
+                d("uri: " + userInfo + " " + url + " " + uri);
+
+            // TBD
+            //    Will deal with https later.
+            if (!url.getProtocol().equalsIgnoreCase("http")
+                && !url.getProtocol().equalsIgnoreCase("https")) {
+                log.severe("SAAJ0052.p2p.protocol.mustbe.http.or.https");
+                throw new IllegalArgumentException(
+                    "Protocol "
+                        + url.getProtocol()
+                        + " not supported in URL "
+                        + url);
+            }
+            httpConnection = (HttpURLConnection) createConnection(url);
+
+            httpConnection.setRequestMethod("GET");
+
+            httpConnection.setDoOutput(true);
+            httpConnection.setDoInput(true);
+            httpConnection.setUseCaches(false);
+            HttpURLConnection.setFollowRedirects(true);
+
+            httpConnection.connect();
+
+            try {
+
+                responseCode = httpConnection.getResponseCode();
+
+                // let HTTP_INTERNAL_ERROR (500) through because it is used for SOAP faults
+                if (responseCode == HttpURLConnection.HTTP_INTERNAL_ERROR) {
+                    isFailure = true;
+                } else if ((responseCode / 100) != 2) {
+                    log.log(Level.SEVERE,
+                            "SAAJ0008.p2p.bad.response",
+                            new String[] { httpConnection.getResponseMessage()});
+                    throw new SOAPExceptionImpl(
+                        "Bad response: ("
+                            + responseCode
+                            + httpConnection.getResponseMessage());
+
+                }
+            } catch (IOException e) {
+                // on JDK1.3.1_01, we end up here, but then getResponseCode() succeeds!
+                responseCode = httpConnection.getResponseCode();
+                if (responseCode == HttpURLConnection.HTTP_INTERNAL_ERROR) {
+                    isFailure = true;
+                } else {
+                    throw e;
+                }
+
+            }
+
+        } catch (SOAPException ex) {
+            throw ex;
+        } catch (Exception ex) {
+            log.severe("SAAJ0012.p2p.get.failed");
+            throw new SOAPExceptionImpl("Get failed", ex);
+        }
+
+        SOAPMessage response = null;
+        if (responseCode == HttpURLConnection.HTTP_OK || isFailure) {
+            try {
+                MimeHeaders headers = new MimeHeaders();
+
+                String key, value;
+
+                // Header field 0 is the status line so we skip it.
+
+                int i = 1;
+
+                while (true) {
+                    key = httpConnection.getHeaderFieldKey(i);
+                    value = httpConnection.getHeaderField(i);
+
+                    if (key == null && value == null)
+                        break;
+
+                    if (key != null) {
+                        StringTokenizer values =
+                            new StringTokenizer(value, ",");
+                        while (values.hasMoreTokens())
+                            headers.addHeader(key, values.nextToken().trim());
+                    }
+                    i++;
+                }
+
+                InputStream httpIn =
+                    (isFailure
+                        ? httpConnection.getErrorStream()
+                        : httpConnection.getInputStream());
+
+                byte[] bytes = readFully(httpIn);
+
+                int length =
+                    httpConnection.getContentLength() == -1
+                        ? bytes.length
+                        : httpConnection.getContentLength();
+
+                // If no reply message is returned,
+                // content-Length header field value is expected to be zero.
+                if (length == 0) {
+                    response = null;
+                    log.warning("SAAJ0014.p2p.content.zero");
+                } else {
+
+                    ByteInputStream in = new ByteInputStream(bytes, length);
+                    response = messageFactory.createMessage(headers, in);
+                }
+
+                httpIn.close();
+                httpConnection.disconnect();
+
+            } catch (SOAPException ex) {
+                throw ex;
+            } catch (Exception ex) {
+                log.log(Level.SEVERE,
+                        "SAAJ0010.p2p.cannot.read.resp",
+                        ex);
+                throw new SOAPExceptionImpl(
+                    "Unable to read response: " + ex.getMessage());
+            }
+        }
+        return response;
+    }
+
+    private byte[] readFully(InputStream istream) throws IOException {
+        ByteArrayOutputStream bout = new ByteArrayOutputStream();
+        byte[] buf = new byte[1024];
+        int num = 0;
+
+        while ((num = istream.read(buf)) != -1) {
+            bout.write(buf, 0, num);
+        }
+
+        byte[] ret = bout.toByteArray();
+
+        return ret;
+    }
+
+    private static String SSL_PKG = "com.sun.net.ssl.internal.www.protocol";
+    private static String SSL_PROVIDER =
+        "com.sun.net.ssl.internal.ssl.Provider";
+    private void initHttps() {
+        //if(!setHttps) {
+        String pkgs = System.getProperty("java.protocol.handler.pkgs");
+        log.log(Level.FINE,
+                "SAAJ0053.p2p.providers",
+                new String[] { pkgs });
+
+        if (pkgs == null || pkgs.indexOf(SSL_PKG) < 0) {
+            if (pkgs == null)
+                pkgs = SSL_PKG;
+            else
+                pkgs = pkgs + "|" + SSL_PKG;
+            System.setProperty("java.protocol.handler.pkgs", pkgs);
+            log.log(Level.FINE,
+                    "SAAJ0054.p2p.set.providers",
+                    new String[] { pkgs });
+            try {
+                Class c = Class.forName(SSL_PROVIDER);
+                Provider p = (Provider) c.newInstance();
+                Security.addProvider(p);
+                log.log(Level.FINE,
+                        "SAAJ0055.p2p.added.ssl.provider",
+                        new String[] { SSL_PROVIDER });
+                //System.out.println("Added SSL_PROVIDER " + SSL_PROVIDER);
+                //setHttps = true;
+            } catch (Exception ex) {
+            }
+        }
+        //}
+    }
+
+    private void initAuthUserInfo(HttpURLConnection conn, String userInfo) {
+        String user;
+        String password;
+        if (userInfo != null) { // get the user and password
+            //System.out.println("UserInfo= " + userInfo );
+            int delimiter = userInfo.indexOf(':');
+            if (delimiter == -1) {
+                user = ParseUtil.decode(userInfo);
+                password = null;
+            } else {
+                user = ParseUtil.decode(userInfo.substring(0, delimiter++));
+                password = ParseUtil.decode(userInfo.substring(delimiter));
+            }
+
+            String plain = user + ":";
+            byte[] nameBytes = plain.getBytes();
+            byte[] passwdBytes = password.getBytes();
+
+            // concatenate user name and password bytes and encode them
+            byte[] concat = new byte[nameBytes.length + passwdBytes.length];
+
+            System.arraycopy(nameBytes, 0, concat, 0, nameBytes.length);
+            System.arraycopy(
+                passwdBytes,
+                0,
+                concat,
+                nameBytes.length,
+                passwdBytes.length);
+            String auth = "Basic " + new String(Base64.encode(concat));
+            conn.setRequestProperty("Authorization", auth);
+            if (dL > 0)
+                d("Adding auth " + auth);
+        }
+    }
+
+    private static final int dL = 0;
+    private void d(String s) {
+        log.log(Level.SEVERE,
+                "SAAJ0013.p2p.HttpSOAPConnection",
+                new String[] { s });
+        System.err.println("HttpSOAPConnection: " + s);
+    }
+
+    private java.net.HttpURLConnection createConnection(URL endpoint)
+        throws IOException {
+        return (HttpURLConnection) endpoint.openConnection();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/HttpSOAPConnectionFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/HttpSOAPConnectionFactory.java
new file mode 100644
index 0000000..88b180a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/HttpSOAPConnectionFactory.java
@@ -0,0 +1,47 @@
+/*
+ * $Id: HttpSOAPConnectionFactory.java,v 1.6 2006/01/27 12:49:18 vj135062 Exp $
+ * $Revision: 1.6 $
+ * $Date: 2006/01/27 12:49:18 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.client.p2p;
+
+import javax.xml.soap.*;
+
+/**
+ * Implementation of the SOAPConnectionFactory
+ *
+ * @author Anil Vijendran (anil@sun.com)
+ */
+public class HttpSOAPConnectionFactory extends SOAPConnectionFactory {
+
+    public SOAPConnection createConnection()
+        throws SOAPException
+    {
+        return new HttpSOAPConnection();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/LocalStrings.properties b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/LocalStrings.properties
new file mode 100644
index 0000000..00e2468
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/client/p2p/LocalStrings.properties
@@ -0,0 +1,31 @@
+# SAAJ ResourceBundle properties file
+# Contains Log messages
+# Error messages
+SAAJ0001.p2p.cannot.create.msg.factory=SAAJ0001: Unable to create Message Factory
+SAAJ0002.p2p.close.already.closed.conn=SAAJ0002: Connection already closed (from close method)
+SAAJ0003.p2p.call.already.closed.conn=SAAJ0003: Connection already closed (from call)
+SAAJ0004.p2p.internal.err=SAAJ0004: Internal error
+SAAJ0005.p2p.=SAAJ0005: Bad URL (endPoint instance of javax.xml.messaging.URLEndpoint)
+# 0005 : getURL failed on javax.xml.messaging.URLEndpoint
+SAAJ0006.p2p.bad.URL=SAAJ0006: Bad URL (endPoint instance of String)
+SAAJ0007.p2p.bad.endPoint.type=SAAJ0007: Bad endPoint type (endPoint instance of URL)
+SAAJ0008.p2p.bad.response=SAAJ0008: Bad Response; {0}
+SAAJ0009.p2p.msg.send.failed=SAAJ0009: Message send failed
+SAAJ0010.p2p.cannot.read.resp=SAAJ0010: Unable to read response
+SAAJ0011.p2p.get.already.closed.conn=SAAJ0011: Connection already closed (from get)
+SAAJ0012.p2p.get.failed=SAAJ0012: Get failed
+SAAJ0013.p2p.HttpSOAPConnection=SAAJ0013: HttpSOAPConnection: {0}
+SAAJ0014.p2p.content.zero=SAAJ0014: Invalid reply message. Content length of reply was zero.
+
+# Debug messages
+SAAJ0050.p2p.proxy.host=SAAJ0050: Proxy host: {0}
+SAAJ0051.p2p.proxy.port=SAAJ0051: Proxy Port: {0}
+SAAJ0052.p2p.protocol.mustbe.http.or.https=SAAJ0052: Protocol not supported in URL, must be http or https
+SAAJ0053.p2p.providers=SAAJ0053: Providers {0}
+SAAJ0054.p2p.set.providers=SAAJ0054: Setting Providers {0}
+SAAJ0055.p2p.added.ssl.provider=SAAJ0055: Added SSL_PROVIDER {0}
+
+# Trace messages
+SAAJ0090.p2p.endpoint.available.only.for.JAXM=SAAJ0090: URLEndpoint is available only when JAXM is there
+SAAJ0091.p2p.https.auth.in.POST.true=SAAJ0091: HTTPS Authorization in POST set to true
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/Header.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/Header.java
new file mode 100644
index 0000000..e0065b2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/Header.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime;
+
+
+/**
+ * The Header class stores a name/value pair to represent headers.
+ *
+ * @author John Mani
+ */
+
+public interface Header {
+
+    /**
+     * Returns the name of this header.
+     *
+     * @return          name of the header
+     */
+    String getName();
+
+    /**
+     * Returns the value of this header.
+     *
+     * @return          value of the header
+     */
+    String getValue();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/MessagingException.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/MessagingException.java
new file mode 100644
index 0000000..d83cea8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/MessagingException.java
@@ -0,0 +1,141 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime;
+
+
+/**
+ * The base class for all exceptions thrown by the Messaging classes
+ *
+ * @author John Mani
+ * @author Bill Shannon
+ */
+
+public class MessagingException extends Exception {
+
+    /**
+     * The next exception in the chain.
+     *
+     * @serial
+     */
+    private Exception next;
+
+    /**
+     * Constructs a MessagingException with no detail message.
+     */
+    public MessagingException() {
+        super();
+    }
+
+    /**
+     * Constructs a MessagingException with the specified detail message.
+     * @param s         the detail message
+     */
+    public MessagingException(String s) {
+        super(s);
+    }
+
+    /**
+     * Constructs a MessagingException with the specified
+     * Exception and detail message. The specified exception is chained
+     * to this exception.
+     * @param s         the detail message
+     * @param e         the embedded exception
+     * @see     #getNextException
+     * @see     #setNextException
+     */
+    public MessagingException(String s, Exception e) {
+        super(s);
+        next = e;
+    }
+
+    /**
+     * Get the next exception chained to this one. If the
+     * next exception is a MessagingException, the chain
+     * may extend further.
+     *
+     * @return  next Exception, null if none.
+     */
+    public Exception getNextException() {
+        return next;
+    }
+
+    /**
+     * Add an exception to the end of the chain. If the end
+     * is <strong>not</strong> a MessagingException, this
+     * exception cannot be added to the end.
+     *
+     * @param   ex      the new end of the Exception chain
+     * @return          <code>true</code> if the this Exception
+     *                  was added, <code>false</code> otherwise.
+     */
+    public synchronized boolean setNextException(Exception ex) {
+        Exception theEnd = this;
+        while (theEnd instanceof MessagingException &&
+               ((MessagingException)theEnd).next != null) {
+            theEnd = ((MessagingException)theEnd).next;
+        }
+        // If the end is a MessagingException, we can add this
+        // exception to the chain.
+        if (theEnd instanceof MessagingException) {
+            ((MessagingException)theEnd).next = ex;
+            return true;
+        } else
+            return false;
+    }
+
+    /**
+     * Produce the message, include the message from the nested
+     * exception if there is one.
+     */
+    public String getMessage() {
+        if (next == null)
+            return super.getMessage();
+        Exception n = next;
+        String s = super.getMessage();
+        StringBuffer sb = new StringBuffer(s == null ? "" : s);
+        while (n != null) {
+            sb.append(";\n  nested exception is:\n\t");
+            if (n instanceof MessagingException) {
+                MessagingException mex = (MessagingException)n;
+                sb.append(n.getClass().toString());
+                String msg = mex.getSuperMessage();
+                if (msg != null) {
+                    sb.append(": ");
+                    sb.append(msg);
+                }
+                n = mex.next;
+            } else {
+                sb.append(n.toString());
+                n = null;
+            }
+        }
+        return sb.toString();
+    }
+
+    private String getSuperMessage() {
+        return super.getMessage();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/MultipartDataSource.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/MultipartDataSource.java
new file mode 100644
index 0000000..ed86e59
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/MultipartDataSource.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeBodyPart;
+
+import javax.activation.DataSource;
+
+/**
+ * MultipartDataSource is a <code>DataSource</code> that contains body
+ * parts.  This allows "mail aware" <code>DataContentHandlers</code> to
+ * be implemented more efficiently by being aware of such
+ * <code>DataSources</code> and using the appropriate methods to access
+ * <code>BodyParts</code>. <p>
+ *
+ * Note that the data of a MultipartDataSource is also available as
+ * an input stream. <p>
+ *
+ * This interface will typically be implemented by providers that
+ * preparse multipart bodies, for example an IMAP provider.
+ *
+ * @author      John Mani
+ * @see         javax.activation.DataSource
+ */
+
+public interface MultipartDataSource extends DataSource {
+
+    /**
+     * Return the number of enclosed MimeBodyPart objects.
+     *
+     * @return          number of parts
+     */
+    public int getCount();
+
+    /**
+     * Get the specified MimeBodyPart.  Parts are numbered starting at 0.
+     *
+     * @param index     the index of the desired MimeBodyPart
+     * @return          the MimeBodyPart
+     * @exception       IndexOutOfBoundsException if the given index
+     *                  is out of range.
+     * @exception       MessagingException
+     */
+    public MimeBodyPart getBodyPart(int index) throws MessagingException;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/BMMimeMultipart.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/BMMimeMultipart.java
new file mode 100644
index 0000000..b7466df
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/BMMimeMultipart.java
@@ -0,0 +1,737 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import java.io.*;
+import java.util.BitSet;
+
+import javax.activation.DataSource;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.*;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.util.*;
+
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+import com.sun.xml.internal.messaging.saaj.util.FinalArrayList;
+
+/**
+ * The MimeMultipart class is an implementation of the abstract Multipart
+ * class that uses MIME conventions for the multipart data. <p>
+ *
+ * A MimeMultipart is obtained from a MimePart whose primary type
+ * is "multipart" (by invoking the part's <code>getContent()</code> method)
+ * or it can be created by a client as part of creating a new MimeMessage. <p>
+ *
+ * The default multipart subtype is "mixed".  The other multipart
+ * subtypes, such as "alternative", "related", and so on, can be
+ * implemented as subclasses of MimeMultipart with additional methods
+ * to implement the additional semantics of that type of multipart
+ * content. The intent is that service providers, mail JavaBean writers
+ * and mail clients will write many such subclasses and their Command
+ * Beans, and will install them into the JavaBeans Activation
+ * Framework, so that any JavaMail implementation and its clients can
+ * transparently find and use these classes. Thus, a MIME multipart
+ * handler is treated just like any other type handler, thereby
+ * decoupling the process of providing multipart handlers from the
+ * JavaMail API. Lacking these additional MimeMultipart subclasses,
+ * all subtypes of MIME multipart data appear as MimeMultipart objects. <p>
+ *
+ * An application can directly construct a MIME multipart object of any
+ * subtype by using the <code>MimeMultipart(String subtype)</code>
+ * constructor.  For example, to create a "multipart/alternative" object,
+ * use <code>new MimeMultipart("alternative")</code>.
+ *
+ */
+
+//TODO: cleanup the SharedInputStream handling
+public  class BMMimeMultipart extends MimeMultipart {
+
+    /*
+     * When true it indicates parsing hasnt been done at all
+     */
+    private boolean begining = true;
+
+    int[] bcs = new int[256];
+    int[] gss = null;
+    private static final int BUFFER_SIZE = 4096;
+    private byte[] buffer = new byte[BUFFER_SIZE];
+    private byte[] prevBuffer = new byte[BUFFER_SIZE];
+    private BitSet lastPartFound = new BitSet(1);
+
+    // cached inputstream which is possibly partially consumed
+    private InputStream in = null;
+    private String boundary = null;
+    // current stream position, set to -1 on EOF
+    int b = 0;
+
+    // property to indicate if lazyAttachments is ON
+    private boolean lazyAttachments = false;
+
+    /**
+     * Default constructor. An empty MimeMultipart object
+     * is created. Its content type is set to "multipart/mixed".
+     * A unique boundary string is generated and this string is
+     * setup as the "boundary" parameter for the
+     * <code>contentType</code> field. <p>
+     *
+     * MimeBodyParts may be added later.
+     */
+    public BMMimeMultipart() {
+        super();
+        //this("mixed");
+    }
+
+    /**
+     * Construct a MimeMultipart object of the given subtype.
+     * A unique boundary string is generated and this string is
+     * setup as the "boundary" parameter for the
+     * <code>contentType</code> field. <p>
+     *
+     * MimeBodyParts may be added later.
+     */
+    public BMMimeMultipart(String subtype) {
+        super(subtype);
+        /*
+         * Compute a boundary string.
+        String boundary = UniqueValue.getUniqueBoundaryValue();
+        ContentType cType = new ContentType("multipart", subtype, null);
+        contentType.setParameter("boundary", boundary);
+         */
+    }
+
+    /**
+     * Constructs a MimeMultipart object and its bodyparts from the
+     * given DataSource. <p>
+     *
+     * This constructor handles as a special case the situation where the
+     * given DataSource is a MultipartDataSource object.  In this case, this
+     * method just invokes the superclass (i.e., Multipart) constructor
+     * that takes a MultipartDataSource object. <p>
+     *
+     * Otherwise, the DataSource is assumed to provide a MIME multipart
+     * byte stream.  The <code>parsed</code> flag is set to false.  When
+     * the data for the body parts are needed, the parser extracts the
+     * "boundary" parameter from the content type of this DataSource,
+     * skips the 'preamble' and reads bytes till the terminating
+     * boundary and creates MimeBodyParts for each part of the stream.
+     *
+     * @param   ds      DataSource, can be a MultipartDataSource
+     */
+    public BMMimeMultipart(DataSource ds, ContentType ct)
+        throws MessagingException {
+        super(ds,ct);
+        boundary = ct.getParameter("boundary");
+        /*
+        if (ds instanceof MultipartDataSource) {
+            // ask super to do this for us.
+            setMultipartDataSource((MultipartDataSource)ds);
+            return;
+        }
+
+        // 'ds' was not a MultipartDataSource, we have
+        // to parse this ourself.
+        parsed = false;
+        this.ds = ds;
+        if (ct==null)
+            contentType = new ContentType(ds.getContentType());
+        else
+            contentType = ct;
+       */
+
+    }
+
+    public InputStream initStream() throws MessagingException {
+
+        if (in == null) {
+            try {
+                in = ds.getInputStream();
+                if (!(in instanceof ByteArrayInputStream) &&
+                    !(in instanceof BufferedInputStream) &&
+                    !(in instanceof SharedInputStream))
+                    in = new BufferedInputStream(in);
+            } catch (Exception ex) {
+                throw new MessagingException("No inputstream from datasource");
+            }
+
+            if (!in.markSupported()) {
+                throw new MessagingException(
+                    "InputStream does not support Marking");
+            }
+        }
+        return in;
+    }
+
+    /**
+     * Parse the InputStream from our DataSource, constructing the
+     * appropriate MimeBodyParts.  The <code>parsed</code> flag is
+     * set to true, and if true on entry nothing is done.  This
+     * method is called by all other methods that need data for
+     * the body parts, to make sure the data has been parsed.
+     *
+     * @since   JavaMail 1.2
+     */
+    protected  void parse() throws  MessagingException {
+        if (parsed)
+            return;
+
+        initStream();
+
+        SharedInputStream sin = null;
+        if (in instanceof SharedInputStream) {
+            sin = (SharedInputStream)in;
+        }
+
+        String bnd = "--" + boundary;
+        byte[] bndbytes = ASCIIUtility.getBytes(bnd);
+        try {
+            parse(in, bndbytes, sin);
+        } catch (IOException ioex) {
+            throw new MessagingException("IO Error", ioex);
+        } catch (Exception ex) {
+            ex.printStackTrace();
+            throw new MessagingException("Error", ex);
+        }
+
+        parsed = true;
+    }
+
+    public boolean lastBodyPartFound() {
+        return lastPartFound.get(0);
+    }
+
+    public MimeBodyPart getNextPart(
+        InputStream stream, byte[] pattern, SharedInputStream sin)
+        throws Exception {
+
+        if (!stream.markSupported()) {
+            throw new Exception("InputStream does not support Marking");
+        }
+
+        if (begining) {
+            compile(pattern);
+            if (!skipPreamble(stream, pattern, sin)) {
+                throw new Exception(
+                    "Missing Start Boundary, or boundary does not start on a new line");
+            }
+            begining = false;
+        }
+
+        if (lastBodyPartFound()) {
+            throw new Exception("No parts found in Multipart InputStream");
+        }
+
+        if (sin != null) {
+            long start = sin.getPosition();
+            b = readHeaders(stream);
+            if (b == -1) {
+                throw new Exception(
+                    "End of Stream encountered while reading part headers");
+            }
+            long[] v = new long[1];
+            v[0] = -1; // just to ensure the code later sets it correctly
+            b = readBody(stream, pattern, v, null, sin);
+            // looks like this check has to be disabled
+            // it is allowed to have Mime Package without closing boundary
+            /*
+            if ((b == -1) && !lastBodyPartFound()) {
+                throw new Exception(
+                    "End of Stream encountered without closing boundary");
+            }
+            */
+            long end = v[0];
+            MimeBodyPart mbp = createMimeBodyPart(sin.newStream(start, end));
+            addBodyPart(mbp);
+            return mbp;
+
+        } else {
+            InternetHeaders headers = createInternetHeaders(stream);
+            ByteOutputStream baos = new ByteOutputStream();
+            b = readBody(stream, pattern, null,baos, null);
+            // looks like this check has to be disabled
+            // in the old impl it is allowed to have Mime Package
+            // without closing boundary
+            /*
+            if ((b == -1) && !lastBodyPartFound()) {
+                throw new Exception(
+                    "End of Stream encountered without closing boundary");
+            }*/
+            MimeBodyPart mbp = createMimeBodyPart(
+                headers, baos.getBytes(), baos.getCount());
+            addBodyPart(mbp);
+            return mbp;
+        }
+
+    }
+
+    public boolean parse(
+        InputStream stream, byte[] pattern, SharedInputStream sin)
+        throws Exception {
+
+        while (!lastPartFound.get(0) && (b != -1)) {
+           getNextPart(stream, pattern, sin);
+        }
+        return true;
+    }
+
+    private int readHeaders(InputStream is) throws Exception {
+        // if the headers are to end properly then there has to be CRLF
+        // actually we just need to mark the start and end positions
+        int b = is.read();
+        while(b != -1) {
+            // when it is a shared input stream no need to copy
+            if (b == '\r') {
+                b = is.read();
+                if (b == '\n') {
+                    b = is.read();
+                    if (b == '\r') {
+                        b = is.read();
+                        if (b == '\n') {
+                           return b;
+                        } else {
+                            continue;
+                        }
+                    } else {
+                        continue;
+                    }
+                } else {
+                    continue;
+                }
+            }
+            b = is.read();
+        }
+        if (b == -1) {
+            throw new Exception(
+            "End of inputstream while reading Mime-Part Headers");
+        }
+        return b;
+    }
+
+    private int readBody(
+        InputStream is, byte[] pattern, long[] posVector,
+        ByteOutputStream baos, SharedInputStream sin)
+        throws Exception {
+        if (!find(is, pattern, posVector, baos, sin)) {
+            throw new Exception(
+            "Missing boundary delimitier while reading Body Part");
+        }
+        return b;
+    }
+
+    private boolean skipPreamble(
+        InputStream is, byte[] pattern, SharedInputStream sin)
+        throws Exception {
+        if (!find(is, pattern, sin)) {
+            return false;
+        }
+        if (lastPartFound.get(0)) {
+            throw new Exception(
+            "Found closing boundary delimiter while trying to skip preamble");
+        }
+        return true;
+    }
+
+
+    public int  readNext(InputStream is, byte[] buff, int patternLength,
+        BitSet eof, long[] posVector, SharedInputStream sin)
+        throws Exception {
+
+        int bufferLength = is.read(buffer, 0, patternLength);
+        if (bufferLength == -1) {
+           eof.flip(0);
+        } else if (bufferLength < patternLength) {
+            //repeatedly read patternLength - bufferLength
+            int temp = 0;
+            long pos = 0;
+            int i = bufferLength;
+            for (; i < patternLength; i++) {
+                if (sin != null) {
+                    pos = sin.getPosition();
+                }
+                temp = is.read();
+                if (temp == -1) {
+                    eof.flip(0);
+                    if (sin != null) {
+                        posVector[0] = pos;
+                    }
+                    break;
+                }
+                buffer[i] = (byte)temp;
+            }
+            bufferLength=i;
+        }
+        return bufferLength;
+    }
+
+    public boolean find(InputStream is, byte[] pattern, SharedInputStream sin)
+        throws Exception {
+        int i;
+        int l = pattern.length;
+        int lx = l -1;
+        int bufferLength = 0;
+        BitSet eof = new BitSet(1);
+        long[] posVector = new long[1];
+
+        while (true) {
+            is.mark(l);
+            bufferLength = readNext(is, buffer, l, eof, posVector, sin);
+            if (eof.get(0)) {
+                // End of stream
+                return false;
+            }
+
+            /*
+            if (bufferLength < l) {
+                //is.reset();
+                return false;
+            }*/
+
+            for(i = lx; i >= 0; i--) {
+                if (buffer[i] != pattern[i]) {
+                    break;
+                }
+            }
+
+            if (i < 0) {
+                // found the boundary, skip *LWSP-char and CRLF
+                if (!skipLWSPAndCRLF(is)) {
+                    throw new Exception("Boundary does not terminate with CRLF");
+                }
+                return true;
+            }
+
+            int s = Math.max(i + 1 - bcs[buffer[i] & 0x7f], gss[i]);
+            is.reset();
+            is.skip(s);
+        }
+    }
+
+    public boolean find(
+        InputStream is, byte[] pattern, long[] posVector,
+        ByteOutputStream out, SharedInputStream sin) throws Exception {
+        int i;
+        int l = pattern.length;
+        int lx = l -1;
+        int bufferLength = 0;
+        int s = 0;
+        long endPos = -1;
+        byte[] tmp = null;
+
+        boolean first = true;
+        BitSet eof = new BitSet(1);
+
+        while (true) {
+            is.mark(l);
+            if (!first) {
+                tmp = prevBuffer;
+                prevBuffer = buffer;
+                buffer = tmp;
+            }
+            if (sin != null) {
+                endPos = sin.getPosition();
+            }
+
+            bufferLength = readNext(is, buffer, l, eof, posVector, sin);
+
+            if (bufferLength == -1) {
+                // End of stream
+                // looks like it is allowed to not have a closing boundary
+                //return false;
+                //if (sin != null) {
+                 //   posVector[0] = endPos;
+                //}
+                b = -1;
+                if ((s == l) && (sin == null)) {
+                    out.write(prevBuffer, 0, s);
+                }
+                return true;
+            }
+
+            if (bufferLength < l) {
+                if (sin != null) {
+                    //endPos = sin.getPosition();
+                    //posVector[0] = endPos;
+                } else {
+                    // looks like it is allowed to not have a closing boundary
+                    // in the old implementation
+                        out.write(buffer, 0, bufferLength);
+                }
+                // looks like it is allowed to not have a closing boundary
+                // in the old implementation
+                //return false;
+                b = -1;
+                return true;
+            }
+
+            for(i = lx; i >= 0; i--) {
+                if (buffer[i] != pattern[i]) {
+                    break;
+                }
+            }
+
+            if (i < 0) {
+                if (s > 0) {
+                    //looks like the earlier impl allowed just an LF
+                    // so if s == 1 : it must be an LF
+                    // if s == 2 : it must be a CR LF
+                    if (s <= 2) {
+                        String crlf = new String(prevBuffer, 0, s);
+                        if (!"\n".equals(crlf) && !"\r\n".equals(crlf)) {
+                            throw new Exception(
+                                "Boundary characters encountered in part Body " +
+                                "without a preceeding CRLF");
+                        } else {
+                            if (sin != null) {
+                                posVector[0] = endPos;
+                            }
+                        }
+                    } else if (s > 2) {
+                        if ((prevBuffer[s-2] == '\r') && (prevBuffer[s-1] == '\n')) {
+                            if (sin != null) {
+                                posVector[0] = endPos - 2;
+                            } else {
+                                out.write(prevBuffer, 0, s - 2);
+                            }
+                        } else if (prevBuffer[s-1] == '\n') {
+                            //old impl allowed just a \n
+                            if (sin != null) {
+                                posVector[0] = endPos - 1;
+                            } else {
+                                out.write(prevBuffer, 0, s - 1);
+                            }
+                        } else {
+                            throw new Exception(
+                                "Boundary characters encountered in part Body " +
+                                "without a preceeding CRLF");
+                        }
+                    }
+                }
+                // found the boundary, skip *LWSP-char and CRLF
+                if (!skipLWSPAndCRLF(is)) {
+                    //throw new Exception(
+                     //   "Boundary does not terminate with CRLF");
+                }
+                return true;
+            }
+
+            if ((s > 0) && (sin == null)) {
+                if (prevBuffer[s-1] == (byte)13) {
+                    // if buffer[0] == (byte)10
+                    if (buffer[0] == (byte)10) {
+                        int j=lx-1;
+                        for(j = lx-1; j > 0; j--) {
+                            if (buffer[j+1] != pattern[j]) {
+                                break;
+                             }
+                         }
+                         if (j == 0) {
+                             // matched the pattern excluding the last char of the pattern
+                             // so dont write the CR into stream
+                             out.write(prevBuffer,0,s-1);
+                         } else {
+                             out.write(prevBuffer,0,s);
+                         }
+                    } else {
+                        out.write(prevBuffer, 0, s);
+                    }
+                } else {
+                    out.write(prevBuffer, 0, s);
+                }
+            }
+
+            s = Math.max(i + 1 - bcs[buffer[i] & 0x7f], gss[i]);
+            is.reset();
+            is.skip(s);
+            if (first) {
+                first = false;
+            }
+        }
+    }
+
+    private boolean skipLWSPAndCRLF(InputStream is) throws Exception {
+
+        b = is.read();
+        //looks like old impl allowed just a \n as well
+        if (b == '\n') {
+            return true;
+        }
+
+        if (b == '\r') {
+            b = is.read();
+            //skip any multiple '\r' "\r\n" --> "\r\r\n" on Win2k
+            if (b == '\r') {
+                b = is.read();
+            }
+            if (b == '\n') {
+                return true;
+            } else {
+                throw new Exception(
+                    "transport padding after a Mime Boundary  should end in a CRLF, found CR only");
+            }
+        }
+
+        if (b == '-') {
+            b = is.read();
+            if (b != '-') {
+               throw new Exception(
+                   "Unexpected singular '-' character after Mime Boundary");
+            } else {
+                //System.out.println("Last Part Found");
+                lastPartFound.flip(0);
+                // read the next char
+                b  = is.read();
+            }
+        }
+
+        while ((b != -1) && ((b == ' ') || (b == '\t'))) {
+            b = is.read();
+            if (b == '\r') {
+                b = is.read();
+                //skip any multiple '\r': "\r\n" --> "\r\r\n" on Win2k
+                if (b == '\r') {
+                    b = is.read();
+                }
+                if (b == '\n') {
+                   return true;
+                }
+            }
+        }
+
+        if (b == -1) {
+            // the last boundary need not have CRLF
+            if (!lastPartFound.get(0)) {
+                throw new Exception(
+                    "End of Multipart Stream before encountering  closing boundary delimiter");
+            }
+            return true;
+        }
+        return false;
+    }
+
+    private void compile(byte[] pattern) {
+        int l = pattern.length;
+
+        int i;
+        int j;
+
+        // Copied from J2SE 1.4 regex code
+        // java.util.regex.Pattern.java
+
+        // Initialise Bad Character Shift table
+        for (i = 0; i < l; i++) {
+            bcs[pattern[i]] = i + 1;
+        }
+
+        // Initialise Good Suffix Shift table
+        gss = new int[l];
+  NEXT: for (i = l; i > 0; i--) {
+            // j is the beginning index of suffix being considered
+            for (j = l - 1; j >= i; j--) {
+                // Testing for good suffix
+                if (pattern[j] == pattern[j - i]) {
+                    // pattern[j..len] is a good suffix
+                    gss[j - 1] = i;
+                } else {
+                   // No match. The array has already been
+                   // filled up with correct values before.
+                   continue NEXT;
+                }
+            }
+            while (j > 0) {
+                gss[--j] = i;
+            }
+        }
+        gss[l - 1] = 1;
+    }
+
+
+    /**
+     * Iterates through all the parts and outputs each Mime part
+     * separated by a boundary.
+     */
+    byte[] buf = new byte[1024];
+
+    public void writeTo(OutputStream os)
+            throws IOException, MessagingException {
+
+        // inputStream was not null
+        if (in != null) {
+            contentType.setParameter("boundary", this.boundary);
+        }
+
+        String bnd = "--" + contentType.getParameter("boundary");
+        for (int i = 0; i < parts.size(); i++) {
+            OutputUtil.writeln(bnd, os); // put out boundary
+            ((MimeBodyPart)parts.get(i)).writeTo(os);
+            OutputUtil.writeln(os); // put out empty line
+        }
+
+        if (in != null) {
+            OutputUtil.writeln(bnd, os); // put out boundary
+            if ((os instanceof ByteOutputStream) && lazyAttachments) {
+                ((ByteOutputStream)os).write(in);
+            } else {
+                ByteOutputStream baos = new ByteOutputStream(in.available());
+                baos.write(in);
+                baos.writeTo(os);
+                // reset the inputstream so that we can support a
+                //getAttachment later
+                in = baos.newInputStream();
+            }
+
+            // this will endup writing the end boundary
+        } else {
+        // put out last boundary
+            OutputUtil.writeAsAscii(bnd, os);
+            OutputUtil.writeAsAscii("--", os);
+        }
+    }
+
+    public void setInputStream(InputStream is) {
+        this.in = is;
+    }
+
+    public InputStream getInputStream() {
+        return this.in;
+    }
+
+    public void setBoundary(String bnd) {
+        this.boundary = bnd;
+        if (this.contentType != null) {
+            this.contentType.setParameter("boundary", bnd);
+        }
+    }
+    public String getBoundary() {
+        return this.boundary;
+    }
+
+    public boolean isEndOfStream() {
+        return (b == -1);
+    }
+
+    public void setLazyAttachments(boolean flag) {
+        lazyAttachments = flag;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ContentDisposition.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ContentDisposition.java
new file mode 100644
index 0000000..0774051
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ContentDisposition.java
@@ -0,0 +1,173 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+
+/**
+ * This class represents a MIME ContentDisposition value. It provides
+ * methods to parse a ContentDisposition string into individual components
+ * and to generate a MIME style ContentDisposition string.
+ *
+ * @author  John Mani
+ */
+
+public class ContentDisposition {
+
+    private String disposition; // disposition
+    private ParameterList list; // parameter list
+
+    /**
+     * No-arg Constructor.
+     */
+    public ContentDisposition() { }
+
+    /**
+     * Constructor.
+     *
+     * @param   disposition     disposition
+     * @param   list    ParameterList
+     * @since           JavaMail 1.2
+     */
+    public ContentDisposition(String disposition, ParameterList list) {
+        this.disposition = disposition;
+        this.list = list;
+    }
+
+    /**
+     * Constructor that takes a ContentDisposition string. The String
+     * is parsed into its constituents: dispostion and parameters.
+     * A ParseException is thrown if the parse fails.
+     *
+     * @param   s       the ContentDisposition string.
+     * @exception       ParseException if the parse fails.
+     * @since           JavaMail 1.2
+     */
+    public ContentDisposition(String s) throws ParseException {
+        HeaderTokenizer h = new HeaderTokenizer(s, HeaderTokenizer.MIME);
+        HeaderTokenizer.Token tk;
+
+        // First "disposition" ..
+        tk = h.next();
+        if (tk.getType() != HeaderTokenizer.Token.ATOM)
+            throw new ParseException();
+        disposition = tk.getValue();
+
+        // Then parameters ..
+        String rem = h.getRemainder();
+        if (rem != null)
+            list = new ParameterList(rem);
+    }
+
+    /**
+     * Return the disposition value.
+     * @return the disposition
+     * @since           JavaMail 1.2
+     */
+    public String getDisposition() {
+        return disposition;
+    }
+
+    /**
+     * Return the specified parameter value. Returns <code>null</code>
+     * if this parameter is absent.
+     * @return  parameter value
+     * @since           JavaMail 1.2
+     */
+    public String getParameter(String name) {
+        if (list == null)
+            return null;
+
+        return list.get(name);
+    }
+
+    /**
+     * Return a ParameterList object that holds all the available
+     * parameters. Returns null if no parameters are available.
+     *
+     * @return  ParameterList
+     * @since           JavaMail 1.2
+     */
+    public ParameterList getParameterList() {
+        return list;
+    }
+
+    /**
+     * Set the primary type. Overrides existing primary type.
+     * @param   primaryType     primary type
+     * @since           JavaMail 1.2
+     */
+    public void setDisposition(String disposition) {
+        this.disposition = disposition;
+    }
+
+    /**
+     * Set the specified parameter. If this parameter already exists,
+     * it is replaced by this new value.
+     *
+     * @param   name    parameter name
+     * @param   value   parameter value
+     * @since           JavaMail 1.2
+     */
+    public void setParameter(String name, String value) {
+        if (list == null)
+            list = new ParameterList();
+
+        list.set(name, value);
+    }
+
+    /**
+     * Set a new ParameterList.
+     * @param   list    ParameterList
+     * @since           JavaMail 1.2
+     */
+    public void setParameterList(ParameterList list) {
+        this.list = list;
+    }
+
+    /**
+     * Retrieve a RFC2045 style string representation of
+     * this ContentDisposition. Returns <code>null</code> if
+     * the conversion failed.
+     *
+     * @return  RFC2045 style string
+     * @since           JavaMail 1.2
+     */
+    public String toString() {
+        if (disposition == null)
+            return null;
+
+        if (list == null)
+            return disposition;
+
+        StringBuffer sb = new StringBuffer(disposition);
+
+        // append the parameter list
+        // use the length of the string buffer + the length of
+        // the header name formatted as follows "Content-Disposition: "
+        sb.append(list.toString(sb.length() + 21));
+        return sb.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ContentType.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ContentType.java
new file mode 100644
index 0000000..082cc51
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ContentType.java
@@ -0,0 +1,270 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+
+/**
+ * This class represents a MIME ContentType value. It provides
+ * methods to parse a ContentType string into individual components
+ * and to generate a MIME style ContentType string.
+ *
+ * @author  John Mani
+ */
+public final class ContentType {
+
+    private String primaryType; // primary type
+    private String subType;     // subtype
+    private ParameterList list; // parameter list
+
+    /**
+     * No-arg Constructor.
+     */
+    public ContentType() { }
+
+    /**
+     * Constructor.
+     *
+     * @param   primaryType     primary type
+     * @param   subType subType
+     * @param   list    ParameterList
+     */
+    public ContentType(String primaryType, String subType,
+                       ParameterList list) {
+        this.primaryType = primaryType;
+        this.subType = subType;
+        if (list == null)
+            list = new ParameterList();
+        this.list = list;
+    }
+
+    /**
+     * Constructor that takes a Content-Type string. The String
+     * is parsed into its constituents: primaryType, subType
+     * and parameters. A ParseException is thrown if the parse fails.
+     *
+     * @param   s       the Content-Type string.
+     * @exception       ParseException if the parse fails.
+     */
+    public ContentType(String s) throws ParseException {
+        HeaderTokenizer h = new HeaderTokenizer(s, HeaderTokenizer.MIME);
+        HeaderTokenizer.Token tk;
+
+        // First "type" ..
+        tk = h.next();
+        if (tk.getType() != HeaderTokenizer.Token.ATOM)
+            throw new ParseException();
+        primaryType = tk.getValue();
+
+        // The '/' separator ..
+        tk = h.next();
+        if ((char)tk.getType() != '/')
+            throw new ParseException();
+
+        // Then "subType" ..
+        tk = h.next();
+        if (tk.getType() != HeaderTokenizer.Token.ATOM)
+            throw new ParseException();
+        subType = tk.getValue();
+
+        // Finally parameters ..
+        String rem = h.getRemainder();
+        if (rem != null)
+            list = new ParameterList(rem);
+    }
+
+    public ContentType copy() {
+        return new ContentType(primaryType,subType,list.copy());
+    }
+
+    /**
+     * Return the primary type.
+     * @return the primary type
+     */
+    public String getPrimaryType() {
+        return primaryType;
+    }
+
+    /**
+     * Return the subType.
+     * @return the subType
+     */
+    public String getSubType() {
+        return subType;
+    }
+
+    /**
+     * Return the MIME type string, without the parameters.
+     * The returned value is basically the concatenation of
+     * the primaryType, the '/' character and the secondaryType.
+     *
+     * @return the type
+     */
+    public String getBaseType() {
+        return primaryType + '/' + subType;
+    }
+
+    /**
+     * Return the specified parameter value. Returns <code>null</code>
+     * if this parameter is absent.
+     * @return  parameter value
+     */
+    public String getParameter(String name) {
+        if (list == null)
+            return null;
+
+        return list.get(name);
+    }
+
+    /**
+     * Return a ParameterList object that holds all the available
+     * parameters. Returns null if no parameters are available.
+     *
+     * @return  ParameterList
+     */
+    public ParameterList getParameterList() {
+        return list;
+    }
+
+    /**
+     * Set the primary type. Overrides existing primary type.
+     * @param   primaryType     primary type
+     */
+    public void setPrimaryType(String primaryType) {
+        this.primaryType = primaryType;
+    }
+
+    /**
+     * Set the subType. Overrides existing subType
+     * @param   subType subType
+     */
+    public void setSubType(String subType) {
+        this.subType = subType;
+    }
+
+    /**
+     * Set the specified parameter. If this parameter already exists,
+     * it is replaced by this new value.
+     *
+     * @param   name    parameter name
+     * @param   value   parameter value
+     */
+    public void setParameter(String name, String value) {
+        if (list == null)
+            list = new ParameterList();
+
+        list.set(name, value);
+    }
+
+    /**
+     * Set a new ParameterList.
+     * @param   list    ParameterList
+     */
+    public void setParameterList(ParameterList list) {
+        this.list = list;
+    }
+
+    /**
+     * Retrieve a RFC2045 style string representation of
+     * this Content-Type. Returns <code>null</code> if
+     * the conversion failed.
+     *
+     * @return  RFC2045 style string
+     */
+    public String toString() {
+        if (primaryType == null || subType == null) // need both
+            return null;
+
+        StringBuffer sb = new StringBuffer();
+        sb.append(primaryType).append('/').append(subType);
+        if (list != null)
+        // Http Binding section of the "SOAP with attachments" specification says,
+        // "SOAP message senders should send Content-Type headers on a single long line."
+        // (http://www.w3.org/TR/SOAP-attachments#HTTPBinding)
+            sb.append(list.toString());
+
+        return sb.toString();
+    }
+
+    /**
+     * Match with the specified ContentType object. This method
+     * compares <strong>only the <code>primaryType</code> and
+     * <code>subType</code> </strong>. The parameters of both operands
+     * are ignored. <p>
+     *
+     * For example, this method will return <code>true</code> when
+     * comparing the ContentTypes for <strong>"text/plain"</strong>
+     * and <strong>"text/plain; charset=foobar"</strong>.
+     *
+     * If the <code>subType</code> of either operand is the special
+     * character '*', then the subtype is ignored during the match.
+     * For example, this method will return <code>true</code> when
+     * comparing the ContentTypes for <strong>"text/plain"</strong>
+     * and <strong>"text/*" </strong>
+     *
+     * @param   cType to compare this against
+     */
+    public boolean match(ContentType cType) {
+        // Match primaryType
+        if (!primaryType.equalsIgnoreCase(cType.getPrimaryType()))
+            return false;
+
+        String sType = cType.getSubType();
+
+        // If either one of the subTypes is wildcarded, return true
+        if ((subType.charAt(0) == '*') || (sType.charAt(0) == '*'))
+            return true;
+
+        // Match subType
+        if (!subType.equalsIgnoreCase(sType))
+            return false;
+
+        return true;
+    }
+
+    /**
+     * Match with the specified content-type string. This method
+     * compares <strong>only the <code>primaryType</code> and
+     * <code>subType</code> </strong>.
+     * The parameters of both operands are ignored. <p>
+     *
+     * For example, this method will return <code>true</code> when
+     * comparing the ContentType for <strong>"text/plain"</strong>
+     * with <strong>"text/plain; charset=foobar"</strong>.
+     *
+     * If the <code>subType</code> of either operand is the special
+     * character '*', then the subtype is ignored during the match.
+     * For example, this method will return <code>true</code> when
+     * comparing the ContentType for <strong>"text/plain"</strong>
+     * with <strong>"text/*" </strong>
+     */
+    public boolean match(String s) {
+        try {
+            return match(new ContentType(s));
+        } catch (ParseException pex) {
+            return false;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/HeaderTokenizer.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/HeaderTokenizer.java
new file mode 100644
index 0000000..7486de6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/HeaderTokenizer.java
@@ -0,0 +1,375 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+
+/**
+ * This class tokenizes RFC822 and MIME headers into the basic
+ * symbols specified by RFC822 and MIME. <p>
+ *
+ * This class handles folded headers (ie headers with embedded
+ * CRLF SPACE sequences). The folds are removed in the returned
+ * tokens.
+ *
+ * @author  John Mani
+ */
+
+public class HeaderTokenizer {
+
+    /**
+     * The Token class represents tokens returned by the
+     * HeaderTokenizer.
+     */
+    public static class Token {
+
+        private int type;
+        private String value;
+
+        /**
+         * Token type indicating an ATOM.
+         */
+        public static final int ATOM            = -1;
+
+        /**
+         * Token type indicating a quoted string. The value
+         * field contains the string without the quotes.
+         */
+        public static final int QUOTEDSTRING    = -2;
+
+        /**
+         * Token type indicating a comment. The value field
+         * contains the comment string without the comment
+         * start and end symbols.
+         */
+        public static final int COMMENT         = -3;
+
+        /**
+         * Token type indicating end of input.
+         */
+        public static final int  EOF            = -4;
+
+        /**
+         * Constructor.
+         * @param       type    Token type
+         * @param       value   Token value
+         */
+        public Token(int type, String value) {
+             this.type = type;
+             this.value = value;
+        }
+
+        /**
+         * Return the type of the token. If the token represents a
+         * delimiter or a control character, the type is that character
+         * itself, converted to an integer. Otherwise, it's value is
+         * one of the following:
+         * <ul>
+         * <li><code>ATOM</code> A sequence of ASCII characters
+         *      delimited by either SPACE, CTL, "(", <"> or the
+         *      specified SPECIALS
+         * <li><code>QUOTEDSTRING</code> A sequence of ASCII characters
+         *      within quotes
+         * <li><code>COMMENT</code> A sequence of ASCII characters
+         *      within "(" and ")".
+         * <li><code>EOF</code> End of header
+         * </ul>
+         */
+        public int getType() {
+            return type;
+        }
+
+        /**
+         * Returns the value of the token just read. When the current
+         * token is a quoted string, this field contains the body of the
+         * string, without the quotes. When the current token is a comment,
+         * this field contains the body of the comment.
+         *
+         * @return      token value
+         */
+        public String getValue() {
+            return value;
+        }
+    }
+
+    private String string; // the string to be tokenized
+    private boolean skipComments; // should comments be skipped ?
+    private String delimiters; // delimiter string
+    private int currentPos; // current parse position
+    private int maxPos; // string length
+    private int nextPos; // track start of next Token for next()
+    private int peekPos; // track start of next Token for peek()
+
+    /**
+     * RFC822 specials
+     */
+    public final static String RFC822 = "()<>@,;:\\\"\t .[]";
+
+    /**
+     * MIME specials
+     */
+    public final static String MIME = "()<>@,;:\\\"\t []/?=";
+
+    // The EOF Token
+    private final static Token EOFToken = new Token(Token.EOF, null);
+
+    /**
+     * Constructor that takes a rfc822 style header.
+     *
+     * @param   header  The rfc822 header to be tokenized
+     * @param   delimiters      Set of delimiter characters
+     *                          to be used to delimit ATOMS. These
+     *                          are usually <code>RFC822</code> or
+     *                          <code>MIME</code>
+     * @param   skipComments  If true, comments are skipped and
+     *                          not returned as tokens
+     */
+    public HeaderTokenizer(String header, String delimiters,
+                           boolean skipComments) {
+        string = (header == null) ? "" : header; // paranoia ?!
+        this.skipComments = skipComments;
+        this.delimiters = delimiters;
+        currentPos = nextPos = peekPos = 0;
+        maxPos = string.length();
+    }
+
+    /**
+     * Constructor. Comments are ignored and not returned as tokens
+     *
+     * @param   header  The header that is tokenized
+     * @param   delimiters  The delimiters to be used
+     */
+    public HeaderTokenizer(String header, String delimiters) {
+        this(header, delimiters, true);
+    }
+
+    /**
+     * Constructor. The RFC822 defined delimiters - RFC822 - are
+     * used to delimit ATOMS. Also comments are skipped and not
+     * returned as tokens
+     */
+    public HeaderTokenizer(String header)  {
+        this(header, RFC822);
+    }
+
+    /**
+     * Parses the next token from this String. <p>
+     *
+     * Clients sit in a loop calling next() to parse successive
+     * tokens until an EOF Token is returned.
+     *
+     * @return          the next Token
+     * @exception       ParseException if the parse fails
+     */
+    public Token next() throws ParseException {
+        Token tk;
+
+        currentPos = nextPos; // setup currentPos
+        tk = getNext();
+        nextPos = peekPos = currentPos; // update currentPos and peekPos
+        return tk;
+    }
+
+    /**
+     * Peek at the next token, without actually removing the token
+     * from the parse stream. Invoking this method multiple times
+     * will return successive tokens, until <code>next()</code> is
+     * called. <p>
+     *
+     * @return          the next Token
+     * @exception       ParseException if the parse fails
+     */
+    public Token peek() throws ParseException {
+        Token tk;
+
+        currentPos = peekPos; // setup currentPos
+        tk = getNext();
+        peekPos = currentPos; // update peekPos
+        return tk;
+    }
+
+    /**
+     * Return the rest of the Header.
+     *
+     * @return String   rest of header. null is returned if we are
+     *                  already at end of header
+     */
+    public String getRemainder() {
+        return string.substring(nextPos);
+    }
+
+    /*
+     * Return the next token starting from 'currentPos'. After the
+     * parse, 'currentPos' is updated to point to the start of the
+     * next token.
+     */
+    private Token getNext() throws ParseException {
+        // If we're already at end of string, return EOF
+        if (currentPos >= maxPos)
+            return EOFToken;
+
+        // Skip white-space, position currentPos beyond the space
+        if (skipWhiteSpace() == Token.EOF)
+            return EOFToken;
+
+        char c;
+        int start;
+        boolean filter = false;
+
+        c = string.charAt(currentPos);
+
+        // Check or Skip comments and position currentPos
+        // beyond the comment
+        while (c == '(') {
+            // Parsing comment ..
+            int nesting;
+            for (start = ++currentPos, nesting = 1;
+                 nesting > 0 && currentPos < maxPos;
+                 currentPos++) {
+                c = string.charAt(currentPos);
+                if (c == '\\') {  // Escape sequence
+                    currentPos++; // skip the escaped character
+                    filter = true;
+                } else if (c == '\r')
+                    filter = true;
+                else if (c == '(')
+                    nesting++;
+                else if (c == ')')
+                    nesting--;
+            }
+            if (nesting != 0)
+                throw new ParseException("Unbalanced comments");
+
+            if (!skipComments) {
+                // Return the comment, if we are asked to.
+                // Note that the comment start & end markers are ignored.
+                String s;
+                if (filter) // need to go thru the token again.
+                    s = filterToken(string, start, currentPos-1);
+                else
+                    s = string.substring(start,currentPos-1);
+
+                return new Token(Token.COMMENT, s);
+            }
+
+            // Skip any whitespace after the comment.
+            if (skipWhiteSpace() == Token.EOF)
+                return EOFToken;
+            c = string.charAt(currentPos);
+        }
+
+        // Check for quoted-string and position currentPos
+        //  beyond the terminating quote
+        if (c == '"') {
+            for (start = ++currentPos; currentPos < maxPos; currentPos++) {
+                c = string.charAt(currentPos);
+                if (c == '\\') { // Escape sequence
+                    currentPos++;
+                    filter = true;
+                } else if (c == '\r')
+                    filter = true;
+                else if (c == '"') {
+                    currentPos++;
+                    String s;
+
+                    if (filter)
+                        s = filterToken(string, start, currentPos-1);
+                    else
+                        s = string.substring(start,currentPos-1);
+
+                    return new Token(Token.QUOTEDSTRING, s);
+                }
+            }
+            throw new ParseException("Unbalanced quoted string");
+        }
+
+        // Check for SPECIAL or CTL
+        if (c < 040 || c >= 0177 || delimiters.indexOf(c) >= 0) {
+            currentPos++; // re-position currentPos
+            char ch[] = new char[1];
+            ch[0] = c;
+            return new Token((int)c, new String(ch));
+        }
+
+        // Check for ATOM
+        for (start = currentPos; currentPos < maxPos; currentPos++) {
+            c = string.charAt(currentPos);
+            // ATOM is delimited by either SPACE, CTL, "(", <">
+            // or the specified SPECIALS
+            if (c < 040 || c >= 0177 || c == '(' || c == ' ' ||
+                c == '"' || delimiters.indexOf(c) >= 0)
+                break;
+        }
+        return new Token(Token.ATOM, string.substring(start, currentPos));
+    }
+
+    // Skip SPACE, HT, CR and NL
+    private int skipWhiteSpace() {
+        char c;
+        for (; currentPos < maxPos; currentPos++)
+            if (((c = string.charAt(currentPos)) != ' ') &&
+                (c != '\t') && (c != '\r') && (c != '\n'))
+                return currentPos;
+        return Token.EOF;
+    }
+
+    /* Process escape sequences and embedded LWSPs from a comment or
+     * quoted string.
+     */
+    private static String filterToken(String s, int start, int end) {
+        StringBuffer sb = new StringBuffer();
+        char c;
+        boolean gotEscape = false;
+        boolean gotCR = false;
+
+        for (int i = start; i < end; i++) {
+            c = s.charAt(i);
+            if (c == '\n' && gotCR) {
+                // This LF is part of an unescaped
+                // CRLF sequence (i.e, LWSP). Skip it.
+                gotCR = false;
+                continue;
+            }
+
+            gotCR = false;
+            if (!gotEscape) {
+                // Previous character was NOT '\'
+                if (c == '\\') // skip this character
+                    gotEscape = true;
+                else if (c == '\r') // skip this character
+                    gotCR = true;
+                else // append this character
+                    sb.append(c);
+            } else {
+                // Previous character was '\'. So no need to
+                // bother with any special processing, just
+                // append this character
+                sb.append(c);
+                gotEscape = false;
+            }
+        }
+        return sb.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/InternetHeaders.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/InternetHeaders.java
new file mode 100644
index 0000000..15c106c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/InternetHeaders.java
@@ -0,0 +1,396 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.Header;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.MessagingException;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.util.LineInputStream;
+import com.sun.xml.internal.messaging.saaj.util.FinalArrayList;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.AbstractList;
+import java.util.List;
+import java.util.NoSuchElementException;
+
+/**
+ * InternetHeaders is a utility class that manages RFC822 style
+ * headers. Given an RFC822 format message stream, it reads lines
+ * until the blank line that indicates end of header. The input stream
+ * is positioned at the start of the body. The lines are stored
+ * within the object and can be extracted as either Strings or
+ * {@link Header} objects. <p>
+ * <p/>
+ * This class is mostly intended for service providers. MimeMessage
+ * and MimeBody use this class for holding their headers. <p>
+ * <p/>
+ * <hr> <strong>A note on RFC822 and MIME headers</strong><p>
+ * <p/>
+ * RFC822 and MIME header fields <strong>must</strong> contain only
+ * US-ASCII characters. If a header contains non US-ASCII characters,
+ * it must be encoded as per the rules in RFC 2047. The MimeUtility
+ * class provided in this package can be used to to achieve this.
+ * Callers of the <code>setHeader</code>, <code>addHeader</code>, and
+ * <code>addHeaderLine</code> methods are responsible for enforcing
+ * the MIME requirements for the specified headers.  In addition, these
+ * header fields must be folded (wrapped) before being sent if they
+ * exceed the line length limitation for the transport (1000 bytes for
+ * SMTP).  Received headers may have been folded.  The application is
+ * responsible for folding and unfolding headers as appropriate. <p>
+ *
+ * @author John Mani
+ * @author Bill Shannon
+ * @see MimeUtility
+ */
+public final class InternetHeaders {
+
+    private final FinalArrayList headers = new FinalArrayList();
+
+    /**
+     * Lazily cerated view of header lines (Strings).
+     */
+    private List headerValueView;
+
+    /**
+     * Create an empty InternetHeaders object.
+     */
+    public InternetHeaders() {
+    }
+
+    /**
+     * Read and parse the given RFC822 message stream till the
+     * blank line separating the header from the body. The input
+     * stream is left positioned at the start of the body. The
+     * header lines are stored internally. <p>
+     * <p/>
+     * For efficiency, wrap a BufferedInputStream around the actual
+     * input stream and pass it as the parameter.
+     *
+     * @param   is RFC822 input stream
+     */
+    public InternetHeaders(InputStream is) throws MessagingException {
+        load(is);
+    }
+
+    /**
+     * Read and parse the given RFC822 message stream till the
+     * blank line separating the header from the body. Store the
+     * header lines inside this InternetHeaders object. <p>
+     * <p/>
+     * Note that the header lines are added into this InternetHeaders
+     * object, so any existing headers in this object will not be
+     * affected.
+     *
+     * @param   is RFC822 input stream
+     */
+    public void load(InputStream is) throws MessagingException {
+        // Read header lines until a blank line. It is valid
+        // to have BodyParts with no header lines.
+        String line;
+        LineInputStream lis = new LineInputStream(is);
+        String prevline = null; // the previous header line, as a string
+        // a buffer to accumulate the header in, when we know it's needed
+        StringBuffer lineBuffer = new StringBuffer();
+
+        try {
+            //while ((line = lis.readLine()) != null) {
+            do {
+                line = lis.readLine();
+                if (line != null &&
+                        (line.startsWith(" ") || line.startsWith("\t"))) {
+                    // continuation of header
+                    if (prevline != null) {
+                        lineBuffer.append(prevline);
+                        prevline = null;
+                    }
+                    lineBuffer.append("\r\n");
+                    lineBuffer.append(line);
+                } else {
+                    // new header
+                    if (prevline != null)
+                        addHeaderLine(prevline);
+                    else if (lineBuffer.length() > 0) {
+                        // store previous header first
+                        addHeaderLine(lineBuffer.toString());
+                        lineBuffer.setLength(0);
+                    }
+                    prevline = line;
+                }
+            } while (line != null && line.length() > 0);
+        } catch (IOException ioex) {
+            throw new MessagingException("Error in input stream", ioex);
+        }
+    }
+
+    /**
+     * Return all the values for the specified header. The
+     * values are String objects.  Returns <code>null</code>
+     * if no headers with the specified name exist.
+     *
+     * @param   name header name
+     * @return          array of header values, or null if none
+     */
+    public String[] getHeader(String name) {
+        // XXX - should we just step through in index order?
+        FinalArrayList v = new FinalArrayList(); // accumulate return values
+
+        int len = headers.size();
+        for( int i=0; i<len; i++ ) {
+            hdr h = (hdr) headers.get(i);
+            if (name.equalsIgnoreCase(h.name)) {
+                v.add(h.getValue());
+            }
+        }
+        if (v.size() == 0)
+            return (null);
+        // convert Vector to an array for return
+        return (String[]) v.toArray(new String[v.size()]);
+    }
+
+    /**
+     * Get all the headers for this header name, returned as a single
+     * String, with headers separated by the delimiter. If the
+     * delimiter is <code>null</code>, only the first header is
+     * returned.  Returns <code>null</code>
+     * if no headers with the specified name exist.
+     *
+     * @param delimiter delimiter
+     * @return the value fields for all headers with
+     *         this name, or null if none
+     * @param   name header name
+     */
+    public String getHeader(String name, String delimiter) {
+        String[] s = getHeader(name);
+
+        if (s == null)
+            return null;
+
+        if ((s.length == 1) || delimiter == null)
+            return s[0];
+
+        StringBuffer r = new StringBuffer(s[0]);
+        for (int i = 1; i < s.length; i++) {
+            r.append(delimiter);
+            r.append(s[i]);
+        }
+        return r.toString();
+    }
+
+    /**
+     * Change the first header line that matches name
+     * to have value, adding a new header if no existing header
+     * matches. Remove all matching headers but the first. <p>
+     * <p/>
+     * Note that RFC822 headers can only contain US-ASCII characters
+     *
+     * @param   name    header name
+     * @param   value   header value
+     */
+    public void setHeader(String name, String value) {
+        boolean found = false;
+
+        for (int i = 0; i < headers.size(); i++) {
+            hdr h = (hdr) headers.get(i);
+            if (name.equalsIgnoreCase(h.name)) {
+                if (!found) {
+                    int j;
+                    if (h.line != null && (j = h.line.indexOf(':')) >= 0) {
+                        h.line = h.line.substring(0, j + 1) + " " + value;
+                    } else {
+                        h.line = name + ": " + value;
+                    }
+                    found = true;
+                } else {
+                    headers.remove(i);
+                    i--;    // have to look at i again
+                }
+            }
+        }
+
+        if (!found) {
+            addHeader(name, value);
+        }
+    }
+
+    /**
+     * Add a header with the specified name and value to the header list. <p>
+     * <p/>
+     * Note that RFC822 headers can only contain US-ASCII characters.
+     *
+     * @param   name    header name
+     * @param   value   header value
+     */
+    public void addHeader(String name, String value) {
+        int pos = headers.size();
+        for (int i = headers.size() - 1; i >= 0; i--) {
+            hdr h = (hdr) headers.get(i);
+            if (name.equalsIgnoreCase(h.name)) {
+                headers.add(i + 1, new hdr(name, value));
+                return;
+            }
+            // marker for default place to add new headers
+            if (h.name.equals(":"))
+                pos = i;
+        }
+        headers.add(pos, new hdr(name, value));
+    }
+
+    /**
+     * Remove all header entries that match the given name
+     *
+     * @param   name header name
+     */
+    public void removeHeader(String name) {
+        for (int i = 0; i < headers.size(); i++) {
+            hdr h = (hdr) headers.get(i);
+            if (name.equalsIgnoreCase(h.name)) {
+                headers.remove(i);
+                i--;    // have to look at i again
+            }
+        }
+    }
+
+    /**
+     * Return all the headers as an Enumeration of
+     * {@link Header} objects.
+     *
+     * @return  Header objects
+     */
+    public FinalArrayList getAllHeaders() {
+        return headers; // conceptually it should be read-only, but for performance reason I'm not wrapping it here
+    }
+
+    /**
+     * Add an RFC822 header line to the header store.
+     * If the line starts with a space or tab (a continuation line),
+     * add it to the last header line in the list. <p>
+     * <p/>
+     * Note that RFC822 headers can only contain US-ASCII characters
+     *
+     * @param   line    raw RFC822 header line
+     */
+    public void addHeaderLine(String line) {
+        try {
+            char c = line.charAt(0);
+            if (c == ' ' || c == '\t') {
+                hdr h = (hdr) headers.get(headers.size() - 1);
+                h.line += "\r\n" + line;
+            } else
+                headers.add(new hdr(line));
+        } catch (StringIndexOutOfBoundsException e) {
+            // line is empty, ignore it
+            return;
+        } catch (NoSuchElementException e) {
+            // XXX - vector is empty?
+        }
+    }
+
+    /**
+     * Return all the header lines as a collection
+     */
+    public List getAllHeaderLines() {
+        if(headerValueView==null)
+            headerValueView = new AbstractList() {
+                public Object get(int index) {
+                    return ((hdr)headers.get(index)).line;
+                }
+
+                public int size() {
+                    return headers.size();
+                }
+            };
+        return headerValueView;
+    }
+}
+
+/*
+ * A private utility class to represent an individual header.
+ */
+
+class hdr implements Header {
+    // XXX - should these be private?
+    String name;    // the canonicalized (trimmed) name of this header
+    // XXX - should name be stored in lower case?
+    String line;    // the entire RFC822 header "line"
+
+    /*
+     * Constructor that takes a line and splits out
+     * the header name.
+     */
+    hdr(String l) {
+        int i = l.indexOf(':');
+        if (i < 0) {
+            // should never happen
+            name = l.trim();
+        } else {
+            name = l.substring(0, i).trim();
+        }
+        line = l;
+    }
+
+    /*
+     * Constructor that takes a header name and value.
+     */
+    hdr(String n, String v) {
+        name = n;
+        line = n + ": " + v;
+    }
+
+    /*
+     * Return the "name" part of the header line.
+     */
+    public String getName() {
+        return name;
+    }
+
+    /*
+     * Return the "value" part of the header line.
+     */
+    public String getValue() {
+        int i = line.indexOf(':');
+        if (i < 0)
+            return line;
+
+        int j;
+        if (name.equalsIgnoreCase("Content-Description")) {
+            // Content-Description should retain the folded whitespace after header unfolding -
+            // rf. RFC2822 section 2.2.3, rf. RFC2822 section 3.2.3
+            for (j = i + 1; j < line.length(); j++) {
+                char c = line.charAt(j);
+                if (!(/*c == ' ' ||*/c == '\t' || c == '\r' || c == '\n'))
+                    break;
+            }
+        } else {
+            // skip whitespace after ':'
+            for (j = i + 1; j < line.length(); j++) {
+                char c = line.charAt(j);
+                if (!(c == ' ' || c == '\t' || c == '\r' || c == '\n'))
+                    break;
+            }
+        }
+        return line.substring(j);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeBodyPart.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeBodyPart.java
new file mode 100644
index 0000000..12c9364
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeBodyPart.java
@@ -0,0 +1,1087 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.MessagingException;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.util.OutputUtil;
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+import com.sun.xml.internal.messaging.saaj.util.FinalArrayList;
+
+import javax.activation.DataHandler;
+import java.io.BufferedInputStream;
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.io.UnsupportedEncodingException;
+import java.util.List;
+
+/**
+ * This class represents a MIME body part.
+ * MimeBodyParts are contained in <code>MimeMultipart</code>
+ * objects. <p>
+ *
+ * MimeBodyPart uses the <code>InternetHeaders</code> class to parse
+ * and store the headers of that body part. <p>
+ *
+ * <hr><strong>A note on RFC 822 and MIME headers</strong><p>
+ *
+ * RFC 822 header fields <strong>must</strong> contain only
+ * US-ASCII characters. MIME allows non ASCII characters to be present
+ * in certain portions of certain headers, by encoding those characters.
+ * RFC 2047 specifies the rules for doing this. The MimeUtility
+ * class provided in this package can be used to to achieve this.
+ * Callers of the <code>setHeader</code>, <code>addHeader</code>, and
+ * <code>addHeaderLine</code> methods are responsible for enforcing
+ * the MIME requirements for the specified headers.  In addition, these
+ * header fields must be folded (wrapped) before being sent if they
+ * exceed the line length limitation for the transport (1000 bytes for
+ * SMTP).  Received headers may have been folded.  The application is
+ * responsible for folding and unfolding headers as appropriate. <p>
+ *
+ * @author John Mani
+ * @author Bill Shannon
+ * @see MimeUtility
+ */
+
+public final class MimeBodyPart {
+
+    /**
+     * This part should be presented as an attachment.
+     * @see #getDisposition
+     * @see #setDisposition
+     */
+    public static final String ATTACHMENT = "attachment";
+
+    /**
+     * This part should be presented inline.
+     * @see #getDisposition
+     * @see #setDisposition
+     */
+    public static final String INLINE = "inline";
+
+
+    // Paranoia:
+    // allow this last minute change to be disabled if it causes problems
+    private static boolean setDefaultTextCharset = true;
+
+    static {
+        try {
+            String s = System.getProperty("mail.mime.setdefaulttextcharset");
+            // default to true
+            setDefaultTextCharset = s == null || !s.equalsIgnoreCase("false");
+        } catch (SecurityException sex) {
+            // ignore it
+        }
+    }
+
+    /*
+        Data is represented in one of three forms.
+        Either we have a DataHandler, or byte[] as the raw content image, or the contentStream.
+        It's OK to have more than one of them, provided that they are identical.
+    */
+
+    /**
+     * The DataHandler object representing this MimeBodyPart's content.
+     */
+    private DataHandler dh;
+
+    /**
+     * Byte array that holds the bytes of the content of this MimeBodyPart.
+     * Used in a pair with {@link #contentLength} to denote a regision of a buffer
+     * as a valid data.
+     */
+    private byte[] content;
+    private int contentLength;
+    private int start = 0;
+
+    /**
+     * If the data for this body part was supplied by an
+     * InputStream that implements the SharedInputStream interface,
+     * <code>contentStream</code> is another such stream representing
+     * the content of this body part.  In this case, <code>content</code>
+     * will be null.
+     *
+     * @since   JavaMail 1.2
+     */
+    private InputStream contentStream;
+
+
+
+    /**
+     * The InternetHeaders object that stores all the headers
+     * of this body part.
+     */
+    private final InternetHeaders headers;
+
+    /**
+     * The <code>MimeMultipart</code> object containing this <code>MimeBodyPart</code>,
+     * if known.
+     * @since   JavaMail 1.1
+     */
+    private MimeMultipart parent;
+
+    /**
+     * An empty MimeBodyPart object is created.
+     * This body part maybe filled in by a client constructing a multipart
+     * message.
+     */
+    public MimeBodyPart() {
+        headers = new InternetHeaders();
+    }
+
+    /**
+     * Constructs a MimeBodyPart by reading and parsing the data from
+     * the specified input stream. The parser consumes data till the end
+     * of the given input stream.  The input stream must start at the
+     * beginning of a valid MIME body part and must terminate at the end
+     * of that body part. <p>
+     *
+     * Note that the "boundary" string that delimits body parts must
+     * <strong>not</strong> be included in the input stream. The intention
+     * is that the MimeMultipart parser will extract each body part's bytes
+     * from a multipart stream and feed them into this constructor, without
+     * the delimiter strings.
+     *
+     * @param   is      the body part Input Stream
+     */
+    public MimeBodyPart(InputStream is) throws MessagingException {
+        if (!(is instanceof ByteArrayInputStream) &&
+                !(is instanceof BufferedInputStream) &&
+                !(is instanceof SharedInputStream))
+            is = new BufferedInputStream(is);
+
+        headers = new InternetHeaders(is);
+
+        if (is instanceof SharedInputStream) {
+            SharedInputStream sis = (SharedInputStream) is;
+            contentStream = sis.newStream(sis.getPosition(), -1);
+        } else {
+            try {
+                ByteOutputStream bos = new ByteOutputStream();
+                bos.write(is);
+                content = bos.getBytes();
+                contentLength = bos.getCount();
+            } catch (IOException ioex) {
+                throw new MessagingException("Error reading input stream", ioex);
+            }
+        }
+
+    }
+
+    /**
+     * Constructs a MimeBodyPart using the given header and
+     * content bytes. <p>
+     *
+     * Used by providers.
+     *
+     * @param   headers The header of this part
+     * @param   content bytes representing the body of this part.
+     */
+    public MimeBodyPart(InternetHeaders headers, byte[] content, int len) {
+        this.headers = headers;
+        this.content = content;
+        this.contentLength = len;
+    }
+
+    public MimeBodyPart(
+        InternetHeaders headers, byte[] content, int start,  int len) {
+        this.headers = headers;
+        this.content = content;
+        this.start = start;
+        this.contentLength = len;
+    }
+
+    /**
+     * Return the containing <code>MimeMultipart</code> object,
+     * or <code>null</code> if not known.
+     */
+    public MimeMultipart getParent() {
+        return parent;
+    }
+
+    /**
+     * Set the parent of this <code>MimeBodyPart</code> to be the specified
+     * <code>MimeMultipart</code>.  Normally called by <code>MimeMultipart</code>'s
+     * <code>addBodyPart</code> method.  <code>parent</code> may be
+     * <code>null</code> if the <code>MimeBodyPart</code> is being removed
+     * from its containing <code>MimeMultipart</code>.
+     * @since   JavaMail 1.1
+     */
+    public void setParent(MimeMultipart parent) {
+        this.parent = parent;
+    }
+
+    /**
+     * Return the size of the content of this body part in bytes.
+     * Return -1 if the size cannot be determined. <p>
+     *
+     * Note that this number may not be an exact measure of the
+     * content size and may or may not account for any transfer
+     * encoding of the content. <p>
+     *
+     * This implementation returns the size of the <code>content</code>
+     * array (if not null), or, if <code>contentStream</code> is not
+     * null, and the <code>available</code> method returns a positive
+     * number, it returns that number as the size.  Otherwise, it returns
+     * -1.
+     *
+     * @return size in bytes, or -1 if not known
+     */
+    public int getSize() {
+        if (content != null)
+            return contentLength;
+        if (contentStream != null) {
+            try {
+                int size = contentStream.available();
+                // only believe the size if it's greate than zero, since zero
+                // is the default returned by the InputStream class itself
+                if (size > 0)
+                    return size;
+            } catch (IOException ex) {
+                // ignore it
+            }
+        }
+        return -1;
+    }
+
+    /**
+     * Return the number of lines for the content of this MimeBodyPart.
+     * Return -1 if this number cannot be determined. <p>
+     *
+     * Note that this number may not be an exact measure of the
+     * content length and may or may not account for any transfer
+     * encoding of the content. <p>
+     *
+     * This implementation returns -1.
+     *
+     * @return number of lines, or -1 if not known
+     */
+     public int getLineCount() {
+        return -1;
+     }
+
+    /**
+     * Returns the value of the RFC 822 "Content-Type" header field.
+     * This represents the content type of the content of this
+     * body part. This value must not be null. If this field is
+     * unavailable, "text/plain" should be returned. <p>
+     *
+     * This implementation uses <code>getHeader(name)</code>
+     * to obtain the requisite header field.
+     *
+     * @return  Content-Type of this body part
+     */
+    public String getContentType() {
+        String s = getHeader("Content-Type", null);
+        if (s == null)
+            s = "text/plain";
+
+        return s;
+    }
+
+    /**
+     * Is this MimeBodyPart of the specified MIME type?  This method
+     * compares <strong>only the <code>primaryType</code> and
+     * <code>subType</code></strong>.
+     * The parameters of the content types are ignored. <p>
+     *
+     * For example, this method will return <code>true</code> when
+     * comparing a MimeBodyPart of content type <strong>"text/plain"</strong>
+     * with <strong>"text/plain; charset=foobar"</strong>. <p>
+     *
+     * If the <code>subType</code> of <code>mimeType</code> is the
+     * special character '*', then the subtype is ignored during the
+     * comparison.
+     */
+    public boolean isMimeType(String mimeType) {
+        boolean result;
+        // XXX - lots of room for optimization here!
+        try {
+            ContentType ct = new ContentType(getContentType());
+            result = ct.match(mimeType);
+        } catch (ParseException ex) {
+            result = getContentType().equalsIgnoreCase(mimeType);
+        }
+        return result;
+    }
+
+    /**
+     * Returns the value of the "Content-Disposition" header field.
+     * This represents the disposition of this part. The disposition
+     * describes how the part should be presented to the user. <p>
+     *
+     * If the Content-Disposition field is unavailable,
+     * null is returned. <p>
+     *
+     * This implementation uses <code>getHeader(name)</code>
+     * to obtain the requisite header field.
+     *
+     * @see #headers
+     */
+    public String getDisposition() throws MessagingException {
+        String s = getHeader("Content-Disposition", null);
+
+        if (s == null)
+            return null;
+
+        ContentDisposition cd = new ContentDisposition(s);
+        return cd.getDisposition();
+    }
+
+    /**
+     * Set the "Content-Disposition" header field of this body part.
+     * If the disposition is null, any existing "Content-Disposition"
+     * header field is removed.
+     *
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     */
+    public void setDisposition(String disposition) throws MessagingException {
+        if (disposition == null)
+            removeHeader("Content-Disposition");
+        else {
+            String s = getHeader("Content-Disposition", null);
+            if (s != null) {
+                /* A Content-Disposition header already exists ..
+                 *
+                 * Override disposition, but attempt to retain
+                 * existing disposition parameters
+                 */
+                ContentDisposition cd = new ContentDisposition(s);
+                cd.setDisposition(disposition);
+                disposition = cd.toString();
+            }
+            setHeader("Content-Disposition", disposition);
+        }
+    }
+
+    /**
+     * Returns the content transfer encoding from the
+     * "Content-Transfer-Encoding" header
+     * field. Returns <code>null</code> if the header is unavailable
+     * or its value is absent. <p>
+     *
+     * This implementation uses <code>getHeader(name)</code>
+     * to obtain the requisite header field.
+     *
+     * @see #headers
+     */
+    public String getEncoding() throws MessagingException {
+        String s = getHeader("Content-Transfer-Encoding", null);
+
+        if (s == null)
+            return null;
+
+        s = s.trim();   // get rid of trailing spaces
+        // quick check for known values to avoid unnecessary use
+        // of tokenizer.
+        if (s.equalsIgnoreCase("7bit") || s.equalsIgnoreCase("8bit") ||
+            s.equalsIgnoreCase("quoted-printable") ||
+            s.equalsIgnoreCase("base64"))
+            return s;
+
+        // Tokenize the header to obtain the encoding (skip comments)
+        HeaderTokenizer h = new HeaderTokenizer(s, HeaderTokenizer.MIME);
+
+        HeaderTokenizer.Token tk;
+        int tkType;
+
+        for (;;) {
+            tk = h.next(); // get a token
+            tkType = tk.getType();
+            if (tkType == HeaderTokenizer.Token.EOF)
+            break; // done
+            else if (tkType == HeaderTokenizer.Token.ATOM)
+            return tk.getValue();
+            else // invalid token, skip it.
+            continue;
+        }
+        return s;
+    }
+
+    /**
+     * Returns the value of the "Content-ID" header field. Returns
+     * <code>null</code> if the field is unavailable or its value is
+     * absent. <p>
+     *
+     * This implementation uses <code>getHeader(name)</code>
+     * to obtain the requisite header field.
+     */
+    public String getContentID() {
+        return getHeader("Content-ID", null);
+    }
+
+    /**
+     * Set the "Content-ID" header field of this body part.
+     * If the <code>cid</code> parameter is null, any existing
+     * "Content-ID" is removed.
+     *
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     * @since           JavaMail 1.3
+     */
+    public void setContentID(String cid) {
+        if (cid == null)
+            removeHeader("Content-ID");
+        else
+            setHeader("Content-ID", cid);
+    }
+
+    /**
+     * Return the value of the "Content-MD5" header field. Returns
+     * <code>null</code> if this field is unavailable or its value
+     * is absent. <p>
+     *
+     * This implementation uses <code>getHeader(name)</code>
+     * to obtain the requisite header field.
+     */
+    public String getContentMD5() {
+        return getHeader("Content-MD5", null);
+    }
+
+    /**
+     * Set the "Content-MD5" header field of this body part.
+     *
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     */
+    public void setContentMD5(String md5) {
+        setHeader("Content-MD5", md5);
+    }
+
+    /**
+     * Get the languages specified in the Content-Language header
+     * of this MimeBodyPart. The Content-Language header is defined by
+     * RFC 1766. Returns <code>null</code> if this header is not
+     * available or its value is absent. <p>
+     *
+     * This implementation uses <code>getHeader(name)</code>
+     * to obtain the requisite header field.
+     */
+    public String[] getContentLanguage() throws MessagingException {
+        String s = getHeader("Content-Language", null);
+
+        if (s == null)
+            return null;
+
+        // Tokenize the header to obtain the Language-tags (skip comments)
+        HeaderTokenizer h = new HeaderTokenizer(s, HeaderTokenizer.MIME);
+        FinalArrayList v = new FinalArrayList();
+
+        HeaderTokenizer.Token tk;
+        int tkType;
+
+        while (true) {
+            tk = h.next(); // get a language-tag
+            tkType = tk.getType();
+            if (tkType == HeaderTokenizer.Token.EOF)
+            break; // done
+            else if (tkType == HeaderTokenizer.Token.ATOM) v.add(tk.getValue());
+            else // invalid token, skip it.
+            continue;
+        }
+
+        if (v.size() == 0)
+            return null;
+
+        return (String[])v.toArray(new String[v.size()]);
+    }
+
+    /**
+     * Set the Content-Language header of this MimeBodyPart. The
+     * Content-Language header is defined by RFC 1766.
+     *
+     * @param languages         array of language tags
+     */
+    public void setContentLanguage(String[] languages) {
+        StringBuffer sb = new StringBuffer(languages[0]);
+        for (int i = 1; i < languages.length; i++)
+            sb.append(',').append(languages[i]);
+        setHeader("Content-Language", sb.toString());
+    }
+
+    /**
+     * Returns the "Content-Description" header field of this body part.
+     * This typically associates some descriptive information with
+     * this part. Returns null if this field is unavailable or its
+     * value is absent. <p>
+     *
+     * If the Content-Description field is encoded as per RFC 2047,
+     * it is decoded and converted into Unicode. If the decoding or
+     * conversion fails, the raw data is returned as is. <p>
+     *
+     * This implementation uses <code>getHeader(name)</code>
+     * to obtain the requisite header field.
+     *
+     * @return  content description
+     */
+    public String getDescription() {
+        String rawvalue = getHeader("Content-Description", null);
+
+        if (rawvalue == null)
+            return null;
+
+        try {
+            return MimeUtility.decodeText(MimeUtility.unfold(rawvalue));
+        } catch (UnsupportedEncodingException ex) {
+            return rawvalue;
+        }
+    }
+
+    /**
+     * Set the "Content-Description" header field for this body part.
+     * If the description parameter is <code>null</code>, then any
+     * existing "Content-Description" fields are removed. <p>
+     *
+     * If the description contains non US-ASCII characters, it will
+     * be encoded using the platform's default charset. If the
+     * description contains only US-ASCII characters, no encoding
+     * is done and it is used as is. <p>
+     *
+     * Note that if the charset encoding process fails, a
+     * MessagingException is thrown, and an UnsupportedEncodingException
+     * is included in the chain of nested exceptions within the
+     * MessagingException.
+     *
+     * @param description content description
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     * @exception       MessagingException An
+     *                  UnsupportedEncodingException may be included
+     *                  in the exception chain if the charset
+     *                  conversion fails.
+     */
+    public void setDescription(String description) throws MessagingException {
+        setDescription(description, null);
+    }
+
+    /**
+     * Set the "Content-Description" header field for this body part.
+     * If the description parameter is <code>null</code>, then any
+     * existing "Content-Description" fields are removed. <p>
+     *
+     * If the description contains non US-ASCII characters, it will
+     * be encoded using the specified charset. If the description
+     * contains only US-ASCII characters, no encoding  is done and
+     * it is used as is. <p>
+     *
+     * Note that if the charset encoding process fails, a
+     * MessagingException is thrown, and an UnsupportedEncodingException
+     * is included in the chain of nested exceptions within the
+     * MessagingException.
+     *
+     * @param   description     Description
+     * @param   charset         Charset for encoding
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     * @exception       MessagingException An
+     *                  UnsupportedEncodingException may be included
+     *                  in the exception chain if the charset
+     *                  conversion fails.
+     */
+    public void setDescription(String description, String charset)
+                throws MessagingException {
+        if (description == null) {
+            removeHeader("Content-Description");
+            return;
+        }
+
+        try {
+            setHeader("Content-Description", MimeUtility.fold(21,
+            MimeUtility.encodeText(description, charset, null)));
+        } catch (UnsupportedEncodingException uex) {
+            throw new MessagingException("Encoding error", uex);
+        }
+    }
+
+    /**
+     * Get the filename associated with this body part. <p>
+     *
+     * Returns the value of the "filename" parameter from the
+     * "Content-Disposition" header field of this body part. If its
+     * not available, returns the value of the "name" parameter from
+     * the "Content-Type" header field of this body part.
+     * Returns <code>null</code> if both are absent.
+     *
+     * @return  filename
+     */
+    public String getFileName() throws MessagingException {
+        String filename = null;
+        String s = getHeader("Content-Disposition", null);
+
+        if (s != null) {
+            // Parse the header ..
+            ContentDisposition cd = new ContentDisposition(s);
+            filename = cd.getParameter("filename");
+        }
+        if (filename == null) {
+            // Still no filename ? Try the "name" ContentType parameter
+            s = getHeader("Content-Type", null);
+            if (s != null) {
+            try {
+                ContentType ct = new ContentType(s);
+                filename = ct.getParameter("name");
+            } catch (ParseException pex) { }    // ignore it
+            }
+        }
+        return filename;
+    }
+
+    /**
+     * Set the filename associated with this body part, if possible. <p>
+     *
+     * Sets the "filename" parameter of the "Content-Disposition"
+     * header field of this body part.
+     *
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     */
+    public void setFileName(String filename) throws MessagingException {
+        // Set the Content-Disposition "filename" parameter
+        String s = getHeader("Content-Disposition", null);
+        ContentDisposition cd =
+            new ContentDisposition(s == null ? ATTACHMENT : s);
+        cd.setParameter("filename", filename);
+        setHeader("Content-Disposition", cd.toString());
+
+        /* Also attempt to set the Content-Type "name" parameter,
+         * to satisfy ancient MUAs.
+         * XXX: This is not RFC compliant, and hence should really
+         * be conditional based on some property. Fix this once we
+         * figure out how to get at Properties from here !
+         */
+        s = getHeader("Content-Type", null);
+        if (s != null) {
+            try {
+            ContentType cType = new ContentType(s);
+            cType.setParameter("name", filename);
+            setHeader("Content-Type", cType.toString());
+            } catch (ParseException pex) { }    // ignore it
+        }
+    }
+
+    /**
+     * Return a decoded input stream for this body part's "content". <p>
+     *
+     * This implementation obtains the input stream from the DataHandler.
+     * That is, it invokes getDataHandler().getInputStream();
+     *
+     * @return          an InputStream
+     * @exception       IOException this is typically thrown by the
+     *                  DataHandler. Refer to the documentation for
+     *                  javax.activation.DataHandler for more details.
+     *
+     * @see     #getContentStream
+     * @see     DataHandler#getInputStream
+     */
+    public InputStream getInputStream()
+                throws IOException {
+        return getDataHandler().getInputStream();
+    }
+
+   /**
+     * Produce the raw bytes of the content. This method is used
+     * when creating a DataHandler object for the content. Subclasses
+     * that can provide a separate input stream for just the MimeBodyPart
+     * content might want to override this method. <p>
+     *
+     * @see #content
+     */
+    /*package*/ InputStream getContentStream() throws MessagingException {
+        if (contentStream != null)
+            return ((SharedInputStream)contentStream).newStream(0, -1);
+        if (content != null)
+            return new ByteArrayInputStream(content,start,contentLength);
+
+        throw new MessagingException("No content");
+    }
+
+    /**
+     * Return an InputStream to the raw data with any Content-Transfer-Encoding
+     * intact.  This method is useful if the "Content-Transfer-Encoding"
+     * header is incorrect or corrupt, which would prevent the
+     * <code>getInputStream</code> method or <code>getContent</code> method
+     * from returning the correct data.  In such a case the application may
+     * use this method and attempt to decode the raw data itself. <p>
+     *
+     * This implementation simply calls the <code>getContentStream</code>
+     * method.
+     *
+     * @see     #getInputStream
+     * @see     #getContentStream
+     * @since   JavaMail 1.2
+     */
+    public InputStream getRawInputStream() throws MessagingException {
+        return getContentStream();
+    }
+
+    /**
+     * Return a DataHandler for this body part's content. <p>
+     *
+     * The implementation provided here works just like the
+     * the implementation in MimeMessage.
+     */
+    public DataHandler getDataHandler() {
+        if (dh == null)
+            dh = new DataHandler(new MimePartDataSource(this));
+        return dh;
+    }
+
+    /**
+     * Return the content as a java object. The type of the object
+     * returned is of course dependent on the content itself. For
+     * example, the native format of a text/plain content is usually
+     * a String object. The native format for a "multipart"
+     * content is always a MimeMultipart subclass. For content types that are
+     * unknown to the DataHandler system, an input stream is returned
+     * as the content. <p>
+     *
+     * This implementation obtains the content from the DataHandler.
+     * That is, it invokes getDataHandler().getContent();
+     *
+     * @return          Object
+     * @exception       IOException this is typically thrown by the
+     *                  DataHandler. Refer to the documentation for
+     *                  javax.activation.DataHandler for more details.
+     */
+    public Object getContent() throws IOException {
+        return getDataHandler().getContent();
+    }
+
+    /**
+     * This method provides the mechanism to set this body part's content.
+     * The given DataHandler object should wrap the actual content.
+     *
+     * @param   dh      The DataHandler for the content
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     */
+    public void setDataHandler(DataHandler dh) {
+        this.dh = dh;
+        this.content = null;
+        this.contentStream = null;
+        removeHeader("Content-Type");
+        removeHeader("Content-Transfer-Encoding");
+    }
+
+    /**
+     * A convenience method for setting this body part's content. <p>
+     *
+     * The content is wrapped in a DataHandler object. Note that a
+     * DataContentHandler class for the specified type should be
+     * available to the JavaMail implementation for this to work right.
+     * That is, to do <code>setContent(foobar, "application/x-foobar")</code>,
+     * a DataContentHandler for "application/x-foobar" should be installed.
+     * Refer to the Java Activation Framework for more information.
+     *
+     * @param   o       the content object
+     * @param   type    Mime type of the object
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     */
+    public void setContent(Object o, String type) {
+        if (o instanceof MimeMultipart) {
+            setContent((MimeMultipart)o);
+        } else {
+            setDataHandler(new DataHandler(o, type));
+        }
+    }
+
+    /**
+     * Convenience method that sets the given String as this
+     * part's content, with a MIME type of "text/plain". If the
+     * string contains non US-ASCII characters, it will be encoded
+     * using the platform's default charset. The charset is also
+     * used to set the "charset" parameter. <p>
+     *
+     * Note that there may be a performance penalty if
+     * <code>text</code> is large, since this method may have
+     * to scan all the characters to determine what charset to
+     * use. <p>
+     * If the charset is already known, use the
+     * setText() version that takes the charset parameter.
+     *
+     * @see     #setText(String text, String charset)
+     */
+    public void setText(String text) {
+        setText(text, null);
+    }
+
+    /**
+     * Convenience method that sets the given String as this part's
+     * content, with a MIME type of "text/plain" and the specified
+     * charset. The given Unicode string will be charset-encoded
+     * using the specified charset. The charset is also used to set
+     * the "charset" parameter.
+     */
+    public void setText(String text, String charset) {
+        if (charset == null) {
+            if (MimeUtility.checkAscii(text) != MimeUtility.ALL_ASCII)
+                charset = MimeUtility.getDefaultMIMECharset();
+            else
+                charset = "us-ascii";
+        }
+        setContent(text, "text/plain; charset=" +
+                MimeUtility.quote(charset, HeaderTokenizer.MIME));
+    }
+
+    /**
+     * This method sets the body part's content to a MimeMultipart object.
+     *
+     * @param  mp       The multipart object that is the Message's content
+     * @exception       IllegalStateException if this body part is
+     *                  obtained from a READ_ONLY folder.
+     */
+    public void setContent(MimeMultipart mp) {
+        setDataHandler(new DataHandler(mp, mp.getContentType().toString()));
+        mp.setParent(this);
+    }
+
+    /**
+     * Output the body part as an RFC 822 format stream.
+     *
+     * @exception MessagingException
+     * @exception IOException   if an error occurs writing to the
+     *                          stream or if an error is generated
+     *                          by the javax.activation layer.
+     * @see DataHandler#writeTo
+     */
+    public void writeTo(OutputStream os)
+                                throws IOException, MessagingException {
+
+        // First, write out the header
+        List hdrLines = headers.getAllHeaderLines();
+        int sz = hdrLines.size();
+        for( int i=0; i<sz; i++ )
+            OutputUtil.writeln((String)hdrLines.get(i),os);
+
+        // The CRLF separator between header and content
+        OutputUtil.writeln(os);
+
+        // Finally, the content.
+        // XXX: May need to account for ESMTP ?
+        if (contentStream != null) {
+            ((SharedInputStream)contentStream).writeTo(0,-1,os);
+        } else
+        if (content != null) {
+            os.write(content,start,contentLength);
+        } else
+        if (dh!=null) {
+            // this is the slowest route, so try it as the last resort
+            OutputStream wos = MimeUtility.encode(os, getEncoding());
+            getDataHandler().writeTo(wos);
+            if(os!=wos)
+                wos.flush(); // Needed to complete encoding
+        } else {
+            throw new MessagingException("no content");
+        }
+    }
+
+    /**
+     * Get all the headers for this header_name. Note that certain
+     * headers may be encoded as per RFC 2047 if they contain
+     * non US-ASCII characters and these should be decoded.
+     *
+     * @param   name    name of header
+     * @return  array of headers
+     * @see     MimeUtility
+     */
+    public String[] getHeader(String name) {
+        return headers.getHeader(name);
+    }
+
+    /**
+     * Get all the headers for this header name, returned as a single
+     * String, with headers separated by the delimiter. If the
+     * delimiter is <code>null</code>, only the first header is
+     * returned.
+     *
+     * @param name              the name of this header
+     * @param delimiter         delimiter between fields in returned string
+     * @return                  the value fields for all headers with
+     *                          this name
+     */
+    public String getHeader(String name, String delimiter) {
+        return headers.getHeader(name, delimiter);
+    }
+
+    /**
+     * Set the value for this header_name. Replaces all existing
+     * header values with this new value. Note that RFC 822 headers
+     * must contain only US-ASCII characters, so a header that
+     * contains non US-ASCII characters must be encoded as per the
+     * rules of RFC 2047.
+     *
+     * @param   name    header name
+     * @param   value   header value
+     * @see     MimeUtility
+     */
+    public void setHeader(String name, String value) {
+        headers.setHeader(name, value);
+    }
+
+    /**
+     * Add this value to the existing values for this header_name.
+     * Note that RFC 822 headers must contain only US-ASCII
+     * characters, so a header that contains non US-ASCII characters
+     * must be encoded as per the rules of RFC 2047.
+     *
+     * @param   name    header name
+     * @param   value   header value
+     * @see     MimeUtility
+     */
+    public void addHeader(String name, String value) {
+        headers.addHeader(name, value);
+    }
+
+    /**
+     * Remove all headers with this name.
+     */
+    public void removeHeader(String name) {
+        headers.removeHeader(name);
+    }
+
+    /**
+     * Return all the headers from this Message as an Enumeration of
+     * Header objects.
+     */
+    public FinalArrayList getAllHeaders() {
+        return headers.getAllHeaders();
+    }
+
+
+    /**
+     * Add a header line to this body part
+     */
+    public void addHeaderLine(String line) {
+        headers.addHeaderLine(line);
+    }
+
+    /**
+     * Examine the content of this body part and update the appropriate
+     * MIME headers.  Typical headers that get set here are
+     * <code>Content-Type</code> and <code>Content-Transfer-Encoding</code>.
+     * Headers might need to be updated in two cases:
+     *
+     * <br>
+     * - A message being crafted by a mail application will certainly
+     * need to activate this method at some point to fill up its internal
+     * headers.
+     *
+     * <br>
+     * - A message read in from a Store will have obtained
+     * all its headers from the store, and so doesn't need this.
+     * However, if this message is editable and if any edits have
+     * been made to either the content or message structure, we might
+     * need to resync our headers.
+     *
+     * <br>
+     * In both cases this method is typically called by the
+     * <code>Message.saveChanges</code> method.
+     */
+    protected void updateHeaders() throws MessagingException {
+        DataHandler dh = getDataHandler();
+        if (dh == null) // Huh ?
+            return;
+
+        try {
+            String type = dh.getContentType();
+            boolean composite = false;
+            boolean needCTHeader = getHeader("Content-Type") == null;
+
+            ContentType cType = new ContentType(type);
+            if (cType.match("multipart/*")) {
+                // If multipart, recurse
+                composite = true;
+                Object o = dh.getContent();
+                ((MimeMultipart) o).updateHeaders();
+            } else if (cType.match("message/rfc822")) {
+                composite = true;
+            }
+
+            // Content-Transfer-Encoding, but only if we don't
+            // already have one
+            if (!composite) {   // not allowed on composite parts
+                if (getHeader("Content-Transfer-Encoding") == null)
+                    setEncoding(MimeUtility.getEncoding(dh));
+
+                if (needCTHeader && setDefaultTextCharset &&
+                        cType.match("text/*") &&
+                        cType.getParameter("charset") == null) {
+                    /*
+                     * Set a default charset for text parts.
+                     * We really should examine the data to determine
+                     * whether or not it's all ASCII, but that's too
+                     * expensive so we make an assumption:  If we
+                     * chose 7bit encoding for this data, it's probably
+                     * ASCII.  (MimeUtility.getEncoding will choose
+                     * 7bit only in this case, but someone might've
+                     * set the Content-Transfer-Encoding header manually.)
+                     */
+                    String charset;
+                    String enc = getEncoding();
+                    if (enc != null && enc.equalsIgnoreCase("7bit"))
+                        charset = "us-ascii";
+                    else
+                        charset = MimeUtility.getDefaultMIMECharset();
+                    cType.setParameter("charset", charset);
+                    type = cType.toString();
+                }
+            }
+
+            // Now, let's update our own headers ...
+
+            // Content-type, but only if we don't already have one
+            if (needCTHeader) {
+                /*
+                 * Pull out "filename" from Content-Disposition, and
+                 * use that to set the "name" parameter. This is to
+                 * satisfy older MUAs (DtMail, Roam and probably
+                 * a bunch of others).
+                 */
+                String s = getHeader("Content-Disposition", null);
+                if (s != null) {
+                    // Parse the header ..
+                    ContentDisposition cd = new ContentDisposition(s);
+                    String filename = cd.getParameter("filename");
+                    if (filename != null) {
+                        cType.setParameter("name", filename);
+                        type = cType.toString();
+                    }
+                }
+
+                setHeader("Content-Type", type);
+            }
+        } catch (IOException ex) {
+            throw new MessagingException("IOException updating headers", ex);
+        }
+    }
+
+    private void setEncoding(String encoding) {
+            setHeader("Content-Transfer-Encoding", encoding);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeMultipart.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeMultipart.java
new file mode 100644
index 0000000..4394aed
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeMultipart.java
@@ -0,0 +1,628 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import java.io.*;
+
+import javax.activation.DataSource;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.*;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.util.*;
+import com.sun.xml.internal.messaging.saaj.util.FinalArrayList;
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+
+/**
+ * The MimeMultipart class is an implementation
+ * that uses MIME conventions for the multipart data. <p>
+ *
+ * A MimeMultipart is obtained from a MimeBodyPart whose primary type
+ * is "multipart" (by invoking the part's <code>getContent()</code> method)
+ * or it can be created by a client as part of creating a new MimeMessage. <p>
+ *
+ * The default multipart subtype is "mixed".  The other multipart
+ * subtypes, such as "alternative", "related", and so on, can be
+ * implemented as subclasses of MimeMultipart with additional methods
+ * to implement the additional semantics of that type of multipart
+ * content. The intent is that service providers, mail JavaBean writers
+ * and mail clients will write many such subclasses and their Command
+ * Beans, and will install them into the JavaBeans Activation
+ * Framework, so that any JavaMail implementation and its clients can
+ * transparently find and use these classes. Thus, a MIME multipart
+ * handler is treated just like any other type handler, thereby
+ * decoupling the process of providing multipart handlers from the
+ * JavaMail API. Lacking these additional MimeMultipart subclasses,
+ * all subtypes of MIME multipart data appear as MimeMultipart objects. <p>
+ *
+ * An application can directly construct a MIME multipart object of any
+ * subtype by using the <code>MimeMultipart(String subtype)</code>
+ * constructor.  For example, to create a "multipart/alternative" object,
+ * use <code>new MimeMultipart("alternative")</code>.
+ *
+ * @author  John Mani
+ * @author  Bill Shannon
+ * @author  Max Spivak
+ */
+
+//BM MimeMultipart can extend this
+public  class MimeMultipart {
+
+    /**
+     * The DataSource supplying our InputStream.
+     */
+    protected DataSource ds = null;
+
+    /**
+     * Have we parsed the data from our InputStream yet?
+     * Defaults to true; set to false when our constructor is
+     * given a DataSource with an InputStream that we need to
+     * parse.
+     */
+    protected boolean parsed = true;
+
+    /**
+     * Vector of MimeBodyPart objects.
+     */
+    protected FinalArrayList parts = new FinalArrayList(); // Holds BodyParts
+
+    /**
+     * This field specifies the content-type of this multipart
+     * object. It defaults to "multipart/mixed".
+     */
+    protected ContentType contentType;
+
+    /**
+     * The <code>MimeBodyPart</code> containing this <code>MimeMultipart</code>,
+     * if known.
+     * @since   JavaMail 1.1
+     */
+    protected MimeBodyPart parent;
+
+    /**
+     * Default constructor. An empty MimeMultipart object
+     * is created. Its content type is set to "multipart/mixed".
+     * A unique boundary string is generated and this string is
+     * setup as the "boundary" parameter for the
+     * <code>contentType</code> field. <p>
+     *
+     * MimeBodyParts may be added later.
+     */
+    public MimeMultipart() {
+        this("mixed");
+    }
+
+    /**
+     * Construct a MimeMultipart object of the given subtype.
+     * A unique boundary string is generated and this string is
+     * setup as the "boundary" parameter for the
+     * <code>contentType</code> field. <p>
+     *
+     * MimeBodyParts may be added later.
+     */
+    public MimeMultipart(String subtype) {
+        //super();
+        /*
+         * Compute a boundary string.
+         */
+        String boundary = UniqueValue.getUniqueBoundaryValue();
+        contentType = new ContentType("multipart", subtype, null);
+        contentType.setParameter("boundary", boundary);
+    }
+
+    /**
+     * Constructs a MimeMultipart object and its bodyparts from the
+     * given DataSource. <p>
+     *
+     * This constructor handles as a special case the situation where the
+     * given DataSource is a MultipartDataSource object.
+     *
+     * Otherwise, the DataSource is assumed to provide a MIME multipart
+     * byte stream.  The <code>parsed</code> flag is set to false.  When
+     * the data for the body parts are needed, the parser extracts the
+     * "boundary" parameter from the content type of this DataSource,
+     * skips the 'preamble' and reads bytes till the terminating
+     * boundary and creates MimeBodyParts for each part of the stream.
+     *
+     * @param   ds      DataSource, can be a MultipartDataSource
+     * @param ct
+     *      This must be the same information as {@link DataSource#getContentType()}.
+     *      All the callers of this method seem to have this object handy, so
+     *      for performance reason this method accepts it. Can be null.
+     */
+    public MimeMultipart(DataSource ds, ContentType ct) throws MessagingException {
+        // 'ds' was not a MultipartDataSource, we have
+        // to parse this ourself.
+        parsed = false;
+        this.ds = ds;
+        if (ct==null)
+            contentType = new ContentType(ds.getContentType());
+        else
+            contentType = ct;
+    }
+
+    /**
+     * Set the subtype. This method should be invoked only on a new
+     * MimeMultipart object created by the client. The default subtype
+     * of such a multipart object is "mixed". <p>
+     *
+     * @param   subtype         Subtype
+     */
+    public  void setSubType(String subtype) {
+        contentType.setSubType(subtype);
+    }
+
+    /**
+     * Return the number of enclosed MimeBodyPart objects.
+     *
+     * @return          number of parts
+     */
+    public  int getCount() throws MessagingException {
+        parse();
+        if (parts == null)
+            return 0;
+
+        return parts.size();
+    }
+
+    /**
+     * Get the specified MimeBodyPart.  BodyParts are numbered starting at 0.
+     *
+     * @param index     the index of the desired MimeBodyPart
+     * @return          the MimeBodyPart
+     * @exception       MessagingException if no such MimeBodyPart exists
+     */
+    public  MimeBodyPart getBodyPart(int index)
+                        throws MessagingException {
+        parse();
+        if (parts == null)
+            throw new IndexOutOfBoundsException("No such BodyPart");
+
+        return (MimeBodyPart)parts.get(index);
+    }
+
+    /**
+     * Get the MimeBodyPart referred to by the given ContentID (CID).
+     * Returns null if the part is not found.
+     *
+     * @param  CID      the ContentID of the desired part
+     * @return          the MimeBodyPart
+     */
+    public  MimeBodyPart getBodyPart(String CID)
+                        throws MessagingException {
+        parse();
+
+        int count = getCount();
+        for (int i = 0; i < count; i++) {
+           MimeBodyPart part = getBodyPart(i);
+           String s = part.getContentID();
+           if (s != null && s.equals(CID))
+                return part;
+        }
+        return null;
+    }
+
+    /**
+     * Update headers. The default implementation here just
+     * calls the <code>updateHeaders</code> method on each of its
+     * children BodyParts. <p>
+     *
+     * Note that the boundary parameter is already set up when
+     * a new and empty MimeMultipart object is created. <p>
+     *
+     * This method is called when the <code>saveChanges</code>
+     * method is invoked on the Message object containing this
+     * MimeMultipart. This is typically done as part of the Message
+     * send process, however note that a client is free to call
+     * it any number of times. So if the header updating process is
+     * expensive for a specific MimeMultipart subclass, then it
+     * might itself want to track whether its internal state actually
+     * did change, and do the header updating only if necessary.
+     */
+    protected void updateHeaders() throws MessagingException {
+        for (int i = 0; i < parts.size(); i++)
+            ((MimeBodyPart)parts.get(i)).updateHeaders();
+    }
+
+    /**
+     * Iterates through all the parts and outputs each Mime part
+     * separated by a boundary.
+     */
+    public void writeTo(OutputStream os)
+            throws IOException, MessagingException {
+        parse();
+
+        String boundary = "--" + contentType.getParameter("boundary");
+
+        for (int i = 0; i < parts.size(); i++) {
+            OutputUtil.writeln(boundary, os); // put out boundary
+            getBodyPart(i).writeTo(os);
+            OutputUtil.writeln(os); // put out empty line
+        }
+
+        // put out last boundary
+        OutputUtil.writeAsAscii(boundary, os);
+        OutputUtil.writeAsAscii("--", os);
+    }
+
+    /**
+     * Parse the InputStream from our DataSource, constructing the
+     * appropriate MimeBodyParts.  The <code>parsed</code> flag is
+     * set to true, and if true on entry nothing is done.  This
+     * method is called by all other methods that need data for
+     * the body parts, to make sure the data has been parsed.
+     *
+     * @since   JavaMail 1.2
+     */
+    protected  void parse() throws MessagingException {
+        if (parsed)
+            return;
+
+        InputStream in;
+        SharedInputStream sin = null;
+        long start = 0, end = 0;
+
+        try {
+            in = ds.getInputStream();
+            if (!(in instanceof ByteArrayInputStream) &&
+                !(in instanceof BufferedInputStream) &&
+                !(in instanceof SharedInputStream))
+                in = new BufferedInputStream(in);
+        } catch (Exception ex) {
+            throw new MessagingException("No inputstream from datasource");
+        }
+        if (in instanceof SharedInputStream)
+            sin = (SharedInputStream)in;
+
+        String boundary = "--" + contentType.getParameter("boundary");
+        byte[] bndbytes = ASCIIUtility.getBytes(boundary);
+        int bl = bndbytes.length;
+
+        try {
+            // Skip the preamble
+            LineInputStream lin = new LineInputStream(in);
+            String line;
+            while ((line = lin.readLine()) != null) {
+                /*
+                 * Strip trailing whitespace.  Can't use trim method
+                 * because it's too aggressive.  Some bogus MIME
+                 * messages will include control characters in the
+                 * boundary string.
+                 */
+                int i;
+                for (i = line.length() - 1; i >= 0; i--) {
+                    char c = line.charAt(i);
+                    if (!(c == ' ' || c == '\t'))
+                        break;
+                }
+                line = line.substring(0, i + 1);
+                if (line.equals(boundary))
+                    break;
+            }
+            if (line == null)
+                throw new MessagingException("Missing start boundary");
+
+            /*
+             * Read and process body parts until we see the
+             * terminating boundary line (or EOF).
+             */
+            boolean done = false;
+        getparts:
+            while (!done) {
+                InternetHeaders headers = null;
+                if (sin != null) {
+                    start = sin.getPosition();
+                    // skip headers
+                    while ((line = lin.readLine()) != null && line.length() > 0)
+                        ;
+                    if (line == null) {
+                        //throw new MessagingException("EOF skipping headers");
+                        // assume there's just a missing end boundary
+                        break getparts;
+                    }
+                } else {
+                    // collect the headers for this body part
+                    headers = createInternetHeaders(in);
+                }
+
+                if (!in.markSupported())
+                    throw new MessagingException("Stream doesn't support mark");
+
+                ByteOutputStream buf = null;
+                // if we don't have a shared input stream, we copy the data
+                if (sin == null)
+                    buf = new ByteOutputStream();
+                int b;
+                boolean bol = true;    // beginning of line flag
+                // the two possible end of line characters
+                int eol1 = -1, eol2 = -1;
+
+                /*
+                 * Read and save the content bytes in buf.
+                 */
+                for (;;) {
+                    if (bol) {
+                        /*
+                         * At the beginning of a line, check whether the
+                         * next line is a boundary.
+                         */
+                        int i;
+                        in.mark(bl + 4 + 1000); // bnd + "--\r\n" + lots of LWSP
+                        // read bytes, matching against the boundary
+                        for (i = 0; i < bl; i++)
+                            if (in.read() != bndbytes[i])
+                                break;
+                        if (i == bl) {
+                            // matched the boundary, check for last boundary
+                            int b2 = in.read();
+                            if (b2 == '-') {
+                                if (in.read() == '-') {
+                                    done = true;
+                                    break;      // ignore trailing text
+                                }
+                            }
+                            // skip linear whitespace
+                            while (b2 == ' ' || b2 == '\t')
+                                b2 = in.read();
+                            // check for end of line
+                            if (b2 == '\n')
+                                break;  // got it!  break out of the loop
+                            if (b2 == '\r') {
+                                in.mark(1);
+                                if (in.read() != '\n')
+                                    in.reset();
+                                break;  // got it!  break out of the loop
+                            }
+                        }
+                        // failed to match, reset and proceed normally
+                        in.reset();
+
+                        // if this is not the first line, write out the
+                        // end of line characters from the previous line
+                        if (buf != null && eol1 != -1) {
+                            buf.write(eol1);
+                            if (eol2 != -1)
+                                buf.write(eol2);
+                            eol1 = eol2 = -1;
+                        }
+                    }
+
+                    // read the next byte
+                    if ((b = in.read()) < 0) {
+                        done = true;
+                        break;
+                    }
+
+                    /*
+                     * If we're at the end of the line, save the eol characters
+                     * to be written out before the beginning of the next line.
+                     */
+                    if (b == '\r' || b == '\n') {
+                        bol = true;
+                        if (sin != null)
+                            end = sin.getPosition() - 1;
+                        eol1 = b;
+                        if (b == '\r') {
+                            in.mark(1);
+                            if ((b = in.read()) == '\n')
+                                eol2 = b;
+                            else
+                                in.reset();
+                        }
+                    } else {
+                        bol = false;
+                        if (buf != null)
+                            buf.write(b);
+                    }
+                }
+
+                /*
+                 * Create a MimeBody element to represent this body part.
+                 */
+                MimeBodyPart part;
+                if (sin != null)
+                    part = createMimeBodyPart(sin.newStream(start, end));
+                else
+                    part = createMimeBodyPart(headers, buf.getBytes(), buf.getCount());
+                addBodyPart(part);
+            }
+        } catch (IOException ioex) {
+            throw new MessagingException("IO Error", ioex);
+        }
+
+        parsed = true;
+    }
+
+    /**
+     * Create and return an InternetHeaders object that loads the
+     * headers from the given InputStream.  Subclasses can override
+     * this method to return a subclass of InternetHeaders, if
+     * necessary.  This implementation simply constructs and returns
+     * an InternetHeaders object.
+     *
+     * @param   is      the InputStream to read the headers from
+     * @exception       MessagingException
+     * @since           JavaMail 1.2
+     */
+    protected InternetHeaders createInternetHeaders(InputStream is)
+                                throws MessagingException {
+        return new InternetHeaders(is);
+    }
+
+    /**
+     * Create and return a MimeBodyPart object to represent a
+     * body part parsed from the InputStream.  Subclasses can override
+     * this method to return a subclass of MimeBodyPart, if
+     * necessary.  This implementation simply constructs and returns
+     * a MimeBodyPart object.
+     *
+     * @param   headers         the headers for the body part
+     * @param   content         the content of the body part
+     * @since                   JavaMail 1.2
+     */
+    protected MimeBodyPart createMimeBodyPart(InternetHeaders headers, byte[] content, int len) {
+            return new MimeBodyPart(headers, content,len);
+    }
+
+    /**
+     * Create and return a MimeBodyPart object to represent a
+     * body part parsed from the InputStream.  Subclasses can override
+     * this method to return a subclass of MimeBodyPart, if
+     * necessary.  This implementation simply constructs and returns
+     * a MimeBodyPart object.
+     *
+     * @param   is              InputStream containing the body part
+     * @exception               MessagingException
+     * @since                   JavaMail 1.2
+     */
+    protected MimeBodyPart createMimeBodyPart(InputStream is) throws MessagingException {
+            return new MimeBodyPart(is);
+    }
+
+    /**
+     * Setup this MimeMultipart object from the given MultipartDataSource. <p>
+     *
+     * The method adds the MultipartDataSource's MimeBodyPart
+     * objects into this MimeMultipart. This MimeMultipart's contentType is
+     * set to that of the MultipartDataSource. <p>
+     *
+     * This method is typically used in those cases where one
+     * has a multipart data source that has already been pre-parsed into
+     * the individual body parts (for example, an IMAP datasource), but
+     * needs to create an appropriate MimeMultipart subclass that represents
+     * a specific multipart subtype.
+     *
+     * @param   mp      MimeMultipart datasource
+     */
+
+    protected void setMultipartDataSource(MultipartDataSource mp)
+                        throws MessagingException {
+        contentType = new ContentType(mp.getContentType());
+
+        int count = mp.getCount();
+        for (int i = 0; i < count; i++)
+            addBodyPart(mp.getBodyPart(i));
+    }
+
+    /**
+     * Return the content-type of this MimeMultipart. <p>
+     *
+     * This implementation just returns the value of the
+     * <code>contentType</code> field.
+     *
+     * @return  content-type
+     * @see     #contentType
+     */
+    public ContentType getContentType() {
+            return contentType;
+    }
+
+    /**
+     * Remove the specified part from the multipart message.
+     * Shifts all the parts after the removed part down one.
+     *
+     * @param   part    The part to remove
+     * @return          true if part removed, false otherwise
+     * @exception       MessagingException if no such MimeBodyPart exists
+     */
+    public boolean removeBodyPart(MimeBodyPart part) throws MessagingException {
+        if (parts == null)
+            throw new MessagingException("No such body part");
+
+        boolean ret = parts.remove(part);
+        part.setParent(null);
+        return ret;
+    }
+
+    /**
+     * Remove the part at specified location (starting from 0).
+     * Shifts all the parts after the removed part down one.
+     *
+     * @param   index   Index of the part to remove
+     * @exception       IndexOutOfBoundsException if the given index
+     *                  is out of range.
+     */
+    public void removeBodyPart(int index) {
+        if (parts == null)
+            throw new IndexOutOfBoundsException("No such BodyPart");
+
+        MimeBodyPart part = (MimeBodyPart)parts.get(index);
+        parts.remove(index);
+        part.setParent(null);
+    }
+
+    /**
+     * Adds a MimeBodyPart to the multipart.  The MimeBodyPart is appended to
+     * the list of existing Parts.
+     *
+     * @param  part  The MimeBodyPart to be appended
+     */
+    public synchronized void addBodyPart(MimeBodyPart part) {
+        if (parts == null)
+            parts = new FinalArrayList();
+
+        parts.add(part);
+        part.setParent(this);
+    }
+
+    /**
+     * Adds a MimeBodyPart at position <code>index</code>.
+     * If <code>index</code> is not the last one in the list,
+     * the subsequent parts are shifted up. If <code>index</code>
+     * is larger than the number of parts present, the
+     * MimeBodyPart is appended to the end.
+     *
+     * @param  part  The MimeBodyPart to be inserted
+     * @param  index Location where to insert the part
+     */
+    public synchronized void addBodyPart(MimeBodyPart part, int index) {
+        if (parts == null)
+            parts = new FinalArrayList();
+
+        parts.add(index,part);
+        part.setParent(this);
+    }
+
+    /**
+     * Return the <code>MimeBodyPart</code> that contains this <code>MimeMultipart</code>
+     * object, or <code>null</code> if not known.
+     * @since   JavaMail 1.1
+     */
+    MimeBodyPart getParent() {
+        return parent;
+    }
+
+    /**
+     * Set the parent of this <code>MimeMultipart</code> to be the specified
+     * <code>MimeBodyPart</code>.  Normally called by the <code>Message</code>
+     * or <code>MimeBodyPart</code> <code>setContent(MimeMultipart)</code> method.
+     * <code>parent</code> may be <code>null</code> if the
+     * <code>MimeMultipart</code> is being removed from its containing
+     * <code>MimeBodyPart</code>.
+     * @since   JavaMail 1.1
+     */
+    void setParent(MimeBodyPart parent) {
+        this.parent = parent;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimePartDataSource.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimePartDataSource.java
new file mode 100644
index 0000000..e8d3298
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimePartDataSource.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import java.io.*;
+import java.net.UnknownServiceException;
+
+import javax.activation.DataSource;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.MessagingException;
+
+/**
+ * A utility class that implements a DataSource out of
+ * a MimeBodyPart. This class is primarily meant for service providers.
+ *
+ * @author      John Mani
+ */
+
+public final class MimePartDataSource implements DataSource {
+    private final MimeBodyPart part;
+
+    /**
+     * Constructor, that constructs a DataSource from a MimeBodyPart.
+     */
+    public MimePartDataSource(MimeBodyPart part) {
+        this.part = part;
+    }
+
+    /**
+     * Returns an input stream from this  MimeBodyPart. <p>
+     *
+     * This method applies the appropriate transfer-decoding, based
+     * on the Content-Transfer-Encoding attribute of this MimeBodyPart.
+     * Thus the returned input stream is a decoded stream of bytes.<p>
+     *
+     * This implementation obtains the raw content from the MimeBodyPart
+     * using the <code>getContentStream()</code> method and decodes
+     * it using the <code>MimeUtility.decode()</code> method.
+     *
+     * @return  decoded input stream
+     */
+    public InputStream getInputStream() throws IOException {
+
+        try {
+        InputStream is = part.getContentStream();
+
+            String encoding = part.getEncoding();
+            if (encoding != null)
+                return MimeUtility.decode(is, encoding);
+            else
+                return is;
+        } catch (MessagingException mex) {
+            throw new IOException(mex.getMessage());
+        }
+    }
+
+    /**
+     * DataSource method to return an output stream. <p>
+     *
+     * This implementation throws the UnknownServiceException.
+     */
+    public OutputStream getOutputStream() throws IOException {
+        throw new UnknownServiceException();
+    }
+
+    /**
+     * Returns the content-type of this DataSource. <p>
+     *
+     * This implementation just invokes the <code>getContentType</code>
+     * method on the MimeBodyPart.
+     */
+    public String getContentType() {
+        return part.getContentType();
+    }
+
+    /**
+     * DataSource method to return a name.  <p>
+     *
+     * This implementation just returns an empty string.
+     */
+    public String getName() {
+        try {
+                return part.getFileName();
+        } catch (MessagingException mex) {
+        return "";
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeUtility.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeUtility.java
new file mode 100644
index 0000000..95c8f19
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/MimeUtility.java
@@ -0,0 +1,1501 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import java.io.*;
+import java.util.*;
+
+import javax.activation.DataHandler;
+import javax.activation.DataSource;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.MessagingException;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.util.*;
+
+/**
+ * This is a utility class that provides various MIME related
+ * functionality. <p>
+ *
+ * There are a set of methods to encode and decode MIME headers as
+ * per RFC 2047. A brief description on handling such headers is
+ * given below: <p>
+ *
+ * RFC 822 mail headers <strong>must</strong> contain only US-ASCII
+ * characters. Headers that contain non US-ASCII characters must be
+ * encoded so that they contain only US-ASCII characters. Basically,
+ * this process involves using either BASE64 or QP to encode certain
+ * characters. RFC 2047 describes this in detail. <p>
+ *
+ * In Java, Strings contain (16 bit) Unicode characters. ASCII is a
+ * subset of Unicode (and occupies the range 0 - 127). A String
+ * that contains only ASCII characters is already mail-safe. If the
+ * String contains non US-ASCII characters, it must be encoded. An
+ * additional complexity in this step is that since Unicode is not
+ * yet a widely used charset, one might want to first charset-encode
+ * the String into another charset and then do the transfer-encoding.
+ * <p>
+ * Note that to get the actual bytes of a mail-safe String (say,
+ * for sending over SMTP), one must do
+ * <p><blockquote><pre>
+ *
+ *      byte[] bytes = string.getBytes("iso-8859-1");
+ *
+ * </pre></blockquote><p>
+ *
+ * The <code>setHeader</code> and <code>addHeader</code> methods
+ * on MimeMessage and MimeBodyPart assume that the given header values
+ * are Unicode strings that contain only US-ASCII characters. Hence
+ * the callers of those methods must insure that the values they pass
+ * do not contain non US-ASCII characters. The methods in this class
+ * help do this. <p>
+ *
+ * The <code>getHeader</code> family of methods on MimeMessage and
+ * MimeBodyPart return the raw header value. These might be encoded
+ * as per RFC 2047, and if so, must be decoded into Unicode Strings.
+ * The methods in this class help to do this. <p>
+ *
+ * Several System properties control strict conformance to the MIME
+ * spec.  Note that these are not session properties but must be set
+ * globally as System properties. <p>
+ *
+ * The <code>mail.mime.decodetext.strict</code> property controls
+ * decoding of MIME encoded words.  The MIME spec requires that encoded
+ * words start at the beginning of a whitespace separated word.  Some
+ * mailers incorrectly include encoded words in the middle of a word.
+ * If the <code>mail.mime.decodetext.strict</code> System property is
+ * set to <code>"false"</code>, an attempt will be made to decode these
+ * illegal encoded words. The default is true. <p>
+ *
+ * The <code>mail.mime.encodeeol.strict</code> property controls the
+ * choice of Content-Transfer-Encoding for MIME parts that are not of
+ * type "text".  Often such parts will contain textual data for which
+ * an encoding that allows normal end of line conventions is appropriate.
+ * In rare cases, such a part will appear to contain entirely textual
+ * data, but will require an encoding that preserves CR and LF characters
+ * without change.  If the <code>mail.mime.decodetext.strict</code>
+ * System property is set to <code>"true"</code>, such an encoding will
+ * be used when necessary.  The default is false. <p>
+ *
+ * In addition, the <code>mail.mime.charset</code> System property can
+ * be used to specify the default MIME charset to use for encoded words
+ * and text parts that don't otherwise specify a charset.  Normally, the
+ * default MIME charset is derived from the default Java charset, as
+ * specified in the <code>file.encoding</code> System property.  Most
+ * applications will have no need to explicitly set the default MIME
+ * charset.  In cases where the default MIME charset to be used for
+ * mail messages is different than the charset used for files stored on
+ * the system, this property should be set.
+ *
+ * @author  John Mani
+ * @author  Bill Shannon
+ */
+
+public class MimeUtility {
+
+    // This class cannot be instantiated
+    private MimeUtility() { }
+
+    public static final int ALL = -1;
+
+    private static final int BUFFER_SIZE = 1024;
+    private static boolean decodeStrict = true;
+    private static boolean encodeEolStrict = false;
+    private static boolean foldEncodedWords = false;
+    private static boolean foldText = true;
+
+    static {
+        try {
+            String s = System.getProperty("mail.mime.decodetext.strict");
+            // default to true
+            decodeStrict = s == null || !s.equalsIgnoreCase("false");
+            s = System.getProperty("mail.mime.encodeeol.strict");
+            // default to false
+            encodeEolStrict = s != null && s.equalsIgnoreCase("true");
+            s = System.getProperty("mail.mime.foldencodedwords");
+            // default to false
+            foldEncodedWords = s != null && s.equalsIgnoreCase("true");
+            s = System.getProperty("mail.mime.foldtext");
+            // default to true
+            foldText = s == null || !s.equalsIgnoreCase("false");
+        } catch (SecurityException sex) {
+            // ignore it
+        }
+    }
+
+
+    /**
+     * Get the content-transfer-encoding that should be applied
+     * to the input stream of this datasource, to make it mailsafe. <p>
+     *
+     * The algorithm used here is: <br>
+     * <ul>
+     * <li>
+     * If the primary type of this datasource is "text" and if all
+     * the bytes in its input stream are US-ASCII, then the encoding
+     * is "7bit". If more than half of the bytes are non-US-ASCII, then
+     * the encoding is "base64". If less than half of the bytes are
+     * non-US-ASCII, then the encoding is "quoted-printable".
+     * <li>
+     * If the primary type of this datasource is not "text", then if
+     * all the bytes of its input stream are US-ASCII, the encoding
+     * is "7bit". If there is even one non-US-ASCII character, the
+     * encoding is "base64".
+     * </ul>
+     *
+     * @param   ds      DataSource
+     * @return          the encoding. This is either "7bit",
+     *                  "quoted-printable" or "base64"
+     */
+    public static String getEncoding(DataSource ds) {
+        ContentType cType = null;
+        InputStream is = null;
+        String encoding = null;
+
+        try {
+            cType = new ContentType(ds.getContentType());
+            is = ds.getInputStream();
+        } catch (Exception ex) {
+            return "base64"; // what else ?!
+        }
+
+        boolean isText = cType.match("text/*");
+        // if not text, stop processing when we see non-ASCII
+        int i = checkAscii(is, ALL, !isText);
+        switch (i) {
+        case ALL_ASCII:
+            encoding = "7bit"; // all ascii
+            break;
+        case MOSTLY_ASCII:
+            encoding = "quoted-printable"; // mostly ascii
+            break;
+        default:
+            encoding = "base64"; // mostly binary
+            break;
+        }
+
+        // Close the input stream
+        try {
+            is.close();
+        } catch (IOException ioex) { }
+
+        return encoding;
+    }
+
+    /**
+     * Same as <code>getEncoding(DataSource)</code> except that instead
+     * of reading the data from an <code>InputStream</code> it uses the
+     * <code>writeTo</code> method to examine the data.  This is more
+     * efficient in the common case of a <code>DataHandler</code>
+     * created with an object and a MIME type (for example, a
+     * "text/plain" String) because all the I/O is done in this
+     * thread.  In the case requiring an <code>InputStream</code> the
+     * <code>DataHandler</code> uses a thread, a pair of pipe streams,
+     * and the <code>writeTo</code> method to produce the data. <p>
+     *
+     * @since   JavaMail 1.2
+     */
+    public static String getEncoding(DataHandler dh) {
+        ContentType cType = null;
+        String encoding = null;
+
+        /*
+         * Try to pick the most efficient means of determining the
+         * encoding.  If this DataHandler was created using a DataSource,
+         * the getEncoding(DataSource) method is typically faster.  If
+         * the DataHandler was created with an object, this method is
+         * much faster.  To distinguish the two cases, we use a heuristic.
+         * A DataHandler created with an object will always have a null name.
+         * A DataHandler created with a DataSource will usually have a
+         * non-null name.
+         *
+         * XXX - This is actually quite a disgusting hack, but it makes
+         *       a common case run over twice as fast.
+         */
+        if (dh.getName() != null)
+            return getEncoding(dh.getDataSource());
+
+        try {
+            cType = new ContentType(dh.getContentType());
+        } catch (Exception ex) {
+            return "base64"; // what else ?!
+        }
+
+        if (cType.match("text/*")) {
+            // Check all of the available bytes
+            AsciiOutputStream aos = new AsciiOutputStream(false, false);
+            try {
+                dh.writeTo(aos);
+            } catch (IOException ex) { }        // ignore it
+            switch (aos.getAscii()) {
+            case ALL_ASCII:
+                encoding = "7bit"; // all ascii
+                break;
+            case MOSTLY_ASCII:
+                encoding = "quoted-printable"; // mostly ascii
+                break;
+            default:
+                encoding = "base64"; // mostly binary
+                break;
+            }
+        } else { // not "text"
+            // Check all of available bytes, break out if we find
+            // at least one non-US-ASCII character
+            AsciiOutputStream aos =
+                        new AsciiOutputStream(true, encodeEolStrict);
+            try {
+                dh.writeTo(aos);
+            } catch (IOException ex) { }        // ignore it
+            if (aos.getAscii() == ALL_ASCII) // all ascii
+                encoding = "7bit";
+            else // found atleast one non-ascii character, use b64
+                encoding = "base64";
+        }
+
+        return encoding;
+    }
+
+    /**
+     * Decode the given input stream. The Input stream returned is
+     * the decoded input stream. All the encodings defined in RFC 2045
+     * are supported here. They include "base64", "quoted-printable",
+     * "7bit", "8bit", and "binary". In addition, "uuencode" is also
+     * supported.
+     *
+     * @param   is              input stream
+     * @param   encoding        the encoding of the stream.
+     * @return                  decoded input stream.
+     */
+    public static InputStream decode(InputStream is, String encoding)
+                throws MessagingException {
+        if (encoding.equalsIgnoreCase("base64"))
+            return new BASE64DecoderStream(is);
+        else if (encoding.equalsIgnoreCase("quoted-printable"))
+            return new QPDecoderStream(is);
+        else if (encoding.equalsIgnoreCase("uuencode") ||
+                 encoding.equalsIgnoreCase("x-uuencode") ||
+                 encoding.equalsIgnoreCase("x-uue"))
+            return new UUDecoderStream(is);
+        else if (encoding.equalsIgnoreCase("binary") ||
+                 encoding.equalsIgnoreCase("7bit") ||
+                 encoding.equalsIgnoreCase("8bit"))
+            return is;
+        else
+            throw new MessagingException("Unknown encoding: " + encoding);
+    }
+
+    /**
+     * Wrap an encoder around the given output stream.
+     * All the encodings defined in RFC 2045 are supported here.
+     * They include "base64", "quoted-printable", "7bit", "8bit" and
+     * "binary". In addition, "uuencode" is also supported.
+     *
+     * @param   os              output stream
+     * @param   encoding        the encoding of the stream.
+     * @return                  output stream that applies the
+     *                          specified encoding.
+     */
+    public static OutputStream encode(OutputStream os, String encoding)
+                throws MessagingException {
+        if (encoding == null)
+            return os;
+        else if (encoding.equalsIgnoreCase("base64"))
+            return new BASE64EncoderStream(os);
+        else if (encoding.equalsIgnoreCase("quoted-printable"))
+            return new QPEncoderStream(os);
+        else if (encoding.equalsIgnoreCase("uuencode") ||
+                 encoding.equalsIgnoreCase("x-uuencode") ||
+                 encoding.equalsIgnoreCase("x-uue"))
+            return new UUEncoderStream(os);
+        else if (encoding.equalsIgnoreCase("binary") ||
+                 encoding.equalsIgnoreCase("7bit") ||
+                 encoding.equalsIgnoreCase("8bit"))
+            return os;
+        else
+            throw new MessagingException("Unknown encoding: " +encoding);
+    }
+
+    /**
+     * Wrap an encoder around the given output stream.
+     * All the encodings defined in RFC 2045 are supported here.
+     * They include "base64", "quoted-printable", "7bit", "8bit" and
+     * "binary". In addition, "uuencode" is also supported.
+     * The <code>filename</code> parameter is used with the "uuencode"
+     * encoding and is included in the encoded output.
+     *
+     * @param   os              output stream
+     * @param   encoding        the encoding of the stream.
+     * @param   filename        name for the file being encoded (only used
+     *                          with uuencode)
+     * @return                  output stream that applies the
+     *                          specified encoding.
+     * @since                   JavaMail 1.2
+     */
+    public static OutputStream encode(OutputStream os, String encoding,
+                                      String filename)
+                throws MessagingException {
+        if (encoding == null)
+            return os;
+        else if (encoding.equalsIgnoreCase("base64"))
+            return new BASE64EncoderStream(os);
+        else if (encoding.equalsIgnoreCase("quoted-printable"))
+            return new QPEncoderStream(os);
+        else if (encoding.equalsIgnoreCase("uuencode") ||
+                 encoding.equalsIgnoreCase("x-uuencode") ||
+                 encoding.equalsIgnoreCase("x-uue"))
+            return new UUEncoderStream(os, filename);
+        else if (encoding.equalsIgnoreCase("binary") ||
+                 encoding.equalsIgnoreCase("7bit") ||
+                 encoding.equalsIgnoreCase("8bit"))
+            return os;
+        else
+            throw new MessagingException("Unknown encoding: " +encoding);
+    }
+
+    /**
+     * Encode a RFC 822 "text" token into mail-safe form as per
+     * RFC 2047. <p>
+     *
+     * The given Unicode string is examined for non US-ASCII
+     * characters. If the string contains only US-ASCII characters,
+     * it is returned as-is.  If the string contains non US-ASCII
+     * characters, it is first character-encoded using the platform's
+     * default charset, then transfer-encoded using either the B or
+     * Q encoding. The resulting bytes are then returned as a Unicode
+     * string containing only ASCII  characters. <p>
+     *
+     * Note that this method should be used to encode only
+     * "unstructured" RFC 822 headers. <p>
+     *
+     * Example of usage:
+     * <p><blockquote><pre>
+     *
+     *  MimeBodyPart part = ...
+     *  String rawvalue = "FooBar Mailer, Japanese version 1.1"
+     *  try {
+     *    // If we know for sure that rawvalue contains only US-ASCII
+     *    // characters, we can skip the encoding part
+     *    part.setHeader("X-mailer", MimeUtility.encodeText(rawvalue));
+     *  } catch (UnsupportedEncodingException e) {
+     *    // encoding failure
+     *  } catch (MessagingException me) {
+     *   // setHeader() failure
+     *  }
+     *
+     * </pre></blockquote><p>
+     *
+     * @param   text    unicode string
+     * @return  Unicode string containing only US-ASCII characters
+     * @exception UnsupportedEncodingException if the encoding fails
+     */
+    public static String encodeText(String text)
+                        throws UnsupportedEncodingException {
+        return encodeText(text, null, null);
+    }
+
+    /**
+     * Encode a RFC 822 "text" token into mail-safe form as per
+     * RFC 2047. <p>
+     *
+     * The given Unicode string is examined for non US-ASCII
+     * characters. If the string contains only US-ASCII characters,
+     * it is returned as-is.  If the string contains non US-ASCII
+     * characters, it is first character-encoded using the specified
+     * charset, then transfer-encoded using either the B or Q encoding.
+     * The resulting bytes are then returned as a Unicode string
+     * containing only ASCII characters. <p>
+     *
+     * Note that this method should be used to encode only
+     * "unstructured" RFC 822 headers.
+     *
+     * @param   text    the header value
+     * @param   charset the charset. If this parameter is null, the
+     *          platform's default chatset is used.
+     * @param   encoding the encoding to be used. Currently supported
+     *          values are "B" and "Q". If this parameter is null, then
+     *          the "Q" encoding is used if most of characters to be
+     *          encoded are in the ASCII charset, otherwise "B" encoding
+     *          is used.
+     * @return  Unicode string containing only US-ASCII characters
+     */
+    public static String encodeText(String text, String charset,
+                                    String encoding)
+                        throws UnsupportedEncodingException {
+        return encodeWord(text, charset, encoding, false);
+    }
+
+    /**
+     * Decode "unstructured" headers, that is, headers that are defined
+     * as '*text' as per RFC 822. <p>
+     *
+     * The string is decoded using the algorithm specified in
+     * RFC 2047, Section 6.1.1. If the charset-conversion fails
+     * for any sequence, an UnsupportedEncodingException is thrown.
+     * If the String is not an RFC 2047 style encoded header, it is
+     * returned as-is <p>
+     *
+     * Example of usage:
+     * <p><blockquote><pre>
+     *
+     *  MimeBodyPart part = ...
+     *  String rawvalue = null;
+     *  String  value = null;
+     *  try {
+     *    if ((rawvalue = part.getHeader("X-mailer")[0]) != null)
+     *      value = MimeUtility.decodeText(rawvalue);
+     *  } catch (UnsupportedEncodingException e) {
+     *      // Don't care
+     *      value = rawvalue;
+     *  } catch (MessagingException me) { }
+     *
+     *  return value;
+     *
+     * </pre></blockquote><p>
+     *
+     * @param   etext   the possibly encoded value
+     * @exception       UnsupportedEncodingException if the charset
+     *                  conversion failed.
+     */
+    public static String decodeText(String etext)
+                throws UnsupportedEncodingException {
+        /*
+         * We look for sequences separated by "linear-white-space".
+         * (as per RFC 2047, Section 6.1.1)
+         * RFC 822 defines "linear-white-space" as SPACE | HT | CR | NL.
+         */
+        String lwsp = " \t\n\r";
+        StringTokenizer st;
+
+        /*
+         * First, lets do a quick run thru the string and check
+         * whether the sequence "=?"  exists at all. If none exists,
+         * we know there are no encoded-words in here and we can just
+         * return the string as-is, without suffering thru the later
+         * decoding logic.
+         * This handles the most common case of unencoded headers
+         * efficiently.
+         */
+        if (etext.indexOf("=?") == -1)
+            return etext;
+
+        // Encoded words found. Start decoding ...
+
+        st = new StringTokenizer(etext, lwsp, true);
+        StringBuffer sb = new StringBuffer();  // decode buffer
+        StringBuffer wsb = new StringBuffer(); // white space buffer
+        boolean prevWasEncoded = false;
+
+        while (st.hasMoreTokens()) {
+            char c;
+            String s = st.nextToken();
+            // If whitespace, append it to the whitespace buffer
+            if (((c = s.charAt(0)) == ' ') || (c == '\t') ||
+                (c == '\r') || (c == '\n'))
+                wsb.append(c);
+            else {
+                // Check if token is an 'encoded-word' ..
+                String word;
+                try {
+                    word = decodeWord(s);
+                    // Yes, this IS an 'encoded-word'.
+                    if (!prevWasEncoded && wsb.length() > 0) {
+                        // if the previous word was also encoded, we
+                        // should ignore the collected whitespace. Else
+                        // we include the whitespace as well.
+                        sb.append(wsb);
+                    }
+                    prevWasEncoded = true;
+                } catch (ParseException pex) {
+                    // This is NOT an 'encoded-word'.
+                    word = s;
+                    // possibly decode inner encoded words
+                    if (!decodeStrict)
+                        word = decodeInnerWords(word);
+                    // include colleced whitespace ..
+                    if (wsb.length() > 0)
+                        sb.append(wsb);
+                    prevWasEncoded = false;
+                }
+                sb.append(word); // append the actual word
+                wsb.setLength(0); // reset wsb for reuse
+            }
+        }
+        return sb.toString();
+    }
+
+    /**
+     * Encode a RFC 822 "word" token into mail-safe form as per
+     * RFC 2047. <p>
+     *
+     * The given Unicode string is examined for non US-ASCII
+     * characters. If the string contains only US-ASCII characters,
+     * it is returned as-is.  If the string contains non US-ASCII
+     * characters, it is first character-encoded using the platform's
+     * default charset, then transfer-encoded using either the B or
+     * Q encoding. The resulting bytes are then returned as a Unicode
+     * string containing only ASCII  characters. <p>
+     *
+     * This method is meant to be used when creating RFC 822 "phrases".
+     * The InternetAddress class, for example, uses this to encode
+     * it's 'phrase' component.
+     *
+     * @param   text    unicode string
+     * @return  Array of Unicode strings containing only US-ASCII
+     *          characters.
+     * @exception UnsupportedEncodingException if the encoding fails
+     */
+    public static String encodeWord(String word)
+                        throws UnsupportedEncodingException {
+        return encodeWord(word, null, null);
+    }
+
+    /**
+     * Encode a RFC 822 "word" token into mail-safe form as per
+     * RFC 2047. <p>
+     *
+     * The given Unicode string is examined for non US-ASCII
+     * characters. If the string contains only US-ASCII characters,
+     * it is returned as-is.  If the string contains non US-ASCII
+     * characters, it is first character-encoded using the specified
+     * charset, then transfer-encoded using either the B or Q encoding.
+     * The resulting bytes are then returned as a Unicode string
+     * containing only ASCII characters. <p>
+     *
+     * @param   text    unicode string
+     * @param   charset the MIME charset
+     * @param   encoding the encoding to be used. Currently supported
+     *          values are "B" and "Q". If this parameter is null, then
+     *          the "Q" encoding is used if most of characters to be
+     *          encoded are in the ASCII charset, otherwise "B" encoding
+     *          is used.
+     * @return  Unicode string containing only US-ASCII characters
+     * @exception UnsupportedEncodingException if the encoding fails
+     */
+    public static String encodeWord(String word, String charset,
+                                    String encoding)
+                        throws UnsupportedEncodingException {
+        return encodeWord(word, charset, encoding, true);
+    }
+
+    /*
+     * Encode the given string. The parameter 'encodingWord' should
+     * be true if a RFC 822 "word" token is being encoded and false if a
+     * RFC 822 "text" token is being encoded. This is because the
+     * "Q" encoding defined in RFC 2047 has more restrictions when
+     * encoding "word" tokens. (Sigh)
+     */
+    private static String encodeWord(String string, String charset,
+                                     String encoding, boolean encodingWord)
+                        throws UnsupportedEncodingException {
+
+        // If 'string' contains only US-ASCII characters, just
+        // return it.
+        int ascii = checkAscii(string);
+        if (ascii == ALL_ASCII)
+            return string;
+
+        // Else, apply the specified charset conversion.
+        String jcharset;
+        if (charset == null) { // use default charset
+            jcharset = getDefaultJavaCharset(); // the java charset
+            charset = getDefaultMIMECharset(); // the MIME equivalent
+        } else // MIME charset -> java charset
+            jcharset = javaCharset(charset);
+
+        // If no transfer-encoding is specified, figure one out.
+        if (encoding == null) {
+            if (ascii != MOSTLY_NONASCII)
+                encoding = "Q";
+            else
+                encoding = "B";
+        }
+
+        boolean b64;
+        if (encoding.equalsIgnoreCase("B"))
+            b64 = true;
+        else if (encoding.equalsIgnoreCase("Q"))
+            b64 = false;
+        else
+            throw new UnsupportedEncodingException(
+                        "Unknown transfer encoding: " + encoding);
+
+        StringBuffer outb = new StringBuffer(); // the output buffer
+        doEncode(string, b64, jcharset,
+                 // As per RFC 2047, size of an encoded string should not
+                 // exceed 75 bytes.
+                 // 7 = size of "=?", '?', 'B'/'Q', '?', "?="
+                 75 - 7 - charset.length(), // the available space
+                 "=?" + charset + "?" + encoding + "?", // prefix
+                 true, encodingWord, outb);
+
+        return outb.toString();
+    }
+
+    private static void doEncode(String string, boolean b64,
+                String jcharset, int avail, String prefix,
+                boolean first, boolean encodingWord, StringBuffer buf)
+                        throws UnsupportedEncodingException {
+
+        // First find out what the length of the encoded version of
+        // 'string' would be.
+        byte[] bytes = string.getBytes(jcharset);
+        int len;
+        if (b64) // "B" encoding
+            len = BEncoderStream.encodedLength(bytes);
+        else // "Q"
+            len = QEncoderStream.encodedLength(bytes, encodingWord);
+
+        int size;
+        if ((len > avail) && ((size = string.length()) > 1)) {
+            // If the length is greater than 'avail', split 'string'
+            // into two and recurse.
+            doEncode(string.substring(0, size/2), b64, jcharset,
+                     avail, prefix, first, encodingWord, buf);
+            doEncode(string.substring(size/2, size), b64, jcharset,
+                     avail, prefix, false, encodingWord, buf);
+        } else {
+            // length <= than 'avail'. Encode the given string
+            ByteArrayOutputStream os = new ByteArrayOutputStream(BUFFER_SIZE);
+            OutputStream eos; // the encoder
+            if (b64) // "B" encoding
+                eos = new BEncoderStream(os);
+            else // "Q" encoding
+                eos = new QEncoderStream(os, encodingWord);
+
+            try { // do the encoding
+                eos.write(bytes);
+                eos.close();
+            } catch (IOException ioex) { }
+
+            byte[] encodedBytes = os.toByteArray(); // the encoded stuff
+            // Now write out the encoded (all ASCII) bytes into our
+            // StringBuffer
+            if (!first) // not the first line of this sequence
+                if (foldEncodedWords)
+                    buf.append("\r\n "); // start a continuation line
+                else
+                    buf.append(" "); // line will be folded later
+
+            buf.append(prefix);
+            for (int i = 0; i < encodedBytes.length; i++)
+                buf.append((char)encodedBytes[i]);
+            buf.append("?="); // terminate the current sequence
+        }
+    }
+
+    /**
+     * The string is parsed using the rules in RFC 2047 for parsing
+     * an "encoded-word". If the parse fails, a ParseException is
+     * thrown. Otherwise, it is transfer-decoded, and then
+     * charset-converted into Unicode. If the charset-conversion
+     * fails, an UnsupportedEncodingException is thrown.<p>
+     *
+     * @param   eword   the possibly encoded value
+     * @exception       ParseException if the string is not an
+     *                  encoded-word as per RFC 2047.
+     * @exception       UnsupportedEncodingException if the charset
+     *                  conversion failed.
+     */
+    public static String decodeWord(String eword)
+                throws ParseException, UnsupportedEncodingException {
+
+        if (!eword.startsWith("=?")) // not an encoded word
+            throw new ParseException();
+
+        // get charset
+        int start = 2; int pos;
+        if ((pos = eword.indexOf('?', start)) == -1)
+            throw new ParseException();
+        String charset = javaCharset(eword.substring(start, pos));
+
+        // get encoding
+        start = pos+1;
+        if ((pos = eword.indexOf('?', start)) == -1)
+            throw new ParseException();
+        String encoding = eword.substring(start, pos);
+
+        // get encoded-sequence
+        start = pos+1;
+        if ((pos = eword.indexOf("?=", start)) == -1)
+            throw new ParseException();
+        String word = eword.substring(start, pos);
+
+        try {
+            // Extract the bytes from word
+            ByteArrayInputStream bis =
+                new ByteArrayInputStream(ASCIIUtility.getBytes(word));
+
+            // Get the appropriate decoder
+            InputStream is;
+            if (encoding.equalsIgnoreCase("B"))
+                is = new BASE64DecoderStream(bis);
+            else if (encoding.equalsIgnoreCase("Q"))
+                is = new QDecoderStream(bis);
+            else
+                throw new UnsupportedEncodingException(
+                                "unknown encoding: " + encoding);
+
+            // For b64 & q, size of decoded word <= size of word. So
+            // the decoded bytes must fit into the 'bytes' array. This
+            // is certainly more efficient than writing bytes into a
+            // ByteArrayOutputStream and then pulling out the byte[]
+            // from it.
+            int count = bis.available();
+            byte[] bytes = new byte[count];
+            // count is set to the actual number of decoded bytes
+            count = is.read(bytes, 0, count);
+
+            // Finally, convert the decoded bytes into a String using
+            // the specified charset
+            String s = new String(bytes, 0, count, charset);
+            if (pos + 2 < eword.length()) {
+                // there's still more text in the string
+                String rest = eword.substring(pos + 2);
+                if (!decodeStrict)
+                    rest = decodeInnerWords(rest);
+                s += rest;
+            }
+            return s;
+        } catch (UnsupportedEncodingException uex) {
+            // explicitly catch and rethrow this exception, otherwise
+            // the below IOException catch will swallow this up!
+            throw uex;
+        } catch (IOException ioex) {
+            // Shouldn't happen.
+            throw new ParseException();
+        } catch (IllegalArgumentException iex) {
+            /* An unknown charset of the form ISO-XXX-XXX, will cause
+             * the JDK to throw an IllegalArgumentException ... Since the
+             * JDK will attempt to create a classname using this string,
+             * but valid classnames must not contain the character '-',
+             * and this results in an IllegalArgumentException, rather than
+             * the expected UnsupportedEncodingException. Yikes
+             */
+            throw new UnsupportedEncodingException();
+        }
+    }
+
+    /**
+     * Look for encoded words within a word.  The MIME spec doesn't
+     * allow this, but many broken mailers, especially Japanese mailers,
+     * produce such incorrect encodings.
+     */
+    private static String decodeInnerWords(String word)
+                                throws UnsupportedEncodingException {
+        int start = 0, i;
+        StringBuffer buf = new StringBuffer();
+        while ((i = word.indexOf("=?", start)) >= 0) {
+            buf.append(word.substring(start, i));
+            int end = word.indexOf("?=", i);
+            if (end < 0)
+                break;
+            String s = word.substring(i, end + 2);
+            try {
+                s = decodeWord(s);
+            } catch (ParseException pex) {
+                // ignore it, just use the original string
+            }
+            buf.append(s);
+            start = end + 2;
+        }
+        if (start == 0)
+            return word;
+        if (start < word.length())
+            buf.append(word.substring(start));
+        return buf.toString();
+    }
+
+    /**
+     * A utility method to quote a word, if the word contains any
+     * characters from the specified 'specials' list.<p>
+     *
+     * The <code>HeaderTokenizer</code> class defines two special
+     * sets of delimiters - MIME and RFC 822. <p>
+     *
+     * This method is typically used during the generation of
+     * RFC 822 and MIME header fields.
+     *
+     * @param   word    word to be quoted
+     * @param   specials the set of special characters
+     * @return          the possibly quoted word
+     * @see     javax.mail.internet.HeaderTokenizer#MIME
+     * @see     javax.mail.internet.HeaderTokenizer#RFC822
+     */
+    public static String quote(String word, String specials) {
+        int len = word.length();
+
+        /*
+         * Look for any "bad" characters, Escape and
+         *  quote the entire string if necessary.
+         */
+        boolean needQuoting = false;
+        for (int i = 0; i < len; i++) {
+            char c = word.charAt(i);
+            if (c == '"' || c == '\\' || c == '\r' || c == '\n') {
+                // need to escape them and then quote the whole string
+                StringBuffer sb = new StringBuffer(len + 3);
+                sb.append('"');
+                sb.append(word.substring(0, i));
+                int lastc = 0;
+                for (int j = i; j < len; j++) {
+                    char cc = word.charAt(j);
+                    if ((cc == '"') || (cc == '\\') ||
+                        (cc == '\r') || (cc == '\n'))
+                        if (cc == '\n' && lastc == '\r')
+                            ;   // do nothing, CR was already escaped
+                        else
+                            sb.append('\\');    // Escape the character
+                    sb.append(cc);
+                    lastc = cc;
+                }
+                sb.append('"');
+                return sb.toString();
+            } else if (c < 040 || c >= 0177 || specials.indexOf(c) >= 0)
+                // These characters cause the string to be quoted
+                needQuoting = true;
+        }
+
+        if (needQuoting) {
+            StringBuffer sb = new StringBuffer(len + 2);
+            sb.append('"').append(word).append('"');
+            return sb.toString();
+        } else
+            return word;
+    }
+
+    /**
+     * Fold a string at linear whitespace so that each line is no longer
+     * than 76 characters, if possible.  If there are more than 76
+     * non-whitespace characters consecutively, the string is folded at
+     * the first whitespace after that sequence.  The parameter
+     * <code>used</code> indicates how many characters have been used in
+     * the current line; it is usually the length of the header name. <p>
+     *
+     * Note that line breaks in the string aren't escaped; they probably
+     * should be.
+     *
+     * @param   used    characters used in line so far
+     * @param   s       the string to fold
+     * @return          the folded string
+     */
+    /*public*/ static String fold(int used, String s) {
+        if (!foldText)
+            return s;
+
+        int end;
+        char c;
+        // Strip trailing spaces
+        for (end = s.length() - 1; end >= 0; end--) {
+            c = s.charAt(end);
+            if (c != ' ' && c != '\t')
+                break;
+        }
+        if (end != s.length() - 1)
+            s = s.substring(0, end + 1);
+
+        // if the string fits now, just return it
+        if (used + s.length() <= 76)
+            return s;
+
+        // have to actually fold the string
+        StringBuffer sb = new StringBuffer(s.length() + 4);
+        char lastc = 0;
+        while (used + s.length() > 76) {
+            int lastspace = -1;
+            for (int i = 0; i < s.length(); i++) {
+                if (lastspace != -1 && used + i > 76)
+                    break;
+                c = s.charAt(i);
+                if (c == ' ' || c == '\t')
+                    if (!(lastc == ' ' || lastc == '\t'))
+                        lastspace = i;
+                lastc = c;
+            }
+            if (lastspace == -1) {
+                // no space, use the whole thing
+                sb.append(s);
+                s = "";
+                used = 0;
+                break;
+            }
+            sb.append(s.substring(0, lastspace));
+            sb.append("\r\n");
+            lastc = s.charAt(lastspace);
+            sb.append(lastc);
+            s = s.substring(lastspace + 1);
+            used = 1;
+        }
+        sb.append(s);
+        return sb.toString();
+    }
+
+    /**
+     * Unfold a folded header.  Any line breaks that aren't escaped and
+     * are followed by whitespace are removed.
+     *
+     * @param   s       the string to unfold
+     * @return          the unfolded string
+     */
+    /*public*/ static String unfold(String s) {
+        if (!foldText)
+            return s;
+
+        StringBuffer sb = null;
+        int i;
+        while ((i = indexOfAny(s, "\r\n")) >= 0) {
+            int start = i;
+            int l = s.length();
+            i++;                // skip CR or NL
+            if (i < l && s.charAt(i - 1) == '\r' && s.charAt(i) == '\n')
+                i++;    // skip LF
+            if (start == 0 || s.charAt(start - 1) != '\\') {
+                char c;
+                // if next line starts with whitespace, skip all of it
+                // XXX - always has to be true?
+                if (i < l && ((c = s.charAt(i)) == ' ' || c == '\t')) {
+                    i++;        // skip whitespace
+                    while (i < l && ((c = s.charAt(i)) == ' ' || c == '\t'))
+                        i++;
+                    if (sb == null)
+                        sb = new StringBuffer(s.length());
+                    if (start != 0) {
+                        sb.append(s.substring(0, start));
+                        sb.append(' ');
+                    }
+                    s = s.substring(i);
+                    continue;
+                }
+                // it's not a continuation line, just leave it in
+                if (sb == null)
+                    sb = new StringBuffer(s.length());
+                sb.append(s.substring(0, i));
+                s = s.substring(i);
+            } else {
+                // there's a backslash at "start - 1"
+                // strip it out, but leave in the line break
+                if (sb == null)
+                    sb = new StringBuffer(s.length());
+                sb.append(s.substring(0, start - 1));
+                sb.append(s.substring(start, i));
+                s = s.substring(i);
+            }
+        }
+        if (sb != null) {
+            sb.append(s);
+            return sb.toString();
+        } else
+            return s;
+    }
+
+    /**
+     * Return the first index of any of the characters in "any" in "s",
+     * or -1 if none are found.
+     *
+     * This should be a method on String.
+     */
+    private static int indexOfAny(String s, String any) {
+        return indexOfAny(s, any, 0);
+    }
+
+    private static int indexOfAny(String s, String any, int start) {
+        try {
+            int len = s.length();
+            for (int i = start; i < len; i++) {
+                if (any.indexOf(s.charAt(i)) >= 0)
+                    return i;
+            }
+            return -1;
+        } catch (StringIndexOutOfBoundsException e) {
+            return -1;
+        }
+    }
+
+    /**
+     * Convert a MIME charset name into a valid Java charset name. <p>
+     *
+     * @param charset   the MIME charset name
+     * @return  the Java charset equivalent. If a suitable mapping is
+     *          not available, the passed in charset is itself returned.
+     */
+    public static String javaCharset(String charset) {
+        if (mime2java == null || charset == null)
+            // no mapping table, or charset parameter is null
+            return charset;
+
+        String alias = (String)mime2java.get(charset.toLowerCase());
+        return alias == null ? charset : alias;
+    }
+
+    /**
+     * Convert a java charset into its MIME charset name. <p>
+     *
+     * Note that a future version of JDK (post 1.2) might provide
+     * this functionality, in which case, we may deprecate this
+     * method then.
+     *
+     * @param   charset    the JDK charset
+     * @return          the MIME/IANA equivalent. If a mapping
+     *                  is not possible, the passed in charset itself
+     *                  is returned.
+     * @since           JavaMail 1.1
+     */
+    public static String mimeCharset(String charset) {
+        if (java2mime == null || charset == null)
+            // no mapping table or charset param is null
+            return charset;
+
+        String alias = (String)java2mime.get(charset.toLowerCase());
+        return alias == null ? charset : alias;
+    }
+
+    private static String defaultJavaCharset;
+    private static String defaultMIMECharset;
+
+    /**
+     * Get the default charset corresponding to the system's current
+     * default locale.  If the System property <code>mail.mime.charset</code>
+     * is set, a system charset corresponding to this MIME charset will be
+     * returned. <p>
+     *
+     * @return  the default charset of the system's default locale,
+     *          as a Java charset. (NOT a MIME charset)
+     * @since   JavaMail 1.1
+     */
+    public static String getDefaultJavaCharset() {
+        if (defaultJavaCharset == null) {
+            /*
+             * If mail.mime.charset is set, it controls the default
+             * Java charset as well.
+             */
+            String mimecs = null;
+            try {
+                mimecs = System.getProperty("mail.mime.charset");
+            } catch (SecurityException ex) { }  // ignore it
+            if (mimecs != null && mimecs.length() > 0) {
+                defaultJavaCharset = javaCharset(mimecs);
+                return defaultJavaCharset;
+            }
+
+            try {
+                defaultJavaCharset = System.getProperty("file.encoding",
+                                                        "8859_1");
+            } catch (SecurityException sex) {
+
+                class NullInputStream extends InputStream {
+                    public int read() {
+                        return 0;
+                    }
+                }
+                InputStreamReader reader =
+                        new InputStreamReader(new NullInputStream());
+                defaultJavaCharset = reader.getEncoding();
+                if (defaultJavaCharset == null)
+                    defaultJavaCharset = "8859_1";
+            }
+        }
+
+        return defaultJavaCharset;
+    }
+
+    /*
+     * Get the default MIME charset for this locale.
+     */
+    static String getDefaultMIMECharset() {
+        if (defaultMIMECharset == null) {
+            try {
+                defaultMIMECharset = System.getProperty("mail.mime.charset");
+            } catch (SecurityException ex) { }  // ignore it
+        }
+        if (defaultMIMECharset == null)
+            defaultMIMECharset = mimeCharset(getDefaultJavaCharset());
+        return defaultMIMECharset;
+    }
+
+    // Tables to map MIME charset names to Java names and vice versa.
+    // XXX - Should eventually use J2SE 1.4 java.nio.charset.Charset
+    private static Hashtable mime2java;
+    private static Hashtable java2mime;
+
+    static {
+        java2mime = new Hashtable(40);
+        mime2java = new Hashtable(10);
+
+        try {
+            // Use this class's classloader to load the mapping file
+            // XXX - we should use SecuritySupport, but it's in another package
+            InputStream is =
+                    com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeUtility.class.getResourceAsStream(
+                    "/META-INF/javamail.charset.map");
+
+            if (is != null) {
+                is = new LineInputStream(is);
+
+                // Load the JDK-to-MIME charset mapping table
+                loadMappings((LineInputStream)is, java2mime);
+
+                // Load the MIME-to-JDK charset mapping table
+                loadMappings((LineInputStream)is, mime2java);
+            }
+        } catch (Exception ex) { }
+
+        // If we didn't load the tables, e.g., because we didn't have
+        // permission, load them manually.  The entries here should be
+        // the same as the default javamail.charset.map.
+        if (java2mime.isEmpty()) {
+            java2mime.put("8859_1", "ISO-8859-1");
+            java2mime.put("iso8859_1", "ISO-8859-1");
+            java2mime.put("ISO8859-1", "ISO-8859-1");
+
+            java2mime.put("8859_2", "ISO-8859-2");
+            java2mime.put("iso8859_2", "ISO-8859-2");
+            java2mime.put("ISO8859-2", "ISO-8859-2");
+
+            java2mime.put("8859_3", "ISO-8859-3");
+            java2mime.put("iso8859_3", "ISO-8859-3");
+            java2mime.put("ISO8859-3", "ISO-8859-3");
+
+            java2mime.put("8859_4", "ISO-8859-4");
+            java2mime.put("iso8859_4", "ISO-8859-4");
+            java2mime.put("ISO8859-4", "ISO-8859-4");
+
+            java2mime.put("8859_5", "ISO-8859-5");
+            java2mime.put("iso8859_5", "ISO-8859-5");
+            java2mime.put("ISO8859-5", "ISO-8859-5");
+
+            java2mime.put("8859_6", "ISO-8859-6");
+            java2mime.put("iso8859_6", "ISO-8859-6");
+            java2mime.put("ISO8859-6", "ISO-8859-6");
+
+            java2mime.put("8859_7", "ISO-8859-7");
+            java2mime.put("iso8859_7", "ISO-8859-7");
+            java2mime.put("ISO8859-7", "ISO-8859-7");
+
+            java2mime.put("8859_8", "ISO-8859-8");
+            java2mime.put("iso8859_8", "ISO-8859-8");
+            java2mime.put("ISO8859-8", "ISO-8859-8");
+
+            java2mime.put("8859_9", "ISO-8859-9");
+            java2mime.put("iso8859_9", "ISO-8859-9");
+            java2mime.put("ISO8859-9", "ISO-8859-9");
+
+            java2mime.put("SJIS", "Shift_JIS");
+            java2mime.put("MS932", "Shift_JIS");
+            java2mime.put("JIS", "ISO-2022-JP");
+            java2mime.put("ISO2022JP", "ISO-2022-JP");
+            java2mime.put("EUC_JP", "euc-jp");
+            java2mime.put("KOI8_R", "koi8-r");
+            java2mime.put("EUC_CN", "euc-cn");
+            java2mime.put("EUC_TW", "euc-tw");
+            java2mime.put("EUC_KR", "euc-kr");
+        }
+        if (mime2java.isEmpty()) {
+            mime2java.put("iso-2022-cn", "ISO2022CN");
+            mime2java.put("iso-2022-kr", "ISO2022KR");
+            mime2java.put("utf-8", "UTF8");
+            mime2java.put("utf8", "UTF8");
+            mime2java.put("ja_jp.iso2022-7", "ISO2022JP");
+            mime2java.put("ja_jp.eucjp", "EUCJIS");
+            mime2java.put("euc-kr", "KSC5601");
+            mime2java.put("euckr", "KSC5601");
+            mime2java.put("us-ascii", "ISO-8859-1");
+            mime2java.put("x-us-ascii", "ISO-8859-1");
+        }
+    }
+
+    private static void loadMappings(LineInputStream is, Hashtable table) {
+        String currLine;
+
+        while (true) {
+            try {
+                currLine = is.readLine();
+            } catch (IOException ioex) {
+                break; // error in reading, stop
+            }
+
+            if (currLine == null) // end of file, stop
+                break;
+            if (currLine.startsWith("--") && currLine.endsWith("--"))
+                // end of this table
+                break;
+
+            // ignore empty lines and comments
+            if (currLine.trim().length() == 0 || currLine.startsWith("#"))
+                continue;
+
+            // A valid entry is of the form <key><separator><value>
+            // where, <separator> := SPACE | HT. Parse this
+            StringTokenizer tk = new StringTokenizer(currLine, " \t");
+            try {
+                String key = tk.nextToken();
+                String value = tk.nextToken();
+                table.put(key.toLowerCase(), value);
+            } catch (NoSuchElementException nex) { }
+        }
+    }
+
+    static final int ALL_ASCII          = 1;
+    static final int MOSTLY_ASCII       = 2;
+    static final int MOSTLY_NONASCII    = 3;
+
+    /**
+     * Check if the given string contains non US-ASCII characters.
+     * @param   s       string
+     * @return          ALL_ASCII if all characters in the string
+     *                  belong to the US-ASCII charset. MOSTLY_ASCII
+     *                  if more than half of the available characters
+     *                  are US-ASCII characters. Else MOSTLY_NONASCII.
+     */
+    static int checkAscii(String s) {
+        int ascii = 0, non_ascii = 0;
+        int l = s.length();
+
+        for (int i = 0; i < l; i++) {
+            if (nonascii((int)s.charAt(i))) // non-ascii
+                non_ascii++;
+            else
+                ascii++;
+        }
+
+        if (non_ascii == 0)
+            return ALL_ASCII;
+        if (ascii > non_ascii)
+            return MOSTLY_ASCII;
+
+        return MOSTLY_NONASCII;
+    }
+
+    /**
+     * Check if the given byte array contains non US-ASCII characters.
+     * @param   b       byte array
+     * @return          ALL_ASCII if all characters in the string
+     *                  belong to the US-ASCII charset. MOSTLY_ASCII
+     *                  if more than half of the available characters
+     *                  are US-ASCII characters. Else MOSTLY_NONASCII.
+     *
+     * XXX - this method is no longer used
+     */
+    static int checkAscii(byte[] b) {
+        int ascii = 0, non_ascii = 0;
+
+        for (int i=0; i < b.length; i++) {
+            // The '&' operator automatically causes b[i] to be promoted
+            // to an int, and we mask out the higher bytes in the int
+            // so that the resulting value is not a negative integer.
+            if (nonascii(b[i] & 0xff)) // non-ascii
+                non_ascii++;
+            else
+                ascii++;
+        }
+
+        if (non_ascii == 0)
+            return ALL_ASCII;
+        if (ascii > non_ascii)
+            return MOSTLY_ASCII;
+
+        return MOSTLY_NONASCII;
+    }
+
+    /**
+     * Check if the given input stream contains non US-ASCII characters.
+     * Upto <code>max</code> bytes are checked. If <code>max</code> is
+     * set to <code>ALL</code>, then all the bytes available in this
+     * input stream are checked. If <code>breakOnNonAscii</code> is true
+     * the check terminates when the first non-US-ASCII character is
+     * found and MOSTLY_NONASCII is returned. Else, the check continues
+     * till <code>max</code> bytes or till the end of stream.
+     *
+     * @param   is      the input stream
+     * @param   max     maximum bytes to check for. The special value
+     *                  ALL indicates that all the bytes in this input
+     *                  stream must be checked.
+     * @param   breakOnNonAscii if <code>true</code>, then terminate the
+     *                  the check when the first non-US-ASCII character
+     *                  is found.
+     * @return          ALL_ASCII if all characters in the string
+     *                  belong to the US-ASCII charset. MOSTLY_ASCII
+     *                  if more than half of the available characters
+     *                  are US-ASCII characters. Else MOSTLY_NONASCII.
+     */
+    static int checkAscii(InputStream is, int max, boolean breakOnNonAscii) {
+        int ascii = 0, non_ascii = 0;
+        int len;
+        int block = 4096;
+        int linelen = 0;
+        boolean longLine = false, badEOL = false;
+        boolean checkEOL = encodeEolStrict && breakOnNonAscii;
+        byte buf[] = null;
+        if (max != 0) {
+            block = (max == ALL) ? 4096 : Math.min(max, 4096);
+            buf = new byte[block];
+        }
+        while (max != 0) {
+            try {
+                if ((len = is.read(buf, 0, block)) == -1)
+                    break;
+                int lastb = 0;
+                for (int i = 0; i < len; i++) {
+                    // The '&' operator automatically causes b[i] to
+                    // be promoted to an int, and we mask out the higher
+                    // bytes in the int so that the resulting value is
+                    // not a negative integer.
+                    int b = buf[i] & 0xff;
+                    if (checkEOL &&
+                            ((lastb == '\r' && b != '\n') ||
+                            (lastb != '\r' && b == '\n')))
+                        badEOL = true;
+                    if (b == '\r' || b == '\n')
+                        linelen = 0;
+                    else {
+                        linelen++;
+                        if (linelen > 998)      // 1000 - CRLF
+                            longLine = true;
+                    }
+                    if (nonascii(b)) {  // non-ascii
+                        if (breakOnNonAscii) // we are done
+                            return MOSTLY_NONASCII;
+                        else
+                            non_ascii++;
+                    } else
+                        ascii++;
+                    lastb = b;
+                }
+            } catch (IOException ioex) {
+                break;
+            }
+            if (max != ALL)
+                max -= len;
+        }
+
+        if (max == 0 && breakOnNonAscii)
+            // We have been told to break on the first non-ascii character.
+            // We haven't got any non-ascii character yet, but then we
+            // have not checked all of the available bytes either. So we
+            // cannot say for sure that this input stream is ALL_ASCII,
+            // and hence we must play safe and return MOSTLY_NONASCII
+
+            return MOSTLY_NONASCII;
+
+        if (non_ascii == 0) { // no non-us-ascii characters so far
+            // If we're looking at non-text data, and we saw CR without LF
+            // or vice versa, consider this mostly non-ASCII so that it
+            // will be base64 encoded (since the quoted-printable encoder
+            // doesn't encode this case properly).
+            if (badEOL)
+                return MOSTLY_NONASCII;
+            // if we've seen a long line, we degrade to mostly ascii
+            else if (longLine)
+                return MOSTLY_ASCII;
+            else
+                return ALL_ASCII;
+        }
+        if (ascii > non_ascii) // mostly ascii
+            return MOSTLY_ASCII;
+        return MOSTLY_NONASCII;
+    }
+
+    static final boolean nonascii(int b) {
+        return b >= 0177 || (b < 040 && b != '\r' && b != '\n' && b != '\t');
+    }
+}
+
+/**
+ * An OutputStream that determines whether the data written to
+ * it is all ASCII, mostly ASCII, or mostly non-ASCII.
+ */
+class AsciiOutputStream extends OutputStream {
+    private boolean breakOnNonAscii;
+    private int ascii = 0, non_ascii = 0;
+    private int linelen = 0;
+    private boolean longLine = false;
+    private boolean badEOL = false;
+    private boolean checkEOL = false;
+    private int lastb = 0;
+    private int ret = 0;
+
+    public AsciiOutputStream(boolean breakOnNonAscii, boolean encodeEolStrict) {
+        this.breakOnNonAscii = breakOnNonAscii;
+        checkEOL = encodeEolStrict && breakOnNonAscii;
+    }
+
+    public void write(int b) throws IOException {
+        check(b);
+    }
+
+    public void write(byte b[]) throws IOException {
+        write(b, 0, b.length);
+    }
+
+    public void write(byte b[], int off, int len) throws IOException {
+        len += off;
+        for (int i = off; i < len ; i++)
+            check(b[i]);
+    }
+
+    private final void check(int b) throws IOException {
+        b &= 0xff;
+        if (checkEOL &&
+                ((lastb == '\r' && b != '\n') || (lastb != '\r' && b == '\n')))
+            badEOL = true;
+        if (b == '\r' || b == '\n')
+            linelen = 0;
+        else {
+            linelen++;
+            if (linelen > 998)  // 1000 - CRLF
+                longLine = true;
+        }
+        if (MimeUtility.nonascii(b)) { // non-ascii
+            non_ascii++;
+            if (breakOnNonAscii) {      // we are done
+                ret = MimeUtility.MOSTLY_NONASCII;
+                throw new EOFException();
+            }
+        } else
+            ascii++;
+        lastb = b;
+    }
+
+    /**
+     * Return ASCII-ness of data stream.
+     */
+    public int getAscii() {
+        if (ret != 0)
+            return ret;
+        // If we're looking at non-text data, and we saw CR without LF
+        // or vice versa, consider this mostly non-ASCII so that it
+        // will be base64 encoded (since the quoted-printable encoder
+        // doesn't encode this case properly).
+        if (badEOL)
+            return MimeUtility.MOSTLY_NONASCII;
+        else if (non_ascii == 0) { // no non-us-ascii characters so far
+            // if we've seen a long line, we degrade to mostly ascii
+            if (longLine)
+                return MimeUtility.MOSTLY_ASCII;
+            else
+                return MimeUtility.ALL_ASCII;
+        }
+        if (ascii > non_ascii) // mostly ascii
+            return MimeUtility.MOSTLY_ASCII;
+        return MimeUtility.MOSTLY_NONASCII;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ParameterList.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ParameterList.java
new file mode 100644
index 0000000..4fa98eb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ParameterList.java
@@ -0,0 +1,228 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+
+/**
+ * This class holds MIME parameters (attribute-value pairs).
+ *
+ * @author  John Mani
+ */
+
+public final class ParameterList {
+
+    private final HashMap list;
+
+    /**
+     * No-arg Constructor.
+     */
+    public ParameterList() {
+        this.list = new HashMap();
+    }
+
+    private ParameterList(HashMap m) {
+        this.list = m;
+    }
+
+    /**
+     * Constructor that takes a parameter-list string. The String
+     * is parsed and the parameters are collected and stored internally.
+     * A ParseException is thrown if the parse fails.
+     * Note that an empty parameter-list string is valid and will be
+     * parsed into an empty ParameterList.
+     *
+     * @param   s       the parameter-list string.
+     * @exception       ParseException if the parse fails.
+     */
+    public ParameterList(String s) throws ParseException {
+        HeaderTokenizer h = new HeaderTokenizer(s, HeaderTokenizer.MIME);
+        HeaderTokenizer.Token tk;
+        int type;
+        String name;
+
+        list = new HashMap();
+        while (true) {
+            tk = h.next();
+            type = tk.getType();
+
+            if (type == HeaderTokenizer.Token.EOF) // done
+                return;
+
+            if ((char)type == ';') {
+                // expect parameter name
+                tk = h.next();
+                // tolerate trailing semicolon, even though it violates the spec
+                if (tk.getType() == HeaderTokenizer.Token.EOF)
+                    return;
+                // parameter name must be a MIME Atom
+                if (tk.getType() != HeaderTokenizer.Token.ATOM)
+                    throw new ParseException();
+                name = tk.getValue().toLowerCase();
+
+                // expect '='
+                tk = h.next();
+                if ((char)tk.getType() != '=')
+                    throw new ParseException();
+
+                // expect parameter value
+                tk = h.next();
+                type = tk.getType();
+                // parameter value must be a MIME Atom or Quoted String
+                if (type != HeaderTokenizer.Token.ATOM &&
+                    type != HeaderTokenizer.Token.QUOTEDSTRING)
+                    throw new ParseException();
+
+                list.put(name, tk.getValue());
+            } else
+                throw new ParseException();
+        }
+    }
+
+    /**
+     * Return the number of parameters in this list.
+     *
+     * @return  number of parameters.
+     */
+    public int size() {
+        return list.size();
+    }
+
+    /**
+     * Returns the value of the specified parameter. Note that
+     * parameter names are case-insensitive.
+     *
+     * @param name      parameter name.
+     * @return          Value of the parameter. Returns
+     *                  <code>null</code> if the parameter is not
+     *                  present.
+     */
+    public String get(String name) {
+        return (String)list.get(name.trim().toLowerCase());
+    }
+
+    /**
+     * Set a parameter. If this parameter already exists, it is
+     * replaced by this new value.
+     *
+     * @param   name    name of the parameter.
+     * @param   value   value of the parameter.
+     */
+    public void set(String name, String value) {
+        list.put(name.trim().toLowerCase(), value);
+    }
+
+    /**
+     * Removes the specified parameter from this ParameterList.
+     * This method does nothing if the parameter is not present.
+     *
+     * @param   name    name of the parameter.
+     */
+    public void remove(String name) {
+        list.remove(name.trim().toLowerCase());
+    }
+
+    /**
+     * Return an enumeration of the names of all parameters in this
+     * list.
+     *
+     * @return Enumeration of all parameter names in this list.
+     */
+    public Iterator getNames() {
+        return list.keySet().iterator();
+    }
+
+
+    /**
+     * Convert this ParameterList into a MIME String. If this is
+     * an empty list, an empty string is returned.
+     *
+     * @return          String
+     */
+    public String toString() {
+        return toString(0);
+    }
+
+    /**
+     * Convert this ParameterList into a MIME String. If this is
+     * an empty list, an empty string is returned.
+     *
+     * The 'used' parameter specifies the number of character positions
+     * already taken up in the field into which the resulting parameter
+     * list is to be inserted. It's used to determine where to fold the
+     * resulting parameter list.
+     *
+     * @param used      number of character positions already used, in
+     *                  the field into which the parameter list is to
+     *                  be inserted.
+     * @return          String
+     */
+    public String toString(int used) {
+        StringBuffer sb = new StringBuffer();
+        Iterator itr = list.entrySet().iterator();
+
+        while (itr.hasNext()) {
+            Map.Entry e = (Map.Entry)itr.next();
+            String name = (String)e.getKey();
+            String value = quote((String)e.getValue());
+            sb.append("; ");
+            used += 2;
+            int len = name.length() + value.length() + 1;
+            if (used + len > 76) { // overflows ...
+                sb.append("\r\n\t"); // .. start new continuation line
+                used = 8; // account for the starting <tab> char
+            }
+            sb.append(name).append('=');
+            used += name.length() + 1;
+            if (used + value.length() > 76) { // still overflows ...
+                // have to fold value
+                String s = MimeUtility.fold(used, value);
+                sb.append(s);
+                int lastlf = s.lastIndexOf('\n');
+                if (lastlf >= 0)        // always true
+                    used += s.length() - lastlf - 1;
+                else
+                    used += s.length();
+            } else {
+                sb.append(value);
+                used += value.length();
+            }
+        }
+
+        return sb.toString();
+    }
+
+    // Quote a parameter value token if required.
+    private String quote(String value) {
+        return MimeUtility.quote(value, HeaderTokenizer.MIME);
+    }
+
+    public ParameterList copy() {
+        return new ParameterList((HashMap)list.clone());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ParseException.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ParseException.java
new file mode 100644
index 0000000..724fa67
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/ParseException.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.MessagingException;
+
+/**
+ * The exception thrown due to an error in parsing RFC822
+ * or MIME headers
+ *
+ * @author John Mani
+ */
+
+public class ParseException extends MessagingException {
+
+    /**
+     * Constructs a ParseException with no detail message.
+     */
+    public ParseException() {
+        super();
+    }
+
+    /**
+     * Constructs a ParseException with the specified detail message.
+     * @param s         the detail message
+     */
+    public ParseException(String s) {
+        super(s);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/SharedInputStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/SharedInputStream.java
new file mode 100644
index 0000000..4b993ad
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/SharedInputStream.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+import java.io.InputStream;
+import java.io.OutputStream;
+
+// SAAJ doesn't utilize this, but I think it should.
+/**
+ * An InputStream that is backed by data that can be shared by multiple
+ * readers may implement this interface.  This allows users of such an
+ * InputStream to determine the current positionin the InputStream, and
+ * to create new InputStreams representing a subset of the data in the
+ * original InputStream.  The new InputStream will access the same
+ * underlying data as the original, without copying the data.
+ *
+ * @author  Bill Shannon
+ * @since JavaMail 1.2
+ */
+
+public interface SharedInputStream {
+    /**
+     * Return the current position in the InputStream, as an
+     * offset from the beginning of the InputStream.
+     *
+     * @return  the current position
+     */
+    public long getPosition();
+
+    /**
+     * Return a new InputStream representing a subset of the data
+     * from this InputStream, starting at <code>start</code> (inclusive)
+     * up to <code>end</code> (exclusive).  <code>start</code> must be
+     * non-negative.  If <code>end</code> is -1, the new stream ends
+     * at the same place as this stream.  The returned InputStream
+     * will also implement the SharedInputStream interface.
+     *
+     * @param   start   the starting position
+     * @param   end     the ending position + 1
+     * @return          the new stream
+     */
+    public InputStream newStream(long start, long end);
+
+    /**
+     * Writes the specified region to another {@link OutputStream}.
+     */
+    public void writeTo(long start,long end, OutputStream out);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/UniqueValue.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/UniqueValue.java
new file mode 100644
index 0000000..61d486a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/internet/UniqueValue.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.internet;
+
+
+/**
+ * This is a utility class that generates unique values. The generated
+ * String contains only US-ASCII characters and hence is safe for use
+ * in RFC822 headers. <p>
+ *
+ * This is a package private class.
+ *
+ * @author John Mani
+ * @author Max Spivak
+ * @author Bill Shannon
+ */
+
+class UniqueValue {
+    /**
+     * A global part number.  Access is not synchronized because the
+     * value is only one part of the unique value and so doesn't need
+     * to be accurate.
+     */
+    private static int part = 0;
+
+    /**
+     * Get a unique value for use in a multipart boundary string.
+     *
+     * This implementation generates it by concatenating a global
+     * part number, a newly created object's <code>hashCode()</code>,
+     * and the current time (in milliseconds).
+     */
+    public static String getUniqueBoundaryValue() {
+        StringBuffer s = new StringBuffer();
+
+        // Unique string is ----=_Part_<part>_<hashcode>.<currentTime>
+        s.append("----=_Part_").append(part++).append("_").
+          append(s.hashCode()).append('.').
+          append(System.currentTimeMillis());
+        return s.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/ASCIIUtility.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/ASCIIUtility.java
new file mode 100644
index 0000000..9f33685
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/ASCIIUtility.java
@@ -0,0 +1,142 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+
+import java.io.*;
+
+public class ASCIIUtility {
+
+    // Private constructor so that this class is not instantiated
+    private ASCIIUtility() { }
+
+
+    /**
+     * Convert the bytes within the specified range of the given byte
+     * array into a signed integer in the given radix . The range extends
+     * from <code>start</code> till, but not including <code>end</code>. <p>
+     *
+     * Based on java.lang.Integer.parseInt()
+     */
+    public static int parseInt(byte[] b, int start, int end, int radix)
+                throws NumberFormatException {
+        if (b == null)
+            throw new NumberFormatException("null");
+
+        int result = 0;
+        boolean negative = false;
+        int i = start;
+        int limit;
+        int multmin;
+        int digit;
+
+        if (end > start) {
+            if (b[i] == '-') {
+                negative = true;
+                limit = Integer.MIN_VALUE;
+                i++;
+            } else {
+                limit = -Integer.MAX_VALUE;
+            }
+            multmin = limit / radix;
+            if (i < end) {
+                digit = Character.digit((char)b[i++], radix);
+                if (digit < 0) {
+                    throw new NumberFormatException(
+                        "illegal number: " + toString(b, start, end)
+                        );
+                } else {
+                    result = -digit;
+                }
+            }
+            while (i < end) {
+                // Accumulating negatively avoids surprises near MAX_VALUE
+                digit = Character.digit((char)b[i++], radix);
+                if (digit < 0) {
+                    throw new NumberFormatException("illegal number");
+                }
+                if (result < multmin) {
+                    throw new NumberFormatException("illegal number");
+                }
+                result *= radix;
+                if (result < limit + digit) {
+                    throw new NumberFormatException("illegal number");
+                }
+                result -= digit;
+            }
+        } else {
+            throw new NumberFormatException("illegal number");
+        }
+        if (negative) {
+            if (i > start + 1) {
+                return result;
+            } else {    /* Only got "-" */
+                throw new NumberFormatException("illegal number");
+            }
+        } else {
+            return -result;
+        }
+    }
+
+    /**
+     * Convert the bytes within the specified range of the given byte
+     * array into a String. The range extends from <code>start</code>
+     * till, but not including <code>end</code>. <p>
+     */
+    public static String toString(byte[] b, int start, int end) {
+        int size = end - start;
+        char[] theChars = new char[size];
+
+        for (int i = 0, j = start; i < size; )
+            theChars[i++] = (char)(b[j++]&0xff);
+
+        return new String(theChars);
+    }
+
+    public static byte[] getBytes(String s) {
+        char [] chars= s.toCharArray();
+        int size = chars.length;
+        byte[] bytes = new byte[size];
+
+        for (int i = 0; i < size;)
+            bytes[i] = (byte) chars[i++];
+        return bytes;
+    }
+
+    /**
+     *
+     * @deprecated
+     *      this is an expensive operation that require an additional
+     *      buffer reallocation just to get the array of an exact size.
+     *      Unless you absolutely need the exact size array, don't use this.
+     *      Use {@link ByteOutputStream} and {@link ByteOutputStream#write(InputStream)}.
+     */
+    public static byte[] getBytes(InputStream is) throws IOException {
+        ByteOutputStream bos = new ByteOutputStream();
+        bos.write(is);
+        return bos.toByteArray();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BASE64DecoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BASE64DecoderStream.java
new file mode 100644
index 0000000..470ffde
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BASE64DecoderStream.java
@@ -0,0 +1,250 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.*;
+
+/**
+ * This class implements a BASE64 Decoder. It is implemented as
+ * a FilterInputStream, so one can just wrap this class around
+ * any input stream and read bytes from this filter. The decoding
+ * is done as the bytes are read out.
+ *
+ * @author John Mani
+ * @author Bill Shannon
+ */
+
+public class BASE64DecoderStream extends FilterInputStream {
+    private byte[] buffer;      // cache of decoded bytes
+    private int bufsize = 0;    // size of the cache
+    private int index = 0;      // index into the cache
+
+    /**
+     * Create a BASE64 decoder that decodes the specified input stream
+     * @param in        the input stream
+     */
+    public BASE64DecoderStream(InputStream in) {
+        super(in);
+        buffer = new byte[3];
+    }
+
+    /**
+     * Read the next decoded byte from this input stream. The byte
+     * is returned as an <code>int</code> in the range <code>0</code>
+     * to <code>255</code>. If no byte is available because the end of
+     * the stream has been reached, the value <code>-1</code> is returned.
+     * This method blocks until input data is available, the end of the
+     * stream is detected, or an exception is thrown.
+     *
+     * @return     next byte of data, or <code>-1</code> if the end of the
+     *             stream is reached.
+     * @exception  IOException  if an I/O error occurs.
+     * @see        java.io.FilterInputStream#in
+     */
+    public int read() throws IOException {
+        if (index >= bufsize) {
+            decode(); // Fills up buffer
+            if (bufsize == 0) // buffer is empty
+                return -1;
+            index = 0; // reset index into buffer
+        }
+        return buffer[index++] & 0xff; // Zero off the MSB
+    }
+
+    /**
+     * Reads up to <code>len</code> decoded bytes of data from this input stream
+     * into an array of bytes. This method blocks until some input is
+     * available.
+     * <p>
+     *
+     * @param      buf   the buffer into which the data is read.
+     * @param      off   the start offset of the data.
+     * @param      len   the maximum number of bytes read.
+     * @return     the total number of bytes read into the buffer, or
+     *             <code>-1</code> if there is no more data because the end of
+     *             the stream has been reached.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public int read(byte[] buf, int off, int len) throws IOException {
+        int i, c;
+        for (i = 0; i < len; i++) {
+            if ((c = read()) == -1) {
+                if (i == 0) // At end of stream, so we should
+                    i = -1; // return -1 , NOT 0.
+                break;
+            }
+            buf[off+i] = (byte)c;
+        }
+
+        return i;
+    }
+
+    /**
+     * Tests if this input stream supports marks. Currently this class
+     * does not support marks
+     */
+    public boolean markSupported() {
+        return false; // Maybe later ..
+    }
+
+    /**
+     * Returns the number of bytes that can be read from this input
+     * stream without blocking. However, this figure is only
+     * a close approximation in case the original encoded stream
+     * contains embedded CRLFs; since the CRLFs are discarded, not decoded
+     */
+    public int available() throws IOException {
+         // This is only an estimate, since in.available()
+         // might include CRLFs too ..
+         return ((in.available() * 3)/4 + (bufsize-index));
+    }
+
+    /**
+     * This character array provides the character to value map
+     * based on RFC1521.
+     */
+    private final static char pem_array[] = {
+        'A','B','C','D','E','F','G','H', // 0
+        'I','J','K','L','M','N','O','P', // 1
+        'Q','R','S','T','U','V','W','X', // 2
+        'Y','Z','a','b','c','d','e','f', // 3
+        'g','h','i','j','k','l','m','n', // 4
+        'o','p','q','r','s','t','u','v', // 5
+        'w','x','y','z','0','1','2','3', // 6
+        '4','5','6','7','8','9','+','/'  // 7
+    };
+
+    private final static byte pem_convert_array[] = new byte[256];
+
+    static {
+        for (int i = 0; i < 255; i++)
+            pem_convert_array[i] = -1;
+        for(int i = 0; i < pem_array.length; i++)
+            pem_convert_array[pem_array[i]] = (byte) i;
+    }
+
+    /* The decoder algorithm */
+    private byte[] decode_buffer = new byte[4];
+    private void decode() throws IOException {
+        bufsize = 0;
+        /*
+         * We need 4 valid base64 characters before we start decoding.
+         * We skip anything that's not a valid base64 character (usually
+         * just CRLF).
+         */
+        int got = 0;
+        while (got < 4) {
+            int i = in.read();
+            if (i == -1) {
+                if (got == 0)
+                    return;     // EOF before any data is ok
+                throw new IOException("Error in encoded stream, got " + got);
+            }
+            if (i >= 0 && i < 256 && i == '=' || pem_convert_array[i] != -1)
+                decode_buffer[got++] = (byte)i;
+        }
+
+        byte a, b;
+        a = pem_convert_array[decode_buffer[0] & 0xff];
+        b = pem_convert_array[decode_buffer[1] & 0xff];
+        // The first decoded byte
+        buffer[bufsize++] = (byte)(((a << 2) & 0xfc) | ((b >>> 4) & 3));
+
+        if (decode_buffer[2] == '=') // End of this BASE64 encoding
+            return;
+        a = b;
+        b = pem_convert_array[decode_buffer[2] & 0xff];
+        // The second decoded byte
+        buffer[bufsize++] = (byte)(((a << 4) & 0xf0) | ((b >>> 2) & 0xf));
+
+        if (decode_buffer[3] == '=') // End of this BASE64 encoding
+            return;
+        a = b;
+        b = pem_convert_array[decode_buffer[3] & 0xff];
+        // The third decoded byte
+        buffer[bufsize++] = (byte)(((a << 6) & 0xc0) | (b & 0x3f));
+    }
+
+    /**
+     * Base64 decode a byte array.  No line breaks are allowed.
+     * This method is suitable for short strings, such as those
+     * in the IMAP AUTHENTICATE protocol, but not to decode the
+     * entire content of a MIME part.
+     *
+     * NOTE: inbuf may only contain valid base64 characters.
+     *       Whitespace is not ignored.
+     */
+    public static byte[] decode(byte[] inbuf) {
+        int size = (inbuf.length / 4) * 3;
+        if (size == 0)
+            return inbuf;
+
+        if (inbuf[inbuf.length - 1] == '=') {
+            size--;
+            if (inbuf[inbuf.length - 2] == '=')
+                size--;
+        }
+        byte[] outbuf = new byte[size];
+
+        int inpos = 0, outpos = 0;
+        size = inbuf.length;
+        while (size > 0) {
+            byte a, b;
+            a = pem_convert_array[inbuf[inpos++] & 0xff];
+            b = pem_convert_array[inbuf[inpos++] & 0xff];
+            // The first decoded byte
+            outbuf[outpos++] = (byte)(((a << 2) & 0xfc) | ((b >>> 4) & 3));
+
+            if (inbuf[inpos] == '=') // End of this BASE64 encoding
+                return outbuf;
+            a = b;
+            b = pem_convert_array[inbuf[inpos++] & 0xff];
+            // The second decoded byte
+            outbuf[outpos++] = (byte)(((a << 4) & 0xf0) | ((b >>> 2) & 0xf));
+
+            if (inbuf[inpos] == '=') // End of this BASE64 encoding
+                return outbuf;
+            a = b;
+            b = pem_convert_array[inbuf[inpos++] & 0xff];
+            // The third decoded byte
+            outbuf[outpos++] = (byte)(((a << 6) & 0xc0) | (b & 0x3f));
+            size -= 4;
+        }
+        return outbuf;
+    }
+
+    /*** begin TEST program ***
+    public static void main(String argv[]) throws Exception {
+        FileInputStream infile = new FileInputStream(argv[0]);
+        BASE64DecoderStream decoder = new BASE64DecoderStream(infile);
+        int c;
+
+        while ((c = decoder.read()) != -1)
+            System.out.print((char)c);
+        System.out.flush();
+    }
+    *** end TEST program ***/
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BASE64EncoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BASE64EncoderStream.java
new file mode 100644
index 0000000..05d9cbc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BASE64EncoderStream.java
@@ -0,0 +1,238 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.*;
+
+/**
+ * This class implements a BASE64 Encoder. It is implemented as
+ * a FilterOutputStream, so one can just wrap this class around
+ * any output stream and write bytes into this filter. The Encoding
+ * is done as the bytes are written out.
+ *
+ * @author John Mani
+ * @author Bill Shannon
+ */
+
+public class BASE64EncoderStream extends FilterOutputStream {
+    private byte[] buffer;      // cache of bytes that are yet to be encoded
+    private int bufsize = 0;    // size of the cache
+    private int count = 0;      // number of bytes that have been output
+    private int bytesPerLine;   // number of bytes per line
+
+    /**
+     * Create a BASE64 encoder that encodes the specified input stream
+     * @param out        the output stream
+     * @param bytesPerLine  number of bytes per line. The encoder inserts
+     *                   a CRLF sequence after the specified number of bytes
+     */
+    public BASE64EncoderStream(OutputStream out, int bytesPerLine) {
+        super(out);
+        buffer = new byte[3];
+        this.bytesPerLine = bytesPerLine;
+    }
+
+    /**
+     * Create a BASE64 encoder that encodes the specified input stream.
+     * Inserts the CRLF sequence after outputting 76 bytes.
+     * @param out        the output stream
+     */
+    public BASE64EncoderStream(OutputStream out) {
+        this(out, 76);
+    }
+
+    /**
+     * Encodes <code>len</code> bytes from the specified
+     * <code>byte</code> array starting at offset <code>off</code> to
+     * this output stream.
+     *
+     * @param      b     the data.
+     * @param      off   the start offset in the data.
+     * @param      len   the number of bytes to write.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void write(byte[] b, int off, int len) throws IOException {
+        for (int i = 0; i < len; i++)
+            write(b[off + i]);
+    }
+
+    /**
+     * Encodes <code>b.length</code> bytes to this output stream.
+     * @param      b   the data to be written.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void write(byte[] b) throws IOException {
+        write(b, 0, b.length);
+    }
+
+    /**
+     * Encodes the specified <code>byte</code> to this output stream.
+     * @param      c   the <code>byte</code>.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void write(int c) throws IOException {
+        buffer[bufsize++] = (byte)c;
+        if (bufsize == 3) { // Encoding unit = 3 bytes
+            encode();
+            bufsize = 0;
+        }
+    }
+
+    /**
+     * Flushes this output stream and forces any buffered output bytes
+     * to be encoded out to the stream.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void flush() throws IOException {
+        if (bufsize > 0) { // If there's unencoded characters in the buffer ..
+            encode();      // .. encode them
+            bufsize = 0;
+        }
+        out.flush();
+    }
+
+    /**
+     * Forces any buffered output bytes to be encoded out to the stream
+     * and closes this output stream
+     */
+    public void close() throws IOException {
+        flush();
+        out.close();
+    }
+
+    /** This array maps the characters to their 6 bit values */
+    private final static char pem_array[] = {
+        'A','B','C','D','E','F','G','H', // 0
+        'I','J','K','L','M','N','O','P', // 1
+        'Q','R','S','T','U','V','W','X', // 2
+        'Y','Z','a','b','c','d','e','f', // 3
+        'g','h','i','j','k','l','m','n', // 4
+        'o','p','q','r','s','t','u','v', // 5
+        'w','x','y','z','0','1','2','3', // 6
+        '4','5','6','7','8','9','+','/'  // 7
+    };
+
+    private void encode() throws IOException {
+        // If writing out this encoded unit will cause overflow,
+        // start a new line.
+        if (count + 4 > bytesPerLine) {
+            out.write('\r');
+            out.write('\n');
+            count = 0;
+        }
+
+        byte a, b, c;
+        if (bufsize == 1) {
+            a = buffer[0];
+            b = 0;
+            c = 0;
+            out.write(pem_array[(a >>> 2) & 0x3F]);
+            out.write(pem_array[((a << 4) & 0x30) + ((b >>> 4) & 0xf)]);
+            out.write('='); // pad character
+            out.write('='); // pad character
+        } else if (bufsize == 2) {
+            a = buffer[0];
+            b = buffer[1];
+            c = 0;
+            out.write(pem_array[(a >>> 2) & 0x3F]);
+            out.write(pem_array[((a << 4) & 0x30) + ((b >>> 4) & 0xf)]);
+            out.write(pem_array[((b << 2) & 0x3c) + ((c >>> 6) & 0x3)]);
+            out.write('='); // pad character
+        } else {
+            a = buffer[0];
+            b = buffer[1];
+            c = buffer[2];
+            out.write(pem_array[(a >>> 2) & 0x3F]);
+            out.write(pem_array[((a << 4) & 0x30) + ((b >>> 4) & 0xf)]);
+            out.write(pem_array[((b << 2) & 0x3c) + ((c >>> 6) & 0x3)]);
+            out.write(pem_array[c & 0x3F]);
+        }
+
+        // increment count
+        count += 4;
+    }
+
+    /**
+     * Base64 encode a byte array.  No line breaks are inserted.
+     * This method is suitable for short strings, such as those
+     * in the IMAP AUTHENTICATE protocol, but not to encode the
+     * entire content of a MIME part.
+     */
+    public static byte[] encode(byte[] inbuf) {
+        if (inbuf.length == 0)
+            return inbuf;
+        byte[] outbuf = new byte[((inbuf.length + 2) / 3) * 4];
+        int inpos = 0, outpos = 0;
+        int size = inbuf.length;
+        while (size > 0) {
+            byte a, b, c;
+            if (size == 1) {
+                a = inbuf[inpos++];
+                b = 0;
+                c = 0;
+                outbuf[outpos++] = (byte)pem_array[(a >>> 2) & 0x3F];
+                outbuf[outpos++] =
+                        (byte)pem_array[((a << 4) & 0x30) + ((b >>> 4) & 0xf)];
+                outbuf[outpos++] = (byte)'=';  // pad character
+                outbuf[outpos++] = (byte)'=';  // pad character
+            } else if (size == 2) {
+                a = inbuf[inpos++];
+                b = inbuf[inpos++];
+                c = 0;
+                outbuf[outpos++] = (byte)pem_array[(a >>> 2) & 0x3F];
+                outbuf[outpos++] =
+                        (byte)pem_array[((a << 4) & 0x30) + ((b >>> 4) & 0xf)];
+                outbuf[outpos++] =
+                        (byte)pem_array[((b << 2) & 0x3c) + ((c >>> 6) & 0x3)];
+                outbuf[outpos++] = (byte)'=';  // pad character
+            } else {
+                a = inbuf[inpos++];
+                b = inbuf[inpos++];
+                c = inbuf[inpos++];
+                outbuf[outpos++] = (byte)pem_array[(a >>> 2) & 0x3F];
+                outbuf[outpos++] =
+                        (byte)pem_array[((a << 4) & 0x30) + ((b >>> 4) & 0xf)];
+                outbuf[outpos++] =
+                        (byte)pem_array[((b << 2) & 0x3c) + ((c >>> 6) & 0x3)];
+                outbuf[outpos++] = (byte)pem_array[c & 0x3F];
+            }
+            size -= 3;
+        }
+        return outbuf;
+    }
+
+    /*** begin TEST program
+    public static void main(String argv[]) throws Exception {
+        FileInputStream infile = new FileInputStream(argv[0]);
+        BASE64EncoderStream encoder = new BASE64EncoderStream(System.out);
+        int c;
+
+        while ((c = infile.read()) != -1)
+            encoder.write(c);
+        encoder.close();
+    }
+    *** end TEST program **/
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BEncoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BEncoderStream.java
new file mode 100644
index 0000000..1170a93
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/BEncoderStream.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.OutputStream;
+
+/**
+ * This class implements a 'B' Encoder as defined by RFC2047 for
+ * encoding MIME headers. It subclasses the BASE64EncoderStream
+ * class.
+ *
+ * @author John Mani
+ */
+
+public class BEncoderStream extends BASE64EncoderStream {
+
+    /**
+     * Create a 'B' encoder that encodes the specified input stream.
+     * @param out        the output stream
+     */
+    public BEncoderStream(OutputStream out) {
+        super(out, Integer.MAX_VALUE); // MAX_VALUE is 2^31, should
+                                       // suffice (!) to indicate that
+                                       // CRLFs should not be inserted
+    }
+
+    /**
+     * Returns the length of the encoded version of this byte array.
+     */
+    public static int encodedLength(byte[] b) {
+        return ((b.length + 2)/3) * 4;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/LineInputStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/LineInputStream.java
new file mode 100644
index 0000000..93b8775
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/LineInputStream.java
@@ -0,0 +1,106 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.*;
+
+/**
+ * This class is to support reading CRLF terminated lines that
+ * contain only US-ASCII characters from an input stream. Provides
+ * functionality that is similar to the deprecated
+ * <code>DataInputStream.readLine()</code>. Expected use is to read
+ * lines as String objects from a RFC822 stream.
+ *
+ * It is implemented as a FilterInputStream, so one can just wrap
+ * this class around any input stream and read bytes from this filter.
+ *
+ * @author John Mani
+ */
+
+public final class LineInputStream extends FilterInputStream {
+
+    private char[] lineBuffer = null; // reusable byte buffer
+
+    public LineInputStream(InputStream in) {
+        super(in);
+    }
+
+    /**
+     * Read a line containing only ASCII characters from the input
+     * stream. A line is terminated by a CR or NL or CR-NL sequence.
+     * A common error is a CR-CR-NL sequence, which will also terminate
+     * a line.
+     * The line terminator is not returned as part of the returned
+     * String. Returns null if no data is available. <p>
+     *
+     * This class is similar to the deprecated
+     * <code>DataInputStream.readLine()</code>
+     */
+    public String readLine() throws IOException {
+        InputStream in = this.in;
+        char[] buf = lineBuffer;
+
+        if (buf == null)
+            buf = lineBuffer = new char[128];
+
+        int c1;
+        int room = buf.length;
+        int offset = 0;
+
+        while ((c1 = in.read()) != -1) {
+            if (c1 == '\n') // Got NL, outa here.
+                break;
+            else if (c1 == '\r') {
+                // Got CR, is the next char NL ?
+                int c2 = in.read();
+                if (c2 == '\r')         // discard extraneous CR
+                    c2 = in.read();
+                if (c2 != '\n') {
+                    // If not NL, push it back
+                    if (!(in instanceof PushbackInputStream))
+                        in = this.in = new PushbackInputStream(in);
+                    ((PushbackInputStream)in).unread(c2);
+                }
+                break; // outa here.
+            }
+
+            // Not CR, NL or CR-NL ...
+            // .. Insert the byte into our byte buffer
+            if (--room < 0) { // No room, need to grow.
+                buf = new char[offset + 128];
+                room = buf.length - offset - 1;
+                System.arraycopy(lineBuffer, 0, buf, 0, offset);
+                lineBuffer = buf;
+            }
+            buf[offset++] = (char)c1;
+        }
+
+        if ((c1 == -1) && (offset == 0))
+            return null;
+
+        return String.copyValueOf(buf, 0, offset);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/OutputUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/OutputUtil.java
new file mode 100644
index 0000000..d0a6a90
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/OutputUtil.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+
+import java.io.OutputStream;
+import java.io.IOException;
+
+/**
+ * This class is to support writing out Strings as a sequence of bytes
+ * terminated by a CRLF sequence. The String must contain only US-ASCII
+ * characters.<p>
+ *
+ * The expected use is to write out RFC822 style headers to an output
+ * stream. <p>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class OutputUtil {
+    private static byte[] newline = {'\r','\n'};
+
+    public static void writeln(String s,OutputStream out) throws IOException {
+        writeAsAscii(s,out);
+        writeln(out);
+    }
+
+    /**
+     * Writes a string as ASCII string.
+     */
+    public static void writeAsAscii(String s,OutputStream out) throws IOException {
+        int len = s.length();
+        for( int i=0; i<len; i++ )
+            out.write((byte)s.charAt(i));
+    }
+
+    public static void writeln(OutputStream out) throws IOException {
+        out.write(newline);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QDecoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QDecoderStream.java
new file mode 100644
index 0000000..358b7ce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QDecoderStream.java
@@ -0,0 +1,78 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+/**
+ * This class implements a Q Decoder as defined in RFC 2047
+ * for decoding MIME headers. It subclasses the QPDecoderStream class.
+ *
+ * @author John Mani
+ */
+
+public class QDecoderStream extends QPDecoderStream {
+
+    /**
+     * Create a Q-decoder that decodes the specified input stream.
+     * @param in        the input stream
+     */
+    public QDecoderStream(InputStream in) {
+        super(in);
+    }
+
+    /**
+     * Read the next decoded byte from this input stream. The byte
+     * is returned as an <code>int</code> in the range <code>0</code>
+     * to <code>255</code>. If no byte is available because the end of
+     * the stream has been reached, the value <code>-1</code> is returned.
+     * This method blocks until input data is available, the end of the
+     * stream is detected, or an exception is thrown.
+     *
+     * @return     the next byte of data, or <code>-1</code> if the end of the
+     *             stream is reached.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public int read() throws IOException {
+        int c = in.read();
+
+        if (c == '_') // Return '_' as ' '
+            return ' ';
+        else if (c == '=') {
+            // QP Encoded atom. Get the next two bytes ..
+            ba[0] = (byte)in.read();
+            ba[1] = (byte)in.read();
+            // .. and decode them
+            try {
+                return ASCIIUtility.parseInt(ba, 0, 2, 16);
+            } catch (NumberFormatException nex) {
+                throw new IOException("Error in QP stream " + nex.getMessage());
+            }
+        } else
+            return c;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QEncoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QEncoderStream.java
new file mode 100644
index 0000000..2b635d2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QEncoderStream.java
@@ -0,0 +1,105 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.IOException;
+import java.io.OutputStream;
+
+/**
+ * This class implements a Q Encoder as defined by RFC 2047 for
+ * encoding MIME headers. It subclasses the QPEncoderStream class.
+ *
+ * @author John Mani
+ */
+
+public class QEncoderStream extends QPEncoderStream {
+
+    private String specials;
+    private static String WORD_SPECIALS = "=_?\"#$%&'(),.:;<>@[\\]^`{|}~";
+    private static String TEXT_SPECIALS = "=_?";
+
+    /**
+     * Create a Q encoder that encodes the specified input stream
+     * @param out        the output stream
+     * @param encodingWord true if we are Q-encoding a word within a
+     *                  phrase.
+     */
+    public QEncoderStream(OutputStream out, boolean encodingWord) {
+        super(out, Integer.MAX_VALUE); // MAX_VALUE is 2^31, should
+                                       // suffice (!) to indicate that
+                                       // CRLFs should not be inserted
+                                       // when encoding rfc822 headers
+
+        // a RFC822 "word" token has more restrictions than a
+        // RFC822 "text" token.
+        specials = encodingWord ? WORD_SPECIALS : TEXT_SPECIALS;
+    }
+
+    /**
+     * Encodes the specified <code>byte</code> to this output stream.
+     * @param      c   the <code>byte</code>.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void write(int c) throws IOException {
+        c = c & 0xff; // Turn off the MSB.
+        if (c == ' ')
+            output('_', false);
+        else if (c < 040 || c >= 0177 || specials.indexOf(c) >= 0)
+            // Encoding required.
+            output(c, true);
+        else // No encoding required
+            output(c, false);
+    }
+
+    /**
+     * Returns the length of the encoded version of this byte array.
+     */
+    public static int encodedLength(byte[] b, boolean encodingWord) {
+        int len = 0;
+        String specials = encodingWord ? WORD_SPECIALS: TEXT_SPECIALS;
+        for (int i = 0; i < b.length; i++) {
+            int c = b[i] & 0xff; // Mask off MSB
+            if (c < 040 || c >= 0177 || specials.indexOf(c) >= 0)
+                // needs encoding
+                len += 3; // Q-encoding is 1 -> 3 conversion
+            else
+                len++;
+        }
+        return len;
+    }
+
+    /**** begin TEST program ***
+    public static void main(String argv[]) throws Exception {
+        FileInputStream infile = new FileInputStream(argv[0]);
+        QEncoderStream encoder = new QEncoderStream(System.out);
+        int c;
+
+        while ((c = infile.read()) != -1)
+            encoder.write(c);
+        encoder.close();
+    }
+    *** end TEST program ***/
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QPDecoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QPDecoderStream.java
new file mode 100644
index 0000000..3dcc0a1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QPDecoderStream.java
@@ -0,0 +1,192 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.*;
+
+/**
+ * This class implements a QP Decoder. It is implemented as
+ * a FilterInputStream, so one can just wrap this class around
+ * any input stream and read bytes from this filter. The decoding
+ * is done as the bytes are read out.
+ *
+ * @author John Mani
+ */
+
+public class QPDecoderStream extends FilterInputStream {
+    protected byte[] ba = new byte[2];
+    protected int spaces = 0;
+
+    /**
+     * Create a Quoted Printable decoder that decodes the specified
+     * input stream.
+     * @param in        the input stream
+     */
+    public QPDecoderStream(InputStream in) {
+        super(new PushbackInputStream(in, 2)); // pushback of size=2
+    }
+
+    /**
+     * Read the next decoded byte from this input stream. The byte
+     * is returned as an <code>int</code> in the range <code>0</code>
+     * to <code>255</code>. If no byte is available because the end of
+     * the stream has been reached, the value <code>-1</code> is returned.
+     * This method blocks until input data is available, the end of the
+     * stream is detected, or an exception is thrown.
+     *
+     * @return     the next byte of data, or <code>-1</code> if the end of the
+     *             stream is reached.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public int read() throws IOException {
+        if (spaces > 0) {
+            // We have cached space characters, return one
+            spaces--;
+            return ' ';
+        }
+
+        int c = in.read();
+
+        if (c == ' ') {
+            // Got space, keep reading till we get a non-space char
+            while ((c = in.read()) == ' ')
+                spaces++;
+
+            if (c == '\r' || c == '\n' || c == -1)
+                // If the non-space char is CR/LF/EOF, the spaces we got
+                // so far is junk introduced during transport. Junk 'em.
+                spaces = 0;
+            else {
+                // The non-space char is NOT CR/LF, the spaces are valid.
+                ((PushbackInputStream)in).unread(c);
+                c = ' ';
+            }
+            return c; // return either <SPACE> or <CR/LF>
+        }
+        else if (c == '=') {
+            // QP Encoded atom. Decode the next two bytes
+            int a = in.read();
+
+            if (a == '\n') {
+                /* Hmm ... not really confirming QP encoding, but lets
+                 * allow this as a LF terminated encoded line .. and
+                 * consider this a soft linebreak and recurse to fetch
+                 * the next char.
+                 */
+                return read();
+            } else if (a == '\r') {
+                // Expecting LF. This forms a soft linebreak to be ignored.
+                int b = in.read();
+                if (b != '\n')
+                    /* Not really confirming QP encoding, but
+                     * lets allow this as well.
+                     */
+                    ((PushbackInputStream)in).unread(b);
+                return read();
+            } else if (a == -1) {
+                // Not valid QP encoding, but we be nice and tolerant here !
+                return -1;
+            } else {
+                ba[0] = (byte)a;
+                ba[1] = (byte)in.read();
+                try {
+                    return ASCIIUtility.parseInt(ba, 0, 2, 16);
+                } catch (NumberFormatException nex) {
+                    /*
+                    System.err.println(
+                        "Illegal characters in QP encoded stream: " +
+                        ASCIIUtility.toString(ba, 0, 2)
+                    );
+                    */
+
+                    ((PushbackInputStream)in).unread(ba);
+                    return c;
+                }
+            }
+        }
+        return c;
+    }
+
+    /**
+     * Reads up to <code>len</code> decoded bytes of data from this input stream
+     * into an array of bytes. This method blocks until some input is
+     * available.
+     * <p>
+     *
+     * @param      buf   the buffer into which the data is read.
+     * @param      off   the start offset of the data.
+     * @param      len   the maximum number of bytes read.
+     * @return     the total number of bytes read into the buffer, or
+     *             <code>-1</code> if there is no more data because the end of
+     *             the stream has been reached.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public int read(byte[] buf, int off, int len) throws IOException {
+        int i, c;
+        for (i = 0; i < len; i++) {
+            if ((c = read()) == -1) {
+                if (i == 0) // At end of stream, so we should
+                    i = -1; // return -1 , NOT 0.
+                break;
+            }
+            buf[off+i] = (byte)c;
+        }
+        return i;
+    }
+
+    /**
+     * Tests if this input stream supports marks. Currently this class
+     * does not support marks
+     */
+    public boolean markSupported() {
+        return false;
+    }
+
+    /**
+     * Returns the number of bytes that can be read from this input
+     * stream without blocking. The QP algorithm does not permit
+     * a priori knowledge of the number of bytes after decoding, so
+     * this method just invokes the <code>available</code> method
+     * of the original input stream.
+     */
+    public int available() throws IOException {
+        // This is bogus ! We don't really know how much
+        // bytes are available *after* decoding
+        return in.available();
+    }
+
+    /**** begin TEST program
+    public static void main(String argv[]) throws Exception {
+        FileInputStream infile = new FileInputStream(argv[0]);
+        QPDecoderStream decoder = new QPDecoderStream(infile);
+        int c;
+
+        while ((c = decoder.read()) != -1)
+            System.out.print((char)c);
+        System.out.println();
+    }
+    *** end TEST program ****/
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QPEncoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QPEncoderStream.java
new file mode 100644
index 0000000..ab323db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/QPEncoderStream.java
@@ -0,0 +1,193 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.*;
+
+/**
+ * This class implements a Quoted Printable Encoder. It is implemented as
+ * a FilterOutputStream, so one can just wrap this class around
+ * any output stream and write bytes into this filter. The Encoding
+ * is done as the bytes are written out.
+ *
+ * @author John Mani
+ */
+
+public class QPEncoderStream extends FilterOutputStream {
+    private int count = 0;      // number of bytes that have been output
+    private int bytesPerLine;   // number of bytes per line
+    private boolean gotSpace = false;
+    private boolean gotCR = false;
+
+    /**
+     * Create a QP encoder that encodes the specified input stream
+     * @param out        the output stream
+     * @param bytesPerLine  the number of bytes per line. The encoder
+     *                   inserts a CRLF sequence after this many number
+     *                   of bytes.
+     */
+    public QPEncoderStream(OutputStream out, int bytesPerLine) {
+        super(out);
+        // Subtract 1 to account for the '=' in the soft-return
+        // at the end of a line
+        this.bytesPerLine = bytesPerLine - 1;
+    }
+
+    /**
+     * Create a QP encoder that encodes the specified input stream.
+     * Inserts the CRLF sequence after outputting 76 bytes.
+     * @param out        the output stream
+     */
+    public QPEncoderStream(OutputStream out) {
+        this(out, 76);
+    }
+
+    /**
+     * Encodes <code>len</code> bytes from the specified
+     * <code>byte</code> array starting at offset <code>off</code> to
+     * this output stream.
+     *
+     * @param      b     the data.
+     * @param      off   the start offset in the data.
+     * @param      len   the number of bytes to write.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void write(byte[] b, int off, int len) throws IOException {
+        for (int i = 0; i < len; i++)
+            write(b[off + i]);
+    }
+
+    /**
+     * Encodes <code>b.length</code> bytes to this output stream.
+     * @param      b   the data to be written.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void write(byte[] b) throws IOException {
+        write(b, 0, b.length);
+    }
+
+    /**
+     * Encodes the specified <code>byte</code> to this output stream.
+     * @param      c   the <code>byte</code>.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void write(int c) throws IOException {
+        c = c & 0xff; // Turn off the MSB.
+        if (gotSpace) { // previous character was <SPACE>
+            if (c == '\r' || c == '\n')
+                // if CR/LF, we need to encode the <SPACE> char
+                output(' ', true);
+            else // no encoding required, just output the char
+                output(' ', false);
+            gotSpace = false;
+        }
+
+        if (c == '\r') {
+            gotCR = true;
+            outputCRLF();
+        } else {
+            if (c == '\n') {
+                if (gotCR)
+                    // This is a CRLF sequence, we already output the
+                    // corresponding CRLF when we got the CR, so ignore this
+                    ;
+                else
+                    outputCRLF();
+            } else if (c == ' ') {
+                gotSpace = true;
+            } else if (c < 040 || c >= 0177 || c == '=')
+                // Encoding required.
+                output(c, true);
+            else // No encoding required
+                output(c, false);
+            // whatever it was, it wasn't a CR
+            gotCR = false;
+        }
+    }
+
+    /**
+     * Flushes this output stream and forces any buffered output bytes
+     * to be encoded out to the stream.
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public void flush() throws IOException {
+        out.flush();
+    }
+
+    /**
+     * Forces any buffered output bytes to be encoded out to the stream
+     * and closes this output stream
+     */
+    public void close() throws IOException {
+        out.close();
+    }
+
+    private void outputCRLF() throws IOException {
+        out.write('\r');
+        out.write('\n');
+        count = 0;
+    }
+
+    // The encoding table
+    private final static char hex[] = {
+        '0','1', '2', '3', '4', '5', '6', '7',
+        '8','9', 'A', 'B', 'C', 'D', 'E', 'F'
+    };
+
+    protected void output(int c, boolean encode) throws IOException {
+        if (encode) {
+            if ((count += 3) > bytesPerLine) {
+                out.write('=');
+                out.write('\r');
+                out.write('\n');
+                count = 3; // set the next line's length
+            }
+            out.write('=');
+            out.write(hex[c >> 4]);
+            out.write(hex[c & 0xf]);
+        } else {
+            if (++count > bytesPerLine) {
+                out.write('=');
+                out.write('\r');
+                out.write('\n');
+                count = 1; // set the next line's length
+            }
+            out.write(c);
+        }
+    }
+
+    /**** begin TEST program ***
+    public static void main(String argv[]) throws Exception {
+        FileInputStream infile = new FileInputStream(argv[0]);
+        QPEncoderStream encoder = new QPEncoderStream(System.out);
+        int c;
+
+        while ((c = infile.read()) != -1)
+            encoder.write(c);
+        encoder.close();
+    }
+    *** end TEST program ***/
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/UUDecoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/UUDecoderStream.java
new file mode 100644
index 0000000..625634c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/UUDecoderStream.java
@@ -0,0 +1,251 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.*;
+
+/**
+ * This class implements a UUDecoder. It is implemented as
+ * a FilterInputStream, so one can just wrap this class around
+ * any input stream and read bytes from this filter. The decoding
+ * is done as the bytes are read out.
+ *
+ * @author John Mani
+ * @author Bill Shannon
+ */
+
+public class UUDecoderStream extends FilterInputStream {
+    private String name;
+    private int mode;
+
+    private byte[] buffer;      // cache of decoded bytes
+    private int bufsize = 0;    // size of the cache
+    private int index = 0;      // index into the cache
+    private boolean gotPrefix = false;
+    private boolean gotEnd = false;
+    private LineInputStream lin;
+
+    /**
+     * Create a UUdecoder that decodes the specified input stream
+     * @param in        the input stream
+     */
+    public UUDecoderStream(InputStream in) {
+        super(in);
+        lin = new LineInputStream(in);
+        buffer = new byte[45]; // max decoded chars in a line = 45
+    }
+
+    /**
+     * Read the next decoded byte from this input stream. The byte
+     * is returned as an <code>int</code> in the range <code>0</code>
+     * to <code>255</code>. If no byte is available because the end of
+     * the stream has been reached, the value <code>-1</code> is returned.
+     * This method blocks until input data is available, the end of the
+     * stream is detected, or an exception is thrown.
+     *
+     * @return     next byte of data, or <code>-1</code> if the end of
+     *             stream is reached.
+     * @exception  IOException  if an I/O error occurs.
+     * @see        java.io.FilterInputStream#in
+     */
+
+    public int read() throws IOException {
+        if (index >= bufsize) {
+            readPrefix();
+            if (!decode())
+                return -1;
+            index = 0; // reset index into buffer
+        }
+        return buffer[index++] & 0xff; // return lower byte
+    }
+
+    public int read(byte[] buf, int off, int len) throws IOException {
+        int i, c;
+        for (i = 0; i < len; i++) {
+            if ((c = read()) == -1) {
+                if (i == 0) // At end of stream, so we should
+                    i = -1; // return -1, NOT 0.
+                break;
+            }
+            buf[off+i] = (byte)c;
+        }
+        return i;
+    }
+
+    public boolean markSupported() {
+        return false;
+    }
+
+    public int available() throws IOException {
+         // This is only an estimate, since in.available()
+         // might include CRLFs too ..
+         return ((in.available() * 3)/4 + (bufsize-index));
+    }
+
+    /**
+     * Get the "name" field from the prefix. This is meant to
+     * be the pathname of the decoded file
+     *
+     * @return     name of decoded file
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public String getName() throws IOException {
+        readPrefix();
+        return name;
+    }
+
+    /**
+     * Get the "mode" field from the prefix. This is the permission
+     * mode of the source file.
+     *
+     * @return     permission mode of source file
+     * @exception  IOException  if an I/O error occurs.
+     */
+    public int getMode() throws IOException {
+        readPrefix();
+        return mode;
+    }
+
+    /**
+     * UUencoded streams start off with the line:
+     *  "begin <mode> <filename>"
+     * Search for this prefix and gobble it up.
+     */
+    private void readPrefix() throws IOException {
+        if (gotPrefix) // got the prefix
+            return;
+
+        String s;
+        for (;;) {
+            // read till we get the prefix: "begin MODE FILENAME"
+            s = lin.readLine(); // NOTE: readLine consumes CRLF pairs too
+            if (s == null)
+                throw new IOException("UUDecoder error: No Begin");
+            if (s.regionMatches(true, 0, "begin", 0, 5)) {
+                try {
+                    mode = Integer.parseInt(s.substring(6,9));
+                } catch (NumberFormatException ex) {
+                    throw new IOException("UUDecoder error: " + ex.toString());
+                }
+                name = s.substring(10);
+                gotPrefix = true;
+                return;
+            }
+        }
+    }
+
+    private boolean decode() throws IOException {
+
+        if (gotEnd)
+            return false;
+        bufsize = 0;
+        String line;
+        do {
+            line = lin.readLine();
+
+            /*
+             * Improperly encoded data sometimes omits the zero length
+             * line that starts with a space character, we detect the
+             * following "end" line here.
+             */
+            if (line == null)
+                throw new IOException("Missing End");
+            if (line.regionMatches(true, 0, "end", 0, 3)) {
+                gotEnd = true;
+                return false;
+            }
+        } while (line.length() == 0);
+        int count = line.charAt(0);
+        if (count < ' ')
+            throw new IOException("Buffer format error");
+
+        /*
+         * The first character in a line is the number of original (not
+         *  the encoded atoms) characters in the line. Note that all the
+         *  code below has to handle the <SPACE> character that indicates
+         *  end of encoded stream.
+         */
+        count = (count - ' ') & 0x3f;
+
+        if (count == 0) {
+            line = lin.readLine();
+            if (line == null || !line.regionMatches(true, 0, "end", 0, 3))
+                throw new IOException("Missing End");
+            gotEnd = true;
+            return false;
+        }
+
+        int need = ((count * 8)+5)/6;
+//System.out.println("count " + count + ", need " + need + ", len " + line.length());
+        if (line.length() < need + 1)
+            throw new IOException("Short buffer error");
+
+        int i = 1;
+        byte a, b;
+        /*
+         * A correct uuencoder always encodes 3 characters at a time, even
+         * if there aren't 3 characters left.  But since some people out
+         * there have broken uuencoders we handle the case where they
+         * don't include these "unnecessary" characters.
+         */
+        while (bufsize < count) {
+            // continue decoding until we get 'count' decoded chars
+            a = (byte)((line.charAt(i++) - ' ') & 0x3f);
+            b = (byte)((line.charAt(i++) - ' ') & 0x3f);
+            buffer[bufsize++] = (byte)(((a << 2) & 0xfc) | ((b >>> 4) & 3));
+
+            if (bufsize < count) {
+                a = b;
+                b = (byte)((line.charAt(i++) - ' ') & 0x3f);
+                buffer[bufsize++] =
+                                (byte)(((a << 4) & 0xf0) | ((b >>> 2) & 0xf));
+            }
+
+            if (bufsize < count) {
+                a = b;
+                b = (byte)((line.charAt(i++) - ' ') & 0x3f);
+                buffer[bufsize++] = (byte)(((a << 6) & 0xc0) | (b & 0x3f));
+            }
+        }
+        return true;
+    }
+
+    /*** begin TEST program *****
+    public static void main(String argv[]) throws Exception {
+        FileInputStream infile = new FileInputStream(argv[0]);
+        UUDecoderStream decoder = new UUDecoderStream(infile);
+        int c;
+
+        try {
+            while ((c = decoder.read()) != -1)
+                System.out.write(c);
+            System.out.flush();
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
+    **** end TEST program ****/
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/UUEncoderStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/UUEncoderStream.java
new file mode 100644
index 0000000..6287228
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/packaging/mime/util/UUEncoderStream.java
@@ -0,0 +1,200 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.packaging.mime.util;
+
+import java.io.*;
+
+/**
+ * This class implements a UUEncoder. It is implemented as
+ * a FilterOutputStream, so one can just wrap this class around
+ * any output stream and write bytes into this filter. The Encoding
+ * is done as the bytes are written out.
+ *
+ * @author John Mani
+ */
+
+public class UUEncoderStream extends FilterOutputStream {
+    private byte[] buffer;      // cache of bytes that are yet to be encoded
+    private int bufsize = 0;    // size of the cache
+    private boolean wrotePrefix = false;
+
+    protected String name;      // name of file
+    protected int mode;         // permissions mode
+
+    /**
+     * Create a UUencoder that encodes the specified input stream
+     * @param out        the output stream
+     */
+    public UUEncoderStream(OutputStream out) {
+        this(out, "encoder.buf", 644);
+    }
+
+    /**
+     * Create a UUencoder that encodes the specified input stream
+     * @param out        the output stream
+     * @param name       Specifies a name for the encoded buffer
+     */
+    public UUEncoderStream(OutputStream out, String name) {
+        this(out, name, 644);
+    }
+
+    /**
+     * Create a UUencoder that encodes the specified input stream
+     * @param out        the output stream
+     * @param name       Specifies a name for the encoded buffer
+     * @param mode       Specifies permission mode for the encoded buffer
+     */
+    public UUEncoderStream(OutputStream out, String name, int mode) {
+        super(out);
+        this.name = name;
+        this.mode = mode;
+        buffer = new byte[45];
+    }
+
+    /**
+     * Set up the buffer name and permission mode.
+     * This method has any effect only if it is invoked before
+     * you start writing into the output stream
+     */
+    public void setNameMode(String name, int mode) {
+        this.name = name;
+        this.mode = mode;
+    }
+
+    public void write(byte[] b, int off, int len) throws IOException {
+        for (int i = 0; i < len; i++)
+            write(b[off + i]);
+    }
+
+    public void write(byte[] data) throws IOException {
+        write(data, 0, data.length);
+    }
+
+    public void write(int c) throws IOException {
+        /* buffer up characters till we get a line's worth, then encode
+         * and write them out. Max number of characters allowed per
+         * line is 45.
+         */
+        buffer[bufsize++] = (byte)c;
+        if (bufsize == 45) {
+            writePrefix();
+            encode();
+            bufsize = 0;
+        }
+    }
+
+    public void flush() throws IOException {
+        if (bufsize > 0) { // If there's unencoded characters in the buffer
+            writePrefix();
+            encode();      // .. encode them
+        }
+        writeSuffix();
+        out.flush();
+    }
+
+    public void close() throws IOException {
+        flush();
+        out.close();
+    }
+
+    /**
+     * Write out the prefix: "begin <mode> <name>"
+     */
+    private void writePrefix() throws IOException {
+        if (!wrotePrefix) {
+            PrintStream ps = new PrintStream(out);
+            ps.println("begin " + mode + " " + name);
+            ps.flush();
+            wrotePrefix = true;
+        }
+    }
+
+    /**
+     * Write a single line containing space and the suffix line
+     * containing the single word "end" (terminated by a newline)
+     */
+    private void writeSuffix() throws IOException {
+        PrintStream ps = new PrintStream(out);
+        ps.println(" \nend");
+        ps.flush();
+    }
+
+    /**
+     * Encode a line.
+     * Start off with the character count, followed by the encoded atoms
+     * and terminate with LF. (or is it CRLF or the local line-terminator ?)
+     * Take three bytes and encodes them into 4 characters
+     * If bufsize if not a multiple of 3, the remaining bytes are filled
+     * with '1'. This insures that the last line won't end in spaces
+     * and potentiallly be truncated.
+     */
+    private void encode() throws IOException {
+        byte a, b, c;
+        int c1, c2, c3, c4;
+        int i = 0;
+
+        // Start off with the count of characters in the line
+        out.write((bufsize & 0x3f) + ' ');
+
+        while (i < bufsize) {
+            a = buffer[i++];
+            if (i < bufsize) {
+                b = buffer[i++];
+                if (i < bufsize)
+                    c = buffer[i++];
+                else // default c to 1
+                    c = 1;
+            }
+            else { // default b & c to 1
+                b = 1;
+                c = 1;
+            }
+
+            c1 = (a >>> 2) & 0x3f;
+            c2 = ((a << 4) & 0x30) | ((b >>> 4) & 0xf);
+            c3 = ((b << 2) & 0x3c) | ((c >>> 6) & 0x3);
+            c4 = c & 0x3f;
+            out.write(c1 + ' ');
+            out.write(c2 + ' ');
+            out.write(c3 + ' ');
+            out.write(c4 + ' ');
+        }
+        // Terminate with LF. (should it be CRLF or local line-terminator ?)
+        out.write('\n');
+    }
+
+    /**** begin TEST program *****
+    public static void main(String argv[]) throws Exception {
+        FileInputStream infile = new FileInputStream(argv[0]);
+        UUEncoderStream encoder = new UUEncoderStream(System.out);
+        int c;
+
+        while ((c = infile.read()) != -1)
+            encoder.write(c);
+        encoder.close();
+    }
+    **** end TEST program *****/
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/AttachmentPartImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/AttachmentPartImpl.java
new file mode 100644
index 0000000..62ee4c4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/AttachmentPartImpl.java
@@ -0,0 +1,521 @@
+/*
+ * $Id: AttachmentPartImpl.java,v 1.45 2006/01/27 12:49:26 vj135062 Exp $
+ * $Revision: 1.45 $
+ * $Date: 2006/01/27 12:49:26 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.util.ASCIIUtility;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.Header;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimePartDataSource;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.InternetHeaders;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeBodyPart;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeUtility;
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+import javax.activation.CommandMap;
+import javax.activation.DataHandler;
+import javax.activation.MailcapCommandMap;
+import javax.xml.soap.AttachmentPart;
+import javax.xml.soap.MimeHeader;
+import javax.xml.soap.MimeHeaders;
+import javax.xml.soap.SOAPException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.ByteArrayInputStream;
+import java.io.OutputStream;
+import java.util.Iterator;
+import java.util.List;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.activation.*;
+import javax.xml.soap.*;
+
+/**
+ * Implementation of attachments.
+ *
+ * @author Anil Vijendran (akv@eng.sun.com)
+ */
+public class AttachmentPartImpl extends AttachmentPart {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    static {
+        try {
+            CommandMap map = CommandMap.getDefaultCommandMap();
+            if (map instanceof MailcapCommandMap) {
+                MailcapCommandMap mailMap = (MailcapCommandMap) map;
+                String hndlrStr = ";;x-java-content-handler=";
+                mailMap.addMailcap(
+                    "text/xml"
+                        + hndlrStr
+                        + "com.sun.xml.internal.messaging.saaj.soap.XmlDataContentHandler");
+                mailMap.addMailcap(
+                    "application/xml"
+                        + hndlrStr
+                        + "com.sun.xml.internal.messaging.saaj.soap.XmlDataContentHandler");
+                mailMap.addMailcap(
+                    "application/fastinfoset"
+                        + hndlrStr
+                        + "com.sun.xml.internal.messaging.saaj.soap.FastInfosetDataContentHandler");
+                mailMap.addMailcap(
+                    "image/jpeg"
+                        + hndlrStr
+                        + "com.sun.xml.internal.messaging.saaj.soap.JpegDataContentHandler");
+                mailMap.addMailcap(
+                    "image/gif"
+                        + hndlrStr
+                        + "com.sun.xml.internal.messaging.saaj.soap.GifDataContentHandler");
+                /*mailMap.addMailcap(
+                    "multipart/*"
+                        + hndlrStr
+                        + "com.sun.xml.internal.messaging.saaj.soap.MultipartDataContentHandler");*/
+                mailMap.addMailcap(
+                    "image/*"
+                        + hndlrStr
+                        + "com.sun.xml.internal.messaging.saaj.soap.ImageDataContentHandler");
+                mailMap.addMailcap(
+                    "text/plain"
+                        + hndlrStr
+                        + "com.sun.xml.internal.messaging.saaj.soap.StringDataContentHandler");
+            } else {
+                throw new SOAPExceptionImpl("Default CommandMap is not a MailcapCommandMap");
+            }
+        } catch (Throwable t) {
+            log.log(
+                Level.SEVERE,
+                "SAAJ0508.soap.cannot.register.handlers",
+                t);
+            if (t instanceof RuntimeException) {
+                throw (RuntimeException) t;
+            } else {
+                throw new RuntimeException(t.getLocalizedMessage());
+            }
+        }
+    };
+
+    private final MimeHeaders headers;
+    private MimeBodyPart rawContent = null;
+    private DataHandler dataHandler = null;
+
+    public AttachmentPartImpl() {
+        headers = new MimeHeaders();
+    }
+
+    public int getSize() throws SOAPException {
+        byte[] bytes;
+
+        if ((rawContent == null) && (dataHandler == null))
+            return 0;
+
+        if (rawContent != null) {
+            try {
+                return rawContent.getSize();
+            } catch (Exception ex) {
+                log.log(
+                    Level.SEVERE,
+                    "SAAJ0573.soap.attachment.getrawbytes.ioexception",
+                    new String[] { ex.getLocalizedMessage()});
+                throw new SOAPExceptionImpl("Raw InputStream Error: " + ex);
+            }
+        } else {
+            ByteOutputStream bout = new ByteOutputStream();
+            try {
+                dataHandler.writeTo(bout);
+            } catch (IOException ex) {
+                log.log(
+                    Level.SEVERE,
+                    "SAAJ0501.soap.data.handler.err",
+                    new String[] { ex.getLocalizedMessage()});
+                throw new SOAPExceptionImpl("Data handler error: " + ex);
+            }
+            bytes = bout.getBytes();
+            if (bytes != null)
+                return bytes.length;
+        }
+        return -1;
+    }
+
+    public void clearContent() {
+        dataHandler = null;
+        rawContent = null;
+    }
+
+    public Object getContent() throws SOAPException {
+        try {
+            if (dataHandler != null)  {
+                return getDataHandler().getContent();
+            } else if (rawContent != null) {
+                return rawContent.getContent();
+            } else {
+                log.severe("SAAJ0572.soap.no.content.for.attachment");
+                throw new SOAPExceptionImpl("No data handler/content associated with this attachment");
+            }
+        } catch (Exception ex) {
+            log.log(Level.SEVERE, "SAAJ0575.soap.attachment.getcontent.exception", ex);
+            throw new SOAPExceptionImpl(ex.getLocalizedMessage());
+        }
+    }
+
+    public void setContent(Object object, String contentType)
+        throws IllegalArgumentException {
+        DataHandler dh = new DataHandler(object, contentType);
+
+        setDataHandler(dh);
+    }
+
+
+    public DataHandler getDataHandler() throws SOAPException {
+        if (dataHandler == null) {
+            if (rawContent != null) {
+                return new DataHandler(new MimePartDataSource(rawContent));
+            }
+            log.severe("SAAJ0502.soap.no.handler.for.attachment");
+            throw new SOAPExceptionImpl("No data handler associated with this attachment");
+        }
+        return dataHandler;
+    }
+
+    public void setDataHandler(DataHandler dataHandler)
+        throws IllegalArgumentException {
+        if (dataHandler == null) {
+            log.severe("SAAJ0503.soap.no.null.to.dataHandler");
+            throw new IllegalArgumentException("Null dataHandler argument to setDataHandler");
+        }
+        this.dataHandler = dataHandler;
+        rawContent = null;
+
+        log.log(
+            Level.FINE,
+            "SAAJ0580.soap.set.Content-Type",
+            new String[] { dataHandler.getContentType()});
+        setMimeHeader("Content-Type", dataHandler.getContentType());
+    }
+
+    public void removeAllMimeHeaders() {
+        headers.removeAllHeaders();
+    }
+
+    public void removeMimeHeader(String header) {
+        headers.removeHeader(header);
+    }
+
+    public String[] getMimeHeader(String name) {
+        return headers.getHeader(name);
+    }
+
+    public void setMimeHeader(String name, String value) {
+        headers.setHeader(name, value);
+    }
+
+    public void addMimeHeader(String name, String value) {
+        headers.addHeader(name, value);
+    }
+
+    public Iterator getAllMimeHeaders() {
+        return headers.getAllHeaders();
+    }
+
+    public Iterator getMatchingMimeHeaders(String[] names) {
+        return headers.getMatchingHeaders(names);
+    }
+
+    public Iterator getNonMatchingMimeHeaders(String[] names) {
+        return headers.getNonMatchingHeaders(names);
+    }
+
+    boolean hasAllHeaders(MimeHeaders hdrs) {
+        if (hdrs != null) {
+            Iterator i = hdrs.getAllHeaders();
+            while (i.hasNext()) {
+                MimeHeader hdr = (MimeHeader) i.next();
+                String[] values = headers.getHeader(hdr.getName());
+                boolean found = false;
+
+                if (values != null) {
+                    for (int j = 0; j < values.length; j++)
+                        if (hdr.getValue().equalsIgnoreCase(values[j])) {
+                            found = true;
+                            break;
+                        }
+                }
+
+                if (!found) {
+                    return false;
+                }
+            }
+        }
+        return true;
+    }
+
+    MimeBodyPart getMimePart() throws SOAPException {
+        try {
+            if (rawContent != null) {
+                copyMimeHeaders(headers, rawContent);
+                return rawContent;
+            }
+
+            MimeBodyPart envelope = new MimeBodyPart();
+
+            envelope.setDataHandler(dataHandler);
+            copyMimeHeaders(headers, envelope);
+
+            return envelope;
+        } catch (Exception ex) {
+            log.severe("SAAJ0504.soap.cannot.externalize.attachment");
+            throw new SOAPExceptionImpl("Unable to externalize attachment", ex);
+        }
+    }
+
+    public static void copyMimeHeaders(MimeHeaders headers, MimeBodyPart mbp)
+        throws SOAPException {
+
+        Iterator i = headers.getAllHeaders();
+
+        while (i.hasNext())
+            try {
+                MimeHeader mh = (MimeHeader) i.next();
+
+                mbp.setHeader(mh.getName(), mh.getValue());
+            } catch (Exception ex) {
+                log.severe("SAAJ0505.soap.cannot.copy.mime.hdr");
+                throw new SOAPExceptionImpl("Unable to copy MIME header", ex);
+            }
+    }
+
+    public static void copyMimeHeaders(MimeBodyPart mbp, AttachmentPartImpl ap)
+        throws SOAPException {
+        try {
+            List hdr = mbp.getAllHeaders();
+            int sz = hdr.size();
+            for( int i=0; i<sz; i++ ) {
+                Header h = (Header)hdr.get(i);
+                if(h.getName().equalsIgnoreCase("Content-Type"))
+                    continue;   // skip
+                ap.addMimeHeader(h.getName(), h.getValue());
+            }
+        } catch (Exception ex) {
+            log.severe("SAAJ0506.soap.cannot.copy.mime.hdrs.into.attachment");
+            throw new SOAPExceptionImpl(
+                "Unable to copy MIME headers into attachment",
+                ex);
+        }
+    }
+
+    public  void setBase64Content(InputStream content, String contentType)
+        throws SOAPException {
+        dataHandler = null;
+        try {
+            InputStream decoded = MimeUtility.decode(content, "base64");
+            InternetHeaders hdrs = new InternetHeaders();
+            hdrs.setHeader("Content-Type", contentType);
+            //TODO: reading the entire attachment here is ineffcient. Somehow the MimeBodyPart
+            // Ctor with inputStream causes problems based on the InputStream
+            // has markSupported()==true
+            ByteOutputStream bos = new ByteOutputStream();
+            bos.write(decoded);
+            rawContent = new MimeBodyPart(hdrs, bos.getBytes(), bos.getCount());
+            setMimeHeader("Content-Type", contentType);
+        } catch (Exception e) {
+            log.log(Level.SEVERE, "SAAJ0578.soap.attachment.setbase64content.exception", e);
+            throw new SOAPExceptionImpl(e.getLocalizedMessage());
+        }
+    }
+
+    public  InputStream getBase64Content() throws SOAPException {
+        InputStream stream;
+        if (rawContent != null) {
+            try {
+                 stream = rawContent.getInputStream();
+            } catch (Exception e) {
+                log.log(Level.SEVERE,"SAAJ0579.soap.attachment.getbase64content.exception", e);
+                throw new SOAPExceptionImpl(e.getLocalizedMessage());
+            }
+        } else if (dataHandler != null) {
+            try {
+                stream = dataHandler.getInputStream();
+            } catch (IOException e) {
+                log.severe("SAAJ0574.soap.attachment.datahandler.ioexception");
+                throw new SOAPExceptionImpl("DataHandler error" + e);
+            }
+        } else {
+            log.severe("SAAJ0572.soap.no.content.for.attachment");
+            throw new SOAPExceptionImpl("No data handler/content associated with this attachment");
+        }
+
+        //TODO: Write a BASE64EncoderInputStream instead,
+        // this code below is inefficient
+        // where we are trying to read the whole attachment first
+        int len;
+        int size = 1024;
+        byte [] buf;
+        if (stream != null) {
+            try {
+                ByteArrayOutputStream bos = new ByteArrayOutputStream(size);
+                //TODO: try and optimize this on the same lines as
+                // ByteOutputStream : to eliminate the temp buffer here
+                OutputStream ret = MimeUtility.encode(bos, "base64");
+                buf = new byte[size];
+                while ((len = stream.read(buf, 0, size)) != -1) {
+                    ret.write(buf, 0, len);
+                }
+                ret.flush();
+                buf = bos.toByteArray();
+                return new ByteArrayInputStream(buf);
+            } catch (Exception e) {
+                // throw new SOAPException
+                log.log(Level.SEVERE,"SAAJ0579.soap.attachment.getbase64content.exception", e);
+                throw new SOAPExceptionImpl(e.getLocalizedMessage());
+            }
+        } else {
+          //throw  new SOAPException
+          log.log(Level.SEVERE,"SAAJ0572.soap.no.content.for.attachment");
+          throw new SOAPExceptionImpl("No data handler/content associated with this attachment");
+        }
+    }
+
+    public void setRawContent(InputStream content, String contentType)
+        throws SOAPException {
+        dataHandler = null;
+        try {
+            InternetHeaders hdrs = new InternetHeaders();
+            hdrs.setHeader("Content-Type", contentType);
+            //TODO: reading the entire attachment here is ineffcient. Somehow the MimeBodyPart
+            // Ctor with inputStream causes problems based on whether the InputStream has
+            // markSupported()==true or false
+            ByteOutputStream bos = new ByteOutputStream();
+            bos.write(content);
+            rawContent = new MimeBodyPart(hdrs, bos.getBytes(), bos.getCount());
+            setMimeHeader("Content-Type", contentType);
+        } catch (Exception e) {
+            log.log(Level.SEVERE, "SAAJ0576.soap.attachment.setrawcontent.exception", e);
+            throw new SOAPExceptionImpl(e.getLocalizedMessage());
+        }
+    }
+
+   /*
+    public void setRawContentBytes(byte[] content, String contentType)
+        throws SOAPException {
+        if (content == null) {
+            throw new SOAPExceptionImpl("Null content passed to setRawContentBytes");
+        }
+        dataHandler = null;
+        try {
+            InternetHeaders hdrs = new InternetHeaders();
+            hdrs.setHeader("Content-Type", contentType);
+            rawContent = new MimeBodyPart(hdrs, content, content.length);
+            setMimeHeader("Content-Type", contentType);
+        } catch (Exception e) {
+            log.log(Level.SEVERE, "SAAJ0576.soap.attachment.setrawcontent.exception", e);
+            throw new SOAPExceptionImpl(e.getLocalizedMessage());
+        }
+    } */
+
+    public void setRawContentBytes(
+        byte[] content, int off, int len, String contentType)
+        throws SOAPException {
+        if (content == null) {
+            throw new SOAPExceptionImpl("Null content passed to setRawContentBytes");
+        }
+        dataHandler = null;
+        try {
+            InternetHeaders hdrs = new InternetHeaders();
+            hdrs.setHeader("Content-Type", contentType);
+            rawContent = new MimeBodyPart(hdrs, content, off, len);
+            setMimeHeader("Content-Type", contentType);
+        } catch (Exception e) {
+            log.log(Level.SEVERE,
+                "SAAJ0576.soap.attachment.setrawcontent.exception", e);
+            throw new SOAPExceptionImpl(e.getLocalizedMessage());
+        }
+    }
+
+    public  InputStream getRawContent() throws SOAPException {
+        if (rawContent != null) {
+            try {
+                return rawContent.getInputStream();
+            } catch (Exception e) {
+                log.log(Level.SEVERE,"SAAJ0577.soap.attachment.getrawcontent.exception", e);
+                throw new SOAPExceptionImpl(e.getLocalizedMessage());
+            }
+        } else if (dataHandler != null) {
+            try {
+                return dataHandler.getInputStream();
+            } catch (IOException e) {
+                log.severe("SAAJ0574.soap.attachment.datahandler.ioexception");
+                throw new SOAPExceptionImpl("DataHandler error" + e);
+            }
+        } else {
+            log.severe("SAAJ0572.soap.no.content.for.attachment");
+            throw new SOAPExceptionImpl("No data handler/content associated with this attachment");
+        }
+    }
+
+    //TODO: investigate size differences in mime.AttachImageTest
+    public  byte[] getRawContentBytes() throws SOAPException {
+        InputStream ret;
+        if (rawContent != null) {
+            try {
+                ret = rawContent.getInputStream();
+                return ASCIIUtility.getBytes(ret);
+            } catch (Exception e) {
+                log.log(Level.SEVERE,"SAAJ0577.soap.attachment.getrawcontent.exception", e);
+                throw new SOAPExceptionImpl(e.getLocalizedMessage());
+            }
+        } else if (dataHandler != null) {
+            try {
+                ret = dataHandler.getInputStream();
+                return ASCIIUtility.getBytes(ret);
+            } catch (IOException e) {
+                log.severe("SAAJ0574.soap.attachment.datahandler.ioexception");
+                throw new SOAPExceptionImpl("DataHandler error" + e);
+            }
+        } else {
+            log.severe("SAAJ0572.soap.no.content.for.attachment");
+            throw new SOAPExceptionImpl("No data handler/content associated with this attachment");
+        }
+    }
+
+    // attachments are equal if they are the same reference
+    public boolean equals(Object o) {
+        return (this == o);
+    }
+
+    public MimeHeaders getMimeHeaders() {
+        return headers;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/Envelope.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/Envelope.java
new file mode 100644
index 0000000..2c3301d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/Envelope.java
@@ -0,0 +1,60 @@
+/*
+ * $Id: Envelope.java,v 1.8 2006/01/27 12:49:26 vj135062 Exp $
+ * $Revision: 1.8 $
+ * $Date: 2006/01/27 12:49:26 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.io.IOException;
+import java.io.OutputStream;
+
+import javax.xml.soap.SOAPEnvelope;
+import javax.xml.transform.Source;
+
+/**
+ * Different implementations for SOAP Envelope must all implement this
+ * interface.
+ *
+ * @author Anil Vijendran (akv@eng.sun.com)
+ */
+public interface Envelope extends SOAPEnvelope {
+    /**
+     * Get the content as a JAXP Source.
+     */
+    Source getContent();
+
+    /**
+     * Output the content.
+     */
+    void output(OutputStream out) throws IOException;
+
+    /**
+     * Output the content.
+     */
+    void output(OutputStream out, boolean isFastInfoset) throws IOException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/EnvelopeFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/EnvelopeFactory.java
new file mode 100644
index 0000000..1ae2aa1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/EnvelopeFactory.java
@@ -0,0 +1,120 @@
+/*
+ * $Id: EnvelopeFactory.java,v 1.24 2006/01/27 12:49:26 vj135062 Exp $
+ * $Revision: 1.24 $
+ * $Date: 2006/01/27 12:49:26 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.util.logging.Logger;
+
+import javax.xml.parsers.SAXParser;
+import javax.xml.soap.SOAPException;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.sax.SAXSource;
+import javax.xml.transform.stream.StreamSource;
+
+import org.xml.sax.InputSource;
+import org.xml.sax.XMLReader;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.util.*;
+
+import com.sun.xml.internal.messaging.saaj.util.transform.EfficientStreamingTransformer;
+
+/**
+ * EnvelopeFactory creates SOAP Envelope objects using different
+ * underlying implementations.
+ */
+public class EnvelopeFactory {
+
+    protected static Logger
+        log = Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+        "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    private static ParserPool parserPool = new ParserPool(5);
+
+    public static Envelope createEnvelope(Source src, SOAPPartImpl soapPart)
+        throws SOAPException
+    {
+        // Insert SAX filter to disallow Document Type Declarations since
+        // they are not legal in SOAP
+        SAXParser saxParser = null;
+        if (src instanceof StreamSource) {
+            if (src instanceof JAXMStreamSource) {
+                try {
+                    ((JAXMStreamSource) src).reset();
+                } catch (java.io.IOException ioe) {
+                    log.severe("SAAJ0515.source.reset.exception");
+                    throw new SOAPExceptionImpl(ioe);
+                }
+            }
+            try {
+                saxParser = parserPool.get();
+            } catch (Exception e) {
+                log.severe("SAAJ0601.util.newSAXParser.exception");
+                throw new SOAPExceptionImpl(
+                    "Couldn't get a SAX parser while constructing a envelope",
+                    e);
+            }
+            InputSource is = SAXSource.sourceToInputSource(src);
+            XMLReader rejectFilter;
+            try {
+                rejectFilter = new RejectDoctypeSaxFilter(saxParser);
+            } catch (Exception ex) {
+                log.severe("SAAJ0510.soap.cannot.create.envelope");
+                throw new SOAPExceptionImpl(
+                    "Unable to create envelope from given source: ",
+                    ex);
+            }
+            src = new SAXSource(rejectFilter, is);
+        }
+
+        try {
+            Transformer transformer =
+                EfficientStreamingTransformer.newTransformer();
+            DOMResult result = new DOMResult(soapPart);
+            transformer.transform(src, result);
+
+            Envelope env = (Envelope) soapPart.getEnvelope();
+            if (saxParser != null) {
+                parserPool.put(saxParser);
+            }
+            return env;
+        } catch (Exception ex) {
+            if (ex instanceof SOAPVersionMismatchException) {
+                throw (SOAPVersionMismatchException) ex;
+            }
+            log.severe("SAAJ0511.soap.cannot.create.envelope");
+            throw new SOAPExceptionImpl(
+                "Unable to create envelope from given source: ",
+                ex);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/FastInfosetDataContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/FastInfosetDataContentHandler.java
new file mode 100644
index 0000000..8056b0e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/FastInfosetDataContentHandler.java
@@ -0,0 +1,126 @@
+/*
+ * $Id: FastInfosetDataContentHandler.java,v 1.1.1.1 2006/01/27 13:10:56 kumarjayanti Exp $
+ * $Revision: 1.1.1.1 $
+ * $Date: 2006/01/27 13:10:56 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.awt.datatransfer.DataFlavor;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.InputStream;
+
+import javax.activation.*;
+import javax.xml.transform.Source;
+
+import com.sun.xml.internal.messaging.saaj.util.FastInfosetReflection;
+
+/**
+ * JAF data handler for Fast Infoset content
+ *
+ * @author Santiago Pericas-Geertsen
+ */
+public class FastInfosetDataContentHandler implements DataContentHandler {
+    public final String STR_SRC = "com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSource";
+
+    public FastInfosetDataContentHandler() {
+    }
+
+    /**
+     * return the DataFlavors for this <code>DataContentHandler</code>
+     * @return The DataFlavors.
+     */
+    public DataFlavor[] getTransferDataFlavors() { // throws Exception;
+        DataFlavor flavors[] = new DataFlavor[1];
+        flavors[0] = new ActivationDataFlavor(
+                FastInfosetReflection.getFastInfosetSource_class(),
+                "application/fastinfoset", "Fast Infoset");
+        return flavors;
+    }
+
+    /**
+     * return the Transfer Data of type DataFlavor from InputStream
+     * @param df The DataFlavor.
+     * @param ins The InputStream corresponding to the data.
+     * @return The constructed Object.
+     */
+    public Object getTransferData(DataFlavor flavor, DataSource dataSource)
+        throws IOException
+    {
+        if (flavor.getMimeType().startsWith("application/fastinfoset")) {
+            try {
+                if (flavor.getRepresentationClass().getName().equals(STR_SRC)) {
+                    return FastInfosetReflection.FastInfosetSource_new(
+                        dataSource.getInputStream());
+                }
+            }
+            catch (Exception e) {
+                throw new IOException(e.getMessage());
+            }
+        }
+        return null;
+    }
+
+    public Object getContent(DataSource dataSource) throws IOException {
+        try {
+            return FastInfosetReflection.FastInfosetSource_new(
+                dataSource.getInputStream());
+        }
+        catch (Exception e) {
+            throw new IOException(e.getMessage());
+        }
+    }
+
+    /**
+     * construct an object from a byte stream
+     * (similar semantically to previous method, we are deciding
+     *  which one to support)
+     */
+    public void writeTo(Object obj, String mimeType, OutputStream os)
+        throws IOException
+    {
+        if (!mimeType.equals("application/fastinfoset")) {
+            throw new IOException("Invalid content type \"" + mimeType
+                + "\" for FastInfosetDCH");
+        }
+
+        try {
+            InputStream is = FastInfosetReflection.FastInfosetSource_getInputStream(
+                (Source) obj);
+
+            int n; byte[] buffer = new byte[4096];
+            while ((n = is.read(buffer)) != -1) {
+                os.write(buffer, 0, n);
+            }
+        }
+        catch (Exception ex) {
+            throw new IOException(
+                "Error copying FI source to output stream " + ex.getMessage());
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/GifDataContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/GifDataContentHandler.java
new file mode 100644
index 0000000..30e5154
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/GifDataContentHandler.java
@@ -0,0 +1,120 @@
+/*
+ * $Id: GifDataContentHandler.java,v 1.15 2006/01/27 12:49:26 vj135062 Exp $
+ * $Revision: 1.15 $
+ * $Date: 2006/01/27 12:49:26 $
+ */
+
+/*
+ * Copyright 2006-2007 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.awt.datatransfer.DataFlavor;
+import java.io.*;
+
+import java.awt.image.BufferedImage;
+import java.awt.*;
+
+import javax.activation.*;
+
+/**
+ * DataContentHandler for image/gif.
+ *
+ * @author Ana Lindstrom-Tamer
+ */
+public class GifDataContentHandler extends Component implements DataContentHandler {
+    private static ActivationDataFlavor myDF =
+        new ActivationDataFlavor(
+            java.awt.Image.class,
+            "image/gif",
+            "GIF Image");
+
+    protected ActivationDataFlavor getDF() {
+        return myDF;
+    }
+
+    /**
+     * Return the DataFlavors for this <code>DataContentHandler</code>.
+     *
+     * @return The DataFlavors
+     */
+    public DataFlavor[] getTransferDataFlavors() { // throws Exception;
+        return new DataFlavor[] { getDF()};
+    }
+
+    /**
+     * Return the Transfer Data of type DataFlavor from InputStream.
+     *
+     * @param df The DataFlavor
+     * @param ins The InputStream corresponding to the data
+     * @return String object
+     */
+    public Object getTransferData(DataFlavor df, DataSource ds)
+        throws IOException {
+        // use myDF.equals to be sure to get ActivationDataFlavor.equals,
+        // which properly ignores Content-Type parameters in comparison
+        if (getDF().equals(df))
+            return getContent(ds);
+        else
+            return null;
+    }
+
+    public Object getContent(DataSource ds) throws IOException {
+        InputStream is = ds.getInputStream();
+        int pos = 0;
+        int count;
+        byte buf[] = new byte[1024];
+
+        while ((count = is.read(buf, pos, buf.length - pos)) != -1) {
+            pos += count;
+            if (pos >= buf.length) {
+                int size = buf.length;
+                if (size < 256*1024)
+                    size += size;
+                else
+                    size += 256*1024;
+                byte tbuf[] = new byte[size];
+                System.arraycopy(buf, 0, tbuf, 0, pos);
+                buf = tbuf;
+            }
+        }
+        Toolkit tk = Toolkit.getDefaultToolkit();
+        return tk.createImage(buf, 0, pos);
+    }
+
+    /**
+     * Write the object to the output stream, using the specified MIME type.
+     */
+    public void writeTo(Object obj, String type, OutputStream os)
+                        throws IOException {
+        if (!(obj instanceof Image))
+            throw new IOException("\"" + getDF().getMimeType() +
+                "\" DataContentHandler requires Image object, " +
+                "was given object of type " + obj.getClass().toString());
+
+        throw new IOException(getDF().getMimeType() + " encoding not supported");
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ImageDataContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ImageDataContentHandler.java
new file mode 100644
index 0000000..23e957e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ImageDataContentHandler.java
@@ -0,0 +1,174 @@
+/*
+ * $Id: ImageDataContentHandler.java,v 1.5 2006/01/27 12:49:26 vj135062 Exp $
+ * $Revision: 1.5 $
+ * $Date: 2006/01/27 12:49:26 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.awt.*;
+import java.awt.datatransfer.DataFlavor;
+import java.awt.image.BufferedImage;
+import java.io.*;
+import java.util.Iterator;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.activation.*;
+import javax.imageio.ImageIO;
+import javax.imageio.ImageWriter;
+import javax.imageio.stream.ImageOutputStream;
+
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class ImageDataContentHandler extends Component
+    implements DataContentHandler {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    private DataFlavor[] flavor;
+
+    public ImageDataContentHandler() {
+        String[] mimeTypes = ImageIO.getReaderMIMETypes();
+        flavor = new DataFlavor[mimeTypes.length];
+        for(int i=0; i < mimeTypes.length; i++) {
+            flavor[i] = new ActivationDataFlavor(
+                java.awt.Image.class, mimeTypes[i], "Image");
+        }
+    }
+
+    /**
+     * Returns an array of DataFlavor objects indicating the flavors the
+     * data can be provided in. The array should be ordered according to
+     * preference for providing the data (from most richly descriptive to
+     * least descriptive).
+     *
+     * @return The DataFlavors.
+     */
+    public DataFlavor[] getTransferDataFlavors() {
+        return flavor;
+    }
+
+    /**
+     * Returns an object which represents the data to be transferred.
+     * The class of the object returned is defined by the representation class
+     * of the flavor.
+     *
+     * @param df The DataFlavor representing the requested type.
+     * @param ds The DataSource representing the data to be converted.
+     * @return The constructed Object.
+     */
+    public Object getTransferData(DataFlavor df, DataSource ds)
+        throws IOException {
+        for (int i=0; i < flavor.length; i++) {
+            if (flavor[i].equals(df)) {
+                return getContent(ds);
+            }
+        }
+        return null;
+    }
+
+    /**
+     * Return an object representing the data in its most preferred form.
+     * Generally this will be the form described by the first DataFlavor
+     * returned by the <code>getTransferDataFlavors</code> method.
+     *
+     * @param ds The DataSource representing the data to be converted.
+     * @return The constructed Object.
+     */
+    public Object getContent(DataSource ds) throws IOException {
+        return ImageIO.read(new BufferedInputStream(ds.getInputStream()));
+    }
+
+    /**
+     * Convert the object to a byte stream of the specified MIME type
+     * and write it to the output stream.
+     *
+     * @param obj   The object to be converted.
+     * @param mimeType  The requested MIME type of the resulting byte stream.
+     * @param os    The output stream into which to write the converted
+     *          byte stream.
+     */
+
+    public void writeTo(Object obj, String type, OutputStream os)
+        throws IOException {
+
+        try {
+            BufferedImage bufImage = null;
+            if (obj instanceof BufferedImage) {
+                bufImage = (BufferedImage)obj;
+            } else if (obj instanceof Image) {
+                bufImage = render((Image)obj);
+            } else {
+                log.log(Level.SEVERE,
+                    "SAAJ0520.soap.invalid.obj.type",
+                    new String[] { obj.getClass().toString() });
+                throw new IOException(
+                    "ImageDataContentHandler requires Image object, "
+                    + "was given object of type "
+                    + obj.getClass().toString());
+            }
+            ImageWriter writer = null;
+            Iterator i = ImageIO.getImageWritersByMIMEType(type);
+            if (i.hasNext()) {
+                writer = (ImageWriter)i.next();
+            }
+            if (writer != null) {
+                ImageOutputStream stream = null;
+                stream = ImageIO.createImageOutputStream(os);
+                writer.setOutput(stream);
+                writer.write(bufImage);
+                stream.close();
+            } else {
+                log.log(Level.SEVERE, "SAAJ0526.soap.unsupported.mime.type",
+                    new String[] { type });
+                throw new IOException("Unsupported mime type:"+ type);
+            }
+        } catch (Exception e) {
+            log.severe("SAAJ0525.soap.cannot.encode.img");
+            throw new IOException("Unable to encode the image to a stream "
+                + e.getMessage());
+        }
+    }
+
+
+    private BufferedImage render(Image img) throws InterruptedException {
+
+        MediaTracker tracker = new MediaTracker(this);
+        tracker.addImage(img, 0);
+        tracker.waitForAll();
+        BufferedImage bufImage = new BufferedImage(img.getWidth(null),
+            img.getHeight(null), BufferedImage.TYPE_INT_RGB);
+        Graphics g = bufImage.createGraphics();
+        g.drawImage(img, 0, 0, null);
+        g.dispose();
+        return bufImage;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/JpegDataContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/JpegDataContentHandler.java
new file mode 100644
index 0000000..e1cae6c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/JpegDataContentHandler.java
@@ -0,0 +1,165 @@
+/*
+ * $Id: JpegDataContentHandler.java,v 1.15 2006/01/27 12:49:26 vj135062 Exp $
+ * $Revision: 1.15 $
+ * $Date: 2006/01/27 12:49:26 $
+ */
+
+/*
+ * Copyright 2006-2007 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.awt.*;
+import java.awt.datatransfer.DataFlavor;
+import java.awt.image.BufferedImage;
+import java.io.*;
+
+import javax.activation.*;
+
+import javax.imageio.ImageIO;
+
+/**
+ * JAF data handler for Jpeg content
+ *
+ * @author Ana Lindstrom-Tamer
+ */
+
+public class JpegDataContentHandler
+    extends Component
+    implements DataContentHandler {
+    public final String STR_SRC = "java.awt.Image";
+
+    /**
+     * return the DataFlavors for this <code>DataContentHandler</code>
+     * @return The DataFlavors.
+     */
+    public DataFlavor[] getTransferDataFlavors() { // throws Exception;
+        DataFlavor flavors[] = new DataFlavor[1];
+
+        try {
+            flavors[0] =
+                new ActivationDataFlavor(
+                    Class.forName(STR_SRC),
+                    "image/jpeg",
+                    "JPEG");
+        } catch (Exception e) {
+            System.out.println(e);
+        }
+
+        return flavors;
+    }
+
+    /**
+     * return the Transfer Data of type DataFlavor from InputStream
+     * @param df The DataFlavor.
+     * @param ins The InputStream corresponding to the data.
+     * @return The constructed Object.
+     */
+    public Object getTransferData(DataFlavor df, DataSource ds) {
+
+        // this is sort of hacky, but will work for the
+        // sake of testing...
+        if (df.getMimeType().startsWith("image/jpeg")) {
+            if (df.getRepresentationClass().getName().equals(STR_SRC)) {
+                InputStream inputStream = null;
+                BufferedImage jpegLoadImage = null;
+
+                try {
+                    inputStream = ds.getInputStream();
+                    jpegLoadImage = ImageIO.read(inputStream);
+
+                } catch (Exception e) {
+                    System.out.println(e);
+                }
+
+                return jpegLoadImage;
+            }
+        }
+        return null;
+    }
+
+    /**
+     *
+     */
+    public Object getContent(DataSource ds) { // throws Exception;
+        InputStream inputStream = null;
+        BufferedImage jpegLoadImage = null;
+
+        try {
+            inputStream = ds.getInputStream();
+            jpegLoadImage = ImageIO.read(inputStream);
+
+        } catch (Exception e) {
+        }
+
+        return (Image) jpegLoadImage;
+    }
+
+    /**
+     * construct an object from a byte stream
+     * (similar semantically to previous method, we are deciding
+     *  which one to support)
+     */
+    public void writeTo(Object obj, String mimeType, OutputStream os)
+        throws IOException {
+        if (!mimeType.equals("image/jpeg"))
+            throw new IOException(
+                "Invalid content type \""
+                    + mimeType
+                    + "\" for ImageContentHandler");
+
+        if (obj.equals(null)) {
+            throw new IOException("Null object for ImageContentHandler");
+        }
+
+        try {
+            BufferedImage bufImage = null;
+            if (obj instanceof BufferedImage) {
+                bufImage = (BufferedImage) obj;
+
+            } else {
+                Image img = (Image) obj;
+                MediaTracker tracker = new MediaTracker(this);
+                tracker.addImage(img, 0);
+                tracker.waitForAll();
+                if (tracker.isErrorAny()) {
+                        throw new IOException("Error while loading image");
+                }
+                bufImage =
+                    new BufferedImage(
+                        img.getWidth(null),
+                        img.getHeight(null),
+                        BufferedImage.TYPE_INT_RGB);
+
+                Graphics g = bufImage.createGraphics();
+                g.drawImage(img, 0, 0, null);
+            }
+            ImageIO.write(bufImage, "jpeg", os);
+        } catch (Exception ex) {
+            throw new IOException(
+                "Unable to run the JPEG Encoder on a stream "
+                    + ex.getMessage());
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/LocalStrings.properties b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/LocalStrings.properties
new file mode 100644
index 0000000..bbb0d0f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/LocalStrings.properties
@@ -0,0 +1,83 @@
+# SAAJ ResourceBundle properties file
+# Contains Log messages for soap pkg
+# Error messages
+SAAJ0501.soap.data.handler.err=SAAJ0501: Data handler error: {0}
+SAAJ0502.soap.no.handler.for.attachment=SAAJ0502: No data handler associated with this attachment
+SAAJ0503.soap.no.null.to.dataHandler=SAAJ0503: Null dataHandler argument to setDataHandler
+SAAJ0504.soap.cannot.externalize.attachment=SAAJ0504: Unable to externalize attachment
+SAAJ0505.soap.cannot.copy.mime.hdr=SAAJ0505: Unable to copy MIME header
+SAAJ0506.soap.cannot.copy.mime.hdrs.into.attachment=SAAJ0506: Unable to copy MIME headers into attachment
+SAAJ0507.soap.cannot.create.handler=SAAJ0507: Unable to create DataHandler for {0}
+SAAJ0508.soap.cannot.register.handlers=SAAJ050: Unable to register handlers in JAF command map
+
+SAAJ0510.soap.cannot.create.envelope=SAAJ0510: Unable to create envelope from given source
+SAAJ0511.soap.cannot.create.envelope=SAAJ0511: Unable to create envelope from given source
+SAAJ0512.soap.incorrect.factory.used=SAAJ0512: Unable to create envelope: incorrect factory used during tree construction
+SAAJ0513.soap.unknown.ns=SAAJ0513: Unable to create envelope from given source because the namespace was not recognized
+SAAJ0514.soap.root.elem.not.named.envelope=SAAJ0514: Unable to create envelope from given source because the root element is not named Envelope
+SAAJ0515.source.reset.exception=SAAJ0515: Unable to reset the soap-part content source
+
+SAAJ0520.soap.invalid.obj.type=SAAJ0520: DataContentHandler requires Image object, but was given object of type {0}
+SAAJ0521.soap.set.Content-Type=SAAJ0521: Content-Type set to {0}
+SAAJ0522.soap.invalid.type.for.img.handler=SAAJ0522: Invalid content-type {0} for ImageContentHandler
+SAAJ0523.soap.null.obj.for.img.handler=SAAJ0523: Null object for ImageContentHandler
+SAAJ0524.soap.cannot.run.jpg.encoder=SAAJ0524: Unable to run the JPEG Encoder on a stream
+SAAJ0525.soap.cannot.encode.img=SAAJ0525: Unable to encode image to a stream
+SAAJ0526.soap.unsupported.mime.type=SAAJ0526: Unsupported mime type {0}
+
+SAAJ0530.soap.unknown.Content-Type=SAAJ0530: Unrecognized Content-Type
+SAAJ0531.soap.cannot.parse.Content-Type=SAAJ0531: Unable to parse content type
+SAAJ0532.soap.no.Content-Type=SAAJ0532: Absent Content-Type
+SAAJ0533.soap.incorrect.Content-Type=SAAJ0533: Cannot create message: incorrect content-type for SOAP version. Got {0}, but expected {1}
+SAAJ0534.soap.unknown.Content-Type=SAAJ0534: Unrecognized Content-Type
+SAAJ0535.soap.cannot.internalize.message=SAAJ0535: Unable to internalize message
+SAAJ0536.soap.content-type.mustbe.multipart=SAAJ0536: Content-Type needs to be Multipart/Related and with type=text/xml or application/soap+xml
+SAAJ0537.soap.invalid.content-type=SAAJ0537: Invalid Content-Type. Could be an error message instead of a SOAP message
+SAAJ0538.soap.cannot.convert.msg.to.multipart.obj=SAAJ0538: Unable to convert SOAP message into a Multipart object
+SAAJ0539.soap.cannot.get.header.stream=SAAJ0539: Unable to get header stream in saveChanges
+SAAJ0540.soap.err.saving.multipart.msg=SAAJ0540: Error during saving a multipart message
+SAAJ0541.soap.fragment.not.bound.to.part=SAAJ0541: Could not complete operation. Fragment not bound to SOAP part
+SAAJ0542.soap.proc.instructions.not.allowed.in.docs=SAAJ0542: Processing Instructions are not allowed in SOAP documents
+SAAJ0543.soap.entity.refs.not.allowed.in.docs=SAAJ0543: Entity References are not allowed in SOAP documents
+SAAJ0544.soap.no.valid.reader.for.src=SAAJ0544: Source does not have a valid Reader or InputStream
+SAAJ0545.soap.cannot.set.src.for.part=SAAJ0545: Error setting the source for SOAPPart
+SAAJ0546.soap.stream.incorrect.type=SAAJ0546: Internal error: stream not of the right type
+SAAJ0547.soap.cannot.externalize=SAAJ0547: Error while trying to externalize
+SAAJ0548.soap.cannot.externalize.hdr=SAAJ0548: Unable to externalize header
+SAAJ0549.soap.part.invalid.Content-Type=SAAJ0549: Bad Content-Type for SOAP Part {0}
+SAAJ0550.soap.null.headers=SAAJ0550: Cannot create message: Headers can't be null
+SAAJ0551.soap.unsupported.encoding=SAAJ0551: Unsupported encoding {0}
+SAAJ0552.soap.xml.decl.parsing.failed=SAAJ0552: XML declaration parsing failed
+SAAJ0553.soappart.renamenode.not.supported=SAAJ0553: renameNode on SOAPPart not supported
+SAAJ0554.soappart.normalizeDocument.not.supported=SAAJ0554: normalizeDocument on SOAPPart not supported
+SAAJ0555.soappart.getDomConfig.not.supported=SAAJ0555: getDomConfig on SOAPPart not supported
+SAAJ0556.soappart.adoptNode.not.supported=SAAJ0556: adoptNode on SOAPPart not supported
+SAAJ0557.soappart.setDocumentURI.not.supported=SAAJ0557: setDocumentURI on SOAPPart not supported
+SAAJ0558.soappart.getDocumentURI.not.supported=SAAJ0558: getDocumentURI on SOAPPart not supported
+SAAJ0559.soappart.setStrictErrorChecking.not.supported=SAAJ0559: setStrictErrorChecking on SOAPPart not supported
+SAAJ0560.soappart.getInputEncoding.not.supported=SAAJ0560: getInputEncoding on SOAPPart not supported
+SAAJ0561.soappart.getXmlEncoding.not.supported=SAAJ0561: getXmlEncoding on SOAPPart not supported
+SAAJ0562.soappart.getXmlStandalone.not.supported=SAAJ0562: getXmlStandalone on SOAPPart not supported
+SAAJ0563.soappart.setXmlStandalone.not.supported=SAAJ0563: setXmlStandalone on SOAPPart not supported
+SAAJ0564.soappart.getXmlVersion.not.supported=SAAJ0564: getXmlVersion on SOAPPart not supported
+SAAJ0565.soappart.setXmlVersion.not.supported=SAAJ0565: setXmlVersion on SOAPPart not supported
+SAAJ0566.soappart.getStrictErrorChecking.not.supported=SAAJ0566: getStrictErrorChecking on SOAPPart not supported
+SAAJ0567.soap.null.input=SAAJ0567: Null {0} argument to {1}
+SAAJ0568.soap.unsupported.protocol=SAAJ0568: Protocol {0} does not support {1}
+SAAJ0569.soap.unknown.protocol=SAAJ0569: Unknown Protocol {0} specified for creating {1}
+SAAJ0570.soappart.parent.element.not.defined=SAAJ0570: The parent element of a soap part is not defined
+SAAJ0571.soappart.setValue.not.defined=SAAJ0571: Setting value of a soap part is not defined
+SAAJ0572.soap.no.content.for.attachment=SAAJ0572: No data handler/content associated with this attachment
+SAAJ0573.soap.attachment.getrawbytes.ioexception=SAAJ0573: IOException while reading the raw attachment content
+SAAJ0574.soap.attachment.datahandler.ioexception=SAAJ0574: IOException while trying to obtain the inputstream from datahandler for this attachment
+SAAJ0575.soap.attachment.getcontent.exception=SAAJ0575: Exception while trying to retrieveing content for this attachment
+SAAJ0576.soap.attachment.setrawcontent.exception=SAAJ0576: Exception while trying to set the Raw content for this attachment
+SAAJ0577.soap.attachment.getrawcontent.exception=SAAJ0577: Exception while trying to get the Raw content for this attachment
+SAAJ0578.soap.attachment.setbase64content.exception=SAAJ0578: Exception while trying to set the Decoded content for this attachment
+SAAJ0579.soap.attachment.getbase64content.exception=SAAJ0579: Exception while trying to get the Encoded content for this attachment
+SAAJ0590.soap.unable.to.locate.attachment=SAAJ0590: Unable to locate attachment with cid {0}
+SAAJ0591.soap.exception.in.set.property=SAAJ0591: Exception {0}  when trying to set Property {1} on SOAP Message
+
+# Info messages
+SAAJ0580.soap.set.Content-Type=SAAJ0580: Content-Type set to {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MessageFactoryImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MessageFactoryImpl.java
new file mode 100644
index 0000000..8a8920d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MessageFactoryImpl.java
@@ -0,0 +1,119 @@
+/*
+ * $Id: MessageFactoryImpl.java,v 1.23 2006/01/27 12:49:27 vj135062 Exp $
+ * $Revision: 1.23 $
+ * $Date: 2006/01/27 12:49:27 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.io.*;
+import java.util.logging.Logger;
+
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ContentType;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ParseException;
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.ver1_1.Message1_1Impl;
+import com.sun.xml.internal.messaging.saaj.soap.ver1_2.Message1_2Impl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+import com.sun.xml.internal.messaging.saaj.util.TeeInputStream;
+
+/**
+ * A factory for creating SOAP messages.
+ *
+ * Converted to a placeholder for common functionality between SOAP
+ * implementations.
+ *
+ * @author Phil Goodwin (phil.goodwin@sun.com)
+ */
+public class MessageFactoryImpl extends MessageFactory {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    protected static OutputStream listener;
+
+    protected boolean lazyAttachments = false;
+
+    public static OutputStream listen(OutputStream newListener) {
+        OutputStream oldListener = listener;
+        listener = newListener;
+        return oldListener;
+    }
+
+    public SOAPMessage createMessage() throws SOAPException {
+        throw new UnsupportedOperationException();
+    }
+
+    public SOAPMessage createMessage(boolean isFastInfoset,
+        boolean acceptFastInfoset) throws SOAPException
+    {
+        throw new UnsupportedOperationException();
+    }
+
+    public SOAPMessage createMessage(MimeHeaders headers, InputStream in)
+        throws SOAPException, IOException {
+        String contentTypeString = MessageImpl.getContentType(headers);
+
+        if (listener != null) {
+            in = new TeeInputStream(in, listener);
+        }
+
+        try {
+            ContentType contentType = new ContentType(contentTypeString);
+            int stat = MessageImpl.identifyContentType(contentType);
+
+            if (MessageImpl.isSoap1_1Content(stat)) {
+                return new Message1_1Impl(headers,contentType,stat,in);
+            } else if (MessageImpl.isSoap1_2Content(stat)) {
+                return new Message1_2Impl(headers,contentType,stat,in);
+            } else {
+                log.severe("SAAJ0530.soap.unknown.Content-Type");
+                throw new SOAPExceptionImpl("Unrecognized Content-Type");
+            }
+        } catch (ParseException e) {
+            log.severe("SAAJ0531.soap.cannot.parse.Content-Type");
+            throw new SOAPExceptionImpl(
+                "Unable to parse content type: " + e.getMessage());
+        }
+    }
+
+    protected static final String getContentType(MimeHeaders headers) {
+        String[] values = headers.getHeader("Content-Type");
+        if (values == null)
+            return null;
+        else
+            return values[0];
+    }
+
+    public void setLazyAttachmentOptimization(boolean flag) {
+        lazyAttachments = flag;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MessageImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MessageImpl.java
new file mode 100644
index 0000000..6f49a1c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MessageImpl.java
@@ -0,0 +1,1333 @@
+/*
+ * $Id: MessageImpl.java,v 1.3 2006/08/04 09:24:24 ashutoshshahi Exp $
+ * $Revision: 1.3 $
+ * $Date: 2006/08/04 09:24:24 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.io.*;
+import java.util.*;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.activation.DataHandler;
+import javax.activation.DataSource;
+import javax.xml.soap.*;
+import javax.xml.transform.Source;
+import javax.xml.transform.stream.StreamSource;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.Header;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.*;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.util.*;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.MessagingException;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.EnvelopeImpl;
+import com.sun.xml.internal.messaging.saaj.util.*;
+
+/**
+ * The message implementation for SOAP messages with
+ * attachments. Messages for specific profiles will likely extend this
+ * MessageImpl class and add more value for that particular profile.
+ *
+ * @author Anil Vijendran (akv@eng.sun.com)
+ * @author Rajiv Mordani (rajiv.mordani@sun.com)
+ * @author Manveen Kaur (manveen.kaur@sun.com)
+ */
+
+public abstract class MessageImpl
+    extends SOAPMessage
+    implements SOAPConstants {
+
+
+    public static final String CONTENT_ID             = "Content-ID";
+    public static final String CONTENT_LOCATION       = "Content-Location";
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    protected static final int PLAIN_XML_FLAG      = 1;      // 00001
+    protected static final int MIME_MULTIPART_FLAG = 2;      // 00010
+    protected static final int SOAP1_1_FLAG = 4;             // 00100
+    protected static final int SOAP1_2_FLAG = 8;             // 01000
+    protected static final int MIME_MULTIPART_XOP_FLAG = 14; // 01110
+    protected static final int XOP_FLAG = 13;                // 01101
+    protected static final int FI_ENCODED_FLAG     = 16;     // 10000
+
+    protected MimeHeaders headers;
+    protected SOAPPartImpl soapPart;
+    protected FinalArrayList attachments;
+    protected boolean saved = false;
+    protected byte[] messageBytes;
+    protected int messageByteCount;
+    protected HashMap properties = new HashMap();
+
+    // used for lazy attachment initialization
+    protected MimeMultipart multiPart = null;
+    protected boolean attachmentsInitialized = false;
+
+    /**
+     * True if this part is encoded using Fast Infoset.
+     * MIME -> application/fastinfoset
+     */
+    protected boolean isFastInfoset = false;
+
+    /**
+     * True if the Accept header of this message includes
+     * application/fastinfoset
+     */
+    protected boolean acceptFastInfoset = false;
+
+    protected MimeMultipart mmp = null;
+
+    // if attachments are present, don't read the entire message in byte stream in saveTo()
+    private boolean optimizeAttachmentProcessing = true;
+
+    // switch back to old MimeMultipart incase of problem
+    private static boolean switchOffBM = false;
+    private static boolean switchOffLazyAttachment = false;
+
+    static {
+        try {
+            String s = System.getProperty("saaj.mime.optimization");
+            if ((s != null) && s.equals("false")) {
+                switchOffBM = true;
+            }
+            s = System.getProperty("saaj.lazy.mime.optimization");
+            if ((s != null) && s.equals("false")) {
+                switchOffLazyAttachment = true;
+            }
+        } catch (SecurityException ex) {
+            // ignore it
+        }
+    }
+
+    //property to indicate optimized serialization for lazy attachments
+    private boolean lazyAttachments = false;
+
+    // most of the times, Content-Types are already all lower cased.
+    // String.toLowerCase() works faster in this case, so even if you
+    // are only doing one comparison, it pays off to use String.toLowerCase()
+    // than String.equalsIgnoreCase(). When you do more than one comparison,
+    // the benefits of String.toLowerCase() dominates.
+    //
+    //
+    // for FI,
+    //   use application/fastinfoset for SOAP 1.1
+    //   use application/soap+fastinfoset for SOAP 1.2
+    // to speed up comparisons, test methods always use lower cases.
+
+    /**
+     * @param primary
+     *      must be all lower case
+     * @param sub
+     *      must be all lower case
+     */
+    private static boolean isSoap1_1Type(String primary, String sub) {
+        return primary.equals("text") && sub.equals("xml")
+            || primary.equals("application")
+               && sub.equals("fastinfoset");
+    }
+
+    /**
+     * @param type
+     *      must be all lower case
+     */
+    private static boolean isEqualToSoap1_1Type(String type) {
+        return type.startsWith("text/xml") ||
+               type.startsWith("application/fastinfoset");
+    }
+
+    /**
+     * @param primary
+     *      must be all lower case
+     * @param sub
+     *      must be all lower case
+     */
+    private static boolean isSoap1_2Type(String primary, String sub) {
+        return primary.equals("application")
+               && (sub.equals("soap+xml")
+                   || sub.equals("soap+fastinfoset"));
+    }
+
+    /**
+     * @param type
+     *      must be all lower case
+     */
+    private static boolean isEqualToSoap1_2Type(String type) {
+        return type.startsWith("application/soap+xml") ||
+               type.startsWith("application/soap+fastinfoset");
+    }
+
+    /**
+      * Construct a new message. This will be invoked before message
+      * sends.
+      */
+    protected MessageImpl() {
+        this(false, false);
+        attachmentsInitialized = true;
+    }
+
+    /**
+      * Construct a new message. This will be invoked before message
+      * sends.
+      */
+    protected MessageImpl(boolean isFastInfoset, boolean acceptFastInfoset) {
+        this.isFastInfoset = isFastInfoset;
+        this.acceptFastInfoset = acceptFastInfoset;
+
+        headers = new MimeHeaders();
+        headers.setHeader("Accept", getExpectedAcceptHeader());
+    }
+
+    /**
+     * Shallow copy.
+     */
+    protected MessageImpl(SOAPMessage msg) {
+        if (!(msg instanceof MessageImpl)) {
+            // don't know how to handle this.
+        }
+        MessageImpl src = (MessageImpl) msg;
+        this.headers = src.headers;
+        this.soapPart = src.soapPart;
+        this.attachments = src.attachments;
+        this.saved = src.saved;
+        this.messageBytes = src.messageBytes;
+        this.messageByteCount = src.messageByteCount;
+        this.properties = src.properties;
+    }
+
+    /**
+     * @param stat
+     *      the mask value obtained from {@link #identifyContentType(ContentType)}
+     */
+    protected static boolean isSoap1_1Content(int stat) {
+        return (stat & SOAP1_1_FLAG) != 0;
+    }
+
+    /**
+     * @param stat
+     *      the mask value obtained from {@link #identifyContentType(ContentType)}
+     */
+    protected static boolean isSoap1_2Content(int stat) {
+        return (stat & SOAP1_2_FLAG) != 0;
+    }
+
+     private static boolean isMimeMultipartXOPPackage(ContentType contentType) {
+        String type = contentType.getParameter("type");
+        if(type==null)
+            return false;
+
+        type = type.toLowerCase();
+        if(!type.startsWith("application/xop+xml"))
+            return false;
+
+        String startinfo = contentType.getParameter("start-info");
+        if(startinfo == null)
+            return false;
+        startinfo = startinfo.toLowerCase();
+        return isEqualToSoap1_2Type(startinfo) || isEqualToSoap1_1Type(startinfo);
+    }
+
+    private static boolean isSOAPBodyXOPPackage(ContentType contentType){
+        String primary = contentType.getPrimaryType();
+        String sub = contentType.getSubType();
+
+        if (primary.equalsIgnoreCase("application")) {
+            if (sub.equalsIgnoreCase("xop+xml")) {
+                String type = getTypeParameter(contentType);
+                return isEqualToSoap1_2Type(type) || isEqualToSoap1_1Type(type);
+            }
+        }
+        return false;
+    }
+
+    /**
+     * Construct a message from an input stream. When messages are
+     * received, there's two parts -- the transport headers and the
+     * message content in a transport specific stream.
+     */
+    protected MessageImpl(MimeHeaders headers, final InputStream in)
+        throws SOAPExceptionImpl {
+        ContentType ct = parseContentType(headers);
+        init(headers,identifyContentType(ct),ct,in);
+    }
+
+    private static ContentType parseContentType(MimeHeaders headers) throws SOAPExceptionImpl {
+        final String ct;
+        if (headers != null)
+            ct = getContentType(headers);
+        else {
+            log.severe("SAAJ0550.soap.null.headers");
+            throw new SOAPExceptionImpl("Cannot create message: " +
+                                        "Headers can't be null");
+        }
+
+        if (ct == null) {
+            log.severe("SAAJ0532.soap.no.Content-Type");
+            throw new SOAPExceptionImpl("Absent Content-Type");
+        }
+        try {
+            return new ContentType(ct);
+        } catch (Throwable ex) {
+            log.severe("SAAJ0535.soap.cannot.internalize.message");
+            throw new SOAPExceptionImpl("Unable to internalize message", ex);
+        }
+    }
+
+    /**
+     * Construct a message from an input stream. When messages are
+     * received, there's two parts -- the transport headers and the
+     * message content in a transport specific stream.
+     *
+     * @param contentType
+     *      The parsed content type header from the headers variable.
+     *      This is redundant parameter, but it avoids reparsing this header again.
+     * @param stat
+     *      The result of {@link #identifyContentType(ContentType)} over
+     *      the contentType parameter. This redundant parameter, but it avoids
+     *      recomputing this information again.
+     */
+    protected MessageImpl(MimeHeaders headers, final ContentType contentType, int stat, final InputStream in) throws SOAPExceptionImpl {
+        init(headers, stat, contentType, in);
+
+    }
+
+    private void init(MimeHeaders headers, int stat, final ContentType contentType, final InputStream in) throws SOAPExceptionImpl {
+        this.headers = headers;
+
+        try {
+
+            // Set isFastInfoset/acceptFastInfoset flag based on MIME type
+            if ((stat & FI_ENCODED_FLAG) > 0) {
+                isFastInfoset = acceptFastInfoset = true;
+            }
+
+            // If necessary, inspect Accept header to set acceptFastInfoset
+            if (!isFastInfoset) {
+                String[] values = headers.getHeader("Accept");
+                if (values != null) {
+                    for (int i = 0; i < values.length; i++) {
+                        StringTokenizer st = new StringTokenizer(values[i], ",");
+                        while (st.hasMoreTokens()) {
+                            final String token = st.nextToken().trim();
+                            if (token.equalsIgnoreCase("application/fastinfoset") ||
+                                token.equalsIgnoreCase("application/soap+fastinfoset")) {
+                                acceptFastInfoset = true;
+                                break;
+                            }
+                        }
+                    }
+                }
+            }
+
+            if (!isCorrectSoapVersion(stat)) {
+                log.log(
+                    Level.SEVERE,
+                    "SAAJ0533.soap.incorrect.Content-Type",
+                    new String[] {
+                        contentType.toString(),
+                        getExpectedContentType()});
+                throw new SOAPVersionMismatchException(
+                    "Cannot create message: incorrect content-type for SOAP version. Got: "
+                        + contentType
+                        + " Expected: "
+                        + getExpectedContentType());
+            }
+
+            if ((stat & PLAIN_XML_FLAG) != 0) {
+                if (isFastInfoset) {
+                    getSOAPPart().setContent(
+                        FastInfosetReflection.FastInfosetSource_new(in));
+                } else {
+                    initCharsetProperty(contentType);
+                    getSOAPPart().setContent(new StreamSource(in));
+                }
+            }
+            else if ((stat & MIME_MULTIPART_FLAG) != 0) {
+                DataSource ds = new DataSource() {
+                    public InputStream getInputStream() {
+                        return in;
+                    }
+
+                    public OutputStream getOutputStream() {
+                        return null;
+                    }
+
+                    public String getContentType() {
+                        return contentType.toString();
+                    }
+
+                    public String getName() {
+                        return "";
+                    }
+                };
+
+                multiPart = null;
+                if (switchOffBM) {
+                    multiPart = new MimeMultipart(ds,contentType);
+                } else {
+                    multiPart = new BMMimeMultipart(ds,contentType);
+                }
+
+                String startParam = contentType.getParameter("start");
+                MimeBodyPart soapMessagePart = null;
+                String contentID = null;
+                if (switchOffBM || switchOffLazyAttachment) {
+                    if(startParam == null) {
+                        soapMessagePart = multiPart.getBodyPart(0);
+                        for (int i = 1; i < multiPart.getCount(); i++) {
+                            initializeAttachment(multiPart, i);
+                        }
+                    } else {
+                        soapMessagePart = multiPart.getBodyPart(startParam);
+                        for (int i = 0; i < multiPart.getCount(); i++) {
+                            contentID = multiPart.getBodyPart(i).getContentID();
+                            if(!contentID.equals(startParam))
+                                initializeAttachment(multiPart, i);
+                        }
+                    }
+                } else {
+                    BMMimeMultipart bmMultipart =
+                        (BMMimeMultipart)multiPart;
+                    InputStream stream = bmMultipart.initStream();
+
+                    SharedInputStream sin = null;
+                    if (stream instanceof SharedInputStream) {
+                        sin = (SharedInputStream)stream;
+                    }
+
+                    String boundary = "--" +
+                        contentType.getParameter("boundary");
+                    byte[] bndbytes = ASCIIUtility.getBytes(boundary);
+                    if (startParam == null) {
+                        soapMessagePart =
+                            bmMultipart.getNextPart(stream, bndbytes, sin);
+                        bmMultipart.removeBodyPart(soapMessagePart);
+                    } else {
+                        MimeBodyPart bp = null;
+                        try {
+                            while(!startParam.equals(contentID)) {
+                                bp = bmMultipart.getNextPart(
+                                    stream, bndbytes, sin);
+                                contentID = bp.getContentID();
+                            }
+                            soapMessagePart = bp;
+                            bmMultipart.removeBodyPart(bp);
+                        } catch (Exception e) {
+                            throw new SOAPExceptionImpl(e);
+                        }
+                    }
+                }
+
+                ContentType soapPartCType = new ContentType(
+                                            soapMessagePart.getContentType());
+                initCharsetProperty(soapPartCType);
+                String baseType = soapPartCType.getBaseType().toLowerCase();
+                if(!(isEqualToSoap1_1Type(baseType)
+                  || isEqualToSoap1_2Type(baseType)
+                  || isSOAPBodyXOPPackage(soapPartCType))) {
+                    log.log(Level.SEVERE,
+                            "SAAJ0549.soap.part.invalid.Content-Type",
+                            new Object[] {baseType});
+                    throw new SOAPExceptionImpl(
+                            "Bad Content-Type for SOAP Part : " +
+                            baseType);
+                }
+
+                SOAPPart soapPart = getSOAPPart();
+                setMimeHeaders(soapPart, soapMessagePart);
+                soapPart.setContent(isFastInfoset ?
+                     (Source) FastInfosetReflection.FastInfosetSource_new(
+                         soapMessagePart.getInputStream()) :
+                     (Source) new StreamSource(soapMessagePart.getInputStream()));
+            } else {
+                log.severe("SAAJ0534.soap.unknown.Content-Type");
+                throw new SOAPExceptionImpl("Unrecognized Content-Type");
+            }
+        } catch (Throwable ex) {
+            log.severe("SAAJ0535.soap.cannot.internalize.message");
+            throw new SOAPExceptionImpl("Unable to internalize message", ex);
+        }
+        needsSave();
+    }
+
+    public boolean isFastInfoset() {
+        return isFastInfoset;
+    }
+
+    public boolean acceptFastInfoset() {
+        return acceptFastInfoset;
+    }
+
+    public void setIsFastInfoset(boolean value) {
+        if (value != isFastInfoset) {
+            isFastInfoset = value;
+            if (isFastInfoset) {
+                acceptFastInfoset = true;
+            }
+            saved = false;      // ensure transcoding if necessary
+        }
+    }
+
+    public Object getProperty(String property) {
+        return (String) properties.get(property);
+    }
+
+    public void setProperty(String property, Object value) {
+        verify(property, value);
+        properties.put(property, value);
+    }
+
+    private void verify(String property, Object value) {
+        if (property.equalsIgnoreCase(SOAPMessage.WRITE_XML_DECLARATION)) {
+            if (!("true".equals(value) || "false".equals(value)))
+                throw new RuntimeException(
+                    property + " must have value false or true");
+
+            try {
+                EnvelopeImpl env = (EnvelopeImpl) getSOAPPart().getEnvelope();
+                if ("true".equalsIgnoreCase((String)value)) {
+                    env.setOmitXmlDecl("no");
+                } else if ("false".equalsIgnoreCase((String)value)) {
+                    env.setOmitXmlDecl("yes");
+                }
+            } catch (Exception e) {
+                log.log(Level.SEVERE, "SAAJ0591.soap.exception.in.set.property",
+                    new Object[] {e.getMessage(), "javax.xml.soap.write-xml-declaration"});
+                throw new RuntimeException(e);
+            }
+            return;
+        }
+
+        if (property.equalsIgnoreCase(SOAPMessage.CHARACTER_SET_ENCODING)) {
+            try {
+                ((EnvelopeImpl) getSOAPPart().getEnvelope()).setCharsetEncoding((String)value);
+            } catch (Exception e) {
+                log.log(Level.SEVERE, "SAAJ0591.soap.exception.in.set.property",
+                    new Object[] {e.getMessage(), "javax.xml.soap.character-set-encoding"});
+                throw new RuntimeException(e);
+            }
+        }
+    }
+
+    protected abstract boolean isCorrectSoapVersion(int contentTypeId);
+
+    protected abstract String getExpectedContentType();
+    protected abstract String getExpectedAcceptHeader();
+
+    /**
+     * Sniffs the Content-Type header so that we can determine how to process.
+     *
+     * <p>
+     * In the absence of type attribute we assume it to be text/xml.
+     * That would mean we're easy on accepting the message and
+     * generate the correct thing (as the SWA spec also specifies
+     * that the type parameter should always be text/xml)
+     *
+     * @return
+     *      combination of flags, such as PLAIN_XML_CODE and MIME_MULTIPART_CODE.
+     */
+    // SOAP1.2 allow SOAP1.2 content type
+    static int identifyContentType(ContentType contentType)
+        throws SOAPExceptionImpl {
+        // TBD
+        //    Is there anything else we need to verify here?
+
+        String primary = contentType.getPrimaryType().toLowerCase();
+        String sub = contentType.getSubType().toLowerCase();
+
+        if (primary.equals("multipart")) {
+            if (sub.equals("related")) {
+                String type = getTypeParameter(contentType);
+                if (isEqualToSoap1_1Type(type)) {
+                    return (type.equals("application/fastinfoset") ?
+                           FI_ENCODED_FLAG : 0) | MIME_MULTIPART_FLAG | SOAP1_1_FLAG;
+                }
+                else if (isEqualToSoap1_2Type(type)) {
+                    return (type.equals("application/soap+fastinfoset") ?
+                           FI_ENCODED_FLAG : 0) | MIME_MULTIPART_FLAG | SOAP1_2_FLAG;
+                } else if (isMimeMultipartXOPPackage(contentType)) {
+                    return MIME_MULTIPART_XOP_FLAG;
+                } else {
+                    log.severe("SAAJ0536.soap.content-type.mustbe.multipart");
+                    throw new SOAPExceptionImpl(
+                        "Content-Type needs to be Multipart/Related "
+                            + "and with \"type=text/xml\" "
+                            + "or \"type=application/soap+xml\"");
+                }
+            } else {
+                log.severe("SAAJ0537.soap.invalid.content-type");
+                throw new SOAPExceptionImpl(
+                    "Invalid Content-Type: " + primary + '/' + sub);
+            }
+        }
+        else if (isSoap1_1Type(primary, sub)) {
+            return (primary.equalsIgnoreCase("application")
+                    && sub.equalsIgnoreCase("fastinfoset") ?
+                        FI_ENCODED_FLAG : 0)
+                   | PLAIN_XML_FLAG | SOAP1_1_FLAG;
+        }
+        else if (isSoap1_2Type(primary, sub)) {
+            return (primary.equalsIgnoreCase("application")
+                    && sub.equalsIgnoreCase("soap+fastinfoset") ?
+                        FI_ENCODED_FLAG : 0)
+                   | PLAIN_XML_FLAG | SOAP1_2_FLAG;
+        } else if(isSOAPBodyXOPPackage(contentType)){
+            return XOP_FLAG;
+        } else {
+            log.severe("SAAJ0537.soap.invalid.content-type");
+            throw new SOAPExceptionImpl(
+                "Invalid Content-Type:"
+                    + primary
+                    + '/'
+                    + sub
+                    + ". Is this an error message instead of a SOAP response?");
+        }
+    }
+
+    /**
+     * Obtains the type parameter of the Content-Type header. Defaults to "text/xml".
+     */
+    private static String getTypeParameter(ContentType contentType) {
+        String p = contentType.getParameter("type");
+        if(p!=null)
+            return p.toLowerCase();
+        else
+            return "text/xml";
+    }
+
+    public MimeHeaders getMimeHeaders() {
+        return this.headers;
+    }
+
+    final static String getContentType(MimeHeaders headers) {
+        String[] values = headers.getHeader("Content-Type");
+        if (values == null)
+            return null;
+        else
+            return values[0];
+    }
+
+    /*
+     * Get the complete ContentType value along with optional parameters.
+     */
+    public String getContentType() {
+        return getContentType(this.headers);
+    }
+
+    public void setContentType(String type) {
+        headers.setHeader("Content-Type", type);
+        needsSave();
+    }
+
+    private ContentType ContentType() {
+        ContentType ct = null;
+        try {
+            ct = new ContentType(getContentType());
+        } catch (Exception e) {
+            // what to do here?
+        }
+        return ct;
+    }
+
+    /*
+     * Return the MIME type string, without the parameters.
+     */
+    public String getBaseType() {
+        return ContentType().getBaseType();
+    }
+
+    public void setBaseType(String type) {
+        ContentType ct = ContentType();
+        ct.setParameter("type", type);
+        headers.setHeader("Content-Type", ct.toString());
+        needsSave();
+    }
+
+    public String getAction() {
+        return ContentType().getParameter("action");
+    }
+
+    public void setAction(String action) {
+        ContentType ct = ContentType();
+        ct.setParameter("action", action);
+        headers.setHeader("Content-Type", ct.toString());
+        needsSave();
+    }
+
+    public String getCharset() {
+        return ContentType().getParameter("charset");
+    }
+
+    public void setCharset(String charset) {
+        ContentType ct = ContentType();
+        ct.setParameter("charset", charset);
+        headers.setHeader("Content-Type", ct.toString());
+        needsSave();
+    }
+
+    /**
+     * All write methods (i.e setters) should call this method in
+     * order to make sure that a save is necessary since the state
+     * has been modified.
+     */
+    private final void needsSave() {
+        saved = false;
+    }
+
+    public  boolean saveRequired() {
+        return saved != true;
+    }
+
+    public String getContentDescription() {
+        String[] values = headers.getHeader("Content-Description");
+        if (values != null && values.length > 0)
+            return values[0];
+        return null;
+    }
+
+    public void setContentDescription(String description) {
+        headers.setHeader("Content-Description", description);
+        needsSave();
+    }
+
+    public abstract SOAPPart getSOAPPart();
+
+    public void removeAllAttachments() {
+        try {
+            initializeAllAttachments();
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+
+        if (attachments != null) {
+            attachments.clear();
+            needsSave();
+        }
+    }
+
+    public int countAttachments() {
+        try {
+            initializeAllAttachments();
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+        if (attachments != null)
+            return attachments.size();
+        return 0;
+    }
+
+    public void addAttachmentPart(AttachmentPart attachment) {
+        try {
+            initializeAllAttachments();
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+        if (attachments == null)
+            attachments = new FinalArrayList();
+
+        attachments.add(attachment);
+
+        needsSave();
+    }
+
+    static private final Iterator nullIter = Collections.EMPTY_LIST.iterator();
+
+    public Iterator getAttachments() {
+        try {
+            initializeAllAttachments();
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+        if (attachments == null)
+            return nullIter;
+        return attachments.iterator();
+    }
+
+    private class MimeMatchingIterator implements Iterator {
+        public MimeMatchingIterator(MimeHeaders headers) {
+            this.headers = headers;
+            this.iter = attachments.iterator();
+        }
+
+        private Iterator iter;
+        private MimeHeaders headers;
+        private Object nextAttachment;
+
+        public boolean hasNext() {
+            if (nextAttachment == null)
+                nextAttachment = nextMatch();
+            return nextAttachment != null;
+        }
+
+        public Object next() {
+            if (nextAttachment != null) {
+                Object ret = nextAttachment;
+                nextAttachment = null;
+                return ret;
+            }
+
+            if (hasNext())
+                return nextAttachment;
+
+            return null;
+        }
+
+        Object nextMatch() {
+            while (iter.hasNext()) {
+                AttachmentPartImpl ap = (AttachmentPartImpl) iter.next();
+                if (ap.hasAllHeaders(headers))
+                    return ap;
+            }
+            return null;
+        }
+
+        public void remove() {
+            iter.remove();
+        }
+    }
+
+    public Iterator getAttachments(MimeHeaders headers) {
+        try {
+            initializeAllAttachments();
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+        if (attachments == null)
+            return nullIter;
+
+        return new MimeMatchingIterator(headers);
+    }
+
+    public void removeAttachments(MimeHeaders headers) {
+        try {
+            initializeAllAttachments();
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+        if (attachments == null)
+            return ;
+
+        Iterator it =  new MimeMatchingIterator(headers);
+        while (it.hasNext()) {
+            int index = attachments.indexOf(it.next());
+            attachments.set(index, null);
+        }
+        FinalArrayList f = new FinalArrayList();
+        for (int i = 0; i < attachments.size(); i++) {
+            if (attachments.get(i) != null) {
+                f.add(attachments.get(i));
+            }
+        }
+        attachments = f;
+    }
+
+    public AttachmentPart createAttachmentPart() {
+        return new AttachmentPartImpl();
+    }
+
+    public  AttachmentPart getAttachment(SOAPElement element)
+        throws SOAPException {
+        try {
+            initializeAllAttachments();
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+        String uri;
+        String hrefAttr = element.getAttribute("href");
+        if ("".equals(hrefAttr)) {
+            Node node = getValueNodeStrict(element);
+            String swaRef = null;
+            if (node != null) {
+                swaRef = node.getValue();
+            }
+            if (swaRef == null || "".equals(swaRef)) {
+                return null;
+            } else {
+                uri = swaRef;
+            }
+        } else {
+            uri = hrefAttr;
+        }
+        return getAttachmentPart(uri);
+    }
+
+    private Node getValueNodeStrict(SOAPElement element) {
+        Node node = (Node)element.getFirstChild();
+        if (node != null) {
+            if (node.getNextSibling() == null
+                && node.getNodeType() == org.w3c.dom.Node.TEXT_NODE) {
+                return node;
+            } else {
+                return null;
+            }
+        }
+        return null;
+    }
+
+
+    private AttachmentPart getAttachmentPart(String uri) throws SOAPException {
+        AttachmentPart _part;
+        try {
+            if (uri.startsWith("cid:")) {
+                // rfc2392
+                uri = '<'+uri.substring("cid:".length())+'>';
+
+                MimeHeaders headersToMatch = new MimeHeaders();
+                headersToMatch.addHeader(CONTENT_ID, uri);
+
+                Iterator i = this.getAttachments(headersToMatch);
+                _part = (i == null) ? null : (AttachmentPart)i.next();
+            } else {
+                // try content-location
+                MimeHeaders headersToMatch = new MimeHeaders();
+                headersToMatch.addHeader(CONTENT_LOCATION, uri);
+
+                Iterator i = this.getAttachments(headersToMatch);
+                _part = (i == null) ? null : (AttachmentPart)i.next();
+            }
+
+            // try  auto-generated JAXRPC CID
+            if (_part == null) {
+                Iterator j = this.getAttachments();
+
+                while (j.hasNext()) {
+                    AttachmentPart p = (AttachmentPart)j.next();
+                    String cl = p.getContentId();
+                    if (cl != null) {
+                        // obtain the partname
+                        int eqIndex = cl.indexOf("=");
+                        if (eqIndex > -1) {
+                            cl = cl.substring(1, eqIndex);
+                            if (cl.equalsIgnoreCase(uri)) {
+                                _part = p;
+                                 break;
+                            }
+                        }
+                    }
+                }
+            }
+
+        } catch (Exception se) {
+            log.log(Level.SEVERE, "SAAJ0590.soap.unable.to.locate.attachment", new Object[] {uri});
+            throw new SOAPExceptionImpl(se);
+        }
+        return _part;
+    }
+
+    private final ByteInputStream getHeaderBytes()
+        throws IOException {
+        SOAPPartImpl sp = (SOAPPartImpl) getSOAPPart();
+        return sp.getContentAsStream();
+    }
+
+    private String convertToSingleLine(String contentType) {
+        StringBuffer buffer = new StringBuffer();
+        for (int i = 0; i < contentType.length(); i ++) {
+            char c = contentType.charAt(i);
+            if (c != '\r' && c != '\n' && c != '\t')
+                buffer.append(c);
+        }
+        return buffer.toString();
+    }
+
+    private MimeMultipart getMimeMessage() throws SOAPException {
+        try {
+            SOAPPartImpl soapPart = (SOAPPartImpl) getSOAPPart();
+            MimeBodyPart mimeSoapPart = soapPart.getMimePart();
+
+            /*
+             * Get content type from this message instead of soapPart
+             * to ensure agreement if soapPart is transcoded (XML <-> FI)
+             */
+            ContentType soapPartCtype = new ContentType(getExpectedContentType());
+
+            if (!isFastInfoset) {
+                soapPartCtype.setParameter("charset", initCharset());
+            }
+            mimeSoapPart.setHeader("Content-Type", soapPartCtype.toString());
+
+            MimeMultipart headerAndBody = null;
+
+            if (!switchOffBM && !switchOffLazyAttachment &&
+                   (multiPart != null) && !attachmentsInitialized) {
+                headerAndBody = new BMMimeMultipart();
+                headerAndBody.addBodyPart(mimeSoapPart);
+                if (attachments != null) {
+                    for (Iterator eachAttachment = attachments.iterator();
+                         eachAttachment.hasNext();) {
+                        headerAndBody.addBodyPart(
+                            ((AttachmentPartImpl) eachAttachment.next())
+                                .getMimePart());
+                    }
+                }
+                InputStream in = ((BMMimeMultipart)multiPart).getInputStream();
+                if (!((BMMimeMultipart)multiPart).lastBodyPartFound() &&
+                    !((BMMimeMultipart)multiPart).isEndOfStream()) {
+                    ((BMMimeMultipart)headerAndBody).setInputStream(in);
+                    ((BMMimeMultipart)headerAndBody).setBoundary(
+                        ((BMMimeMultipart)multiPart).getBoundary());
+                    ((BMMimeMultipart)headerAndBody).
+                        setLazyAttachments(lazyAttachments);
+                }
+
+            } else {
+                headerAndBody = new MimeMultipart();
+                headerAndBody.addBodyPart(mimeSoapPart);
+
+                for (Iterator eachAttachement = getAttachments();
+                    eachAttachement.hasNext();
+                    ) {
+                    headerAndBody.addBodyPart(
+                        ((AttachmentPartImpl) eachAttachement.next())
+                            .getMimePart());
+                }
+            }
+
+            ContentType contentType = headerAndBody.getContentType();
+
+            ParameterList l = contentType.getParameterList();
+
+            // set content type depending on SOAP version
+            l.set("type", getExpectedContentType());
+            l.set("boundary", contentType.getParameter("boundary"));
+            ContentType nct = new ContentType("multipart", "related", l);
+
+            headers.setHeader(
+                "Content-Type",
+                convertToSingleLine(nct.toString()));
+          // TBD
+          //    Set content length MIME header here.
+
+            return headerAndBody;
+        } catch (SOAPException ex) {
+            throw ex;
+        } catch (Throwable ex) {
+            log.severe("SAAJ0538.soap.cannot.convert.msg.to.multipart.obj");
+            throw new SOAPExceptionImpl(
+                "Unable to convert SOAP message into "
+                    + "a MimeMultipart object",
+                ex);
+        }
+    }
+
+    private String initCharset() {
+
+        String charset = null;
+
+        String[] cts = getMimeHeaders().getHeader("Content-Type");
+        if ((cts != null) && (cts[0] != null)) {
+            charset = getCharsetString(cts[0]);
+        }
+
+        if (charset == null) {
+            charset = (String) getProperty(CHARACTER_SET_ENCODING);
+        }
+
+        if (charset != null) {
+            return charset;
+        }
+
+        return "utf-8";
+    }
+
+    private String getCharsetString(String s) {
+        try {
+            int index = s.indexOf(";");
+            if(index < 0)
+                return null;
+            ParameterList pl = new ParameterList(s.substring(index));
+            return pl.get("charset");
+        } catch(Exception e) {
+            return null;
+        }
+    }
+
+    public void saveChanges() throws SOAPException {
+
+        // suck in all the data from the attachments and have it
+        // ready for writing/sending etc.
+
+        String charset = initCharset();
+
+        /*if (countAttachments() == 0) {*/
+        int attachmentCount = (attachments == null) ? 0 : attachments.size();
+        if (attachmentCount == 0) {
+            if (!switchOffBM && !switchOffLazyAttachment &&
+                !attachmentsInitialized && (multiPart != null)) {
+                // so there might be attachments
+                attachmentCount = 1;
+            }
+        }
+
+        try {
+            if ((attachmentCount == 0) && !hasXOPContent()) {
+                ByteInputStream in;
+                try{
+                /*
+                 * Not sure why this is called getHeaderBytes(), but it actually
+                 * returns the whole message as a byte stream. This stream could
+                 * be either XML of Fast depending on the mode.
+                 */
+                    in = getHeaderBytes();
+                    // no attachments, hence this property can be false
+                    this.optimizeAttachmentProcessing = false;
+                } catch (IOException ex) {
+                    log.severe("SAAJ0539.soap.cannot.get.header.stream");
+                    throw new SOAPExceptionImpl(
+                            "Unable to get header stream in saveChanges: ",
+                            ex);
+                }
+
+                messageBytes = in.getBytes();
+                messageByteCount = in.getCount();
+
+                headers.setHeader(
+                        "Content-Type",
+                        getExpectedContentType() +
+                        (isFastInfoset ? "" : "; charset=" + charset));
+                headers.setHeader(
+                    "Content-Length",
+                    Integer.toString(messageByteCount));
+            } else {
+                if(hasXOPContent())
+                    mmp = getXOPMessage();
+                else
+                    mmp = getMimeMessage();
+            }
+        } catch (Throwable ex) {
+            log.severe("SAAJ0540.soap.err.saving.multipart.msg");
+            throw new SOAPExceptionImpl(
+                    "Error during saving a multipart message",
+                    ex);
+        }
+
+        // FIX ME -- SOAP Action replaced by Content-Type optional parameter action
+        /*
+        if(isCorrectSoapVersion(SOAP1_1_FLAG)) {
+
+            String[] soapAction = headers.getHeader("SOAPAction");
+
+            if (soapAction == null || soapAction.length == 0)
+                headers.setHeader("SOAPAction", "\"\"");
+
+        }
+        */
+
+        saved = true;
+    }
+
+    private MimeMultipart getXOPMessage() throws SOAPException {
+        try {
+            MimeMultipart headerAndBody = new MimeMultipart();
+            SOAPPartImpl soapPart =  (SOAPPartImpl)getSOAPPart();
+            MimeBodyPart mimeSoapPart = soapPart.getMimePart();
+            ContentType soapPartCtype =
+                new ContentType("application/xop+xml");
+            soapPartCtype.setParameter("type", getExpectedContentType());
+            String charset = initCharset();
+            soapPartCtype.setParameter("charset", charset);
+            mimeSoapPart.setHeader("Content-Type", soapPartCtype.toString());
+            headerAndBody.addBodyPart(mimeSoapPart);
+
+            for (Iterator eachAttachement = getAttachments();
+                eachAttachement.hasNext();
+                ) {
+                headerAndBody.addBodyPart(
+                    ((AttachmentPartImpl) eachAttachement.next())
+                        .getMimePart());
+            }
+
+            ContentType contentType = headerAndBody.getContentType();
+
+            ParameterList l = contentType.getParameterList();
+
+            //lets not write start-info for now till we get servlet fix done
+            l.set("start-info", getExpectedContentType());//+";charset="+initCharset());
+
+            // set content type depending on SOAP version
+            l.set("type", "application/xop+xml");
+
+            if (isCorrectSoapVersion(SOAP1_2_FLAG)) {
+                 String action = getAction();
+                 if(action != null)
+                     l.set("action", action);
+            }
+
+            l.set("boundary", contentType.getParameter("boundary"));
+            ContentType nct = new ContentType("Multipart", "Related", l);
+            headers.setHeader(
+                "Content-Type",
+                convertToSingleLine(nct.toString()));
+            // TBD
+            //    Set content length MIME header here.
+
+            return headerAndBody;
+        } catch (SOAPException ex) {
+            throw ex;
+        } catch (Throwable ex) {
+            log.severe("SAAJ0538.soap.cannot.convert.msg.to.multipart.obj");
+            throw new SOAPExceptionImpl(
+                "Unable to convert SOAP message into "
+                    + "a MimeMultipart object",
+                ex);
+        }
+
+    }
+
+    private boolean hasXOPContent() throws ParseException {
+        String type = getContentType();
+        if(type == null)
+            return false;
+        ContentType ct = new ContentType(type);
+        return isMimeMultipartXOPPackage(ct) || isSOAPBodyXOPPackage(ct);
+    }
+
+    public void writeTo(OutputStream out) throws SOAPException, IOException {
+        if (saveRequired()){
+            this.optimizeAttachmentProcessing = true;
+            saveChanges();
+        }
+
+        if(!optimizeAttachmentProcessing){
+            out.write(messageBytes, 0, messageByteCount);
+        }
+        else{
+            try{
+                if(hasXOPContent()){
+                    mmp.writeTo(out);
+                }else{
+                    mmp.writeTo(out);
+                    if (!switchOffBM && !switchOffLazyAttachment &&
+                            (multiPart != null) && !attachmentsInitialized) {
+                        ((BMMimeMultipart)multiPart).setInputStream(
+                                ((BMMimeMultipart)mmp).getInputStream());
+                    }
+                }
+            } catch(Exception ex){
+                log.severe("SAAJ0540.soap.err.saving.multipart.msg");
+                throw new SOAPExceptionImpl(
+                        "Error during saving a multipart message",
+                        ex);
+            }
+        }
+
+        if(isCorrectSoapVersion(SOAP1_1_FLAG)) {
+
+            String[] soapAction = headers.getHeader("SOAPAction");
+
+            if (soapAction == null || soapAction.length == 0)
+                headers.setHeader("SOAPAction", "\"\"");
+
+        }
+
+        messageBytes = null;
+        needsSave();
+    }
+
+    public SOAPBody getSOAPBody() throws SOAPException {
+        return getSOAPPart().getEnvelope().getBody();
+    }
+
+    public SOAPHeader getSOAPHeader() throws SOAPException {
+        return getSOAPPart().getEnvelope().getHeader();
+    }
+
+    private void initializeAllAttachments ()
+        throws MessagingException, SOAPException {
+        if (switchOffBM || switchOffLazyAttachment) {
+            return;
+        }
+
+        if (attachmentsInitialized || (multiPart == null)) {
+            return;
+        }
+
+        if (attachments == null)
+            attachments = new FinalArrayList();
+
+        int count = multiPart.getCount();
+        for (int i=0; i < count; i++ ) {
+            initializeAttachment(multiPart.getBodyPart(i));
+        }
+        attachmentsInitialized = true;
+        //multiPart = null;
+        needsSave();
+     }
+
+    private void initializeAttachment(MimeBodyPart mbp) throws SOAPException {
+        AttachmentPartImpl attachmentPart = new AttachmentPartImpl();
+        DataHandler attachmentHandler = mbp.getDataHandler();
+        attachmentPart.setDataHandler(attachmentHandler);
+
+        AttachmentPartImpl.copyMimeHeaders(mbp, attachmentPart);
+        attachments.add(attachmentPart);
+    }
+
+    private void initializeAttachment(MimeMultipart multiPart, int i)
+        throws Exception {
+        MimeBodyPart currentBodyPart = multiPart.getBodyPart(i);
+        AttachmentPartImpl attachmentPart = new AttachmentPartImpl();
+
+        DataHandler attachmentHandler = currentBodyPart.getDataHandler();
+        attachmentPart.setDataHandler(attachmentHandler);
+
+        AttachmentPartImpl.copyMimeHeaders(currentBodyPart, attachmentPart);
+        addAttachmentPart(attachmentPart);
+    }
+
+    private void setMimeHeaders(SOAPPart soapPart,
+            MimeBodyPart soapMessagePart) throws Exception {
+
+        // first remove the existing content-type
+        soapPart.removeAllMimeHeaders();
+        // add everything present in soapMessagePart
+        List headers = soapMessagePart.getAllHeaders();
+        int sz = headers.size();
+        for( int i=0; i<sz; i++ ) {
+            Header h = (Header) headers.get(i);
+            soapPart.addMimeHeader(h.getName(), h.getValue());
+        }
+    }
+
+    private void initCharsetProperty(ContentType contentType) {
+        String charset = contentType.getParameter("charset");
+        if (charset != null) {
+            ((SOAPPartImpl) getSOAPPart()).setSourceCharsetEncoding(charset);
+            if(!charset.equalsIgnoreCase("utf-8"))
+                setProperty(CHARACTER_SET_ENCODING, charset);
+        }
+    }
+
+    public void setLazyAttachments(boolean flag) {
+        lazyAttachments = flag;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MultipartDataContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MultipartDataContentHandler.java
new file mode 100644
index 0000000..6b5defe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/MultipartDataContentHandler.java
@@ -0,0 +1,105 @@
+/*
+ * $Id: MultipartDataContentHandler.java,v 1.3 2006/01/27 12:49:28 vj135062 Exp $
+ * $Revision: 1.3 $
+ * $Date: 2006/01/27 12:49:28 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.io.*;
+import java.awt.datatransfer.DataFlavor;
+import javax.activation.*;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeMultipart;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ContentType;
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+
+public class MultipartDataContentHandler implements DataContentHandler {
+    private ActivationDataFlavor myDF = new ActivationDataFlavor(
+            com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeMultipart.class,
+            "multipart/mixed",
+            "Multipart");
+
+    /**
+     * Return the DataFlavors for this <code>DataContentHandler</code>.
+     *
+     * @return The DataFlavors
+     */
+    public DataFlavor[] getTransferDataFlavors() { // throws Exception;
+        return new DataFlavor[] { myDF };
+    }
+
+    /**
+     * Return the Transfer Data of type DataFlavor from InputStream.
+     *
+     * @param df The DataFlavor
+     * @param ins The InputStream corresponding to the data
+     * @return String object
+     */
+    public Object getTransferData(DataFlavor df, DataSource ds) {
+        // use myDF.equals to be sure to get ActivationDataFlavor.equals,
+        // which properly ignores Content-Type parameters in comparison
+        if (myDF.equals(df))
+            return getContent(ds);
+        else
+            return null;
+    }
+
+    /**
+     * Return the content.
+     */
+    public Object getContent(DataSource ds) {
+        try {
+            return new MimeMultipart(
+                ds, new ContentType(ds.getContentType()));
+        } catch (Exception e) {
+            return null;
+        }
+    }
+
+    /**
+     * Write the object to the output stream, using the specific MIME type.
+     */
+    public void writeTo(Object obj, String mimeType, OutputStream os)
+                        throws IOException {
+        if (obj instanceof MimeMultipart) {
+            try {
+                //TODO: temporarily allow only ByteOutputStream
+                // Need to add writeTo(OutputStream) on MimeMultipart
+                ByteOutputStream baos = null;
+                if (os instanceof ByteOutputStream) {
+                    baos = (ByteOutputStream)os;
+                } else {
+                    throw new IOException("Input Stream expected to be a com.sun.xml.internal.messaging.saaj.util.ByteOutputStream, but found " +
+                        os.getClass().getName());
+                }
+                ((MimeMultipart)obj).writeTo(baos);
+            } catch (Exception e) {
+                throw new IOException(e.toString());
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SAAJMetaFactoryImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SAAJMetaFactoryImpl.java
new file mode 100644
index 0000000..ea99d40
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SAAJMetaFactoryImpl.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import javax.xml.soap.SAAJMetaFactory;
+import javax.xml.soap.SOAPConstants;
+import javax.xml.soap.MessageFactory;
+import javax.xml.soap.SOAPFactory;
+import javax.xml.soap.SOAPException;
+
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class SAAJMetaFactoryImpl extends SAAJMetaFactory {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    protected  MessageFactory newMessageFactory(String protocol)
+        throws SOAPException {
+        if (SOAPConstants.SOAP_1_1_PROTOCOL.equals(protocol)) {
+              return new com.sun.xml.internal.messaging.saaj.soap.ver1_1.SOAPMessageFactory1_1Impl();
+        } else if (SOAPConstants.SOAP_1_2_PROTOCOL.equals(protocol)) {
+              return new com.sun.xml.internal.messaging.saaj.soap.ver1_2.SOAPMessageFactory1_2Impl();
+        } else if (SOAPConstants.DYNAMIC_SOAP_PROTOCOL.equals(protocol)) {
+              return new com.sun.xml.internal.messaging.saaj.soap.dynamic.SOAPMessageFactoryDynamicImpl();
+        } else {
+            log.log(
+                Level.SEVERE,
+                "SAAJ0569.soap.unknown.protocol",
+                new Object[] {protocol, "MessageFactory"});
+            throw new SOAPException("Unknown Protocol: " + protocol +
+                                        "  specified for creating MessageFactory");
+        }
+    }
+
+    protected  SOAPFactory newSOAPFactory(String protocol)
+        throws SOAPException {
+        if (SOAPConstants.SOAP_1_1_PROTOCOL.equals(protocol)) {
+            return new com.sun.xml.internal.messaging.saaj.soap.ver1_1.SOAPFactory1_1Impl();
+        } else if (SOAPConstants.SOAP_1_2_PROTOCOL.equals(protocol)) {
+            return new com.sun.xml.internal.messaging.saaj.soap.ver1_2.SOAPFactory1_2Impl();
+        } else if (SOAPConstants.DYNAMIC_SOAP_PROTOCOL.equals(protocol)) {
+            return new com.sun.xml.internal.messaging.saaj.soap.dynamic.SOAPFactoryDynamicImpl();
+        } else {
+            log.log(
+                Level.SEVERE,
+                "SAAJ0569.soap.unknown.protocol",
+                new Object[] {protocol, "SOAPFactory"});
+            throw new SOAPException("Unknown Protocol: " + protocol +
+                                        "  specified for creating SOAPFactory");
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocument.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocument.java
new file mode 100644
index 0000000..92ce2c1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocument.java
@@ -0,0 +1,39 @@
+/*
+ * $Id: SOAPDocument.java,v 1.5 2006/01/27 12:49:28 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap;
+
+public interface SOAPDocument {
+    SOAPPartImpl getSOAPPart();
+    SOAPDocumentImpl getDocument();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocumentFragment.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocumentFragment.java
new file mode 100644
index 0000000..71c0b28
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocumentFragment.java
@@ -0,0 +1,49 @@
+/*
+ * $Id: SOAPDocumentFragment.java,v 1.6 2006/01/27 12:49:28 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import com.sun.org.apache.xerces.internal.dom.CoreDocumentImpl;
+import com.sun.org.apache.xerces.internal.dom.DocumentFragmentImpl;
+
+public class SOAPDocumentFragment extends DocumentFragmentImpl {
+
+    public SOAPDocumentFragment(CoreDocumentImpl ownerDoc) {
+        super(ownerDoc);
+    }
+
+    public SOAPDocumentFragment() {
+        super();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocumentImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocumentImpl.java
new file mode 100644
index 0000000..5b8d797
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPDocumentImpl.java
@@ -0,0 +1,184 @@
+/*
+ * $Id: SOAPDocumentImpl.java,v 1.15 2006/01/27 12:49:29 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.util.logging.Logger;
+
+import com.sun.org.apache.xerces.internal.dom.DocumentImpl;
+import org.w3c.dom.*;
+
+import com.sun.xml.internal.messaging.saaj.soap.impl.*;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class SOAPDocumentImpl extends DocumentImpl implements SOAPDocument {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    SOAPPartImpl enclosingSOAPPart;
+
+    public SOAPDocumentImpl(SOAPPartImpl enclosingDocument) {
+        this.enclosingSOAPPart = enclosingDocument;
+    }
+
+    //    public SOAPDocumentImpl(boolean grammarAccess) {
+    //        super(grammarAccess);
+    //    }
+    //
+    //    public SOAPDocumentImpl(DocumentType doctype) {
+    //        super(doctype);
+    //    }
+    //
+    //    public SOAPDocumentImpl(DocumentType doctype, boolean grammarAccess) {
+    //        super(doctype, grammarAccess);
+    //    }
+
+    public SOAPPartImpl getSOAPPart() {
+        if (enclosingSOAPPart == null) {
+            log.severe("SAAJ0541.soap.fragment.not.bound.to.part");
+            throw new RuntimeException("Could not complete operation. Fragment not bound to SOAP part.");
+        }
+        return enclosingSOAPPart;
+    }
+
+    public SOAPDocumentImpl getDocument() {
+        return this;
+    }
+
+    public DocumentType getDoctype() {
+        // SOAP means no DTD, No DTD means no doctype (SOAP 1.2 only?)
+        return null;
+    }
+
+    public DOMImplementation getImplementation() {
+        return super.getImplementation();
+    }
+
+    public Element getDocumentElement() {
+        // This had better be an Envelope!
+        getSOAPPart().doGetDocumentElement();
+        return doGetDocumentElement();
+    }
+
+    protected Element doGetDocumentElement() {
+        return super.getDocumentElement();
+    }
+
+    public Element createElement(String tagName) throws DOMException {
+        return ElementFactory.createElement(
+            this,
+            NameImpl.getLocalNameFromTagName(tagName),
+            NameImpl.getPrefixFromTagName(tagName),
+            null);
+    }
+
+    public DocumentFragment createDocumentFragment() {
+        return new SOAPDocumentFragment(this);
+    }
+
+    public org.w3c.dom.Text createTextNode(String data) {
+        return new TextImpl(this, data);
+    }
+
+    public Comment createComment(String data) {
+        return new CommentImpl(this, data);
+    }
+
+    public CDATASection createCDATASection(String data) throws DOMException {
+        return new CDATAImpl(this, data);
+    }
+
+    public ProcessingInstruction createProcessingInstruction(
+        String target,
+        String data)
+        throws DOMException {
+        log.severe("SAAJ0542.soap.proc.instructions.not.allowed.in.docs");
+        throw new UnsupportedOperationException("Processing Instructions are not allowed in SOAP documents");
+    }
+
+    public Attr createAttribute(String name) throws DOMException {
+        return super.createAttribute(name);
+    }
+
+    public EntityReference createEntityReference(String name)
+        throws DOMException {
+            log.severe("SAAJ0543.soap.entity.refs.not.allowed.in.docs");
+            throw new UnsupportedOperationException("Entity References are not allowed in SOAP documents");
+    }
+
+    public NodeList getElementsByTagName(String tagname) {
+        return super.getElementsByTagName(tagname);
+    }
+
+    public org.w3c.dom.Node importNode(Node importedNode, boolean deep)
+        throws DOMException {
+        return super.importNode(importedNode, deep);
+    }
+
+    public Element createElementNS(String namespaceURI, String qualifiedName)
+        throws DOMException {
+        return ElementFactory.createElement(
+            this,
+            NameImpl.getLocalNameFromTagName(qualifiedName),
+            NameImpl.getPrefixFromTagName(qualifiedName),
+            namespaceURI);
+    }
+
+    public Attr createAttributeNS(String namespaceURI, String qualifiedName)
+        throws DOMException {
+        return super.createAttributeNS(namespaceURI, qualifiedName);
+    }
+
+    public NodeList getElementsByTagNameNS(
+        String namespaceURI,
+        String localName) {
+        return super.getElementsByTagNameNS(namespaceURI, localName);
+    }
+
+    public Element getElementById(String elementId) {
+        return super.getElementById(elementId);
+    }
+
+    public Node cloneNode(boolean deep) {
+        SOAPPartImpl newSoapPart = getSOAPPart().doCloneNode();
+        super.cloneNode(newSoapPart.getDocument(), deep);
+        return newSoapPart;
+    }
+
+    public void cloneNode(SOAPDocumentImpl newdoc, boolean deep) {
+        super.cloneNode(newdoc, deep);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPFactoryImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPFactoryImpl.java
new file mode 100644
index 0000000..897a607
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPFactoryImpl.java
@@ -0,0 +1,184 @@
+/*
+ * $Id: SOAPFactoryImpl.java,v 1.21 2006/01/27 12:49:29 vj135062 Exp $
+ * $Revision: 1.21 $
+ * $Date: 2006/01/27 12:49:29 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.util.logging.Logger;
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.soap.impl.ElementFactory;
+import com.sun.xml.internal.messaging.saaj.soap.impl.ElementImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.*;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.Document;
+import org.w3c.dom.NodeList;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Attr;
+
+public abstract class SOAPFactoryImpl extends SOAPFactory {
+
+    protected static Logger
+        log = Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+                               "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    protected abstract SOAPDocumentImpl createDocument();
+
+    public SOAPElement createElement(String tagName) throws SOAPException {
+         if (tagName == null) {
+             log.log(
+                 Level.SEVERE,"SAAJ0567.soap.null.input",
+                 new Object[] {"tagName","SOAPFactory.createElement"});
+             throw new SOAPException("Null tagName argument passed to createElement");
+         }
+        return ElementFactory.createElement(createDocument(),
+                        NameImpl.createFromTagName(tagName));
+    }
+
+    public SOAPElement createElement(Name name) throws SOAPException {
+        // @since SAAJ 1.3
+        // If the Name was null it would cause a NullPointerException in earlier release
+        if (name == null) {
+            log.log(Level.SEVERE,"SAAJ0567.soap.null.input",
+                        new Object[] {"name","SOAPFactory.createElement"});
+            throw new SOAPException("Null name argument passed to createElement");
+        }
+        return ElementFactory.createElement(createDocument(), name);
+    }
+
+    public SOAPElement createElement(QName qname) throws SOAPException {
+        if (qname == null) {
+            log.log(Level.SEVERE,"SAAJ0567.soap.null.input",
+                        new Object[] {"qname","SOAPFactory.createElement"});
+            throw new SOAPException("Null qname argument passed to createElement");
+        }
+        return ElementFactory.createElement(createDocument(),qname);
+    }
+
+    public SOAPElement createElement(
+        String localName,
+        String prefix,
+        String uri)  throws SOAPException {
+
+        // @since SAAJ 1.3
+        // if prefix !=null but localName== null then in earlier releases it would create
+        // a Qualified Name  <prefix>:null which is not meaningful
+        if (localName == null) {
+            log.log(Level.SEVERE,"SAAJ0567.soap.null.input",
+                        new Object[] {"localName","SOAPFactory.createElement"});
+            throw new SOAPException("Null localName argument passed to createElement");
+        }
+        return ElementFactory.createElement(createDocument(), localName, prefix, uri);
+    }
+
+    public Name createName(String localName, String prefix, String uri)
+        throws SOAPException {
+        // @since SAAJ 1.3
+        // if localName==null, earlier impl would create Name with localName=""
+        // which is absurd.
+        if (localName == null) {
+            log.log(
+                 Level.SEVERE,"SAAJ0567.soap.null.input",
+                 new Object[] {"localName","SOAPFactory.createName"});
+            throw new SOAPException("Null localName argument passed to createName");
+        }
+        return NameImpl.create(localName, prefix, uri);
+    }
+
+    public Name createName(String localName) throws SOAPException {
+        // @since SAAJ 1.3
+        // if localName==null, earlier impl would create Name with localName=null
+        // which is absurd.
+        if (localName == null) {
+            log.log(
+                Level.SEVERE,"SAAJ0567.soap.null.input",
+                new Object[] {"localName","SOAPFactory.createName"});
+            throw new SOAPException("Null localName argument passed to createName");
+        }
+        return NameImpl.createFromUnqualifiedName(localName);
+    }
+
+    // Note: the child elements might still be org.w3c.dom.Element's, but the
+    // getChildElements will do the conversion to SOAPElement when called.
+    public SOAPElement createElement(Element domElement) throws SOAPException {
+        if (domElement == null) {
+            return null;
+        }
+        return convertToSoapElement(domElement);
+    }
+
+    private  SOAPElement convertToSoapElement(Element element) throws SOAPException {
+
+        if (element instanceof SOAPElement) {
+            return (SOAPElement) element;
+        }
+
+        SOAPElement copy = createElement(
+                                element.getLocalName(),
+                                element.getPrefix(),
+                                element.getNamespaceURI());
+
+        Document ownerDoc = copy.getOwnerDocument();
+
+        NamedNodeMap attrMap = element.getAttributes();
+        for (int i=0; i < attrMap.getLength(); i++) {
+            Attr nextAttr = (Attr)attrMap.item(i);
+            Attr importedAttr = (Attr)ownerDoc.importNode(nextAttr, true);
+            copy.setAttributeNodeNS(importedAttr);
+        }
+
+
+        NodeList nl = element.getChildNodes();
+        for (int i=0; i < nl.getLength(); i++) {
+            org.w3c.dom.Node next = nl.item(i);
+            org.w3c.dom.Node imported = ownerDoc.importNode(next, true);
+            copy.appendChild(imported);
+        }
+
+        return copy;
+    }
+
+    public Detail createDetail() throws SOAPException {
+        throw new UnsupportedOperationException();
+    }
+
+    public  SOAPFault createFault(String reasonText, QName faultCode) throws SOAPException {
+        throw new UnsupportedOperationException();
+    }
+
+    public SOAPFault createFault() throws SOAPException {
+        throw new UnsupportedOperationException();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPIOException.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPIOException.java
new file mode 100644
index 0000000..d9e6ea9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPIOException.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * Created on Nov 19, 2002
+ *
+ * To change this generated comment edit the template variable "filecomment":
+ * Window>Preferences>Java>Templates.
+ * To enable and disable the creation of file comments go to
+ * Window>Preferences>Java>Code Generation.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.io.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+
+public class SOAPIOException extends IOException {
+    SOAPExceptionImpl soapException;
+
+    public SOAPIOException() {
+        super();
+        soapException = new SOAPExceptionImpl();
+        soapException.fillInStackTrace();
+    }
+
+    public SOAPIOException(String s) {
+        super();
+        soapException = new SOAPExceptionImpl(s);
+        soapException.fillInStackTrace();
+    }
+
+    public SOAPIOException(String reason, Throwable cause) {
+        super();
+        soapException = new SOAPExceptionImpl(reason, cause);
+        soapException.fillInStackTrace();
+    }
+
+    public SOAPIOException(Throwable cause) {
+        super(cause.toString());
+        soapException = new SOAPExceptionImpl(cause);
+        soapException.fillInStackTrace();
+    }
+
+    public Throwable fillInStackTrace() {
+        if (soapException != null) {
+            soapException.fillInStackTrace();
+        }
+        return this;
+    }
+
+    public String getLocalizedMessage() {
+        return soapException.getLocalizedMessage();
+    }
+
+    public String getMessage() {
+        return soapException.getMessage();
+    }
+
+    public void printStackTrace() {
+        soapException.printStackTrace();
+    }
+
+    public void printStackTrace(PrintStream s) {
+        soapException.printStackTrace(s);
+    }
+
+    public void printStackTrace(PrintWriter s) {
+        soapException.printStackTrace(s);
+    }
+
+    public String toString() {
+        return soapException.toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPPartImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPPartImpl.java
new file mode 100644
index 0000000..60d4c1c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPPartImpl.java
@@ -0,0 +1,799 @@
+/*
+ * $Id: SOAPPartImpl.java,v 1.1.1.1 2006/01/27 13:10:55 kumarjayanti Exp $
+ * $Revision: 1.1.1.1 $
+ * $Date: 2006/01/27 13:10:55 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.io.*;
+import java.util.Iterator;
+import java.util.logging.Logger;
+import java.util.logging.Level;
+
+import javax.activation.DataHandler;
+import javax.activation.DataSource;
+import javax.xml.soap.*;
+import javax.xml.transform.Source;
+import javax.xml.transform.stream.StreamSource;
+
+import org.w3c.dom.*;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeBodyPart;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.ElementImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.EnvelopeImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.*;
+import javax.xml.transform.sax.SAXSource;
+
+/**
+ * SOAPPartImpl is the first attachment. This contains the XML/SOAP document.
+ *
+ * @author Anil Vijendran (anil@sun.com)
+ */
+public abstract class SOAPPartImpl extends SOAPPart implements SOAPDocument {
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.LocalStrings");
+
+    protected MimeHeaders headers;
+    protected Envelope envelope;
+    protected Source source;
+    protected SOAPDocumentImpl document;
+
+    //flag to indicate if a setContent happened.
+    private boolean sourceWasSet = false;
+
+    // Records whether the input source had an xml decl or not.
+    protected boolean omitXmlDecl = true;
+
+    // Records the charset encoding of the input stream source if provided.
+    protected String sourceCharsetEncoding = null;
+
+    /**
+     * Reference to containing message (may be null)
+     */
+    protected MessageImpl message;
+
+    protected SOAPPartImpl() {
+        this(null);
+    }
+
+    protected SOAPPartImpl(MessageImpl message) {
+        document = new SOAPDocumentImpl(this);
+        headers = new MimeHeaders();
+        this.message = message;
+        headers.setHeader("Content-Type", getContentType());
+    }
+
+    protected abstract String getContentType();
+    protected abstract Envelope createEnvelopeFromSource()
+    throws SOAPException;
+    protected abstract Envelope createEmptyEnvelope(String prefix)
+    throws SOAPException;
+    protected abstract SOAPPartImpl duplicateType();
+
+    protected String getContentTypeString() {
+        return getContentType();
+    }
+
+    public boolean isFastInfoset() {
+        return (message != null) ? message.isFastInfoset() : false;
+    }
+
+    public SOAPEnvelope getEnvelope() throws SOAPException {
+
+        // If there is no SOAP envelope already created, then create
+        // one from a source if one exists. If there is a newer source
+        // then use that source.
+
+        if (sourceWasSet)
+              sourceWasSet = false;
+
+        lookForEnvelope();
+        if (envelope != null) {
+            if (source != null) { // there's a newer source, use it
+                document.removeChild(envelope);
+                envelope = createEnvelopeFromSource();
+            }
+        } else if (source != null) {
+            envelope = createEnvelopeFromSource();
+        } else {
+            envelope = createEmptyEnvelope(null);
+            document.insertBefore(envelope, null);
+        }
+        return envelope;
+    }
+
+    protected void lookForEnvelope() throws SOAPException {
+        Element envelopeChildElement = document.doGetDocumentElement();
+        if (envelopeChildElement == null || envelopeChildElement instanceof Envelope) {
+            envelope = (EnvelopeImpl) envelopeChildElement;
+        } else if (!(envelopeChildElement instanceof ElementImpl)) {
+            log.severe("SAAJ0512.soap.incorrect.factory.used");
+            throw new SOAPExceptionImpl("Unable to create envelope: incorrect factory used during tree construction");
+        } else {
+            ElementImpl soapElement = (ElementImpl) envelopeChildElement;
+            if (soapElement.getLocalName().equalsIgnoreCase("Envelope")) {
+                String prefix = soapElement.getPrefix();
+                String uri = (prefix == null) ? soapElement.getNamespaceURI() : soapElement.getNamespaceURI(prefix);
+                if(!uri.equals(NameImpl.SOAP11_NAMESPACE) && !uri.equals(NameImpl.SOAP12_NAMESPACE)) {
+                    log.severe("SAAJ0513.soap.unknown.ns");
+                    throw new SOAPVersionMismatchException("Unable to create envelope from given source because the namespace was not recognized");
+                }
+            } else {
+                log.severe("SAAJ0514.soap.root.elem.not.named.envelope");
+                throw new SOAPExceptionImpl(
+                    "Unable to create envelope from given source because the root element is not named \"Envelope\"");
+            }
+        }
+    }
+
+    public void removeAllMimeHeaders() {
+        headers.removeAllHeaders();
+    }
+
+    public void removeMimeHeader(String header) {
+        headers.removeHeader(header);
+    }
+
+    public String[] getMimeHeader(String name) {
+        return headers.getHeader(name);
+    }
+
+    public void setMimeHeader(String name, String value) {
+        headers.setHeader(name, value);
+    }
+
+    public void addMimeHeader(String name, String value) {
+        headers.addHeader(name, value);
+    }
+
+    public Iterator getAllMimeHeaders() {
+        return headers.getAllHeaders();
+    }
+
+    public Iterator getMatchingMimeHeaders(String[] names) {
+        return headers.getMatchingHeaders(names);
+    }
+
+    public Iterator getNonMatchingMimeHeaders(String[] names) {
+        return headers.getNonMatchingHeaders(names);
+    }
+
+    public Source getContent() throws SOAPException {
+        if (source != null) {
+            InputStream bis = null;
+            if (source instanceof JAXMStreamSource) {
+                StreamSource streamSource = (StreamSource)source;
+                bis = streamSource.getInputStream();
+            } else if (FastInfosetReflection.isFastInfosetSource(source)) {
+                // FastInfosetSource inherits from SAXSource
+                SAXSource saxSource = (SAXSource)source;
+                bis = saxSource.getInputSource().getByteStream();
+            }
+
+            if (bis != null) {
+                try {
+                    bis.reset();
+                } catch (IOException e) {
+                    /* This exception will never be thrown.
+                     *
+                     * The setContent method will modify the source
+                     * if StreamSource to JAXMStreamSource, that uses
+                     * a ByteInputStream, and for a FastInfosetSource will
+                     * replace the InputStream with a ByteInputStream.
+                     */
+                }
+            }
+            return source;
+        }
+
+        return ((Envelope) getEnvelope()).getContent();
+    }
+
+    public void setContent(Source source) throws SOAPException {
+        try {
+            if (source instanceof StreamSource) {
+                InputStream is = ((StreamSource) source).getInputStream();
+                Reader rdr = ((StreamSource) source).getReader();
+
+                if (is != null) {
+                    this.source = new JAXMStreamSource(is);
+                } else if (rdr != null) {
+                    this.source = new JAXMStreamSource(rdr);
+                } else {
+                    log.severe("SAAJ0544.soap.no.valid.reader.for.src");
+                    throw new SOAPExceptionImpl("Source does not have a valid Reader or InputStream");
+                }
+            }
+            else if (FastInfosetReflection.isFastInfosetSource(source)) {
+                // InputStream is = source.getInputStream()
+                InputStream is = FastInfosetReflection.FastInfosetSource_getInputStream(source);
+
+                /*
+                 * Underlying stream must be ByteInputStream for getContentAsStream(). We pay the
+                 * cost of copying the underlying bytes here to avoid multiple copies every time
+                 * getBytes() is called on a ByteInputStream.
+                 */
+                if (!(is instanceof ByteInputStream)) {
+                    ByteOutputStream bout = new ByteOutputStream();
+                    bout.write(is);
+
+                    // source.setInputStream(new ByteInputStream(...))
+                    FastInfosetReflection.FastInfosetSource_setInputStream(
+                        source, bout.newInputStream());
+                }
+                this.source = source;
+            }
+            else {
+                this.source = source;
+            }
+            sourceWasSet = true;
+        }
+        catch (Exception ex) {
+            ex.printStackTrace();
+
+            log.severe("SAAJ0545.soap.cannot.set.src.for.part");
+            throw new SOAPExceptionImpl(
+            "Error setting the source for SOAPPart: " + ex.getMessage());
+        }
+    }
+
+    public ByteInputStream getContentAsStream() throws IOException {
+        if (source != null) {
+            InputStream is = null;
+
+            // Allow message to be transcode if so requested
+            if (source instanceof StreamSource && !isFastInfoset()) {
+                is = ((StreamSource) source).getInputStream();
+            }
+            else if (FastInfosetReflection.isFastInfosetSource(source) &&
+                isFastInfoset())
+            {
+                try {
+                    // InputStream is = source.getInputStream()
+                    is = FastInfosetReflection.FastInfosetSource_getInputStream(source);
+                }
+                catch (Exception e) {
+                    throw new IOException(e.toString());
+                }
+            }
+
+            if (is != null) {
+                if (!(is instanceof ByteInputStream)) {
+                    log.severe("SAAJ0546.soap.stream.incorrect.type");
+                    throw new IOException("Internal error: stream not of the right type");
+                }
+                return (ByteInputStream) is;
+            }
+            // need to do something here for reader...
+            // for now we'll see if we can fallback...
+        }
+
+        ByteOutputStream b = new ByteOutputStream();
+
+        Envelope env = null;
+
+        try {
+            env = (Envelope) getEnvelope();
+            env.output(b, isFastInfoset());
+        }
+        catch (SOAPException soapException) {
+            log.severe("SAAJ0547.soap.cannot.externalize");
+            throw new SOAPIOException(
+            "SOAP exception while trying to externalize: ",
+            soapException);
+        }
+
+        return b.newInputStream();
+    }
+
+    MimeBodyPart getMimePart() throws SOAPException {
+        try {
+            MimeBodyPart headerEnvelope = new MimeBodyPart();
+
+            headerEnvelope.setDataHandler(getDataHandler());
+            AttachmentPartImpl.copyMimeHeaders(headers, headerEnvelope);
+
+            return headerEnvelope;
+        } catch (SOAPException ex) {
+            throw ex;
+        } catch (Exception ex) {
+            log.severe("SAAJ0548.soap.cannot.externalize.hdr");
+            throw new SOAPExceptionImpl("Unable to externalize header", ex);
+        }
+    }
+
+    MimeHeaders getMimeHeaders() {
+        return headers;
+    }
+
+    DataHandler getDataHandler() {
+        DataSource ds = new DataSource() {
+            public OutputStream getOutputStream() throws IOException {
+                throw new IOException("Illegal Operation");
+            }
+
+            public String getContentType() {
+                return getContentTypeString();
+            }
+
+            public String getName() {
+                return getContentId();
+            }
+
+            public InputStream getInputStream() throws IOException {
+                return getContentAsStream();
+            }
+        };
+        return new DataHandler(ds);
+    }
+
+    public SOAPDocumentImpl getDocument() {
+        handleNewSource();
+        return document;
+    }
+
+    public SOAPPartImpl getSOAPPart() {
+        return this;
+    }
+
+    public DocumentType getDoctype() {
+        return document.getDoctype();
+    }
+
+    // Forward all of these calls to the document to ensure that they work the
+    // same way whether they are called from here or directly from the document.
+    // If the document needs any help from this SOAPPart then
+    // Make it use a call-back as in doGetDocumentElement() below
+    public DOMImplementation getImplementation() {
+        return document.getImplementation();
+    }
+
+    public Element getDocumentElement() {
+        // If there is no SOAP envelope already created, then create
+        // one from a source if one exists. If there is a newer source
+        // then use that source.
+        try {
+            getEnvelope();
+        } catch (SOAPException e) {
+        }
+        return document.getDocumentElement();
+    }
+
+    protected void doGetDocumentElement() {
+        handleNewSource();
+        try {
+            lookForEnvelope();
+        } catch (SOAPException e) {
+        }
+    }
+
+    public Element createElement(String tagName) throws DOMException {
+        return document.createElement(tagName);
+    }
+
+    public DocumentFragment createDocumentFragment() {
+        return document.createDocumentFragment();
+    }
+
+    public org.w3c.dom.Text createTextNode(String data) {
+        return document.createTextNode(data);
+    }
+
+    public Comment createComment(String data) {
+        return document.createComment(data);
+    }
+
+    public CDATASection createCDATASection(String data) throws DOMException {
+        return document.createCDATASection(data);
+    }
+
+    public ProcessingInstruction createProcessingInstruction(
+    String target,
+    String data)
+    throws DOMException {
+        return document.createProcessingInstruction(target, data);
+    }
+
+    public Attr createAttribute(String name) throws DOMException {
+        return document.createAttribute(name);
+    }
+
+    public EntityReference createEntityReference(String name)
+    throws DOMException {
+        return document.createEntityReference(name);
+    }
+
+    public NodeList getElementsByTagName(String tagname) {
+        handleNewSource();
+        return document.getElementsByTagName(tagname);
+    }
+
+    public org.w3c.dom.Node importNode(
+        org.w3c.dom.Node importedNode,
+        boolean deep)
+        throws DOMException {
+        handleNewSource();
+        return document.importNode(importedNode, deep);
+    }
+
+    public Element createElementNS(String namespaceURI, String qualifiedName)
+    throws DOMException {
+        return document.createElementNS(namespaceURI, qualifiedName);
+    }
+
+    public Attr createAttributeNS(String namespaceURI, String qualifiedName)
+    throws DOMException {
+        return document.createAttributeNS(namespaceURI, qualifiedName);
+    }
+
+    public NodeList getElementsByTagNameNS(
+        String namespaceURI,
+        String localName) {
+        handleNewSource();
+        return document.getElementsByTagNameNS(namespaceURI, localName);
+    }
+
+    public Element getElementById(String elementId) {
+        handleNewSource();
+        return document.getElementById(elementId);
+    }
+    public org.w3c.dom.Node appendChild(org.w3c.dom.Node newChild)
+        throws DOMException {
+        handleNewSource();
+        return document.appendChild(newChild);
+    }
+
+    public org.w3c.dom.Node cloneNode(boolean deep) {
+        handleNewSource();
+        return document.cloneNode(deep);
+    }
+
+    protected SOAPPartImpl doCloneNode() {
+        handleNewSource();
+        SOAPPartImpl newSoapPart = duplicateType();
+
+        newSoapPart.headers = MimeHeadersUtil.copy(this.headers);
+        newSoapPart.source = this.source;
+        return newSoapPart;
+    }
+
+    public NamedNodeMap getAttributes() {
+        return document.getAttributes();
+    }
+
+    public NodeList getChildNodes() {
+        handleNewSource();
+        return document.getChildNodes();
+    }
+
+    public org.w3c.dom.Node getFirstChild() {
+        handleNewSource();
+        return document.getFirstChild();
+    }
+
+    public org.w3c.dom.Node getLastChild() {
+        handleNewSource();
+        return document.getLastChild();
+    }
+
+    public String getLocalName() {
+        return document.getLocalName();
+    }
+
+    public String getNamespaceURI() {
+        return document.getNamespaceURI();
+    }
+
+    public org.w3c.dom.Node getNextSibling() {
+        handleNewSource();
+        return document.getNextSibling();
+    }
+
+    public String getNodeName() {
+        return document.getNodeName();
+    }
+
+    public short getNodeType() {
+        return document.getNodeType();
+    }
+
+    public String getNodeValue() throws DOMException {
+        return document.getNodeValue();
+    }
+
+    public Document getOwnerDocument() {
+        return document.getOwnerDocument();
+    }
+
+    public org.w3c.dom.Node getParentNode() {
+        return document.getParentNode();
+    }
+
+    public String getPrefix() {
+        return document.getPrefix();
+    }
+
+    public org.w3c.dom.Node getPreviousSibling() {
+        return document.getPreviousSibling();
+    }
+
+    public boolean hasAttributes() {
+        return document.hasAttributes();
+    }
+
+    public boolean hasChildNodes() {
+        handleNewSource();
+        return document.hasChildNodes();
+    }
+
+    public org.w3c.dom.Node insertBefore(
+        org.w3c.dom.Node arg0,
+        org.w3c.dom.Node arg1)
+        throws DOMException {
+        handleNewSource();
+        return document.insertBefore(arg0, arg1);
+    }
+
+    public boolean isSupported(String arg0, String arg1) {
+        return document.isSupported(arg0, arg1);
+    }
+
+    public void normalize() {
+        handleNewSource();
+        document.normalize();
+    }
+
+    public org.w3c.dom.Node removeChild(org.w3c.dom.Node arg0)
+        throws DOMException {
+        handleNewSource();
+        return document.removeChild(arg0);
+    }
+
+    public org.w3c.dom.Node replaceChild(
+        org.w3c.dom.Node arg0,
+        org.w3c.dom.Node arg1)
+        throws DOMException {
+        handleNewSource();
+        return document.replaceChild(arg0, arg1);
+    }
+
+    public void setNodeValue(String arg0) throws DOMException {
+        document.setNodeValue(arg0);
+    }
+
+    public void setPrefix(String arg0) throws DOMException {
+        document.setPrefix(arg0);
+    }
+
+    private void handleNewSource() {
+        if (sourceWasSet) {
+         // There is a newer source use that source.
+         try {
+             getEnvelope();
+         } catch (SOAPException e) {
+         }
+      }
+    }
+
+    protected XMLDeclarationParser lookForXmlDecl() throws SOAPException {
+        if ((source != null) && (source instanceof StreamSource)) {
+
+            Reader reader = null;
+
+            InputStream inputStream = ((StreamSource) source).getInputStream();
+            if (inputStream != null) {
+                if (sourceCharsetEncoding == null) {
+                    reader = new InputStreamReader(inputStream);
+                } else {
+                    try {
+                        reader =
+                            new InputStreamReader(
+                                inputStream, sourceCharsetEncoding);
+                    } catch (UnsupportedEncodingException uee) {
+                        log.log(
+                            Level.SEVERE,
+                            "SAAJ0551.soap.unsupported.encoding",
+                            new Object[] {sourceCharsetEncoding});
+                        throw new SOAPExceptionImpl(
+                            "Unsupported encoding " + sourceCharsetEncoding,
+                            uee);
+                    }
+                }
+            } else {
+                reader = ((StreamSource) source).getReader();
+            }
+            if (reader != null) {
+                PushbackReader pushbackReader =
+                    new PushbackReader(reader, 4096); //some size to unread <?xml ....?>
+                XMLDeclarationParser ev =
+                        new XMLDeclarationParser(pushbackReader);
+                try {
+                    ev.parse();
+                } catch (Exception e) {
+                    log.log(
+                        Level.SEVERE,
+                        "SAAJ0552.soap.xml.decl.parsing.failed");
+                    throw new SOAPExceptionImpl(
+                        "XML declaration parsing failed", e);
+                }
+                String xmlDecl = ev.getXmlDeclaration();
+                if ((xmlDecl != null) && (xmlDecl.length() > 0))
+                    this.omitXmlDecl = false;
+                return ev;
+            }
+        }
+        return null;
+    }
+
+    public void setSourceCharsetEncoding(String charset) {
+        this.sourceCharsetEncoding = charset;
+    }
+
+    public org.w3c.dom.Node renameNode(org.w3c.dom.Node n, String namespaceURI, String qualifiedName)
+        throws DOMException {
+        handleNewSource();
+        return document.renameNode(n, namespaceURI, qualifiedName);
+    }
+
+    public void normalizeDocument() {
+        document.normalizeDocument();
+    }
+
+    public DOMConfiguration getDomConfig() {
+        return document.getDomConfig();
+    }
+
+    public org.w3c.dom.Node adoptNode(org.w3c.dom.Node source) throws DOMException {
+        handleNewSource();
+        return document.adoptNode(source);
+    }
+
+    public void setDocumentURI(String documentURI) {
+        document.setDocumentURI(documentURI);
+    }
+
+    public String getDocumentURI() {
+        return document.getDocumentURI();
+    }
+
+    public void  setStrictErrorChecking(boolean strictErrorChecking) {
+        document.setStrictErrorChecking(strictErrorChecking);
+    }
+
+    public String getInputEncoding() {
+        return document.getInputEncoding();
+    }
+
+    public String getXmlEncoding() {
+        return document.getXmlEncoding();
+    }
+
+    public boolean getXmlStandalone() {
+        return document.getXmlStandalone();
+    }
+
+    public void setXmlStandalone(boolean xmlStandalone) throws DOMException {
+        document.setXmlStandalone(xmlStandalone);
+    }
+
+    public String getXmlVersion() {
+        return document.getXmlVersion();
+    }
+
+    public void setXmlVersion(String xmlVersion) throws DOMException {
+        document.setXmlVersion(xmlVersion);
+    }
+
+    public boolean  getStrictErrorChecking() {
+        return document.getStrictErrorChecking();
+    }
+
+    // DOM L3 methods from org.w3c.dom.Node
+    public String getBaseURI() {
+        return document.getBaseURI();
+    }
+
+    public short compareDocumentPosition(org.w3c.dom.Node other)
+                              throws DOMException {
+        return document.compareDocumentPosition(other);
+    }
+
+    public String getTextContent()
+                      throws DOMException {
+        return document.getTextContent();
+    }
+
+    public void setTextContent(String textContent) throws DOMException {
+         document.setTextContent(textContent);
+    }
+
+    public boolean isSameNode(org.w3c.dom.Node other) {
+        return document.isSameNode(other);
+    }
+
+    public String lookupPrefix(String namespaceURI) {
+        return document.lookupPrefix(namespaceURI);
+    }
+
+    public boolean isDefaultNamespace(String namespaceURI) {
+        return document.isDefaultNamespace(namespaceURI);
+    }
+
+    public String lookupNamespaceURI(String prefix) {
+        return document.lookupNamespaceURI(prefix);
+    }
+
+    public boolean isEqualNode(org.w3c.dom.Node arg) {
+        return document.isEqualNode(arg);
+    }
+
+    public Object getFeature(String feature,
+                  String version) {
+        return  document.getFeature(feature,version);
+    }
+
+    public Object setUserData(String key,
+                   Object data,
+                  UserDataHandler handler) {
+        return document.setUserData(key, data, handler);
+    }
+
+    public Object getUserData(String key) {
+        return document.getUserData(key);
+    }
+
+    public void recycleNode() {
+        // Nothing seems to be required to be done here
+    }
+
+    public String getValue() {
+        return null;
+    }
+
+    public void setValue(String value) {
+        log.severe("SAAJ0571.soappart.setValue.not.defined");
+        throw new IllegalStateException("Setting value of a soap part is not defined");
+    }
+
+    public void setParentElement(SOAPElement parent) throws SOAPException {
+        log.severe("SAAJ0570.soappart.parent.element.not.defined");
+        throw new SOAPExceptionImpl("The parent element of a soap part is not defined");
+    }
+
+    public SOAPElement getParentElement() {
+        return null;
+    }
+
+    public void detachNode() {
+        // Nothing seems to be required to be done here
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPVersionMismatchException.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPVersionMismatchException.java
new file mode 100644
index 0000000..db53492
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/SOAPVersionMismatchException.java
@@ -0,0 +1,76 @@
+/*
+ * $Id: SOAPVersionMismatchException.java,v 1.6 2006/01/27 12:49:29 vj135062 Exp $
+ * $Revision: 1.6 $
+ * $Date: 2006/01/27 12:49:29 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+
+public class SOAPVersionMismatchException extends SOAPExceptionImpl {
+    /**
+     * Constructs a <code>SOAPExceptionImpl</code> object with no
+     * reason or embedded <code>Throwable</code> object.
+     */
+    public SOAPVersionMismatchException() {
+        super();
+    }
+
+    /**
+     * Constructs a <code>SOAPExceptionImpl</code> object with the given
+     * <code>String</code> as the reason for the exception being thrown.
+     *
+     * @param reason a description of what caused the exception
+     */
+    public SOAPVersionMismatchException(String reason) {
+        super(reason);
+    }
+
+    /**
+     * Constructs a <code>SOAPExceptionImpl</code> object with the given
+     * <code>String</code> as the reason for the exception being thrown
+     * and the given <code>Throwable</code> object as an embedded
+     * exception.
+     *
+     * @param reason a description of what caused the exception
+     * @param cause a <code>Throwable</code> object that is to
+     *        be embedded in this <code>SOAPExceptionImpl</code> object
+     */
+    public SOAPVersionMismatchException(String reason, Throwable cause) {
+        super(reason, cause);
+    }
+
+    /**
+     * Constructs a <code>SOAPExceptionImpl</code> object initialized
+     * with the given <code>Throwable</code> object.
+     */
+    public SOAPVersionMismatchException(Throwable cause) {
+        super(cause);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/StringDataContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/StringDataContentHandler.java
new file mode 100644
index 0000000..cad725c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/StringDataContentHandler.java
@@ -0,0 +1,160 @@
+/*
+ * $Id: StringDataContentHandler.java,v 1.6 2006/01/27 12:49:29 vj135062 Exp $
+ * $Revision: 1.6 $
+ * $Date: 2006/01/27 12:49:29 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.awt.datatransfer.DataFlavor;
+import java.io.*;
+
+import javax.activation.*;
+
+/**
+ * JAF data content handler for text/plain --> String
+ *
+ * @author Anil Vijendran
+ */
+public class StringDataContentHandler implements DataContentHandler {
+    /**
+     * return the DataFlavors for this <code>DataContentHandler</code>
+     * @return The DataFlavors.
+     */
+    public DataFlavor[] getTransferDataFlavors() { // throws Exception;
+        DataFlavor flavors[] = new DataFlavor[2];
+
+        try {
+            flavors[0] =
+                new ActivationDataFlavor(
+                    Class.forName("java.lang.String"),
+                    "text/plain",
+                    "text string");
+        } catch (Exception e) {
+        }
+
+        flavors[1] = new DataFlavor("text/plain", "Plain Text");
+        return flavors;
+    }
+
+    /**
+     * return the Transfer Data of type DataFlavor from InputStream
+     * @param df The DataFlavor.
+     * @param ins The InputStream corresponding to the data.
+     * @return The constructed Object.
+     */
+    public Object getTransferData(DataFlavor df, DataSource ds) {
+
+        // this is sort of hacky, but will work for the
+        // sake of testing...
+        if (df.getMimeType().startsWith("text/plain")) {
+            if (df
+                .getRepresentationClass()
+                .getName()
+                .equals("java.lang.String")) {
+                // spit out String
+                StringBuffer buf = new StringBuffer();
+                char data[] = new char[1024];
+                // InputStream is = null;
+                InputStreamReader isr = null;
+                int bytes_read = 0;
+                int total_bytes = 0;
+
+                try {
+                    isr = new InputStreamReader(ds.getInputStream());
+
+                    while (true) {
+                        bytes_read = isr.read(data);
+                        if (bytes_read > 0)
+                            buf.append(data, 0, bytes_read);
+                        else
+                            break;
+                        total_bytes += bytes_read;
+                    }
+                } catch (Exception e) {
+                }
+
+                return buf.toString();
+
+            } else if (
+                df.getRepresentationClass().getName().equals(
+                    "java.io.InputStream")) {
+                // spit out InputStream
+                try {
+                    return ds.getInputStream();
+                } catch (Exception e) {
+                }
+            }
+
+        }
+        return null;
+    }
+
+    /**
+     *
+     */
+    public Object getContent(DataSource ds) { // throws Exception;
+        StringBuffer buf = new StringBuffer();
+        char data[] = new char[1024];
+        // InputStream is = null;
+        InputStreamReader isr = null;
+        int bytes_read = 0;
+        int total_bytes = 0;
+
+        try {
+            isr = new InputStreamReader(ds.getInputStream());
+
+            while (true) {
+                bytes_read = isr.read(data);
+                if (bytes_read > 0)
+                    buf.append(data, 0, bytes_read);
+                else
+                    break;
+                total_bytes += bytes_read;
+            }
+        } catch (Exception e) {
+        }
+
+        return buf.toString();
+    }
+    /**
+     * construct an object from a byte stream
+     * (similar semantically to previous method, we are deciding
+     *  which one to support)
+     */
+    public void writeTo(Object obj, String mimeType, OutputStream os)
+        throws IOException {
+        if (!mimeType.startsWith("text/plain"))
+            throw new IOException(
+                "Invalid type \"" + mimeType + "\" on StringDCH");
+
+        Writer out = new OutputStreamWriter(os);
+        out.write((String) obj);
+        out.flush();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/XmlDataContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/XmlDataContentHandler.java
new file mode 100644
index 0000000..e188cf4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/XmlDataContentHandler.java
@@ -0,0 +1,126 @@
+/*
+ * $Id: XmlDataContentHandler.java,v 1.12 2006/01/27 12:49:30 vj135062 Exp $
+ * $Revision: 1.12 $
+ * $Date: 2006/01/27 12:49:30 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap;
+
+import java.awt.datatransfer.DataFlavor;
+import java.io.IOException;
+import java.io.OutputStream;
+
+import javax.activation.*;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.transform.stream.StreamSource;
+
+import com.sun.xml.internal.messaging.saaj.util.transform.EfficientStreamingTransformer;
+
+/**
+ * JAF data handler for XML content
+ *
+ * @author Anil Vijendran
+ */
+public class XmlDataContentHandler implements DataContentHandler {
+    public final String STR_SRC = "javax.xml.transform.stream.StreamSource";
+    private static Class streamSourceClass = null;
+
+    public XmlDataContentHandler() throws ClassNotFoundException {
+        if (streamSourceClass == null) {
+            streamSourceClass = Class.forName(STR_SRC);
+        }
+    }
+
+    /**
+     * return the DataFlavors for this <code>DataContentHandler</code>
+     * @return The DataFlavors.
+     */
+    public DataFlavor[] getTransferDataFlavors() { // throws Exception;
+        DataFlavor flavors[] = new DataFlavor[2];
+
+        flavors[0] =
+            new ActivationDataFlavor(streamSourceClass, "text/xml", "XML");
+        flavors[1] =
+            new ActivationDataFlavor(streamSourceClass, "application/xml", "XML");
+
+        return flavors;
+    }
+
+    /**
+     * return the Transfer Data of type DataFlavor from InputStream
+     * @param df The DataFlavor.
+     * @param ins The InputStream corresponding to the data.
+     * @return The constructed Object.
+     */
+    public Object getTransferData(DataFlavor flavor, DataSource dataSource)
+        throws IOException {
+        if (flavor.getMimeType().startsWith("text/xml") ||
+                flavor.getMimeType().startsWith("application/xml")) {
+            if (flavor.getRepresentationClass().getName().equals(STR_SRC)) {
+                return new StreamSource(dataSource.getInputStream());
+            }
+        }
+        return null;
+    }
+
+    /**
+     *
+     */
+    public Object getContent(DataSource dataSource) throws IOException {
+        return new StreamSource(dataSource.getInputStream());
+    }
+
+    /**
+     * construct an object from a byte stream
+     * (similar semantically to previous method, we are deciding
+     *  which one to support)
+     */
+    public void writeTo(Object obj, String mimeType, OutputStream os)
+        throws IOException {
+        if (!mimeType.equals("text/xml") && !mimeType.equals("application/xml"))
+            throw new IOException(
+                "Invalid content type \"" + mimeType + "\" for XmlDCH");
+
+
+        try {
+            Transformer transformer = EfficientStreamingTransformer.newTransformer();
+            StreamResult result = new StreamResult(os);
+            if (obj instanceof DataSource) {
+                // Streaming transform applies only to javax.xml.transform.StreamSource
+                transformer.transform((Source) getContent((DataSource)obj), result);
+            } else {
+                transformer.transform((Source) obj, result);
+            }
+        } catch (Exception ex) {
+            throw new IOException(
+                "Unable to run the JAXP transformer on a stream "
+                    + ex.getMessage());
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/dynamic/SOAPFactoryDynamicImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/dynamic/SOAPFactoryDynamicImpl.java
new file mode 100644
index 0000000..4331e98
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/dynamic/SOAPFactoryDynamicImpl.java
@@ -0,0 +1,52 @@
+/*
+ * $Id: SOAPFactoryDynamicImpl.java,v 1.2 2006/01/27 12:49:32 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.dynamic;
+
+import javax.xml.soap.Detail;
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPFactoryImpl;
+
+public class SOAPFactoryDynamicImpl extends SOAPFactoryImpl {
+    protected SOAPDocumentImpl createDocument() {
+        return null;
+    }
+
+    public Detail createDetail() throws SOAPException {
+        throw new UnsupportedOperationException(
+                "createDetail() not supported for Dynamic Protocol");
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/dynamic/SOAPMessageFactoryDynamicImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/dynamic/SOAPMessageFactoryDynamicImpl.java
new file mode 100644
index 0000000..51afa7b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/dynamic/SOAPMessageFactoryDynamicImpl.java
@@ -0,0 +1,49 @@
+/*
+ * $Id: SOAPMessageFactoryDynamicImpl.java,v 1.4 2006/01/27 12:49:32 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.dynamic;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.MessageFactoryImpl;
+
+public class SOAPMessageFactoryDynamicImpl extends MessageFactoryImpl {
+    public SOAPMessage createMessage() throws SOAPException {
+        throw new UnsupportedOperationException(
+                "createMessage() not supported for Dynamic Protocol");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/BodyElementImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/BodyElementImpl.java
new file mode 100644
index 0000000..a14e586
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/BodyElementImpl.java
@@ -0,0 +1,64 @@
+/*
+ * $Id: BodyElementImpl.java,v 1.14 2006/01/27 12:49:33 vj135062 Exp $
+ * $Revision: 1.14 $
+ * $Date: 2006/01/27 12:49:33 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+
+/**
+ * All elements of the SOAP-ENV:BODY.
+ *
+ * @author Anil Vijendran (akv@eng.sun.com)
+ */
+public abstract class BodyElementImpl
+    extends ElementImpl
+    implements SOAPBodyElement {
+
+    public BodyElementImpl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+
+    public BodyElementImpl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    public void setParentElement(SOAPElement element) throws SOAPException {
+        if (! (element instanceof SOAPBody)) {
+            log.severe("SAAJ0101.impl.parent.of.body.elem.mustbe.body");
+            throw new SOAPException("Parent of a SOAPBodyElement has to be a SOAPBody");
+        }
+        super.setParentElement(element);
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/BodyImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/BodyImpl.java
new file mode 100644
index 0000000..ebf51c5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/BodyImpl.java
@@ -0,0 +1,330 @@
+/*
+ * $Id: BodyImpl.java,v 1.41 2006/01/27 12:49:34 vj135062 Exp $
+ * $Revision: 1.41 $
+ * $Date: 2006/01/27 12:49:34 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.Iterator;
+import java.util.Locale;
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+
+import org.w3c.dom.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+/**
+ * The implementation of SOAP-ENV:BODY or the SOAPBody abstraction.
+ *
+ * @author Anil Vijendran (anil@sun.com)
+ */
+public abstract class BodyImpl extends ElementImpl implements SOAPBody {
+    private SOAPFault fault;
+
+    protected BodyImpl(SOAPDocumentImpl ownerDoc, NameImpl bodyName) {
+        super(ownerDoc, bodyName);
+    }
+
+    protected abstract NameImpl getFaultName(String name);
+    protected abstract boolean isFault(SOAPElement child);
+    protected abstract SOAPBodyElement createBodyElement(Name name);
+    protected abstract SOAPBodyElement createBodyElement(QName name);
+    protected abstract SOAPFault createFaultElement();
+    protected abstract QName getDefaultFaultCode();
+
+    public SOAPFault addFault() throws SOAPException {
+        if (hasFault()) {
+            log.severe("SAAJ0110.impl.fault.already.exists");
+            throw new SOAPExceptionImpl("Error: Fault already exists");
+        }
+
+        fault = createFaultElement();
+
+        addNode(fault);
+
+        fault.setFaultCode(getDefaultFaultCode());
+        fault.setFaultString("Fault string, and possibly fault code, not set");
+
+        return fault;
+    }
+
+    public SOAPFault addFault(
+        Name faultCode,
+        String faultString,
+        Locale locale)
+        throws SOAPException {
+
+        SOAPFault fault = addFault();
+        fault.setFaultCode(faultCode);
+        fault.setFaultString(faultString, locale);
+        return fault;
+    }
+
+   public SOAPFault addFault(
+        QName faultCode,
+        String faultString,
+        Locale locale)
+        throws SOAPException {
+
+        SOAPFault fault = addFault();
+        fault.setFaultCode(faultCode);
+        fault.setFaultString(faultString, locale);
+        return fault;
+    }
+
+    public SOAPFault addFault(Name faultCode, String faultString)
+        throws SOAPException {
+
+        SOAPFault fault = addFault();
+        fault.setFaultCode(faultCode);
+        fault.setFaultString(faultString);
+        return fault;
+    }
+
+    public SOAPFault addFault(QName faultCode, String faultString)
+        throws SOAPException {
+
+        SOAPFault fault = addFault();
+        fault.setFaultCode(faultCode);
+        fault.setFaultString(faultString);
+        return fault;
+    }
+
+    void initializeFault() {
+        FaultImpl flt = (FaultImpl) findFault();
+        fault = flt;
+    }
+
+    protected SOAPElement findFault() {
+        Iterator eachChild = getChildElementNodes();
+        while (eachChild.hasNext()) {
+            SOAPElement child = (SOAPElement) eachChild.next();
+            if (isFault(child)) {
+                return child;
+            }
+        }
+
+        return null;
+    }
+
+    public boolean hasFault() {
+        initializeFault();
+        return fault != null;
+    }
+
+    public SOAPFault getFault() {
+        if (hasFault())
+            return fault;
+        return null;
+    }
+
+    public SOAPBodyElement addBodyElement(Name name) throws SOAPException {
+        SOAPBodyElement newBodyElement =
+            (SOAPBodyElement) ElementFactory.createNamedElement(
+                ((SOAPDocument) getOwnerDocument()).getDocument(),
+                name.getLocalName(),
+                name.getPrefix(),
+                name.getURI());
+        if (newBodyElement == null) {
+            newBodyElement = createBodyElement(name);
+        }
+        addNode(newBodyElement);
+        return newBodyElement;
+    }
+
+    public SOAPBodyElement addBodyElement(QName qname) throws SOAPException {
+        SOAPBodyElement newBodyElement =
+            (SOAPBodyElement) ElementFactory.createNamedElement(
+                ((SOAPDocument) getOwnerDocument()).getDocument(),
+                qname.getLocalPart(),
+                qname.getPrefix(),
+                qname.getNamespaceURI());
+        if (newBodyElement == null) {
+            newBodyElement = createBodyElement(qname);
+        }
+        addNode(newBodyElement);
+        return newBodyElement;
+    }
+
+    public void setParentElement(SOAPElement element) throws SOAPException {
+
+        if (!(element instanceof SOAPEnvelope)) {
+            log.severe("SAAJ0111.impl.body.parent.must.be.envelope");
+            throw new SOAPException("Parent of SOAPBody has to be a SOAPEnvelope");
+        }
+        super.setParentElement(element);
+    }
+
+    protected SOAPElement addElement(Name name) throws SOAPException {
+        return addBodyElement(name);
+    }
+
+    protected SOAPElement addElement(QName name) throws SOAPException {
+        return addBodyElement(name);
+    }
+
+    //    public Node insertBefore(Node newElement, Node ref) throws DOMException {
+    //        if (!(newElement instanceof SOAPBodyElement) && (newElement instanceof SOAPElement)) {
+    //            newElement = new ElementWrapper((ElementImpl) newElement);
+    //        }
+    //        return super.insertBefore(newElement, ref);
+    //    }
+    //
+    //    public Node replaceChild(Node newElement, Node ref) throws DOMException {
+    //        if (!(newElement instanceof SOAPBodyElement) && (newElement instanceof SOAPElement)) {
+    //            newElement = new ElementWrapper((ElementImpl) newElement);
+    //        }
+    //        return super.replaceChild(newElement, ref);
+    //    }
+
+    public SOAPBodyElement addDocument(Document document)
+        throws SOAPException {
+        /*
+
+                Element rootNode =
+                    document.getDocumentElement();
+                // Causes all deferred nodes to be inflated
+                rootNode.normalize();
+                adoptElement(rootNode);
+                SOAPBodyElement bodyElement = (SOAPBodyElement) convertToSoapElement(rootNode);
+                addNode(bodyElement);
+                return bodyElement;
+        */
+        ///*
+        SOAPBodyElement newBodyElement = null;
+        DocumentFragment docFrag = document.createDocumentFragment();
+        Element rootElement = document.getDocumentElement();
+        if(rootElement != null) {
+            docFrag.appendChild(rootElement);
+
+            Document ownerDoc = getOwnerDocument();
+            // This copies the whole tree which could be very big so it's slow.
+            // However, it does have the advantage of actually working.
+            org.w3c.dom.Node replacingNode = ownerDoc.importNode(docFrag, true);
+            // Adding replacingNode at the last of the children list of body
+            addNode(replacingNode);
+            Iterator i =
+                getChildElements(NameImpl.copyElementName(rootElement));
+            // Return the child element with the required name which is at the
+            // end of the list
+            while(i.hasNext())
+                newBodyElement = (SOAPBodyElement) i.next();
+        }
+        return newBodyElement;
+        //*/
+    }
+
+    protected SOAPElement convertToSoapElement(Element element) {
+        if ((element instanceof SOAPBodyElement) &&
+            //this check is required because ElementImpl currently
+            // implements SOAPBodyElement
+            !(element.getClass().equals(ElementImpl.class))) {
+            return (SOAPElement) element;
+        } else {
+            return replaceElementWithSOAPElement(
+                element,
+                (ElementImpl) createBodyElement(NameImpl
+                    .copyElementName(element)));
+        }
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        log.log(Level.SEVERE,
+                "SAAJ0146.impl.invalid.name.change.requested",
+                new Object[] {elementQName.getLocalPart(),
+                              newName.getLocalPart()});
+        throw new SOAPException("Cannot change name for "
+                                + elementQName.getLocalPart() + " to "
+                                + newName.getLocalPart());
+    }
+
+    public Document extractContentAsDocument() throws SOAPException {
+
+        Iterator eachChild = getChildElements();
+        javax.xml.soap.Node firstBodyElement = null;
+
+        while (eachChild.hasNext() &&
+               !(firstBodyElement instanceof SOAPElement))
+            firstBodyElement = (javax.xml.soap.Node) eachChild.next();
+
+        boolean exactlyOneChildElement = true;
+        if (firstBodyElement == null)
+            exactlyOneChildElement = false;
+        else {
+            for (org.w3c.dom.Node node = firstBodyElement.getNextSibling();
+                 node != null;
+                 node = node.getNextSibling()) {
+
+                if (node instanceof Element) {
+                    exactlyOneChildElement = false;
+                    break;
+                }
+            }
+        }
+
+        if(!exactlyOneChildElement) {
+            log.log(Level.SEVERE,
+                    "SAAJ0250.impl.body.should.have.exactly.one.child");
+            throw new SOAPException("Cannot extract Document from body");
+        }
+
+        Document document = null;
+        try {
+            DocumentBuilderFactory factory =
+                new com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl();
+            factory.setNamespaceAware(true);
+            DocumentBuilder builder = factory.newDocumentBuilder();
+            document = builder.newDocument();
+
+            Element rootElement = (Element) document.importNode(
+                                                firstBodyElement,
+                                                true);
+
+            document.appendChild(rootElement);
+
+        } catch(Exception e) {
+            log.log(Level.SEVERE,
+                    "SAAJ0251.impl.cannot.extract.document.from.body");
+            throw new SOAPExceptionImpl(
+                "Unable to extract Document from body", e);
+        }
+
+        firstBodyElement.detachNode();
+
+        return document;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/CDATAImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/CDATAImpl.java
new file mode 100644
index 0000000..99431d2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/CDATAImpl.java
@@ -0,0 +1,95 @@
+/*
+ * $Id: CDATAImpl.java,v 1.19 2006/01/27 12:49:34 vj135062 Exp $
+ * $Revision: 1.19 $
+ * $Date: 2006/01/27 12:49:34 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.logging.Logger;
+
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class CDATAImpl
+    extends com.sun.org.apache.xerces.internal.dom.CDATASectionImpl
+    implements javax.xml.soap.Text {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_IMPL_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.impl.LocalStrings");
+
+    static final String cdataUC = "<![CDATA[";
+    static final String cdataLC = "<![cdata[";
+
+    public CDATAImpl(SOAPDocumentImpl ownerDoc, String text) {
+        super(ownerDoc, text);
+    }
+
+    public String getValue() {
+        String nodeValue = getNodeValue();
+        return (nodeValue.equals("") ? null : nodeValue);
+    }
+
+    public void setValue(String text) {
+        setNodeValue(text);
+    }
+
+    public void setParentElement(SOAPElement parent) throws SOAPException {
+        if (parent == null) {
+            log.severe("SAAJ0145.impl.no.null.to.parent.elem");
+            throw new SOAPException("Cannot pass NULL to setParentElement");
+        }
+        ((ElementImpl) parent).addNode(this);
+    }
+
+    public SOAPElement getParentElement() {
+        return (SOAPElement) getParentNode();
+    }
+
+
+    public void detachNode() {
+        org.w3c.dom.Node parent = getParentNode();
+        if (parent != null) {
+            parent.removeChild(this);
+        }
+    }
+
+    public void recycleNode() {
+        detachNode();
+        // TBD
+        //  - add this to the factory so subsequent
+        //    creations can reuse this object.
+    }
+
+    public boolean isComment() {
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/CommentImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/CommentImpl.java
new file mode 100644
index 0000000..fe775b1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/CommentImpl.java
@@ -0,0 +1,119 @@
+/*
+ * $Id: CommentImpl.java,v 1.17 2006/01/27 12:49:34 vj135062 Exp $
+ * $Revision: 1.17 $
+ * $Date: 2006/01/27 12:49:34 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.ResourceBundle;
+import java.util.logging.Logger;
+
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPException;
+
+import org.w3c.dom.DOMException;
+import org.w3c.dom.Text;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class CommentImpl
+    extends com.sun.org.apache.xerces.internal.dom.CommentImpl
+    implements javax.xml.soap.Text, org.w3c.dom.Comment {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_IMPL_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.impl.LocalStrings");
+    protected static ResourceBundle rb =
+        log.getResourceBundle();
+
+    public CommentImpl(SOAPDocumentImpl ownerDoc, String text) {
+        super(ownerDoc, text);
+    }
+
+    public String getValue() {
+        String nodeValue = getNodeValue();
+        return (nodeValue.equals("") ? null : nodeValue);
+    }
+
+    public void setValue(String text) {
+        setNodeValue(text);
+    }
+
+
+    public void setParentElement(SOAPElement element) throws SOAPException {
+        if (element == null) {
+            log.severe("SAAJ0112.impl.no.null.to.parent.elem");
+            throw new SOAPException("Cannot pass NULL to setParentElement");
+        }
+        ((ElementImpl) element).addNode(this);
+    }
+
+    public SOAPElement getParentElement() {
+        return (SOAPElement) getParentNode();
+    }
+
+    public void detachNode() {
+        org.w3c.dom.Node parent = getParentNode();
+        if (parent != null) {
+            parent.removeChild(this);
+        }
+    }
+
+    public void recycleNode() {
+        detachNode();
+        // TBD
+        //  - add this to the factory so subsequent
+        //    creations can reuse this object.
+    }
+
+    public boolean isComment() {
+        return true;
+    }
+
+    public Text splitText(int offset) throws DOMException {
+        log.severe("SAAJ0113.impl.cannot.split.text.from.comment");
+        throw new UnsupportedOperationException("Cannot split text from a Comment Node.");
+    }
+
+    public Text replaceWholeText(String content) throws DOMException {
+        log.severe("SAAJ0114.impl.cannot.replace.wholetext.from.comment");
+        throw new UnsupportedOperationException("Cannot replace Whole Text from a Comment Node.");
+    }
+
+    public String getWholeText() {
+        //TODO: maybe we have to implement this in future.
+        throw new UnsupportedOperationException("Not Supported");
+    }
+
+    public boolean isElementContentWhitespace() {
+        //TODO: maybe we have to implement this in future.
+        throw new UnsupportedOperationException("Not Supported");
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/DetailEntryImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/DetailEntryImpl.java
new file mode 100644
index 0000000..24a8d32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/DetailEntryImpl.java
@@ -0,0 +1,48 @@
+/*
+ * $Id: DetailEntryImpl.java,v 1.8 2006/01/27 12:49:34 vj135062 Exp $
+ * $Revision: 1.8 $
+ * $Date: 2006/01/27 12:49:34 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.DetailEntry;
+import javax.xml.soap.Name;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+
+public abstract class DetailEntryImpl
+    extends ElementImpl
+    implements DetailEntry {
+    public DetailEntryImpl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+    public DetailEntryImpl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/DetailImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/DetailImpl.java
new file mode 100644
index 0000000..8c67ca0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/DetailImpl.java
@@ -0,0 +1,127 @@
+/*
+ * $Id: DetailImpl.java,v 1.16 2006/01/27 12:49:34 vj135062 Exp $
+ * $Revision: 1.16 $
+ * $Date: 2006/01/27 12:49:34 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.Iterator;
+import java.util.NoSuchElementException;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import org.w3c.dom.Element;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public abstract class DetailImpl extends FaultElementImpl implements Detail {
+    public DetailImpl(SOAPDocumentImpl ownerDoc, NameImpl detailName) {
+        super(ownerDoc, detailName);
+    }
+
+    protected abstract DetailEntry createDetailEntry(Name name);
+    protected abstract DetailEntry createDetailEntry(QName name);
+
+    public DetailEntry addDetailEntry(Name name) throws SOAPException {
+        DetailEntry entry = createDetailEntry(name);
+        addNode(entry);
+        return (DetailEntry) circumventBug5034339(entry);
+    }
+
+    public DetailEntry addDetailEntry(QName qname) throws SOAPException {
+        DetailEntry entry = createDetailEntry(qname);
+        addNode(entry);
+        return (DetailEntry) circumventBug5034339(entry);
+    }
+
+    protected SOAPElement addElement(Name name) throws SOAPException {
+        return addDetailEntry(name);
+    }
+
+    protected SOAPElement addElement(QName name) throws SOAPException {
+        return addDetailEntry(name);
+    }
+
+    protected SOAPElement convertToSoapElement(Element element) {
+        if (element instanceof DetailEntry) {
+            return (SOAPElement) element;
+        } else {
+            DetailEntry detailEntry =
+                createDetailEntry(NameImpl.copyElementName(element));
+            return replaceElementWithSOAPElement(
+                element,
+                (ElementImpl) detailEntry);
+        }
+    }
+
+    public Iterator getDetailEntries() {
+        return new Iterator() {
+            Iterator eachNode = getChildElementNodes();
+            SOAPElement next = null;
+            SOAPElement last = null;
+
+            public boolean hasNext() {
+                if (next == null) {
+                    while (eachNode.hasNext()) {
+                        next = (SOAPElement) eachNode.next();
+                        if (next instanceof DetailEntry) {
+                            break;
+                        }
+                        next = null;
+                    }
+                }
+                return next != null;
+            }
+
+            public Object next() {
+                if (!hasNext()) {
+                    throw new NoSuchElementException();
+                }
+                last = next;
+                next = null;
+                return last;
+            }
+
+            public void remove() {
+                if (last == null) {
+                    throw new IllegalStateException();
+                }
+                SOAPElement target = last;
+                removeChild(target);
+                last = null;
+            }
+        };
+    }
+
+   protected  boolean isStandardFaultElement() {
+       return true;
+   }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/ElementFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/ElementFactory.java
new file mode 100644
index 0000000..efae488
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/ElementFactory.java
@@ -0,0 +1,172 @@
+/*
+ * $Id: ElementFactory.java,v 1.16 2006/01/27 12:49:35 vj135062 Exp $
+ * $Revision: 1.16 $
+ * $Date: 2006/01/27 12:49:35 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.soap.ver1_1.*;
+import com.sun.xml.internal.messaging.saaj.soap.ver1_2.*;
+
+
+public class ElementFactory {
+    public static SOAPElement createElement(
+        SOAPDocumentImpl ownerDocument,
+        Name name) {
+        return createElement(
+            ownerDocument,
+            name.getLocalName(),
+            name.getPrefix(),
+            name.getURI());
+    }
+    public static SOAPElement createElement(
+        SOAPDocumentImpl ownerDocument,
+        QName name) {
+        return createElement(
+            ownerDocument,
+            name.getLocalPart(),
+            name.getPrefix(),
+            name.getNamespaceURI());
+    }
+
+    public static SOAPElement createElement(
+        SOAPDocumentImpl ownerDocument,
+        String localName,
+        String prefix,
+        String namespaceUri) {
+
+
+        if (ownerDocument == null) {
+            if (NameImpl.SOAP11_NAMESPACE.equals(namespaceUri)) {
+                ownerDocument = new SOAPPart1_1Impl().getDocument();
+            } else if (NameImpl.SOAP12_NAMESPACE.equals(namespaceUri)) {
+                ownerDocument = new SOAPPart1_2Impl().getDocument();
+            } else {
+                ownerDocument = new SOAPDocumentImpl(null);
+            }
+        }
+
+        SOAPElement newElement =
+            createNamedElement(ownerDocument, localName, prefix, namespaceUri);
+
+        return newElement != null
+            ? newElement
+            : new ElementImpl(
+                ownerDocument,
+                namespaceUri,
+                NameImpl.createQName(prefix, localName));
+    }
+
+    public static SOAPElement createNamedElement(
+        SOAPDocumentImpl ownerDocument,
+        String localName,
+        String prefix,
+        String namespaceUri) {
+
+        if (prefix == null) {
+            prefix = NameImpl.SOAP_ENVELOPE_PREFIX;
+        }
+
+        if (localName.equalsIgnoreCase("Envelope")) {
+            if (NameImpl.SOAP11_NAMESPACE.equals(namespaceUri)) {
+                return new Envelope1_1Impl(ownerDocument, prefix);
+            } else if (NameImpl.SOAP12_NAMESPACE.equals(namespaceUri)) {
+                return new Envelope1_2Impl(ownerDocument, prefix);
+            }
+        }
+        if (localName.equalsIgnoreCase("Body")) {
+            if (NameImpl.SOAP11_NAMESPACE.equals(namespaceUri)) {
+                return new Body1_1Impl(ownerDocument, prefix);
+            } else if (NameImpl.SOAP12_NAMESPACE.equals(namespaceUri)) {
+                return new Body1_2Impl(ownerDocument, prefix);
+            }
+        }
+        if (localName.equalsIgnoreCase("Header")) {
+            if (NameImpl.SOAP11_NAMESPACE.equals(namespaceUri)) {
+                return new Header1_1Impl(ownerDocument, prefix);
+            } else if (NameImpl.SOAP12_NAMESPACE.equals(namespaceUri)) {
+                return new Header1_2Impl(ownerDocument, prefix);
+            }
+        }
+        if (localName.equalsIgnoreCase("Fault")) {
+            SOAPFault fault = null;
+            if (NameImpl.SOAP11_NAMESPACE.equals(namespaceUri)) {
+                fault = new Fault1_1Impl(ownerDocument, prefix);
+            } else if (NameImpl.SOAP12_NAMESPACE.equals(namespaceUri)) {
+                fault = new Fault1_2Impl(ownerDocument, prefix);
+            }
+
+            if (fault != null) {
+//                try {
+//                    fault.addNamespaceDeclaration(
+//                        NameImpl.SOAP_ENVELOPE_PREFIX,
+//                        SOAPConstants.URI_NS_SOAP_ENVELOPE);
+//                    fault.setFaultCode(
+//                        NameImpl.create(
+//                            "Server",
+//                            NameImpl.SOAP_ENVELOPE_PREFIX,
+//                            SOAPConstants.URI_NS_SOAP_ENVELOPE));
+//                    fault.setFaultString(
+//                        "Fault string, and possibly fault code, not set");
+//                } catch (SOAPException e) {
+//                }
+                return fault;
+            }
+
+        }
+        if (localName.equalsIgnoreCase("Detail")) {
+            if (NameImpl.SOAP11_NAMESPACE.equals(namespaceUri)) {
+                return new Detail1_1Impl(ownerDocument, prefix);
+            } else if (NameImpl.SOAP12_NAMESPACE.equals(namespaceUri)) {
+                return new Detail1_2Impl(ownerDocument, prefix);
+            }
+        }
+        if (localName.equalsIgnoreCase("faultcode")
+            || localName.equalsIgnoreCase("faultstring")
+            || localName.equalsIgnoreCase("faultactor")) {
+            // SOAP 1.2 does not have fault(code/string/actor)
+            // So there is no else case required
+            if (NameImpl.SOAP11_NAMESPACE.equals(namespaceUri)) {
+                return new FaultElement1_1Impl(ownerDocument,
+                                               localName,
+                                               prefix);
+            }
+        }
+
+        return null;
+    }
+
+    protected static void invalidCreate(String msg) {
+        throw new TreeException(msg);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/ElementImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/ElementImpl.java
new file mode 100644
index 0000000..f9cfa2a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/ElementImpl.java
@@ -0,0 +1,1233 @@
+/*
+ * $Id: ElementImpl.java,v 1.1.1.1 2006/01/27 13:10:57 kumarjayanti Exp $
+ * $Revision: 1.1.1.1 $
+ * $Date: 2006/01/27 13:10:57 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.*;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.org.apache.xerces.internal.xni.NamespaceContext;
+import org.w3c.dom.*;
+import org.w3c.dom.Node;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.*;
+
+public class ElementImpl
+    extends com.sun.org.apache.xerces.internal.dom.ElementNSImpl
+    implements SOAPElement, SOAPBodyElement {
+
+    public static final String DSIG_NS = "http://www.w3.org/2000/09/xmldsig#".intern();
+    public static final String XENC_NS = "http://www.w3.org/2001/04/xmlenc#".intern();
+    public static final String WSU_NS = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd".intern();
+
+    private AttributeManager encodingStyleAttribute = new AttributeManager();
+
+    protected QName elementQName;
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_IMPL_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.impl.LocalStrings");
+
+    public ElementImpl(SOAPDocumentImpl ownerDoc, Name name) {
+        super(
+            ownerDoc,
+            name.getURI(),
+            name.getQualifiedName(),
+            name.getLocalName());
+        elementQName = NameImpl.convertToQName(name);
+    }
+
+    public ElementImpl(SOAPDocumentImpl ownerDoc, QName name) {
+        super(
+            ownerDoc,
+            name.getNamespaceURI(),
+            getQualifiedName(name),
+            name.getLocalPart());
+        elementQName = name;
+    }
+
+    public ElementImpl(
+        SOAPDocumentImpl ownerDoc,
+        String uri,
+        String qualifiedName) {
+
+        super(ownerDoc, uri, qualifiedName);
+        elementQName =
+            new QName(uri, getLocalPart(qualifiedName), getPrefix(qualifiedName));
+    }
+
+    public void ensureNamespaceIsDeclared(String prefix, String uri) {
+        String alreadyDeclaredUri = getNamespaceURI(prefix);
+        if (alreadyDeclaredUri == null || !alreadyDeclaredUri.equals(uri)) {
+            try {
+                addNamespaceDeclaration(prefix, uri);
+            } catch (SOAPException e) { /*ignore*/
+            }
+        }
+    }
+
+    public Document getOwnerDocument() {
+        SOAPDocument ownerSOAPDocument =
+            ((SOAPDocument) super.getOwnerDocument());
+        if (ownerSOAPDocument == null) {
+            return null;
+        }
+        return ownerSOAPDocument.getDocument();
+    }
+
+    public SOAPElement addChildElement(Name name) throws SOAPException {
+        return  addElement(name);
+    }
+
+    public SOAPElement addChildElement(QName qname) throws SOAPException {
+        return  addElement(qname);
+    }
+
+    public SOAPElement addChildElement(String localName) throws SOAPException {
+        return (SOAPElement) addChildElement(
+            NameImpl.createFromUnqualifiedName(localName));
+    }
+
+    public SOAPElement addChildElement(String localName, String prefix)
+        throws SOAPException {
+        String uri = getNamespaceURI(prefix);
+        if (uri == null) {
+            log.log(
+                Level.SEVERE,
+                "SAAJ0101.impl.parent.of.body.elem.mustbe.body",
+                new String[] { prefix });
+            throw new SOAPExceptionImpl(
+                "Unable to locate namespace for prefix " + prefix);
+        }
+        return addChildElement(localName, prefix, uri);
+    }
+
+    public String getNamespaceURI(String prefix) {
+
+        if ("xmlns".equals(prefix)) {
+            return NamespaceContext.XMLNS_URI;
+        }
+
+        if("xml".equals(prefix)) {
+            return NamespaceContext.XML_URI;
+        }
+
+        if ("".equals(prefix)) {
+
+            org.w3c.dom.Node currentAncestor = this;
+            while (currentAncestor != null &&
+                   !(currentAncestor instanceof Document)) {
+
+                if (currentAncestor instanceof ElementImpl) {
+                    QName name = ((ElementImpl) currentAncestor).getElementQName();
+                    /*
+                    if (prefix.equals(name.getPrefix())) {
+                        String uri = name.getNamespaceURI();
+                        if ("".equals(uri)) {
+                            return null;
+                        }
+                        else {
+                            return uri;
+                        }
+                    }*/
+                    if (((Element) currentAncestor).hasAttributeNS(
+                            NamespaceContext.XMLNS_URI, "xmlns")) {
+
+                        String uri =
+                            ((Element) currentAncestor).getAttributeNS(
+                                NamespaceContext.XMLNS_URI, "xmlns");
+                        if ("".equals(uri))
+                            return null;
+                        else {
+                            return uri;
+                        }
+                    }
+                }
+                currentAncestor = currentAncestor.getParentNode();
+            }
+
+        } else if (prefix != null) {
+            // Find if there's an ancester whose name contains this prefix
+            org.w3c.dom.Node currentAncestor = this;
+            while (currentAncestor != null &&
+                   !(currentAncestor instanceof Document)) {
+                /*
+                if (prefix.equals(currentAncestor.getPrefix())) {
+                    String uri = currentAncestor.getNamespaceURI();
+                    // this is because the javadoc says getNamespaceURI() is not a computed value
+                    // and URI for a non-empty prefix cannot be null
+                    if (uri != null)
+                        return uri;
+                }*/
+                if (((Element) currentAncestor).hasAttributeNS(
+                        NamespaceContext.XMLNS_URI, prefix)) {
+                    return ((Element) currentAncestor).getAttributeNS(
+                               NamespaceContext.XMLNS_URI, prefix);
+                }
+
+                currentAncestor = currentAncestor.getParentNode();
+            }
+        }
+
+        return null;
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        ElementImpl copy =
+            new ElementImpl((SOAPDocumentImpl) getOwnerDocument(), newName);
+        return replaceElementWithSOAPElement(this,copy);
+    }
+
+    public QName createQName(String localName, String prefix)
+        throws SOAPException {
+        String uri = getNamespaceURI(prefix);
+        if (uri == null) {
+            log.log(Level.SEVERE, "SAAJ0102.impl.cannot.locate.ns",
+                    new Object[] {prefix});
+            throw new SOAPException("Unable to locate namespace for prefix "
+                                    + prefix);
+        }
+        return new QName(uri, localName, prefix);
+    }
+
+    public String getNamespacePrefix(String uri) {
+
+        NamespaceContextIterator eachNamespace = getNamespaceContextNodes();
+        while (eachNamespace.hasNext()) {
+            org.w3c.dom.Attr namespaceDecl = eachNamespace.nextNamespaceAttr();
+            if (namespaceDecl.getNodeValue().equals(uri)) {
+                String candidatePrefix = namespaceDecl.getLocalName();
+                if ("xmlns".equals(candidatePrefix))
+                    return "";
+                else
+                    return candidatePrefix;
+            }
+        }
+
+        // Find if any of the ancestors' name has this uri
+        org.w3c.dom.Node currentAncestor = this;
+        while (currentAncestor != null &&
+               !(currentAncestor instanceof Document)) {
+
+            if (uri.equals(currentAncestor.getNamespaceURI()))
+                return currentAncestor.getPrefix();
+            currentAncestor = currentAncestor.getParentNode();
+        }
+
+        return null;
+    }
+
+    protected org.w3c.dom.Attr getNamespaceAttr(String prefix) {
+        NamespaceContextIterator eachNamespace = getNamespaceContextNodes();
+        if (!"".equals(prefix))
+            prefix = ":"+prefix;
+        while (eachNamespace.hasNext()) {
+            org.w3c.dom.Attr namespaceDecl = eachNamespace.nextNamespaceAttr();
+            if (!"".equals(prefix)) {
+                if (namespaceDecl.getNodeName().endsWith(prefix))
+                    return namespaceDecl;
+            } else {
+                if (namespaceDecl.getNodeName().equals("xmlns"))
+                    return namespaceDecl;
+            }
+        }
+        return null;
+    }
+
+    public NamespaceContextIterator getNamespaceContextNodes() {
+        return getNamespaceContextNodes(true);
+    }
+
+    public NamespaceContextIterator getNamespaceContextNodes(boolean traverseStack) {
+        return new NamespaceContextIterator(this, traverseStack);
+    }
+
+    public SOAPElement addChildElement(
+        String localName,
+        String prefix,
+        String uri)
+        throws SOAPException {
+
+        SOAPElement newElement = createElement(NameImpl.create(localName, prefix, uri));
+        addNode(newElement);
+        return convertToSoapElement(newElement);
+    }
+
+    public SOAPElement addChildElement(SOAPElement element)
+        throws SOAPException {
+
+        // check if Element falls in SOAP 1.1 or 1.2 namespace.
+        String elementURI = element.getElementName().getURI();
+        String localName = element.getLocalName();
+
+        if ((SOAPConstants.URI_NS_SOAP_ENVELOPE).equals(elementURI)
+            || (SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE).equals(elementURI)) {
+
+
+            if ("Envelope".equalsIgnoreCase(localName) ||
+                "Header".equalsIgnoreCase(localName) || "Body".equalsIgnoreCase(localName)) {
+                log.severe("SAAJ0103.impl.cannot.add.fragements");
+                throw new SOAPExceptionImpl(
+                    "Cannot add fragments which contain elements "
+                        + "which are in the SOAP namespace");
+            }
+
+            if ("Fault".equalsIgnoreCase(localName) && !"Body".equalsIgnoreCase(this.getLocalName())) {
+                log.severe("SAAJ0154.impl.adding.fault.to.nonbody");
+                throw new SOAPExceptionImpl("Cannot add a SOAPFault as a child of " + this.getLocalName());
+            }
+
+            if ("Detail".equalsIgnoreCase(localName) && !"Fault".equalsIgnoreCase(this.getLocalName())) {
+                log.severe("SAAJ0155.impl.adding.detail.nonfault");
+                throw new SOAPExceptionImpl("Cannot add a Detail as a child of " + this.getLocalName());
+            }
+
+            if ("Fault".equalsIgnoreCase(localName)) {
+               // if body is not empty throw an exception
+               if (!elementURI.equals(this.getElementName().getURI())) {
+                   log.severe("SAAJ0158.impl.version.mismatch.fault");
+                   throw new SOAPExceptionImpl("SOAP Version mismatch encountered when trying to add SOAPFault to SOAPBody");
+               }
+               Iterator it = this.getChildElements();
+               if (it.hasNext()) {
+                   log.severe("SAAJ0156.impl.adding.fault.error");
+                   throw new SOAPExceptionImpl("Cannot add SOAPFault as a child of a non-Empty SOAPBody");
+               }
+            }
+        }
+
+        // preserve the encodingStyle attr as it may get lost in the import
+        String encodingStyle = element.getEncodingStyle();
+
+        ElementImpl importedElement = (ElementImpl) importElement(element);
+        addNode(importedElement);
+
+        if (encodingStyle != null)
+            importedElement.setEncodingStyle(encodingStyle);
+
+        return convertToSoapElement(importedElement);
+    }
+
+    protected Element importElement(Element element) {
+        Document document = getOwnerDocument();
+        Document oldDocument = element.getOwnerDocument();
+        if (!oldDocument.equals(document)) {
+            return (Element) document.importNode(element, true);
+        } else {
+            return element;
+        }
+    }
+
+    protected SOAPElement addElement(Name name) throws SOAPException {
+        SOAPElement newElement = createElement(name);
+        addNode(newElement);
+        return circumventBug5034339(newElement);
+    }
+
+    protected SOAPElement addElement(QName name) throws SOAPException {
+        SOAPElement newElement = createElement(name);
+        addNode(newElement);
+        return circumventBug5034339(newElement);
+    }
+
+    protected SOAPElement createElement(Name name) {
+
+        if (isNamespaceQualified(name)) {
+            return (SOAPElement)
+                getOwnerDocument().createElementNS(
+                                       name.getURI(),
+                                       name.getQualifiedName());
+        } else {
+            return (SOAPElement)
+                getOwnerDocument().createElement(name.getQualifiedName());
+        }
+    }
+
+    protected SOAPElement createElement(QName name) {
+
+        if (isNamespaceQualified(name)) {
+            return (SOAPElement)
+                getOwnerDocument().createElementNS(
+                                       name.getNamespaceURI(),
+                                       getQualifiedName(name));
+        } else {
+            return (SOAPElement)
+                getOwnerDocument().createElement(getQualifiedName(name));
+        }
+    }
+
+    protected void addNode(org.w3c.dom.Node newElement) throws SOAPException {
+        insertBefore(newElement, null);
+
+        if (getOwnerDocument() instanceof DocumentFragment)
+            return;
+
+        if (newElement instanceof ElementImpl) {
+            ElementImpl element = (ElementImpl) newElement;
+            QName elementName = element.getElementQName();
+            if (!"".equals(elementName.getNamespaceURI())) {
+                element.ensureNamespaceIsDeclared(
+                    elementName.getPrefix(), elementName.getNamespaceURI());
+            }
+        }
+
+    }
+
+    protected SOAPElement findChild(NameImpl name) {
+        Iterator eachChild = getChildElementNodes();
+        while (eachChild.hasNext()) {
+            SOAPElement child = (SOAPElement) eachChild.next();
+            if (child.getElementName().equals(name)) {
+                return child;
+            }
+        }
+
+        return null;
+    }
+
+    public SOAPElement addTextNode(String text) throws SOAPException {
+        if (text.startsWith(CDATAImpl.cdataUC)
+            || text.startsWith(CDATAImpl.cdataLC))
+            return addCDATA(
+                text.substring(CDATAImpl.cdataUC.length(), text.length() - 3));
+        return addText(text);
+    }
+
+    protected SOAPElement addCDATA(String text) throws SOAPException {
+        org.w3c.dom.Text cdata =
+            (org.w3c.dom.Text) getOwnerDocument().createCDATASection(text);
+        addNode(cdata);
+        return this;
+    }
+
+    protected SOAPElement addText(String text) throws SOAPException {
+        org.w3c.dom.Text textNode =
+            (org.w3c.dom.Text) getOwnerDocument().createTextNode(text);
+        addNode(textNode);
+        return this;
+    }
+
+    public SOAPElement addAttribute(Name name, String value)
+        throws SOAPException {
+        addAttributeBare(name, value);
+        if (!"".equals(name.getURI())) {
+            ensureNamespaceIsDeclared(name.getPrefix(), name.getURI());
+        }
+        return this;
+    }
+
+    public SOAPElement addAttribute(QName qname, String value)
+        throws SOAPException {
+        addAttributeBare(qname, value);
+        if (!"".equals(qname.getNamespaceURI())) {
+            ensureNamespaceIsDeclared(qname.getPrefix(), qname.getNamespaceURI());
+        }
+        return this;
+    }
+
+    private void addAttributeBare(Name name, String value) {
+        addAttributeBare(
+            name.getURI(),
+            name.getPrefix(),
+            name.getQualifiedName(),
+            value);
+    }
+    private void addAttributeBare(QName name, String value) {
+        addAttributeBare(
+            name.getNamespaceURI(),
+            name.getPrefix(),
+            getQualifiedName(name),
+            value);
+    }
+
+    private void addAttributeBare(
+        String uri,
+        String prefix,
+        String qualifiedName,
+        String value) {
+
+        uri = uri.length() == 0 ? null : uri;
+        if (qualifiedName.equals("xmlns")) {
+            uri = NamespaceContext.XMLNS_URI;
+        }
+
+        if (uri == null) {
+            setAttribute(qualifiedName, value);
+        } else {
+            setAttributeNS(uri, qualifiedName, value);
+        }
+    }
+
+    public SOAPElement addNamespaceDeclaration(String prefix, String uri)
+        throws SOAPException {
+        if (prefix.length() > 0) {
+            setAttributeNS(NamespaceContext.XMLNS_URI, "xmlns:" + prefix, uri);
+        } else {
+            setAttributeNS(NamespaceContext.XMLNS_URI, "xmlns", uri);
+        }
+        tryToFindEncodingStyleAttributeName();
+        return this;
+    }
+
+    public String getAttributeValue(Name name) {
+        return getAttributeValueFrom(this, name);
+    }
+
+    public String getAttributeValue(QName qname) {
+        return getAttributeValueFrom(
+                   this,
+                   qname.getNamespaceURI(),
+                   qname.getLocalPart(),
+                   qname.getPrefix(),
+                   getQualifiedName(qname));
+    }
+
+    public Iterator getAllAttributes() {
+        Iterator i = getAllAttributesFrom(this);
+        ArrayList list = new ArrayList();
+        while (i.hasNext()) {
+            Name name = (Name) i.next();
+            if (!"xmlns".equalsIgnoreCase(name.getPrefix()))
+                list.add(name);
+        }
+        return list.iterator();
+    }
+
+    public Iterator getAllAttributesAsQNames() {
+        Iterator i = getAllAttributesFrom(this);
+        ArrayList list = new ArrayList();
+        while (i.hasNext()) {
+            Name name = (Name) i.next();
+            if (!"xmlns".equalsIgnoreCase(name.getPrefix())) {
+                list.add(NameImpl.convertToQName(name));
+            }
+        }
+        return list.iterator();
+    }
+
+
+    public Iterator getNamespacePrefixes() {
+        return doGetNamespacePrefixes(false);
+    }
+
+    public Iterator getVisibleNamespacePrefixes() {
+        return doGetNamespacePrefixes(true);
+    }
+
+    protected Iterator doGetNamespacePrefixes(final boolean deep) {
+        return new Iterator() {
+            String next = null;
+            String last = null;
+            NamespaceContextIterator eachNamespace =
+                getNamespaceContextNodes(deep);
+
+            void findNext() {
+                while (next == null && eachNamespace.hasNext()) {
+                    String attributeKey =
+                        eachNamespace.nextNamespaceAttr().getNodeName();
+                    if (attributeKey.startsWith("xmlns:")) {
+                        next = attributeKey.substring("xmlns:".length());
+                    }
+                }
+            }
+
+            public boolean hasNext() {
+                findNext();
+                return next != null;
+            }
+
+            public Object next() {
+                findNext();
+                if (next == null) {
+                    throw new NoSuchElementException();
+                }
+
+                last = next;
+                next = null;
+                return last;
+            }
+
+            public void remove() {
+                if (last == null) {
+                    throw new IllegalStateException();
+                }
+                eachNamespace.remove();
+                next = null;
+                last = null;
+            }
+        };
+    }
+
+    public Name getElementName() {
+        return NameImpl.convertToName(elementQName);
+    }
+
+    public QName getElementQName() {
+        return elementQName;
+    }
+
+    public boolean removeAttribute(Name name) {
+        return removeAttribute(name.getURI(), name.getLocalName());
+    }
+
+    public boolean removeAttribute(QName name) {
+        return removeAttribute(name.getNamespaceURI(), name.getLocalPart());
+    }
+
+    private boolean removeAttribute(String uri, String localName) {
+        String nonzeroLengthUri =
+            (uri == null || uri.length() == 0) ? null : uri;
+        org.w3c.dom.Attr attribute =
+            getAttributeNodeNS(nonzeroLengthUri, localName);
+        if (attribute == null) {
+            return false;
+        }
+        removeAttributeNode(attribute);
+        return true;
+    }
+
+    public boolean removeNamespaceDeclaration(String prefix) {
+        org.w3c.dom.Attr declaration = getNamespaceAttr(prefix);
+        if (declaration == null) {
+            return false;
+        }
+        try {
+            removeAttributeNode(declaration);
+        } catch (DOMException de) {
+            // ignore
+        }
+        return true;
+    }
+
+    public Iterator getChildElements() {
+        return getChildElementsFrom(this);
+    }
+
+    protected SOAPElement convertToSoapElement(Element element) {
+        if (element instanceof SOAPElement) {
+            return (SOAPElement) element;
+        } else {
+            return replaceElementWithSOAPElement(
+                element,
+                (ElementImpl) createElement(NameImpl.copyElementName(element)));
+        }
+    }
+
+    protected static SOAPElement replaceElementWithSOAPElement(
+        Element element,
+        ElementImpl copy) {
+
+        Iterator eachAttribute = getAllAttributesFrom(element);
+        while (eachAttribute.hasNext()) {
+            Name name = (Name) eachAttribute.next();
+            copy.addAttributeBare(name, getAttributeValueFrom(element, name));
+        }
+
+        Iterator eachChild = getChildElementsFrom(element);
+        while (eachChild.hasNext()) {
+            Node nextChild = (Node) eachChild.next();
+            copy.insertBefore(nextChild, null);
+        }
+
+        Node parent = element.getParentNode();
+        if (parent != null) {
+            parent.replaceChild(copy, element);
+        } // XXX else throw an exception?
+
+        return copy;
+    }
+
+    protected Iterator getChildElementNodes() {
+        return new Iterator() {
+            Iterator eachNode = getChildElements();
+            Node next = null;
+            Node last = null;
+
+            public boolean hasNext() {
+                if (next == null) {
+                    while (eachNode.hasNext()) {
+                        Node node = (Node) eachNode.next();
+                        if (node instanceof SOAPElement) {
+                            next = node;
+                            break;
+                        }
+                    }
+                }
+                return next != null;
+            }
+
+            public Object next() {
+                if (hasNext()) {
+                    last = next;
+                    next = null;
+                    return last;
+                }
+                throw new NoSuchElementException();
+            }
+
+            public void remove() {
+                if (last == null) {
+                    throw new IllegalStateException();
+                }
+                Node target = last;
+                last = null;
+                removeChild(target);
+            }
+        };
+    }
+
+    public Iterator getChildElements(final Name name) {
+       return getChildElements(name.getURI(), name.getLocalName());
+    }
+
+    public Iterator getChildElements(final QName qname) {
+        return getChildElements(qname.getNamespaceURI(), qname.getLocalPart());
+    }
+
+    private Iterator getChildElements(final String nameUri, final String nameLocal) {
+        return new Iterator() {
+            Iterator eachElement = getChildElementNodes();
+            Node next = null;
+            Node last = null;
+
+            public boolean hasNext() {
+                if (next == null) {
+                    while (eachElement.hasNext()) {
+                        Node element = (Node) eachElement.next();
+                        String elementUri = element.getNamespaceURI();
+                        elementUri = elementUri == null ? "" : elementUri;
+                        String elementName = element.getLocalName();
+                        if (elementUri.equals(nameUri)
+                            && elementName.equals(nameLocal)) {
+                            next = element;
+                            break;
+                        }
+                    }
+                }
+                return next != null;
+            }
+
+            public Object next() {
+                if (!hasNext()) {
+                    throw new NoSuchElementException();
+                }
+                last = next;
+                next = null;
+                return last;
+            }
+
+            public void remove() {
+                if (last == null) {
+                    throw new IllegalStateException();
+                }
+                Node target = last;
+                last = null;
+                removeChild(target);
+            }
+        };
+    }
+
+    public void removeContents() {
+        Node currentChild = getFirstChild();
+
+        while (currentChild != null) {
+            Node temp = currentChild.getNextSibling();
+            if (currentChild instanceof javax.xml.soap.Node) {
+                ((javax.xml.soap.Node) currentChild).detachNode();
+            } else {
+                Node parent = currentChild.getParentNode();
+                if (parent != null) {
+                    parent.removeChild(currentChild);
+                }
+
+            }
+            currentChild = temp;
+        }
+    }
+
+    public void setEncodingStyle(String encodingStyle) throws SOAPException {
+        if (!"".equals(encodingStyle)) {
+            try {
+                JaxmURI uri = new JaxmURI(encodingStyle);
+            } catch (JaxmURI.MalformedURIException m) {
+                log.log(
+                    Level.SEVERE,
+                    "SAAJ0105.impl.encoding.style.mustbe.valid.URI",
+                    new String[] { encodingStyle });
+                throw new IllegalArgumentException(
+                    "Encoding style (" + encodingStyle + ") should be a valid URI");
+            }
+        }
+        encodingStyleAttribute.setValue(encodingStyle);
+        tryToFindEncodingStyleAttributeName();
+    }
+
+    public String getEncodingStyle() {
+        String encodingStyle = encodingStyleAttribute.getValue();
+        if (encodingStyle != null)
+            return encodingStyle;
+        String soapNamespace = getSOAPNamespace();
+        if (soapNamespace != null) {
+            Attr attr = getAttributeNodeNS(soapNamespace, "encodingStyle");
+            if (attr != null) {
+                encodingStyle = attr.getValue();
+                try {
+                    setEncodingStyle(encodingStyle);
+                } catch (SOAPException se) {
+                    // has to be ignored
+                }
+                return encodingStyle;
+            }
+        }
+        return null;
+    }
+
+    // Node methods
+    public String getValue() {
+        javax.xml.soap.Node valueNode = getValueNode();
+        return valueNode == null ? null : valueNode.getValue();
+    }
+
+    public void setValue(String value) {
+        Node valueNode = getValueNodeStrict();
+        if (valueNode != null) {
+            valueNode.setNodeValue(value);
+        } else {
+            try {
+                addTextNode(value);
+            } catch (SOAPException e) {
+                throw new RuntimeException(e.getMessage());
+            }
+        }
+    }
+
+    protected Node getValueNodeStrict() {
+        Node node = getFirstChild();
+        if (node != null) {
+            if (node.getNextSibling() == null
+                && node.getNodeType() == org.w3c.dom.Node.TEXT_NODE) {
+                return node;
+            } else {
+                log.severe("SAAJ0107.impl.elem.child.not.single.text");
+                throw new IllegalStateException();
+            }
+        }
+
+        return null;
+    }
+
+    protected javax.xml.soap.Node getValueNode() {
+        Iterator i = getChildElements();
+        while (i.hasNext()) {
+            javax.xml.soap.Node n = (javax.xml.soap.Node) i.next();
+            if (n.getNodeType() == org.w3c.dom.Node.TEXT_NODE ||
+                n.getNodeType() == org.w3c.dom.Node.CDATA_SECTION_NODE) {
+                // TODO: Hack to fix text node split into multiple lines.
+                normalize();
+                // Should remove the normalization step when this gets fixed in
+                // DOM/Xerces.
+                return (javax.xml.soap.Node) n;
+            }
+        }
+        return null;
+    }
+
+    public void setParentElement(SOAPElement element) throws SOAPException {
+        if (element == null) {
+            log.severe("SAAJ0106.impl.no.null.to.parent.elem");
+            throw new SOAPException("Cannot pass NULL to setParentElement");
+        }
+        element.addChildElement(this);
+        findEncodingStyleAttributeName();
+    }
+
+    protected void findEncodingStyleAttributeName() throws SOAPException {
+        String soapNamespace = getSOAPNamespace();
+        if (soapNamespace != null) {
+            String soapNamespacePrefix = getNamespacePrefix(soapNamespace);
+            if (soapNamespacePrefix != null) {
+                setEncodingStyleNamespace(soapNamespace, soapNamespacePrefix);
+            }
+        }
+    }
+
+    protected void setEncodingStyleNamespace(
+        String soapNamespace,
+        String soapNamespacePrefix)
+        throws SOAPException {
+        Name encodingStyleAttributeName =
+            NameImpl.create(
+                "encodingStyle",
+                soapNamespacePrefix,
+                soapNamespace);
+        encodingStyleAttribute.setName(encodingStyleAttributeName);
+    }
+
+    public SOAPElement getParentElement() {
+        Node parentNode = getParentNode();
+        if (parentNode instanceof SOAPDocument) {
+            return null;
+        }
+        return (SOAPElement) parentNode;
+    }
+
+    protected String getSOAPNamespace() {
+        String soapNamespace = null;
+
+        SOAPElement antecedent = this;
+        while (antecedent != null) {
+            Name antecedentName = antecedent.getElementName();
+            String antecedentNamespace = antecedentName.getURI();
+
+            if (NameImpl.SOAP11_NAMESPACE.equals(antecedentNamespace)
+                || NameImpl.SOAP12_NAMESPACE.equals(antecedentNamespace)) {
+
+                soapNamespace = antecedentNamespace;
+                break;
+            }
+
+            antecedent = antecedent.getParentElement();
+        }
+
+        return soapNamespace;
+    }
+
+    public void detachNode() {
+        Node parent = getParentNode();
+        if (parent != null) {
+            parent.removeChild(this);
+        }
+        encodingStyleAttribute.clearName();
+        tryToFindEncodingStyleAttributeName();
+    }
+
+    public void tryToFindEncodingStyleAttributeName() {
+        try {
+            findEncodingStyleAttributeName();
+        } catch (SOAPException e) { /*okay to fail*/
+        }
+    }
+
+    public void recycleNode() {
+        detachNode();
+        // TBD
+        //  - add this to the factory so subsequent
+        //    creations can reuse this object.
+    }
+
+    class AttributeManager {
+        Name attributeName = null;
+        String attributeValue = null;
+
+        public void setName(Name newName) throws SOAPException {
+            clearAttribute();
+            attributeName = newName;
+            reconcileAttribute();
+        }
+        public void clearName() {
+            clearAttribute();
+            attributeName = null;
+        }
+        public void setValue(String value) throws SOAPException {
+            attributeValue = value;
+            reconcileAttribute();
+        }
+        public Name getName() {
+            return attributeName;
+        }
+        public String getValue() {
+            return attributeValue;
+        }
+        private void reconcileAttribute() throws SOAPException {
+            if (attributeName != null) {
+                removeAttribute(attributeName);
+                if (attributeValue != null) {
+                    addAttribute(attributeName, attributeValue);
+                }
+            }
+        }
+        private void clearAttribute() {
+            if (attributeName != null) {
+                removeAttribute(attributeName);
+            }
+        }
+    }
+
+    protected static org.w3c.dom.Attr getNamespaceAttrFrom(
+        Element element,
+        String prefix) {
+        NamespaceContextIterator eachNamespace =
+            new NamespaceContextIterator(element);
+        while (eachNamespace.hasNext()) {
+            org.w3c.dom.Attr namespaceDecl = eachNamespace.nextNamespaceAttr();
+            String declaredPrefix =
+                NameImpl.getLocalNameFromTagName(namespaceDecl.getNodeName());
+            if (declaredPrefix.equals(prefix)) {
+                return namespaceDecl;
+            }
+        }
+        return null;
+    }
+
+    protected static Iterator getAllAttributesFrom(final Element element) {
+        final NamedNodeMap attributes = element.getAttributes();
+
+        return new Iterator() {
+            int attributesLength = attributes.getLength();
+            int attributeIndex = 0;
+            String currentName;
+
+            public boolean hasNext() {
+                return attributeIndex < attributesLength;
+            }
+
+            public Object next() {
+                if (!hasNext()) {
+                    throw new NoSuchElementException();
+                }
+                Node current = attributes.item(attributeIndex++);
+                currentName = current.getNodeName();
+
+                String prefix = NameImpl.getPrefixFromTagName(currentName);
+                if (prefix.length() == 0) {
+                    return NameImpl.createFromUnqualifiedName(currentName);
+                } else {
+                    Name attributeName =
+                        NameImpl.createFromQualifiedName(
+                            currentName,
+                            current.getNamespaceURI());
+                    return attributeName;
+                }
+            }
+
+            public void remove() {
+                if (currentName == null) {
+                    throw new IllegalStateException();
+                }
+                attributes.removeNamedItem(currentName);
+            }
+        };
+    }
+
+    protected static String getAttributeValueFrom(Element element, Name name) {
+      return getAttributeValueFrom(
+          element,
+          name.getURI(),
+          name.getLocalName(),
+          name.getPrefix(),
+          name.getQualifiedName());
+    }
+
+    private static String getAttributeValueFrom(
+        Element element,
+        String uri,
+        String localName,
+        String prefix,
+        String qualifiedName) {
+
+        String nonzeroLengthUri =
+            (uri == null || uri.length() == 0) ? null : uri;
+
+        boolean mustUseGetAttributeNodeNS =  (nonzeroLengthUri != null);
+
+        if (mustUseGetAttributeNodeNS) {
+
+            if (!element.hasAttributeNS(uri, localName)) {
+                return null;
+            }
+
+            String attrValue =
+                element.getAttributeNS(nonzeroLengthUri, localName);
+
+            return attrValue;
+        }
+
+        Attr attribute = null;
+        attribute = element.getAttributeNode(qualifiedName);
+
+        return attribute == null ? null : attribute.getValue();
+    }
+
+    protected static Iterator getChildElementsFrom(final Element element) {
+        return new Iterator() {
+            Node next = element.getFirstChild();
+            Node nextNext = null;
+            Node last = null;
+
+            public boolean hasNext() {
+                if (next != null) {
+                    return true;
+                }
+                if (next == null && nextNext != null) {
+                    next = nextNext;
+                }
+
+                return next != null;
+            }
+
+            public Object next() {
+                if (hasNext()) {
+                    last = next;
+                    next = null;
+
+                    if ((element instanceof ElementImpl)
+                        && (last instanceof Element)) {
+                        last =
+                            ((ElementImpl) element).convertToSoapElement(
+                                (Element) last);
+                    }
+
+                    nextNext = last.getNextSibling();
+                    return last;
+                }
+                throw new NoSuchElementException();
+            }
+
+            public void remove() {
+                if (last == null) {
+                    throw new IllegalStateException();
+                }
+                Node target = last;
+                last = null;
+                element.removeChild(target);
+            }
+        };
+    }
+
+    public static String getQualifiedName(QName name) {
+        String prefix = name.getPrefix();
+        String localName = name.getLocalPart();
+        String qualifiedName = null;
+
+            if (prefix != null && prefix.length() > 0) {
+                qualifiedName = prefix + ":" + localName;
+            } else {
+                qualifiedName = localName;
+            }
+         return qualifiedName;
+    }
+
+    public static String getLocalPart(String qualifiedName) {
+        if (qualifiedName == null) {
+            // Log
+            throw new IllegalArgumentException("Cannot get local name for a \"null\" qualified name");
+        }
+
+        int index = qualifiedName.indexOf(':');
+        if (index < 0)
+            return qualifiedName;
+        else
+            return qualifiedName.substring(index + 1);
+    }
+
+    public static String getPrefix(String qualifiedName) {
+        if (qualifiedName == null) {
+            // Log
+            throw new IllegalArgumentException("Cannot get prefix for a  \"null\" qualified name");
+        }
+
+        int index = qualifiedName.indexOf(':');
+        if (index < 0)
+            return "";
+        else
+            return qualifiedName.substring(0, index);
+    }
+
+    protected boolean isNamespaceQualified(Name name) {
+        return !"".equals(name.getURI());
+    }
+
+    protected boolean isNamespaceQualified(QName name) {
+        return !"".equals(name.getNamespaceURI());
+    }
+
+    protected SOAPElement circumventBug5034339(SOAPElement element) {
+
+        Name elementName = element.getElementName();
+        if (!isNamespaceQualified(elementName)) {
+            String prefix = elementName.getPrefix();
+            String defaultNamespace = getNamespaceURI(prefix);
+            if (defaultNamespace != null) {
+                Name newElementName =
+                    NameImpl.create(
+                        elementName.getLocalName(),
+                        elementName.getPrefix(),
+                        defaultNamespace);
+                SOAPElement newElement = createElement(newElementName);
+                replaceChild(newElement, element);
+                return newElement;
+            }
+        }
+        return element;
+    }
+
+    //TODO: This is a temporary SAAJ workaround for optimizing XWS
+    // should be removed once the corresponding JAXP bug is fixed
+    // It appears the bug will be fixed in JAXP 1.4 (not by Appserver 9 timeframe)
+    public void setAttributeNS(
+        String namespaceURI,String qualifiedName, String value) {
+        int index = qualifiedName.indexOf(':');
+        String prefix, localName;
+        if (index < 0) {
+            prefix = null;
+            localName = qualifiedName;
+        }
+        else {
+            prefix = qualifiedName.substring(0, index);
+            localName = qualifiedName.substring(index + 1);
+        }
+                super.setAttributeNS(namespaceURI,qualifiedName,value);
+        //String tmpLocalName = this.getLocalName();
+        String tmpURI = this.getNamespaceURI();
+        boolean isIDNS = false;
+        if( tmpURI != null && (tmpURI.equals(DSIG_NS) || tmpURI.equals(XENC_NS))){
+            isIDNS = true;
+        }
+        //No need to check for Signature/encryption element
+        //just check for namespace.
+        if(localName.equals("Id")){
+            if(namespaceURI == null || namespaceURI.equals("")){
+                setIdAttribute(localName,true);
+            }else if(isIDNS || WSU_NS.equals(namespaceURI)){
+                setIdAttributeNS(namespaceURI,localName,true);
+            }
+        }
+
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/EnvelopeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/EnvelopeImpl.java
new file mode 100644
index 0000000..76af746
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/EnvelopeImpl.java
@@ -0,0 +1,368 @@
+/*
+ * $Id: EnvelopeImpl.java,v 1.1.1.1 2006/01/27 13:10:56 kumarjayanti Exp $
+ * $Revision: 1.1.1.1 $
+ * $Date: 2006/01/27 13:10:56 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+
+import java.util.Iterator;
+import java.util.logging.Level;
+import org.w3c.dom.Document;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+import javax.xml.transform.*;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.transform.sax.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.Envelope;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.FastInfosetReflection;
+import com.sun.xml.internal.messaging.saaj.util.transform.EfficientStreamingTransformer;
+
+/**
+ * Our implementation of the SOAP envelope.
+ *
+ * @author Anil Vijendran (anil@sun.com)
+ */
+public abstract class EnvelopeImpl extends ElementImpl implements Envelope {
+    protected HeaderImpl header;
+    protected BodyImpl body;
+    String omitXmlDecl = "yes";
+    String charset = "utf-8";
+    String xmlDecl = null;
+
+    protected EnvelopeImpl(SOAPDocumentImpl ownerDoc, Name name) {
+        super(ownerDoc, name);
+    }
+
+    protected EnvelopeImpl(SOAPDocumentImpl ownerDoc, QName name) {
+        super(ownerDoc, name);
+    }
+
+    protected EnvelopeImpl(
+        SOAPDocumentImpl ownerDoc,
+        NameImpl name,
+        boolean createHeader,
+        boolean createBody)
+        throws SOAPException {
+        this(ownerDoc, name);
+
+        ensureNamespaceIsDeclared(
+            getElementQName().getPrefix(), getElementQName().getNamespaceURI());
+
+        // XXX
+        if (createHeader)
+            addHeader();
+
+        if (createBody)
+            addBody();
+    }
+
+    protected abstract NameImpl getHeaderName(String prefix);
+    protected abstract NameImpl getBodyName(String prefix);
+
+    public SOAPHeader addHeader() throws SOAPException {
+        return addHeader(null);
+    }
+
+    public SOAPHeader addHeader(String prefix) throws SOAPException {
+
+        if (prefix == null || prefix.equals("")) {
+            prefix = getPrefix();
+        }
+
+        NameImpl headerName = getHeaderName(prefix);
+        NameImpl bodyName = getBodyName(prefix);
+
+        HeaderImpl header = null;
+        SOAPElement firstChild = null;
+
+        Iterator eachChild = getChildElementNodes();
+        if (eachChild.hasNext()) {
+            firstChild = (SOAPElement) eachChild.next();
+            if (firstChild.getElementName().equals(headerName)) {
+                log.severe("SAAJ0120.impl.header.already.exists");
+                throw new SOAPExceptionImpl("Can't add a header when one is already present.");
+            } else if (!firstChild.getElementName().equals(bodyName)) {
+                log.severe("SAAJ0121.impl.invalid.first.child.of.envelope");
+                throw new SOAPExceptionImpl("First child of Envelope must be either a Header or Body");
+            }
+        }
+
+        header = (HeaderImpl) createElement(headerName);
+        insertBefore(header, firstChild);
+        header.ensureNamespaceIsDeclared(headerName.getPrefix(), headerName.getURI());
+
+        return header;
+    }
+
+    protected void lookForHeader() throws SOAPException {
+        NameImpl headerName = getHeaderName(null);
+
+        HeaderImpl hdr = (HeaderImpl) findChild(headerName);
+        header = hdr;
+    }
+
+    public SOAPHeader getHeader() throws SOAPException {
+        lookForHeader();
+        return header;
+    }
+
+    protected void lookForBody() throws SOAPException {
+        NameImpl bodyName = getBodyName(null);
+
+        BodyImpl bodyChildElement = (BodyImpl) findChild(bodyName);
+        body = bodyChildElement;
+    }
+
+    public SOAPBody addBody() throws SOAPException {
+        return addBody(null);
+    }
+
+    public SOAPBody addBody(String prefix) throws SOAPException {
+        lookForBody();
+
+        if (prefix == null || prefix.equals("")) {
+            prefix = getPrefix();
+        }
+
+        if (body == null) {
+            NameImpl bodyName = getBodyName(prefix);
+            body = (BodyImpl) createElement(bodyName);
+            insertBefore(body, null);
+            body.ensureNamespaceIsDeclared(bodyName.getPrefix(), bodyName.getURI());
+        } else {
+            log.severe("SAAJ0122.impl.body.already.exists");
+            throw new SOAPExceptionImpl("Can't add a body when one is already present.");
+        }
+
+        return body;
+    }
+
+    protected SOAPElement addElement(Name name) throws SOAPException {
+        if (getBodyName(null).equals(name)) {
+            return addBody(name.getPrefix());
+        }
+        if (getHeaderName(null).equals(name)) {
+            return addHeader(name.getPrefix());
+        }
+
+        return super.addElement(name);
+    }
+
+    protected SOAPElement addElement(QName name) throws SOAPException {
+        if (getBodyName(null).equals(NameImpl.convertToName(name))) {
+            return addBody(name.getPrefix());
+        }
+        if (getHeaderName(null).equals(NameImpl.convertToName(name))) {
+            return addHeader(name.getPrefix());
+        }
+
+        return super.addElement(name);
+    }
+
+    public SOAPBody getBody() throws SOAPException {
+        lookForBody();
+        return body;
+    }
+
+    public Source getContent() {
+        return new DOMSource(getOwnerDocument());
+    }
+
+    public Name createName(String localName, String prefix, String uri)
+        throws SOAPException {
+
+        // validating parameters before passing them on
+        // to make sure that the namespace specification rules are followed
+
+        // reserved xmlns prefix cannot be used.
+        if ("xmlns".equals(prefix)) {
+            log.severe("SAAJ0123.impl.no.reserved.xmlns");
+            throw new SOAPExceptionImpl("Cannot declare reserved xmlns prefix");
+        }
+        // Qualified name cannot be xmlns.
+        if ((prefix == null) && ("xmlns".equals(localName))) {
+            log.severe("SAAJ0124.impl.qualified.name.cannot.be.xmlns");
+            throw new SOAPExceptionImpl("Qualified name cannot be xmlns");
+        }
+
+        return NameImpl.create(localName, prefix, uri);
+    }
+
+    public Name createName(String localName, String prefix)
+        throws SOAPException {
+        String namespace = getNamespaceURI(prefix);
+        if (namespace == null) {
+            log.log(
+                Level.SEVERE,
+                "SAAJ0126.impl.cannot.locate.ns",
+                new String[] { prefix });
+            throw new SOAPExceptionImpl(
+                "Unable to locate namespace for prefix " + prefix);
+        }
+        return NameImpl.create(localName, prefix, namespace);
+    }
+
+    public Name createName(String localName) throws SOAPException {
+        return NameImpl.createFromUnqualifiedName(localName);
+    }
+
+    public void setOmitXmlDecl(String value) {
+        this.omitXmlDecl = value;
+    }
+
+    public void setXmlDecl(String value) {
+        this.xmlDecl = value;
+    }
+
+    private String getOmitXmlDecl() {
+        return this.omitXmlDecl;
+    }
+
+    public void setCharsetEncoding(String value) {
+        charset = value;
+    }
+
+    public void output(OutputStream out) throws IOException {
+        try {
+            Transformer transformer =
+                EfficientStreamingTransformer.newTransformer();
+
+            transformer.setOutputProperty(
+                OutputKeys.OMIT_XML_DECLARATION, "yes");
+                /*omitXmlDecl);*/
+            // no equivalent for "setExpandEmptyElements"
+            transformer.setOutputProperty(
+                OutputKeys.ENCODING,
+                charset);
+
+            if (omitXmlDecl.equals("no") && xmlDecl == null) {
+                xmlDecl = "<?xml version=\"" + getOwnerDocument().getXmlVersion() + "\" encoding=\"" +
+                    charset + "\" ?>";
+            }
+
+           StreamResult result = new StreamResult(out);
+            if (xmlDecl != null) {
+                OutputStreamWriter writer = new OutputStreamWriter(out, charset);
+                writer.write(xmlDecl);
+                writer.flush();
+                result = new StreamResult(writer);
+            }
+
+
+            log.log(
+                Level.FINE,
+                "SAAJ0190.impl.set.xml.declaration",
+                new String[] { omitXmlDecl });
+            log.log(
+                Level.FINE,
+                "SAAJ0191.impl.set.encoding",
+                new String[] { charset });
+
+            //StreamResult result = new StreamResult(out);
+            transformer.transform(getContent(), result);
+        } catch (Exception ex) {
+            throw new IOException(ex.getMessage());
+        }
+    }
+
+    /**
+     * Serialize to FI if boolean parameter set.
+     */
+    public void output(OutputStream out, boolean isFastInfoset)
+        throws IOException
+    {
+        if (!isFastInfoset) {
+            output(out);
+        }
+        else {
+            try {
+                // Run transform and generate FI output from content
+                Source source = getContent();
+                Transformer transformer = EfficientStreamingTransformer.newTransformer();
+                    transformer.transform(getContent(),
+                        FastInfosetReflection.FastInfosetResult_new(out));
+            }
+            catch (Exception ex) {
+                throw new IOException(ex.getMessage());
+            }
+        }
+    }
+
+    //    public void prettyPrint(OutputStream out) throws IOException {
+    //        if (getDocument() == null)
+    //            initDocument();
+    //
+    //        OutputFormat format = OutputFormat.createPrettyPrint();
+    //
+    //        format.setIndentSize(2);
+    //        format.setNewlines(true);
+    //        format.setTrimText(true);
+    //        format.setPadText(true);
+    //        format.setExpandEmptyElements(false);
+    //
+    //        XMLWriter writer = new XMLWriter(out, format);
+    //        writer.write(getDocument());
+    //    }
+    //
+    //    public void prettyPrint(Writer out) throws IOException {
+    //        if (getDocument() == null)
+    //            initDocument();
+    //
+    //        OutputFormat format = OutputFormat.createPrettyPrint();
+    //
+    //        format.setIndentSize(2);
+    //        format.setNewlines(true);
+    //        format.setTrimText(true);
+    //        format.setPadText(true);
+    //        format.setExpandEmptyElements(false);
+    //
+    //        XMLWriter writer = new XMLWriter(out, format);
+    //        writer.write(getDocument());
+    //    }
+
+
+     public SOAPElement setElementQName(QName newName) throws SOAPException {
+        log.log(Level.SEVERE,
+                "SAAJ0146.impl.invalid.name.change.requested",
+                new Object[] {elementQName.getLocalPart(),
+                              newName.getLocalPart()});
+        throw new SOAPException("Cannot change name for "
+                                + elementQName.getLocalPart() + " to "
+                                + newName.getLocalPart());
+     }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/FaultElementImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/FaultElementImpl.java
new file mode 100644
index 0000000..8206c5a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/FaultElementImpl.java
@@ -0,0 +1,67 @@
+/*
+ * $Id: FaultElementImpl.java,v 1.10 2006/01/27 12:49:35 vj135062 Exp $
+ * $Revision: 1.10 $
+ * $Date: 2006/01/27 12:49:35 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPFaultElement;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public abstract class FaultElementImpl
+    extends ElementImpl
+    implements SOAPFaultElement {
+
+    protected FaultElementImpl(SOAPDocumentImpl ownerDoc, NameImpl qname) {
+        super(ownerDoc, qname);
+    }
+
+    protected FaultElementImpl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    protected abstract boolean isStandardFaultElement();
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+            log.log(Level.SEVERE,
+                    "SAAJ0146.impl.invalid.name.change.requested",
+                    new Object[] {elementQName.getLocalPart(),
+                                  newName.getLocalPart()});
+            throw new SOAPException("Cannot change name for "
+                                    + elementQName.getLocalPart() + " to "
+                                    + newName.getLocalPart());
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/FaultImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/FaultImpl.java
new file mode 100644
index 0000000..21c87fc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/FaultImpl.java
@@ -0,0 +1,353 @@
+/*
+ * $Id: FaultImpl.java,v 1.55 2006/01/27 12:49:35 vj135062 Exp $
+ * $Revision: 1.55 $
+ * $Date: 2006/01/27 12:49:35 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.Locale;
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import org.w3c.dom.Element;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public abstract class FaultImpl extends ElementImpl implements SOAPFault {
+
+    /* This can also represent a fault reason element */
+    protected SOAPFaultElement faultStringElement;
+
+    /* This can also represent a fault role element */
+    protected SOAPFaultElement faultActorElement;
+
+    protected SOAPFaultElement faultCodeElement;
+
+    protected Detail detail;
+
+    protected FaultImpl(SOAPDocumentImpl ownerDoc, NameImpl name) {
+        super(ownerDoc, name);
+    }
+
+
+    protected abstract NameImpl getDetailName();
+    protected abstract NameImpl getFaultCodeName();
+    protected abstract NameImpl getFaultStringName();
+    protected abstract NameImpl getFaultActorName();
+    protected abstract DetailImpl createDetail();
+    protected abstract FaultElementImpl createSOAPFaultElement(String localName);
+    protected abstract void checkIfStandardFaultCode(String faultCode, String uri) throws SOAPException;
+    protected abstract void finallySetFaultCode(String faultcode) throws SOAPException;
+    protected abstract boolean isStandardFaultElement(String localName);
+    protected abstract QName getDefaultFaultCode();
+
+
+    protected void findFaultCodeElement() {
+        this.faultCodeElement =
+            (SOAPFaultElement) findChild(getFaultCodeName());
+    }
+
+    protected void findFaultActorElement() {
+        this.faultActorElement =
+            (SOAPFaultElement) findChild(getFaultActorName());
+    }
+
+    protected void findFaultStringElement() {
+        this.faultStringElement =
+            (SOAPFaultElement) findChild(getFaultStringName());
+    }
+
+    public void setFaultCode(String faultCode) throws SOAPException {
+        setFaultCode(
+            NameImpl.getLocalNameFromTagName(faultCode),
+            NameImpl.getPrefixFromTagName(faultCode),
+            null);
+    }
+
+    public void setFaultCode(String faultCode, String prefix, String uri)
+        throws SOAPException {
+
+        if (prefix == null || prefix.equals("")) {
+            if (uri == null || uri.equals("")) {
+                log.severe("SAAJ0140.impl.no.ns.URI");
+                throw new SOAPExceptionImpl("No NamespaceURI, SOAP requires faultcode content to be a QName");
+            }
+            prefix = getNamespacePrefix(uri);
+            if (prefix == null || prefix.equals("")) {
+                prefix = "ns0";
+            }
+        }
+
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+
+        if (this.faultCodeElement == null)
+            this.faultCodeElement = addFaultCodeElement();
+        else
+            this.faultCodeElement.removeContents();
+
+        if (uri == null || uri.equals("")) {
+            uri = this.faultCodeElement.getNamespaceURI(prefix);
+        }
+        if (uri == null || uri.equals("")) {
+            log.severe("SAAJ0140.impl.no.ns.URI");
+            throw new SOAPExceptionImpl("No NamespaceURI, SOAP requires faultcode content to be a QName");
+        } else {
+            checkIfStandardFaultCode(faultCode, uri);
+            ((FaultElementImpl) this.faultCodeElement).ensureNamespaceIsDeclared(prefix, uri);
+        }
+        finallySetFaultCode(prefix + ":" + faultCode);
+    }
+
+    public void setFaultCode(Name faultCodeQName) throws SOAPException {
+        setFaultCode(
+            faultCodeQName.getLocalName(),
+            faultCodeQName.getPrefix(),
+            faultCodeQName.getURI());
+    }
+
+    public void setFaultCode(QName faultCodeQName) throws SOAPException {
+        setFaultCode(
+            faultCodeQName.getLocalPart(),
+            faultCodeQName.getPrefix(),
+            faultCodeQName.getNamespaceURI());
+    }
+
+    protected static QName convertCodeToQName(
+        String code,
+        SOAPElement codeContainingElement) {
+
+        int prefixIndex = code.indexOf(':');
+        if (prefixIndex == -1) {
+            return new QName(code);
+        }
+
+        String prefix = code.substring(0, prefixIndex);
+        String nsName =
+            ((ElementImpl) codeContainingElement).getNamespaceURI(prefix);
+        return new QName(nsName, getLocalPart(code), prefix);
+    }
+
+    protected void initializeDetail() {
+        NameImpl detailName = getDetailName();
+        detail = (Detail) findChild(detailName);
+    }
+
+    public Detail getDetail() {
+        if (detail == null)
+            initializeDetail();
+        if ((detail != null) && (detail.getParentNode() == null)) {
+        // a detach node was called on it
+            detail = null;
+        }
+        return detail;
+    }
+
+    public Detail addDetail() throws SOAPException {
+        if (detail == null)
+            initializeDetail();
+        if (detail == null) {
+            detail = createDetail();
+            addNode(detail);
+            return detail;
+        } else {
+            // Log
+            throw new SOAPExceptionImpl("Error: Detail already exists");
+        }
+    }
+
+    public boolean hasDetail() {
+        return (getDetail() != null);
+    }
+
+    public void setFaultActor(String faultActor) throws SOAPException {
+        if (this.faultActorElement == null)
+            findFaultActorElement();
+        if (this.faultActorElement != null)
+            this.faultActorElement.detachNode();
+        if (faultActor == null)
+            return;
+        this.faultActorElement =
+            addSOAPFaultElement(getFaultActorName().getLocalName());
+        this.faultActorElement.addTextNode(faultActor);
+    }
+
+    public String getFaultActor() {
+        if (this.faultActorElement == null)
+            findFaultActorElement();
+        if (this.faultActorElement != null) {
+                return this.faultActorElement.getValue();
+        }
+        return null;
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+
+        log.log(
+            Level.SEVERE,
+            "SAAJ0146.impl.invalid.name.change.requested",
+            new Object[] {elementQName.getLocalPart(), newName.getLocalPart()});
+        throw new SOAPException(
+            "Cannot change name for " + elementQName.getLocalPart() + " to " + newName.getLocalPart());
+    }
+
+    protected SOAPElement convertToSoapElement(Element element) {
+        if (element instanceof SOAPFaultElement) {
+            return (SOAPElement) element;
+        } else if (element instanceof SOAPElement) {
+            SOAPElement soapElement = (SOAPElement) element;
+            if (getDetailName().equals(soapElement.getElementName())) {
+                return replaceElementWithSOAPElement(element, createDetail());
+            } else {
+                String localName =
+                    soapElement.getElementName().getLocalName();
+                if (isStandardFaultElement(localName))
+                    return replaceElementWithSOAPElement(
+                               element,
+                               createSOAPFaultElement(localName));
+                return soapElement;
+            }
+        } else {
+            Name elementName = NameImpl.copyElementName(element);
+            ElementImpl newElement;
+            if (getDetailName().equals(elementName)) {
+                newElement = (ElementImpl) createDetail();
+            } else {
+                String localName = elementName.getLocalName();
+                if (isStandardFaultElement(localName))
+                    newElement =
+                        (ElementImpl) createSOAPFaultElement(localName);
+                else
+                    newElement = (ElementImpl) createElement(elementName);
+            }
+            return replaceElementWithSOAPElement(element, newElement);
+        }
+    }
+
+    private SOAPFaultElement addFaultCodeElement() throws SOAPException {
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        if (this.faultCodeElement == null) {
+            this.faultCodeElement =
+                addSOAPFaultElement(getFaultCodeName().getLocalName());
+            return this.faultCodeElement;
+        } else {
+            throw new SOAPExceptionImpl("Error: Faultcode already exists");
+        }
+    }
+
+    private SOAPFaultElement addFaultStringElement() throws SOAPException {
+        if (this.faultStringElement == null)
+            findFaultStringElement();
+        if (this.faultStringElement == null) {
+            this.faultStringElement =
+                addSOAPFaultElement(getFaultStringName().getLocalName());
+            return this.faultStringElement;
+        } else {
+            // Log
+            throw new SOAPExceptionImpl("Error: Faultstring already exists");
+        }
+    }
+
+    private SOAPFaultElement addFaultActorElement() throws SOAPException {
+        if (this.faultActorElement == null)
+            findFaultActorElement();
+        if (this.faultActorElement == null) {
+            this.faultActorElement =
+                addSOAPFaultElement(getFaultActorName().getLocalName());
+            return this.faultActorElement;
+        } else {
+            // Log
+            throw new SOAPExceptionImpl("Error: Faultactor already exists");
+        }
+    }
+
+    protected SOAPElement addElement(Name name) throws SOAPException {
+        if (getDetailName().equals(name)) {
+            return addDetail();
+        } else if(getFaultCodeName().equals(name)) {
+            return addFaultCodeElement();
+        } else if(getFaultStringName().equals(name)) {
+            return addFaultStringElement();
+        } else if(getFaultActorName().equals(name)) {
+            return addFaultActorElement();
+        }
+        return super.addElement(name);
+    }
+
+    protected SOAPElement addElement(QName name) throws SOAPException {
+        return addElement(NameImpl.convertToName(name));
+    }
+
+    protected FaultElementImpl addSOAPFaultElement(String localName)
+        throws SOAPException {
+
+        FaultElementImpl faultElem = createSOAPFaultElement(localName);
+        addNode(faultElem);
+        return faultElem;
+    }
+
+    /**
+     * Convert an xml:lang attribute value into a Locale object
+     */
+    protected static Locale xmlLangToLocale(String xmlLang) {
+        if (xmlLang == null) {
+            return null;
+        }
+
+        // Spec uses hyphen as separator
+        int index = xmlLang.indexOf("-");
+
+        // Accept underscore as separator as well
+        if (index == -1) {
+            index = xmlLang.indexOf("_");
+        }
+
+        if (index == -1) {
+            // No separator so assume only a language component
+            return new Locale(xmlLang, "");
+        }
+
+        String language = xmlLang.substring(0, index);
+        String country = xmlLang.substring(index + 1);
+        return new Locale(language, country);
+    }
+
+    protected static String localeToXmlLang(Locale locale) {
+        String xmlLang = locale.getLanguage();
+        String country = locale.getCountry();
+        if (!"".equals(country)) {
+            xmlLang += "-" + country;
+        }
+        return xmlLang;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/HeaderElementImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/HeaderElementImpl.java
new file mode 100644
index 0000000..0d6ec82
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/HeaderElementImpl.java
@@ -0,0 +1,140 @@
+/*
+ * $Id: HeaderElementImpl.java,v 1.26 2006/01/27 12:49:35 vj135062 Exp $
+ * $Revision: 1.26 $
+ * $Date: 2006/01/27 12:49:35 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public abstract class HeaderElementImpl
+    extends ElementImpl
+    implements SOAPHeaderElement {
+
+    protected static Name RELAY_ATTRIBUTE_LOCAL_NAME =
+        NameImpl.createFromTagName("relay");
+    protected static Name MUST_UNDERSTAND_ATTRIBUTE_LOCAL_NAME =
+        NameImpl.createFromTagName("mustUnderstand");
+
+    public HeaderElementImpl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+    public HeaderElementImpl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    protected abstract NameImpl getActorAttributeName();
+    protected abstract NameImpl getRoleAttributeName();
+    protected abstract NameImpl getMustunderstandAttributeName();
+    protected abstract boolean getMustunderstandAttributeValue(String str);
+    protected abstract String getMustunderstandLiteralValue(boolean mu);
+    protected abstract NameImpl getRelayAttributeName();
+    protected abstract boolean getRelayAttributeValue(String str);
+    protected abstract String getRelayLiteralValue(boolean mu);
+    protected abstract String getActorOrRole();
+
+
+    public void setParentElement(SOAPElement element) throws SOAPException {
+        if (!(element instanceof SOAPHeader)) {
+            log.severe("SAAJ0130.impl.header.elem.parent.mustbe.header");
+            throw new SOAPException("Parent of a SOAPHeaderElement has to be a SOAPHeader");
+        }
+
+        super.setParentElement(element);
+    }
+
+    public void setActor(String actorUri) {
+        try {
+            removeAttribute(getActorAttributeName());
+            addAttribute((Name) getActorAttributeName(), actorUri);
+        } catch (SOAPException ex) {
+        }
+    }
+
+    //SOAP 1.2 supports Role
+    public void setRole(String roleUri) throws SOAPException {
+        // runtime exception thrown if called for SOAP 1.1
+        removeAttribute(getRoleAttributeName());
+        addAttribute((Name) getRoleAttributeName(), roleUri);
+    }
+
+
+    Name actorAttNameWithoutNS = NameImpl.createFromTagName("actor");
+
+    public String getActor() {
+        String actor = getAttributeValue(getActorAttributeName());
+        return actor;
+    }
+
+    Name roleAttNameWithoutNS = NameImpl.createFromTagName("role");
+
+    public String getRole() {
+        // runtime exception thrown for 1.1
+        String role = getAttributeValue(getRoleAttributeName());
+        return role;
+    }
+
+    public void setMustUnderstand(boolean mustUnderstand) {
+        try {
+            removeAttribute(getMustunderstandAttributeName());
+            addAttribute(
+                (Name) getMustunderstandAttributeName(),
+                getMustunderstandLiteralValue(mustUnderstand));
+        } catch (SOAPException ex) {
+        }
+    }
+
+    public boolean getMustUnderstand() {
+        String mu = getAttributeValue(getMustunderstandAttributeName());
+
+        if (mu != null)
+            return getMustunderstandAttributeValue(mu);
+
+        return false;
+    }
+
+    public void setRelay(boolean relay) throws SOAPException {
+        // runtime exception thrown for 1.1
+        removeAttribute(getRelayAttributeName());
+        addAttribute(
+            (Name) getRelayAttributeName(),
+            getRelayLiteralValue(relay));
+    }
+
+    public boolean getRelay() {
+        String mu = getAttributeValue(getRelayAttributeName());
+        if (mu != null)
+            return getRelayAttributeValue(mu);
+
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/HeaderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/HeaderImpl.java
new file mode 100644
index 0000000..2ea6d07
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/HeaderImpl.java
@@ -0,0 +1,310 @@
+/*
+ * $Id: HeaderImpl.java,v 1.33 2006/01/27 12:49:35 vj135062 Exp $
+ * $Revision: 1.33 $
+ * $Date: 2006/01/27 12:49:35 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.*;
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import org.w3c.dom.Element;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public abstract class HeaderImpl extends ElementImpl implements SOAPHeader {
+    protected static final boolean MUST_UNDERSTAND_ONLY = false;
+
+    protected HeaderImpl(SOAPDocumentImpl ownerDoc, NameImpl name) {
+        super(ownerDoc, name);
+    }
+
+    protected abstract SOAPHeaderElement createHeaderElement(Name name)
+        throws SOAPException;
+    protected abstract SOAPHeaderElement createHeaderElement(QName name)
+        throws SOAPException;
+    protected abstract NameImpl getNotUnderstoodName();
+    protected abstract NameImpl getUpgradeName();
+    protected abstract NameImpl getSupportedEnvelopeName();
+
+    public SOAPHeaderElement addHeaderElement(Name name) throws SOAPException {
+        SOAPElement newHeaderElement =
+            ElementFactory.createNamedElement(
+                ((SOAPDocument) getOwnerDocument()).getDocument(),
+                name.getLocalName(),
+                name.getPrefix(),
+                name.getURI());
+        if (newHeaderElement == null
+            || !(newHeaderElement instanceof SOAPHeaderElement)) {
+            newHeaderElement = createHeaderElement(name);
+        }
+
+        // header elements must be namespace qualified
+        // check that URI is  not empty, ensuring that the element is NS qualified.
+        String uri = newHeaderElement.getElementQName().getNamespaceURI();
+        if ((uri == null) || ("").equals(uri)) {
+            log.severe("SAAJ0131.impl.header.elems.ns.qualified");
+            throw new SOAPExceptionImpl("HeaderElements must be namespace qualified");
+        }
+        addNode(newHeaderElement);
+        return (SOAPHeaderElement) newHeaderElement;
+    }
+
+    public SOAPHeaderElement addHeaderElement(QName name) throws SOAPException {
+        SOAPElement newHeaderElement =
+            ElementFactory.createNamedElement(
+                ((SOAPDocument) getOwnerDocument()).getDocument(),
+                name.getLocalPart(),
+                name.getPrefix(),
+                name.getNamespaceURI());
+        if (newHeaderElement == null
+            || !(newHeaderElement instanceof SOAPHeaderElement)) {
+            newHeaderElement = createHeaderElement(name);
+        }
+
+        // header elements must be namespace qualified
+        // check that URI is  not empty, ensuring that the element is NS qualified.
+        String uri = newHeaderElement.getElementQName().getNamespaceURI();
+        if ((uri == null) || ("").equals(uri)) {
+            log.severe("SAAJ0131.impl.header.elems.ns.qualified");
+            throw new SOAPExceptionImpl("HeaderElements must be namespace qualified");
+        }
+        addNode(newHeaderElement);
+        return (SOAPHeaderElement) newHeaderElement;
+    }
+
+    protected SOAPElement addElement(Name name) throws SOAPException {
+        return addHeaderElement(name);
+    }
+
+    protected SOAPElement addElement(QName name) throws SOAPException {
+        return addHeaderElement(name);
+    }
+
+    public Iterator examineHeaderElements(String actor) {
+        return getHeaderElementsForActor(actor, false, false);
+    }
+
+    public Iterator extractHeaderElements(String actor) {
+        return getHeaderElementsForActor(actor, true, false);
+    }
+
+    protected Iterator getHeaderElementsForActor(
+        String actor,
+        boolean detach,
+        boolean mustUnderstand) {
+        if (actor == null || actor.equals("")) {
+            log.severe("SAAJ0132.impl.invalid.value.for.actor.or.role");
+            throw new IllegalArgumentException("Invalid value for actor or role");
+        }
+        return getHeaderElements(actor, detach, mustUnderstand);
+    }
+
+    protected Iterator getHeaderElements(
+        String actor,
+        boolean detach,
+        boolean mustUnderstand) {
+        List elementList = new ArrayList();
+
+        Iterator eachChild = getChildElements();
+
+        Object currentChild = iterate(eachChild);
+        while (currentChild != null) {
+            if (!(currentChild instanceof SOAPHeaderElement)) {
+                currentChild = iterate(eachChild);
+            } else {
+                HeaderElementImpl currentElement =
+                    (HeaderElementImpl) currentChild;
+                currentChild = iterate(eachChild);
+
+                boolean isMustUnderstandMatching =
+                    (!mustUnderstand || currentElement.getMustUnderstand());
+                boolean doAdd = false;
+                if (actor == null && isMustUnderstandMatching) {
+                    doAdd = true;
+                } else {
+                    String currentActor = currentElement.getActorOrRole();
+                    if (currentActor == null) {
+                        currentActor = "";
+                    }
+
+                    if (currentActor.equalsIgnoreCase(actor)
+                        && isMustUnderstandMatching) {
+                        doAdd = true;
+                    }
+                }
+
+                if (doAdd) {
+                    elementList.add(currentElement);
+                    if (detach) {
+                        currentElement.detachNode();
+                    }
+                }
+            }
+        }
+
+        return elementList.listIterator();
+    }
+
+    private Object iterate(Iterator each) {
+        return each.hasNext() ? each.next() : null;
+    }
+
+    public void setParentElement(SOAPElement element) throws SOAPException {
+        if (!(element instanceof SOAPEnvelope)) {
+            log.severe("SAAJ0133.impl.header.parent.mustbe.envelope");
+            throw new SOAPException("Parent of SOAPHeader has to be a SOAPEnvelope");
+        }
+        super.setParentElement(element);
+    }
+
+    // overriding ElementImpl's method to ensure that HeaderElements are
+    // namespace qualified. Holds for both SOAP versions.
+    // TODO - This check needs to be made for other addChildElement() methods
+    // as well.
+    public SOAPElement addChildElement(String localName) throws SOAPException {
+
+        SOAPElement element = super.addChildElement(localName);
+        // check that URI is  not empty, ensuring that the element is NS qualified.
+        String uri = element.getElementName().getURI();
+        if ((uri == null) || ("").equals(uri)) {
+            log.severe("SAAJ0134.impl.header.elems.ns.qualified");
+            throw new SOAPExceptionImpl("HeaderElements must be namespace qualified");
+        }
+        return element;
+    }
+
+    public Iterator examineAllHeaderElements() {
+        return getHeaderElements(null, false, MUST_UNDERSTAND_ONLY);
+    }
+
+    public Iterator examineMustUnderstandHeaderElements(String actor) {
+        return getHeaderElements(actor, false, true);
+
+    }
+
+    public Iterator extractAllHeaderElements() {
+        return getHeaderElements(null, true, false);
+    }
+
+    public SOAPHeaderElement addUpgradeHeaderElement(Iterator supportedSoapUris)
+        throws SOAPException {
+        if (supportedSoapUris == null) {
+            log.severe("SAAJ0411.ver1_2.no.null.supportedURIs");
+            throw new SOAPException("Argument cannot be null; iterator of supportedURIs cannot be null");
+        }
+        if (!supportedSoapUris.hasNext()) {
+            log.severe("SAAJ0412.ver1_2.no.empty.list.of.supportedURIs");
+            throw new SOAPException("List of supported URIs cannot be empty");
+        }
+        Name upgradeName = getUpgradeName();
+        SOAPHeaderElement upgradeHeaderElement =
+            (SOAPHeaderElement) addChildElement(upgradeName);
+        Name supportedEnvelopeName = getSupportedEnvelopeName();
+        int i = 0;
+        while (supportedSoapUris.hasNext()) {
+            SOAPElement subElement =
+                upgradeHeaderElement.addChildElement(supportedEnvelopeName);
+            String ns = "ns" + Integer.toString(i);
+            subElement.addAttribute(
+                NameImpl.createFromUnqualifiedName("qname"),
+                ns + ":Envelope");
+            subElement.addNamespaceDeclaration(
+                ns,
+                (String) supportedSoapUris.next());
+            i ++;
+        }
+        return upgradeHeaderElement;
+    }
+
+    public SOAPHeaderElement addUpgradeHeaderElement(String supportedSoapUri)
+        throws SOAPException {
+        return addUpgradeHeaderElement(new String[] {supportedSoapUri});
+    }
+
+    public SOAPHeaderElement addUpgradeHeaderElement(String[] supportedSoapUris)
+        throws SOAPException {
+
+        if (supportedSoapUris == null) {
+            log.severe("SAAJ0411.ver1_2.no.null.supportedURIs");
+            throw new SOAPException("Argument cannot be null; array of supportedURIs cannot be null");
+        }
+        if (supportedSoapUris.length == 0) {
+            log.severe("SAAJ0412.ver1_2.no.empty.list.of.supportedURIs");
+            throw new SOAPException("List of supported URIs cannot be empty");
+        }
+        Name upgradeName = getUpgradeName();
+        SOAPHeaderElement upgradeHeaderElement =
+            (SOAPHeaderElement) addChildElement(upgradeName);
+        Name supportedEnvelopeName = getSupportedEnvelopeName();
+        for (int i = 0; i < supportedSoapUris.length; i ++) {
+            SOAPElement subElement =
+                upgradeHeaderElement.addChildElement(supportedEnvelopeName);
+            String ns = "ns" + Integer.toString(i);
+            subElement.addAttribute(
+                NameImpl.createFromUnqualifiedName("qname"),
+                ns + ":Envelope");
+            subElement.addNamespaceDeclaration(ns, supportedSoapUris[i]);
+        }
+        return upgradeHeaderElement;
+    }
+
+    protected SOAPElement convertToSoapElement(Element element) {
+        if (element instanceof SOAPHeaderElement) {
+            return (SOAPElement) element;
+        } else {
+            SOAPHeaderElement headerElement;
+            try {
+                headerElement =
+                    createHeaderElement(NameImpl.copyElementName(element));
+            } catch (SOAPException e) {
+                throw new ClassCastException("Could not convert Element to SOAPHeaderElement: " + e.getMessage());
+            }
+            return replaceElementWithSOAPElement(
+                element,
+                (ElementImpl) headerElement);
+        }
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+       log.log(Level.SEVERE,
+                "SAAJ0146.impl.invalid.name.change.requested",
+                new Object[] {elementQName.getLocalPart(),
+                              newName.getLocalPart()});
+        throw new SOAPException("Cannot change name for "
+                                + elementQName.getLocalPart() + " to "
+                                + newName.getLocalPart());
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/LocalStrings.properties b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/LocalStrings.properties
new file mode 100644
index 0000000..10bec01
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/LocalStrings.properties
@@ -0,0 +1,61 @@
+# SAAJ ResourceBundle properties file
+# Contains Log messages for impl
+# Error messages
+SAAJ0101.impl.parent.of.body.elem.mustbe.body=SAAJ0101: Parent of a SOAPBodyElement has to be a SOAPBody
+SAAJ0102.impl.cannot.locate.ns=SAAJ0102: Unable to locate namespace for prefix {0}
+SAAJ0103.impl.cannot.add.fragements=SAAJ0103: Cannot add fragments which contain elements which are in the SOAP namespace
+SAAJ0105.impl.encoding.style.mustbe.valid.URI=SAAJ0105: Encoding style {0} should be a valid URI
+SAAJ0106.impl.no.null.to.parent.elem=SAAJ0106: Cannot pass NULL to setParentElement
+SAAJ0107.impl.elem.child.not.single.text=SAAJ0107: Cannot setValue on an Element that does not have an only child of type Text
+
+SAAJ0110.impl.fault.already.exists=SAAJ0110: Error: Fault already exists
+SAAJ0111.impl.body.parent.must.be.envelope=SAAJ0111: Parent of SOAPBody has to be a SOAPEnvelope
+
+SAAJ0112.impl.no.null.to.parent.elem=SAAJ0112: Cannot pass NULL to setParentElement
+SAAJ0113.impl.cannot.split.text.from.comment=SAAJ0113: Cannot split text from a Comment Node
+SAAJ0114.impl.cannot.replace.wholetext.from.comment=SAAJ0114: Cannot replace whole text from a Comment Node
+
+SAAJ0120.impl.header.already.exists=SAAJ0120: Can't add a header when one is already present
+SAAJ0121.impl.invalid.first.child.of.envelope=SAAJ0121: First child of Envelope must be either a Header or Body
+SAAJ0122.impl.body.already.exists=SAAJ0122: Can't add a body when one is already present
+SAAJ0123.impl.no.reserved.xmlns=SAAJ0123: Cannot declare reserved xmlns prefix
+SAAJ0124.impl.qualified.name.cannot.be.xmlns=SAAJ0124: Qualified name cannot be xmlns
+#SAAJ0125.impl.URI.cannot.be.null=SAAJ0125: URI cannot be null
+SAAJ0126.impl.cannot.locate.ns=SAAJ0126: Unable to locate namespace for prefix {0} 
+SAAJ0127.impl.no.null.for.parent.elem=SAAJ0127: Cannot pass NULL to setParentElement
+
+SAAJ0130.impl.header.elem.parent.mustbe.header=SAAJ0130: Parent of a SOAPHeaderElement has to be a SOAPHeader
+SAAJ0131.impl.header.elems.ns.qualified=SAAJ0131: HeaderElements must be namespace qualified
+SAAJ0132.impl.invalid.value.for.actor.or.role=SAAJ0132: Invalid value for actor or role
+SAAJ0133.impl.header.parent.mustbe.envelope=SAAJ0133: Parent of SOAPHeader has to be a SOAPEnvelope
+SAAJ0134.impl.header.elems.ns.qualified=SAAJ0134: HeaderElements must be namespace qualified
+
+SAAJ0140.impl.no.ns.URI=SAAJ0140: No NamespaceURI, SOAP requires faultcode content to be a QName
+SAAJ0141.impl.detail.exists=SAAJ0141: Detail already exists
+SAAJ0142.impl.reason.or.text.not.supported=SAAJ0142: Fault/Reason/Text not supported by this SOAP version, try SOAP 1.2 or later
+SAAJ0143.impl.node.not.supported=SAAJ0143: Fault/Node not supported by this SOAP version, try SOAP 1.2 or later
+SAAJ0144.impl.role.not.supported=SAAJ0144: Fault/Role not supported by this SOAP version, try SOAP 1.2 or later
+SAAJ0145.impl.no.null.to.parent.elem=SAAJ0145: Cannot pass NULL to setParentElement
+SAAJ0146.impl.invalid.name.change.requested=SAAJ0146: Cannot change name of element {0} to {1}
+SAAJ0147.impl.invalid.uri.change.requested=SAAJ0147: Cannot change the URI for prefix {0} from {1} to {2} in setElementQName
+SAAJ0148.impl.invalid.prefix.for.uri=Non-empty namespace URI: {0} for an empty prefix in SetElementQName
+
+SAAJ0250.impl.body.should.have.exactly.one.child=SAAJ0250: Cannot extract Document from body
+SAAJ0251.impl.cannot.extract.document.from.body=SAAJ0251: Unable to extract Document from body
+
+# Debug messages
+SAAJ0150.impl.added.attr=SAAJ0150: Added attribute {0}
+SAAJ0151.impl.no.children=SAAJ0151: Cannot find node containing value: there are no children
+SAAJ0152.impl.first.child.not.text.node=SAAJ0152: Cannot find node containing value: first child is not a Text node
+SAAJ0153.impl.multiple.children.same.value=SAAJ0153: Cannot find node containing value: There is more than one child node
+SAAJ0154.impl.adding.fault.to.nonbody=SAAJ0154: A SOAPFault element can only be added as a child of SOAPBody
+SAAJ0155.impl.adding.detail.nonfault=SAAJ0155: A Detail element can only be added as a child of a SOAPFault
+SAAJ0156.impl.adding.fault.error=SAAJ0156: Cannot add SOAPFault, a SOAPFault should be the only child of a SOAPBody
+SAAJ0157.impl.detail.exists.error=SAAJ0157: Cannot add Detail, Detail already exists
+SAAJ0158.impl.version.mismatch.fault=SAAJ0158: SOAP Version mismatch encountered when trying to add SOAPFault to SOAPBody
+SAAJ0159.impl.version.mismatch.detail=SAAJ0159: SOAP Version mismatch encountered when trying to add Detail to SOAPFault
+
+# Info messages
+SAAJ0190.impl.set.xml.declaration=SAAJ0190: Omit XML declaration set to {0}
+SAAJ0191.impl.set.encoding=SAAJ0191: Encoding is set to {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/TextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/TextImpl.java
new file mode 100644
index 0000000..a1b542a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/TextImpl.java
@@ -0,0 +1,94 @@
+/*
+ * $Id: TextImpl.java,v 1.19 2006/01/27 12:49:36 vj135062 Exp $
+ * $Revision: 1.19 $
+ * $Date: 2006/01/27 12:49:36 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+import java.util.logging.Logger;
+
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class TextImpl
+    extends com.sun.org.apache.xerces.internal.dom.TextImpl
+    implements javax.xml.soap.Text, org.w3c.dom.Text {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_IMPL_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.impl.LocalStrings");
+
+    public TextImpl(SOAPDocumentImpl ownerDoc, String text) {
+        super(ownerDoc, text);
+    }
+
+    public String getValue() {
+        String nodeValue = getNodeValue();
+        return (nodeValue.equals("") ? null : nodeValue);
+    }
+
+    public void setValue(String text) {
+        setNodeValue(text);
+    }
+
+    public void setParentElement(SOAPElement parent) throws SOAPException {
+        if (parent == null) {
+            log.severe("SAAJ0126.impl.cannot.locate.ns");
+            throw new SOAPException("Cannot pass NULL to setParentElement");
+        }
+        ((ElementImpl) parent).addNode(this);
+    }
+
+    public SOAPElement getParentElement() {
+        return (SOAPElement) getParentNode();
+    }
+
+
+    public void detachNode() {
+        org.w3c.dom.Node parent = getParentNode();
+        if (parent != null) {
+            parent.removeChild(this);
+        }
+    }
+
+    public void recycleNode() {
+        detachNode();
+        // TBD
+        //  - add this to the factory so subsequent
+        //    creations can reuse this object.
+    }
+
+    public boolean isComment() {
+        String txt = getNodeValue();
+
+        return txt.startsWith("<!--") && txt.endsWith("-->");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/TreeException.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/TreeException.java
new file mode 100644
index 0000000..a21fee8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/impl/TreeException.java
@@ -0,0 +1,37 @@
+/*
+ * $Id: TreeException.java,v 1.5 2006/01/27 12:49:36 vj135062 Exp $
+ * $Revision: 1.5 $
+ * $Date: 2006/01/27 12:49:36 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.impl;
+
+public class TreeException extends RuntimeException {
+    public TreeException(String reason) {
+        super(reason);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/name/LocalStrings.properties b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/name/LocalStrings.properties
new file mode 100644
index 0000000..616870d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/name/LocalStrings.properties
@@ -0,0 +1,6 @@
+# SAAJ ResourceBundle properties file
+# Contains Log messages for name pkg
+# Error messages
+SAAJ0201.name.not.created.from.null.tag=SAAJ0201: Cannot create a name from a null tag
+SAAJ0202.name.invalid.arg.format=SAAJ0202: Argument "{0}" must be of the form: prefix:localName
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/name/NameImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/name/NameImpl.java
new file mode 100644
index 0000000..f580ef3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/name/NameImpl.java
@@ -0,0 +1,557 @@
+/*
+ * $Id: NameImpl.java,v 1.48 2006/01/27 12:49:38 vj135062 Exp $
+ * $Revision: 1.48 $
+ * $Date: 2006/01/27 12:49:38 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.soap.name;
+
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.Name;
+import javax.xml.soap.SOAPConstants;
+
+import com.sun.org.apache.xerces.internal.xni.NamespaceContext;
+import org.w3c.dom.Element;
+
+import com.sun.xml.internal.messaging.saaj.soap.impl.ElementImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class NameImpl implements Name {
+    public static final String XML_NAMESPACE_PREFIX = "xml";
+    public static final String XML_SCHEMA_NAMESPACE_PREFIX = "xs";
+    public static final String SOAP_ENVELOPE_PREFIX = "SOAP-ENV";
+
+    public static final String XML_NAMESPACE =
+        "http://www.w3.org/XML/1998/namespace";
+    public static final String SOAP11_NAMESPACE =
+        SOAPConstants.URI_NS_SOAP_ENVELOPE;
+    public static final String SOAP12_NAMESPACE =
+        SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE;
+    public static final String XML_SCHEMA_NAMESPACE =
+        "http://www.w3.org/2001/XMLSchema";
+
+    protected String uri = "";
+    protected String localName = "";
+    protected String prefix = "";
+    private String qualifiedName = null;
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.NAMING_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.name.LocalStrings");
+
+    protected NameImpl(String name) {
+        this.localName = name == null ? "" : name;
+    }
+
+    protected NameImpl(String name, String prefix, String uri) {
+        this.uri = uri == null ? "" : uri;
+        this.localName = name == null ? "" : name;
+        this.prefix = prefix == null ? "" : prefix;
+
+        if (this.prefix.equals("xmlns") && this.uri.equals("")) {
+            this.uri = NamespaceContext.XMLNS_URI;
+        }
+        if (this.uri.equals(NamespaceContext.XMLNS_URI) && this.prefix.equals("")) {
+            this.prefix = "xmlns";
+        }
+    }
+
+    public static Name convertToName(QName qname) {
+        return new NameImpl(qname.getLocalPart(),
+                            qname.getPrefix(),
+                            qname.getNamespaceURI());
+    }
+
+    public static QName convertToQName(Name name) {
+        return new QName(name.getURI(),
+                         name.getLocalName(),
+                         name.getPrefix());
+    }
+
+    public static NameImpl createFromUnqualifiedName(String name) {
+        return new NameImpl(name);
+    }
+
+    public static Name createFromTagName(String tagName) {
+        return createFromTagAndUri(tagName, "");
+    }
+
+    public static Name createFromQualifiedName(
+        String qualifiedName,
+        String uri) {
+        return createFromTagAndUri(qualifiedName, uri);
+    }
+
+    protected static Name createFromTagAndUri(String tagName, String uri) {
+        if (tagName == null) {
+            log.severe("SAAJ0201.name.not.created.from.null.tag");
+            throw new IllegalArgumentException("Cannot create a name from a null tag.");
+        }
+        int index = tagName.indexOf(':');
+        if (index < 0) {
+            return new NameImpl(tagName, "", uri);
+        } else {
+            return new NameImpl(
+                tagName.substring(index + 1),
+                tagName.substring(0, index),
+                uri);
+        }
+    }
+
+    protected static int getPrefixSeparatorIndex(String qualifiedName) {
+        int index = qualifiedName.indexOf(':');
+        if (index < 0) {
+            log.log(
+                Level.SEVERE,
+                "SAAJ0202.name.invalid.arg.format",
+                new String[] { qualifiedName });
+            throw new IllegalArgumentException(
+                "Argument \""
+                    + qualifiedName
+                    + "\" must be of the form: \"prefix:localName\"");
+        }
+        return index;
+    }
+
+    public static String getPrefixFromQualifiedName(String qualifiedName) {
+        return qualifiedName.substring(
+            0,
+            getPrefixSeparatorIndex(qualifiedName));
+    }
+
+    public static String getLocalNameFromQualifiedName(String qualifiedName) {
+        return qualifiedName.substring(
+            getPrefixSeparatorIndex(qualifiedName) + 1);
+    }
+
+    public static String getPrefixFromTagName(String tagName) {
+        if (isQualified(tagName)) {
+            return getPrefixFromQualifiedName(tagName);
+        }
+        return "";
+    }
+
+    public static String getLocalNameFromTagName(String tagName) {
+        if (isQualified(tagName)) {
+            return getLocalNameFromQualifiedName(tagName);
+        }
+        return tagName;
+    }
+
+    public static boolean isQualified(String tagName) {
+        return tagName.indexOf(':') >= 0;
+    }
+
+    public static NameImpl create(String name, String prefix, String uri) {
+        if (prefix == null)
+            prefix = "";
+        if (uri == null)
+            uri = "";
+        if (name == null)
+            name = "";
+
+        if (!uri.equals("") && !name.equals("")) {
+            if (uri.equals(NameImpl.SOAP11_NAMESPACE)) {
+                if (name.equalsIgnoreCase("Envelope"))
+                    return createEnvelope1_1Name(prefix);
+                else if (name.equalsIgnoreCase("Header"))
+                    return createHeader1_1Name(prefix);
+                else if (name.equalsIgnoreCase("Body"))
+                    return createBody1_1Name(prefix);
+                else if (name.equalsIgnoreCase("Fault"))
+                    return createFault1_1Name(prefix);
+                else
+                    return new SOAP1_1Name(name, prefix);
+            } else if (uri.equals(SOAP12_NAMESPACE)) {
+                if (name.equalsIgnoreCase("Envelope"))
+                    return createEnvelope1_2Name(prefix);
+                else if (name.equalsIgnoreCase("Header"))
+                    return createHeader1_2Name(prefix);
+                else if (name.equalsIgnoreCase("Body"))
+                    return createBody1_2Name(prefix);
+                else if (
+                    name.equals("Fault")
+                        || name.equals("Reason")
+                        || name.equals("Detail"))
+                    return createFault1_2Name(name, prefix);
+                else if (name.equals("Code") || name.equals("Subcode"))
+                    return createCodeSubcode1_2Name(prefix, name);
+                else
+                    return new SOAP1_2Name(name, prefix);
+            }
+
+        }
+        return new NameImpl(name, prefix, uri);
+    }
+
+    public static String createQName(String prefix, String localName) {
+        if (prefix == null || prefix.equals("")) {
+            return localName;
+        }
+        return prefix + ":" + localName;
+    }
+
+    public boolean equals(Object obj) {
+        if (!(obj instanceof Name)) {
+            return false;
+        }
+
+        Name otherName = (Name) obj;
+
+        if (!uri.equals(otherName.getURI())) {
+            return false;
+        }
+
+        if (!localName.equals(otherName.getLocalName())) {
+            return false;
+        }
+
+        return true;
+    }
+
+    /**
+     * Get the local name part of this XML Name.
+     *
+     * @return a string for the local name.
+     */
+    public String getLocalName() {
+        return localName;
+    }
+
+    /* getQualifiedName is inherited from QName */
+
+    /**
+     * Returns the prefix associated with the namespace of the name.
+     *
+     * @return the prefix as a string.
+     */
+    public String getPrefix() {
+        return prefix;
+    }
+
+    /**
+     * Returns the URI associated of the namespace.
+     *
+     * @return the uri as a string.
+     */
+    public String getURI() {
+        return uri;
+    }
+
+    /**
+     * Returns a String version of the name suitable for use in an XML document.
+     */
+    public String getQualifiedName() {
+        if (qualifiedName == null) {
+            if (prefix != null && prefix.length() > 0) {
+                qualifiedName = prefix + ":" + localName;
+            } else {
+                qualifiedName = localName;
+            }
+        }
+        return qualifiedName;
+    }
+
+    /**
+     * Create a name object for a SOAP1.1 Envelope.
+     */
+    public static NameImpl createEnvelope1_1Name(String prefix) {
+        return new Envelope1_1Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.2 Envelope.
+     */
+    public static NameImpl createEnvelope1_2Name(String prefix) {
+        return new Envelope1_2Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.1 Header.
+     */
+    public static NameImpl createHeader1_1Name(String prefix) {
+        return new Header1_1Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.2 Header.
+     */
+    public static NameImpl createHeader1_2Name(String prefix) {
+        return new Header1_2Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.1 Body.
+     */
+    public static NameImpl createBody1_1Name(String prefix) {
+        return new Body1_1Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.2 Body.
+     */
+    public static NameImpl createBody1_2Name(String prefix) {
+        return new Body1_2Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.1 Fault.
+     */
+    public static NameImpl createFault1_1Name(String prefix) {
+        return new Fault1_1Name(prefix);
+    }
+
+    /**
+      * Create a name object for a SOAP1.2 NotUnderstood element.
+      */
+    public static NameImpl createNotUnderstood1_2Name(String prefix) {
+        return new NotUnderstood1_2Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.2 Upgrade element.
+     */
+    public static NameImpl createUpgrade1_2Name(String prefix) {
+        return new Upgrade1_2Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.2 SupportedEnvelope Upgrade element.
+     */
+    public static NameImpl createSupportedEnvelope1_2Name(String prefix) {
+        return new SupportedEnvelope1_2Name(prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.2
+     * Fault, Reason or Detail.
+     *
+     * @param localName Local Name of element
+     */
+    public static NameImpl createFault1_2Name(
+        String localName,
+        String prefix) {
+        return new Fault1_2Name(localName, prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.2 Fault/Code or Subcode.
+     *
+     * @param localName Either "Code" or "Subcode"
+     */
+    public static NameImpl createCodeSubcode1_2Name(
+        String prefix,
+        String localName) {
+        return new CodeSubcode1_2Name(localName, prefix);
+    }
+
+    /**
+     * Create a name object for a SOAP1.1 Fault Detail.
+     */
+    public static NameImpl createDetail1_1Name() {
+        return new Detail1_1Name();
+    }
+
+    public static NameImpl createDetail1_1Name(String prefix) {
+        return new Detail1_1Name(prefix);
+    }
+
+    public static NameImpl createFaultElement1_1Name(String localName) {
+        return new FaultElement1_1Name(localName);
+    }
+
+    public static NameImpl createFaultElement1_1Name(String localName,
+                                                     String prefix) {
+        return new FaultElement1_1Name(localName, prefix);
+    }
+
+    public static NameImpl createSOAP11Name(String string) {
+        return new SOAP1_1Name(string, null);
+    }
+    public static NameImpl createSOAP12Name(String string) {
+        return new SOAP1_2Name(string, null);
+    }
+
+    public static NameImpl createSOAP12Name(String localName, String prefix) {
+        return new SOAP1_2Name(localName, prefix);
+    }
+
+    public static NameImpl createXmlName(String localName) {
+        return new NameImpl(localName, XML_NAMESPACE_PREFIX, XML_NAMESPACE);
+    }
+
+    public static Name copyElementName(Element element) {
+        String localName = element.getLocalName();
+        String prefix = element.getPrefix();
+        String uri = element.getNamespaceURI();
+        return create(localName, prefix, uri);
+    }
+
+
+static class SOAP1_1Name extends NameImpl {
+    SOAP1_1Name(String name, String prefix) {
+        super(
+            name,
+            (prefix == null || prefix.equals(""))
+                ? NameImpl.SOAP_ENVELOPE_PREFIX
+                : prefix,
+            NameImpl.SOAP11_NAMESPACE);
+    }
+}
+
+static class Envelope1_1Name extends SOAP1_1Name {
+    Envelope1_1Name(String prefix) {
+        super("Envelope", prefix);
+    }
+}
+
+static class Header1_1Name extends SOAP1_1Name {
+    Header1_1Name(String prefix) {
+        super("Header", prefix);
+    }
+}
+
+static class Body1_1Name extends SOAP1_1Name {
+    Body1_1Name(String prefix) {
+        super("Body", prefix);
+    }
+}
+
+static class Fault1_1Name extends NameImpl {
+    Fault1_1Name(String prefix) {
+        super(
+            "Fault",
+            (prefix == null || prefix.equals(""))
+                ? SOAP_ENVELOPE_PREFIX
+                : prefix,
+            SOAP11_NAMESPACE);
+    }
+}
+
+static class Detail1_1Name extends NameImpl {
+    Detail1_1Name() {
+        super("detail");
+    }
+
+    Detail1_1Name(String prefix) {
+        super("detail", prefix, "");
+    }
+}
+
+static class FaultElement1_1Name extends NameImpl {
+    FaultElement1_1Name(String localName) {
+        super(localName);
+    }
+
+    FaultElement1_1Name(String localName, String prefix) {
+        super(localName, prefix, "");
+    }
+}
+
+static class SOAP1_2Name extends NameImpl {
+    SOAP1_2Name(String name, String prefix) {
+        super(
+            name,
+            (prefix == null || prefix.equals(""))
+                ? SOAPConstants.SOAP_ENV_PREFIX
+                : prefix,
+            SOAP12_NAMESPACE);
+    }
+}
+
+static class Envelope1_2Name extends SOAP1_2Name {
+    Envelope1_2Name(String prefix) {
+        super("Envelope", prefix);
+    }
+}
+
+static class Header1_2Name extends SOAP1_2Name {
+    Header1_2Name(String prefix) {
+        super("Header", prefix);
+    }
+}
+
+static class Body1_2Name extends SOAP1_2Name {
+    Body1_2Name(String prefix) {
+        super("Body", prefix);
+    }
+}
+
+static class Fault1_2Name extends NameImpl {
+    Fault1_2Name(String name, String prefix) {
+        super(
+            (name == null || name.equals("")) ? "Fault" : name,
+            (prefix == null || prefix.equals(""))
+                ? SOAPConstants.SOAP_ENV_PREFIX
+                : prefix,
+            SOAP12_NAMESPACE);
+    }
+}
+
+static class NotUnderstood1_2Name extends NameImpl {
+    NotUnderstood1_2Name(String prefix) {
+        super(
+            "NotUnderstood",
+            (prefix == null || prefix.equals(""))
+                ? SOAPConstants.SOAP_ENV_PREFIX
+                : prefix,
+            SOAP12_NAMESPACE);
+    }
+}
+
+static class Upgrade1_2Name extends NameImpl {
+    Upgrade1_2Name(String prefix) {
+        super(
+            "Upgrade",
+            (prefix == null || prefix.equals(""))
+                ? SOAPConstants.SOAP_ENV_PREFIX
+                : prefix,
+            SOAP12_NAMESPACE);
+    }
+}
+
+static class SupportedEnvelope1_2Name extends NameImpl {
+    SupportedEnvelope1_2Name(String prefix) {
+        super(
+            "SupportedEnvelope",
+            (prefix == null || prefix.equals(""))
+                ? SOAPConstants.SOAP_ENV_PREFIX
+                : prefix,
+            SOAP12_NAMESPACE);
+    }
+}
+
+static class CodeSubcode1_2Name extends SOAP1_2Name {
+    CodeSubcode1_2Name(String prefix, String localName) {
+        super(prefix, localName);
+    }
+}
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Body1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Body1_1Impl.java
new file mode 100644
index 0000000..600b4a1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Body1_1Impl.java
@@ -0,0 +1,87 @@
+/*
+ * $Id: Body1_1Impl.java,v 1.14 2006/01/27 12:49:38 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import java.util.Locale;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.BodyImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public class Body1_1Impl extends BodyImpl {
+    public Body1_1Impl(SOAPDocumentImpl ownerDocument, String prefix) {
+            super(ownerDocument, NameImpl.createBody1_1Name(prefix));
+    }
+
+    public SOAPFault addSOAP12Fault(QName faultCode, String faultReason, Locale locale) {
+        // log message here
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    protected NameImpl getFaultName(String name) {
+        // Ignore name
+        return NameImpl.createFault1_1Name(null);
+    }
+
+    protected SOAPBodyElement createBodyElement(Name name) {
+        return new BodyElement1_1Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+
+    protected SOAPBodyElement createBodyElement(QName name) {
+        return new BodyElement1_1Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+
+    protected QName getDefaultFaultCode() {
+        return new QName(SOAPConstants.URI_NS_SOAP_1_1_ENVELOPE, "Server");
+    }
+
+    protected boolean isFault(SOAPElement child) {
+        // SOAP 1.1 faults always use the default name
+        return child.getElementName().equals(getFaultName(null));
+    }
+
+    protected SOAPFault createFaultElement() {
+        return new Fault1_1Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(), getPrefix());
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/BodyElement1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/BodyElement1_1Impl.java
new file mode 100644
index 0000000..5cb845f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/BodyElement1_1Impl.java
@@ -0,0 +1,57 @@
+/*
+ * $Id: BodyElement1_1Impl.java,v 1.13 2006/01/27 12:49:39 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.Name;
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.BodyElementImpl;
+
+public class BodyElement1_1Impl extends BodyElementImpl {
+
+    public BodyElement1_1Impl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+    public BodyElement1_1Impl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        BodyElementImpl copy =
+            new BodyElement1_1Impl((SOAPDocumentImpl) getOwnerDocument(), newName);
+        return replaceElementWithSOAPElement(this,copy);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Detail1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Detail1_1Impl.java
new file mode 100644
index 0000000..29b7ee4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Detail1_1Impl.java
@@ -0,0 +1,63 @@
+/*
+ * $Id: Detail1_1Impl.java,v 1.12 2006/01/27 12:49:40 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.DetailEntry;
+import javax.xml.soap.Name;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.DetailImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public class Detail1_1Impl extends DetailImpl {
+
+    public Detail1_1Impl(SOAPDocumentImpl ownerDoc, String prefix) {
+        super(ownerDoc, NameImpl.createDetail1_1Name(prefix));
+    }
+    public Detail1_1Impl(SOAPDocumentImpl ownerDoc) {
+        super(ownerDoc, NameImpl.createDetail1_1Name());
+    }
+    protected DetailEntry createDetailEntry(Name name) {
+        return new DetailEntry1_1Impl(
+            (SOAPDocumentImpl) getOwnerDocument(),
+            name);
+    }
+    protected DetailEntry createDetailEntry(QName name) {
+        return new DetailEntry1_1Impl(
+            (SOAPDocumentImpl) getOwnerDocument(),
+            name);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/DetailEntry1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/DetailEntry1_1Impl.java
new file mode 100644
index 0000000..ab8be34
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/DetailEntry1_1Impl.java
@@ -0,0 +1,57 @@
+/*
+ * $Id: DetailEntry1_1Impl.java,v 1.13 2006/01/27 12:49:40 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.Name;
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.DetailEntryImpl;
+
+public class DetailEntry1_1Impl extends DetailEntryImpl {
+
+    public DetailEntry1_1Impl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+    public DetailEntry1_1Impl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        DetailEntryImpl copy =
+            new DetailEntry1_1Impl((SOAPDocumentImpl) getOwnerDocument(), newName);
+        return replaceElementWithSOAPElement(this,copy);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Envelope1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Envelope1_1Impl.java
new file mode 100644
index 0000000..5ec27a4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Envelope1_1Impl.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/*
+ * $Id: Envelope1_1Impl.java,v 1.8 2006/01/27 12:49:41 vj135062 Exp $
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.EnvelopeImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public class Envelope1_1Impl extends EnvelopeImpl {
+
+    public Envelope1_1Impl(SOAPDocumentImpl ownerDoc, String prefix){
+        super(ownerDoc, NameImpl.createEnvelope1_1Name(prefix));
+    }
+    Envelope1_1Impl(
+        SOAPDocumentImpl ownerDoc,
+        String prefix,
+        boolean createHeader,
+        boolean createBody)
+        throws SOAPException {
+        super(
+            ownerDoc,
+            NameImpl.createEnvelope1_1Name(prefix),
+            createHeader,
+            createBody);
+    }
+    protected NameImpl getBodyName(String prefix) {
+        return NameImpl.createBody1_1Name(prefix);
+    }
+
+    protected NameImpl getHeaderName(String prefix) {
+        return NameImpl.createHeader1_1Name(prefix);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Fault1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Fault1_1Impl.java
new file mode 100644
index 0000000..2015515
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Fault1_1Impl.java
@@ -0,0 +1,304 @@
+/*
+ * $Id: Fault1_1Impl.java,v 1.20 2006/01/27 12:49:41 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import java.util.Iterator;
+import java.util.Locale;
+import java.util.logging.Logger;
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPFaultElement;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPConstants;
+import javax.xml.soap.Name;
+import javax.xml.soap.Name;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.*;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+
+
+public class Fault1_1Impl extends FaultImpl {
+
+    protected static Logger log =
+        Logger.getLogger(
+            LogDomainConstants.SOAP_VER1_1_DOMAIN,
+            "com.sun.xml.internal.messaging.saaj.soap.ver1_1.LocalStrings");
+
+    public Fault1_1Impl(SOAPDocumentImpl ownerDocument, String prefix) {
+       super(ownerDocument, NameImpl.createFault1_1Name(prefix));
+    }
+
+    protected NameImpl getDetailName() {
+        return NameImpl.createDetail1_1Name();
+    }
+
+    protected NameImpl getFaultCodeName() {
+        return NameImpl.createFromUnqualifiedName("faultcode");
+    }
+
+    protected NameImpl getFaultStringName() {
+        return NameImpl.createFromUnqualifiedName("faultstring");
+    }
+
+    protected NameImpl getFaultActorName() {
+        return NameImpl.createFromUnqualifiedName("faultactor");
+    }
+
+    protected DetailImpl createDetail() {
+        return new Detail1_1Impl(
+                       ((SOAPDocument) getOwnerDocument()).getDocument());
+    }
+
+    protected FaultElementImpl createSOAPFaultElement(String localName) {
+        return new FaultElement1_1Impl(
+                       ((SOAPDocument) getOwnerDocument()).getDocument(),
+                       localName);
+    }
+
+    protected void checkIfStandardFaultCode(String faultCode, String uri)
+        throws SOAPException {
+        // SOAP 1.1 doesn't seem to mandate using faultcode from a particular
+        // set of values.
+        // Also need to be backward compatible.
+    }
+
+    protected void finallySetFaultCode(String faultcode) throws SOAPException {
+        this.faultCodeElement.addTextNode(faultcode);
+    }
+
+    public String getFaultCode() {
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        return this.faultCodeElement.getValue();
+    }
+
+    public Name getFaultCodeAsName() {
+
+        String faultcodeString = getFaultCode();
+        if (faultcodeString == null) {
+            return null;
+        }
+        int prefixIndex = faultcodeString.indexOf(':');
+        if (prefixIndex == -1) {
+            // Not a valid SOAP message, but we return the unqualified name
+            // anyway since some apps do not strictly conform to SOAP
+            // specs.  A message that does not contain a <faultcode>
+            // element itself is also not valid in which case we return
+            // null instead of throwing an exception so this is consistent.
+            return NameImpl.createFromUnqualifiedName(faultcodeString);
+        }
+
+        // Get the prefix and map it to a namespace name (AKA namespace URI)
+        String prefix = faultcodeString.substring(0, prefixIndex);
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        String nsName = this.faultCodeElement.getNamespaceURI(prefix);
+        return NameImpl.createFromQualifiedName(faultcodeString, nsName);
+    }
+
+    public QName getFaultCodeAsQName() {
+        String faultcodeString = getFaultCode();
+        if (faultcodeString == null) {
+            return null;
+        }
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        return convertCodeToQName(faultcodeString, this.faultCodeElement);
+    }
+
+    public void setFaultString(String faultString) throws SOAPException {
+
+        if (this.faultStringElement == null)
+            findFaultStringElement();
+
+        if (this.faultStringElement == null)
+            this.faultStringElement = addSOAPFaultElement("faultstring");
+        else {
+            this.faultStringElement.removeContents();
+            //this.faultStringElement.removeAttributeNS("http://www.w3.org/XML/1998/namespace", "lang");
+            this.faultStringElement.removeAttribute("xml:lang");
+        }
+
+        this.faultStringElement.addTextNode(faultString);
+    }
+
+    public String getFaultString() {
+        if (this.faultStringElement == null)
+            findFaultStringElement();
+        return this.faultStringElement.getValue();
+
+    }
+
+    public Locale getFaultStringLocale() {
+        if (this.faultStringElement == null)
+            findFaultStringElement();
+        if (this.faultStringElement != null) {
+            String xmlLangAttr =
+                this.faultStringElement.getAttributeValue(
+                    NameImpl.createFromUnqualifiedName("xml:lang"));
+            if (xmlLangAttr != null)
+                return xmlLangToLocale(xmlLangAttr);
+        }
+        return null;
+    }
+
+    public void setFaultString(String faultString, Locale locale)
+        throws SOAPException {
+        setFaultString(faultString);
+        this.faultStringElement.addAttribute(
+            NameImpl.createFromTagName("xml:lang"),
+            localeToXmlLang(locale));
+    }
+
+    protected boolean isStandardFaultElement(String localName) {
+        if (localName.equalsIgnoreCase("detail") ||
+            localName.equalsIgnoreCase("faultcode") ||
+            localName.equalsIgnoreCase("faultstring") ||
+            localName.equalsIgnoreCase("faultactor")) {
+            return true;
+        }
+        return false;
+    }
+
+    public void appendFaultSubcode(QName subcode) {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "appendFaultSubcode");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public void removeAllFaultSubcodes() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "removeAllFaultSubcodes");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public Iterator getFaultSubcodes() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "getFaultSubcodes");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public String getFaultReasonText(Locale locale) {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "getFaultReasonText");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public Iterator getFaultReasonTexts() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "getFaultReasonTexts");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public Iterator getFaultReasonLocales() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "getFaultReasonLocales");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public void addFaultReasonText(String text, java.util.Locale locale)
+        throws SOAPException {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "addFaultReasonText");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public String getFaultRole() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "getFaultRole");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public void setFaultRole(String uri) {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "setFaultRole");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public String getFaultNode() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "getFaultNode");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    public void setFaultNode(String uri) {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            "setFaultNode");
+        throw new UnsupportedOperationException("Not supported in SOAP 1.1");
+    }
+
+    protected QName getDefaultFaultCode() {
+        return new QName(SOAPConstants.URI_NS_SOAP_1_1_ENVELOPE, "Server");
+    }
+
+    public SOAPElement addChildElement(SOAPElement element)
+        throws SOAPException {
+        String localName = element.getLocalName();
+        if ("Detail".equalsIgnoreCase(localName)) {
+            if (hasDetail()) {
+                log.severe("SAAJ0305.ver1_2.detail.exists.error");
+                throw new SOAPExceptionImpl("Cannot add Detail, Detail already exists");
+            }
+        }
+        return super.addChildElement(element);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/FaultElement1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/FaultElement1_1Impl.java
new file mode 100644
index 0000000..53487d1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/FaultElement1_1Impl.java
@@ -0,0 +1,85 @@
+/*
+ * $Id: FaultElement1_1Impl.java,v 1.12 2006/01/27 12:49:41 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.FaultElementImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public class FaultElement1_1Impl extends FaultElementImpl {
+
+    public FaultElement1_1Impl(SOAPDocumentImpl ownerDoc, NameImpl qname) {
+        super(ownerDoc, qname);
+    }
+
+    public FaultElement1_1Impl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    public FaultElement1_1Impl(SOAPDocumentImpl ownerDoc,
+                               String localName) {
+        super(ownerDoc, NameImpl.createFaultElement1_1Name(localName));
+    }
+
+    public FaultElement1_1Impl(SOAPDocumentImpl ownerDoc,
+                               String localName,
+                               String prefix) {
+        super(ownerDoc,
+              NameImpl.createFaultElement1_1Name(localName, prefix));
+    }
+
+    protected boolean isStandardFaultElement() {
+        String localName = elementQName.getLocalPart();
+        if (localName.equalsIgnoreCase("faultcode") ||
+            localName.equalsIgnoreCase("faultstring") ||
+            localName.equalsIgnoreCase("faultactor")) {
+            return true;
+        }
+        return false;
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        if (!isStandardFaultElement()) {
+            FaultElement1_1Impl copy =
+                new FaultElement1_1Impl((SOAPDocumentImpl) getOwnerDocument(), newName);
+            return replaceElementWithSOAPElement(this,copy);
+        } else {
+            return super.setElementQName(newName);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Header1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Header1_1Impl.java
new file mode 100644
index 0000000..73a22b2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Header1_1Impl.java
@@ -0,0 +1,101 @@
+/*
+ * $Id: Header1_1Impl.java,v 1.29 2006/01/27 12:49:41 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import java.util.List;
+import java.util.Iterator;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.HeaderImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class Header1_1Impl extends HeaderImpl {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_VER1_1_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_1.LocalStrings");
+
+    public Header1_1Impl(SOAPDocumentImpl ownerDocument, String prefix) {
+            super(ownerDocument, NameImpl.createHeader1_1Name(prefix));
+    }
+
+    protected NameImpl getNotUnderstoodName() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0301.ver1_1.hdr.op.unsupported.in.SOAP1.1",
+            new String[] { "getNotUnderstoodName" });
+        throw new UnsupportedOperationException("Not supported by SOAP 1.1");
+    }
+
+    protected NameImpl getUpgradeName() {
+        return NameImpl.create(
+            "Upgrade",
+            getPrefix(),
+            SOAPConstants.URI_NS_SOAP_1_1_ENVELOPE);
+    }
+
+    protected NameImpl getSupportedEnvelopeName() {
+        return NameImpl.create(
+            "SupportedEnvelope",
+            getPrefix(),
+            SOAPConstants.URI_NS_SOAP_1_1_ENVELOPE);
+    }
+
+    public SOAPHeaderElement addNotUnderstoodHeaderElement(QName name)
+        throws SOAPException {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0301.ver1_1.hdr.op.unsupported.in.SOAP1.1",
+            new String[] { "addNotUnderstoodHeaderElement" });
+        throw new UnsupportedOperationException("Not supported by SOAP 1.1");
+    }
+
+    protected SOAPHeaderElement createHeaderElement(Name name) {
+        return new HeaderElement1_1Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+    protected SOAPHeaderElement createHeaderElement(QName name) {
+        return new HeaderElement1_1Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/HeaderElement1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/HeaderElement1_1Impl.java
new file mode 100644
index 0000000..9c24353
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/HeaderElement1_1Impl.java
@@ -0,0 +1,125 @@
+/*
+ * $Id: HeaderElement1_1Impl.java,v 1.29 2006/01/27 12:49:41 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.Name;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPElement;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.HeaderElementImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class HeaderElement1_1Impl extends HeaderElementImpl {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_VER1_1_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_1.LocalStrings");
+
+    public HeaderElement1_1Impl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+    public HeaderElement1_1Impl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        HeaderElementImpl copy =
+            new HeaderElement1_1Impl((SOAPDocumentImpl) getOwnerDocument(), newName);
+        return replaceElementWithSOAPElement(this,copy);
+    }
+
+    protected NameImpl getActorAttributeName() {
+        return NameImpl.create("actor", null, NameImpl.SOAP11_NAMESPACE);
+    }
+
+    // role not supported by SOAP 1.1
+    protected NameImpl getRoleAttributeName() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0302.ver1_1.hdr.attr.unsupported.in.SOAP1.1",
+            new String[] { "Role" });
+        throw new UnsupportedOperationException("Role not supported by SOAP 1.1");
+    }
+
+    protected NameImpl getMustunderstandAttributeName() {
+        return NameImpl.create("mustUnderstand", null, NameImpl.SOAP11_NAMESPACE);
+    }
+
+    // mustUnderstand attribute has literal value "1" or "0"
+    protected String getMustunderstandLiteralValue(boolean mustUnderstand) {
+        return (mustUnderstand == true ? "1" : "0");
+    }
+
+    protected boolean getMustunderstandAttributeValue(String mu) {
+        if ("1".equals(mu) || "true".equalsIgnoreCase(mu))
+            return true;
+        return false;
+    }
+
+    // relay not supported by SOAP 1.1
+    protected NameImpl getRelayAttributeName() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0302.ver1_1.hdr.attr.unsupported.in.SOAP1.1",
+            new String[] { "Relay" });
+        throw new UnsupportedOperationException("Relay not supported by SOAP 1.1");
+    }
+
+    protected String getRelayLiteralValue(boolean relayAttr) {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0302.ver1_1.hdr.attr.unsupported.in.SOAP1.1",
+            new String[] { "Relay" });
+        throw new UnsupportedOperationException("Relay not supported by SOAP 1.1");
+    }
+
+    protected boolean getRelayAttributeValue(String mu) {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0302.ver1_1.hdr.attr.unsupported.in.SOAP1.1",
+            new String[] { "Relay" });
+        throw new UnsupportedOperationException("Relay not supported by SOAP 1.1");
+    }
+
+    protected String getActorOrRole() {
+        return getActor();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/LocalStrings.properties b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/LocalStrings.properties
new file mode 100644
index 0000000..5a9f7f6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/LocalStrings.properties
@@ -0,0 +1,10 @@
+# SAAJ ResourceBundle properties file
+# Contains Log messages for ver1_1 pkg
+
+# Error messages
+SAAJ0301.ver1_1.hdr.op.unsupported.in.SOAP1.1=SAAJ0301: Operation {0} not supported by SOAP 1.1
+SAAJ0302.ver1_1.hdr.attr.unsupported.in.SOAP1.1=SAAJ0302: {0} not supported by SOAP 1.1
+SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1=SAAJ0303: Operation {0} not supported by SOAP 1.1 
+SAAJ0304.ver1_1.msg.invalid.SOAP1.1=SAAJ0304: InputStream does not represent a valid SOAP 1.1 Message 
+SAAJ0305.ver1_2.detail.exists.error=SAAJ0305: Cannot add Detail, Detail already exists
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Message1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Message1_1Impl.java
new file mode 100644
index 0000000..2af5bf0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/Message1_1Impl.java
@@ -0,0 +1,129 @@
+/*
+ * $Id: Message1_1Impl.java,v 1.24 2006/01/27 12:49:41 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ContentType;
+import com.sun.xml.internal.messaging.saaj.soap.MessageImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+public class Message1_1Impl extends MessageImpl implements SOAPConstants {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_VER1_1_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_1.LocalStrings");
+
+    public Message1_1Impl() {
+        super();
+    }
+
+    public Message1_1Impl(boolean isFastInfoset, boolean acceptFastInfoset) {
+        super(isFastInfoset, acceptFastInfoset);
+    }
+
+    public Message1_1Impl(SOAPMessage msg) {
+        super(msg);
+    }
+
+    // unused. can we delete this? - Kohsuke
+    public Message1_1Impl(MimeHeaders headers, InputStream in)
+        throws IOException, SOAPExceptionImpl {
+        super(headers, in);
+    }
+
+    public Message1_1Impl(MimeHeaders headers, ContentType ct, int stat, InputStream in)
+        throws SOAPExceptionImpl {
+        super(headers,ct,stat,in);
+    }
+
+    public SOAPPart getSOAPPart() {
+        if (soapPart == null) {
+            soapPart = new SOAPPart1_1Impl(this);
+        }
+        return soapPart;
+    }
+
+    protected boolean isCorrectSoapVersion(int contentTypeId) {
+        return (contentTypeId & SOAP1_1_FLAG) != 0;
+    }
+
+    public String getAction() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            new String[] { "Action" });
+        throw new UnsupportedOperationException("Operation not supported by SOAP 1.1");
+    }
+
+    public void setAction(String type) {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            new String[] { "Action" });
+        throw new UnsupportedOperationException("Operation not supported by SOAP 1.1");
+    }
+
+    public String getCharset() {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            new String[] { "Charset" });
+        throw new UnsupportedOperationException("Operation not supported by SOAP 1.1");
+    }
+
+    public void setCharset(String charset) {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0303.ver1_1.msg.op.unsupported.in.SOAP1.1",
+            new String[] { "Charset" });
+        throw new UnsupportedOperationException("Operation not supported by SOAP 1.1");
+    }
+
+    protected String getExpectedContentType() {
+        return isFastInfoset ? "application/fastinfoset" : "text/xml";
+    }
+
+   protected String getExpectedAcceptHeader() {
+       String accept = "text/xml, text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2";
+       return acceptFastInfoset ? ("application/fastinfoset, " + accept) : accept;
+   }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPFactory1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPFactory1_1Impl.java
new file mode 100644
index 0000000..8f09a65
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPFactory1_1Impl.java
@@ -0,0 +1,68 @@
+/*
+ * $Id: SOAPFactory1_1Impl.java,v 1.4 2006/01/27 12:49:42 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import javax.xml.soap.Detail;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPFault;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPFactoryImpl;
+
+public class SOAPFactory1_1Impl extends SOAPFactoryImpl {
+    protected SOAPDocumentImpl createDocument() {
+        return (new SOAPPart1_1Impl()).getDocument();
+    }
+
+    public Detail createDetail() throws SOAPException {
+        return new Detail1_1Impl(createDocument());
+    }
+
+    public SOAPFault createFault(String reasonText, QName faultCode)
+        throws SOAPException {
+        Fault1_1Impl fault = new Fault1_1Impl(createDocument(), null);
+        fault.setFaultString(reasonText);
+        fault.setFaultCode(faultCode);
+        return fault;
+    }
+
+    public SOAPFault createFault() throws SOAPException {
+        Fault1_1Impl fault = new Fault1_1Impl(createDocument(), null);
+        fault.setFaultCode(fault.getDefaultFaultCode());
+        fault.setFaultString("Fault string, and possibly fault code, not set");
+        return fault;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPMessageFactory1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPMessageFactory1_1Impl.java
new file mode 100644
index 0000000..845d2bf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPMessageFactory1_1Impl.java
@@ -0,0 +1,67 @@
+/*
+ * $Id: SOAPMessageFactory1_1Impl.java,v 1.7 2006/01/27 12:49:42 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.MessageFactoryImpl;
+import com.sun.xml.internal.messaging.saaj.soap.MessageImpl;
+
+public class SOAPMessageFactory1_1Impl extends MessageFactoryImpl {
+
+    public SOAPMessage createMessage() throws SOAPException {
+        return new Message1_1Impl();
+    }
+
+    public SOAPMessage createMessage(boolean isFastInfoset,
+        boolean acceptFastInfoset) throws SOAPException
+    {
+        return new Message1_1Impl(isFastInfoset, acceptFastInfoset);
+    }
+
+    public SOAPMessage createMessage(MimeHeaders headers, InputStream in)
+        throws IOException, SOAPExceptionImpl {
+        if ((headers == null) || (getContentType(headers) == null)) {
+            headers = new MimeHeaders();
+            headers.setHeader("Content-Type", SOAPConstants.SOAP_1_1_CONTENT_TYPE);
+        }
+        MessageImpl msg = new Message1_1Impl(headers, in);
+        msg.setLazyAttachments(lazyAttachments);
+        return msg;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPPart1_1Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPPart1_1Impl.java
new file mode 100644
index 0000000..69d534a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_1/SOAPPart1_1Impl.java
@@ -0,0 +1,97 @@
+/*
+ * $Id: SOAPPart1_1Impl.java,v 1.1.1.1 2006/01/27 13:10:57 kumarjayanti Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_1;
+
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.soap.SOAPConstants;
+import javax.xml.soap.SOAPException;
+import javax.xml.transform.Source;
+
+import com.sun.xml.internal.messaging.saaj.soap.*;
+import com.sun.xml.internal.messaging.saaj.soap.impl.EnvelopeImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+import com.sun.xml.internal.messaging.saaj.util.XMLDeclarationParser;
+
+public class SOAPPart1_1Impl extends SOAPPartImpl implements SOAPConstants {
+
+    protected static Logger log =
+        Logger.getLogger(LogDomainConstants.SOAP_VER1_1_DOMAIN,
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_1.LocalStrings");
+
+    public SOAPPart1_1Impl() {
+        super();
+     }
+
+    public SOAPPart1_1Impl(MessageImpl message) {
+        super(message);
+    }
+
+    protected String getContentType() {
+        return isFastInfoset() ? "application/fastinfoset" : "text/xml";
+    }
+
+    protected Envelope createEnvelopeFromSource() throws SOAPException {
+        // Record the presence of xml declaration before the envelope gets
+        // created.
+        XMLDeclarationParser parser = lookForXmlDecl();
+        Source tmp = source;
+        source = null;
+        EnvelopeImpl envelope =
+            (EnvelopeImpl) EnvelopeFactory.createEnvelope(tmp, this);
+
+        if (!envelope.getNamespaceURI().equals(SOAPConstants.URI_NS_SOAP_1_1_ENVELOPE)) {
+            log.severe("SAAJ0304.ver1_1.msg.invalid.SOAP1.1");
+            throw new SOAPException("InputStream does not represent a valid SOAP 1.1 Message");
+        }
+
+        if (!omitXmlDecl) {
+            envelope.setOmitXmlDecl("no");
+            envelope.setXmlDecl(parser.getXmlDeclaration());
+            envelope.setCharsetEncoding(parser.getEncoding());
+        }
+        return envelope;
+    }
+
+    protected Envelope createEmptyEnvelope(String prefix)
+        throws SOAPException {
+        return new Envelope1_1Impl(getDocument(), prefix, true, true);
+    }
+
+    protected SOAPPartImpl duplicateType() {
+        return new SOAPPart1_1Impl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Body1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Body1_2Impl.java
new file mode 100644
index 0000000..357bd0a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Body1_2Impl.java
@@ -0,0 +1,201 @@
+/*
+ * $Id: Body1_2Impl.java,v 1.32 2006/01/27 12:49:44 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.util.logging.Logger;
+import java.util.Locale;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import org.w3c.dom.Node;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.BodyImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public class Body1_2Impl extends BodyImpl {
+
+    protected static Logger log =
+        Logger.getLogger(Body1_2Impl.class.getName(),
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_2.LocalStrings");
+
+    public Body1_2Impl(SOAPDocumentImpl ownerDocument, String prefix) {
+            super(ownerDocument, NameImpl.createBody1_2Name(prefix));
+    }
+
+    protected NameImpl getFaultName(String name) {
+        return NameImpl.createFault1_2Name(name, null);
+    }
+
+    protected SOAPBodyElement createBodyElement(Name name) {
+        return new BodyElement1_2Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+    protected SOAPBodyElement createBodyElement(QName name) {
+        return new BodyElement1_2Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+
+    protected QName getDefaultFaultCode() {
+        return SOAPConstants.SOAP_RECEIVER_FAULT;
+    }
+
+    public SOAPFault addFault() throws SOAPException {
+        if (hasAnyChildElement()) {
+            log.severe("SAAJ0402.ver1_2.only.fault.allowed.in.body");
+            throw new SOAPExceptionImpl(
+                "No other element except Fault allowed in SOAPBody");
+        }
+        return super.addFault();
+    }
+
+    /*
+     * Override setEncodingStyle of ElementImpl to restrict adding encodingStyle
+     * attribute to SOAP Body (SOAP 1.2 spec, part 1, section 5.1.1)
+     */
+    public void setEncodingStyle(String encodingStyle) throws SOAPException {
+        log.severe("SAAJ0401.ver1_2.no.encodingstyle.in.body");
+        throw new SOAPExceptionImpl("encodingStyle attribute cannot appear on Body");
+    }
+
+    /*
+     * Override addAttribute of ElementImpl to restrict adding encodingStyle
+     * attribute to SOAP Body (SOAP 1.2 spec, part 1, section 5.1.1)
+     */
+    public SOAPElement addAttribute(Name name, String value)
+        throws SOAPException {
+        if (name.getLocalName().equals("encodingStyle")
+            && name.getURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+    public SOAPElement addAttribute(QName name, String value)
+        throws SOAPException {
+        if (name.getLocalPart().equals("encodingStyle")
+            && name.getNamespaceURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+    protected boolean isFault(SOAPElement child) {
+        return (child.getElementName().getURI().equals(
+                    SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE) &&
+                child.getElementName().getLocalName().equals(
+                    "Fault"));
+    }
+
+    protected SOAPFault createFaultElement() {
+        return new Fault1_2Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(), getPrefix());
+    }
+
+    /*
+     * section 5.4 of SOAP1.2 candidate recommendation says that a
+     * SOAP message MUST contain a single Fault element as the only
+     * child element of the SOAP Body.
+     */
+    public SOAPBodyElement addBodyElement(Name name) throws SOAPException {
+        if (hasFault()) {
+            log.severe("SAAJ0402.ver1_2.only.fault.allowed.in.body");
+            throw new SOAPExceptionImpl(
+                "No other element except Fault allowed in SOAPBody");
+        }
+        return super.addBodyElement(name);
+    }
+
+    public SOAPBodyElement addBodyElement(QName name) throws SOAPException {
+        if (hasFault()) {
+            log.severe("SAAJ0402.ver1_2.only.fault.allowed.in.body");
+            throw new SOAPExceptionImpl(
+                "No other element except Fault allowed in SOAPBody");
+        }
+        return super.addBodyElement(name);
+    }
+
+    protected SOAPElement addElement(Name name) throws SOAPException {
+        if (hasFault()) {
+            log.severe("SAAJ0402.ver1_2.only.fault.allowed.in.body");
+            throw new SOAPExceptionImpl(
+                "No other element except Fault allowed in SOAPBody");
+        }
+        return super.addElement(name);
+    }
+
+    protected SOAPElement addElement(QName name) throws SOAPException {
+        if (hasFault()) {
+            log.severe("SAAJ0402.ver1_2.only.fault.allowed.in.body");
+            throw new SOAPExceptionImpl(
+                "No other element except Fault allowed in SOAPBody");
+        }
+        return super.addElement(name);
+    }
+
+    public SOAPElement addChildElement(Name name) throws SOAPException {
+        if (hasFault()) {
+            log.severe("SAAJ0402.ver1_2.only.fault.allowed.in.body");
+            throw new SOAPExceptionImpl(
+                "No other element except Fault allowed in SOAPBody");
+        }
+        return super.addChildElement(name);
+    }
+
+    public SOAPElement addChildElement(QName name) throws SOAPException {
+        if (hasFault()) {
+            log.severe("SAAJ0402.ver1_2.only.fault.allowed.in.body");
+            throw new SOAPExceptionImpl(
+                "No other element except Fault allowed in SOAPBody");
+        }
+        return super.addChildElement(name);
+    }
+
+    private boolean hasAnyChildElement() {
+        Node currentNode = getFirstChild();
+        while (currentNode != null) {
+            if (currentNode.getNodeType() == Node.ELEMENT_NODE)
+                return true;
+            currentNode = currentNode.getNextSibling();
+        }
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/BodyElement1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/BodyElement1_2Impl.java
new file mode 100644
index 0000000..3a1340d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/BodyElement1_2Impl.java
@@ -0,0 +1,60 @@
+/*
+ * $Id: BodyElement1_2Impl.java,v 1.13 2006/01/27 12:49:44 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.Name;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPElement;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.BodyElementImpl;
+
+public class BodyElement1_2Impl extends BodyElementImpl {
+
+    public BodyElement1_2Impl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+
+    public BodyElement1_2Impl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        BodyElementImpl copy =
+            new BodyElement1_2Impl((SOAPDocumentImpl) getOwnerDocument(), newName);
+        return replaceElementWithSOAPElement(this,copy);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Detail1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Detail1_2Impl.java
new file mode 100644
index 0000000..45c670b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Detail1_2Impl.java
@@ -0,0 +1,99 @@
+/*
+ * $Id: Detail1_2Impl.java,v 1.24 2006/01/27 12:49:45 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.util.logging.Logger;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.DetailImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public class Detail1_2Impl extends DetailImpl {
+
+    protected static Logger log =
+        Logger.getLogger(Detail1_2Impl.class.getName(),
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_2.LocalStrings");
+
+    public Detail1_2Impl(SOAPDocumentImpl ownerDocument, String prefix) {
+        super(ownerDocument, NameImpl.createSOAP12Name("Detail", prefix));
+    }
+
+    public Detail1_2Impl(SOAPDocumentImpl ownerDocument) {
+        super(ownerDocument, NameImpl.createSOAP12Name("Detail"));
+    }
+
+    protected DetailEntry createDetailEntry(Name name) {
+        return new DetailEntry1_2Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+
+    protected DetailEntry createDetailEntry(QName name) {
+        return new DetailEntry1_2Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+
+    /*
+     * Override setEncodingStyle of ElementImpl to restrict adding encodingStyle
+     * attribute to SOAP Detail (SOAP 1.2 spec, part 1, section 5.1.1)
+     */
+    public void setEncodingStyle(String encodingStyle) throws SOAPException {
+        log.severe("SAAJ0403.ver1_2.no.encodingStyle.in.detail");
+        throw new SOAPExceptionImpl("EncodingStyle attribute cannot appear in Detail");
+    }
+
+    public SOAPElement addAttribute(Name name, String value)
+        throws SOAPException {
+        if (name.getLocalName().equals("encodingStyle")
+            && name.getURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+    public SOAPElement addAttribute(QName name, String value)
+        throws SOAPException {
+        if (name.getLocalPart().equals("encodingStyle")
+            && name.getNamespaceURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/DetailEntry1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/DetailEntry1_2Impl.java
new file mode 100644
index 0000000..64af1a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/DetailEntry1_2Impl.java
@@ -0,0 +1,60 @@
+/*
+ * $Id: DetailEntry1_2Impl.java,v 1.13 2006/01/27 12:49:45 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.Name;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPElement;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.DetailEntryImpl;
+
+public class DetailEntry1_2Impl extends DetailEntryImpl {
+
+    public DetailEntry1_2Impl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+
+    public DetailEntry1_2Impl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        DetailEntryImpl copy =
+            new DetailEntry1_2Impl((SOAPDocumentImpl) getOwnerDocument(), newName);
+        return replaceElementWithSOAPElement(this,copy);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Envelope1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Envelope1_2Impl.java
new file mode 100644
index 0000000..9c0b568
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Envelope1_2Impl.java
@@ -0,0 +1,151 @@
+/*
+ * $Id: Envelope1_2Impl.java,v 1.26 2006/01/27 12:49:47 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.util.logging.Logger;
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.EnvelopeImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public class Envelope1_2Impl extends EnvelopeImpl {
+
+    protected static Logger log =
+        Logger.getLogger(Envelope1_2Impl.class.getName(),
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_2.LocalStrings");
+
+    public Envelope1_2Impl(SOAPDocumentImpl ownerDoc, String prefix) {
+        super(ownerDoc, NameImpl.createEnvelope1_2Name(prefix));
+    }
+
+    public Envelope1_2Impl(
+        SOAPDocumentImpl ownerDoc,
+        String prefix,
+        boolean createHeader,
+        boolean createBody)
+        throws SOAPException {
+        super(
+            ownerDoc,
+            NameImpl.createEnvelope1_2Name(prefix),
+            createHeader,
+            createBody);
+    }
+
+    protected NameImpl getBodyName(String prefix) {
+        return NameImpl.createBody1_2Name(prefix);
+    }
+
+    protected NameImpl getHeaderName(String prefix) {
+        return NameImpl.createHeader1_2Name(prefix);
+    }
+
+    /*
+     * Override setEncodingStyle of ElementImpl to restrict adding encodingStyle
+     * attribute to SOAP Envelope (SOAP 1.2 spec, part 1, section 5.1.1)
+     */
+    public void setEncodingStyle(String encodingStyle) throws SOAPException {
+        log.severe("SAAJ0404.ver1_2.no.encodingStyle.in.envelope");
+        throw new SOAPExceptionImpl("encodingStyle attribute cannot appear on Envelope");
+    }
+
+    /*
+     * Override addAttribute of ElementImpl to restrict adding encodingStyle
+     * attribute to SOAP Envelope (SOAP 1.2 spec, part 1, section 5.1.1)
+     */
+    public SOAPElement addAttribute(Name name, String value)
+        throws SOAPException {
+        if (name.getLocalName().equals("encodingStyle")
+            && name.getURI().equals(SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE)) {
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+    public SOAPElement addAttribute(QName name, String value)
+        throws SOAPException {
+        if (name.getLocalPart().equals("encodingStyle")
+            && name.getNamespaceURI().equals(SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE)) {
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+
+    /*
+     * Override addChildElement method to ensure that no element
+     * is added after body in SOAP 1.2.
+     */
+    public SOAPElement addChildElement(Name name) throws SOAPException {
+        // check if body already exists
+        if (getBody() != null) {
+            log.severe("SAAJ0405.ver1_2.body.must.last.in.envelope");
+            throw new SOAPExceptionImpl(
+                "Body must be the last element in" + " SOAP Envelope");
+        }
+        return super.addChildElement(name);
+    }
+
+    public SOAPElement addChildElement(QName name) throws SOAPException {
+        // check if body already exists
+        if (getBody() != null) {
+            log.severe("SAAJ0405.ver1_2.body.must.last.in.envelope");
+            throw new SOAPExceptionImpl(
+                "Body must be the last element in" + " SOAP Envelope");
+        }
+        return super.addChildElement(name);
+    }
+
+
+    /*
+     * Ideally we should be overriding other addChildElement() methods as well
+     * but we are not adding them here since internally all those call the
+     * method addChildElement(Name name).
+     * In future, if this behaviour changes, then we would need to override
+     * all the rest of them as well.
+     *
+     */
+
+    public SOAPElement addTextNode(String text) throws SOAPException {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0416.ver1_2.adding.text.not.legal",
+            getElementQName());
+        throw new SOAPExceptionImpl("Adding text to SOAP 1.2 Envelope is not legal");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Fault1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Fault1_2Impl.java
new file mode 100644
index 0000000..73d3236
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Fault1_2Impl.java
@@ -0,0 +1,550 @@
+/*
+ * $Id: Fault1_2Impl.java,v 1.45 2006/01/27 12:49:47 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.util.*;
+import java.util.logging.Logger;
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.*;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+
+public class Fault1_2Impl extends FaultImpl {
+
+    protected static Logger log =
+        Logger.getLogger(
+            LogDomainConstants.SOAP_VER1_2_DOMAIN,
+            "com.sun.xml.internal.messaging.saaj.soap.ver1_2.LocalStrings");
+
+    private static final QName textName =
+        new QName(SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE, "Text");
+    private final QName valueName =
+        new QName(SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE, "Value", getPrefix());
+    private final QName subcodeName =
+        new QName(SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE, "Subcode", getPrefix());
+
+    private SOAPElement innermostSubCodeElement = null;
+
+    public Fault1_2Impl(SOAPDocumentImpl ownerDoc, String name, String prefix) {
+        super(ownerDoc, NameImpl.createFault1_2Name(name, prefix));
+    }
+
+    public Fault1_2Impl(SOAPDocumentImpl ownerDocument, String prefix) {
+        super(ownerDocument, NameImpl.createFault1_2Name(null, prefix));
+    }
+
+    protected NameImpl getDetailName() {
+        return NameImpl.createSOAP12Name("Detail", getPrefix());
+    }
+
+    protected NameImpl getFaultCodeName() {
+        return NameImpl.createSOAP12Name("Code", getPrefix());
+    }
+
+    protected NameImpl getFaultStringName() {
+        return getFaultReasonName();
+    }
+
+    protected NameImpl getFaultActorName() {
+        return getFaultRoleName();
+    }
+
+    private  NameImpl getFaultRoleName() {
+        return NameImpl.createSOAP12Name("Role", getPrefix());
+    }
+
+    private  NameImpl getFaultReasonName() {
+        return NameImpl.createSOAP12Name("Reason", getPrefix());
+    }
+
+    private  NameImpl getFaultReasonTextName() {
+        return NameImpl.createSOAP12Name("Text", getPrefix());
+    }
+
+    private  NameImpl getFaultNodeName() {
+        return NameImpl.createSOAP12Name("Node", getPrefix());
+    }
+
+    private static NameImpl getXmlLangName() {
+        return NameImpl.createXmlName("lang");
+    }
+
+    protected DetailImpl createDetail() {
+        return new Detail1_2Impl(
+                       ((SOAPDocument) getOwnerDocument()).getDocument());
+    }
+
+    protected FaultElementImpl createSOAPFaultElement(String localName) {
+        return new FaultElement1_2Impl(
+                       ((SOAPDocument) getOwnerDocument()).getDocument(),
+                       localName);
+    }
+
+    protected void checkIfStandardFaultCode(String faultCode, String uri)
+        throws SOAPException {
+        QName qname = new QName(uri, faultCode);
+        if (SOAPConstants.SOAP_DATAENCODINGUNKNOWN_FAULT.equals(qname) ||
+            SOAPConstants.SOAP_MUSTUNDERSTAND_FAULT.equals(qname) ||
+            SOAPConstants.SOAP_RECEIVER_FAULT.equals(qname) ||
+            SOAPConstants.SOAP_SENDER_FAULT.equals(qname) ||
+            SOAPConstants.SOAP_VERSIONMISMATCH_FAULT.equals(qname))
+            return;
+        log.log(
+            Level.SEVERE,
+            "SAAJ0435.ver1_2.code.not.standard",
+            qname);
+        throw new SOAPExceptionImpl(qname + " is not a standard Code value");
+    }
+
+    protected void finallySetFaultCode(String faultcode) throws SOAPException {
+        SOAPElement value = this.faultCodeElement.addChildElement(valueName);
+        value.addTextNode(faultcode);
+    }
+
+    private void findReasonElement() {
+        findFaultStringElement();
+    }
+
+    public Iterator getFaultReasonTexts() throws SOAPException {
+        // Fault Reason has similar semantics as faultstring
+        if (this.faultStringElement == null)
+            findReasonElement();
+        Iterator eachTextElement =
+            this.faultStringElement.getChildElements(textName);
+        List texts = new ArrayList();
+        while (eachTextElement.hasNext()) {
+            SOAPElement textElement = (SOAPElement) eachTextElement.next();
+            Locale thisLocale = getLocale(textElement);
+            if (thisLocale == null) {
+                log.severe("SAAJ0431.ver1_2.xml.lang.missing");
+                throw new SOAPExceptionImpl("\"xml:lang\" attribute is not present on the Text element");
+            }
+            texts.add(textElement.getValue());
+        }
+        if (texts.isEmpty()) {
+            log.severe("SAAJ0434.ver1_2.text.element.not.present");
+            throw new SOAPExceptionImpl("env:Text must be present inside env:Reason");
+        }
+        return texts.iterator();
+    }
+
+    public void addFaultReasonText(String text, java.util.Locale locale)
+        throws SOAPException {
+
+        if (locale == null) {
+            log.severe("SAAJ0430.ver1_2.locale.required");
+            throw new SOAPException("locale is required and must not be null");
+        }
+
+        // Fault Reason has similar semantics as faultstring
+        if (this.faultStringElement == null)
+            findReasonElement();
+        SOAPElement reasonText;
+
+        if (this.faultStringElement == null) {
+            this.faultStringElement = addSOAPFaultElement("Reason");
+            reasonText =
+                this.faultStringElement.addChildElement(
+                    getFaultReasonTextName());
+        } else {
+            removeDefaultFaultString();
+            reasonText = getFaultReasonTextElement(locale);
+            if (reasonText != null) {
+                reasonText.removeContents();
+            } else {
+                reasonText =
+                    this.faultStringElement.addChildElement(
+                        getFaultReasonTextName());
+            }
+        }
+
+        String xmlLang = localeToXmlLang(locale);
+        reasonText.addAttribute(getXmlLangName(), xmlLang);
+        reasonText.addTextNode(text);
+    }
+
+    private void removeDefaultFaultString() throws SOAPException {
+        SOAPElement reasonText = getFaultReasonTextElement(Locale.getDefault());
+        if (reasonText != null) {
+            String defaultFaultString =
+                "Fault string, and possibly fault code, not set";
+            if (defaultFaultString.equals(reasonText.getValue())) {
+                reasonText.detachNode();
+            }
+        }
+    }
+
+    public String getFaultReasonText(Locale locale) throws SOAPException {
+
+        if (locale == null)
+            return null;
+
+        // Fault Reason has similar semantics as faultstring
+        if (this.faultStringElement == null)
+            findReasonElement();
+
+        if (this.faultStringElement != null) {
+            SOAPElement textElement = getFaultReasonTextElement(locale);
+            if (textElement != null) {
+                textElement.normalize();
+                return textElement.getFirstChild().getNodeValue();
+            }
+        }
+
+        return null;
+    }
+
+    public Iterator getFaultReasonLocales() throws SOAPException {
+        // Fault Reason has similar semantics as faultstring
+        if (this.faultStringElement == null)
+            findReasonElement();
+        Iterator eachTextElement =
+            this.faultStringElement.getChildElements(textName);
+        List localeSet = new ArrayList();
+        while (eachTextElement.hasNext()) {
+            SOAPElement textElement = (SOAPElement) eachTextElement.next();
+            Locale thisLocale = getLocale(textElement);
+            if (thisLocale == null) {
+                log.severe("SAAJ0431.ver1_2.xml.lang.missing");
+                throw new SOAPExceptionImpl("\"xml:lang\" attribute is not present on the Text element");
+            }
+            localeSet.add(thisLocale);
+        }
+        if (localeSet.isEmpty()) {
+            log.severe("SAAJ0434.ver1_2.text.element.not.present");
+            throw new SOAPExceptionImpl("env:Text elements with mandatory xml:lang attributes must be present inside env:Reason");
+        }
+        return localeSet.iterator();
+    }
+
+    public Locale getFaultStringLocale() {
+        Locale locale = null;
+        try {
+            locale = (Locale) getFaultReasonLocales().next();
+        } catch (SOAPException e) {}
+        return locale;
+    }
+
+    /*
+     * This method assumes that locale and faultStringElement are non-null
+     */
+    private SOAPElement getFaultReasonTextElement(Locale locale)
+        throws SOAPException {
+
+        // Fault Reason has similar semantics as faultstring
+        Iterator eachTextElement =
+            this.faultStringElement.getChildElements(textName);
+        while (eachTextElement.hasNext()) {
+            SOAPElement textElement = (SOAPElement) eachTextElement.next();
+            Locale thisLocale = getLocale(textElement);
+            if (thisLocale == null) {
+                log.severe("SAAJ0431.ver1_2.xml.lang.missing");
+                throw new SOAPExceptionImpl("\"xml:lang\" attribute is not present on the Text element");
+            }
+            if (thisLocale.equals(locale)) {
+                return textElement;
+            }
+        }
+        return null;
+    }
+
+    public String getFaultNode() {
+        SOAPElement faultNode = findChild(getFaultNodeName());
+        if (faultNode == null) {
+            return null;
+        }
+        return faultNode.getValue();
+    }
+
+    public void setFaultNode(String uri) throws SOAPException {
+        SOAPElement faultNode = findChild(getFaultNodeName());
+        if (faultNode != null) {
+            faultNode.detachNode();
+        }
+        faultNode = createSOAPFaultElement(getFaultNodeName().getLocalName());
+        faultNode = faultNode.addTextNode(uri);
+        if (getFaultRole() != null) {
+            insertBefore(faultNode, this.faultActorElement);
+            return;
+        }
+        if (hasDetail()) {
+            insertBefore(faultNode, this.detail);
+            return;
+        }
+        addNode(faultNode);
+    }
+
+    public String getFaultRole() {
+        return getFaultActor();
+    }
+
+    public void setFaultRole(String uri) throws SOAPException {
+        if (this.faultActorElement == null)
+            findFaultActorElement();
+        if (this.faultActorElement != null)
+            this.faultActorElement.detachNode();
+        this.faultActorElement =
+            createSOAPFaultElement(getFaultActorName().getLocalName());
+        this.faultActorElement.addTextNode(uri);
+        if (hasDetail()) {
+            insertBefore(this.faultActorElement, this.detail);
+            return;
+        }
+        addNode(this.faultActorElement);
+    }
+
+    public String getFaultCode() {
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        Iterator codeValues =
+            this.faultCodeElement.getChildElements(valueName);
+        return ((SOAPElement) codeValues.next()).getValue();
+    }
+
+    public QName getFaultCodeAsQName() {
+        String faultcode = getFaultCode();
+        if (faultcode == null) {
+            return null;
+        }
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        Iterator valueElements =
+            this.faultCodeElement.getChildElements(valueName);
+        return convertCodeToQName(
+            faultcode,
+            (SOAPElement) valueElements.next());
+    }
+
+    public Name getFaultCodeAsName() {
+        String faultcode = getFaultCode();
+        if (faultcode == null) {
+            return null;
+        }
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        Iterator valueElements =
+            this.faultCodeElement.getChildElements(valueName);
+        return NameImpl.convertToName(
+            convertCodeToQName(
+                faultcode,
+                (SOAPElement) valueElements.next()));
+    }
+
+    public String getFaultString() {
+        String reason = null;
+        try {
+            //reason = getFaultReasonText(Locale.getDefault());
+            //if (reason == null)
+            reason = (String) getFaultReasonTexts().next();
+        } catch (SOAPException e) {}
+        return reason;
+    }
+
+    public void setFaultString(String faultString) throws SOAPException {
+        addFaultReasonText(faultString, Locale.getDefault());
+    }
+
+    public void setFaultString(
+        String faultString,
+        Locale locale)
+        throws SOAPException {
+        addFaultReasonText(faultString, locale);
+    }
+
+    public void appendFaultSubcode(QName subcode) throws SOAPException {
+        if (subcode == null) {
+            return;
+        }
+        if (subcode.getNamespaceURI() == null ||
+            "".equals(subcode.getNamespaceURI())) {
+
+            log.severe("SAAJ0432.ver1_2.subcode.not.ns.qualified");
+            throw new SOAPExceptionImpl("A Subcode must be namespace-qualified");
+        }
+        if (innermostSubCodeElement == null) {
+            if (faultCodeElement == null)
+                findFaultCodeElement();
+            innermostSubCodeElement = faultCodeElement;
+        }
+        String prefix = null;
+        if (subcode.getPrefix() == null || "".equals(subcode.getPrefix())) {
+            prefix =
+                ((ElementImpl) innermostSubCodeElement).getNamespacePrefix(
+                    subcode.getNamespaceURI());
+        } else
+            prefix = subcode.getPrefix();
+        if (prefix == null || "".equals(prefix)) {
+            prefix = "ns1";
+        }
+        innermostSubCodeElement =
+            innermostSubCodeElement.addChildElement(subcodeName);
+        SOAPElement subcodeValueElement =
+            innermostSubCodeElement.addChildElement(valueName);
+        ((ElementImpl) subcodeValueElement).ensureNamespaceIsDeclared(
+            prefix,
+            subcode.getNamespaceURI());
+        subcodeValueElement.addTextNode(prefix + ":" + subcode.getLocalPart());
+    }
+
+    public void removeAllFaultSubcodes() {
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        Iterator subcodeElements =
+            this.faultCodeElement.getChildElements(subcodeName);
+        if (subcodeElements.hasNext()) {
+            SOAPElement subcode = (SOAPElement) subcodeElements.next();
+            subcode.detachNode();
+        }
+    }
+
+    public Iterator getFaultSubcodes() {
+        if (this.faultCodeElement == null)
+            findFaultCodeElement();
+        final List subcodeList = new ArrayList();
+        SOAPElement currentCodeElement = this.faultCodeElement;
+        Iterator subcodeElements =
+            currentCodeElement.getChildElements(subcodeName);
+        while (subcodeElements.hasNext()) {
+            currentCodeElement = (ElementImpl) subcodeElements.next();
+            Iterator valueElements =
+                currentCodeElement.getChildElements(valueName);
+            SOAPElement valueElement = (SOAPElement) valueElements.next();
+            String code = valueElement.getValue();
+            subcodeList.add(convertCodeToQName(code, valueElement));
+            subcodeElements = currentCodeElement.getChildElements(subcodeName);
+        }
+        //return subcodeList.iterator();
+        return new Iterator() {
+            Iterator subCodeIter = subcodeList.iterator();
+
+            public boolean hasNext() {
+                return subCodeIter.hasNext();
+            }
+
+            public Object next() {
+                return subCodeIter.next();
+            }
+
+            public void remove() {
+                throw new UnsupportedOperationException(
+                    "Method remove() not supported on SubCodes Iterator");
+            }
+        };
+    }
+
+    private static Locale getLocale(SOAPElement reasonText) {
+        return xmlLangToLocale(reasonText.getAttributeValue(getXmlLangName()));
+    }
+
+    /*
+     * Override setEncodingStyle of ElementImpl to restrict adding encodingStyle
+     * attribute to SOAP Fault (SOAP 1.2 spec, part 1, section 5.1.1)
+     */
+    public void setEncodingStyle(String encodingStyle) throws SOAPException {
+        log.severe("SAAJ0407.ver1_2.no.encodingStyle.in.fault");
+        throw new SOAPExceptionImpl("encodingStyle attribute cannot appear on Fault");
+    }
+
+    public SOAPElement addAttribute(Name name, String value)
+        throws SOAPException {
+        if (name.getLocalName().equals("encodingStyle")
+            && name.getURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+    public SOAPElement addAttribute(QName name, String value)
+        throws SOAPException {
+        if (name.getLocalPart().equals("encodingStyle")
+            && name.getNamespaceURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+    public SOAPElement addTextNode(String text) throws SOAPException {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0416.ver1_2.adding.text.not.legal",
+            getElementQName());
+        throw new SOAPExceptionImpl("Adding text to SOAP 1.2 Fault is not legal");
+    }
+
+    public SOAPElement addChildElement(SOAPElement element)
+        throws SOAPException {
+        String localName = element.getLocalName();
+        if ("Detail".equalsIgnoreCase(localName)) {
+            if (hasDetail()) {
+                log.severe("SAAJ0436.ver1_2.detail.exists.error");
+                throw new SOAPExceptionImpl("Cannot add Detail, Detail already exists");
+            }
+            String uri = element.getElementQName().getNamespaceURI();
+            if (!uri.equals(SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE)) {
+                log.severe("SAAJ0437.ver1_2.version.mismatch.error");
+                throw new SOAPExceptionImpl("Cannot add Detail, Incorrect SOAP version specified for Detail element");
+            }
+        }
+        if (element instanceof Detail1_2Impl) {
+            ElementImpl importedElement = (ElementImpl) importElement(element);
+            addNode(importedElement);
+            return convertToSoapElement(importedElement);
+        } else
+            return super.addChildElement(element);
+    }
+
+    protected boolean isStandardFaultElement(String localName) {
+        if (localName.equalsIgnoreCase("code") ||
+            localName.equalsIgnoreCase("reason") ||
+            localName.equalsIgnoreCase("node") ||
+            localName.equalsIgnoreCase("role") ||
+            localName.equalsIgnoreCase("detail")) {
+            return true;
+        }
+        return false;
+    }
+
+    protected QName getDefaultFaultCode() {
+        return SOAPConstants.SOAP_SENDER_FAULT;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/FaultElement1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/FaultElement1_2Impl.java
new file mode 100644
index 0000000..d82058a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/FaultElement1_2Impl.java
@@ -0,0 +1,103 @@
+/*
+ * $Id: FaultElement1_2Impl.java,v 1.13 2006/01/27 12:49:48 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.Name;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.FaultElementImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+
+public class FaultElement1_2Impl extends FaultElementImpl {
+
+    public FaultElement1_2Impl(SOAPDocumentImpl ownerDoc, NameImpl qname) {
+        super(ownerDoc, qname);
+    }
+
+    public FaultElement1_2Impl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    public FaultElement1_2Impl(SOAPDocumentImpl ownerDoc, String localName) {
+        super(ownerDoc, NameImpl.createSOAP12Name(localName));
+    }
+
+    protected boolean isStandardFaultElement() {
+        String localName = elementQName.getLocalPart();
+        if (localName.equalsIgnoreCase("code") ||
+            localName.equalsIgnoreCase("reason") ||
+            localName.equalsIgnoreCase("node") ||
+            localName.equalsIgnoreCase("role")) {
+            return true;
+        }
+        return false;
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        if (!isStandardFaultElement()) {
+            FaultElement1_2Impl copy =
+                new FaultElement1_2Impl((SOAPDocumentImpl) getOwnerDocument(), newName);
+            return replaceElementWithSOAPElement(this,copy);
+        } else {
+            return super.setElementQName(newName);
+        }
+    }
+
+    public void setEncodingStyle(String encodingStyle) throws SOAPException {
+        log.severe("SAAJ0408.ver1_2.no.encodingStyle.in.fault.child");
+        throw new SOAPExceptionImpl("encodingStyle attribute cannot appear on a Fault child element");
+    }
+
+    public SOAPElement addAttribute(Name name, String value)
+        throws SOAPException {
+        if (name.getLocalName().equals("encodingStyle")
+            && name.getURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+    public SOAPElement addAttribute(QName name, String value)
+        throws SOAPException {
+        if (name.getLocalPart().equals("encodingStyle")
+            && name.getNamespaceURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Header1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Header1_2Impl.java
new file mode 100644
index 0000000..7f99063
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Header1_2Impl.java
@@ -0,0 +1,163 @@
+/*
+ * $Id: Header1_2Impl.java,v 1.36 2006/01/27 12:49:48 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.util.List;
+import java.util.Iterator;
+import java.util.logging.Logger;
+import java.util.logging.Level;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocument;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.HeaderElementImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.HeaderImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+import com.sun.xml.internal.messaging.saaj.util.LogDomainConstants;
+
+
+public class Header1_2Impl extends HeaderImpl {
+
+    protected static Logger log =
+        Logger.getLogger(
+            LogDomainConstants.SOAP_VER1_2_DOMAIN,
+            "com.sun.xml.internal.messaging.saaj.soap.ver1_2.LocalStrings");
+
+    public Header1_2Impl(SOAPDocumentImpl ownerDocument, String prefix) {
+        super(ownerDocument, NameImpl.createHeader1_2Name(prefix));
+    }
+
+    protected NameImpl getNotUnderstoodName() {
+        return NameImpl.createNotUnderstood1_2Name(null);
+    }
+
+    protected NameImpl getUpgradeName() {
+        return NameImpl.createUpgrade1_2Name(null);
+    }
+
+    protected NameImpl getSupportedEnvelopeName() {
+        return NameImpl.createSupportedEnvelope1_2Name(null);
+    }
+
+    public SOAPHeaderElement addNotUnderstoodHeaderElement(final QName sourceName)
+        throws SOAPException {
+
+        if (sourceName == null) {
+            log.severe("SAAJ0410.ver1_2.no.null.to.addNotUnderstoodHeader");
+            throw new SOAPException("Cannot pass NULL to addNotUnderstoodHeaderElement");
+        }
+        if ("".equals(sourceName.getNamespaceURI())) {
+            log.severe("SAAJ0417.ver1_2.qname.not.ns.qualified");
+            throw new SOAPException("The qname passed to addNotUnderstoodHeaderElement must be namespace-qualified");
+        }
+        String prefix = sourceName.getPrefix();
+        if ("".equals(prefix)) {
+            prefix = "ns1";
+        }
+        Name notunderstoodName = getNotUnderstoodName();
+        SOAPHeaderElement notunderstoodHeaderElement =
+            (SOAPHeaderElement) addChildElement(notunderstoodName);
+        notunderstoodHeaderElement.addAttribute(
+            NameImpl.createFromUnqualifiedName("qname"),
+            getQualifiedName(
+                new QName(
+                    sourceName.getNamespaceURI(),
+                    sourceName.getLocalPart(),
+                    prefix)));
+        notunderstoodHeaderElement.addNamespaceDeclaration(
+            prefix,
+            sourceName.getNamespaceURI());
+        return notunderstoodHeaderElement;
+    }
+
+    public SOAPElement addTextNode(String text) throws SOAPException {
+        log.log(
+            Level.SEVERE,
+            "SAAJ0416.ver1_2.adding.text.not.legal",
+            getElementQName());
+        throw new SOAPExceptionImpl("Adding text to SOAP 1.2 Header is not legal");
+    }
+
+    protected SOAPHeaderElement createHeaderElement(Name name)
+        throws SOAPException {
+        String uri = name.getURI();
+        if (uri == null || uri.equals("")) {
+            log.severe("SAAJ0413.ver1_2.header.elems.must.be.ns.qualified");
+            throw new SOAPExceptionImpl("SOAP 1.2 header elements must be namespace qualified");
+        }
+        return new HeaderElement1_2Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+
+    protected SOAPHeaderElement createHeaderElement(QName name)
+        throws SOAPException {
+        String uri = name.getNamespaceURI();
+        if (uri == null || uri.equals("")) {
+            log.severe("SAAJ0413.ver1_2.header.elems.must.be.ns.qualified");
+            throw new SOAPExceptionImpl("SOAP 1.2 header elements must be namespace qualified");
+        }
+        return new HeaderElement1_2Impl(
+            ((SOAPDocument) getOwnerDocument()).getDocument(),
+            name);
+    }
+
+    public void setEncodingStyle(String encodingStyle) throws SOAPException {
+        log.severe("SAAJ0409.ver1_2.no.encodingstyle.in.header");
+        throw new SOAPExceptionImpl("encodingStyle attribute cannot appear on Header");
+    }
+
+    public SOAPElement addAttribute(Name name, String value)
+        throws SOAPException {
+        if (name.getLocalName().equals("encodingStyle")
+            && name.getURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+
+    public SOAPElement addAttribute(QName name, String value)
+        throws SOAPException {
+        if (name.getLocalPart().equals("encodingStyle")
+            && name.getNamespaceURI().equals(NameImpl.SOAP12_NAMESPACE)) {
+
+            setEncodingStyle(value);
+        }
+        return super.addAttribute(name, value);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/HeaderElement1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/HeaderElement1_2Impl.java
new file mode 100644
index 0000000..41f97b6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/HeaderElement1_2Impl.java
@@ -0,0 +1,108 @@
+/*
+ * $Id: HeaderElement1_2Impl.java,v 1.29 2006/01/27 12:49:48 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.util.logging.Logger;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.Name;
+import javax.xml.soap.SOAPElement;
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.impl.HeaderElementImpl;
+import com.sun.xml.internal.messaging.saaj.soap.name.NameImpl;
+
+public class HeaderElement1_2Impl extends HeaderElementImpl {
+
+    private static Logger log =
+        Logger.getLogger(HeaderElement1_2Impl.class.getName(),
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_2.LocalStrings");
+
+    public HeaderElement1_2Impl(SOAPDocumentImpl ownerDoc, Name qname) {
+        super(ownerDoc, qname);
+    }
+    public HeaderElement1_2Impl(SOAPDocumentImpl ownerDoc, QName qname) {
+        super(ownerDoc, qname);
+    }
+
+    public SOAPElement setElementQName(QName newName) throws SOAPException {
+        HeaderElementImpl copy =
+            new HeaderElement1_2Impl((SOAPDocumentImpl)getOwnerDocument(), newName);
+        return replaceElementWithSOAPElement(this,copy);
+    }
+
+    protected NameImpl getRoleAttributeName() {
+        return NameImpl.create("role", null, NameImpl.SOAP12_NAMESPACE);
+    }
+
+    // Actor equivalent to Role in SOAP 1.2
+    protected NameImpl getActorAttributeName() {
+        return getRoleAttributeName();
+    }
+
+    protected NameImpl getMustunderstandAttributeName() {
+        return NameImpl.create("mustUnderstand", null, NameImpl.SOAP12_NAMESPACE);
+    }
+
+    // mustUnderstand attribute has literal value "true" or "false"
+    protected String getMustunderstandLiteralValue(boolean mustUnderstand) {
+        return (mustUnderstand == true ? "true" : "false");
+    }
+
+    protected boolean getMustunderstandAttributeValue(String mu) {
+        if (mu.equals("true") || mu.equals("1"))
+            return true;
+        return false;
+    }
+
+   protected NameImpl getRelayAttributeName() {
+        return NameImpl.create("relay", null, NameImpl.SOAP12_NAMESPACE);
+    }
+
+    //relay attribute has literal value "true" or "false"
+    protected String getRelayLiteralValue(boolean relay) {
+        return (relay == true ? "true" : "false");
+    }
+
+    protected boolean getRelayAttributeValue(String relay) {
+        if (relay.equals("true") || relay.equals("1"))
+            return true;
+        return false;
+    }
+
+    protected String getActorOrRole() {
+        return getRole();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/LocalStrings.properties b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/LocalStrings.properties
new file mode 100644
index 0000000..79d1f3b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/LocalStrings.properties
@@ -0,0 +1,31 @@
+# SAAJ ResourceBundle properties file
+# Contains Log messages for ver1_2 pkg
+
+SAAJ0401.ver1_2.no.encodingstyle.in.body=SAAJ0401: encodingStyle attribute cannot appear on Body
+SAAJ0402.ver1_2.only.fault.allowed.in.body=SAAJ0402: No other element except Fault allowed in SOAPBody
+SAAJ0403.ver1_2.no.encodingStyle.in.detail=SAAJ0403: encodingStyle attribute cannot appear on Detail
+SAAJ0404.ver1_2.no.encodingStyle.in.envelope=SAAJ0404: encodingStyle attribute cannot appear on Envelope
+SAAJ0405.ver1_2.body.must.last.in.envelope=SAAJ0405: Body must be last element in SOAPEnvelope
+SAAJ0406.ver1_2.only.header.body.allowed.in.envelope=SAAJ0406: Envelope cannot contain anything other than Header and Body
+SAAJ0407.ver1_2.no.encodingStyle.in.fault=SAAJ0407: encodingStyle attribute cannot appear on Fault
+SAAJ0408.ver1_2.no.encodingStyle.in.fault.child=SAAJ0408: encodingStyle attribute cannot appear on a Fault child element
+SAAJ0409.ver1_2.no.encodingstyle.in.header=SAAJ0401: encodingStyle attribute cannot appear on Header
+SAAJ0410.ver1_2.no.null.to.addNotUnderstoodHeader=SAAJ0410: Cannot pass NULL to addNotUnderstoodHeaderElement
+SAAJ0411.ver1_2.no.null.supportedURIs=SAAJ0411: Argument cannot be null; supportedURIs cannot be null
+SAAJ0412.ver1_2.no.empty.list.of.supportedURIs=SAAJ0412: List of supported URIs cannot be empty
+SAAJ0413.ver1_2.header.elems.must.be.ns.qualified=SAAJ0413: SOAP 1.2 header elements must be namespace qualified
+#SAAJ0414.ver1_2.actor.unsupported.in.soap1.2=SAAJ0414: Actor not supported by SOAP 1.2
+SAAJ0415.ver1_2.msg.invalid.soap1.2=SAAJ0415: InputStream does not represent a valid SOAP 1.2 Message
+SAAJ0416.ver1_2.adding.text.not.legal=SAAJ0416: Adding text to {0} is not legal
+SAAJ0417.ver1_2.qname.not.ns.qualified=SAAJ0417: The qname passed to addNotUnderstoodHeaderElement must be namespace-qualified
+
+#SOAPFault related errors
+SAAJ0430.ver1_2.locale.required=SAAJ0430: locale is required and must not be null
+SAAJ0431.ver1_2.xml.lang.missing=SAAJ0431: "xml:lang" attribute is not present on the Text element
+SAAJ0432.ver1_2.subcode.not.ns.qualified=SAAJ0432: A Subcode must be namespace-qualified
+#SAAJ0433.ver1_2.could.not.locate.prefix.for.uri=SAAJ0433: Unable to locate prefix for namespace value {0}
+SAAJ0434.ver1_2.text.element.not.present=SAAJ0434: env:Text must be present inside env:Reason
+SAAJ0435.ver1_2.code.not.standard=SAAJ0435: {0} is not a standard Code value
+SAAJ0436.ver1_2.detail.exists.error=SAAJ0436: Cannot add Detail, Detail already exists
+SAAJ0437.ver1_2.version.mismatch.error=SAAJ0437: Incorrect SOAP version for Detail element, expected SOAP 1.2
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Message1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Message1_2Impl.java
new file mode 100644
index 0000000..fbe3527
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/Message1_2Impl.java
@@ -0,0 +1,90 @@
+/*
+ * $Id: Message1_2Impl.java,v 1.18 2006/01/27 12:49:48 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ContentType;
+import com.sun.xml.internal.messaging.saaj.soap.MessageImpl;
+
+public class Message1_2Impl extends MessageImpl implements SOAPConstants{
+
+    public Message1_2Impl() {
+        super();
+    }
+
+    public Message1_2Impl(SOAPMessage msg) {
+        super(msg);
+    }
+
+    public Message1_2Impl(boolean isFastInfoset, boolean acceptFastInfoset) {
+        super(isFastInfoset, acceptFastInfoset);
+    }
+
+    // unused. can we delete this? - Kohsuke
+    public Message1_2Impl(MimeHeaders headers, InputStream in)
+        throws IOException, SOAPExceptionImpl {
+        super(headers, in);
+    }
+
+    public Message1_2Impl(MimeHeaders headers, ContentType ct, int stat, InputStream in)
+        throws SOAPExceptionImpl {
+        super(headers,ct,stat,in);
+    }
+
+    public SOAPPart getSOAPPart()  {
+        if (soapPart == null)
+            soapPart = new SOAPPart1_2Impl(this);
+
+        return soapPart;
+    }
+
+    protected boolean isCorrectSoapVersion(int contentTypeId) {
+        return (contentTypeId & SOAP1_2_FLAG) != 0;
+    }
+
+    protected String getExpectedContentType() {
+        return isFastInfoset ? "application/soap+fastinfoset" : "application/soap+xml";
+    }
+
+   protected String getExpectedAcceptHeader() {
+       String accept = "application/soap+xml, text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2";
+       return acceptFastInfoset ? ("application/soap+fastinfoset, " + accept) : accept;
+   }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPFactory1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPFactory1_2Impl.java
new file mode 100644
index 0000000..0fa8a53
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPFactory1_2Impl.java
@@ -0,0 +1,69 @@
+/*
+ * $Id: SOAPFactory1_2Impl.java,v 1.4 2006/01/27 12:49:48 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import javax.xml.soap.Detail;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPFault;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.messaging.saaj.soap.SOAPDocumentImpl;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPFactoryImpl;
+
+public class SOAPFactory1_2Impl extends SOAPFactoryImpl {
+    protected SOAPDocumentImpl createDocument() {
+        return (new SOAPPart1_2Impl()).getDocument();
+    }
+
+    public Detail createDetail() throws SOAPException {
+        return new Detail1_2Impl(createDocument());
+    }
+
+    public SOAPFault createFault(String reasonText, QName faultCode)
+        throws SOAPException {
+        Fault1_2Impl fault = new Fault1_2Impl(createDocument(), null);
+        fault.setFaultString(reasonText);
+        fault.setFaultCode(faultCode);
+        return fault;
+    }
+
+    public SOAPFault createFault() throws SOAPException {
+        Fault1_2Impl fault = new Fault1_2Impl(createDocument(), null);
+        fault.setFaultCode(fault.getDefaultFaultCode());
+        fault.setFaultString("Fault string, and possibly fault code, not set");
+        return fault;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPMessageFactory1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPMessageFactory1_2Impl.java
new file mode 100644
index 0000000..0bd20e1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPMessageFactory1_2Impl.java
@@ -0,0 +1,67 @@
+/*
+ * $Id: SOAPMessageFactory1_2Impl.java,v 1.7 2006/01/27 12:49:48 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author JAX-RPC RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+import javax.xml.soap.*;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import com.sun.xml.internal.messaging.saaj.soap.MessageFactoryImpl;
+import com.sun.xml.internal.messaging.saaj.soap.MessageImpl;
+
+public class SOAPMessageFactory1_2Impl extends MessageFactoryImpl {
+
+    public SOAPMessage createMessage() throws SOAPException {
+        return new Message1_2Impl();
+    }
+
+    public SOAPMessage createMessage(boolean isFastInfoset,
+        boolean acceptFastInfoset) throws SOAPException
+    {
+        return new Message1_2Impl(isFastInfoset, acceptFastInfoset);
+    }
+
+    public SOAPMessage createMessage(MimeHeaders headers, InputStream in)
+        throws IOException, SOAPExceptionImpl {
+        if ((headers == null) || (getContentType(headers) == null)) {
+            headers = new MimeHeaders();
+            headers.setHeader("Content-Type", SOAPConstants.SOAP_1_2_CONTENT_TYPE);
+        }
+        MessageImpl msg = new Message1_2Impl(headers, in);
+        msg.setLazyAttachments(lazyAttachments);
+        return msg;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPPart1_2Impl.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPPart1_2Impl.java
new file mode 100644
index 0000000..91ceb39
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/soap/ver1_2/SOAPPart1_2Impl.java
@@ -0,0 +1,92 @@
+/*
+ * $Id: SOAPPart1_2Impl.java,v 1.1.1.1 2006/01/27 13:10:57 kumarjayanti Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.soap.ver1_2;
+
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import javax.xml.soap.SOAPConstants;
+import javax.xml.soap.SOAPException;
+import javax.xml.transform.Source;
+
+import com.sun.xml.internal.messaging.saaj.soap.*;
+import com.sun.xml.internal.messaging.saaj.soap.impl.EnvelopeImpl;
+import com.sun.xml.internal.messaging.saaj.util.XMLDeclarationParser;
+
+public class SOAPPart1_2Impl extends SOAPPartImpl implements SOAPConstants{
+
+    protected static Logger log =
+        Logger.getLogger(SOAPPart1_2Impl.class.getName(),
+                         "com.sun.xml.internal.messaging.saaj.soap.ver1_2.LocalStrings");
+
+    public SOAPPart1_2Impl() {
+        super();
+    }
+
+    public SOAPPart1_2Impl(MessageImpl message) {
+        super(message);
+    }
+
+    protected String getContentType() {
+        return "application/soap+xml";
+    }
+
+    protected Envelope createEmptyEnvelope(String prefix) throws SOAPException {
+        return new Envelope1_2Impl(getDocument(), prefix, true, true);
+    }
+
+    protected Envelope createEnvelopeFromSource() throws SOAPException {
+        XMLDeclarationParser parser = lookForXmlDecl();
+        Source tmp = source;
+        source = null;
+        EnvelopeImpl envelope = (EnvelopeImpl)EnvelopeFactory.createEnvelope(tmp, this);
+        if (!envelope.getNamespaceURI().equals(SOAPConstants.URI_NS_SOAP_1_2_ENVELOPE)) {
+            log.severe("SAAJ0415.ver1_2.msg.invalid.soap1.2");
+            throw new SOAPException("InputStream does not represent a valid SOAP 1.2 Message");
+        }
+
+        if (!omitXmlDecl) {
+            envelope.setOmitXmlDecl("no");
+            envelope.setXmlDecl(parser.getXmlDeclaration());
+            envelope.setCharsetEncoding(parser.getEncoding());
+        }
+        return envelope;
+
+    }
+
+    protected SOAPPartImpl duplicateType() {
+        return new SOAPPart1_2Impl();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/Base64.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/Base64.java
new file mode 100644
index 0000000..e8d3b0c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/Base64.java
@@ -0,0 +1,276 @@
+/*
+ * $Id: Base64.java,v 1.4 2006/01/27 12:49:50 vj135062 Exp $
+ * $Revision: 1.4 $
+ * $Date: 2006/01/27 12:49:50 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+
+// Cut & paste from tomcat
+
+/**
+ * This class provides encode/decode for RFC 2045 Base64 as
+ * defined by RFC 2045, N. Freed and N. Borenstein.
+ * RFC 2045: Multipurpose Internet Mail Extensions (MIME)
+ * Part One: Format of Internet Message Bodies. Reference
+ * 1996 Available at: http://www.ietf.org/rfc/rfc2045.txt
+ * This class is used by XML Schema binary format validation
+ *
+ * @author Jeffrey Rodriguez
+ */
+public final class Base64 {
+
+
+    static private final int  BASELENGTH         = 255;
+    static private final int  LOOKUPLENGTH       = 63;
+    static private final int  TWENTYFOURBITGROUP = 24;
+    static private final int  EIGHTBIT           = 8;
+    static private final int  SIXTEENBIT         = 16;
+    static private final int  SIXBIT             = 6;
+    static private final int  FOURBYTE           = 4;
+
+
+    static private final byte PAD               = ( byte ) '=';
+    static private byte [] base64Alphabet       = new byte[BASELENGTH];
+    static private byte [] lookUpBase64Alphabet = new byte[LOOKUPLENGTH];
+
+    static {
+
+        for (int i = 0; i<BASELENGTH; i++ ) {
+            base64Alphabet[i] = -1;
+        }
+        for ( int i = 'Z'; i >= 'A'; i-- ) {
+            base64Alphabet[i] = (byte) (i-'A');
+        }
+        for ( int i = 'z'; i>= 'a'; i--) {
+            base64Alphabet[i] = (byte) ( i-'a' + 26);
+        }
+
+        for ( int i = '9'; i >= '0'; i--) {
+            base64Alphabet[i] = (byte) (i-'0' + 52);
+        }
+
+        base64Alphabet['+']  = 62;
+        base64Alphabet['/']  = 63;
+
+       for (int i = 0; i<=25; i++ )
+            lookUpBase64Alphabet[i] = (byte) ('A'+i );
+
+        for (int i = 26,  j = 0; i<=51; i++, j++ )
+            lookUpBase64Alphabet[i] = (byte) ('a'+ j );
+
+        for (int i = 52,  j = 0; i<=61; i++, j++ )
+            lookUpBase64Alphabet[i] = (byte) ('0' + j );
+
+    }
+
+
+    static boolean isBase64( byte octect ) {
+        //shall we ignore white space? JEFF??
+        return(octect == PAD || base64Alphabet[octect] != -1 );
+    }
+
+
+    static boolean isArrayByteBase64( byte[] arrayOctect ) {
+        int length = arrayOctect.length;
+        if ( length == 0 )
+            return false;
+        for ( int i=0; i < length; i++ ) {
+            if ( Base64.isBase64( arrayOctect[i] ) == false)
+                return false;
+        }
+        return true;
+    }
+
+    /**
+     * Encodes hex octects into Base64
+     *
+     * @param binaryData Array containing binaryData
+     * @return Encoded Base64 array
+     */
+    public static byte[] encode( byte[] binaryData ) {
+        int      lengthDataBits    = binaryData.length*EIGHTBIT;
+        int      fewerThan24bits   = lengthDataBits%TWENTYFOURBITGROUP;
+        int      numberTriplets    = lengthDataBits/TWENTYFOURBITGROUP;
+        byte     encodedData[]     = null;
+
+
+        if ( fewerThan24bits != 0 ) //data not divisible by 24 bit
+            encodedData = new byte[ (numberTriplets + 1 )*4  ];
+        else // 16 or 8 bit
+            encodedData = new byte[ numberTriplets*4 ];
+
+        byte k=0, l=0, b1=0,b2=0,b3=0;
+
+        int encodedIndex = 0;
+        int dataIndex   = 0;
+        int i           = 0;
+        for ( i = 0; i<numberTriplets; i++ ) {
+
+            dataIndex = i*3;
+            b1 = binaryData[dataIndex];
+            b2 = binaryData[dataIndex + 1];
+            b3 = binaryData[dataIndex + 2];
+
+            l  = (byte)(b2 & 0x0f);
+            k  = (byte)(b1 & 0x03);
+
+            encodedIndex = i*4;
+            encodedData[encodedIndex]   = lookUpBase64Alphabet[ b1 >>2 ];
+            encodedData[encodedIndex+1] = lookUpBase64Alphabet[(b2 >>4 ) |
+( k<<4 )];
+            encodedData[encodedIndex+2] = lookUpBase64Alphabet[ (l <<2 ) |
+( b3>>6)];
+            encodedData[encodedIndex+3] = lookUpBase64Alphabet[ b3 & 0x3f ];
+        }
+
+        // form integral number of 6-bit groups
+        dataIndex    = i*3;
+        encodedIndex = i*4;
+        if (fewerThan24bits == EIGHTBIT ) {
+            b1 = binaryData[dataIndex];
+            k = (byte) ( b1 &0x03 );
+            encodedData[encodedIndex]     = lookUpBase64Alphabet[ b1 >>2 ];
+            encodedData[encodedIndex + 1] = lookUpBase64Alphabet[ k<<4 ];
+            encodedData[encodedIndex + 2] = PAD;
+            encodedData[encodedIndex + 3] = PAD;
+        } else if ( fewerThan24bits == SIXTEENBIT ) {
+
+            b1 = binaryData[dataIndex];
+            b2 = binaryData[dataIndex +1 ];
+            l = ( byte ) ( b2 &0x0f );
+            k = ( byte ) ( b1 &0x03 );
+            encodedData[encodedIndex]     = lookUpBase64Alphabet[ b1 >>2 ];
+            encodedData[encodedIndex + 1] = lookUpBase64Alphabet[ (b2 >>4 )
+| ( k<<4 )];
+            encodedData[encodedIndex + 2] = lookUpBase64Alphabet[ l<<2 ];
+            encodedData[encodedIndex + 3] = PAD;
+        }
+        return encodedData;
+    }
+
+
+    /**
+     * Decodes Base64 data into octects
+     *
+     * @param binaryData Byte array containing Base64 data
+     * @return Array containind decoded data.
+     */
+    public byte[] decode( byte[] base64Data ) {
+        int      numberQuadruple    = base64Data.length/FOURBYTE;
+        byte     decodedData[]      = null;
+        byte     b1=0,b2=0,b3=0, b4=0, marker0=0, marker1=0;
+
+        // Throw away anything not in base64Data
+        // Adjust size
+
+        int encodedIndex = 0;
+        int dataIndex    = 0;
+        decodedData      = new byte[ numberQuadruple*3 + 1 ];
+
+        for (int i = 0; i<numberQuadruple; i++ ) {
+            dataIndex = i*4;
+            marker0   = base64Data[dataIndex +2];
+            marker1   = base64Data[dataIndex +3];
+
+            b1 = base64Alphabet[base64Data[dataIndex]];
+            b2 = base64Alphabet[base64Data[dataIndex +1]];
+
+            if ( marker0 != PAD && marker1 != PAD ) {     //No PAD e.g 3cQl
+                b3 = base64Alphabet[ marker0 ];
+                b4 = base64Alphabet[ marker1 ];
+
+                decodedData[encodedIndex]   = (byte)(  b1 <<2 | b2>>4 ) ;
+                decodedData[encodedIndex+1] = (byte)(((b2 & 0xf)<<4 ) |(
+(b3>>2) & 0xf) );
+                decodedData[encodedIndex+2] = (byte)( b3<<6 | b4 );
+            } else if ( marker0 == PAD ) {               //Two PAD e.g. 3c[Pad][Pad]
+                decodedData[encodedIndex]   = (byte)(  b1 <<2 | b2>>4 ) ;
+                decodedData[encodedIndex+1] = (byte)((b2 & 0xf)<<4 );
+                decodedData[encodedIndex+2] = (byte) 0;
+            } else if ( marker1 == PAD ) {              //One PAD e.g. 3cQ[Pad]
+                b3 = base64Alphabet[ marker0 ];
+
+                decodedData[encodedIndex]   = (byte)(  b1 <<2 | b2>>4 );
+                decodedData[encodedIndex+1] = (byte)(((b2 & 0xf)<<4 ) |(
+(b3>>2) & 0xf) );
+                decodedData[encodedIndex+2] = (byte)( b3<<6);
+            }
+            encodedIndex += 3;
+        }
+        return decodedData;
+
+    }
+
+    static final int base64[]= {
+        64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 62, 64, 64, 64, 63,
+            52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 64, 64, 64, 64, 64, 64,
+            64,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,
+            15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 64, 64, 64, 64, 64,
+            64, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
+            41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
+            64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64
+    };
+
+    public static String base64Decode( String orig ) {
+        char chars[]=orig.toCharArray();
+        StringBuffer sb=new StringBuffer();
+        int i=0;
+
+        int shift = 0;   // # of excess bits stored in accum
+        int acc = 0;
+
+        for (i=0; i<chars.length; i++) {
+            int v = base64[ chars[i] & 0xFF ];
+
+            if ( v >= 64 ) {
+                if( chars[i] != '=' )
+                    System.out.println("Wrong char in base64: " + chars[i]);
+            } else {
+                acc= ( acc << 6 ) | v;
+                shift += 6;
+                if ( shift >= 8 ) {
+                    shift -= 8;
+                    sb.append( (char) ((acc >> shift) & 0xff));
+                }
+            }
+        }
+        return sb.toString();
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ByteInputStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ByteInputStream.java
new file mode 100644
index 0000000..8b06d45
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ByteInputStream.java
@@ -0,0 +1,69 @@
+/*
+ * $Id: ByteInputStream.java,v 1.6 2006/01/27 12:49:51 vj135062 Exp $ $Revision:
+ * 1.3 $ $Date: 2006/01/27 12:49:51 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+
+// This class just gives access to the underlying buffer without copying.
+
+public class ByteInputStream extends ByteArrayInputStream {
+    private static final byte[] EMPTY_ARRAY = new byte[0];
+
+    public ByteInputStream() {
+        this(EMPTY_ARRAY, 0);
+    }
+
+    public ByteInputStream(byte buf[], int length) {
+        super(buf, 0, length);
+    }
+
+    public ByteInputStream(byte buf[], int offset, int length) {
+        super(buf, offset, length);
+    }
+
+    public byte[] getBytes() {
+        return buf;
+    }
+
+    public int getCount() {
+        return count;
+    }
+
+    public void close() throws IOException {
+        reset();
+    }
+
+    public void setBuf(byte[] buf) {
+        this.buf = buf;
+        this.pos = 0;
+        this.count = buf.length;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ByteOutputStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ByteOutputStream.java
new file mode 100644
index 0000000..569a05b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ByteOutputStream.java
@@ -0,0 +1,184 @@
+/*
+ * $Id: ByteOutputStream.java,v 1.7 2006/01/27 12:49:51 vj135062 Exp $
+ * $Revision: 1.7 $ $Date: 2006/01/27 12:49:51 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.io.BufferedOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.InputStream;
+import java.io.ByteArrayInputStream;
+
+/**
+ * Customized {@link BufferedOutputStream}.
+ *
+ * <p>
+ * Compared to {@link BufferedOutputStream},
+ * this class:
+ *
+ * <ol>
+ * <li>doesn't do synchronization
+ * <li>allows access to the raw buffer
+ * <li>almost no parameter check
+ */
+public final class ByteOutputStream extends OutputStream {
+    /**
+     * The buffer where data is stored.
+     */
+    protected byte[] buf;
+
+    /**
+     * The number of valid bytes in the buffer.
+     */
+    protected int count = 0;
+
+    public ByteOutputStream() {
+        this(1024);
+    }
+
+    public ByteOutputStream(int size) {
+        buf = new byte[size];
+    }
+
+    /**
+     * Copies all the bytes from this input into this buffer.
+     */
+    public void write(InputStream in) throws IOException {
+        if (in instanceof ByteArrayInputStream) {
+            int size = in.available();
+            ensureCapacity(size);
+            count += in.read(buf,count,size);
+            return;
+        }
+        while(true) {
+            int cap = buf.length-count;
+            int sz = in.read(buf,count,cap);
+            if(sz<0)    return;     // hit EOS
+
+            count += sz;
+            if(cap==sz)
+                // the buffer filled up. double the buffer
+                ensureCapacity(count);
+        }
+    }
+
+    public void write(int b) {
+        ensureCapacity(1);
+        buf[count] = (byte) b;
+        count++;
+    }
+
+    /**
+     * Ensure that the buffer has at least this much space.
+     */
+    private void ensureCapacity(int space) {
+        int newcount = space + count;
+        if (newcount > buf.length) {
+            byte[] newbuf = new byte[Math.max(buf.length << 1, newcount)];
+            System.arraycopy(buf, 0, newbuf, 0, count);
+            buf = newbuf;
+        }
+    }
+
+    public void write(byte[] b, int off, int len) {
+        ensureCapacity(len);
+        System.arraycopy(b, off, buf, count, len);
+        count += len;
+    }
+
+    public void write(byte[] b) {
+        write(b, 0, b.length);
+    }
+
+    /**
+     * Writes a string as ASCII string.
+     */
+    public void writeAsAscii(String s) {
+        int len = s.length();
+
+        ensureCapacity(len);
+
+        int ptr = count;
+        for( int i=0; i<len; i++ )
+            buf[ptr++] = (byte)s.charAt(i);
+        count = ptr;
+    }
+
+    public void writeTo(OutputStream out) throws IOException {
+        out.write(buf, 0, count);
+    }
+
+    public void reset() {
+        count = 0;
+    }
+
+    /**
+     * Evil buffer reallocation method.
+     * Don't use it unless you absolutely have to.
+     *
+     * @deprecated
+     *      because this is evil!
+     */
+    public byte toByteArray()[] {
+        byte[] newbuf = new byte[count];
+        System.arraycopy(buf, 0, newbuf, 0, count);
+        return newbuf;
+    }
+
+    public int size() {
+        return count;
+    }
+
+    public ByteInputStream newInputStream() {
+        return new ByteInputStream(buf,count);
+    }
+
+    /**
+     * Converts the buffer's contents into a string, translating bytes into
+     * characters according to the platform's default character encoding.
+     *
+     * @return String translated from the buffer's contents.
+     * @since JDK1.1
+     */
+    public String toString() {
+        return new String(buf, 0, count);
+    }
+
+    public void close() {
+    }
+
+    public byte[] getBytes() {
+        return buf;
+    }
+
+
+    public int getCount() {
+        return count;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/CharReader.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/CharReader.java
new file mode 100644
index 0000000..c1af31f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/CharReader.java
@@ -0,0 +1,53 @@
+/*
+ * $Id: CharReader.java,v 1.6 2006/01/27 12:49:51 vj135062 Exp $
+ * $Revision: 1.6 $
+ * $Date: 2006/01/27 12:49:51 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.io.CharArrayReader;
+
+// This class just gives access to the underlying buffer without copying.
+
+public class CharReader extends CharArrayReader {
+    public CharReader(char buf[], int length) {
+        super(buf, 0, length);
+    }
+
+    public CharReader(char buf[], int offset, int length) {
+        super(buf, offset, length);
+    }
+
+    public char[] getChars() {
+        return buf;
+    }
+
+    public int getCount() {
+        return count;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/CharWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/CharWriter.java
new file mode 100644
index 0000000..9b3be81
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/CharWriter.java
@@ -0,0 +1,53 @@
+/*
+ * $Id: CharWriter.java,v 1.6 2006/01/27 12:49:51 vj135062 Exp $
+ * $Revision: 1.6 $
+ * $Date: 2006/01/27 12:49:51 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.io.CharArrayWriter;
+
+// This class just gives access to the underlying buffer without copying.
+
+public class CharWriter extends CharArrayWriter {
+    public CharWriter () {
+        super();
+    }
+
+    public CharWriter(int size) {
+        super(size);
+    }
+
+    public char[] getChars() {
+        return buf;
+    }
+
+    public int getCount() {
+        return count;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/FastInfosetReflection.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/FastInfosetReflection.java
new file mode 100644
index 0000000..526c0ce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/FastInfosetReflection.java
@@ -0,0 +1,248 @@
+/*
+ * $Id: FastInfosetReflection.java,v 1.2 2006/06/06 18:46:01 sandoz Exp $
+ * $Revision: 1.2 $
+ * $Date: 2006/06/06 18:46:01 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.lang.reflect.*;
+import javax.xml.transform.Source;
+import javax.xml.transform.Result;
+import java.io.InputStream;
+import java.io.OutputStream;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Node;
+
+/**
+ *
+ * @author Santiago.PericasGeertsen@sun.com
+ * @author Paul.Sandoz@sun.com
+ */
+public class FastInfosetReflection {
+
+    /**
+     * FI DOMDocumentParser constructor using reflection.
+     */
+    static Constructor fiDOMDocumentParser_new;
+
+    /**
+     * FI <code>DOMDocumentParser.parse()</code> method via reflection.
+     */
+    static Method fiDOMDocumentParser_parse;
+
+    /**
+     * FI DOMDocumentSerializer constructor using reflection.
+     */
+    static Constructor fiDOMDocumentSerializer_new;
+
+    /**
+     * FI <code>FastInfosetSource.serialize(Document)</code> method via reflection.
+     */
+    static Method fiDOMDocumentSerializer_serialize;
+
+    /**
+     * FI <code>FastInfosetSource.setOutputStream(OutputStream)</code> method via reflection.
+     */
+    static Method fiDOMDocumentSerializer_setOutputStream;
+
+    /**
+     * FI FastInfosetSource constructor using reflection.
+     */
+    static Class fiFastInfosetSource_class;
+
+    /**
+     * FI FastInfosetSource constructor using reflection.
+     */
+    static Constructor fiFastInfosetSource_new;
+
+    /**
+     * FI <code>FastInfosetSource.getInputStream()</code> method via reflection.
+     */
+    static Method fiFastInfosetSource_getInputStream;
+
+    /**
+     * FI <code>FastInfosetSource.setInputSTream()</code> method via reflection.
+     */
+    static Method fiFastInfosetSource_setInputStream;
+
+    /**
+     * FI FastInfosetResult constructor using reflection.
+     */
+    static Constructor fiFastInfosetResult_new;
+
+    /**
+     * FI <code>FastInfosetResult.getOutputSTream()</code> method via reflection.
+     */
+    static Method fiFastInfosetResult_getOutputStream;
+
+    static {
+        try {
+            Class clazz = null;
+            clazz =
+                Class.forName("com.sun.xml.internal.fastinfoset.dom.DOMDocumentParser");
+            fiDOMDocumentParser_new = clazz.getConstructor(null);
+            fiDOMDocumentParser_parse = clazz.getMethod("parse",
+                new Class[] { org.w3c.dom.Document.class, java.io.InputStream.class });
+
+            clazz = Class.forName("com.sun.xml.internal.fastinfoset.dom.DOMDocumentSerializer");
+            fiDOMDocumentSerializer_new = clazz.getConstructor(null);
+            fiDOMDocumentSerializer_serialize = clazz.getMethod("serialize",
+                new Class[] { org.w3c.dom.Node.class });
+            fiDOMDocumentSerializer_setOutputStream = clazz.getMethod("setOutputStream",
+                new Class[] { java.io.OutputStream.class });
+
+            fiFastInfosetSource_class = clazz = Class.forName("com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSource");
+            fiFastInfosetSource_new = clazz.getConstructor(
+                new Class[] { java.io.InputStream.class });
+            fiFastInfosetSource_getInputStream = clazz.getMethod("getInputStream", null);
+            fiFastInfosetSource_setInputStream = clazz.getMethod("setInputStream",
+                new Class[] { java.io.InputStream.class });
+
+            clazz = Class.forName("com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetResult");
+            fiFastInfosetResult_new = clazz.getConstructor(
+                new Class[] { java.io.OutputStream.class });
+            fiFastInfosetResult_getOutputStream = clazz.getMethod("getOutputStream", null);
+        }
+        catch (Exception e) {
+            // falls through
+        }
+    }
+
+    // -- DOMDocumentParser ----------------------------------------------
+
+    public static Object DOMDocumentParser_new() throws Exception {
+        if (fiDOMDocumentParser_new == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return fiDOMDocumentParser_new.newInstance(null);
+    }
+
+    public static void DOMDocumentParser_parse(Object parser,
+        Document d, InputStream s) throws Exception
+    {
+        if (fiDOMDocumentParser_parse == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        fiDOMDocumentParser_parse.invoke(parser, new Object[] { d, s });
+    }
+
+    // -- DOMDocumentSerializer-------------------------------------------
+
+    public static Object DOMDocumentSerializer_new() throws Exception {
+        if (fiDOMDocumentSerializer_new == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return fiDOMDocumentSerializer_new.newInstance(null);
+    }
+
+    public static void DOMDocumentSerializer_serialize(Object serializer, Node node)
+        throws Exception
+    {
+        if (fiDOMDocumentSerializer_serialize == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        fiDOMDocumentSerializer_serialize.invoke(serializer, new Object[] { node });
+    }
+
+    public static void DOMDocumentSerializer_setOutputStream(Object serializer,
+        OutputStream os) throws Exception
+    {
+        if (fiDOMDocumentSerializer_setOutputStream == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        fiDOMDocumentSerializer_setOutputStream.invoke(serializer, new Object[] { os });
+    }
+
+    // -- FastInfosetSource ----------------------------------------------
+
+    public static boolean isFastInfosetSource(Source source) {
+        return source.getClass().getName().equals(
+            "com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSource");
+    }
+
+    public static Class getFastInfosetSource_class() {
+        if (fiFastInfosetSource_class == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+
+        return fiFastInfosetSource_class;
+    }
+    public static Source FastInfosetSource_new(InputStream is)
+        throws Exception
+    {
+        if (fiFastInfosetSource_new == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return (Source) fiFastInfosetSource_new.newInstance(new Object[] { is });
+    }
+
+    public static InputStream FastInfosetSource_getInputStream(Source source)
+        throws Exception
+    {
+        if (fiFastInfosetSource_getInputStream == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return (InputStream) fiFastInfosetSource_getInputStream.invoke(source, null);
+    }
+
+    public static void FastInfosetSource_setInputStream(Source source,
+        InputStream is) throws Exception
+    {
+        if (fiFastInfosetSource_setInputStream == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        fiFastInfosetSource_setInputStream.invoke(source, new Object[] { is });
+    }
+
+    // -- FastInfosetResult ----------------------------------------------
+
+    public static boolean isFastInfosetResult(Result result) {
+        return result.getClass().getName().equals(
+            "com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetResult");
+    }
+
+    public static Result FastInfosetResult_new(OutputStream os)
+        throws Exception
+    {
+        if (fiFastInfosetResult_new == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return (Result) fiFastInfosetResult_new.newInstance(new Object[] { os });
+    }
+
+    public static OutputStream FastInfosetResult_getOutputStream(Result result)
+        throws Exception
+    {
+        if (fiFastInfosetResult_getOutputStream == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return (OutputStream) fiFastInfosetResult_getOutputStream.invoke(result, null);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/FinalArrayList.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/FinalArrayList.java
new file mode 100644
index 0000000..22768e6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/FinalArrayList.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.util.ArrayList;
+import java.util.Collection;
+
+/**
+ * {@link ArrayList} with a final marker to help JIT.
+ * @author Kohsuke Kawaguchi
+ */
+public final class FinalArrayList extends ArrayList {
+    public FinalArrayList(int initialCapacity) {
+        super(initialCapacity);
+    }
+
+    public FinalArrayList() {
+    }
+
+    public FinalArrayList(Collection collection) {
+        super(collection);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/JAXMStreamSource.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/JAXMStreamSource.java
new file mode 100644
index 0000000..81dc485
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/JAXMStreamSource.java
@@ -0,0 +1,81 @@
+/*
+ * $Id: JAXMStreamSource.java,v 1.9 2006/01/27 12:49:51 vj135062 Exp $
+ * $Revision: 1.9 $
+ * $Date: 2006/01/27 12:49:51 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.io.*;
+
+import javax.xml.transform.stream.StreamSource;
+
+
+/**
+ *
+ * @author Anil Vijendran
+ */
+public class JAXMStreamSource extends StreamSource {
+    ByteInputStream in;
+    Reader reader;
+
+    public JAXMStreamSource(InputStream is) throws IOException {
+                if (is instanceof ByteInputStream) {
+                        this.in = (ByteInputStream)is;
+                } else {
+                        ByteOutputStream bout = new ByteOutputStream();
+                        bout.write(is);
+                        this.in = bout.newInputStream();
+                }
+    }
+
+    public JAXMStreamSource(Reader rdr) throws IOException {
+        CharWriter cout = new CharWriter();
+        char[] temp = new char[1024];
+        int len;
+
+        while (-1 != (len = rdr.read(temp)))
+            cout.write(temp, 0, len);
+
+        this.reader = new CharReader(cout.getChars(), cout.getCount());
+    }
+
+    public InputStream getInputStream() {
+        return in;
+    }
+
+    public Reader getReader() {
+        return reader;
+    }
+
+    public void reset() throws IOException {
+            if (in != null)
+                in.reset();
+            if (reader != null)
+                reader.reset();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/JaxmURI.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/JaxmURI.java
new file mode 100644
index 0000000..e805e7e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/JaxmURI.java
@@ -0,0 +1,1379 @@
+/*
+ * $Id: JaxmURI.java,v 1.4 2006/01/27 12:49:51 vj135062 Exp $
+ * $Revision: 1.4 $
+ * $Date: 2006/01/27 12:49:51 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+// Imported from: org.apache.xerces.util
+// Needed to work around differences in JDK1.2 and 1.3 and deal with userInfo
+
+import java.io.IOException;
+import java.io.Serializable;
+
+
+/**********************************************************************
+* A class to represent a Uniform Resource Identifier (URI). This class
+* is designed to handle the parsing of URIs and provide access to
+* the various components (scheme, host, port, userinfo, path, query
+* string and fragment) that may constitute a URI.
+* <p>
+* Parsing of a URI specification is done according to the URI
+* syntax described in RFC 2396
+* <http://www.ietf.org/rfc/rfc2396.txt?number=2396>. Every URI consists
+* of a scheme, followed by a colon (':'), followed by a scheme-specific
+* part. For URIs that follow the "generic URI" syntax, the scheme-
+* specific part begins with two slashes ("//") and may be followed
+* by an authority segment (comprised of user information, host, and
+* port), path segment, query segment and fragment. Note that RFC 2396
+* no longer specifies the use of the parameters segment and excludes
+* the "user:password" syntax as part of the authority segment. If
+* "user:password" appears in a URI, the entire user/password string
+* is stored as userinfo.
+* <p>
+* For URIs that do not follow the "generic URI" syntax (e.g. mailto),
+* the entire scheme-specific part is treated as the "path" portion
+* of the URI.
+* <p>
+* Note that, unlike the java.net.URL class, this class does not provide
+* any built-in network access functionality nor does it provide any
+* scheme-specific functionality (for example, it does not know a
+* default port for a specific scheme). Rather, it only knows the
+* grammar and basic set of operations that can be applied to a URI.
+*
+*
+**********************************************************************/
+ public class JaxmURI implements Serializable {
+
+  /*******************************************************************
+  * MalformedURIExceptions are thrown in the process of building a URI
+  * or setting fields on a URI when an operation would result in an
+  * invalid URI specification.
+  *
+  ********************************************************************/
+  public static class MalformedURIException extends IOException {
+
+   /******************************************************************
+    * Constructs a <code>MalformedURIException</code> with no specified
+    * detail message.
+    ******************************************************************/
+    public MalformedURIException() {
+      super();
+    }
+
+    /*****************************************************************
+    * Constructs a <code>MalformedURIException</code> with the
+    * specified detail message.
+    *
+    * @param p_msg the detail message.
+    ******************************************************************/
+    public MalformedURIException(String p_msg) {
+      super(p_msg);
+    }
+  }
+
+  /** reserved characters */
+  private static final String RESERVED_CHARACTERS = ";/?:@&=+$,";
+
+  /** URI punctuation mark characters - these, combined with
+      alphanumerics, constitute the "unreserved" characters */
+  private static final String MARK_CHARACTERS = "-_.!~*'() ";
+
+  /** scheme can be composed of alphanumerics and these characters */
+  private static final String SCHEME_CHARACTERS = "+-.";
+
+  /** userinfo can be composed of unreserved, escaped and these
+      characters */
+  private static final String USERINFO_CHARACTERS = ";:&=+$,";
+
+  /** Stores the scheme (usually the protocol) for this URI. */
+  private String m_scheme = null;
+
+  /** If specified, stores the userinfo for this URI; otherwise null */
+  private String m_userinfo = null;
+
+  /** If specified, stores the host for this URI; otherwise null */
+  private String m_host = null;
+
+  /** If specified, stores the port for this URI; otherwise -1 */
+  private int m_port = -1;
+
+  /** If specified, stores the path for this URI; otherwise null */
+  private String m_path = null;
+
+  /** If specified, stores the query string for this URI; otherwise
+      null.  */
+  private String m_queryString = null;
+
+  /** If specified, stores the fragment for this URI; otherwise null */
+  private String m_fragment = null;
+
+  private static boolean DEBUG = false;
+
+  /**
+  * Construct a new and uninitialized URI.
+  */
+  public JaxmURI() {
+  }
+
+ /**
+  * Construct a new URI from another URI. All fields for this URI are
+  * set equal to the fields of the URI passed in.
+  *
+  * @param p_other the URI to copy (cannot be null)
+  */
+  public JaxmURI(JaxmURI p_other) {
+    initialize(p_other);
+  }
+
+ /**
+  * Construct a new URI from a URI specification string. If the
+  * specification follows the "generic URI" syntax, (two slashes
+  * following the first colon), the specification will be parsed
+  * accordingly - setting the scheme, userinfo, host,port, path, query
+  * string and fragment fields as necessary. If the specification does
+  * not follow the "generic URI" syntax, the specification is parsed
+  * into a scheme and scheme-specific part (stored as the path) only.
+  *
+  * @param p_uriSpec the URI specification string (cannot be null or
+  *                  empty)
+  *
+  * @exception MalformedURIException if p_uriSpec violates any syntax
+  *                                   rules
+  */
+  public JaxmURI(String p_uriSpec) throws MalformedURIException {
+    this((JaxmURI)null, p_uriSpec);
+  }
+
+ /**
+  * Construct a new URI from a base URI and a URI specification string.
+  * The URI specification string may be a relative URI.
+  *
+  * @param p_base the base URI (cannot be null if p_uriSpec is null or
+  *               empty)
+  * @param p_uriSpec the URI specification string (cannot be null or
+  *                  empty if p_base is null)
+  *
+  * @exception MalformedURIException if p_uriSpec violates any syntax
+  *                                  rules
+  */
+  public JaxmURI(JaxmURI p_base, String p_uriSpec) throws MalformedURIException {
+    initialize(p_base, p_uriSpec);
+  }
+
+ /**
+  * Construct a new URI that does not follow the generic URI syntax.
+  * Only the scheme and scheme-specific part (stored as the path) are
+  * initialized.
+  *
+  * @param p_scheme the URI scheme (cannot be null or empty)
+  * @param p_schemeSpecificPart the scheme-specific part (cannot be
+  *                             null or empty)
+  *
+  * @exception MalformedURIException if p_scheme violates any
+  *                                  syntax rules
+  */
+  public JaxmURI(String p_scheme, String p_schemeSpecificPart)
+             throws MalformedURIException {
+    if (p_scheme == null || p_scheme.trim().length() == 0) {
+      throw new MalformedURIException(
+            "Cannot construct URI with null/empty scheme!");
+    }
+    if (p_schemeSpecificPart == null ||
+        p_schemeSpecificPart.trim().length() == 0) {
+      throw new MalformedURIException(
+          "Cannot construct URI with null/empty scheme-specific part!");
+    }
+    setScheme(p_scheme);
+    setPath(p_schemeSpecificPart);
+  }
+
+ /**
+  * Construct a new URI that follows the generic URI syntax from its
+  * component parts. Each component is validated for syntax and some
+  * basic semantic checks are performed as well.  See the individual
+  * setter methods for specifics.
+  *
+  * @param p_scheme the URI scheme (cannot be null or empty)
+  * @param p_host the hostname or IPv4 address for the URI
+  * @param p_path the URI path - if the path contains '?' or '#',
+  *               then the query string and/or fragment will be
+  *               set from the path; however, if the query and
+  *               fragment are specified both in the path and as
+  *               separate parameters, an exception is thrown
+  * @param p_queryString the URI query string (cannot be specified
+  *                      if path is null)
+  * @param p_fragment the URI fragment (cannot be specified if path
+  *                   is null)
+  *
+  * @exception MalformedURIException if any of the parameters violates
+  *                                  syntax rules or semantic rules
+  */
+  public JaxmURI(String p_scheme, String p_host, String p_path,
+             String p_queryString, String p_fragment)
+         throws MalformedURIException {
+    this(p_scheme, null, p_host, -1, p_path, p_queryString, p_fragment);
+  }
+
+ /**
+  * Construct a new URI that follows the generic URI syntax from its
+  * component parts. Each component is validated for syntax and some
+  * basic semantic checks are performed as well.  See the individual
+  * setter methods for specifics.
+  *
+  * @param p_scheme the URI scheme (cannot be null or empty)
+  * @param p_userinfo the URI userinfo (cannot be specified if host
+  *                   is null)
+  * @param p_host the hostname or IPv4 address for the URI
+  * @param p_port the URI port (may be -1 for "unspecified"; cannot
+  *               be specified if host is null)
+  * @param p_path the URI path - if the path contains '?' or '#',
+  *               then the query string and/or fragment will be
+  *               set from the path; however, if the query and
+  *               fragment are specified both in the path and as
+  *               separate parameters, an exception is thrown
+  * @param p_queryString the URI query string (cannot be specified
+  *                      if path is null)
+  * @param p_fragment the URI fragment (cannot be specified if path
+  *                   is null)
+  *
+  * @exception MalformedURIException if any of the parameters violates
+  *                                  syntax rules or semantic rules
+  */
+  public JaxmURI(String p_scheme, String p_userinfo,
+             String p_host, int p_port, String p_path,
+             String p_queryString, String p_fragment)
+         throws MalformedURIException {
+    if (p_scheme == null || p_scheme.trim().length() == 0) {
+      throw new MalformedURIException("Scheme is required!");
+    }
+
+    if (p_host == null) {
+      if (p_userinfo != null) {
+        throw new MalformedURIException(
+             "Userinfo may not be specified if host is not specified!");
+      }
+      if (p_port != -1) {
+        throw new MalformedURIException(
+             "Port may not be specified if host is not specified!");
+      }
+    }
+
+    if (p_path != null) {
+      if (p_path.indexOf('?') != -1 && p_queryString != null) {
+        throw new MalformedURIException(
+          "Query string cannot be specified in path and query string!");
+      }
+
+      if (p_path.indexOf('#') != -1 && p_fragment != null) {
+        throw new MalformedURIException(
+          "Fragment cannot be specified in both the path and fragment!");
+      }
+    }
+
+    setScheme(p_scheme);
+    setHost(p_host);
+    setPort(p_port);
+    setUserinfo(p_userinfo);
+    setPath(p_path);
+    setQueryString(p_queryString);
+    setFragment(p_fragment);
+  }
+
+ /**
+  * Initialize all fields of this URI from another URI.
+  *
+  * @param p_other the URI to copy (cannot be null)
+  */
+  private void initialize(JaxmURI p_other) {
+    m_scheme = p_other.getScheme();
+    m_userinfo = p_other.getUserinfo();
+    m_host = p_other.getHost();
+    m_port = p_other.getPort();
+    m_path = p_other.getPath();
+    m_queryString = p_other.getQueryString();
+    m_fragment = p_other.getFragment();
+  }
+
+ /**
+  * Initializes this URI from a base URI and a URI specification string.
+  * See RFC 2396 Section 4 and Appendix B for specifications on parsing
+  * the URI and Section 5 for specifications on resolving relative URIs
+  * and relative paths.
+  *
+  * @param p_base the base URI (may be null if p_uriSpec is an absolute
+  *               URI)
+  * @param p_uriSpec the URI spec string which may be an absolute or
+  *                  relative URI (can only be null/empty if p_base
+  *                  is not null)
+  *
+  * @exception MalformedURIException if p_base is null and p_uriSpec
+  *                                  is not an absolute URI or if
+  *                                  p_uriSpec violates syntax rules
+  */
+  private void initialize(JaxmURI p_base, String p_uriSpec)
+                         throws MalformedURIException {
+    if (p_base == null &&
+        (p_uriSpec == null || p_uriSpec.trim().length() == 0)) {
+      throw new MalformedURIException(
+                  "Cannot initialize URI with empty parameters.");
+      }
+
+    // just make a copy of the base if spec is empty
+    if (p_uriSpec == null || p_uriSpec.trim().length() == 0) {
+      initialize(p_base);
+      return;
+    }
+
+    String uriSpec = p_uriSpec.trim();
+    int uriSpecLen = uriSpec.length();
+    int index = 0;
+
+    // Check for scheme, which must be before `/'. Also handle names with
+    // DOS drive letters ('D:'), so 1-character schemes are not allowed.
+    int colonIdx = uriSpec.indexOf(':');
+    int slashIdx = uriSpec.indexOf('/');
+    if ((colonIdx < 2) || (colonIdx > slashIdx && slashIdx != -1)) {
+      int fragmentIdx = uriSpec.indexOf('#');
+      // A standalone base is a valid URI according to spec
+      if (p_base == null && fragmentIdx != 0 ) {
+        throw new MalformedURIException("No scheme found in URI.");
+      }
+    }
+    else {
+      initializeScheme(uriSpec);
+      index = m_scheme.length()+1;
+    }
+
+    // two slashes means generic URI syntax, so we get the authority
+    if (((index+1) < uriSpecLen) &&
+        (uriSpec.substring(index).startsWith("//"))) {
+      index += 2;
+      int startPos = index;
+
+      // get authority - everything up to path, query or fragment
+      char testChar = '\0';
+      while (index < uriSpecLen) {
+        testChar = uriSpec.charAt(index);
+        if (testChar == '/' || testChar == '?' || testChar == '#') {
+          break;
+        }
+        index++;
+      }
+
+      // if we found authority, parse it out, otherwise we set the
+      // host to empty string
+      if (index > startPos) {
+        initializeAuthority(uriSpec.substring(startPos, index));
+      }
+      else {
+        m_host = "";
+      }
+    }
+
+    initializePath(uriSpec.substring(index));
+
+    // Resolve relative URI to base URI - see RFC 2396 Section 5.2
+    // In some cases, it might make more sense to throw an exception
+    // (when scheme is specified is the string spec and the base URI
+    // is also specified, for example), but we're just following the
+    // RFC specifications
+    if (p_base != null) {
+
+      // check to see if this is the current doc - RFC 2396 5.2 #2
+      // note that this is slightly different from the RFC spec in that
+      // we don't include the check for query string being null
+      // - this handles cases where the urispec is just a query
+      // string or a fragment (e.g. "?y" or "#s") -
+      // see <http://www.ics.uci.edu/~fielding/url/test1.html> which
+      // identified this as a bug in the RFC
+      if (m_path.length() == 0 && m_scheme == null &&
+          m_host == null) {
+        m_scheme = p_base.getScheme();
+        m_userinfo = p_base.getUserinfo();
+        m_host = p_base.getHost();
+        m_port = p_base.getPort();
+        m_path = p_base.getPath();
+
+        if (m_queryString == null) {
+          m_queryString = p_base.getQueryString();
+        }
+        return;
+      }
+
+      // check for scheme - RFC 2396 5.2 #3
+      // if we found a scheme, it means absolute URI, so we're done
+      if (m_scheme == null) {
+        m_scheme = p_base.getScheme();
+      }
+      else {
+        return;
+      }
+
+      // check for authority - RFC 2396 5.2 #4
+      // if we found a host, then we've got a network path, so we're done
+      if (m_host == null) {
+        m_userinfo = p_base.getUserinfo();
+        m_host = p_base.getHost();
+        m_port = p_base.getPort();
+      }
+      else {
+        return;
+      }
+
+      // check for absolute path - RFC 2396 5.2 #5
+      if (m_path.length() > 0 &&
+          m_path.startsWith("/")) {
+        return;
+      }
+
+      // if we get to this point, we need to resolve relative path
+      // RFC 2396 5.2 #6
+      String path = new String();
+      String basePath = p_base.getPath();
+
+      // 6a - get all but the last segment of the base URI path
+      if (basePath != null) {
+        int lastSlash = basePath.lastIndexOf('/');
+        if (lastSlash != -1) {
+          path = basePath.substring(0, lastSlash+1);
+        }
+      }
+
+      // 6b - append the relative URI path
+      path = path.concat(m_path);
+
+      // 6c - remove all "./" where "." is a complete path segment
+      index = -1;
+      while ((index = path.indexOf("/./")) != -1) {
+        path = path.substring(0, index+1).concat(path.substring(index+3));
+      }
+
+      // 6d - remove "." if path ends with "." as a complete path segment
+      if (path.endsWith("/.")) {
+        path = path.substring(0, path.length()-1);
+      }
+
+      // 6e - remove all "<segment>/../" where "<segment>" is a complete
+      // path segment not equal to ".."
+      index = 1;
+      int segIndex = -1;
+      String tempString = null;
+
+      while ((index = path.indexOf("/../", index)) > 0) {
+        tempString = path.substring(0, path.indexOf("/../"));
+        segIndex = tempString.lastIndexOf('/');
+        if (segIndex != -1) {
+          if (!tempString.substring(segIndex++).equals("..")) {
+            path = path.substring(0, segIndex).concat(path.substring(index+4));
+          }
+          else
+            index += 4;
+        }
+        else
+          index += 4;
+      }
+
+      // 6f - remove ending "<segment>/.." where "<segment>" is a
+      // complete path segment
+      if (path.endsWith("/..")) {
+        tempString = path.substring(0, path.length()-3);
+        segIndex = tempString.lastIndexOf('/');
+        if (segIndex != -1) {
+          path = path.substring(0, segIndex+1);
+        }
+      }
+      m_path = path;
+    }
+  }
+
+ /**
+  * Initialize the scheme for this URI from a URI string spec.
+  *
+  * @param p_uriSpec the URI specification (cannot be null)
+  *
+  * @exception MalformedURIException if URI does not have a conformant
+  *                                  scheme
+  */
+  private void initializeScheme(String p_uriSpec)
+                 throws MalformedURIException {
+    int uriSpecLen = p_uriSpec.length();
+    int index = 0;
+    String scheme = null;
+    char testChar = '\0';
+
+    while (index < uriSpecLen) {
+      testChar = p_uriSpec.charAt(index);
+      if (testChar == ':' || testChar == '/' ||
+          testChar == '?' || testChar == '#') {
+        break;
+      }
+      index++;
+    }
+    scheme = p_uriSpec.substring(0, index);
+
+    if (scheme.length() == 0) {
+      throw new MalformedURIException("No scheme found in URI.");
+    }
+    else {
+      setScheme(scheme);
+    }
+  }
+
+ /**
+  * Initialize the authority (userinfo, host and port) for this
+  * URI from a URI string spec.
+  *
+  * @param p_uriSpec the URI specification (cannot be null)
+  *
+  * @exception MalformedURIException if p_uriSpec violates syntax rules
+  */
+  private void initializeAuthority(String p_uriSpec)
+                 throws MalformedURIException {
+    int index = 0;
+    int start = 0;
+    int end = p_uriSpec.length();
+    char testChar = '\0';
+    String userinfo = null;
+
+    // userinfo is everything up @
+    if (p_uriSpec.indexOf('@', start) != -1) {
+      while (index < end) {
+        testChar = p_uriSpec.charAt(index);
+        if (testChar == '@') {
+          break;
+        }
+        index++;
+      }
+      userinfo = p_uriSpec.substring(start, index);
+      index++;
+    }
+
+    // host is everything up to ':'
+    String host = null;
+    start = index;
+    while (index < end) {
+      testChar = p_uriSpec.charAt(index);
+      if (testChar == ':') {
+        break;
+      }
+      index++;
+    }
+    host = p_uriSpec.substring(start, index);
+    int port = -1;
+    if (host.length() > 0) {
+      // port
+      if (testChar == ':') {
+        index++;
+        start = index;
+        while (index < end) {
+          index++;
+        }
+        String portStr = p_uriSpec.substring(start, index);
+        if (portStr.length() > 0) {
+          for (int i = 0; i < portStr.length(); i++) {
+            if (!isDigit(portStr.charAt(i))) {
+              throw new MalformedURIException(
+                   portStr +
+                   " is invalid. Port should only contain digits!");
+            }
+          }
+          try {
+            port = Integer.parseInt(portStr);
+          }
+          catch (NumberFormatException nfe) {
+            // can't happen
+          }
+        }
+      }
+    }
+    setHost(host);
+    setPort(port);
+    setUserinfo(userinfo);
+  }
+
+ /**
+  * Initialize the path for this URI from a URI string spec.
+  *
+  * @param p_uriSpec the URI specification (cannot be null)
+  *
+  * @exception MalformedURIException if p_uriSpec violates syntax rules
+  */
+  private void initializePath(String p_uriSpec)
+                 throws MalformedURIException {
+    if (p_uriSpec == null) {
+      throw new MalformedURIException(
+                "Cannot initialize path from null string!");
+    }
+
+    int index = 0;
+    int start = 0;
+    int end = p_uriSpec.length();
+    char testChar = '\0';
+
+    // path - everything up to query string or fragment
+    while (index < end) {
+      testChar = p_uriSpec.charAt(index);
+      if (testChar == '?' || testChar == '#') {
+        break;
+      }
+      // check for valid escape sequence
+      if (testChar == '%') {
+         if (index+2 >= end ||
+            !isHex(p_uriSpec.charAt(index+1)) ||
+            !isHex(p_uriSpec.charAt(index+2))) {
+          throw new MalformedURIException(
+                "Path contains invalid escape sequence!");
+         }
+      }
+      else if (!isReservedCharacter(testChar) &&
+               !isUnreservedCharacter(testChar)) {
+        throw new MalformedURIException(
+                  "Path contains invalid character: " + testChar);
+      }
+      index++;
+    }
+    m_path = p_uriSpec.substring(start, index);
+
+    // query - starts with ? and up to fragment or end
+    if (testChar == '?') {
+      index++;
+      start = index;
+      while (index < end) {
+        testChar = p_uriSpec.charAt(index);
+        if (testChar == '#') {
+          break;
+        }
+        if (testChar == '%') {
+           if (index+2 >= end ||
+              !isHex(p_uriSpec.charAt(index+1)) ||
+              !isHex(p_uriSpec.charAt(index+2))) {
+            throw new MalformedURIException(
+                    "Query string contains invalid escape sequence!");
+           }
+        }
+        else if (!isReservedCharacter(testChar) &&
+                 !isUnreservedCharacter(testChar)) {
+          throw new MalformedURIException(
+                "Query string contains invalid character:" + testChar);
+        }
+        index++;
+      }
+      m_queryString = p_uriSpec.substring(start, index);
+    }
+
+    // fragment - starts with #
+    if (testChar == '#') {
+      index++;
+      start = index;
+      while (index < end) {
+        testChar = p_uriSpec.charAt(index);
+
+        if (testChar == '%') {
+           if (index+2 >= end ||
+              !isHex(p_uriSpec.charAt(index+1)) ||
+              !isHex(p_uriSpec.charAt(index+2))) {
+            throw new MalformedURIException(
+                    "Fragment contains invalid escape sequence!");
+           }
+        }
+        else if (!isReservedCharacter(testChar) &&
+                 !isUnreservedCharacter(testChar)) {
+          throw new MalformedURIException(
+                "Fragment contains invalid character:"+testChar);
+        }
+        index++;
+      }
+      m_fragment = p_uriSpec.substring(start, index);
+    }
+  }
+
+ /**
+  * Get the scheme for this URI.
+  *
+  * @return the scheme for this URI
+  */
+  public String getScheme() {
+    return m_scheme;
+  }
+
+ /**
+  * Get the scheme-specific part for this URI (everything following the
+  * scheme and the first colon). See RFC 2396 Section 5.2 for spec.
+  *
+  * @return the scheme-specific part for this URI
+  */
+  public String getSchemeSpecificPart() {
+    StringBuffer schemespec = new StringBuffer();
+
+    if (m_userinfo != null || m_host != null || m_port != -1) {
+      schemespec.append("//");
+    }
+
+    if (m_userinfo != null) {
+      schemespec.append(m_userinfo);
+      schemespec.append('@');
+    }
+
+    if (m_host != null) {
+      schemespec.append(m_host);
+    }
+
+    if (m_port != -1) {
+      schemespec.append(':');
+      schemespec.append(m_port);
+    }
+
+    if (m_path != null) {
+      schemespec.append((m_path));
+    }
+
+    if (m_queryString != null) {
+      schemespec.append('?');
+      schemespec.append(m_queryString);
+    }
+
+    if (m_fragment != null) {
+      schemespec.append('#');
+      schemespec.append(m_fragment);
+    }
+
+    return schemespec.toString();
+  }
+
+ /**
+  * Get the userinfo for this URI.
+  *
+  * @return the userinfo for this URI (null if not specified).
+  */
+  public String getUserinfo() {
+    return m_userinfo;
+  }
+
+  /**
+  * Get the host for this URI.
+  *
+  * @return the host for this URI (null if not specified).
+  */
+  public String getHost() {
+    return m_host;
+  }
+
+ /**
+  * Get the port for this URI.
+  *
+  * @return the port for this URI (-1 if not specified).
+  */
+  public int getPort() {
+    return m_port;
+  }
+
+ /**
+  * Get the path for this URI (optionally with the query string and
+  * fragment).
+  *
+  * @param p_includeQueryString if true (and query string is not null),
+  *                             then a "?" followed by the query string
+  *                             will be appended
+  * @param p_includeFragment if true (and fragment is not null),
+  *                             then a "#" followed by the fragment
+  *                             will be appended
+  *
+  * @return the path for this URI possibly including the query string
+  *         and fragment
+  */
+  public String getPath(boolean p_includeQueryString,
+                        boolean p_includeFragment) {
+    StringBuffer pathString = new StringBuffer(m_path);
+
+    if (p_includeQueryString && m_queryString != null) {
+      pathString.append('?');
+      pathString.append(m_queryString);
+    }
+
+    if (p_includeFragment && m_fragment != null) {
+      pathString.append('#');
+      pathString.append(m_fragment);
+    }
+    return pathString.toString();
+  }
+
+ /**
+  * Get the path for this URI. Note that the value returned is the path
+  * only and does not include the query string or fragment.
+  *
+  * @return the path for this URI.
+  */
+  public String getPath() {
+    return m_path;
+  }
+
+ /**
+  * Get the query string for this URI.
+  *
+  * @return the query string for this URI. Null is returned if there
+  *         was no "?" in the URI spec, empty string if there was a
+  *         "?" but no query string following it.
+  */
+  public String getQueryString() {
+    return m_queryString;
+  }
+
+ /**
+  * Get the fragment for this URI.
+  *
+  * @return the fragment for this URI. Null is returned if there
+  *         was no "#" in the URI spec, empty string if there was a
+  *         "#" but no fragment following it.
+  */
+  public String getFragment() {
+    return m_fragment;
+  }
+
+ /**
+  * Set the scheme for this URI. The scheme is converted to lowercase
+  * before it is set.
+  *
+  * @param p_scheme the scheme for this URI (cannot be null)
+  *
+  * @exception MalformedURIException if p_scheme is not a conformant
+  *                                  scheme name
+  */
+  public void setScheme(String p_scheme) throws MalformedURIException {
+    if (p_scheme == null) {
+      throw new MalformedURIException(
+                "Cannot set scheme from null string!");
+    }
+    if (!isConformantSchemeName(p_scheme)) {
+      throw new MalformedURIException("The scheme is not conformant.");
+    }
+
+    m_scheme = p_scheme.toLowerCase();
+  }
+
+ /**
+  * Set the userinfo for this URI. If a non-null value is passed in and
+  * the host value is null, then an exception is thrown.
+  *
+  * @param p_userinfo the userinfo for this URI
+  *
+  * @exception MalformedURIException if p_userinfo contains invalid
+  *                                  characters
+  */
+  public void setUserinfo(String p_userinfo) throws MalformedURIException {
+    if (p_userinfo == null) {
+      m_userinfo = null;
+    }
+    else {
+      if (m_host == null) {
+        throw new MalformedURIException(
+                     "Userinfo cannot be set when host is null!");
+      }
+
+      // userinfo can contain alphanumerics, mark characters, escaped
+      // and ';',':','&','=','+','$',','
+      int index = 0;
+      int end = p_userinfo.length();
+      char testChar = '\0';
+      while (index < end) {
+        testChar = p_userinfo.charAt(index);
+        if (testChar == '%') {
+          if (index+2 >= end ||
+              !isHex(p_userinfo.charAt(index+1)) ||
+              !isHex(p_userinfo.charAt(index+2))) {
+            throw new MalformedURIException(
+                  "Userinfo contains invalid escape sequence!");
+          }
+        }
+        else if (!isUnreservedCharacter(testChar) &&
+                 USERINFO_CHARACTERS.indexOf(testChar) == -1) {
+          throw new MalformedURIException(
+                  "Userinfo contains invalid character:"+testChar);
+        }
+        index++;
+      }
+    }
+    m_userinfo = p_userinfo;
+  }
+
+  /**
+  * Set the host for this URI. If null is passed in, the userinfo
+  * field is also set to null and the port is set to -1.
+  *
+  * @param p_host the host for this URI
+  *
+  * @exception MalformedURIException if p_host is not a valid IP
+  *                                  address or DNS hostname.
+  */
+  public void setHost(String p_host) throws MalformedURIException {
+    if (p_host == null || p_host.trim().length() == 0) {
+      m_host = p_host;
+      m_userinfo = null;
+      m_port = -1;
+    }
+    else if (!isWellFormedAddress(p_host)) {
+      throw new MalformedURIException("Host is not a well formed address!");
+    }
+    m_host = p_host;
+  }
+
+ /**
+  * Set the port for this URI. -1 is used to indicate that the port is
+  * not specified, otherwise valid port numbers are  between 0 and 65535.
+  * If a valid port number is passed in and the host field is null,
+  * an exception is thrown.
+  *
+  * @param p_port the port number for this URI
+  *
+  * @exception MalformedURIException if p_port is not -1 and not a
+  *                                  valid port number
+  */
+  public void setPort(int p_port) throws MalformedURIException {
+    if (p_port >= 0 && p_port <= 65535) {
+      if (m_host == null) {
+        throw new MalformedURIException(
+                      "Port cannot be set when host is null!");
+      }
+    }
+    else if (p_port != -1) {
+      throw new MalformedURIException("Invalid port number!");
+    }
+    m_port = p_port;
+  }
+
+ /**
+  * Set the path for this URI. If the supplied path is null, then the
+  * query string and fragment are set to null as well. If the supplied
+  * path includes a query string and/or fragment, these fields will be
+  * parsed and set as well. Note that, for URIs following the "generic
+  * URI" syntax, the path specified should start with a slash.
+  * For URIs that do not follow the generic URI syntax, this method
+  * sets the scheme-specific part.
+  *
+  * @param p_path the path for this URI (may be null)
+  *
+  * @exception MalformedURIException if p_path contains invalid
+  *                                  characters
+  */
+  public void setPath(String p_path) throws MalformedURIException {
+    if (p_path == null) {
+      m_path = null;
+      m_queryString = null;
+      m_fragment = null;
+    }
+    else {
+      initializePath(p_path);
+    }
+  }
+
+ /**
+  * Append to the end of the path of this URI. If the current path does
+  * not end in a slash and the path to be appended does not begin with
+  * a slash, a slash will be appended to the current path before the
+  * new segment is added. Also, if the current path ends in a slash
+  * and the new segment begins with a slash, the extra slash will be
+  * removed before the new segment is appended.
+  *
+  * @param p_addToPath the new segment to be added to the current path
+  *
+  * @exception MalformedURIException if p_addToPath contains syntax
+  *                                  errors
+  */
+  public void appendPath(String p_addToPath)
+                         throws MalformedURIException {
+    if (p_addToPath == null || p_addToPath.trim().length() == 0) {
+      return;
+    }
+
+    if (!isURIString(p_addToPath)) {
+      throw new MalformedURIException(
+              "Path contains invalid character!");
+    }
+
+    if (m_path == null || m_path.trim().length() == 0) {
+      if (p_addToPath.startsWith("/")) {
+        m_path = p_addToPath;
+      }
+      else {
+        m_path = "/" + p_addToPath;
+      }
+    }
+    else if (m_path.endsWith("/")) {
+      if (p_addToPath.startsWith("/")) {
+        m_path = m_path.concat(p_addToPath.substring(1));
+      }
+      else {
+        m_path = m_path.concat(p_addToPath);
+      }
+    }
+    else {
+      if (p_addToPath.startsWith("/")) {
+        m_path = m_path.concat(p_addToPath);
+      }
+      else {
+        m_path = m_path.concat("/" + p_addToPath);
+      }
+    }
+  }
+
+ /**
+  * Set the query string for this URI. A non-null value is valid only
+  * if this is an URI conforming to the generic URI syntax and
+  * the path value is not null.
+  *
+  * @param p_queryString the query string for this URI
+  *
+  * @exception MalformedURIException if p_queryString is not null and this
+  *                                  URI does not conform to the generic
+  *                                  URI syntax or if the path is null
+  */
+  public void setQueryString(String p_queryString) throws MalformedURIException {
+    if (p_queryString == null) {
+      m_queryString = null;
+    }
+    else if (!isGenericURI()) {
+      throw new MalformedURIException(
+              "Query string can only be set for a generic URI!");
+    }
+    else if (getPath() == null) {
+      throw new MalformedURIException(
+              "Query string cannot be set when path is null!");
+    }
+    else if (!isURIString(p_queryString)) {
+      throw new MalformedURIException(
+              "Query string contains invalid character!");
+    }
+    else {
+      m_queryString = p_queryString;
+    }
+  }
+
+ /**
+  * Set the fragment for this URI. A non-null value is valid only
+  * if this is a URI conforming to the generic URI syntax and
+  * the path value is not null.
+  *
+  * @param p_fragment the fragment for this URI
+  *
+  * @exception MalformedURIException if p_fragment is not null and this
+  *                                  URI does not conform to the generic
+  *                                  URI syntax or if the path is null
+  */
+  public void setFragment(String p_fragment) throws MalformedURIException {
+    if (p_fragment == null) {
+      m_fragment = null;
+    }
+    else if (!isGenericURI()) {
+      throw new MalformedURIException(
+         "Fragment can only be set for a generic URI!");
+    }
+    else if (getPath() == null) {
+      throw new MalformedURIException(
+              "Fragment cannot be set when path is null!");
+    }
+    else if (!isURIString(p_fragment)) {
+      throw new MalformedURIException(
+              "Fragment contains invalid character!");
+    }
+    else {
+      m_fragment = p_fragment;
+    }
+  }
+
+ /**
+  * Determines if the passed-in Object is equivalent to this URI.
+  *
+  * @param p_test the Object to test for equality.
+  *
+  * @return true if p_test is a URI with all values equal to this
+  *         URI, false otherwise
+  */
+  public boolean equals(Object p_test) {
+    if (p_test instanceof JaxmURI) {
+      JaxmURI testURI = (JaxmURI) p_test;
+      if (((m_scheme == null && testURI.m_scheme == null) ||
+           (m_scheme != null && testURI.m_scheme != null &&
+            m_scheme.equals(testURI.m_scheme))) &&
+          ((m_userinfo == null && testURI.m_userinfo == null) ||
+           (m_userinfo != null && testURI.m_userinfo != null &&
+            m_userinfo.equals(testURI.m_userinfo))) &&
+          ((m_host == null && testURI.m_host == null) ||
+           (m_host != null && testURI.m_host != null &&
+            m_host.equals(testURI.m_host))) &&
+            m_port == testURI.m_port &&
+          ((m_path == null && testURI.m_path == null) ||
+           (m_path != null && testURI.m_path != null &&
+            m_path.equals(testURI.m_path))) &&
+          ((m_queryString == null && testURI.m_queryString == null) ||
+           (m_queryString != null && testURI.m_queryString != null &&
+            m_queryString.equals(testURI.m_queryString))) &&
+          ((m_fragment == null && testURI.m_fragment == null) ||
+           (m_fragment != null && testURI.m_fragment != null &&
+            m_fragment.equals(testURI.m_fragment)))) {
+        return true;
+      }
+    }
+    return false;
+  }
+
+ /**
+  * Get the URI as a string specification. See RFC 2396 Section 5.2.
+  *
+  * @return the URI string specification
+  */
+  public String toString() {
+    StringBuffer uriSpecString = new StringBuffer();
+
+    if (m_scheme != null) {
+      uriSpecString.append(m_scheme);
+      uriSpecString.append(':');
+    }
+    uriSpecString.append(getSchemeSpecificPart());
+    return uriSpecString.toString();
+  }
+
+ /**
+  * Get the indicator as to whether this URI uses the "generic URI"
+  * syntax.
+  *
+  * @return true if this URI uses the "generic URI" syntax, false
+  *         otherwise
+  */
+  public boolean isGenericURI() {
+    // presence of the host (whether valid or empty) means
+    // double-slashes which means generic uri
+    return (m_host != null);
+  }
+
+ /**
+  * Determine whether a scheme conforms to the rules for a scheme name.
+  * A scheme is conformant if it starts with an alphanumeric, and
+  * contains only alphanumerics, '+','-' and '.'.
+  *
+  * @return true if the scheme is conformant, false otherwise
+  */
+  public static boolean isConformantSchemeName(String p_scheme) {
+    if (p_scheme == null || p_scheme.trim().length() == 0) {
+      return false;
+    }
+
+    if (!isAlpha(p_scheme.charAt(0))) {
+      return false;
+    }
+
+    char testChar;
+    for (int i = 1; i < p_scheme.length(); i++) {
+      testChar = p_scheme.charAt(i);
+      if (!isAlphanum(testChar) &&
+          SCHEME_CHARACTERS.indexOf(testChar) == -1) {
+        return false;
+      }
+    }
+
+    return true;
+  }
+
+ /**
+  * Determine whether a string is syntactically capable of representing
+  * a valid IPv4 address or the domain name of a network host. A valid
+  * IPv4 address consists of four decimal digit groups separated by a
+  * '.'. A hostname consists of domain labels (each of which must
+  * begin and end with an alphanumeric but may contain '-') separated
+  & by a '.'. See RFC 2396 Section 3.2.2.
+  *
+  * @return true if the string is a syntactically valid IPv4 address
+  *              or hostname
+  */
+  public static boolean isWellFormedAddress(String p_address) {
+    if (p_address == null) {
+      return false;
+    }
+
+    String address = p_address.trim();
+    int addrLength = address.length();
+    if (addrLength == 0 || addrLength > 255) {
+      return false;
+    }
+
+    if (address.startsWith(".") || address.startsWith("-")) {
+      return false;
+    }
+
+    // rightmost domain label starting with digit indicates IP address
+    // since top level domain label can only start with an alpha
+    // see RFC 2396 Section 3.2.2
+    int index = address.lastIndexOf('.');
+    if (address.endsWith(".")) {
+      index = address.substring(0, index).lastIndexOf('.');
+    }
+
+    if (index+1 < addrLength && isDigit(p_address.charAt(index+1))) {
+      char testChar;
+      int numDots = 0;
+
+      // make sure that 1) we see only digits and dot separators, 2) that
+      // any dot separator is preceded and followed by a digit and
+      // 3) that we find 3 dots
+      for (int i = 0; i < addrLength; i++) {
+        testChar = address.charAt(i);
+        if (testChar == '.') {
+          if (!isDigit(address.charAt(i-1)) ||
+              (i+1 < addrLength && !isDigit(address.charAt(i+1)))) {
+            return false;
+          }
+          numDots++;
+        }
+        else if (!isDigit(testChar)) {
+          return false;
+        }
+      }
+      if (numDots != 3) {
+        return false;
+      }
+    }
+    else {
+      // domain labels can contain alphanumerics and '-"
+      // but must start and end with an alphanumeric
+      char testChar;
+
+      for (int i = 0; i < addrLength; i++) {
+        testChar = address.charAt(i);
+        if (testChar == '.') {
+          if (!isAlphanum(address.charAt(i-1))) {
+            return false;
+          }
+          if (i+1 < addrLength && !isAlphanum(address.charAt(i+1))) {
+            return false;
+          }
+        }
+        else if (!isAlphanum(testChar) && testChar != '-') {
+          return false;
+        }
+      }
+    }
+    return true;
+  }
+
+
+ /**
+  * Determine whether a char is a digit.
+  *
+  * @return true if the char is betweeen '0' and '9', false otherwise
+  */
+  private static boolean isDigit(char p_char) {
+    return p_char >= '0' && p_char <= '9';
+  }
+
+ /**
+  * Determine whether a character is a hexadecimal character.
+  *
+  * @return true if the char is betweeen '0' and '9', 'a' and 'f'
+  *         or 'A' and 'F', false otherwise
+  */
+  private static boolean isHex(char p_char) {
+    return (isDigit(p_char) ||
+            (p_char >= 'a' && p_char <= 'f') ||
+            (p_char >= 'A' && p_char <= 'F'));
+  }
+
+ /**
+  * Determine whether a char is an alphabetic character: a-z or A-Z
+  *
+  * @return true if the char is alphabetic, false otherwise
+  */
+  private static boolean isAlpha(char p_char) {
+    return ((p_char >= 'a' && p_char <= 'z') ||
+            (p_char >= 'A' && p_char <= 'Z' ));
+  }
+
+ /**
+  * Determine whether a char is an alphanumeric: 0-9, a-z or A-Z
+  *
+  * @return true if the char is alphanumeric, false otherwise
+  */
+  private static boolean isAlphanum(char p_char) {
+    return (isAlpha(p_char) || isDigit(p_char));
+  }
+
+ /**
+  * Determine whether a character is a reserved character:
+  * ';', '/', '?', ':', '@', '&', '=', '+', '$' or ','
+  *
+  * @return true if the string contains any reserved characters
+  */
+  private static boolean isReservedCharacter(char p_char) {
+    return RESERVED_CHARACTERS.indexOf(p_char) != -1;
+  }
+
+ /**
+  * Determine whether a char is an unreserved character.
+  *
+  * @return true if the char is unreserved, false otherwise
+  */
+  private static boolean isUnreservedCharacter(char p_char) {
+    return (isAlphanum(p_char) ||
+            MARK_CHARACTERS.indexOf(p_char) != -1);
+  }
+
+ /**
+  * Determine whether a given string contains only URI characters (also
+  * called "uric" in RFC 2396). uric consist of all reserved
+  * characters, unreserved characters and escaped characters.
+  *
+  * @return true if the string is comprised of uric, false otherwise
+  */
+  private static boolean isURIString(String p_uric) {
+    if (p_uric == null) {
+      return false;
+    }
+    int end = p_uric.length();
+    char testChar = '\0';
+    for (int i = 0; i < end; i++) {
+      testChar = p_uric.charAt(i);
+      if (testChar == '%') {
+        if (i+2 >= end ||
+            !isHex(p_uric.charAt(i+1)) ||
+            !isHex(p_uric.charAt(i+2))) {
+          return false;
+        }
+        else {
+          i += 2;
+          continue;
+        }
+      }
+      if (isReservedCharacter(testChar) ||
+          isUnreservedCharacter(testChar)) {
+          continue;
+      }
+      else {
+        return false;
+      }
+    }
+    return true;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/LocalStrings.properties b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/LocalStrings.properties
new file mode 100644
index 0000000..ecfbb43
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/LocalStrings.properties
@@ -0,0 +1,9 @@
+# SAAJ ResourceBundle properties file
+# Contains Log messages for util pkg
+# Error messages
+SAAJ0601.util.newSAXParser.exception=SAAJ0601: Can't create RejectDoctypSaxFilter because SAXParserFactory.newSAXParser threw an exception. See stack trace for detalis
+SAAJ0602.util.getXMLReader.exception=SAAJ0602: Can't create RejectDoctypSaxFilter because SAXParser.getXMLReader threw an exception. See stack trace for detalis
+SAAJ0603.util.setProperty.exception=SAAJ0603: Can't create RejectDoctypSaxFilter because XMLReader.setProperty threw an exception. See stack trace for detalis
+
+# Info messages
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/LogDomainConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/LogDomainConstants.java
new file mode 100644
index 0000000..2896864
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/LogDomainConstants.java
@@ -0,0 +1,75 @@
+/*
+ * $Id: LogDomainConstants.java,v 1.5 2006/01/27 12:49:52 vj135062 Exp $
+ * $Revision: 1.5 $
+ * $Date: 2006/01/27 12:49:52 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.util;
+
+/**
+ * @author  Manveen Kaur (manveen.kaur@eng.sun.com)
+ */
+
+/**
+ * This interface defines a number of constants pertaining to Logging domains.
+ */
+
+public interface LogDomainConstants {
+
+    // TBD -- this should be configurable from a properties
+    // file or something .. Leaving it as it is for now.
+    public static String MODULE_TOPLEVEL_DOMAIN =
+                    "javax.xml.messaging.saaj";
+
+    // First Level Domain
+    public static String CLIENT_DOMAIN =
+                MODULE_TOPLEVEL_DOMAIN + ".client";
+
+    public static String SOAP_DOMAIN =
+                MODULE_TOPLEVEL_DOMAIN + ".soap";
+
+    public static String UTIL_DOMAIN =
+                MODULE_TOPLEVEL_DOMAIN + ".util";
+
+    // Second Level Domain
+    public static String HTTP_CONN_DOMAIN =
+                  CLIENT_DOMAIN + ".p2p";
+
+    public static String NAMING_DOMAIN =
+                SOAP_DOMAIN + ".name";
+
+    public static String SOAP_IMPL_DOMAIN =
+                  SOAP_DOMAIN + ".impl";
+
+    public static String SOAP_VER1_1_DOMAIN =
+                  SOAP_DOMAIN + ".ver1_1";
+
+    public static String SOAP_VER1_2_DOMAIN =
+                  SOAP_DOMAIN + ".ver1_2";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/MimeHeadersUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/MimeHeadersUtil.java
new file mode 100644
index 0000000..5847e54
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/MimeHeadersUtil.java
@@ -0,0 +1,54 @@
+/*
+ * $Id: MimeHeadersUtil.java,v 1.5 2006/01/27 12:49:52 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.util.Iterator;
+
+import javax.xml.soap.MimeHeader;
+import javax.xml.soap.MimeHeaders;
+
+public class MimeHeadersUtil {
+    public static MimeHeaders copy(MimeHeaders headers) {
+        MimeHeaders newHeaders = new MimeHeaders();
+        Iterator eachHeader = headers.getAllHeaders();
+        while (eachHeader.hasNext()) {
+            MimeHeader currentHeader = (MimeHeader) eachHeader.next();
+
+            newHeaders.addHeader(
+                currentHeader.getName(),
+                currentHeader.getValue());
+        }
+        return newHeaders;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/NamespaceContextIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/NamespaceContextIterator.java
new file mode 100644
index 0000000..a78d1ef
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/NamespaceContextIterator.java
@@ -0,0 +1,126 @@
+/*
+ * $Id: NamespaceContextIterator.java,v 1.8 2006/01/27 12:49:52 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+*
+* @author SAAJ RI Development Team
+*/
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.util.Iterator;
+import java.util.NoSuchElementException;
+
+import org.w3c.dom.*;
+
+public class NamespaceContextIterator implements Iterator {
+    Node context;
+    NamedNodeMap attributes = null;
+    int attributesLength;
+    int attributeIndex;
+    Attr next = null;
+    Attr last = null;
+    boolean traverseStack = true;
+
+    public NamespaceContextIterator(Node context) {
+        this.context = context;
+        findContextAttributes();
+    }
+
+    public NamespaceContextIterator(Node context, boolean traverseStack) {
+        this(context);
+        this.traverseStack = traverseStack;
+    }
+
+    protected void findContextAttributes() {
+        while (context != null) {
+            int type = context.getNodeType();
+            if (type == Node.ELEMENT_NODE) {
+                attributes = context.getAttributes();
+                attributesLength = attributes.getLength();
+                attributeIndex = 0;
+                return;
+            } else {
+                context = null;
+            }
+        }
+    }
+
+    protected void findNext() {
+        while (next == null && context != null) {
+            for (; attributeIndex < attributesLength; ++attributeIndex) {
+                Node currentAttribute = attributes.item(attributeIndex);
+                String attributeName = currentAttribute.getNodeName();
+                if (attributeName.startsWith("xmlns")
+                    && (attributeName.length() == 5
+                        || attributeName.charAt(5) == ':')) {
+                    next = (Attr) currentAttribute;
+                    ++attributeIndex;
+                    return;
+                }
+            }
+            if (traverseStack) {
+                context = context.getParentNode();
+                findContextAttributes();
+            } else {
+                context = null;
+            }
+        }
+    }
+
+    public boolean hasNext() {
+        findNext();
+        return next != null;
+    }
+
+    public Object next() {
+        return getNext();
+    }
+
+    public Attr nextNamespaceAttr() {
+        return getNext();
+    }
+
+    protected Attr getNext() {
+        findNext();
+        if (next == null) {
+            throw new NoSuchElementException();
+        }
+        last = next;
+        next = null;
+        return last;
+    }
+
+    public void remove() {
+        if (last == null) {
+            throw new IllegalStateException();
+        }
+        ((Element) context).removeAttributeNode(last);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ParseUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ParseUtil.java
new file mode 100644
index 0000000..fef90d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ParseUtil.java
@@ -0,0 +1,98 @@
+/*
+ * $Id: ParseUtil.java,v 1.5 2006/01/27 12:49:52 vj135062 Exp $
+ * $Revision: 1.5 $
+ * $Date: 2006/01/27 12:49:52 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+
+// Cut&paste from sun.net.www.ParseUtil: decode, unescape
+
+public class ParseUtil {
+    /**
+     * Un-escape and return the character at position i in string s.
+     */
+    private static char unescape(String s, int i) {
+        return (char) Integer.parseInt(s.substring(i+1,i+3),16);
+    }
+
+    /**
+     * Returns a new String constructed from the specified String by replacing
+     * the URL escape sequences and UTF8 encoding with the characters they
+     * represent.
+     */
+    public static String decode(String s) {
+        StringBuffer sb = new StringBuffer();
+
+        int i=0;
+        while (i<s.length()) {
+            char c = s.charAt(i);
+            char c2, c3;
+
+            if (c != '%') {
+                i++;
+            } else {
+                try {
+                    c = unescape(s, i);
+                    i += 3;
+
+                    if ((c & 0x80) != 0) {
+                        switch (c >> 4) {
+                            case 0xC: case 0xD:
+                                c2 = unescape(s, i);
+                                i += 3;
+                                c = (char)(((c & 0x1f) << 6) | (c2 & 0x3f));
+                                break;
+
+                            case 0xE:
+                                c2 = unescape(s, i);
+                                i += 3;
+                                c3 = unescape(s, i);
+                                i += 3;
+                                c = (char)(((c & 0x0f) << 12) |
+                                           ((c2 & 0x3f) << 6) |
+                                            (c3 & 0x3f));
+                                break;
+
+                            default:
+                                throw new IllegalArgumentException();
+                        }
+                    }
+                } catch (NumberFormatException e) {
+                    throw new IllegalArgumentException();
+                }
+            }
+
+            sb.append(c);
+        }
+
+        return sb.toString();
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ParserPool.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ParserPool.java
new file mode 100644
index 0000000..75fb28c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/ParserPool.java
@@ -0,0 +1,72 @@
+/*
+ * $Id: ParserPool.java,v 1.5 2006/01/27 12:49:52 vj135062 Exp $
+ * $Revision: 1.5 $
+ * $Date: 2006/01/27 12:49:52 $
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.util.EmptyStackException;
+import java.util.Stack;
+
+import javax.xml.parsers.*;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Pool of SAXParser objects
+ */
+public class ParserPool {
+    private Stack parsers;
+    private SAXParserFactory factory;
+    private int capacity;
+
+    public ParserPool(int capacity) {
+                this.capacity = capacity;
+        factory = new com.sun.org.apache.xerces.internal.jaxp.SAXParserFactoryImpl(); //SAXParserFactory.newInstance();
+        factory.setNamespaceAware(true);
+        parsers = new Stack();
+    }
+
+    public synchronized SAXParser get() throws ParserConfigurationException,
+                SAXException {
+
+        try {
+            return (SAXParser) parsers.pop();
+        } catch (EmptyStackException e) {
+            return factory.newSAXParser();
+        }
+    }
+
+    public synchronized void put(SAXParser parser) {
+        if (parsers.size() < capacity) {
+            parsers.push(parser);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/RejectDoctypeSaxFilter.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/RejectDoctypeSaxFilter.java
new file mode 100644
index 0000000..4ea1c90
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/RejectDoctypeSaxFilter.java
@@ -0,0 +1,182 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.util.logging.Logger;
+
+import javax.xml.parsers.SAXParser;
+import javax.xml.soap.SOAPException;
+
+import org.xml.sax.*;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
+import org.xml.sax.helpers.AttributesImpl;
+
+/**
+ * Users of this class see a SAX2 XMLReader (via XMLFilterImpl).  This
+ * class creates a parent XMLReader via JAXP and installs itself as a SAX2
+ * extension LexicalHandler which rejects document type declarations
+ * because they are not legal in SOAP.  If the user of this class sets a
+ * LexicalHandler, then it forwards events to that handler.
+ *
+ * $Id: RejectDoctypeSaxFilter.java,v 1.13 2006/01/27 12:49:52 vj135062 Exp $
+ * @author Edwin Goei
+ */
+
+public class RejectDoctypeSaxFilter extends XMLFilterImpl implements XMLReader, LexicalHandler{
+    protected static Logger log =
+    Logger.getLogger(LogDomainConstants.UTIL_DOMAIN,
+    "com.sun.xml.internal.messaging.saaj.util.LocalStrings");
+
+    /** Standard SAX 2.0 ext property */
+    static final String LEXICAL_HANDLER_PROP =
+    "http://xml.org/sax/properties/lexical-handler";
+
+    static final String WSU_NS = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd".intern();
+    static final String SIGNATURE_LNAME = "Signature".intern();
+    static final String ENCRYPTED_DATA_LNAME = "EncryptedData".intern();
+    static final String DSIG_NS = "http://www.w3.org/2000/09/xmldsig#".intern();
+    static final String XENC_NS = "http://www.w3.org/2001/04/xmlenc#".intern();
+    static final String ID_NAME = "ID".intern();
+
+    /** LexicalHandler to forward events to, if any */
+    private LexicalHandler lexicalHandler;
+
+    public RejectDoctypeSaxFilter(SAXParser saxParser) throws SOAPException {
+        XMLReader xmlReader;
+        try {
+            xmlReader = saxParser.getXMLReader();
+        } catch (Exception e) {
+            log.severe("SAAJ0602.util.getXMLReader.exception");
+            throw new SOAPExceptionImpl(
+            "Couldn't get an XMLReader while constructing a RejectDoctypeSaxFilter",
+            e);
+        }
+
+        // Set ourselves up to be the SAX LexicalHandler
+        try {
+            xmlReader.setProperty(LEXICAL_HANDLER_PROP, this);
+        } catch (Exception e) {
+            log.severe("SAAJ0603.util.setProperty.exception");
+            throw new SOAPExceptionImpl(
+            "Couldn't set the lexical handler property while constructing a RejectDoctypeSaxFilter",
+            e);
+        }
+
+        // Set the parent XMLReader of this SAX filter
+        setParent(xmlReader);
+    }
+
+    /*
+     * Override setProperty() to capture any LexicalHandler that is set for
+     * forwarding of events.
+     */
+    public void setProperty(String name, Object value)
+    throws SAXNotRecognizedException, SAXNotSupportedException {
+        if (LEXICAL_HANDLER_PROP.equals(name)) {
+            lexicalHandler = (LexicalHandler) value;
+        } else {
+            super.setProperty(name, value);
+        }
+    }
+
+    //
+    // Beginning of SAX LexicalHandler callbacks...
+    //
+
+    public void startDTD(String name, String publicId, String systemId)
+    throws SAXException {
+        throw new SAXException("Document Type Declaration is not allowed");
+    }
+
+    public void endDTD() throws SAXException {
+    }
+
+    public void startEntity(String name) throws SAXException {
+        if (lexicalHandler != null) {
+            lexicalHandler.startEntity(name);
+        }
+    }
+
+    public void endEntity(String name) throws SAXException {
+        if (lexicalHandler != null) {
+            lexicalHandler.endEntity(name);
+        }
+    }
+
+    public void startCDATA() throws SAXException {
+        if (lexicalHandler != null) {
+            lexicalHandler.startCDATA();
+        }
+    }
+
+    public void endCDATA() throws SAXException {
+        if (lexicalHandler != null) {
+            lexicalHandler.endCDATA();
+        }
+    }
+
+    public void comment(char[] ch, int start, int length) throws SAXException {
+        if (lexicalHandler != null) {
+            lexicalHandler.comment(ch, start, length);
+        }
+    }
+
+    //
+    // End of SAX LexicalHandler callbacks
+    //
+
+    public void startElement(String namespaceURI, String localName,
+    String qName, Attributes atts)   throws SAXException{
+        if(atts != null ){
+            boolean eos = false;
+            if(namespaceURI == DSIG_NS || XENC_NS == namespaceURI){
+                eos = true;
+            }
+            int length = atts.getLength();
+            AttributesImpl attrImpl = new AttributesImpl();
+            for(int i=0; i< length;i++){
+                String name = atts.getLocalName(i);
+                if(name!=null && (name.equals("Id"))){
+                    if(eos || atts.getURI(i) == WSU_NS ){
+                        attrImpl.addAttribute(atts.getURI(i), atts.getLocalName(i),
+                        atts.getQName(i), ID_NAME, atts.getValue(i));
+                    }else{
+                         attrImpl.addAttribute(atts.getURI(i), atts.getLocalName(i), atts.getQName(i), atts.getType(i), atts.getValue(i));
+                    }
+                }else{
+                    attrImpl.addAttribute(atts.getURI(i), atts.getLocalName(i),
+                    atts.getQName(i), atts.getType(i), atts.getValue(i));
+                }
+            }
+            super.startElement(namespaceURI,localName, qName,attrImpl);
+        }else{
+            super.startElement(namespaceURI,localName, qName, atts);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/TeeInputStream.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/TeeInputStream.java
new file mode 100644
index 0000000..79aace8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/TeeInputStream.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Created on Feb 28, 2003
+ *
+ * To change this generated comment go to
+ * Window>Preferences>Java>Code Generation>Code Template
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.io.*;
+
+/**
+ * @author pgoodwin
+ */
+public class TeeInputStream extends InputStream {
+    protected InputStream source;
+    protected OutputStream copySink;
+
+    public TeeInputStream(InputStream source, OutputStream sink) {
+        super();
+        this.copySink = sink;
+        this.source = source;
+    }
+
+    public int read() throws IOException {
+        int result = source.read();
+        copySink.write(result);
+        return result;
+    }
+
+    public int available() throws IOException {
+        return source.available();
+    }
+
+    public void close() throws IOException {
+        source.close();
+    }
+
+    public synchronized void mark(int readlimit) {
+        source.mark(readlimit);
+    }
+
+    public boolean markSupported() {
+        return source.markSupported();
+    }
+
+    public int read(byte[] b, int off, int len) throws IOException {
+        int result = source.read(b, off, len);
+        copySink.write(b, off, len);
+        return result;
+    }
+
+    public int read(byte[] b) throws IOException {
+        int result = source.read(b);
+        copySink.write(b);
+        return result;
+    }
+
+    public synchronized void reset() throws IOException {
+        source.reset();
+    }
+
+    public long skip(long n) throws IOException {
+        return source.skip(n);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/XMLDeclarationParser.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/XMLDeclarationParser.java
new file mode 100644
index 0000000..720a28d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/XMLDeclarationParser.java
@@ -0,0 +1,180 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.messaging.saaj.util;
+
+import java.io.*;
+import java.util.HashMap;
+import java.util.Iterator;
+
+import javax.xml.transform.TransformerException;
+
+/*
+ * Class that parses the very first construct in the document i.e.
+ *  <?xml ... ?>
+ *
+ * @author Panos Kougiouris (panos@acm.org)
+ */
+
+public class XMLDeclarationParser {
+    private String m_encoding;
+    private PushbackReader m_pushbackReader;
+    private boolean m_hasHeader; // preserve the case where no XML Header exists
+    private String xmlDecl = null;
+    static String gt16 = null;
+    static String utf16Decl = null;
+
+    static {
+         try {
+             gt16 = new String(">".getBytes("utf-16"));
+             utf16Decl = new String("<?xml".getBytes("utf-16"));
+         } catch (Exception e) {}
+    }
+
+    //---------------------------------------------------------------------
+
+    public XMLDeclarationParser(PushbackReader pr)
+    {
+        m_pushbackReader = pr;
+        m_encoding = "utf-8";
+        m_hasHeader = false;
+    }
+
+    //---------------------------------------------------------------------
+    public String getEncoding()
+    {
+        return m_encoding;
+    }
+
+    public String getXmlDeclaration() {
+        return xmlDecl;
+    }
+
+    //---------------------------------------------------------------------
+
+     public void parse()  throws TransformerException, IOException
+     {
+        int c = 0;
+        int index = 0;
+        char[] aChar = new char[65535];
+        StringBuffer xmlDeclStr = new StringBuffer();
+        while ((c = m_pushbackReader.read()) != -1) {
+            aChar[index] = (char)c;
+            xmlDeclStr.append((char)c);
+            index++;
+            if (c == '>') {
+                break;
+            }
+        }
+        int len = index;
+
+        String decl = xmlDeclStr.toString();
+        boolean utf16 = false;
+        boolean utf8 = false;
+
+        int xmlIndex = decl.indexOf(utf16Decl);
+        if (xmlIndex > -1) {
+            utf16 = true;
+        } else {
+            xmlIndex = decl.indexOf("<?xml");
+            if (xmlIndex > -1) {
+                utf8 = true;
+            }
+        }
+
+        // no XML decl
+        if (!utf16 && !utf8) {
+            m_pushbackReader.unread(aChar, 0, len);
+            return;
+        }
+        m_hasHeader = true;
+
+        if (utf16) {
+            xmlDecl = new String(decl.getBytes(), "utf-16");
+            xmlDecl = xmlDecl.substring(xmlDecl.indexOf("<"));
+        } else {
+            xmlDecl = decl;
+        }
+        // do we want to check that there are no other characters preceeding <?xml
+        if (xmlIndex != 0) {
+            throw new IOException("Unexpected characters before XML declaration");
+        }
+
+        int versionIndex =  xmlDecl.indexOf("version");
+        if (versionIndex == -1) {
+            throw new IOException("Mandatory 'version' attribute Missing in XML declaration");
+        }
+
+        // now set
+        int encodingIndex = xmlDecl.indexOf("encoding");
+        if (encodingIndex == -1) {
+            return;
+        }
+
+        if (versionIndex > encodingIndex) {
+            throw new IOException("The 'version' attribute should preceed the 'encoding' attribute in an XML Declaration");
+        }
+
+        int stdAloneIndex = xmlDecl.indexOf("standalone");
+        if ((stdAloneIndex > -1) && ((stdAloneIndex < versionIndex) || (stdAloneIndex < encodingIndex))) {
+            throw new IOException("The 'standalone' attribute should be the last attribute in an XML Declaration");
+        }
+
+        int eqIndex = xmlDecl.indexOf("=", encodingIndex);
+        if (eqIndex == -1) {
+            throw new IOException("Missing '=' character after 'encoding' in XML declaration");
+        }
+
+        m_encoding = parseEncoding(xmlDecl, eqIndex);
+        if(m_encoding.startsWith("\"")){
+            m_encoding = m_encoding.substring(m_encoding.indexOf("\"")+1, m_encoding.lastIndexOf("\""));
+        } else if(m_encoding.startsWith("\'")){
+            m_encoding = m_encoding.substring(m_encoding.indexOf("\'")+1, m_encoding.lastIndexOf("\'"));
+        }
+     }
+
+     //--------------------------------------------------------------------
+
+    public void writeTo(Writer wr) throws IOException {
+        if (!m_hasHeader) return;
+        wr.write(xmlDecl.toString());
+    }
+
+    private String parseEncoding(String xmlDeclFinal, int eqIndex) throws IOException {
+        java.util.StringTokenizer strTok = new java.util.StringTokenizer(
+            xmlDeclFinal.substring(eqIndex + 1));
+        if (strTok.hasMoreTokens()) {
+            String encodingTok = strTok.nextToken();
+            int indexofQ = encodingTok.indexOf("?");
+            if (indexofQ > -1) {
+                return encodingTok.substring(0,indexofQ);
+            } else {
+                return encodingTok;
+            }
+        } else {
+            throw new IOException("Error parsing 'encoding' attribute in XML declaration");
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/transform/EfficientStreamingTransformer.java b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/transform/EfficientStreamingTransformer.java
new file mode 100644
index 0000000..540f606
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/messaging/saaj/util/transform/EfficientStreamingTransformer.java
@@ -0,0 +1,412 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * EfficientStreamingTransformer.java
+ *
+ * Created on July 29, 2002, 3:49 PM
+ */
+
+package com.sun.xml.internal.messaging.saaj.util.transform;
+
+import java.io.*;
+
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+
+import javax.xml.transform.*;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.transform.stream.StreamSource;
+
+import org.w3c.dom.Document;
+
+import com.sun.xml.internal.messaging.saaj.util.XMLDeclarationParser;
+import com.sun.xml.internal.messaging.saaj.util.FastInfosetReflection;
+
+/**
+ * This class is a proxy for a Transformer object with optimizations
+ * for certain cases. If source and result are of type stream, then
+ * bytes are simply copied whenever possible (note that this assumes
+ * that the input is well formed). In addition, it provides support for
+ * FI using native DOM parsers and serializers.
+ *
+ * @author Panos Kougiouris panos@acm.org
+ * @author Santiago.PericasGeertsen@sun.com
+ *
+ */
+public class EfficientStreamingTransformer
+    extends javax.xml.transform.Transformer {
+
+  static final String version;
+  static final String vendor;
+
+  protected static TransformerFactory transformerFactory = TransformerFactory.newInstance();
+
+  static {
+        version = System.getProperty("java.vm.version");
+        vendor = System.getProperty("java.vm.vendor");
+        if (vendor.startsWith("Sun") &&
+            (version.startsWith("1.4") || version.startsWith("1.3"))) {
+            transformerFactory =
+                new com.sun.org.apache.xalan.internal.xsltc.trax.TransformerFactoryImpl();
+        }
+  }
+
+    /**
+     * TransformerFactory instance.
+     */
+
+    /**
+     * Underlying XSLT transformer.
+     */
+    private Transformer m_realTransformer = null;
+
+    /**
+     * Undelying FI DOM parser.
+     */
+    private Object m_fiDOMDocumentParser = null;
+
+    /**
+     * Underlying FI DOM serializer.
+     */
+    private Object m_fiDOMDocumentSerializer = null;
+
+    private EfficientStreamingTransformer() {
+    }
+
+    private void materialize() throws TransformerException {
+        if (m_realTransformer == null) {
+            m_realTransformer = transformerFactory.newTransformer();
+        }
+    }
+
+    public void clearParameters() {
+        if (m_realTransformer != null)
+            m_realTransformer.clearParameters();
+    }
+
+    public javax.xml.transform.ErrorListener getErrorListener() {
+        try {
+            materialize();
+            return m_realTransformer.getErrorListener();
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+        return null;
+    }
+
+    public java.util.Properties getOutputProperties() {
+        try {
+            materialize();
+            return m_realTransformer.getOutputProperties();
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+        return null;
+    }
+
+    public String getOutputProperty(String str)
+        throws java.lang.IllegalArgumentException {
+        try {
+            materialize();
+            return m_realTransformer.getOutputProperty(str);
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+        return null;
+    }
+
+    public Object getParameter(String str) {
+        try {
+            materialize();
+            return m_realTransformer.getParameter(str);
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+        return null;
+    }
+
+    public javax.xml.transform.URIResolver getURIResolver() {
+        try {
+            materialize();
+            return m_realTransformer.getURIResolver();
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+        return null;
+    }
+
+    public void setErrorListener(
+        javax.xml.transform.ErrorListener errorListener)
+        throws java.lang.IllegalArgumentException {
+        try {
+            materialize();
+            m_realTransformer.setErrorListener(errorListener);
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+    }
+
+    public void setOutputProperties(java.util.Properties properties)
+        throws java.lang.IllegalArgumentException {
+        try {
+            materialize();
+            m_realTransformer.setOutputProperties(properties);
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+    }
+
+    public void setOutputProperty(String str, String str1)
+        throws java.lang.IllegalArgumentException {
+        try {
+            materialize();
+            m_realTransformer.setOutputProperty(str, str1);
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+    }
+
+    public void setParameter(String str, Object obj) {
+        try {
+            materialize();
+            m_realTransformer.setParameter(str, obj);
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+    }
+
+    public void setURIResolver(javax.xml.transform.URIResolver uRIResolver) {
+        try {
+            materialize();
+            m_realTransformer.setURIResolver(uRIResolver);
+        } catch (TransformerException e) {
+            // will be caught later
+        }
+    }
+
+    private InputStream getInputStreamFromSource(StreamSource s)
+        throws TransformerException {
+
+        InputStream stream = s.getInputStream();
+        if (stream != null)
+            return stream;
+
+        if (s.getReader() != null)
+            return null;
+
+        String systemId = s.getSystemId();
+        if (systemId != null) {
+            try {
+                String fileURL = systemId;
+
+                if (systemId.startsWith("file:///"))
+                {
+                    /*
+                     systemId is:
+                     file:///<drive>:/some/path/file.xml
+                     or
+                     file:///some/path/file.xml
+                    */
+
+                    String absolutePath = systemId.substring(7);
+                    /*
+                     /<drive>:/some/path/file.xml
+                     or
+                     /some/path/file.xml
+                    */
+
+                    boolean hasDriveDesignator = absolutePath.indexOf(":") > 0;
+                    if (hasDriveDesignator) {
+                      String driveDesignatedPath = absolutePath.substring(1);
+                      /*
+                      <drive>:/some/path/file.xml */
+                      fileURL = driveDesignatedPath;
+                    }
+                    else {
+                      /*
+                      /some/path/file.xml */
+                      fileURL = absolutePath;
+                    }
+                }
+                return new FileInputStream(fileURL);
+            } catch (IOException e) {
+                throw new TransformerException(e.toString());
+            }
+        }
+
+        throw new TransformerException("Unexpected StreamSource object");
+    }
+
+    //------------------------------------------------------------------------
+
+    public void transform(
+        javax.xml.transform.Source source,
+        javax.xml.transform.Result result)
+        throws javax.xml.transform.TransformerException
+    {
+        // StreamSource -> StreamResult
+        if ((source instanceof StreamSource)
+            && (result instanceof StreamResult)) {
+            try {
+                StreamSource streamSource = (StreamSource) source;
+                InputStream is = getInputStreamFromSource(streamSource);
+
+                OutputStream os = ((StreamResult) result).getOutputStream();
+                if (os == null)
+                    // TODO: We might want to fix this if it were to be used beyond
+                    // XmlDataContentHandler that we know uses only OutputStream
+                    throw new TransformerException("Unexpected StreamResult object contains null OutputStream");
+
+                if (is != null) {
+                    if (is.markSupported())
+                        is.mark(Integer.MAX_VALUE);
+                    int num;
+                    byte[] b = new byte[8192];
+                    while ((num = is.read(b)) != -1) {
+                        os.write(b, 0, num);
+                    }
+                    if (is.markSupported())
+                        is.reset();
+                    return;
+                }
+
+                Reader reader = streamSource.getReader();
+                if (reader != null) {
+
+                    if (reader.markSupported())
+                        reader.mark(Integer.MAX_VALUE);
+
+                    PushbackReader pushbackReader = new PushbackReader(reader, 4096);
+                    //some size to unread <?xml ....?>
+                    XMLDeclarationParser ev =
+                        new XMLDeclarationParser(pushbackReader);
+                    try {
+                        ev.parse();
+                    } catch (Exception ex) {
+                        throw new TransformerException(
+                            "Unable to run the JAXP transformer on a stream "
+                                + ex.getMessage());
+                    }
+                    Writer writer =
+                        new OutputStreamWriter(os /*, ev.getEncoding()*/);
+                    ev.writeTo(writer);         // doesn't write any, if no header
+
+                    int num;
+                    char[] ac = new char[8192];
+                    while ((num = pushbackReader.read(ac)) != -1) {
+                        writer.write(ac, 0, num);
+                    }
+                    writer.flush();
+
+                    if (reader.markSupported())
+                        reader.reset();
+                    return;
+                }
+            } catch (IOException e) {
+                e.printStackTrace();
+                throw new TransformerException(e.toString());
+            }
+
+            throw new TransformerException("Unexpected StreamSource object");
+        }
+        // FastInfosetSource -> DOMResult
+        else if (FastInfosetReflection.isFastInfosetSource(source)
+                && (result instanceof DOMResult))
+        {
+            try {
+                // Use reflection to avoid a static dep with FI
+                if (m_fiDOMDocumentParser == null) {
+                    m_fiDOMDocumentParser = FastInfosetReflection.DOMDocumentParser_new();
+                }
+
+                // m_fiDOMDocumentParser.parse(document, source.getInputStream())
+                FastInfosetReflection.DOMDocumentParser_parse(
+                    m_fiDOMDocumentParser,
+                    (Document) ((DOMResult) result).getNode(),
+                    FastInfosetReflection.FastInfosetSource_getInputStream(source));
+
+                // We're done!
+                return;
+            }
+            catch (Exception e) {
+                throw new TransformerException(e);
+            }
+        }
+        // DOMSource -> FastInfosetResult
+        else if ((source instanceof DOMSource)
+                && FastInfosetReflection.isFastInfosetResult(result))
+        {
+            try {
+                // Use reflection to avoid a static dep with FI
+                if (m_fiDOMDocumentSerializer == null) {
+                    m_fiDOMDocumentSerializer = FastInfosetReflection.DOMDocumentSerializer_new();
+                }
+
+                // m_fiDOMDocumentSerializer.setOutputStream(result.getOutputStream())
+                FastInfosetReflection.DOMDocumentSerializer_setOutputStream(
+                    m_fiDOMDocumentSerializer,
+                    FastInfosetReflection.FastInfosetResult_getOutputStream(result));
+
+                // m_fiDOMDocumentSerializer.serialize(node)
+                FastInfosetReflection.DOMDocumentSerializer_serialize(
+                    m_fiDOMDocumentSerializer,
+                    ((DOMSource) source).getNode());
+
+                // We're done!
+                return;
+            }
+            catch (Exception e) {
+                throw new TransformerException(e);
+            }
+        }
+
+        // All other cases -- use transformer object
+
+        materialize();
+        m_realTransformer.transform(source, result);
+    }
+
+    /**
+     * Threadlocal to hold a Transformer instance for this thread.
+     */
+    private static ThreadLocal effTransformer = new ThreadLocal();
+
+    /**
+     * Return Transformer instance for this thread, allocating a new one if
+     * necessary. Note that this method does not clear global parameters,
+     * properties or any other data set on a previously used transformer.
+     */
+    public static Transformer newTransformer() {
+        Transformer tt = (Transformer) effTransformer.get();
+        if (tt == null) {
+            effTransformer.set(tt = new EfficientStreamingTransformer());
+        }
+        return tt;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithm.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithm.java
new file mode 100644
index 0000000..20b6429
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithm.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+
+public interface EncodingAlgorithm {
+
+    public Object decodeFromBytes(byte[] b, int start, int length) throws EncodingAlgorithmException;
+
+    public Object decodeFromInputStream(InputStream s) throws EncodingAlgorithmException, IOException;
+
+
+    public void encodeToOutputStream(Object data, OutputStream s) throws EncodingAlgorithmException, IOException;
+
+
+    public Object convertFromCharacters(char[] ch, int start, int length) throws EncodingAlgorithmException;
+
+    public void convertToCharacters(Object data, StringBuffer s) throws EncodingAlgorithmException;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithmException.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithmException.java
new file mode 100644
index 0000000..579ab95
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithmException.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+public class EncodingAlgorithmException extends FastInfosetException {
+
+    public EncodingAlgorithmException(String message) {
+        super(message);
+    }
+
+    public EncodingAlgorithmException(String message, Exception e) {
+        super(message, e);
+    }
+
+    public EncodingAlgorithmException(Exception e) {
+        super(e);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithmIndexes.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithmIndexes.java
new file mode 100644
index 0000000..15b321a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/EncodingAlgorithmIndexes.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+/**
+ * The indexes of built-in encoding algorithms.
+ *
+ * <p>The indexes of the built-in encoding algorithms are specified
+ * in ITU-T Rec. X.891 | ISO/IEC 24824-1 (Fast Infoset), clause
+ * 10. The indexes start from 0 instead of 1 as specified.<p>
+ *
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.EncodingAlgorithmContentHandler
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.EncodingAlgorithmAttributes
+ */
+public final class EncodingAlgorithmIndexes {
+    public static final int HEXADECIMAL = 0;
+    public static final int BASE64      = 1;
+    public static final int SHORT       = 2;
+    public static final int INT         = 3;
+    public static final int LONG        = 4;
+    public static final int BOOLEAN     = 5;
+    public static final int FLOAT       = 6;
+    public static final int DOUBLE      = 7;
+    public static final int UUID        = 8;
+    public static final int CDATA       = 9;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/ExternalVocabulary.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/ExternalVocabulary.java
new file mode 100644
index 0000000..917ec32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/ExternalVocabulary.java
@@ -0,0 +1,85 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+/**
+ * An external vocabulary.
+ * <p>
+ * An external vocabulary has a URI that refers to a vocabulary.
+ *
+ * @author Paul.Sandoz@Sun.Com
+ */
+public class ExternalVocabulary {
+
+    /**
+     * A URI that refers to the external vocabulary.
+     */
+    public final String URI;
+
+    /**
+     * The vocabulary that is refered to by the URI.
+     */
+    public final Vocabulary vocabulary;
+
+    public ExternalVocabulary(String URI, Vocabulary vocabulary) {
+        if (URI == null || vocabulary == null) {
+            throw new IllegalArgumentException();
+        }
+
+        this.URI = URI;
+        this.vocabulary = vocabulary;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetException.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetException.java
new file mode 100644
index 0000000..632dc89
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetException.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+public class FastInfosetException extends Exception {
+
+    public FastInfosetException(String message) {
+        super(message);
+    }
+
+    public FastInfosetException(String message, Exception e) {
+        super(message, e);
+    }
+
+    public FastInfosetException(Exception e) {
+        super(e);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetParser.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetParser.java
new file mode 100644
index 0000000..c668f58
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetParser.java
@@ -0,0 +1,175 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+import java.util.Map;
+
+/**
+ * A general interface for parsers of fast infoset documents.
+ *
+ * <p>
+ * This interface contains common methods that are not specific to any
+ * API associated with the parsing of fast infoset documents.
+ *
+ * @author Paul.Sandoz@Sun.Com
+ */
+public interface FastInfosetParser {
+    /**
+     * The property name to be used for getting and setting the string
+     * interning property of a parser.
+     *
+     */
+    public static final String STRING_INTERNING_PROPERTY =
+        "http://jvnet.org/fastinfoset/parser/properties/string-interning";
+
+    /**
+     * The property name to be used for getting and setting the buffer size
+     * of a parser.
+     */
+    public static final String BUFFER_SIZE_PROPERTY =
+        "http://jvnet.org/fastinfoset/parser/properties/buffer-size";
+
+    /**
+     * The property name to be used for getting and setting the
+     * Map containing encoding algorithms.
+     *
+     */
+    public static final String REGISTERED_ENCODING_ALGORITHMS_PROPERTY =
+        "http://jvnet.org/fastinfoset/parser/properties/registered-encoding-algorithms";
+
+   /**
+     * The property name to be used for getting and setting the
+     * Map containing external vocabularies.
+     *
+     */
+    public static final String EXTERNAL_VOCABULARIES_PROPERTY =
+        "http://jvnet.org/fastinfoset/parser/properties/external-vocabularies";
+
+
+    /**
+     * Set the string interning property.
+     *
+     * <p>If the string interning property is set to true then
+     * <code>String</code> objects instantiated for [namespace name], [prefix]
+     * and [local name] infoset properties will be interned using the method
+     * {@link String#intern()}.
+     *
+     * @param stringInterning The string interning property.
+     */
+    public void setStringInterning(boolean stringInterning);
+
+    /**
+     * Return the string interning property.
+     *
+     * @return The string interning property.
+     */
+    public boolean getStringInterning();
+
+    /**
+     * Set the buffer size.
+     *
+     * <p>The size of the buffer for parsing is set using this
+     * method. Requests for sizes smaller then the current size will be ignored.
+     * Otherwise the buffer will be resized when the next parse is performed.<p>
+     *
+     * @param bufferSize The requested buffer size.
+     */
+    public void setBufferSize(int bufferSize);
+
+
+    /**
+     * Get the buffer size.
+     *
+     * @return The buffer size.
+     */
+    public int getBufferSize();
+
+
+    /**
+     * Sets the set of registered encoding algorithms.
+     *
+     * @param algorithms The set of registered algorithms.
+     */
+    public void setRegisteredEncodingAlgorithms(Map algorithms);
+
+    /**
+     * Gets the set of registered encoding algorithms.
+     *
+     * @return The set of registered algorithms.
+     */
+    public Map getRegisteredEncodingAlgorithms();
+
+    /**
+     * Set the map of referenced external vocabularies.
+     * <p>
+     * The map (but not the keys and values) be cloned.
+     *
+     * @param referencedVocabualries the map of URI to vocabulary.
+     */
+    public void setExternalVocabularies(Map referencedVocabualries);
+
+    /**
+     * Get the map of referenced external vocabularies.
+     *
+     * @return the map of URI to vocabulary.
+     * @deprecated
+     *     The map returned will not be the same instance and contain
+     *     the same entries as the map set by {@link #setExternalVocabularies}
+     *     method.
+     */
+    public Map getExternalVocabularies();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetResult.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetResult.java
new file mode 100644
index 0000000..53f66c7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetResult.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+import java.io.OutputStream;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.ext.LexicalHandler;
+import javax.xml.transform.sax.SAXResult;
+import com.sun.xml.internal.fastinfoset.sax.SAXDocumentSerializer;
+
+/**
+ *  A JAXP Result implementation that supports the serialization to fast
+ *  infoset documents for use by applications that expect a Result.
+ *
+ *  <P>The derivation of FIResult from SAXResult is an implementation
+ *  detail.<P>
+ *
+ *  <P>This implementation is designed for interoperation with JAXP and is not
+ *  not designed with performance in mind. It is recommended that for performant
+ *  interoperation alternative serializer specific solutions be used.<P>
+ *
+ *  <P>General applications shall not call the following methods:
+ *   <UL>
+ *     <LI>setHandler</LI>
+ *     <LI>setLexicalHandler</LI>
+ *     <LI>setSystemId</LI>
+ *   </UL>
+ *  </P>
+ */
+public class FastInfosetResult extends SAXResult {
+
+    OutputStream _outputStream;
+
+    public FastInfosetResult(OutputStream outputStream) {
+        _outputStream = outputStream;
+    }
+
+    public ContentHandler getHandler() {
+        ContentHandler handler = super.getHandler();
+        if (handler == null) {
+            handler = new SAXDocumentSerializer();
+            setHandler(handler);
+        }
+        ((SAXDocumentSerializer) handler).setOutputStream(_outputStream);
+        return handler;
+    }
+
+    public LexicalHandler getLexicalHandler() {
+        return (LexicalHandler) getHandler();
+    }
+
+    public OutputStream getOutputStream() {
+        return _outputStream;
+    }
+
+    public void setOutputStream(OutputStream outputStream) {
+        _outputStream = outputStream;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetSerializer.java
new file mode 100644
index 0000000..3570433
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetSerializer.java
@@ -0,0 +1,266 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+import java.io.OutputStream;
+import java.util.Map;
+
+/**
+ * A general interface for serializers of fast infoset documents.
+ *
+ * <p>
+ * This interface contains common methods that are not specific to any
+ * API associated with the serialization of XML Infoset to fast infoset
+ * documents.
+ *
+ * @author Paul.Sandoz@Sun.Com
+ */
+public interface FastInfosetSerializer {
+    /**
+     * The feature to ignore comments.
+     * <p>
+     * The default value is false. If true a serializer shall ignore comments
+     * and shall not serialize them.
+     */
+    public static final String IGNORE_COMMENTS_FEATURE =
+        "http://jvnet.org/fastinfoset/serializer/feature/ignore/comments";
+
+    /**
+     * The feature to ignore processing instructions.
+     * <p>
+     * The default value is false. If true a serializer shall ignore processing
+     * instructions and shall not serialize them.
+     */
+    public static final String IGNORE_PROCESSING_INSTRUCTIONS_FEATURE =
+        "http://jvnet.org/fastinfoset/serializer/feature/ignore/processingInstructions";
+
+    /**
+     * The feature to ignore text content that consists completely of white
+     * space characters.
+     * <p>
+     * The default value is false. If true a serializer shall ignore text
+     * content that consists completely of white space characters.
+     */
+    public static final String IGNORE_WHITE_SPACE_TEXT_CONTENT_FEATURE =
+        "http://jvnet.org/fastinfoset/serializer/feature/ignore/whiteSpaceTextContent";
+
+    /**
+     * The property name to be used for getting and setting the buffer size
+     * of a parser.
+     */
+    public static final String BUFFER_SIZE_PROPERTY =
+        "http://jvnet.org/fastinfoset/parser/properties/buffer-size";
+
+    /**
+     * The property name to be used for getting and setting the
+     * Map containing encoding algorithms.
+     *
+     */
+    public static final String REGISTERED_ENCODING_ALGORITHMS_PROPERTY =
+        "http://jvnet.org/fastinfoset/parser/properties/registered-encoding-algorithms";
+
+   /**
+     * The property name to be used for getting and setting the
+     * Map containing external vocabularies.
+     *
+     */
+    public static final String EXTERNAL_VOCABULARIES_PROPERTY =
+        "http://jvnet.org/fastinfoset/parser/properties/external-vocabularies";
+
+    /**
+     * The default value for the limit on the size of character content chunks
+     * that will be indexed.
+     */
+    public final static int CHARACTER_CONTENT_CHUNK_SIZE_CONSTRAINT = 7;
+
+    /**
+     * The default value for the limit on the size of attribute values
+     * that will be indexed.
+     */
+    public final static int ATTRIBUTE_VALUE_SIZE_CONSTRAINT = 7;
+
+    /**
+     * The character encoding scheme string for UTF-8.
+     */
+    public static final String UTF_8 = "UTF-8";
+
+    /**
+     * The character encoding scheme string for UTF-16BE.
+     */
+    public static final String UTF_16BE = "UTF-16BE";
+
+    /**
+     * Set the {@link #IGNORE_COMMENTS_FEATURE}.
+     * @param ignoreComments true if the feature shall be ignored.
+     */
+    public void setIgnoreComments(boolean ignoreComments);
+
+    /**
+     * Get the {@link #IGNORE_COMMENTS_FEATURE}.
+     * @return true if the feature is ignored, false otherwise.
+     */
+    public boolean getIgnoreComments();
+
+    /**
+     * Set the {@link #IGNORE_PROCESSING_INSTRUCTIONS_FEATURE}.
+     * @param ignoreProcesingInstructions true if the feature shall be ignored.
+     */
+    public void setIgnoreProcesingInstructions(boolean ignoreProcesingInstructions);
+
+    /**
+     * Get the {@link #IGNORE_PROCESSING_INSTRUCTIONS_FEATURE}.
+     * @return true if the feature is ignored, false otherwise.
+     */
+    public boolean getIgnoreProcesingInstructions();
+
+    /**
+     * Set the {@link #IGNORE_WHITE_SPACE_TEXT_CONTENT_FEATURE}.
+     * @param ignoreWhiteSpaceTextContent true if the feature shall be ignored.
+     */
+    public void setIgnoreWhiteSpaceTextContent(boolean ignoreWhiteSpaceTextContent);
+
+    /**
+     * Get the {@link #IGNORE_WHITE_SPACE_TEXT_CONTENT_FEATURE}.
+     * @return true if the feature is ignored, false otherwise.
+     */
+    public boolean getIgnoreWhiteSpaceTextContent();
+
+    /**
+     * Sets the character encoding scheme.
+     *
+     * The character encoding can be either UTF-8 or UTF-16BE for the
+     * the encoding of chunks of CIIs, the [normalized value]
+     * property of attribute information items, comment information
+     * items and processing instruction information items.
+     *
+     * @param characterEncodingScheme The set of registered algorithms.
+     */
+    public void setCharacterEncodingScheme(String characterEncodingScheme);
+
+    /**
+     * Gets the character encoding scheme.
+     *
+     * @return The character encoding scheme.
+     */
+    public String getCharacterEncodingScheme();
+
+    /**
+     * Sets the set of registered encoding algorithms.
+     *
+     * @param algorithms The set of registered algorithms.
+     */
+    public void setRegisteredEncodingAlgorithms(Map algorithms);
+
+    /**
+     * Gets the set of registered encoding algorithms.
+     *
+     * @return The set of registered algorithms.
+     */
+    public Map getRegisteredEncodingAlgorithms();
+
+    /**
+     * Sets the limit on the size of character content chunks
+     * that will be indexed.
+     *
+     * @param size The character content chunk size limit. Any chunk less
+     * that a length of size limit will be indexed.
+     */
+    public void setCharacterContentChunkSizeLimit(int size);
+
+    /**
+     * Gets the limit on the size of character content chunks
+     * that will be indexed.
+     *
+     * @return The character content chunk size limit.
+     */
+    public int getCharacterContentChunkSizeLimit();
+
+    /**
+     * Sets the limit on the size of attribute values
+     * that will be indexed.
+     *
+     * @param size The attribute value size limit. Any value less
+     * that a length of size limit will be indexed.
+     */
+    public void setAttributeValueSizeLimit(int size);
+
+    /**
+     * Gets the limit on the size of attribute values
+     * that will be indexed.
+     *
+     * @return The attribute value size limit.
+     */
+    public int getAttributeValueSizeLimit();
+
+    /**
+     * Set the external vocabulary that shall be used when serializing.
+     *
+     * @param v the vocabulary.
+     */
+    public void setExternalVocabulary(ExternalVocabulary v);
+
+    /**
+     * Reset the serializer for reuse serializing another XML infoset.
+     */
+    public void reset();
+
+    /**
+     * Set the OutputStream to serialize the XML infoset to a
+     * fast infoset document.
+     *
+     * @param s the OutputStream where the fast infoset document is written to.
+     */
+    public void setOutputStream(OutputStream s);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetSource.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetSource.java
new file mode 100644
index 0000000..d68dc5e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/FastInfosetSource.java
@@ -0,0 +1,114 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+import java.io.InputStream;
+
+import javax.xml.transform.sax.SAXSource;
+
+import org.xml.sax.InputSource;
+import org.xml.sax.XMLReader;
+
+import com.sun.xml.internal.fastinfoset.sax.SAXDocumentParser;
+
+/**
+ *  A JAXP Source implementation that supports the parsing fast
+ *  infoset document for use by applications that expect a Source.
+ *
+ *  <P>The derivation of FISource from SAXSource is an implementation
+ *  detail.<P>
+ *
+ *  <P>This implementation is designed for interoperation with JAXP and is not
+ *  not designed with performance in mind. It is recommended that for performant
+ *  interoperation alternative parser specific solutions be used.<P>
+ *
+ *  <P>Applications shall obey the following restrictions:
+ *   <UL>
+ *     <LI>The setXMLReader and setInputSource shall not be called.</LI>
+ *     <LI>The XMLReader object obtained by the getXMLReader method shall
+ *        be used only for parsing the InputSource object returned by
+ *        the getInputSource method.</LI>
+ *     <LI>The InputSource object obtained by the getInputSource method shall
+ *        be used only for being parsed by the XMLReader object returned by
+ *        the getXMLReader method.</LI>
+ *   </UL>
+ *  </P>
+ */
+public class FastInfosetSource extends SAXSource {
+
+    public FastInfosetSource(InputStream inputStream) {
+        super(new InputSource(inputStream));
+    }
+
+    public XMLReader getXMLReader() {
+        XMLReader reader = super.getXMLReader();
+        if (reader == null) {
+            reader = new SAXDocumentParser();
+            setXMLReader(reader);
+        }
+        ((SAXDocumentParser) reader).setInputStream(getInputStream());
+        return reader;
+    }
+
+    public InputStream getInputStream() {
+        return getInputSource().getByteStream();
+    }
+
+    public void setInputStream(InputStream inputStream) {
+        setInputSource(new InputSource(inputStream));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/RestrictedAlphabet.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/RestrictedAlphabet.java
new file mode 100644
index 0000000..03ced32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/RestrictedAlphabet.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+public final class RestrictedAlphabet {
+
+    public static final String NUMERIC_CHARACTERS = "0123456789-+.E ";
+
+    public static final int NUMERIC_CHARACTERS_INDEX = 0;
+
+    public static final String DATE_TIME_CHARACTERS = "0123456789-:TZ ";
+
+    public static final int DATE_TIME_CHARACTERS_INDEX = 1;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/Vocabulary.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/Vocabulary.java
new file mode 100644
index 0000000..15cfced
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/Vocabulary.java
@@ -0,0 +1,137 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset;
+
+import java.util.LinkedHashSet;
+import java.util.Set;
+import javax.xml.namespace.QName;
+
+/**
+ * A canonical representation of a vocabulary.
+ * <p>
+ * Each vocabulary table is represented as a Set. A vocabulary table entry is
+ * represented as an item in the Set.
+ * <p>
+ * The 1st item contained in a Set is assigned the smallest index value,
+ * n say (where n >= 0). The 2nd item is assigned an index value of n + 1. The kth
+ * item is assigned an index value of n + (k - 1).
+ * <p>
+ * A Fast Infoset parser/serializer implementation will tranform the canonical
+ * representation of a Vocabulary instance into a more optimal form suitable
+ * for the efficient usage according to the API implemented by the parsers and
+ * serialziers.
+ */
+public class Vocabulary {
+    /**
+     * The restricted alphabet table, containing String objects.
+     */
+    public final Set restrictedAlphabets = new LinkedHashSet();
+
+    /**
+     * The encoding algorithm table, containing String objects.
+     */
+    public final Set encodingAlgorithms = new LinkedHashSet();
+
+    /**
+     * The prefix table, containing String objects.
+     */
+    public final Set prefixes = new LinkedHashSet();
+
+    /**
+     * The namespace name table, containing String objects.
+     */
+    public final Set namespaceNames = new LinkedHashSet();
+
+    /**
+     * The local name table, containing String objects.
+     */
+    public final Set localNames = new LinkedHashSet();
+
+    /**
+     * The "other NCName" table, containing String objects.
+     */
+    public final Set otherNCNames = new LinkedHashSet();
+
+    /**
+     * The "other URI" table, containing String objects.
+     */
+    public final Set otherURIs = new LinkedHashSet();
+
+    /**
+     * The "attribute value" table, containing String objects.
+     */
+    public final Set attributeValues = new LinkedHashSet();
+
+    /**
+     * The "other string" table, containing String objects.
+     */
+    public final Set otherStrings = new LinkedHashSet();
+
+    /**
+     * The "character content chunk" table, containing String objects.
+     */
+    public final Set characterContentChunks = new LinkedHashSet();
+
+    /**
+     * The element table, containing QName objects.
+     */
+    public final Set elements = new LinkedHashSet();
+
+    /**
+     * The attribute table, containing QName objects.
+     */
+    public final Set attributes = new LinkedHashSet();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/EncodingAlgorithmAttributes.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/EncodingAlgorithmAttributes.java
new file mode 100644
index 0000000..7d2d1d5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/EncodingAlgorithmAttributes.java
@@ -0,0 +1,125 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset.sax;
+
+import org.xml.sax.Attributes;
+
+
+/**
+ * Interface for a list of XML attributes that may contain encoding algorithm
+ * data.
+ * <p>
+ * Implementations shall ensure that the {@link Attributes#getValue(int)} method
+ * correctly returns a String object even if the attribute is represented
+ * as algorithm data.
+ * <p>
+ * If an attribute has algorithm data then the {@link #getAlgorithmData} method
+ * shall return a non <code>null</code> value.
+ *
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.FastInfosetReader
+ * @see org.xml.sax.XMLReader
+ */
+public interface EncodingAlgorithmAttributes extends Attributes {
+
+    /**
+     * Return the URI of the encoding algorithm.
+     *
+     * <p>If the algorithm data corresponds to a built-in encoding algorithm
+     *    then the null is returned.</p>
+     *
+     * <p>If the algorithm data corresponds to an application-defined encoding
+     *    algorithm then the URI of the algorithm is returned.</p>
+     *
+     * <p>If {@link #getAlgorithmData(int)} returns null then the result of
+     *    this method is undefined.<p>
+     *
+     * @param index The attribute index (zero-based).
+     * @return The URI. If the index is out of range then null is returned.
+     */
+    public String getAlgorithmURI(int index);
+
+    /**
+     * Return the index of the encoding algorithm.
+     *
+     * <p>If {@link #getAlgorithmData(int)} returns null then the result of
+     *    this method is undefined.<p>
+     *
+     * @param index The attribute index (zero-based).
+     * @return The algorithm index. If index is out of range then -1 is returned.
+     * @see com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes
+     */
+    public int getAlgorithmIndex(int index);
+
+    /**
+     * Return the data of the encoding algorithm.
+     *
+     * <p>If the algorithm data corresponds to a built-in encoding algorithm
+     *    then an Object corresponding to the Java primitive type is returned.</p>
+     *
+     * <p>If the algorithm data corresponds to an application-defined encoding
+     *    algorithm then an Object that is an instance of <code>byte[]</code>
+     *    is returned if there is no EncodingAlgorithm registered for the
+     *    application-defined encoding algorithm URI. Otherwise, an Object produced
+     *    from the registeredEncodingAlgorithm is returned.</p>
+     *
+     * <p>If there no encoding algorithm data associated an attribute then
+     *    <code>null</code> is returned.<p>
+     *
+     * @param index The attribute index (zero-based).
+     * @return The data. If the index is out of range then null is returned.
+     */
+    public Object getAlgorithmData(int index);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/EncodingAlgorithmContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/EncodingAlgorithmContentHandler.java
new file mode 100644
index 0000000..8975eb5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/EncodingAlgorithmContentHandler.java
@@ -0,0 +1,135 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset.sax;
+
+import org.xml.sax.SAXException;
+
+/**
+ * SAX2 extention handler to receive notification of encoding algorithm data.
+ *
+ * <p>This is an optional extension handler for SAX2. XML readers are not
+ * required to recognize this handler, and it is not part of core-only
+ * SAX2 distributions.</p>
+ *
+ * <p>This interface may be used with with a Fast Infoset
+ * SAX parser to receive notification of encoding algorithm data specified
+ * in ITU-T Rec. X.891 | ISO/IEC 24824-1 (Fast Infoset) clause 10 and for
+ * application defined encoding algorithms specified as part of the
+ * initial vocabulary of a fast infoset document.<p>
+ *
+ * <p>To set the EncodingAlgorithmContentHandler for an XML reader, use the
+ * {@link org.xml.sax.XMLReader#setProperty setProperty} method
+ * with the property name
+ * <code>URI TO BE DEFINED</code>
+ * and an object implementing this interface (or null) as the value.
+ * If the reader does not report primitive data types, it will throw a
+ * {@link org.xml.sax.SAXNotRecognizedException SAXNotRecognizedException}</p>
+ *
+ * <p>To set the EncodingAlgorithmContentHandler for an Fast Infoset reader, use
+ * {@link com.sun.xml.internal.org.jvnet.fastinfoset.sax.FastInfosetReader#setEncodingAlgorithmContentHandler
+ *  setEncodingAlgorithmContentHandler} method.<p>
+ *
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.PrimitiveTypeContentHandler
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.FastInfosetReader
+ * @see org.xml.sax.XMLReader
+ */
+public interface EncodingAlgorithmContentHandler {
+    /**
+     * Receive notification of encoding algorithm data as an array
+     * of byte.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing encoding algorithm data.<p>
+     *
+     * <p>The Parser will call the method of this interface to report each
+     * encoding algorithm data. Parsers MUST return all contiguous
+     * characters in a single chunk</p>
+     *
+     * <p>Parsers may return all contiguous bytes in a single chunk, or
+     * they may split it into several chunks providing that the length of
+     * each chunk is of the required length to successfully apply the
+     * encoding algorithm to the chunk.</p>
+     *
+     * @param URI the URI of the encoding algorithm
+     * @param algorithm the encoding algorithm index
+     * @param b the array of byte
+     * @param start the start position in the array
+     * @param length the number of byte to read from the array
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     * @see com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes
+     */
+    public void octets(String URI, int algorithm, byte[] b, int start, int length)  throws SAXException;
+
+    /**
+     * Receive notification of encoding algorithm data as an object.
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing encoding algorithm data that is converted from an
+     * array of byte to an object more suitable for processing.<p>
+     *
+     * @param URI the URI of the encoding algorithm
+     * @param algorithm the encoding algorithm index
+     * @param o the encoding algorithm object
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     * @see com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes
+     */
+    public void object(String URI, int algorithm, Object o)  throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/FastInfosetReader.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/FastInfosetReader.java
new file mode 100644
index 0000000..0b1871a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/FastInfosetReader.java
@@ -0,0 +1,283 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset.sax;
+
+import java.io.IOException;
+import java.io.InputStream;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetParser;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.ext.DeclHandler;
+import org.xml.sax.ext.LexicalHandler;
+
+/**
+ * Interface for reading an Fast Infoset document using callbacks.
+ *
+ * <p>FastInfosetReader is the interface that a Fast Infoset parser's
+ * SAX2 driver must implement. This interface allows an application to
+ * to register Fast Infoset specific event handlers for encoding algorithms.</p>
+ *
+ * <p>The reception of encoding algorithm events is determined by
+ * the registration of:
+ * <ul>
+ *    <li>A {@link PrimitiveTypeContentHandler}, for the recieving of events,
+ *        associated with built-in encoding algorithms, for decoded data that
+ *        can be reported as Java primitive types.</li>
+ *    <li>A {@link EncodingAlgorithmContentHandler}, for the recieving of events,
+ *        associated with built-in and application-defined encoding algorithms, for
+ *        decoded data that can be reported as an array of octets or as a Java
+ *        Object.</li>
+ *    <li>{@link com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithm} implementations, for
+ *        the receiving of events, associated with application defined algorithms.
+ *        for decoded data that shall be reported as a Java Object by way of the
+ *        registered EncodingAlgorithmContentHandler.</li>
+ * </ul>
+ * </p>
+ *
+ * <p>The reporting of element content events for built-in algorithms
+ *    is determimed by the following:
+ * <ul>
+ *    <li>If a PrimitiveContentHandler is registered then decoded data is reported
+ *        as Java primitive types using the corresponding methods on the PrimitiveContentHandler
+ *        interface.</li>
+ *    <li>If a PrimitiveContentHandler is not registered and a
+ *        EncodingAlgorithmContentHandler is registered then decoded data is reported
+ *        as Java Objects using {@link EncodingAlgorithmContentHandler#object(String, int, Object)}.
+ *        An Object shall correspond to the Java primitive type that
+ *        would otherwise be reported using the PrimitiveContentHandler.</li>
+ *    <li>If neither is registered then then decoded data is reported as characters.</li>
+ * </ul>
+ * </p>
+ *
+ * <p>The reporting of element content events for application-defined algorithms
+ *    is determimed by the following:
+ * <ul>
+ *    <li>If an EncodingAlgorithmContentHandler is registered and there is no
+ *        EncodingAlgorithm registered for an application-defined encoding algorithm
+ *        then decoded data for such an algoroithm is reported as an array of octets
+ *        using {@link EncodingAlgorithmContentHandler#octets(String, int, byte[], int, int)};
+ *        otherwise</li>
+ *    <li>If there is an EncodingAlgorithm registered for the application-defined
+ *        encoding algorithm then the decoded data is reported as a Java Object,
+ *        returned by decoding according to the EncodingAlgorithm, using
+ *        {@link EncodingAlgorithmContentHandler#object(String, int, Object)}.</li>
+ * </ul>
+ * </p>
+ *
+ * <p>The reporting of attribute values for encoding algorithms is achieved using
+ * {@link EncodingAlgorithmAttributes} that extends {@link org.xml.sax.Attributes}.
+ * The registered ContentHandler may cast the attr paramter of the
+ * {@link org.xml.sax.ContentHandler#startElement(String, String, String, org.xml.sax.Attributes)}
+ * to the EncodingAlgorithmAttributes interface to access to encoding algorithm information.
+ * </p>
+ *
+ * <p>The reporting of attribute values for built-in algorithms
+ *    is determimed by the following:
+ * <ul>
+ *    <li>If a PrimitiveContentHandler or EncodingAlgorithmContentHandler is
+ *        registered then decoded data is reported as Java Objects corresponding
+ *        to the Java primitive types. The Java Objects may be obtained using
+ *        {@link EncodingAlgorithmAttributes#getAlgorithmData(int)}.
+ *    <li>If neither is registered then then decoded data is reported as characters.</li>
+ * </ul>
+ * </p>
+ *
+ * <p>The reporting of attribute values for application-defined algorithms
+ *    is determimed by the following:
+ * <ul>
+ *    <li>If an EncodingAlgorithmContentHandler is registered and there is no
+ *        EncodingAlgorithm registered for an application-defined encoding algorithm
+ *        then decoded data for such an algoroithm is reported as Java Object,
+ *        that is an instance of <code>byte[]</code>,
+ *        using {@link EncodingAlgorithmAttributes#getAlgorithmData(int)};
+ *        otherwise</li>
+ *    <li>If there is an EncodingAlgorithm registered for the application-defined
+ *        encoding algorithm then the decoded data is reported as a Java Object,
+ *        returned by decoding according to the EncodingAlgorithm, using
+ *        {@link EncodingAlgorithmAttributes#getAlgorithmData(int)}.</li>
+ * </ul>
+ * </p>
+ *
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.PrimitiveTypeContentHandler
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.EncodingAlgorithmContentHandler
+ * @see org.xml.sax.XMLReader
+ * @see org.xml.sax.ContentHandler
+ */
+public interface FastInfosetReader extends XMLReader, FastInfosetParser {
+    /**
+     * The property name to be used for getting and setting the
+     * EncodingAlgorithmContentHandler.
+     *
+     */
+    public static final String ENCODING_ALGORITHM_CONTENT_HANDLER_PROPERTY =
+            "http://jvnet.org/fastinfoset/sax/properties/encoding-algorithm-content-handler";
+
+    /**
+     * The property name to be used for getting and setting the
+     * PrimtiveTypeContentHandler.
+     *
+     */
+    public static final String PRIMITIVE_TYPE_CONTENT_HANDLER_PROPERTY =
+            "http://jvnet.org/fastinfoset/sax/properties/primitive-type-content-handler";
+
+    /**
+     * Parse a fast infoset document from an InputStream.
+     *
+     * <p>The application can use this method to instruct the Fast Infoset
+     * reader to begin parsing a fast infoset document from a byte stream.</p>
+     *
+     * <p>Applications may not invoke this method while a parse is in progress
+     * (they should create a new XMLReader instead for each nested XML document).
+     * Once a parse is complete, an application may reuse the same
+     * FastInfosetReader object, possibly with a different byte stream.</p>
+     *
+     * <p>During the parse, the FastInfosetReader will provide information about
+     * the fast infoset document through the registered event handlers.<p>
+     *
+     * <p> This method is synchronous: it will not return until parsing has ended.
+     * If a client application wants to terminate parsing early, it should throw
+     * an exception.<p>
+     *
+     * @param s The byte stream to parse from.
+     */
+    public void parse(InputStream s) throws IOException, FastInfosetException, SAXException;
+
+    /**
+     * Allow an application to register a lexical handler.
+     *
+     * <p>Applications may register a new or different handler in the
+     * middle of a parse, and the SAX parser must begin using the new
+     * handler immediately.</p>
+     *
+     * @param handler The lexical handler.
+     * @see #getLexicalHandler
+     */
+    public void setLexicalHandler(LexicalHandler handler);
+
+    /**
+     * Return the current lexical handler.
+     *
+     * @return The current lexical handler, or null if none
+     *         has been registered.
+     * @see #setLexicalHandler
+     */
+    public LexicalHandler getLexicalHandler();
+
+    /**
+     * Allow an application to register a DTD declaration handler.
+     *
+     * <p>Applications may register a new or different handler in the
+     * middle of a parse, and the SAX parser must begin using the new
+     * handler immediately.</p>
+     *
+     * @param handler The DTD declaration handler.
+     * @see #getLexicalHandler
+     */
+    public void setDeclHandler(DeclHandler handler);
+
+    /**
+     * Return the current DTD declaration handler.
+     *
+     * @return The current DTD declaration handler, or null if none
+     *         has been registered.
+     * @see #setLexicalHandler
+     */
+    public DeclHandler getDeclHandler();
+
+    /**
+     * Allow an application to register an encoding algorithm handler.
+     *
+     * <p>Applications may register a new or different handler in the
+     * middle of a parse, and the SAX parser must begin using the new
+     * handler immediately.</p>
+     *
+     * @param handler The encoding algorithm handler.
+     * @see #getEncodingAlgorithmContentHandler
+     */
+    public void setEncodingAlgorithmContentHandler(EncodingAlgorithmContentHandler handler);
+
+    /**
+     * Return the current encoding algorithm handler.
+     *
+     * @return The current encoding algorithm handler, or null if none
+     *         has been registered.
+     * @see #setEncodingAlgorithmContentHandler
+     */
+    public EncodingAlgorithmContentHandler getEncodingAlgorithmContentHandler();
+
+    /**
+     * Allow an application to register a primitive type handler.
+     *
+     * <p>Applications may register a new or different handler in the
+     * middle of a parse, and the SAX parser must begin using the new
+     * handler immediately.</p>
+     *
+     * @param handler The primitive type handler.
+     * @see #getPrimitiveTypeContentHandler
+     */
+    public void setPrimitiveTypeContentHandler(PrimitiveTypeContentHandler handler);
+
+
+    /**
+     * Return the current primitive type handler.
+     *
+     * @return The current primitive type handler, or null if none
+     *         has been registered.
+     * @see #setPrimitiveTypeContentHandler
+     */
+    public PrimitiveTypeContentHandler getPrimitiveTypeContentHandler();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/FastInfosetWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/FastInfosetWriter.java
new file mode 100644
index 0000000..5ff2c89
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/FastInfosetWriter.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset.sax;
+
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSerializer;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.ext.LexicalHandler;
+
+public interface FastInfosetWriter extends ContentHandler, LexicalHandler,
+        EncodingAlgorithmContentHandler, PrimitiveTypeContentHandler,
+        RestrictedAlphabetContentHandler, FastInfosetSerializer {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/PrimitiveTypeContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/PrimitiveTypeContentHandler.java
new file mode 100644
index 0000000..17021a6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/PrimitiveTypeContentHandler.java
@@ -0,0 +1,251 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset.sax;
+
+import org.xml.sax.SAXException;
+
+/**
+ * SAX2 extention handler to receive notification of character data as
+ * primtive types.
+ *
+ * <p>This is an optional extension handler for SAX2. XML readers are not
+ * required to recognize this handler, and it is not part of core-only
+ * SAX2 distributions.</p>
+ *
+ * <p>This interface may be used with with a Fast Infoset
+ * SAX parser to receive notification of data encoded using the
+ * following built-in encoding algorithms specified in ITU-T Rec. X.891 | ISO/IEC 24824-1
+ * (Fast Infoset), clause 10: "boolean", "base64", "short", "int", "long",
+ * "float", "double" and "uuid" encoding algorithms.<p>
+ *
+ * <p>To set the PrimitiveTypeContentHandler for an XML reader, use the
+ * {@link org.xml.sax.XMLReader#setProperty setProperty} method
+ * with the property name
+ * <code>URI TO BE DEFINED</code>
+ * and an object implementing this interface (or null) as the value.
+ * If the reader does not report primitive data types, it will throw a
+ * {@link org.xml.sax.SAXNotRecognizedException SAXNotRecognizedException}</p>
+ *
+ * <p>To set the PrimitiveTypeContentHandler for an Fast Infoset reader, use
+ * {@link com.sun.xml.internal.org.jvnet.fastinfoset.sax.FastInfosetReader#setPrimitiveTypeContentHandler
+ *  setPrimitiveTypeContentHandler} method.<p>
+
+ * <p>The Parser will call methods of this interface to report each
+ * chunk of character data that has been converted to an array of primitive
+ * types, for example an array of integer or an array of float. Parsers may
+ * return all contiguous primtive types in a single chunk, or they may split
+ * it into several chunks</p>
+ *
+ * <p>The application must not attempt to read from the array
+ * outside of the specified range.</p>
+ *
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.EncodingAlgorithmContentHandler
+ * @see com.sun.xml.internal.org.jvnet.fastinfoset.sax.FastInfosetReader
+ * @see org.xml.sax.XMLReader
+ */
+public interface PrimitiveTypeContentHandler {
+    /**
+     * Receive notification of character data as an array of boolean.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing data encoded using the "boolean" encoding
+     * algorithm, see subclause 10.7<p>.
+     *
+     * @param b the array of boolean
+     * @param start the start position in the array
+     * @param length the number of boolean to read from the array
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     */
+    public void booleans(boolean [] b, int start, int length) throws SAXException;
+
+    /**
+     * Receive notification of character data as an array of byte.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing data encoded using the "base64" encoding
+     * algorithm, see subclause 10.3, or the "hexadecimal" encoding
+     * algorithm, see subclause 10.2.
+     *
+     * <p>Such a notification may occur for binary data that would
+     * normally require base 64 encoding and reported as character data
+     * using the {@link org.xml.sax.ContentHandler#characters characters}
+     * method <p>.
+     *
+     * @param b the array of byte
+     * @param start the start position in the array
+     * @param length the number of byte to read from the array
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     */
+    public void bytes(byte[] b, int start, int length) throws SAXException;
+
+    /**
+     * Receive notification of character data as an array of short.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing data encoded using the "short" encoding
+     * algorithm, see subclause 10.4<p>.
+     *
+     * @param s the array of short
+     * @param start the start position in the array
+     * @param length the number of short to read from the array
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     */
+    public void shorts(short[] s, int start, int length) throws SAXException;
+
+    /**
+     * Receive notification of character data as an array of int.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing data encoded using the "int" encoding
+     * algorithm, see subclause 10.5<p>.
+     *
+     * @param i the array of int
+     * @param start the start position in the array
+     * @param length the number of int to read from the array
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     */
+    public void ints(int [] i, int start, int length) throws SAXException;
+
+    /**
+     * Receive notification of character data as an array of long.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing data encoded using the "long" encoding
+     * algorithm, see subclause 10.6<p>.
+     *
+     * @param l the array of long
+     * @param start the start position in the array
+     * @param length the number of long to read from the array
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     */
+    public void longs(long [] l, int start, int length) throws SAXException;
+
+    /**
+     * Receive notification of character data as an array of float.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing data encoded using the "float" encoding
+     * algorithm, see subclause 10.8<p>.
+     *
+     * @param f the array of float
+     * @param start the start position in the array
+     * @param length the number of float to read from the array
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     */
+    public void floats(float [] f, int start, int length) throws SAXException;
+
+    /**
+     * Receive notification of character data as an array of double.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing data encoded using the "double" encoding
+     * algorithm, see subclause 10.9<p>.
+     *
+     * @param d the array of double
+     * @param start the start position in the array
+     * @param length the number of double to read from the array
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     */
+    public void doubles(double [] d, int start, int length) throws SAXException;
+
+    /**
+     * Receive notification of character data as an two array of UUID.
+     *
+     * <p>The application must not attempt to read from the array
+     * outside of the specified range.</p>
+     *
+     * <p>Such notifications will occur for a Fast Infoset SAX parser
+     * when processing data encoded using the "uuid" encoding
+     * algorithm, see subclause 10.10<p>.
+     *
+     * @param msblsb the array of long containing pairs of most signficant
+     * bits and least significant bits of the UUIDs
+     * @param start the start position in the array
+     * @param length the number of long to read from the array. This will
+     * be twice the number of UUIDs, which are pairs of two long values
+     * @throws org.xml.sax.SAXException any SAX exception, possibly
+     *            wrapping another exception
+     */
+    public void uuids(long[] msblsb, int start, int length) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/RestrictedAlphabetContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/RestrictedAlphabetContentHandler.java
new file mode 100644
index 0000000..f60bc6a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/RestrictedAlphabetContentHandler.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+package com.sun.xml.internal.org.jvnet.fastinfoset.sax;
+
+import org.xml.sax.SAXException;
+
+public interface RestrictedAlphabetContentHandler {
+
+    public void numericCharacters(char ch[], int start, int length) throws SAXException;
+
+    public void dateTimeCharacters(char ch[], int start, int length) throws SAXException;
+
+    public void alphabetCharacters(String alphabet, char ch[], int start, int length) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/helpers/EncodingAlgorithmAttributesImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/helpers/EncodingAlgorithmAttributesImpl.java
new file mode 100644
index 0000000..24e1bda
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/helpers/EncodingAlgorithmAttributesImpl.java
@@ -0,0 +1,552 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+package com.sun.xml.internal.org.jvnet.fastinfoset.sax.helpers;
+
+import com.sun.xml.internal.fastinfoset.CommonResourceBundle;
+import com.sun.xml.internal.fastinfoset.EncodingConstants;
+import com.sun.xml.internal.fastinfoset.algorithm.BuiltInEncodingAlgorithmFactory;
+import java.io.IOException;
+import java.util.Map;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithm;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.EncodingAlgorithmIndexes;
+import com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetException;
+import com.sun.xml.internal.org.jvnet.fastinfoset.sax.EncodingAlgorithmAttributes;
+import org.xml.sax.Attributes;
+
+/**
+ * Default implementation of the {@link EncodingAlgorithmAttributes} interface.
+ *
+ * <p>This class provides a default implementation of the SAX2
+ * {@link EncodingAlgorithmAttributes} interface, with the
+ * addition of manipulators so that the list can be modified or
+ * reused.</p>
+ *
+ * <p>There are two typical uses of this class:</p>
+ *
+ * <ol>
+ * <li>to take a persistent snapshot of an EncodingAlgorithmAttributes object
+ *  in a {@link org.xml.sax.ContentHandler#startElement startElement} event; or</li>
+ * <li>to construct or modify an EncodingAlgorithmAttributes object in a SAX2
+ * driver or filter.</li>
+ * </ol>
+ */
+public class EncodingAlgorithmAttributesImpl implements EncodingAlgorithmAttributes {
+    private static final int DEFAULT_CAPACITY       = 8;
+
+    private static final int URI_OFFSET             = 0;
+    private static final int LOCALNAME_OFFSET       = 1;
+    private static final int QNAME_OFFSET           = 2;
+    private static final int TYPE_OFFSET            = 3;
+    private static final int VALUE_OFFSET           = 4;
+    private static final int ALGORITHMURI_OFFSET    = 5;
+
+    private static final int SIZE                   = 6;
+
+    private Map _registeredEncodingAlgorithms;
+
+    private int _length;
+
+    private String[] _data;
+
+    private int[] _algorithmIds;
+
+    private Object[] _algorithmData;
+
+    /**
+     * Construct a new, empty EncodingAlgorithmAttributesImpl object.
+     */
+    public EncodingAlgorithmAttributesImpl() {
+        this(null, null);
+    }
+
+    /**
+     * Copy an existing Attributes object.
+     *
+     * <p>This constructor is especially useful inside a
+     * {@link org.xml.sax.ContentHandler#startElement startElement} event.</p>
+     *
+     * @param attributes The existing Attributes object.
+     */
+    public EncodingAlgorithmAttributesImpl(Attributes attributes) {
+        this(null, attributes);
+    }
+
+    /**
+     * Use registered encoding algorithms and copy an existing Attributes object.
+     *
+     * <p>This constructor is especially useful inside a
+     * {@link org.xml.sax.ContentHandler#startElement startElement} event.</p>
+     *
+     * @param registeredEncodingAlgorithms
+     *      The registeredEncodingAlgorithms encoding algorithms.
+     * @param attributes The existing Attributes object.
+     */
+    public EncodingAlgorithmAttributesImpl(Map registeredEncodingAlgorithms,
+            Attributes attributes) {
+        _data = new String[DEFAULT_CAPACITY * SIZE];
+        _algorithmIds = new int[DEFAULT_CAPACITY];
+        _algorithmData = new Object[DEFAULT_CAPACITY];
+
+        _registeredEncodingAlgorithms = registeredEncodingAlgorithms;
+
+        if (attributes != null) {
+            if (attributes instanceof EncodingAlgorithmAttributes) {
+                setAttributes((EncodingAlgorithmAttributes)attributes);
+            } else {
+                setAttributes(attributes);
+            }
+        }
+    }
+
+    /**
+     * Clear the attribute list for reuse.
+     *
+     */
+    public final void clear() {
+        for (int i = 0; i < _length; i++) {
+            _data[i * SIZE + VALUE_OFFSET] = null;
+            _algorithmData[i] = null;
+        }
+        _length = 0;
+    }
+
+    /**
+     * Add an attribute to the end of the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * to see if the attribute is already in the list: that is
+     * the responsibility of the application.</p>
+     *
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified (prefixed) name, or the empty string
+     *        if qualified names are not available.
+     * @param type The attribute type as a string.
+     * @param value The attribute value.
+     */
+    public void addAttribute(String URI, String localName, String qName,
+            String type, String value) {
+        if (_length >= _algorithmData.length) {
+            resize();
+        }
+
+        int i = _length * SIZE;
+        _data[i++] = replaceNull(URI);
+        _data[i++] = replaceNull(localName);
+        _data[i++] = replaceNull(qName);
+        _data[i++] = replaceNull(type);
+        _data[i++] = replaceNull(value);
+
+        _length++;
+    }
+
+    /**
+     * Add an attribute with built in algorithm data to the end of the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * to see if the attribute is already in the list: that is
+     * the responsibility of the application.</p>
+     *
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified (prefixed) name, or the empty string
+     *        if qualified names are not available.
+     * @param builtInAlgorithmID The built in algorithm ID.
+     * @param algorithmData The built in algorithm data.
+     */
+    public void addAttributeWithBuiltInAlgorithmData(String URI, String localName, String qName,
+            int builtInAlgorithmID, Object algorithmData) {
+        if (_length >= _algorithmData.length) {
+            resize();
+        }
+
+        int i = _length * SIZE;
+        _data[i++] = replaceNull(URI);
+        _data[i++] = replaceNull(localName);
+        _data[i++] = replaceNull(qName);
+        _data[i++] = "CDATA";
+        _data[i++] = "";
+        _data[i++] = null;
+        _algorithmIds[_length] = builtInAlgorithmID;
+        _algorithmData[_length] = algorithmData;
+
+        _length++;
+    }
+
+    /**
+     * Add an attribute with algorithm data to the end of the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * to see if the attribute is already in the list: that is
+     * the responsibility of the application.</p>
+     *
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified (prefixed) name, or the empty string
+     *        if qualified names are not available.
+     * @param algorithmURI The algorithm URI, or null if a built in algorithm
+     * @param algorithmID The algorithm ID.
+     * @param algorithmData The algorithm data.
+     */
+    public void addAttributeWithAlgorithmData(String URI, String localName, String qName,
+            String algorithmURI, int algorithmID, Object algorithmData) {
+        if (_length >= _algorithmData.length) {
+            resize();
+        }
+
+        int i = _length * SIZE;
+        _data[i++] = replaceNull(URI);
+        _data[i++] = replaceNull(localName);
+        _data[i++] = replaceNull(qName);
+        _data[i++] = "CDATA";
+        _data[i++] = "";
+        _data[i++] = algorithmURI;
+        _algorithmIds[_length] = algorithmID;
+        _algorithmData[_length] = algorithmData;
+
+        _length++;
+    }
+
+    /**
+     * Replace an attribute value with algorithm data.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * to see if the attribute is already in the list: that is
+     * the responsibility of the application.</p>
+     *
+     * @param index The index of the attribute whose value is to be replaced
+     * @param algorithmURI The algorithm URI, or null if a built in algorithm
+     * @param algorithmID The algorithm ID.
+     * @param algorithmData The algorithm data.
+     */
+    public void replaceWithAttributeAlgorithmData(int index,
+            String algorithmURI, int algorithmID, Object algorithmData) {
+        if (index < 0 || index >= _length) return;
+
+        int i = index * SIZE;
+        _data[i + VALUE_OFFSET] = null;
+        _data[i + ALGORITHMURI_OFFSET] = algorithmURI;
+        _algorithmIds[index] = algorithmID;
+        _algorithmData[index] = algorithmData;
+    }
+
+    /**
+     * Copy an entire Attributes object.
+     *
+     * @param atts The attributes to copy.
+     */
+    public void setAttributes(Attributes atts) {
+        _length = atts.getLength();
+        if (_length > 0) {
+
+            if (_length >= _algorithmData.length) {
+                resizeNoCopy();
+            }
+
+            int index = 0;
+            for (int i = 0; i < _length; i++) {
+                _data[index++] = atts.getURI(i);
+                _data[index++] = atts.getLocalName(i);
+                _data[index++] = atts.getQName(i);
+                _data[index++] = atts.getType(i);
+                _data[index++] = atts.getValue(i);
+                index++;
+            }
+        }
+    }
+
+    /**
+     * Copy an entire EncodingAlgorithmAttributes object.
+     *
+     * @param atts The attributes to copy.
+     */
+    public void setAttributes(EncodingAlgorithmAttributes atts) {
+        _length = atts.getLength();
+        if (_length > 0) {
+
+            if (_length >= _algorithmData.length) {
+                resizeNoCopy();
+            }
+
+            int index = 0;
+            for (int i = 0; i < _length; i++) {
+                _data[index++] = atts.getURI(i);
+                _data[index++] = atts.getLocalName(i);
+                _data[index++] = atts.getQName(i);
+                _data[index++] = atts.getType(i);
+                _data[index++] = atts.getValue(i);
+                _data[index++] = atts.getAlgorithmURI(i);
+                _algorithmIds[i] = atts.getAlgorithmIndex(i);
+                _algorithmData[i] = atts.getAlgorithmData(i);
+            }
+        }
+    }
+
+    // org.xml.sax.Attributes
+
+    public final int getLength() {
+        return _length;
+    }
+
+    public final String getLocalName(int index) {
+        if (index >= 0 && index < _length) {
+            return _data[index * SIZE + LOCALNAME_OFFSET];
+        } else {
+            return null;
+        }
+    }
+
+    public final String getQName(int index) {
+        if (index >= 0 && index < _length) {
+            return _data[index * SIZE + QNAME_OFFSET];
+        } else {
+            return null;
+        }
+    }
+
+    public final String getType(int index) {
+        if (index >= 0 && index < _length) {
+            return _data[index * SIZE + TYPE_OFFSET];
+        } else {
+            return null;
+        }
+    }
+
+    public final String getURI(int index) {
+        if (index >= 0 && index < _length) {
+            return _data[index * SIZE + URI_OFFSET];
+        } else {
+            return null;
+        }
+    }
+
+    public final String getValue(int index) {
+        if (index >= 0 && index < _length) {
+            final String value = _data[index * SIZE + VALUE_OFFSET];
+            if (value != null) return value;
+        } else {
+            return null;
+        }
+
+        if (_algorithmData[index] == null || _registeredEncodingAlgorithms == null) {
+            return null;
+        }
+
+        try {
+            return _data[index * SIZE + VALUE_OFFSET] = convertEncodingAlgorithmDataToString(
+                    _algorithmIds[index],
+                    _data[index * SIZE + ALGORITHMURI_OFFSET],
+                    _algorithmData[index]).toString();
+        } catch (IOException e) {
+            return null;
+        } catch (FastInfosetException e) {
+            return null;
+        }
+    }
+
+    public final int getIndex(String qName) {
+        for (int index = 0; index < _length; index++) {
+            if (qName.equals(_data[index * SIZE + QNAME_OFFSET])) {
+                return index;
+            }
+        }
+        return -1;
+    }
+
+    public final String getType(String qName) {
+        int index = getIndex(qName);
+        if (index >= 0) {
+            return _data[index * SIZE + TYPE_OFFSET];
+        } else {
+            return null;
+        }
+    }
+
+    public final String getValue(String qName) {
+        int index = getIndex(qName);
+        if (index >= 0) {
+            return getValue(index);
+        } else {
+            return null;
+        }
+    }
+
+    public final int getIndex(String uri, String localName) {
+        for (int index = 0; index < _length; index++) {
+            if (localName.equals(_data[index * SIZE + LOCALNAME_OFFSET]) &&
+                    uri.equals(_data[index * SIZE + URI_OFFSET])) {
+                return index;
+            }
+        }
+        return -1;
+    }
+
+    public final String getType(String uri, String localName) {
+        int index = getIndex(uri, localName);
+        if (index >= 0) {
+            return _data[index * SIZE + TYPE_OFFSET];
+        } else {
+            return null;
+        }
+    }
+
+    public final String getValue(String uri, String localName) {
+        int index = getIndex(uri, localName);
+        if (index >= 0) {
+            return getValue(index);
+        } else {
+            return null;
+        }
+    }
+
+    // EncodingAlgorithmAttributes
+
+    public final String getAlgorithmURI(int index) {
+        if (index >= 0 && index < _length) {
+            return _data[index * SIZE + ALGORITHMURI_OFFSET];
+        } else {
+            return null;
+        }
+    }
+
+    public final int getAlgorithmIndex(int index) {
+        if (index >= 0 && index < _length) {
+            return _algorithmIds[index];
+        } else {
+            return -1;
+        }
+    }
+
+    public final Object getAlgorithmData(int index) {
+        if (index >= 0 && index < _length) {
+            return _algorithmData[index];
+        } else {
+            return null;
+        }
+    }
+
+
+    // -----
+
+    private final String replaceNull(String s) {
+        return (s != null) ? s : "";
+    }
+
+    private final void resizeNoCopy() {
+        final int newLength = _length * 3 / 2 + 1;
+
+        _data = new String[newLength * SIZE];
+        _algorithmIds = new int[newLength];
+        _algorithmData = new Object[newLength];
+    }
+
+    private final void resize() {
+        final int newLength = _length * 3 / 2 + 1;
+
+        String[] data = new String[newLength * SIZE];
+        int[] algorithmIds = new int[newLength];
+        Object[] algorithmData = new Object[newLength];
+
+        System.arraycopy(_data, 0, data, 0, _length * SIZE);
+        System.arraycopy(_algorithmIds, 0, algorithmIds, 0, _length);
+        System.arraycopy(_algorithmData, 0, algorithmData, 0, _length);
+
+        _data = data;
+        _algorithmIds = algorithmIds;
+        _algorithmData = algorithmData;
+    }
+
+    private final StringBuffer convertEncodingAlgorithmDataToString(
+            int identifier, String URI, Object data) throws FastInfosetException, IOException {
+        EncodingAlgorithm ea = null;
+        if (identifier < EncodingConstants.ENCODING_ALGORITHM_BUILTIN_END) {
+            ea = BuiltInEncodingAlgorithmFactory.table[identifier];
+        } else if (identifier == EncodingAlgorithmIndexes.CDATA) {
+            throw new EncodingAlgorithmException(
+                    CommonResourceBundle.getInstance().getString("message.CDATAAlgorithmNotSupported"));
+        } else if (identifier >= EncodingConstants.ENCODING_ALGORITHM_APPLICATION_START) {
+            if (URI == null) {
+                throw new EncodingAlgorithmException(
+                        CommonResourceBundle.getInstance().getString("message.URINotPresent") + identifier);
+            }
+
+            ea = (EncodingAlgorithm)_registeredEncodingAlgorithms.get(URI);
+            if (ea == null) {
+                throw new EncodingAlgorithmException(
+                        CommonResourceBundle.getInstance().getString("message.algorithmNotRegistered") + URI);
+            }
+        } else {
+            // Reserved built-in algorithms for future use
+            // TODO should use sax property to decide if event will be
+            // reported, allows for support through handler if required.
+            throw new EncodingAlgorithmException(
+                    CommonResourceBundle.getInstance().getString("message.identifiers10to31Reserved"));
+        }
+
+        final StringBuffer sb = new StringBuffer();
+        ea.convertToCharacters(data, sb);
+        return sb;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/helpers/FastInfosetDefaultHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/helpers/FastInfosetDefaultHandler.java
new file mode 100644
index 0000000..50b8723
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/org/jvnet/fastinfoset/sax/helpers/FastInfosetDefaultHandler.java
@@ -0,0 +1,140 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ */
+
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ *
+ * THIS FILE WAS MODIFIED BY SUN MICROSYSTEMS, INC.
+ *
+ */
+
+
+package com.sun.xml.internal.org.jvnet.fastinfoset.sax.helpers;
+
+import com.sun.xml.internal.org.jvnet.fastinfoset.sax.*;
+import org.xml.sax.SAXException;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.DefaultHandler;
+
+/**
+ * Default base class for SAX event handlers of a {@link FastInfosetReader}.
+ * <p>
+ * This class is available as a convenience for applications: it provides
+ * default implementations for all of the callbacks of the following:
+ * <UL>
+ *   <LI>{@link DefaultHandler}</LI>
+ *   <LI>{@link LexicalHandler}</LI>
+ *   <LI>{@link EncodingAlgorithmContentHandler}</LI>
+ *   <LI>{@link PrimitiveTypeContentHandler}</LI>
+ * </UL>
+ * Application writers can extend this class when they need to implement only
+ * part of an interface; parser writers can instantiate this class to provide
+ * default handlers when the application has not supplied its own.
+ */
+public class FastInfosetDefaultHandler extends DefaultHandler implements
+        LexicalHandler, EncodingAlgorithmContentHandler, PrimitiveTypeContentHandler {
+
+    // LexicalHandler
+
+    public void comment(char[] ch, int start, int length) throws SAXException {
+    }
+
+    public void startCDATA() throws SAXException {
+    }
+
+    public void endCDATA() throws SAXException {
+    }
+
+    public void startDTD(String name, String publicId, String systemId) throws SAXException {
+    }
+
+    public void endDTD() throws SAXException {
+    }
+
+    public void startEntity(String name) throws SAXException {
+    }
+
+    public void endEntity(String name) throws SAXException {
+    }
+
+
+    // EncodingAlgorithmContentHandler
+
+    public void octets(String URI, int algorithm, byte[] b, int start, int length)  throws SAXException {
+    }
+
+    public void object(String URI, int algorithm, Object o)  throws SAXException {
+    }
+
+
+    // PrimitiveTypeContentHandler
+
+    public void booleans(boolean[] b, int start, int length) throws SAXException {
+    }
+
+    public void bytes(byte[] b, int start, int length) throws SAXException {
+    }
+
+    public void shorts(short[] s, int start, int length) throws SAXException {
+    }
+
+    public void ints(int[] i, int start, int length) throws SAXException {
+    }
+
+    public void longs(long[] l, int start, int length) throws SAXException {
+    }
+
+    public void floats(float[] f, int start, int length) throws SAXException {
+    }
+
+    public void doubles(double[] d, int start, int length) throws SAXException {
+    }
+
+    public void uuids(long[] msblsb, int start, int length) throws SAXException {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Annotations.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Annotations.java
new file mode 100644
index 0000000..3e6f4b4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Annotations.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+
+/**
+ * Includes attributes and child elements before any RELAX NG element.
+ */
+public interface Annotations<
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    CL extends CommentList<L>> {
+
+    /**
+     * Called for an attribute annotation.
+     */
+    void addAttribute(String ns, String localName, String prefix, String value, L loc) throws BuildException;
+
+    /**
+     * Called for a child element annotation.
+     */
+    void addElement(E ea) throws BuildException;
+
+    /**
+     * Adds comments following the last initial child element annotation.
+     */
+    void addComment(CL comments) throws BuildException;
+
+    void addLeadingComment(CL comments) throws BuildException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/BuildException.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/BuildException.java
new file mode 100644
index 0000000..3b62400
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/BuildException.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+/**
+ * Signals an error while building schemas.
+ *
+ * <p>
+ * Only {@link SchemaBuilder} can throw this exception to
+ * abort the parsing in the middle.
+ */
+public class BuildException extends RuntimeException {
+    private final Throwable cause;
+    public BuildException(Throwable cause) {
+        if (cause == null)
+            throw new NullPointerException("null cause");
+        this.cause = cause;
+    }
+
+    public Throwable getCause() {
+        return cause;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/CommentList.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/CommentList.java
new file mode 100644
index 0000000..39c2879
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/CommentList.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+
+
+public interface CommentList<L extends Location> {
+  void addComment(String value, L loc) throws BuildException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/DataPatternBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/DataPatternBuilder.java
new file mode 100644
index 0000000..6826c32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/DataPatternBuilder.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.*;
+
+
+public interface DataPatternBuilder<
+    P extends ParsedPattern,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L>> {
+
+  void addParam(String name, String value, Context context, String ns, L loc, A anno) throws BuildException;
+  void annotation(E ea);
+  P makePattern(L loc, A anno) throws BuildException;
+  P makePattern(P except, L loc, A anno) throws BuildException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Div.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Div.java
new file mode 100644
index 0000000..759c324
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Div.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+
+public interface Div<
+        P extends ParsedPattern,
+        E extends ParsedElementAnnotation,
+        L extends Location,
+        A extends Annotations<E,L,CL>,
+        CL extends CommentList<L>> extends GrammarSection<P,E,L,A,CL> {
+  void endDiv(L loc, A anno) throws BuildException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/ElementAnnotationBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/ElementAnnotationBuilder.java
new file mode 100644
index 0000000..9e52d48
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/ElementAnnotationBuilder.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+
+/**
+ * Used to build foreign element annotations.
+ */
+public interface ElementAnnotationBuilder<
+    P extends ParsedPattern,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L>> extends Annotations<E,L,CL> {
+
+    /**
+     * Called when a child text is found.
+     */
+    void addText(String value, L loc, CL comments) throws BuildException;
+
+    /**
+     * Called at the end to build an application data structure.
+     */
+    E makeElementAnnotation() throws BuildException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Grammar.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Grammar.java
new file mode 100644
index 0000000..c6658d0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Grammar.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+/**
+ * {@link Scope} for &lt;grammar> element that serves as a container
+ * of &lt;define>s.
+ */
+public interface Grammar<
+    P extends ParsedPattern,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L>> extends GrammarSection<P,E,L,A,CL>, Scope<P,E,L,A,CL> {
+    P endGrammar(L loc, A anno) throws BuildException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/GrammarSection.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/GrammarSection.java
new file mode 100644
index 0000000..caf78e0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/GrammarSection.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+
+/**
+ * The container that can have &lt;define> elements.
+ * <p>
+ * {@link Div}, {@link Grammar}, {@link Include}, or {@link IncludedGrammar}.
+ */
+public interface GrammarSection<
+    P extends ParsedPattern,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L>> {
+
+    static final class Combine {
+        private final String name;
+        private Combine(String name) {
+            this.name = name;
+        }
+        final public String toString() {
+            return name;
+        }
+    }
+
+    static final Combine COMBINE_CHOICE = new Combine("choice");
+    static final Combine COMBINE_INTERLEAVE = new Combine("interleave");
+
+    // using \u0000 guarantees that the name will be never used as
+    // a user-defined pattern name.
+    static final String START = "\u0000#start\u0000";
+
+    /**
+     * Called when a pattern is defined.
+     *
+     * @param name
+     *      Name of the pattern. For the definition by a &lt;start/> element,
+     *      this parameter is the same as {@link #START}.
+     *      to test if it's a named pattern definition or the start pattern definition.
+     * @param combine
+     *      null or {@link #COMBINE_CHOICE} or {@link #COMBINE_INTERLEAVE} depending
+     *      on the value of the combine attribute.
+     * @param pattern
+     *      The pattern to be defined.
+     */
+    void define( String name, Combine combine, P pattern, L loc, A anno) throws BuildException;
+
+    /**
+     * Called when an annotation is found.
+     */
+    void topLevelAnnotation(E ea) throws BuildException;
+
+    /**
+     * Called when a comment is found.
+     */
+    void topLevelComment(CL comments) throws BuildException;
+
+    /**
+     * Called when &lt;div> is found.
+     *
+     * @return
+     *      the returned {@link Div} object will receive callbacks for structures
+     *      inside the &lt;div> element.
+     */
+    Div<P,E,L,A,CL> makeDiv();
+
+    /**
+     * Returns null if already in an include.
+     */
+    Include<P,E,L,A,CL> makeInclude();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Include.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Include.java
new file mode 100644
index 0000000..7acbce7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Include.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+
+public interface Include<
+    P extends ParsedPattern,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L>> extends GrammarSection<P,E,L,A,CL> {
+    /**
+     * @param current
+     *      The current document we are parsing.
+     *      This is the document that contains an include.
+     */
+  void endInclude(Parseable current, String uri, String ns,
+                  L loc, A anno) throws BuildException, IllegalSchemaException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/IncludedGrammar.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/IncludedGrammar.java
new file mode 100644
index 0000000..f7ff878
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/IncludedGrammar.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.parse.Parseable;
+
+/**
+ * {@link Scope} for &lt;grammar> element of the &lt;include>d grammar.
+ * <p>
+ * This object builds &lt;define>s in the included grammar that
+ * override the definitions in the original grammar.
+ */
+public interface IncludedGrammar<
+    P extends ParsedPattern,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L>> extends GrammarSection<P,E,L,A,CL>, Scope<P,E,L,A,CL> {
+
+    /**
+     *
+     * @return
+     *      technically, an included gramamr does not produce a pattern,
+     *      but this allows {@link Parseable#parseInclude(String, SchemaBuilder, IncludedGrammar, String)}
+     *      to return the result from {@link IncludedGrammar} nicely.
+     *
+     *      <p>
+     *      The value returned from this method will be returned from the abovementioned method.
+     */
+    P endIncludedGrammar(L loc, A anno) throws BuildException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/NameClassBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/NameClassBuilder.java
new file mode 100644
index 0000000..8a342a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/NameClassBuilder.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+
+import java.util.List;
+
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface NameClassBuilder<
+    N extends ParsedNameClass,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L> > {
+
+    N annotate(N nc, A anno) throws BuildException;
+    N annotateAfter(N nc, E e) throws BuildException;
+    N commentAfter(N nc, CL comments) throws BuildException;
+    N makeChoice(List<N> nameClasses, L loc, A anno);
+
+// should be handled by parser - KK
+//    static final String INHERIT_NS = new String("#inherit");
+
+// similarly, xmlns:* attribute should be rejected by the parser -KK
+
+    N makeName(String ns, String localName, String prefix, L loc, A anno);
+    N makeNsName(String ns, L loc, A anno);
+    /**
+     * Caller must enforce constraints on except.
+     */
+    N makeNsName(String ns, N except, L loc, A anno);
+    N makeAnyName(L loc, A anno);
+    /**
+     * Caller must enforce constraints on except.
+     */
+    N makeAnyName(N except, L loc, A anno);
+
+    N makeErrorNameClass();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/SchemaBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/SchemaBuilder.java
new file mode 100644
index 0000000..cd20f03
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/SchemaBuilder.java
@@ -0,0 +1,182 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.*;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+
+import java.util.List;
+
+// TODO: define combine error check should be done by the parser.
+public interface SchemaBuilder<
+    N extends ParsedNameClass,
+    P extends ParsedPattern,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L>> {
+
+    /**
+     * Returns the {@link NameClassBuilder}, which is used to build name
+     * classes for this {@link SchemaBuilder}. The
+     * {@link com.sun.xml.internal.rngom.nc.NameClass}es that are built will then be
+     * fed into this {@link SchemaBuilder}to further build RELAX NG patterns.
+     *
+     * @return always return a non-null valid object. This method can (and
+     *         probably should) always return the same object.
+     */
+    NameClassBuilder<N,E,L,A,CL> getNameClassBuilder() throws BuildException;
+
+    P makeChoice(List<P> patterns, L loc, A anno) throws BuildException;
+
+    P makeInterleave(List<P> patterns, L loc, A anno) throws BuildException;
+
+    P makeGroup(List<P> patterns, L loc, A anno) throws BuildException;
+
+    P makeOneOrMore(P p, L loc, A anno) throws BuildException;
+
+    P makeZeroOrMore(P p, L loc, A anno) throws BuildException;
+
+    P makeOptional(P p, L loc, A anno) throws BuildException;
+
+    P makeList(P p, L loc, A anno) throws BuildException;
+
+    P makeMixed(P p, L loc, A anno) throws BuildException;
+
+    P makeEmpty(L loc, A anno);
+
+    P makeNotAllowed(L loc, A anno);
+
+    P makeText(L loc, A anno);
+
+    P makeAttribute(N nc, P p, L loc, A anno) throws BuildException;
+
+    P makeElement(N nc, P p, L loc, A anno) throws BuildException;
+
+    DataPatternBuilder makeDataPatternBuilder(String datatypeLibrary, String type, L loc) throws BuildException;
+
+    P makeValue(String datatypeLibrary, String type, String value,
+            Context c, String ns, L loc, A anno) throws BuildException;
+
+    /**
+     *
+     * @param parent
+     *      The parent scope. null if there's no parent scope.
+     *      For example, if the complete document looks like the following:
+     *      <pre><xmp>
+     *      <grammar>
+     *        <start><element name="root"><empty/></element></start>
+     *      </grammar>
+     *      </xmp></pre>
+     *      Then when the outer-most {@link Grammar} is created, it will
+     *      receive the <tt>null</tt> parent.
+     */
+    Grammar<P,E,L,A,CL> makeGrammar(Scope<P,E,L,A,CL> parent);
+
+    /**
+     * Called when annotation is found right inside a pattern
+     *
+     * such as,
+     *
+     * <pre><xmp>
+     * <element name="foo">     <!-- this becomes 'P' -->
+     *   <foreign:annotation /> <!-- this becomes 'A' -->
+     *   ...
+     * </element>
+     * </xmp></pre>
+     */
+    P annotate(P p, A anno) throws BuildException;
+
+    /**
+     * Called when element annotation is found after a pattern.
+     *
+     * such as,
+     *
+     * <pre><xmp>
+     * <element name="foo">
+     *   <empty />              <!-- this becomes 'P' -->
+     *   <foreign:annotation /> <!-- this becomes 'E' -->
+     * </element>
+     * </xmp></pre>
+     */
+    P annotateAfter(P p, E e) throws BuildException;
+
+    P commentAfter(P p, CL comments) throws BuildException;
+
+    /**
+     *
+     * @param current
+     *      Current grammar that we are parsing. This is what contains
+     *      externalRef.
+     * @param scope
+     *      The parent scope. null if there's no parent scope.
+     *      See {@link #makeGrammar(Scope)} for more details about
+     *      when this parameter can be null.
+     */
+    P makeExternalRef(Parseable current, String uri, String ns, Scope<P,E,L,A,CL> scope,
+        L loc, A anno) throws BuildException, IllegalSchemaException;
+
+    L makeLocation(String systemId, int lineNumber, int columnNumber);
+
+    /**
+     * Creates {@link Annotations} object to parse annotations on patterns.
+     *
+     * @return
+     *      must be non-null.
+     */
+    A makeAnnotations(CL comments, Context context);
+
+    ElementAnnotationBuilder<P,E,L,A,CL> makeElementAnnotationBuilder(String ns,
+        String localName, String prefix, L loc, CL comments,
+        Context context);
+
+    CL makeCommentList();
+
+    P makeErrorPattern();
+
+    /**
+     * If this {@link SchemaBuilder}is interested in actually parsing
+     * comments, this method returns true.
+     * <p>
+     * Returning false allows the schema parser to speed up the processing by
+     * skiping comment-related handlings.
+     */
+    boolean usesComments();
+
+    /**
+     * Called after all the parsing is done.
+     *
+     * <p>
+     * This hook typically allows as {@link SchemaBuilder} to expand
+     * notAllowed (if it's following the simplification as in the spec.)
+     */
+    P expandPattern( P p ) throws BuildException, IllegalSchemaException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Scope.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Scope.java
new file mode 100644
index 0000000..5f208bc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/builder/Scope.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.builder;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+public interface Scope<
+    P extends ParsedPattern,
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L> > extends GrammarSection<P,E,L,A,CL> {
+    P makeParentRef(String name, L loc, A anno) throws BuildException;
+    P makeRef(String name, L loc, A anno) throws BuildException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/Location.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/Location.java
new file mode 100644
index 0000000..a078fba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/Location.java
@@ -0,0 +1,28 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.om;
+
+public interface Location { }
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedElementAnnotation.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedElementAnnotation.java
new file mode 100644
index 0000000..ceb22d8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedElementAnnotation.java
@@ -0,0 +1,28 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.om;
+
+public interface ParsedElementAnnotation { }
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedNameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedNameClass.java
new file mode 100644
index 0000000..e9da9c4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedNameClass.java
@@ -0,0 +1,28 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.om;
+
+public interface ParsedNameClass { }
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedPattern.java
new file mode 100644
index 0000000..d3a1ff9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/om/ParsedPattern.java
@@ -0,0 +1,28 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.om;
+
+public interface ParsedPattern { }
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/CheckingSchemaBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/CheckingSchemaBuilder.java
new file mode 100644
index 0000000..ff2a977
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/CheckingSchemaBuilder.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.util;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.binary.SchemaBuilderImpl;
+import com.sun.xml.internal.rngom.binary.SchemaPatternBuilder;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.host.ParsedPatternHost;
+import com.sun.xml.internal.rngom.parse.host.SchemaBuilderHost;
+import org.relaxng.datatype.DatatypeLibraryFactory;
+import org.xml.sax.ErrorHandler;
+
+/**
+ * Wraps a {@link SchemaBuilder} and does all the semantic checks
+ * required by the RELAX NG spec.
+ *
+ * <h2>Usage</h2>
+ * <p>
+ * Whereas you normally write it as follows:
+ * <pre>
+ * YourParsedPattern r = (YourParsedPattern)parseable.parse(sb);
+ * </pre>
+ * write this as follows:
+ * <pre>
+ * YourParsedPattern r = (YourParsedPattern)parseable.parse(new CheckingSchemaBuilder(sb,eh));
+ * </pre>
+ *
+ * <p>
+ * The checking is done by using the <tt>rngom.binary</tt> package, so if you are using
+ * that package for parsing schemas, then there's no need to use this.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class CheckingSchemaBuilder extends SchemaBuilderHost {
+    /**
+     *
+     * @param sb
+     *      Your {@link SchemaBuilder} that parses RELAX NG schemas.
+     * @param eh
+     *      All the errors found will be sent to this handler.
+     */
+    public CheckingSchemaBuilder( SchemaBuilder sb, ErrorHandler eh ) {
+        super(new SchemaBuilderImpl(eh),sb);
+    }
+    public CheckingSchemaBuilder( SchemaBuilder sb, ErrorHandler eh, DatatypeLibraryFactory dlf ) {
+        super(new SchemaBuilderImpl(eh,dlf,new SchemaPatternBuilder()),sb);
+    }
+
+    public ParsedPattern expandPattern(ParsedPattern p)
+        throws BuildException, IllegalSchemaException {
+
+        // just return the result from the user-given SchemaBuilder
+        ParsedPatternHost r = (ParsedPatternHost)super.expandPattern(p);
+        return r.rhs;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/LocatorImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/LocatorImpl.java
new file mode 100644
index 0000000..e85e96c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/LocatorImpl.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.ast.util;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import org.xml.sax.Locator;
+
+/**
+ * {@link Locator} implementation with {@link Location} marker.
+ */
+public class LocatorImpl implements Locator, Location {
+    private final String systemId;
+    private final int lineNumber;
+    private final int columnNumber;
+
+    public LocatorImpl(String systemId, int lineNumber, int columnNumber) {
+        this.systemId = systemId;
+        this.lineNumber = lineNumber;
+        this.columnNumber = columnNumber;
+    }
+
+    public String getPublicId() {
+        return null;
+    }
+
+    public String getSystemId() {
+        return systemId;
+    }
+
+    public int getLineNumber() {
+        return lineNumber;
+    }
+
+    public int getColumnNumber() {
+        return columnNumber;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/package.html b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/package.html
new file mode 100644
index 0000000..2e91664
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/ast/util/package.html
@@ -0,0 +1,3 @@
+Typical implementations of the ast.builder/ast.om packages.
+
+Those classes are solely intended to make the AST implementation easier.
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/AfterPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/AfterPattern.java
new file mode 100644
index 0000000..034ebef
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/AfterPattern.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+
+
+public class AfterPattern extends BinaryPattern {
+  AfterPattern(Pattern p1, Pattern p2) {
+    super(false,
+          combineHashCode(AFTER_HASH_CODE, p1.hashCode(), p2.hashCode()),
+          p1,
+          p2);
+  }
+
+  boolean isNotAllowed() {
+    return p1.isNotAllowed();
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseAfter(this);
+  }
+  public void accept(PatternVisitor visitor) {
+      visitor.visitAfter(p1,p2);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Alphabet.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Alphabet.java
new file mode 100644
index 0000000..e93bd85
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Alphabet.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.nc.ChoiceNameClass;
+import com.sun.xml.internal.rngom.nc.NameClass;
+
+class Alphabet {
+  private NameClass nameClass;
+
+  boolean isEmpty() {
+    return nameClass == null;
+  }
+
+  void addElement(NameClass nc) {
+    if (nameClass == null)
+      nameClass = nc;
+    else if (nc != null)
+      nameClass = new ChoiceNameClass(nameClass, nc);
+  }
+
+  void addAlphabet(Alphabet a) {
+    addElement(a.nameClass);
+  }
+
+  void checkOverlap(Alphabet a) throws RestrictionViolationException {
+    if (nameClass != null
+        && a.nameClass != null
+        && nameClass.hasOverlapWith(a.nameClass))
+      throw new RestrictionViolationException("interleave_element_overlap");
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/AttributePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/AttributePattern.java
new file mode 100644
index 0000000..bce2aad
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/AttributePattern.java
@@ -0,0 +1,124 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import com.sun.xml.internal.rngom.nc.SimpleNameClass;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+public final class AttributePattern extends Pattern {
+  private NameClass nameClass;
+  private Pattern p;
+  private Locator loc;
+
+  AttributePattern(NameClass nameClass, Pattern value, Locator loc) {
+    super(false,
+          EMPTY_CONTENT_TYPE,
+          combineHashCode(ATTRIBUTE_HASH_CODE,
+                          nameClass.hashCode(),
+                          value.hashCode()));
+    this.nameClass = nameClass;
+    this.p = value;
+    this.loc = loc;
+  }
+
+  Pattern expand(SchemaPatternBuilder b) {
+    Pattern ep = p.expand(b);
+    if (ep != p)
+      return b.makeAttribute(nameClass, ep, loc);
+    else
+      return this;
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    switch (context) {
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_attribute");
+    case ELEMENT_CONTEXT:
+      if (nameClass.isOpen())
+        throw new RestrictionViolationException("open_name_class_not_repeated");
+      break;
+    case ELEMENT_REPEAT_GROUP_CONTEXT:
+      throw new RestrictionViolationException("one_or_more_contains_group_contains_attribute");
+    case ELEMENT_REPEAT_INTERLEAVE_CONTEXT:
+      throw new RestrictionViolationException("one_or_more_contains_interleave_contains_attribute");
+    case LIST_CONTEXT:
+      throw new RestrictionViolationException("list_contains_attribute");
+    case ATTRIBUTE_CONTEXT:
+      throw new RestrictionViolationException("attribute_contains_attribute");
+    case DATA_EXCEPT_CONTEXT:
+      throw new RestrictionViolationException("data_except_contains_attribute");
+    }
+    if (!dad.addAttribute(nameClass)) {
+      if (nameClass instanceof SimpleNameClass)
+        throw new RestrictionViolationException("duplicate_attribute_detail", ((SimpleNameClass)nameClass).name);
+      else
+        throw new RestrictionViolationException("duplicate_attribute");
+    }
+    try {
+      p.checkRestrictions(ATTRIBUTE_CONTEXT, null, null);
+    }
+    catch (RestrictionViolationException e) {
+      e.maybeSetLocator(loc);
+      throw e;
+    }
+  }
+
+  boolean samePattern(Pattern other) {
+    if (!(other instanceof AttributePattern))
+      return false;
+    AttributePattern ap = (AttributePattern)other;
+    return nameClass.equals(ap.nameClass)&& p == ap.p;
+  }
+
+  void checkRecursion(int depth) throws SAXException {
+    p.checkRecursion(depth);
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitAttribute(nameClass, p);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseAttribute(this);
+  }
+
+  public Pattern getContent() {
+    return p;
+  }
+
+  public NameClass getNameClass() {
+    return nameClass;
+  }
+
+  public Locator getLocator() {
+    return loc;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/BinaryPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/BinaryPattern.java
new file mode 100644
index 0000000..b1ca8c9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/BinaryPattern.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import org.xml.sax.SAXException;
+
+import java.util.Collection;
+import java.util.List;
+import java.util.ArrayList;
+
+public abstract class BinaryPattern extends Pattern {
+  protected final Pattern p1;
+  protected final Pattern p2;
+
+  BinaryPattern(boolean nullable, int hc, Pattern p1, Pattern p2) {
+    super(nullable, Math.max(p1.getContentType(), p2.getContentType()), hc);
+    this.p1 = p1;
+    this.p2 = p2;
+  }
+
+  void checkRecursion(int depth) throws SAXException {
+    p1.checkRecursion(depth);
+    p2.checkRecursion(depth);
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    p1.checkRestrictions(context, dad, alpha);
+    p2.checkRestrictions(context, dad, alpha);
+  }
+
+  boolean samePattern(Pattern other) {
+    if (getClass() != other.getClass())
+      return false;
+    BinaryPattern b = (BinaryPattern)other;
+    return p1 == b.p1 && p2 == b.p2;
+  }
+
+  public final Pattern getOperand1() {
+    return p1;
+  }
+
+  public final Pattern getOperand2() {
+    return p2;
+  }
+
+  /**
+   * Adds all the children of this pattern to the given collection.
+   *
+   * <p>
+   * For example, if this pattern is (A|B|C), it adds A, B, and C
+   * to the collection, even though internally it's represented
+   * as (A|(B|C)).
+   */
+  public final void fillChildren( Collection col ) {
+    fillChildren(getClass(),p1,col);
+    fillChildren(getClass(),p2,col);
+  }
+
+  /**
+   * Same as {@link #fillChildren(Collection)} but returns an array.
+   */
+  public final Pattern[] getChildren() {
+      List lst = new ArrayList();
+      fillChildren(lst);
+      return (Pattern[]) lst.toArray(new Pattern[lst.size()]);
+  }
+
+  private void fillChildren( Class c, Pattern p, Collection col ) {
+    if(p.getClass()==c) {
+      BinaryPattern bp = (BinaryPattern)p;
+      bp.fillChildren(c,bp.p1,col);
+      bp.fillChildren(c,bp.p2,col);
+    } else {
+      col.add(p);
+    }
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ChoicePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ChoicePattern.java
new file mode 100644
index 0000000..14cbea7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ChoicePattern.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+
+public class ChoicePattern extends BinaryPattern {
+  ChoicePattern(Pattern p1, Pattern p2) {
+    super(p1.isNullable() || p2.isNullable(),
+          combineHashCode(CHOICE_HASH_CODE, p1.hashCode(), p2.hashCode()),
+          p1,
+          p2);
+  }
+  Pattern expand(SchemaPatternBuilder b) {
+    Pattern ep1 = p1.expand(b);
+    Pattern ep2 = p2.expand(b);
+    if (ep1 != p1 || ep2 != p2)
+      return b.makeChoice(ep1, ep2);
+    else
+      return this;
+  }
+
+  boolean containsChoice(Pattern p) {
+    return p1.containsChoice(p) || p2.containsChoice(p);
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitChoice(p1, p2);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseChoice(this);
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    if (dad != null)
+      dad.startChoice();
+    p1.checkRestrictions(context, dad, alpha);
+    if (dad != null)
+      dad.alternative();
+    p2.checkRestrictions(context, dad, alpha);
+    if (dad != null)
+      dad.endChoice();
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DataExceptPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DataExceptPattern.java
new file mode 100644
index 0000000..7e3cdd4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DataExceptPattern.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import org.relaxng.datatype.Datatype;
+import org.xml.sax.Locator;
+
+public class DataExceptPattern extends DataPattern {
+  private Pattern except;
+  private Locator loc;
+
+  DataExceptPattern(Datatype dt, Pattern except, Locator loc) {
+    super(dt);
+    this.except = except;
+    this.loc = loc;
+  }
+
+  boolean samePattern(Pattern other) {
+    if (!super.samePattern(other))
+      return false;
+    return except.samePattern(((DataExceptPattern)other).except);
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitDataExcept(getDatatype(), except);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseDataExcept(this);
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    super.checkRestrictions(context, dad, alpha);
+    try {
+      except.checkRestrictions(DATA_EXCEPT_CONTEXT, null, null);
+    }
+    catch (RestrictionViolationException e) {
+      e.maybeSetLocator(loc);
+      throw e;
+    }
+  }
+
+  Pattern getExcept() {
+    return except;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DataPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DataPattern.java
new file mode 100644
index 0000000..2c4573c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DataPattern.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import org.relaxng.datatype.Datatype;
+
+public class DataPattern extends StringPattern {
+  private Datatype dt;
+
+  DataPattern(Datatype dt) {
+    super(combineHashCode(DATA_HASH_CODE, dt.hashCode()));
+    this.dt = dt;
+  }
+
+  boolean samePattern(Pattern other) {
+    if (other.getClass() != this.getClass())
+      return false;
+    return dt.equals(((DataPattern)other).dt);
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitData(dt);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseData(this);
+  }
+
+  Datatype getDatatype() {
+    return dt;
+  }
+
+  boolean allowsAnyString() {
+      return false;
+//    return dt instanceof Datatype2 && ((Datatype2)dt).alwaysValid();
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    switch (context) {
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_data");
+    }
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DuplicateAttributeDetector.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DuplicateAttributeDetector.java
new file mode 100644
index 0000000..aa9d8b5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/DuplicateAttributeDetector.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import com.sun.xml.internal.rngom.nc.NameClass;
+
+class DuplicateAttributeDetector {
+    private List nameClasses = new ArrayList();
+    private Alternative alternatives = null;
+
+    private static class Alternative {
+        private int startIndex;
+        private int endIndex;
+        private Alternative parent;
+
+        private Alternative(int startIndex, Alternative parent) {
+            this.startIndex = startIndex;
+            this.endIndex = startIndex;
+            this.parent = parent;
+        }
+    }
+
+    boolean addAttribute(NameClass nc) {
+        int lim = nameClasses.size();
+        for (Alternative a = alternatives; a != null; a = a.parent) {
+            for (int i = a.endIndex; i < lim; i++)
+                if (nc.hasOverlapWith((NameClass) nameClasses.get(i)))
+                    return false;
+            lim = a.startIndex;
+        }
+        for (int i = 0; i < lim; i++)
+            if (nc.hasOverlapWith((NameClass) nameClasses.get(i)))
+                return false;
+        nameClasses.add(nc);
+        return true;
+    }
+
+    void startChoice() {
+        alternatives = new Alternative(nameClasses.size(), alternatives);
+    }
+
+    void alternative() {
+        alternatives.endIndex = nameClasses.size();
+    }
+
+    void endChoice() {
+        alternatives = alternatives.parent;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ElementPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ElementPattern.java
new file mode 100644
index 0000000..59bf0ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ElementPattern.java
@@ -0,0 +1,123 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+public final class ElementPattern extends Pattern {
+  private Pattern p;
+  private NameClass origNameClass;
+  private NameClass nameClass;
+  private boolean expanded = false;
+  private boolean checkedRestrictions = false;
+  private Locator loc;
+
+  ElementPattern(NameClass nameClass, Pattern p, Locator loc) {
+    super(false,
+          ELEMENT_CONTENT_TYPE,
+          combineHashCode(ELEMENT_HASH_CODE,
+                          nameClass.hashCode(),
+                          p.hashCode()));
+    this.nameClass = nameClass;
+    this.origNameClass = nameClass;
+    this.p = p;
+    this.loc = loc;
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    if (alpha != null)
+      alpha.addElement(origNameClass);
+    if (checkedRestrictions)
+      return;
+    switch (context) {
+    case DATA_EXCEPT_CONTEXT:
+      throw new RestrictionViolationException("data_except_contains_element");
+    case LIST_CONTEXT:
+      throw new RestrictionViolationException("list_contains_element");
+    case ATTRIBUTE_CONTEXT:
+      throw new RestrictionViolationException("attribute_contains_element");
+    }
+    checkedRestrictions = true;
+    try {
+      p.checkRestrictions(ELEMENT_CONTEXT, new DuplicateAttributeDetector(), null);
+    }
+    catch (RestrictionViolationException e) {
+      checkedRestrictions = false;
+      e.maybeSetLocator(loc);
+      throw e;
+    }
+  }
+
+  Pattern expand(SchemaPatternBuilder b) {
+    if (!expanded) {
+      expanded = true;
+      p = p.expand(b);
+      if (p.isNotAllowed())
+        nameClass = NameClass.NULL;
+    }
+    return this;
+  }
+
+  boolean samePattern(Pattern other) {
+    if (!(other instanceof ElementPattern))
+      return false;
+    ElementPattern ep = (ElementPattern)other;
+    return nameClass.equals(ep.nameClass) && p == ep.p;
+  }
+
+  void checkRecursion(int depth) throws SAXException {
+    p.checkRecursion(depth + 1);
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitElement(nameClass, p);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseElement(this);
+  }
+
+  void setContent(Pattern p) {
+    this.p = p;
+  }
+
+  public Pattern getContent() {
+    return p;
+  }
+
+  public NameClass getNameClass() {
+    return nameClass;
+  }
+
+  public Locator getLocator() {
+    return loc;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/EmptyPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/EmptyPattern.java
new file mode 100644
index 0000000..3a6db7e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/EmptyPattern.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+
+public class EmptyPattern extends Pattern {
+  EmptyPattern() {
+    super(true, EMPTY_CONTENT_TYPE, EMPTY_HASH_CODE);
+  }
+  boolean samePattern(Pattern other) {
+    return other instanceof EmptyPattern;
+  }
+  public void accept(PatternVisitor visitor) {
+    visitor.visitEmpty();
+  }
+  public Object apply(PatternFunction f) {
+    return f.caseEmpty(this);
+  }
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    switch (context) {
+    case DATA_EXCEPT_CONTEXT:
+      throw new RestrictionViolationException("data_except_contains_empty");
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_empty");
+    }
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ErrorPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ErrorPattern.java
new file mode 100644
index 0000000..2fad943
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ErrorPattern.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+
+public class ErrorPattern extends Pattern {
+  ErrorPattern() {
+    super(false, EMPTY_CONTENT_TYPE, ERROR_HASH_CODE);
+  }
+  boolean samePattern(Pattern other) {
+    return other instanceof ErrorPattern;
+  }
+  public void accept(PatternVisitor visitor) {
+    visitor.visitError();
+  }
+  public Object apply(PatternFunction f) {
+    return f.caseError(this);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/GroupPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/GroupPattern.java
new file mode 100644
index 0000000..86bd95b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/GroupPattern.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.*;
+
+public class GroupPattern extends BinaryPattern {
+  GroupPattern(Pattern p1, Pattern p2) {
+    super(p1.isNullable() && p2.isNullable(),
+          combineHashCode(GROUP_HASH_CODE, p1.hashCode(), p2.hashCode()),
+          p1,
+          p2);
+  }
+
+  Pattern expand(SchemaPatternBuilder b) {
+    Pattern ep1 = p1.expand(b);
+    Pattern ep2 = p2.expand(b);
+    if (ep1 != p1 || ep2 != p2)
+      return b.makeGroup(ep1, ep2);
+    else
+      return this;
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha) throws RestrictionViolationException {
+    switch (context) {
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_group");
+    case DATA_EXCEPT_CONTEXT:
+      throw new RestrictionViolationException("data_except_contains_group");
+    }
+    super.checkRestrictions(context == ELEMENT_REPEAT_CONTEXT
+                            ? ELEMENT_REPEAT_GROUP_CONTEXT
+                            : context,
+                            dad,
+                            alpha);
+    if (context != LIST_CONTEXT
+        && !contentTypeGroupable(p1.getContentType(), p2.getContentType()))
+      throw new RestrictionViolationException("group_string");
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitGroup(p1, p2);
+  }
+  public Object apply(PatternFunction f) {
+    return f.caseGroup(this);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/InterleavePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/InterleavePattern.java
new file mode 100644
index 0000000..068ca23
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/InterleavePattern.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+
+public class InterleavePattern extends BinaryPattern {
+  InterleavePattern(Pattern p1, Pattern p2) {
+    super(p1.isNullable() && p2.isNullable(),
+          combineHashCode(INTERLEAVE_HASH_CODE, p1.hashCode(), p2.hashCode()),
+          p1,
+          p2);
+  }
+  Pattern expand(SchemaPatternBuilder b) {
+    Pattern ep1 = p1.expand(b);
+    Pattern ep2 = p2.expand(b);
+    if (ep1 != p1 || ep2 != p2)
+      return b.makeInterleave(ep1, ep2);
+    else
+      return this;
+  }
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    switch (context) {
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_interleave");
+    case DATA_EXCEPT_CONTEXT:
+      throw new RestrictionViolationException("data_except_contains_interleave");
+    case LIST_CONTEXT:
+      throw new RestrictionViolationException("list_contains_interleave");
+    }
+    if (context == ELEMENT_REPEAT_CONTEXT)
+      context = ELEMENT_REPEAT_INTERLEAVE_CONTEXT;
+    Alphabet a1;
+    if (alpha != null && alpha.isEmpty())
+      a1 = alpha;
+    else
+      a1 = new Alphabet();
+    p1.checkRestrictions(context, dad, a1);
+    if (a1.isEmpty())
+      p2.checkRestrictions(context, dad, a1);
+    else {
+      Alphabet a2 = new Alphabet();
+      p2.checkRestrictions(context, dad, a2);
+      a1.checkOverlap(a2);
+      if (alpha != null) {
+        if (alpha != a1)
+          alpha.addAlphabet(a1);
+        alpha.addAlphabet(a2);
+      }
+    }
+    if (context != LIST_CONTEXT
+        && !contentTypeGroupable(p1.getContentType(), p2.getContentType()))
+      throw new RestrictionViolationException("interleave_string");
+    if (p1.getContentType() == MIXED_CONTENT_TYPE
+        && p2.getContentType() == MIXED_CONTENT_TYPE)
+      throw new RestrictionViolationException("interleave_text_overlap");
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitInterleave(p1, p2);
+  }
+  public Object apply(PatternFunction f) {
+    return f.caseInterleave(this);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ListPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ListPattern.java
new file mode 100644
index 0000000..c898dd1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ListPattern.java
@@ -0,0 +1,92 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+public class ListPattern extends Pattern {
+  Pattern p;
+  Locator locator;
+
+  ListPattern(Pattern p, Locator locator) {
+    super(false,
+          DATA_CONTENT_TYPE,
+          combineHashCode(LIST_HASH_CODE, p.hashCode()));
+    this.p = p;
+    this.locator = locator;
+  }
+
+  Pattern expand(SchemaPatternBuilder b) {
+    Pattern ep = p.expand(b);
+    if (ep != p)
+      return b.makeList(ep, locator);
+    else
+      return this;
+  }
+
+  void checkRecursion(int depth) throws SAXException {
+    p.checkRecursion(depth);
+  }
+
+  boolean samePattern(Pattern other) {
+    return (other instanceof ListPattern
+            && p == ((ListPattern)other).p);
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitList(p);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseList(this);
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    switch (context) {
+    case DATA_EXCEPT_CONTEXT:
+      throw new RestrictionViolationException("data_except_contains_list");
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_list");
+    case LIST_CONTEXT:
+      throw new RestrictionViolationException("list_contains_list");
+    }
+    try {
+      p.checkRestrictions(LIST_CONTEXT, dad, null);
+    }
+    catch (RestrictionViolationException e) {
+      e.maybeSetLocator(locator);
+      throw e;
+    }
+  }
+
+  Pattern getOperand() {
+    return p;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Messages.properties
new file mode 100644
index 0000000..0b71e64
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Messages.properties
@@ -0,0 +1,103 @@
+# Properties file specifying messages
+illegal_href_attribute=illegal \"href\" attribute
+ns_attribute_ignored=\"ns\" attribute ignored
+reference_to_undefined=reference to undefined pattern \"{0}\"
+missing_start_element=missing \"start\" element
+recursive_reference=bad recursive reference to pattern \"{0}\"
+recursive_include=recursive inclusion of URL \"{0}\"
+duplicate_define=multiple definitions of \"{0}\" without \"combine\" attribute
+duplicate_start=multiple definitions of start without \"combine\" attribute
+conflict_combine_define=conflicting values of \"combine\" attribute for definition of \"{0}\"
+conflict_combine_start=conflicting values of \"combine\" attribute for definition of start
+missing_start_replacement=\"start\" in \"include\" does not override anything
+missing_define_replacement=definition of \"{0}\" in \"include\" does not override anything
+interleave_string=interleave of \"string\" or \"data\" element
+group_string=group of \"string\" or \"data\" element
+one_or_more_string=repeat of \"string\" or \"data\" element
+unrecognized_datatype=datatype \"{1}\" from library \"{0}\" not recognized
+unsupported_datatype_detail=datatype \"{1}\" from library \"{0}\" not supported: {2}
+unrecognized_datatype_library=datatype library \"{0}\" not recognized
+unrecognized_builtin_datatype=no such builtin datatype \"{0}\": must be \"string\" or \"token\"
+invalid_value=\"{0}\" is not a valid value of the datatype
+parent_ref_outside_grammar=reference to non-existent parent grammar
+ref_outside_grammar=reference to non-existent grammar
+expected_one_name_class=found \"{0}\" element but expected no further content
+builtin_param=builtin datatypes do not have any parameters
+invalid_param_display=invalid parameter:\n{0}
+invalid_param_detail_display=invalid parameter: {0}:\n{1}
+display_param={0}>>>>{1}
+invalid_param_detail=invalid parameter: {0}
+invalid_param=invalid parameter
+invalid_params_detail=invalid parameters: {0}
+invalid_params=invalid parameters
+datatype_requires_parameter=datatype cannot be used without parameters
+datatype_requires_parameter_detail=datatype cannot be used without parameters: {0}
+
+attribute_contains_attribute=\"attribute\" contains \"attribute\"
+attribute_contains_element=\"attribute\" contains \"element\"
+data_except_contains_attribute=\"except\" in \"data\" contains \"attribute\"
+data_except_contains_element=\"except\" in \"data\" contains \"element\"
+data_except_contains_empty=\"except\" in \"data\" contains \"empty\"
+data_except_contains_group=\"except\" in \"data\" contains \"group\"
+data_except_contains_interleave=\"except\" in \"data\" contains \"interleave\"
+data_except_contains_list=\"except\" in \"data\" contains \"list\"
+data_except_contains_one_or_more=\"except\" in \"data\" contains \"oneOrMore\"
+data_except_contains_text=\"except\" in \"data\" contains \"text\"
+list_contains_attribute=\"list\" contains \"attribute\"
+list_contains_element=\"list\" contains \"element\"
+list_contains_list=\"list\" contains \"list\"
+list_contains_text=\"list\" contains \"text\"
+one_or_more_contains_group_contains_attribute=\"oneOrMore\" contains \"group\" contains \"attribute\"
+one_or_more_contains_interleave_contains_attribute=\"oneOrMore\" contains \"interleave\" contains \"attribute\"
+start_contains_attribute=\"start\" contains \"attribute\"
+start_contains_data=\"start\" contains \"data\"
+start_contains_empty=\"start\" contains \"empty\"
+start_contains_group=\"start\" contains \"group\"
+start_contains_interleave=\"start\" contains \"interleave\"
+start_contains_list=\"start\" contains \"list\"
+start_contains_one_or_more=\"start\" contains \"oneOrMore\"
+start_contains_text=\"start\" contains \"text\"
+start_contains_value=\"start\" contains \"value\"
+duplicate_attribute=duplicate attribute
+duplicate_attribute_detail=duplicate attribute {0}
+interleave_element_overlap=overlapping element names in operands of \"interleave\"
+list_contains_interleave=\"list\" contains \"interleave\"
+interleave_text_overlap=both operands of \"interleave\" contain \"text\"
+open_name_class_not_repeated=attribute using \"nsName\" or \"anyName\" must be in \"oneOrMore\"
+xmlns_uri_attribute=attribute must not have namespace URI \"http://www.w3.org/2000/xmlns\"
+xmlns_attribute=attribute must not be named \"xmlns\"
+
+# Validation errors
+unknown_element=unknown element {0}
+required_elements_missing=required elements missing
+out_of_context_element=element {0} not allowed in this context
+impossible_attribute_ignored=attribute {0} not allowed at this point; ignored
+bad_attribute_value=bad value for attribute {0}
+required_attributes_missing=required attributes missing
+unfinished_element=unfinished element
+text_not_allowed=text not allowed here
+document_incomplete=document incompletely matched
+string_not_allowed=bad character content for element
+only_text_not_allowed=element cannot have content that consists only of text
+schema_allows_nothing=schema does not allow anything: it is equivalent to <notAllowed/>
+
+# ID correctness errors
+id_element_name_class=an \"element\" pattern containing an \"attribute\" pattern with a non-null ID-type must have a name class that contains only \"choice\" and \"name\" elements
+id_attribute_name_class=an \"attribute\" pattern with a non-null ID-type must have a name class that is a single name
+id_parent=a \"data\" or \"value\" pattern with non-null ID-type must occur as the child of an \"attribute\" pattern
+id_type_conflict=conflicting ID-types for attribute {1} of element {0}
+
+# ID soundness errors
+id_no_tokens=value of attribute of type ID contained no tokens
+id_multiple_tokens=value of attribute of type ID contained multiple tokens
+idref_no_tokens=value of attribute of type IDREF contained no tokens
+idref_multiple_tokens=value of attribute of type IDREF contained multiple tokens
+idrefs_no_tokens=value of attribute of type IDREFS contained no tokens
+missing_id=IDREF \"{0}\" without matching ID
+duplicate_id=ID \"{0}\" has already been defined
+first_id=first occurrence of ID \"{0}\"
+
+# Fragments
+name_absent_namespace=\"{0}\"
+name_with_namespace=\"{1}\" from namespace \"{0}\"
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/NotAllowedPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/NotAllowedPattern.java
new file mode 100644
index 0000000..ccb97c0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/NotAllowedPattern.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+
+public class NotAllowedPattern extends Pattern {
+  NotAllowedPattern() {
+    super(false, EMPTY_CONTENT_TYPE, NOT_ALLOWED_HASH_CODE);
+  }
+  boolean isNotAllowed() {
+    return true;
+  }
+  boolean samePattern(Pattern other) {
+    // needs to work for UnexpandedNotAllowedPattern
+    return other.getClass() == this.getClass();
+  }
+  public void accept(PatternVisitor visitor) {
+    visitor.visitNotAllowed();
+  }
+  public Object apply(PatternFunction f) {
+    return f.caseNotAllowed(this);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/OneOrMorePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/OneOrMorePattern.java
new file mode 100644
index 0000000..8c9f1bd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/OneOrMorePattern.java
@@ -0,0 +1,89 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import org.xml.sax.SAXException;
+
+public class OneOrMorePattern extends Pattern {
+  Pattern p;
+
+  OneOrMorePattern(Pattern p) {
+    super(p.isNullable(),
+          p.getContentType(),
+          combineHashCode(ONE_OR_MORE_HASH_CODE, p.hashCode()));
+    this.p = p;
+  }
+
+  Pattern expand(SchemaPatternBuilder b) {
+    Pattern ep = p.expand(b);
+    if (ep != p)
+      return b.makeOneOrMore(ep);
+    else
+      return this;
+  }
+
+  void checkRecursion(int depth) throws SAXException {
+    p.checkRecursion(depth);
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    switch (context) {
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_one_or_more");
+    case DATA_EXCEPT_CONTEXT:
+      throw new RestrictionViolationException("data_except_contains_one_or_more");
+    }
+
+    p.checkRestrictions(context == ELEMENT_CONTEXT
+                        ? ELEMENT_REPEAT_CONTEXT
+                        : context,
+                        dad,
+                        alpha);
+    if (context != LIST_CONTEXT
+        && !contentTypeGroupable(p.getContentType(), p.getContentType()))
+      throw new RestrictionViolationException("one_or_more_string");
+  }
+
+  boolean samePattern(Pattern other) {
+    return (other instanceof OneOrMorePattern
+            && p == ((OneOrMorePattern)other).p);
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitOneOrMore(p);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseOneOrMore(this);
+  }
+
+  Pattern getOperand() {
+    return p;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Pattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Pattern.java
new file mode 100644
index 0000000..6f04f43
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/Pattern.java
@@ -0,0 +1,141 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import org.xml.sax.SAXException;
+
+public abstract class Pattern implements ParsedPattern {
+  private boolean nullable;
+  private int hc;
+  private int contentType;
+
+  static final int TEXT_HASH_CODE = 1;
+  static final int ERROR_HASH_CODE = 3;
+  static final int EMPTY_HASH_CODE = 5;
+  static final int NOT_ALLOWED_HASH_CODE = 7;
+  static final int CHOICE_HASH_CODE = 11;
+  static final int GROUP_HASH_CODE = 13;
+  static final int INTERLEAVE_HASH_CODE = 17;
+  static final int ONE_OR_MORE_HASH_CODE = 19;
+  static final int ELEMENT_HASH_CODE = 23;
+  static final int VALUE_HASH_CODE = 27;
+  static final int ATTRIBUTE_HASH_CODE = 29;
+  static final int DATA_HASH_CODE = 31;
+  static final int LIST_HASH_CODE = 37;
+  static final int AFTER_HASH_CODE = 41;
+
+  static int combineHashCode(int hc1, int hc2, int hc3) {
+    return hc1 * hc2 * hc3;
+  }
+
+  static int combineHashCode(int hc1, int hc2) {
+    return hc1 * hc2;
+  }
+
+  static final int EMPTY_CONTENT_TYPE = 0;
+  static final int ELEMENT_CONTENT_TYPE = 1;
+  static final int MIXED_CONTENT_TYPE = 2;
+  static final int DATA_CONTENT_TYPE = 3;
+
+  Pattern(boolean nullable, int contentType, int hc) {
+    this.nullable = nullable;
+    this.contentType = contentType;
+    this.hc = hc;
+  }
+
+  Pattern() {
+    this.nullable = false;
+    this.hc = hashCode();
+    this.contentType = EMPTY_CONTENT_TYPE;
+  }
+
+  void checkRecursion(int depth) throws SAXException { }
+
+  Pattern expand(SchemaPatternBuilder b) {
+    return this;
+  }
+
+  /**
+   * Returns true if the pattern is nullable.
+   *
+   * <p>
+   * A pattern is nullable when it can match the empty sequence.
+   */
+  public final boolean isNullable() {
+    return nullable;
+  }
+
+  boolean isNotAllowed() {
+    return false;
+  }
+
+  static final int START_CONTEXT = 0;
+  static final int ELEMENT_CONTEXT = 1;
+  static final int ELEMENT_REPEAT_CONTEXT = 2;
+  static final int ELEMENT_REPEAT_GROUP_CONTEXT = 3;
+  static final int ELEMENT_REPEAT_INTERLEAVE_CONTEXT = 4;
+  static final int ATTRIBUTE_CONTEXT = 5;
+  static final int LIST_CONTEXT = 6;
+  static final int DATA_EXCEPT_CONTEXT = 7;
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+  }
+
+  // Know that other is not null
+  abstract boolean samePattern(Pattern other);
+
+  final int patternHashCode() {
+    return hc;
+  }
+
+  final int getContentType() {
+    return contentType;
+  }
+
+  boolean containsChoice(Pattern p) {
+    return this == p;
+  }
+
+  public abstract void accept(PatternVisitor visitor);
+  public abstract Object apply(PatternFunction f);
+
+//  DPattern applyForPattern(PatternFunction f) {
+//    return (DPattern)apply(f);
+//  }
+
+  static boolean contentTypeGroupable(int ct1, int ct2) {
+    if (ct1 == EMPTY_CONTENT_TYPE || ct2 == EMPTY_CONTENT_TYPE)
+      return true;
+    if (ct1 == DATA_CONTENT_TYPE || ct2 == DATA_CONTENT_TYPE)
+      return false;
+    return true;
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/PatternBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/PatternBuilder.java
new file mode 100644
index 0000000..4086d72
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/PatternBuilder.java
@@ -0,0 +1,117 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+public class PatternBuilder {
+  private final EmptyPattern empty;
+  protected final NotAllowedPattern notAllowed;
+  protected final PatternInterner interner;
+
+  public PatternBuilder() {
+    empty = new EmptyPattern();
+    notAllowed = new NotAllowedPattern();
+    interner = new PatternInterner();
+  }
+
+  public PatternBuilder(PatternBuilder parent) {
+    empty = parent.empty;
+    notAllowed = parent.notAllowed;
+    interner = new PatternInterner(parent.interner);
+  }
+
+  Pattern makeEmpty() {
+    return empty;
+  }
+
+  Pattern makeNotAllowed() {
+    return notAllowed;
+  }
+
+  Pattern makeGroup(Pattern p1, Pattern p2) {
+    if (p1 == empty)
+      return p2;
+    if (p2 == empty)
+      return p1;
+    if (p1 == notAllowed || p2 == notAllowed)
+      return notAllowed;
+    if (false && p1 instanceof GroupPattern) {
+      GroupPattern sp = (GroupPattern)p1;
+      return makeGroup(sp.p1, makeGroup(sp.p2, p2));
+    }
+    Pattern p = new GroupPattern(p1, p2);
+    return interner.intern(p);
+  }
+
+  Pattern makeInterleave(Pattern p1, Pattern p2) {
+    if (p1 == empty)
+      return p2;
+    if (p2 == empty)
+      return p1;
+    if (p1 == notAllowed || p2 == notAllowed)
+      return notAllowed;
+    if (false && p1 instanceof InterleavePattern) {
+      InterleavePattern ip = (InterleavePattern)p1;
+      return makeInterleave(ip.p1, makeInterleave(ip.p2, p2));
+    }
+    if (false) {
+    if (p2 instanceof InterleavePattern) {
+      InterleavePattern ip = (InterleavePattern)p2;
+      if (p1.hashCode() > ip.p1.hashCode())
+        return makeInterleave(ip.p1, makeInterleave(p1, ip.p2));
+    }
+    else if (p1.hashCode() > p2.hashCode())
+      return makeInterleave(p2, p1);
+    }
+    Pattern p = new InterleavePattern(p1, p2);
+    return interner.intern(p);
+  }
+
+  Pattern makeChoice(Pattern p1, Pattern p2) {
+    if (p1 == empty && p2.isNullable())
+      return p2;
+    if (p2 == empty && p1.isNullable())
+      return p1;
+    Pattern p = new ChoicePattern(p1, p2);
+    return interner.intern(p);
+  }
+
+  Pattern makeOneOrMore(Pattern p) {
+    if (p == empty
+        || p == notAllowed
+        || p instanceof OneOrMorePattern)
+      return p;
+    Pattern p1 = new OneOrMorePattern(p);
+    return interner.intern(p1);
+  }
+
+  Pattern makeOptional(Pattern p) {
+    return makeChoice(p, empty);
+  }
+
+  Pattern makeZeroOrMore(Pattern p) {
+    return makeOptional(makeOneOrMore(p));
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/PatternInterner.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/PatternInterner.java
new file mode 100644
index 0000000..5ae8d1e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/PatternInterner.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+final class PatternInterner {
+    private static final int INIT_SIZE = 256;
+    private static final float LOAD_FACTOR = 0.3f;
+    private Pattern[] table;
+    private int used;
+    private int usedLimit;
+
+    PatternInterner() {
+        table = null;
+        used = 0;
+        usedLimit = 0;
+    }
+
+    PatternInterner(PatternInterner parent) {
+        table = parent.table;
+        if (table != null)
+            table = (Pattern[]) table.clone();
+        used = parent.used;
+        usedLimit = parent.usedLimit;
+    }
+
+    Pattern intern(Pattern p) {
+        int h;
+
+        if (table == null) {
+            table = new Pattern[INIT_SIZE];
+            usedLimit = (int) (INIT_SIZE * LOAD_FACTOR);
+            h = firstIndex(p);
+        } else {
+            for (h = firstIndex(p); table[h] != null; h = nextIndex(h)) {
+                if (p.samePattern(table[h]))
+                    return table[h];
+            }
+        }
+        if (used >= usedLimit) {
+            // rehash
+            Pattern[] oldTable = table;
+            table = new Pattern[table.length << 1];
+            for (int i = oldTable.length; i > 0;) {
+                --i;
+                if (oldTable[i] != null) {
+                    int j;
+                    for (j = firstIndex(oldTable[i]);
+                        table[j] != null;
+                        j = nextIndex(j));
+                    table[j] = oldTable[i];
+                }
+            }
+            for (h = firstIndex(p); table[h] != null; h = nextIndex(h));
+            usedLimit = (int) (table.length * LOAD_FACTOR);
+        }
+        used++;
+        table[h] = p;
+        return p;
+    }
+
+    private int firstIndex(Pattern p) {
+        return p.patternHashCode() & (table.length - 1);
+    }
+
+    private int nextIndex(int i) {
+        return i == 0 ? table.length - 1 : i - 1;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/RefPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/RefPattern.java
new file mode 100644
index 0000000..4e02208
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/RefPattern.java
@@ -0,0 +1,131 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+public class RefPattern extends Pattern {
+  private Pattern p;
+  private Locator refLoc;
+  private String name;
+  private int checkRecursionDepth = -1;
+  private boolean combineImplicit = false;
+  private byte combineType = COMBINE_NONE;
+  private byte replacementStatus = REPLACEMENT_KEEP;
+  private boolean expanded = false;
+
+  static final byte REPLACEMENT_KEEP = 0;
+  static final byte REPLACEMENT_REQUIRE = 1;
+  static final byte REPLACEMENT_IGNORE = 2;
+
+  static final byte COMBINE_NONE = 0;
+  static final byte COMBINE_CHOICE = 1;
+  static final byte COMBINE_INTERLEAVE = 2;
+
+  RefPattern(String name) {
+    this.name = name;
+  }
+
+  Pattern getPattern() {
+    return p;
+  }
+
+  void setPattern(Pattern p) {
+    this.p = p;
+  }
+
+  Locator getRefLocator() {
+    return refLoc;
+  }
+
+  void setRefLocator(Locator loc) {
+    this.refLoc = loc;
+  }
+
+  void checkRecursion(int depth) throws SAXException {
+    if (checkRecursionDepth == -1) {
+      checkRecursionDepth = depth;
+      p.checkRecursion(depth);
+      checkRecursionDepth = -2;
+    }
+    else if (depth == checkRecursionDepth)
+      // XXX try to recover from this?
+      throw new SAXParseException(SchemaBuilderImpl.localizer.message("recursive_reference", name),
+                                  refLoc);
+  }
+
+  Pattern expand(SchemaPatternBuilder b) {
+    if (!expanded) {
+      p = p.expand(b);
+      expanded = true;
+    }
+    return p;
+  }
+
+  boolean samePattern(Pattern other) {
+    return false;
+  }
+
+  public void accept(PatternVisitor visitor) {
+    p.accept(visitor);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseRef(this);
+  }
+
+  byte getReplacementStatus() {
+    return replacementStatus;
+  }
+
+  void setReplacementStatus(byte replacementStatus) {
+    this.replacementStatus = replacementStatus;
+  }
+
+  boolean isCombineImplicit() {
+    return combineImplicit;
+  }
+
+  void setCombineImplicit() {
+    combineImplicit = true;
+  }
+
+  byte getCombineType() {
+    return combineType;
+  }
+
+  void setCombineType(byte combineType) {
+    this.combineType = combineType;
+  }
+
+  String getName() {
+    return name;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/RestrictionViolationException.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/RestrictionViolationException.java
new file mode 100644
index 0000000..a9de621
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/RestrictionViolationException.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import javax.xml.namespace.QName;
+
+import org.xml.sax.Locator;
+
+final class RestrictionViolationException extends Exception {
+    private String messageId;
+    private Locator loc;
+    private QName name;
+
+    RestrictionViolationException(String messageId) {
+        this.messageId = messageId;
+    }
+
+    RestrictionViolationException(String messageId, QName name) {
+        this.messageId = messageId;
+        this.name = name;
+    }
+
+    String getMessageId() {
+        return messageId;
+    }
+
+    Locator getLocator() {
+        return loc;
+    }
+
+    void maybeSetLocator(Locator loc) {
+        if (this.loc == null)
+            this.loc = loc;
+    }
+
+    QName getName() {
+        return name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/SchemaBuilderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/SchemaBuilderImpl.java
new file mode 100644
index 0000000..75546b8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/SchemaBuilderImpl.java
@@ -0,0 +1,766 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.util.List;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Div;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.builder.GrammarSection;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.ast.util.LocatorImpl;
+import com.sun.xml.internal.rngom.dt.builtin.BuiltinDatatypeLibraryFactory;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import com.sun.xml.internal.rngom.nc.NameClassBuilderImpl;
+import com.sun.xml.internal.rngom.parse.Context;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import com.sun.xml.internal.rngom.util.Localizer;
+import org.relaxng.datatype.Datatype;
+import org.relaxng.datatype.DatatypeBuilder;
+import org.relaxng.datatype.DatatypeException;
+import org.relaxng.datatype.DatatypeLibrary;
+import org.relaxng.datatype.DatatypeLibraryFactory;
+import org.relaxng.datatype.ValidationContext;
+import org.relaxng.datatype.helpers.DatatypeLibraryLoader;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+public class SchemaBuilderImpl implements SchemaBuilder, ElementAnnotationBuilder, CommentList {
+  private final SchemaBuilderImpl parent;
+  private boolean hadError = false;
+  private final SchemaPatternBuilder pb;
+  private final DatatypeLibraryFactory datatypeLibraryFactory;
+  private final String inheritNs;
+  private final ErrorHandler eh;
+  private final OpenIncludes openIncludes;
+  private final NameClassBuilder ncb =new NameClassBuilderImpl();
+  static final Localizer localizer = new Localizer(SchemaBuilderImpl.class);
+
+  static class OpenIncludes {
+    final String uri;
+    final OpenIncludes parent;
+
+    OpenIncludes(String uri, OpenIncludes parent) {
+      this.uri = uri;
+      this.parent = parent;
+    }
+  }
+
+  public ParsedPattern expandPattern(ParsedPattern _pattern)
+        throws BuildException, IllegalSchemaException {
+        Pattern pattern = (Pattern) _pattern;
+        if (!hadError) {
+            try {
+                pattern.checkRecursion(0);
+                pattern = pattern.expand(pb);
+                pattern.checkRestrictions(Pattern.START_CONTEXT, null, null);
+                if (!hadError) return pattern;
+            } catch (SAXParseException e) {
+                error(e);
+            } catch (SAXException e) {
+                throw new BuildException(e);
+            } catch (RestrictionViolationException e) {
+                if (e.getName() != null)
+                    error(e.getMessageId(), e.getName().toString(), e
+                        .getLocator());
+                else
+                    error(e.getMessageId(), e.getLocator());
+            }
+        }
+        throw new IllegalSchemaException();
+    }
+
+  /**
+   *
+   * @param eh
+   *        Error handler to receive errors while building the schema.
+   */
+  public SchemaBuilderImpl(ErrorHandler eh) {
+      this(eh,new BuiltinDatatypeLibraryFactory(new DatatypeLibraryLoader()),new SchemaPatternBuilder());
+  }
+
+  /**
+   *
+   * @param eh
+   *        Error handler to receive errors while building the schema.
+   * @param datatypeLibraryFactory
+   *        This is consulted to locate datatype libraries.
+   * @param pb
+   *        Used to build patterns.
+   */
+  public SchemaBuilderImpl(ErrorHandler eh,
+                            DatatypeLibraryFactory datatypeLibraryFactory,
+                            SchemaPatternBuilder pb) {
+    this.parent = null;
+    this.eh = eh;
+    this.datatypeLibraryFactory = datatypeLibraryFactory;
+    this.pb = pb;
+    this.inheritNs = "";
+    this.openIncludes = null;
+  }
+
+  private SchemaBuilderImpl(String inheritNs,
+                            String uri,
+                            SchemaBuilderImpl parent) {
+    this.parent = parent;
+    this.eh = parent.eh;
+    this.datatypeLibraryFactory = parent.datatypeLibraryFactory;
+    this.pb = parent.pb;
+    this.inheritNs = inheritNs;
+    this.openIncludes = new OpenIncludes(uri, parent.openIncludes);
+  }
+
+  public NameClassBuilder getNameClassBuilder() {
+      return ncb;
+  }
+
+  public ParsedPattern makeChoice(List patterns, Location loc, Annotations anno)
+          throws BuildException {
+    if (patterns.isEmpty())
+      throw new IllegalArgumentException();
+    Pattern result = (Pattern)patterns.get(0);
+    for (int i = 1; i < patterns.size(); i++)
+      result = pb.makeChoice(result, (Pattern)patterns.get(i));
+    return result;
+  }
+
+  public ParsedPattern makeInterleave(List patterns, Location loc, Annotations anno)
+          throws BuildException {
+    if (patterns.isEmpty())
+      throw new IllegalArgumentException();
+    Pattern result = (Pattern)patterns.get(0);
+    for (int i = 1; i < patterns.size(); i++)
+      result = pb.makeInterleave(result, (Pattern)patterns.get(i));
+    return result;
+  }
+
+  public ParsedPattern makeGroup(List patterns, Location loc, Annotations anno)
+          throws BuildException {
+    if (patterns.isEmpty())
+      throw new IllegalArgumentException();
+    Pattern result = (Pattern)patterns.get(0);
+    for (int i = 1; i < patterns.size(); i++)
+      result = pb.makeGroup(result, (Pattern)patterns.get(i));
+    return result;
+  }
+
+  public ParsedPattern makeOneOrMore(ParsedPattern p, Location loc, Annotations anno)
+          throws BuildException {
+    return pb.makeOneOrMore((Pattern)p);
+  }
+
+  public ParsedPattern makeZeroOrMore(ParsedPattern p, Location loc, Annotations anno)
+          throws BuildException {
+    return pb.makeZeroOrMore((Pattern)p);
+  }
+
+  public ParsedPattern makeOptional(ParsedPattern p, Location loc, Annotations anno)
+          throws BuildException {
+    return pb.makeOptional((Pattern)p);
+  }
+
+  public ParsedPattern makeList(ParsedPattern p, Location loc, Annotations anno)
+          throws BuildException {
+    return pb.makeList((Pattern)p, (Locator)loc);
+  }
+
+  public ParsedPattern makeMixed(ParsedPattern p, Location loc, Annotations anno)
+          throws BuildException {
+    return pb.makeMixed((Pattern)p);
+  }
+
+  public ParsedPattern makeEmpty(Location loc, Annotations anno) {
+    return pb.makeEmpty();
+  }
+
+  public ParsedPattern makeNotAllowed(Location loc, Annotations anno) {
+    return pb.makeUnexpandedNotAllowed();
+  }
+
+  public ParsedPattern makeText(Location loc, Annotations anno) {
+    return pb.makeText();
+  }
+
+  public ParsedPattern makeErrorPattern() {
+    return pb.makeError();
+  }
+
+//  public ParsedNameClass makeErrorNameClass() {
+//    return new ErrorNameClass();
+//  }
+
+  public ParsedPattern makeAttribute(ParsedNameClass nc, ParsedPattern p, Location loc, Annotations anno)
+          throws BuildException {
+    return pb.makeAttribute((NameClass)nc, (Pattern)p, (Locator)loc);
+  }
+
+  public ParsedPattern makeElement(ParsedNameClass nc, ParsedPattern p, Location loc, Annotations anno)
+          throws BuildException {
+    return pb.makeElement((NameClass)nc, (Pattern)p, (Locator)loc);
+  }
+
+  private class DummyDataPatternBuilder implements DataPatternBuilder {
+    public void addParam(String name, String value, Context context, String ns, Location loc, Annotations anno)
+            throws BuildException {
+    }
+
+    public ParsedPattern makePattern(Location loc, Annotations anno)
+            throws BuildException {
+      return pb.makeError();
+    }
+
+    public ParsedPattern makePattern(ParsedPattern except, Location loc, Annotations anno)
+            throws BuildException {
+      return pb.makeError();
+    }
+
+    public void annotation(ParsedElementAnnotation ea) {
+    }
+  }
+
+  private class ValidationContextImpl implements ValidationContext {
+    private ValidationContext vc;
+    private String ns;
+
+    ValidationContextImpl(ValidationContext vc, String ns) {
+      this.vc = vc;
+      this.ns = ns.length() == 0 ? null : ns;
+    }
+
+    public String resolveNamespacePrefix(String prefix) {
+      return prefix.length() == 0 ? ns : vc.resolveNamespacePrefix(prefix);
+    }
+
+    public String getBaseUri() {
+      return vc.getBaseUri();
+    }
+
+    public boolean isUnparsedEntity(String entityName) {
+      return vc.isUnparsedEntity(entityName);
+    }
+
+    public boolean isNotation(String notationName) {
+      return vc.isNotation(notationName);
+    }
+  }
+
+  private class DataPatternBuilderImpl implements DataPatternBuilder {
+    private DatatypeBuilder dtb;
+    DataPatternBuilderImpl(DatatypeBuilder dtb) {
+      this.dtb = dtb;
+    }
+
+    public void addParam(String name, String value, Context context, String ns, Location loc, Annotations anno)
+            throws BuildException {
+      try {
+        dtb.addParameter(name, value, new ValidationContextImpl(context, ns));
+      }
+      catch (DatatypeException e) {
+        String detail = e.getMessage();
+        int pos = e.getIndex();
+        String displayedParam;
+        if (pos == DatatypeException.UNKNOWN)
+          displayedParam = null;
+        else
+          displayedParam = displayParam(value, pos);
+        if (displayedParam != null) {
+          if (detail != null)
+            error("invalid_param_detail_display", detail, displayedParam, (Locator)loc);
+          else
+            error("invalid_param_display", displayedParam, (Locator)loc);
+        }
+        else if (detail != null)
+          error("invalid_param_detail", detail, (Locator)loc);
+        else
+          error("invalid_param", (Locator)loc);
+      }
+    }
+
+    String displayParam(String value, int pos) {
+      if (pos < 0)
+        pos = 0;
+      else if (pos > value.length())
+        pos = value.length();
+      return localizer.message("display_param", value.substring(0, pos), value.substring(pos));
+    }
+
+    public ParsedPattern makePattern(Location loc, Annotations anno)
+            throws BuildException {
+      try {
+        return pb.makeData(dtb.createDatatype());
+      }
+      catch (DatatypeException e) {
+        String detail = e.getMessage();
+        if (detail != null)
+          error("invalid_params_detail", detail, (Locator)loc);
+        else
+          error("invalid_params", (Locator)loc);
+        return pb.makeError();
+      }
+    }
+
+    public ParsedPattern makePattern(ParsedPattern except, Location loc, Annotations anno)
+            throws BuildException {
+      try {
+        return pb.makeDataExcept(dtb.createDatatype(), (Pattern)except, (Locator)loc);
+      }
+      catch (DatatypeException e) {
+        String detail = e.getMessage();
+        if (detail != null)
+          error("invalid_params_detail", detail, (Locator)loc);
+        else
+          error("invalid_params", (Locator)loc);
+        return pb.makeError();
+      }
+    }
+
+    public void annotation(ParsedElementAnnotation ea) {
+    }
+  }
+
+  public DataPatternBuilder makeDataPatternBuilder(String datatypeLibrary, String type, Location loc)
+          throws BuildException {
+    DatatypeLibrary dl = datatypeLibraryFactory.createDatatypeLibrary(datatypeLibrary);
+    if (dl == null)
+      error("unrecognized_datatype_library", datatypeLibrary, (Locator)loc);
+    else {
+      try {
+        return new DataPatternBuilderImpl(dl.createDatatypeBuilder(type));
+      }
+      catch (DatatypeException e) {
+        String detail = e.getMessage();
+        if (detail != null)
+          error("unsupported_datatype_detail", datatypeLibrary, type, detail, (Locator)loc);
+        else
+          error("unrecognized_datatype", datatypeLibrary, type, (Locator)loc);
+      }
+    }
+    return new DummyDataPatternBuilder();
+  }
+
+  public ParsedPattern makeValue(String datatypeLibrary, String type, String value, Context context, String ns,
+                                 Location loc, Annotations anno) throws BuildException {
+    DatatypeLibrary dl = datatypeLibraryFactory.createDatatypeLibrary(datatypeLibrary);
+    if (dl == null)
+      error("unrecognized_datatype_library", datatypeLibrary, (Locator)loc);
+    else {
+      try {
+        DatatypeBuilder dtb = dl.createDatatypeBuilder(type);
+        try {
+          Datatype dt = dtb.createDatatype();
+          Object obj = dt.createValue(value, new ValidationContextImpl(context, ns));
+          if (obj != null)
+            return pb.makeValue(dt, obj);
+          error("invalid_value", value, (Locator)loc);
+        }
+        catch (DatatypeException e) {
+          String detail = e.getMessage();
+          if (detail != null)
+            error("datatype_requires_param_detail", detail, (Locator)loc);
+          else
+            error("datatype_requires_param", (Locator)loc);
+        }
+      }
+      catch (DatatypeException e) {
+        error("unrecognized_datatype", datatypeLibrary, type, (Locator)loc);
+      }
+    }
+    return pb.makeError();
+  }
+
+  static class GrammarImpl implements Grammar, Div, IncludedGrammar {
+    private final SchemaBuilderImpl sb;
+    private final Hashtable defines;
+    private final RefPattern startRef;
+    private final Scope parent;
+
+    private GrammarImpl(SchemaBuilderImpl sb, Scope parent) {
+      this.sb = sb;
+      this.parent = parent;
+      this.defines = new Hashtable();
+      this.startRef = new RefPattern(null);
+    }
+
+    protected GrammarImpl(SchemaBuilderImpl sb, GrammarImpl g) {
+      this.sb = sb;
+      parent = g.parent;
+      startRef = g.startRef;
+      defines = g.defines;
+    }
+
+    public ParsedPattern endGrammar(Location loc, Annotations anno) throws BuildException {
+      for (Enumeration e = defines.keys();
+           e.hasMoreElements();) {
+        String name = (String)e.nextElement();
+        RefPattern rp = (RefPattern)defines.get(name);
+        if (rp.getPattern() == null) {
+          sb.error("reference_to_undefined", name, rp.getRefLocator());
+          rp.setPattern(sb.pb.makeError());
+        }
+      }
+      Pattern start = startRef.getPattern();
+      if (start == null) {
+        sb.error("missing_start_element", (Locator)loc);
+        start = sb.pb.makeError();
+      }
+      return start;
+    }
+
+    public void endDiv(Location loc, Annotations anno) throws BuildException {
+      // nothing to do
+    }
+
+    public ParsedPattern endIncludedGrammar(Location loc, Annotations anno) throws BuildException {
+        return null;
+    }
+
+    public void define(String name, GrammarSection.Combine combine, ParsedPattern pattern, Location loc, Annotations anno)
+            throws BuildException {
+      define(lookup(name), combine, pattern, loc);
+    }
+
+    private void define(RefPattern rp, GrammarSection.Combine combine, ParsedPattern pattern, Location loc)
+            throws BuildException {
+      switch (rp.getReplacementStatus()) {
+      case RefPattern.REPLACEMENT_KEEP:
+        if (combine == null) {
+          if (rp.isCombineImplicit()) {
+            if (rp.getName() == null)
+              sb.error("duplicate_start", (Locator)loc);
+            else
+              sb.error("duplicate_define", rp.getName(), (Locator)loc);
+          }
+          else
+            rp.setCombineImplicit();
+        }
+        else {
+          byte combineType = (combine == COMBINE_CHOICE ? RefPattern.COMBINE_CHOICE : RefPattern.COMBINE_INTERLEAVE);
+          if (rp.getCombineType() != RefPattern.COMBINE_NONE
+              && rp.getCombineType() != combineType) {
+            if (rp.getName() == null)
+              sb.error("conflict_combine_start", (Locator)loc);
+            else
+              sb.error("conflict_combine_define", rp.getName(), (Locator)loc);
+          }
+          rp.setCombineType(combineType);
+        }
+        Pattern p = (Pattern)pattern;
+        if (rp.getPattern() == null)
+          rp.setPattern(p);
+        else if (rp.getCombineType() == RefPattern.COMBINE_INTERLEAVE)
+          rp.setPattern(sb.pb.makeInterleave(rp.getPattern(), p));
+        else
+          rp.setPattern(sb.pb.makeChoice(rp.getPattern(), p));
+        break;
+      case RefPattern.REPLACEMENT_REQUIRE:
+        rp.setReplacementStatus(RefPattern.REPLACEMENT_IGNORE);
+        break;
+      case RefPattern.REPLACEMENT_IGNORE:
+        break;
+      }
+    }
+
+    public void topLevelAnnotation(ParsedElementAnnotation ea) throws BuildException {
+    }
+
+    public void topLevelComment(CommentList comments) throws BuildException {
+    }
+
+    private RefPattern lookup(String name) {
+      if (name == START)
+        return startRef;
+      return lookup1(name);
+    }
+
+    private RefPattern lookup1(String name) {
+      RefPattern p = (RefPattern)defines.get(name);
+      if (p == null) {
+        p = new RefPattern(name);
+        defines.put(name, p);
+      }
+      return p;
+    }
+
+    public ParsedPattern makeRef(String name, Location loc, Annotations anno) throws BuildException {
+      RefPattern p = lookup1(name);
+      if (p.getRefLocator() == null && loc != null)
+        p.setRefLocator((Locator)loc);
+      return p;
+    }
+
+    public ParsedPattern makeParentRef(String name, Location loc, Annotations anno) throws BuildException {
+        // TODO: do this check by the caller
+      if (parent == null) {
+        sb.error("parent_ref_outside_grammar", (Locator)loc);
+        return sb.makeErrorPattern();
+      }
+      return parent.makeRef(name, loc, anno);
+    }
+
+    public Div makeDiv() {
+      return this;
+    }
+
+    public Include makeInclude() {
+      return new IncludeImpl(sb, this);
+    }
+
+  }
+
+
+  static class Override {
+    Override(RefPattern prp, Override next) {
+      this.prp = prp;
+      this.next = next;
+    }
+
+    RefPattern prp;
+    Override next;
+    byte replacementStatus;
+  }
+
+
+  private static class IncludeImpl implements Include, Div {
+    private SchemaBuilderImpl sb;
+    private Override overrides;
+    private GrammarImpl grammar;
+
+    private IncludeImpl(SchemaBuilderImpl sb, GrammarImpl grammar) {
+      this.sb = sb;
+      this.grammar = grammar;
+    }
+
+    public void define(String name, GrammarSection.Combine combine, ParsedPattern pattern, Location loc, Annotations anno)
+            throws BuildException {
+      RefPattern rp = grammar.lookup(name);
+      overrides = new Override(rp, overrides);
+      grammar.define(rp, combine, pattern, loc);
+    }
+
+    public void endDiv(Location loc, Annotations anno) throws BuildException {
+      // nothing to do
+    }
+
+    public void topLevelAnnotation(ParsedElementAnnotation ea) throws BuildException {
+      // nothing to do
+    }
+
+    public void topLevelComment(CommentList comments) throws BuildException {
+    }
+
+    public Div makeDiv() {
+      return this;
+    }
+
+    public void endInclude(Parseable current,String uri, String ns,
+                           Location loc, Annotations anno) throws BuildException {
+      for (OpenIncludes inc = sb.openIncludes;
+           inc != null;
+           inc = inc.parent) {
+        if (inc.uri.equals(uri)) {
+          sb.error("recursive_include", uri, (Locator)loc);
+          return;
+        }
+      }
+
+      for (Override o = overrides; o != null; o = o.next) {
+        o.replacementStatus = o.prp.getReplacementStatus();
+        o.prp.setReplacementStatus(RefPattern.REPLACEMENT_REQUIRE);
+      }
+      try {
+        SchemaBuilderImpl isb = new SchemaBuilderImpl(ns, uri, sb);
+        current.parseInclude(uri, isb, new GrammarImpl(isb, grammar), ns);
+        for (Override o = overrides; o != null; o = o.next) {
+          if (o.prp.getReplacementStatus() == RefPattern.REPLACEMENT_REQUIRE) {
+            if (o.prp.getName() == null)
+              sb.error("missing_start_replacement", (Locator)loc);
+            else
+              sb.error("missing_define_replacement", o.prp.getName(), (Locator)loc);
+          }
+        }
+      }
+      catch (IllegalSchemaException e) {
+        sb.noteError();
+      }
+      finally {
+        for (Override o = overrides; o != null; o = o.next)
+          o.prp.setReplacementStatus(o.replacementStatus);
+      }
+    }
+
+    public Include makeInclude() {
+      return null;
+    }
+  }
+
+  public Grammar makeGrammar(Scope parent) {
+    return new GrammarImpl(this, parent);
+  }
+
+  public ParsedPattern annotate(ParsedPattern p, Annotations anno) throws BuildException {
+    return p;
+  }
+
+
+  public ParsedPattern annotateAfter(ParsedPattern p, ParsedElementAnnotation e) throws BuildException {
+    return p;
+  }
+
+  public ParsedPattern commentAfter(ParsedPattern p, CommentList comments) throws BuildException {
+    return p;
+  }
+
+
+  public ParsedPattern makeExternalRef(Parseable current, String uri, String ns, Scope scope,
+                                       Location loc, Annotations anno)
+          throws BuildException {
+    for (OpenIncludes inc = openIncludes;
+         inc != null;
+         inc = inc.parent) {
+      if (inc.uri.equals(uri)) {
+        error("recursive_include", uri, (Locator)loc);
+        return pb.makeError();
+      }
+    }
+    try {
+      return current.parseExternal(uri, new SchemaBuilderImpl(ns, uri, this), scope, ns );
+    }
+    catch (IllegalSchemaException e) {
+      noteError();
+      return pb.makeError();
+    }
+  }
+
+
+
+  public Location makeLocation(String systemId, int lineNumber, int columnNumber) {
+    return new LocatorImpl(systemId, lineNumber, columnNumber);
+  }
+
+  public Annotations makeAnnotations(CommentList comments, Context context) {
+    return this;
+  }
+
+  public ElementAnnotationBuilder makeElementAnnotationBuilder(String ns, String localName, String prefix,
+                                                               Location loc, CommentList comments, Context context) {
+    return this;
+  }
+
+  public CommentList makeCommentList() {
+    return this;
+  }
+
+  public void addComment(String value, Location loc) throws BuildException {
+  }
+
+  public void addAttribute(String ns, String localName, String prefix, String value, Location loc) {
+    // nothing needed
+  }
+
+  public void addElement(ParsedElementAnnotation ea) {
+    // nothing needed
+  }
+
+  public void addComment(CommentList comments) throws BuildException {
+    // nothing needed
+  }
+
+  public void addLeadingComment(CommentList comments) throws BuildException {
+    // nothing needed
+  }
+
+  public ParsedElementAnnotation makeElementAnnotation() {
+    return null;
+  }
+
+  public void addText(String value, Location loc, CommentList comments) throws BuildException {
+  }
+
+  public boolean usesComments() {
+    return false;
+  }
+
+  private void error(SAXParseException message) throws BuildException {
+    noteError();
+    try {
+      if (eh != null)
+        eh.error(message);
+    }
+    catch (SAXException e) {
+      throw new BuildException(e);
+    }
+  }
+
+  private void warning(SAXParseException message) throws BuildException {
+    try {
+      if (eh != null)
+        eh.warning(message);
+    }
+    catch (SAXException e) {
+      throw new BuildException(e);
+    }
+  }
+
+  private void error(String key, Locator loc) throws BuildException {
+    error(new SAXParseException(localizer.message(key), loc));
+  }
+
+  private void error(String key, String arg, Locator loc) throws BuildException {
+    error(new SAXParseException(localizer.message(key, arg), loc));
+  }
+
+  private void error(String key, String arg1, String arg2, Locator loc) throws BuildException {
+    error(new SAXParseException(localizer.message(key, arg1, arg2), loc));
+  }
+
+  private void error(String key, String arg1, String arg2, String arg3, Locator loc) throws BuildException {
+    error(new SAXParseException(localizer.message(key, new Object[]{arg1, arg2, arg3}), loc));
+  }
+  private void noteError() {
+    if (!hadError && parent != null)
+      parent.noteError();
+    hadError = true;
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/SchemaPatternBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/SchemaPatternBuilder.java
new file mode 100644
index 0000000..919fa27
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/SchemaPatternBuilder.java
@@ -0,0 +1,125 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.nc.NameClass;
+import org.relaxng.datatype.Datatype;
+import org.xml.sax.Locator;
+
+public class SchemaPatternBuilder extends PatternBuilder {
+  private boolean idTypes;
+  private final Pattern unexpandedNotAllowed =
+        new NotAllowedPattern() {
+        boolean isNotAllowed() {
+            return false;
+        }
+        Pattern expand(SchemaPatternBuilder b) {
+            return b.makeNotAllowed();
+        }
+    };
+
+  private final TextPattern text = new TextPattern();
+  private final PatternInterner schemaInterner = new PatternInterner();
+
+  public SchemaPatternBuilder() { }
+
+  public boolean hasIdTypes() {
+    return idTypes;
+  }
+
+  Pattern makeElement(NameClass nameClass, Pattern content, Locator loc) {
+    Pattern p = new ElementPattern(nameClass, content, loc);
+    return schemaInterner.intern(p);
+  }
+
+  Pattern makeAttribute(NameClass nameClass, Pattern value, Locator loc) {
+    if (value == notAllowed)
+      return value;
+    Pattern p = new AttributePattern(nameClass, value, loc);
+    return schemaInterner.intern(p);
+  }
+
+  Pattern makeData(Datatype dt) {
+    noteDatatype(dt);
+    Pattern p = new DataPattern(dt);
+    return schemaInterner.intern(p);
+  }
+
+  Pattern makeDataExcept(Datatype dt, Pattern except, Locator loc) {
+    noteDatatype(dt);
+    Pattern p = new DataExceptPattern(dt, except, loc);
+    return schemaInterner.intern(p);
+  }
+
+  Pattern makeValue(Datatype dt, Object obj) {
+    noteDatatype(dt);
+    Pattern p = new ValuePattern(dt, obj);
+    return schemaInterner.intern(p);
+  }
+
+  Pattern makeText() {
+    return text;
+  }
+
+  Pattern makeOneOrMore(Pattern p) {
+    if (p == text)
+      return p;
+    return super.makeOneOrMore(p);
+  }
+
+  Pattern makeUnexpandedNotAllowed() {
+    return unexpandedNotAllowed;
+  }
+
+  Pattern makeError() {
+    Pattern p = new ErrorPattern();
+    return schemaInterner.intern(p);
+  }
+
+  Pattern makeChoice(Pattern p1, Pattern p2) {
+    if (p1 == notAllowed || p1 == p2)
+      return p2;
+    if (p2 == notAllowed)
+      return p1;
+    return super.makeChoice(p1, p2);
+  }
+
+  Pattern makeList(Pattern p, Locator loc) {
+    if (p == notAllowed)
+      return p;
+    Pattern p1 = new ListPattern(p, loc);
+    return schemaInterner.intern(p1);
+  }
+
+  Pattern makeMixed(Pattern p) {
+    return makeInterleave(text, p);
+  }
+
+  private void noteDatatype(Datatype dt) {
+    if (dt.getIdType() != Datatype.ID_TYPE_NULL)
+      idTypes = true;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/StringPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/StringPattern.java
new file mode 100644
index 0000000..09d8da1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/StringPattern.java
@@ -0,0 +1,32 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+abstract class StringPattern extends Pattern {
+  StringPattern(int hc) {
+    super(false, DATA_CONTENT_TYPE, hc);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/TextPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/TextPattern.java
new file mode 100644
index 0000000..6b15463
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/TextPattern.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+
+public class TextPattern extends Pattern {
+  TextPattern() {
+    super(true, MIXED_CONTENT_TYPE, TEXT_HASH_CODE);
+  }
+
+  boolean samePattern(Pattern other) {
+    return other instanceof TextPattern;
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitText();
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseText(this);
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    switch (context) {
+    case DATA_EXCEPT_CONTEXT:
+      throw new RestrictionViolationException("data_except_contains_text");
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_text");
+    case LIST_CONTEXT:
+      throw new RestrictionViolationException("list_contains_text");
+    }
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ValuePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ValuePattern.java
new file mode 100644
index 0000000..18e4c59
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/ValuePattern.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary;
+
+import com.sun.xml.internal.rngom.binary.visitor.PatternFunction;
+import com.sun.xml.internal.rngom.binary.visitor.PatternVisitor;
+import org.relaxng.datatype.Datatype;
+
+public class ValuePattern extends StringPattern {
+  Object obj;
+  Datatype dt;
+
+  ValuePattern(Datatype dt, Object obj) {
+    super(combineHashCode(VALUE_HASH_CODE, obj.hashCode()));
+    this.dt = dt;
+    this.obj = obj;
+  }
+
+  boolean samePattern(Pattern other) {
+    if (getClass() != other.getClass())
+      return false;
+    if (!(other instanceof ValuePattern))
+      return false;
+    return (dt.equals(((ValuePattern)other).dt)
+            && dt.sameValue(obj, ((ValuePattern)other).obj));
+  }
+
+  public void accept(PatternVisitor visitor) {
+    visitor.visitValue(dt, obj);
+  }
+
+  public Object apply(PatternFunction f) {
+    return f.caseValue(this);
+  }
+
+  void checkRestrictions(int context, DuplicateAttributeDetector dad, Alphabet alpha)
+    throws RestrictionViolationException {
+    switch (context) {
+    case START_CONTEXT:
+      throw new RestrictionViolationException("start_contains_value");
+    }
+  }
+
+  Datatype getDatatype() {
+    return dt;
+  }
+
+  Object getValue() {
+    return obj;
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/package.html b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/package.html
new file mode 100644
index 0000000..b924926
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/package.html
@@ -0,0 +1,5 @@
+<html>
+  <body>
+    Minimal binarized pattern object model (one example of <tt>ast.om</tt> implementation).
+  </body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/ChildElementFinder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/ChildElementFinder.java
new file mode 100644
index 0000000..4a40740
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/ChildElementFinder.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary.visitor;
+
+import com.sun.xml.internal.rngom.binary.Pattern;
+import com.sun.xml.internal.rngom.nc.NameClass;
+
+import java.util.HashSet;
+import java.util.Set;
+
+/**
+ * Visits a pattern and creates a list of possible child elements.
+ *
+ * <p>
+ * One can use a similar technique to introspect a pattern.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class ChildElementFinder extends PatternWalker {
+
+    private final Set children = new HashSet();
+
+    /**
+     * Represents a child element.
+     */
+    public static class Element {
+        public final NameClass nc;
+        public final Pattern content;
+
+        public Element(NameClass nc, Pattern content) {
+            this.nc = nc;
+            this.content = content;
+        }
+
+        public boolean equals(Object o) {
+            if (this == o) return true;
+            if (!(o instanceof Element)) return false;
+
+            final Element element = (Element) o;
+
+            if (content != null ? !content.equals(element.content) : element.content != null) return false;
+            if (nc != null ? !nc.equals(element.nc) : element.nc != null) return false;
+
+            return true;
+        }
+
+        public int hashCode() {
+            int result;
+            result = (nc != null ? nc.hashCode() : 0);
+            result = 29 * result + (content != null ? content.hashCode() : 0);
+            return result;
+        }
+    }
+
+    /**
+     * Returns a set of {@link Element}.
+     */
+    public Set getChildren() {
+        return children;
+    }
+
+    public void visitElement(NameClass nc, Pattern content) {
+        children.add(new Element(nc,content));
+    }
+
+    public void visitAttribute(NameClass ns, Pattern value) {
+        // there will be no element inside attribute,
+        // so don't go in there.
+    }
+
+    public void visitList(Pattern p) {
+        // there will be no element inside a list,
+        // so don't go in there.
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternFunction.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternFunction.java
new file mode 100644
index 0000000..ef7bef9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternFunction.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary.visitor;
+
+import com.sun.xml.internal.rngom.binary.AfterPattern;
+import com.sun.xml.internal.rngom.binary.AttributePattern;
+import com.sun.xml.internal.rngom.binary.ChoicePattern;
+import com.sun.xml.internal.rngom.binary.DataExceptPattern;
+import com.sun.xml.internal.rngom.binary.DataPattern;
+import com.sun.xml.internal.rngom.binary.ElementPattern;
+import com.sun.xml.internal.rngom.binary.EmptyPattern;
+import com.sun.xml.internal.rngom.binary.ErrorPattern;
+import com.sun.xml.internal.rngom.binary.GroupPattern;
+import com.sun.xml.internal.rngom.binary.InterleavePattern;
+import com.sun.xml.internal.rngom.binary.ListPattern;
+import com.sun.xml.internal.rngom.binary.NotAllowedPattern;
+import com.sun.xml.internal.rngom.binary.OneOrMorePattern;
+import com.sun.xml.internal.rngom.binary.RefPattern;
+import com.sun.xml.internal.rngom.binary.TextPattern;
+import com.sun.xml.internal.rngom.binary.ValuePattern;
+
+public interface PatternFunction {
+    Object caseEmpty(EmptyPattern p);
+    Object caseNotAllowed(NotAllowedPattern p);
+    Object caseError(ErrorPattern p);
+    Object caseGroup(GroupPattern p);
+    Object caseInterleave(InterleavePattern p);
+    Object caseChoice(ChoicePattern p);
+    Object caseOneOrMore(OneOrMorePattern p);
+    Object caseElement(ElementPattern p);
+    Object caseAttribute(AttributePattern p);
+    Object caseData(DataPattern p);
+    Object caseDataExcept(DataExceptPattern p);
+    Object caseValue(ValuePattern p);
+    Object caseText(TextPattern p);
+    Object caseList(ListPattern p);
+    Object caseRef(RefPattern p);
+    Object caseAfter(AfterPattern p);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternVisitor.java
new file mode 100644
index 0000000..adaab60
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternVisitor.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary.visitor;
+
+import com.sun.xml.internal.rngom.binary.Pattern;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import org.relaxng.datatype.Datatype;
+
+public interface PatternVisitor {
+    void visitEmpty();
+    void visitNotAllowed();
+    void visitError();
+    void visitAfter(Pattern p1, Pattern p2);
+    void visitGroup(Pattern p1, Pattern p2);
+    void visitInterleave(Pattern p1, Pattern p2);
+    void visitChoice(Pattern p1, Pattern p2);
+    void visitOneOrMore(Pattern p);
+    void visitElement(NameClass nc, Pattern content);
+    void visitAttribute(NameClass ns, Pattern value);
+    void visitData(Datatype dt);
+    void visitDataExcept(Datatype dt, Pattern except);
+    void visitValue(Datatype dt, Object obj);
+    void visitText();
+    void visitList(Pattern p);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternWalker.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternWalker.java
new file mode 100644
index 0000000..fa52209
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/binary/visitor/PatternWalker.java
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.binary.visitor;
+
+import com.sun.xml.internal.rngom.binary.Pattern;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import org.relaxng.datatype.Datatype;
+
+/**
+ * Walks the pattern tree.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class PatternWalker implements PatternVisitor {
+    public void visitEmpty() {
+    }
+
+    public void visitNotAllowed() {
+    }
+
+    public void visitError() {
+    }
+
+    public void visitGroup(Pattern p1, Pattern p2) {
+        visitBinary(p1, p2);
+    }
+
+    protected void visitBinary(Pattern p1, Pattern p2) {
+        p1.accept(this);
+        p2.accept(this);
+    }
+
+    public void visitInterleave(Pattern p1, Pattern p2) {
+        visitBinary(p1, p2);
+    }
+
+    public void visitChoice(Pattern p1, Pattern p2) {
+        visitBinary(p1, p2);
+    }
+
+    public void visitOneOrMore(Pattern p) {
+        p.accept(this);
+    }
+
+    public void visitElement(NameClass nc, Pattern content) {
+        content.accept(this);
+    }
+
+    public void visitAttribute(NameClass ns, Pattern value) {
+        value.accept(this);
+    }
+
+    public void visitData(Datatype dt) {
+    }
+
+    public void visitDataExcept(Datatype dt, Pattern except) {
+    }
+
+    public void visitValue(Datatype dt, Object obj) {
+    }
+
+    public void visitText() {
+    }
+
+    public void visitList(Pattern p) {
+        p.accept(this);
+    }
+
+    public void visitAfter(Pattern p1, Pattern p2) {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/Annotation.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/Annotation.java
new file mode 100644
index 0000000..381e6b0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/Annotation.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.util.LocatorImpl;
+
+import javax.xml.namespace.QName;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+class Annotation implements Annotations<ElementWrapper,LocatorImpl,CommentListImpl> {
+
+    private final DAnnotation a = new DAnnotation();
+
+    public void addAttribute(String ns, String localName, String prefix, String value, LocatorImpl loc) throws BuildException {
+        a.attributes.put(new QName(ns,localName,prefix),
+            new DAnnotation.Attribute(ns,localName,prefix,value,loc));
+    }
+
+    public void addElement(ElementWrapper ea) throws BuildException {
+        a.contents.add(ea.element);
+    }
+
+    public void addComment(CommentListImpl comments) throws BuildException {
+    }
+
+    public void addLeadingComment(CommentListImpl comments) throws BuildException {
+    }
+
+    DAnnotation getResult() {
+        return a;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/CommentListImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/CommentListImpl.java
new file mode 100644
index 0000000..843a592
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/CommentListImpl.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.util.LocatorImpl;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class CommentListImpl implements CommentList<LocatorImpl> {
+    public void addComment(String value, LocatorImpl loc) throws BuildException {
+        // TODO
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DAnnotation.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DAnnotation.java
new file mode 100644
index 0000000..b4d4609
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DAnnotation.java
@@ -0,0 +1,173 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import org.xml.sax.Locator;
+import org.w3c.dom.Element;
+
+import javax.xml.namespace.QName;
+import java.util.Map;
+import java.util.HashMap;
+import java.util.List;
+import java.util.ArrayList;
+import java.util.Collections;
+
+/**
+ * Annotation.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DAnnotation {
+
+    /**
+     * Instance reserved to be empty.
+     */
+    static final DAnnotation EMPTY = new DAnnotation();
+
+    /**
+     * Keyed by QName.
+     */
+    final Map<QName,Attribute> attributes = new HashMap<QName,Attribute>();
+
+    /**
+     * List of nested elements.
+     */
+    final List<Element> contents = new ArrayList<Element>();
+
+    /**
+     * Attribute.
+     */
+    public static class Attribute {
+        private final String ns;
+        private final String localName;
+        private final String prefix;
+
+        private String value;
+        private Locator loc;
+
+        public Attribute(String ns, String localName, String prefix) {
+            this.ns = ns;
+            this.localName = localName;
+            this.prefix = prefix;
+        }
+
+        public Attribute(String ns, String localName, String prefix, String value, Locator loc) {
+            this.ns = ns;
+            this.localName = localName;
+            this.prefix = prefix;
+            this.value = value;
+            this.loc = loc;
+        }
+
+        /**
+         * Gets the namespace URI of this attribute.
+         *
+         * @return
+         *      can be empty (to represent the default namespace), but never null.
+         */
+        public String getNs() {
+            return ns;
+        }
+
+        /**
+         * Gets the local name of this attribute.
+         *
+         * @return
+         *      always non-null.
+         */
+        public String getLocalName() {
+            return localName;
+        }
+
+        /**
+         * Gets the prefix of thie attribute.
+         *
+         * @return
+         *      null if this attribute didn't have a prefix.
+         */
+        public String getPrefix() {
+            return prefix;
+        }
+
+        /**
+         * Gets the attribute value.
+         *
+         * @return
+         *      never null.
+         */
+        public String getValue() {
+            return value;
+        }
+
+        /**
+         * Gets the location in the source schema file where this annotation was present.
+         *
+         * @return
+         *      never null.
+         */
+        public Locator getLoc() {
+            return loc;
+        }
+    }
+
+    /**
+     * Gets the attribute of a given name.
+     *
+     * @param nsUri
+     *      can be empty but must not be null.
+     * @return
+     *      null if no such attribute is found.
+     */
+    public Attribute getAttribute( String nsUri, String localName ) {
+        return getAttribute(new QName(nsUri,localName));
+    }
+
+    public Attribute getAttribute( QName n ) {
+        return attributes.get(n);
+    }
+
+    /**
+     * Gets the read-only view of all the attributes.
+     *
+     * @return
+     *      can be empty but never null.
+     *      the returned map is read-only.
+     */
+    public Map<QName,Attribute> getAttributes() {
+        return Collections.unmodifiableMap(attributes);
+    }
+
+    /**
+     * Gets the read-only view of all the child elements of this annotation.
+     *
+     * @return
+     *      can be empty but never null.
+     *      the returned list is read-only.
+     */
+    public List<Element> getChildren() {
+        return Collections.unmodifiableList(contents);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DAttributePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DAttributePattern.java
new file mode 100644
index 0000000..eb08aed
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DAttributePattern.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.nc.NameClass;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DAttributePattern extends DXmlTokenPattern {
+    public DAttributePattern(NameClass name) {
+        super(name);
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onAttribute(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DChoicePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DChoicePattern.java
new file mode 100644
index 0000000..863fed0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DChoicePattern.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+/**
+ * &lt;choice> pattern.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DChoicePattern extends DContainerPattern {
+    public boolean isNullable() {
+        for( DPattern p=firstChild(); p!=null; p=p.next )
+            if(p.isNullable())
+                return true;
+        return false;
+    }
+    public <V> V accept( DPatternVisitor<V> visitor ) {
+        return visitor.onChoice(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DContainerPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DContainerPattern.java
new file mode 100644
index 0000000..5e29a5f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DContainerPattern.java
@@ -0,0 +1,85 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import java.util.Iterator;
+
+
+/**
+ * A pattern that can contain other patterns.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class DContainerPattern extends DPattern implements Iterable<DPattern> {
+    private DPattern head;
+    private DPattern tail;
+
+    public DPattern firstChild() {
+        return head;
+    }
+
+    public DPattern lastChild() {
+        return tail;
+    }
+
+    public int countChildren() {
+        int i=0;
+        for( DPattern p=firstChild(); p!=null; p=p.next)
+            i++;
+        return i;
+    }
+
+    public Iterator<DPattern> iterator() {
+        return new Iterator<DPattern>() {
+            DPattern next = head;
+            public boolean hasNext() {
+                return next!=null;
+            }
+
+            public DPattern next() {
+                DPattern r = next;
+                next = next.next;
+                return r;
+            }
+
+            public void remove() {
+                throw new UnsupportedOperationException();
+            }
+        };
+    }
+
+    void add( DPattern child ) {
+        if(tail==null) {
+            child.prev = child.next = null;
+            head = tail = child;
+        } else {
+            child.prev = tail;
+            tail.next = child;
+            child.next = null;
+            tail = child;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DDataPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DDataPattern.java
new file mode 100644
index 0000000..38aa868
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DDataPattern.java
@@ -0,0 +1,136 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.parse.Context;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DDataPattern extends DPattern {
+    DPattern except;
+
+    String datatypeLibrary;
+    String type;
+
+    final List<Param> params = new ArrayList<Param>();
+
+    /**
+     * Parameter to a data pattern.
+     */
+    public final class Param {
+        String name;
+        String value;
+        Context context;
+        String ns;
+        Location loc;
+        Annotation anno;
+
+        public Param(String name, String value, Context context, String ns, Location loc, Annotation anno) {
+            this.name = name;
+            this.value = value;
+            this.context = context;
+            this.ns = ns;
+            this.loc = loc;
+            this.anno = anno;
+        }
+
+        public String getName() {
+            return name;
+        }
+
+        public String getValue() {
+            return value;
+        }
+
+        public Context getContext() {
+            return context;
+        }
+
+        public String getNs() {
+            return ns;
+        }
+
+        public Location getLoc() {
+            return loc;
+        }
+
+        public Annotation getAnno() {
+            return anno;
+        }
+    }
+
+    /**
+     * Gets the datatype library URI.
+     *
+     * @return
+     *      Can be empty (which represents the built-in datatypes), but never null.
+     */
+    public String getDatatypeLibrary() {
+        return datatypeLibrary;
+    }
+
+    /**
+     * Gets the datatype name, such as "int" or "token".
+     *
+     * @return
+     *      never null.
+     */
+    public String getType() {
+        return type;
+    }
+
+    /**
+     * Gets the parameters of this &lt;data pattern.
+     *
+     * @return
+     *      can be empty but never null.
+     */
+    public List<Param> getParams() {
+        return params;
+    }
+
+    /**
+     * Gets the pattern that reprsents the &lt;except> child of this data pattern.
+     *
+     * @return null if not exist.
+     */
+    public DPattern getExcept() {
+        return except;
+    }
+
+    public boolean isNullable() {
+        return false;
+    }
+
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onData(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DDefine.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DDefine.java
new file mode 100644
index 0000000..8401f18
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DDefine.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DDefine {
+    private final String name;
+
+    private DPattern pattern;
+    private Boolean nullable;
+    DAnnotation annotation;
+
+    public DDefine(String name) {
+        this.name = name;
+    }
+
+    public DPattern getPattern() {
+        return pattern;
+    }
+
+    public DAnnotation getAnnotation() {
+        if(annotation==null)
+            return DAnnotation.EMPTY;
+        return annotation;
+    }
+
+    public void setPattern(DPattern pattern) {
+        this.pattern = pattern;
+        this.nullable = null;
+    }
+
+    /**
+     * Gets the name of the pattern block.
+     */
+    public String getName() {
+        return name;
+    }
+
+    public boolean isNullable() {
+        if(nullable==null)
+            nullable = pattern.isNullable()?Boolean.TRUE:Boolean.FALSE;
+        return nullable.booleanValue();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DElementPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DElementPattern.java
new file mode 100644
index 0000000..c0b0b7d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DElementPattern.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.nc.NameClass;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DElementPattern extends DXmlTokenPattern {
+    public DElementPattern(NameClass name) {
+        super(name);
+    }
+
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onElement(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DEmptyPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DEmptyPattern.java
new file mode 100644
index 0000000..36226a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DEmptyPattern.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DEmptyPattern extends DPattern {
+    public boolean isNullable() {
+        return true;
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onEmpty(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DGrammarPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DGrammarPattern.java
new file mode 100644
index 0000000..7690a77
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DGrammarPattern.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+
+/**
+ * &lt;grammar> pattern, which is a collection of named patterns.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DGrammarPattern extends DPattern implements Iterable<DDefine> {
+    private final Map<String,DDefine> patterns = new HashMap<String,DDefine>();
+
+    DPattern start;
+
+    /**
+     * Gets the start pattern.
+     */
+    public DPattern getStart() {
+        return start;
+    }
+
+    /**
+     * Gets the named pattern by its name.
+     *
+     * @return
+     *      null if not found.
+     */
+    public DDefine get( String name ) {
+        return patterns.get(name);
+    }
+
+    DDefine getOrAdd( String name ) {
+        if(patterns.containsKey(name)) {
+            return get(name);
+        } else {
+            DDefine d = new DDefine(name);
+            patterns.put(name,d);
+            return d;
+        }
+    }
+
+    /**
+     * Iterates all the {@link DDefine}s in this grammar.
+     */
+    public Iterator<DDefine> iterator() {
+        return patterns.values().iterator();
+    }
+
+    public boolean isNullable() {
+        return start.isNullable();
+    }
+
+    public <V> V accept( DPatternVisitor<V> visitor ) {
+        return visitor.onGrammar(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DGroupPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DGroupPattern.java
new file mode 100644
index 0000000..403b6cf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DGroupPattern.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DGroupPattern extends DContainerPattern {
+    public boolean isNullable() {
+        for( DPattern p=firstChild(); p!=null; p=p.next )
+            if(!p.isNullable())
+                return false;
+        return true;
+    }
+    public <V> V accept( DPatternVisitor<V> visitor ) {
+        return visitor.onGroup(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DInterleavePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DInterleavePattern.java
new file mode 100644
index 0000000..d0b2201
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DInterleavePattern.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DInterleavePattern extends DContainerPattern {
+    public boolean isNullable() {
+        for( DPattern p=firstChild(); p!=null; p=p.next )
+            if(!p.isNullable())
+                return false;
+        return true;
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onInterleave(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DListPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DListPattern.java
new file mode 100644
index 0000000..7655d66
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DListPattern.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DListPattern extends DUnaryPattern {
+    public boolean isNullable() {
+        return getChild().isNullable();
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onList(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DMixedPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DMixedPattern.java
new file mode 100644
index 0000000..8b4de88
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DMixedPattern.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DMixedPattern extends DUnaryPattern {
+    public boolean isNullable() {
+        return getChild().isNullable();
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onMixed(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DNotAllowedPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DNotAllowedPattern.java
new file mode 100644
index 0000000..fa3aa69
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DNotAllowedPattern.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DNotAllowedPattern extends DPattern {
+    public boolean isNullable() {
+        return false;
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onNotAllowed(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOMPrinter.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOMPrinter.java
new file mode 100644
index 0000000..d65d6fe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOMPrinter.java
@@ -0,0 +1,171 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.CDATASection;
+import org.w3c.dom.Comment;
+import org.w3c.dom.Document;
+import org.w3c.dom.DocumentFragment;
+import org.w3c.dom.Element;
+import org.w3c.dom.EntityReference;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+import org.w3c.dom.ProcessingInstruction;
+import org.w3c.dom.Text;
+
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+
+/**
+ * Printer of DOM to XML using StAX {@link XMLStreamWriter}.
+ *
+ * @author <A href="mailto:demakov@ispras.ru">Alexey Demakov</A>
+ */
+class DOMPrinter {
+    protected XMLStreamWriter out;
+
+    public DOMPrinter(XMLStreamWriter out) {
+        this.out = out;
+    }
+
+    public void print(Node node) throws XMLStreamException {
+        switch (node.getNodeType()) {
+        case Node.DOCUMENT_NODE:
+            visitDocument((Document) node);
+            break;
+        case Node.DOCUMENT_FRAGMENT_NODE:
+            visitDocumentFragment((DocumentFragment) node);
+            break;
+        case Node.ELEMENT_NODE:
+            visitElement((Element) node);
+            break;
+        case Node.TEXT_NODE:
+            visitText((Text) node);
+            break;
+        case Node.CDATA_SECTION_NODE:
+            visitCDATASection((CDATASection) node);
+            break;
+        case Node.PROCESSING_INSTRUCTION_NODE:
+            visitProcessingInstruction((ProcessingInstruction) node);
+            break;
+        case Node.ENTITY_REFERENCE_NODE:
+            visitReference((EntityReference) node);
+            break;
+        case Node.COMMENT_NODE:
+            visitComment((Comment) node);
+            break;
+        case Node.DOCUMENT_TYPE_NODE:
+            break;
+        case Node.ATTRIBUTE_NODE:
+        case Node.ENTITY_NODE:
+        default:
+            throw new XMLStreamException("Unexpected DOM Node Type "
+                + node.getNodeType()
+            );
+        }
+    }
+
+    protected void visitChildren(Node node)
+        throws XMLStreamException {
+        NodeList nodeList = node.getChildNodes();
+        if (nodeList != null) {
+            for (int i = 0; i < nodeList.getLength(); i++) {
+                print(nodeList.item(i));
+            }
+        }
+    }
+
+    protected void visitDocument(Document document)
+        throws XMLStreamException {
+        out.writeStartDocument();
+        print(document.getDocumentElement());
+        out.writeEndDocument();
+    }
+
+    protected void visitDocumentFragment(DocumentFragment documentFragment)
+        throws XMLStreamException {
+        visitChildren(documentFragment);
+    }
+
+    protected void visitElement(Element node)
+        throws XMLStreamException {
+        out.writeStartElement(node.getPrefix()
+            , node.getLocalName()
+            , node.getNamespaceURI()
+        );
+        NamedNodeMap attrs = node.getAttributes();
+        for (int i = 0; i < attrs.getLength(); i++) {
+            visitAttr((Attr) attrs.item(i));
+        }
+        visitChildren(node);
+        out.writeEndElement();
+    }
+
+    protected void visitAttr(Attr node)
+        throws XMLStreamException {
+        String name = node.getLocalName();
+        if (name.equals("xmlns")) {
+            out.writeDefaultNamespace(node.getNamespaceURI());
+        } else {
+            String prefix = node.getPrefix();
+            if (prefix != null && prefix.equals("xmlns")) {
+                out.writeNamespace(prefix, node.getNamespaceURI());
+            } else {
+                out.writeAttribute(prefix
+                    , node.getNamespaceURI()
+                    , name
+                    , node.getNodeValue()
+                );
+            }
+        }
+    }
+
+    protected void visitComment(Comment comment) throws XMLStreamException {
+        out.writeComment(comment.getData());
+    }
+
+    protected void visitText(Text node) throws XMLStreamException {
+        out.writeCharacters(node.getNodeValue());
+    }
+
+    protected void visitCDATASection(CDATASection cdata) throws XMLStreamException {
+        out.writeCData(cdata.getNodeValue());
+    }
+
+    protected void visitProcessingInstruction(ProcessingInstruction processingInstruction)
+        throws XMLStreamException {
+        out.writeProcessingInstruction(processingInstruction.getNodeName()
+            , processingInstruction.getData()
+        );
+    }
+
+    protected void visitReference(EntityReference entityReference)
+        throws XMLStreamException {
+        visitChildren(entityReference);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOneOrMorePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOneOrMorePattern.java
new file mode 100644
index 0000000..c8a77c8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOneOrMorePattern.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DOneOrMorePattern extends DUnaryPattern {
+    public boolean isNullable() {
+        return getChild().isNullable();
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onOneOrMore(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOptionalPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOptionalPattern.java
new file mode 100644
index 0000000..3956f19
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DOptionalPattern.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DOptionalPattern extends DUnaryPattern {
+    public boolean isNullable() {
+        return true;
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onOptional(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPattern.java
new file mode 100644
index 0000000..118d148
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPattern.java
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import org.xml.sax.Locator;
+
+/**
+ * Base class of all the patterns.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class DPattern implements ParsedPattern {
+    Locator location;
+    DAnnotation annotation;
+
+    /**
+     * Used to chain the child patterns in a doubly-linked list.
+     */
+    DPattern next;
+    DPattern prev;
+
+    /**
+     * Returns where the pattern is defined in the source code.
+     */
+    public Locator getLocation() {
+        return location;
+    }
+
+    /**
+     * Returns the annotation associated with it.
+     *
+     * @return
+     *      may be empty, but never be null.
+     */
+    public DAnnotation getAnnotation() {
+        if(annotation==null)
+            return DAnnotation.EMPTY;
+        return annotation;
+    }
+
+    /**
+     * Returns true if this pattern is nullable.
+     *
+     * A nullable pattern is a pattern that can match the empty sequence.
+     */
+    public abstract boolean isNullable();
+
+    public abstract <V> V accept( DPatternVisitor<V> visitor );
+
+    /**
+     * Creates a {@link Parseable} object that reparses this pattern.
+     */
+    public Parseable createParseable() {
+        return new PatternParseable(this);
+    }
+
+    /**
+     * Returns true if this is {@link DElementPattern}.
+     */
+    public final boolean isElement() {
+        return this instanceof DElementPattern;
+    }
+
+    /**
+     * Returns true if this is {@link DAttributePattern}.
+     */
+    public final boolean isAttribute() {
+        return this instanceof DAttributePattern;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPatternVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPatternVisitor.java
new file mode 100644
index 0000000..d879298
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPatternVisitor.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface DPatternVisitor<V> {
+    V onAttribute( DAttributePattern p );
+    V onChoice( DChoicePattern p );
+    V onData( DDataPattern p );
+    V onElement( DElementPattern p );
+    V onEmpty( DEmptyPattern p );
+    V onGrammar( DGrammarPattern p );
+    V onGroup( DGroupPattern p );
+    V onInterleave( DInterleavePattern p );
+    V onList( DListPattern p );
+    V onMixed( DMixedPattern p );
+    V onNotAllowed( DNotAllowedPattern p );
+    V onOneOrMore( DOneOrMorePattern p );
+    V onOptional( DOptionalPattern p );
+    V onRef( DRefPattern p );
+    V onText( DTextPattern p );
+    V onValue( DValuePattern p );
+    V onZeroOrMore( DZeroOrMorePattern p );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPatternWalker.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPatternWalker.java
new file mode 100644
index 0000000..3ca7fb6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DPatternWalker.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DPatternWalker implements DPatternVisitor<Void> {
+    public Void onAttribute(DAttributePattern p) {
+        return onXmlToken(p);
+    }
+
+    protected Void onXmlToken(DXmlTokenPattern p) {
+        return onUnary(p);
+    }
+
+    public Void onChoice(DChoicePattern p) {
+        return onContainer(p);
+    }
+
+    protected Void onContainer(DContainerPattern p) {
+        for( DPattern c=p.firstChild(); c!=null; c=c.next )
+            c.accept(this);
+        return null;
+    }
+
+    public Void onData(DDataPattern p) {
+        return null;
+    }
+
+    public Void onElement(DElementPattern p) {
+        return onXmlToken(p);
+    }
+
+    public Void onEmpty(DEmptyPattern p) {
+        return null;
+    }
+
+    public Void onGrammar(DGrammarPattern p) {
+        return p.getStart().accept(this);
+    }
+
+    public Void onGroup(DGroupPattern p) {
+        return onContainer(p);
+    }
+
+    public Void onInterleave(DInterleavePattern p) {
+        return onContainer(p);
+    }
+
+    public Void onList(DListPattern p) {
+        return onUnary(p);
+    }
+
+    public Void onMixed(DMixedPattern p) {
+        return onUnary(p);
+    }
+
+    public Void onNotAllowed(DNotAllowedPattern p) {
+        return null;
+    }
+
+    public Void onOneOrMore(DOneOrMorePattern p) {
+        return onUnary(p);
+    }
+
+    public Void onOptional(DOptionalPattern p) {
+        return onUnary(p);
+    }
+
+    public Void onRef(DRefPattern p) {
+        return p.getTarget().getPattern().accept(this);
+    }
+
+    public Void onText(DTextPattern p) {
+        return null;
+    }
+
+    public Void onValue(DValuePattern p) {
+        return null;
+    }
+
+    public Void onZeroOrMore(DZeroOrMorePattern p) {
+        return onUnary(p);
+    }
+
+    protected Void onUnary(DUnaryPattern p) {
+        return p.getChild().accept(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DRefPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DRefPattern.java
new file mode 100644
index 0000000..7eb09cf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DRefPattern.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DRefPattern extends DPattern {
+    private final DDefine target;
+
+    public DRefPattern(DDefine target) {
+        this.target = target;
+    }
+
+    public boolean isNullable() {
+        return target.isNullable();
+    }
+
+    /**
+     * Gets the {@link DDefine} that this block refers to.
+     */
+    public DDefine getTarget() {
+        return target;
+    }
+
+    /**
+     * Gets the name of the target.
+     */
+    public String getName() {
+        return target.getName();
+    }
+
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onRef(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DSchemaBuilderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DSchemaBuilderImpl.java
new file mode 100644
index 0000000..ff9fb90
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DSchemaBuilderImpl.java
@@ -0,0 +1,213 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.ast.util.LocatorImpl;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import com.sun.xml.internal.rngom.nc.NameClassBuilderImpl;
+import com.sun.xml.internal.rngom.parse.Context;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import org.w3c.dom.Document;
+
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.ParserConfigurationException;
+import java.util.List;
+
+/**
+ * Parses as {@link Parseable} into a {@link DPattern}.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DSchemaBuilderImpl implements SchemaBuilder
+    <NameClass,DPattern,ElementWrapper,LocatorImpl,Annotation,CommentListImpl> {
+
+    private final NameClassBuilder ncb = new NameClassBuilderImpl();
+
+    /**
+     * Used to parse annotations.
+     */
+    private final Document dom;
+
+    public DSchemaBuilderImpl() {
+        try {
+            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+            dbf.setNamespaceAware(true);
+            this.dom = dbf.newDocumentBuilder().newDocument();
+        } catch (ParserConfigurationException e) {
+            // impossible
+            throw new InternalError(e.getMessage());
+        }
+    }
+
+    public NameClassBuilder getNameClassBuilder() throws BuildException {
+        return ncb;
+    }
+
+    static  DPattern wrap( DPattern p, LocatorImpl loc, Annotation anno ) {
+        p.location = loc;
+        if(anno!=null)
+            p.annotation = anno.getResult();
+        return p;
+    }
+
+    static DContainerPattern addAll( DContainerPattern parent, List<DPattern> children) {
+        for (DPattern c : children)
+            parent.add(c);
+        return parent;
+    }
+
+    static DUnaryPattern addBody( DUnaryPattern parent, ParsedPattern _body, LocatorImpl loc ) {
+        parent.setChild( (DPattern)_body );
+        return parent;
+    }
+
+    public DPattern makeChoice(List<DPattern> patterns, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addAll(new DChoicePattern(),patterns),loc,anno);
+    }
+
+    public DPattern makeInterleave(List<DPattern> patterns, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addAll(new DInterleavePattern(),patterns),loc,anno);
+    }
+
+    public DPattern makeGroup(List<DPattern> patterns, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addAll(new DGroupPattern(),patterns),loc,anno);
+    }
+
+    public DPattern makeOneOrMore(DPattern p, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addBody(new DOneOrMorePattern(),p,loc),loc,anno);
+    }
+
+    public DPattern makeZeroOrMore(DPattern p, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addBody(new DZeroOrMorePattern(),p,loc),loc,anno);
+    }
+
+    public DPattern makeOptional(DPattern p, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addBody(new DOptionalPattern(),p,loc),loc,anno);
+    }
+
+    public DPattern makeList(DPattern p, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addBody(new DListPattern(),p,loc),loc,anno);
+    }
+
+    public DPattern makeMixed(DPattern p, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addBody(new DMixedPattern(),p,loc),loc,anno);
+    }
+
+    public DPattern makeEmpty(LocatorImpl loc, Annotation anno) {
+        return wrap(new DEmptyPattern(),loc,anno);
+    }
+
+    public DPattern makeNotAllowed(LocatorImpl loc, Annotation anno) {
+        return wrap(new DNotAllowedPattern(),loc,anno);
+    }
+
+    public DPattern makeText(LocatorImpl loc, Annotation anno) {
+        return wrap(new DTextPattern(),loc,anno);
+    }
+
+    public DPattern makeAttribute(NameClass nc, DPattern p, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addBody(new DAttributePattern(nc),p,loc),loc,anno);
+    }
+
+    public DPattern makeElement(NameClass nc, DPattern p, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(addBody(new DElementPattern(nc),p,loc),loc,anno);
+    }
+
+    public DataPatternBuilder makeDataPatternBuilder(String datatypeLibrary, String type, LocatorImpl loc) throws BuildException {
+        return new DataPatternBuilderImpl(datatypeLibrary,type,loc);
+    }
+
+    public DPattern makeValue(String datatypeLibrary, String type, String value, Context c, String ns, LocatorImpl loc, Annotation anno) throws BuildException {
+        return wrap(new DValuePattern(datatypeLibrary,type,value,c.copy(),ns),loc,anno);
+    }
+
+    public Grammar makeGrammar(Scope parent) {
+        return new GrammarBuilderImpl(new DGrammarPattern(),parent,this);
+    }
+
+    public DPattern annotate(DPattern p, Annotation anno) throws BuildException {
+        // TODO: not sure when this is used
+        return p;
+    }
+
+    public DPattern annotateAfter(DPattern p, ElementWrapper e) throws BuildException {
+        // TODO
+        return p;
+    }
+
+    public DPattern commentAfter(DPattern p, CommentListImpl comments) throws BuildException {
+        // TODO
+        return p;
+    }
+
+    public DPattern makeExternalRef(Parseable current, String uri, String ns,
+                                    Scope<DPattern, ElementWrapper, LocatorImpl, Annotation, CommentListImpl> scope, LocatorImpl loc, Annotation anno) throws BuildException, IllegalSchemaException {
+        // TODO
+        return null;
+    }
+
+    public LocatorImpl makeLocation(String systemId, int lineNumber, int columnNumber) {
+        return new LocatorImpl(systemId,lineNumber,columnNumber);
+    }
+
+    public Annotation makeAnnotations(CommentListImpl comments, Context context) {
+        return new Annotation();
+    }
+
+    public ElementAnnotationBuilder makeElementAnnotationBuilder(String ns, String localName, String prefix, LocatorImpl loc, CommentListImpl comments, Context context) {
+        String qname;
+        if(prefix==null)
+            qname = localName;
+        else
+            qname = prefix+':'+localName;
+        return new ElementAnnotationBuilderImpl(dom.createElementNS(ns,qname));
+    }
+
+    public CommentListImpl makeCommentList() {
+        return null;
+    }
+
+    public DPattern makeErrorPattern() {
+        return new DNotAllowedPattern();
+    }
+
+    public boolean usesComments() {
+        return false;
+    }
+
+    public DPattern expandPattern(DPattern p) throws BuildException, IllegalSchemaException {
+        return p;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DTextPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DTextPattern.java
new file mode 100644
index 0000000..dcdc9b6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DTextPattern.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DTextPattern extends DPattern {
+    public boolean isNullable() {
+        return true;
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onText(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DUnaryPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DUnaryPattern.java
new file mode 100644
index 0000000..f83deb7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DUnaryPattern.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class DUnaryPattern extends DPattern {
+    private DPattern child;
+
+    public DPattern getChild() {
+        return child;
+    }
+
+    public void setChild(DPattern child) {
+        this.child = child;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DValuePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DValuePattern.java
new file mode 100644
index 0000000..ed7bfdf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DValuePattern.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.parse.Context;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DValuePattern extends DPattern {
+    private String datatypeLibrary;
+    private String type;
+    private String value;
+    private Context context;
+    private String ns;
+
+    public DValuePattern(String datatypeLibrary, String type, String value, Context context, String ns) {
+        this.datatypeLibrary = datatypeLibrary;
+        this.type = type;
+        this.value = value;
+        this.context = context;
+        this.ns = ns;
+    }
+
+    public String getDatatypeLibrary() {
+        return datatypeLibrary;
+    }
+
+    public String getType() {
+        return type;
+    }
+
+    public String getValue() {
+        return value;
+    }
+
+    public Context getContext() {
+        return context;
+    }
+
+    public String getNs() {
+        return ns;
+    }
+
+    public boolean isNullable() {
+        return false;
+    }
+
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onValue(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DXMLPrinter.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DXMLPrinter.java
new file mode 100644
index 0000000..fb17c24
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DXMLPrinter.java
@@ -0,0 +1,564 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import java.io.FileOutputStream;
+import java.io.OutputStream;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLOutputFactory;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.util.CheckingSchemaBuilder;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import com.sun.xml.internal.rngom.nc.NameClassVisitor;
+import com.sun.xml.internal.rngom.nc.SimpleNameClass;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import com.sun.xml.internal.rngom.parse.compact.CompactParseable;
+import com.sun.xml.internal.rngom.parse.xml.SAXParseable;
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.DefaultHandler;
+
+/**
+ * Printer of RELAX NG digested model to XML using StAX {@link XMLStreamWriter}.
+ *
+ * @author <A href="mailto:demakov@ispras.ru">Alexey Demakov</A>
+ */
+public class DXMLPrinter {
+    protected XMLStreamWriter out;
+    protected String indentStep = "\t";
+    protected String newLine = System.getProperty("line.separator");
+    protected int indent;
+    protected boolean afterEnd = false;
+    protected DXMLPrinterVisitor visitor;
+    protected NameClassXMLPrinterVisitor ncVisitor;
+    protected DOMPrinter domPrinter;
+
+    /**
+     * @param out Output stream.
+     */
+    public DXMLPrinter(XMLStreamWriter out) {
+        this.out = out;
+        this.visitor = new DXMLPrinterVisitor();
+        this.ncVisitor = new NameClassXMLPrinterVisitor();
+        this.domPrinter = new DOMPrinter(out);
+    }
+
+    /**
+     * Prints grammar enclosed by start/end document.
+     *
+     * @param grammar
+     * @throws XMLStreamException
+     */
+    public void printDocument(DGrammarPattern grammar) throws XMLStreamException {
+        try {
+            visitor.startDocument();
+            visitor.on(grammar);
+            visitor.endDocument();
+        } catch (XMLWriterException e) {
+            throw (XMLStreamException) e.getCause();
+        }
+    }
+
+    /**
+     * Prints XML fragment for the given pattern.
+     *
+     * @throws XMLStreamException
+     */
+    public void print(DPattern pattern) throws XMLStreamException {
+        try {
+            pattern.accept(visitor);
+        } catch (XMLWriterException e) {
+            throw (XMLStreamException) e.getCause();
+        }
+    }
+
+    /**
+     * Prints XML fragment for the given name class.
+     *
+     * @throws XMLStreamException
+     */
+    public void print(NameClass nc) throws XMLStreamException {
+        try {
+            nc.accept(ncVisitor);
+        } catch (XMLWriterException e) {
+            throw (XMLStreamException) e.getCause();
+        }
+    }
+
+    public void print(Node node) throws XMLStreamException {
+        domPrinter.print(node);
+    }
+
+    protected class XMLWriterException extends RuntimeException {
+        protected XMLWriterException(Throwable cause) {
+            super(cause);
+        }
+    }
+
+    protected class XMLWriter {
+        protected void newLine() {
+            try {
+                out.writeCharacters(newLine);
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        protected void indent() {
+            try {
+                for (int i = 0; i < indent; i++) {
+                    out.writeCharacters(indentStep);
+                }
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        public void startDocument() {
+            try {
+                out.writeStartDocument();
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        public void endDocument() {
+            try {
+                out.writeEndDocument();
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        public final void start(String element) {
+            try {
+                newLine();
+                indent();
+                out.writeStartElement(element);
+                indent++;
+                afterEnd = false;
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        public void end() {
+            try {
+                indent--;
+                if (afterEnd) {
+                    newLine();
+                    indent();
+                }
+                out.writeEndElement();
+                afterEnd = true;
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        public void attr(String prefix, String ns, String name, String value) {
+            try {
+                out.writeAttribute(prefix, ns, name, value);
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        public void attr(String name, String value) {
+            try {
+                out.writeAttribute(name, value);
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        public void ns(String prefix, String uri) {
+            try {
+                out.writeNamespace(prefix, uri);
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+
+        public void body(String text) {
+            try {
+                out.writeCharacters(text);
+                afterEnd = false;
+            } catch (XMLStreamException e) {
+                throw new XMLWriterException(e);
+            }
+        }
+    }
+
+    protected class DXMLPrinterVisitor extends XMLWriter implements DPatternVisitor<Void> {
+        protected void on(DPattern p) {
+            p.accept(this);
+        }
+
+        protected void unwrapGroup(DPattern p) {
+            if (p instanceof DGroupPattern && p.getAnnotation() == DAnnotation.EMPTY) {
+                for (DPattern d : (DGroupPattern) p) {
+                    on(d);
+                }
+            } else {
+                on(p);
+            }
+        }
+
+        protected void unwrapChoice(DPattern p) {
+            if (p instanceof DChoicePattern && p.getAnnotation() == DAnnotation.EMPTY) {
+                for (DPattern d : (DChoicePattern) p) {
+                    on(d);
+                }
+            } else {
+                on(p);
+            }
+        }
+
+        protected void on(NameClass nc) {
+            if (nc instanceof SimpleNameClass) {
+                QName qname = ((SimpleNameClass) nc).name;
+                String name = qname.getLocalPart();
+                if (!qname.getPrefix().equals("")) name = qname.getPrefix() + ":";
+                attr("name", name);
+            } else {
+                nc.accept(ncVisitor);
+            }
+        }
+
+        protected void on(DAnnotation ann) {
+            if (ann == DAnnotation.EMPTY) return;
+            for (DAnnotation.Attribute attr : ann.getAttributes().values()) {
+                attr(attr.getPrefix(), attr.getNs(), attr.getLocalName(), attr.getValue());
+            }
+            for (Element elem : ann.getChildren()) {
+                try {
+                    newLine();
+                    indent();
+                    print(elem);
+                }
+                catch (XMLStreamException e) {
+                    throw new XMLWriterException(e);
+                }
+            }
+        }
+
+        public Void onAttribute(DAttributePattern p) {
+            start("attribute");
+            on(p.getName());
+            on(p.getAnnotation());
+            DPattern child = p.getChild();
+            // do not print default value
+            if (!(child instanceof DTextPattern)) {
+                on(p.getChild());
+            }
+            end();
+            return null;
+        }
+
+        public Void onChoice(DChoicePattern p) {
+            start("choice");
+            on(p.getAnnotation());
+            for (DPattern d : p) {
+                on(d);
+            }
+            end();
+            return null;
+        }
+
+        public Void onData(DDataPattern p) {
+            List<DDataPattern.Param> params = p.getParams();
+            DPattern except = p.getExcept();
+            start("data");
+            attr("datatypeLibrary", p.getDatatypeLibrary());
+            attr("type", p.getType());
+            on(p.getAnnotation());
+            for (DDataPattern.Param param : params) {
+                start("param");
+                attr("ns", param.getNs());
+                attr("name", param.getName());
+                body(param.getValue());
+                end();
+            }
+            if (except != null) {
+                start("except");
+                unwrapChoice(except);
+                end();
+            }
+            end();
+            return null;
+        }
+
+        public Void onElement(DElementPattern p) {
+            start("element");
+            on(p.getName());
+            on(p.getAnnotation());
+            unwrapGroup(p.getChild());
+            end();
+            return null;
+        }
+
+        public Void onEmpty(DEmptyPattern p) {
+            start("empty");
+            on(p.getAnnotation());
+            end();
+            return null;
+        }
+
+        public Void onGrammar(DGrammarPattern p) {
+            start("grammar");
+            ns(null, WellKnownNamespaces.RELAX_NG);
+            on(p.getAnnotation());
+            start("start");
+            on(p.getStart());
+            end();
+            for (DDefine d : p) {
+                start("define");
+                attr("name", d.getName());
+                on(d.getAnnotation());
+                unwrapGroup(d.getPattern());
+                end();
+            }
+            end();
+            return null;
+        }
+
+        public Void onGroup(DGroupPattern p) {
+            start("group");
+            on(p.getAnnotation());
+            for (DPattern d : p) {
+                on(d);
+            }
+            end();
+            return null;
+        }
+
+        public Void onInterleave(DInterleavePattern p) {
+            start("interleave");
+            on(p.getAnnotation());
+            for (DPattern d : p) {
+                on(d);
+            }
+            end();
+            return null;
+        }
+
+        public Void onList(DListPattern p) {
+            start("list");
+            on(p.getAnnotation());
+            unwrapGroup(p.getChild());
+            end();
+            return null;
+        }
+
+        public Void onMixed(DMixedPattern p) {
+            start("mixed");
+            on(p.getAnnotation());
+            unwrapGroup(p.getChild());
+            end();
+            return null;
+        }
+
+        public Void onNotAllowed(DNotAllowedPattern p) {
+            start("notAllowed");
+            on(p.getAnnotation());
+            end();
+            return null;
+        }
+
+        public Void onOneOrMore(DOneOrMorePattern p) {
+            start("oneOrMore");
+            on(p.getAnnotation());
+            unwrapGroup(p.getChild());
+            end();
+            return null;
+        }
+
+        public Void onOptional(DOptionalPattern p) {
+            start("optional");
+            on(p.getAnnotation());
+            unwrapGroup(p.getChild());
+            end();
+            return null;
+        }
+
+        public Void onRef(DRefPattern p) {
+            start("ref");
+            attr("name", p.getName());
+            on(p.getAnnotation());
+            end();
+            return null;
+        }
+
+        public Void onText(DTextPattern p) {
+            start("text");
+            on(p.getAnnotation());
+            end();
+            return null;
+        }
+
+        public Void onValue(DValuePattern p) {
+            start("value");
+            if (!p.getNs().equals("")) attr("ns", p.getNs());
+            attr("datatypeLibrary", p.getDatatypeLibrary());
+            attr("type", p.getType());
+            on(p.getAnnotation());
+            body(p.getValue());
+            end();
+            return null;
+        }
+
+        public Void onZeroOrMore(DZeroOrMorePattern p) {
+            start("zeroOrMore");
+            on(p.getAnnotation());
+            unwrapGroup(p.getChild());
+            end();
+            return null;
+        }
+    }
+
+    protected class NameClassXMLPrinterVisitor extends XMLWriter implements NameClassVisitor<Void> {
+        public Void visitChoice(NameClass nc1, NameClass nc2) {
+            // TODO: flatten nested choices
+            start("choice");
+            nc1.accept(this);
+            nc2.accept(this);
+            end();
+            return null;
+        }
+
+        public Void visitNsName(String ns) {
+            start("nsName");
+            attr("ns", ns);
+            end();
+            return null;
+        }
+
+        public Void visitNsNameExcept(String ns, NameClass nc) {
+            start("nsName");
+            attr("ns", ns);
+            start("except");
+            nc.accept(this);
+            end();
+            end();
+            return null;
+        }
+
+        public Void visitAnyName() {
+            start("anyName");
+            end();
+            return null;
+        }
+
+        public Void visitAnyNameExcept(NameClass nc) {
+            start("anyName");
+            start("except");
+            nc.accept(this);
+            end();
+            end();
+            return null;
+        }
+
+        public Void visitName(QName name) {
+            start("name");
+            if (!name.getPrefix().equals("")) {
+                body(name.getPrefix() + ":");
+            }
+            body(name.getLocalPart());
+            end();
+            return null;
+        }
+
+        public Void visitNull() {
+            throw new UnsupportedOperationException("visitNull");
+        }
+    }
+
+    public static void main(String[] args) throws Exception {
+        Parseable p;
+
+        ErrorHandler eh = new DefaultHandler() {
+            public void error(SAXParseException e) throws SAXException {
+                throw e;
+            }
+        };
+
+        // the error handler passed to Parseable will receive parsing errors.
+        if (args[0].endsWith(".rng")) {
+            p = new SAXParseable(new InputSource(args[0]), eh);
+        } else {
+            p = new CompactParseable(new InputSource(args[0]), eh);
+        }
+
+        // the error handler passed to CheckingSchemaBuilder will receive additional
+        // errors found during the RELAX NG restrictions check.
+        // typically you'd want to pass in the same error handler,
+        // as there's really no distinction between those two kinds of errors.
+        SchemaBuilder sb = new CheckingSchemaBuilder(new DSchemaBuilderImpl(), eh);
+        try {
+            // run the parser
+            DGrammarPattern grammar = (DGrammarPattern) p.parse(sb);
+            OutputStream out = new FileOutputStream(args[1]);
+            XMLOutputFactory factory = XMLOutputFactory.newInstance();
+            XMLStreamWriter output = factory.createXMLStreamWriter(out);
+            DXMLPrinter printer = new DXMLPrinter(output);
+            printer.printDocument(grammar);
+            output.close();
+            out.close();
+        } catch (BuildException e) {
+            if (e.getCause() instanceof SAXParseException) {
+                SAXParseException se = (SAXParseException) e.getCause();
+                System.out.println("("
+                    + se.getLineNumber()
+                    + ","
+                    + se.getColumnNumber()
+                    + "): "
+                    + se.getMessage());
+                return;
+            } else
+                // I found that Crimson doesn't show the proper stack trace
+                // when a RuntimeException happens inside a SchemaBuilder.
+                // the following code shows the actual exception that happened.
+                if (e.getCause() instanceof SAXException) {
+                    SAXException se = (SAXException) e.getCause();
+                    if (se.getException() != null)
+                        se.getException().printStackTrace();
+                }
+            throw e;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DXmlTokenPattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DXmlTokenPattern.java
new file mode 100644
index 0000000..41a7584
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DXmlTokenPattern.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.nc.NameClass;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class DXmlTokenPattern extends DUnaryPattern {
+    private final NameClass name;
+
+    public DXmlTokenPattern(NameClass name) {
+        this.name = name;
+    }
+
+    /**
+     * Gets the name class of this element/attribute.
+     */
+    public NameClass getName() {
+        return name;
+    }
+
+    public final boolean isNullable() {
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DZeroOrMorePattern.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DZeroOrMorePattern.java
new file mode 100644
index 0000000..77fbf8a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DZeroOrMorePattern.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DZeroOrMorePattern extends DUnaryPattern {
+    public boolean isNullable() {
+        return true;
+    }
+    public Object accept( DPatternVisitor visitor ) {
+        return visitor.onZeroOrMore(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DataPatternBuilderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DataPatternBuilderImpl.java
new file mode 100644
index 0000000..896529f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/DataPatternBuilderImpl.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.Context;
+import org.xml.sax.Locator;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class DataPatternBuilderImpl implements DataPatternBuilder {
+
+    private final DDataPattern p;
+
+    public DataPatternBuilderImpl(String datatypeLibrary, String type, Location loc) {
+        p = new DDataPattern();
+        p.location = (Locator)loc;
+        p.datatypeLibrary = datatypeLibrary;
+        p.type = type;
+    }
+
+    public void addParam(String name, String value, Context context, String ns, Location loc, Annotations anno) throws BuildException {
+        p.params.add(p.new Param(name,value,context.copy(),ns,loc,(Annotation)anno));
+    }
+
+    public void annotation(ParsedElementAnnotation ea) {
+        // TODO
+    }
+
+    public ParsedPattern makePattern(Location loc, Annotations anno) throws BuildException {
+        return makePattern(null,loc,anno);
+    }
+
+    public ParsedPattern makePattern(ParsedPattern except, Location loc, Annotations anno) throws BuildException {
+        p.except = (DPattern)except;
+        if(anno!=null)
+            p.annotation = ((Annotation)anno).getResult();
+        return p;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/ElementAnnotationBuilderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/ElementAnnotationBuilderImpl.java
new file mode 100644
index 0000000..22046d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/ElementAnnotationBuilderImpl.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import org.w3c.dom.Element;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+class ElementAnnotationBuilderImpl implements ElementAnnotationBuilder {
+
+    private final Element e;
+
+    public ElementAnnotationBuilderImpl(Element e) {
+        this.e = e;
+    }
+
+
+    public void addText(String value, Location loc, CommentList comments) throws BuildException {
+        e.appendChild(e.getOwnerDocument().createTextNode(value));
+    }
+
+    public ParsedElementAnnotation makeElementAnnotation() throws BuildException {
+        return new ElementWrapper(e);
+    }
+
+    public void addAttribute(String ns, String localName, String prefix, String value, Location loc) throws BuildException {
+        e.setAttributeNS(ns,localName,value);
+    }
+
+    public void addElement(ParsedElementAnnotation ea) throws BuildException {
+        e.appendChild(((ElementWrapper)ea).element);
+    }
+
+    public void addComment(CommentList comments) throws BuildException {
+    }
+
+    public void addLeadingComment(CommentList comments) throws BuildException {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/ElementWrapper.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/ElementWrapper.java
new file mode 100644
index 0000000..dc3cf31
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/ElementWrapper.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import org.w3c.dom.Element;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class ElementWrapper implements ParsedElementAnnotation {
+    final Element element;
+
+    public ElementWrapper(Element e) {
+        this.element = e;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/GrammarBuilderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/GrammarBuilderImpl.java
new file mode 100644
index 0000000..31d8a47
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/GrammarBuilderImpl.java
@@ -0,0 +1,117 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.Div;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.ast.util.LocatorImpl;
+import org.w3c.dom.Element;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+class GrammarBuilderImpl implements Grammar, Div {
+
+    protected final DGrammarPattern grammar;
+
+    protected final Scope parent;
+
+    protected final DSchemaBuilderImpl sb;
+
+    /**
+     * Additional top-level element annotations.
+     * Can be null.
+     */
+    private List<Element> additionalElementAnnotations;
+
+    public GrammarBuilderImpl(DGrammarPattern p, Scope parent, DSchemaBuilderImpl sb) {
+        this.grammar = p;
+        this.parent = parent;
+        this.sb = sb;
+    }
+
+    public ParsedPattern endGrammar(Location loc, Annotations anno) throws BuildException {
+        if(anno!=null)
+            grammar.annotation = ((Annotation)anno).getResult();
+        if(additionalElementAnnotations!=null) {
+            if(grammar.annotation==null)
+                grammar.annotation = new DAnnotation();
+            grammar.annotation.contents.addAll(additionalElementAnnotations);
+        }
+        return grammar;
+    }
+
+    public void endDiv(Location loc, Annotations anno) throws BuildException {
+    }
+
+    public void define(String name, Combine combine, ParsedPattern pattern, Location loc, Annotations anno) throws BuildException {
+        if(name==START)
+            grammar.start = (DPattern)pattern;
+        else {
+            // TODO: handle combine
+            DDefine d = grammar.getOrAdd(name);
+            d.setPattern( (DPattern) pattern );
+            if(anno!=null)
+                d.annotation = ((Annotation)anno).getResult();
+        }
+    }
+
+    public void topLevelAnnotation(ParsedElementAnnotation ea) throws BuildException {
+        if(additionalElementAnnotations==null)
+            additionalElementAnnotations = new ArrayList<Element>();
+        additionalElementAnnotations.add(((ElementWrapper)ea).element);
+    }
+
+    public void topLevelComment(CommentList comments) throws BuildException {
+    }
+
+    public Div makeDiv() {
+        return this;
+    }
+
+    public Include makeInclude() {
+        return new IncludeImpl(grammar,parent,sb);
+    }
+
+    public ParsedPattern makeParentRef(String name, Location loc, Annotations anno) throws BuildException {
+        return parent.makeRef(name,loc,anno);
+    }
+
+    public ParsedPattern makeRef(String name, Location loc, Annotations anno) throws BuildException {
+        return DSchemaBuilderImpl.wrap( new DRefPattern(grammar.getOrAdd(name)), (LocatorImpl)loc, (Annotation)anno );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/IncludeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/IncludeImpl.java
new file mode 100644
index 0000000..34f4d1a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/IncludeImpl.java
@@ -0,0 +1,87 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+
+import java.util.HashSet;
+import java.util.Set;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class IncludeImpl extends GrammarBuilderImpl implements Include {
+
+    private Set overridenPatterns = new HashSet();
+    private boolean startOverriden = false;
+
+    public IncludeImpl(DGrammarPattern p, Scope parent, DSchemaBuilderImpl sb) {
+        super(p, parent, sb);
+    }
+
+    public void define(String name, Combine combine, ParsedPattern pattern, Location loc, Annotations anno) throws BuildException {
+        super.define(name, combine, pattern, loc, anno);
+        if(name==START)
+            startOverriden = true;
+        else
+            overridenPatterns.add(name);
+    }
+
+    public void endInclude(Parseable current, String uri, String ns, Location loc, Annotations anno) throws BuildException, IllegalSchemaException {
+        current.parseInclude(uri,sb,new IncludedGrammarImpl(grammar,parent,sb),ns);
+    }
+
+    private class IncludedGrammarImpl extends GrammarBuilderImpl implements IncludedGrammar {
+        public IncludedGrammarImpl(DGrammarPattern p, Scope parent, DSchemaBuilderImpl sb) {
+            super(p, parent, sb);
+        }
+
+        public void define(String name, Combine combine, ParsedPattern pattern, Location loc, Annotations anno) throws BuildException {
+            // check for overridden pattern
+            if(name==START) {
+                if(startOverriden)
+                    return;
+            } else {
+                if(overridenPatterns.contains(name))
+                    return;
+            }
+            // otherwise define
+            super.define(name, combine, pattern, loc, anno);
+        }
+
+        public ParsedPattern endIncludedGrammar(Location loc, Annotations anno) throws BuildException {
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/Main.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/Main.java
new file mode 100644
index 0000000..d5db94f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/Main.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.util.CheckingSchemaBuilder;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import com.sun.xml.internal.rngom.parse.compact.CompactParseable;
+import com.sun.xml.internal.rngom.parse.xml.SAXParseable;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.DefaultHandler;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class Main {
+    public static void main(String[] args) throws Exception {
+        Parseable p;
+
+        ErrorHandler eh = new DefaultHandler() {
+            public void error(SAXParseException e) throws SAXException {
+                throw e;
+            }
+        };
+
+        // the error handler passed to Parseable will receive parsing errors.
+        if(args[0].endsWith(".rng"))
+            p = new SAXParseable(new InputSource(args[0]),eh);
+        else
+            p = new CompactParseable(new InputSource(args[0]),eh);
+
+        // the error handler passed to CheckingSchemaBuilder will receive additional
+        // errors found during the RELAX NG restrictions check.
+        // typically you'd want to pass in the same error handler,
+        // as there's really no distinction between those two kinds of errors.
+        SchemaBuilder sb = new CheckingSchemaBuilder(new DSchemaBuilderImpl(),eh);
+        try {
+            // run the parser
+            p.parse(sb);
+        } catch( BuildException e ) {
+            // I found that Crimson doesn't show the proper stack trace
+            // when a RuntimeException happens inside a SchemaBuilder.
+            // the following code shows the actual exception that happened.
+            if( e.getCause() instanceof SAXException ) {
+                SAXException se = (SAXException) e.getCause();
+                if(se.getException()!=null)
+                    se.getException().printStackTrace();
+            }
+            throw e;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/PatternParseable.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/PatternParseable.java
new file mode 100644
index 0000000..6ba41e3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/PatternParseable.java
@@ -0,0 +1,207 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.digested;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.nc.NameClass;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import org.xml.sax.Locator;
+
+import java.util.List;
+import java.util.ArrayList;
+
+/**
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class PatternParseable implements Parseable {
+    private final DPattern pattern;
+
+    public PatternParseable(DPattern p) {
+        this.pattern = p;
+    }
+
+    public ParsedPattern parse(SchemaBuilder sb) throws BuildException {
+        return (ParsedPattern)pattern.accept(new Parser(sb));
+    }
+
+    public ParsedPattern parseInclude(String uri, SchemaBuilder f, IncludedGrammar g, String inheritedNs) throws BuildException {
+        throw new UnsupportedOperationException();
+    }
+
+    public ParsedPattern parseExternal(String uri, SchemaBuilder f, Scope s, String inheritedNs) throws BuildException {
+        throw new UnsupportedOperationException();
+    }
+
+
+    private static class Parser implements DPatternVisitor<ParsedPattern> {
+        private final SchemaBuilder sb;
+
+        public Parser(SchemaBuilder sb) {
+            this.sb = sb;
+        }
+
+        private Annotations parseAnnotation(DPattern p) {
+            // TODO
+            return null;
+        }
+
+        private Location parseLocation(DPattern p) {
+            Locator l = p.getLocation();
+            return sb.makeLocation(l.getSystemId(),l.getLineNumber(),l.getColumnNumber());
+        }
+
+        private ParsedNameClass parseNameClass(NameClass name) {
+            // TODO: reparse the name class
+            return name;
+        }
+
+
+
+        public ParsedPattern onAttribute(DAttributePattern p) {
+            return sb.makeAttribute(
+                parseNameClass(p.getName()),
+                (ParsedPattern)p.getChild().accept(this),
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onChoice(DChoicePattern p) {
+            List<ParsedPattern> kids = new ArrayList<ParsedPattern>();
+            for( DPattern c=p.firstChild(); c!=null; c=c.next )
+                kids.add( (ParsedPattern)c.accept(this) );
+            return sb.makeChoice(kids,parseLocation(p),null);
+        }
+
+        public ParsedPattern onData(DDataPattern p) {
+            // TODO
+            return null;
+        }
+
+        public ParsedPattern onElement(DElementPattern p) {
+            return sb.makeElement(
+                parseNameClass(p.getName()),
+                (ParsedPattern)p.getChild().accept(this),
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onEmpty(DEmptyPattern p) {
+            return sb.makeEmpty(
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onGrammar(DGrammarPattern p) {
+            // TODO
+            return null;
+        }
+
+        public ParsedPattern onGroup(DGroupPattern p) {
+            List<ParsedPattern> kids = new ArrayList<ParsedPattern>();
+            for( DPattern c=p.firstChild(); c!=null; c=c.next )
+                kids.add( (ParsedPattern)c.accept(this) );
+            return sb.makeGroup(kids,parseLocation(p),null);
+        }
+
+        public ParsedPattern onInterleave(DInterleavePattern p) {
+            List<ParsedPattern> kids = new ArrayList<ParsedPattern>();
+            for( DPattern c=p.firstChild(); c!=null; c=c.next )
+                kids.add( (ParsedPattern)c.accept(this) );
+            return sb.makeInterleave(kids,parseLocation(p),null);
+        }
+
+        public ParsedPattern onList(DListPattern p) {
+            return sb.makeList(
+                (ParsedPattern)p.getChild().accept(this),
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onMixed(DMixedPattern p) {
+            return sb.makeMixed(
+                (ParsedPattern)p.getChild().accept(this),
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onNotAllowed(DNotAllowedPattern p) {
+            return sb.makeNotAllowed(
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onOneOrMore(DOneOrMorePattern p) {
+            return sb.makeOneOrMore(
+                (ParsedPattern)p.getChild().accept(this),
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onOptional(DOptionalPattern p) {
+            return sb.makeOptional(
+                (ParsedPattern)p.getChild().accept(this),
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onRef(DRefPattern p) {
+            // TODO
+            return null;
+        }
+
+        public ParsedPattern onText(DTextPattern p) {
+            return sb.makeText(
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onValue(DValuePattern p) {
+            return sb.makeValue(
+                p.getDatatypeLibrary(),
+                p.getType(),
+                p.getValue(),
+                p.getContext(),
+                p.getNs(),
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+
+        public ParsedPattern onZeroOrMore(DZeroOrMorePattern p) {
+            return sb.makeZeroOrMore(
+                (ParsedPattern)p.getChild().accept(this),
+                parseLocation(p),
+                parseAnnotation(p) );
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/package.html b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/package.html
new file mode 100644
index 0000000..e6f75b9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/digested/package.html
@@ -0,0 +1,5 @@
+<html><body>
+Another RELAX NG AST implementation that optimizes away
+inclusions and some other syntax sugars, while still retaining
+all the annotations, location information, and etc.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/CachedDatatypeLibraryFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/CachedDatatypeLibraryFactory.java
new file mode 100644
index 0000000..415efff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/CachedDatatypeLibraryFactory.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.dt;
+
+import org.relaxng.datatype.DatatypeLibrary;
+import org.relaxng.datatype.DatatypeLibraryFactory;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class CachedDatatypeLibraryFactory implements DatatypeLibraryFactory {
+
+    private String lastUri;
+    private DatatypeLibrary lastLib;
+
+    private final DatatypeLibraryFactory core;
+
+    public CachedDatatypeLibraryFactory( DatatypeLibraryFactory core ) {
+        this.core = core;
+    }
+
+    public DatatypeLibrary createDatatypeLibrary(String namespaceURI) {
+        if( lastUri==namespaceURI )
+            return lastLib;
+
+        lastUri = namespaceURI;
+        lastLib = core.createDatatypeLibrary(namespaceURI);
+        return lastLib;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/CascadingDatatypeLibraryFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/CascadingDatatypeLibraryFactory.java
new file mode 100644
index 0000000..6f79fb3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/CascadingDatatypeLibraryFactory.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.dt;
+
+import org.relaxng.datatype.DatatypeLibrary;
+import org.relaxng.datatype.DatatypeLibraryFactory;
+
+/**
+ *
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class CascadingDatatypeLibraryFactory implements DatatypeLibraryFactory {
+    private final DatatypeLibraryFactory factory1;
+    private final DatatypeLibraryFactory factory2;
+
+    public CascadingDatatypeLibraryFactory( DatatypeLibraryFactory factory1, DatatypeLibraryFactory factory2) {
+        this.factory1 = factory1;
+        this.factory2 = factory2;
+    }
+
+    public DatatypeLibrary createDatatypeLibrary(String namespaceURI) {
+        DatatypeLibrary lib = factory1.createDatatypeLibrary(namespaceURI);
+        if(lib==null)
+            lib = factory2.createDatatypeLibrary(namespaceURI);
+        return lib;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/DoNothingDatatypeLibraryFactoryImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/DoNothingDatatypeLibraryFactoryImpl.java
new file mode 100644
index 0000000..af62b73
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/DoNothingDatatypeLibraryFactoryImpl.java
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.dt;
+
+import org.relaxng.datatype.DatatypeLibraryFactory;
+import org.relaxng.datatype.DatatypeLibrary;
+import org.relaxng.datatype.Datatype;
+import org.relaxng.datatype.DatatypeBuilder;
+import org.relaxng.datatype.DatatypeException;
+import org.relaxng.datatype.ValidationContext;
+import org.relaxng.datatype.DatatypeStreamingValidator;
+import org.relaxng.datatype.helpers.StreamingValidatorImpl;
+
+/**
+ * {@link DatatypeLibraryFactory} implementation
+ * that returns a dummy {@link Datatype}.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public final class DoNothingDatatypeLibraryFactoryImpl implements DatatypeLibraryFactory {
+    public DatatypeLibrary createDatatypeLibrary(String s) {
+        return new DatatypeLibrary() {
+
+            public Datatype createDatatype(String s) throws DatatypeException {
+                return createDatatypeBuilder(s).createDatatype();
+            }
+
+            public DatatypeBuilder createDatatypeBuilder(String s) throws DatatypeException {
+                return new DatatypeBuilder() {
+                    public void addParameter(String s, String s1, ValidationContext validationContext) throws DatatypeException {
+                    }
+
+                    public Datatype createDatatype() throws DatatypeException {
+                        return new Datatype() {
+
+                            public boolean isValid(String s, ValidationContext validationContext) {
+                                return false;
+                            }
+
+                            public void checkValid(String s, ValidationContext validationContext) throws DatatypeException {
+                            }
+
+                            public DatatypeStreamingValidator createStreamingValidator(ValidationContext validationContext) {
+                                return new StreamingValidatorImpl(this,validationContext);
+                            }
+
+                            public Object createValue(String s, ValidationContext validationContext) {
+                                return null;
+                            }
+
+                            public boolean sameValue(Object o, Object o1) {
+                                return false;
+                            }
+
+                            public int valueHashCode(Object o) {
+                                return 0;
+                            }
+
+                            public int getIdType() {
+                                return ID_TYPE_NULL;
+                            }
+
+                            public boolean isContextDependent() {
+                                return false;
+                            }
+                        };
+                    }
+                };
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeBuilder.java
new file mode 100644
index 0000000..ac5d825
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeBuilder.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.dt.builtin;
+
+import org.relaxng.datatype.Datatype;
+import org.relaxng.datatype.DatatypeBuilder;
+import org.relaxng.datatype.DatatypeException;
+import org.relaxng.datatype.ValidationContext;
+
+import com.sun.xml.internal.rngom.util.Localizer;
+
+class BuiltinDatatypeBuilder implements DatatypeBuilder {
+  private final Datatype dt;
+
+  private static final Localizer localizer = new Localizer(BuiltinDatatypeBuilder.class);
+
+  BuiltinDatatypeBuilder(Datatype dt) {
+    this.dt = dt;
+  }
+
+  public void addParameter(String name,
+                           String value,
+                           ValidationContext context) throws DatatypeException {
+    throw new DatatypeException(localizer.message("builtin_param"));
+  }
+
+  public Datatype createDatatype() {
+    return dt;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeLibrary.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeLibrary.java
new file mode 100644
index 0000000..4c2c2ff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeLibrary.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.dt.builtin;
+
+import org.relaxng.datatype.Datatype;
+import org.relaxng.datatype.DatatypeBuilder;
+import org.relaxng.datatype.DatatypeException;
+import org.relaxng.datatype.DatatypeLibrary;
+import org.relaxng.datatype.DatatypeLibraryFactory;
+
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+
+public class BuiltinDatatypeLibrary implements DatatypeLibrary {
+    private final DatatypeLibraryFactory factory;
+    private DatatypeLibrary xsdDatatypeLibrary = null;
+
+    BuiltinDatatypeLibrary(DatatypeLibraryFactory factory) {
+        this.factory = factory;
+    }
+
+    public DatatypeBuilder createDatatypeBuilder(String type)
+        throws DatatypeException {
+        xsdDatatypeLibrary =
+            factory.createDatatypeLibrary(
+                WellKnownNamespaces.XML_SCHEMA_DATATYPES);
+        if (xsdDatatypeLibrary == null)
+            throw new DatatypeException();
+
+        if (type.equals("string") || type.equals("token")) {
+            return new BuiltinDatatypeBuilder(
+                xsdDatatypeLibrary.createDatatype(type));
+        }
+        throw new DatatypeException();
+    }
+    public Datatype createDatatype(String type) throws DatatypeException {
+        return createDatatypeBuilder(type).createDatatype();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeLibraryFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeLibraryFactory.java
new file mode 100644
index 0000000..b7b2f5f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/BuiltinDatatypeLibraryFactory.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.dt.builtin;
+
+import org.relaxng.datatype.DatatypeLibrary;
+import org.relaxng.datatype.DatatypeLibraryFactory;
+
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+
+/**
+ * {@link DatatypeLibraryFactory} for
+ * RELAX NG Built-in datatype library and compatibility datatype library.
+ */
+public class BuiltinDatatypeLibraryFactory implements DatatypeLibraryFactory {
+    private final DatatypeLibrary builtinDatatypeLibrary;
+    private final DatatypeLibrary compatibilityDatatypeLibrary;
+    /**
+     * Target of delegation.
+     */
+    private final DatatypeLibraryFactory core;
+
+    public BuiltinDatatypeLibraryFactory( DatatypeLibraryFactory coreFactory ) {
+        builtinDatatypeLibrary = new BuiltinDatatypeLibrary(coreFactory);
+        compatibilityDatatypeLibrary = new CompatibilityDatatypeLibrary(coreFactory);
+        this.core = coreFactory;
+    }
+
+    public DatatypeLibrary createDatatypeLibrary(String uri) {
+        if (uri.equals(""))
+            return builtinDatatypeLibrary;
+        if (uri.equals(WellKnownNamespaces.RELAX_NG_COMPATIBILITY_DATATYPES))
+            return compatibilityDatatypeLibrary;
+        return core.createDatatypeLibrary(uri);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/CompatibilityDatatypeLibrary.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/CompatibilityDatatypeLibrary.java
new file mode 100644
index 0000000..ab62681
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/CompatibilityDatatypeLibrary.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.dt.builtin;
+
+import org.relaxng.datatype.Datatype;
+import org.relaxng.datatype.DatatypeBuilder;
+import org.relaxng.datatype.DatatypeException;
+import org.relaxng.datatype.DatatypeLibrary;
+import org.relaxng.datatype.DatatypeLibraryFactory;
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+
+class CompatibilityDatatypeLibrary implements DatatypeLibrary {
+    private final DatatypeLibraryFactory factory;
+    private DatatypeLibrary xsdDatatypeLibrary = null;
+
+    CompatibilityDatatypeLibrary(DatatypeLibraryFactory factory) {
+        this.factory = factory;
+    }
+
+    public DatatypeBuilder createDatatypeBuilder(String type)
+        throws DatatypeException {
+        if (type.equals("ID")
+            || type.equals("IDREF")
+            || type.equals("IDREFS")) {
+            if (xsdDatatypeLibrary == null) {
+                xsdDatatypeLibrary =
+                    factory.createDatatypeLibrary(
+                        WellKnownNamespaces.XML_SCHEMA_DATATYPES);
+                if (xsdDatatypeLibrary == null)
+                    throw new DatatypeException();
+            }
+            return xsdDatatypeLibrary.createDatatypeBuilder(type);
+        }
+        throw new DatatypeException();
+    }
+
+    public Datatype createDatatype(String type) throws DatatypeException {
+        return createDatatypeBuilder(type).createDatatype();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/Messages.properties
new file mode 100644
index 0000000..42e74f4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/Messages.properties
@@ -0,0 +1,3 @@
+# Properties file specifying messages
+builtin_param=builtin datatypes do not have any parameters
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/package.html b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/package.html
new file mode 100644
index 0000000..c12e27d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/dt/builtin/package.html
@@ -0,0 +1 @@
+RELAX NG built-in datatype implementation.
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/AnyNameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/AnyNameClass.java
new file mode 100644
index 0000000..eb5751c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/AnyNameClass.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+final class AnyNameClass extends NameClass {
+
+    protected AnyNameClass() {} // no instanciation
+
+    public boolean contains(QName name) {
+        return true;
+    }
+
+    public int containsSpecificity(QName name) {
+        return SPECIFICITY_ANY_NAME;
+    }
+
+    public boolean equals(Object obj) {
+        return obj==this;
+    }
+
+    public int hashCode() {
+        return AnyNameClass.class.hashCode();
+    }
+
+    public <V> V accept(NameClassVisitor<V> visitor) {
+        return visitor.visitAnyName();
+    }
+
+    public boolean isOpen() {
+        return true;
+    }
+
+    private static Object readReplace() {
+        return NameClass.ANY;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/AnyNameExceptNameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/AnyNameExceptNameClass.java
new file mode 100644
index 0000000..6d75a29
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/AnyNameExceptNameClass.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+public class AnyNameExceptNameClass extends NameClass {
+
+    private final NameClass nameClass;
+
+    public AnyNameExceptNameClass(NameClass nameClass) {
+        this.nameClass = nameClass;
+    }
+
+    public boolean contains(QName name) {
+        return !nameClass.contains(name);
+    }
+
+    public int containsSpecificity(QName name) {
+        return contains(name) ? SPECIFICITY_ANY_NAME : SPECIFICITY_NONE;
+    }
+
+    public boolean equals(Object obj) {
+        if (obj == null || !(obj instanceof AnyNameExceptNameClass))
+            return false;
+        return nameClass.equals(((AnyNameExceptNameClass) obj).nameClass);
+    }
+
+    public int hashCode() {
+        return ~nameClass.hashCode();
+    }
+
+    public <V> V accept(NameClassVisitor<V> visitor) {
+        return visitor.visitAnyNameExcept(nameClass);
+    }
+
+    public boolean isOpen() {
+        return true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/ChoiceNameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/ChoiceNameClass.java
new file mode 100644
index 0000000..ccc0f73
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/ChoiceNameClass.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+public class ChoiceNameClass extends NameClass {
+
+    private final NameClass nameClass1;
+    private final NameClass nameClass2;
+
+    public ChoiceNameClass(NameClass nameClass1, NameClass nameClass2) {
+        this.nameClass1 = nameClass1;
+        this.nameClass2 = nameClass2;
+    }
+
+    public boolean contains(QName name) {
+        return (nameClass1.contains(name) || nameClass2.contains(name));
+    }
+
+    public int containsSpecificity(QName name) {
+        return Math.max(
+            nameClass1.containsSpecificity(name),
+            nameClass2.containsSpecificity(name));
+    }
+
+    public int hashCode() {
+        return nameClass1.hashCode() ^ nameClass2.hashCode();
+    }
+
+    public boolean equals(Object obj) {
+        if (obj == null || !(obj instanceof ChoiceNameClass))
+            return false;
+        ChoiceNameClass other = (ChoiceNameClass) obj;
+        return (
+            nameClass1.equals(other.nameClass1)
+                && nameClass2.equals(other.nameClass2));
+    }
+
+    public <V> V accept(NameClassVisitor<V> visitor) {
+        return visitor.visitChoice(nameClass1, nameClass2);
+    }
+
+    public boolean isOpen() {
+        return nameClass1.isOpen() || nameClass2.isOpen();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClass.java
new file mode 100644
index 0000000..f15d4a4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClass.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+
+import javax.xml.namespace.QName;
+import java.io.Serializable;
+import java.util.HashSet;
+import java.util.Set;
+
+/**
+ * Name class is a set of {@link QName}s.
+ */
+public abstract class NameClass implements ParsedNameClass, Serializable {
+    static final int SPECIFICITY_NONE = -1;
+    static final int SPECIFICITY_ANY_NAME = 0;
+    static final int SPECIFICITY_NS_NAME = 1;
+    static final int SPECIFICITY_NAME = 2;
+
+    /**
+     * Returns true if the given {@link QName} is a valid name
+     * for this QName.
+     */
+    public abstract boolean contains(QName name);
+
+    public abstract int containsSpecificity(QName name);
+
+    /**
+     * Visitor pattern support.
+     */
+    public abstract <V> V accept(NameClassVisitor<V> visitor);
+
+    /**
+     * Returns true if the name class accepts infinite number of
+     * {@link QName}s.
+     *
+     * <p>
+     * Intuitively, this method returns true if the name class is
+     * some sort of wildcard.
+     */
+    public abstract boolean isOpen();
+
+    /**
+     * If the name class is closed (IOW !{@link #isOpen()}),
+     * return the set of names in this name class. Otherwise the behavior
+     * is undefined.
+     */
+    public Set<QName> listNames() {
+        final Set<QName> names = new HashSet<QName>();
+        accept(new NameClassWalker() {
+            public Void visitName(QName name) {
+                names.add(name);
+                return null;
+            }
+        });
+        return names;
+    }
+
+    /**
+     * Returns true if the intersection between this name class
+     * and the specified name class is non-empty.
+     */
+    public final boolean hasOverlapWith( NameClass nc2 ) {
+        return OverlapDetector.overlap(this,nc2);
+    }
+
+
+    /** Sigleton instance that represents "anyName". */
+    public static final NameClass ANY = new AnyNameClass();
+
+    /**
+     * Sigleton instance that accepts no name.
+     *
+     * <p>
+     * This instance is useful when doing boolean arithmetic over
+     * name classes (such as computing an inverse of a given name class, etc),
+     * even though it can never appear in a RELAX NG surface syntax.
+     *
+     * <p>
+     * Internally, this instance is also used for:
+     * <ol>
+     *  <li>Used to recover from errors during parsing.
+     *  <li>Mark element patterns with &lt;notAllowed/> content model.
+     * </ol>
+     */
+    public static final NameClass NULL = new NullNameClass();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassBuilderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassBuilderImpl.java
new file mode 100644
index 0000000..278cf1a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassBuilderImpl.java
@@ -0,0 +1,92 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+import java.util.List;
+
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class NameClassBuilderImpl<
+    E extends ParsedElementAnnotation,
+    L extends Location,
+    A extends Annotations<E,L,CL>,
+    CL extends CommentList<L>> implements NameClassBuilder<NameClass,E,L,A,CL> {
+
+    public NameClass makeChoice(List<NameClass> nameClasses, L loc, A anno) {
+      NameClass result = nameClasses.get(0);
+      for (int i = 1; i < nameClasses.size(); i++)
+        result = new ChoiceNameClass(result, nameClasses.get(i));
+      return result;
+    }
+
+    public NameClass makeName(String ns, String localName, String prefix, L loc, A anno) {
+      return new SimpleNameClass(ns, localName);
+    }
+
+    public NameClass makeNsName(String ns, L loc, A anno) {
+      return new NsNameClass(ns);
+    }
+
+    public NameClass makeNsName(String ns, NameClass except, L loc, A anno) {
+      return new NsNameExceptNameClass(ns, except);
+    }
+
+    public NameClass makeAnyName(L loc, A anno) {
+      return NameClass.ANY;
+    }
+
+    public NameClass makeAnyName(NameClass except, L loc, A anno) {
+      return new AnyNameExceptNameClass(except);
+    }
+
+    public NameClass makeErrorNameClass() {
+        return NameClass.NULL;
+    }
+
+    public NameClass annotate(NameClass nc, A anno) throws BuildException {
+      return nc;
+    }
+
+    public NameClass annotateAfter(NameClass nc, E e) throws BuildException {
+      return nc;
+    }
+
+    public NameClass commentAfter(NameClass nc, CL comments) throws BuildException {
+      return nc;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassVisitor.java
new file mode 100644
index 0000000..b527fe9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassVisitor.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Visitor pattern over {@link NameClass} and its subclasses.
+ */
+public interface NameClassVisitor<V> {
+    /**
+     * Called for {@link ChoiceNameClass}
+     */
+    V visitChoice(NameClass nc1, NameClass nc2);
+    /**
+     * Called for {@link NsNameClass}
+     */
+    V visitNsName(String ns);
+    /**
+     * Called for {@link NsNameExceptNameClass}
+     */
+    V visitNsNameExcept(String ns, NameClass nc);
+    /**
+     * Called for {@link NameClass#ANY}
+     */
+    V visitAnyName();
+    /**
+     * Called for {@link AnyNameExceptNameClass}
+     */
+    V visitAnyNameExcept(NameClass nc);
+    /**
+     * Called for {@link SimpleNameClass}
+     */
+    V visitName(QName name);
+    /**
+     * Called for {@link NameClass#NULL}.
+     */
+    V visitNull();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassWalker.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassWalker.java
new file mode 100644
index 0000000..2fca7d2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NameClassWalker.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class NameClassWalker implements NameClassVisitor<Void> {
+
+    public Void visitChoice(NameClass nc1, NameClass nc2) {
+        nc1.accept(this);
+        return nc2.accept(this);
+    }
+
+    public Void visitNsName(String ns) {
+        return null;
+    }
+
+    public Void visitNsNameExcept(String ns, NameClass nc) {
+        return nc.accept(this);
+    }
+
+    public Void visitAnyName() {
+        return null;
+    }
+
+    public Void visitAnyNameExcept(NameClass nc) {
+        return nc.accept(this);
+    }
+
+    public Void visitName(QName name) {
+        return null;
+    }
+
+    public Void visitNull() {
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NsNameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NsNameClass.java
new file mode 100644
index 0000000..9a45c0d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NsNameClass.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+public final class NsNameClass extends NameClass {
+
+  private final String namespaceUri;
+
+  public NsNameClass(String namespaceUri) {
+    this.namespaceUri = namespaceUri;
+  }
+
+  public boolean contains(QName name) {
+    return this.namespaceUri.equals(name.getNamespaceURI());
+  }
+
+  public int containsSpecificity(QName name) {
+    return contains(name) ? SPECIFICITY_NS_NAME : SPECIFICITY_NONE;
+  }
+
+  public int hashCode() {
+    return namespaceUri.hashCode();
+  }
+
+  public boolean equals(Object obj) {
+    if (obj == null || !(obj instanceof NsNameClass))
+      return false;
+    return namespaceUri.equals(((NsNameClass)obj).namespaceUri);
+  }
+
+  public <V> V accept(NameClassVisitor<V> visitor) {
+    return visitor.visitNsName(namespaceUri);
+  }
+
+  public boolean isOpen() {
+    return true;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NsNameExceptNameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NsNameExceptNameClass.java
new file mode 100644
index 0000000..ead30dd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NsNameExceptNameClass.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+public class NsNameExceptNameClass extends NameClass {
+
+  private final NameClass nameClass;
+  private final String namespaceURI;
+
+  public NsNameExceptNameClass(String namespaceURI, NameClass nameClass) {
+    this.namespaceURI = namespaceURI;
+    this.nameClass = nameClass;
+  }
+
+  public boolean contains(QName name) {
+    return (this.namespaceURI.equals(name.getNamespaceURI())
+            && !nameClass.contains(name));
+  }
+
+  public int containsSpecificity(QName name) {
+    return contains(name) ? SPECIFICITY_NS_NAME : SPECIFICITY_NONE;
+  }
+
+  public boolean equals(Object obj) {
+    if (obj == null || !(obj instanceof NsNameExceptNameClass))
+      return false;
+    NsNameExceptNameClass other = (NsNameExceptNameClass)obj;
+    return (namespaceURI.equals(other.namespaceURI)
+            && nameClass.equals(other.nameClass));
+  }
+
+  public int hashCode() {
+    return namespaceURI.hashCode() ^ nameClass.hashCode();
+  }
+
+  public <V> V accept(NameClassVisitor<V> visitor) {
+    return visitor.visitNsNameExcept(namespaceURI, nameClass);
+  }
+
+  public boolean isOpen() {
+    return true;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NullNameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NullNameClass.java
new file mode 100644
index 0000000..16121db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/NullNameClass.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+final class NullNameClass extends NameClass {
+    protected NullNameClass() {
+    }
+
+    public boolean contains(QName name) {
+        return false;
+    }
+
+    public int containsSpecificity(QName name) {
+        return SPECIFICITY_NONE;
+    }
+
+    public int hashCode() {
+        return NullNameClass.class.hashCode();
+    }
+
+    public boolean equals(Object obj) {
+        return this==obj;
+    }
+
+    public <V> V accept(NameClassVisitor<V> visitor) {
+        return visitor.visitNull();
+    }
+
+    public boolean isOpen() {
+        return false;
+    }
+
+    private Object readResolve() {
+        return NameClass.NULL;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/OverlapDetector.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/OverlapDetector.java
new file mode 100644
index 0000000..ab453b9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/OverlapDetector.java
@@ -0,0 +1,97 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+class OverlapDetector implements NameClassVisitor<Void> {
+    private NameClass nc1;
+    private NameClass nc2;
+    private boolean overlaps = false;
+
+    static final String IMPOSSIBLE = "\u0000";
+
+    private OverlapDetector(NameClass nc1, NameClass nc2) {
+        this.nc1 = nc1;
+        this.nc2 = nc2;
+        nc1.accept(this);
+        nc2.accept(this);
+    }
+
+    private void probe(QName name) {
+        if (nc1.contains(name) && nc2.contains(name))
+            overlaps = true;
+    }
+
+    public Void visitChoice(NameClass nc1, NameClass nc2) {
+        nc1.accept(this);
+        nc2.accept(this);
+        return null;
+    }
+
+    public Void visitNsName(String ns) {
+        probe(new QName(ns, IMPOSSIBLE));
+        return null;
+    }
+
+    public Void visitNsNameExcept(String ns, NameClass ex) {
+        probe(new QName(ns, IMPOSSIBLE));
+        ex.accept(this);
+        return null;
+    }
+
+    public Void visitAnyName() {
+        probe(new QName(IMPOSSIBLE, IMPOSSIBLE));
+        return null;
+    }
+
+    public Void visitAnyNameExcept(NameClass ex) {
+        probe(new QName(IMPOSSIBLE, IMPOSSIBLE));
+        ex.accept(this);
+        return null;
+    }
+
+    public Void visitName(QName name) {
+        probe(name);
+        return null;
+    }
+
+    public Void visitNull() {
+        return null;
+    }
+
+    static boolean overlap(NameClass nc1, NameClass nc2) {
+        if (nc2 instanceof SimpleNameClass) {
+            SimpleNameClass snc = (SimpleNameClass) nc2;
+            return nc1.contains(snc.name);
+        }
+        if (nc1 instanceof SimpleNameClass) {
+            SimpleNameClass snc = (SimpleNameClass) nc1;
+            return nc2.contains(snc.name);
+        }
+        return new OverlapDetector(nc1, nc2).overlaps;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/SimpleNameClass.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/SimpleNameClass.java
new file mode 100644
index 0000000..8b4429b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/SimpleNameClass.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.nc;
+
+import javax.xml.namespace.QName;
+
+public class SimpleNameClass extends NameClass {
+
+    public final QName name;
+
+    public SimpleNameClass(QName name) {
+        this.name = name;
+    }
+
+    public SimpleNameClass( String nsUri, String localPart ) {
+        this( new QName(nsUri,localPart) );
+    }
+
+    public boolean contains(QName name) {
+        return this.name.equals(name);
+    }
+
+    public int containsSpecificity(QName name) {
+        return contains(name) ? SPECIFICITY_NAME : SPECIFICITY_NONE;
+    }
+
+    public int hashCode() {
+        return name.hashCode();
+    }
+
+    public boolean equals(Object obj) {
+        if (obj == null || !(obj instanceof SimpleNameClass))
+            return false;
+        SimpleNameClass other = (SimpleNameClass) obj;
+        return name.equals(other.name);
+    }
+
+    public <V> V accept(NameClassVisitor<V> visitor) {
+        return visitor.visitName(name);
+    }
+
+    public boolean isOpen() {
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/package.html b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/package.html
new file mode 100644
index 0000000..90a792a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/nc/package.html
@@ -0,0 +1,5 @@
+<html>
+  <body>
+    Default Name Class Object Model (one example of <tt>ast.om</tt> implementation).
+  </body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Context.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Context.java
new file mode 100644
index 0000000..2e74e43
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Context.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse;
+
+import java.util.Enumeration;
+import org.relaxng.datatype.ValidationContext;
+
+/**
+ * Provides contextual information.
+ *
+ * This is typically useful for parsing QNames.
+ */
+public interface Context extends ValidationContext {
+    /**
+     * Enumerates the prefixes bound to namespaces.
+     */
+    Enumeration prefixes();
+
+    /**
+     * Returns the immutable snapshot of this {@link Context}.
+     */
+    Context copy();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/IllegalSchemaException.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/IllegalSchemaException.java
new file mode 100644
index 0000000..b83223b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/IllegalSchemaException.java
@@ -0,0 +1,31 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse;
+
+/**
+ * Signals a violation of the RELAX NG spec.
+ */
+public class IllegalSchemaException extends Exception { }
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Messages.properties
new file mode 100644
index 0000000..011c2a6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Messages.properties
@@ -0,0 +1,4 @@
+# common messages between XML and compact syntax parser
+parent_ref_outside_grammar=parentRef is used outside a grammar
+ref_outside_grammar=ref is used outside a grammar
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Parseable.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Parseable.java
new file mode 100644
index 0000000..eef5efb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/Parseable.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse;
+
+import com.sun.xml.internal.rngom.ast.builder.*;
+import com.sun.xml.internal.rngom.ast.om.*;
+
+/**
+ * An input that can be turned into a RELAX NG pattern.
+ *
+ * <p>
+ * This is either a RELAX NG schema in the XML format, or a RELAX NG
+ * schema in the compact syntax.
+ */
+public interface Parseable {
+    /**
+     * Parses this {@link Parseable} object into a RELAX NG pattern.
+     *
+     * @param sb
+     *      The builder of the schema object model. This object
+     *      dictates how the actual pattern is constructed.
+     *
+     * @return
+     *      a parsed object. Always returns a non-null valid object.
+     */
+    <P extends ParsedPattern> P parse(SchemaBuilder<?,P,?,?,?,?> sb) throws BuildException, IllegalSchemaException;
+
+    /**
+     * Called from {@link Include} in response to
+     * {@link Include#endInclude(Parseable, String, String, Location, Annotations)}
+     * to parse the included grammar.
+     *
+     * @param g
+     *      receives the events from the included grammar.
+     */
+    <P extends ParsedPattern> P parseInclude(String uri, SchemaBuilder<?,P,?,?,?,?> f, IncludedGrammar<P,?,?,?,?> g, String inheritedNs)
+        throws BuildException, IllegalSchemaException;
+
+    /**
+     * Called from {@link SchemaBuilder} in response to
+     * {@link SchemaBuilder#makeExternalRef(Parseable, String, String, Scope, Location, Annotations)}
+     * to parse the referenced grammar.
+     *
+     * @param f
+     *      receives the events from the referenced grammar.
+     */
+    <P extends ParsedPattern> P parseExternal(String uri, SchemaBuilder<?,P,?,?,?,?> f, Scope s, String inheritedNs)
+        throws BuildException, IllegalSchemaException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactParseable.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactParseable.java
new file mode 100644
index 0000000..b60d9c0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactParseable.java
@@ -0,0 +1,118 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.compact;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.io.PushbackInputStream;
+import java.io.Reader;
+import java.net.URL;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import com.sun.xml.internal.rngom.xml.util.EncodingMap;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+
+/**
+ * RELAX NG schema in the compact syntax.
+ */
+public class CompactParseable implements Parseable {
+  private final InputSource in;
+  private final ErrorHandler eh;
+
+  public CompactParseable(InputSource in, ErrorHandler eh) {
+    this.in = in;
+    this.eh = eh;
+  }
+
+  public ParsedPattern parse(SchemaBuilder sb) throws BuildException, IllegalSchemaException {
+      ParsedPattern p = new CompactSyntax(this, makeReader(in), in.getSystemId(), sb, eh, "").parse(null);
+      return sb.expandPattern(p);
+  }
+
+  public ParsedPattern parseInclude(String uri, SchemaBuilder sb, IncludedGrammar g, String inheritedNs)
+          throws BuildException, IllegalSchemaException {
+    InputSource tem = new InputSource(uri);
+    tem.setEncoding(in.getEncoding());
+    return new CompactSyntax(this, makeReader(tem), uri, sb, eh, inheritedNs).parseInclude(g);
+  }
+
+  public ParsedPattern parseExternal(String uri, SchemaBuilder sb, Scope scope, String inheritedNs)
+          throws BuildException, IllegalSchemaException {
+    InputSource tem = new InputSource(uri);
+    tem.setEncoding(in.getEncoding());
+    return new CompactSyntax(this, makeReader(tem), uri, sb, eh, inheritedNs).parse(scope);
+  }
+
+  private static final String UTF8 = EncodingMap.getJavaName("UTF-8");
+  private static final String UTF16 = EncodingMap.getJavaName("UTF-16");
+
+  private static Reader makeReader(InputSource is) throws BuildException {
+    try {
+      Reader r = is.getCharacterStream();
+      if (r == null) {
+        InputStream in = is.getByteStream();
+        if (in == null) {
+          String systemId = is.getSystemId();
+          in = new URL(systemId).openStream();
+        }
+        String encoding = is.getEncoding();
+        if (encoding == null) {
+          PushbackInputStream pb = new PushbackInputStream(in, 2);
+          encoding = detectEncoding(pb);
+          in = pb;
+        }
+        r = new InputStreamReader(in, encoding);
+      }
+      return r;
+    }
+    catch (IOException e) {
+      throw new BuildException(e);
+    }
+  }
+
+  static private String detectEncoding(PushbackInputStream in) throws IOException {
+    String encoding = UTF8;
+    int b1 = in.read();
+    if (b1 != -1) {
+      int b2 = in.read();
+      if (b2 != -1) {
+        in.unread(b2);
+        if ((b1 == 0xFF && b2 == 0xFE) || (b1 == 0xFE && b2 == 0xFF))
+          encoding = UTF16;
+      }
+      in.unread(b1);
+    }
+    return encoding;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntax.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntax.java
new file mode 100644
index 0000000..cf0d077
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntax.java
@@ -0,0 +1,3350 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* Generated By:JavaCC: Do not edit this line. CompactSyntax.java */
+package com.sun.xml.internal.rngom.parse.compact;
+
+import java.io.Reader;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.Arrays;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.util.List;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Div;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.builder.GrammarSection;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.Context;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.LocatorImpl;
+
+import com.sun.xml.internal.rngom.util.Localizer;
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+
+
+public class CompactSyntax implements Context, CompactSyntaxConstants {
+  private static final int IN_ELEMENT = 0;
+  private static final int IN_ATTRIBUTE = 1;
+  private static final int IN_ANY_NAME = 2;
+  private static final int IN_NS_NAME = 4;
+
+  private String defaultNamespace;
+  private String compatibilityPrefix = null;
+  private SchemaBuilder sb;
+  private NameClassBuilder ncb;
+  private String sourceUri;
+  /**
+   * This is what we are parsing right now.
+   */
+  private CompactParseable parseable;
+  private ErrorHandler eh;
+  private final Hashtable namespaceTable = new Hashtable();
+  private final Hashtable datatypesTable = new Hashtable();
+  private boolean hadError = false;
+  private static final Localizer localizer = new Localizer(new Localizer(Parseable.class),CompactSyntax.class);
+  private final Hashtable attributeNameTable = new Hashtable();
+  private boolean annotationsIncludeElements = false;
+
+  /**
+   * String that represents the inherited namespace.
+   *
+   * <p>
+   * HACK: we always allocate a new String instance so that
+   * we can distinguish inherited value from the explicitly
+   * given value.
+   */
+  private /*final*/ String inheritedNs; // essentially final but JavaCC don't let us declare it as so.
+
+  final class LocatedString {
+    private final String str;
+    private final Token tok;
+
+    LocatedString(String str, Token tok) {
+      this.str = str;
+      this.tok = tok;
+    }
+
+    String getString() {
+      return str;
+    }
+
+    Location getLocation() {
+      return makeLocation(tok);
+    }
+
+    Token getToken() {
+      return tok;
+    }
+
+  }
+
+  public CompactSyntax(CompactParseable parseable, Reader r, String sourceUri, SchemaBuilder sb, ErrorHandler eh, String inheritedNs) {
+    this(r);
+    this.sourceUri = sourceUri;
+    this.parseable = parseable;
+    this.sb = sb;
+    this.ncb = sb.getNameClassBuilder();
+    this.eh = eh;
+    // this causes the root pattern to have non-null annotations
+    // which is useful because it gives a context to trang
+    this.topLevelComments = sb.makeCommentList();
+    this.inheritedNs = defaultNamespace = new String(inheritedNs);
+  }
+
+  ParsedPattern parse(Scope scope) throws IllegalSchemaException {
+    try {
+      ParsedPattern p = Input(scope);
+      if (!hadError)
+        return p;
+    }
+    catch (ParseException e) {
+      error("syntax_error", e.getMessage(), e.currentToken.next);
+    }
+    catch (EscapeSyntaxException e) {
+      reportEscapeSyntaxException(e);
+    }
+    throw new IllegalSchemaException();
+  }
+
+  ParsedPattern parseInclude(IncludedGrammar g) throws IllegalSchemaException {
+    try {
+      ParsedPattern p = IncludedGrammar(g);
+      if (!hadError)
+        return p;
+    }
+    catch (ParseException e) {
+      error("syntax_error", e.getMessage(), e.currentToken.next);
+    }
+    catch (EscapeSyntaxException e) {
+      reportEscapeSyntaxException(e);
+    }
+    throw new IllegalSchemaException();
+  }
+
+  private void checkNsName(int context, LocatedString ns) {
+    if ((context & IN_NS_NAME) != 0)
+      error("ns_name_except_contains_ns_name", ns.getToken());
+  }
+
+  private void checkAnyName(int context, Token t) {
+    if ((context & IN_NS_NAME) != 0)
+      error("ns_name_except_contains_any_name", t);
+    if ((context & IN_ANY_NAME) != 0)
+      error("any_name_except_contains_any_name", t);
+  }
+
+  private void error(String key, Token tok) {
+    doError(localizer.message(key), tok);
+  }
+
+  private void error(String key, String arg, Token tok) {
+    doError(localizer.message(key, arg), tok);
+  }
+
+  private void error(String key, String arg1, String arg2, Token tok) {
+    doError(localizer.message(key, arg1, arg2), tok);
+  }
+
+  private void doError(String message, Token tok) {
+    hadError = true;
+    if (eh != null) {
+      LocatorImpl loc = new LocatorImpl();
+      loc.setLineNumber(tok.beginLine);
+      loc.setColumnNumber(tok.beginColumn);
+      loc.setSystemId(sourceUri);
+      try {
+        eh.error(new SAXParseException(message, loc));
+      }
+      catch (SAXException se) {
+        throw new BuildException(se);
+      }
+    }
+  }
+
+  private void reportEscapeSyntaxException(EscapeSyntaxException e) {
+    if (eh != null) {
+      LocatorImpl loc = new LocatorImpl();
+      loc.setLineNumber(e.getLineNumber());
+      loc.setColumnNumber(e.getColumnNumber());
+      loc.setSystemId(sourceUri);
+      try {
+        eh.error(new SAXParseException(localizer.message(e.getKey()), loc));
+      }
+      catch (SAXException se) {
+        throw new BuildException(se);
+      }
+    }
+  }
+
+  private static String unquote(String s) {
+    if (s.length() >= 6 && s.charAt(0) == s.charAt(1)) {
+      s = s.replace('\u0000', '\n');
+      return s.substring(3, s.length() - 3);
+    }
+    else
+      return s.substring(1, s.length() - 1);
+  }
+
+  Location makeLocation(Token t) {
+    return sb.makeLocation(sourceUri, t.beginLine, t.beginColumn);
+  }
+
+  private static ParsedPattern[] addPattern(ParsedPattern[] patterns, int i, ParsedPattern p) {
+    if (i >= patterns.length) {
+      ParsedPattern[] oldPatterns = patterns;
+      patterns = new ParsedPattern[oldPatterns.length*2];
+      System.arraycopy(oldPatterns, 0, patterns, 0, oldPatterns.length);
+    }
+    patterns[i] = p;
+    return patterns;
+  }
+
+  String getCompatibilityPrefix() {
+    if (compatibilityPrefix == null) {
+      compatibilityPrefix = "a";
+      while (namespaceTable.get(compatibilityPrefix) != null)
+        compatibilityPrefix = compatibilityPrefix + "a";
+    }
+    return compatibilityPrefix;
+  }
+
+  public String resolveNamespacePrefix(String prefix) {
+    String result = (String)namespaceTable.get(prefix);
+    if (result.length() == 0)
+      return null;
+    return result;
+  }
+
+  public Enumeration prefixes() {
+    return namespaceTable.keys();
+  }
+
+  public String getBaseUri() {
+    return sourceUri;
+  }
+
+  public boolean isUnparsedEntity(String entityName) {
+    return false;
+  }
+
+  public boolean isNotation(String notationName) {
+    return false;
+  }
+
+  public Context copy() {
+    return this;
+  }
+
+  private Context getContext() {
+    return this;
+  }
+
+  private CommentList getComments() {
+    return getComments(getTopLevelComments());
+  }
+
+  private CommentList topLevelComments;
+
+  private CommentList getTopLevelComments() {
+    CommentList tem = topLevelComments;
+    topLevelComments = null;
+    return tem;
+  }
+
+  private void noteTopLevelComments() {
+    topLevelComments = getComments(topLevelComments);
+  }
+
+  private void topLevelComments(GrammarSection section) {
+    section.topLevelComment(getComments(null));
+  }
+
+  private Token lastCommentSourceToken = null;
+
+  private CommentList getComments(CommentList comments) {
+    Token nextToken = getToken(1);
+    if (lastCommentSourceToken != nextToken) {
+      if (lastCommentSourceToken == null)
+        lastCommentSourceToken = token;
+      do {
+        lastCommentSourceToken = lastCommentSourceToken.next;
+        Token t = lastCommentSourceToken.specialToken;
+        if (t != null) {
+          while (t.specialToken != null)
+            t = t.specialToken;
+          if (comments == null)
+            comments = sb.makeCommentList();
+          for (; t != null; t = t.next) {
+            String s = mungeComment(t.image);
+            Location loc = makeLocation(t);
+            if (t.next != null
+                && t.next.kind == CompactSyntaxConstants.SINGLE_LINE_COMMENT_CONTINUE) {
+              StringBuffer buf = new StringBuffer(s);
+              do {
+                t = t.next;
+                buf.append('\n');
+                buf.append(mungeComment(t.image));
+              } while (t.next != null
+                       && t.next.kind == CompactSyntaxConstants.SINGLE_LINE_COMMENT_CONTINUE);
+              s = buf.toString();
+            }
+            comments.addComment(s, loc);
+          }
+        }
+      } while (lastCommentSourceToken != nextToken);
+    }
+    return comments;
+  }
+
+  private ParsedPattern afterComments(ParsedPattern p) {
+    CommentList comments = getComments(null);
+    if (comments == null)
+      return p;
+    return sb.commentAfter(p, comments);
+  }
+
+  private ParsedNameClass afterComments(ParsedNameClass nc) {
+    CommentList comments = getComments(null);
+    if (comments == null)
+      return nc;
+    return ncb.commentAfter(nc, comments);
+  }
+
+  private static String mungeComment(String image) {
+    int i = image.indexOf('#') + 1;
+    while (i < image.length() && image.charAt(i) == '#')
+      i++;
+    if (i < image.length() && image.charAt(i) == ' ')
+      i++;
+    return image.substring(i);
+  }
+
+  private Annotations getCommentsAsAnnotations() {
+    CommentList comments = getComments();
+    if (comments == null)
+      return null;
+    return sb.makeAnnotations(comments, getContext());
+  }
+
+  private Annotations addCommentsToChildAnnotations(Annotations a) {
+    CommentList comments = getComments();
+    if (comments == null)
+      return a;
+    if (a == null)
+      a = sb.makeAnnotations(null, getContext());
+    a.addComment(comments);
+    return a;
+  }
+
+  private Annotations addCommentsToLeadingAnnotations(Annotations a) {
+    CommentList comments = getComments();
+    if (comments == null)
+      return a;
+    if (a == null)
+      return sb.makeAnnotations(comments, getContext());
+    a.addLeadingComment(comments);
+    return a;
+  }
+
+  private Annotations getTopLevelCommentsAsAnnotations() {
+    CommentList comments = getTopLevelComments();
+    if (comments == null)
+      return null;
+    return sb.makeAnnotations(comments, getContext());
+  }
+
+  private void clearAttributeList() {
+    attributeNameTable.clear();
+  }
+
+  private void addAttribute(Annotations a, String ns, String localName, String prefix, String value, Token tok) {
+    String key = ns + "#" + localName;
+    if (attributeNameTable.get(key) != null)
+      error("duplicate_attribute", ns, localName, tok);
+    else {
+      attributeNameTable.put(key, key);
+      a.addAttribute(ns, localName, prefix, value, makeLocation(tok));
+    }
+  }
+
+  private void checkExcept(Token[] except) {
+    if (except[0] != null)
+      error("except_missing_parentheses", except[0]);
+  }
+
+  private String lookupPrefix(String prefix, Token t) {
+    String ns = (String)namespaceTable.get(prefix);
+    if (ns == null) {
+      error("undeclared_prefix", prefix, t);
+      return "#error";
+    }
+    return ns;
+  }
+  private String lookupDatatype(String prefix, Token t) {
+    String ns = (String)datatypesTable.get(prefix);
+    if (ns == null) {
+      error("undeclared_prefix", prefix, t);
+      return ""; // XXX
+    }
+    return ns;
+  }
+  private String resolve(String str) {
+    try {
+     return new URL(new URL(sourceUri), str).toString();
+    }
+    catch (MalformedURLException e) { }
+    return str;
+  }
+
+  final public ParsedPattern Input(Scope scope) throws ParseException {
+  ParsedPattern p;
+    Preamble();
+    if (jj_2_1(2147483647)) {
+      p = TopLevelGrammar(scope);
+    } else {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 1:
+      case 10:
+      case 17:
+      case 18:
+      case 19:
+      case 26:
+      case 27:
+      case 28:
+      case 31:
+      case 32:
+      case 33:
+      case 34:
+      case 35:
+      case 36:
+      case DOCUMENTATION:
+      case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+      case PREFIXED_NAME:
+      case LITERAL:
+        p = Expr(true, scope, null, null);
+                                         p = afterComments(p);
+        jj_consume_token(0);
+        break;
+      default:
+        jj_la1[0] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+    }
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void TopLevelLookahead() throws ParseException {
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case PREFIXED_NAME:
+      jj_consume_token(PREFIXED_NAME);
+      jj_consume_token(1);
+      break;
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      Identifier();
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 1:
+        jj_consume_token(1);
+        break;
+      case 2:
+        jj_consume_token(2);
+        break;
+      case 3:
+        jj_consume_token(3);
+        break;
+      case 4:
+        jj_consume_token(4);
+        break;
+      default:
+        jj_la1[1] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+      break;
+    case 5:
+    case 6:
+    case 7:
+      LookaheadGrammarKeyword();
+      break;
+    case 1:
+      LookaheadBody();
+      LookaheadAfterAnnotations();
+      break;
+    case DOCUMENTATION:
+    case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+      LookaheadDocumentation();
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 1:
+        LookaheadBody();
+        break;
+      default:
+        jj_la1[2] = jj_gen;
+        ;
+      }
+      LookaheadAfterAnnotations();
+      break;
+    default:
+      jj_la1[3] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+  }
+
+  final public void LookaheadAfterAnnotations() throws ParseException {
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      Identifier();
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 2:
+        jj_consume_token(2);
+        break;
+      case 3:
+        jj_consume_token(3);
+        break;
+      case 4:
+        jj_consume_token(4);
+        break;
+      default:
+        jj_la1[4] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+      break;
+    case 5:
+    case 6:
+    case 7:
+      LookaheadGrammarKeyword();
+      break;
+    default:
+      jj_la1[5] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+  }
+
+  final public void LookaheadGrammarKeyword() throws ParseException {
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 5:
+      jj_consume_token(5);
+      break;
+    case 6:
+      jj_consume_token(6);
+      break;
+    case 7:
+      jj_consume_token(7);
+      break;
+    default:
+      jj_la1[6] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+  }
+
+  final public void LookaheadDocumentation() throws ParseException {
+    label_1:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case DOCUMENTATION:
+        jj_consume_token(DOCUMENTATION);
+        break;
+      case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+        jj_consume_token(DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT);
+        break;
+      default:
+        jj_la1[7] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+      label_2:
+      while (true) {
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case DOCUMENTATION_CONTINUE:
+          ;
+          break;
+        default:
+          jj_la1[8] = jj_gen;
+          break label_2;
+        }
+        jj_consume_token(DOCUMENTATION_CONTINUE);
+      }
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case DOCUMENTATION:
+      case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+        ;
+        break;
+      default:
+        jj_la1[9] = jj_gen;
+        break label_1;
+      }
+    }
+  }
+
+  final public void LookaheadBody() throws ParseException {
+    jj_consume_token(1);
+    label_3:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 1:
+      case 2:
+      case 5:
+      case 6:
+      case 7:
+      case 8:
+      case 10:
+      case 13:
+      case 14:
+      case 15:
+      case 16:
+      case 17:
+      case 18:
+      case 19:
+      case 26:
+      case 27:
+      case 31:
+      case 32:
+      case 33:
+      case 34:
+      case 35:
+      case 36:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+      case PREFIXED_NAME:
+      case LITERAL:
+        ;
+        break;
+      default:
+        jj_la1[10] = jj_gen;
+        break label_3;
+      }
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case PREFIXED_NAME:
+        jj_consume_token(PREFIXED_NAME);
+        break;
+      case 5:
+      case 6:
+      case 7:
+      case 10:
+      case 13:
+      case 14:
+      case 15:
+      case 16:
+      case 17:
+      case 18:
+      case 19:
+      case 26:
+      case 27:
+      case 31:
+      case 32:
+      case 33:
+      case 34:
+      case 35:
+      case 36:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+        UnprefixedName();
+        break;
+      case 2:
+        jj_consume_token(2);
+        break;
+      case LITERAL:
+        jj_consume_token(LITERAL);
+        break;
+      case 8:
+        jj_consume_token(8);
+        break;
+      case 1:
+        LookaheadBody();
+        break;
+      default:
+        jj_la1[11] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+    }
+    jj_consume_token(9);
+  }
+
+  final public ParsedPattern IncludedGrammar(IncludedGrammar g) throws ParseException {
+  Annotations a;
+  ParsedPattern p;
+    Preamble();
+    if (jj_2_2(2147483647)) {
+      a = GrammarBody(g, g, getTopLevelCommentsAsAnnotations());
+    } else {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 1:
+      case 10:
+      case DOCUMENTATION:
+      case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+        a = Annotations();
+        jj_consume_token(10);
+        jj_consume_token(11);
+        a = GrammarBody(g, g, a);
+                                                                topLevelComments(g);
+        jj_consume_token(12);
+        break;
+      default:
+        jj_la1[12] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+    }
+    p = afterComments(g.endIncludedGrammar(sb.makeLocation(sourceUri, 1, 1), a));
+    jj_consume_token(0);
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern TopLevelGrammar(Scope scope) throws ParseException {
+  Annotations a = getTopLevelCommentsAsAnnotations();
+  Grammar g;
+  ParsedPattern p;
+    g = sb.makeGrammar(scope);
+    a = GrammarBody(g, g, a);
+    p = afterComments(g.endGrammar(sb.makeLocation(sourceUri, 1, 1), a));
+    jj_consume_token(0);
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void Preamble() throws ParseException {
+    label_4:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 13:
+      case 14:
+      case 16:
+        ;
+        break;
+      default:
+        jj_la1[13] = jj_gen;
+        break label_4;
+      }
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 13:
+      case 14:
+        NamespaceDecl();
+        break;
+      case 16:
+        DatatypesDecl();
+        break;
+      default:
+        jj_la1[14] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+    }
+    namespaceTable.put("xml", WellKnownNamespaces.XML);
+    if (datatypesTable.get("xsd") == null)
+      datatypesTable.put("xsd", WellKnownNamespaces.XML_SCHEMA_DATATYPES);
+  }
+
+  final public void NamespaceDecl() throws ParseException {
+  LocatedString prefix = null;
+  boolean isDefault = false;
+  String namespaceName;
+    noteTopLevelComments();
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 13:
+      jj_consume_token(13);
+      prefix = UnprefixedName();
+      break;
+    case 14:
+      jj_consume_token(14);
+                   isDefault = true;
+      jj_consume_token(13);
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 5:
+      case 6:
+      case 7:
+      case 10:
+      case 13:
+      case 14:
+      case 15:
+      case 16:
+      case 17:
+      case 18:
+      case 19:
+      case 26:
+      case 27:
+      case 31:
+      case 32:
+      case 33:
+      case 34:
+      case 35:
+      case 36:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+        prefix = UnprefixedName();
+        break;
+      default:
+        jj_la1[15] = jj_gen;
+        ;
+      }
+      break;
+    default:
+      jj_la1[16] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    jj_consume_token(2);
+    namespaceName = NamespaceName();
+    if (isDefault)
+      defaultNamespace = namespaceName;
+    if (prefix != null) {
+      if (prefix.getString().equals("xmlns"))
+        error("xmlns_prefix", prefix.getToken());
+      else if (prefix.getString().equals("xml")) {
+        if (!namespaceName.equals(WellKnownNamespaces.XML))
+          error("xml_prefix_bad_uri", prefix.getToken());
+      }
+      else if (namespaceName.equals(WellKnownNamespaces.XML))
+        error("xml_uri_bad_prefix", prefix.getToken());
+      else {
+        if (namespaceName.equals(WellKnownNamespaces.RELAX_NG_COMPATIBILITY_ANNOTATIONS))
+          compatibilityPrefix = prefix.getString();
+        namespaceTable.put(prefix.getString(), namespaceName);
+      }
+    }
+  }
+
+  final public String NamespaceName() throws ParseException {
+  String r;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case LITERAL:
+      r = Literal();
+      break;
+    case 15:
+      jj_consume_token(15);
+                               r = this.inheritedNs;
+      break;
+    default:
+      jj_la1[17] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return r;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void DatatypesDecl() throws ParseException {
+  LocatedString prefix;
+  String uri;
+    noteTopLevelComments();
+    jj_consume_token(16);
+    prefix = UnprefixedName();
+    jj_consume_token(2);
+    uri = Literal();
+    datatypesTable.put(prefix.getString(), uri);
+  }
+
+  final public ParsedPattern AnnotatedPrimaryExpr(boolean topLevel, Scope scope, Token[] except) throws ParseException {
+  Annotations a;
+  ParsedPattern p;
+  ParsedElementAnnotation e;
+  Token t;
+    a = Annotations();
+    p = PrimaryExpr(topLevel, scope, a, except);
+    label_5:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case FANNOTATE:
+        ;
+        break;
+      default:
+        jj_la1[18] = jj_gen;
+        break label_5;
+      }
+      t = jj_consume_token(FANNOTATE);
+      e = AnnotationElement(false);
+       if (topLevel)
+         error("top_level_follow_annotation", t);
+       else
+         p = sb.annotateAfter(p, e);
+    }
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern PrimaryExpr(boolean topLevel, Scope scope, Annotations a, Token[] except) throws ParseException {
+  ParsedPattern p;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 26:
+      p = ElementExpr(scope, a);
+      break;
+    case 27:
+      p = AttributeExpr(scope, a);
+      break;
+    case 10:
+      p = GrammarExpr(scope, a);
+      break;
+    case 33:
+      p = ExternalRefExpr(scope, a);
+      break;
+    case 31:
+      p = ListExpr(scope, a);
+      break;
+    case 32:
+      p = MixedExpr(scope, a);
+      break;
+    case 28:
+      p = ParenExpr(topLevel, scope, a);
+      break;
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      p = IdentifierExpr(scope, a);
+      break;
+    case 34:
+      p = ParentExpr(scope, a);
+      break;
+    case 35:
+    case 36:
+    case PREFIXED_NAME:
+      p = DataExpr(topLevel, scope, a, except);
+      break;
+    case LITERAL:
+      p = ValueExpr(topLevel, a);
+      break;
+    case 18:
+      p = TextExpr(a);
+      break;
+    case 17:
+      p = EmptyExpr(a);
+      break;
+    case 19:
+      p = NotAllowedExpr(a);
+      break;
+    default:
+      jj_la1[19] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern EmptyExpr(Annotations a) throws ParseException {
+  Token t;
+    t = jj_consume_token(17);
+    {if (true) return sb.makeEmpty(makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern TextExpr(Annotations a) throws ParseException {
+  Token t;
+    t = jj_consume_token(18);
+    {if (true) return sb.makeText(makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern NotAllowedExpr(Annotations a) throws ParseException {
+  Token t;
+    t = jj_consume_token(19);
+    {if (true) return sb.makeNotAllowed(makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern Expr(boolean topLevel, Scope scope, Token t, Annotations a) throws ParseException {
+  List patterns = new ArrayList();
+  ParsedPattern p;
+  boolean[] hadOccur = new boolean[1];
+  Token[] except = new Token[1];
+    p = UnaryExpr(topLevel, scope, hadOccur, except);
+    patterns.add(p);
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 20:
+    case 21:
+    case 22:
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 20:
+     checkExcept(except);
+        label_6:
+        while (true) {
+          t = jj_consume_token(20);
+          p = UnaryExpr(topLevel, scope, null, except);
+       patterns.add(p); checkExcept(except);
+          switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+          case 20:
+            ;
+            break;
+          default:
+            jj_la1[20] = jj_gen;
+            break label_6;
+          }
+        }
+      p = sb.makeChoice(patterns, makeLocation(t), a);
+        break;
+      case 21:
+        label_7:
+        while (true) {
+          t = jj_consume_token(21);
+          p = UnaryExpr(topLevel, scope, null, except);
+       patterns.add(p); checkExcept(except);
+          switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+          case 21:
+            ;
+            break;
+          default:
+            jj_la1[21] = jj_gen;
+            break label_7;
+          }
+        }
+      p = sb.makeInterleave(patterns, makeLocation(t), a);
+        break;
+      case 22:
+        label_8:
+        while (true) {
+          t = jj_consume_token(22);
+          p = UnaryExpr(topLevel, scope, null, except);
+       patterns.add(p); checkExcept(except);
+          switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+          case 22:
+            ;
+            break;
+          default:
+            jj_la1[22] = jj_gen;
+            break label_8;
+          }
+        }
+      p = sb.makeGroup(patterns, makeLocation(t), a);
+        break;
+      default:
+        jj_la1[23] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+      break;
+    default:
+      jj_la1[24] = jj_gen;
+      ;
+    }
+    if (patterns.size() == 1 && a != null) {
+      if (hadOccur[0])
+        p = sb.annotate(p, a);
+      else
+        p = sb.makeGroup(patterns, makeLocation(t), a);
+    }
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern UnaryExpr(boolean topLevel, Scope scope, boolean[] hadOccur, Token[] except) throws ParseException {
+  ParsedPattern p;
+  Token t;
+  ParsedElementAnnotation e;
+    p = AnnotatedPrimaryExpr(topLevel, scope, except);
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 23:
+    case 24:
+    case 25:
+     if (hadOccur != null) hadOccur[0] = true;
+     p = afterComments(p);
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 23:
+        t = jj_consume_token(23);
+              checkExcept(except); p = sb.makeOneOrMore(p, makeLocation(t), null);
+        break;
+      case 24:
+        t = jj_consume_token(24);
+                checkExcept(except); p = sb.makeOptional(p, makeLocation(t), null);
+        break;
+      case 25:
+        t = jj_consume_token(25);
+                checkExcept(except); p = sb.makeZeroOrMore(p, makeLocation(t), null);
+        break;
+      default:
+        jj_la1[25] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+      label_9:
+      while (true) {
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case FANNOTATE:
+          ;
+          break;
+        default:
+          jj_la1[26] = jj_gen;
+          break label_9;
+        }
+        t = jj_consume_token(FANNOTATE);
+        e = AnnotationElement(false);
+        if (topLevel)
+          error("top_level_follow_annotation", t);
+        else
+          p = sb.annotateAfter(p, e);
+      }
+      break;
+    default:
+      jj_la1[27] = jj_gen;
+      ;
+    }
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern ElementExpr(Scope scope, Annotations a) throws ParseException {
+  Token t;
+  ParsedNameClass nc;
+  ParsedPattern p;
+    t = jj_consume_token(26);
+    nc = NameClass(IN_ELEMENT, null);
+    jj_consume_token(11);
+    p = Expr(false, scope, null, null);
+    p = afterComments(p);
+    jj_consume_token(12);
+    {if (true) return sb.makeElement(nc, p, makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern AttributeExpr(Scope scope, Annotations a) throws ParseException {
+  Token t;
+  ParsedNameClass nc;
+  ParsedPattern p;
+    t = jj_consume_token(27);
+    nc = NameClass(IN_ATTRIBUTE, null);
+    jj_consume_token(11);
+    p = Expr(false, scope, null, null);
+    p = afterComments(p);
+    jj_consume_token(12);
+    {if (true) return sb.makeAttribute(nc, p, makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass NameClass(int context, Annotations[] pa) throws ParseException {
+  Annotations a;
+  ParsedNameClass nc;
+    a = Annotations();
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 5:
+    case 6:
+    case 7:
+    case 10:
+    case 13:
+    case 14:
+    case 15:
+    case 16:
+    case 17:
+    case 18:
+    case 19:
+    case 26:
+    case 27:
+    case 28:
+    case 31:
+    case 32:
+    case 33:
+    case 34:
+    case 35:
+    case 36:
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+    case PREFIXED_NAME:
+      nc = PrimaryNameClass(context, a);
+      nc = AnnotateAfter(nc);
+      nc = NameClassAlternatives(context, nc, pa);
+      break;
+    case 25:
+      nc = AnyNameExceptClass(context, a, pa);
+      break;
+    case PREFIX_STAR:
+      nc = NsNameExceptClass(context, a, pa);
+      break;
+    default:
+      jj_la1[28] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass AnnotateAfter(ParsedNameClass nc) throws ParseException {
+  ParsedElementAnnotation e;
+    label_10:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case FANNOTATE:
+        ;
+        break;
+      default:
+        jj_la1[29] = jj_gen;
+        break label_10;
+      }
+      jj_consume_token(FANNOTATE);
+      e = AnnotationElement(false);
+                                               nc = ncb.annotateAfter(nc, e);
+    }
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass NameClassAlternatives(int context, ParsedNameClass nc, Annotations[] pa) throws ParseException {
+  Token t;
+  ParsedNameClass[] nameClasses;
+  int nNameClasses;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 20:
+      nameClasses = new ParsedNameClass[2];
+      nameClasses[0] = nc;
+      nNameClasses = 1;
+      label_11:
+      while (true) {
+        t = jj_consume_token(20);
+        nc = BasicNameClass(context);
+        nc = AnnotateAfter(nc);
+      if (nNameClasses >= nameClasses.length) {
+        ParsedNameClass[] oldNameClasses = nameClasses;
+        nameClasses = new ParsedNameClass[oldNameClasses.length*2];
+        System.arraycopy(oldNameClasses, 0, nameClasses, 0, oldNameClasses.length);
+      }
+      nameClasses[nNameClasses++] = nc;
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case 20:
+          ;
+          break;
+        default:
+          jj_la1[30] = jj_gen;
+          break label_11;
+        }
+      }
+      Annotations a;
+      if (pa == null)
+        a = null;
+      else {
+        a = pa[0];
+        pa[0] = null;
+      }
+      nc = ncb.makeChoice(Arrays.asList(nameClasses).subList(0,nNameClasses), makeLocation(t), a);
+      break;
+    default:
+      jj_la1[31] = jj_gen;
+      ;
+    }
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass BasicNameClass(int context) throws ParseException {
+  Annotations a;
+  ParsedNameClass nc;
+    a = Annotations();
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 5:
+    case 6:
+    case 7:
+    case 10:
+    case 13:
+    case 14:
+    case 15:
+    case 16:
+    case 17:
+    case 18:
+    case 19:
+    case 26:
+    case 27:
+    case 28:
+    case 31:
+    case 32:
+    case 33:
+    case 34:
+    case 35:
+    case 36:
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+    case PREFIXED_NAME:
+      nc = PrimaryNameClass(context, a);
+      break;
+    case 25:
+    case PREFIX_STAR:
+      nc = OpenNameClass(context, a);
+      break;
+    default:
+      jj_la1[32] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass PrimaryNameClass(int context, Annotations a) throws ParseException {
+  ParsedNameClass nc;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 5:
+    case 6:
+    case 7:
+    case 10:
+    case 13:
+    case 14:
+    case 15:
+    case 16:
+    case 17:
+    case 18:
+    case 19:
+    case 26:
+    case 27:
+    case 31:
+    case 32:
+    case 33:
+    case 34:
+    case 35:
+    case 36:
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      nc = UnprefixedNameClass(context, a);
+      break;
+    case PREFIXED_NAME:
+      nc = PrefixedNameClass(a);
+      break;
+    case 28:
+      nc = ParenNameClass(context, a);
+      break;
+    default:
+      jj_la1[33] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass OpenNameClass(int context, Annotations a) throws ParseException {
+  Token t;
+  LocatedString ns;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case PREFIX_STAR:
+      ns = NsName();
+                  checkNsName(context, ns); {if (true) return ncb.makeNsName(ns.getString(), ns.getLocation(), a);}
+      break;
+    case 25:
+      t = jj_consume_token(25);
+              checkAnyName(context, t); {if (true) return ncb.makeAnyName(makeLocation(t), a);}
+      break;
+    default:
+      jj_la1[34] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass UnprefixedNameClass(int context, Annotations a) throws ParseException {
+  LocatedString name;
+    name = UnprefixedName();
+    String ns;
+    if ((context & (IN_ATTRIBUTE|IN_ELEMENT)) == IN_ATTRIBUTE)
+      ns = "";
+    else
+      ns = defaultNamespace;
+    {if (true) return ncb.makeName(ns, name.getString(), null, name.getLocation(), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass PrefixedNameClass(Annotations a) throws ParseException {
+  Token t;
+    t = jj_consume_token(PREFIXED_NAME);
+    String qn = t.image;
+    int colon = qn.indexOf(':');
+    String prefix = qn.substring(0, colon);
+    {if (true) return ncb.makeName(lookupPrefix(prefix, t), qn.substring(colon + 1), prefix, makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass NsNameExceptClass(int context, Annotations a, Annotations[] pa) throws ParseException {
+  LocatedString ns;
+  ParsedNameClass nc;
+    ns = NsName();
+    checkNsName(context, ns);
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 30:
+      nc = ExceptNameClass(context | IN_NS_NAME);
+     nc = ncb.makeNsName(ns.getString(), nc, ns.getLocation(), a);
+      nc = AnnotateAfter(nc);
+      break;
+    default:
+      jj_la1[35] = jj_gen;
+      nc = ncb.makeNsName(ns.getString(), ns.getLocation(), a);
+      nc = AnnotateAfter(nc);
+      nc = NameClassAlternatives(context, nc, pa);
+    }
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public LocatedString NsName() throws ParseException {
+  Token t;
+    t = jj_consume_token(PREFIX_STAR);
+    String qn = t.image;
+    String prefix = qn.substring(0, qn.length() - 2);
+    {if (true) return new LocatedString(lookupPrefix(prefix, t), t);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass AnyNameExceptClass(int context, Annotations a, Annotations[] pa) throws ParseException {
+  Token t;
+  ParsedNameClass nc;
+    t = jj_consume_token(25);
+    checkAnyName(context, t);
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 30:
+      nc = ExceptNameClass(context | IN_ANY_NAME);
+     nc = ncb.makeAnyName(nc, makeLocation(t), a);
+      nc = AnnotateAfter(nc);
+      break;
+    default:
+      jj_la1[36] = jj_gen;
+      nc = ncb.makeAnyName(makeLocation(t), a);
+      nc = AnnotateAfter(nc);
+      nc = NameClassAlternatives(context, nc, pa);
+    }
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass ParenNameClass(int context, Annotations a) throws ParseException {
+  Token t;
+  ParsedNameClass nc;
+  Annotations[] pa = new Annotations[]{ a };
+    t = jj_consume_token(28);
+    nc = NameClass(context, pa);
+                                        nc = afterComments(nc);
+    jj_consume_token(29);
+    if (pa[0] != null)
+      nc = ncb.makeChoice(Collections.singletonList(nc), makeLocation(t), pa[0]);
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedNameClass ExceptNameClass(int context) throws ParseException {
+  ParsedNameClass nc;
+    jj_consume_token(30);
+    nc = BasicNameClass(context);
+    {if (true) return nc;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern ListExpr(Scope scope, Annotations a) throws ParseException {
+  Token t;
+  ParsedPattern p;
+    t = jj_consume_token(31);
+    jj_consume_token(11);
+    p = Expr(false, scope, null, null);
+    p = afterComments(p);
+    jj_consume_token(12);
+    {if (true) return sb.makeList(p, makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern MixedExpr(Scope scope, Annotations a) throws ParseException {
+  Token t;
+  ParsedPattern p;
+    t = jj_consume_token(32);
+    jj_consume_token(11);
+    p = Expr(false, scope, null, null);
+    p = afterComments(p);
+    jj_consume_token(12);
+    {if (true) return sb.makeMixed(p, makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern GrammarExpr(Scope scope, Annotations a) throws ParseException {
+  Token t;
+  Grammar g;
+    t = jj_consume_token(10);
+                  g = sb.makeGrammar(scope);
+    jj_consume_token(11);
+    a = GrammarBody(g, g, a);
+                                 topLevelComments(g);
+    jj_consume_token(12);
+    {if (true) return g.endGrammar(makeLocation(t), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern ParenExpr(boolean topLevel, Scope scope, Annotations a) throws ParseException {
+  Token t;
+  ParsedPattern p;
+    t = jj_consume_token(28);
+    p = Expr(topLevel, scope, t, a);
+                                            p = afterComments(p);
+    jj_consume_token(29);
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public Annotations GrammarBody(GrammarSection section, Scope scope, Annotations a) throws ParseException {
+  ParsedElementAnnotation e;
+    label_12:
+    while (true) {
+      if (jj_2_3(2)) {
+        ;
+      } else {
+        break label_12;
+      }
+      e = AnnotationElementNotKeyword();
+     if (a == null) a = sb.makeAnnotations(null, getContext()); a.addElement(e);
+    }
+    label_13:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 1:
+      case 5:
+      case 6:
+      case 7:
+      case DOCUMENTATION:
+      case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+        ;
+        break;
+      default:
+        jj_la1[37] = jj_gen;
+        break label_13;
+      }
+      GrammarComponent(section, scope);
+    }
+    {if (true) return a;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void GrammarComponent(GrammarSection section, Scope scope) throws ParseException {
+  ParsedElementAnnotation e;
+  Annotations a;
+    a = Annotations();
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 5:
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      Definition(section, scope, a);
+      break;
+    case 7:
+      Include(section, scope, a);
+      break;
+    case 6:
+      Div(section, scope, a);
+      break;
+    default:
+      jj_la1[38] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    label_14:
+    while (true) {
+      if (jj_2_4(2)) {
+        ;
+      } else {
+        break label_14;
+      }
+      e = AnnotationElementNotKeyword();
+                                                    section.topLevelAnnotation(e);
+    }
+  }
+
+  final public void Definition(GrammarSection section, Scope scope, Annotations a) throws ParseException {
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      Define(section, scope, a);
+      break;
+    case 5:
+      Start(section, scope, a);
+      break;
+    default:
+      jj_la1[39] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+  }
+
+  final public void Start(GrammarSection section, Scope scope, Annotations a) throws ParseException {
+  Token t;
+  GrammarSection.Combine combine;
+  ParsedPattern p;
+    t = jj_consume_token(5);
+    combine = AssignOp();
+    p = Expr(false, scope, null, null);
+    section.define(GrammarSection.START, combine, p, makeLocation(t), a);
+  }
+
+  final public void Define(GrammarSection section, Scope scope, Annotations a) throws ParseException {
+  LocatedString name;
+  GrammarSection.Combine combine;
+  ParsedPattern p;
+    name = Identifier();
+    combine = AssignOp();
+    p = Expr(false, scope, null, null);
+    section.define(name.getString(), combine, p, name.getLocation(), a);
+  }
+
+  final public GrammarSection.Combine AssignOp() throws ParseException {
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 2:
+      jj_consume_token(2);
+        {if (true) return null;}
+      break;
+    case 4:
+      jj_consume_token(4);
+           {if (true) return GrammarSection.COMBINE_CHOICE;}
+      break;
+    case 3:
+      jj_consume_token(3);
+           {if (true) return GrammarSection.COMBINE_INTERLEAVE;}
+      break;
+    default:
+      jj_la1[40] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void Include(GrammarSection section, Scope scope, Annotations a) throws ParseException {
+  Token t;
+  String href;
+  String ns;
+  Include include = section.makeInclude();
+    t = jj_consume_token(7);
+    href = Literal();
+    ns = Inherit();
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 11:
+      jj_consume_token(11);
+      a = IncludeBody(include, scope, a);
+                                            topLevelComments(include);
+      jj_consume_token(12);
+      break;
+    default:
+      jj_la1[41] = jj_gen;
+      ;
+    }
+    try {
+      include.endInclude(parseable, resolve(href), ns, makeLocation(t), a);
+    }
+    catch (IllegalSchemaException e) { }
+  }
+
+  final public Annotations IncludeBody(GrammarSection section, Scope scope, Annotations a) throws ParseException {
+  ParsedElementAnnotation e;
+    label_15:
+    while (true) {
+      if (jj_2_5(2)) {
+        ;
+      } else {
+        break label_15;
+      }
+      e = AnnotationElementNotKeyword();
+     if (a == null) a = sb.makeAnnotations(null, getContext()); a.addElement(e);
+    }
+    label_16:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 1:
+      case 5:
+      case 6:
+      case DOCUMENTATION:
+      case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+        ;
+        break;
+      default:
+        jj_la1[42] = jj_gen;
+        break label_16;
+      }
+      IncludeComponent(section, scope);
+    }
+    {if (true) return a;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void IncludeComponent(GrammarSection section, Scope scope) throws ParseException {
+  ParsedElementAnnotation e;
+  Annotations a;
+    a = Annotations();
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 5:
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      Definition(section, scope, a);
+      break;
+    case 6:
+      IncludeDiv(section, scope, a);
+      break;
+    default:
+      jj_la1[43] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    label_17:
+    while (true) {
+      if (jj_2_6(2)) {
+        ;
+      } else {
+        break label_17;
+      }
+      e = AnnotationElementNotKeyword();
+                                                    section.topLevelAnnotation(e);
+    }
+  }
+
+  final public void Div(GrammarSection section, Scope scope, Annotations a) throws ParseException {
+  Token t;
+  Div div = section.makeDiv();
+    t = jj_consume_token(6);
+    jj_consume_token(11);
+    a = GrammarBody(div, scope, a);
+                                                 topLevelComments(div);
+    jj_consume_token(12);
+    div.endDiv(makeLocation(t), a);
+  }
+
+  final public void IncludeDiv(GrammarSection section, Scope scope, Annotations a) throws ParseException {
+  Token t;
+  Div div = section.makeDiv();
+    t = jj_consume_token(6);
+    jj_consume_token(11);
+    a = IncludeBody(div, scope, a);
+                                                 topLevelComments(div);
+    jj_consume_token(12);
+    div.endDiv(makeLocation(t), a);
+  }
+
+  final public ParsedPattern ExternalRefExpr(Scope scope, Annotations a) throws ParseException {
+  Token t;
+  String href;
+  String ns;
+    t = jj_consume_token(33);
+    href = Literal();
+    ns = Inherit();
+    try {
+      {if (true) return sb.makeExternalRef(parseable, resolve(href), ns, scope, makeLocation(t), a);}
+    }
+    catch (IllegalSchemaException e) {
+      {if (true) return sb.makeErrorPattern();}
+    }
+    throw new Error("Missing return statement in function");
+  }
+
+  final public String Inherit() throws ParseException {
+  String ns = null;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 15:
+      jj_consume_token(15);
+      jj_consume_token(2);
+      ns = Prefix();
+      break;
+    default:
+      jj_la1[44] = jj_gen;
+      ;
+    }
+    if (ns == null)
+      ns = defaultNamespace;
+    {if (true) return ns;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern ParentExpr(Scope scope, Annotations a) throws ParseException {
+  LocatedString name;
+    jj_consume_token(34);
+             a = addCommentsToChildAnnotations(a);
+    name = Identifier();
+    if(scope==null) {
+      error("parent_ref_outside_grammar",name.getToken());
+      {if (true) return sb.makeErrorPattern();}
+    } else {
+      {if (true) return scope.makeParentRef(name.getString(), name.getLocation(), a);}
+    }
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern IdentifierExpr(Scope scope, Annotations a) throws ParseException {
+  LocatedString name;
+    name = Identifier();
+    if(scope==null) {
+      error("ref_outside_grammar",name.getToken());
+      {if (true) return sb.makeErrorPattern();}
+    } else {
+      {if (true) return scope.makeRef(name.getString(), name.getLocation(), a);}
+    }
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern ValueExpr(boolean topLevel, Annotations a) throws ParseException {
+  LocatedString s;
+    s = LocatedLiteral();
+    if (topLevel && annotationsIncludeElements) {
+      error("top_level_follow_annotation", s.getToken());
+      a = null;
+    }
+    {if (true) return sb.makeValue("", "token", s.getString(), getContext(), defaultNamespace, s.getLocation(), a);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedPattern DataExpr(boolean topLevel, Scope scope, Annotations a, Token[] except) throws ParseException {
+  Token datatypeToken;
+  Location loc;
+  String datatype;
+  String datatypeUri = null;
+  String s = null;
+  ParsedPattern e = null;
+  DataPatternBuilder dpb;
+    datatypeToken = DatatypeName();
+    datatype = datatypeToken.image;
+    loc = makeLocation(datatypeToken);
+    int colon = datatype.indexOf(':');
+    if (colon < 0)
+      datatypeUri = "";
+    else {
+      String prefix = datatype.substring(0, colon);
+      datatypeUri = lookupDatatype(prefix, datatypeToken);
+      datatype = datatype.substring(colon + 1);
+    }
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case LITERAL:
+      s = Literal();
+      if (topLevel && annotationsIncludeElements) {
+        error("top_level_follow_annotation", datatypeToken);
+        a = null;
+      }
+      {if (true) return sb.makeValue(datatypeUri, datatype, s, getContext(), defaultNamespace, loc, a);}
+      break;
+    default:
+      jj_la1[48] = jj_gen;
+        dpb = sb.makeDataPatternBuilder(datatypeUri, datatype, loc);
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 11:
+        Params(dpb);
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case 30:
+          e = Except(scope, except);
+          break;
+        default:
+          jj_la1[45] = jj_gen;
+          ;
+        }
+        break;
+      default:
+        jj_la1[47] = jj_gen;
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case 30:
+          e = Except(scope, except);
+          break;
+        default:
+          jj_la1[46] = jj_gen;
+          ;
+        }
+      }
+        {if (true) return e == null ? dpb.makePattern(loc, a) : dpb.makePattern(e, loc, a);}
+    }
+    throw new Error("Missing return statement in function");
+  }
+
+  final public Token DatatypeName() throws ParseException {
+  Token t;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 35:
+      t = jj_consume_token(35);
+      break;
+    case 36:
+      t = jj_consume_token(36);
+      break;
+    case PREFIXED_NAME:
+      t = jj_consume_token(PREFIXED_NAME);
+      break;
+    default:
+      jj_la1[49] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return t;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public LocatedString Identifier() throws ParseException {
+  LocatedString s;
+  Token t;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case IDENTIFIER:
+      t = jj_consume_token(IDENTIFIER);
+                      s = new LocatedString(t.image, t);
+      break;
+    case ESCAPED_IDENTIFIER:
+      t = jj_consume_token(ESCAPED_IDENTIFIER);
+                               s = new LocatedString(t.image.substring(1), t);
+      break;
+    default:
+      jj_la1[50] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return s;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public String Prefix() throws ParseException {
+  Token t;
+  String prefix;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case IDENTIFIER:
+      t = jj_consume_token(IDENTIFIER);
+                      prefix = t.image;
+      break;
+    case ESCAPED_IDENTIFIER:
+      t = jj_consume_token(ESCAPED_IDENTIFIER);
+                               prefix = t.image.substring(1);
+      break;
+    case 5:
+    case 6:
+    case 7:
+    case 10:
+    case 13:
+    case 14:
+    case 15:
+    case 16:
+    case 17:
+    case 18:
+    case 19:
+    case 26:
+    case 27:
+    case 31:
+    case 32:
+    case 33:
+    case 34:
+    case 35:
+    case 36:
+      t = Keyword();
+                    prefix = t.image;
+      break;
+    default:
+      jj_la1[51] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return lookupPrefix(prefix, t);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public LocatedString UnprefixedName() throws ParseException {
+  LocatedString s;
+  Token t;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      s = Identifier();
+      break;
+    case 5:
+    case 6:
+    case 7:
+    case 10:
+    case 13:
+    case 14:
+    case 15:
+    case 16:
+    case 17:
+    case 18:
+    case 19:
+    case 26:
+    case 27:
+    case 31:
+    case 32:
+    case 33:
+    case 34:
+    case 35:
+    case 36:
+      t = Keyword();
+                     s = new LocatedString(t.image, t);
+      break;
+    default:
+      jj_la1[52] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return s;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void Params(DataPatternBuilder dpb) throws ParseException {
+    jj_consume_token(11);
+    label_18:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 1:
+      case 5:
+      case 6:
+      case 7:
+      case 10:
+      case 13:
+      case 14:
+      case 15:
+      case 16:
+      case 17:
+      case 18:
+      case 19:
+      case 26:
+      case 27:
+      case 31:
+      case 32:
+      case 33:
+      case 34:
+      case 35:
+      case 36:
+      case DOCUMENTATION:
+      case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+        ;
+        break;
+      default:
+        jj_la1[53] = jj_gen;
+        break label_18;
+      }
+      Param(dpb);
+    }
+    jj_consume_token(12);
+  }
+
+  final public void Param(DataPatternBuilder dpb) throws ParseException {
+  LocatedString name;
+  Annotations a;
+  String value;
+    a = Annotations();
+    name = UnprefixedName();
+    jj_consume_token(2);
+                                                  a = addCommentsToLeadingAnnotations(a);
+    value = Literal();
+    dpb.addParam(name.getString(), value, getContext(), defaultNamespace, name.getLocation(), a);
+  }
+
+  final public ParsedPattern Except(Scope scope, Token[] except) throws ParseException {
+  Annotations a;
+  ParsedPattern p;
+  Token t;
+  Token[] innerExcept = new Token[1];
+    t = jj_consume_token(30);
+    a = Annotations();
+    p = PrimaryExpr(false, scope, a, innerExcept);
+    checkExcept(innerExcept);
+    except[0] = t;
+    {if (true) return p;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedElementAnnotation Documentation() throws ParseException {
+  CommentList comments = getComments();
+  ElementAnnotationBuilder eab;
+  Token t;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case DOCUMENTATION:
+      t = jj_consume_token(DOCUMENTATION);
+      break;
+    case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+      t = jj_consume_token(DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT);
+      break;
+    default:
+      jj_la1[54] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    eab = sb.makeElementAnnotationBuilder(WellKnownNamespaces.RELAX_NG_COMPATIBILITY_ANNOTATIONS,
+                                          "documentation",
+                                          getCompatibilityPrefix(),
+                                          makeLocation(t),
+                                          comments,
+                                          getContext());
+    eab.addText(mungeComment(t.image), makeLocation(t), null);
+    label_19:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case DOCUMENTATION_CONTINUE:
+        ;
+        break;
+      default:
+        jj_la1[55] = jj_gen;
+        break label_19;
+      }
+      t = jj_consume_token(DOCUMENTATION_CONTINUE);
+                                  eab.addText("\n" + mungeComment(t.image), makeLocation(t), null);
+    }
+    {if (true) return eab.makeElementAnnotation();}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public Annotations Annotations() throws ParseException {
+  CommentList comments = getComments();
+  Annotations a = null;
+  ParsedElementAnnotation e;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case DOCUMENTATION:
+    case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+      a = sb.makeAnnotations(comments, getContext());
+      label_20:
+      while (true) {
+        e = Documentation();
+                           a.addElement(e);
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case DOCUMENTATION:
+        case DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT:
+          ;
+          break;
+        default:
+          jj_la1[56] = jj_gen;
+          break label_20;
+        }
+      }
+      comments = getComments();
+      if (comments != null)
+        a.addLeadingComment(comments);
+      break;
+    default:
+      jj_la1[57] = jj_gen;
+      ;
+    }
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 1:
+      jj_consume_token(1);
+         if (a == null) a = sb.makeAnnotations(comments, getContext()); clearAttributeList(); annotationsIncludeElements = false;
+      label_21:
+      while (true) {
+        if (jj_2_7(2)) {
+          ;
+        } else {
+          break label_21;
+        }
+        PrefixedAnnotationAttribute(a, false);
+      }
+      label_22:
+      while (true) {
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case 5:
+        case 6:
+        case 7:
+        case 10:
+        case 13:
+        case 14:
+        case 15:
+        case 16:
+        case 17:
+        case 18:
+        case 19:
+        case 26:
+        case 27:
+        case 31:
+        case 32:
+        case 33:
+        case 34:
+        case 35:
+        case 36:
+        case IDENTIFIER:
+        case ESCAPED_IDENTIFIER:
+        case PREFIXED_NAME:
+          ;
+          break;
+        default:
+          jj_la1[58] = jj_gen;
+          break label_22;
+        }
+        e = AnnotationElement(false);
+                                        a.addElement(e); annotationsIncludeElements = true;
+      }
+         a.addComment(getComments());
+      jj_consume_token(9);
+      break;
+    default:
+      jj_la1[59] = jj_gen;
+      ;
+    }
+    if (a == null && comments != null)
+      a = sb.makeAnnotations(comments, getContext());
+    {if (true) return a;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void AnnotationAttribute(Annotations a) throws ParseException {
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case PREFIXED_NAME:
+      PrefixedAnnotationAttribute(a, true);
+      break;
+    case 5:
+    case 6:
+    case 7:
+    case 10:
+    case 13:
+    case 14:
+    case 15:
+    case 16:
+    case 17:
+    case 18:
+    case 19:
+    case 26:
+    case 27:
+    case 31:
+    case 32:
+    case 33:
+    case 34:
+    case 35:
+    case 36:
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      UnprefixedAnnotationAttribute(a);
+      break;
+    default:
+      jj_la1[60] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+  }
+
+  final public void PrefixedAnnotationAttribute(Annotations a, boolean nested) throws ParseException {
+  Token t;
+  String value;
+    t = jj_consume_token(PREFIXED_NAME);
+    jj_consume_token(2);
+    value = Literal();
+    String qn = t.image;
+    int colon = qn.indexOf(':');
+    String prefix = qn.substring(0, colon);
+    String ns = lookupPrefix(prefix, t);
+    if (ns == this.inheritedNs)
+      error("inherited_annotation_namespace", t);
+    else if (ns.length() == 0 && !nested)
+      error("unqualified_annotation_attribute", t);
+    else if (ns.equals(WellKnownNamespaces.RELAX_NG) && !nested)
+      error("relax_ng_namespace", t);
+    /*else if (ns.length() == 0
+             && qn.length() - colon - 1 == 5
+             && qn.regionMatches(colon + 1, "xmlns", 0, 5))
+      error("xmlns_annotation_attribute", t);*/
+    else if (ns.equals(WellKnownNamespaces.XMLNS))
+      error("xmlns_annotation_attribute_uri", t);
+    else {
+      if (ns.length() == 0)
+        prefix = null;
+      addAttribute(a, ns, qn.substring(colon + 1), prefix, value, t);
+    }
+  }
+
+  final public void UnprefixedAnnotationAttribute(Annotations a) throws ParseException {
+  LocatedString name;
+  String value;
+    name = UnprefixedName();
+    jj_consume_token(2);
+    value = Literal();
+    if (name.getString().equals("xmlns"))
+      error("xmlns_annotation_attribute", name.getToken());
+    else
+      addAttribute(a, "", name.getString(), null, value, name.getToken());
+  }
+
+  final public ParsedElementAnnotation AnnotationElement(boolean nested) throws ParseException {
+  ParsedElementAnnotation a;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case PREFIXED_NAME:
+      a = PrefixedAnnotationElement(nested);
+      break;
+    case 5:
+    case 6:
+    case 7:
+    case 10:
+    case 13:
+    case 14:
+    case 15:
+    case 16:
+    case 17:
+    case 18:
+    case 19:
+    case 26:
+    case 27:
+    case 31:
+    case 32:
+    case 33:
+    case 34:
+    case 35:
+    case 36:
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      a = UnprefixedAnnotationElement();
+      break;
+    default:
+      jj_la1[61] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return a;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedElementAnnotation AnnotationElementNotKeyword() throws ParseException {
+  ParsedElementAnnotation a;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case PREFIXED_NAME:
+      a = PrefixedAnnotationElement(false);
+      break;
+    case IDENTIFIER:
+    case ESCAPED_IDENTIFIER:
+      a = IdentifierAnnotationElement();
+      break;
+    default:
+      jj_la1[62] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return a;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedElementAnnotation PrefixedAnnotationElement(boolean nested) throws ParseException {
+  CommentList comments = getComments();
+  Token t;
+  ElementAnnotationBuilder eab;
+    t = jj_consume_token(PREFIXED_NAME);
+    String qn = t.image;
+    int colon = qn.indexOf(':');
+    String prefix = qn.substring(0, colon);
+    String ns = lookupPrefix(prefix, t);
+    if (ns == this.inheritedNs) {
+      error("inherited_annotation_namespace", t);
+      ns = "";
+    }
+    else if (!nested && ns.equals(WellKnownNamespaces.RELAX_NG)) {
+      error("relax_ng_namespace", t);
+      ns = "";
+    }
+    else {
+      if (ns.length() == 0)
+        prefix = null;
+    }
+    eab = sb.makeElementAnnotationBuilder(ns, qn.substring(colon + 1), prefix,
+                                          makeLocation(t), comments, getContext());
+    AnnotationElementContent(eab);
+    {if (true) return eab.makeElementAnnotation();}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedElementAnnotation UnprefixedAnnotationElement() throws ParseException {
+  CommentList comments = getComments();
+  LocatedString name;
+  ElementAnnotationBuilder eab;
+    name = UnprefixedName();
+    eab = sb.makeElementAnnotationBuilder("", name.getString(), null,
+                                          name.getLocation(), comments, getContext());
+    AnnotationElementContent(eab);
+    {if (true) return eab.makeElementAnnotation();}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public ParsedElementAnnotation IdentifierAnnotationElement() throws ParseException {
+  CommentList comments = getComments();
+  LocatedString name;
+  ElementAnnotationBuilder eab;
+    name = Identifier();
+    eab = sb.makeElementAnnotationBuilder("", name.getString(), null,
+                                          name.getLocation(), comments, getContext());
+    AnnotationElementContent(eab);
+    {if (true) return eab.makeElementAnnotation();}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public void AnnotationElementContent(ElementAnnotationBuilder eab) throws ParseException {
+  ParsedElementAnnotation e;
+    jj_consume_token(1);
+        clearAttributeList();
+    label_23:
+    while (true) {
+      if (jj_2_8(2)) {
+        ;
+      } else {
+        break label_23;
+      }
+      AnnotationAttribute(eab);
+    }
+    label_24:
+    while (true) {
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case 5:
+      case 6:
+      case 7:
+      case 10:
+      case 13:
+      case 14:
+      case 15:
+      case 16:
+      case 17:
+      case 18:
+      case 19:
+      case 26:
+      case 27:
+      case 31:
+      case 32:
+      case 33:
+      case 34:
+      case 35:
+      case 36:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+      case PREFIXED_NAME:
+      case LITERAL:
+        ;
+        break;
+      default:
+        jj_la1[63] = jj_gen;
+        break label_24;
+      }
+      switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+      case LITERAL:
+        AnnotationElementLiteral(eab);
+        label_25:
+        while (true) {
+          switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+          case 8:
+            ;
+            break;
+          default:
+            jj_la1[64] = jj_gen;
+            break label_25;
+          }
+          jj_consume_token(8);
+          AnnotationElementLiteral(eab);
+        }
+        break;
+      case 5:
+      case 6:
+      case 7:
+      case 10:
+      case 13:
+      case 14:
+      case 15:
+      case 16:
+      case 17:
+      case 18:
+      case 19:
+      case 26:
+      case 27:
+      case 31:
+      case 32:
+      case 33:
+      case 34:
+      case 35:
+      case 36:
+      case IDENTIFIER:
+      case ESCAPED_IDENTIFIER:
+      case PREFIXED_NAME:
+        e = AnnotationElement(true);
+                                   eab.addElement(e);
+        break;
+      default:
+        jj_la1[65] = jj_gen;
+        jj_consume_token(-1);
+        throw new ParseException();
+      }
+    }
+    eab.addComment(getComments());
+    jj_consume_token(9);
+  }
+
+  final public void AnnotationElementLiteral(ElementAnnotationBuilder eab) throws ParseException {
+  Token t;
+  CommentList comments = getComments();
+    t = jj_consume_token(LITERAL);
+                  eab.addText(unquote(t.image), makeLocation(t), comments);
+  }
+
+  final public String Literal() throws ParseException {
+  Token t;
+  String s;
+  StringBuffer buf;
+    t = jj_consume_token(LITERAL);
+    s = unquote(t.image);
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 8:
+      buf = new StringBuffer(s);
+      label_26:
+      while (true) {
+        jj_consume_token(8);
+        t = jj_consume_token(LITERAL);
+                         buf.append(unquote(t.image));
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case 8:
+          ;
+          break;
+        default:
+          jj_la1[66] = jj_gen;
+          break label_26;
+        }
+      }
+      s = buf.toString();
+      break;
+    default:
+      jj_la1[67] = jj_gen;
+      ;
+    }
+    {if (true) return s;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public LocatedString LocatedLiteral() throws ParseException {
+  Token t;
+  Token t2;
+  String s;
+  StringBuffer buf;
+    t = jj_consume_token(LITERAL);
+    s = unquote(t.image);
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 8:
+      buf = new StringBuffer(s);
+      label_27:
+      while (true) {
+        jj_consume_token(8);
+        t2 = jj_consume_token(LITERAL);
+                          buf.append(unquote(t2.image));
+        switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+        case 8:
+          ;
+          break;
+        default:
+          jj_la1[68] = jj_gen;
+          break label_27;
+        }
+      }
+      s = buf.toString();
+      break;
+    default:
+      jj_la1[69] = jj_gen;
+      ;
+    }
+    {if (true) return new LocatedString(s, t);}
+    throw new Error("Missing return statement in function");
+  }
+
+  final public Token Keyword() throws ParseException {
+  Token t;
+    switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
+    case 26:
+      t = jj_consume_token(26);
+      break;
+    case 27:
+      t = jj_consume_token(27);
+      break;
+    case 13:
+      t = jj_consume_token(13);
+      break;
+    case 31:
+      t = jj_consume_token(31);
+      break;
+    case 32:
+      t = jj_consume_token(32);
+      break;
+    case 10:
+      t = jj_consume_token(10);
+      break;
+    case 17:
+      t = jj_consume_token(17);
+      break;
+    case 18:
+      t = jj_consume_token(18);
+      break;
+    case 34:
+      t = jj_consume_token(34);
+      break;
+    case 33:
+      t = jj_consume_token(33);
+      break;
+    case 19:
+      t = jj_consume_token(19);
+      break;
+    case 5:
+      t = jj_consume_token(5);
+      break;
+    case 7:
+      t = jj_consume_token(7);
+      break;
+    case 14:
+      t = jj_consume_token(14);
+      break;
+    case 15:
+      t = jj_consume_token(15);
+      break;
+    case 35:
+      t = jj_consume_token(35);
+      break;
+    case 36:
+      t = jj_consume_token(36);
+      break;
+    case 16:
+      t = jj_consume_token(16);
+      break;
+    case 6:
+      t = jj_consume_token(6);
+      break;
+    default:
+      jj_la1[70] = jj_gen;
+      jj_consume_token(-1);
+      throw new ParseException();
+    }
+    {if (true) return t;}
+    throw new Error("Missing return statement in function");
+  }
+
+  final private boolean jj_2_1(int xla) {
+    jj_la = xla; jj_lastpos = jj_scanpos = token;
+    try { return !jj_3_1(); }
+    catch(LookaheadSuccess ls) { return true; }
+    finally { jj_save(0, xla); }
+  }
+
+  final private boolean jj_2_2(int xla) {
+    jj_la = xla; jj_lastpos = jj_scanpos = token;
+    try { return !jj_3_2(); }
+    catch(LookaheadSuccess ls) { return true; }
+    finally { jj_save(1, xla); }
+  }
+
+  final private boolean jj_2_3(int xla) {
+    jj_la = xla; jj_lastpos = jj_scanpos = token;
+    try { return !jj_3_3(); }
+    catch(LookaheadSuccess ls) { return true; }
+    finally { jj_save(2, xla); }
+  }
+
+  final private boolean jj_2_4(int xla) {
+    jj_la = xla; jj_lastpos = jj_scanpos = token;
+    try { return !jj_3_4(); }
+    catch(LookaheadSuccess ls) { return true; }
+    finally { jj_save(3, xla); }
+  }
+
+  final private boolean jj_2_5(int xla) {
+    jj_la = xla; jj_lastpos = jj_scanpos = token;
+    try { return !jj_3_5(); }
+    catch(LookaheadSuccess ls) { return true; }
+    finally { jj_save(4, xla); }
+  }
+
+  final private boolean jj_2_6(int xla) {
+    jj_la = xla; jj_lastpos = jj_scanpos = token;
+    try { return !jj_3_6(); }
+    catch(LookaheadSuccess ls) { return true; }
+    finally { jj_save(5, xla); }
+  }
+
+  final private boolean jj_2_7(int xla) {
+    jj_la = xla; jj_lastpos = jj_scanpos = token;
+    try { return !jj_3_7(); }
+    catch(LookaheadSuccess ls) { return true; }
+    finally { jj_save(6, xla); }
+  }
+
+  final private boolean jj_2_8(int xla) {
+    jj_la = xla; jj_lastpos = jj_scanpos = token;
+    try { return !jj_3_8(); }
+    catch(LookaheadSuccess ls) { return true; }
+    finally { jj_save(7, xla); }
+  }
+
+  final private boolean jj_3R_43() {
+    if (jj_scan_token(1)) return true;
+    Token xsp;
+    while (true) {
+      xsp = jj_scanpos;
+      if (jj_3R_52()) { jj_scanpos = xsp; break; }
+    }
+    if (jj_scan_token(9)) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_51() {
+    if (jj_scan_token(ESCAPED_IDENTIFIER)) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_50() {
+    if (jj_scan_token(IDENTIFIER)) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_41() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_3R_50()) {
+    jj_scanpos = xsp;
+    if (jj_3R_51()) return true;
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_47() {
+    if (jj_scan_token(PREFIXED_NAME)) return true;
+    if (jj_3R_56()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_55() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_scan_token(40)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(43)) return true;
+    }
+    while (true) {
+      xsp = jj_scanpos;
+      if (jj_scan_token(41)) { jj_scanpos = xsp; break; }
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_45() {
+    Token xsp;
+    if (jj_3R_55()) return true;
+    while (true) {
+      xsp = jj_scanpos;
+      if (jj_3R_55()) { jj_scanpos = xsp; break; }
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_38() {
+    if (jj_3R_48()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_42() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_scan_token(5)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(6)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(7)) return true;
+    }
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_37() {
+    if (jj_3R_47()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_54() {
+    if (jj_3R_42()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_29() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_3R_37()) {
+    jj_scanpos = xsp;
+    if (jj_3R_38()) return true;
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_44() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_3R_53()) {
+    jj_scanpos = xsp;
+    if (jj_3R_54()) return true;
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_53() {
+    if (jj_3R_41()) return true;
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_scan_token(2)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(3)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(4)) return true;
+    }
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_36() {
+    if (jj_3R_45()) return true;
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_3R_46()) jj_scanpos = xsp;
+    if (jj_3R_44()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_35() {
+    if (jj_3R_43()) return true;
+    if (jj_3R_44()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_34() {
+    if (jj_3R_42()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_33() {
+    if (jj_3R_41()) return true;
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_scan_token(1)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(2)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(3)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(4)) return true;
+    }
+    }
+    }
+    return false;
+  }
+
+  final private boolean jj_3_1() {
+    if (jj_3R_28()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_32() {
+    if (jj_scan_token(PREFIXED_NAME)) return true;
+    if (jj_scan_token(1)) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_28() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_3R_32()) {
+    jj_scanpos = xsp;
+    if (jj_3R_33()) {
+    jj_scanpos = xsp;
+    if (jj_3R_34()) {
+    jj_scanpos = xsp;
+    if (jj_3R_35()) {
+    jj_scanpos = xsp;
+    if (jj_3R_36()) return true;
+    }
+    }
+    }
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_59() {
+    if (jj_3R_43()) return true;
+    return false;
+  }
+
+  final private boolean jj_3_8() {
+    if (jj_3R_31()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_56() {
+    if (jj_scan_token(1)) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_49() {
+    if (jj_3R_57()) return true;
+    if (jj_scan_token(2)) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_40() {
+    if (jj_3R_49()) return true;
+    return false;
+  }
+
+  final private boolean jj_3_4() {
+    if (jj_3R_29()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_48() {
+    if (jj_3R_41()) return true;
+    if (jj_3R_56()) return true;
+    return false;
+  }
+
+  final private boolean jj_3_3() {
+    if (jj_3R_29()) return true;
+    return false;
+  }
+
+  final private boolean jj_3_6() {
+    if (jj_3R_29()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_62() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_scan_token(26)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(27)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(13)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(31)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(32)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(10)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(17)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(18)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(34)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(33)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(19)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(5)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(7)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(14)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(15)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(35)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(36)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(16)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(6)) return true;
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_61() {
+    if (jj_3R_62()) return true;
+    return false;
+  }
+
+  final private boolean jj_3_2() {
+    if (jj_3R_28()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_30() {
+    if (jj_scan_token(PREFIXED_NAME)) return true;
+    if (jj_scan_token(2)) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_60() {
+    if (jj_3R_41()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_58() {
+    if (jj_3R_57()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_57() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_3R_60()) {
+    jj_scanpos = xsp;
+    if (jj_3R_61()) return true;
+    }
+    return false;
+  }
+
+  final private boolean jj_3_5() {
+    if (jj_3R_29()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_31() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_3R_39()) {
+    jj_scanpos = xsp;
+    if (jj_3R_40()) return true;
+    }
+    return false;
+  }
+
+  final private boolean jj_3R_39() {
+    if (jj_3R_30()) return true;
+    return false;
+  }
+
+  final private boolean jj_3_7() {
+    if (jj_3R_30()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_46() {
+    if (jj_3R_43()) return true;
+    return false;
+  }
+
+  final private boolean jj_3R_52() {
+    Token xsp;
+    xsp = jj_scanpos;
+    if (jj_scan_token(57)) {
+    jj_scanpos = xsp;
+    if (jj_3R_58()) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(2)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(58)) {
+    jj_scanpos = xsp;
+    if (jj_scan_token(8)) {
+    jj_scanpos = xsp;
+    if (jj_3R_59()) return true;
+    }
+    }
+    }
+    }
+    }
+    return false;
+  }
+
+  public CompactSyntaxTokenManager token_source;
+  JavaCharStream jj_input_stream;
+  public Token token, jj_nt;
+  private int jj_ntk;
+  private Token jj_scanpos, jj_lastpos;
+  private int jj_la;
+  public boolean lookingAhead = false;
+  private boolean jj_semLA;
+  private int jj_gen;
+  final private int[] jj_la1 = new int[71];
+  static private int[] jj_la1_0;
+  static private int[] jj_la1_1;
+  static {
+      jj_la1_0();
+      jj_la1_1();
+   }
+   private static void jj_la1_0() {
+      jj_la1_0 = new int[] {0x9c0e0402,0x1e,0x2,0xe2,0x1c,0xe0,0xe0,0x0,0x0,0x0,0x8c0fe5e6,0x8c0fe5e6,0x402,0x16000,0x16000,0x8c0fe4e0,0x6000,0x8000,0x0,0x9c0e0400,0x100000,0x200000,0x400000,0x700000,0x700000,0x3800000,0x0,0x3800000,0x9e0fe4e0,0x0,0x100000,0x100000,0x9e0fe4e0,0x9c0fe4e0,0x2000000,0x40000000,0x40000000,0xe2,0xe0,0x20,0x1c,0x800,0x62,0x60,0x8000,0x40000000,0x40000000,0x800,0x0,0x0,0x0,0x8c0fe4e0,0x8c0fe4e0,0x8c0fe4e2,0x0,0x0,0x0,0x0,0x8c0fe4e0,0x2,0x8c0fe4e0,0x8c0fe4e0,0x0,0x8c0fe4e0,0x100,0x8c0fe4e0,0x100,0x100,0x100,0x100,0x8c0fe4e0,};
+   }
+   private static void jj_la1_1() {
+      jj_la1_1 = new int[] {0x6c0091f,0x0,0x0,0x2c00900,0x0,0xc00000,0x0,0x900,0x200,0x900,0x6c0001f,0x6c0001f,0x900,0x0,0x0,0xc0001f,0x0,0x4000000,0x8000000,0x6c0001f,0x0,0x0,0x0,0x0,0x0,0x0,0x8000000,0x0,0x3c0001f,0x8000000,0x0,0x0,0x3c0001f,0x2c0001f,0x1000000,0x0,0x0,0xc00900,0xc00000,0xc00000,0x0,0x0,0xc00900,0xc00000,0x0,0x0,0x0,0x0,0x4000000,0x2000018,0xc00000,0xc0001f,0xc0001f,0xc0091f,0x900,0x200,0x900,0x900,0x2c0001f,0x0,0x2c0001f,0x2c0001f,0x2c00000,0x6c0001f,0x0,0x6c0001f,0x0,0x0,0x0,0x0,0x1f,};
+   }
+  final private JJCalls[] jj_2_rtns = new JJCalls[8];
+  private boolean jj_rescan = false;
+  private int jj_gc = 0;
+
+  public CompactSyntax(java.io.InputStream stream) {
+    jj_input_stream = new JavaCharStream(stream, 1, 1);
+    token_source = new CompactSyntaxTokenManager(jj_input_stream);
+    token = new Token();
+    jj_ntk = -1;
+    jj_gen = 0;
+    for (int i = 0; i < 71; i++) jj_la1[i] = -1;
+    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
+  }
+
+  public void ReInit(java.io.InputStream stream) {
+    jj_input_stream.ReInit(stream, 1, 1);
+    token_source.ReInit(jj_input_stream);
+    token = new Token();
+    jj_ntk = -1;
+    jj_gen = 0;
+    for (int i = 0; i < 71; i++) jj_la1[i] = -1;
+    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
+  }
+
+  public CompactSyntax(java.io.Reader stream) {
+    jj_input_stream = new JavaCharStream(stream, 1, 1);
+    token_source = new CompactSyntaxTokenManager(jj_input_stream);
+    token = new Token();
+    jj_ntk = -1;
+    jj_gen = 0;
+    for (int i = 0; i < 71; i++) jj_la1[i] = -1;
+    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
+  }
+
+  public void ReInit(java.io.Reader stream) {
+    jj_input_stream.ReInit(stream, 1, 1);
+    token_source.ReInit(jj_input_stream);
+    token = new Token();
+    jj_ntk = -1;
+    jj_gen = 0;
+    for (int i = 0; i < 71; i++) jj_la1[i] = -1;
+    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
+  }
+
+  public CompactSyntax(CompactSyntaxTokenManager tm) {
+    token_source = tm;
+    token = new Token();
+    jj_ntk = -1;
+    jj_gen = 0;
+    for (int i = 0; i < 71; i++) jj_la1[i] = -1;
+    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
+  }
+
+  public void ReInit(CompactSyntaxTokenManager tm) {
+    token_source = tm;
+    token = new Token();
+    jj_ntk = -1;
+    jj_gen = 0;
+    for (int i = 0; i < 71; i++) jj_la1[i] = -1;
+    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
+  }
+
+  final private Token jj_consume_token(int kind) throws ParseException {
+    Token oldToken;
+    if ((oldToken = token).next != null) token = token.next;
+    else token = token.next = token_source.getNextToken();
+    jj_ntk = -1;
+    if (token.kind == kind) {
+      jj_gen++;
+      if (++jj_gc > 100) {
+        jj_gc = 0;
+        for (int i = 0; i < jj_2_rtns.length; i++) {
+          JJCalls c = jj_2_rtns[i];
+          while (c != null) {
+            if (c.gen < jj_gen) c.first = null;
+            c = c.next;
+          }
+        }
+      }
+      return token;
+    }
+    token = oldToken;
+    jj_kind = kind;
+    throw generateParseException();
+  }
+
+  static private final class LookaheadSuccess extends java.lang.Error { }
+  final private LookaheadSuccess jj_ls = new LookaheadSuccess();
+  final private boolean jj_scan_token(int kind) {
+    if (jj_scanpos == jj_lastpos) {
+      jj_la--;
+      if (jj_scanpos.next == null) {
+        jj_lastpos = jj_scanpos = jj_scanpos.next = token_source.getNextToken();
+      } else {
+        jj_lastpos = jj_scanpos = jj_scanpos.next;
+      }
+    } else {
+      jj_scanpos = jj_scanpos.next;
+    }
+    if (jj_rescan) {
+      int i = 0; Token tok = token;
+      while (tok != null && tok != jj_scanpos) { i++; tok = tok.next; }
+      if (tok != null) jj_add_error_token(kind, i);
+    }
+    if (jj_scanpos.kind != kind) return true;
+    if (jj_la == 0 && jj_scanpos == jj_lastpos) throw jj_ls;
+    return false;
+  }
+
+  final public Token getNextToken() {
+    if (token.next != null) token = token.next;
+    else token = token.next = token_source.getNextToken();
+    jj_ntk = -1;
+    jj_gen++;
+    return token;
+  }
+
+  final public Token getToken(int index) {
+    Token t = lookingAhead ? jj_scanpos : token;
+    for (int i = 0; i < index; i++) {
+      if (t.next != null) t = t.next;
+      else t = t.next = token_source.getNextToken();
+    }
+    return t;
+  }
+
+  final private int jj_ntk() {
+    if ((jj_nt=token.next) == null)
+      return (jj_ntk = (token.next=token_source.getNextToken()).kind);
+    else
+      return (jj_ntk = jj_nt.kind);
+  }
+
+  private java.util.Vector jj_expentries = new java.util.Vector();
+  private int[] jj_expentry;
+  private int jj_kind = -1;
+  private int[] jj_lasttokens = new int[100];
+  private int jj_endpos;
+
+  private void jj_add_error_token(int kind, int pos) {
+    if (pos >= 100) return;
+    if (pos == jj_endpos + 1) {
+      jj_lasttokens[jj_endpos++] = kind;
+    } else if (jj_endpos != 0) {
+      jj_expentry = new int[jj_endpos];
+      for (int i = 0; i < jj_endpos; i++) {
+        jj_expentry[i] = jj_lasttokens[i];
+      }
+      boolean exists = false;
+      for (java.util.Enumeration e = jj_expentries.elements(); e.hasMoreElements();) {
+        int[] oldentry = (int[])(e.nextElement());
+        if (oldentry.length == jj_expentry.length) {
+          exists = true;
+          for (int i = 0; i < jj_expentry.length; i++) {
+            if (oldentry[i] != jj_expentry[i]) {
+              exists = false;
+              break;
+            }
+          }
+          if (exists) break;
+        }
+      }
+      if (!exists) jj_expentries.addElement(jj_expentry);
+      if (pos != 0) jj_lasttokens[(jj_endpos = pos) - 1] = kind;
+    }
+  }
+
+  public ParseException generateParseException() {
+    jj_expentries.removeAllElements();
+    boolean[] la1tokens = new boolean[61];
+    for (int i = 0; i < 61; i++) {
+      la1tokens[i] = false;
+    }
+    if (jj_kind >= 0) {
+      la1tokens[jj_kind] = true;
+      jj_kind = -1;
+    }
+    for (int i = 0; i < 71; i++) {
+      if (jj_la1[i] == jj_gen) {
+        for (int j = 0; j < 32; j++) {
+          if ((jj_la1_0[i] & (1<<j)) != 0) {
+            la1tokens[j] = true;
+          }
+          if ((jj_la1_1[i] & (1<<j)) != 0) {
+            la1tokens[32+j] = true;
+          }
+        }
+      }
+    }
+    for (int i = 0; i < 61; i++) {
+      if (la1tokens[i]) {
+        jj_expentry = new int[1];
+        jj_expentry[0] = i;
+        jj_expentries.addElement(jj_expentry);
+      }
+    }
+    jj_endpos = 0;
+    jj_rescan_token();
+    jj_add_error_token(0, 0);
+    int[][] exptokseq = new int[jj_expentries.size()][];
+    for (int i = 0; i < jj_expentries.size(); i++) {
+      exptokseq[i] = (int[])jj_expentries.elementAt(i);
+    }
+    return new ParseException(token, exptokseq, tokenImage);
+  }
+
+  final public void enable_tracing() {
+  }
+
+  final public void disable_tracing() {
+  }
+
+  final private void jj_rescan_token() {
+    jj_rescan = true;
+    for (int i = 0; i < 8; i++) {
+      JJCalls p = jj_2_rtns[i];
+      do {
+        if (p.gen > jj_gen) {
+          jj_la = p.arg; jj_lastpos = jj_scanpos = p.first;
+          switch (i) {
+            case 0: jj_3_1(); break;
+            case 1: jj_3_2(); break;
+            case 2: jj_3_3(); break;
+            case 3: jj_3_4(); break;
+            case 4: jj_3_5(); break;
+            case 5: jj_3_6(); break;
+            case 6: jj_3_7(); break;
+            case 7: jj_3_8(); break;
+          }
+        }
+        p = p.next;
+      } while (p != null);
+    }
+    jj_rescan = false;
+  }
+
+  final private void jj_save(int index, int xla) {
+    JJCalls p = jj_2_rtns[index];
+    while (p.gen > jj_gen) {
+      if (p.next == null) { p = p.next = new JJCalls(); break; }
+      p = p.next;
+    }
+    p.gen = jj_gen + xla - jj_la; p.first = token; p.arg = xla;
+  }
+
+  static final class JJCalls {
+    int gen;
+    Token first;
+    int arg;
+    JJCalls next;
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntax.jj b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntax.jj
new file mode 100644
index 0000000..c0b8d25
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntax.jj
@@ -0,0 +1,1963 @@
+options {
+  STATIC = false;
+  UNICODE_INPUT = true;
+  JAVA_UNICODE_ESCAPE = true;
+}
+
+PARSER_BEGIN(CompactSyntax)
+
+package com.sun.xml.internal.rngom.parse.compact;
+
+import java.io.Reader;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.Arrays;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.util.List;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Div;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.builder.GrammarSection;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.Context;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.LocatorImpl;
+
+import com.sun.xml.internal.rngom.util.Localizer;
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+
+
+public class CompactSyntax implements Context {
+  private static final int IN_ELEMENT = 0;
+  private static final int IN_ATTRIBUTE = 1;
+  private static final int IN_ANY_NAME = 2;
+  private static final int IN_NS_NAME = 4;
+
+  private String defaultNamespace;
+  private String compatibilityPrefix = null;
+  private SchemaBuilder sb;
+  private NameClassBuilder ncb;
+  private String sourceUri;
+  /**
+   * This is what we are parsing right now.
+   */
+  private CompactParseable parseable;
+  private ErrorHandler eh;
+  private final Hashtable namespaceTable = new Hashtable();
+  private final Hashtable datatypesTable = new Hashtable();
+  private boolean hadError = false;
+  private static final Localizer localizer = new Localizer(new Localizer(Parseable.class),CompactSyntax.class);
+  private final Hashtable attributeNameTable = new Hashtable();
+  private boolean annotationsIncludeElements = false;
+  
+  /**
+   * String that represents the inherited namespace.
+   * 
+   * <p>
+   * HACK: we always allocate a new String instance so that
+   * we can distinguish inherited value from the explicitly
+   * given value.
+   */
+  private /*final*/ String inheritedNs; // essentially final but JavaCC don't let us declare it as so.
+  
+  final class LocatedString {
+    private final String str;
+    private final Token tok;
+
+    LocatedString(String str, Token tok) {
+      this.str = str;
+      this.tok = tok;
+    }
+
+    String getString() {
+      return str;
+    }
+
+    Location getLocation() {
+      return makeLocation(tok);
+    }
+
+    Token getToken() {
+      return tok;
+    }
+
+  }
+
+  public CompactSyntax(CompactParseable parseable, Reader r, String sourceUri, SchemaBuilder sb, ErrorHandler eh, String inheritedNs) {
+    this(r);
+    this.sourceUri = sourceUri;
+    this.parseable = parseable;
+    this.sb = sb;
+    this.ncb = sb.getNameClassBuilder();
+    this.eh = eh;
+    // this causes the root pattern to have non-null annotations
+    // which is useful because it gives a context to trang
+    this.topLevelComments = sb.makeCommentList();
+    this.inheritedNs = defaultNamespace = new String(inheritedNs);
+  }
+
+  ParsedPattern parse(Scope scope) throws IllegalSchemaException {
+    try {
+      ParsedPattern p = Input(scope);
+      if (!hadError)
+        return p;
+    }
+    catch (ParseException e) {
+      error("syntax_error", e.getMessage(), e.currentToken.next);
+    }
+    catch (EscapeSyntaxException e) {
+      reportEscapeSyntaxException(e);
+    }
+    throw new IllegalSchemaException();
+  }
+
+  ParsedPattern parseInclude(IncludedGrammar g) throws IllegalSchemaException {
+    try {
+      ParsedPattern p = IncludedGrammar(g);
+      if (!hadError)
+        return p;
+    }
+    catch (ParseException e) {
+      error("syntax_error", e.getMessage(), e.currentToken.next);
+    }
+    catch (EscapeSyntaxException e) {
+      reportEscapeSyntaxException(e);
+    }
+    throw new IllegalSchemaException();
+  }
+
+  private void checkNsName(int context, LocatedString ns) {
+    if ((context & IN_NS_NAME) != 0)
+      error("ns_name_except_contains_ns_name", ns.getToken());
+  }
+
+  private void checkAnyName(int context, Token t) {
+    if ((context & IN_NS_NAME) != 0)
+      error("ns_name_except_contains_any_name", t);
+    if ((context & IN_ANY_NAME) != 0)
+      error("any_name_except_contains_any_name", t);
+  }
+
+  private void error(String key, Token tok) {
+    doError(localizer.message(key), tok);
+  }
+
+  private void error(String key, String arg, Token tok) {
+    doError(localizer.message(key, arg), tok);
+  }
+
+  private void error(String key, String arg1, String arg2, Token tok) {
+    doError(localizer.message(key, arg1, arg2), tok);
+  }
+
+  private void doError(String message, Token tok) {
+    hadError = true;
+    if (eh != null) {
+      LocatorImpl loc = new LocatorImpl();
+      loc.setLineNumber(tok.beginLine);
+      loc.setColumnNumber(tok.beginColumn);
+      loc.setSystemId(sourceUri);
+      try {
+	eh.error(new SAXParseException(message, loc));
+      }
+      catch (SAXException se) {
+	throw new BuildException(se);
+      }
+    }
+  }
+
+  private void reportEscapeSyntaxException(EscapeSyntaxException e) {
+    if (eh != null) {
+      LocatorImpl loc = new LocatorImpl();
+      loc.setLineNumber(e.getLineNumber());
+      loc.setColumnNumber(e.getColumnNumber());
+      loc.setSystemId(sourceUri);
+      try {
+	eh.error(new SAXParseException(localizer.message(e.getKey()), loc));
+      }
+      catch (SAXException se) {
+	throw new BuildException(se);
+      }
+    }
+  }
+
+  private static String unquote(String s) {
+    if (s.length() >= 6 && s.charAt(0) == s.charAt(1)) {
+      s = s.replace('\u0000', '\n');
+      return s.substring(3, s.length() - 3);
+    }
+    else
+      return s.substring(1, s.length() - 1);
+  }
+
+  Location makeLocation(Token t) {
+    return sb.makeLocation(sourceUri, t.beginLine, t.beginColumn);
+  }
+
+  private static ParsedPattern[] addPattern(ParsedPattern[] patterns, int i, ParsedPattern p) {
+    if (i >= patterns.length) {
+      ParsedPattern[] oldPatterns = patterns;
+      patterns = new ParsedPattern[oldPatterns.length*2];
+      System.arraycopy(oldPatterns, 0, patterns, 0, oldPatterns.length);
+    }
+    patterns[i] = p;
+    return patterns;
+  }
+
+  String getCompatibilityPrefix() {
+    if (compatibilityPrefix == null) {
+      compatibilityPrefix = "a";
+      while (namespaceTable.get(compatibilityPrefix) != null)
+        compatibilityPrefix = compatibilityPrefix + "a";
+    }
+    return compatibilityPrefix;
+  }
+
+  public String resolveNamespacePrefix(String prefix) {
+    String result = (String)namespaceTable.get(prefix);
+    if (result.length() == 0)
+      return null;
+    return result;
+  }
+
+  public Enumeration prefixes() {
+    return namespaceTable.keys();
+  }
+
+  public String getBaseUri() {
+    return sourceUri;
+  }
+
+  public boolean isUnparsedEntity(String entityName) {
+    return false;
+  }
+
+  public boolean isNotation(String notationName) {
+    return false;
+  }
+
+  public Context copy() {
+    return this;
+  }
+
+  private Context getContext() {
+    return this;
+  }
+
+  private CommentList getComments() {
+    return getComments(getTopLevelComments());
+  }
+
+  private CommentList topLevelComments;
+
+  private CommentList getTopLevelComments() {
+    CommentList tem = topLevelComments;
+    topLevelComments = null;
+    return tem;
+  }
+
+  private void noteTopLevelComments() {
+    topLevelComments = getComments(topLevelComments);
+  }
+
+  private void topLevelComments(GrammarSection section) {
+    section.topLevelComment(getComments(null));
+  }
+
+  private Token lastCommentSourceToken = null;
+
+  private CommentList getComments(CommentList comments) {
+    Token nextToken = getToken(1);
+    if (lastCommentSourceToken != nextToken) {
+      if (lastCommentSourceToken == null)
+        lastCommentSourceToken = token;
+      do {
+	lastCommentSourceToken = lastCommentSourceToken.next;
+	Token t = lastCommentSourceToken.specialToken;
+	if (t != null) {
+	  while (t.specialToken != null)
+	    t = t.specialToken;
+	  if (comments == null)
+	    comments = sb.makeCommentList();
+	  for (; t != null; t = t.next) {
+            String s = mungeComment(t.image);
+            Location loc = makeLocation(t);
+            if (t.next != null
+                && t.next.kind == CompactSyntaxConstants.SINGLE_LINE_COMMENT_CONTINUE) {
+              StringBuffer buf = new StringBuffer(s);
+              do {
+                t = t.next;
+                buf.append('\n');
+                buf.append(mungeComment(t.image));
+              } while (t.next != null
+                       && t.next.kind == CompactSyntaxConstants.SINGLE_LINE_COMMENT_CONTINUE);
+              s = buf.toString();
+            }
+	    comments.addComment(s, loc);
+          }
+	}
+      } while (lastCommentSourceToken != nextToken);
+    }
+    return comments;
+  }
+
+  private ParsedPattern afterComments(ParsedPattern p) {
+    CommentList comments = getComments(null);
+    if (comments == null)
+      return p;
+    return sb.commentAfter(p, comments);
+  }
+
+  private ParsedNameClass afterComments(ParsedNameClass nc) {
+    CommentList comments = getComments(null);
+    if (comments == null)
+      return nc;
+    return ncb.commentAfter(nc, comments);
+  }
+
+  private static String mungeComment(String image) {
+    int i = image.indexOf('#') + 1;
+    while (i < image.length() && image.charAt(i) == '#')
+      i++;
+    if (i < image.length() && image.charAt(i) == ' ')
+      i++;
+    return image.substring(i);
+  }
+
+  private Annotations getCommentsAsAnnotations() {
+    CommentList comments = getComments();
+    if (comments == null)
+      return null;
+    return sb.makeAnnotations(comments, getContext());
+  }
+
+  private Annotations addCommentsToChildAnnotations(Annotations a) {
+    CommentList comments = getComments();
+    if (comments == null)
+      return a;
+    if (a == null)
+      a = sb.makeAnnotations(null, getContext());
+    a.addComment(comments);
+    return a;
+  }
+
+  private Annotations addCommentsToLeadingAnnotations(Annotations a) {
+    CommentList comments = getComments();
+    if (comments == null)
+      return a;
+    if (a == null)
+      return sb.makeAnnotations(comments, getContext());
+    a.addLeadingComment(comments);
+    return a;
+  }
+
+  private Annotations getTopLevelCommentsAsAnnotations() {
+    CommentList comments = getTopLevelComments();
+    if (comments == null)
+      return null;
+    return sb.makeAnnotations(comments, getContext());
+  }
+
+  private void clearAttributeList() {
+    attributeNameTable.clear();
+  }
+
+  private void addAttribute(Annotations a, String ns, String localName, String prefix, String value, Token tok) {
+    String key = ns + "#" + localName;
+    if (attributeNameTable.get(key) != null)
+      error("duplicate_attribute", ns, localName, tok);
+    else {
+      attributeNameTable.put(key, key);
+      a.addAttribute(ns, localName, prefix, value, makeLocation(tok));
+    }
+  }
+
+  private void checkExcept(Token[] except) {
+    if (except[0] != null)
+      error("except_missing_parentheses", except[0]);
+  }
+
+  private String lookupPrefix(String prefix, Token t) {
+    String ns = (String)namespaceTable.get(prefix);
+    if (ns == null) {
+      error("undeclared_prefix", prefix, t);
+      return "#error";
+    }
+    return ns;
+  }
+  private String lookupDatatype(String prefix, Token t) {
+    String ns = (String)datatypesTable.get(prefix);
+    if (ns == null) {
+      error("undeclared_prefix", prefix, t);
+      return ""; // XXX
+    }
+    return ns;
+  }
+  private String resolve(String str) {
+    try {
+     return new URL(new URL(sourceUri), str).toString();
+    }
+    catch (MalformedURLException e) { }
+    return str;
+  }
+}
+
+PARSER_END(CompactSyntax)
+
+ParsedPattern Input(Scope scope) :
+{
+  ParsedPattern p;
+}
+{
+  Preamble()
+  (LOOKAHEAD(TopLevelLookahead()) p = TopLevelGrammar(scope)
+   | p = Expr(true, scope, null, null) { p = afterComments(p); } <EOF>)
+  { return p; }
+}
+
+void TopLevelLookahead() :
+{}
+{
+  <PREFIXED_NAME> "["
+  | Identifier() ("[" | "=" | "&=" | "|=")
+  | LookaheadGrammarKeyword()
+  | LookaheadBody() LookaheadAfterAnnotations()
+  | LookaheadDocumentation() (LookaheadBody())? LookaheadAfterAnnotations()
+}
+
+void LookaheadAfterAnnotations() :
+{}
+{
+  Identifier() ("=" | "&=" | "|=")
+  | LookaheadGrammarKeyword()
+}
+
+void LookaheadGrammarKeyword() :
+{}
+{
+  "start" | "div" | "include"
+}
+
+void LookaheadDocumentation() :
+{}
+{
+  ((<DOCUMENTATION> | <DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT>) (<DOCUMENTATION_CONTINUE>)*)+
+}
+
+void LookaheadBody() :
+{}
+{
+  "["
+   (<PREFIXED_NAME> | UnprefixedName() | "=" | <LITERAL> | "~" | LookaheadBody() )*
+  "]"
+}
+
+ParsedPattern IncludedGrammar(IncludedGrammar g) :
+{
+  Annotations a;
+  ParsedPattern p;
+}
+{
+  Preamble()
+  (LOOKAHEAD(TopLevelLookahead()) a = GrammarBody(g, g, getTopLevelCommentsAsAnnotations())
+   | a = Annotations() "grammar" "{" a = GrammarBody(g, g, a) { topLevelComments(g); } "}")
+  { p = afterComments(g.endIncludedGrammar(sb.makeLocation(sourceUri, 1, 1), a)); }
+  <EOF>
+  { return p; }
+}
+
+ParsedPattern TopLevelGrammar(Scope scope) :
+{
+  Annotations a = getTopLevelCommentsAsAnnotations();
+  Grammar g;
+  ParsedPattern p;
+}
+{
+  { g = sb.makeGrammar(scope); }
+  a = GrammarBody(g, g, a)
+  { p = afterComments(g.endGrammar(sb.makeLocation(sourceUri, 1, 1), a)); }
+  <EOF>
+  { return p; }
+}
+
+void Preamble() :
+{}
+{
+  (NamespaceDecl() | DatatypesDecl())*
+  {
+    namespaceTable.put("xml", WellKnownNamespaces.XML);
+    if (datatypesTable.get("xsd") == null)
+      datatypesTable.put("xsd", WellKnownNamespaces.XML_SCHEMA_DATATYPES);
+  }
+}
+
+void NamespaceDecl() :
+{
+  LocatedString prefix = null;
+  boolean isDefault = false;
+  String namespaceName;
+}
+{
+  { noteTopLevelComments(); }
+  (("namespace" prefix = UnprefixedName())
+    | ("default" { isDefault = true; }
+      "namespace" (prefix = UnprefixedName())?))
+  "="
+  namespaceName = NamespaceName()
+  {
+    if (isDefault)
+      defaultNamespace = namespaceName;
+    if (prefix != null) {
+      if (prefix.getString().equals("xmlns"))
+        error("xmlns_prefix", prefix.getToken());
+      else if (prefix.getString().equals("xml")) {
+        if (!namespaceName.equals(WellKnownNamespaces.XML))
+          error("xml_prefix_bad_uri", prefix.getToken());
+      }
+      else if (namespaceName.equals(WellKnownNamespaces.XML))
+        error("xml_uri_bad_prefix", prefix.getToken());
+      else {
+        if (namespaceName.equals(WellKnownNamespaces.RELAX_NG_COMPATIBILITY_ANNOTATIONS))
+          compatibilityPrefix = prefix.getString();
+        namespaceTable.put(prefix.getString(), namespaceName);
+      }
+    }
+  }
+}
+
+String NamespaceName() :
+{
+  String r;
+}
+{
+  (r = Literal() | "inherit" { r = this.inheritedNs; })
+  { return r; }
+}
+
+void DatatypesDecl() :
+{
+  LocatedString prefix;
+  String uri;
+}
+{
+  { noteTopLevelComments(); }
+  "datatypes" prefix = UnprefixedName() "=" uri = Literal()
+  {
+    datatypesTable.put(prefix.getString(), uri);
+  }
+}
+
+ParsedPattern AnnotatedPrimaryExpr(boolean topLevel, Scope scope, Token[] except) :
+{
+  Annotations a;
+  ParsedPattern p;
+  ParsedElementAnnotation e;
+  Token t;
+}
+{
+  a = Annotations()
+  p = PrimaryExpr(topLevel, scope, a, except)
+  ( t = <FANNOTATE> e = AnnotationElement(false) {
+       if (topLevel)
+         error("top_level_follow_annotation", t);
+       else
+         p = sb.annotateAfter(p, e);
+     })*
+  { return p; }
+}
+
+
+ParsedPattern PrimaryExpr(boolean topLevel, Scope scope, Annotations a, Token[] except) :
+{
+  ParsedPattern p;
+}
+{
+  (p = ElementExpr(scope, a)
+   | p = AttributeExpr(scope, a)
+   | p = GrammarExpr(scope, a)
+   | p = ExternalRefExpr(scope, a)
+   | p = ListExpr(scope, a)
+   | p = MixedExpr(scope, a)
+   | p = ParenExpr(topLevel, scope, a)
+   | p = IdentifierExpr(scope, a)
+   | p = ParentExpr(scope, a)
+   | p = DataExpr(topLevel, scope, a, except)
+   | p = ValueExpr(topLevel, a)
+   | p = TextExpr(a)
+   | p = EmptyExpr(a)
+   | p = NotAllowedExpr(a))
+  { return p; }
+}
+
+ParsedPattern EmptyExpr(Annotations a) :
+{
+  Token t;
+}
+{
+  t = "empty"
+  { return sb.makeEmpty(makeLocation(t), a); }
+}
+
+ParsedPattern TextExpr(Annotations a) :
+{
+  Token t;
+}
+{
+  t = "text"
+  { return sb.makeText(makeLocation(t), a); }
+}
+
+ParsedPattern NotAllowedExpr(Annotations a) :
+{
+  Token t;
+}
+{
+  t = "notAllowed"
+  { return sb.makeNotAllowed(makeLocation(t), a); }
+}
+
+ParsedPattern Expr(boolean topLevel, Scope scope, Token t, Annotations a) :
+{
+  List patterns = new ArrayList();
+  ParsedPattern p;
+  boolean[] hadOccur = new boolean[1];
+  Token[] except = new Token[1];
+}
+{
+  p = UnaryExpr(topLevel, scope, hadOccur, except)
+  { patterns.add(p); }
+  (
+   { checkExcept(except); }
+   (t = "|" p = UnaryExpr(topLevel, scope, null, except)
+     { patterns.add(p); checkExcept(except); } )+
+    { p = sb.makeChoice(patterns, makeLocation(t), a); }
+    | (t = "&" p = UnaryExpr(topLevel, scope, null, except)
+     { patterns.add(p); checkExcept(except); } )+
+    { p = sb.makeInterleave(patterns, makeLocation(t), a); }
+    | (t = "," p = UnaryExpr(topLevel, scope, null, except)
+     { patterns.add(p); checkExcept(except); } )+
+    { p = sb.makeGroup(patterns, makeLocation(t), a); }
+  )?
+  {
+    if (patterns.size() == 1 && a != null) {
+      if (hadOccur[0])
+        p = sb.annotate(p, a);
+      else
+        p = sb.makeGroup(patterns, makeLocation(t), a);
+    }
+    return p;
+  }
+}
+
+ParsedPattern UnaryExpr(boolean topLevel, Scope scope, boolean[] hadOccur, Token[] except) :
+{
+  ParsedPattern p;
+  Token t;
+  ParsedElementAnnotation e;
+}
+{
+  p = AnnotatedPrimaryExpr(topLevel, scope, except)
+  (
+   {
+     if (hadOccur != null) hadOccur[0] = true;
+     p = afterComments(p);
+   }
+   (t = "+" { checkExcept(except); p = sb.makeOneOrMore(p, makeLocation(t), null); }
+    | t = "?" { checkExcept(except); p = sb.makeOptional(p, makeLocation(t), null); }
+    | t = "*" { checkExcept(except); p = sb.makeZeroOrMore(p, makeLocation(t), null); })
+   ( t = <FANNOTATE> e = AnnotationElement(false) {
+        if (topLevel)
+          error("top_level_follow_annotation", t);
+        else
+          p = sb.annotateAfter(p, e);
+     } )*
+  )?
+  { return p; }
+}
+
+ParsedPattern ElementExpr(Scope scope, Annotations a) :
+{
+  Token t;
+  ParsedNameClass nc;
+  ParsedPattern p;
+}
+{
+  t = "element"
+  nc = NameClass(IN_ELEMENT, null)
+  "{"
+  p = Expr(false, scope, null, null)
+  { p = afterComments(p); }
+  "}"
+  { return sb.makeElement(nc, p, makeLocation(t), a); }
+}
+
+ParsedPattern AttributeExpr(Scope scope, Annotations a) :
+{
+  Token t;
+  ParsedNameClass nc;
+  ParsedPattern p;
+}
+{
+  t = "attribute"
+  nc = NameClass(IN_ATTRIBUTE, null)
+  "{"
+  p = Expr(false, scope, null, null)
+  { p = afterComments(p); }
+  "}"
+  { return sb.makeAttribute(nc, p, makeLocation(t), a); }
+}
+
+ParsedNameClass NameClass(int context, Annotations[] pa) :
+{
+  Annotations a;
+  ParsedNameClass nc;
+}
+{
+  a = Annotations()
+  (nc = PrimaryNameClass(context, a) nc = AnnotateAfter(nc) nc = NameClassAlternatives(context, nc, pa)
+   | nc = AnyNameExceptClass(context, a, pa)
+   | nc = NsNameExceptClass(context, a, pa))
+  { return nc; }
+}
+
+ParsedNameClass AnnotateAfter(ParsedNameClass nc) :
+{
+  ParsedElementAnnotation e;
+}
+{
+  ( <FANNOTATE> e = AnnotationElement(false) { nc = ncb.annotateAfter(nc, e); })*
+  { return nc; }
+}
+
+ParsedNameClass NameClassAlternatives(int context, ParsedNameClass nc, Annotations[] pa) :
+{
+  Token t;
+  ParsedNameClass[] nameClasses;
+  int nNameClasses;
+}
+{
+  (
+    {
+      nameClasses = new ParsedNameClass[2];
+      nameClasses[0] = nc;
+      nNameClasses = 1;
+    }
+    (t = "|" nc = BasicNameClass(context) nc = AnnotateAfter(nc)
+    {
+      if (nNameClasses >= nameClasses.length) {
+	ParsedNameClass[] oldNameClasses = nameClasses;
+	nameClasses = new ParsedNameClass[oldNameClasses.length*2];
+	System.arraycopy(oldNameClasses, 0, nameClasses, 0, oldNameClasses.length);
+      }
+      nameClasses[nNameClasses++] = nc;
+    })+
+    {
+      Annotations a;
+      if (pa == null)
+        a = null;
+      else {
+        a = pa[0];
+        pa[0] = null;
+      }
+      nc = ncb.makeChoice(Arrays.asList(nameClasses).subList(0,nNameClasses), makeLocation(t), a);
+    }
+  )?
+  { return nc; }
+}
+
+ParsedNameClass BasicNameClass(int context) :
+{
+  Annotations a;
+  ParsedNameClass nc;
+}
+{
+  a = Annotations()
+  (nc = PrimaryNameClass(context, a)
+   | nc = OpenNameClass(context, a))
+  { return nc; }
+}
+
+ParsedNameClass PrimaryNameClass(int context, Annotations a) :
+{
+  ParsedNameClass nc;
+}
+{
+  (nc = UnprefixedNameClass(context, a)
+   | nc = PrefixedNameClass(a)
+   | nc = ParenNameClass(context, a))
+  { return nc; }
+}
+
+ParsedNameClass OpenNameClass(int context, Annotations a) :
+{
+  Token t;
+  LocatedString ns;
+}
+{
+  ns = NsName() { checkNsName(context, ns); return ncb.makeNsName(ns.getString(), ns.getLocation(), a); }
+  | t = "*" { checkAnyName(context, t); return ncb.makeAnyName(makeLocation(t), a); }
+}
+
+
+ParsedNameClass UnprefixedNameClass(int context, Annotations a) :
+{
+  LocatedString name;
+}
+{
+  name = UnprefixedName()
+  {
+    String ns;
+    if ((context & (IN_ATTRIBUTE|IN_ELEMENT)) == IN_ATTRIBUTE)
+      ns = "";
+    else
+      ns = defaultNamespace;
+    return ncb.makeName(ns, name.getString(), null, name.getLocation(), a);
+  }
+}
+
+ParsedNameClass PrefixedNameClass(Annotations a) :
+{
+  Token t;
+}
+{
+  t = <PREFIXED_NAME>
+  {
+    String qn = t.image;
+    int colon = qn.indexOf(':');
+    String prefix = qn.substring(0, colon);
+    return ncb.makeName(lookupPrefix(prefix, t), qn.substring(colon + 1), prefix, makeLocation(t), a);
+  }
+}
+
+ParsedNameClass NsNameExceptClass(int context, Annotations a, Annotations[] pa) :
+{
+  LocatedString ns;
+  ParsedNameClass nc;
+}
+{
+  ns = NsName()
+  { checkNsName(context, ns); }
+  (nc = ExceptNameClass(context | IN_NS_NAME)
+   { nc = ncb.makeNsName(ns.getString(), nc, ns.getLocation(), a); }
+   nc = AnnotateAfter(nc)
+  | { nc = ncb.makeNsName(ns.getString(), ns.getLocation(), a); }
+    nc = AnnotateAfter(nc)
+    nc = NameClassAlternatives(context, nc, pa))
+  { return nc; }
+}
+
+LocatedString NsName() :
+{
+  Token t;
+}
+{
+  t = <PREFIX_STAR>
+  {
+    String qn = t.image;
+    String prefix = qn.substring(0, qn.length() - 2);
+    return new LocatedString(lookupPrefix(prefix, t), t);
+  }
+}
+
+ParsedNameClass AnyNameExceptClass(int context, Annotations a, Annotations[] pa) :
+{
+  Token t;
+  ParsedNameClass nc;
+}
+{
+  t = "*"
+  { checkAnyName(context, t); }
+  (nc = ExceptNameClass(context | IN_ANY_NAME)
+   { nc = ncb.makeAnyName(nc, makeLocation(t), a); }
+   nc = AnnotateAfter(nc)
+  | { nc = ncb.makeAnyName(makeLocation(t), a); }
+    nc = AnnotateAfter(nc)
+    nc = NameClassAlternatives(context, nc, pa))
+  { return nc; }
+}
+
+ParsedNameClass ParenNameClass(int context, Annotations a) :
+{
+  Token t;
+  ParsedNameClass nc;
+  Annotations[] pa = new Annotations[]{ a };
+}
+{
+  t = "(" nc = NameClass(context, pa) { nc = afterComments(nc); } ")"
+  {
+    if (pa[0] != null)
+      nc = ncb.makeChoice(Collections.singletonList(nc), makeLocation(t), pa[0]);
+    return nc;
+  }
+}
+
+ParsedNameClass ExceptNameClass(int context) :
+{
+  ParsedNameClass nc;
+}
+{
+  "-" nc = BasicNameClass(context)
+  { return nc; }
+}
+
+ParsedPattern ListExpr(Scope scope, Annotations a) :
+{
+  Token t;
+  ParsedPattern p;
+}
+{
+  t = "list"
+  "{"
+  p = Expr(false, scope, null, null)
+  { p = afterComments(p); }
+  "}"
+  { return sb.makeList(p, makeLocation(t), a); }
+}
+
+ParsedPattern MixedExpr(Scope scope, Annotations a) :
+{
+  Token t;
+  ParsedPattern p;
+}
+{
+  t = "mixed"
+  "{"
+  p = Expr(false, scope, null, null)
+  { p = afterComments(p); }
+  "}"
+  { return sb.makeMixed(p, makeLocation(t), a); }
+}
+
+ParsedPattern GrammarExpr(Scope scope, Annotations a) :
+{
+  Token t;
+  Grammar g;
+}
+{
+  t = "grammar" { g = sb.makeGrammar(scope); }
+  "{" a = GrammarBody(g, g, a) { topLevelComments(g); } "}"
+  { return g.endGrammar(makeLocation(t), a); }
+}
+
+ParsedPattern ParenExpr(boolean topLevel, Scope scope, Annotations a) :
+{
+  Token t;
+  ParsedPattern p;
+}
+{
+  t = "(" p = Expr(topLevel, scope, t, a) { p = afterComments(p); } ")"
+  { return p; }
+}
+
+Annotations GrammarBody(GrammarSection section, Scope scope, Annotations a) :
+{
+  ParsedElementAnnotation e;
+}
+{
+  (LOOKAHEAD(2) e = AnnotationElementNotKeyword()
+   { if (a == null) a = sb.makeAnnotations(null, getContext()); a.addElement(e); })*
+  (GrammarComponent(section, scope))*
+  { return a; }
+}
+
+void GrammarComponent(GrammarSection section, Scope scope) :
+{
+  ParsedElementAnnotation e;
+  Annotations a;
+}
+{
+  (a = Annotations()
+   (Definition(section, scope, a)
+    | Include(section, scope, a)
+    | Div(section, scope, a)))
+  (LOOKAHEAD(2) e = AnnotationElementNotKeyword() { section.topLevelAnnotation(e); })*
+}
+
+void Definition(GrammarSection section, Scope scope, Annotations a) :
+{}
+{
+  (Define(section, scope, a) | Start(section, scope, a))
+}
+
+void Start(GrammarSection section, Scope scope, Annotations a) :
+{
+  Token t;
+  GrammarSection.Combine combine;
+  ParsedPattern p;
+}
+{
+  t = "start" combine = AssignOp() p = Expr(false, scope, null, null)
+  { section.define(GrammarSection.START, combine, p, makeLocation(t), a); }
+}
+
+void Define(GrammarSection section, Scope scope, Annotations a) :
+{
+  LocatedString name;
+  GrammarSection.Combine combine;
+  ParsedPattern p;
+}
+{
+  name = Identifier() combine = AssignOp() p = Expr(false, scope, null, null)
+  { section.define(name.getString(), combine, p, name.getLocation(), a); }
+}
+
+GrammarSection.Combine AssignOp() :
+{}
+{
+  "=" { return null; }
+  | "|=" { return GrammarSection.COMBINE_CHOICE; }
+  | "&=" { return GrammarSection.COMBINE_INTERLEAVE; }
+}
+
+void Include(GrammarSection section, Scope scope, Annotations a) :
+{
+  Token t;
+  String href;
+  String ns;
+  Include include = section.makeInclude();
+}
+{
+  t = "include" href = Literal()
+  ns = Inherit()
+  ("{" a = IncludeBody(include, scope, a) { topLevelComments(include); } "}")?
+  {
+    try {
+      include.endInclude(parseable, resolve(href), ns, makeLocation(t), a);
+    }
+    catch (IllegalSchemaException e) { }
+  }
+}
+
+Annotations IncludeBody(GrammarSection section, Scope scope, Annotations a) :
+{
+  ParsedElementAnnotation e;
+}
+{
+  (LOOKAHEAD(2) e = AnnotationElementNotKeyword()
+   { if (a == null) a = sb.makeAnnotations(null, getContext()); a.addElement(e); })*
+  (IncludeComponent(section, scope))*
+  { return a; }
+}
+
+
+void IncludeComponent(GrammarSection section, Scope scope) :
+{
+  ParsedElementAnnotation e;
+  Annotations a;
+}
+{
+  (a = Annotations() (Definition(section, scope, a)
+                      | IncludeDiv(section, scope, a)))
+  (LOOKAHEAD(2) e = AnnotationElementNotKeyword() { section.topLevelAnnotation(e); })*
+}
+
+void Div(GrammarSection section, Scope scope, Annotations a) :
+{
+  Token t;
+  Div div = section.makeDiv();
+}
+{
+  t = "div" "{" a = GrammarBody(div, scope, a) { topLevelComments(div); } "}"
+  { div.endDiv(makeLocation(t), a); }
+}
+
+void IncludeDiv(GrammarSection section, Scope scope, Annotations a) :
+{
+  Token t;
+  Div div = section.makeDiv();
+}
+{
+  t = "div" "{" a = IncludeBody(div, scope, a) { topLevelComments(div); } "}"
+  { div.endDiv(makeLocation(t), a); }
+}
+
+ParsedPattern ExternalRefExpr(Scope scope, Annotations a) :
+{
+  Token t;
+  String href;
+  String ns;
+}
+{
+  t = "external" href = Literal()
+  ns = Inherit()
+  {
+    try {
+      return sb.makeExternalRef(parseable, resolve(href), ns, scope, makeLocation(t), a);
+    }
+    catch (IllegalSchemaException e) {
+      return sb.makeErrorPattern();
+    }
+  }
+}
+
+String Inherit() :
+{
+  String ns = null;
+}
+{
+  ("inherit" "=" ns = Prefix())?
+  {
+    if (ns == null)
+      ns = defaultNamespace;
+    return ns;
+  }
+}
+
+ParsedPattern ParentExpr(Scope scope, Annotations a) :
+{
+  LocatedString name;
+}
+{
+  "parent" { a = addCommentsToChildAnnotations(a); } name = Identifier()
+  {
+    if(scope==null) {
+      error("parent_ref_outside_grammar",name.getToken());
+      return sb.makeErrorPattern();
+    } else {
+      return scope.makeParentRef(name.getString(), name.getLocation(), a);
+    }
+  }
+}
+
+ParsedPattern IdentifierExpr(Scope scope, Annotations a) :
+{
+  LocatedString name;
+}
+{
+  name = Identifier()
+  {
+    if(scope==null) {
+      error("ref_outside_grammar",name.getToken());
+      return sb.makeErrorPattern();
+    } else {
+      return scope.makeRef(name.getString(), name.getLocation(), a);
+    }
+  }
+}
+
+ParsedPattern ValueExpr(boolean topLevel, Annotations a) :
+{
+  LocatedString s;
+}
+{
+  s = LocatedLiteral()
+  {
+    if (topLevel && annotationsIncludeElements) {
+      error("top_level_follow_annotation", s.getToken());
+      a = null;
+    }
+    return sb.makeValue("", "token", s.getString(), getContext(), defaultNamespace, s.getLocation(), a);
+  }
+}
+
+ParsedPattern DataExpr(boolean topLevel, Scope scope, Annotations a, Token[] except) :
+{
+  Token datatypeToken;
+  Location loc;
+  String datatype;
+  String datatypeUri = null;
+  String s = null;
+  ParsedPattern e = null;
+  DataPatternBuilder dpb;
+}
+{
+  datatypeToken = DatatypeName()
+  {
+    datatype = datatypeToken.image;
+    loc = makeLocation(datatypeToken);
+    int colon = datatype.indexOf(':');
+    if (colon < 0)
+      datatypeUri = "";
+    else {
+      String prefix = datatype.substring(0, colon);
+      datatypeUri = lookupDatatype(prefix, datatypeToken);
+      datatype = datatype.substring(colon + 1);
+    }
+  }
+  ((s = Literal()
+    {
+      if (topLevel && annotationsIncludeElements) {
+        error("top_level_follow_annotation", datatypeToken);
+        a = null;
+      }
+      return sb.makeValue(datatypeUri, datatype, s, getContext(), defaultNamespace, loc, a);
+    }
+  )
+  | ( { dpb = sb.makeDataPatternBuilder(datatypeUri, datatype, loc); }
+      ( (Params(dpb) (e = Except(scope, except))?)
+        | (e = Except(scope, except))?)
+      { return e == null ? dpb.makePattern(loc, a) : dpb.makePattern(e, loc, a); }))
+}
+
+Token DatatypeName() :
+{
+  Token t;
+}
+{
+  (t = "string" | t = "token" | t = <PREFIXED_NAME>)
+  { return t; }
+}
+
+LocatedString Identifier() :
+{
+  LocatedString s;
+  Token t;
+}
+{
+  (t = <IDENTIFIER> { s = new LocatedString(t.image, t); }
+  | t = <ESCAPED_IDENTIFIER> { s = new LocatedString(t.image.substring(1), t); })
+  { return s; }
+}
+
+String Prefix() :
+{
+  Token t;
+  String prefix;
+}
+{
+  (t = <IDENTIFIER> { prefix = t.image; }
+  | t = <ESCAPED_IDENTIFIER> { prefix = t.image.substring(1); }
+  | t = Keyword() { prefix = t.image; })
+  { return lookupPrefix(prefix, t); }
+}
+
+LocatedString UnprefixedName() :
+{
+  LocatedString s;
+  Token t;
+}
+{
+  (s = Identifier()
+   | t = Keyword() { s = new LocatedString(t.image, t); })
+  { return s; }
+}
+
+void Params(DataPatternBuilder dpb) :
+{}
+{
+  "{" (Param(dpb))* "}"
+}
+
+void Param(DataPatternBuilder dpb) :
+{
+  LocatedString name;
+  Annotations a;
+  String value;
+}
+{
+  a = Annotations() name = UnprefixedName() "=" { a = addCommentsToLeadingAnnotations(a); } value = Literal()
+  { dpb.addParam(name.getString(), value, getContext(), defaultNamespace, name.getLocation(), a); }
+}
+
+ParsedPattern Except(Scope scope, Token[] except) :
+{
+  Annotations a;
+  ParsedPattern p;
+  Token t;
+  Token[] innerExcept = new Token[1];
+}
+{
+  t = "-" a = Annotations() p = PrimaryExpr(false, scope, a, innerExcept)
+  {
+    checkExcept(innerExcept);
+    except[0] = t;
+    return p;
+  }
+}
+
+ParsedElementAnnotation Documentation() :
+{
+  CommentList comments = getComments();
+  ElementAnnotationBuilder eab;
+  Token t;
+}
+{
+  (t = <DOCUMENTATION> | t = <DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT>)
+  {
+    eab = sb.makeElementAnnotationBuilder(WellKnownNamespaces.RELAX_NG_COMPATIBILITY_ANNOTATIONS,
+                                          "documentation",
+                                          getCompatibilityPrefix(),
+                                          makeLocation(t),
+                                          comments,
+                                          getContext());
+    eab.addText(mungeComment(t.image), makeLocation(t), null);
+  }
+  (t = <DOCUMENTATION_CONTINUE> { eab.addText("\n" + mungeComment(t.image), makeLocation(t), null); })*
+  { return eab.makeElementAnnotation(); }
+}
+
+Annotations Annotations() :
+{
+  CommentList comments = getComments();
+  Annotations a = null;
+  ParsedElementAnnotation e;
+}
+{
+  ( { a = sb.makeAnnotations(comments, getContext()); }
+    (e = Documentation() { a.addElement(e); })+
+    {
+      comments = getComments();
+      if (comments != null)
+        a.addLeadingComment(comments);
+    }
+  )?
+  ("[" { if (a == null) a = sb.makeAnnotations(comments, getContext()); clearAttributeList(); annotationsIncludeElements = false; }
+       (LOOKAHEAD(2) PrefixedAnnotationAttribute(a, false) )*
+       ( e = AnnotationElement(false) { a.addElement(e); annotationsIncludeElements = true; } )*
+       { a.addComment(getComments()); }
+  "]")?
+  {
+    if (a == null && comments != null)
+      a = sb.makeAnnotations(comments, getContext());
+    return a;
+  }
+}
+
+void AnnotationAttribute(Annotations a) :
+{}
+{
+  PrefixedAnnotationAttribute(a, true) | UnprefixedAnnotationAttribute(a)
+}
+
+void PrefixedAnnotationAttribute(Annotations a, boolean nested) :
+{
+  Token t;
+  String value;
+}
+{
+  t = <PREFIXED_NAME> "=" value = Literal()
+  {
+    String qn = t.image;
+    int colon = qn.indexOf(':');
+    String prefix = qn.substring(0, colon);
+    String ns = lookupPrefix(prefix, t);
+    if (ns == this.inheritedNs)
+      error("inherited_annotation_namespace", t);
+    else if (ns.length() == 0 && !nested)
+      error("unqualified_annotation_attribute", t);
+    else if (ns.equals(WellKnownNamespaces.RELAX_NG) && !nested)
+      error("relax_ng_namespace", t);
+    /*else if (ns.length() == 0
+             && qn.length() - colon - 1 == 5
+             && qn.regionMatches(colon + 1, "xmlns", 0, 5))
+      error("xmlns_annotation_attribute", t);*/
+    else if (ns.equals(WellKnownNamespaces.XMLNS))
+      error("xmlns_annotation_attribute_uri", t);
+    else {
+      if (ns.length() == 0)
+	prefix = null;
+      addAttribute(a, ns, qn.substring(colon + 1), prefix, value, t);
+    }
+  }
+}
+
+void UnprefixedAnnotationAttribute(Annotations a) :
+{
+  LocatedString name;
+  String value;
+}
+{
+  name = UnprefixedName() "=" value = Literal()
+  {
+    if (name.getString().equals("xmlns"))
+      error("xmlns_annotation_attribute", name.getToken());
+    else
+      addAttribute(a, "", name.getString(), null, value, name.getToken());
+  }
+}
+
+ParsedElementAnnotation AnnotationElement(boolean nested) :
+{
+  ParsedElementAnnotation a;
+}
+{
+  (a = PrefixedAnnotationElement(nested)
+   | a = UnprefixedAnnotationElement())
+  { return a; }
+}
+
+ParsedElementAnnotation AnnotationElementNotKeyword() :
+{
+  ParsedElementAnnotation a;
+}
+{
+  (a = PrefixedAnnotationElement(false)
+   | a = IdentifierAnnotationElement())
+  { return a; }
+}
+
+ParsedElementAnnotation PrefixedAnnotationElement(boolean nested) :
+{
+  CommentList comments = getComments();
+  Token t;
+  ElementAnnotationBuilder eab;
+}
+{
+  t = <PREFIXED_NAME>
+  {
+    String qn = t.image;
+    int colon = qn.indexOf(':');
+    String prefix = qn.substring(0, colon);
+    String ns = lookupPrefix(prefix, t);
+    if (ns == this.inheritedNs) {
+      error("inherited_annotation_namespace", t);
+      ns = "";
+    }
+    else if (!nested && ns.equals(WellKnownNamespaces.RELAX_NG)) {
+      error("relax_ng_namespace", t);
+      ns = "";
+    }
+    else {
+      if (ns.length() == 0)
+        prefix = null;
+    }
+    eab = sb.makeElementAnnotationBuilder(ns, qn.substring(colon + 1), prefix,
+					  makeLocation(t), comments, getContext());
+  }
+  AnnotationElementContent(eab)
+  { return eab.makeElementAnnotation(); }
+}
+
+ParsedElementAnnotation UnprefixedAnnotationElement() :
+{
+  CommentList comments = getComments();
+  LocatedString name;
+  ElementAnnotationBuilder eab;
+}
+{
+  name = UnprefixedName()
+  {
+    eab = sb.makeElementAnnotationBuilder("", name.getString(), null,
+                                          name.getLocation(), comments, getContext());
+  }
+  AnnotationElementContent(eab)
+  { return eab.makeElementAnnotation(); }
+}
+
+ParsedElementAnnotation IdentifierAnnotationElement() :
+{
+  CommentList comments = getComments();
+  LocatedString name;
+  ElementAnnotationBuilder eab;
+}
+{
+  name = Identifier()
+  {
+    eab = sb.makeElementAnnotationBuilder("", name.getString(), null,
+                                          name.getLocation(), comments, getContext());
+  }
+  AnnotationElementContent(eab)
+  { return eab.makeElementAnnotation(); }
+}
+
+void AnnotationElementContent(ElementAnnotationBuilder eab) :
+{
+  ParsedElementAnnotation e;
+}
+{
+  "[" { clearAttributeList(); }
+  (LOOKAHEAD(2) AnnotationAttribute(eab))*
+  ((AnnotationElementLiteral(eab)
+    ("~" AnnotationElementLiteral(eab))*)
+   | e = AnnotationElement(true) { eab.addElement(e); })*
+  { eab.addComment(getComments()); }
+  "]"
+}
+
+void AnnotationElementLiteral(ElementAnnotationBuilder eab) :
+{
+  Token t;
+  CommentList comments = getComments();
+}
+{
+  t = <LITERAL> { eab.addText(unquote(t.image), makeLocation(t), comments); }
+}
+
+String Literal() :
+{
+  Token t;
+  String s;
+  StringBuffer buf;
+}
+{
+  t = <LITERAL>
+  {
+    s = unquote(t.image);
+  }
+  (
+    { buf = new StringBuffer(s); }
+    ("~" t = <LITERAL> { buf.append(unquote(t.image)); })+
+    { s = buf.toString(); }
+  )?
+  { return s; }
+}
+
+LocatedString LocatedLiteral() :
+{
+  Token t;
+  Token t2;
+  String s;
+  StringBuffer buf;
+}
+{
+  t = <LITERAL>
+  {
+    s = unquote(t.image);
+  }
+  (
+    { buf = new StringBuffer(s); }
+    ("~" t2 = <LITERAL> { buf.append(unquote(t2.image)); })+
+    { s = buf.toString(); }
+  )?
+  { return new LocatedString(s, t); }
+}
+
+Token Keyword() :
+{
+  Token t;
+}
+{
+  (t = "element"
+  | t = "attribute"
+  | t = "namespace"
+  | t = "list"
+  | t = "mixed"
+  | t = "grammar"
+  | t = "empty"
+  | t = "text"
+  | t = "parent"
+  | t = "external"
+  | t = "notAllowed"
+  | t = "start"
+  | t = "include"
+  | t = "default"
+  | t = "inherit"
+  | t = "string"
+  | t = "token"
+  | t = "datatypes"
+  | t = "div")
+  { return t; }
+}
+
+<*>
+SKIP: {
+  < #NEWLINE : [ "\u0000", "\n" ] >
+  | < #NOT_NEWLINE : ~[ "\u0000", "\n" ] >
+  | < WS: ([ "\u0000", " ", "\n", "\t" ])+ > : DEFAULT
+}
+
+TOKEN :
+{
+  < DOCUMENTATION: "##" (<NOT_NEWLINE>)* > : AFTER_DOCUMENTATION
+}
+
+<AFTER_DOCUMENTATION>
+TOKEN :
+{
+  < DOCUMENTATION_CONTINUE: <NEWLINE> ([" ", "\t"])* <DOCUMENTATION> >
+}
+
+SPECIAL_TOKEN:
+{
+  < SINGLE_LINE_COMMENT: "#" (<NOT_NEWLINE>)* > : AFTER_SINGLE_LINE_COMMENT
+}
+
+<AFTER_SINGLE_LINE_COMMENT>
+TOKEN :
+{
+  < DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT: <NEWLINE> ([" ", "\t"])* <DOCUMENTATION> > : AFTER_DOCUMENTATION
+}
+
+<AFTER_SINGLE_LINE_COMMENT>
+SPECIAL_TOKEN :
+{
+  < SINGLE_LINE_COMMENT_CONTINUE: <NEWLINE> ([" ", "\t"])* <SINGLE_LINE_COMMENT> >
+}
+
+TOKEN :
+{
+  < #BASE_CHAR : [
+    "\u0041" - "\u005a",
+    "\u0061" - "\u007a",
+    "\u00c0" - "\u00d6",
+    "\u00d8" - "\u00f6",
+    "\u00f8" - "\u00ff",
+    "\u0100" - "\u0131",
+    "\u0134" - "\u013e",
+    "\u0141" - "\u0148",
+    "\u014a" - "\u017e",
+    "\u0180" - "\u01c3",
+    "\u01cd" - "\u01f0",
+    "\u01f4" - "\u01f5",
+    "\u01fa" - "\u0217",
+    "\u0250" - "\u02a8",
+    "\u02bb" - "\u02c1",
+    "\u0386",
+    "\u0388" - "\u038a",
+    "\u038c",
+    "\u038e" - "\u03a1",
+    "\u03a3" - "\u03ce",
+    "\u03d0" - "\u03d6",
+    "\u03da",
+    "\u03dc",
+    "\u03de",
+    "\u03e0",
+    "\u03e2" - "\u03f3",
+    "\u0401" - "\u040c",
+    "\u040e" - "\u044f",
+    "\u0451" - "\u045c",
+    "\u045e" - "\u0481",
+    "\u0490" - "\u04c4",
+    "\u04c7" - "\u04c8",
+    "\u04cb" - "\u04cc",
+    "\u04d0" - "\u04eb",
+    "\u04ee" - "\u04f5",
+    "\u04f8" - "\u04f9",
+    "\u0531" - "\u0556",
+    "\u0559",
+    "\u0561" - "\u0586",
+    "\u05d0" - "\u05ea",
+    "\u05f0" - "\u05f2",
+    "\u0621" - "\u063a",
+    "\u0641" - "\u064a",
+    "\u0671" - "\u06b7",
+    "\u06ba" - "\u06be",
+    "\u06c0" - "\u06ce",
+    "\u06d0" - "\u06d3",
+    "\u06d5",
+    "\u06e5" - "\u06e6",
+    "\u0905" - "\u0939",
+    "\u093d",
+    "\u0958" - "\u0961",
+    "\u0985" - "\u098c",
+    "\u098f" - "\u0990",
+    "\u0993" - "\u09a8",
+    "\u09aa" - "\u09b0",
+    "\u09b2",
+    "\u09b6" - "\u09b9",
+    "\u09dc" - "\u09dd",
+    "\u09df" - "\u09e1",
+    "\u09f0" - "\u09f1",
+    "\u0a05" - "\u0a0a",
+    "\u0a0f" - "\u0a10",
+    "\u0a13" - "\u0a28",
+    "\u0a2a" - "\u0a30",
+    "\u0a32" - "\u0a33",
+    "\u0a35" - "\u0a36",
+    "\u0a38" - "\u0a39",
+    "\u0a59" - "\u0a5c",
+    "\u0a5e",
+    "\u0a72" - "\u0a74",
+    "\u0a85" - "\u0a8b",
+    "\u0a8d",
+    "\u0a8f" - "\u0a91",
+    "\u0a93" - "\u0aa8",
+    "\u0aaa" - "\u0ab0",
+    "\u0ab2" - "\u0ab3",
+    "\u0ab5" - "\u0ab9",
+    "\u0abd",
+    "\u0ae0",
+    "\u0b05" - "\u0b0c",
+    "\u0b0f" - "\u0b10",
+    "\u0b13" - "\u0b28",
+    "\u0b2a" - "\u0b30",
+    "\u0b32" - "\u0b33",
+    "\u0b36" - "\u0b39",
+    "\u0b3d",
+    "\u0b5c" - "\u0b5d",
+    "\u0b5f" - "\u0b61",
+    "\u0b85" - "\u0b8a",
+    "\u0b8e" - "\u0b90",
+    "\u0b92" - "\u0b95",
+    "\u0b99" - "\u0b9a",
+    "\u0b9c",
+    "\u0b9e" - "\u0b9f",
+    "\u0ba3" - "\u0ba4",
+    "\u0ba8" - "\u0baa",
+    "\u0bae" - "\u0bb5",
+    "\u0bb7" - "\u0bb9",
+    "\u0c05" - "\u0c0c",
+    "\u0c0e" - "\u0c10",
+    "\u0c12" - "\u0c28",
+    "\u0c2a" - "\u0c33",
+    "\u0c35" - "\u0c39",
+    "\u0c60" - "\u0c61",
+    "\u0c85" - "\u0c8c",
+    "\u0c8e" - "\u0c90",
+    "\u0c92" - "\u0ca8",
+    "\u0caa" - "\u0cb3",
+    "\u0cb5" - "\u0cb9",
+    "\u0cde",
+    "\u0ce0" - "\u0ce1",
+    "\u0d05" - "\u0d0c",
+    "\u0d0e" - "\u0d10",
+    "\u0d12" - "\u0d28",
+    "\u0d2a" - "\u0d39",
+    "\u0d60" - "\u0d61",
+    "\u0e01" - "\u0e2e",
+    "\u0e30",
+    "\u0e32" - "\u0e33",
+    "\u0e40" - "\u0e45",
+    "\u0e81" - "\u0e82",
+    "\u0e84",
+    "\u0e87" - "\u0e88",
+    "\u0e8a",
+    "\u0e8d",
+    "\u0e94" - "\u0e97",
+    "\u0e99" - "\u0e9f",
+    "\u0ea1" - "\u0ea3",
+    "\u0ea5",
+    "\u0ea7",
+    "\u0eaa" - "\u0eab",
+    "\u0ead" - "\u0eae",
+    "\u0eb0",
+    "\u0eb2" - "\u0eb3",
+    "\u0ebd",
+    "\u0ec0" - "\u0ec4",
+    "\u0f40" - "\u0f47",
+    "\u0f49" - "\u0f69",
+    "\u10a0" - "\u10c5",
+    "\u10d0" - "\u10f6",
+    "\u1100",
+    "\u1102" - "\u1103",
+    "\u1105" - "\u1107",
+    "\u1109",
+    "\u110b" - "\u110c",
+    "\u110e" - "\u1112",
+    "\u113c",
+    "\u113e",
+    "\u1140",
+    "\u114c",
+    "\u114e",
+    "\u1150",
+    "\u1154" - "\u1155",
+    "\u1159",
+    "\u115f" - "\u1161",
+    "\u1163",
+    "\u1165",
+    "\u1167",
+    "\u1169",
+    "\u116d" - "\u116e",
+    "\u1172" - "\u1173",
+    "\u1175",
+    "\u119e",
+    "\u11a8",
+    "\u11ab",
+    "\u11ae" - "\u11af",
+    "\u11b7" - "\u11b8",
+    "\u11ba",
+    "\u11bc" - "\u11c2",
+    "\u11eb",
+    "\u11f0",
+    "\u11f9",
+    "\u1e00" - "\u1e9b",
+    "\u1ea0" - "\u1ef9",
+    "\u1f00" - "\u1f15",
+    "\u1f18" - "\u1f1d",
+    "\u1f20" - "\u1f45",
+    "\u1f48" - "\u1f4d",
+    "\u1f50" - "\u1f57",
+    "\u1f59",
+    "\u1f5b",
+    "\u1f5d",
+    "\u1f5f" - "\u1f7d",
+    "\u1f80" - "\u1fb4",
+    "\u1fb6" - "\u1fbc",
+    "\u1fbe",
+    "\u1fc2" - "\u1fc4",
+    "\u1fc6" - "\u1fcc",
+    "\u1fd0" - "\u1fd3",
+    "\u1fd6" - "\u1fdb",
+    "\u1fe0" - "\u1fec",
+    "\u1ff2" - "\u1ff4",
+    "\u1ff6" - "\u1ffc",
+    "\u2126",
+    "\u212a" - "\u212b",
+    "\u212e",
+    "\u2180" - "\u2182",
+    "\u3041" - "\u3094",
+    "\u30a1" - "\u30fa",
+    "\u3105" - "\u312c",
+    "\uac00" - "\ud7a3"
+    ] >
+  | < #IDEOGRAPHIC : [
+    "\u4e00" - "\u9fa5",
+    "\u3007",
+    "\u3021" - "\u3029"
+    ] >
+  | < #LETTER : (<BASE_CHAR> | <IDEOGRAPHIC>) >
+  | < #COMBINING_CHAR : [
+    "\u0300" - "\u0345",
+    "\u0360" - "\u0361",
+    "\u0483" - "\u0486",
+    "\u0591" - "\u05a1",
+    "\u05a3" - "\u05b9",
+    "\u05bb" - "\u05bd",
+    "\u05bf",
+    "\u05c1" - "\u05c2",
+    "\u05c4",
+    "\u064b" - "\u0652",
+    "\u0670",
+    "\u06d6" - "\u06dc",
+    "\u06dd" - "\u06df",
+    "\u06e0" - "\u06e4",
+    "\u06e7" - "\u06e8",
+    "\u06ea" - "\u06ed",
+    "\u0901" - "\u0903",
+    "\u093c",
+    "\u093e" - "\u094c",
+    "\u094d",
+    "\u0951" - "\u0954",
+    "\u0962" - "\u0963",
+    "\u0981" - "\u0983",
+    "\u09bc",
+    "\u09be",
+    "\u09bf",
+    "\u09c0" - "\u09c4",
+    "\u09c7" - "\u09c8",
+    "\u09cb" - "\u09cd",
+    "\u09d7",
+    "\u09e2" - "\u09e3",
+    "\u0a02",
+    "\u0a3c",
+    "\u0a3e",
+    "\u0a3f",
+    "\u0a40" - "\u0a42",
+    "\u0a47" - "\u0a48",
+    "\u0a4b" - "\u0a4d",
+    "\u0a70" - "\u0a71",
+    "\u0a81" - "\u0a83",
+    "\u0abc",
+    "\u0abe" - "\u0ac5",
+    "\u0ac7" - "\u0ac9",
+    "\u0acb" - "\u0acd",
+    "\u0b01" - "\u0b03",
+    "\u0b3c",
+    "\u0b3e" - "\u0b43",
+    "\u0b47" - "\u0b48",
+    "\u0b4b" - "\u0b4d",
+    "\u0b56" - "\u0b57",
+    "\u0b82" - "\u0b83",
+    "\u0bbe" - "\u0bc2",
+    "\u0bc6" - "\u0bc8",
+    "\u0bca" - "\u0bcd",
+    "\u0bd7",
+    "\u0c01" - "\u0c03",
+    "\u0c3e" - "\u0c44",
+    "\u0c46" - "\u0c48",
+    "\u0c4a" - "\u0c4d",
+    "\u0c55" - "\u0c56",
+    "\u0c82" - "\u0c83",
+    "\u0cbe" - "\u0cc4",
+    "\u0cc6" - "\u0cc8",
+    "\u0cca" - "\u0ccd",
+    "\u0cd5" - "\u0cd6",
+    "\u0d02" - "\u0d03",
+    "\u0d3e" - "\u0d43",
+    "\u0d46" - "\u0d48",
+    "\u0d4a" - "\u0d4d",
+    "\u0d57",
+    "\u0e31",
+    "\u0e34" - "\u0e3a",
+    "\u0e47" - "\u0e4e",
+    "\u0eb1",
+    "\u0eb4" - "\u0eb9",
+    "\u0ebb" - "\u0ebc",
+    "\u0ec8" - "\u0ecd",
+    "\u0f18" - "\u0f19",
+    "\u0f35",
+    "\u0f37",
+    "\u0f39",
+    "\u0f3e",
+    "\u0f3f",
+    "\u0f71" - "\u0f84",
+    "\u0f86" - "\u0f8b",
+    "\u0f90" - "\u0f95",
+    "\u0f97",
+    "\u0f99" - "\u0fad",
+    "\u0fb1" - "\u0fb7",
+    "\u0fb9",
+    "\u20d0" - "\u20dc",
+    "\u20e1",
+    "\u302a" - "\u302f",
+    "\u3099",
+    "\u309a"
+    ] >
+  | < #DIGIT : [
+    "\u0030" - "\u0039",
+    "\u0660" - "\u0669",
+    "\u06f0" - "\u06f9",
+    "\u0966" - "\u096f",
+    "\u09e6" - "\u09ef",
+    "\u0a66" - "\u0a6f",
+    "\u0ae6" - "\u0aef",
+    "\u0b66" - "\u0b6f",
+    "\u0be7" - "\u0bef",
+    "\u0c66" - "\u0c6f",
+    "\u0ce6" - "\u0cef",
+    "\u0d66" - "\u0d6f",
+    "\u0e50" - "\u0e59",
+    "\u0ed0" - "\u0ed9",
+    "\u0f20" - "\u0f29"
+    ] >
+  | < #EXTENDER : [
+    "\u00b7",
+    "\u02d0",
+    "\u02d1",
+    "\u0387",
+    "\u0640",
+    "\u0e46",
+    "\u0ec6",
+    "\u3005",
+    "\u3031" - "\u3035",
+    "\u309d" - "\u309e",
+    "\u30fc" - "\u30fe"
+    ] >
+  | < #NMSTART : (<LETTER> | "_") >
+  | < #NMCHAR : (<LETTER> | <COMBINING_CHAR> | <EXTENDER> | <DIGIT> | "." | "-" | "_") >
+  | < #NCNAME: <NMSTART> (<NMCHAR>)* >
+}
+
+TOKEN :
+{
+  < IDENTIFIER: <NCNAME> >
+  | < ESCAPED_IDENTIFIER: "\\" <NCNAME> >
+  | < PREFIX_STAR: <NCNAME> ":*" >
+  | < PREFIXED_NAME: <NCNAME> ":" <NCNAME> >
+  | < LITERAL : ("\"" (~["\u0000", "\""])* "\"")
+                | ("'" (~["\u0000", "'"])* "'")
+                | ("\"\"\"" (~["\""]
+                             | ("\"" ~["\""])
+                             | ("\"\"" ~["\""]))* "\"\"\"")
+                | ("'''" (~["'"]
+                             | ("'" ~["'"])
+                             | ("''" ~["'"]))* "'''") >
+  | < FANNOTATE : ">>" >
+}
+
+/* This avoids lexical errors from JavaCC. */
+<*>
+TOKEN :
+{
+  < ILLEGAL_CHAR : [ "\u0000" - "\u0008", "\u000b" - "\uffff" ] >
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntaxConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntaxConstants.java
new file mode 100644
index 0000000..0872c13
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntaxConstants.java
@@ -0,0 +1,125 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* Generated By:JavaCC: Do not edit this line. CompactSyntaxConstants.java */
+package com.sun.xml.internal.rngom.parse.compact;
+
+public interface CompactSyntaxConstants {
+
+  int EOF = 0;
+  int NEWLINE = 37;
+  int NOT_NEWLINE = 38;
+  int WS = 39;
+  int DOCUMENTATION = 40;
+  int DOCUMENTATION_CONTINUE = 41;
+  int SINGLE_LINE_COMMENT = 42;
+  int DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT = 43;
+  int SINGLE_LINE_COMMENT_CONTINUE = 44;
+  int BASE_CHAR = 45;
+  int IDEOGRAPHIC = 46;
+  int LETTER = 47;
+  int COMBINING_CHAR = 48;
+  int DIGIT = 49;
+  int EXTENDER = 50;
+  int NMSTART = 51;
+  int NMCHAR = 52;
+  int NCNAME = 53;
+  int IDENTIFIER = 54;
+  int ESCAPED_IDENTIFIER = 55;
+  int PREFIX_STAR = 56;
+  int PREFIXED_NAME = 57;
+  int LITERAL = 58;
+  int FANNOTATE = 59;
+  int ILLEGAL_CHAR = 60;
+
+  int DEFAULT = 0;
+  int AFTER_SINGLE_LINE_COMMENT = 1;
+  int AFTER_DOCUMENTATION = 2;
+
+  String[] tokenImage = {
+    "<EOF>",
+    "\"[\"",
+    "\"=\"",
+    "\"&=\"",
+    "\"|=\"",
+    "\"start\"",
+    "\"div\"",
+    "\"include\"",
+    "\"~\"",
+    "\"]\"",
+    "\"grammar\"",
+    "\"{\"",
+    "\"}\"",
+    "\"namespace\"",
+    "\"default\"",
+    "\"inherit\"",
+    "\"datatypes\"",
+    "\"empty\"",
+    "\"text\"",
+    "\"notAllowed\"",
+    "\"|\"",
+    "\"&\"",
+    "\",\"",
+    "\"+\"",
+    "\"?\"",
+    "\"*\"",
+    "\"element\"",
+    "\"attribute\"",
+    "\"(\"",
+    "\")\"",
+    "\"-\"",
+    "\"list\"",
+    "\"mixed\"",
+    "\"external\"",
+    "\"parent\"",
+    "\"string\"",
+    "\"token\"",
+    "<NEWLINE>",
+    "<NOT_NEWLINE>",
+    "<WS>",
+    "<DOCUMENTATION>",
+    "<DOCUMENTATION_CONTINUE>",
+    "<SINGLE_LINE_COMMENT>",
+    "<DOCUMENTATION_AFTER_SINGLE_LINE_COMMENT>",
+    "<SINGLE_LINE_COMMENT_CONTINUE>",
+    "<BASE_CHAR>",
+    "<IDEOGRAPHIC>",
+    "<LETTER>",
+    "<COMBINING_CHAR>",
+    "<DIGIT>",
+    "<EXTENDER>",
+    "<NMSTART>",
+    "<NMCHAR>",
+    "<NCNAME>",
+    "<IDENTIFIER>",
+    "<ESCAPED_IDENTIFIER>",
+    "<PREFIX_STAR>",
+    "<PREFIXED_NAME>",
+    "<LITERAL>",
+    "\">>\"",
+    "<ILLEGAL_CHAR>",
+  };
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntaxTokenManager.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntaxTokenManager.java
new file mode 100644
index 0000000..963b0cd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/CompactSyntaxTokenManager.java
@@ -0,0 +1,1835 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* Generated By:JavaCC: Do not edit this line. CompactSyntaxTokenManager.java */
+package com.sun.xml.internal.rngom.parse.compact;
+import java.io.Reader;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.Arrays;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.util.List;
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Div;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.builder.GrammarSection;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.Context;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.LocatorImpl;
+import com.sun.xml.internal.rngom.util.Localizer;
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+
+public class CompactSyntaxTokenManager implements CompactSyntaxConstants
+{
+  public  java.io.PrintStream debugStream = System.out;
+  public  void setDebugStream(java.io.PrintStream ds) { debugStream = ds; }
+private final int jjStopStringLiteralDfa_0(int pos, long active0)
+{
+   switch (pos)
+   {
+      case 0:
+         if ((active0 & 0x1f8c0fe4e0L) != 0L)
+         {
+            jjmatchedKind = 54;
+            return 43;
+         }
+         if ((active0 & 0x800000000000000L) != 0L)
+         {
+            jjmatchedKind = 60;
+            return -1;
+         }
+         return -1;
+      case 1:
+         if ((active0 & 0x1f8c0fe4e0L) != 0L)
+         {
+            jjmatchedKind = 54;
+            jjmatchedPos = 1;
+            return 43;
+         }
+         if ((active0 & 0x800000000000000L) != 0L)
+         {
+            if (jjmatchedPos == 0)
+            {
+               jjmatchedKind = 60;
+               jjmatchedPos = 0;
+            }
+            return -1;
+         }
+         return -1;
+      case 2:
+         if ((active0 & 0x1f8c0fe4a0L) != 0L)
+         {
+            jjmatchedKind = 54;
+            jjmatchedPos = 2;
+            return 43;
+         }
+         if ((active0 & 0x40L) != 0L)
+            return 43;
+         return -1;
+      case 3:
+         if ((active0 & 0x1f0c0be4a0L) != 0L)
+         {
+            jjmatchedKind = 54;
+            jjmatchedPos = 3;
+            return 43;
+         }
+         if ((active0 & 0x80040000L) != 0L)
+            return 43;
+         return -1;
+      case 4:
+         if ((active0 & 0xe0c09e480L) != 0L)
+         {
+            jjmatchedKind = 54;
+            jjmatchedPos = 4;
+            return 43;
+         }
+         if ((active0 & 0x1100020020L) != 0L)
+            return 43;
+         return -1;
+      case 5:
+         if ((active0 & 0x20c09e480L) != 0L)
+         {
+            jjmatchedKind = 54;
+            jjmatchedPos = 5;
+            return 43;
+         }
+         if ((active0 & 0xc00000000L) != 0L)
+            return 43;
+         return -1;
+      case 6:
+         if ((active0 & 0x208092000L) != 0L)
+         {
+            jjmatchedKind = 54;
+            jjmatchedPos = 6;
+            return 43;
+         }
+         if ((active0 & 0x400c480L) != 0L)
+            return 43;
+         return -1;
+      case 7:
+         if ((active0 & 0x8092000L) != 0L)
+         {
+            jjmatchedKind = 54;
+            jjmatchedPos = 7;
+            return 43;
+         }
+         if ((active0 & 0x200000000L) != 0L)
+            return 43;
+         return -1;
+      case 8:
+         if ((active0 & 0x80000L) != 0L)
+         {
+            jjmatchedKind = 54;
+            jjmatchedPos = 8;
+            return 43;
+         }
+         if ((active0 & 0x8012000L) != 0L)
+            return 43;
+         return -1;
+      default :
+         return -1;
+   }
+}
+private final int jjStartNfa_0(int pos, long active0)
+{
+   return jjMoveNfa_0(jjStopStringLiteralDfa_0(pos, active0), pos + 1);
+}
+private final int jjStopAtPos(int pos, int kind)
+{
+   jjmatchedKind = kind;
+   jjmatchedPos = pos;
+   return pos + 1;
+}
+private final int jjStartNfaWithStates_0(int pos, int kind, int state)
+{
+   jjmatchedKind = kind;
+   jjmatchedPos = pos;
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) { return pos + 1; }
+   return jjMoveNfa_0(state, pos + 1);
+}
+private final int jjMoveStringLiteralDfa0_0()
+{
+   switch(curChar)
+   {
+      case 38:
+         jjmatchedKind = 21;
+         return jjMoveStringLiteralDfa1_0(0x8L);
+      case 40:
+         return jjStopAtPos(0, 28);
+      case 41:
+         return jjStopAtPos(0, 29);
+      case 42:
+         return jjStopAtPos(0, 25);
+      case 43:
+         return jjStopAtPos(0, 23);
+      case 44:
+         return jjStopAtPos(0, 22);
+      case 45:
+         return jjStopAtPos(0, 30);
+      case 61:
+         return jjStopAtPos(0, 2);
+      case 62:
+         return jjMoveStringLiteralDfa1_0(0x800000000000000L);
+      case 63:
+         return jjStopAtPos(0, 24);
+      case 91:
+         return jjStopAtPos(0, 1);
+      case 93:
+         return jjStopAtPos(0, 9);
+      case 97:
+         return jjMoveStringLiteralDfa1_0(0x8000000L);
+      case 100:
+         return jjMoveStringLiteralDfa1_0(0x14040L);
+      case 101:
+         return jjMoveStringLiteralDfa1_0(0x204020000L);
+      case 103:
+         return jjMoveStringLiteralDfa1_0(0x400L);
+      case 105:
+         return jjMoveStringLiteralDfa1_0(0x8080L);
+      case 108:
+         return jjMoveStringLiteralDfa1_0(0x80000000L);
+      case 109:
+         return jjMoveStringLiteralDfa1_0(0x100000000L);
+      case 110:
+         return jjMoveStringLiteralDfa1_0(0x82000L);
+      case 112:
+         return jjMoveStringLiteralDfa1_0(0x400000000L);
+      case 115:
+         return jjMoveStringLiteralDfa1_0(0x800000020L);
+      case 116:
+         return jjMoveStringLiteralDfa1_0(0x1000040000L);
+      case 123:
+         return jjStopAtPos(0, 11);
+      case 124:
+         jjmatchedKind = 20;
+         return jjMoveStringLiteralDfa1_0(0x10L);
+      case 125:
+         return jjStopAtPos(0, 12);
+      case 126:
+         return jjStopAtPos(0, 8);
+      default :
+         return jjMoveNfa_0(3, 0);
+   }
+}
+private final int jjMoveStringLiteralDfa1_0(long active0)
+{
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(0, active0);
+      return 1;
+   }
+   switch(curChar)
+   {
+      case 61:
+         if ((active0 & 0x8L) != 0L)
+            return jjStopAtPos(1, 3);
+         else if ((active0 & 0x10L) != 0L)
+            return jjStopAtPos(1, 4);
+         break;
+      case 62:
+         if ((active0 & 0x800000000000000L) != 0L)
+            return jjStopAtPos(1, 59);
+         break;
+      case 97:
+         return jjMoveStringLiteralDfa2_0(active0, 0x400012000L);
+      case 101:
+         return jjMoveStringLiteralDfa2_0(active0, 0x44000L);
+      case 105:
+         return jjMoveStringLiteralDfa2_0(active0, 0x180000040L);
+      case 108:
+         return jjMoveStringLiteralDfa2_0(active0, 0x4000000L);
+      case 109:
+         return jjMoveStringLiteralDfa2_0(active0, 0x20000L);
+      case 110:
+         return jjMoveStringLiteralDfa2_0(active0, 0x8080L);
+      case 111:
+         return jjMoveStringLiteralDfa2_0(active0, 0x1000080000L);
+      case 114:
+         return jjMoveStringLiteralDfa2_0(active0, 0x400L);
+      case 116:
+         return jjMoveStringLiteralDfa2_0(active0, 0x808000020L);
+      case 120:
+         return jjMoveStringLiteralDfa2_0(active0, 0x200000000L);
+      default :
+         break;
+   }
+   return jjStartNfa_0(0, active0);
+}
+private final int jjMoveStringLiteralDfa2_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return jjStartNfa_0(0, old0);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(1, active0);
+      return 2;
+   }
+   switch(curChar)
+   {
+      case 97:
+         return jjMoveStringLiteralDfa3_0(active0, 0x420L);
+      case 99:
+         return jjMoveStringLiteralDfa3_0(active0, 0x80L);
+      case 101:
+         return jjMoveStringLiteralDfa3_0(active0, 0x4000000L);
+      case 102:
+         return jjMoveStringLiteralDfa3_0(active0, 0x4000L);
+      case 104:
+         return jjMoveStringLiteralDfa3_0(active0, 0x8000L);
+      case 107:
+         return jjMoveStringLiteralDfa3_0(active0, 0x1000000000L);
+      case 109:
+         return jjMoveStringLiteralDfa3_0(active0, 0x2000L);
+      case 112:
+         return jjMoveStringLiteralDfa3_0(active0, 0x20000L);
+      case 114:
+         return jjMoveStringLiteralDfa3_0(active0, 0xc00000000L);
+      case 115:
+         return jjMoveStringLiteralDfa3_0(active0, 0x80000000L);
+      case 116:
+         return jjMoveStringLiteralDfa3_0(active0, 0x208090000L);
+      case 118:
+         if ((active0 & 0x40L) != 0L)
+            return jjStartNfaWithStates_0(2, 6, 43);
+         break;
+      case 120:
+         return jjMoveStringLiteralDfa3_0(active0, 0x100040000L);
+      default :
+         break;
+   }
+   return jjStartNfa_0(1, active0);
+}
+private final int jjMoveStringLiteralDfa3_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return jjStartNfa_0(1, old0);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(2, active0);
+      return 3;
+   }
+   switch(curChar)
+   {
+      case 65:
+         return jjMoveStringLiteralDfa4_0(active0, 0x80000L);
+      case 97:
+         return jjMoveStringLiteralDfa4_0(active0, 0x14000L);
+      case 101:
+         return jjMoveStringLiteralDfa4_0(active0, 0x170000a000L);
+      case 105:
+         return jjMoveStringLiteralDfa4_0(active0, 0x800000000L);
+      case 108:
+         return jjMoveStringLiteralDfa4_0(active0, 0x80L);
+      case 109:
+         return jjMoveStringLiteralDfa4_0(active0, 0x4000400L);
+      case 114:
+         return jjMoveStringLiteralDfa4_0(active0, 0x8000020L);
+      case 116:
+         if ((active0 & 0x40000L) != 0L)
+            return jjStartNfaWithStates_0(3, 18, 43);
+         else if ((active0 & 0x80000000L) != 0L)
+            return jjStartNfaWithStates_0(3, 31, 43);
+         return jjMoveStringLiteralDfa4_0(active0, 0x20000L);
+      default :
+         break;
+   }
+   return jjStartNfa_0(2, active0);
+}
+private final int jjMoveStringLiteralDfa4_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return jjStartNfa_0(2, old0);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(3, active0);
+      return 4;
+   }
+   switch(curChar)
+   {
+      case 100:
+         if ((active0 & 0x100000000L) != 0L)
+            return jjStartNfaWithStates_0(4, 32, 43);
+         break;
+      case 101:
+         return jjMoveStringLiteralDfa5_0(active0, 0x4000000L);
+      case 105:
+         return jjMoveStringLiteralDfa5_0(active0, 0x8000000L);
+      case 108:
+         return jjMoveStringLiteralDfa5_0(active0, 0x80000L);
+      case 109:
+         return jjMoveStringLiteralDfa5_0(active0, 0x400L);
+      case 110:
+         if ((active0 & 0x1000000000L) != 0L)
+            return jjStartNfaWithStates_0(4, 36, 43);
+         return jjMoveStringLiteralDfa5_0(active0, 0xc00000000L);
+      case 114:
+         return jjMoveStringLiteralDfa5_0(active0, 0x200008000L);
+      case 115:
+         return jjMoveStringLiteralDfa5_0(active0, 0x2000L);
+      case 116:
+         if ((active0 & 0x20L) != 0L)
+            return jjStartNfaWithStates_0(4, 5, 43);
+         return jjMoveStringLiteralDfa5_0(active0, 0x10000L);
+      case 117:
+         return jjMoveStringLiteralDfa5_0(active0, 0x4080L);
+      case 121:
+         if ((active0 & 0x20000L) != 0L)
+            return jjStartNfaWithStates_0(4, 17, 43);
+         break;
+      default :
+         break;
+   }
+   return jjStartNfa_0(3, active0);
+}
+private final int jjMoveStringLiteralDfa5_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return jjStartNfa_0(3, old0);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(4, active0);
+      return 5;
+   }
+   switch(curChar)
+   {
+      case 97:
+         return jjMoveStringLiteralDfa6_0(active0, 0x400L);
+      case 98:
+         return jjMoveStringLiteralDfa6_0(active0, 0x8000000L);
+      case 100:
+         return jjMoveStringLiteralDfa6_0(active0, 0x80L);
+      case 103:
+         if ((active0 & 0x800000000L) != 0L)
+            return jjStartNfaWithStates_0(5, 35, 43);
+         break;
+      case 105:
+         return jjMoveStringLiteralDfa6_0(active0, 0x8000L);
+      case 108:
+         return jjMoveStringLiteralDfa6_0(active0, 0x84000L);
+      case 110:
+         return jjMoveStringLiteralDfa6_0(active0, 0x204000000L);
+      case 112:
+         return jjMoveStringLiteralDfa6_0(active0, 0x2000L);
+      case 116:
+         if ((active0 & 0x400000000L) != 0L)
+            return jjStartNfaWithStates_0(5, 34, 43);
+         break;
+      case 121:
+         return jjMoveStringLiteralDfa6_0(active0, 0x10000L);
+      default :
+         break;
+   }
+   return jjStartNfa_0(4, active0);
+}
+private final int jjMoveStringLiteralDfa6_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return jjStartNfa_0(4, old0);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(5, active0);
+      return 6;
+   }
+   switch(curChar)
+   {
+      case 97:
+         return jjMoveStringLiteralDfa7_0(active0, 0x200002000L);
+      case 101:
+         if ((active0 & 0x80L) != 0L)
+            return jjStartNfaWithStates_0(6, 7, 43);
+         break;
+      case 111:
+         return jjMoveStringLiteralDfa7_0(active0, 0x80000L);
+      case 112:
+         return jjMoveStringLiteralDfa7_0(active0, 0x10000L);
+      case 114:
+         if ((active0 & 0x400L) != 0L)
+            return jjStartNfaWithStates_0(6, 10, 43);
+         break;
+      case 116:
+         if ((active0 & 0x4000L) != 0L)
+            return jjStartNfaWithStates_0(6, 14, 43);
+         else if ((active0 & 0x8000L) != 0L)
+            return jjStartNfaWithStates_0(6, 15, 43);
+         else if ((active0 & 0x4000000L) != 0L)
+            return jjStartNfaWithStates_0(6, 26, 43);
+         break;
+      case 117:
+         return jjMoveStringLiteralDfa7_0(active0, 0x8000000L);
+      default :
+         break;
+   }
+   return jjStartNfa_0(5, active0);
+}
+private final int jjMoveStringLiteralDfa7_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return jjStartNfa_0(5, old0);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(6, active0);
+      return 7;
+   }
+   switch(curChar)
+   {
+      case 99:
+         return jjMoveStringLiteralDfa8_0(active0, 0x2000L);
+      case 101:
+         return jjMoveStringLiteralDfa8_0(active0, 0x10000L);
+      case 108:
+         if ((active0 & 0x200000000L) != 0L)
+            return jjStartNfaWithStates_0(7, 33, 43);
+         break;
+      case 116:
+         return jjMoveStringLiteralDfa8_0(active0, 0x8000000L);
+      case 119:
+         return jjMoveStringLiteralDfa8_0(active0, 0x80000L);
+      default :
+         break;
+   }
+   return jjStartNfa_0(6, active0);
+}
+private final int jjMoveStringLiteralDfa8_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return jjStartNfa_0(6, old0);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(7, active0);
+      return 8;
+   }
+   switch(curChar)
+   {
+      case 101:
+         if ((active0 & 0x2000L) != 0L)
+            return jjStartNfaWithStates_0(8, 13, 43);
+         else if ((active0 & 0x8000000L) != 0L)
+            return jjStartNfaWithStates_0(8, 27, 43);
+         return jjMoveStringLiteralDfa9_0(active0, 0x80000L);
+      case 115:
+         if ((active0 & 0x10000L) != 0L)
+            return jjStartNfaWithStates_0(8, 16, 43);
+         break;
+      default :
+         break;
+   }
+   return jjStartNfa_0(7, active0);
+}
+private final int jjMoveStringLiteralDfa9_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return jjStartNfa_0(7, old0);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      jjStopStringLiteralDfa_0(8, active0);
+      return 9;
+   }
+   switch(curChar)
+   {
+      case 100:
+         if ((active0 & 0x80000L) != 0L)
+            return jjStartNfaWithStates_0(9, 19, 43);
+         break;
+      default :
+         break;
+   }
+   return jjStartNfa_0(8, active0);
+}
+private final void jjCheckNAdd(int state)
+{
+   if (jjrounds[state] != jjround)
+   {
+      jjstateSet[jjnewStateCnt++] = state;
+      jjrounds[state] = jjround;
+   }
+}
+private final void jjAddStates(int start, int end)
+{
+   do {
+      jjstateSet[jjnewStateCnt++] = jjnextStates[start];
+   } while (start++ != end);
+}
+private final void jjCheckNAddTwoStates(int state1, int state2)
+{
+   jjCheckNAdd(state1);
+   jjCheckNAdd(state2);
+}
+private final void jjCheckNAddStates(int start, int end)
+{
+   do {
+      jjCheckNAdd(jjnextStates[start]);
+   } while (start++ != end);
+}
+private final void jjCheckNAddStates(int start)
+{
+   jjCheckNAdd(jjnextStates[start]);
+   jjCheckNAdd(jjnextStates[start + 1]);
+}
+static final long[] jjbitVec0 = {
+   0xfffffffffffffffeL, 0xffffffffffffffffL, 0xffffffffffffffffL, 0xffffffffffffffffL
+};
+static final long[] jjbitVec2 = {
+   0x0L, 0x0L, 0xffffffffffffffffL, 0xffffffffffffffffL
+};
+static final long[] jjbitVec3 = {
+   0x0L, 0xffffffffffffc000L, 0xfffff0007fffffffL, 0x7fffffL
+};
+static final long[] jjbitVec4 = {
+   0x0L, 0x0L, 0x0L, 0xff7fffffff7fffffL
+};
+static final long[] jjbitVec5 = {
+   0x7ff3ffffffffffffL, 0x7ffffffffffffdfeL, 0xffffffffffffffffL, 0xfc31ffffffffe00fL
+};
+static final long[] jjbitVec6 = {
+   0xffffffL, 0xffffffffffff0000L, 0xf80001ffffffffffL, 0x3L
+};
+static final long[] jjbitVec7 = {
+   0x0L, 0x0L, 0xfffffffbffffd740L, 0xffffd547f7fffL
+};
+static final long[] jjbitVec8 = {
+   0xffffffffffffdffeL, 0xffffffffdffeffffL, 0xffffffffffff0003L, 0x33fcfffffff199fL
+};
+static final long[] jjbitVec9 = {
+   0xfffe000000000000L, 0xfffffffe027fffffL, 0x7fL, 0x707ffffff0000L
+};
+static final long[] jjbitVec10 = {
+   0x7fffffe00000000L, 0xfffe0000000007feL, 0x7cffffffffffffffL, 0x60002f7fffL
+};
+static final long[] jjbitVec11 = {
+   0x23ffffffffffffe0L, 0x3ff000000L, 0x3c5fdfffff99fe0L, 0x30003b0000000L
+};
+static final long[] jjbitVec12 = {
+   0x36dfdfffff987e0L, 0x1c00005e000000L, 0x23edfdfffffbafe0L, 0x100000000L
+};
+static final long[] jjbitVec13 = {
+   0x23cdfdfffff99fe0L, 0x3b0000000L, 0x3bfc718d63dc7e0L, 0x0L
+};
+static final long[] jjbitVec14 = {
+   0x3effdfffffddfe0L, 0x300000000L, 0x3effdfffffddfe0L, 0x340000000L
+};
+static final long[] jjbitVec15 = {
+   0x3fffdfffffddfe0L, 0x300000000L, 0x0L, 0x0L
+};
+static final long[] jjbitVec16 = {
+   0xd7ffffffffffeL, 0x3fL, 0x200d6caefef02596L, 0x1fL
+};
+static final long[] jjbitVec17 = {
+   0x0L, 0x3fffffffeffL, 0x0L, 0x0L
+};
+static final long[] jjbitVec18 = {
+   0x0L, 0x0L, 0xffffffff00000000L, 0x7fffffffff003fL
+};
+static final long[] jjbitVec19 = {
+   0x500000000007daedL, 0x2c62ab82315001L, 0xf580c90040000000L, 0x201080000000007L
+};
+static final long[] jjbitVec20 = {
+   0xffffffffffffffffL, 0xffffffffffffffffL, 0xffffffff0fffffffL, 0x3ffffffffffffffL
+};
+static final long[] jjbitVec21 = {
+   0xffffffff3f3fffffL, 0x3fffffffaaff3f3fL, 0x5fdfffffffffffffL, 0x1fdc1fff0fcf1fdcL
+};
+static final long[] jjbitVec22 = {
+   0x4c4000000000L, 0x0L, 0x7L, 0x0L
+};
+static final long[] jjbitVec23 = {
+   0x3fe00000080L, 0xfffffffffffffffeL, 0xfffffffe001fffffL, 0x7ffffffffffffffL
+};
+static final long[] jjbitVec24 = {
+   0x1fffffffffe0L, 0x0L, 0x0L, 0x0L
+};
+static final long[] jjbitVec25 = {
+   0xffffffffffffffffL, 0xffffffffffffffffL, 0x3fffffffffL, 0x0L
+};
+static final long[] jjbitVec26 = {
+   0xffffffffffffffffL, 0xffffffffffffffffL, 0xfffffffffL, 0x0L
+};
+static final long[] jjbitVec27 = {
+   0x0L, 0x0L, 0x80000000000000L, 0xff7fffffff7fffffL
+};
+static final long[] jjbitVec28 = {
+   0xffffffL, 0xffffffffffff0000L, 0xf80001ffffffffffL, 0x30003L
+};
+static final long[] jjbitVec29 = {
+   0xffffffffffffffffL, 0x30000003fL, 0xfffffffbffffd7c0L, 0xffffd547f7fffL
+};
+static final long[] jjbitVec30 = {
+   0xffffffffffffdffeL, 0xffffffffdffeffffL, 0xffffffffffff007bL, 0x33fcfffffff199fL
+};
+static final long[] jjbitVec31 = {
+   0xfffe000000000000L, 0xfffffffe027fffffL, 0xbbfffffbfffe007fL, 0x707ffffff0016L
+};
+static final long[] jjbitVec32 = {
+   0x7fffffe00000000L, 0xffff03ff0007ffffL, 0x7cffffffffffffffL, 0x3ff3dffffef7fffL
+};
+static final long[] jjbitVec33 = {
+   0xf3ffffffffffffeeL, 0xffcfff1e3fffL, 0xd3c5fdfffff99feeL, 0x3ffcfb080399fL
+};
+static final long[] jjbitVec34 = {
+   0xd36dfdfffff987e4L, 0x1fffc05e003987L, 0xf3edfdfffffbafeeL, 0xffc100003bbfL
+};
+static final long[] jjbitVec35 = {
+   0xf3cdfdfffff99feeL, 0xffc3b0c0398fL, 0xc3bfc718d63dc7ecL, 0xff8000803dc7L
+};
+static final long[] jjbitVec36 = {
+   0xc3effdfffffddfeeL, 0xffc300603ddfL, 0xc3effdfffffddfecL, 0xffc340603ddfL
+};
+static final long[] jjbitVec37 = {
+   0xc3fffdfffffddfecL, 0xffc300803dcfL, 0x0L, 0x0L
+};
+static final long[] jjbitVec38 = {
+   0x7ff7ffffffffffeL, 0x3ff7fffL, 0x3bff6caefef02596L, 0x3ff3f5fL
+};
+static final long[] jjbitVec39 = {
+   0xc2a003ff03000000L, 0xfffe03fffffffeffL, 0x2fe3ffffebf0fdfL, 0x0L
+};
+static final long[] jjbitVec40 = {
+   0x0L, 0x0L, 0x0L, 0x21fff0000L
+};
+static final long[] jjbitVec41 = {
+   0x3efffe000000a0L, 0xfffffffffffffffeL, 0xfffffffe661fffffL, 0x77ffffffffffffffL
+};
+private final int jjMoveNfa_0(int startState, int curPos)
+{
+   int[] nextStates;
+   int startsAt = 0;
+   jjnewStateCnt = 43;
+   int i = 1;
+   jjstateSet[0] = startState;
+   int j, kind = 0x7fffffff;
+   for (;;)
+   {
+      if (++jjround == 0x7fffffff)
+         ReInitRounds();
+      if (curChar < 64)
+      {
+         long l = 1L << curChar;
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 3:
+                  if ((0xfffffffffffff9ffL & l) != 0L)
+                  {
+                     if (kind > 60)
+                        kind = 60;
+                  }
+                  if ((0x100000601L & l) != 0L)
+                  {
+                     if (kind > 39)
+                        kind = 39;
+                     jjCheckNAdd(0);
+                  }
+                  else if (curChar == 39)
+                     jjstateSet[jjnewStateCnt++] = 31;
+                  else if (curChar == 34)
+                     jjstateSet[jjnewStateCnt++] = 22;
+                  else if (curChar == 35)
+                  {
+                     if (kind > 42)
+                        kind = 42;
+                     jjCheckNAdd(5);
+                  }
+                  if (curChar == 39)
+                     jjCheckNAddTwoStates(13, 14);
+                  else if (curChar == 34)
+                     jjCheckNAddTwoStates(10, 11);
+                  else if (curChar == 35)
+                     jjstateSet[jjnewStateCnt++] = 1;
+                  break;
+               case 43:
+                  if ((0x3ff600000000000L & l) != 0L)
+                     jjCheckNAddTwoStates(39, 40);
+                  else if (curChar == 58)
+                     jjstateSet[jjnewStateCnt++] = 41;
+                  if ((0x3ff600000000000L & l) != 0L)
+                     jjCheckNAddTwoStates(36, 38);
+                  else if (curChar == 58)
+                     jjstateSet[jjnewStateCnt++] = 37;
+                  if ((0x3ff600000000000L & l) != 0L)
+                  {
+                     if (kind > 54)
+                        kind = 54;
+                     jjCheckNAdd(35);
+                  }
+                  break;
+               case 0:
+                  if ((0x100000601L & l) == 0L)
+                     break;
+                  if (kind > 39)
+                     kind = 39;
+                  jjCheckNAdd(0);
+                  break;
+               case 1:
+                  if (curChar != 35)
+                     break;
+                  if (kind > 40)
+                     kind = 40;
+                  jjCheckNAdd(2);
+                  break;
+               case 2:
+                  if ((0xfffffffffffffbfeL & l) == 0L)
+                     break;
+                  if (kind > 40)
+                     kind = 40;
+                  jjCheckNAdd(2);
+                  break;
+               case 4:
+                  if (curChar != 35)
+                     break;
+                  if (kind > 42)
+                     kind = 42;
+                  jjCheckNAdd(5);
+                  break;
+               case 5:
+                  if ((0xfffffffffffffbfeL & l) == 0L)
+                     break;
+                  if (kind > 42)
+                     kind = 42;
+                  jjCheckNAdd(5);
+                  break;
+               case 8:
+                  if ((0x3ff600000000000L & l) == 0L)
+                     break;
+                  if (kind > 55)
+                     kind = 55;
+                  jjstateSet[jjnewStateCnt++] = 8;
+                  break;
+               case 9:
+                  if (curChar == 34)
+                     jjCheckNAddTwoStates(10, 11);
+                  break;
+               case 10:
+                  if ((0xfffffffbfffffffeL & l) != 0L)
+                     jjCheckNAddTwoStates(10, 11);
+                  break;
+               case 11:
+               case 20:
+                  if (curChar == 34 && kind > 58)
+                     kind = 58;
+                  break;
+               case 12:
+                  if (curChar == 39)
+                     jjCheckNAddTwoStates(13, 14);
+                  break;
+               case 13:
+                  if ((0xffffff7ffffffffeL & l) != 0L)
+                     jjCheckNAddTwoStates(13, 14);
+                  break;
+               case 14:
+               case 29:
+                  if (curChar == 39 && kind > 58)
+                     kind = 58;
+                  break;
+               case 15:
+                  if (curChar == 34)
+                     jjCheckNAddStates(0, 2);
+                  break;
+               case 16:
+                  if ((0xfffffffbffffffffL & l) != 0L)
+                     jjCheckNAddStates(0, 2);
+                  break;
+               case 17:
+               case 19:
+                  if (curChar == 34)
+                     jjCheckNAdd(16);
+                  break;
+               case 18:
+                  if (curChar == 34)
+                     jjAddStates(3, 4);
+                  break;
+               case 21:
+                  if (curChar == 34)
+                     jjstateSet[jjnewStateCnt++] = 20;
+                  break;
+               case 22:
+                  if (curChar == 34)
+                     jjstateSet[jjnewStateCnt++] = 15;
+                  break;
+               case 23:
+                  if (curChar == 34)
+                     jjstateSet[jjnewStateCnt++] = 22;
+                  break;
+               case 24:
+                  if (curChar == 39)
+                     jjCheckNAddStates(5, 7);
+                  break;
+               case 25:
+                  if ((0xffffff7fffffffffL & l) != 0L)
+                     jjCheckNAddStates(5, 7);
+                  break;
+               case 26:
+               case 28:
+                  if (curChar == 39)
+                     jjCheckNAdd(25);
+                  break;
+               case 27:
+                  if (curChar == 39)
+                     jjAddStates(8, 9);
+                  break;
+               case 30:
+                  if (curChar == 39)
+                     jjstateSet[jjnewStateCnt++] = 29;
+                  break;
+               case 31:
+                  if (curChar == 39)
+                     jjstateSet[jjnewStateCnt++] = 24;
+                  break;
+               case 32:
+                  if (curChar == 39)
+                     jjstateSet[jjnewStateCnt++] = 31;
+                  break;
+               case 33:
+                  if ((0xfffffffffffff9ffL & l) != 0L && kind > 60)
+                     kind = 60;
+                  break;
+               case 35:
+                  if ((0x3ff600000000000L & l) == 0L)
+                     break;
+                  if (kind > 54)
+                     kind = 54;
+                  jjCheckNAdd(35);
+                  break;
+               case 36:
+                  if ((0x3ff600000000000L & l) != 0L)
+                     jjCheckNAddTwoStates(36, 38);
+                  break;
+               case 37:
+                  if (curChar == 42 && kind > 56)
+                     kind = 56;
+                  break;
+               case 38:
+                  if (curChar == 58)
+                     jjstateSet[jjnewStateCnt++] = 37;
+                  break;
+               case 39:
+                  if ((0x3ff600000000000L & l) != 0L)
+                     jjCheckNAddTwoStates(39, 40);
+                  break;
+               case 40:
+                  if (curChar == 58)
+                     jjstateSet[jjnewStateCnt++] = 41;
+                  break;
+               case 42:
+                  if ((0x3ff600000000000L & l) == 0L)
+                     break;
+                  if (kind > 57)
+                     kind = 57;
+                  jjstateSet[jjnewStateCnt++] = 42;
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      else if (curChar < 128)
+      {
+         long l = 1L << (curChar & 077);
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 3:
+                  if (kind > 60)
+                     kind = 60;
+                  if ((0x7fffffe87fffffeL & l) != 0L)
+                  {
+                     if (kind > 54)
+                        kind = 54;
+                     jjCheckNAddStates(10, 14);
+                  }
+                  else if (curChar == 92)
+                     jjstateSet[jjnewStateCnt++] = 7;
+                  break;
+               case 43:
+                  if ((0x7fffffe87fffffeL & l) != 0L)
+                     jjCheckNAddTwoStates(39, 40);
+                  if ((0x7fffffe87fffffeL & l) != 0L)
+                     jjCheckNAddTwoStates(36, 38);
+                  if ((0x7fffffe87fffffeL & l) != 0L)
+                  {
+                     if (kind > 54)
+                        kind = 54;
+                     jjCheckNAdd(35);
+                  }
+                  break;
+               case 2:
+                  if (kind > 40)
+                     kind = 40;
+                  jjstateSet[jjnewStateCnt++] = 2;
+                  break;
+               case 5:
+                  if (kind > 42)
+                     kind = 42;
+                  jjstateSet[jjnewStateCnt++] = 5;
+                  break;
+               case 6:
+                  if (curChar == 92)
+                     jjstateSet[jjnewStateCnt++] = 7;
+                  break;
+               case 7:
+               case 8:
+                  if ((0x7fffffe87fffffeL & l) == 0L)
+                     break;
+                  if (kind > 55)
+                     kind = 55;
+                  jjCheckNAdd(8);
+                  break;
+               case 10:
+                  jjAddStates(15, 16);
+                  break;
+               case 13:
+                  jjAddStates(17, 18);
+                  break;
+               case 16:
+                  jjAddStates(0, 2);
+                  break;
+               case 25:
+                  jjAddStates(5, 7);
+                  break;
+               case 33:
+                  if (kind > 60)
+                     kind = 60;
+                  break;
+               case 34:
+                  if ((0x7fffffe87fffffeL & l) == 0L)
+                     break;
+                  if (kind > 54)
+                     kind = 54;
+                  jjCheckNAddStates(10, 14);
+                  break;
+               case 35:
+                  if ((0x7fffffe87fffffeL & l) == 0L)
+                     break;
+                  if (kind > 54)
+                     kind = 54;
+                  jjCheckNAdd(35);
+                  break;
+               case 36:
+                  if ((0x7fffffe87fffffeL & l) != 0L)
+                     jjCheckNAddTwoStates(36, 38);
+                  break;
+               case 39:
+                  if ((0x7fffffe87fffffeL & l) != 0L)
+                     jjCheckNAddTwoStates(39, 40);
+                  break;
+               case 41:
+               case 42:
+                  if ((0x7fffffe87fffffeL & l) == 0L)
+                     break;
+                  if (kind > 57)
+                     kind = 57;
+                  jjCheckNAdd(42);
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      else
+      {
+         int hiByte = (int)(curChar >> 8);
+         int i1 = hiByte >> 6;
+         long l1 = 1L << (hiByte & 077);
+         int i2 = (curChar & 0xff) >> 6;
+         long l2 = 1L << (curChar & 077);
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 3:
+                  if (jjCanMove_0(hiByte, i1, i2, l1, l2))
+                  {
+                     if (kind > 60)
+                        kind = 60;
+                  }
+                  if (jjCanMove_1(hiByte, i1, i2, l1, l2))
+                  {
+                     if (kind > 54)
+                        kind = 54;
+                     jjCheckNAddStates(10, 14);
+                  }
+                  break;
+               case 43:
+                  if (jjCanMove_2(hiByte, i1, i2, l1, l2))
+                  {
+                     if (kind > 54)
+                        kind = 54;
+                     jjCheckNAdd(35);
+                  }
+                  if (jjCanMove_2(hiByte, i1, i2, l1, l2))
+                     jjCheckNAddTwoStates(36, 38);
+                  if (jjCanMove_2(hiByte, i1, i2, l1, l2))
+                     jjCheckNAddTwoStates(39, 40);
+                  break;
+               case 2:
+                  if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 40)
+                     kind = 40;
+                  jjstateSet[jjnewStateCnt++] = 2;
+                  break;
+               case 5:
+                  if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 42)
+                     kind = 42;
+                  jjstateSet[jjnewStateCnt++] = 5;
+                  break;
+               case 7:
+                  if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 55)
+                     kind = 55;
+                  jjCheckNAdd(8);
+                  break;
+               case 8:
+                  if (!jjCanMove_2(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 55)
+                     kind = 55;
+                  jjCheckNAdd(8);
+                  break;
+               case 10:
+                  if (jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     jjAddStates(15, 16);
+                  break;
+               case 13:
+                  if (jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     jjAddStates(17, 18);
+                  break;
+               case 16:
+                  if (jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     jjAddStates(0, 2);
+                  break;
+               case 25:
+                  if (jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     jjAddStates(5, 7);
+                  break;
+               case 33:
+                  if (jjCanMove_0(hiByte, i1, i2, l1, l2) && kind > 60)
+                     kind = 60;
+                  break;
+               case 34:
+                  if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 54)
+                     kind = 54;
+                  jjCheckNAddStates(10, 14);
+                  break;
+               case 35:
+                  if (!jjCanMove_2(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 54)
+                     kind = 54;
+                  jjCheckNAdd(35);
+                  break;
+               case 36:
+                  if (jjCanMove_2(hiByte, i1, i2, l1, l2))
+                     jjCheckNAddTwoStates(36, 38);
+                  break;
+               case 39:
+                  if (jjCanMove_2(hiByte, i1, i2, l1, l2))
+                     jjCheckNAddTwoStates(39, 40);
+                  break;
+               case 41:
+                  if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 57)
+                     kind = 57;
+                  jjCheckNAdd(42);
+                  break;
+               case 42:
+                  if (!jjCanMove_2(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 57)
+                     kind = 57;
+                  jjCheckNAdd(42);
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      if (kind != 0x7fffffff)
+      {
+         jjmatchedKind = kind;
+         jjmatchedPos = curPos;
+         kind = 0x7fffffff;
+      }
+      ++curPos;
+      if ((i = jjnewStateCnt) == (startsAt = 43 - (jjnewStateCnt = startsAt)))
+         return curPos;
+      try { curChar = input_stream.readChar(); }
+      catch(java.io.IOException e) { return curPos; }
+   }
+}
+private final int jjMoveStringLiteralDfa0_1()
+{
+   return jjMoveNfa_1(1, 0);
+}
+private final int jjMoveNfa_1(int startState, int curPos)
+{
+   int[] nextStates;
+   int startsAt = 0;
+   jjnewStateCnt = 10;
+   int i = 1;
+   jjstateSet[0] = startState;
+   int j, kind = 0x7fffffff;
+   for (;;)
+   {
+      if (++jjround == 0x7fffffff)
+         ReInitRounds();
+      if (curChar < 64)
+      {
+         long l = 1L << curChar;
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 1:
+                  if ((0xfffffffffffff9ffL & l) != 0L)
+                  {
+                     if (kind > 60)
+                        kind = 60;
+                  }
+                  if ((0x100000601L & l) != 0L)
+                  {
+                     if (kind > 39)
+                        kind = 39;
+                     jjCheckNAdd(0);
+                  }
+                  if ((0x401L & l) != 0L)
+                     jjCheckNAddStates(19, 22);
+                  break;
+               case 0:
+                  if ((0x100000601L & l) == 0L)
+                     break;
+                  if (kind > 39)
+                     kind = 39;
+                  jjCheckNAdd(0);
+                  break;
+               case 2:
+                  if ((0x401L & l) != 0L)
+                     jjCheckNAddStates(19, 22);
+                  break;
+               case 3:
+                  if ((0x100000200L & l) != 0L)
+                     jjCheckNAddTwoStates(3, 6);
+                  break;
+               case 4:
+                  if (curChar != 35)
+                     break;
+                  if (kind > 43)
+                     kind = 43;
+                  jjCheckNAdd(5);
+                  break;
+               case 5:
+                  if ((0xfffffffffffffbfeL & l) == 0L)
+                     break;
+                  if (kind > 43)
+                     kind = 43;
+                  jjCheckNAdd(5);
+                  break;
+               case 6:
+                  if (curChar == 35)
+                     jjstateSet[jjnewStateCnt++] = 4;
+                  break;
+               case 7:
+                  if ((0x100000200L & l) != 0L)
+                     jjCheckNAddTwoStates(7, 8);
+                  break;
+               case 8:
+                  if (curChar != 35)
+                     break;
+                  if (kind > 44)
+                     kind = 44;
+                  jjCheckNAdd(9);
+                  break;
+               case 9:
+                  if ((0xfffffffffffffbfeL & l) == 0L)
+                     break;
+                  if (kind > 44)
+                     kind = 44;
+                  jjCheckNAdd(9);
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      else if (curChar < 128)
+      {
+         long l = 1L << (curChar & 077);
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 1:
+                  if (kind > 60)
+                     kind = 60;
+                  break;
+               case 5:
+                  if (kind > 43)
+                     kind = 43;
+                  jjstateSet[jjnewStateCnt++] = 5;
+                  break;
+               case 9:
+                  if (kind > 44)
+                     kind = 44;
+                  jjstateSet[jjnewStateCnt++] = 9;
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      else
+      {
+         int hiByte = (int)(curChar >> 8);
+         int i1 = hiByte >> 6;
+         long l1 = 1L << (hiByte & 077);
+         int i2 = (curChar & 0xff) >> 6;
+         long l2 = 1L << (curChar & 077);
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 1:
+                  if (jjCanMove_0(hiByte, i1, i2, l1, l2) && kind > 60)
+                     kind = 60;
+                  break;
+               case 5:
+                  if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 43)
+                     kind = 43;
+                  jjstateSet[jjnewStateCnt++] = 5;
+                  break;
+               case 9:
+                  if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 44)
+                     kind = 44;
+                  jjstateSet[jjnewStateCnt++] = 9;
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      if (kind != 0x7fffffff)
+      {
+         jjmatchedKind = kind;
+         jjmatchedPos = curPos;
+         kind = 0x7fffffff;
+      }
+      ++curPos;
+      if ((i = jjnewStateCnt) == (startsAt = 10 - (jjnewStateCnt = startsAt)))
+         return curPos;
+      try { curChar = input_stream.readChar(); }
+      catch(java.io.IOException e) { return curPos; }
+   }
+}
+private final int jjMoveStringLiteralDfa0_2()
+{
+   return jjMoveNfa_2(1, 0);
+}
+private final int jjMoveNfa_2(int startState, int curPos)
+{
+   int[] nextStates;
+   int startsAt = 0;
+   jjnewStateCnt = 7;
+   int i = 1;
+   jjstateSet[0] = startState;
+   int j, kind = 0x7fffffff;
+   for (;;)
+   {
+      if (++jjround == 0x7fffffff)
+         ReInitRounds();
+      if (curChar < 64)
+      {
+         long l = 1L << curChar;
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 1:
+                  if ((0xfffffffffffff9ffL & l) != 0L)
+                  {
+                     if (kind > 60)
+                        kind = 60;
+                  }
+                  if ((0x100000601L & l) != 0L)
+                  {
+                     if (kind > 39)
+                        kind = 39;
+                     jjCheckNAdd(0);
+                  }
+                  if ((0x401L & l) != 0L)
+                     jjCheckNAddTwoStates(2, 5);
+                  break;
+               case 0:
+                  if ((0x100000601L & l) == 0L)
+                     break;
+                  if (kind > 39)
+                     kind = 39;
+                  jjCheckNAdd(0);
+                  break;
+               case 2:
+                  if ((0x100000200L & l) != 0L)
+                     jjCheckNAddTwoStates(2, 5);
+                  break;
+               case 3:
+                  if (curChar != 35)
+                     break;
+                  if (kind > 41)
+                     kind = 41;
+                  jjCheckNAdd(4);
+                  break;
+               case 4:
+                  if ((0xfffffffffffffbfeL & l) == 0L)
+                     break;
+                  if (kind > 41)
+                     kind = 41;
+                  jjCheckNAdd(4);
+                  break;
+               case 5:
+                  if (curChar == 35)
+                     jjstateSet[jjnewStateCnt++] = 3;
+                  break;
+               case 6:
+                  if ((0xfffffffffffff9ffL & l) != 0L && kind > 60)
+                     kind = 60;
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      else if (curChar < 128)
+      {
+         long l = 1L << (curChar & 077);
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 1:
+                  if (kind > 60)
+                     kind = 60;
+                  break;
+               case 4:
+                  if (kind > 41)
+                     kind = 41;
+                  jjstateSet[jjnewStateCnt++] = 4;
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      else
+      {
+         int hiByte = (int)(curChar >> 8);
+         int i1 = hiByte >> 6;
+         long l1 = 1L << (hiByte & 077);
+         int i2 = (curChar & 0xff) >> 6;
+         long l2 = 1L << (curChar & 077);
+         MatchLoop: do
+         {
+            switch(jjstateSet[--i])
+            {
+               case 1:
+                  if (jjCanMove_0(hiByte, i1, i2, l1, l2) && kind > 60)
+                     kind = 60;
+                  break;
+               case 4:
+                  if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
+                     break;
+                  if (kind > 41)
+                     kind = 41;
+                  jjstateSet[jjnewStateCnt++] = 4;
+                  break;
+               default : break;
+            }
+         } while(i != startsAt);
+      }
+      if (kind != 0x7fffffff)
+      {
+         jjmatchedKind = kind;
+         jjmatchedPos = curPos;
+         kind = 0x7fffffff;
+      }
+      ++curPos;
+      if ((i = jjnewStateCnt) == (startsAt = 7 - (jjnewStateCnt = startsAt)))
+         return curPos;
+      try { curChar = input_stream.readChar(); }
+      catch(java.io.IOException e) { return curPos; }
+   }
+}
+static final int[] jjnextStates = {
+   16, 17, 18, 19, 21, 25, 26, 27, 28, 30, 35, 36, 38, 39, 40, 10,
+   11, 13, 14, 3, 6, 7, 8,
+};
+private static final boolean jjCanMove_0(int hiByte, int i1, int i2, long l1, long l2)
+{
+   switch(hiByte)
+   {
+      case 0:
+         return ((jjbitVec2[i2] & l2) != 0L);
+      default :
+         if ((jjbitVec0[i1] & l1) != 0L)
+            return true;
+         return false;
+   }
+}
+private static final boolean jjCanMove_1(int hiByte, int i1, int i2, long l1, long l2)
+{
+   switch(hiByte)
+   {
+      case 0:
+         return ((jjbitVec4[i2] & l2) != 0L);
+      case 1:
+         return ((jjbitVec5[i2] & l2) != 0L);
+      case 2:
+         return ((jjbitVec6[i2] & l2) != 0L);
+      case 3:
+         return ((jjbitVec7[i2] & l2) != 0L);
+      case 4:
+         return ((jjbitVec8[i2] & l2) != 0L);
+      case 5:
+         return ((jjbitVec9[i2] & l2) != 0L);
+      case 6:
+         return ((jjbitVec10[i2] & l2) != 0L);
+      case 9:
+         return ((jjbitVec11[i2] & l2) != 0L);
+      case 10:
+         return ((jjbitVec12[i2] & l2) != 0L);
+      case 11:
+         return ((jjbitVec13[i2] & l2) != 0L);
+      case 12:
+         return ((jjbitVec14[i2] & l2) != 0L);
+      case 13:
+         return ((jjbitVec15[i2] & l2) != 0L);
+      case 14:
+         return ((jjbitVec16[i2] & l2) != 0L);
+      case 15:
+         return ((jjbitVec17[i2] & l2) != 0L);
+      case 16:
+         return ((jjbitVec18[i2] & l2) != 0L);
+      case 17:
+         return ((jjbitVec19[i2] & l2) != 0L);
+      case 30:
+         return ((jjbitVec20[i2] & l2) != 0L);
+      case 31:
+         return ((jjbitVec21[i2] & l2) != 0L);
+      case 33:
+         return ((jjbitVec22[i2] & l2) != 0L);
+      case 48:
+         return ((jjbitVec23[i2] & l2) != 0L);
+      case 49:
+         return ((jjbitVec24[i2] & l2) != 0L);
+      case 159:
+         return ((jjbitVec25[i2] & l2) != 0L);
+      case 215:
+         return ((jjbitVec26[i2] & l2) != 0L);
+      default :
+         if ((jjbitVec3[i1] & l1) != 0L)
+            return true;
+         return false;
+   }
+}
+private static final boolean jjCanMove_2(int hiByte, int i1, int i2, long l1, long l2)
+{
+   switch(hiByte)
+   {
+      case 0:
+         return ((jjbitVec27[i2] & l2) != 0L);
+      case 1:
+         return ((jjbitVec5[i2] & l2) != 0L);
+      case 2:
+         return ((jjbitVec28[i2] & l2) != 0L);
+      case 3:
+         return ((jjbitVec29[i2] & l2) != 0L);
+      case 4:
+         return ((jjbitVec30[i2] & l2) != 0L);
+      case 5:
+         return ((jjbitVec31[i2] & l2) != 0L);
+      case 6:
+         return ((jjbitVec32[i2] & l2) != 0L);
+      case 9:
+         return ((jjbitVec33[i2] & l2) != 0L);
+      case 10:
+         return ((jjbitVec34[i2] & l2) != 0L);
+      case 11:
+         return ((jjbitVec35[i2] & l2) != 0L);
+      case 12:
+         return ((jjbitVec36[i2] & l2) != 0L);
+      case 13:
+         return ((jjbitVec37[i2] & l2) != 0L);
+      case 14:
+         return ((jjbitVec38[i2] & l2) != 0L);
+      case 15:
+         return ((jjbitVec39[i2] & l2) != 0L);
+      case 16:
+         return ((jjbitVec18[i2] & l2) != 0L);
+      case 17:
+         return ((jjbitVec19[i2] & l2) != 0L);
+      case 30:
+         return ((jjbitVec20[i2] & l2) != 0L);
+      case 31:
+         return ((jjbitVec21[i2] & l2) != 0L);
+      case 32:
+         return ((jjbitVec40[i2] & l2) != 0L);
+      case 33:
+         return ((jjbitVec22[i2] & l2) != 0L);
+      case 48:
+         return ((jjbitVec41[i2] & l2) != 0L);
+      case 49:
+         return ((jjbitVec24[i2] & l2) != 0L);
+      case 159:
+         return ((jjbitVec25[i2] & l2) != 0L);
+      case 215:
+         return ((jjbitVec26[i2] & l2) != 0L);
+      default :
+         if ((jjbitVec3[i1] & l1) != 0L)
+            return true;
+         return false;
+   }
+}
+public static final String[] jjstrLiteralImages = {
+"", "\133", "\75", "\46\75", "\174\75", "\163\164\141\162\164",
+"\144\151\166", "\151\156\143\154\165\144\145", "\176", "\135",
+"\147\162\141\155\155\141\162", "\173", "\175", "\156\141\155\145\163\160\141\143\145",
+"\144\145\146\141\165\154\164", "\151\156\150\145\162\151\164", "\144\141\164\141\164\171\160\145\163",
+"\145\155\160\164\171", "\164\145\170\164", "\156\157\164\101\154\154\157\167\145\144", "\174", "\46",
+"\54", "\53", "\77", "\52", "\145\154\145\155\145\156\164",
+"\141\164\164\162\151\142\165\164\145", "\50", "\51", "\55", "\154\151\163\164", "\155\151\170\145\144",
+"\145\170\164\145\162\156\141\154", "\160\141\162\145\156\164", "\163\164\162\151\156\147",
+"\164\157\153\145\156", null, null, null, null, null, null, null, null, null, null, null, null, null,
+null, null, null, null, null, null, null, null, null, "\76\76", null, };
+public static final String[] lexStateNames = {
+   "DEFAULT",
+   "AFTER_SINGLE_LINE_COMMENT",
+   "AFTER_DOCUMENTATION",
+};
+public static final int[] jjnewLexState = {
+   -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
+   -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0, 2, -1, 1, 2, -1, -1, -1, -1, -1, -1,
+   -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
+};
+static final long[] jjtoToken = {
+   0x1fc00b1fffffffffL,
+};
+static final long[] jjtoSkip = {
+   0x148000000000L,
+};
+static final long[] jjtoSpecial = {
+   0x140000000000L,
+};
+protected JavaCharStream input_stream;
+private final int[] jjrounds = new int[43];
+private final int[] jjstateSet = new int[86];
+StringBuffer image;
+int jjimageLen;
+int lengthOfMatch;
+protected char curChar;
+public CompactSyntaxTokenManager(JavaCharStream stream)
+{
+   if (JavaCharStream.staticFlag)
+      throw new Error("ERROR: Cannot use a static CharStream class with a non-static lexical analyzer.");
+   input_stream = stream;
+}
+public CompactSyntaxTokenManager(JavaCharStream stream, int lexState)
+{
+   this(stream);
+   SwitchTo(lexState);
+}
+public void ReInit(JavaCharStream stream)
+{
+   jjmatchedPos = jjnewStateCnt = 0;
+   curLexState = defaultLexState;
+   input_stream = stream;
+   ReInitRounds();
+}
+private final void ReInitRounds()
+{
+   int i;
+   jjround = 0x80000001;
+   for (i = 43; i-- > 0;)
+      jjrounds[i] = 0x80000000;
+}
+public void ReInit(JavaCharStream stream, int lexState)
+{
+   ReInit(stream);
+   SwitchTo(lexState);
+}
+public void SwitchTo(int lexState)
+{
+   if (lexState >= 3 || lexState < 0)
+      throw new TokenMgrError("Error: Ignoring invalid lexical state : " + lexState + ". State unchanged.", TokenMgrError.INVALID_LEXICAL_STATE);
+   else
+      curLexState = lexState;
+}
+
+protected Token jjFillToken()
+{
+   Token t = Token.newToken(jjmatchedKind);
+   t.kind = jjmatchedKind;
+   String im = jjstrLiteralImages[jjmatchedKind];
+   t.image = (im == null) ? input_stream.GetImage() : im;
+   t.beginLine = input_stream.getBeginLine();
+   t.beginColumn = input_stream.getBeginColumn();
+   t.endLine = input_stream.getEndLine();
+   t.endColumn = input_stream.getEndColumn();
+   return t;
+}
+
+int curLexState = 0;
+int defaultLexState = 0;
+int jjnewStateCnt;
+int jjround;
+int jjmatchedPos;
+int jjmatchedKind;
+
+public Token getNextToken()
+{
+  int kind;
+  Token specialToken = null;
+  Token matchedToken;
+  int curPos = 0;
+
+  EOFLoop :
+  for (;;)
+  {
+   try
+   {
+      curChar = input_stream.BeginToken();
+   }
+   catch(java.io.IOException e)
+   {
+      jjmatchedKind = 0;
+      matchedToken = jjFillToken();
+      matchedToken.specialToken = specialToken;
+      return matchedToken;
+   }
+   image = null;
+   jjimageLen = 0;
+
+   switch(curLexState)
+   {
+     case 0:
+       jjmatchedKind = 0x7fffffff;
+       jjmatchedPos = 0;
+       curPos = jjMoveStringLiteralDfa0_0();
+       break;
+     case 1:
+       jjmatchedKind = 0x7fffffff;
+       jjmatchedPos = 0;
+       curPos = jjMoveStringLiteralDfa0_1();
+       break;
+     case 2:
+       jjmatchedKind = 0x7fffffff;
+       jjmatchedPos = 0;
+       curPos = jjMoveStringLiteralDfa0_2();
+       break;
+   }
+     if (jjmatchedKind != 0x7fffffff)
+     {
+        if (jjmatchedPos + 1 < curPos)
+           input_stream.backup(curPos - jjmatchedPos - 1);
+        if ((jjtoToken[jjmatchedKind >> 6] & (1L << (jjmatchedKind & 077))) != 0L)
+        {
+           matchedToken = jjFillToken();
+           matchedToken.specialToken = specialToken;
+       if (jjnewLexState[jjmatchedKind] != -1)
+         curLexState = jjnewLexState[jjmatchedKind];
+           return matchedToken;
+        }
+        else
+        {
+           if ((jjtoSpecial[jjmatchedKind >> 6] & (1L << (jjmatchedKind & 077))) != 0L)
+           {
+              matchedToken = jjFillToken();
+              if (specialToken == null)
+                 specialToken = matchedToken;
+              else
+              {
+                 matchedToken.specialToken = specialToken;
+                 specialToken = (specialToken.next = matchedToken);
+              }
+              SkipLexicalActions(matchedToken);
+           }
+           else
+              SkipLexicalActions(null);
+         if (jjnewLexState[jjmatchedKind] != -1)
+           curLexState = jjnewLexState[jjmatchedKind];
+           continue EOFLoop;
+        }
+     }
+     int error_line = input_stream.getEndLine();
+     int error_column = input_stream.getEndColumn();
+     String error_after = null;
+     boolean EOFSeen = false;
+     try { input_stream.readChar(); input_stream.backup(1); }
+     catch (java.io.IOException e1) {
+        EOFSeen = true;
+        error_after = curPos <= 1 ? "" : input_stream.GetImage();
+        if (curChar == '\n' || curChar == '\r') {
+           error_line++;
+           error_column = 0;
+        }
+        else
+           error_column++;
+     }
+     if (!EOFSeen) {
+        input_stream.backup(1);
+        error_after = curPos <= 1 ? "" : input_stream.GetImage();
+     }
+     throw new TokenMgrError(EOFSeen, curLexState, error_line, error_column, error_after, curChar, TokenMgrError.LEXICAL_ERROR);
+  }
+}
+
+void SkipLexicalActions(Token matchedToken)
+{
+   switch(jjmatchedKind)
+   {
+      default :
+         break;
+   }
+}
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/EOFException.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/EOFException.java
new file mode 100644
index 0000000..b7cca0a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/EOFException.java
@@ -0,0 +1,31 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.compact;
+
+import java.io.IOException;
+
+public class EOFException extends IOException {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/EscapeSyntaxException.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/EscapeSyntaxException.java
new file mode 100644
index 0000000..57d51be
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/EscapeSyntaxException.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.compact;
+
+class EscapeSyntaxException extends RuntimeException {
+  private final String key;
+  private final int lineNumber;
+  private final int columnNumber;
+
+  EscapeSyntaxException(String key, int lineNumber, int columnNumber) {
+    this.key = key;
+    this.lineNumber = lineNumber;
+    this.columnNumber = columnNumber;
+  }
+
+  String getKey() {
+    return key;
+  }
+
+  int getLineNumber() {
+    return lineNumber;
+  }
+
+  int getColumnNumber() {
+    return columnNumber;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/JavaCharStream.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/JavaCharStream.java
new file mode 100644
index 0000000..bb0a085
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/JavaCharStream.java
@@ -0,0 +1,572 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* Generated By:JavaCC: Do not edit this line. JavaCharStream.java Version 3.0 */
+package com.sun.xml.internal.rngom.parse.compact;
+
+/**
+ * An implementation of interface CharStream, where the stream is assumed to
+ * contain only ASCII characters (with java-like unicode escape processing).
+ */
+
+public class JavaCharStream
+{
+  public static final boolean staticFlag = false;
+  static final int hexval(char c) throws java.io.IOException {
+    switch(c)
+    {
+       case '0' :
+          return 0;
+       case '1' :
+          return 1;
+       case '2' :
+          return 2;
+       case '3' :
+          return 3;
+       case '4' :
+          return 4;
+       case '5' :
+          return 5;
+       case '6' :
+          return 6;
+       case '7' :
+          return 7;
+       case '8' :
+          return 8;
+       case '9' :
+          return 9;
+
+       case 'a' :
+       case 'A' :
+          return 10;
+       case 'b' :
+       case 'B' :
+          return 11;
+       case 'c' :
+       case 'C' :
+          return 12;
+       case 'd' :
+       case 'D' :
+          return 13;
+       case 'e' :
+       case 'E' :
+          return 14;
+       case 'f' :
+       case 'F' :
+          return 15;
+    }
+
+    throw new java.io.IOException(); // Should never come here
+  }
+
+  public int bufpos = -1;
+  int bufsize;
+  int available;
+  int tokenBegin;
+  protected int bufline[];
+  protected int bufcolumn[];
+
+  protected int column = 0;
+  protected int line = 1;
+
+  protected boolean prevCharIsCR = false;
+  protected boolean prevCharIsLF = false;
+
+  protected java.io.Reader inputStream;
+
+  protected char[] nextCharBuf;
+  protected char[] buffer;
+  protected int maxNextCharInd = 0;
+  protected int nextCharInd = -1;
+  protected int inBuf = 0;
+
+  protected void ExpandBuff(boolean wrapAround)
+  {
+     char[] newbuffer = new char[bufsize + 2048];
+     int newbufline[] = new int[bufsize + 2048];
+     int newbufcolumn[] = new int[bufsize + 2048];
+
+     try
+     {
+        if (wrapAround)
+        {
+           System.arraycopy(buffer, tokenBegin, newbuffer, 0, bufsize - tokenBegin);
+           System.arraycopy(buffer, 0, newbuffer,
+                                             bufsize - tokenBegin, bufpos);
+           buffer = newbuffer;
+
+           System.arraycopy(bufline, tokenBegin, newbufline, 0, bufsize - tokenBegin);
+           System.arraycopy(bufline, 0, newbufline, bufsize - tokenBegin, bufpos);
+           bufline = newbufline;
+
+           System.arraycopy(bufcolumn, tokenBegin, newbufcolumn, 0, bufsize - tokenBegin);
+           System.arraycopy(bufcolumn, 0, newbufcolumn, bufsize - tokenBegin, bufpos);
+           bufcolumn = newbufcolumn;
+
+           bufpos += (bufsize - tokenBegin);
+        }
+        else
+        {
+           System.arraycopy(buffer, tokenBegin, newbuffer, 0, bufsize - tokenBegin);
+           buffer = newbuffer;
+
+           System.arraycopy(bufline, tokenBegin, newbufline, 0, bufsize - tokenBegin);
+           bufline = newbufline;
+
+           System.arraycopy(bufcolumn, tokenBegin, newbufcolumn, 0, bufsize - tokenBegin);
+           bufcolumn = newbufcolumn;
+
+           bufpos -= tokenBegin;
+        }
+     }
+     catch (Throwable t)
+     {
+        throw new Error(t.getMessage());
+     }
+
+     available = (bufsize += 2048);
+     tokenBegin = 0;
+  }
+
+  protected void FillBuff() throws java.io.IOException
+  {
+     int i;
+     if (maxNextCharInd == 4096)
+        maxNextCharInd = nextCharInd = 0;
+
+     try {
+        if ((i = inputStream.read(nextCharBuf, maxNextCharInd,
+                                            4096 - maxNextCharInd)) == -1)
+        {
+           inputStream.close();
+           throw new java.io.IOException();
+        }
+        else
+           maxNextCharInd += i;
+        return;
+     }
+     catch(java.io.IOException e) {
+        if (bufpos != 0)
+        {
+           --bufpos;
+           backup(0);
+        }
+        else
+        {
+           bufline[bufpos] = line;
+           bufcolumn[bufpos] = column;
+        }
+        throw e;
+     }
+  }
+
+  protected char ReadByte() throws java.io.IOException
+  {
+     if (++nextCharInd >= maxNextCharInd)
+        FillBuff();
+
+     return nextCharBuf[nextCharInd];
+  }
+
+  public char BeginToken() throws java.io.IOException
+  {
+     if (inBuf > 0)
+     {
+        --inBuf;
+
+        if (++bufpos == bufsize)
+           bufpos = 0;
+
+        tokenBegin = bufpos;
+        return buffer[bufpos];
+     }
+
+     tokenBegin = 0;
+     bufpos = -1;
+
+     return readChar();
+  }
+
+  protected void AdjustBuffSize()
+  {
+     if (available == bufsize)
+     {
+        if (tokenBegin > 2048)
+        {
+           bufpos = 0;
+           available = tokenBegin;
+        }
+        else
+           ExpandBuff(false);
+     }
+     else if (available > tokenBegin)
+        available = bufsize;
+     else if ((tokenBegin - available) < 2048)
+        ExpandBuff(true);
+     else
+        available = tokenBegin;
+  }
+
+  protected void UpdateLineColumn(char c)
+  {
+     column++;
+
+     if (prevCharIsLF)
+     {
+        prevCharIsLF = false;
+        line += (column = 1);
+     }
+     else if (prevCharIsCR)
+     {
+        prevCharIsCR = false;
+        if (c == '\n')
+        {
+           prevCharIsLF = true;
+        }
+        else
+           line += (column = 1);
+     }
+
+     switch (c)
+     {
+        case '\r' :
+           prevCharIsCR = true;
+           break;
+        case '\n' :
+           prevCharIsLF = true;
+           break;
+        case '\t' :
+           column--;
+           column += (8 - (column & 07));
+           break;
+        default :
+           break;
+     }
+
+     bufline[bufpos] = line;
+     bufcolumn[bufpos] = column;
+  }
+
+  public char readChar() throws java.io.IOException
+  {
+     if (inBuf > 0)
+     {
+        --inBuf;
+
+        if (++bufpos == bufsize)
+           bufpos = 0;
+
+        return buffer[bufpos];
+     }
+
+     char c;
+
+     if (++bufpos == available)
+        AdjustBuffSize();
+
+     if ((buffer[bufpos] = c = ReadByte()) == '\\')
+     {
+        UpdateLineColumn(c);
+
+        int backSlashCnt = 1;
+
+        for (;;) // Read all the backslashes
+        {
+           if (++bufpos == available)
+              AdjustBuffSize();
+
+           try
+           {
+              if ((buffer[bufpos] = c = ReadByte()) != '\\')
+              {
+                 UpdateLineColumn(c);
+                 // found a non-backslash char.
+                 if ((c == 'u') && ((backSlashCnt & 1) == 1))
+                 {
+                    if (--bufpos < 0)
+                       bufpos = bufsize - 1;
+
+                    break;
+                 }
+
+                 backup(backSlashCnt);
+                 return '\\';
+              }
+           }
+           catch(java.io.IOException e)
+           {
+              if (backSlashCnt > 1)
+                 backup(backSlashCnt);
+
+              return '\\';
+           }
+
+           UpdateLineColumn(c);
+           backSlashCnt++;
+        }
+
+        // Here, we have seen an odd number of backslash's followed by a 'u'
+        try
+        {
+           while ((c = ReadByte()) == 'u')
+              ++column;
+
+           buffer[bufpos] = c = (char)(hexval(c) << 12 |
+                                       hexval(ReadByte()) << 8 |
+                                       hexval(ReadByte()) << 4 |
+                                       hexval(ReadByte()));
+
+           column += 4;
+        }
+        catch(java.io.IOException e)
+        {
+           throw new Error("Invalid escape character at line " + line +
+                                         " column " + column + ".");
+        }
+
+        if (backSlashCnt == 1)
+           return c;
+        else
+        {
+           backup(backSlashCnt - 1);
+           return '\\';
+        }
+     }
+     else
+     {
+        UpdateLineColumn(c);
+        return (c);
+     }
+  }
+
+  /**
+   * @deprecated
+   * @see #getEndColumn
+   */
+
+  public int getColumn() {
+     return bufcolumn[bufpos];
+  }
+
+  /**
+   * @deprecated
+   * @see #getEndLine
+   */
+
+  public int getLine() {
+     return bufline[bufpos];
+  }
+
+  public int getEndColumn() {
+     return bufcolumn[bufpos];
+  }
+
+  public int getEndLine() {
+     return bufline[bufpos];
+  }
+
+  public int getBeginColumn() {
+     return bufcolumn[tokenBegin];
+  }
+
+  public int getBeginLine() {
+     return bufline[tokenBegin];
+  }
+
+  public void backup(int amount) {
+
+    inBuf += amount;
+    if ((bufpos -= amount) < 0)
+       bufpos += bufsize;
+  }
+
+  public JavaCharStream(java.io.Reader dstream,
+                 int startline, int startcolumn, int buffersize)
+  {
+    inputStream = dstream;
+    line = startline;
+    column = startcolumn - 1;
+
+    available = bufsize = buffersize;
+    buffer = new char[buffersize];
+    bufline = new int[buffersize];
+    bufcolumn = new int[buffersize];
+    nextCharBuf = new char[4096];
+  }
+
+  public JavaCharStream(java.io.Reader dstream,
+                                        int startline, int startcolumn)
+  {
+     this(dstream, startline, startcolumn, 4096);
+  }
+
+  public JavaCharStream(java.io.Reader dstream)
+  {
+     this(dstream, 1, 1, 4096);
+  }
+  public void ReInit(java.io.Reader dstream,
+                 int startline, int startcolumn, int buffersize)
+  {
+    inputStream = dstream;
+    line = startline;
+    column = startcolumn - 1;
+
+    if (buffer == null || buffersize != buffer.length)
+    {
+      available = bufsize = buffersize;
+      buffer = new char[buffersize];
+      bufline = new int[buffersize];
+      bufcolumn = new int[buffersize];
+      nextCharBuf = new char[4096];
+    }
+    prevCharIsLF = prevCharIsCR = false;
+    tokenBegin = inBuf = maxNextCharInd = 0;
+    nextCharInd = bufpos = -1;
+  }
+
+  public void ReInit(java.io.Reader dstream,
+                                        int startline, int startcolumn)
+  {
+     ReInit(dstream, startline, startcolumn, 4096);
+  }
+
+  public void ReInit(java.io.Reader dstream)
+  {
+     ReInit(dstream, 1, 1, 4096);
+  }
+  public JavaCharStream(java.io.InputStream dstream, int startline,
+  int startcolumn, int buffersize)
+  {
+     this(new java.io.InputStreamReader(dstream), startline, startcolumn, 4096);
+  }
+
+  public JavaCharStream(java.io.InputStream dstream, int startline,
+                                                           int startcolumn)
+  {
+     this(dstream, startline, startcolumn, 4096);
+  }
+
+  public JavaCharStream(java.io.InputStream dstream)
+  {
+     this(dstream, 1, 1, 4096);
+  }
+
+  public void ReInit(java.io.InputStream dstream, int startline,
+  int startcolumn, int buffersize)
+  {
+     ReInit(new java.io.InputStreamReader(dstream), startline, startcolumn, 4096);
+  }
+  public void ReInit(java.io.InputStream dstream, int startline,
+                                                           int startcolumn)
+  {
+     ReInit(dstream, startline, startcolumn, 4096);
+  }
+  public void ReInit(java.io.InputStream dstream)
+  {
+     ReInit(dstream, 1, 1, 4096);
+  }
+
+  public String GetImage()
+  {
+     if (bufpos >= tokenBegin)
+        return new String(buffer, tokenBegin, bufpos - tokenBegin + 1);
+     else
+        return new String(buffer, tokenBegin, bufsize - tokenBegin) +
+                              new String(buffer, 0, bufpos + 1);
+  }
+
+  public char[] GetSuffix(int len)
+  {
+     char[] ret = new char[len];
+
+     if ((bufpos + 1) >= len)
+        System.arraycopy(buffer, bufpos - len + 1, ret, 0, len);
+     else
+     {
+        System.arraycopy(buffer, bufsize - (len - bufpos - 1), ret, 0,
+                                                          len - bufpos - 1);
+        System.arraycopy(buffer, 0, ret, len - bufpos - 1, bufpos + 1);
+     }
+
+     return ret;
+  }
+
+  public void Done()
+  {
+     nextCharBuf = null;
+     buffer = null;
+     bufline = null;
+     bufcolumn = null;
+  }
+
+  /**
+   * Method to adjust line and column numbers for the start of a token.
+   */
+  public void adjustBeginLineColumn(int newLine, int newCol)
+  {
+     int start = tokenBegin;
+     int len;
+
+     if (bufpos >= tokenBegin)
+     {
+        len = bufpos - tokenBegin + inBuf + 1;
+     }
+     else
+     {
+        len = bufsize - tokenBegin + bufpos + 1 + inBuf;
+     }
+
+     int i = 0, j = 0, k = 0;
+     int nextColDiff = 0, columnDiff = 0;
+
+     while (i < len &&
+            bufline[j = start % bufsize] == bufline[k = ++start % bufsize])
+     {
+        bufline[j] = newLine;
+        nextColDiff = columnDiff + bufcolumn[k] - bufcolumn[j];
+        bufcolumn[j] = newCol + columnDiff;
+        columnDiff = nextColDiff;
+        i++;
+     }
+
+     if (i < len)
+     {
+        bufline[j] = newLine++;
+        bufcolumn[j] = newCol + columnDiff;
+
+        while (i++ < len)
+        {
+           if (bufline[j = start % bufsize] != bufline[++start % bufsize])
+              bufline[j] = newLine++;
+           else
+              bufline[j] = newLine;
+        }
+     }
+
+     line = bufline[j];
+     column = bufcolumn[j];
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/Messages.properties
new file mode 100644
index 0000000..45c8940
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/Messages.properties
@@ -0,0 +1,23 @@
+syntax_error=syntax error: {0}
+undeclared_prefix=undeclared prefix \"{0}\"
+xmlns_prefix=prefix must not be \"xmlns\"
+unqualified_annotation_attribute=annotation attribute must have a namespace URI
+inherited_annotation_namespace=namespace URI for annotation cannot be inherited
+xmlns_annotation_attribute=annotation attribute cannot be named \"xmlns\"
+duplicate_attribute=multiple attributes with local name \"{0}\" and namespace URI \"{1}\"
+except_missing_parentheses=parentheses required around \"-\" expression
+xmlns_annotation_attribute_uri=annotation attribute cannot have namespace URI \"http://www.w3.org/2000/xmlns\"
+xml_prefix_bad_uri=prefix \"xml\" can only be bound to namespace URI \"http://www.w3.org/XML/1998/namespace\"
+xml_uri_bad_prefix=only prefix \"xml\" can be bound to namespace URI \"http://www.w3.org/XML/1998/namespace\"
+illegal_hex_digit=expected hex digit
+char_code_too_big=character code must be less than 0x110000
+illegal_char_code=code of character that is not allowed
+illegal_char_code_ref=reference to character whose code is not allowed
+incomplete_escape=incomplete escape sequence
+any_name_except_contains_any_name=\"except\" in \"anyName\" contains \"anyName\"
+ns_name_except_contains_any_name=\"except\" in \"nsName\" contains \"anyName\"
+ns_name_except_contains_ns_name=\"except\" in \"nsName\" contains \"nsName\"
+illegal_surrogate_pair=illegal surrogate pair
+relax_ng_namespace=annotations cannot have namespace URI \"http://relaxng.org/ns/structure/1.0\"
+top_level_follow_annotation=top-level pattern cannot have following annotations
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/ParseException.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/ParseException.java
new file mode 100644
index 0000000..5e198e8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/ParseException.java
@@ -0,0 +1,217 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* Generated By:JavaCC: Do not edit this line. ParseException.java Version 3.0 */
+package com.sun.xml.internal.rngom.parse.compact;
+
+/**
+ * This exception is thrown when parse errors are encountered.
+ * You can explicitly create objects of this exception type by
+ * calling the method generateParseException in the generated
+ * parser.
+ *
+ * You can modify this class to customize your error reporting
+ * mechanisms so long as you retain the public fields.
+ */
+public class ParseException extends Exception {
+
+  /**
+   * This constructor is used by the method "generateParseException"
+   * in the generated parser.  Calling this constructor generates
+   * a new object of this type with the fields "currentToken",
+   * "expectedTokenSequences", and "tokenImage" set.  The boolean
+   * flag "specialConstructor" is also set to true to indicate that
+   * this constructor was used to create this object.
+   * This constructor calls its super class with the empty string
+   * to force the "toString" method of parent class "Throwable" to
+   * print the error message in the form:
+   *     ParseException: <result of getMessage>
+   */
+  public ParseException(Token currentTokenVal,
+                        int[][] expectedTokenSequencesVal,
+                        String[] tokenImageVal
+                       )
+  {
+    super("");
+    specialConstructor = true;
+    currentToken = currentTokenVal;
+    expectedTokenSequences = expectedTokenSequencesVal;
+    tokenImage = tokenImageVal;
+  }
+
+  /**
+   * The following constructors are for use by you for whatever
+   * purpose you can think of.  Constructing the exception in this
+   * manner makes the exception behave in the normal way - i.e., as
+   * documented in the class "Throwable".  The fields "errorToken",
+   * "expectedTokenSequences", and "tokenImage" do not contain
+   * relevant information.  The JavaCC generated code does not use
+   * these constructors.
+   */
+
+  public ParseException() {
+    super();
+    specialConstructor = false;
+  }
+
+  public ParseException(String message) {
+    super(message);
+    specialConstructor = false;
+  }
+
+  /**
+   * This variable determines which constructor was used to create
+   * this object and thereby affects the semantics of the
+   * "getMessage" method (see below).
+   */
+  protected boolean specialConstructor;
+
+  /**
+   * This is the last token that has been consumed successfully.  If
+   * this object has been created due to a parse error, the token
+   * followng this token will (therefore) be the first error token.
+   */
+  public Token currentToken;
+
+  /**
+   * Each entry in this array is an array of integers.  Each array
+   * of integers represents a sequence of tokens (by their ordinal
+   * values) that is expected at this point of the parse.
+   */
+  public int[][] expectedTokenSequences;
+
+  /**
+   * This is a reference to the "tokenImage" array of the generated
+   * parser within which the parse error occurred.  This array is
+   * defined in the generated ...Constants interface.
+   */
+  public String[] tokenImage;
+
+  /**
+   * This method has the standard behavior when this object has been
+   * created using the standard constructors.  Otherwise, it uses
+   * "currentToken" and "expectedTokenSequences" to generate a parse
+   * error message and returns it.  If this object has been created
+   * due to a parse error, and you do not catch it (it gets thrown
+   * from the parser), then this method is called during the printing
+   * of the final stack trace, and hence the correct error message
+   * gets displayed.
+   */
+  public String getMessage() {
+    if (!specialConstructor) {
+      return super.getMessage();
+    }
+    String expected = "";
+    int maxSize = 0;
+    for (int i = 0; i < expectedTokenSequences.length; i++) {
+      if (maxSize < expectedTokenSequences[i].length) {
+        maxSize = expectedTokenSequences[i].length;
+      }
+      for (int j = 0; j < expectedTokenSequences[i].length; j++) {
+        expected += tokenImage[expectedTokenSequences[i][j]] + " ";
+      }
+      if (expectedTokenSequences[i][expectedTokenSequences[i].length - 1] != 0) {
+        expected += "...";
+      }
+      expected += eol + "    ";
+    }
+    String retval = "Encountered \"";
+    Token tok = currentToken.next;
+    for (int i = 0; i < maxSize; i++) {
+      if (i != 0) retval += " ";
+      if (tok.kind == 0) {
+        retval += tokenImage[0];
+        break;
+      }
+      retval += add_escapes(tok.image);
+      tok = tok.next;
+    }
+    retval += "\" at line " + currentToken.next.beginLine + ", column " + currentToken.next.beginColumn;
+    retval += "." + eol;
+    if (expectedTokenSequences.length == 1) {
+      retval += "Was expecting:" + eol + "    ";
+    } else {
+      retval += "Was expecting one of:" + eol + "    ";
+    }
+    retval += expected;
+    return retval;
+  }
+
+  /**
+   * The end of line string for this machine.
+   */
+  protected String eol = System.getProperty("line.separator", "\n");
+
+  /**
+   * Used to convert raw characters to their escaped version
+   * when these raw version cannot be used as part of an ASCII
+   * string literal.
+   */
+  protected String add_escapes(String str) {
+      StringBuffer retval = new StringBuffer();
+      char ch;
+      for (int i = 0; i < str.length(); i++) {
+        switch (str.charAt(i))
+        {
+           case 0 :
+              continue;
+           case '\b':
+              retval.append("\\b");
+              continue;
+           case '\t':
+              retval.append("\\t");
+              continue;
+           case '\n':
+              retval.append("\\n");
+              continue;
+           case '\f':
+              retval.append("\\f");
+              continue;
+           case '\r':
+              retval.append("\\r");
+              continue;
+           case '\"':
+              retval.append("\\\"");
+              continue;
+           case '\'':
+              retval.append("\\\'");
+              continue;
+           case '\\':
+              retval.append("\\\\");
+              continue;
+           default:
+              if ((ch = str.charAt(i)) < 0x20 || ch > 0x7e) {
+                 String s = "0000" + Integer.toString(ch, 16);
+                 retval.append("\\u" + s.substring(s.length() - 4, s.length()));
+              } else {
+                 retval.append(ch);
+              }
+              continue;
+        }
+      }
+      return retval.toString();
+   }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/Token.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/Token.java
new file mode 100644
index 0000000..3e56daa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/Token.java
@@ -0,0 +1,106 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* Generated By:JavaCC: Do not edit this line. Token.java Version 3.0 */
+package com.sun.xml.internal.rngom.parse.compact;
+
+/**
+ * Describes the input token stream.
+ */
+
+public class Token {
+
+  /**
+   * An integer that describes the kind of this token.  This numbering
+   * system is determined by JavaCCParser, and a table of these numbers is
+   * stored in the file ...Constants.java.
+   */
+  public int kind;
+
+  /**
+   * beginLine and beginColumn describe the position of the first character
+   * of this token; endLine and endColumn describe the position of the
+   * last character of this token.
+   */
+  public int beginLine, beginColumn, endLine, endColumn;
+
+  /**
+   * The string image of the token.
+   */
+  public String image;
+
+  /**
+   * A reference to the next regular (non-special) token from the input
+   * stream.  If this is the last token from the input stream, or if the
+   * token manager has not read tokens beyond this one, this field is
+   * set to null.  This is true only if this token is also a regular
+   * token.  Otherwise, see below for a description of the contents of
+   * this field.
+   */
+  public Token next;
+
+  /**
+   * This field is used to access special tokens that occur prior to this
+   * token, but after the immediately preceding regular (non-special) token.
+   * If there are no such special tokens, this field is set to null.
+   * When there are more than one such special token, this field refers
+   * to the last of these special tokens, which in turn refers to the next
+   * previous special token through its specialToken field, and so on
+   * until the first special token (whose specialToken field is null).
+   * The next fields of special tokens refer to other special tokens that
+   * immediately follow it (without an intervening regular token).  If there
+   * is no such token, this field is null.
+   */
+  public Token specialToken;
+
+  /**
+   * Returns the image.
+   */
+  public String toString()
+  {
+     return image;
+  }
+
+  /**
+   * Returns a new Token object, by default. However, if you want, you
+   * can create and return subclass objects based on the value of ofKind.
+   * Simply add the cases to the switch for all those special cases.
+   * For example, if you have a subclass of Token called IDToken that
+   * you want to create if ofKind is ID, simlpy add something like :
+   *
+   *    case MyParserConstants.ID : return new IDToken();
+   *
+   * to the following switch statement. Then you can cast matchedToken
+   * variable to the appropriate type and use it in your lexical actions.
+   */
+  public static final Token newToken(int ofKind)
+  {
+     switch(ofKind)
+     {
+       default : return new Token();
+     }
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/TokenMgrError.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/TokenMgrError.java
new file mode 100644
index 0000000..6cba0d2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/TokenMgrError.java
@@ -0,0 +1,158 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* Generated By:JavaCC: Do not edit this line. TokenMgrError.java Version 3.0 */
+package com.sun.xml.internal.rngom.parse.compact;
+
+public class TokenMgrError extends Error
+{
+   /*
+    * Ordinals for various reasons why an Error of this type can be thrown.
+    */
+
+   /**
+    * Lexical error occured.
+    */
+   static final int LEXICAL_ERROR = 0;
+
+   /**
+    * An attempt wass made to create a second instance of a static token manager.
+    */
+   static final int STATIC_LEXER_ERROR = 1;
+
+   /**
+    * Tried to change to an invalid lexical state.
+    */
+   static final int INVALID_LEXICAL_STATE = 2;
+
+   /**
+    * Detected (and bailed out of) an infinite loop in the token manager.
+    */
+   static final int LOOP_DETECTED = 3;
+
+   /**
+    * Indicates the reason why the exception is thrown. It will have
+    * one of the above 4 values.
+    */
+   int errorCode;
+
+   /**
+    * Replaces unprintable characters by their espaced (or unicode escaped)
+    * equivalents in the given string
+    */
+   protected static final String addEscapes(String str) {
+      StringBuffer retval = new StringBuffer();
+      char ch;
+      for (int i = 0; i < str.length(); i++) {
+        switch (str.charAt(i))
+        {
+           case 0 :
+              continue;
+           case '\b':
+              retval.append("\\b");
+              continue;
+           case '\t':
+              retval.append("\\t");
+              continue;
+           case '\n':
+              retval.append("\\n");
+              continue;
+           case '\f':
+              retval.append("\\f");
+              continue;
+           case '\r':
+              retval.append("\\r");
+              continue;
+           case '\"':
+              retval.append("\\\"");
+              continue;
+           case '\'':
+              retval.append("\\\'");
+              continue;
+           case '\\':
+              retval.append("\\\\");
+              continue;
+           default:
+              if ((ch = str.charAt(i)) < 0x20 || ch > 0x7e) {
+                 String s = "0000" + Integer.toString(ch, 16);
+                 retval.append("\\u" + s.substring(s.length() - 4, s.length()));
+              } else {
+                 retval.append(ch);
+              }
+              continue;
+        }
+      }
+      return retval.toString();
+   }
+
+   /**
+    * Returns a detailed message for the Error when it is thrown by the
+    * token manager to indicate a lexical error.
+    * Parameters :
+    *    EOFSeen     : indicates if EOF caused the lexicl error
+    *    curLexState : lexical state in which this error occured
+    *    errorLine   : line number when the error occured
+    *    errorColumn : column number when the error occured
+    *    errorAfter  : prefix that was seen before this error occured
+    *    curchar     : the offending character
+    * Note: You can customize the lexical error message by modifying this method.
+    */
+   protected static String LexicalError(boolean EOFSeen, int lexState, int errorLine, int errorColumn, String errorAfter, char curChar) {
+      return("Lexical error at line " +
+           errorLine + ", column " +
+           errorColumn + ".  Encountered: " +
+           (EOFSeen ? "<EOF> " : ("\"" + addEscapes(String.valueOf(curChar)) + "\"") + " (" + (int)curChar + "), ") +
+           "after : \"" + addEscapes(errorAfter) + "\"");
+   }
+
+   /**
+    * You can also modify the body of this method to customize your error messages.
+    * For example, cases like LOOP_DETECTED and INVALID_LEXICAL_STATE are not
+    * of end-users concern, so you can return something like :
+    *
+    *     "Internal Error : Please file a bug report .... "
+    *
+    * from this method for such cases in the release version of your parser.
+    */
+   public String getMessage() {
+      return super.getMessage();
+   }
+
+   /*
+    * Constructors of various flavors follow.
+    */
+
+   public TokenMgrError() {
+   }
+
+   public TokenMgrError(String message, int reason) {
+      super(message);
+      errorCode = reason;
+   }
+
+   public TokenMgrError(boolean EOFSeen, int lexState, int errorLine, int errorColumn, String errorAfter, char curChar, int reason) {
+      this(LexicalError(EOFSeen, lexState, errorLine, errorColumn, errorAfter, curChar), reason);
+   }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/UCode_UCodeESC_CharStream.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/UCode_UCodeESC_CharStream.java
new file mode 100644
index 0000000..86ac3e9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/compact/UCode_UCodeESC_CharStream.java
@@ -0,0 +1,574 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* Generated By:JavaCC: Do not edit this line. UCode_UCodeESC_CharStream.java Version 0.7pre6 */
+/* The previous line keeps JavaCC quiet. In fact, the JavaCC generated file
+   has been edited to fix some bugs. */
+package com.sun.xml.internal.rngom.parse.compact;
+
+import com.sun.xml.internal.rngom.util.Utf16;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+
+import java.io.IOException;
+
+/**
+ * An implementation of interface CharStream, where the stream is assumed to
+ * contain 16-bit unicode characters.
+ */
+public final class UCode_UCodeESC_CharStream {
+  public static final boolean staticFlag = false;
+
+  static final int hexval(char c) {
+    switch (c) {
+    case '0':
+      return 0;
+    case '1':
+      return 1;
+    case '2':
+      return 2;
+    case '3':
+      return 3;
+    case '4':
+      return 4;
+    case '5':
+      return 5;
+    case '6':
+      return 6;
+    case '7':
+      return 7;
+    case '8':
+      return 8;
+    case '9':
+      return 9;
+
+    case 'a':
+    case 'A':
+      return 10;
+    case 'b':
+    case 'B':
+      return 11;
+    case 'c':
+    case 'C':
+      return 12;
+    case 'd':
+    case 'D':
+      return 13;
+    case 'e':
+    case 'E':
+      return 14;
+    case 'f':
+    case 'F':
+      return 15;
+    }
+    return -1;
+  }
+
+  public int bufpos = -1;
+  int bufsize;
+  int available;
+  int tokenBegin;
+  private int bufline[];
+  private int bufcolumn[];
+
+  private int column = 0;
+  private int line = 1;
+
+  private java.io.Reader inputStream;
+  private boolean closed = false;
+
+  private boolean prevCharIsLF = false;
+
+  private char[] nextCharBuf;
+  private char[] buffer;
+  private int maxNextCharInd = 0;
+  private int nextCharInd = -1;
+  private int inBuf = 0;
+
+  private final void ExpandBuff(boolean wrapAround) {
+    char[] newbuffer = new char[bufsize + 2048];
+    int newbufline[] = new int[bufsize + 2048];
+    int newbufcolumn[] = new int[bufsize + 2048];
+
+    if (wrapAround) {
+      System.arraycopy(buffer, tokenBegin, newbuffer, 0, bufsize - tokenBegin);
+      System.arraycopy(buffer, 0, newbuffer,
+                       bufsize - tokenBegin, bufpos);
+      buffer = newbuffer;
+
+      System.arraycopy(bufline, tokenBegin, newbufline, 0, bufsize - tokenBegin);
+      System.arraycopy(bufline, 0, newbufline, bufsize - tokenBegin, bufpos);
+      bufline = newbufline;
+
+      System.arraycopy(bufcolumn, tokenBegin, newbufcolumn, 0, bufsize - tokenBegin);
+      System.arraycopy(bufcolumn, 0, newbufcolumn, bufsize - tokenBegin, bufpos);
+      bufcolumn = newbufcolumn;
+
+      bufpos += (bufsize - tokenBegin);
+    }
+    else {
+      System.arraycopy(buffer, tokenBegin, newbuffer, 0, bufsize - tokenBegin);
+      buffer = newbuffer;
+
+      System.arraycopy(bufline, tokenBegin, newbufline, 0, bufsize - tokenBegin);
+      bufline = newbufline;
+
+      System.arraycopy(bufcolumn, tokenBegin, newbufcolumn, 0, bufsize - tokenBegin);
+      bufcolumn = newbufcolumn;
+
+      bufpos -= tokenBegin;
+    }
+
+    available = (bufsize += 2048);
+    tokenBegin = 0;
+  }
+
+  private final void FillBuff() throws EOFException {
+    int i;
+    if (maxNextCharInd == 4096)
+      maxNextCharInd = nextCharInd = 0;
+
+    if (closed)
+      throw new EOFException();
+    try {
+      if ((i = inputStream.read(nextCharBuf, maxNextCharInd, 4096 - maxNextCharInd)) == -1) {
+        closed = true;
+        inputStream.close();
+        throw new EOFException();
+      }
+      else
+        maxNextCharInd += i;
+    }
+    catch (IOException e) {
+      throw new BuildException(e);
+    }
+  }
+
+  private final char ReadChar() throws EOFException {
+    if (++nextCharInd >= maxNextCharInd)
+      FillBuff();
+
+    return nextCharBuf[nextCharInd];
+  }
+
+  private final char PeekChar() throws EOFException {
+    char c = ReadChar();
+    --nextCharInd;
+    return c;
+  }
+
+  public final char BeginToken() throws EOFException {
+    if (inBuf > 0) {
+      --inBuf;
+      return buffer[tokenBegin = (bufpos == bufsize - 1) ? (bufpos = 0)
+              : ++bufpos];
+    }
+
+    tokenBegin = 0;
+    bufpos = -1;
+
+    return readChar();
+  }
+
+  private final void AdjustBuffSize() {
+    if (available == bufsize) {
+      if (tokenBegin > 2048) {
+        bufpos = 0;
+        available = tokenBegin;
+      }
+      else
+        ExpandBuff(false);
+    }
+    else if (available > tokenBegin)
+      available = bufsize;
+    else if ((tokenBegin - available) < 2048)
+      ExpandBuff(true);
+    else
+      available = tokenBegin;
+  }
+
+  private final void UpdateLineColumn(char c) {
+    column++;
+
+    if (prevCharIsLF) {
+      prevCharIsLF = false;
+      line += (column = 1);
+    }
+
+    switch (c) {
+    case NEWLINE_MARKER:
+      prevCharIsLF = true;
+      break;
+    case '\t':
+      column--;
+      column += (8 - (column & 07));
+      break;
+    default :
+      break;
+    }
+
+    bufline[bufpos] = line;
+    bufcolumn[bufpos] = column;
+  }
+
+  private final char NEWLINE_MARKER = '\u0000';
+
+  public final char readChar() throws EOFException {
+    if (inBuf > 0) {
+      --inBuf;
+      return buffer[(bufpos == bufsize - 1) ? (bufpos = 0) : ++bufpos];
+    }
+
+    char c;
+    try {
+      c = ReadChar();
+      switch (c) {
+      case '\r':
+        c = NEWLINE_MARKER;
+        try {
+          if (PeekChar() == '\n')
+            ReadChar();
+        }
+        catch (EOFException e) {
+        }
+        break;
+      case '\n':
+        c = NEWLINE_MARKER;
+        break;
+      case '\t':
+        break;
+      default:
+        if (c >= 0x20) {
+          if (Utf16.isSurrogate(c)) {
+            if (Utf16.isSurrogate2(c))
+              throw new EscapeSyntaxException("illegal_surrogate_pair", line, column + 1);
+            if (++bufpos == available)
+              AdjustBuffSize();
+            buffer[bufpos] = c;
+            // UpdateLineColumn(c);
+            try {
+              c = ReadChar();
+            }
+            catch (EOFException e) {
+              throw new EscapeSyntaxException("illegal_surrogate_pair", line, column + 1);
+            }
+            if (!Utf16.isSurrogate2(c))
+              throw new EscapeSyntaxException("illegal_surrogate_pair", line, column + 2);
+          }
+          break;
+        }
+        // fall through
+      case '\uFFFE':
+      case '\uFFFF':
+        throw new EscapeSyntaxException("illegal_char_code", line, column + 1);
+      }
+    }
+    catch (EOFException e) {
+      if (bufpos == -1) {
+        if (++bufpos == available)
+          AdjustBuffSize();
+        bufline[bufpos] = line;
+        bufcolumn[bufpos] = column;
+      }
+      throw e;
+    }
+    if (++bufpos == available)
+      AdjustBuffSize();
+    buffer[bufpos] = c;
+    UpdateLineColumn(c);
+    try {
+      if (c != '\\' || PeekChar() != 'x')
+        return c;
+    }
+    catch (EOFException e) {
+      return c;
+    }
+
+    int xCnt = 1;
+    for (;;) {
+      ReadChar();
+      if (++bufpos == available)
+        AdjustBuffSize();
+      buffer[bufpos] = 'x';
+      UpdateLineColumn('x');
+      try {
+        c = PeekChar();
+      }
+      catch (EOFException e) {
+        backup(xCnt);
+        return '\\';
+      }
+      if (c == '{') {
+        ReadChar();
+        column++;
+        // backup past the 'x's
+        bufpos -= xCnt;
+        if (bufpos < 0)
+          bufpos += bufsize;
+        break;
+      }
+      if (c != 'x') {
+        backup(xCnt);
+        return '\\';
+      }
+      xCnt++;
+    }
+    try {
+      int scalarValue = hexval(ReadChar());
+      column++;
+      if (scalarValue < 0)
+        throw new EscapeSyntaxException("illegal_hex_digit", line, column);
+      while ((c = ReadChar()) != '}') {
+        column++;
+        int n = hexval(c);
+        if (n < 0)
+          throw new EscapeSyntaxException("illegal_hex_digit", line, column);
+        scalarValue <<= 4;
+        scalarValue |= n;
+        if (scalarValue >= 0x110000)
+          throw new EscapeSyntaxException("char_code_too_big", line, column);
+      }
+      column++; // for the '}'
+      if (scalarValue <= 0xFFFF) {
+        c = (char)scalarValue;
+        switch (c) {
+        case '\n':
+        case '\r':
+        case '\t':
+          break;
+        default:
+          if (c >= 0x20 && !Utf16.isSurrogate(c))
+            break;
+          // fall through
+        case '\uFFFE':
+        case '\uFFFF':
+          throw new EscapeSyntaxException("illegal_char_code_ref", line, column);
+        }
+        buffer[bufpos] = c;
+        return c;
+      }
+      c = Utf16.surrogate1(scalarValue);
+      buffer[bufpos] = c;
+      int bufpos1 = bufpos;
+      if (++bufpos == bufsize)
+        bufpos = 0;
+      buffer[bufpos] = Utf16.surrogate2(scalarValue);
+      bufline[bufpos] = bufline[bufpos1];
+      bufcolumn[bufpos] = bufcolumn[bufpos1];
+      backup(1);
+      return c;
+    }
+    catch (EOFException e) {
+      throw new EscapeSyntaxException("incomplete_escape", line, column);
+    }
+  }
+
+  /**
+   * @deprecated
+   * @see #getEndColumn
+   */
+
+  public final int getColumn() {
+    return bufcolumn[bufpos];
+  }
+
+  /**
+   * @deprecated
+   * @see #getEndLine
+   */
+
+  public final int getLine() {
+    return bufline[bufpos];
+  }
+
+  public final int getEndColumn() {
+    return bufcolumn[bufpos];
+  }
+
+  public final int getEndLine() {
+    return bufline[bufpos];
+  }
+
+  public final int getBeginColumn() {
+    return bufcolumn[tokenBegin];
+  }
+
+  public final int getBeginLine() {
+    return bufline[tokenBegin];
+  }
+
+  public final void backup(int amount) {
+
+    inBuf += amount;
+    if ((bufpos -= amount) < 0)
+      bufpos += bufsize;
+  }
+
+  public UCode_UCodeESC_CharStream(java.io.Reader dstream,
+                                   int startline, int startcolumn, int buffersize) {
+    inputStream = dstream;
+    line = startline;
+    column = startcolumn - 1;
+
+    available = bufsize = buffersize;
+    buffer = new char[buffersize];
+    bufline = new int[buffersize];
+    bufcolumn = new int[buffersize];
+    nextCharBuf = new char[4096];
+    skipBOM();
+  }
+
+  public UCode_UCodeESC_CharStream(java.io.Reader dstream,
+                                   int startline, int startcolumn) {
+    this(dstream, startline, startcolumn, 4096);
+  }
+
+  public void ReInit(java.io.Reader dstream,
+                     int startline, int startcolumn, int buffersize) {
+    inputStream = dstream;
+    closed = false;
+    line = startline;
+    column = startcolumn - 1;
+
+    if (buffer == null || buffersize != buffer.length) {
+      available = bufsize = buffersize;
+      buffer = new char[buffersize];
+      bufline = new int[buffersize];
+      bufcolumn = new int[buffersize];
+      nextCharBuf = new char[4096];
+    }
+    prevCharIsLF = false;
+    tokenBegin = inBuf = maxNextCharInd = 0;
+    nextCharInd = bufpos = -1;
+    skipBOM();
+  }
+
+  public void ReInit(java.io.Reader dstream,
+                     int startline, int startcolumn) {
+    ReInit(dstream, startline, startcolumn, 4096);
+  }
+
+  public UCode_UCodeESC_CharStream(java.io.InputStream dstream, int startline,
+                                   int startcolumn, int buffersize) {
+    this(new java.io.InputStreamReader(dstream), startline, startcolumn, 4096);
+  }
+
+  public UCode_UCodeESC_CharStream(java.io.InputStream dstream, int startline,
+                                   int startcolumn) {
+    this(dstream, startline, startcolumn, 4096);
+  }
+
+  public void ReInit(java.io.InputStream dstream, int startline,
+                     int startcolumn, int buffersize) {
+    ReInit(new java.io.InputStreamReader(dstream), startline, startcolumn, 4096);
+  }
+
+  public void ReInit(java.io.InputStream dstream, int startline,
+                     int startcolumn) {
+    ReInit(dstream, startline, startcolumn, 4096);
+  }
+
+  static private final char BOM = '\ufeff';
+
+  private void skipBOM() {
+    try {
+      if (PeekChar() == BOM)
+        ReadChar();
+    }
+    catch (EOFException e) {
+    }
+  }
+
+  public final String GetImage() {
+    if (bufpos >= tokenBegin)
+      return new String(buffer, tokenBegin, bufpos - tokenBegin + 1);
+    else
+      return new String(buffer, tokenBegin, bufsize - tokenBegin) +
+              new String(buffer, 0, bufpos + 1);
+  }
+
+  public final char[] GetSuffix(int len) {
+    char[] ret = new char[len];
+
+    if ((bufpos + 1) >= len)
+      System.arraycopy(buffer, bufpos - len + 1, ret, 0, len);
+    else {
+      System.arraycopy(buffer, bufsize - (len - bufpos - 1), ret, 0,
+                       len - bufpos - 1);
+      System.arraycopy(buffer, 0, ret, len - bufpos - 1, bufpos + 1);
+    }
+
+    return ret;
+  }
+
+  public void Done() {
+    nextCharBuf = null;
+    buffer = null;
+    bufline = null;
+    bufcolumn = null;
+  }
+
+  /**
+   * Method to adjust line and column numbers for the start of a token.<BR>
+   */
+  public void adjustBeginLineColumn(int newLine, int newCol) {
+    int start = tokenBegin;
+    int len;
+
+    if (bufpos >= tokenBegin) {
+      len = bufpos - tokenBegin + inBuf + 1;
+    }
+    else {
+      len = bufsize - tokenBegin + bufpos + 1 + inBuf;
+    }
+
+    int i = 0, j = 0, k = 0;
+    int nextColDiff = 0, columnDiff = 0;
+
+    while (i < len &&
+            bufline[j = start % bufsize] == bufline[k = ++start % bufsize]) {
+      bufline[j] = newLine;
+      nextColDiff = columnDiff + bufcolumn[k] - bufcolumn[j];
+      bufcolumn[j] = newCol + columnDiff;
+      columnDiff = nextColDiff;
+      i++;
+    }
+
+    if (i < len) {
+      bufline[j] = newLine++;
+      bufcolumn[j] = newCol + columnDiff;
+
+      while (i++ < len) {
+        if (bufline[j = start % bufsize] != bufline[++start % bufsize])
+          bufline[j] = newLine++;
+        else
+          bufline[j] = newLine;
+      }
+    }
+
+    line = bufline[j];
+    column = bufcolumn[j];
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/AnnotationsHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/AnnotationsHost.java
new file mode 100644
index 0000000..0e2e646
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/AnnotationsHost.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+class AnnotationsHost extends Base implements Annotations {
+    final Annotations lhs;
+    final Annotations rhs;
+
+    AnnotationsHost( Annotations lhs, Annotations rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public void addAttribute(String ns, String localName, String prefix,
+        String value, Location _loc) throws BuildException {
+        LocationHost loc = cast(_loc);
+        lhs.addAttribute(ns, localName, prefix, value, loc.lhs);
+        rhs.addAttribute(ns, localName, prefix, value, loc.rhs);
+    }
+
+    public void addComment(CommentList _comments) throws BuildException {
+        CommentListHost comments = (CommentListHost) _comments;
+        lhs.addComment(comments==null?null:comments.lhs);
+        rhs.addComment(comments==null?null:comments.rhs);
+    }
+
+    public void addElement(ParsedElementAnnotation _ea) throws BuildException {
+        ParsedElementAnnotationHost ea = (ParsedElementAnnotationHost) _ea;
+        lhs.addElement(ea.lhs);
+        rhs.addElement(ea.rhs);
+    }
+
+    public void addLeadingComment(CommentList _comments) throws BuildException {
+        CommentListHost comments = (CommentListHost) _comments;
+        lhs.addLeadingComment(comments.lhs);
+        rhs.addLeadingComment(comments.rhs);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/Base.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/Base.java
new file mode 100644
index 0000000..f48cd2b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/Base.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.om.Location;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class Base {
+    protected AnnotationsHost cast( Annotations ann ) {
+        if(ann==null)
+            return nullAnnotations;
+        else
+            return (AnnotationsHost)ann;
+    }
+
+    protected LocationHost cast( Location loc ) {
+        if(loc==null)
+            return nullLocation;
+        else
+            return (LocationHost)loc;
+    }
+
+    private static final AnnotationsHost nullAnnotations = new AnnotationsHost(null,null);
+    private static final LocationHost nullLocation = new LocationHost(null,null);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/CommentListHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/CommentListHost.java
new file mode 100644
index 0000000..4b42441
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/CommentListHost.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.om.Location;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+class CommentListHost extends Base implements CommentList {
+
+    final CommentList lhs;
+    final CommentList rhs;
+
+    CommentListHost(CommentList lhs, CommentList rhs) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public void addComment(String value, Location _loc) throws BuildException {
+        LocationHost loc = cast(_loc);
+        if(lhs!=null)
+            lhs.addComment(value,loc.lhs);
+        if(rhs!=null)
+            rhs.addComment(value,loc.rhs);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/DataPatternBuilderHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/DataPatternBuilderHost.java
new file mode 100644
index 0000000..c80b7ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/DataPatternBuilderHost.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.Context;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class DataPatternBuilderHost extends Base implements DataPatternBuilder {
+    final DataPatternBuilder lhs;
+    final DataPatternBuilder rhs;
+
+    DataPatternBuilderHost( DataPatternBuilder lhs, DataPatternBuilder rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public void addParam(String name, String value, Context context, String ns, Location _loc, Annotations _anno) throws BuildException {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        lhs.addParam( name, value, context, ns, loc.lhs, anno.lhs );
+        rhs.addParam( name, value, context, ns, loc.rhs, anno.rhs );
+    }
+
+    public void annotation(ParsedElementAnnotation _ea) {
+        ParsedElementAnnotationHost ea = (ParsedElementAnnotationHost) _ea;
+
+        lhs.annotation(ea.lhs);
+        rhs.annotation(ea.rhs);
+    }
+
+    public ParsedPattern makePattern(Location _loc, Annotations _anno) throws BuildException {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makePattern( loc.lhs, anno.lhs ),
+            rhs.makePattern( loc.rhs, anno.rhs ));
+    }
+
+    public ParsedPattern makePattern(ParsedPattern _except, Location _loc, Annotations _anno) throws BuildException {
+        ParsedPatternHost except = (ParsedPatternHost) _except;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makePattern(except.lhs, loc.lhs, anno.lhs),
+            rhs.makePattern(except.rhs, loc.rhs, anno.rhs));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/DivHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/DivHost.java
new file mode 100644
index 0000000..1493bfa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/DivHost.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.Div;
+import com.sun.xml.internal.rngom.ast.om.Location;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class DivHost extends GrammarSectionHost implements Div {
+    private final Div lhs;
+    private final Div rhs;
+
+    DivHost(Div lhs, Div rhs) {
+        super(lhs, rhs);
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public void endDiv(Location _loc, Annotations _anno) throws BuildException {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        lhs.endDiv( loc.lhs, anno.lhs );
+        rhs.endDiv( loc.rhs, anno.rhs );
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ElementAnnotationBuilderHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ElementAnnotationBuilderHost.java
new file mode 100644
index 0000000..bf81d57
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ElementAnnotationBuilderHost.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class ElementAnnotationBuilderHost extends AnnotationsHost implements ElementAnnotationBuilder {
+    final ElementAnnotationBuilder lhs;
+    final ElementAnnotationBuilder rhs;
+
+    ElementAnnotationBuilderHost( ElementAnnotationBuilder lhs, ElementAnnotationBuilder rhs ) {
+        super(lhs,rhs);
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public void addText(String value, Location _loc, CommentList _comments) throws BuildException {
+        LocationHost loc = cast(_loc);
+        CommentListHost comments = (CommentListHost) _comments;
+
+        lhs.addText( value, loc.lhs, comments==null?null:comments.lhs );
+        rhs.addText( value, loc.rhs, comments==null?null:comments.rhs );
+    }
+
+    public ParsedElementAnnotation makeElementAnnotation() throws BuildException {
+        return new ParsedElementAnnotationHost(
+            lhs.makeElementAnnotation(),
+            rhs.makeElementAnnotation() );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/GrammarHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/GrammarHost.java
new file mode 100644
index 0000000..a35ab1d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/GrammarHost.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+
+/**
+ * Wraps {@link Grammar} and provides error checking.
+ *
+ * <p>
+ * The following errors are checked by this host:
+ *
+ * <ol>
+ *  <li>referenced to undefined patterns.
+ * </ol>
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class GrammarHost extends ScopeHost implements Grammar {
+    final Grammar lhs;
+    final Grammar rhs;
+
+    public GrammarHost(Grammar lhs,Grammar rhs) {
+        super(lhs,rhs);
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public ParsedPattern endGrammar(Location _loc, Annotations _anno) throws BuildException {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.endGrammar(loc.lhs, anno.lhs),
+            rhs.endGrammar(loc.rhs, anno.rhs));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/GrammarSectionHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/GrammarSectionHost.java
new file mode 100644
index 0000000..48ef7da
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/GrammarSectionHost.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.Div;
+import com.sun.xml.internal.rngom.ast.builder.GrammarSection;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class GrammarSectionHost extends Base implements GrammarSection {
+    private final GrammarSection lhs;
+    private final GrammarSection rhs;
+
+    GrammarSectionHost( GrammarSection lhs, GrammarSection rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+        if(lhs==null || rhs==null)
+            throw new IllegalArgumentException();
+    }
+
+    public void define(String name, Combine combine, ParsedPattern _pattern,
+        Location _loc, Annotations _anno) throws BuildException {
+        ParsedPatternHost pattern = (ParsedPatternHost) _pattern;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        lhs.define(name, combine, pattern.lhs, loc.lhs, anno.lhs);
+        rhs.define(name, combine, pattern.rhs, loc.rhs, anno.rhs);
+    }
+
+    public Div makeDiv() {
+        return new DivHost( lhs.makeDiv(), rhs.makeDiv() );
+    }
+
+    public Include makeInclude() {
+        Include l = lhs.makeInclude();
+        if(l==null) return null;
+        return new IncludeHost( l, rhs.makeInclude() );
+    }
+
+    public void topLevelAnnotation(ParsedElementAnnotation _ea) throws BuildException {
+        ParsedElementAnnotationHost ea = (ParsedElementAnnotationHost) _ea;
+        lhs.topLevelAnnotation(ea==null?null:ea.lhs);
+        rhs.topLevelAnnotation(ea==null?null:ea.rhs);
+    }
+
+    public void topLevelComment(CommentList _comments) throws BuildException {
+        CommentListHost comments = (CommentListHost) _comments;
+
+        lhs.topLevelComment(comments==null?null:comments.lhs);
+        rhs.topLevelComment(comments==null?null:comments.rhs);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/IncludeHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/IncludeHost.java
new file mode 100644
index 0000000..0385ec7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/IncludeHost.java
@@ -0,0 +1,58 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class IncludeHost extends GrammarSectionHost implements Include {
+
+    private final Include lhs;
+    private final Include rhs;
+
+    IncludeHost(Include lhs, Include rhs) {
+        super(lhs, rhs);
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public void endInclude(Parseable current, String uri, String ns, Location _loc, Annotations _anno) throws BuildException, IllegalSchemaException {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        lhs.endInclude( current, uri, ns, loc.lhs, anno.lhs );
+        rhs.endInclude( current, uri, ns, loc.rhs, anno.rhs );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/LocationHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/LocationHost.java
new file mode 100644
index 0000000..363ec50
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/LocationHost.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.om.Location;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class LocationHost implements Location {
+    final Location lhs;
+    final Location rhs;
+
+    LocationHost( Location lhs, Location rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/NameClassBuilderHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/NameClassBuilderHost.java
new file mode 100644
index 0000000..039520c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/NameClassBuilderHost.java
@@ -0,0 +1,145 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+
+import java.util.List;
+import java.util.ArrayList;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class NameClassBuilderHost extends Base implements NameClassBuilder {
+    final NameClassBuilder lhs;
+    final NameClassBuilder rhs;
+
+    NameClassBuilderHost( NameClassBuilder lhs, NameClassBuilder rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public ParsedNameClass annotate(ParsedNameClass _nc, Annotations _anno) throws BuildException {
+        ParsedNameClassHost nc = (ParsedNameClassHost) _nc;
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedNameClassHost(
+            lhs.annotate(nc.lhs, anno.lhs),
+            rhs.annotate(nc.rhs, anno.rhs) );
+    }
+
+    public ParsedNameClass annotateAfter(ParsedNameClass _nc, ParsedElementAnnotation _e) throws BuildException {
+        ParsedNameClassHost nc = (ParsedNameClassHost) _nc;
+        ParsedElementAnnotationHost e = (ParsedElementAnnotationHost) _e;
+
+        return new ParsedNameClassHost(
+            lhs.annotateAfter(nc.lhs, e.lhs),
+            rhs.annotateAfter(nc.rhs, e.rhs));
+    }
+
+    public ParsedNameClass commentAfter(ParsedNameClass _nc, CommentList _comments) throws BuildException {
+        ParsedNameClassHost nc = (ParsedNameClassHost) _nc;
+        CommentListHost comments = (CommentListHost) _comments;
+
+        return new ParsedNameClassHost(
+            lhs.commentAfter(nc.lhs, comments==null?null:comments.lhs),
+            rhs.commentAfter(nc.rhs, comments==null?null:comments.rhs));
+    }
+
+    public ParsedNameClass makeChoice(List _nameClasses, Location _loc, Annotations _anno) {
+        List<ParsedNameClass> lnc = new ArrayList<ParsedNameClass>();
+        List<ParsedNameClass> rnc = new ArrayList<ParsedNameClass>();
+        for( int i=0; i<_nameClasses.size(); i++ ) {
+            lnc.add(((ParsedNameClassHost)_nameClasses.get(i)).lhs);
+            rnc.add(((ParsedNameClassHost)_nameClasses.get(i)).rhs);
+        }
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedNameClassHost(
+            lhs.makeChoice( lnc, loc.lhs, anno.lhs ),
+            rhs.makeChoice( rnc, loc.rhs, anno.rhs ) );
+    }
+
+    public ParsedNameClass makeName(String ns, String localName, String prefix, Location _loc, Annotations _anno) {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedNameClassHost(
+            lhs.makeName( ns, localName, prefix, loc.lhs, anno.lhs ),
+            rhs.makeName( ns, localName, prefix, loc.rhs, anno.rhs ) );
+    }
+
+    public ParsedNameClass makeNsName(String ns, Location _loc, Annotations _anno) {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedNameClassHost(
+            lhs.makeNsName( ns, loc.lhs, anno.lhs ),
+            rhs.makeNsName( ns, loc.rhs, anno.rhs ) );
+    }
+
+    public ParsedNameClass makeNsName(String ns, ParsedNameClass _except, Location _loc, Annotations _anno) {
+        ParsedNameClassHost except = (ParsedNameClassHost) _except;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedNameClassHost(
+            lhs.makeNsName( ns, except.lhs, loc.lhs, anno.lhs ),
+            rhs.makeNsName( ns, except.rhs, loc.rhs, anno.rhs ) );
+    }
+
+    public ParsedNameClass makeAnyName(Location _loc, Annotations _anno) {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedNameClassHost(
+            lhs.makeAnyName( loc.lhs, anno.lhs ),
+            rhs.makeAnyName( loc.rhs, anno.rhs ) );
+    }
+
+    public ParsedNameClass makeAnyName(ParsedNameClass _except, Location _loc, Annotations _anno) {
+        ParsedNameClassHost except = (ParsedNameClassHost) _except;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedNameClassHost(
+            lhs.makeAnyName( except.lhs, loc.lhs, anno.lhs ),
+            rhs.makeAnyName( except.rhs, loc.rhs, anno.rhs ) );
+    }
+
+    public ParsedNameClass makeErrorNameClass() {
+        return new ParsedNameClassHost( lhs.makeErrorNameClass(), rhs.makeErrorNameClass() );
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedElementAnnotationHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedElementAnnotationHost.java
new file mode 100644
index 0000000..d6fc53e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedElementAnnotationHost.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class ParsedElementAnnotationHost implements ParsedElementAnnotation {
+    final ParsedElementAnnotation lhs;
+    final ParsedElementAnnotation rhs;
+
+    ParsedElementAnnotationHost( ParsedElementAnnotation lhs, ParsedElementAnnotation rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedNameClassHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedNameClassHost.java
new file mode 100644
index 0000000..a6a11f8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedNameClassHost.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+final class ParsedNameClassHost implements ParsedNameClass {
+    final ParsedNameClass lhs;
+    final ParsedNameClass rhs;
+
+    ParsedNameClassHost( ParsedNameClass lhs, ParsedNameClass rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedPatternHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedPatternHost.java
new file mode 100644
index 0000000..c6cc785
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ParsedPatternHost.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class ParsedPatternHost implements ParsedPattern {
+    public final ParsedPattern lhs;
+    public final ParsedPattern rhs;
+
+    ParsedPatternHost( ParsedPattern lhs, ParsedPattern rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/SchemaBuilderHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/SchemaBuilderHost.java
new file mode 100644
index 0000000..1260b6c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/SchemaBuilderHost.java
@@ -0,0 +1,352 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.Context;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+
+import java.util.List;
+import java.util.ArrayList;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class SchemaBuilderHost extends Base implements SchemaBuilder {
+    final SchemaBuilder lhs;
+    final SchemaBuilder rhs;
+
+    public SchemaBuilderHost( SchemaBuilder lhs, SchemaBuilder rhs ) {
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public ParsedPattern annotate(ParsedPattern _p, Annotations _anno)
+        throws BuildException {
+
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        AnnotationsHost a = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.annotate(p.lhs, a.lhs),
+            rhs.annotate(p.lhs, a.lhs) );
+    }
+
+    public ParsedPattern annotateAfter(ParsedPattern _p,
+        ParsedElementAnnotation _e) throws BuildException {
+
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        ParsedElementAnnotationHost e = (ParsedElementAnnotationHost) _e;
+        return new ParsedPatternHost(
+            lhs.annotateAfter(p.lhs, e.lhs),
+            rhs.annotateAfter(p.rhs, e.rhs));
+    }
+
+    public ParsedPattern commentAfter(ParsedPattern _p, CommentList _comments)
+        throws BuildException {
+
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        CommentListHost comments = (CommentListHost) _comments;
+
+        return new ParsedPatternHost(
+            lhs.commentAfter(p.lhs, comments==null?null:comments.lhs),
+            rhs.commentAfter(p.rhs, comments==null?null:comments.rhs));
+    }
+
+    public ParsedPattern expandPattern(ParsedPattern _p) throws BuildException, IllegalSchemaException {
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        return new ParsedPatternHost(
+            lhs.expandPattern(p.lhs),
+            rhs.expandPattern(p.rhs));
+    }
+
+    public NameClassBuilder getNameClassBuilder() throws BuildException {
+        return new NameClassBuilderHost( lhs.getNameClassBuilder(), rhs.getNameClassBuilder() );
+    }
+
+    public Annotations makeAnnotations(CommentList _comments, Context context) {
+        CommentListHost comments = (CommentListHost) _comments;
+        Annotations l = lhs.makeAnnotations((comments!=null)?comments.lhs:null, context);
+        Annotations r = rhs.makeAnnotations((comments!=null)?comments.rhs:null, context);
+        if(l==null || r==null)
+            throw new IllegalArgumentException("annotations cannot be null");
+        return new AnnotationsHost(l,r);
+    }
+
+    public ParsedPattern makeAttribute(ParsedNameClass _nc, ParsedPattern _p,
+        Location _loc, Annotations _anno) throws BuildException {
+
+        ParsedNameClassHost nc = (ParsedNameClassHost) _nc;
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeAttribute(nc.lhs, p.lhs, loc.lhs, anno.lhs),
+            rhs.makeAttribute(nc.rhs, p.rhs, loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeChoice(List patterns,
+        Location _loc, Annotations _anno) throws BuildException {
+
+        List<ParsedPattern> lp = new ArrayList<ParsedPattern>();
+        List<ParsedPattern> rp = new ArrayList<ParsedPattern>();
+        for( int i=0; i<patterns.size(); i++ ) {
+            lp.add( ((ParsedPatternHost)patterns.get(i)).lhs);
+            rp.add( ((ParsedPatternHost)patterns.get(i)).rhs);
+        }
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeChoice(lp, loc.lhs, anno.lhs),
+            rhs.makeChoice(rp, loc.rhs, anno.rhs));
+    }
+
+    public CommentList makeCommentList() {
+        return new CommentListHost(
+            lhs.makeCommentList(),
+            rhs.makeCommentList() );
+    }
+
+    public DataPatternBuilder makeDataPatternBuilder(String datatypeLibrary,
+        String type, Location _loc) throws BuildException {
+        LocationHost loc = cast(_loc);
+
+        return new DataPatternBuilderHost(
+            lhs.makeDataPatternBuilder(datatypeLibrary, type, loc.lhs),
+            rhs.makeDataPatternBuilder(datatypeLibrary, type, loc.rhs) );
+    }
+
+    public ParsedPattern makeElement(ParsedNameClass _nc, ParsedPattern _p,
+        Location _loc, Annotations _anno) throws BuildException {
+
+        ParsedNameClassHost nc = (ParsedNameClassHost) _nc;
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeElement(nc.lhs, p.lhs, loc.lhs, anno.lhs),
+            rhs.makeElement(nc.rhs, p.rhs, loc.rhs, anno.rhs));
+    }
+
+    public ElementAnnotationBuilder makeElementAnnotationBuilder(String ns,
+        String localName, String prefix, Location _loc, CommentList _comments,
+        Context context) {
+        LocationHost loc = cast(_loc);
+        CommentListHost comments = (CommentListHost) _comments;
+
+        return new ElementAnnotationBuilderHost(
+            lhs.makeElementAnnotationBuilder(ns, localName, prefix, loc.lhs, comments==null?null:comments.lhs, context),
+            rhs.makeElementAnnotationBuilder(ns, localName, prefix, loc.rhs, comments==null?null:comments.rhs, context) );
+    }
+
+    public ParsedPattern makeEmpty(Location _loc, Annotations _anno) {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeEmpty(loc.lhs, anno.lhs),
+            rhs.makeEmpty(loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeErrorPattern() {
+        return new ParsedPatternHost(
+            lhs.makeErrorPattern(),
+            rhs.makeErrorPattern() );
+    }
+
+    public ParsedPattern makeExternalRef(Parseable current, String uri,
+        String ns, Scope _scope, Location _loc, Annotations _anno)
+        throws BuildException, IllegalSchemaException {
+
+        ScopeHost scope = (ScopeHost) _scope;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeExternalRef(current, uri, ns, scope.lhs, loc.lhs, anno.lhs),
+            rhs.makeExternalRef(current, uri, ns, scope.rhs, loc.rhs, anno.rhs) );
+    }
+
+    public Grammar makeGrammar(Scope _parent) {
+        ScopeHost parent = (ScopeHost) _parent;
+
+        return new GrammarHost(
+            lhs.makeGrammar((parent!=null)?parent.lhs:null),
+            rhs.makeGrammar((parent!=null)?parent.rhs:null) );
+    }
+
+    public ParsedPattern makeGroup(List patterns,
+        Location _loc, Annotations _anno) throws BuildException {
+
+        List<ParsedPattern> lp = new ArrayList<ParsedPattern>();
+        List<ParsedPattern> rp = new ArrayList<ParsedPattern>();
+        for( int i=0; i<patterns.size(); i++ ) {
+            lp.add( ((ParsedPatternHost)patterns.get(i)).lhs);
+            rp.add( ((ParsedPatternHost)patterns.get(i)).rhs);
+        }
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeGroup(lp, loc.lhs, anno.lhs),
+            rhs.makeGroup(rp, loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeInterleave(List patterns,
+        Location _loc, Annotations _anno) throws BuildException {
+
+        List<ParsedPattern> lp = new ArrayList<ParsedPattern>();
+        List<ParsedPattern> rp = new ArrayList<ParsedPattern>();
+        for( int i=0; i<patterns.size(); i++ ) {
+            lp.add( ((ParsedPatternHost)patterns.get(i)).lhs);
+            rp.add( ((ParsedPatternHost)patterns.get(i)).rhs);
+        }
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeInterleave(lp, loc.lhs, anno.lhs),
+            rhs.makeInterleave(rp, loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeList(ParsedPattern _p, Location _loc,
+        Annotations _anno) throws BuildException {
+
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeList(p.lhs, loc.lhs, anno.lhs),
+            rhs.makeList(p.rhs, loc.rhs, anno.rhs));
+    }
+
+    public Location makeLocation(String systemId, int lineNumber,
+        int columnNumber) {
+        return new LocationHost(
+            lhs.makeLocation(systemId, lineNumber, columnNumber),
+            rhs.makeLocation(systemId, lineNumber, columnNumber));
+    }
+
+    public ParsedPattern makeMixed(ParsedPattern _p, Location _loc,
+        Annotations _anno) throws BuildException {
+
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeMixed(p.lhs, loc.lhs, anno.lhs),
+            rhs.makeMixed(p.rhs, loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeNotAllowed(Location _loc, Annotations _anno) {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeNotAllowed(loc.lhs, anno.lhs),
+            rhs.makeNotAllowed(loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeOneOrMore(ParsedPattern _p, Location _loc,
+        Annotations _anno) throws BuildException {
+
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeOneOrMore(p.lhs, loc.lhs, anno.lhs),
+            rhs.makeOneOrMore(p.rhs, loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeZeroOrMore(ParsedPattern _p, Location _loc,
+        Annotations _anno) throws BuildException {
+
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeZeroOrMore(p.lhs, loc.lhs, anno.lhs),
+            rhs.makeZeroOrMore(p.rhs, loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeOptional(ParsedPattern _p, Location _loc,
+        Annotations _anno) throws BuildException {
+
+        ParsedPatternHost p = (ParsedPatternHost) _p;
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeOptional(p.lhs, loc.lhs, anno.lhs),
+            rhs.makeOptional(p.rhs, loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeText(Location _loc, Annotations _anno) {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeText(loc.lhs, anno.lhs),
+            rhs.makeText(loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeValue(String datatypeLibrary, String type,
+        String value, Context c, String ns, Location _loc, Annotations _anno)
+        throws BuildException {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeValue(datatypeLibrary,type,value,c,ns,loc.lhs,anno.lhs),
+            rhs.makeValue(datatypeLibrary,type,value,c,ns,loc.rhs,anno.rhs));
+    }
+
+    public boolean usesComments() {
+        return lhs.usesComments() || rhs.usesComments();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ScopeHost.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ScopeHost.java
new file mode 100644
index 0000000..c5b12da
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/ScopeHost.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.host;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+
+/**
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class ScopeHost extends GrammarSectionHost implements Scope {
+    protected final Scope lhs;
+    protected final Scope rhs;
+
+    protected ScopeHost( Scope lhs, Scope rhs ) {
+        super(lhs,rhs);
+        this.lhs = lhs;
+        this.rhs = rhs;
+    }
+
+    public ParsedPattern makeParentRef(String name, Location _loc, Annotations _anno) throws BuildException {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeParentRef(name, loc.lhs, anno.lhs),
+            rhs.makeParentRef(name, loc.rhs, anno.rhs));
+    }
+
+    public ParsedPattern makeRef(String name, Location _loc, Annotations _anno) throws BuildException {
+        LocationHost loc = cast(_loc);
+        AnnotationsHost anno = cast(_anno);
+
+        return new ParsedPatternHost(
+            lhs.makeRef(name, loc.lhs, anno.lhs),
+            rhs.makeRef(name, loc.rhs, anno.rhs));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/package.html b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/package.html
new file mode 100644
index 0000000..c3635be
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/host/package.html
@@ -0,0 +1,2 @@
+implementation of the <tt>asm.builder</tt> package that uses two
+other builds simultaneously.
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/DtdContext.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/DtdContext.java
new file mode 100644
index 0000000..ca15677
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/DtdContext.java
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.xml;
+
+import org.xml.sax.DTDHandler;
+import org.xml.sax.SAXException;
+import org.relaxng.datatype.ValidationContext;
+
+import java.util.Hashtable;
+
+public abstract class DtdContext implements DTDHandler, ValidationContext {
+    private final Hashtable notationTable;
+    private final Hashtable unparsedEntityTable;
+
+    public DtdContext() {
+        notationTable = new Hashtable();
+        unparsedEntityTable = new Hashtable();
+    }
+
+    public DtdContext(DtdContext dc) {
+        notationTable = dc.notationTable;
+        unparsedEntityTable = dc.unparsedEntityTable;
+    }
+
+    public void notationDecl(String name, String publicId, String systemId)
+        throws SAXException {
+        notationTable.put(name, name);
+    }
+
+    public void unparsedEntityDecl(
+        String name,
+        String publicId,
+        String systemId,
+        String notationName)
+        throws SAXException {
+        unparsedEntityTable.put(name, name);
+    }
+
+    public boolean isNotation(String notationName) {
+        return notationTable.get(notationName) != null;
+    }
+
+    public boolean isUnparsedEntity(String entityName) {
+        return unparsedEntityTable.get(entityName) != null;
+    }
+
+    public void clearDtdContext() {
+        notationTable.clear();
+        unparsedEntityTable.clear();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/Messages.properties
new file mode 100644
index 0000000..5aa4b02
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/Messages.properties
@@ -0,0 +1,39 @@
+no_comment_support=SAX parser \"{0}\" cannot report comments
+any_name_except_contains_any_name=\"except\" in \"anyName\" contains \"anyName\"
+attribute_multi_pattern=\"attribute\" pattern must contain at most one pattern
+combine_attribute_bad_value=bad value \"{0}\" for \"combine\" attribute; value must be \"choice\" or \"interleave\"
+expected_define=found \"{0}\" element but expected \"define\" or \"start\" or \"include\" or \"div\" element
+expected_empty=found \"{0}\" element but expected empty content
+expected_except=found \"{0}\" element but expected \"except\"
+expected_grammar=found \"{0}\" element but expected \"grammar\" element
+expected_name=found \"{0}\" element but expected a name
+expected_name_class=found \"{0}\" element but expected a name-class
+expected_param_except=only \"param\" and \"except\" child elements are allowed
+expected_pattern=found \"{0}\" element but expected a pattern
+fragment_identifier_datatype_library=URI in value of \"datatypeLibrary\" attribute must not have a fragment identifier
+href_fragment_id=fragment identifier ignored in value of \"href\" attribute
+illegal_attribute_ignored=illegal attribute \"{0}\" ignored
+illegal_characters_ignored=illegal characters ignored
+illegal_name_attribute=illegal \"name\" attribute
+invalid_ncname=\"{0}\" is not a valid local name
+invalid_uri=\"{0}\" is not a valid URI reference according to RFC 2396
+missing_children=missing children
+missing_href_attribute=missing \"href\" attribute
+missing_name_attribute=missing \"name\" attribute
+missing_name_class=expected child element specifying name class
+missing_type_attribute=missing \"type\" attribute
+multiple_except=at most one \"except\" child element is allowed
+name_contains_foreign_element=\"name\" element cannot contain foreign elements
+ns_name_except_contains_any_name=\"except\" in \"nsName\" contains \"anyName\"
+ns_name_except_contains_ns_name=\"except\" in \"nsName\" contains \"nsName\"
+param_after_except=\"param\" is not allowed after \"except\"
+param_contains_foreign_element=\"param\" element cannot contain foreign elements
+qualified_attribute=attribute name \"{0}\" incorrectly qualified with RELAX NG namespace URI
+relative_datatype_library=URI in value of \"datatypeLibrary\" attribute must not be relative
+root_bad_namespace_uri=namespace URI of document element must be \"{0}\"
+start_multi_pattern=\"start\" pattern must contain at most one pattern
+too_many_children=too many child elements: only one child element is allowed
+undefined_prefix=undefined prefix \"{0}\"
+value_contains_foreign_element=\"value\" element cannot contain foreign elements
+wrong_uri_version=namespace URI has wrong version: expected \"{0}\" but got \"{1}\"
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/SAXParseable.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/SAXParseable.java
new file mode 100644
index 0000000..e1c0dc8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/SAXParseable.java
@@ -0,0 +1,129 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.xml;
+
+import java.io.IOException;
+
+import com.sun.xml.internal.rngom.ast.builder.BuildException;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import com.sun.xml.internal.rngom.xml.sax.JAXPXMLReaderCreator;
+import com.sun.xml.internal.rngom.xml.sax.XMLReaderCreator;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+
+/**
+ * RELAX NG schema in the XML syntax.
+ *
+ */
+public class SAXParseable implements Parseable {
+  private final InputSource in;
+
+  final XMLReaderCreator xrc;
+  final ErrorHandler eh;
+
+  public SAXParseable(InputSource in, ErrorHandler eh, XMLReaderCreator xrc) {
+      this.xrc = xrc;
+      this.eh = eh;
+    this.in = in;
+  }
+
+  public SAXParseable(InputSource in, ErrorHandler eh) {
+      this(in,eh,new JAXPXMLReaderCreator());
+  }
+
+  public ParsedPattern parse(SchemaBuilder schemaBuilder) throws BuildException, IllegalSchemaException {
+    try {
+      XMLReader xr = xrc.createXMLReader();
+      SchemaParser sp = new SchemaParser(this, xr, eh, schemaBuilder, null, null,"");
+      xr.parse(in);
+      ParsedPattern p = sp.getParsedPattern();
+      return schemaBuilder.expandPattern(p);
+    }
+    catch (SAXException e) {
+      throw toBuildException(e);
+    }
+    catch (IOException e) {
+      throw new BuildException(e);
+    }
+  }
+
+      public ParsedPattern parseInclude(String uri, SchemaBuilder schemaBuilder, IncludedGrammar g, String inheritedNs)
+              throws BuildException, IllegalSchemaException {
+        try {
+          XMLReader xr = xrc.createXMLReader();
+          SchemaParser sp = new SchemaParser(this, xr, eh, schemaBuilder, g, g, inheritedNs);
+          xr.parse(makeInputSource(xr, uri));
+          return sp.getParsedPattern();
+        }
+        catch (SAXException e) {
+         throw SAXParseable.toBuildException(e);
+        }
+        catch (IOException e) {
+         throw new BuildException(e);
+        }
+      }
+
+      public ParsedPattern parseExternal(String uri, SchemaBuilder schemaBuilder, Scope s, String inheritedNs)
+              throws BuildException, IllegalSchemaException {
+        try {
+          XMLReader xr = xrc.createXMLReader();
+          SchemaParser sp = new SchemaParser(this, xr, eh, schemaBuilder, null, s, inheritedNs);
+          xr.parse(makeInputSource(xr, uri));
+          return sp.getParsedPattern();
+        }
+        catch (SAXException e) {
+          throw SAXParseable.toBuildException(e);
+        }
+        catch (IOException e) {
+          throw new BuildException(e);
+        }
+      }
+
+      private static InputSource makeInputSource(XMLReader xr, String systemId) throws IOException, SAXException {
+        EntityResolver er = xr.getEntityResolver();
+        if (er != null) {
+          InputSource inputSource = er.resolveEntity(null, systemId);
+          if (inputSource != null)
+        return inputSource;
+        }
+        return new InputSource(systemId);
+      }
+
+      static BuildException toBuildException(SAXException e) {
+        Exception inner = e.getException();
+        if (inner instanceof BuildException)
+          throw (BuildException)inner;
+        throw new BuildException(e);
+      }
+    }
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/SchemaParser.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/SchemaParser.java
new file mode 100644
index 0000000..f755a5e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/parse/xml/SchemaParser.java
@@ -0,0 +1,1664 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.parse.xml;
+
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.util.Stack;
+import java.util.Vector;
+import java.util.List;
+import java.util.ArrayList;
+import java.util.Arrays;
+
+import com.sun.xml.internal.rngom.ast.builder.Annotations;
+import com.sun.xml.internal.rngom.ast.builder.CommentList;
+import com.sun.xml.internal.rngom.ast.builder.DataPatternBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Div;
+import com.sun.xml.internal.rngom.ast.builder.ElementAnnotationBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Grammar;
+import com.sun.xml.internal.rngom.ast.builder.GrammarSection;
+import com.sun.xml.internal.rngom.ast.builder.Include;
+import com.sun.xml.internal.rngom.ast.builder.IncludedGrammar;
+import com.sun.xml.internal.rngom.ast.builder.NameClassBuilder;
+import com.sun.xml.internal.rngom.ast.builder.SchemaBuilder;
+import com.sun.xml.internal.rngom.ast.builder.Scope;
+import com.sun.xml.internal.rngom.ast.om.Location;
+import com.sun.xml.internal.rngom.ast.om.ParsedElementAnnotation;
+import com.sun.xml.internal.rngom.ast.om.ParsedNameClass;
+import com.sun.xml.internal.rngom.ast.om.ParsedPattern;
+import com.sun.xml.internal.rngom.parse.Context;
+import com.sun.xml.internal.rngom.parse.IllegalSchemaException;
+import com.sun.xml.internal.rngom.parse.Parseable;
+import com.sun.xml.internal.rngom.util.Localizer;
+import com.sun.xml.internal.rngom.util.Uri;
+import com.sun.xml.internal.rngom.xml.sax.AbstractLexicalHandler;
+import com.sun.xml.internal.rngom.xml.sax.XmlBaseHandler;
+import com.sun.xml.internal.rngom.xml.util.Naming;
+import com.sun.xml.internal.rngom.xml.util.WellKnownNamespaces;
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXNotRecognizedException;
+import org.xml.sax.SAXNotSupportedException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.DefaultHandler;
+
+class SchemaParser {
+
+  private static final String relaxngURIPrefix =
+          WellKnownNamespaces.RELAX_NG.substring(0, WellKnownNamespaces.RELAX_NG.lastIndexOf('/') + 1);
+  static final String relaxng10URI = WellKnownNamespaces.RELAX_NG;
+  private static final Localizer localizer = new Localizer(new Localizer(Parseable.class),SchemaParser.class);
+
+  private String relaxngURI;
+  private final XMLReader xr;
+  private final ErrorHandler eh;
+  private final SchemaBuilder schemaBuilder;
+  /**
+   * The value of the {@link SchemaBuilder#getNameClassBuilder()}
+   * for the {@link #schemaBuilder} object.
+   */
+  private final NameClassBuilder nameClassBuilder;
+  private ParsedPattern startPattern;
+  private Locator locator;
+  private final XmlBaseHandler xmlBaseHandler = new XmlBaseHandler();
+  private final ContextImpl context = new ContextImpl();
+
+  private boolean hadError = false;
+
+  private Hashtable patternTable;
+  private Hashtable nameClassTable;
+
+  static class PrefixMapping {
+    final String prefix;
+    final String uri;
+    final PrefixMapping next;
+
+    PrefixMapping(String prefix, String uri, PrefixMapping next) {
+      this.prefix = prefix;
+      this.uri = uri;
+      this.next = next;
+    }
+  }
+
+  static abstract class AbstractContext extends DtdContext implements Context {
+    PrefixMapping prefixMapping;
+
+    AbstractContext() {
+      prefixMapping = new PrefixMapping("xml", WellKnownNamespaces.XML, null);
+    }
+
+    AbstractContext(AbstractContext context) {
+      super(context);
+      prefixMapping = context.prefixMapping;
+    }
+
+    public String resolveNamespacePrefix(String prefix) {
+      for (PrefixMapping p = prefixMapping; p != null; p = p.next)
+        if (p.prefix.equals(prefix))
+          return p.uri;
+      return null;
+    }
+
+    public Enumeration prefixes() {
+      Vector v = new Vector();
+      for (PrefixMapping p = prefixMapping; p != null; p = p.next) {
+        if (!v.contains(p.prefix))
+          v.addElement(p.prefix);
+      }
+      return v.elements();
+    }
+
+    public Context copy() {
+      return new SavedContext(this);
+    }
+  }
+
+  static class SavedContext extends AbstractContext {
+    private final String baseUri;
+    SavedContext(AbstractContext context) {
+      super(context);
+      this.baseUri = context.getBaseUri();
+    }
+
+    public String getBaseUri() {
+      return baseUri;
+    }
+  }
+
+  class ContextImpl extends AbstractContext {
+    public String getBaseUri() {
+      return xmlBaseHandler.getBaseUri();
+    }
+  }
+
+  static interface CommentHandler {
+    void comment(String value);
+  }
+
+  abstract class Handler implements ContentHandler, CommentHandler {
+    CommentList comments;
+
+    CommentList getComments() {
+      CommentList tem = comments;
+      comments = null;
+      return tem;
+    }
+
+    public void comment(String value) {
+      if (comments == null)
+        comments = schemaBuilder.makeCommentList();
+      comments.addComment(value, makeLocation());
+    }
+    public void processingInstruction(String target, String date) { }
+    public void skippedEntity(String name) { }
+    public void ignorableWhitespace(char[] ch, int start, int len) { }
+    public void startDocument() { }
+    public void endDocument() { }
+    public void startPrefixMapping(String prefix, String uri) {
+      context.prefixMapping = new PrefixMapping(prefix, uri, context.prefixMapping);
+    }
+
+    public void endPrefixMapping(String prefix) {
+      context.prefixMapping = context.prefixMapping.next;
+    }
+
+    public void setDocumentLocator(Locator loc) {
+      locator = loc;
+      xmlBaseHandler.setLocator(loc);
+    }
+  }
+
+  abstract class State extends Handler {
+    State parent;
+    String nsInherit;
+    String ns;
+    String datatypeLibrary;
+    /**
+     * The current scope, or null if there's none.
+     */
+    Scope scope;
+    Location startLocation;
+    Annotations annotations;
+
+    void set() {
+      xr.setContentHandler(this);
+    }
+
+    abstract State create();
+    abstract State createChildState(String localName) throws SAXException;
+
+
+    void setParent(State parent) {
+      this.parent = parent;
+      this.nsInherit = parent.getNs();
+      this.datatypeLibrary = parent.datatypeLibrary;
+      this.scope = parent.scope;
+      this.startLocation = makeLocation();
+      if (parent.comments != null) {
+        annotations = schemaBuilder.makeAnnotations(parent.comments, getContext());
+        parent.comments = null;
+      }
+      else if (parent instanceof RootState)
+        annotations = schemaBuilder.makeAnnotations(null, getContext());
+    }
+
+    String getNs() {
+      return ns == null ? nsInherit : ns;
+    }
+
+    boolean isRelaxNGElement(String uri) throws SAXException {
+      return uri.equals(relaxngURI);
+    }
+
+    public void startElement(String namespaceURI,
+                             String localName,
+                             String qName,
+                             Attributes atts) throws SAXException {
+      xmlBaseHandler.startElement();
+      if (isRelaxNGElement(namespaceURI)) {
+        State state = createChildState(localName);
+        if (state == null) {
+          xr.setContentHandler(new Skipper(this));
+          return;
+        }
+        state.setParent(this);
+        state.set();
+        state.attributes(atts);
+      }
+      else {
+        checkForeignElement();
+        ForeignElementHandler feh = new ForeignElementHandler(this, getComments());
+        feh.startElement(namespaceURI, localName, qName, atts);
+        xr.setContentHandler(feh);
+      }
+    }
+
+    public void endElement(String namespaceURI,
+                           String localName,
+                           String qName) throws SAXException {
+      xmlBaseHandler.endElement();
+      parent.set();
+      end();
+    }
+
+    void setName(String name) throws SAXException {
+      error("illegal_name_attribute");
+    }
+
+    void setOtherAttribute(String name, String value) throws SAXException {
+      error("illegal_attribute_ignored", name);
+    }
+
+    void endAttributes() throws SAXException {
+    }
+
+    void checkForeignElement() throws SAXException {
+    }
+
+    void attributes(Attributes atts) throws SAXException {
+      int len = atts.getLength();
+      for (int i = 0; i < len; i++) {
+        String uri = atts.getURI(i);
+        if (uri.length() == 0) {
+          String name = atts.getLocalName(i);
+          if (name.equals("name"))
+            setName(atts.getValue(i).trim());
+          else if (name.equals("ns"))
+            ns = atts.getValue(i);
+          else if (name.equals("datatypeLibrary")) {
+            datatypeLibrary = atts.getValue(i);
+            checkUri(datatypeLibrary);
+            if (!datatypeLibrary.equals("")
+                && !Uri.isAbsolute(datatypeLibrary))
+              error("relative_datatype_library");
+            if (Uri.hasFragmentId(datatypeLibrary))
+              error("fragment_identifier_datatype_library");
+            datatypeLibrary = Uri.escapeDisallowedChars(datatypeLibrary);
+          }
+          else
+            setOtherAttribute(name, atts.getValue(i));
+        }
+        else if (uri.equals(relaxngURI))
+          error("qualified_attribute", atts.getLocalName(i));
+        else if (uri.equals(WellKnownNamespaces.XML)
+                 && atts.getLocalName(i).equals("base"))
+          xmlBaseHandler.xmlBaseAttribute(atts.getValue(i));
+        else {
+          if (annotations == null)
+            annotations = schemaBuilder.makeAnnotations(null, getContext());
+          annotations.addAttribute(uri, atts.getLocalName(i), findPrefix(atts.getQName(i), uri),
+                                   atts.getValue(i), startLocation);
+        }
+      }
+      endAttributes();
+    }
+
+    abstract void end() throws SAXException;
+
+    void endChild(ParsedPattern pattern) {
+      // XXX cannot happen; throw exception
+    }
+
+    void endChild(ParsedNameClass nc) {
+      // XXX cannot happen; throw exception
+    }
+
+    public void startDocument() { }
+    public void endDocument() {
+      if (comments != null && startPattern != null) {
+        startPattern = schemaBuilder.commentAfter(startPattern, comments);
+        comments = null;
+      }
+    }
+
+    public void characters(char[] ch, int start, int len) throws SAXException {
+      for (int i = 0; i < len; i++) {
+        switch(ch[start + i]) {
+        case ' ':
+        case '\r':
+        case '\n':
+        case '\t':
+          break;
+        default:
+          error("illegal_characters_ignored");
+          break;
+        }
+      }
+    }
+
+    boolean isPatternNamespaceURI(String s) {
+      return s.equals(relaxngURI);
+    }
+
+    void endForeignChild(ParsedElementAnnotation ea) {
+      if (annotations == null)
+        annotations = schemaBuilder.makeAnnotations(null, getContext());
+      annotations.addElement(ea);
+    }
+
+    void mergeLeadingComments() {
+      if (comments != null) {
+        if (annotations == null)
+          annotations = schemaBuilder.makeAnnotations(comments, getContext());
+        else
+          annotations.addLeadingComment(comments);
+        comments = null;
+      }
+    }
+  }
+
+  class ForeignElementHandler extends Handler {
+    final State nextState;
+    ElementAnnotationBuilder builder;
+    final Stack builderStack = new Stack();
+    StringBuffer textBuf;
+    Location textLoc;
+
+    ForeignElementHandler(State nextState, CommentList comments) {
+      this.nextState = nextState;
+      this.comments = comments;
+    }
+
+    public void startElement(String namespaceURI, String localName,
+                             String qName, Attributes atts) {
+      flushText();
+      if (builder != null)
+        builderStack.push(builder);
+      Location loc = makeLocation();
+      builder = schemaBuilder.makeElementAnnotationBuilder(namespaceURI,
+                                                           localName,
+                                                           findPrefix(qName, namespaceURI),
+                                                           loc,
+                                                           getComments(),
+                                                           getContext());
+      int len = atts.getLength();
+      for (int i = 0; i < len; i++) {
+        String uri = atts.getURI(i);
+        builder.addAttribute(uri, atts.getLocalName(i), findPrefix(atts.getQName(i), uri),
+                             atts.getValue(i), loc);
+      }
+    }
+
+    public void endElement(String namespaceURI, String localName,
+                           String qName) {
+      flushText();
+      if (comments != null)
+        builder.addComment(getComments());
+      ParsedElementAnnotation ea = builder.makeElementAnnotation();
+      if (builderStack.empty()) {
+        nextState.endForeignChild(ea);
+        nextState.set();
+      }
+      else {
+        builder = (ElementAnnotationBuilder)builderStack.pop();
+        builder.addElement(ea);
+      }
+    }
+
+    public void characters(char ch[], int start, int length) {
+      if (textBuf == null)
+        textBuf = new StringBuffer();
+      textBuf.append(ch, start, length);
+      if (textLoc == null)
+        textLoc = makeLocation();
+    }
+
+    public void comment(String value) {
+      flushText();
+      super.comment(value);
+    }
+
+    void flushText() {
+      if (textBuf != null && textBuf.length() != 0) {
+        builder.addText(textBuf.toString(), textLoc, getComments());
+        textBuf.setLength(0);
+      }
+      textLoc = null;
+    }
+  }
+
+  class Skipper extends DefaultHandler implements CommentHandler {
+    int level = 1;
+    final State nextState;
+
+    Skipper(State nextState) {
+      this.nextState = nextState;
+    }
+
+    public void startElement(String namespaceURI,
+                             String localName,
+                             String qName,
+                             Attributes atts) throws SAXException {
+      ++level;
+    }
+
+    public void endElement(String namespaceURI,
+                           String localName,
+                           String qName) throws SAXException {
+      if (--level == 0)
+        nextState.set();
+    }
+
+    public void comment(String value) {
+    }
+  }
+
+  abstract class EmptyContentState extends State {
+
+    State createChildState(String localName) throws SAXException {
+      error("expected_empty", localName);
+      return null;
+    }
+
+    abstract ParsedPattern makePattern() throws SAXException;
+
+    void end() throws SAXException {
+      if (comments != null) {
+        if (annotations == null)
+          annotations = schemaBuilder.makeAnnotations(null, getContext());
+        annotations.addComment(comments);
+        comments = null;
+      }
+      parent.endChild(makePattern());
+    }
+  }
+
+  static private final int INIT_CHILD_ALLOC = 5;
+
+  abstract class PatternContainerState extends State {
+    List<ParsedPattern> childPatterns;
+
+    State createChildState(String localName) throws SAXException {
+      State state = (State)patternTable.get(localName);
+      if (state == null) {
+        error("expected_pattern", localName);
+        return null;
+      }
+      return state.create();
+    }
+
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      if (patterns.size() == 1 && anno == null)
+        return patterns.get(0);
+      return schemaBuilder.makeGroup(patterns, loc, anno);
+    }
+
+    void endChild(ParsedPattern pattern) {
+      if (childPatterns == null)
+        childPatterns = new ArrayList<ParsedPattern>(INIT_CHILD_ALLOC);
+      childPatterns.add(pattern);
+    }
+
+    void endForeignChild(ParsedElementAnnotation ea) {
+      if (childPatterns == null)
+        super.endForeignChild(ea);
+      else {
+        int idx = childPatterns.size()-1;
+        childPatterns.set(idx, schemaBuilder.annotateAfter(childPatterns.get(idx), ea));
+      }
+    }
+
+    void end() throws SAXException {
+      if (childPatterns == null) {
+        error("missing_children");
+        endChild(schemaBuilder.makeErrorPattern());
+      }
+      if (comments != null) {
+        int idx = childPatterns.size()-1;
+        childPatterns.set(idx,schemaBuilder.commentAfter(childPatterns.get(idx), comments));
+        comments = null;
+      }
+      sendPatternToParent(buildPattern(childPatterns, startLocation, annotations));
+    }
+
+    void sendPatternToParent(ParsedPattern p) {
+      parent.endChild(p);
+    }
+  }
+
+  class GroupState extends PatternContainerState {
+    State create() {
+      return new GroupState();
+    }
+  }
+
+  class ZeroOrMoreState extends PatternContainerState {
+    State create() {
+      return new ZeroOrMoreState();
+    }
+
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return schemaBuilder.makeZeroOrMore(super.buildPattern(patterns, loc, null), loc, anno);
+    }
+  }
+
+  class OneOrMoreState extends PatternContainerState {
+    State create() {
+      return new OneOrMoreState();
+    }
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return schemaBuilder.makeOneOrMore(super.buildPattern(patterns, loc, null), loc, anno);
+    }
+  }
+
+  class OptionalState extends PatternContainerState {
+    State create() {
+      return new OptionalState();
+    }
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return schemaBuilder.makeOptional(super.buildPattern(patterns, loc, null), loc, anno);
+    }
+  }
+
+  class ListState extends PatternContainerState {
+    State create() {
+      return new ListState();
+    }
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return schemaBuilder.makeList(super.buildPattern(patterns, loc, null), loc, anno);
+    }
+  }
+
+  class ChoiceState extends PatternContainerState {
+    State create() {
+      return new ChoiceState();
+    }
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return schemaBuilder.makeChoice(patterns, loc, anno);
+    }
+  }
+
+  class InterleaveState extends PatternContainerState {
+    State create() {
+      return new InterleaveState();
+    }
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) {
+      return schemaBuilder.makeInterleave(patterns, loc, anno);
+    }
+  }
+
+  class MixedState extends PatternContainerState {
+    State create() {
+      return new MixedState();
+    }
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return schemaBuilder.makeMixed(super.buildPattern(patterns, loc, null), loc, anno);
+    }
+  }
+
+  static interface NameClassRef {
+    void setNameClass(ParsedNameClass nc);
+  }
+
+  class ElementState extends PatternContainerState implements NameClassRef {
+    ParsedNameClass nameClass;
+    boolean nameClassWasAttribute;
+    String name;
+
+    void setName(String name) {
+      this.name = name;
+    }
+
+    public void setNameClass(ParsedNameClass nc) {
+      nameClass = nc;
+    }
+
+    void endAttributes() throws SAXException {
+      if (name != null) {
+        nameClass = expandName(name, getNs(), null);
+        nameClassWasAttribute = true;
+      }
+      else
+        new NameClassChildState(this, this).set();
+    }
+
+    State create() {
+      return new ElementState();
+    }
+
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return schemaBuilder.makeElement(nameClass, super.buildPattern(patterns, loc, null), loc, anno);
+    }
+
+    void endForeignChild(ParsedElementAnnotation ea) {
+      if (nameClassWasAttribute || childPatterns!=null || nameClass == null)
+        super.endForeignChild(ea);
+      else
+        nameClass = nameClassBuilder.annotateAfter(nameClass, ea);
+    }
+  }
+
+  class RootState extends PatternContainerState {
+    IncludedGrammar grammar;
+
+    RootState() {
+    }
+
+    RootState(IncludedGrammar grammar, Scope scope, String ns) {
+      this.grammar = grammar;
+      this.scope = scope;
+      this.nsInherit = ns;
+      this.datatypeLibrary = "";
+    }
+
+    State create() {
+      return new RootState();
+    }
+
+    State createChildState(String localName) throws SAXException {
+      if (grammar == null)
+        return super.createChildState(localName);
+      if (localName.equals("grammar"))
+        return new MergeGrammarState(grammar);
+      error("expected_grammar", localName);
+      return null;
+    }
+
+    void checkForeignElement() throws SAXException {
+      error("root_bad_namespace_uri", WellKnownNamespaces.RELAX_NG);
+    }
+
+    void endChild(ParsedPattern pattern) {
+      startPattern = pattern;
+    }
+
+    boolean isRelaxNGElement(String uri) throws SAXException {
+      if (!uri.startsWith(relaxngURIPrefix))
+        return false;
+      if (!uri.equals(WellKnownNamespaces.RELAX_NG))
+        warning("wrong_uri_version",
+                WellKnownNamespaces.RELAX_NG.substring(relaxngURIPrefix.length()),
+                uri.substring(relaxngURIPrefix.length()));
+      relaxngURI = uri;
+      return true;
+    }
+
+  }
+
+  class NotAllowedState extends EmptyContentState {
+    State create() {
+      return new NotAllowedState();
+    }
+
+    ParsedPattern makePattern() {
+      return schemaBuilder.makeNotAllowed(startLocation, annotations);
+    }
+  }
+
+  class EmptyState extends EmptyContentState {
+    State create() {
+      return new EmptyState();
+    }
+
+    ParsedPattern makePattern() {
+      return schemaBuilder.makeEmpty(startLocation, annotations);
+    }
+  }
+
+  class TextState extends EmptyContentState {
+    State create() {
+      return new TextState();
+    }
+
+    ParsedPattern makePattern() {
+      return schemaBuilder.makeText(startLocation, annotations);
+    }
+  }
+
+  class ValueState extends EmptyContentState {
+    final StringBuffer buf = new StringBuffer();
+    String type;
+
+    State create() {
+      return new ValueState();
+    }
+
+    void setOtherAttribute(String name, String value) throws SAXException {
+      if (name.equals("type"))
+        type = checkNCName(value.trim());
+      else
+        super.setOtherAttribute(name, value);
+    }
+
+    public void characters(char[] ch, int start, int len) {
+      buf.append(ch, start, len);
+    }
+
+    void checkForeignElement() throws SAXException {
+      error("value_contains_foreign_element");
+    }
+
+    ParsedPattern makePattern() throws SAXException {
+      if (type == null)
+        return makePattern("", "token");
+      else
+        return makePattern(datatypeLibrary, type);
+    }
+
+    void end() throws SAXException {
+      mergeLeadingComments();
+      super.end();
+    }
+
+    ParsedPattern makePattern(String datatypeLibrary, String type) {
+      return schemaBuilder.makeValue(datatypeLibrary,
+                                     type,
+                                     buf.toString(),
+                                     getContext(),
+                                     getNs(),
+                                     startLocation,
+                                     annotations);
+    }
+
+  }
+
+  class DataState extends State {
+    String type;
+    ParsedPattern except = null;
+    DataPatternBuilder dpb = null;
+
+    State create() {
+      return new DataState();
+    }
+
+    State createChildState(String localName) throws SAXException {
+      if (localName.equals("param")) {
+        if (except != null)
+          error("param_after_except");
+        return new ParamState(dpb);
+      }
+      if (localName.equals("except")) {
+        if (except != null)
+          error("multiple_except");
+        return new ChoiceState();
+      }
+      error("expected_param_except", localName);
+      return null;
+    }
+
+    void setOtherAttribute(String name, String value) throws SAXException {
+      if (name.equals("type"))
+        type = checkNCName(value.trim());
+      else
+        super.setOtherAttribute(name, value);
+    }
+
+    void endAttributes() throws SAXException {
+      if (type == null)
+        error("missing_type_attribute");
+      else
+        dpb = schemaBuilder.makeDataPatternBuilder(datatypeLibrary, type, startLocation);
+    }
+
+    void endForeignChild(ParsedElementAnnotation ea) {
+      dpb.annotation(ea);
+    }
+
+    void end() throws SAXException {
+      ParsedPattern p;
+      if (dpb != null) {
+        if (except != null)
+          p = dpb.makePattern(except, startLocation, annotations);
+        else
+          p = dpb.makePattern(startLocation, annotations);
+      }
+      else
+        p = schemaBuilder.makeErrorPattern();
+      // XXX need to capture comments
+      parent.endChild(p);
+    }
+
+    void endChild(ParsedPattern pattern) {
+      except = pattern;
+    }
+
+  }
+
+  class ParamState extends State {
+    private final StringBuffer buf = new StringBuffer();
+    private final DataPatternBuilder dpb;
+    private String name;
+
+    ParamState(DataPatternBuilder dpb) {
+      this.dpb = dpb;
+    }
+
+    State create() {
+      return new ParamState(null);
+    }
+
+    void setName(String name) throws SAXException {
+      this.name = checkNCName(name);
+    }
+
+    void endAttributes() throws SAXException {
+      if (name == null)
+        error("missing_name_attribute");
+    }
+
+    State createChildState(String localName) throws SAXException {
+      error("expected_empty", localName);
+      return null;
+    }
+
+    public void characters(char[] ch, int start, int len) {
+      buf.append(ch, start, len);
+    }
+
+    void checkForeignElement() throws SAXException {
+      error("param_contains_foreign_element");
+    }
+
+    void end() throws SAXException {
+      if (name == null)
+        return;
+      if (dpb == null)
+        return;
+      mergeLeadingComments();
+      dpb.addParam(name, buf.toString(), getContext(), getNs(), startLocation, annotations);
+    }
+  }
+
+  class AttributeState extends PatternContainerState implements NameClassRef {
+    ParsedNameClass nameClass;
+    boolean nameClassWasAttribute;
+    String name;
+
+    State create() {
+      return new AttributeState();
+    }
+
+    void setName(String name) {
+      this.name = name;
+    }
+
+    public void setNameClass(ParsedNameClass nc) {
+      nameClass = nc;
+    }
+
+    void endAttributes() throws SAXException {
+      if (name != null) {
+        String nsUse;
+        if (ns != null)
+          nsUse = ns;
+        else
+          nsUse = "";
+        nameClass = expandName(name, nsUse, null);
+        nameClassWasAttribute = true;
+      }
+      else
+        new NameClassChildState(this, this).set();
+    }
+
+    void endForeignChild(ParsedElementAnnotation ea) {
+      if (nameClassWasAttribute || childPatterns!=null || nameClass == null)
+        super.endForeignChild(ea);
+      else
+        nameClass = nameClassBuilder.annotateAfter(nameClass, ea);
+    }
+
+    void end() throws SAXException {
+      if (childPatterns == null)
+        endChild(schemaBuilder.makeText(startLocation, null));
+      super.end();
+    }
+
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return schemaBuilder.makeAttribute(nameClass, super.buildPattern(patterns, loc, null), loc, anno);
+    }
+
+    State createChildState(String localName) throws SAXException {
+      State tem = super.createChildState(localName);
+      if (tem != null && childPatterns!=null)
+        error("attribute_multi_pattern");
+      return tem;
+    }
+
+  }
+
+  abstract class SinglePatternContainerState extends PatternContainerState {
+    State createChildState(String localName) throws SAXException {
+      if (childPatterns==null)
+        return super.createChildState(localName);
+      error("too_many_children");
+      return null;
+    }
+  }
+
+  class GrammarSectionState extends State {
+    GrammarSection section;
+
+    GrammarSectionState() { }
+
+    GrammarSectionState(GrammarSection section) {
+      this.section = section;
+    }
+
+    State create() {
+      return new GrammarSectionState(null);
+    }
+
+    State createChildState(String localName) throws SAXException {
+      if (localName.equals("define"))
+        return new DefineState(section);
+      if (localName.equals("start"))
+        return new StartState(section);
+      if (localName.equals("include")) {
+        Include include = section.makeInclude();
+        if (include != null)
+          return new IncludeState(include);
+      }
+      if (localName.equals("div"))
+        return new DivState(section.makeDiv());
+      error("expected_define", localName);
+      // XXX better errors
+      return null;
+    }
+
+    void end() throws SAXException {
+      if (comments != null) {
+        section.topLevelComment(comments);
+        comments = null;
+      }
+    }
+
+    void endForeignChild(ParsedElementAnnotation ea) {
+      section.topLevelAnnotation(ea);
+    }
+  }
+
+  class DivState extends GrammarSectionState {
+    final Div div;
+    DivState(Div div) {
+      super(div);
+      this.div = div;
+    }
+
+    void end() throws SAXException {
+      super.end();
+      div.endDiv(startLocation, annotations);
+    }
+  }
+
+  class IncludeState extends GrammarSectionState {
+    String href;
+    final Include include;
+
+    IncludeState(Include include) {
+      super(include);
+      this.include = include;
+    }
+
+    void setOtherAttribute(String name, String value) throws SAXException {
+      if (name.equals("href")) {
+        href = value;
+        checkUri(href);
+      }
+      else
+        super.setOtherAttribute(name, value);
+    }
+
+    void endAttributes() throws SAXException {
+      if (href == null)
+        error("missing_href_attribute");
+      else
+        href = resolve(href);
+    }
+
+    void end() throws SAXException {
+      super.end();
+      if (href != null) {
+        try {
+          include.endInclude(parseable, href, getNs(), startLocation, annotations);
+        }
+        catch (IllegalSchemaException e) {
+        }
+      }
+    }
+  }
+
+  class MergeGrammarState extends GrammarSectionState {
+    final IncludedGrammar grammar;
+    MergeGrammarState(IncludedGrammar grammar) {
+      super(grammar);
+      this.grammar = grammar;
+    }
+
+    void end() throws SAXException {
+      super.end();
+      parent.endChild(grammar.endIncludedGrammar(startLocation, annotations));
+    }
+  }
+
+  class GrammarState extends GrammarSectionState {
+    Grammar grammar;
+
+    void setParent(State parent) {
+      super.setParent(parent);
+      grammar = schemaBuilder.makeGrammar(scope);
+      section = grammar;
+      scope = grammar;
+    }
+
+    State create() {
+      return new GrammarState();
+    }
+
+    void end() throws SAXException {
+      super.end();
+      parent.endChild(grammar.endGrammar(startLocation, annotations));
+    }
+  }
+
+  class RefState extends EmptyContentState {
+    String name;
+
+    State create() {
+      return new RefState();
+    }
+
+
+    void endAttributes() throws SAXException {
+      if (name == null)
+        error("missing_name_attribute");
+    }
+
+    void setName(String name) throws SAXException {
+      this.name = checkNCName(name);
+    }
+
+    ParsedPattern makePattern() throws SAXException {
+      if (name == null)
+        return schemaBuilder.makeErrorPattern();
+      if(scope==null) {
+          error("ref_outside_grammar",name);
+          return schemaBuilder.makeErrorPattern();
+      } else
+          return scope.makeRef(name, startLocation, annotations);
+    }
+  }
+
+  class ParentRefState extends RefState {
+    State create() {
+      return new ParentRefState();
+    }
+
+    ParsedPattern makePattern() throws SAXException {
+      if (name == null)
+        return schemaBuilder.makeErrorPattern();
+      if(scope==null) {
+        error("parent_ref_outside_grammar",name);
+        return schemaBuilder.makeErrorPattern();
+      } else
+        return scope.makeParentRef(name, startLocation, annotations);
+    }
+  }
+
+  class ExternalRefState extends EmptyContentState {
+    String href;
+    ParsedPattern includedPattern;
+
+    State create() {
+      return new ExternalRefState();
+    }
+
+    void setOtherAttribute(String name, String value) throws SAXException {
+      if (name.equals("href")) {
+        href = value;
+        checkUri(href);
+      }
+      else
+        super.setOtherAttribute(name, value);
+    }
+
+    void endAttributes() throws SAXException {
+      if (href == null)
+        error("missing_href_attribute");
+      else
+        href = resolve(href);
+    }
+
+    ParsedPattern makePattern() {
+      if (href != null) {
+        try {
+          return schemaBuilder.makeExternalRef(parseable,
+                                               href,
+                                               getNs(),
+                                               scope,
+                                               startLocation,
+                                               annotations);
+        }
+        catch (IllegalSchemaException e) { }
+      }
+      return schemaBuilder.makeErrorPattern();
+    }
+  }
+
+  abstract class DefinitionState extends PatternContainerState {
+    GrammarSection.Combine combine = null;
+    final GrammarSection section;
+
+    DefinitionState(GrammarSection section) {
+      this.section = section;
+    }
+
+    void setOtherAttribute(String name, String value) throws SAXException {
+      if (name.equals("combine")) {
+        value = value.trim();
+        if (value.equals("choice"))
+          combine = GrammarSection.COMBINE_CHOICE;
+        else if (value.equals("interleave"))
+          combine = GrammarSection.COMBINE_INTERLEAVE;
+        else
+          error("combine_attribute_bad_value", value);
+      }
+      else
+        super.setOtherAttribute(name, value);
+    }
+
+    ParsedPattern buildPattern(List<ParsedPattern> patterns, Location loc, Annotations anno) throws SAXException {
+      return super.buildPattern(patterns, loc, null);
+    }
+  }
+
+  class DefineState extends DefinitionState {
+    String name;
+
+    DefineState(GrammarSection section) {
+      super(section);
+    }
+
+    State create() {
+      return new DefineState(null);
+    }
+
+    void setName(String name) throws SAXException {
+      this.name = checkNCName(name);
+    }
+
+    void endAttributes() throws SAXException {
+      if (name == null)
+        error("missing_name_attribute");
+    }
+
+    void sendPatternToParent(ParsedPattern p) {
+      if (name != null)
+        section.define(name, combine, p, startLocation, annotations);
+    }
+
+  }
+
+  class StartState extends DefinitionState {
+
+    StartState(GrammarSection section) {
+      super(section);
+    }
+
+    State create() {
+      return new StartState(null);
+    }
+
+    void sendPatternToParent(ParsedPattern p) {
+      section.define(GrammarSection.START, combine, p, startLocation, annotations);
+    }
+
+    State createChildState(String localName) throws SAXException {
+      State tem = super.createChildState(localName);
+      if (tem != null && childPatterns!=null)
+        error("start_multi_pattern");
+      return tem;
+    }
+
+  }
+
+  abstract class NameClassContainerState extends State {
+    State createChildState(String localName) throws SAXException {
+      State state = (State)nameClassTable.get(localName);
+      if (state == null) {
+        error("expected_name_class", localName);
+        return null;
+      }
+      return state.create();
+    }
+  }
+
+  class NameClassChildState extends NameClassContainerState {
+    final State prevState;
+    final NameClassRef nameClassRef;
+
+    State create() {
+      return null;
+    }
+
+    NameClassChildState(State prevState, NameClassRef nameClassRef) {
+      this.prevState = prevState;
+      this.nameClassRef = nameClassRef;
+      setParent(prevState.parent);
+      this.ns = prevState.ns;
+    }
+
+    void endChild(ParsedNameClass nameClass) {
+      nameClassRef.setNameClass(nameClass);
+      prevState.set();
+    }
+
+    void endForeignChild(ParsedElementAnnotation ea) {
+      prevState.endForeignChild(ea);
+    }
+
+    void end() throws SAXException {
+      nameClassRef.setNameClass(nameClassBuilder.makeErrorNameClass());
+      error("missing_name_class");
+      prevState.set();
+      prevState.end();
+    }
+  }
+
+  abstract class NameClassBaseState extends State {
+
+    abstract ParsedNameClass makeNameClass() throws SAXException;
+
+    void end() throws SAXException {
+      parent.endChild(makeNameClass());
+    }
+  }
+
+  class NameState extends NameClassBaseState {
+    final StringBuffer buf = new StringBuffer();
+
+    State createChildState(String localName) throws SAXException {
+      error("expected_name", localName);
+      return null;
+    }
+
+    State create() {
+      return new NameState();
+    }
+
+    public void characters(char[] ch, int start, int len) {
+      buf.append(ch, start, len);
+    }
+
+    void checkForeignElement() throws SAXException {
+      error("name_contains_foreign_element");
+    }
+
+    ParsedNameClass makeNameClass() throws SAXException {
+      mergeLeadingComments();
+      return expandName(buf.toString().trim(), getNs(), annotations);
+    }
+
+  }
+
+  private static final int PATTERN_CONTEXT = 0;
+  private static final int ANY_NAME_CONTEXT = 1;
+  private static final int NS_NAME_CONTEXT = 2;
+private SAXParseable parseable;
+
+  class AnyNameState extends NameClassBaseState {
+    ParsedNameClass except = null;
+
+    State create() {
+      return new AnyNameState();
+    }
+
+    State createChildState(String localName) throws SAXException {
+      if (localName.equals("except")) {
+        if (except != null)
+          error("multiple_except");
+        return new NameClassChoiceState(getContext());
+      }
+      error("expected_except", localName);
+      return null;
+    }
+
+    int getContext() {
+      return ANY_NAME_CONTEXT;
+    }
+
+    ParsedNameClass makeNameClass() {
+      if (except == null)
+        return makeNameClassNoExcept();
+      else
+        return makeNameClassExcept(except);
+    }
+
+    ParsedNameClass makeNameClassNoExcept() {
+      return nameClassBuilder.makeAnyName(startLocation, annotations);
+    }
+
+    ParsedNameClass makeNameClassExcept(ParsedNameClass except) {
+      return nameClassBuilder.makeAnyName(except, startLocation, annotations);
+    }
+
+    void endChild(ParsedNameClass nameClass) {
+      except = nameClass;
+    }
+
+  }
+
+  class NsNameState extends AnyNameState {
+    State create() {
+      return new NsNameState();
+    }
+
+    ParsedNameClass makeNameClassNoExcept() {
+      return nameClassBuilder.makeNsName(getNs(), null, null);
+    }
+
+    ParsedNameClass makeNameClassExcept(ParsedNameClass except) {
+      return nameClassBuilder.makeNsName(getNs(), except, null, null);
+    }
+
+    int getContext() {
+      return NS_NAME_CONTEXT;
+    }
+
+  }
+
+  class NameClassChoiceState extends NameClassContainerState {
+    private ParsedNameClass[] nameClasses;
+    private int nNameClasses;
+    private int context;
+
+    NameClassChoiceState() {
+      this.context = PATTERN_CONTEXT;
+    }
+
+    NameClassChoiceState(int context) {
+      this.context = context;
+    }
+
+    void setParent(State parent) {
+      super.setParent(parent);
+      if (parent instanceof NameClassChoiceState)
+        this.context = ((NameClassChoiceState)parent).context;
+    }
+
+    State create() {
+      return new NameClassChoiceState();
+    }
+
+    State createChildState(String localName) throws SAXException {
+      if (localName.equals("anyName")) {
+        if (context >= ANY_NAME_CONTEXT) {
+          error(context == ANY_NAME_CONTEXT
+                ? "any_name_except_contains_any_name"
+                : "ns_name_except_contains_any_name");
+          return null;
+        }
+      }
+      else if (localName.equals("nsName")) {
+        if (context == NS_NAME_CONTEXT) {
+          error("ns_name_except_contains_ns_name");
+          return null;
+        }
+      }
+      return super.createChildState(localName);
+    }
+
+    void endChild(ParsedNameClass nc) {
+      if (nameClasses == null)
+        nameClasses = new ParsedNameClass[INIT_CHILD_ALLOC];
+      else if (nNameClasses >= nameClasses.length) {
+        ParsedNameClass[] newNameClasses = new ParsedNameClass[nameClasses.length * 2];
+        System.arraycopy(nameClasses, 0, newNameClasses, 0, nameClasses.length);
+        nameClasses = newNameClasses;
+      }
+      nameClasses[nNameClasses++] = nc;
+    }
+
+    void endForeignChild(ParsedElementAnnotation ea) {
+      if (nNameClasses == 0)
+        super.endForeignChild(ea);
+      else
+        nameClasses[nNameClasses - 1] = nameClassBuilder.annotateAfter(nameClasses[nNameClasses - 1], ea);
+    }
+
+    void end() throws SAXException {
+      if (nNameClasses == 0) {
+        error("missing_name_class");
+        parent.endChild(nameClassBuilder.makeErrorNameClass());
+        return;
+      }
+      if (comments != null) {
+        nameClasses[nNameClasses - 1] = nameClassBuilder.commentAfter(nameClasses[nNameClasses - 1], comments);
+        comments = null;
+      }
+      parent.endChild(nameClassBuilder.makeChoice(Arrays.asList(nameClasses).subList(0,nNameClasses), startLocation, annotations));
+    }
+  }
+
+  private void initPatternTable() {
+    patternTable = new Hashtable();
+    patternTable.put("zeroOrMore", new ZeroOrMoreState());
+    patternTable.put("oneOrMore", new OneOrMoreState());
+    patternTable.put("optional", new OptionalState());
+    patternTable.put("list", new ListState());
+    patternTable.put("choice", new ChoiceState());
+    patternTable.put("interleave", new InterleaveState());
+    patternTable.put("group", new GroupState());
+    patternTable.put("mixed", new MixedState());
+    patternTable.put("element", new ElementState());
+    patternTable.put("attribute", new AttributeState());
+    patternTable.put("empty", new EmptyState());
+    patternTable.put("text", new TextState());
+    patternTable.put("value", new ValueState());
+    patternTable.put("data", new DataState());
+    patternTable.put("notAllowed", new NotAllowedState());
+    patternTable.put("grammar", new GrammarState());
+    patternTable.put("ref", new RefState());
+    patternTable.put("parentRef", new ParentRefState());
+    patternTable.put("externalRef", new ExternalRefState());
+  }
+
+  private void initNameClassTable() {
+    nameClassTable = new Hashtable();
+    nameClassTable.put("name", new NameState());
+    nameClassTable.put("anyName", new AnyNameState());
+    nameClassTable.put("nsName", new NsNameState());
+    nameClassTable.put("choice", new NameClassChoiceState());
+  }
+
+  public ParsedPattern getParsedPattern() throws IllegalSchemaException {
+    if (hadError)
+      throw new IllegalSchemaException();
+    return startPattern;
+  }
+
+  private void error(String key) throws SAXException {
+    error(key, locator);
+  }
+
+  private void error(String key, String arg) throws SAXException {
+    error(key, arg, locator);
+  }
+
+  void error(String key, String arg1, String arg2) throws SAXException {
+    error(key, arg1, arg2, locator);
+  }
+
+  private void error(String key, Locator loc) throws SAXException {
+    error(new SAXParseException(localizer.message(key), loc));
+  }
+
+  private void error(String key, String arg, Locator loc) throws SAXException {
+    error(new SAXParseException(localizer.message(key, arg), loc));
+  }
+
+  private void error(String key, String arg1, String arg2, Locator loc)
+    throws SAXException {
+    error(new SAXParseException(localizer.message(key, arg1, arg2), loc));
+  }
+
+  private void error(SAXParseException e) throws SAXException {
+    hadError = true;
+    if (eh != null)
+      eh.error(e);
+  }
+
+  void warning(String key) throws SAXException {
+    warning(key, locator);
+  }
+
+  private void warning(String key, String arg) throws SAXException {
+    warning(key, arg, locator);
+  }
+
+  private void warning(String key, String arg1, String arg2) throws SAXException {
+    warning(key, arg1, arg2, locator);
+  }
+
+  private void warning(String key, Locator loc) throws SAXException {
+    warning(new SAXParseException(localizer.message(key), loc));
+  }
+
+  private void warning(String key, String arg, Locator loc) throws SAXException {
+    warning(new SAXParseException(localizer.message(key, arg), loc));
+  }
+
+  private void warning(String key, String arg1, String arg2, Locator loc)
+    throws SAXException {
+    warning(new SAXParseException(localizer.message(key, arg1, arg2), loc));
+  }
+
+  private void warning(SAXParseException e) throws SAXException {
+    if (eh != null)
+      eh.warning(e);
+  }
+
+  SchemaParser(SAXParseable parseable,
+               XMLReader xr,
+               ErrorHandler eh,
+               SchemaBuilder schemaBuilder,
+               IncludedGrammar grammar,
+               Scope scope,
+               String inheritedNs) throws SAXException {
+    this.parseable = parseable;
+    this.xr = xr;
+    this.eh = eh;
+    this.schemaBuilder = schemaBuilder;
+    this.nameClassBuilder = schemaBuilder.getNameClassBuilder();
+    if (eh != null)
+      xr.setErrorHandler(eh);
+    xr.setDTDHandler(context);
+    if (schemaBuilder.usesComments()) {
+      try {
+        xr.setProperty("http://xml.org/sax/properties/lexical-handler", new LexicalHandlerImpl());
+      }
+      catch (SAXNotRecognizedException e) {
+        warning("no_comment_support", xr.getClass().getName());
+      }
+      catch (SAXNotSupportedException e) {
+        warning("no_comment_support", xr.getClass().getName());
+      }
+    }
+    initPatternTable();
+    initNameClassTable();
+    new RootState(grammar, scope, inheritedNs).set();
+  }
+
+
+  private Context getContext() {
+    return context;
+  }
+
+  class LexicalHandlerImpl extends AbstractLexicalHandler {
+    private boolean inDtd = false;
+
+    public void startDTD(String s, String s1, String s2) throws SAXException {
+      inDtd = true;
+    }
+
+    public void endDTD() throws SAXException {
+      inDtd = false;
+    }
+
+    public void comment(char[] chars, int start, int length) throws SAXException {
+      if (!inDtd)
+        ((CommentHandler)xr.getContentHandler()).comment(new String(chars, start, length));
+    }
+  }
+
+  private ParsedNameClass expandName(String name, String ns, Annotations anno) throws SAXException {
+    int ic = name.indexOf(':');
+    if (ic == -1)
+      return nameClassBuilder.makeName(ns, checkNCName(name), null, null, anno);
+    String prefix = checkNCName(name.substring(0, ic));
+    String localName = checkNCName(name.substring(ic + 1));
+    for (PrefixMapping tem = context.prefixMapping; tem != null; tem = tem.next)
+      if (tem.prefix.equals(prefix))
+        return nameClassBuilder.makeName(tem.uri, localName, prefix, null, anno);
+    error("undefined_prefix", prefix);
+    return nameClassBuilder.makeName("", localName, null, null, anno);
+  }
+
+  private String findPrefix(String qName, String uri) {
+    String prefix = null;
+    if (qName == null || qName.equals("")) {
+      for (PrefixMapping p = context.prefixMapping; p != null; p = p.next)
+        if (p.uri.equals(uri)) {
+          prefix = p.prefix;
+          break;
+        }
+    }
+    else {
+      int off = qName.indexOf(':');
+      if (off > 0)
+        prefix = qName.substring(0, off);
+    }
+    return prefix;
+  }
+  private String checkNCName(String str) throws SAXException {
+    if (!Naming.isNcname(str))
+      error("invalid_ncname", str);
+    return str;
+  }
+
+  private String resolve(String systemId) throws SAXException {
+    if (Uri.hasFragmentId(systemId))
+      error("href_fragment_id");
+    systemId = Uri.escapeDisallowedChars(systemId);
+    return Uri.resolve(xmlBaseHandler.getBaseUri(), systemId);
+  }
+
+  private Location makeLocation() {
+    if (locator == null)
+      return null;
+    return schemaBuilder.makeLocation(locator.getSystemId(),
+                                      locator.getLineNumber(),
+                                      locator.getColumnNumber());
+  }
+
+  private void checkUri(String s) throws SAXException {
+    if (!Uri.isValid(s))
+      error("invalid_uri", s);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Localizer.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Localizer.java
new file mode 100644
index 0000000..22eea0c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Localizer.java
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.util;
+
+import java.text.MessageFormat;
+import java.util.MissingResourceException;
+import java.util.ResourceBundle;
+
+/**
+ * Localizes messages.
+ */
+public class Localizer {
+    private final Class cls;
+    private ResourceBundle bundle;
+    /**
+     * If non-null, any resources that weren't found in this localizer
+     * will be delegated to the parent.
+     */
+    private final Localizer parent;
+
+    public Localizer(Class cls) {
+        this(null,cls);
+    }
+
+    public Localizer(Localizer parent, Class cls) {
+        this.parent = parent;
+        this.cls = cls;
+    }
+
+    private String getString(String key) {
+        try {
+            return getBundle().getString(key);
+        } catch( MissingResourceException e ) {
+            // delegation
+            if(parent!=null)
+                return parent.getString(key);
+            else
+                throw e;
+        }
+    }
+
+    public String message(String key) {
+        return MessageFormat.format(getString(key), new Object[]{});
+    }
+
+    public String message(String key, Object arg) {
+        return MessageFormat.format(getString(key),
+            new Object[]{arg});
+    }
+
+    public String message(String key, Object arg1, Object arg2) {
+        return MessageFormat.format(getString(key), new Object[]{
+                arg1, arg2});
+    }
+
+    public String message(String key, Object[] args) {
+        return MessageFormat.format(getString(key), args);
+    }
+
+    private ResourceBundle getBundle() {
+        if (bundle == null) {
+            String s = cls.getName();
+            int i = s.lastIndexOf('.');
+            if (i > 0)
+                s = s.substring(0, i + 1);
+            else
+                s = "";
+            bundle = ResourceBundle.getBundle(s + "Messages");
+        }
+        return bundle;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Uri.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Uri.java
new file mode 100644
index 0000000..7724b38
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Uri.java
@@ -0,0 +1,174 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.util;
+
+import java.net.URL;
+import java.net.MalformedURLException;
+import java.io.UnsupportedEncodingException;
+
+public class Uri {
+  private static String utf8 = "UTF-8";
+
+  public static boolean isValid(String s) {
+    return isValidPercent(s) && isValidFragment(s) && isValidScheme(s);
+  }
+
+  private static final String HEX_DIGITS = "0123456789abcdef";
+
+  public static String escapeDisallowedChars(String s) {
+    StringBuffer buf = null;
+    int len = s.length();
+    int done = 0;
+    for (;;) {
+      int i = done;
+      for (;;) {
+        if (i == len) {
+          if (done == 0)
+            return s;
+          break;
+        }
+        if (isExcluded(s.charAt(i)))
+          break;
+        i++;
+      }
+      if (buf == null)
+        buf = new StringBuffer();
+      if (i > done) {
+        buf.append(s.substring(done, i));
+        done = i;
+      }
+      if (i == len)
+        break;
+      for (i++; i < len && isExcluded(s.charAt(i)); i++)
+        ;
+      String tem = s.substring(done, i);
+      byte[] bytes;
+      try {
+        bytes = tem.getBytes(utf8);
+      }
+      catch (UnsupportedEncodingException e) {
+        utf8 = "UTF8";
+        try {
+          bytes = tem.getBytes(utf8);
+        }
+        catch (UnsupportedEncodingException e2) {
+          // Give up
+          return s;
+        }
+      }
+      for (int j = 0; j < bytes.length; j++) {
+        buf.append('%');
+        buf.append(HEX_DIGITS.charAt((bytes[j] & 0xFF) >> 4));
+        buf.append(HEX_DIGITS.charAt(bytes[j] & 0xF));
+      }
+      done = i;
+    }
+    return buf.toString();
+  }
+
+  private static final String excluded = "<>\"{}|\\^`";
+
+  private static boolean isExcluded(char c) {
+    return c <= 0x20 || c >= 0x7F || excluded.indexOf(c) >= 0;
+  }
+
+  private static boolean isAlpha(char c) {
+    return ('a' <= c && c <= 'z') || ('A' <= c && c <= 'Z');
+  }
+
+  private static boolean isHexDigit(char c) {
+    return ('a' <= c && c <= 'f') || ('A' <= c && c <= 'F') || isDigit(c);
+  }
+
+  private static boolean isDigit(char c) {
+    return '0' <= c && c <= '9';
+  }
+
+  private static boolean isSchemeChar(char c) {
+    return isAlpha(c) || isDigit(c) || c == '+' || c == '-' || c =='.';
+  }
+
+  private static boolean isValidPercent(String s) {
+    int len = s.length();
+    for (int i = 0; i < len; i++)
+      if (s.charAt(i) == '%') {
+        if (i + 2 >= len)
+          return false;
+        else if (!isHexDigit(s.charAt(i + 1))
+                 || !isHexDigit(s.charAt(i + 2)))
+          return false;
+      }
+    return true;
+  }
+
+  private static boolean isValidFragment(String s) {
+    int i = s.indexOf('#');
+    return i < 0 || s.indexOf('#', i + 1) < 0;
+  }
+
+  private static boolean isValidScheme(String s) {
+    if (!isAbsolute(s))
+      return true;
+    int i = s.indexOf(':');
+    if (i == 0
+        || i + 1 == s.length()
+        || !isAlpha(s.charAt(0)))
+      return false;
+    while (--i > 0)
+      if (!isSchemeChar(s.charAt(i)))
+        return false;
+    return true;
+  }
+
+  public static String resolve(String baseUri, String uriReference) {
+    if (!isAbsolute(uriReference) && baseUri != null && isAbsolute(baseUri)) {
+      try {
+        return new URL(new URL(baseUri), uriReference).toString();
+      }
+      catch (MalformedURLException e) { }
+    }
+    return uriReference;
+  }
+
+  public static boolean hasFragmentId(String uri) {
+    return uri.indexOf('#') >= 0;
+  }
+
+  public static boolean isAbsolute(String uri) {
+    int i = uri.indexOf(':');
+    if (i < 0)
+      return false;
+    while (--i >= 0) {
+      switch (uri.charAt(i)) {
+      case '#':
+      case '/':
+      case '?':
+        return false;
+      }
+    }
+    return true;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Utf16.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Utf16.java
new file mode 100644
index 0000000..caebb73
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/util/Utf16.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.util;
+
+public abstract class Utf16 {
+  // 110110XX XXXXXX 110111XX XXXXXX
+  static public boolean isSurrogate(char c) {
+    return (c & 0xF800) == 0xD800;
+  }
+  static public boolean isSurrogate1(char c) {
+    return (c & 0xFC00) == 0xD800;
+  }
+  static public boolean isSurrogate2(char c) {
+    return (c & 0xFC00) == 0xDC00;
+  }
+  static public int scalarValue(char c1, char c2) {
+    return (((c1 & 0x3FF) << 10) | (c2 & 0x3FF)) + 0x10000;
+  }
+  static public char surrogate1(int c) {
+    return (char)(((c - 0x10000) >> 10) | 0xD800);
+  }
+  static public char surrogate2(int c) {
+    return (char)(((c - 0x10000) & 0x3FF) | 0xDC00);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/AbstractLexicalHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/AbstractLexicalHandler.java
new file mode 100644
index 0000000..605c146
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/AbstractLexicalHandler.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.xml.sax;
+
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.SAXException;
+
+public class AbstractLexicalHandler implements LexicalHandler {
+  public void startDTD(String s, String s1, String s2) throws SAXException {
+  }
+
+  public void endDTD() throws SAXException {
+  }
+
+  public void startEntity(String s) throws SAXException {
+  }
+
+  public void endEntity(String s) throws SAXException {
+  }
+
+  public void startCDATA() throws SAXException {
+  }
+
+  public void endCDATA() throws SAXException {
+  }
+
+  public void comment(char[] chars, int start, int length) throws SAXException {
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/JAXPXMLReaderCreator.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/JAXPXMLReaderCreator.java
new file mode 100644
index 0000000..58998a8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/JAXPXMLReaderCreator.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.xml.sax;
+
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.parsers.SAXParserFactory;
+
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+
+/**
+ * {@link XMLReaderCreator} that uses JAXP to create
+ * {@link XMLReader}s.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class JAXPXMLReaderCreator implements XMLReaderCreator {
+
+    private final SAXParserFactory spf;
+
+    public JAXPXMLReaderCreator( SAXParserFactory spf ) {
+        this.spf = spf;
+    }
+
+    /**
+     * Creates a {@link JAXPXMLReaderCreator} by using
+     * {@link SAXParserFactory#newInstance()}.
+     */
+    public JAXPXMLReaderCreator() {
+        spf = SAXParserFactory.newInstance();
+        spf.setNamespaceAware(true);
+    }
+
+    /**
+     * @see com.sun.xml.internal.rngom.xml.sax.XMLReaderCreator#createXMLReader()
+     */
+    public XMLReader createXMLReader() throws SAXException {
+        try {
+            return spf.newSAXParser().getXMLReader();
+        } catch (ParserConfigurationException e) {
+            throw new SAXException(e);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/XMLReaderCreator.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/XMLReaderCreator.java
new file mode 100644
index 0000000..d7641a0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/XMLReaderCreator.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.xml.sax;
+
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+
+/**
+ * A factory for <code>XMLReader</code>s.  Thread-safety is determined by each particular
+ * implementation of this interface.
+ *
+ * @author <a href="mailto:jjc@jclark.com">James Clark</a>
+ */
+public interface XMLReaderCreator {
+  /**
+   * Creates a new <code>XMLReader</code>.
+   *
+   * @return a new <code>XMLReader</code>; never <code>null</code>
+   * @throws org.xml.sax.SAXException If an <code>XMLReader</code> cannot be created for any reason
+   */
+  XMLReader createXMLReader() throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/XmlBaseHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/XmlBaseHandler.java
new file mode 100644
index 0000000..d11044d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/sax/XmlBaseHandler.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.xml.sax;
+
+import com.sun.xml.internal.rngom.util.Uri;
+import org.xml.sax.Locator;
+
+public class XmlBaseHandler {
+  private int depth = 0;
+  private Locator loc;
+  private Entry stack = null;
+
+  private static class Entry {
+    private Entry parent;
+    private String attValue;
+    private String systemId;
+    private int depth;
+  }
+
+  public void setLocator(Locator loc) {
+    this.loc = loc;
+  }
+
+  public void startElement() {
+    ++depth;
+  }
+
+  public void endElement() {
+    if (stack != null && stack.depth == depth)
+      stack = stack.parent;
+    --depth;
+  }
+
+  public void xmlBaseAttribute(String value) {
+    Entry entry = new Entry();
+    entry.parent = stack;
+    stack = entry;
+    entry.attValue = Uri.escapeDisallowedChars(value);
+    entry.systemId = getSystemId();
+    entry.depth = depth;
+  }
+
+  private String getSystemId() {
+    return loc == null ? null : loc.getSystemId();
+  }
+
+  public String getBaseUri() {
+    return getBaseUri1(getSystemId(), stack);
+  }
+
+  private static String getBaseUri1(String baseUri, Entry stack) {
+    if (stack == null
+        || (baseUri != null && !baseUri.equals(stack.systemId)))
+      return baseUri;
+    baseUri = stack.attValue;
+    if (Uri.isAbsolute(baseUri))
+      return baseUri;
+    return Uri.resolve(getBaseUri1(stack.systemId, stack.parent), baseUri);
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/EncodingMap.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/EncodingMap.java
new file mode 100644
index 0000000..4a25f02
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/EncodingMap.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.xml.util;
+
+import java.io.UnsupportedEncodingException;
+
+public abstract class EncodingMap {
+  private static final String[] aliases = {
+    "UTF-8", "UTF8",
+    "UTF-16", "Unicode",
+    "UTF-16BE", "UnicodeBigUnmarked",
+    "UTF-16LE", "UnicodeLittleUnmarked",
+    "US-ASCII", "ASCII",
+    "TIS-620", "TIS620"
+  };
+
+  static public String getJavaName(String enc) {
+    try {
+      "x".getBytes(enc);
+    }
+    catch (UnsupportedEncodingException e) {
+      for (int i = 0; i < aliases.length; i += 2) {
+        if (enc.equalsIgnoreCase(aliases[i])) {
+          try {
+            "x".getBytes(aliases[i + 1]);
+            return aliases[i + 1];
+          }
+          catch (UnsupportedEncodingException e2) {}
+        }
+      }
+    }
+    return enc;
+  }
+
+  static public void main(String[] args) {
+    System.err.println(getJavaName(args[0]));
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/Naming.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/Naming.java
new file mode 100644
index 0000000..e333360
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/Naming.java
@@ -0,0 +1,206 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.xml.util;
+
+public class Naming {
+
+  private Naming() { }
+
+  private static final int CT_NAME = 1;
+  private static final int CT_NMSTRT = 2;
+
+  private static final String nameStartSingles =
+  "\u003a\u005f\u0386\u038c\u03da\u03dc\u03de\u03e0\u0559\u06d5\u093d\u09b2" +
+  "\u0a5e\u0a8d\u0abd\u0ae0\u0b3d\u0b9c\u0cde\u0e30\u0e84\u0e8a\u0e8d\u0ea5" +
+  "\u0ea7\u0eb0\u0ebd\u1100\u1109\u113c\u113e\u1140\u114c\u114e\u1150\u1159" +
+  "\u1163\u1165\u1167\u1169\u1175\u119e\u11a8\u11ab\u11ba\u11eb\u11f0\u11f9" +
+  "\u1f59\u1f5b\u1f5d\u1fbe\u2126\u212e\u3007";
+  private static final String nameStartRanges =
+  "\u0041\u005a\u0061\u007a\u00c0\u00d6\u00d8\u00f6\u00f8\u00ff\u0100\u0131" +
+  "\u0134\u013e\u0141\u0148\u014a\u017e\u0180\u01c3\u01cd\u01f0\u01f4\u01f5" +
+  "\u01fa\u0217\u0250\u02a8\u02bb\u02c1\u0388\u038a\u038e\u03a1\u03a3\u03ce" +
+  "\u03d0\u03d6\u03e2\u03f3\u0401\u040c\u040e\u044f\u0451\u045c\u045e\u0481" +
+  "\u0490\u04c4\u04c7\u04c8\u04cb\u04cc\u04d0\u04eb\u04ee\u04f5\u04f8\u04f9" +
+  "\u0531\u0556\u0561\u0586\u05d0\u05ea\u05f0\u05f2\u0621\u063a\u0641\u064a" +
+  "\u0671\u06b7\u06ba\u06be\u06c0\u06ce\u06d0\u06d3\u06e5\u06e6\u0905\u0939" +
+  "\u0958\u0961\u0985\u098c\u098f\u0990\u0993\u09a8\u09aa\u09b0\u09b6\u09b9" +
+  "\u09dc\u09dd\u09df\u09e1\u09f0\u09f1\u0a05\u0a0a\u0a0f\u0a10\u0a13\u0a28" +
+  "\u0a2a\u0a30\u0a32\u0a33\u0a35\u0a36\u0a38\u0a39\u0a59\u0a5c\u0a72\u0a74" +
+  "\u0a85\u0a8b\u0a8f\u0a91\u0a93\u0aa8\u0aaa\u0ab0\u0ab2\u0ab3\u0ab5\u0ab9" +
+  "\u0b05\u0b0c\u0b0f\u0b10\u0b13\u0b28\u0b2a\u0b30\u0b32\u0b33\u0b36\u0b39" +
+  "\u0b5c\u0b5d\u0b5f\u0b61\u0b85\u0b8a\u0b8e\u0b90\u0b92\u0b95\u0b99\u0b9a" +
+  "\u0b9e\u0b9f\u0ba3\u0ba4\u0ba8\u0baa\u0bae\u0bb5\u0bb7\u0bb9\u0c05\u0c0c" +
+  "\u0c0e\u0c10\u0c12\u0c28\u0c2a\u0c33\u0c35\u0c39\u0c60\u0c61\u0c85\u0c8c" +
+  "\u0c8e\u0c90\u0c92\u0ca8\u0caa\u0cb3\u0cb5\u0cb9\u0ce0\u0ce1\u0d05\u0d0c" +
+  "\u0d0e\u0d10\u0d12\u0d28\u0d2a\u0d39\u0d60\u0d61\u0e01\u0e2e\u0e32\u0e33" +
+  "\u0e40\u0e45\u0e81\u0e82\u0e87\u0e88\u0e94\u0e97\u0e99\u0e9f\u0ea1\u0ea3" +
+  "\u0eaa\u0eab\u0ead\u0eae\u0eb2\u0eb3\u0ec0\u0ec4\u0f40\u0f47\u0f49\u0f69" +
+  "\u10a0\u10c5\u10d0\u10f6\u1102\u1103\u1105\u1107\u110b\u110c\u110e\u1112" +
+  "\u1154\u1155\u115f\u1161\u116d\u116e\u1172\u1173\u11ae\u11af\u11b7\u11b8" +
+  "\u11bc\u11c2\u1e00\u1e9b\u1ea0\u1ef9\u1f00\u1f15\u1f18\u1f1d\u1f20\u1f45" +
+  "\u1f48\u1f4d\u1f50\u1f57\u1f5f\u1f7d\u1f80\u1fb4\u1fb6\u1fbc\u1fc2\u1fc4" +
+  "\u1fc6\u1fcc\u1fd0\u1fd3\u1fd6\u1fdb\u1fe0\u1fec\u1ff2\u1ff4\u1ff6\u1ffc" +
+  "\u212a\u212b\u2180\u2182\u3041\u3094\u30a1\u30fa\u3105\u312c\uac00\ud7a3" +
+  "\u4e00\u9fa5\u3021\u3029";
+  private static final String nameSingles =
+  "\u002d\u002e\u05bf\u05c4\u0670\u093c\u094d\u09bc\u09be\u09bf\u09d7\u0a02" +
+  "\u0a3c\u0a3e\u0a3f\u0abc\u0b3c\u0bd7\u0d57\u0e31\u0eb1\u0f35\u0f37\u0f39" +
+  "\u0f3e\u0f3f\u0f97\u0fb9\u20e1\u3099\u309a\u00b7\u02d0\u02d1\u0387\u0640" +
+  "\u0e46\u0ec6\u3005";
+  private static final String nameRanges =
+  "\u0300\u0345\u0360\u0361\u0483\u0486\u0591\u05a1\u05a3\u05b9\u05bb\u05bd" +
+  "\u05c1\u05c2\u064b\u0652\u06d6\u06dc\u06dd\u06df\u06e0\u06e4\u06e7\u06e8" +
+  "\u06ea\u06ed\u0901\u0903\u093e\u094c\u0951\u0954\u0962\u0963\u0981\u0983" +
+  "\u09c0\u09c4\u09c7\u09c8\u09cb\u09cd\u09e2\u09e3\u0a40\u0a42\u0a47\u0a48" +
+  "\u0a4b\u0a4d\u0a70\u0a71\u0a81\u0a83\u0abe\u0ac5\u0ac7\u0ac9\u0acb\u0acd" +
+  "\u0b01\u0b03\u0b3e\u0b43\u0b47\u0b48\u0b4b\u0b4d\u0b56\u0b57\u0b82\u0b83" +
+  "\u0bbe\u0bc2\u0bc6\u0bc8\u0bca\u0bcd\u0c01\u0c03\u0c3e\u0c44\u0c46\u0c48" +
+  "\u0c4a\u0c4d\u0c55\u0c56\u0c82\u0c83\u0cbe\u0cc4\u0cc6\u0cc8\u0cca\u0ccd" +
+  "\u0cd5\u0cd6\u0d02\u0d03\u0d3e\u0d43\u0d46\u0d48\u0d4a\u0d4d\u0e34\u0e3a" +
+  "\u0e47\u0e4e\u0eb4\u0eb9\u0ebb\u0ebc\u0ec8\u0ecd\u0f18\u0f19\u0f71\u0f84" +
+  "\u0f86\u0f8b\u0f90\u0f95\u0f99\u0fad\u0fb1\u0fb7\u20d0\u20dc\u302a\u302f" +
+  "\u0030\u0039\u0660\u0669\u06f0\u06f9\u0966\u096f\u09e6\u09ef\u0a66\u0a6f" +
+  "\u0ae6\u0aef\u0b66\u0b6f\u0be7\u0bef\u0c66\u0c6f\u0ce6\u0cef\u0d66\u0d6f" +
+  "\u0e50\u0e59\u0ed0\u0ed9\u0f20\u0f29\u3031\u3035\u309d\u309e\u30fc\u30fe";
+
+  private final static byte[][] charTypeTable;
+
+  static {
+    charTypeTable = new byte[256][];
+    for (int i = 0; i < nameSingles.length(); i++)
+      setCharType(nameSingles.charAt(i), CT_NAME);
+    for (int i = 0; i < nameRanges.length(); i += 2)
+      setCharType(nameRanges.charAt(i), nameRanges.charAt(i + 1), CT_NAME);
+    for (int i = 0; i < nameStartSingles.length(); i++)
+      setCharType(nameStartSingles.charAt(i), CT_NMSTRT);
+    for (int i = 0; i < nameStartRanges.length(); i += 2)
+      setCharType(nameStartRanges.charAt(i), nameStartRanges.charAt(i + 1),
+                  CT_NMSTRT);
+    byte[] other = new byte[256];
+    for (int i = 0; i < 256; i++)
+      if (charTypeTable[i] == null)
+        charTypeTable[i] = other;
+  }
+
+  private static void setCharType(char c, int type) {
+    int hi = c >> 8;
+    if (charTypeTable[hi] == null)
+      charTypeTable[hi] = new byte[256];
+    charTypeTable[hi][c & 0xFF] = (byte)type;
+  }
+
+  private static void setCharType(char min, char max, int type) {
+    byte[] shared = null;
+    do {
+      if ((min & 0xFF) == 0) {
+        for (; min + 0xFF <= max; min += 0x100) {
+          if (shared == null) {
+            shared = new byte[256];
+            for (int i = 0; i < 256; i++)
+              shared[i] = (byte)type;
+          }
+          charTypeTable[min >> 8] = shared;
+          if (min + 0xFF == max)
+            return;
+        }
+      }
+      setCharType(min, type);
+    } while (min++ != max);
+  }
+
+  private static boolean isNameStartChar(char c) {
+    return charTypeTable[c >> 8][c & 0xff] == CT_NMSTRT;
+  }
+
+  private static boolean isNameStartCharNs(char c) {
+    return isNameStartChar(c) && c != ':';
+  }
+
+  private static boolean isNameChar(char c) {
+    return charTypeTable[c >> 8][c & 0xff] != 0;
+  }
+
+  private static boolean isNameCharNs(char c) {
+    return isNameChar(c) && c != ':';
+  }
+
+  public static boolean isName(String s) {
+    int len = s.length();
+    if (len == 0)
+      return false;
+    if (!isNameStartChar(s.charAt(0)))
+      return false;
+    for (int i = 1; i < len; i++)
+      if (!isNameChar(s.charAt(i)))
+        return false;
+    return true;
+  }
+
+  public static boolean isNmtoken(String s) {
+    int len = s.length();
+    if (len == 0)
+      return false;
+    for (int i = 0; i < len; i++)
+      if (!isNameChar(s.charAt(i)))
+        return false;
+    return true;
+  }
+
+  public static boolean isNcname(String s) {
+    int len = s.length();
+    if (len == 0)
+      return false;
+    if (!isNameStartCharNs(s.charAt(0)))
+      return false;
+    for (int i = 1; i < len; i++)
+      if (!isNameCharNs(s.charAt(i)))
+        return false;
+    return true;
+  }
+
+  public static boolean isQname(String s) {
+    int len = s.length();
+    if (len == 0)
+      return false;
+    if (!isNameStartCharNs(s.charAt(0)))
+      return false;
+    for (int i = 1; i < len; i++) {
+      char c = s.charAt(i);
+      if (!isNameChar(c)) {
+        if (c == ':' && ++i < len && isNameStartCharNs(s.charAt(i))) {
+          for (++i; i < len; i++)
+            if (!isNameCharNs(s.charAt(i)))
+              return false;
+          return true;
+        }
+        return false;
+      }
+    }
+    return true;
+  }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/WellKnownNamespaces.java b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/WellKnownNamespaces.java
new file mode 100644
index 0000000..2c7021c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/rngom/xml/util/WellKnownNamespaces.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.rngom.xml.util;
+
+public class WellKnownNamespaces {
+  static public final String XML = "http://www.w3.org/XML/1998/namespace";
+  static public final String XMLNS = "http://www.w3.org/2000/xmlns";
+  static public final String XML_SCHEMA_DATATYPES = "http://www.w3.org/2001/XMLSchema-datatypes";
+  static public final String XML_SCHEMA = "http://www.w3.org/2001/XMLSchema";
+  static public final String RELAX_NG_COMPATIBILITY_DATATYPES = "http://relaxng.org/ns/compatibility/datatypes/1.0";
+  static public final String RELAX_NG = "http://relaxng.org/ns/structure/1.0";
+  static public final String RELAX_NG_0_9 = "http://relaxng.org/ns/structure/0.9";
+  static public final String RELAX_NG_COMPATIBILITY_ANNOTATIONS = "http://relaxng.org/ns/compatibility/annotations/1.0";
+
+  private WellKnownNamespaces() {
+  }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/Attribute.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Attribute.java
new file mode 100644
index 0000000..40f05db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Attribute.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class Attribute {
+    final String nsUri;
+    final String localName;
+
+    /**
+     * Attributes of an element form a linked list.
+     */
+    Attribute next;
+
+    /**
+     * Attribute value that potentially contains dummy prefixes.
+     */
+    final StringBuilder value = new StringBuilder();
+
+    Attribute(String nsUri, String localName) {
+        assert nsUri!=null && localName!=null;
+
+        this.nsUri = nsUri;
+        this.localName = localName;
+    }
+
+    boolean hasName( String nsUri, String localName ) {
+        return this.localName.equals(localName) && this.nsUri.equals(nsUri);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/Cdata.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Cdata.java
new file mode 100644
index 0000000..e28fa76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Cdata.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * CDATA section.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class Cdata extends Text {
+    Cdata(Document document, NamespaceResolver nsResolver, Object obj) {
+        super(document, nsResolver, obj);
+    }
+
+    void accept(ContentVisitor visitor) {
+        visitor.onCdata(buffer);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/Comment.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Comment.java
new file mode 100644
index 0000000..95ae608
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Comment.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * Comment.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class Comment extends Content {
+    /**
+     * The text to be writtten.
+     */
+    private final StringBuilder buffer = new StringBuilder();
+
+    public Comment(Document document, NamespaceResolver nsResolver, Object obj) {
+        document.writeValue(obj,nsResolver,buffer);
+    }
+
+    boolean concludesPendingStartTag() {
+        return false;
+    }
+
+    void accept(ContentVisitor visitor) {
+        visitor.onComment(buffer);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/ContainerElement.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/ContainerElement.java
new file mode 100644
index 0000000..d07d3ce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/ContainerElement.java
@@ -0,0 +1,375 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.txw2.annotation.XmlNamespace;
+import com.sun.xml.internal.txw2.annotation.XmlValue;
+import com.sun.xml.internal.txw2.annotation.XmlCDATA;
+
+import javax.xml.namespace.QName;
+import java.lang.reflect.InvocationHandler;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.lang.reflect.Proxy;
+
+/**
+ * Dynamically implements {@link TypedXmlWriter} interfaces.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class ContainerElement implements InvocationHandler, TypedXmlWriter {
+
+    final Document document;
+
+    /**
+     * Initially, point to the start tag token, but
+     * once we know we are done with the start tag, we will reset it to null
+     * so that the token sequence can be GC-ed.
+     */
+    StartTag startTag;
+    final EndTag endTag = new EndTag();
+
+    /**
+     * Namespace URI of this element.
+     */
+    private final String nsUri;
+
+    /**
+     * When this element can accept more child content, this value
+     * is non-null and holds the last child {@link Content}.
+     *
+     * If this element is committed, this parameter is null.
+     */
+    private Content tail;
+
+    /**
+     * Uncommitted {@link ContainerElement}s form a doubly-linked list,
+     * so that the parent can close them recursively.
+     */
+    private ContainerElement prevOpen;
+    private ContainerElement nextOpen;
+    private final ContainerElement parent;
+    private ContainerElement lastOpenChild;
+
+    /**
+     * Set to true if the start eleent is blocked.
+     */
+    private boolean blocked;
+
+    public ContainerElement(Document document,ContainerElement parent,String nsUri, String localName) {
+        this.parent = parent;
+        this.document = document;
+        this.nsUri = nsUri;
+        this.startTag = new StartTag(this,nsUri,localName);
+        tail = startTag;
+
+        if(isRoot())
+            document.setFirstContent(startTag);
+    }
+
+    private boolean isRoot() {
+        return parent==null;
+    }
+
+    private boolean isCommitted() {
+        return tail==null;
+    }
+
+    public Document getDocument() {
+        return document;
+    }
+
+    boolean isBlocked() {
+        return blocked && !isCommitted();
+    }
+
+    public void block() {
+        blocked = true;
+    }
+
+    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
+        if(method.getDeclaringClass()==TypedXmlWriter.class || method.getDeclaringClass()==Object.class) {
+            // forward to myself
+            try {
+                return method.invoke(this,args);
+            } catch (InvocationTargetException e) {
+                throw e.getTargetException();
+            }
+        }
+
+        XmlAttribute xa = method.getAnnotation(XmlAttribute.class);
+        XmlValue xv = method.getAnnotation(XmlValue.class);
+        XmlElement xe = method.getAnnotation(XmlElement.class);
+
+
+        if(xa!=null) {
+            if(xv!=null || xe!=null)
+                throw new IllegalAnnotationException(method.toString());
+
+            addAttribute(xa,method,args);
+            return proxy; // allow method chaining
+        }
+        if(xv!=null) {
+            if(xe!=null)
+                throw new IllegalAnnotationException(method.toString());
+
+            _pcdata(args);
+            return proxy; // allow method chaining
+        }
+
+        return addElement(xe,method,args);
+    }
+
+    /**
+     * Writes an attribute.
+     */
+    private void addAttribute(XmlAttribute xa, Method method, Object[] args) {
+        assert xa!=null;
+
+        checkStartTag();
+
+        String localName = xa.value();
+        if(xa.value().length()==0)
+            localName = method.getName();
+
+        _attribute(xa.ns(),localName,args);
+    }
+
+    private void checkStartTag() {
+        if(startTag==null)
+            throw new IllegalStateException("start tag has already been written");
+    }
+
+    /**
+     * Writes a new element.
+     */
+    private Object addElement(XmlElement e, Method method, Object[] args) {
+        Class<?> rt = method.getReturnType();
+
+        // the last precedence: default name
+        String nsUri = "##default";
+        String localName = method.getName();
+
+        if(e!=null) {
+            // then the annotation on this method
+            if(e.value().length()!=0)
+                localName = e.value();
+            nsUri = e.ns();
+        }
+
+        if(nsUri.equals("##default")) {
+            // look for the annotation on the declaring class
+            Class<?> c = method.getDeclaringClass();
+            XmlElement ce = c.getAnnotation(XmlElement.class);
+            if(ce!=null) {
+                nsUri = ce.ns();
+            }
+
+            if(nsUri.equals("##default"))
+                // then default to the XmlNamespace
+                nsUri = getNamespace(c.getPackage());
+        }
+
+
+
+        if(rt==Void.TYPE) {
+            // leaf element with just a value
+
+            boolean isCDATA = method.getAnnotation(XmlCDATA.class)!=null;
+
+            StartTag st = new StartTag(document,nsUri,localName);
+            addChild(st);
+            for( Object arg : args ) {
+                Text text;
+                if(isCDATA)     text = new Cdata(document,st,arg);
+                else            text = new Pcdata(document,st,arg);
+                addChild(text);
+            }
+            addChild(new EndTag());
+            return null;
+        }
+        if(TypedXmlWriter.class.isAssignableFrom(rt)) {
+            // sub writer
+            return _element(nsUri,localName,(Class)rt);
+        }
+
+        throw new IllegalSignatureException("Illegal return type: "+rt);
+    }
+
+    /**
+     * Decides the namespace URI of the given package.
+     */
+    private String getNamespace(Package pkg) {
+        if(pkg==null)       return "";
+
+        String nsUri;
+        XmlNamespace ns = pkg.getAnnotation(XmlNamespace.class);
+        if(ns!=null)
+            nsUri = ns.value();
+        else
+            nsUri = "";
+        return nsUri;
+    }
+
+    /**
+     * Appends this child object to the tail.
+     */
+    private void addChild(Content child) {
+        tail.setNext(document,child);
+        tail = child;
+    }
+
+    public void commit() {
+        commit(true);
+    }
+
+    public void commit(boolean includingAllPredecessors) {
+        _commit(includingAllPredecessors);
+        document.flush();
+    }
+
+    private void _commit(boolean includingAllPredecessors) {
+        if(isCommitted())  return;
+
+        addChild(endTag);
+        if(isRoot())
+            addChild(new EndDocument());
+        tail = null;
+
+        // _commit predecessors if so told
+        if(includingAllPredecessors) {
+            for( ContainerElement e=this; e!=null; e=e.parent ) {
+                while(e.prevOpen!=null) {
+                    e.prevOpen._commit(false);
+                    // e.prevOpen should change as a result of committing it.
+                }
+            }
+        }
+
+        // _commit all children recursively
+        while(lastOpenChild!=null)
+            lastOpenChild._commit(false);
+
+        // remove this node from the link
+        if(parent!=null) {
+            if(parent.lastOpenChild==this) {
+                assert nextOpen==null : "this must be the last one";
+                parent.lastOpenChild = prevOpen;
+            } else {
+                assert nextOpen.prevOpen==this;
+                nextOpen.prevOpen = this.prevOpen;
+            }
+            if(prevOpen!=null) {
+                assert prevOpen.nextOpen==this;
+                prevOpen.nextOpen = this.nextOpen;
+            }
+        }
+
+        this.nextOpen = null;
+        this.prevOpen = null;
+    }
+
+    public void _attribute(String localName, Object value) {
+        _attribute("",localName,value);
+    }
+
+    public void _attribute(String nsUri, String localName, Object value) {
+        checkStartTag();
+        startTag.addAttribute(nsUri,localName,value);
+    }
+
+    public void _attribute(QName attributeName, Object value) {
+        _attribute(attributeName.getNamespaceURI(),attributeName.getLocalPart(),value);
+    }
+
+    public void _namespace(String uri) {
+        _namespace(uri,false);
+    }
+
+    public void _namespace(String uri, String prefix) {
+        if(prefix==null)
+            throw new IllegalArgumentException();
+        checkStartTag();
+        startTag.addNamespaceDecl(uri,prefix,false);
+    }
+
+    public void _namespace(String uri, boolean requirePrefix) {
+        checkStartTag();
+        startTag.addNamespaceDecl(uri,null,requirePrefix);
+    }
+
+    public void _pcdata(Object value) {
+        // we need to allow this method even when startTag has already been completed.
+        // checkStartTag();
+        addChild(new Pcdata(document,startTag,value));
+    }
+
+    public void _cdata(Object value) {
+        addChild(new Cdata(document,startTag,value));
+    }
+
+    public void _comment(Object value) throws UnsupportedOperationException {
+        addChild(new Comment(document,startTag,value));
+    }
+
+    public <T extends TypedXmlWriter> T _element(String localName, Class<T> contentModel) {
+        return _element(nsUri,localName,contentModel);
+    }
+
+    public <T extends TypedXmlWriter> T _element(QName tagName, Class<T> contentModel) {
+        return _element(tagName.getNamespaceURI(),tagName.getLocalPart(),contentModel);
+    }
+
+    public <T extends TypedXmlWriter> T _element(Class<T> contentModel) {
+        return _element(TXW.getTagName(contentModel),contentModel);
+    }
+
+    public <T extends TypedXmlWriter> T _cast(Class<T> facadeType) {
+        return facadeType.cast(Proxy.newProxyInstance(facadeType.getClassLoader(),new Class[]{facadeType},this));
+    }
+
+    public <T extends TypedXmlWriter> T _element(String nsUri, String localName, Class<T> contentModel) {
+        ContainerElement child = new ContainerElement(document,this,nsUri,localName);
+        addChild(child.startTag);
+        tail = child.endTag;
+
+        // update uncommitted link list
+        if(lastOpenChild!=null) {
+            assert lastOpenChild.parent==this;
+
+            assert child.prevOpen==null;
+            assert child.nextOpen==null;
+            child.prevOpen = lastOpenChild;
+            assert lastOpenChild.nextOpen==null;
+            lastOpenChild.nextOpen = child;
+        }
+
+        this.lastOpenChild = child;
+
+        return child._cast(contentModel);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/Content.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Content.java
new file mode 100644
index 0000000..0be8c32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Content.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+abstract class Content {
+    private Content next;
+
+    /**
+     * Returns null if the next token has not decided yet.
+     */
+    final Content getNext() {
+        return next;
+    }
+
+    /**
+     *
+     * @param doc
+     *      A {@link Content} object is so light-weight that
+     *      it doesn't even remember what document it belongs to.
+     *      So the caller needs to "remind" a {@link Content}
+     *      who its owner is.
+     */
+    final void setNext(Document doc,Content next) {
+        assert next!=null;
+        assert this.next==null : "next of "+this+" is already set to "+this.next;
+        this.next = next;
+        doc.run();
+    }
+
+    /**
+     * Returns true if this content is ready to be committed.
+     */
+    boolean isReadyToCommit() {
+        return true;
+    }
+
+    /**
+     * Returns true if this {@link Content} can guarantee that
+     * no more new namespace decls is necessary for the currently
+     * pending start tag.
+     */
+    abstract boolean concludesPendingStartTag();
+
+    /**
+     * Accepts a visitor.
+     */
+    abstract void accept(ContentVisitor visitor);
+
+    /**
+     * Called when this content is written to the output.
+     */
+    public void written() {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/ContentVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/ContentVisitor.java
new file mode 100644
index 0000000..fc93d60
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/ContentVisitor.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * Visits {@link Content}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+interface ContentVisitor {
+    void onStartDocument();
+
+    void onEndDocument();
+
+    void onEndTag();
+
+    void onPcdata(StringBuilder buffer);
+
+    void onCdata(StringBuilder buffer);
+
+    void onStartTag(String nsUri, String localName, Attribute attributes, NamespaceDecl namespaces);
+
+    void onComment(StringBuilder buffer);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/DatatypeWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/DatatypeWriter.java
new file mode 100644
index 0000000..3b6c350
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/DatatypeWriter.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Pluggable datatype writer.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface DatatypeWriter<DT> {
+
+    /**
+     * Gets the Java class that this writer can write.
+     *
+     * @return
+     *      must not be null. Must be the same value always.
+     */
+    Class<DT> getType();
+
+    /**
+     * Prints the given datatype object and appends that result
+     * into the given buffer.
+     *
+     * @param dt
+     *      the datatype object to be printed.
+     * @param resolver
+     *      allows the converter to declare additional namespace prefixes.
+     */
+    void print(DT dt, NamespaceResolver resolver, StringBuilder buf);
+
+
+    static final DatatypeWriter<?>[] BUILDIN = new DatatypeWriter<?>[] {
+        new DatatypeWriter<String>() {
+            public Class<String> getType() {
+                return String.class;
+            }
+            public void print(String s, NamespaceResolver resolver, StringBuilder buf) {
+                buf.append(s);
+            }
+        },
+        new DatatypeWriter<Integer>() {
+            public Class<Integer> getType() {
+                return Integer.class;
+            }
+            public void print(Integer i, NamespaceResolver resolver, StringBuilder buf) {
+                buf.append(i);
+            }
+        },
+        new DatatypeWriter<Float>() {
+            public Class<Float> getType() {
+                return Float.class;
+            }
+            public void print(Float f, NamespaceResolver resolver, StringBuilder buf) {
+                buf.append(f);
+            }
+        },
+        new DatatypeWriter<Double>() {
+            public Class<Double> getType() {
+                return Double.class;
+            }
+            public void print(Double d, NamespaceResolver resolver, StringBuilder buf) {
+                buf.append(d);
+            }
+        },
+        new DatatypeWriter<QName>() {
+            public Class<QName> getType() {
+                return QName.class;
+            }
+            public void print(QName qn, NamespaceResolver resolver, StringBuilder buf) {
+                String p = resolver.getPrefix(qn.getNamespaceURI());
+                if(p.length()!=0)
+                    buf.append(p).append(':');
+                buf.append(qn.getLocalPart());
+            }
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/Document.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Document.java
new file mode 100644
index 0000000..e7bda23
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Document.java
@@ -0,0 +1,337 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+import com.sun.xml.internal.txw2.output.XmlSerializer;
+
+import java.util.Map;
+import java.util.HashMap;
+
+/**
+ * Coordinates the entire writing process.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class Document {
+
+    private final XmlSerializer out;
+
+    /**
+     * Set to true once we invoke {@link XmlSerializer#startDocument()}.
+     *
+     * <p>
+     * This is so that we can defer the writing as much as possible.
+     */
+    private boolean started=false;
+
+    /**
+     * Currently active writer.
+     *
+     * <p>
+     * This points to the last written token.
+     */
+    private Content current = null;
+
+    private final Map<Class,DatatypeWriter> datatypeWriters = new HashMap<Class,DatatypeWriter>();
+
+    /**
+     * Used to generate unique namespace prefix.
+     */
+    private int iota = 1;
+
+    /**
+     * Used to keep track of in-scope namespace bindings declared in ancestors.
+     */
+    private final NamespaceSupport inscopeNamespace = new NamespaceSupport();
+
+    /**
+     * Remembers the namespace declarations of the last unclosed start tag,
+     * so that we can fix up dummy prefixes in {@link Pcdata}.
+     */
+    private NamespaceDecl activeNamespaces;
+
+
+    Document(XmlSerializer out) {
+        this.out = out;
+        for( DatatypeWriter dw : DatatypeWriter.BUILDIN )
+            datatypeWriters.put(dw.getType(),dw);
+    }
+
+    void flush() {
+        out.flush();
+    }
+
+    void setFirstContent(Content c) {
+        assert current==null;
+        current = new StartDocument();
+        current.setNext(this,c);
+    }
+
+    /**
+     * Defines additional user object -> string conversion logic.
+     *
+     * <p>
+     * Applications can add their own {@link DatatypeWriter} so that
+     * application-specific objects can be turned into {@link String}
+     * for output.
+     *
+     * @param dw
+     *      The {@link DatatypeWriter} to be added. Must not be null.
+     */
+    public void addDatatypeWriter( DatatypeWriter<?> dw ) {
+        datatypeWriters.put(dw.getType(),dw);
+    }
+
+    /**
+     * Performs the output as much as possible
+     */
+    void run() {
+        while(true) {
+            Content next = current.getNext();
+            if(next==null || !next.isReadyToCommit())
+                return;
+            next.accept(visitor);
+            next.written();
+            current = next;
+        }
+    }
+
+    /**
+     * Appends the given object to the end of the given buffer.
+     *
+     * @param nsResolver
+     *      use
+     */
+    void writeValue( Object obj, NamespaceResolver nsResolver, StringBuilder buf ) {
+        if(obj==null)
+            throw new IllegalArgumentException("argument contains null");
+
+        if(obj instanceof Object[]) {
+            for( Object o : (Object[])obj )
+                writeValue(o,nsResolver,buf);
+            return;
+        }
+        if(obj instanceof Iterable) {
+            for( Object o : (Iterable<?>)obj )
+                writeValue(o,nsResolver,buf);
+            return;
+        }
+
+        if(buf.length()>0)
+            buf.append(' ');
+
+        Class c = obj.getClass();
+        while(c!=null) {
+            DatatypeWriter dw = datatypeWriters.get(c);
+            if(dw!=null) {
+                dw.print(obj,nsResolver,buf);
+                return;
+            }
+            c = c.getSuperclass();
+        }
+
+        // if nothing applies, just use toString
+        buf.append(obj);
+    }
+
+    // I wanted to hide those write method from users
+    private final ContentVisitor visitor = new ContentVisitor() {
+        public void onStartDocument() {
+            // the startDocument token is used as the sentry, so this method shall never
+            // be called.
+            // out.startDocument() is invoked when we write the start tag of the root element.
+            throw new IllegalStateException();
+        }
+
+        public void onEndDocument() {
+            out.endDocument();
+        }
+
+        public void onEndTag() {
+            out.endTag();
+            inscopeNamespace.popContext();
+            activeNamespaces = null;
+        }
+
+        public void onPcdata(StringBuilder buffer) {
+            if(activeNamespaces!=null)
+                buffer = fixPrefix(buffer);
+            out.text(buffer);
+        }
+
+        public void onCdata(StringBuilder buffer) {
+            if(activeNamespaces!=null)
+                buffer = fixPrefix(buffer);
+            out.cdata(buffer);
+        }
+
+        public void onComment(StringBuilder buffer) {
+            if(activeNamespaces!=null)
+                buffer = fixPrefix(buffer);
+            out.comment(buffer);
+        }
+
+        public void onStartTag(String nsUri, String localName, Attribute attributes, NamespaceDecl namespaces) {
+            assert nsUri!=null;
+            assert localName!=null;
+
+            activeNamespaces = namespaces;
+
+            if(!started) {
+                started = true;
+                out.startDocument();
+            }
+
+            inscopeNamespace.pushContext();
+
+            // declare the explicitly bound namespaces
+            for( NamespaceDecl ns=namespaces; ns!=null; ns=ns.next ) {
+                ns.declared = false;    // reset this flag
+
+                if(ns.prefix!=null) {
+                    String uri = inscopeNamespace.getURI(ns.prefix);
+                    if(uri!=null && uri.equals(ns.uri))
+                        ; // already declared
+                    else {
+                        // declare this new binding
+                        inscopeNamespace.declarePrefix(ns.prefix,ns.uri);
+                        ns.declared = true;
+                    }
+                }
+            }
+
+            // then use in-scope namespace to assign prefixes to others
+            for( NamespaceDecl ns=namespaces; ns!=null; ns=ns.next ) {
+                if(ns.prefix==null) {
+                    if(inscopeNamespace.getURI("").equals(ns.uri))
+                        ns.prefix="";
+                    else {
+                        String p = inscopeNamespace.getPrefix(ns.uri);
+                        if(p==null) {
+                            // assign a new one
+                            while(inscopeNamespace.getURI(p=newPrefix())!=null)
+                                ;
+                            ns.declared = true;
+                            inscopeNamespace.declarePrefix(p,ns.uri);
+                        }
+                        ns.prefix = p;
+                    }
+                }
+            }
+
+            // the first namespace decl must be the one for the element
+            assert namespaces.uri.equals(nsUri);
+            assert namespaces.prefix!=null : "a prefix must have been all allocated";
+            out.beginStartTag(nsUri,localName,namespaces.prefix);
+
+            // declare namespaces
+            for( NamespaceDecl ns=namespaces; ns!=null; ns=ns.next ) {
+                if(ns.declared)
+                    out.writeXmlns( ns.prefix, ns.uri );
+            }
+
+            // writeBody attributes
+            for( Attribute a=attributes; a!=null; a=a.next) {
+                String prefix;
+                if(a.nsUri.length()==0) prefix="";
+                else                    prefix=inscopeNamespace.getPrefix(a.nsUri);
+                out.writeAttribute( a.nsUri, a.localName, prefix, fixPrefix(a.value) );
+            }
+
+            out.endStartTag(nsUri,localName,namespaces.prefix);
+        }
+    };
+
+    /**
+     * Used by {@link #newPrefix()}.
+     */
+    private final StringBuilder prefixSeed = new StringBuilder("ns");
+
+    private int prefixIota = 0;
+
+    /**
+     * Allocates a new unique prefix.
+     */
+    private String newPrefix() {
+        prefixSeed.setLength(2);
+        prefixSeed.append(++prefixIota);
+        return prefixSeed.toString();
+    }
+
+    /**
+     * Replaces dummy prefixes in the value to the real ones
+     * by using {@link #activeNamespaces}.
+     *
+     * @return
+     *      the buffer passed as the <tt>buf</tt> parameter.
+     */
+    private StringBuilder fixPrefix(StringBuilder buf) {
+        assert activeNamespaces!=null;
+
+        int i;
+        int len=buf.length();
+        for(i=0;i<len;i++)
+            if( buf.charAt(i)==MAGIC )
+                break;
+        // typically it doens't contain any prefix.
+        // just return the original buffer in that case
+        if(i==len)
+            return buf;
+
+        while(i<len) {
+            char uriIdx = buf.charAt(i+1);
+            NamespaceDecl ns = activeNamespaces;
+            while(ns!=null && ns.uniqueId!=uriIdx)
+                ns=ns.next;
+            if(ns==null)
+                throw new IllegalStateException("Unexpected use of prefixes "+buf);
+
+            int length = 2;
+            String prefix = ns.prefix;
+            if(prefix.length()==0) {
+                if(buf.length()<=i+2 || buf.charAt(i+2)!=':')
+                    throw new IllegalStateException("Unexpected use of prefixes "+buf);
+                length=3;
+            }
+
+            buf.replace(i,i+length,prefix);
+            len += prefix.length()-length;
+
+            while(i<len && buf.charAt(i)!=MAGIC)
+                i++;
+        }
+
+        return buf;
+    }
+
+    /**
+     * The first char of the dummy prefix.
+     */
+    static final char MAGIC = '\u0000';
+
+    char assignNewId() {
+        return (char)iota++;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/EndDocument.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/EndDocument.java
new file mode 100644
index 0000000..0402c56
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/EndDocument.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class EndDocument extends Content {
+    boolean concludesPendingStartTag() {
+        return true;
+    }
+
+    void accept(ContentVisitor visitor) {
+        visitor.onEndDocument();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/EndTag.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/EndTag.java
new file mode 100644
index 0000000..34b3964
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/EndTag.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class EndTag extends Content {
+    boolean concludesPendingStartTag() {
+        return true;
+    }
+
+    void accept(ContentVisitor visitor) {
+        visitor.onEndTag();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/IllegalAnnotationException.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/IllegalAnnotationException.java
new file mode 100644
index 0000000..5a02573
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/IllegalAnnotationException.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * Signals an incorrect use of TXW annotations.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class IllegalAnnotationException extends TxwException {
+    public IllegalAnnotationException(String message) {
+        super(message);
+    }
+
+    public IllegalAnnotationException(Throwable cause) {
+        super(cause);
+    }
+
+    public IllegalAnnotationException(String message, Throwable cause) {
+        super(message, cause);
+    }
+
+    private static final long serialVersionUID = 1L;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/IllegalSignatureException.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/IllegalSignatureException.java
new file mode 100644
index 0000000..b714779
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/IllegalSignatureException.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * Signals incorrect method signatures on {@link TypedXmlWriter}-derived interfaces.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class IllegalSignatureException extends TxwException {
+    public IllegalSignatureException(String message) {
+        super(message);
+    }
+
+    public IllegalSignatureException(String message, Throwable cause) {
+        super(message, cause);
+    }
+
+    public IllegalSignatureException(Throwable cause) {
+        super(cause);
+    }
+
+    private static final long serialVersionUID = 1L;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceDecl.java
new file mode 100644
index 0000000..48003a9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceDecl.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * Namespace declarations.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class NamespaceDecl {
+    final String uri;
+
+    boolean requirePrefix;
+
+    /**
+     * Dummy prefix assigned for this namespace decl.
+     */
+    final String dummyPrefix;
+
+    final char uniqueId;
+
+    /**
+     * Set to the real prefix once that's computed.
+     */
+    String prefix;
+
+    /**
+     * Used temporarily inside {@link Document#finalizeStartTag()}.
+     * true if this prefix is declared on the new element.
+     */
+    boolean declared;
+
+    /**
+     * Namespace declarations form a linked list.
+     */
+    NamespaceDecl next;
+
+    NamespaceDecl(char uniqueId, String uri, String prefix, boolean requirePrefix ) {
+        this.dummyPrefix = new StringBuilder(2).append(Document.MAGIC).append(uniqueId).toString();
+        this.uri = uri;
+        this.prefix = prefix;
+        this.requirePrefix = requirePrefix;
+        this.uniqueId = uniqueId;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceResolver.java
new file mode 100644
index 0000000..c182d2c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceResolver.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * Used by {@link DatatypeWriter} to declare additional namespaces.
+ *
+ * @see DatatypeWriter
+ * @author Kohsuke Kawaguchi
+ */
+public interface NamespaceResolver {
+    /**
+     * Allocates a prefix for the specified URI and returns it.
+     *
+     * @param nsUri
+     *      the namespace URI to be declared. Can be empty but must not be null.
+     * @return
+     *      the empty string if the URI is bound to the default namespace.
+     *      Otherwise a non-empty string that represents a prefix.
+     */
+    String getPrefix(String nsUri);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceSupport.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceSupport.java
new file mode 100644
index 0000000..8dd4c21
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/NamespaceSupport.java
@@ -0,0 +1,841 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+// NamespaceSupport.java - generic Namespace support for SAX.
+// http://www.saxproject.org
+// Written by David Megginson
+// This class is in the Public Domain.  NO WARRANTY!
+// $Id: NamespaceSupport.java,v 1.1 2005/04/14 21:45:18 kohsuke Exp $
+
+package com.sun.xml.internal.txw2;
+
+import java.util.EmptyStackException;
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.util.Vector;
+
+
+/**
+ * Encapsulate Namespace logic for use by applications using SAX,
+ * or internally by SAX drivers.
+ *
+ * <blockquote>
+ * <em>This module, both source code and documentation, is in the
+ * Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
+ * See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
+ * for further information.
+ * </blockquote>
+ *
+ * <p>This class encapsulates the logic of Namespace processing: it
+ * tracks the declarations currently in force for each context and
+ * automatically processes qualified XML names into their Namespace
+ * parts; it can also be used in reverse for generating XML qnames
+ * from Namespaces.</p>
+ *
+ * <p>Namespace support objects are reusable, but the reset method
+ * must be invoked between each session.</p>
+ *
+ * <p>Here is a simple session:</p>
+ *
+ * <pre>
+ * String parts[] = new String[3];
+ * NamespaceSupport support = new NamespaceSupport();
+ *
+ * support.pushContext();
+ * support.declarePrefix("", "http://www.w3.org/1999/xhtml");
+ * support.declarePrefix("dc", "http://www.purl.org/dc#");
+ *
+ * parts = support.processName("p", parts, false);
+ * System.out.println("Namespace URI: " + parts[0]);
+ * System.out.println("Local name: " + parts[1]);
+ * System.out.println("Raw name: " + parts[2]);
+ *
+ * parts = support.processName("dc:title", parts, false);
+ * System.out.println("Namespace URI: " + parts[0]);
+ * System.out.println("Local name: " + parts[1]);
+ * System.out.println("Raw name: " + parts[2]);
+ *
+ * support.popContext();
+ * </pre>
+ *
+ * <p>Note that this class is optimized for the use case where most
+ * elements do not contain Namespace declarations: if the same
+ * prefix/URI mapping is repeated for each context (for example), this
+ * class will be somewhat less efficient.</p>
+ *
+ * <p>Although SAX drivers (parsers) may choose to use this class to
+ * implement namespace handling, they are not required to do so.
+ * Applications must track namespace information themselves if they
+ * want to use namespace information.
+ *
+ * @since SAX 2.0
+ * @author David Megginson
+ */
+final class NamespaceSupport
+{
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constants.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * The XML Namespace URI as a constant.
+     * The value is <code>http://www.w3.org/XML/1998/namespace</code>
+     * as defined in the "Namespaces in XML" * recommendation.
+     *
+     * <p>This is the Namespace URI that is automatically mapped
+     * to the "xml" prefix.</p>
+     */
+    public final static String XMLNS =
+        "http://www.w3.org/XML/1998/namespace";
+
+
+    /**
+     * The namespace declaration URI as a constant.
+     * The value is <code>http://www.w3.org/xmlns/2000/</code>, as defined
+     * in a backwards-incompatible erratum to the "Namespaces in XML"
+     * recommendation.  Because that erratum postdated SAX2, SAX2 defaults
+     * to the original recommendation, and does not normally use this URI.
+     *
+     *
+     * <p>This is the Namespace URI that is optionally applied to
+     * <em>xmlns</em> and <em>xmlns:*</em> attributes, which are used to
+     * declare namespaces.  </p>
+     *
+     * @since SAX 2.1alpha
+     * @see #setNamespaceDeclUris
+     * @see #isNamespaceDeclUris
+     */
+    public final static String NSDECL =
+        "http://www.w3.org/xmlns/2000/";
+
+
+    /**
+     * An empty enumeration.
+     */
+    private final static Enumeration EMPTY_ENUMERATION =
+        new Vector().elements();
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constructor.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Create a new Namespace support object.
+     */
+    public NamespaceSupport ()
+    {
+        reset();
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Context management.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Reset this Namespace support object for reuse.
+     *
+     * <p>It is necessary to invoke this method before reusing the
+     * Namespace support object for a new session.  If namespace
+     * declaration URIs are to be supported, that flag must also
+     * be set to a non-default value.
+     * </p>
+     *
+     * @see #setNamespaceDeclUris
+     */
+    public void reset ()
+    {
+        contexts = new Context[32];
+        namespaceDeclUris = false;
+        contextPos = 0;
+        contexts[contextPos] = currentContext = new Context();
+        currentContext.declarePrefix("xml", XMLNS);
+    }
+
+
+    /**
+     * Start a new Namespace context.
+     * The new context will automatically inherit
+     * the declarations of its parent context, but it will also keep
+     * track of which declarations were made within this context.
+     *
+     * <p>Event callback code should start a new context once per element.
+     * This means being ready to call this in either of two places.
+     * For elements that don't include namespace declarations, the
+     * <em>ContentHandler.startElement()</em> callback is the right place.
+     * For elements with such a declaration, it'd done in the first
+     * <em>ContentHandler.startPrefixMapping()</em> callback.
+     * A boolean flag can be used to
+     * track whether a context has been started yet.  When either of
+     * those methods is called, it checks the flag to see if a new context
+     * needs to be started.  If so, it starts the context and sets the
+     * flag.  After <em>ContentHandler.startElement()</em>
+     * does that, it always clears the flag.
+     *
+     * <p>Normally, SAX drivers would push a new context at the beginning
+     * of each XML element.  Then they perform a first pass over the
+     * attributes to process all namespace declarations, making
+     * <em>ContentHandler.startPrefixMapping()</em> callbacks.
+     * Then a second pass is made, to determine the namespace-qualified
+     * names for all attributes and for the element name.
+     * Finally all the information for the
+     * <em>ContentHandler.startElement()</em> callback is available,
+     * so it can then be made.
+     *
+     * <p>The Namespace support object always starts with a base context
+     * already in force: in this context, only the "xml" prefix is
+     * declared.</p>
+     *
+     * @see org.xml.sax.ContentHandler
+     * @see #popContext
+     */
+    public void pushContext ()
+    {
+        int max = contexts.length;
+
+        contextPos++;
+
+                                // Extend the array if necessary
+        if (contextPos >= max) {
+            Context newContexts[] = new Context[max*2];
+            System.arraycopy(contexts, 0, newContexts, 0, max);
+            max *= 2;
+            contexts = newContexts;
+        }
+
+                                // Allocate the context if necessary.
+        currentContext = contexts[contextPos];
+        if (currentContext == null) {
+            contexts[contextPos] = currentContext = new Context();
+        }
+
+                                // Set the parent, if any.
+        if (contextPos > 0) {
+            currentContext.setParent(contexts[contextPos - 1]);
+        }
+    }
+
+
+    /**
+     * Revert to the previous Namespace context.
+     *
+     * <p>Normally, you should pop the context at the end of each
+     * XML element.  After popping the context, all Namespace prefix
+     * mappings that were previously in force are restored.</p>
+     *
+     * <p>You must not attempt to declare additional Namespace
+     * prefixes after popping a context, unless you push another
+     * context first.</p>
+     *
+     * @see #pushContext
+     */
+    public void popContext ()
+    {
+        contexts[contextPos].clear();
+        contextPos--;
+        if (contextPos < 0) {
+            throw new EmptyStackException();
+        }
+        currentContext = contexts[contextPos];
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Operations within a context.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Declare a Namespace prefix.  All prefixes must be declared
+     * before they are referenced.  For example, a SAX driver (parser)
+     * would scan an element's attributes
+     * in two passes:  first for namespace declarations,
+     * then a second pass using {@link #processName processName()} to
+     * interpret prefixes against (potentially redefined) prefixes.
+     *
+     * <p>This method declares a prefix in the current Namespace
+     * context; the prefix will remain in force until this context
+     * is popped, unless it is shadowed in a descendant context.</p>
+     *
+     * <p>To declare the default element Namespace, use the empty string as
+     * the prefix.</p>
+     *
+     * <p>Note that there is an asymmetry in this library: {@link
+     * #getPrefix getPrefix} will not return the "" prefix,
+     * even if you have declared a default element namespace.
+     * To check for a default namespace,
+     * you have to look it up explicitly using {@link #getURI getURI}.
+     * This asymmetry exists to make it easier to look up prefixes
+     * for attribute names, where the default prefix is not allowed.</p>
+     *
+     * @param prefix The prefix to declare, or the empty string to
+     *  indicate the default element namespace.  This may never have
+     *  the value "xml" or "xmlns".
+     * @param uri The Namespace URI to associate with the prefix.
+     * @return true if the prefix was legal, false otherwise
+     *
+     * @see #processName
+     * @see #getURI
+     * @see #getPrefix
+     */
+    public boolean declarePrefix (String prefix, String uri)
+    {
+        if (prefix.equals("xml") || prefix.equals("xmlns")) {
+            return false;
+        } else {
+            currentContext.declarePrefix(prefix, uri);
+            return true;
+        }
+    }
+
+
+    /**
+     * Process a raw XML qualified name, after all declarations in the
+     * current context have been handled by {@link #declarePrefix
+     * declarePrefix()}.
+     *
+     * <p>This method processes a raw XML qualified name in the
+     * current context by removing the prefix and looking it up among
+     * the prefixes currently declared.  The return value will be the
+     * array supplied by the caller, filled in as follows:</p>
+     *
+     * <dl>
+     * <dt>parts[0]</dt>
+     * <dd>The Namespace URI, or an empty string if none is
+     *  in use.</dd>
+     * <dt>parts[1]</dt>
+     * <dd>The local name (without prefix).</dd>
+     * <dt>parts[2]</dt>
+     * <dd>The original raw name.</dd>
+     * </dl>
+     *
+     * <p>All of the strings in the array will be internalized.  If
+     * the raw name has a prefix that has not been declared, then
+     * the return value will be null.</p>
+     *
+     * <p>Note that attribute names are processed differently than
+     * element names: an unprefixed element name will receive the
+     * default Namespace (if any), while an unprefixed attribute name
+     * will not.</p>
+     *
+     * @param qName The XML qualified name to be processed.
+     * @param parts An array supplied by the caller, capable of
+     *        holding at least three members.
+     * @param isAttribute A flag indicating whether this is an
+     *        attribute name (true) or an element name (false).
+     * @return The supplied array holding three internalized strings
+     *        representing the Namespace URI (or empty string), the
+     *        local name, and the XML qualified name; or null if there
+     *        is an undeclared prefix.
+     * @see #declarePrefix
+     * @see java.lang.String#intern */
+    public String [] processName (String qName, String parts[],
+                                  boolean isAttribute)
+    {
+        String myParts[] = currentContext.processName(qName, isAttribute);
+        if (myParts == null) {
+            return null;
+        } else {
+            parts[0] = myParts[0];
+            parts[1] = myParts[1];
+            parts[2] = myParts[2];
+            return parts;
+        }
+    }
+
+
+    /**
+     * Look up a prefix and get the currently-mapped Namespace URI.
+     *
+     * <p>This method looks up the prefix in the current context.
+     * Use the empty string ("") for the default Namespace.</p>
+     *
+     * @param prefix The prefix to look up.
+     * @return The associated Namespace URI, or null if the prefix
+     *         is undeclared in this context.
+     * @see #getPrefix
+     * @see #getPrefixes
+     */
+    public String getURI (String prefix)
+    {
+        return currentContext.getURI(prefix);
+    }
+
+
+    /**
+     * Return an enumeration of all prefixes whose declarations are
+     * active in the current context.
+     * This includes declarations from parent contexts that have
+     * not been overridden.
+     *
+     * <p><strong>Note:</strong> if there is a default prefix, it will not be
+     * returned in this enumeration; check for the default prefix
+     * using the {@link #getURI getURI} with an argument of "".</p>
+     *
+     * @return An enumeration of prefixes (never empty).
+     * @see #getDeclaredPrefixes
+     * @see #getURI
+     */
+    public Enumeration getPrefixes ()
+    {
+        return currentContext.getPrefixes();
+    }
+
+
+    /**
+     * Return one of the prefixes mapped to a Namespace URI.
+     *
+     * <p>If more than one prefix is currently mapped to the same
+     * URI, this method will make an arbitrary selection; if you
+     * want all of the prefixes, use the {@link #getPrefixes}
+     * method instead.</p>
+     *
+     * <p><strong>Note:</strong> this will never return the empty (default) prefix;
+     * to check for a default prefix, use the {@link #getURI getURI}
+     * method with an argument of "".</p>
+     *
+     * @param uri the namespace URI
+     * @return one of the prefixes currently mapped to the URI supplied,
+     *         or null if none is mapped or if the URI is assigned to
+     *         the default namespace
+     * @see #getPrefixes(java.lang.String)
+     * @see #getURI
+     */
+    public String getPrefix (String uri)
+    {
+        return currentContext.getPrefix(uri);
+    }
+
+
+    /**
+     * Return an enumeration of all prefixes for a given URI whose
+     * declarations are active in the current context.
+     * This includes declarations from parent contexts that have
+     * not been overridden.
+     *
+     * <p>This method returns prefixes mapped to a specific Namespace
+     * URI.  The xml: prefix will be included.  If you want only one
+     * prefix that's mapped to the Namespace URI, and you don't care
+     * which one you get, use the {@link #getPrefix getPrefix}
+     *  method instead.</p>
+     *
+     * <p><strong>Note:</strong> the empty (default) prefix is <em>never</em> included
+     * in this enumeration; to check for the presence of a default
+     * Namespace, use the {@link #getURI getURI} method with an
+     * argument of "".</p>
+     *
+     * @param uri The Namespace URI.
+     * @return An enumeration of prefixes (never empty).
+     * @see #getPrefix
+     * @see #getDeclaredPrefixes
+     * @see #getURI
+     */
+    public Enumeration getPrefixes (String uri)
+    {
+        Vector prefixes = new Vector();
+        Enumeration allPrefixes = getPrefixes();
+        while (allPrefixes.hasMoreElements()) {
+            String prefix = (String)allPrefixes.nextElement();
+            if (uri.equals(getURI(prefix))) {
+                prefixes.addElement(prefix);
+            }
+        }
+        return prefixes.elements();
+    }
+
+
+    /**
+     * Return an enumeration of all prefixes declared in this context.
+     *
+     * <p>The empty (default) prefix will be included in this
+     * enumeration; note that this behaviour differs from that of
+     * {@link #getPrefix} and {@link #getPrefixes}.</p>
+     *
+     * @return An enumeration of all prefixes declared in this
+     *         context.
+     * @see #getPrefixes
+     * @see #getURI
+     */
+    public Enumeration getDeclaredPrefixes ()
+    {
+        return currentContext.getDeclaredPrefixes();
+    }
+
+    /**
+     * Controls whether namespace declaration attributes are placed
+     * into the {@link #NSDECL NSDECL} namespace
+     * by {@link #processName processName()}.  This may only be
+     * changed before any contexts have been pushed.
+     *
+     * @since SAX 2.1alpha
+     *
+     * @exception IllegalStateException when attempting to set this
+     *  after any context has been pushed.
+     */
+    public void setNamespaceDeclUris (boolean value)
+    {
+        if (contextPos != 0)
+            throw new IllegalStateException ();
+        if (value == namespaceDeclUris)
+            return;
+        namespaceDeclUris = value;
+        if (value)
+            currentContext.declarePrefix ("xmlns", NSDECL);
+        else {
+            contexts[contextPos] = currentContext = new Context();
+            currentContext.declarePrefix("xml", XMLNS);
+        }
+    }
+
+    /**
+     * Returns true if namespace declaration attributes are placed into
+     * a namespace.  This behavior is not the default.
+     *
+     * @since SAX 2.1alpha
+     */
+    public boolean isNamespaceDeclUris ()
+        { return namespaceDeclUris; }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    private Context contexts[];
+    private Context currentContext;
+    private int contextPos;
+    private boolean namespaceDeclUris;
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal classes.
+    ////////////////////////////////////////////////////////////////////
+
+    /**
+     * Internal class for a single Namespace context.
+     *
+     * <p>This module caches and reuses Namespace contexts,
+     * so the number allocated
+     * will be equal to the element depth of the document, not to the total
+     * number of elements (i.e. 5-10 rather than tens of thousands).
+     * Also, data structures used to represent contexts are shared when
+     * possible (child contexts without declarations) to further reduce
+     * the amount of memory that's consumed.
+     * </p>
+     */
+    final class Context {
+
+        /**
+         * Create the root-level Namespace context.
+         */
+        Context ()
+        {
+            copyTables();
+        }
+
+
+        /**
+         * (Re)set the parent of this Namespace context.
+         * The context must either have been freshly constructed,
+         * or must have been cleared.
+         *
+         * @param context The parent Namespace context object.
+         */
+        void setParent (Context parent)
+        {
+            this.parent = parent;
+            declarations = null;
+            prefixTable = parent.prefixTable;
+            uriTable = parent.uriTable;
+            elementNameTable = parent.elementNameTable;
+            attributeNameTable = parent.attributeNameTable;
+            defaultNS = parent.defaultNS;
+            declSeen = false;
+        }
+
+        /**
+         * Makes associated state become collectible,
+         * invalidating this context.
+         * {@link #setParent} must be called before
+         * this context may be used again.
+         */
+        void clear ()
+        {
+            parent = null;
+            prefixTable = null;
+            uriTable = null;
+            elementNameTable = null;
+            attributeNameTable = null;
+            defaultNS = "";
+        }
+
+
+        /**
+         * Declare a Namespace prefix for this context.
+         *
+         * @param prefix The prefix to declare.
+         * @param uri The associated Namespace URI.
+         * @see org.xml.sax.helpers.NamespaceSupport#declarePrefix
+         */
+        void declarePrefix (String prefix, String uri)
+        {
+                                // Lazy processing...
+//          if (!declsOK)
+//              throw new IllegalStateException (
+//                  "can't declare any more prefixes in this context");
+            if (!declSeen) {
+                copyTables();
+            }
+            if (declarations == null) {
+                declarations = new Vector();
+            }
+
+            prefix = prefix.intern();
+            uri = uri.intern();
+            if ("".equals(prefix)) {
+                    defaultNS = uri;
+            } else {
+                prefixTable.put(prefix, uri);
+                uriTable.put(uri, prefix); // may wipe out another prefix
+            }
+            declarations.addElement(prefix);
+        }
+
+
+        /**
+         * Process an XML qualified name in this context.
+         *
+         * @param qName The XML qualified name.
+         * @param isAttribute true if this is an attribute name.
+         * @return An array of three strings containing the
+         *         URI part (or empty string), the local part,
+         *         and the raw name, all internalized, or null
+         *         if there is an undeclared prefix.
+         * @see org.xml.sax.helpers.NamespaceSupport#processName
+         */
+        String [] processName (String qName, boolean isAttribute)
+        {
+            String name[];
+            Hashtable table;
+
+                                // Select the appropriate table.
+            if (isAttribute) {
+                table = attributeNameTable;
+            } else {
+                table = elementNameTable;
+            }
+
+                                // Start by looking in the cache, and
+                                // return immediately if the name
+                                // is already known in this content
+            name = (String[])table.get(qName);
+            if (name != null) {
+                return name;
+            }
+
+                                // We haven't seen this name in this
+                                // context before.  Maybe in the parent
+                                // context, but we can't assume prefix
+                                // bindings are the same.
+            name = new String[3];
+            name[2] = qName.intern();
+            int index = qName.indexOf(':');
+
+
+                                // No prefix.
+            if (index == -1) {
+                if (isAttribute) {
+                    if (qName == "xmlns" && namespaceDeclUris)
+                        name[0] = NSDECL;
+                    else
+                        name[0] = "";
+                } else {
+                    name[0] = defaultNS;
+                }
+                name[1] = name[2];
+            }
+
+                                // Prefix
+            else {
+                String prefix = qName.substring(0, index);
+                String local = qName.substring(index+1);
+                String uri;
+                if ("".equals(prefix)) {
+                    uri = defaultNS;
+                } else {
+                    uri = (String)prefixTable.get(prefix);
+                }
+                if (uri == null
+                        || (!isAttribute && "xmlns".equals (prefix))) {
+                    return null;
+                }
+                name[0] = uri;
+                name[1] = local.intern();
+            }
+
+                                // Save in the cache for future use.
+                                // (Could be shared with parent context...)
+            table.put(name[2], name);
+            return name;
+        }
+
+
+        /**
+         * Look up the URI associated with a prefix in this context.
+         *
+         * @param prefix The prefix to look up.
+         * @return The associated Namespace URI, or null if none is
+         *         declared.
+         * @see org.xml.sax.helpers.NamespaceSupport#getURI
+         */
+        String getURI (String prefix)
+        {
+            if ("".equals(prefix)) {
+                return defaultNS;
+            } else if (prefixTable == null) {
+                return null;
+            } else {
+                return (String)prefixTable.get(prefix);
+            }
+        }
+
+
+        /**
+         * Look up one of the prefixes associated with a URI in this context.
+         *
+         * <p>Since many prefixes may be mapped to the same URI,
+         * the return value may be unreliable.</p>
+         *
+         * @param uri The URI to look up.
+         * @return The associated prefix, or null if none is declared.
+         * @see org.xml.sax.helpers.NamespaceSupport#getPrefix
+         */
+        String getPrefix (String uri)
+        {
+            if (uriTable == null) {
+                return null;
+            } else {
+                return (String)uriTable.get(uri);
+            }
+        }
+
+
+        /**
+         * Return an enumeration of prefixes declared in this context.
+         *
+         * @return An enumeration of prefixes (possibly empty).
+         * @see org.xml.sax.helpers.NamespaceSupport#getDeclaredPrefixes
+         */
+        Enumeration getDeclaredPrefixes ()
+        {
+            if (declarations == null) {
+                return EMPTY_ENUMERATION;
+            } else {
+                return declarations.elements();
+            }
+        }
+
+
+        /**
+         * Return an enumeration of all prefixes currently in force.
+         *
+         * <p>The default prefix, if in force, is <em>not</em>
+         * returned, and will have to be checked for separately.</p>
+         *
+         * @return An enumeration of prefixes (never empty).
+         * @see org.xml.sax.helpers.NamespaceSupport#getPrefixes
+         */
+        Enumeration getPrefixes ()
+        {
+            if (prefixTable == null) {
+                return EMPTY_ENUMERATION;
+            } else {
+                return prefixTable.keys();
+            }
+        }
+
+
+
+        ////////////////////////////////////////////////////////////////
+        // Internal methods.
+        ////////////////////////////////////////////////////////////////
+
+
+        /**
+         * Copy on write for the internal tables in this context.
+         *
+         * <p>This class is optimized for the normal case where most
+         * elements do not contain Namespace declarations.</p>
+         */
+        private void copyTables ()
+        {
+            if (prefixTable != null) {
+                prefixTable = (Hashtable)prefixTable.clone();
+            } else {
+                prefixTable = new Hashtable();
+            }
+            if (uriTable != null) {
+                uriTable = (Hashtable)uriTable.clone();
+            } else {
+                uriTable = new Hashtable();
+            }
+            elementNameTable = new Hashtable();
+            attributeNameTable = new Hashtable();
+            declSeen = true;
+        }
+
+
+
+        ////////////////////////////////////////////////////////////////
+        // Protected state.
+        ////////////////////////////////////////////////////////////////
+
+        Hashtable prefixTable;
+        Hashtable uriTable;
+        Hashtable elementNameTable;
+        Hashtable attributeNameTable;
+        String defaultNS = "";
+
+
+
+        ////////////////////////////////////////////////////////////////
+        // Internal state.
+        ////////////////////////////////////////////////////////////////
+
+        private Vector declarations = null;
+        private boolean declSeen = false;
+        private Context parent = null;
+    }
+}
+
+// end of NamespaceSupport.java
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/Pcdata.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Pcdata.java
new file mode 100644
index 0000000..c32eaa1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Pcdata.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * PCDATA.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+final class Pcdata extends Text {
+    Pcdata(Document document, NamespaceResolver nsResolver, Object obj) {
+        super(document, nsResolver, obj);
+    }
+
+    void accept(ContentVisitor visitor) {
+        visitor.onPcdata(buffer);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/StartDocument.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/StartDocument.java
new file mode 100644
index 0000000..56e659a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/StartDocument.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+final class StartDocument extends Content {
+    boolean concludesPendingStartTag() {
+        return true;
+    }
+
+    void accept(ContentVisitor visitor) {
+        visitor.onStartDocument();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/StartTag.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/StartTag.java
new file mode 100644
index 0000000..f1642ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/StartTag.java
@@ -0,0 +1,247 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+import javax.xml.namespace.QName;
+
+
+/**
+ * Start tag.
+ *
+ * <p>
+ * This object implements {@link NamespaceResolver} for attribute values.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+class StartTag extends Content implements NamespaceResolver {
+    /**
+     * Tag name of the element.
+     *
+     * <p>
+     * This field is also used as a flag to indicate
+     * whether the start tag has been written.
+     * This field is initially set to non-null, and
+     * then reset to null when it's written.
+     */
+    private String uri;
+    // but we keep the local name non-null so that
+    // we can diagnose an error
+    private final String localName;
+
+    private Attribute firstAtt;
+    private Attribute lastAtt;
+
+    /**
+     * If this {@link StartTag} has the parent {@link ContainerElement},
+     * that value. Otherwise null.
+     */
+    private ContainerElement owner;
+
+    /**
+     * Explicitly given namespace declarations on this element.
+     *
+     * <p>
+     * Additional namespace declarations might be necessary to
+     * generate child {@link QName}s and attributes.
+     */
+    private NamespaceDecl firstNs;
+    private NamespaceDecl lastNs;
+
+    final Document document;
+
+    public StartTag(ContainerElement owner, String uri, String localName) {
+        this(owner.document,uri,localName);
+        this.owner = owner;
+    }
+
+    public StartTag(Document document, String uri, String localName) {
+        assert uri!=null;
+        assert localName!=null;
+
+        this.uri = uri;
+        this.localName = localName;
+        this.document = document;
+
+        // TODO: think about a better way to maintain namespace decls.
+        // this requires at least one NamespaceDecl per start tag,
+        // which is rather expensive.
+        addNamespaceDecl(uri,null,false);
+    }
+
+    public void addAttribute(String nsUri, String localName, Object arg) {
+        checkWritable();
+
+        // look for the existing ones
+        Attribute a;
+        for(a=firstAtt; a!=null; a=a.next) {
+            if(a.hasName(nsUri,localName)) {
+                break;
+            }
+        }
+
+        // if not found, declare a new one
+        if(a==null) {
+            a = new Attribute(nsUri,localName);
+            if(lastAtt==null) {
+                assert firstAtt==null;
+                firstAtt = lastAtt = a;
+            } else {
+                assert firstAtt!=null;
+                lastAtt.next = a;
+                lastAtt = a;
+            }
+            if(nsUri.length()>0)
+                addNamespaceDecl(nsUri,null,true);
+        }
+
+        document.writeValue(arg,this,a.value);
+    }
+
+    /**
+     * Declares a new namespace URI on this tag.
+     *
+     * @param uri
+     *      namespace URI to be bound. Can be empty, but must not be null.
+     * @param prefix
+     *      If non-null and non-empty, this prefix is bound to the URI
+     *      on this element. If empty, then the runtime will still try to
+     *      use the URI as the default namespace, but it may fail to do so
+     *      because of the constraints in the XML.
+     *      <p>
+     *      If this parameter is null, the runtime will allocate an unique prefix.
+     * @param requirePrefix
+     *      Used only when the prefix parameter is null. If true, this indicates
+     *      that the non-empty prefix must be assigned to this URI. If false,
+     *      then this URI might be used as the default namespace.
+     *      <p>
+     *      Normally you just need to set it to false.
+     */
+    public NamespaceDecl addNamespaceDecl(String uri, String prefix,boolean requirePrefix) {
+        checkWritable();
+
+        if(uri==null)
+            throw new IllegalArgumentException();
+        if(uri.length()==0) {
+            if(requirePrefix)
+                throw new IllegalArgumentException("The empty namespace cannot have a non-empty prefix");
+            if(prefix!=null && prefix.length()>0)
+                throw new IllegalArgumentException("The empty namespace can be only bound to the empty prefix");
+            prefix = "";
+        }
+
+        // check for the duplicate
+        for(NamespaceDecl n=firstNs; n!=null; n=n.next) {
+            if(uri.equals(n.uri)) {
+                if(prefix==null) {
+                    // reuse this binding
+                    n.requirePrefix |= requirePrefix;
+                    return n;
+                }
+                if(n.prefix==null) {
+                    // reuse this binding
+                    n.prefix = prefix;
+                    n.requirePrefix |= requirePrefix;
+                    return n;
+                }
+                if(prefix.equals(n.prefix)) {
+                    // reuse this binding
+                    n.requirePrefix |= requirePrefix;
+                    return n;
+                }
+            }
+            if(prefix!=null && n.prefix!=null && n.prefix.equals(prefix))
+                throw new IllegalArgumentException(
+                    "Prefix '"+prefix+"' is already bound to '"+n.uri+'\'');
+        }
+
+        NamespaceDecl ns = new NamespaceDecl(document.assignNewId(),uri,prefix,requirePrefix);
+        if(lastNs==null) {
+            assert firstNs==null;
+            firstNs = lastNs = ns;
+        } else {
+            assert firstNs!=null;
+            lastNs.next = ns;
+            lastNs = ns;
+        }
+        return ns;
+    }
+
+    /**
+     * Throws an error if the start tag has already been committed.
+     */
+    private void checkWritable() {
+        if(isWritten())
+            throw new IllegalStateException(
+                "The start tag of "+this.localName+" has already been written. " +
+                "If you need out of order writing, see the TypedXmlWriter.block method");
+    }
+
+    /**
+     * Returns true if this start tag has already been written.
+     */
+    boolean isWritten() {
+        return uri==null;
+    }
+
+    /**
+     * A {@link StartTag} can be only written after
+     * we are sure that all the necessary namespace declarations are given.
+     */
+    boolean isReadyToCommit() {
+        if(owner!=null && owner.isBlocked())
+            return false;
+
+        for( Content c=getNext(); c!=null; c=c.getNext() )
+            if(c.concludesPendingStartTag())
+                return true;
+
+        return false;
+    }
+
+    public void written() {
+        firstAtt = lastAtt = null;
+        uri = null;
+        if(owner!=null) {
+            assert owner.startTag==this;
+            owner.startTag = null;
+        }
+    }
+
+    boolean concludesPendingStartTag() {
+        return true;
+    }
+
+    void accept(ContentVisitor visitor) {
+        visitor.onStartTag(uri,localName,firstAtt,firstNs);
+    }
+
+    public String getPrefix(String nsUri) {
+        NamespaceDecl ns = addNamespaceDecl(nsUri,null,false);
+        if(ns.prefix!=null)
+            // if the prefix has already been declared, use it.
+            return ns.prefix;
+        return ns.dummyPrefix;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/TXW.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/TXW.java
new file mode 100644
index 0000000..ae67641
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/TXW.java
@@ -0,0 +1,106 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+import com.sun.xml.internal.txw2.output.XmlSerializer;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.txw2.annotation.XmlNamespace;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Entry point to TXW.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class TXW {
+    private TXW() {}    // no instanciation please
+
+
+    /*package*/ static QName getTagName( Class<?> c ) {
+        String localName="";
+        String nsUri="##default";
+
+        XmlElement xe = c.getAnnotation(XmlElement.class);
+        if(xe!=null) {
+            localName = xe.value();
+            nsUri = xe.ns();
+        }
+
+        if(localName.length()==0) {
+            localName = c.getName();
+            int idx = localName.lastIndexOf('.');
+            if(idx>=0)
+                localName = localName.substring(idx+1);
+
+            localName = Character.toLowerCase(localName.charAt(0))+localName.substring(1);
+        }
+
+        if(nsUri.equals("##default")) {
+            Package pkg = c.getPackage();
+            if(pkg!=null) {
+                XmlNamespace xn = pkg.getAnnotation(XmlNamespace.class);
+                if(xn!=null)
+                    nsUri = xn.value();
+            }
+        }
+        if(nsUri.equals("##default"))
+            nsUri = "";
+
+        return new QName(nsUri,localName);
+    }
+
+    /**
+     * Creates a new {@link TypedXmlWriter} to write a new instance of a document.
+     *
+     * @param rootElement
+     *      The {@link TypedXmlWriter} interface that declares the content model of the root element.
+     *      This interface must have {@link XmlElement} annotation on it to designate the tag name
+     *      of the root element.
+     * @param out
+     *      The target of the writing.
+     */
+    public static <T extends TypedXmlWriter> T create( Class<T> rootElement, XmlSerializer out ) {
+        Document doc = new Document(out);
+        QName n = getTagName(rootElement);
+        return new ContainerElement(doc,null,n.getNamespaceURI(),n.getLocalPart())._cast(rootElement);
+    }
+
+    /**
+     * Creates a new {@link TypedXmlWriter} to write a new instance of a document.
+     *
+     * <p>
+     * Similar to the other method, but this version allows the caller to set the
+     * tag name at the run-time.
+     *
+     * @param tagName
+     *      The tag name of the root document.
+     *
+     * @see #create(Class,XmlSerializer)
+     */
+    public static <T extends TypedXmlWriter> T create( QName tagName, Class<T> rootElement, XmlSerializer out ) {
+        return new ContainerElement(new Document(out),null,tagName.getNamespaceURI(),tagName.getLocalPart())._cast(rootElement);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/Text.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Text.java
new file mode 100644
index 0000000..22558c1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/Text.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * {@link Pcdata} or {@link Cdata}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+abstract class Text extends Content {
+    /**
+     * The text to be writtten.
+     */
+    protected final StringBuilder buffer = new StringBuilder();
+
+    protected Text(Document document, NamespaceResolver nsResolver, Object obj) {
+        document.writeValue(obj,nsResolver,buffer);
+    }
+
+    boolean concludesPendingStartTag() {
+        return false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/TxwException.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/TxwException.java
new file mode 100644
index 0000000..7179d99
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/TxwException.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+/**
+ * Signals errors in the TXW processing.
+ */
+public class TxwException extends RuntimeException {
+    public TxwException(String message) {
+        super(message);
+    }
+
+    public TxwException(Throwable cause) {
+        super(cause);
+    }
+
+    public TxwException(String message, Throwable cause) {
+        super(message, cause);
+    }
+
+    private static final long serialVersionUID = 1L;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/TypedXmlWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/TypedXmlWriter.java
new file mode 100644
index 0000000..f2c984c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/TypedXmlWriter.java
@@ -0,0 +1,265 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2;
+
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.txw2.output.XmlSerializer;
+
+import javax.xml.namespace.QName;
+
+/**
+ * Defines common operations for all typed XML writers&#x2E;
+ * Root of all typed XML writer interfaces.
+ *
+ * <p>
+ * This interface defines a series of methods to allow client applications
+ * to write arbitrary well-formed documents.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface TypedXmlWriter {
+    /**
+     * Commits this element (and all its descendants) to the output.
+     *
+     * <p>
+     * Short for <tt>_commit(true)</tt>.
+     */
+    void commit();
+
+    /**
+     * Commits this element (and all its descendants) to the output.
+     *
+     * <p>
+     * Once a writer is committed, nothing can be added to it further.
+     * Committing allows TXW to output a part of the document even
+     * if the rest has not yet been written.
+     *
+     * @param includingAllPredecessors
+     *      if false, this operation will _commit this writer and all its
+     *      descendants writers. If true, in addition to those writers,
+     *      this operation will close all the writers before this writer
+     *      in the document order.
+     */
+    void commit(boolean includingAllPredecessors);
+
+    /**
+     * Blocks the writing of the start tag so that
+     * new attributes can be added even after child
+     * elements are appended.
+     *
+     * <p>
+     * This blocks the output at the token before the start tag until
+     * the {@link #commit()} method is called to _commit this element.
+     *
+     * <p>
+     * For more information, see the TXW documentation.
+     */
+    void block();
+
+    /**
+     * Gets the {@link Document} object that this writer is writing to.
+     *
+     * @return
+     *      always non-null.
+     */
+    Document getDocument();
+
+    /**
+     * Adds an attribute of the given name and the value.
+     *
+     * <p>
+     * Short for <pre>_attribute("",localName,value);</pre>
+     *
+     * @see #_attribute(String, String, Object)
+     */
+    void _attribute( String localName, Object value );
+
+    /**
+     * Adds an attribute of the given name and the value.
+     *
+     * <p>
+     * Short for <pre>_attribute(new QName(nsUri,localName),value);</pre>
+     *
+     * @see #_attribute(QName, Object)
+     */
+    void _attribute( String nsUri, String localName, Object value );
+
+    /**
+     * Adds an attribute of the given name and the value.
+     *
+     * @param attributeName
+     *      must not be null.
+     * @param value
+     *      value of the attribute.
+     *      must not be null.
+     *      See the documentation for the conversion rules.
+     */
+    void _attribute( QName attributeName, Object value );
+
+    /**
+     * Declares a new namespace URI on this element.
+     *
+     * <p>
+     * The runtime system will assign an unique prefix for the URI.
+     *
+     * @param uri
+     *      can be empty, but must not be null.
+     */
+    void _namespace( String uri );
+
+    /**
+     * Declares a new namespace URI on this element to
+     * a specific prefix.
+     *
+     * @param uri
+     *      can be empty, but must not be null.
+     * @param prefix
+     *      If non-empty, this prefix is bound to the URI
+     *      on this element. If empty, then the runtime will still try to
+     *      use the URI as the default namespace, but it may fail to do so
+     *      because of the constraints in the XML.
+     *
+     * @throws IllegalArgumentException
+     *      if the same prefix is already declared on this element.
+     */
+    void _namespace( String uri, String prefix );
+
+    /**
+     * Declares a new namespace URI on this element.
+     *
+     * <p>
+     * The runtime system will assign an unique prefix for the URI.
+     *
+     * @param uri
+     *      can be empty, but must not be null.
+     * @param requirePrefix
+     *      if false, this method behaves just like {@link #_namespace(String)}.
+     *      if true, this guarantees that the URI is bound to a non empty prefix.
+     */
+    void _namespace( String uri, boolean requirePrefix );
+
+    /**
+     * Appends text data.
+     *
+     * @param value
+     *      must not be null.
+     *      See the documentation for the conversion rules.
+     */
+    void _pcdata( Object value );
+
+    /**
+     * Appends CDATA section.
+     *
+     * @param value
+     *      must not be null.
+     *      See the documentation for the conversion rules.
+     */
+    void _cdata( Object value );
+
+    /**
+     * Appends a comment.
+     *
+     * @param value
+     *      must not be null.
+     *      See the documentation for the conversion rules.
+     *
+     * @throws UnsupportedOperationException
+     *      if the underlying {@link XmlSerializer} does not support
+     *      writing comments, this exception can be thrown.
+     */
+    void _comment( Object value ) throws UnsupportedOperationException;
+
+    /**
+     * Appends a new child element.
+     *
+     * <p>
+     * Short for <pre>_element(<i>URI of this element</i>,localName,contentModel);</pre>
+     *
+     * <p>
+     * The namespace URI will be inherited from the parent element.
+     *
+     * @see #_element(String, String, Class)
+     */
+    <T extends TypedXmlWriter> T _element( String localName, Class<T> contentModel );
+
+    /**
+     * Appends a new child element.
+     *
+     * <p>
+     * The newly created child element is appended at the end of the children.
+     *
+     * @param nsUri
+     *      The namespace URI of the newly created element.
+     * @param localName
+     *      The local name of the newly created element.
+     * @param contentModel
+     *      The typed XML writer interface used to write the children of
+     *      the new child element.
+     *
+     * @return
+     *      always return non-null {@link TypedXmlWriter} that can be used
+     *      to write the contents of the newly created child element.
+     */
+    <T extends TypedXmlWriter> T _element( String nsUri, String localName, Class<T> contentModel );
+
+    /**
+     * Appends a new child element.
+     *
+     * <p>
+     * Short for <pre>_element(tagName.getNamespaceURI(),tagName.getLocalPart(),contentModel);</pre>
+     *
+     * @see #_element(String, String, Class)
+     */
+    <T extends TypedXmlWriter> T _element( QName tagName, Class<T> contentModel );
+
+    /**
+     * Appends a new child element.
+     *
+     * <p>
+     * This version of the _element method requires the <i>T</i> class to be
+     * annotated with {@link XmlElement} annotation. The element name will be
+     * taken from there.
+     *
+     * @see #_element(String, String, Class)
+     */
+    <T extends TypedXmlWriter> T _element( Class<T> contentModel );
+
+    /**
+     * Returns a different interface for this typed XML Writer.
+     *
+     * <p>
+     * Semantically, this operation is a 'cast' --- it returns the same underlying
+     * writer in a different interface. The returned new writer and the current writer
+     * will write to the same element.
+     *
+     * <p>
+     * But this is different from Java's ordinary cast because the returned object
+     * is not always the same as the current object.
+     *
+     * @return
+     *      always return non-null.
+     */
+    <T extends TypedXmlWriter> T _cast( Class<T> targetInterface );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlAttribute.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlAttribute.java
new file mode 100644
index 0000000..0a58a21
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlAttribute.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.annotation;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+
+/**
+ * Specifies that the invocation of the method will produce an attribute.
+ *
+ * <p>
+ * The method signature has to match the form <tt>R foo(DT1,DT2,..)</tt>
+ *
+ * <p>
+ * R is either <tt>void</tt> or the type to which the interface that declares
+ * this method is assignable. In the case of the latter, the method will return
+ * <tt>this</tt> object, allowing you to chain the multiple attribute method
+ * invocations like {@link StringBuffer}.
+ *
+ * <p>
+ * DTi must be datatype objects.
+ *
+ * <p>
+ * When this method is called, a new attribute is added to the current element,
+ * whose value is whitespace-separated text from each of the datatype objects.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Retention(RUNTIME)
+@Target({METHOD})
+public @interface XmlAttribute {
+    /**
+     * The local name of the attribute.
+     *
+     * <p>
+     * If left unspecified, the method name is used as the attribute name.
+     *
+     */
+    String value() default "";
+
+    /**
+     * The namespace URI of the attribute.
+     */
+    String ns() default "";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlCDATA.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlCDATA.java
new file mode 100644
index 0000000..9828095
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlCDATA.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.METHOD;
+
+/**
+ * Used along with {@link XmlElement} to write a CDATA section,
+ * instead of the normal PCDATA.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Retention(RUNTIME)
+@Target({METHOD})
+public @interface XmlCDATA {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlElement.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlElement.java
new file mode 100644
index 0000000..e7dc725
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlElement.java
@@ -0,0 +1,97 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.annotation;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.TXW;
+import com.sun.xml.internal.txw2.output.XmlSerializer;
+
+import javax.xml.namespace.QName;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.ElementType.TYPE;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.METHOD;
+
+/**
+ * Specifies the name of the XML element.
+ *
+ * <h2>Used on method</h2>
+ * <p>
+ * When used on methods declared on interfaces that derive
+ * from {@link TypedXmlWriter}, it specifies that the invocation
+ * of the method will produce an element of the specified name.
+ *
+ * <p>
+ * The method signature has to match one of the following patterns.
+ *
+ * <dl>
+ *  <dt>Child writer: <tt>TW foo()</tt></dt>
+ *  <dd>TW must be an interface derived from {@link TypedXmlWriter}.
+ *      When this method is called, a new child element is started,
+ *      and its content can be written by using the returned <tt>TW</tt>
+ *      object. This child element will be ended when its _commit method
+ *      is called.
+ *  <dt>Leaf element: <tt>void foo(DT1,DT2,...)</tt></dt>
+ *  <dd>DTi must be datatype objects.
+ *      When this method is called, a new child element is started,
+ *      followed by the whitespace-separated text data from each of
+ *      the datatype objects, followed by the end tag.
+ * </dl>
+ *
+ * <h2>Used on interface</h2>
+ * <p>
+ * When used on interfaces that derive from {@link TypedXmlWriter},
+ * it associates an element name with that interface. This name is
+ * used in a few places, such as in {@link TXW#create(Class,XmlSerializer)}
+ * and {@link TypedXmlWriter#_element(Class)}.
+ *
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Retention(RUNTIME)
+@Target({METHOD,TYPE})
+public @interface XmlElement {
+    /**
+     * The local name of the element.
+     */
+    String value() default "";
+
+    /**
+     * The namespace URI of this element.
+     *
+     * <p>
+     * If the annotation is on an interface and this paramter is left unspecified,
+     * then the namespace URI is taken from {@link XmlNamespace} annotation on
+     * the package that the interface is in. If {@link XmlNamespace} annotation
+     * doesn't exist, the namespace URI will be "".
+     *
+     * <p>
+     * If the annotation is on a method and this parameter is left unspecified,
+     * then the namespace URI is the same as the namespace URI of the writer interface.
+     */
+    String ns() default "##default";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlNamespace.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlNamespace.java
new file mode 100644
index 0000000..3602f3c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlNamespace.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.annotation;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.PACKAGE;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+/**
+ * Declares the namespace URI of the {@link TypedXmlWriter}s
+ * in a package.
+ *
+ * <p>
+ * This annotation is placed on a package. When specified,
+ * it sets the default value of the namespace URI for
+ * all the elements ({@link XmlElement}s) in the given package.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Retention(RUNTIME)
+@Target({PACKAGE})
+public @interface XmlNamespace {
+    /**
+     * The namespace URI.
+     */
+    String value();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlValue.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlValue.java
new file mode 100644
index 0000000..071c441
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/XmlValue.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.annotation;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+
+import static java.lang.annotation.ElementType.METHOD;
+
+import com.sun.xml.internal.txw2.DatatypeWriter;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+/**
+ * Specifies that the invocation of the method will produce a text
+ *
+ * <p>
+ * The method signature has to match the form <tt>R foo(DT1,DT2,..)</tt>
+ *
+ * <p>
+ * R is either <tt>void</tt> or the type to which the interface that declares
+ * this method is assignable. In the case of the latter, the method will return
+ * <tt>this</tt> object, allowing you to chain the multiple method
+ * invocations like {@link StringBuffer}.
+ *
+ * <p>
+ * DTi must be datatype objects.
+ *
+ * <p>
+ * When this method is called, whitespace-separated text data
+ * is added from each of the datatype objects.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+@Retention(RUNTIME)
+@Target({METHOD})
+public @interface XmlValue {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/package.html b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/package.html
new file mode 100644
index 0000000..de8b832
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/annotation/package.html
@@ -0,0 +1,24 @@
+<html>
+<body>
+  <p>
+    Defines a set of annotations that can be used on TypedXmlWriter interfaces.
+
+  <h3>Package-level Annotation</h3>
+  <p>
+    {@link XmlNamespace} can be used on a package to designate the namespace URI for the
+    whole package.
+
+  <h3>Interface Annotation</h3>
+  <p>
+    {@link XmlElement} can be used on TypedXmlWriter-derived interfaces to associate
+    a tag name to that interface.
+
+  <h3>Method Annotations</h3>
+  <p>
+    {@link XmlElement}, {@link XmlAttribute}, or {@link XmlValue} can be used on a method
+    declared on a TypedXmLWriter-derived interface. Those annotations are mutually-exclusive.
+    See their javadoc for details. If none of the above three annotations are specified,
+    {@link XmlElement} is assumed.
+
+</body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/CharacterEscapeHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/CharacterEscapeHandler.java
new file mode 100644
index 0000000..e441cad
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/CharacterEscapeHandler.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.output;
+
+import java.io.IOException;
+import java.io.Writer;
+
+/**
+ * Performs character escaping and write the result
+ * to the output.
+ *
+ * @since 1.0.1
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface CharacterEscapeHandler {
+
+    /**
+     * @param ch The array of characters.
+     * @param start The starting position.
+     * @param length The number of characters to use.
+     * @param isAttVal true if this is an attribute value literal.
+     */
+    void escape( char ch[], int start, int length, boolean isAttVal, Writer out ) throws IOException;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DataWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DataWriter.java
new file mode 100644
index 0000000..27e0eeb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DataWriter.java
@@ -0,0 +1,372 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+//@@3RD PARTY CODE@@
+
+// DataWriter.java - XML writer for data-oriented files.
+
+package com.sun.xml.internal.txw2.output;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+import java.io.Writer;
+import java.util.Stack;
+
+
+/**
+ * Write data- or field-oriented XML.
+ *
+ * <p>This filter pretty-prints field-oriented XML without mixed content.
+ * all added indentation and newlines will be passed on down
+ * the filter chain (if any).</p>
+ *
+ * <p>In general, all whitespace in an XML document is potentially
+ * significant, so a general-purpose XML writing tool like the
+ * {@link XMLWriter} class cannot
+ * add newlines or indentation.</p>
+ *
+ * <p>There is, however, a large class of XML documents where information
+ * is strictly fielded: each element contains either character data
+ * or other elements, but not both.  For this special case, it is possible
+ * for a writing tool to provide automatic indentation and newlines
+ * without requiring extra work from the user.  Note that this class
+ * will likely not yield appropriate results for document-oriented
+ * XML like XHTML pages, which mix character data and elements together.</p>
+ *
+ * <p>This writer will automatically place each start tag on a new line,
+ * optionally indented if an indent step is provided (by default, there
+ * is no indentation).  If an element contains other elements, the end
+ * tag will also appear on a new line with leading indentation.  Consider,
+ * for example, the following code:</p>
+ *
+ * <pre>
+ * DataWriter w = new DataWriter();
+ *
+ * w.setIndentStep(2);
+ * w.startDocument();
+ * w.startElement("Person");
+ * w.dataElement("name", "Jane Smith");
+ * w.dataElement("date-of-birth", "1965-05-23");
+ * w.dataElement("citizenship", "US");
+ * w.endElement("Person");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>This code will produce the following document:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;Person>
+ *   &lt;name>Jane Smith&lt;/name>
+ *   &lt;date-of-birth>1965-05-23&lt;/date-of-birth>
+ *   &lt;citizenship>US&lt;/citizenship>
+ * &lt;/Person>
+ * </pre>
+ *
+ * <p>This class inherits from {@link XMLWriter},
+ * and provides all of the same support for Namespaces.</p>
+ *
+ * @since 1.0
+ * @author David Megginson, david@megginson.com
+ * @see XMLWriter
+ */
+public class DataWriter extends XMLWriter
+{
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constructors.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Create a new data writer for the specified output.
+     *
+     * @param writer The character stream where the XML document
+     *        will be written.
+     * @param encoding
+     *      If non-null string is specified, it is written as a part
+     *      of the XML declaration.
+     */
+    public DataWriter ( Writer writer, String encoding, CharacterEscapeHandler _escapeHandler )
+    {
+        super(writer,encoding,_escapeHandler);
+    }
+
+
+    public DataWriter (Writer writer, String encoding ) {
+        this( writer, encoding, DumbEscapeHandler.theInstance );
+    }
+
+    public DataWriter (Writer writer) {
+        this( writer, null, DumbEscapeHandler.theInstance );
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Accessors and setters.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Return the current indent step.
+     *
+     * <p>Return the current indent step: each start tag will be
+     * indented by this number of spaces times the number of
+     * ancestors that the element has.</p>
+     *
+     * @return The number of spaces in each indentation step,
+     *         or 0 or less for no indentation.
+     * @see #setIndentStep(int)
+     *
+     * @deprecated
+     *      Only return the length of the indent string.
+     */
+    public int getIndentStep ()
+    {
+        return indentStep.length();
+    }
+
+
+    /**
+     * Set the current indent step.
+     *
+     * @param indentStep The new indent step (0 or less for no
+     *        indentation).
+     * @see #getIndentStep()
+     *
+     * @deprecated
+     *      Should use the version that takes string.
+     */
+    public void setIndentStep (int indentStep)
+    {
+        StringBuilder s = new StringBuilder();
+        for( ; indentStep>0; indentStep-- )   s.append(' ');
+        setIndentStep(s.toString());
+    }
+
+    public void setIndentStep(String s) {
+        this.indentStep = s;
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Override methods from XMLWriter.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Reset the writer so that it can be reused.
+     *
+     * <p>This method is especially useful if the writer failed
+     * with an exception the last time through.</p>
+     *
+     * @see XMLWriter#reset()
+     */
+    public void reset ()
+    {
+        depth = 0;
+        state = SEEN_NOTHING;
+        stateStack = new Stack();
+        super.reset();
+    }
+
+
+    /**
+     * Write a start tag.
+     *
+     * <p>Each tag will begin on a new line, and will be
+     * indented by the current indent step times the number
+     * of ancestors that the element has.</p>
+     *
+     * <p>The newline and indentation will be passed on down
+     * the filter chain through regular characters events.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @param qName The element's qualified (prefixed) name.
+     * @param atts The element's attribute list.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the start tag, or if a filter further
+     *            down the chain raises an exception.
+     * @see XMLWriter#startElement(String, String, String, Attributes)
+     */
+    public void startElement (String uri, String localName,
+                              String qName, Attributes atts)
+        throws SAXException
+    {
+        stateStack.push(SEEN_ELEMENT);
+        state = SEEN_NOTHING;
+        if (depth > 0) {
+            super.characters("\n");
+        }
+        doIndent();
+        super.startElement(uri, localName, qName, atts);
+        depth++;
+    }
+
+
+    /**
+     * Write an end tag.
+     *
+     * <p>If the element has contained other elements, the tag
+     * will appear indented on a new line; otherwise, it will
+     * appear immediately following whatever came before.</p>
+     *
+     * <p>The newline and indentation will be passed on down
+     * the filter chain through regular characters events.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @param qName The element's qualified (prefixed) name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the end tag, or if a filter further
+     *            down the chain raises an exception.
+     * @see XMLWriter#endElement(String, String, String)
+     */
+    public void endElement (String uri, String localName, String qName)
+        throws SAXException
+    {
+        depth--;
+        if (state == SEEN_ELEMENT) {
+            super.characters("\n");
+            doIndent();
+        }
+        super.endElement(uri, localName, qName);
+        state = stateStack.pop();
+    }
+
+
+//    /**
+//     * Write a empty element tag.
+//     *
+//     * <p>Each tag will appear on a new line, and will be
+//     * indented by the current indent step times the number
+//     * of ancestors that the element has.</p>
+//     *
+//     * <p>The newline and indentation will be passed on down
+//     * the filter chain through regular characters events.</p>
+//     *
+//     * @param uri The element's Namespace URI.
+//     * @param localName The element's local name.
+//     * @param qName The element's qualified (prefixed) name.
+//     * @param atts The element's attribute list.
+//     * @exception org.xml.sax.SAXException If there is an error
+//     *            writing the empty tag, or if a filter further
+//     *            down the chain raises an exception.
+//     * @see XMLWriter#emptyElement(String, String, String, Attributes)
+//     */
+//    public void emptyElement (String uri, String localName,
+//                              String qName, Attributes atts)
+//        throws SAXException
+//    {
+//        state = SEEN_ELEMENT;
+//        if (depth > 0) {
+//            super.characters("\n");
+//        }
+//        doIndent();
+//        super.emptyElement(uri, localName, qName, atts);
+//    }
+
+
+    /**
+     * Write a sequence of characters.
+     *
+     * @param ch The characters to write.
+     * @param start The starting position in the array.
+     * @param length The number of characters to use.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the characters, or if a filter further
+     *            down the chain raises an exception.
+     * @see XMLWriter#characters(char[], int, int)
+     */
+    public void characters (char ch[], int start, int length)
+        throws SAXException
+    {
+        state = SEEN_DATA;
+        super.characters(ch, start, length);
+    }
+
+    public void comment(char ch[], int start, int length) throws SAXException {
+        if (depth > 0) {
+            super.characters("\n");
+        }
+        doIndent();
+        super.comment(ch,start,length);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Print indentation for the current level.
+     *
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the indentation characters, or if a filter
+     *            further down the chain raises an exception.
+     */
+    private void doIndent ()
+        throws SAXException
+    {
+        if (depth > 0) {
+            char[] ch = indentStep.toCharArray();
+            for( int i=0; i<depth; i++ )
+                characters(ch, 0, ch.length);
+        }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constants.
+    ////////////////////////////////////////////////////////////////////
+
+    private final static Object SEEN_NOTHING = new Object();
+    private final static Object SEEN_ELEMENT = new Object();
+    private final static Object SEEN_DATA = new Object();
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    private Object state = SEEN_NOTHING;
+    private Stack stateStack = new Stack();
+
+    private String indentStep = "";
+    private int depth = 0;
+
+}
+
+// end of DataWriter.java
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DomSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DomSerializer.java
new file mode 100644
index 0000000..8de932f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DomSerializer.java
@@ -0,0 +1,310 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.output;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.w3c.dom.Text;
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.ext.LexicalHandler;
+
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.transform.dom.DOMResult;
+import java.util.ArrayList;
+import java.util.Stack;
+
+import com.sun.xml.internal.txw2.TxwException;
+
+/**
+ * {@link XmlSerializer} for {@link javax.xml.transform.dom.DOMResult} and {@link org.w3c.dom.Node}.
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+public class DomSerializer implements XmlSerializer {
+
+    // delegate to SaxSerializer
+    private final SaxSerializer serializer;
+
+    public DomSerializer(Node node) {
+        Dom2SaxAdapter adapter = new Dom2SaxAdapter(node);
+        serializer = new SaxSerializer(adapter,adapter);
+    }
+
+    public DomSerializer(DOMResult domResult) {
+        Node node = domResult.getNode();
+
+        if (node == null) {
+            try {
+                DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+                dbf.setNamespaceAware(true);
+                DocumentBuilder db = dbf.newDocumentBuilder();
+                Document doc = db.newDocument();
+                domResult.setNode(doc);
+                serializer = new SaxSerializer(new Dom2SaxAdapter(doc));
+            } catch (ParserConfigurationException pce) {
+                throw new TxwException(pce);
+            }
+        } else {
+            serializer = new SaxSerializer(new Dom2SaxAdapter(node));
+        }
+    }
+
+    // XmlSerializer api's - delegate to SaxSerializer
+    public void startDocument() {
+        serializer.startDocument();
+    }
+
+    public void beginStartTag(String uri, String localName, String prefix) {
+        serializer.beginStartTag(uri, localName, prefix);
+    }
+
+    public void writeAttribute(String uri, String localName, String prefix, StringBuilder value) {
+        serializer.writeAttribute(uri, localName, prefix, value);
+    }
+
+    public void writeXmlns(String prefix, String uri) {
+        serializer.writeXmlns(prefix, uri);
+    }
+
+    public void endStartTag(String uri, String localName, String prefix) {
+        serializer.endStartTag(uri, localName, prefix);
+    }
+
+    public void endTag() {
+        serializer.endTag();
+    }
+
+    public void text(StringBuilder text) {
+        serializer.text(text);
+    }
+
+    public void cdata(StringBuilder text) {
+        serializer.cdata(text);
+    }
+
+    public void comment(StringBuilder comment) {
+        serializer.comment(comment);
+    }
+
+    public void endDocument() {
+        serializer.endDocument();
+    }
+
+    public void flush() {
+        // no flushing
+    }
+}
+
+
+
+
+/**
+ * Builds a DOM tree from SAX2 events.
+ *
+ * @author  Vivek Pandey
+ */
+class Dom2SaxAdapter implements ContentHandler, LexicalHandler {
+
+    private final Node _node;
+    private final Stack _nodeStk = new Stack();
+    private boolean inCDATA;
+
+    public final Element getCurrentElement() {
+        return (Element) _nodeStk.peek();
+    }
+
+    /**
+     * Document object that owns the specified node.
+     */
+    private final Document _document;
+
+    /**
+     * @param   node
+     *      Nodes will be created and added under this object.
+     */
+    public Dom2SaxAdapter(Node node)
+    {
+        _node = node;
+        _nodeStk.push(_node);
+
+        if( node instanceof Document )
+            this._document = (Document)node;
+        else
+            this._document = node.getOwnerDocument();
+    }
+
+    /**
+     * Creates a fresh empty DOM document and adds nodes under this document.
+     */
+    public Dom2SaxAdapter() throws ParserConfigurationException {
+        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
+        factory.setNamespaceAware(true);
+        factory.setValidating(false);
+
+        _document = factory.newDocumentBuilder().newDocument();
+        _node = _document;
+        _nodeStk.push( _document );
+    }
+
+    public Node getDOM() {
+        return _node;
+    }
+
+    public void startDocument() {
+    }
+
+    public void endDocument(){
+    }
+
+    public void startElement(String namespace, String localName, String qName, Attributes attrs){
+
+        // some broken DOM implementatino (we confirmed it with SAXON)
+        // return null from this method.
+        Element element = _document.createElementNS(namespace, qName);
+
+        if( element==null ) {
+            // if so, report an user-friendly error message,
+            // rather than dying mysteriously with NPE.
+            throw new TxwException("Your DOM provider doesn't support the createElementNS method properly");
+        }
+
+        // process namespace bindings
+        for( int i=0; i<unprocessedNamespaces.size(); i+=2 ) {
+            String prefix = (String)unprocessedNamespaces.get(i+0);
+            String uri = (String)unprocessedNamespaces.get(i+1);
+
+            String qname;
+            if( "".equals(prefix) || prefix==null )
+                qname = "xmlns";
+            else
+                qname = "xmlns:"+prefix;
+
+            // older version of Xerces (I confirmed that the bug is gone with Xerces 2.4.0)
+            // have a problem of re-setting the same namespace attribute twice.
+            // work around this bug removing it first.
+            if( element.hasAttributeNS("http://www.w3.org/2000/xmlns/",qname) ) {
+                // further workaround for an old Crimson bug where the removeAttribtueNS
+                // method throws NPE when the element doesn't have any attribute.
+                // to be on the safe side, check the existence of attributes before
+                // attempting to remove it.
+                // for details about this bug, see org.apache.crimson.tree.ElementNode2
+                // line 540 or the following message:
+                // https://jaxb.dev.java.net/servlets/ReadMsg?list=users&msgNo=2767
+                element.removeAttributeNS("http://www.w3.org/2000/xmlns/",qname);
+            }
+            // workaround until here
+
+            element.setAttributeNS("http://www.w3.org/2000/xmlns/",qname, uri);
+        }
+        unprocessedNamespaces.clear();
+
+
+        int length = attrs.getLength();
+        for(int i=0;i<length;i++){
+            String namespaceuri = attrs.getURI(i);
+            String value = attrs.getValue(i);
+            String qname = attrs.getQName(i);
+            element.setAttributeNS(namespaceuri, qname, value);
+        }
+        // append this new node onto current stack node
+        getParent().appendChild(element);
+        // push this node onto stack
+        _nodeStk.push(element);
+    }
+
+    private final Node getParent() {
+        return (Node) _nodeStk.peek();
+    }
+
+    public void endElement(String namespace, String localName, String qName){
+        _nodeStk.pop();
+    }
+
+
+    public void characters(char[] ch, int start, int length) {
+        Node text;
+        if(inCDATA)
+            text = _document.createCDATASection(new String(ch, start, length));
+        else
+            text = _document.createTextNode(new String(ch, start, length));
+        getParent().appendChild(text);
+    }
+
+    public void comment(char ch[], int start, int length) throws SAXException {
+        getParent().appendChild(_document.createComment(new String(ch,start,length)));
+    }
+
+
+
+    public void ignorableWhitespace(char[] ch, int start, int length) {
+    }
+
+    public void processingInstruction(String target, String data) throws org.xml.sax.SAXException{
+        Node node = _document.createProcessingInstruction(target, data);
+        getParent().appendChild(node);
+    }
+
+    public void setDocumentLocator(Locator locator) {
+    }
+
+    public void skippedEntity(String name) {
+    }
+
+    private ArrayList unprocessedNamespaces = new ArrayList();
+
+    public void startPrefixMapping(String prefix, String uri) {
+        unprocessedNamespaces.add(prefix);
+        unprocessedNamespaces.add(uri);
+    }
+
+    public void endPrefixMapping(String prefix) {
+    }
+
+    public void startDTD(String name, String publicId, String systemId) throws SAXException {
+    }
+
+    public void endDTD() throws SAXException {
+    }
+
+    public void startEntity(String name) throws SAXException {
+    }
+
+    public void endEntity(String name) throws SAXException {
+    }
+
+    public void startCDATA() throws SAXException {
+        inCDATA = true;
+    }
+
+    public void endCDATA() throws SAXException {
+        inCDATA = false;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DumbEscapeHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DumbEscapeHandler.java
new file mode 100644
index 0000000..b887f7e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DumbEscapeHandler.java
@@ -0,0 +1,78 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.output;
+
+import java.io.IOException;
+import java.io.Writer;
+
+/**
+ * Escape everything above the US-ASCII code range.
+ * A fallback position.
+ *
+ * Works with any JDK, any encoding.
+ *
+ * @since 1.0.1
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class DumbEscapeHandler implements CharacterEscapeHandler {
+
+    private DumbEscapeHandler() {}  // no instanciation please
+
+    public static final CharacterEscapeHandler theInstance = new DumbEscapeHandler();
+
+    public void escape(char[] ch, int start, int length, boolean isAttVal, Writer out) throws IOException {
+        int limit = start+length;
+        for (int i = start; i < limit; i++) {
+            switch (ch[i]) {
+            case '&':
+                out.write("&amp;");
+                break;
+            case '<':
+                out.write("&lt;");
+                break;
+            case '>':
+                out.write("&gt;");
+                break;
+            case '\"':
+                if (isAttVal) {
+                    out.write("&quot;");
+                } else {
+                    out.write('\"');
+                }
+                break;
+            default:
+                if (ch[i] > '\u007f') {
+                    out.write("&#");
+                    out.write(Integer.toString(ch[i]));
+                    out.write(';');
+                } else {
+                    out.write(ch[i]);
+                }
+            }
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DumpSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DumpSerializer.java
new file mode 100644
index 0000000..67bce07
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/DumpSerializer.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.output;
+
+import java.io.PrintStream;
+
+/**
+ * Shows the call sequence of {@link XmlSerializer} methods.
+ *
+ * Useful for debugging and learning how TXW works.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class DumpSerializer implements XmlSerializer {
+    private final PrintStream out;
+
+    public DumpSerializer(PrintStream out) {
+        this.out = out;
+    }
+
+    public void beginStartTag(String uri, String localName, String prefix) {
+        out.println('<'+prefix+':'+localName);
+    }
+
+    public void writeAttribute(String uri, String localName, String prefix, StringBuilder value) {
+        out.println('@'+prefix+':'+localName+'='+value);
+    }
+
+    public void writeXmlns(String prefix, String uri) {
+        out.println("xmlns:"+prefix+'='+uri);
+    }
+
+    public void endStartTag(String uri, String localName, String prefix) {
+        out.println('>');
+    }
+
+    public void endTag() {
+        out.println("</  >");
+    }
+
+    public void text(StringBuilder text) {
+        out.println(text);
+    }
+
+    public void cdata(StringBuilder text) {
+        out.println("<![CDATA[");
+        out.println(text);
+        out.println("]]>");
+    }
+
+    public void comment(StringBuilder comment) {
+        out.println("<!--");
+        out.println(comment);
+        out.println("-->");
+    }
+
+    public void startDocument() {
+        out.println("<?xml?>");
+    }
+
+    public void endDocument() {
+        out.println("done");
+    }
+
+    public void flush() {
+        out.println("flush");
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/ResultFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/ResultFactory.java
new file mode 100644
index 0000000..9b2bb48
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/ResultFactory.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.output;
+
+import javax.xml.transform.Result;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.sax.SAXResult;
+import javax.xml.transform.stream.StreamResult;
+
+/**
+ * Factory for producing XmlSerializers for various Result types.
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+public abstract class ResultFactory {
+
+    /**
+     * Do not instanciate.
+     */
+    private ResultFactory() {}
+
+    /**
+     * Factory method for producing {@link XmlSerializer) from {@link javax.xml.transform.Result}.
+     *
+     * This method supports {@link javax.xml.transform.sax.SAXResult},
+     * {@link javax.xml.transform.stream.StreamResult}, and {@link javax.xml.transform.dom.DOMResult}.
+     *
+     * @param result the Result that will receive output from the XmlSerializer
+     * @return an implementation of XmlSerializer that will produce output on the supplied Result
+     */
+    public static XmlSerializer createSerializer(Result result) {
+        if (result instanceof SAXResult)
+            return new SaxSerializer((SAXResult) result);
+        if (result instanceof DOMResult)
+            return new DomSerializer((DOMResult) result);
+        if (result instanceof StreamResult)
+            return new StreamSerializer((StreamResult) result);
+
+        throw new UnsupportedOperationException("Unsupported Result type: " + result.getClass().getName());
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/SaxSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/SaxSerializer.java
new file mode 100644
index 0000000..570cd0d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/SaxSerializer.java
@@ -0,0 +1,202 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.output;
+
+import com.sun.xml.internal.txw2.TxwException;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.AttributesImpl;
+
+import javax.xml.transform.sax.SAXResult;
+import java.util.Stack;
+
+/**
+ * {@link XmlSerializer} for {@link SAXResult} and {@link ContentHandler}.
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+public class SaxSerializer implements XmlSerializer {
+
+    private final ContentHandler writer;
+    private final LexicalHandler lexical;
+
+    public SaxSerializer(ContentHandler handler) {
+        this(handler,null);
+    }
+
+    /**
+     * Creates an {@link XmlSerializer} that writes SAX events.
+     *
+     * <p>
+     * Sepcifying a non-null {@link LexicalHandler} allows applications
+     * to write comments and CDATA sections.
+     */
+    public SaxSerializer(ContentHandler handler,LexicalHandler lex) {
+        writer = handler;
+        lexical = lex;
+    }
+
+    public SaxSerializer(SAXResult result) {
+        this(result.getHandler(),result.getLexicalHandler());
+    }
+
+
+    // XmlSerializer implementation
+
+    public void startDocument() {
+        try {
+            writer.startDocument();
+        } catch (SAXException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    // namespace prefix bindings
+    // add in #writeXmlns and fired in #endStartTag
+    private final Stack<String> prefixBindings = new Stack<String>();
+
+    public void writeXmlns(String prefix, String uri) {
+        // defend against parsers that pass null in for "xmlns" prefix
+        if (prefix == null) {
+            prefix = "";
+        }
+
+        if (prefix.equals("xml")) {
+            return;
+        }
+
+        prefixBindings.add(uri);
+        prefixBindings.add(prefix);
+    }
+
+    // element stack
+    private final Stack<String> elementBindings = new Stack<String>();
+
+    public void beginStartTag(String uri, String localName, String prefix) {
+        // save element bindings for #endTag
+        elementBindings.add(getQName(prefix, localName));
+        elementBindings.add(localName);
+        elementBindings.add(uri);
+    }
+
+    // attribute storage
+    // attrs are buffered in #writeAttribute and sent to the content
+    // handler in #endStartTag
+    private final AttributesImpl attrs = new AttributesImpl();
+
+    public void writeAttribute(String uri, String localName, String prefix, StringBuilder value) {
+        attrs.addAttribute(uri,
+                localName,
+                getQName(prefix, localName),
+                "CDATA",
+                value.toString());
+    }
+
+    public void endStartTag(String uri, String localName, String prefix) {
+        try {
+            while (prefixBindings.size() != 0) {
+                writer.startPrefixMapping(prefixBindings.pop(), // prefix
+                        prefixBindings.pop()   // uri
+                );
+            }
+
+            writer.startElement(uri,
+                    localName,
+                    getQName(prefix, localName),
+                    attrs);
+
+            attrs.clear();
+        } catch (SAXException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void endTag() {
+        try {
+            writer.endElement(elementBindings.pop(), // uri
+                    elementBindings.pop(), // localName
+                    elementBindings.pop()  // qname
+            );
+        } catch (SAXException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void text(StringBuilder text) {
+        try {
+            writer.characters(text.toString().toCharArray(), 0, text.length());
+        } catch (SAXException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void cdata(StringBuilder text) {
+        if(lexical==null)
+            throw new UnsupportedOperationException("LexicalHandler is needed to write PCDATA");
+
+        try {
+            lexical.startCDATA();
+            text(text);
+            lexical.endCDATA();
+        } catch (SAXException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void comment(StringBuilder comment) {
+        try {
+            if(lexical==null)
+                throw new UnsupportedOperationException("LexicalHandler is needed to write comments");
+            else
+                lexical.comment(comment.toString().toCharArray(), 0, comment.length() );
+        } catch (SAXException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void endDocument() {
+        try {
+            writer.endDocument();
+        } catch (SAXException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void flush() {
+        // noop
+    }
+
+    // other methods
+    private static String getQName(String prefix, String localName) {
+        final String qName;
+        if (prefix == null || prefix.length() == 0)
+            qName = localName;
+        else
+            qName = prefix + ':' + localName;
+
+        return qName;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/StaxSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/StaxSerializer.java
new file mode 100644
index 0000000..4b6c821
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/StaxSerializer.java
@@ -0,0 +1,138 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.output;
+
+import com.sun.xml.internal.txw2.TxwException;
+
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+
+/**
+ * XML serializer for StAX XMLStreamWriter.
+ *
+ * TODO: add support for XMLEventWriter (if it makes sense)
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+
+public class StaxSerializer implements XmlSerializer {
+    private final XMLStreamWriter out;
+
+    public StaxSerializer(XMLStreamWriter writer) {
+        this.out = writer;
+    }
+
+    public void startDocument() {
+        try {
+            out.writeStartDocument();
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void beginStartTag(String uri, String localName, String prefix) {
+        try {
+            out.writeStartElement(prefix, localName, uri);
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void writeAttribute(String uri, String localName, String prefix, StringBuilder value) {
+        try {
+            out.writeAttribute(prefix, uri, localName, value.toString());
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void writeXmlns(String prefix, String uri) {
+        try {
+            if (prefix.length() == 0) {
+                out.setDefaultNamespace(uri);
+            } else {
+                out.setPrefix(prefix, uri);
+            }
+
+            // this method handles "", null, and "xmlns" prefixes properly
+            out.writeNamespace(prefix, uri);
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void endStartTag(String uri, String localName, String prefix) {
+        // NO-OP
+    }
+
+    public void endTag() {
+        try {
+            out.writeEndElement();
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void text(StringBuilder text) {
+        try {
+            out.writeCharacters(text.toString());
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void cdata(StringBuilder text) {
+        try {
+            out.writeCData(text.toString());
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void comment(StringBuilder comment) {
+        try {
+            out.writeComment(comment.toString());
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void endDocument() {
+        try {
+            out.writeEndDocument();
+            out.flush();
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    public void flush() {
+        try {
+            out.flush();
+        } catch (XMLStreamException e) {
+            throw new TxwException(e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/StreamSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/StreamSerializer.java
new file mode 100644
index 0000000..601fafb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/StreamSerializer.java
@@ -0,0 +1,193 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.txw2.output;
+
+import com.sun.xml.internal.txw2.TxwException;
+
+import javax.xml.transform.stream.StreamResult;
+import java.io.BufferedWriter;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+import java.io.UnsupportedEncodingException;
+
+/**
+ * {@link XmlSerializer} for {@link javax.xml.transform.stream.StreamResult}.
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+public class StreamSerializer implements XmlSerializer {
+
+    // delegate to SaxSerializer
+    private final SaxSerializer serializer;
+
+    private final XMLWriter writer;
+
+    public StreamSerializer(OutputStream out) {
+        this(createWriter(out));
+    }
+
+    public StreamSerializer(OutputStream out,String encoding) throws UnsupportedEncodingException {
+        this(createWriter(out,encoding));
+    }
+
+    public StreamSerializer(Writer out) {
+        this(new StreamResult(out));
+    }
+
+    public StreamSerializer(StreamResult streamResult) {
+        // if this method opened a stream, let it close it
+        final OutputStream[] autoClose = new OutputStream[1];
+
+        if (streamResult.getWriter() != null)
+            writer = createWriter(streamResult.getWriter());
+        else if (streamResult.getOutputStream() != null)
+            writer = createWriter(streamResult.getOutputStream());
+        else if (streamResult.getSystemId() != null) {
+            String fileURL = streamResult.getSystemId();
+
+            fileURL = convertURL(fileURL);
+
+            try {
+                FileOutputStream fos = new FileOutputStream(fileURL);
+                autoClose[0] = fos;
+                writer = createWriter(fos);
+            } catch (IOException e) {
+                throw new TxwException(e);
+            }
+        } else
+            throw new IllegalArgumentException();
+
+        // now delegate to the SaxSerializer
+        serializer = new SaxSerializer(writer,writer) {
+            public void endDocument() {
+                super.endDocument();
+                if(autoClose[0]!=null) {
+                    try {
+                        autoClose[0].close();
+                    } catch (IOException e) {
+                        throw new TxwException(e);
+                    }
+                    autoClose[0] = null;
+                }
+            }
+        };
+    }
+
+    private StreamSerializer(XMLWriter writer) {
+        this.writer = writer;
+        // now delegate to the SaxSerializer
+        serializer = new SaxSerializer(writer,writer);
+    }
+
+    private String convertURL(String url) {
+        url = url.replace('\\', '/');
+        url = url.replaceAll("//","/");
+        url = url.replaceAll("//","/");
+        if (url.startsWith("file:/")) {
+            if (url.substring(6).indexOf(":") > 0)
+                url = url.substring(6);
+            else
+                url = url.substring(5);
+        } // otherwise assume that it's a file name
+        return url;
+    }
+
+    // XmlSerializer api's - delegate to SaxSerializer
+    public void startDocument() {
+        serializer.startDocument();
+    }
+
+    public void beginStartTag(String uri, String localName, String prefix) {
+        serializer.beginStartTag(uri, localName, prefix);
+    }
+
+    public void writeAttribute(String uri, String localName, String prefix, StringBuilder value) {
+        serializer.writeAttribute(uri, localName, prefix, value);
+    }
+
+    public void writeXmlns(String prefix, String uri) {
+        serializer.writeXmlns(prefix, uri);
+    }
+
+    public void endStartTag(String uri, String localName, String prefix) {
+        serializer.endStartTag(uri, localName, prefix);
+    }
+
+    public void endTag() {
+        serializer.endTag();
+    }
+
+    public void text(StringBuilder text) {
+        serializer.text(text);
+    }
+
+    public void cdata(StringBuilder text) {
+        serializer.cdata(text);
+    }
+
+    public void comment(StringBuilder comment) {
+        serializer.comment(comment);
+    }
+
+    public void endDocument() {
+        serializer.endDocument();
+    }
+
+    public void flush() {
+        serializer.flush();
+        try {
+            writer.flush();
+        } catch (IOException e) {
+            throw new TxwException(e);
+        }
+    }
+
+    // other supporting code
+    private static XMLWriter createWriter(Writer w) {
+        // buffering improves the performance
+        DataWriter dw = new DataWriter(new BufferedWriter(w));
+        dw.setIndentStep("  ");
+        return dw;
+    }
+
+    private static XMLWriter createWriter(OutputStream os, String encoding) throws UnsupportedEncodingException {
+        XMLWriter writer = createWriter(new OutputStreamWriter(os,encoding));
+        writer.setEncoding(encoding);
+        return writer;
+    }
+
+    private static XMLWriter createWriter(OutputStream os) {
+        try {
+            return createWriter(os,"UTF-8");
+        } catch (UnsupportedEncodingException e) {
+            // UTF-8 is supported on all platforms.
+            throw new Error(e);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/XMLWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/XMLWriter.java
new file mode 100644
index 0000000..bdbf0ec
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/XMLWriter.java
@@ -0,0 +1,1073 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+// @@3RD PARTY CODE@@
+
+// XMLWriter.java - serialize an XML document.
+// Written by David Megginson, david@megginson.com
+// NO WARRANTY!  This class is in the public domain.
+
+// Id: XMLWriter.java,v 1.5 2000/09/17 01:08:16 david Exp
+
+package com.sun.xml.internal.txw2.output;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.AttributesImpl;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+import java.io.IOException;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+
+
+/**
+ * Filter to write an XML document from a SAX event stream.
+ *
+ * <p>This class can be used by itself or as part of a SAX event
+ * stream: it takes as input a series of SAX2 ContentHandler
+ * events and uses the information in those events to write
+ * an XML document.  Since this class is a filter, it can also
+ * pass the events on down a filter chain for further processing
+ * (you can use the XMLWriter to take a snapshot of the current
+ * state at any point in a filter chain), and it can be
+ * used directly as a ContentHandler for a SAX2 XMLReader.</p>
+ *
+ * <p>The client creates a document by invoking the methods for
+ * standard SAX2 events, always beginning with the
+ * {@link #startDocument startDocument} method and ending with
+ * the {@link #endDocument endDocument} method.  There are convenience
+ * methods provided so that clients to not have to create empty
+ * attribute lists or provide empty strings as parameters; for
+ * example, the method invocation</p>
+ *
+ * <pre>
+ * w.startElement("foo");
+ * </pre>
+ *
+ * <p>is equivalent to the regular SAX2 ContentHandler method</p>
+ *
+ * <pre>
+ * w.startElement("", "foo", "", new AttributesImpl());
+ * </pre>
+ *
+ * <p>Except that it is more efficient because it does not allocate
+ * a new empty attribute list each time.  The following code will send
+ * a simple XML document to standard output:</p>
+ *
+ * <pre>
+ * XMLWriter w = new XMLWriter();
+ *
+ * w.startDocument();
+ * w.startElement("greeting");
+ * w.characters("Hello, world!");
+ * w.endElement("greeting");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>The resulting document will look like this:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;greeting>Hello, world!&lt;/greeting>
+ * </pre>
+ *
+ * <p>In fact, there is an even simpler convenience method,
+ * <var>dataElement</var>, designed for writing elements that
+ * contain only character data, so the code to generate the
+ * document could be shortened to</p>
+ *
+ * <pre>
+ * XMLWriter w = new XMLWriter();
+ *
+ * w.startDocument();
+ * w.dataElement("greeting", "Hello, world!");
+ * w.endDocument();
+ * </pre>
+ *
+ * <h2>Whitespace</h2>
+ *
+ * <p>According to the XML Recommendation, <em>all</em> whitespace
+ * in an XML document is potentially significant to an application,
+ * so this class never adds newlines or indentation.  If you
+ * insert three elements in a row, as in</p>
+ *
+ * <pre>
+ * w.dataElement("item", "1");
+ * w.dataElement("item", "2");
+ * w.dataElement("item", "3");
+ * </pre>
+ *
+ * <p>you will end up with</p>
+ *
+ * <pre>
+ * &lt;item>1&lt;/item>&lt;item>3&lt;/item>&lt;item>3&lt;/item>
+ * </pre>
+ *
+ * <p>You need to invoke one of the <var>characters</var> methods
+ * explicitly to add newlines or indentation.  Alternatively, you
+ * can use {@link DataWriter}, which
+ * is derived from this class -- it is optimized for writing
+ * purely data-oriented (or field-oriented) XML, and does automatic
+ * linebreaks and indentation (but does not support mixed content
+ * properly).</p>
+ *
+ *
+ * <h2>Namespace Support</h2>
+ *
+ * <p>The writer contains extensive support for XML Namespaces, so that
+ * a client application does not have to keep track of prefixes and
+ * supply <var>xmlns</var> attributes.  By default, the XML writer will
+ * generate Namespace declarations in the form _NS1, _NS2, etc., wherever
+ * they are needed, as in the following example:</p>
+ *
+ * <pre>
+ * w.startDocument();
+ * w.emptyElement("http://www.foo.com/ns/", "foo");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>The resulting document will look like this:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;_NS1:foo xmlns:_NS1="http://www.foo.com/ns/"/>
+ * </pre>
+ *
+ * <p>In many cases, document authors will prefer to choose their
+ * own prefixes rather than using the (ugly) default names.  The
+ * XML writer allows two methods for selecting prefixes:</p>
+ *
+ * <ol>
+ * <li>the qualified name</li>
+ * <li>the {@link #setPrefix setPrefix} method.</li>
+ * </ol>
+ *
+ * <p>Whenever the XML writer finds a new Namespace URI, it checks
+ * to see if a qualified (prefixed) name is also available; if so
+ * it attempts to use the name's prefix (as long as the prefix is
+ * not already in use for another Namespace URI).</p>
+ *
+ * <p>Before writing a document, the client can also pre-map a prefix
+ * to a Namespace URI with the setPrefix method:</p>
+ *
+ * <pre>
+ * w.setPrefix("http://www.foo.com/ns/", "foo");
+ * w.startDocument();
+ * w.emptyElement("http://www.foo.com/ns/", "foo");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>The resulting document will look like this:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;foo:foo xmlns:foo="http://www.foo.com/ns/"/>
+ * </pre>
+ *
+ * <p>The default Namespace simply uses an empty string as the prefix:</p>
+ *
+ * <pre>
+ * w.setPrefix("http://www.foo.com/ns/", "");
+ * w.startDocument();
+ * w.emptyElement("http://www.foo.com/ns/", "foo");
+ * w.endDocument();
+ * </pre>
+ *
+ * <p>The resulting document will look like this:</p>
+ *
+ * <pre>
+ * &lt;?xml version="1.0" standalone="yes"?>
+ *
+ * &lt;foo xmlns="http://www.foo.com/ns/"/>
+ * </pre>
+ *
+ * <p>By default, the XML writer will not declare a Namespace until
+ * it is actually used.  Sometimes, this approach will create
+ * a large number of Namespace declarations, as in the following
+ * example:</p>
+ *
+ * <pre>
+ * &lt;xml version="1.0" standalone="yes"?>
+ *
+ * &lt;rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ *  &lt;rdf:Description about="http://www.foo.com/ids/books/12345">
+ *   &lt;dc:title xmlns:dc="http://www.purl.org/dc/">A Dark Night&lt;/dc:title>
+ *   &lt;dc:creator xmlns:dc="http://www.purl.org/dc/">Jane Smith&lt;/dc:title>
+ *   &lt;dc:date xmlns:dc="http://www.purl.org/dc/">2000-09-09&lt;/dc:title>
+ *  &lt;/rdf:Description>
+ * &lt;/rdf:RDF>
+ * </pre>
+ *
+ * <p>The "rdf" prefix is declared only once, because the RDF Namespace
+ * is used by the root element and can be inherited by all of its
+ * descendants; the "dc" prefix, on the other hand, is declared three
+ * times, because no higher element uses the Namespace.  To solve this
+ * problem, you can instruct the XML writer to predeclare Namespaces
+ * on the root element even if they are not used there:</p>
+ *
+ * <pre>
+ * w.forceNSDecl("http://www.purl.org/dc/");
+ * </pre>
+ *
+ * <p>Now, the "dc" prefix will be declared on the root element even
+ * though it's not needed there, and can be inherited by its
+ * descendants:</p>
+ *
+ * <pre>
+ * &lt;xml version="1.0" standalone="yes"?>
+ *
+ * &lt;rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ *             xmlns:dc="http://www.purl.org/dc/">
+ *  &lt;rdf:Description about="http://www.foo.com/ids/books/12345">
+ *   &lt;dc:title>A Dark Night&lt;/dc:title>
+ *   &lt;dc:creator>Jane Smith&lt;/dc:title>
+ *   &lt;dc:date>2000-09-09&lt;/dc:title>
+ *  &lt;/rdf:Description>
+ * &lt;/rdf:RDF>
+ * </pre>
+ *
+ * <p>This approach is also useful for declaring Namespace prefixes
+ * that be used by qualified names appearing in attribute values or
+ * character data.</p>
+ *
+ * @author David Megginson, david@megginson.com
+ * @since JAXB1.0
+ * @see org.xml.sax.XMLFilter
+ * @see org.xml.sax.ContentHandler
+ */
+public class XMLWriter extends XMLFilterImpl implements LexicalHandler
+{
+    ////////////////////////////////////////////////////////////////////
+    // Constructors.
+    ////////////////////////////////////////////////////////////////////
+
+
+
+
+    /**
+     * Create a new XML writer.
+     *
+     * <p>Write to the writer provided.</p>
+     *
+     * @param writer
+     *      The output destination, or null to use standard output.
+     * @param encoding
+     *      If non-null string is specified, it is written as a part
+     *      of the XML declaration.
+     */
+    public XMLWriter (Writer writer, String encoding, CharacterEscapeHandler _escapeHandler )
+    {
+        init(writer,encoding);
+        this.escapeHandler = _escapeHandler;
+    }
+
+    public XMLWriter (Writer writer, String encoding ) {
+        this( writer, encoding, DumbEscapeHandler.theInstance );
+    }
+
+
+
+    /**
+     * Internal initialization method.
+     *
+     * <p>All of the public constructors invoke this method.
+     *
+     * @param writer The output destination, or null to use
+     *        standard output.
+     */
+    private void init (Writer writer,String encoding)
+    {
+        setOutput(writer,encoding);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Public methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Reset the writer.
+     *
+     * <p>This method is especially useful if the writer throws an
+     * exception before it is finished, and you want to reuse the
+     * writer for a new document.  It is usually a good idea to
+     * invoke {@link #flush flush} before resetting the writer,
+     * to make sure that no output is lost.</p>
+     *
+     * <p>This method is invoked automatically by the
+     * {@link #startDocument startDocument} method before writing
+     * a new document.</p>
+     *
+     * <p><strong>Note:</strong> this method will <em>not</em>
+     * clear the prefix or URI information in the writer or
+     * the selected output writer.</p>
+     *
+     * @see #flush()
+     */
+    public void reset ()
+    {
+        elementLevel = 0;
+        startTagIsClosed = true;
+    }
+
+
+    /**
+     * Flush the output.
+     *
+     * <p>This method flushes the output stream.  It is especially useful
+     * when you need to make certain that the entire document has
+     * been written to output but do not want to _commit the output
+     * stream.</p>
+     *
+     * <p>This method is invoked automatically by the
+     * {@link #endDocument endDocument} method after writing a
+     * document.</p>
+     *
+     * @see #reset()
+     */
+    public void flush ()
+        throws IOException
+    {
+        output.flush();
+    }
+
+
+    /**
+     * Set a new output destination for the document.
+     *
+     * @param writer The output destination, or null to use
+     *        standard output.
+     * @see #flush()
+     */
+    public void setOutput (Writer writer,String _encoding)
+    {
+        if (writer == null) {
+            output = new OutputStreamWriter(System.out);
+        } else {
+            output = writer;
+        }
+        encoding = _encoding;
+    }
+
+    public void setEncoding(String encoding) {
+        this.encoding = encoding;
+    }
+
+    /**
+     * Set whether the writer should print out the XML declaration
+     * (&lt;?xml version='1.0' ... ?>).
+     * <p>
+     * This option is set to true by default.
+     */
+    public void setXmlDecl( boolean _writeXmlDecl ) {
+        this.writeXmlDecl = _writeXmlDecl;
+    }
+
+    /**
+     * Sets the header string.
+     *
+     * This string will be written right after the xml declaration
+     * without any escaping. Useful for generating a boiler-plate
+     * DOCTYPE decl, PIs, and comments.
+     *
+     * @param _header
+     *      passing null will work as if the empty string is passed.
+     */
+    public void setHeader( String _header ) {
+        this.header = _header;
+    }
+
+
+    private final HashMap locallyDeclaredPrefix = new HashMap();
+    public void startPrefixMapping( String prefix, String uri ) throws SAXException {
+        locallyDeclaredPrefix.put(prefix,uri);
+    }
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Methods from org.xml.sax.ContentHandler.
+    ////////////////////////////////////////////////////////////////////
+
+    /**
+     * Write the XML declaration at the beginning of the document.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the XML declaration, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#startDocument()
+     */
+    public void startDocument ()
+        throws SAXException
+    {
+        try {
+            reset();
+
+            if(writeXmlDecl) {
+                String e="";
+                if(encoding!=null)
+                    e = " encoding=\""+encoding+"\"";
+
+                write("<?xml version=\"1.0\""+e+" standalone=\"yes\"?>\n");
+            }
+
+            if(header!=null)
+                write(header);
+
+            super.startDocument();
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write a newline at the end of the document.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the newline, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#endDocument()
+     */
+    public void endDocument ()
+        throws SAXException
+    {
+        try {
+            if (!startTagIsClosed) {
+                write("/>");
+                startTagIsClosed = true;
+            }
+            write('\n');
+            super.endDocument();
+            try {
+                flush();
+            } catch (IOException e) {
+                throw new SAXException(e);
+            }
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write a start tag.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param uri The Namespace URI, or the empty string if none
+     *        is available.
+     * @param localName The element's local (unprefixed) name (required).
+     * @param qName The element's qualified (prefixed) name, or the
+     *        empty string is none is available.  This method will
+     *        use the qName as a template for generating a prefix
+     *        if necessary, but it is not guaranteed to use the
+     *        same qName.
+     * @param atts The element's attribute list (must not be null).
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the start tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#startElement(java.lang.String, java.lang.String, java.lang.String, org.xml.sax.Attributes)
+     */
+    public void startElement (String uri, String localName,
+                              String qName, Attributes atts)
+        throws SAXException
+    {
+        try {
+            if (!startTagIsClosed) {
+                write(">");
+            }
+            elementLevel++;
+//            nsSupport.pushContext();
+
+            write('<');
+            writeName(uri, localName, qName, true);
+            writeAttributes(atts);
+
+            // declare namespaces specified by the startPrefixMapping methods
+            if(!locallyDeclaredPrefix.isEmpty()) {
+                Iterator itr = locallyDeclaredPrefix.entrySet().iterator();
+                while(itr.hasNext()) {
+                    Map.Entry e = (Map.Entry)itr.next();
+                    String p = (String)e.getKey();
+                    String u = (String)e.getValue();
+                    if (u == null) {
+                        u = "";
+                    }
+                    write(' ');
+                    if ("".equals(p)) {
+                        write("xmlns=\"");
+                    } else {
+                        write("xmlns:");
+                        write(p);
+                        write("=\"");
+                    }
+                    char ch[] = u.toCharArray();
+                    writeEsc(ch, 0, ch.length, true);
+                    write('\"');
+                }
+                locallyDeclaredPrefix.clear();  // clear the contents
+            }
+
+//            if (elementLevel == 1) {
+//                forceNSDecls();
+//            }
+//            writeNSDecls();
+            super.startElement(uri, localName, qName, atts);
+            startTagIsClosed = false;
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write an end tag.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param uri The Namespace URI, or the empty string if none
+     *        is available.
+     * @param localName The element's local (unprefixed) name (required).
+     * @param qName The element's qualified (prefixed) name, or the
+     *        empty string is none is available.  This method will
+     *        use the qName as a template for generating a prefix
+     *        if necessary, but it is not guaranteed to use the
+     *        same qName.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the end tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#endElement(java.lang.String, java.lang.String, java.lang.String)
+     */
+    public void endElement (String uri, String localName, String qName)
+        throws SAXException
+    {
+        try {
+            if (startTagIsClosed) {
+                write("</");
+                writeName(uri, localName, qName, true);
+                write('>');
+            } else {
+                write("/>");
+                startTagIsClosed = true;
+            }
+            if (elementLevel == 1) {
+                write('\n');
+            }
+            super.endElement(uri, localName, qName);
+//            nsSupport.popContext();
+            elementLevel--;
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write character data.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param ch The array of characters to write.
+     * @param start The starting position in the array.
+     * @param len The number of characters to write.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the characters, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#characters(char[], int, int)
+     */
+    public void characters (char ch[], int start, int len)
+        throws SAXException
+    {
+        try {
+            if (!startTagIsClosed) {
+                write('>');
+                startTagIsClosed = true;
+            }
+            if(inCDATA)
+                output.write(ch,start,len);
+            else
+                writeEsc(ch, start, len, false);
+            super.characters(ch, start, len);
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    /**
+     * Write ignorable whitespace.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param ch The array of characters to write.
+     * @param start The starting position in the array.
+     * @param length The number of characters to write.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the whitespace, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#ignorableWhitespace(char[], int, int)
+     */
+    public void ignorableWhitespace (char ch[], int start, int length)
+        throws SAXException
+    {
+        try {
+            writeEsc(ch, start, length, false);
+            super.ignorableWhitespace(ch, start, length);
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+
+    /**
+     * Write a processing instruction.
+     *
+     * Pass the event on down the filter chain for further processing.
+     *
+     * @param target The PI target.
+     * @param data The PI data.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the PI, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see org.xml.sax.ContentHandler#processingInstruction(java.lang.String, java.lang.String)
+     */
+    public void processingInstruction (String target, String data)
+        throws SAXException
+    {
+        try {
+            if (!startTagIsClosed) {
+                write('>');
+                startTagIsClosed = true;
+            }
+            write("<?");
+            write(target);
+            write(' ');
+            write(data);
+            write("?>");
+            if (elementLevel < 1) {
+                write('\n');
+            }
+            super.processingInstruction(target, data);
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Convenience methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+
+    /**
+     * Start a new element without a qname or attributes.
+     *
+     * <p>This method will provide a default empty attribute
+     * list and an empty string for the qualified name.
+     * It invokes {@link
+     * #startElement(String, String, String, Attributes)}
+     * directly.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the start tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     */
+    public void startElement (String uri, String localName)
+        throws SAXException
+    {
+        startElement(uri, localName, "", EMPTY_ATTS);
+    }
+
+
+    /**
+     * Start a new element without a qname, attributes or a Namespace URI.
+     *
+     * <p>This method will provide an empty string for the
+     * Namespace URI, and empty string for the qualified name,
+     * and a default empty attribute list. It invokes
+     * #startElement(String, String, String, Attributes)}
+     * directly.</p>
+     *
+     * @param localName The element's local name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the start tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     */
+    public void startElement (String localName)
+        throws SAXException
+    {
+        startElement("", localName, "", EMPTY_ATTS);
+    }
+
+
+    /**
+     * End an element without a qname.
+     *
+     * <p>This method will supply an empty string for the qName.
+     * It invokes {@link #endElement(String, String, String)}
+     * directly.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the end tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #endElement(String, String, String)
+     */
+    public void endElement (String uri, String localName)
+        throws SAXException
+    {
+        endElement(uri, localName, "");
+    }
+
+
+    /**
+     * End an element without a Namespace URI or qname.
+     *
+     * <p>This method will supply an empty string for the qName
+     * and an empty string for the Namespace URI.
+     * It invokes {@link #endElement(String, String, String)}
+     * directly.</p>
+     *
+     * @param localName The element's local name.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the end tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #endElement(String, String, String)
+     */
+    public void endElement (String localName)
+        throws SAXException
+    {
+        endElement("", localName, "");
+    }
+
+
+    /**
+     * Write an element with character data content.
+     *
+     * <p>This is a convenience method to write a complete element
+     * with character data content, including the start tag
+     * and end tag.</p>
+     *
+     * <p>This method invokes
+     * {@link #startElement(String, String, String, Attributes)},
+     * followed by
+     * {@link #characters(String)}, followed by
+     * {@link #endElement(String, String, String)}.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @param qName The element's default qualified name.
+     * @param atts The element's attributes.
+     * @param content The character data content.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the empty tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     * @see #characters(String)
+     * @see #endElement(String, String, String)
+     */
+    public void dataElement (String uri, String localName,
+                             String qName, Attributes atts,
+                             String content)
+        throws SAXException
+    {
+        startElement(uri, localName, qName, atts);
+        characters(content);
+        endElement(uri, localName, qName);
+    }
+
+
+    /**
+     * Write an element with character data content but no attributes.
+     *
+     * <p>This is a convenience method to write a complete element
+     * with character data content, including the start tag
+     * and end tag.  This method provides an empty string
+     * for the qname and an empty attribute list.</p>
+     *
+     * <p>This method invokes
+     * {@link #startElement(String, String, String, Attributes)},
+     * followed by
+     * {@link #characters(String)}, followed by
+     * {@link #endElement(String, String, String)}.</p>
+     *
+     * @param uri The element's Namespace URI.
+     * @param localName The element's local name.
+     * @param content The character data content.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the empty tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     * @see #characters(String)
+     * @see #endElement(String, String, String)
+     */
+    public void dataElement (String uri, String localName, String content)
+        throws SAXException
+    {
+        dataElement(uri, localName, "", EMPTY_ATTS, content);
+    }
+
+
+    /**
+     * Write an element with character data content but no attributes or Namespace URI.
+     *
+     * <p>This is a convenience method to write a complete element
+     * with character data content, including the start tag
+     * and end tag.  The method provides an empty string for the
+     * Namespace URI, and empty string for the qualified name,
+     * and an empty attribute list.</p>
+     *
+     * <p>This method invokes
+     * {@link #startElement(String, String, String, Attributes)},
+     * followed by
+     * {@link #characters(String)}, followed by
+     * {@link #endElement(String, String, String)}.</p>
+     *
+     * @param localName The element's local name.
+     * @param content The character data content.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the empty tag, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #startElement(String, String, String, Attributes)
+     * @see #characters(String)
+     * @see #endElement(String, String, String)
+     */
+    public void dataElement (String localName, String content)
+        throws SAXException
+    {
+        dataElement("", localName, "", EMPTY_ATTS, content);
+    }
+
+
+    /**
+     * Write a string of character data, with XML escaping.
+     *
+     * <p>This is a convenience method that takes an XML
+     * String, converts it to a character array, then invokes
+     * {@link #characters(char[], int, int)}.</p>
+     *
+     * @param data The character data.
+     * @exception org.xml.sax.SAXException If there is an error
+     *            writing the string, or if a handler further down
+     *            the filter chain raises an exception.
+     * @see #characters(char[], int, int)
+     */
+    public void characters (String data) throws SAXException {
+        try {
+            if (!startTagIsClosed) {
+                write('>');
+                startTagIsClosed = true;
+            }
+            char ch[] = data.toCharArray();
+            characters(ch, 0, ch.length);
+        } catch( IOException e ) {
+            throw new SAXException(e);
+        }
+    }
+
+
+    public void startDTD(String name, String publicId, String systemId) throws SAXException {
+    }
+
+    public void endDTD() throws SAXException {
+    }
+
+    public void startEntity(String name) throws SAXException {
+    }
+
+    public void endEntity(String name) throws SAXException {
+    }
+
+    public void startCDATA() throws SAXException {
+        try {
+            if (!startTagIsClosed) {
+                write('>');
+                startTagIsClosed = true;
+            }
+            write("<![CDATA[");
+            inCDATA = true;
+        } catch (IOException e) {
+            new SAXException(e);
+        }
+    }
+
+    public void endCDATA() throws SAXException {
+        try {
+            inCDATA = false;
+            write("]]>");
+        } catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+    public void comment(char ch[], int start, int length) throws SAXException {
+        try {
+            output.write("<!--");
+            output.write(ch,start,length);
+            output.write("-->");
+        } catch (IOException e) {
+            throw new SAXException(e);
+        }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+
+
+    /**
+     * Write a raw character.
+     *
+     * @param c The character to write.
+     */
+    private void write (char c) throws IOException {
+        output.write(c);
+    }
+
+
+    /**
+     * Write a raw string.
+     */
+    private void write (String s) throws IOException {
+        output.write(s);
+    }
+
+
+    /**
+     * Write out an attribute list, escaping values.
+     *
+     * The names will have prefixes added to them.
+     *
+     * @param atts The attribute list to write.
+     * @exception SAXException If there is an error writing
+     *            the attribute list, this method will throw an
+     *            IOException wrapped in a SAXException.
+     */
+    private void writeAttributes (Attributes atts) throws IOException, SAXException {
+        int len = atts.getLength();
+        for (int i = 0; i < len; i++) {
+            char ch[] = atts.getValue(i).toCharArray();
+            write(' ');
+            writeName(atts.getURI(i), atts.getLocalName(i),
+                      atts.getQName(i), false);
+            write("=\"");
+            writeEsc(ch, 0, ch.length, true);
+            write('"');
+        }
+    }
+
+
+    /**
+     * Write an array of data characters with escaping.
+     *
+     * @param ch The array of characters.
+     * @param start The starting position.
+     * @param length The number of characters to use.
+     * @param isAttVal true if this is an attribute value literal.
+     * @exception SAXException If there is an error writing
+     *            the characters, this method will throw an
+     *            IOException wrapped in a SAXException.
+     */
+    private void writeEsc (char ch[], int start,
+                             int length, boolean isAttVal)
+        throws SAXException, IOException
+    {
+        escapeHandler.escape(ch, start, length, isAttVal, output);
+    }
+
+
+    /**
+     * Write an element or attribute name.
+     *
+     * @param uri The Namespace URI.
+     * @param localName The local name.
+     * @param qName The prefixed name, if available, or the empty string.
+     * @param isElement true if this is an element name, false if it
+     *        is an attribute name.
+     */
+    private void writeName (String uri, String localName,
+                              String qName, boolean isElement)
+        throws IOException
+    {
+        write(qName);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constants.
+    ////////////////////////////////////////////////////////////////////
+
+    private final Attributes EMPTY_ATTS = new AttributesImpl();
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    private boolean inCDATA = false;
+    private int elementLevel = 0;
+    private Writer output;
+    private String encoding;
+    private boolean writeXmlDecl = true;
+    /**
+     * This string will be written right after the xml declaration
+     * without any escaping. Useful for generating a boiler-plate DOCTYPE decl
+     * , PIs, and comments.
+     */
+    private String header=null;
+
+    private final CharacterEscapeHandler escapeHandler;
+
+    private boolean startTagIsClosed = true;
+}
+
+// end of XMLWriter.java
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/XmlSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/XmlSerializer.java
new file mode 100644
index 0000000..644d443
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/XmlSerializer.java
@@ -0,0 +1,152 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.txw2.output;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+
+
+/**
+ * Low-level typeless XML writer driven from {@link TypedXmlWriter}.
+ *
+ * <p>
+ * Applications can use one of the predefined implementations to
+ * send TXW output to the desired location/format, or they can
+ * choose to implement this interface for custom output.
+ *
+ * <p>
+ * One {@link XmlSerializer} instance is responsible for writing
+ * one XML document.
+ *
+ * <h2>Call Sequence</h2>
+ * TXW calls methods on this interface in the following order:
+ *
+ * <pre>
+ * WHOLE_SEQUENCE := startDocument ELEMENT endDocument
+ * ELEMENT := beginStartTag writeXmlns* writeAttribute* endStartTag CONTENT endTag
+ * CONTENT := (text|ELEMENT)*
+ * </pre>
+ *
+ * <p>
+ * TXW maintains all the in-scope namespace bindings and prefix allocation.
+ * The {@link XmlSerializer} implementation should just use the prefix
+ * specified.
+ * </p>
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XmlSerializer {
+    /**
+     * The first method to be called.
+     */
+    void startDocument();
+
+    /**
+     * Begins writing a start tag.
+     *
+     * @param uri
+     *      the namespace URI of the element. Can be empty but never be null.
+     * @param prefix
+     *      the prefix that should be used for this element. Can be empty,
+     *      but never null.
+     */
+    void beginStartTag(String uri,String localName,String prefix);
+
+    /**
+     * Writes an attribute.
+     *
+     * @param value
+     *      The value of the attribute. It's the callee's responsibility to
+     *      escape special characters (such as &lt;, &gt;, and &amp;) in this buffer.
+     *
+     * @param uri
+     *      the namespace URI of the attribute. Can be empty but never be null.
+     * @param prefix
+     *      the prefix that should be used for this attribute. Can be empty,
+     *      but never null.
+     */
+    void writeAttribute(String uri,String localName,String prefix,StringBuilder value);
+
+    /**
+     * Writes a namespace declaration.
+     *
+     * @param uri
+     *      the namespace URI to be declared. Can be empty but never be null.
+     * @param prefix
+     *      the prefix that is allocated. Can be empty but never be null.
+     */
+    void writeXmlns(String prefix,String uri);
+
+    /**
+     * Completes the start tag.
+     *
+     * @param uri
+     *      the namespace URI of the element. Can be empty but never be null.
+     * @param prefix
+     *      the prefix that should be used for this element. Can be empty,
+     *      but never null.
+     */
+    void endStartTag(String uri,String localName,String prefix);
+
+    /**
+     * Writes an end tag.
+     */
+    void endTag();
+
+    /**
+     * Writes PCDATA.
+     *
+     * @param text
+     *      The character data to be written. It's the callee's responsibility to
+     *      escape special characters (such as &lt;, &gt;, and &amp;) in this buffer.
+     */
+    void text(StringBuilder text);
+
+    /**
+     * Writes CDATA.
+     */
+    void cdata(StringBuilder text);
+
+    /**
+     * Writes a comment.
+     *
+     * @throws UnsupportedOperationException
+     *      if the writer doesn't support writing a comment, it can throw this exception.
+     */
+    void comment(StringBuilder comment);
+
+    /**
+     * The last method to be called.
+     */
+    void endDocument();
+
+    /**
+     * Flush the buffer.
+     *
+     * This method is called when applications invoke {@link TypedXmlWriter#commit(boolean)}
+     * method. If the implementation performs any buffering, it should flush the buffer.
+     */
+    void flush();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/package.html b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/package.html
new file mode 100644
index 0000000..f6c3b6c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/output/package.html
@@ -0,0 +1,7 @@
+<html>
+<body>
+  <p>
+    Defines XmlSerializer and its built-in implementations.
+
+</body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/txw2/package.html b/jaxws/src/share/classes/com/sun/xml/internal/txw2/package.html
new file mode 100644
index 0000000..9340078
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/txw2/package.html
@@ -0,0 +1,7 @@
+<html>
+<body>
+  <p>
+    TXW runtime.
+
+</body>
+</html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/BindingImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/BindingImpl.java
new file mode 100644
index 0000000..a0104c1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/BindingImpl.java
@@ -0,0 +1,205 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.binding;
+
+import com.sun.xml.internal.ws.binding.http.HTTPBindingImpl;
+import com.sun.xml.internal.ws.binding.soap.SOAPBindingImpl;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.modeler.RuntimeModeler;
+import com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegate;
+
+import javax.xml.ws.Binding;
+import javax.xml.ws.handler.Handler;
+import java.util.ArrayList;
+import java.util.List;
+import javax.xml.ws.http.HTTPBinding;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.namespace.QName;
+
+/**
+ * Instances are created by the service, which then
+ * sets the handler chain on the binding impl. The handler
+ * caller class actually creates and manages the handlers.
+ *
+ * <p>Also used on the server side, where non-api calls such as
+ * getHandlerChainCaller cannot be used. So the binding impl
+ * now stores the handler list rather than deferring to the
+ * handler chain caller.
+ *
+ * <p>This class is made abstract as we dont see a situation when a BindingImpl has much meaning without binding id.
+ * IOw, for a specific binding there will be a class extending BindingImpl, for example SOAPBindingImpl.
+ *
+ * <p>The spi Binding interface extends Binding.
+ *
+ * @author WS Development Team
+ */
+public abstract class BindingImpl implements
+    com.sun.xml.internal.ws.spi.runtime.Binding {
+
+    // caller ignored on server side
+    protected HandlerChainCaller chainCaller;
+
+    private SystemHandlerDelegate systemHandlerDelegate;
+    private List<Handler> handlers;
+    private String bindingId;
+    protected QName serviceName;
+
+   // called by DispatchImpl
+    public BindingImpl(String bindingId, QName serviceName) {
+        this.bindingId = bindingId;
+        this.serviceName = serviceName;
+    }
+
+    public BindingImpl(List<Handler> handlerChain, String bindingId, QName serviceName) {
+        handlers = handlerChain;
+        this.bindingId = bindingId;
+        this.serviceName = serviceName;
+    }
+
+
+    /**
+     * Return a copy of the list. If there is a handler chain caller,
+     * this is the proper list. Otherwise, return a copy of 'handlers'
+     * or null if list is null. The RuntimeEndpointInfo.init() method
+     * relies on this list being null if there were no handlers
+     * in the deployment descriptor file.
+     *
+     * @return The list of handlers. This can be null if there are
+     * no handlers. The list may have a different order depending on
+     * whether or not the handlers have been called yet, since the
+     * logical and protocol handlers will be sorted before calling them.
+     *
+     * @see com.sun.xml.internal.ws.server.RuntimeEndpointInfo#init
+     */
+    public List<Handler> getHandlerChain() {
+        if (chainCaller != null) {
+            return new ArrayList(chainCaller.getHandlerChain());
+        }
+        if (handlers == null) {
+            return null;
+        }
+        return new ArrayList(handlers);
+    }
+
+    public boolean hasHandlers() {
+        if (handlers == null || handlers.size() == 0) {
+            return false;
+        }
+        return true;
+    }
+
+    /**
+     * Sets the handlers on the binding. If the handler chain
+     * caller already exists, then the handlers will be set on
+     * the caller and the handler chain held by the binding will
+     * be the sorted list.
+     */
+    public void setHandlerChain(List<Handler> chain) {
+        if (chainCaller != null) {
+            chainCaller = new HandlerChainCaller(chain);
+            handlers = chainCaller.getHandlerChain();
+        } else {
+            handlers = chain;
+        }
+    }
+
+    /**
+     * Creates the handler chain caller if needed and returns
+     * it. Once the handler chain caller exists, this class
+     * defers getHandlers() calls to it to get the new sorted
+     * list of handlers.
+     */
+    public HandlerChainCaller getHandlerChainCaller() {
+        if (chainCaller == null) {
+            chainCaller = new HandlerChainCaller(handlers);
+        }
+        return chainCaller;
+    }
+
+    public String getBindingId(){
+        return bindingId;
+    }
+
+    public String getActualBindingId() {
+        return bindingId;
+    }
+
+    public void setServiceName(QName serviceName){
+        this.serviceName = serviceName;
+    }
+
+    public SystemHandlerDelegate getSystemHandlerDelegate() {
+        return systemHandlerDelegate;
+    }
+
+    public void setSystemHandlerDelegate(SystemHandlerDelegate delegate) {
+        systemHandlerDelegate = delegate;
+    }
+
+    public static com.sun.xml.internal.ws.spi.runtime.Binding getBinding(String bindingId,
+                                                                Class implementorClass, QName serviceName, boolean tokensOK) {
+
+        if (bindingId == null) {
+            // Gets bindingId from @BindingType annotation
+            bindingId = RuntimeModeler.getBindingId(implementorClass);
+            if (bindingId == null) {            // Default one
+                bindingId = SOAPBinding.SOAP11HTTP_BINDING;
+            }
+        }
+        if (tokensOK) {
+            if (bindingId.equals("##SOAP11_HTTP")) {
+                bindingId = SOAPBinding.SOAP11HTTP_BINDING;
+            } else if (bindingId.equals("##SOAP11_HTTP_MTOM")) {
+                bindingId = SOAPBinding.SOAP11HTTP_MTOM_BINDING;
+            } else if (bindingId.equals("##SOAP12_HTTP")) {
+                bindingId = SOAPBinding.SOAP12HTTP_BINDING;
+            } else if (bindingId.equals("##SOAP12_HTTP_MTOM")) {
+                bindingId = SOAPBinding.SOAP12HTTP_MTOM_BINDING;
+            } else if (bindingId.equals("##XML_HTTP")) {
+                bindingId = HTTPBinding.HTTP_BINDING;
+            }
+        }
+        if (bindingId.equals(SOAPBinding.SOAP11HTTP_BINDING)
+            || bindingId.equals(SOAPBinding.SOAP11HTTP_MTOM_BINDING)
+            || bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING)
+            || bindingId.equals(SOAPBinding.SOAP12HTTP_MTOM_BINDING)
+            || bindingId.equals(SOAPBindingImpl.X_SOAP12HTTP_BINDING)) {
+            return new SOAPBindingImpl(bindingId, serviceName);
+        } else if (bindingId.equals(HTTPBinding.HTTP_BINDING)) {
+            return new HTTPBindingImpl();
+        } else {
+            throw new IllegalArgumentException("Wrong bindingId "+bindingId);
+        }
+    }
+
+    public static Binding getDefaultBinding() {
+        return new SOAPBindingImpl(SOAPBinding.SOAP11HTTP_BINDING);
+    }
+
+    public static Binding getDefaultBinding(QName serviceName) {
+        return new SOAPBindingImpl(SOAPBinding.SOAP11HTTP_BINDING, serviceName);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/http/HTTPBindingImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/http/HTTPBindingImpl.java
new file mode 100644
index 0000000..56a1870
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/http/HTTPBindingImpl.java
@@ -0,0 +1,73 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.binding.http;
+
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.handler.Handler;
+import javax.xml.ws.handler.LogicalHandler;
+import javax.xml.ws.http.HTTPBinding;
+
+import java.util.List;
+
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.xml.internal.ws.util.localization.Localizer;
+
+/**
+ * @author WS Development Team
+ */
+public class HTTPBindingImpl extends BindingImpl implements HTTPBinding {
+
+    public HTTPBindingImpl() {
+        super(HTTPBinding.HTTP_BINDING, null);
+    }
+
+    public HTTPBindingImpl(List<Handler> handlerChain) {
+        super(handlerChain, HTTPBinding.HTTP_BINDING, null);
+    }
+
+    /*
+     * Sets the handler chain. Only logical handlers are
+     * allowed with HTTPBinding.
+     */
+    @Override
+    public void setHandlerChain(List<Handler> chain) {
+        for (Handler handler : chain) {
+            if (!(handler instanceof LogicalHandler)) {
+                LocalizableMessageFactory messageFactory =
+                    new LocalizableMessageFactory(
+                    "com.sun.xml.internal.ws.resources.client");
+                Localizer localizer = new Localizer();
+                Localizable locMessage =
+                    messageFactory.getMessage("non.logical.handler.set",
+                    handler.getClass().toString());
+                throw new WebServiceException(localizer.localize(locMessage));
+            }
+        }
+        super.setHandlerChain(chain);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/soap/SOAPBindingImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/soap/SOAPBindingImpl.java
new file mode 100644
index 0000000..60cad69
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/binding/soap/SOAPBindingImpl.java
@@ -0,0 +1,226 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.binding.soap;
+
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegate;
+import com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegateFactory;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.xml.internal.ws.util.localization.Localizer;
+
+import javax.xml.soap.MessageFactory;
+import javax.xml.soap.SOAPFactory;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.handler.Handler;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.namespace.QName;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPBindingImpl extends BindingImpl implements SOAPBinding {
+
+
+    public static final String X_SOAP12HTTP_BINDING =
+        "http://java.sun.com/xml/ns/jaxws/2003/05/soap/bindings/HTTP/";
+
+    protected static String ROLE_NONE;
+
+    protected Set<String> requiredRoles;
+    protected Set<String> roles;
+    protected boolean enableMtom = false;
+
+
+     // called by DispatchImpl
+    public SOAPBindingImpl(String bindingId, QName serviceName) {
+        super(bindingId, serviceName);
+        setup(getBindingId(), getActualBindingId());
+        setupSystemHandlerDelegate(serviceName);
+    }
+
+     public SOAPBindingImpl(String bindingId) {
+        super(bindingId, null);
+        setup(getBindingId(), getActualBindingId());
+        setupSystemHandlerDelegate(null);
+    }
+
+    public SOAPBindingImpl(List<Handler> handlerChain, String bindingId, QName serviceName) {
+        super(handlerChain, bindingId, serviceName);
+        setup(getBindingId(), getActualBindingId());
+        setupSystemHandlerDelegate(serviceName);
+    }
+
+    // if the binding id is unknown, no roles are added
+    protected void setup(String bindingId, String actualBindingId) {
+        requiredRoles = new HashSet<String>();
+        if (bindingId.equals(SOAPBinding.SOAP11HTTP_BINDING)) {
+            requiredRoles.add(SOAPNamespaceConstants.ACTOR_NEXT);
+        } else if (bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING)) {
+            requiredRoles.add(SOAP12NamespaceConstants.ROLE_NEXT);
+            requiredRoles.add(SOAP12NamespaceConstants.ROLE_ULTIMATE_RECEIVER);
+        }
+        ROLE_NONE = SOAP12NamespaceConstants.ROLE_NONE;
+        roles = new HashSet<String>();
+        addRequiredRoles();
+        setRolesOnHandlerChain();
+        if (actualBindingId.equals(SOAP11HTTP_MTOM_BINDING)
+            || actualBindingId.equals(SOAP12HTTP_MTOM_BINDING)) {
+            setMTOMEnabled(true);
+        }
+    }
+
+    /**
+     * For a non standard SOAP1.2 binding, return actual SOAP1.2 binding
+     * For SOAP 1.1 MTOM binding, return SOAP1.1 binding
+     * For SOAP 1.2 MTOM binding, return SOAP 1.2 binding
+     */
+    @Override
+    public String getBindingId() {
+        String bindingId = super.getBindingId();
+        if (bindingId.equals(SOAPBindingImpl.X_SOAP12HTTP_BINDING)) {
+            return SOAP12HTTP_BINDING;
+        }
+        if (bindingId.equals(SOAPBinding.SOAP11HTTP_MTOM_BINDING)) {
+            return SOAP11HTTP_BINDING;
+        }
+        if (bindingId.equals(SOAPBinding.SOAP12HTTP_MTOM_BINDING)) {
+            return SOAP12HTTP_BINDING;
+        }
+        return bindingId;
+    }
+
+    /*
+    * Use this to distinguish SOAP12HTTP_BINDING or X_SOAP12HTTP_BINDING
+    */
+    @Override
+    public String getActualBindingId() {
+        return super.getBindingId();
+    }
+
+    /*
+     * When client sets a new handler chain, must also set roles on
+     * the new handler chain caller that gets created.
+     */
+    public void setHandlerChain(List<Handler> chain) {
+        super.setHandlerChain(chain);
+        setRolesOnHandlerChain();
+    }
+
+    protected void addRequiredRoles() {
+        roles.addAll(requiredRoles);
+    }
+
+    public java.util.Set<String> getRoles() {
+        return roles;
+    }
+
+    /*
+     * Adds the next and other roles in case this has
+     * been called by a user without them.
+     */
+    public void setRoles(Set<String> roles) {
+        if (roles == null) {
+            roles = new HashSet<String>();
+        }
+        if (roles.contains(ROLE_NONE)) {
+            LocalizableMessageFactory messageFactory =
+                new LocalizableMessageFactory("com.sun.xml.internal.ws.resources.client");
+            Localizer localizer = new Localizer();
+            Localizable locMessage =
+                messageFactory.getMessage("invalid.soap.role.none");
+            throw new WebServiceException(localizer.localize(locMessage));
+        }
+        this.roles = roles;
+        addRequiredRoles();
+        setRolesOnHandlerChain();
+    }
+
+
+    /**
+     * Used typically by the runtime to enable/disable Mtom optimization
+     *
+     * @return true or false
+     */
+    public boolean isMTOMEnabled() {
+        return enableMtom;
+    }
+
+    /**
+     * Client application can set if the Mtom optimization should be enabled
+     *
+     * @param b
+     */
+    public void setMTOMEnabled(boolean b) {
+        this.enableMtom = b;
+    }
+
+    public SOAPFactory getSOAPFactory() {
+        return SOAPUtil.getSOAPFactory(getBindingId());
+    }
+
+
+    public MessageFactory getMessageFactory() {
+        return SOAPUtil.getMessageFactory(getBindingId());
+    }
+
+    /**
+     * This call defers to the super class to get the
+     * handler chain caller. It then sets the roles on the
+     * caller before returning it.
+     *
+     * @see com.sun.xml.internal.ws.binding.BindingImpl#getHandlerChainCaller
+     */
+    public HandlerChainCaller getHandlerChainCaller() {
+        HandlerChainCaller caller = super.getHandlerChainCaller();
+        caller.setRoles(roles);
+        return chainCaller;
+    }
+
+    protected void setRolesOnHandlerChain() {
+        if (chainCaller != null) {
+            chainCaller.setRoles(roles);
+        }
+    }
+
+    protected void setupSystemHandlerDelegate(QName serviceName) {
+        SystemHandlerDelegateFactory shdFactory =
+            SystemHandlerDelegateFactory.getFactory();
+        if (shdFactory != null) {
+            setSystemHandlerDelegate((SystemHandlerDelegate)
+                shdFactory.getDelegate(serviceName));
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/AsyncHandlerService.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/AsyncHandlerService.java
new file mode 100644
index 0000000..6ccc0ab
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/AsyncHandlerService.java
@@ -0,0 +1,68 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import javax.xml.ws.AsyncHandler;
+import javax.xml.ws.Response;
+import java.rmi.server.UID;
+import java.util.concurrent.Callable;
+import java.util.concurrent.Executor;
+
+public class AsyncHandlerService {
+
+    private AsyncHandler _handler;
+    private UID _uid;
+    private Executor _executor;
+    private WSFuture wsfuture;
+    private Response response;
+
+    public AsyncHandlerService(AsyncHandler handler, Executor executor) {
+        _uid = new UID();
+        _handler = handler;
+        _executor = executor;
+    }
+
+    public synchronized UID getUID() {
+        return _uid;
+    }
+
+    public void executeWSFuture() {
+
+        _executor.execute((Runnable) wsfuture);
+    }
+
+    public WSFuture<Object> setupAsyncCallback(final Response<Object> result) {
+        response = result;
+
+        wsfuture = new WSFuture<Object>(new Callable<Object>() {
+
+            public Object call() throws Exception {
+                _handler.handleResponse(response);
+                return null;
+            }
+        });
+        return wsfuture;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/BindingProviderProperties.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/BindingProviderProperties.java
new file mode 100644
index 0000000..0ea2574
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/BindingProviderProperties.java
@@ -0,0 +1,132 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.developer.JAXWSProperties;
+
+public interface BindingProviderProperties extends JAXWSProperties{
+
+    //legacy properties
+    public static final String SERVICEIMPL_NAME = "serviceImplementationName";
+    public static final String HOSTNAME_VERIFICATION_PROPERTY =
+        "com.sun.xml.internal.ws.client.http.HostnameVerificationProperty";
+    public static final String HTTP_COOKIE_JAR =
+        "com.sun.xml.internal.ws.client.http.CookieJar";
+    public static final String SECURITY_CONTEXT =
+        "com.sun.xml.internal.ws.security.context";
+    public static final String HTTP_STATUS_CODE =
+        "com.sun.xml.internal.ws.client.http.HTTPStatusCode";
+
+    public static final String REDIRECT_REQUEST_PROPERTY =
+        "com.sun.xml.internal.ws.client.http.RedirectRequestProperty";
+    public static final String SET_ATTACHMENT_PROPERTY =
+        "com.sun.xml.internal.ws.attachment.SetAttachmentContext";
+    public static final String GET_ATTACHMENT_PROPERTY =
+        "com.sun.xml.internal.ws.attachment.GetAttachmentContext";
+    public static final String ONE_WAY_OPERATION =
+        "com.sun.xml.internal.ws.server.OneWayOperation";
+
+
+    // Proprietary
+    public static final String REQUEST_TIMEOUT =
+        "com.sun.xml.internal.ws.request.timeout";
+
+    //JAXWS 2.0
+    public static final String JAXWS_RUNTIME_CONTEXT =
+        "com.sun.xml.internal.ws.runtime.context";
+    public static final String JAXWS_CONTEXT_PROPERTY =
+        "com.sun.xml.internal.ws.context.request";
+    public static final String JAXWS_HANDLER_CONTEXT_PROPERTY =
+        "com.sun.xml.internal.ws.handler.context";
+    public static final String JAXWS_RESPONSE_CONTEXT_PROPERTY =
+        "com.sun.xml.internal.ws.context.response";
+    public static final String JAXWS_CLIENT_ASYNC_HANDLER =
+        "com.sun.xml.internal.ws.client.dispatch.asynchandler";
+    public static final String JAXWS_CLIENT_ASYNC_RESPONSE_CONTEXT =
+        "com.sun.xml.internal.ws.client.dispatch.async.response.context";
+    public static final String JAXWS_CLIENT_HANDLE_PROPERTY =
+        "com.sun.xml.internal.ws.client.handle";
+    public static final String JAXB_CONTEXT_PROPERTY =
+        "com.sun.xml.internal.ws.jaxbcontext";
+
+    public static final String CLIENT_TRANSPORT_FACTORY =
+        "com.sun.xml.internal.ws.client.ClientTransportFactory";
+
+    public static final String JAXB_OUTPUTSTREAM =
+        "com.sun.xml.internal.bind.api.Bridge.outputStream";
+
+    public static final String XML_ENCODING_VALUE = "xml.encoding";                 // deprecated
+    public static final String ACCEPT_ENCODING_PROPERTY = "accept.encoding";
+
+    public static final String CONTENT_TYPE_PROPERTY = "Content-Type";
+    public static final String SOAP_ACTION_PROPERTY = "SOAPAction";
+    public static final String ACCEPT_PROPERTY = "Accept";
+
+    // FI + SOAP 1.1
+    public static final String FAST_INFOSET_TYPE_SOAP11 =
+        "application/fastinfoset";
+
+    // FI + SOAP 1.2
+    public static final String FAST_INFOSET_TYPE_SOAP12 =
+        "application/soap+fastinfoset";
+
+    // XML + XOP + SOAP 1.1
+    public static final String XOP_SOAP11_XML_TYPE_VALUE =
+        "application/xop+xml;type=\"text/xml\"";
+
+    // XML + XOP + SOAP 1.2
+    public static final String XOP_SOAP12_XML_TYPE_VALUE =
+        "application/xop+xml;type=\"application/soap+xml\"";
+
+    public static final String XML_CONTENT_TYPE_VALUE = "text/xml";
+
+    public static final String SOAP12_XML_CONTENT_TYPE_VALUE = "application/soap+xml";
+
+    public static final String STANDARD_ACCEPT_VALUE =
+        "application/xop+xml, text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2";
+
+    public static final String SOAP12_XML_ACCEPT_VALUE =
+        "application/soap+xml" + ", " + STANDARD_ACCEPT_VALUE;
+
+    public static final String XML_ACCEPT_VALUE =
+        XML_CONTENT_TYPE_VALUE + ", " + STANDARD_ACCEPT_VALUE;
+
+    public static final String XML_FI_ACCEPT_VALUE =
+        FAST_INFOSET_TYPE_SOAP11 + ", " + XML_ACCEPT_VALUE;
+
+    public static final String SOAP12_XML_FI_ACCEPT_VALUE =
+        FAST_INFOSET_TYPE_SOAP12 + ", " + SOAP12_XML_ACCEPT_VALUE;
+
+    public String DISPATCH_CONTEXT = "com.sun.xml.internal.ws.client.dispatch.context";
+    public String DISPATCH_MARSHALLER = "com.sun.xml.internal.ws.client.dispatch.marshaller";
+    public String DISPATCH_UNMARSHALLER = "com.sun.xml.internal.ws.client.dispatch.unmarshaller";
+    public static final String BINDING_ID_PROPERTY = "com.sun.xml.internal.ws.binding";
+
+//    // Content negotiation property: values "none", "pessimistic" and "optimistic"
+//    public static final String CONTENT_NEGOTIATION_PROPERTY =
+//        "com.sun.xml.internal.ws.client.ContentNegotiation";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ClientConfigurationException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ClientConfigurationException.java
new file mode 100644
index 0000000..4cb0a39
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ClientConfigurationException.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+
+/**
+ * @author Vivek Pandey
+ */
+public class ClientConfigurationException extends JAXWSExceptionBase {
+    public ClientConfigurationException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ClientConfigurationException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.client";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ClientTransportException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ClientTransportException.java
new file mode 100644
index 0000000..56e8b57
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ClientTransportException.java
@@ -0,0 +1,46 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+
+/**
+ * @author WS Development Team
+ */
+public class ClientTransportException extends JAXWSExceptionBase {
+    public ClientTransportException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ClientTransportException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.client";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoBase.java
new file mode 100644
index 0000000..e78d350
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoBase.java
@@ -0,0 +1,136 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.ept.ContactInfo;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.TargetFinder;
+import com.sun.xml.internal.ws.pept.protocol.Interceptors;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.soap.ClientEncoderDecoder;
+import com.sun.xml.internal.ws.encoding.soap.SOAPDecoder;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+
+import javax.xml.ws.soap.SOAPBinding;
+
+
+/**
+ * @author WS Development Team
+ */
+public class ContactInfoBase implements ContactInfo, SOAPEPTFactory {
+    protected WSConnection _connection;
+    protected MessageDispatcher _messageDispatcher;
+    protected Encoder _encoder;
+    protected Decoder _decoder;
+    private String bindingId;
+    private InternalEncoder internalEncoder;
+
+    public ContactInfoBase(WSConnection connection,
+                           MessageDispatcher messageDispatcher, Encoder encoder, Decoder decoder,
+                           String bindingId) {
+        _connection = connection;
+        _messageDispatcher = messageDispatcher;
+        _encoder = encoder;
+        _decoder = decoder;
+        internalEncoder = new ClientEncoderDecoder();
+        this.bindingId = bindingId;
+    }
+
+    public ContactInfoBase() {
+        _connection = null;
+        _messageDispatcher = null;
+        _encoder = null;
+        _decoder = null;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.ept.ContactInfo#getConnection(com.sun.pept.ept.MessageInfo)
+     */
+    public WSConnection getConnection(MessageInfo arg0) {
+        return _connection;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.ept.EPTFactory#getMessageDispatcher(com.sun.pept.ept.MessageInfo)
+     */
+    public MessageDispatcher getMessageDispatcher(MessageInfo arg0) {
+        return _messageDispatcher;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.ept.EPTFactory#getEncoder(com.sun.pept.ept.MessageInfo)
+     */
+    public Encoder getEncoder(MessageInfo arg0) {
+        return _encoder;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.ept.EPTFactory#getDecoder(com.sun.pept.ept.MessageInfo)
+     */
+    public Decoder getDecoder(MessageInfo arg0) {
+        return _decoder;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.ept.EPTFactory#getInterceptors(com.sun.pept.ept.MessageInfo)
+     */
+    public Interceptors getInterceptors(MessageInfo arg0) {
+        // TODO Auto-generated method stub
+        return null;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.ept.EPTFactory#getTargetFinder(com.sun.pept.ept.MessageInfo)
+     */
+    public TargetFinder getTargetFinder(MessageInfo arg0) {
+        // TODO Auto-generated method stub
+        return null;
+    }
+
+    public SOAPEncoder getSOAPEncoder() {
+        return (SOAPEncoder) _encoder;
+    }
+
+    public SOAPDecoder getSOAPDecoder() {
+        return (SOAPDecoder) _decoder;
+    }
+
+    public InternalEncoder getInternalEncoder() {
+        return internalEncoder;
+    }
+
+    public String getBindingId() {
+        if (bindingId == null) {
+            return SOAPBinding.SOAP11HTTP_BINDING;
+        }
+
+        return bindingId;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoListImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoListImpl.java
new file mode 100644
index 0000000..4f2e5b2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoListImpl.java
@@ -0,0 +1,64 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.pept.ept.ContactInfoList;
+import com.sun.xml.internal.ws.pept.ept.ContactInfoListIterator;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAP12XMLDecoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAP12XMLEncoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLDecoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLEncoder;
+import com.sun.xml.internal.ws.protocol.soap.client.SOAPMessageDispatcher;
+import com.sun.xml.internal.ws.protocol.xml.client.XMLMessageDispatcher;
+
+import javax.xml.ws.soap.SOAPBinding;
+import java.util.ArrayList;
+
+/**
+ * @author WS Development Team
+ * List of {@link com.sun.pept.ept.ContactInfo}s
+ */
+public class ContactInfoListImpl implements ContactInfoList {
+    private static final ArrayList arrayList = new ArrayList();
+    static {
+        arrayList.add(new ContactInfoBase(null,
+            new SOAPMessageDispatcher(),
+            new SOAPXMLEncoder(),
+            new SOAPXMLDecoder(), SOAPBinding.SOAP11HTTP_BINDING));
+        arrayList.add(new ContactInfoBase(null,
+            new SOAPMessageDispatcher(),
+            new SOAP12XMLEncoder(),
+            new SOAP12XMLDecoder(), SOAPBinding.SOAP12HTTP_BINDING));
+    }
+
+    /**
+     * Iterator over the list of {@link com.sun.pept.ept.ContactInfo}s
+     * @see com.sun.pept.ept.ContactInfoList#iterator()
+     */
+    public ContactInfoListIterator iterator() {
+        return new ContactInfoListIteratorBase(arrayList);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoListIteratorBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoListIteratorBase.java
new file mode 100644
index 0000000..e31f563
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContactInfoListIteratorBase.java
@@ -0,0 +1,54 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.pept.ept.ContactInfo;
+import com.sun.xml.internal.ws.pept.ept.ContactInfoListIterator;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+
+
+/**
+ * @author WS Development Team
+ */
+public class ContactInfoListIteratorBase implements ContactInfoListIterator {
+    private Iterator iterator;
+
+    public ContactInfoListIteratorBase(ArrayList list) {
+        iterator = list.iterator();
+    }
+
+    public ContactInfo next() {
+        return (ContactInfo) iterator.next();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.ept.ContactInfoListIterator#hasNext()
+     */
+    public boolean hasNext() {
+        return iterator.hasNext();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContentNegotiation.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContentNegotiation.java
new file mode 100644
index 0000000..da96a77
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContentNegotiation.java
@@ -0,0 +1,70 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.CONTENT_NEGOTIATION_PROPERTY;
+
+import java.util.Map;
+
+public class ContentNegotiation {
+
+    /**
+     * Initializes content negotiation property in <code>MessageStruct</code>
+     * based on request context and system properties.
+     */
+    static public void initialize(Map context, MessageStruct messageStruct) {
+        String value = (String) context.get(CONTENT_NEGOTIATION_PROPERTY);
+        if (value != null) {
+            if (value.equals("none") || value.equals("pessimistic") || value.equals("optimistic")) {
+                messageStruct.setMetaData(CONTENT_NEGOTIATION_PROPERTY, value.intern());
+            } else {
+                throw new SenderException("sender.request.illegalValueForContentNegotiation", value);
+            }
+        } else {
+            initFromSystemProperties(context, messageStruct);
+        }
+    }
+
+    /**
+     * Initializes content negotiation property in <code>MessageStruct</code>
+     * based on system property of the same name.
+     */
+    static public void initFromSystemProperties(Map context, MessageStruct messageStruct)
+        throws SenderException {
+        String value = System.getProperty(CONTENT_NEGOTIATION_PROPERTY);
+
+        if (value == null) {
+            messageStruct.setMetaData(
+                CONTENT_NEGOTIATION_PROPERTY, "none");      // FI is off by default
+        } else if (value.equals("none") || value.equals("pessimistic") || value.equals("optimistic")) {
+            messageStruct.setMetaData(CONTENT_NEGOTIATION_PROPERTY, value.intern());
+            context.put(CONTENT_NEGOTIATION_PROPERTY, value.intern());
+        } else {
+            throw new SenderException("sender.request.illegalValueForContentNegotiation", value);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContextMap.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContextMap.java
new file mode 100644
index 0000000..107e507
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ContextMap.java
@@ -0,0 +1,248 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.ws.BindingProvider;
+import static javax.xml.ws.BindingProvider.*;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.handler.MessageContext;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Set;
+
+public abstract class ContextMap extends HashMap<String,Object>
+    implements BindingProviderProperties {
+
+    /**
+     * Read-only list of known properties.
+     */
+    private static final Set<String> KNOWN_PROPERTIES;
+
+    private static final HashMap<String,Class> _allowedClass = new HashMap<String, Class>();
+
+    protected BindingProvider _owner;
+    protected PortInfoBase portInfo;
+
+    public abstract ContextMap copy();
+
+    static {
+        //JAXWS 2.0 defined
+        _allowedClass.put(USERNAME_PROPERTY, java.lang.String.class);
+        _allowedClass.put(PASSWORD_PROPERTY, java.lang.String.class);
+        _allowedClass.put(ENDPOINT_ADDRESS_PROPERTY, java.lang.String.class);
+        _allowedClass.put(SESSION_MAINTAIN_PROPERTY, java.lang.Boolean.class);
+        _allowedClass.put(SOAPACTION_USE_PROPERTY, java.lang.Boolean.class);
+        _allowedClass.put(SOAPACTION_URI_PROPERTY, java.lang.String.class);
+
+        //now defined in jaxwscontext
+        _allowedClass.put(BindingProviderProperties.JAXB_CONTEXT_PROPERTY, JAXBContext.class);
+
+        Set<String> temp = new HashSet<String>();
+        //JAXWS 2.0 defined
+        temp.add(USERNAME_PROPERTY);
+        temp.add(PASSWORD_PROPERTY);
+        temp.add(ENDPOINT_ADDRESS_PROPERTY);
+        temp.add(SESSION_MAINTAIN_PROPERTY);
+        temp.add(SOAPACTION_USE_PROPERTY);
+        temp.add(SOAPACTION_URI_PROPERTY);
+
+        temp.add(BindingProviderProperties.JAXB_CONTEXT_PROPERTY);
+        //implementation specific
+        temp.add(BindingProviderProperties.ACCEPT_ENCODING_PROPERTY);
+        temp.add(BindingProviderProperties.CLIENT_TRANSPORT_FACTORY);
+        //used to get stub in runtime for handler chain
+        temp.add(BindingProviderProperties.JAXWS_CLIENT_HANDLE_PROPERTY);
+        temp.add(BindingProviderProperties.JAXWS_CLIENT_HANDLE_PROPERTY);
+
+        //JAXRPC 1.0 - 1.1 DEFINED - implementation specific
+        temp.add(BindingProviderProperties.HTTP_COOKIE_JAR);
+        temp.add(BindingProviderProperties.ONE_WAY_OPERATION);
+        temp.add(BindingProviderProperties.HTTP_STATUS_CODE);
+        temp.add(BindingProviderProperties.HOSTNAME_VERIFICATION_PROPERTY);
+        temp.add(BindingProviderProperties.REDIRECT_REQUEST_PROPERTY);
+        temp.add(BindingProviderProperties.SECURITY_CONTEXT);
+        temp.add(BindingProviderProperties.SET_ATTACHMENT_PROPERTY);
+        temp.add(BindingProviderProperties.GET_ATTACHMENT_PROPERTY);
+        //Tod:check with mark regarding property modification
+        //KNOWN_PROPERTIES = Collections.unmodifiableSet(temp);
+
+        temp.add(MessageContext.INBOUND_MESSAGE_ATTACHMENTS);
+        temp.add(MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS);
+        temp.add(MessageContext.WSDL_DESCRIPTION);
+        temp.add(MessageContext.WSDL_INTERFACE);
+        temp.add(MessageContext.WSDL_OPERATION);
+        temp.add(MessageContext.WSDL_PORT);
+        temp.add(MessageContext.WSDL_SERVICE);
+        temp.add(MessageContext.HTTP_REQUEST_METHOD);
+        temp.add(MessageContext.HTTP_REQUEST_HEADERS);
+        temp.add(MessageContext.HTTP_RESPONSE_CODE);
+        temp.add(MessageContext.HTTP_RESPONSE_HEADERS);
+        temp.add(MessageContext.PATH_INFO);
+        temp.add(MessageContext.QUERY_STRING);
+        // Content negotiation property for FI -- "none", "pessimistic", "optimistic"
+        temp.add(BindingProviderProperties.CONTENT_NEGOTIATION_PROPERTY);
+        temp.add(BindingProviderProperties.MTOM_THRESHOLOD_VALUE);
+        KNOWN_PROPERTIES = temp;
+    }
+
+    //used for dispatch
+    public ContextMap(PortInfoBase info, BindingProvider provider) {
+        _owner = provider;
+        if (info != null) {
+            this.portInfo = info;
+        }
+    }
+
+    /**
+     * Copy constructor.
+     */
+    public ContextMap(ContextMap original) {
+        super(original);
+        this._owner = original._owner;
+    }
+
+    //may not need this
+    public ContextMap(BindingProvider owner) {
+        this(null, owner);
+    }
+
+    boolean doValidation() {
+        return _owner != null;
+    }
+
+    public Object put(String name, Object value) {
+        if (doValidation()) {
+            validateProperty(name, value, true);
+            return super.put(name, value);
+        }
+        return null;
+    }
+
+    public Object get(String name) {
+        if (doValidation()) {
+            validateProperty(name, null, false);
+            return super.get(name);
+        }
+        return null;
+    }
+
+    public Iterator<String> getPropertyNames() {
+        return keySet().iterator();
+    }
+
+
+    public Object remove(String name) {
+        if (doValidation()) {
+            validateProperty(name, null, false);
+            return super.remove(name);
+        }
+        return null;
+    }
+
+    private boolean isAllowedValue(String name, Object value) {
+        if ( name.equals(MessageContext.PATH_INFO) ||
+            name.equals(MessageContext.QUERY_STRING))
+                return true;
+
+        if (value == null)
+            return false;
+
+        return true;
+    }
+// no value check needed today
+//        Object[] values = _allowedValues.get(name);
+//        if (values != null) {
+//            boolean allowed = false;
+//            for (Object o : values) {
+//                if (STRING_CLASS.isInstance(o) && (STRING_CLASS.isInstance(value))) {
+//                    if (((java.lang.String) o).equalsIgnoreCase((java.lang.String) value)) {
+//                        allowed = true;
+//                        break;
+//                    }
+//                } else if (BOOLEAN_CLASS.isInstance(o) && (BOOLEAN_CLASS.isInstance(value))) {
+//                    if (Boolean.FALSE.equals(o) || Boolean.TRUE.equals(o)) {
+//                        allowed = true;
+//                        break;
+//                    }
+//                } else {
+//                    //log this
+//                }
+//            }
+//            return allowed;
+//        }
+
+
+
+    private boolean isAllowedClass(String propName, Object value) {
+
+        Class allowedClass = _allowedClass.get(propName);
+        if (allowedClass != null) {
+            return allowedClass.isInstance(value);
+        }
+        return true;
+    }
+
+    private void validateProperty(String name, Object value, boolean isSetter) {
+        if (name == null)
+            throw new WebServiceException(name + " is a User-defined property - property name can not be null. ",
+                new IllegalArgumentException("Name of property is null.  This is an invalid property name. "));
+
+        /* Spec clarifies that this check is not needed.
+        if (!KNOWN_PROPERTIES.contains(name)) {
+            //do validation check on not "javax.xml.ws."
+            if (name.startsWith("javax.xml.ws"))
+                throw new WebServiceException(name + " is a User-defined property - can not start with javax.xml.ws. package",
+                    new IllegalArgumentException("can not start with javax.xml.ws. package"));                                            //let's check the propertyContext
+        }
+        */
+        //is it alreadySet
+        //Object currentPropValue = get(name);
+        //if (currentPropValue != null) {
+        //  if (!isDynamic(name))
+        //      throw new WebServiceException("Property bound to Binding Instance",
+        //          new IllegalArgumentException("Cannot overwrite the Static Property"));
+        //}
+
+        if (isSetter) {
+            if (!isAllowedClass(name, value))
+                throw new WebServiceException(value + " is Not Allowed Class for property " + name,
+                    new IllegalArgumentException("Not Allowed Class for property"));
+
+            if (!isAllowedValue(name, value))
+                throw new WebServiceException(value + " is Not Allowed Value for property " + name,
+                    new IllegalArgumentException("Not Allowed value"));
+        }
+
+    }
+
+ //currently not used
+ /*   public static enum StyleAndUse {
+        RPC_LITERAL,
+        DOCLIT_WRAPPER_STYLE, DOCLIT_NONWRAPPER_STYLE
+    }
+*/
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFBase.java
new file mode 100644
index 0000000..2113917
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFBase.java
@@ -0,0 +1,137 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.pept.Delegate;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.spi.runtime.ClientTransportFactory;
+import com.sun.xml.internal.ws.transport.http.client.HttpClientTransportFactory;
+
+import javax.xml.ws.Binding;
+import javax.xml.ws.BindingProvider;
+
+import java.util.Map;
+
+/**
+ * @author WS Development Team
+ */
+public class EndpointIFBase implements com.sun.xml.internal.ws.pept.presentation.Stub,
+    com.sun.xml.internal.ws.spi.runtime.StubBase, BindingProvider, InternalBindingProvider {
+
+    protected Map<String, Object> _requestContext;
+    protected Map<String, Object> _responseContext;
+
+    protected String _bindingId = null;
+    protected Delegate _delegate = null;
+    protected BindingImpl binding;
+
+    private ClientTransportFactory _transportFactory;
+
+    void setResponseContext(ResponseContext context) {
+        _responseContext = context;
+    }
+
+    public void _setDelegate(Delegate delegate) {
+        _delegate = delegate;
+    }
+
+    public Delegate _getDelegate() {
+        return _delegate;
+    }
+
+    public ClientTransportFactory _getTransportFactory() {
+        _transportFactory =
+            (com.sun.xml.internal.ws.spi.runtime.ClientTransportFactory)getRequestContext().get(BindingProviderProperties.CLIENT_TRANSPORT_FACTORY);
+
+        if (_transportFactory == null) {
+            _transportFactory = new HttpClientTransportFactory();
+        }
+        return _transportFactory;
+    }
+
+    public void _setTransportFactory(ClientTransportFactory f) {
+        getRequestContext().put(BindingProviderProperties.CLIENT_TRANSPORT_FACTORY, f);
+        _transportFactory = f;
+    }
+
+    //toDo: have to update generator on PeptStub to getContext
+    public void updateResponseContext(MessageInfo messageInfo) {
+        ResponseContext responseContext = (ResponseContext)
+            messageInfo.getMetaData(BindingProviderProperties.JAXWS_RESPONSE_CONTEXT_PROPERTY);
+        if (responseContext != null) { // null in async case
+            setResponseContext(responseContext);
+        }
+    }
+
+    /**
+     * Get the JAXWSContext that is used in processing request messages.
+     * <p/>
+     * Modifications to the request context do not affect asynchronous
+     * operations that have already been started.
+     *
+     * @return The JAXWSContext that is used in processing request messages.
+     */
+    public Map<String, Object> getRequestContext() {
+        if (_requestContext == null)
+            _requestContext = new RequestContext(this);
+
+        return _requestContext;
+    }
+
+    /**
+     * Get the JAXWSContext that resulted from processing a response message.
+     * <p/>
+     * The returned context is for the most recently completed synchronous
+     * operation. Subsequent synchronous operation invocations overwrite the
+     * response context. Asynchronous operations return their response context
+     * via the Response interface.
+     *
+     * @return The JAXWSContext that is used in processing request messages.
+     */
+    public Map<String, Object> getResponseContext() {
+        if (_responseContext == null)
+            _responseContext = new ResponseContext(this);
+        return _responseContext;
+    }
+
+    public Binding getBinding() {
+        return binding;
+    }
+
+    public void _setBinding(BindingImpl binding) {
+        this.binding = binding;
+    }
+
+    /**
+     * returns binding id from BindingImpl
+     *
+     * @return the String representing the BindingID
+     */
+    public String _getBindingId() {
+        return _bindingId;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFContext.java
new file mode 100644
index 0000000..30b7cc8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFContext.java
@@ -0,0 +1,123 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.server.RuntimeContext;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.handler.Handler;
+
+import java.util.ArrayList;
+import java.util.List;
+
+
+/**
+ * $author: WS Development Team
+ */
+public class EndpointIFContext {
+
+    private RuntimeContext runtimeContext; //from annotationPro ess
+    private Class serviceInterface;    //prop can take out
+    private QName serviceName;
+    private Class sei;
+    private QName portName;
+    private ArrayList<Handler> handlers;
+    private String endpointAddress;
+    private String bindingId;
+
+
+    public EndpointIFContext(Class sei) {
+        this.sei = sei;
+        handlers = new ArrayList();
+    }
+
+    public RuntimeContext getRuntimeContext() {
+        return runtimeContext;
+    }
+
+    public void setRuntimeContext(RuntimeContext runtimeContext) {
+        this.runtimeContext = runtimeContext;
+    }
+
+    public Class getServiceInterface() {
+        return serviceInterface;
+    }
+
+    public void setServiceInterface(Class serviceInterface) {
+        this.serviceInterface = serviceInterface;
+    }
+
+    public Class getSei() {
+        return sei;
+    }
+
+    public void setSei(Class sei) {
+        this.sei = sei;
+    }
+
+    public QName getPortName() {
+        if (portName == null){
+        if ((runtimeContext != null) && (runtimeContext.getModel() != null))
+            portName = runtimeContext.getModel().getPortName();
+        }
+        return portName;
+    }
+
+    public String getEndpointAddress() {
+        return endpointAddress;
+    }
+
+    public void setPortInfo(QName portQName, String endpoint, String bindingID) {
+        portName = portQName;
+        endpointAddress = endpoint;
+        this.bindingId = bindingID;
+    }
+
+    public String getBindingID() {
+        return bindingId;
+    }
+
+    public QName getServiceName() {
+        return serviceName;
+    }
+
+    public boolean contains(QName serviceName) {
+        if (serviceName.equals(this.serviceName))
+            return true;
+        return false;
+    }
+
+    public void setServiceName(QName serviceName) {
+        this.serviceName = serviceName;
+    }
+
+    public void setPortName(QName portName) {
+        this.portName = portName;
+    }
+
+    public void setBindingID(String bindingId) {
+        this.bindingId = bindingId;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFInvocationHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFInvocationHandler.java
new file mode 100644
index 0000000..f4480bc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/EndpointIFInvocationHandler.java
@@ -0,0 +1,215 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.encoding.soap.internal.DelegateBase;
+import com.sun.xml.internal.ws.model.JavaMethod;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.wsdl.WSDLContext;
+import com.sun.xml.internal.ws.wsdl.parser.PortType;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.AsyncHandler;
+import javax.xml.ws.BindingProvider;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.Service;
+import java.lang.reflect.InvocationHandler;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.net.URL;
+import java.util.concurrent.Executor;
+
+public class EndpointIFInvocationHandler
+    extends EndpointIFBase
+    implements InvocationHandler, com.sun.xml.internal.ws.client.BindingProviderProperties {
+
+    Object _proxy;
+    DelegateBase _delegate;
+
+    EndpointIFContext _endpointContext;
+
+    Class _portInterface;
+    QName _serviceQName;
+
+    RuntimeContext _rtcontext;
+    WSDLContext _wsdlContext;
+    boolean failure;
+    URL wsdlDocumentLocation;
+    WSServiceDelegate _service;
+
+    /**
+     * public constructor
+     */
+
+    public EndpointIFInvocationHandler(Class portInterface, EndpointIFContext eif, WSServiceDelegate service, QName serviceName) {
+
+        if ((eif.getBindingID() == null) || (eif.getRuntimeContext() == null)) {
+            failure = true;
+            return;
+        }
+        _endpointContext = eif;
+        _portInterface = portInterface;
+        _rtcontext = eif.getRuntimeContext();
+        _bindingId = eif.getBindingID();
+        _service = service;
+
+        if (serviceName != null) {
+            if (eif.contains(serviceName))
+                _serviceQName = serviceName;
+            else
+                throw new WebServiceException("Supplied service QName " +
+                    serviceName + " does not exist in this wsdl.");
+        } else
+            _serviceQName =
+                eif.getServiceName();
+
+        if (eif.getEndpointAddress() != null)   //temp workaround for local transport kw
+            getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY,
+                eif.getEndpointAddress());
+
+        ContactInfoListImpl cil = new ContactInfoListImpl();
+        //not sure I need this service argument
+        _delegate = new DelegateBase(cil, service);
+    }
+
+    public void setModel(RuntimeContext rtcontext) {
+        _rtcontext = rtcontext;
+    }
+
+    public void setProxy(Object p) {
+        _proxy = p;
+    }
+
+    public Object invoke(Object proxy, Method method, Object[] args) throws WebServiceException, Throwable {
+
+        try {
+            if (isSEIMethod(method, _portInterface)) {
+                return implementSEIMethod(method, args);
+            } else {
+                return method.invoke(this, args);
+            }
+        } catch (InvocationTargetException e) {
+            throw e.getCause();
+        }
+    }
+
+    /**
+     * Gets a new {@link com.sun.xml.internal.ws.pept.presentation.MessageStruct} from the Delegate, copies
+     * the data and metadata into the newly created MessageStruct, invokes Delegate.send, and
+     * returns the response.
+     */
+    public Object implementSEIMethod(Method method, Object[] parameters) throws Throwable {
+
+        MessageStruct messageStruct = _delegate.getMessageStruct();
+        int mmep = 0;
+        if (_rtcontext != null) {
+            JavaMethod jmethod = _rtcontext.getModel().getJavaMethod(method);
+            if (jmethod != null) {
+                int mep = jmethod.getMEP();
+                mmep = (mep == MessageStruct.REQUEST_RESPONSE_MEP) ?
+                    MessageStruct.REQUEST_RESPONSE_MEP : (mep == MessageStruct.ONE_WAY_MEP) ?
+                    MessageStruct.ONE_WAY_MEP : ((mep == MessageStruct.ASYNC_POLL_MEP) ?
+                    MessageStruct.ASYNC_POLL_MEP : MessageStruct.ASYNC_CALLBACK_MEP);
+            } else throw new WebServiceException("runtime model information for java Method " + method.getName() + " is not known .");
+        } //need to check if this is dispatch invocation
+
+        if (mmep == MessageStruct.ASYNC_CALLBACK_MEP) {
+            for (Object param : parameters) {
+                if (param != null && AsyncHandler.class.isAssignableFrom(param.getClass())) {
+                    //messageStruct.setMetaData(BindingProviderProperties.JAXWS_CLIENT_ASYNC_HANDLER, param);
+                    messageStruct.setMetaData(BindingProviderProperties.JAXWS_CLIENT_ASYNC_HANDLER,
+                        new AsyncHandlerService((AsyncHandler)param, getCurrentExecutor()));
+                }
+            }
+        }
+
+        messageStruct.setMethod(method);
+        messageStruct.setData(parameters);
+        RequestContext requestContext = (RequestContext)(java.util.Map)
+            ((BindingProvider) _proxy).getRequestContext();
+        requestContext.put(JAXWS_CLIENT_HANDLE_PROPERTY, _proxy);
+        messageStruct.setMetaData(JAXWS_RUNTIME_CONTEXT, _rtcontext);
+        messageStruct.setMetaData(JAXWS_CONTEXT_PROPERTY, requestContext);
+
+        //set mtom threshold value to
+        Object mtomThreshold = requestContext.get(MTOM_THRESHOLOD_VALUE);
+        messageStruct.setMetaData(MTOM_THRESHOLOD_VALUE, mtomThreshold);
+
+        messageStruct.setMEP(mmep);
+
+        // Initialize content negotiation property
+        ContentNegotiation.initialize(requestContext, messageStruct);
+
+        // Set MTOM processing for XML requests only
+        if (_rtcontext != null && _rtcontext.getModel() != null) {
+            javax.xml.ws.soap.SOAPBinding sb =
+                (binding instanceof javax.xml.ws.soap.SOAPBinding) ?
+                    (javax.xml.ws.soap.SOAPBinding) binding : null;
+            if (sb != null) {
+                _rtcontext.getModel().enableMtom(sb.isMTOMEnabled());
+            }
+        }
+
+        _delegate.send(messageStruct);
+        updateResponseContext((MessageInfo) messageStruct);
+        switch (messageStruct.getResponseType()) {
+            case MessageStruct.NORMAL_RESPONSE:
+                break;
+            case MessageStruct.CHECKED_EXCEPTION_RESPONSE:
+                if (_rtcontext.getModel().isCheckedException(method, messageStruct.getResponse().getClass()))
+                    throw (Throwable) messageStruct.getResponse();
+                throw (Exception) messageStruct.getResponse();
+            case MessageStruct.UNCHECKED_EXCEPTION_RESPONSE:
+                throw (RuntimeException) messageStruct.getResponse();
+        }
+        return messageStruct.getResponse();
+    }
+
+    boolean isSEIMethod(Method method, Class sei) {
+        return (sei.equals(method.getDeclaringClass())) ? true : false;
+    }
+
+    public EndpointIFContext getEndpointContext() {
+        return _endpointContext;
+    }
+
+    public QName getServiceQName() {
+        return _serviceQName;
+    }
+
+    public Class getPortInterface(){
+        return _portInterface;
+    }
+
+     Executor getCurrentExecutor(){
+        return _service.getExecutor();
+    }
+
+    public QName getWSDLPortTypeQName(){
+        return _service.getWSDLBinding(_endpointContext.getPortName()).getPortTypeName();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/InternalBindingProvider.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/InternalBindingProvider.java
new file mode 100644
index 0000000..9ab8ff9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/InternalBindingProvider.java
@@ -0,0 +1,39 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.binding.BindingImpl;
+
+
+/**
+ * A utility interface for all the classes
+ * that implement BindingProvider.
+ *
+ * @see WebService#setBindingOnProvider(InternalBindingProvider,
+ *      QName, String)
+ */
+public interface InternalBindingProvider {
+    public void _setBinding(BindingImpl binding);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/PortInfoBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/PortInfoBase.java
new file mode 100644
index 0000000..f05497a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/PortInfoBase.java
@@ -0,0 +1,87 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import javax.xml.namespace.QName;
+
+/**
+ * JAXWS Development Team
+ */
+public class PortInfoBase {
+
+    protected String targetEndpoint;
+    protected String defaultNamespace;
+    protected QName name;
+    protected QName portTypeName;
+    protected String bindingId;
+
+    public PortInfoBase(QName name) {
+        this.name = name;
+        targetEndpoint = "";
+        defaultNamespace = "";
+    }
+
+    public PortInfoBase(String targetEndpoint, QName name, String bindingId) {
+        this.targetEndpoint = targetEndpoint;
+        this.name = name;
+        this.bindingId = bindingId;
+    }
+
+    void setName(QName nm) {
+        name = nm;
+    }
+
+    public QName getName() {
+        return name;
+    }
+
+    void setTargetEndpoint(String endpoint) {
+        targetEndpoint = endpoint;
+    }
+
+    public String getTargetEndpoint() {
+        return targetEndpoint;
+    }
+
+    void setBindingId(String id) {
+        bindingId = id;
+    }
+
+    public String getBindingId() {
+        return bindingId;
+    }
+
+    void setPortTypeName(QName typeName) {
+        portTypeName = typeName;
+    }
+
+    public QName getPortTypeName() {
+        return portTypeName;
+    }
+
+    void setDefaultNamespace(String namespace) {
+        defaultNamespace = namespace;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/RequestContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/RequestContext.java
new file mode 100644
index 0000000..94af3a2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/RequestContext.java
@@ -0,0 +1,50 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import javax.xml.ws.BindingProvider;
+
+
+public class RequestContext extends ContextMap {
+
+    public RequestContext(BindingProvider provider) {
+        super(provider);
+    }
+
+    public RequestContext(PortInfoBase port, BindingProvider provider) {
+        super(port, provider);
+    }
+
+    /**
+     * Copy constructor.
+     */
+    private RequestContext(RequestContext original) {
+        super(original);
+    }
+
+    public RequestContext copy() {
+        return new RequestContext(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ResponseContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ResponseContext.java
new file mode 100644
index 0000000..dcb6980
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ResponseContext.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import javax.xml.ws.BindingProvider;
+
+
+public class ResponseContext extends ContextMap {
+    public ResponseContext(BindingProvider provider) {
+        super(provider);
+    }
+
+    /**
+     * Copy constructor.
+     */
+    private ResponseContext(ResponseContext original) {
+        super(original);
+    }
+
+    public ResponseContext copy() {
+        return new ResponseContext(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/SenderException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/SenderException.java
new file mode 100644
index 0000000..f712344
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/SenderException.java
@@ -0,0 +1,50 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+
+/**
+ * @author WS Development Team
+ */
+public class SenderException extends JAXWSExceptionBase {
+    public SenderException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public SenderException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public SenderException(Localizable arg) {
+        super("sender.nestedError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.sender";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ServiceContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ServiceContext.java
new file mode 100644
index 0000000..15c6ddb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ServiceContext.java
@@ -0,0 +1,148 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.handler.HandlerResolverImpl;
+import com.sun.xml.internal.ws.wsdl.WSDLContext;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+
+import org.xml.sax.EntityResolver;
+
+
+/**
+ * $author: WS Development Team
+ */
+public class ServiceContext {
+    private WSDLContext wsdlContext; //from wsdlParsing
+
+    private Class serviceClass;
+    private HandlerResolverImpl handlerResolver;
+    private QName serviceName; //supplied on creation of service
+    private final HashSet<EndpointIFContext> seiContext = new HashSet<EndpointIFContext>();
+    /**
+     * To be used to resolve WSDL resources.
+     */
+    private final EntityResolver entityResolver;
+    private HashMap<QName,Set<String>> rolesMap = new HashMap<QName,Set<String>>();
+    public ServiceContext(EntityResolver entityResolver) {
+        this.entityResolver = entityResolver;
+    }
+
+    public ServiceContext(Class serviceClass, QName serviceName, EntityResolver entityResolver) {
+        this.serviceClass = serviceClass;
+        this.serviceName = serviceName;
+        this.entityResolver = entityResolver;
+    }
+
+    public WSDLContext getWsdlContext() {
+        return wsdlContext;
+    }
+
+    public void setWsdlContext(WSDLContext wsdlContext) {
+        this.wsdlContext = wsdlContext;
+    }
+
+    public HandlerResolverImpl getHandlerResolver() {
+        return handlerResolver;
+    }
+
+    public void setHandlerResolver(HandlerResolverImpl resolver) {
+        this.handlerResolver = resolver;
+    }
+
+    public Set<String> getRoles(QName portName) {
+        return rolesMap.get(portName);
+    }
+
+    public void setRoles(QName portName,Set<String> roles) {
+        rolesMap.put(portName,roles);
+    }
+
+    public EndpointIFContext getEndpointIFContext(String className) {
+        for (EndpointIFContext eif: seiContext){
+            if (eif.getSei().getName().equals(className)){
+                //this is the one
+                return eif;
+            }
+        }
+        return null;
+    }
+
+    public HashSet<EndpointIFContext> getEndpointIFContext() {
+            return seiContext;
+        }
+
+    public void addEndpointIFContext(EndpointIFContext eifContext) {
+        this.seiContext.add(eifContext);
+    }
+
+     public void addEndpointIFContext(List<EndpointIFContext> eifContexts) {
+        this.seiContext.addAll(eifContexts);
+    }
+
+    public Class getServiceClass() {
+        return serviceClass;
+    }
+
+    public void setServiceClass(Class serviceClass) {
+        this.serviceClass = serviceClass;
+    }
+
+    public QName getServiceName() {
+        if (serviceName == null) {
+            if (wsdlContext != null) {
+                setServiceName(wsdlContext.getFirstServiceName());
+            }
+        }
+        return serviceName;
+    }
+
+    public void setServiceName(QName serviceName) {
+        assert(serviceName != null);
+        this.serviceName = serviceName;
+    }
+
+    public EntityResolver getEntityResolver() {
+        return entityResolver;
+    }
+
+    public String toString() {
+        return "ServiceContext{" +
+            "wsdlContext=" + wsdlContext +
+            ", handleResolver=" + handlerResolver +
+            ", serviceClass=" + serviceClass +
+            ", serviceName=" + serviceName +
+            ", seiContext=" + seiContext +
+            ", entityResolver=" + entityResolver +
+            "}";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ServiceContextBuilder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ServiceContextBuilder.java
new file mode 100644
index 0000000..40050dc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/ServiceContextBuilder.java
@@ -0,0 +1,157 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.ws.handler.HandlerResolverImpl;
+import com.sun.xml.internal.ws.handler.PortInfoImpl;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.modeler.RuntimeModeler;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.util.HandlerAnnotationInfo;
+import com.sun.xml.internal.ws.util.HandlerAnnotationProcessor;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.xml.internal.ws.wsdl.WSDLContext;
+import org.xml.sax.EntityResolver;
+import javax.jws.HandlerChain;
+import javax.xml.namespace.QName;
+import javax.xml.ws.Service;
+import javax.xml.ws.WebEndpoint;
+import javax.xml.ws.WebServiceClient;
+import javax.xml.ws.WebServiceException;
+import javax.jws.WebService;
+import java.lang.reflect.Method;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.security.AccessController;
+import java.security.PrivilegedAction;
+import java.util.ArrayList;
+
+/**
+ * $author: WS Development Team
+ */
+public abstract class ServiceContextBuilder {
+    private ServiceContextBuilder() {
+    }  // no instantication please
+
+    /**
+     * Creates a new {@link ServiceContext}.
+     */
+    public static ServiceContext build(URL wsdlLocation, QName serviceName, final Class service, EntityResolver er) throws WebServiceException {
+        ServiceContext serviceContext = new ServiceContext(service, serviceName, er);
+
+        if (wsdlLocation != null){
+            WSDLContext wsCtx = new WSDLContext(wsdlLocation, er);
+
+            //check if the serviceName is a valid one, if its not in the given WSDL fail
+            if(!wsCtx.contains(serviceName))
+                throw new ClientConfigurationException("service.invalidServiceName", serviceName, wsdlLocation);
+
+            serviceContext.setWsdlContext(wsCtx);
+        }
+
+        //if @HandlerChain present, set HandlerResolver on service context
+        HandlerChain handlerChain = (HandlerChain)
+        AccessController.doPrivileged(new PrivilegedAction() {
+            public Object run() {
+                return service.getAnnotation(HandlerChain.class);
+            }
+        });
+        if(handlerChain != null) {
+            HandlerResolverImpl hresolver = new HandlerResolverImpl(serviceContext);
+            serviceContext.setHandlerResolver(hresolver);
+        }
+        return serviceContext;
+    }
+
+    public static void completeServiceContext(QName portName, ServiceContext serviceContext, Class portInterface) {
+        if (portInterface != null)
+            processAnnotations(portName, serviceContext, portInterface);
+    }
+
+    private static void processAnnotations(QName portName, ServiceContext serviceContext, Class portInterface) throws WebServiceException {
+        WSDLContext wsdlContext = serviceContext.getWsdlContext();
+        EndpointIFContext eifc = serviceContext.getEndpointIFContext(portInterface.getName());
+        if ((eifc != null) && (eifc.getRuntimeContext() != null)) {
+            return;
+        }
+        if (eifc == null) {
+            eifc = new EndpointIFContext(portInterface);
+            serviceContext.addEndpointIFContext(eifc);
+        }
+
+        QName serviceName = serviceContext.getServiceName();
+
+        //if portName is null get it from the WSDL
+        if (portName == null) {
+            //get the first port corresponding to the SEI
+            QName portTypeName = RuntimeModeler.getPortTypeName(portInterface);
+            portName = wsdlContext.getWsdlDocument().getPortName(serviceContext.getServiceName(), portTypeName);
+        }
+
+        //still no portName, fail
+        if(portName == null)
+            throw new ClientConfigurationException("service.noPortName", portInterface.getName(), wsdlContext.getWsdlLocation().toString());
+
+        eifc.setPortName(portName);
+        String bindingId = wsdlContext.getBindingID(serviceName, portName);
+        RuntimeModeler modeler = new RuntimeModeler(portInterface,
+            serviceName, bindingId);
+        modeler.setPortName(portName);
+        RuntimeModel model = modeler.buildRuntimeModel();
+
+        eifc.setRuntimeContext(new RuntimeContext(model));
+    }
+
+    private ArrayList<Class<?>> getSEI(final Class sc) {
+
+        if (sc == null) {
+            throw new WebServiceException();
+        }
+
+        //check to make sure this is a service
+        if (!Service.class.isAssignableFrom(sc)) {
+            throw new WebServiceException("service.interface.required" +
+                sc.getName());
+        }
+
+        final ArrayList<Class<?>> classes = new ArrayList<Class<?>>();
+        AccessController.doPrivileged(new PrivilegedAction() {
+            public Object run() {
+                Method[] methods = sc.getDeclaredMethods();
+                for (final Method method : methods) {
+                    method.setAccessible(true);
+                    Class<?> seiClazz = method.getReturnType();
+                    if ((seiClazz != null) && (!seiClazz.equals("void")))
+                        classes.add(seiClazz);
+
+                }
+                return null;
+            }
+        });
+
+        return classes;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/WSFuture.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/WSFuture.java
new file mode 100644
index 0000000..cb2d320
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/WSFuture.java
@@ -0,0 +1,64 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client;
+
+
+import com.sun.xml.internal.ws.client.ResponseContext;
+
+import javax.xml.ws.Response;
+import java.rmi.server.UID;
+import java.util.Map;
+import java.util.concurrent.Callable;
+import java.util.concurrent.FutureTask;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
+import java.util.logging.Logger;
+
+/**
+ * The <code>Response</code> interface provides methods used to obtain the
+ * payload and context a message sent in response to an operation invocation.
+ * For asynchronous operation invocations it provides additional methods to
+ * check the status of the request.
+ *
+ * @author JAXWS Development Team
+ */
+
+
+public class WSFuture<T> extends FutureTask<T> {
+    private static final Logger logger =
+        Logger.getLogger(new StringBuffer().append(com.sun.xml.internal.ws.util.Constants.LoggingDomain).append(".client.dispatch").toString());
+
+    private Lock _lock;
+
+    public WSFuture(Callable<T> callable) {
+        super(callable);
+        _lock = new ReentrantLock();
+    }
+
+    public WSFuture(Runnable runable, T result) {
+        super(runable, result);
+        _lock = new ReentrantLock();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/WSServiceDelegate.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/WSServiceDelegate.java
new file mode 100644
index 0000000..772c605
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/WSServiceDelegate.java
@@ -0,0 +1,423 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2005 Your Corporation. All Rights Reserved.
+ */
+package com.sun.xml.internal.ws.client;
+
+import com.sun.org.apache.xml.internal.resolver.tools.CatalogResolver;
+import com.sun.xml.internal.ws.binding.http.HTTPBindingImpl;
+import com.sun.xml.internal.ws.binding.soap.SOAPBindingImpl;
+import com.sun.xml.internal.ws.client.dispatch.DispatchBase;
+import com.sun.xml.internal.ws.handler.PortInfoImpl;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import com.sun.xml.internal.ws.wsdl.WSDLContext;
+import com.sun.xml.internal.ws.wsdl.parser.Binding;
+import org.xml.sax.EntityResolver;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.namespace.QName;
+import javax.xml.ws.BindingProvider;
+import javax.xml.ws.Dispatch;
+import javax.xml.ws.Service;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.handler.Handler;
+import javax.xml.ws.handler.HandlerResolver;
+import javax.xml.ws.handler.PortInfo;
+import javax.xml.ws.http.HTTPBinding;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.ws.spi.ServiceDelegate;
+import java.lang.reflect.Proxy;
+import java.net.URL;
+import java.util.*;
+import java.util.concurrent.Executor;
+import java.util.concurrent.Executors;
+import java.util.concurrent.ThreadFactory;
+
+/**
+ * <code>Service</code> objects provide the client view of a Web service.
+ * <p><code>Service</code> acts as a factory of the following:
+ * <ul>
+ * <li>Proxies for a target service endpoint.
+ * <li>Instances of <code>javax.xml.ws.Dispatch</code> for
+ * dynamic message-oriented invocation of a remote
+ * operation.
+ * </li>
+ * <p/>
+ * <p>The ports available on a service can be enumerated using the
+ * <code>getPorts</code> method. Alternatively, you can pass a
+ * service endpoint interface to the unary <code>getPort</code> method
+ * and let the runtime select a compatible port.
+ * <p/>
+ * <p>Handler chains for all the objects created by a <code>Service</code>
+ * can be set by means of the provided <code>HandlerRegistry</code>.
+ * <p/>
+ * <p>An <code>Executor</code> may be set on the service in order
+ * to gain better control over the threads used to dispatch asynchronous
+ * callbacks. For instance, thread pooling with certain parameters
+ * can be enabled by creating a <code>ThreadPoolExecutor</code> and
+ * registering it with the service.
+ *
+ * @author WS Development Team
+ * @see java.util.concurrent.Executor
+ * @since JAX-WS 2.0
+ */
+public class WSServiceDelegate extends ServiceDelegate {
+
+    protected static final String GET = "get";
+
+    protected HashSet<QName> ports;
+
+    protected HashMap<QName, PortInfoBase> dispatchPorts;
+    protected HandlerResolver handlerResolver;
+
+    protected Object serviceProxy;
+    protected URL wsdlLocation;
+    protected ServiceContext serviceContext;
+    protected Executor executor;
+    private HashSet<Object> seiProxies;
+
+    /**
+     * {@link CatalogResolver} to check META-INF/jax-ws-catalog.xml.
+     * Lazily created.
+     */
+    private EntityResolver entityResolver;
+
+
+    public WSServiceDelegate(ServiceContext scontext) {
+        serviceContext = scontext;
+        this.dispatchPorts = new HashMap();
+        seiProxies = new HashSet();
+        if (serviceContext.getHandlerResolver() != null) {
+            handlerResolver = serviceContext.getHandlerResolver();
+        }
+    }
+
+    public WSServiceDelegate(URL wsdlDocumentLocation, QName serviceName, Class serviceClass) {
+        //we cant create a Service without serviceName
+        if (serviceName == null)
+            throw new ClientConfigurationException("service.noServiceName");
+
+        this.dispatchPorts = new HashMap();
+        seiProxies = new HashSet();
+
+        serviceContext = ServiceContextBuilder.build(wsdlDocumentLocation, serviceName,
+            serviceClass, XmlUtil.createDefaultCatalogResolver());
+
+        if (serviceContext.getHandlerResolver() != null) {
+            handlerResolver = serviceContext.getHandlerResolver();
+        }
+
+        populatePorts();
+    }
+
+    private void processServiceContext(QName portName, Class portInterface) throws WebServiceException {
+        ServiceContextBuilder.completeServiceContext(portName, serviceContext, portInterface);
+    }
+
+    public URL getWSDLLocation() {
+        if (wsdlLocation == null)
+            setWSDLLocation(getWsdlLocation());
+        return wsdlLocation;
+    }
+
+    public void setWSDLLocation(URL location) {
+        wsdlLocation = location;
+    }
+
+    public Executor getExecutor() {
+        if (executor != null)
+        //todo:needs to be decoupled from service at execution
+        {
+            return (Executor) executor;
+        } else
+            executor = Executors.newFixedThreadPool(3, new DaemonThreadFactory());
+        return executor;
+    }
+
+    public void setExecutor(Executor executor) {
+        this.executor = executor;
+    }
+
+
+    public HandlerResolver getHandlerResolver() {
+        return handlerResolver;
+    }
+
+    public void setHandlerResolver(HandlerResolver resolver) {
+        handlerResolver = resolver;
+    }
+
+    public Object getPort(QName portName, Class portInterface)
+        throws WebServiceException {
+        Object seiProxy = createEndpointIFBaseProxy(portName, portInterface);
+        seiProxies.add(seiProxy);
+        if (portName != null) {
+            addPort(portName);
+        }
+
+        return seiProxy;
+    }
+
+    public Object getPort(Class portInterface) throws WebServiceException {
+        return createEndpointIFBaseProxy(null, portInterface);
+    }
+
+    //todo: rename addPort :spec tbd
+    public void addPort(QName portName, String bindingId,
+                        String endpointAddress) throws WebServiceException {
+
+        if (!dispatchPorts.containsKey(portName)) {
+            dispatchPorts.put(portName, new PortInfoBase(endpointAddress,
+                portName, bindingId));
+        } else
+            throw new WebServiceException("Port " + portName.toString() + " already exists can not create a port with the same name.");
+        // need to add port to list for HandlerRegistry
+        addPort(portName);
+    }
+
+
+    public <T> Dispatch<T> createDispatch(QName qName, Class<T> aClass, Service.Mode mode) throws WebServiceException {
+        return createDispatchClazz(qName, aClass, mode);
+    }
+
+    public Dispatch<Object> createDispatch(QName qName, JAXBContext jaxbContext, Service.Mode mode) throws WebServiceException {
+        return createDispatchJAXB(qName, jaxbContext, mode);
+    }
+
+    public QName getServiceName() {
+        return serviceContext.getServiceName();
+    }
+
+    public Iterator getPorts() throws WebServiceException {
+        if (ports == null)
+            populatePorts();
+
+        if (ports.size() == 0)
+            throw noWsdlException();
+        return ports.iterator();
+    }
+
+    public URL getWSDLDocumentLocation() {
+        return getWsdlLocation();
+    }
+
+    protected void addPorts(QName[] ports) {
+        if (ports != null) {
+            for (int i = 0; i < ports.length; ++i) {
+                addPort(ports[i]);
+            }
+        }
+    }
+
+    private void populatePorts() {
+        if (ports == null)
+            ports = new HashSet<QName>();
+
+        WSDLContext wscontext = serviceContext.getWsdlContext();
+
+        if (serviceContext.getServiceName() == null) {
+            if (wscontext != null) {
+                serviceContext.setServiceName(wscontext.getFirstServiceName());
+            }
+        }
+        Set knownPorts = null;
+
+        if (wscontext != null) {
+            QName serviceName = serviceContext.getServiceName();
+            knownPorts =
+                wscontext.getPortsAsSet(serviceName);
+            if (knownPorts != null) {
+                QName[] portz = (QName[]) knownPorts.toArray(
+                    new QName[knownPorts.size()]);
+                addPorts(portz);
+                for (QName port : portz) {
+                    String endpoint =
+                        wscontext.getEndpoint(serviceName, port);
+                    String bid = wscontext.getWsdlBinding(serviceName, port)
+                        .getBindingId();
+                    dispatchPorts.put(port,
+                        new PortInfoBase(endpoint, port, bid));
+                }
+            }
+        }
+    }
+
+    protected void addPort(QName port) {
+        if (ports == null)
+            populatePorts();
+        ports.add(port);
+    }
+
+    protected WebServiceException noWsdlException() {
+        return new WebServiceException("dii.service.no.wsdl.available");
+    }
+
+    private Object createEndpointIFBaseProxy(QName portName, Class portInterface) throws WebServiceException {
+        //fail if service doesnt have WSDL
+        if (serviceContext.getWsdlContext() == null)
+            throw new ClientConfigurationException("service.noWSDLUrl");
+
+        //if there is portName validate it
+        if ((portName != null) && !serviceContext.getWsdlContext().contains(serviceContext.getServiceName(), portName))
+        {
+            throw new ClientConfigurationException("service.invalidPort", portName, serviceContext.getServiceName(), serviceContext.getWsdlContext().getWsdlLocation().toString());
+        }
+
+        processServiceContext(portName, portInterface);
+
+        //if the portName is null it must have been set inside processServiceContext, now get it
+        //from EndpointIfContext
+        if (portName == null)
+            portName = serviceContext.getEndpointIFContext(portInterface.getName()).getPortName();
+
+        return buildEndpointIFProxy(portName, portInterface);
+    }
+
+    protected HashSet<QName> getPortsAsSet() {
+        if (ports == null)
+            populatePorts();
+        return ports;
+    }
+
+    /*
+     * Set the binding on the binding provider. Called by the service
+     * class when creating the binding provider.
+     */
+    protected void setBindingOnProvider(InternalBindingProvider provider,
+                                        QName portName, String bindingId) {
+
+        // get handler chain
+        List<Handler> handlerChain = null;
+        HandlerResolver hResolver = getHandlerResolver();
+        if (handlerResolver != null && getServiceName() != null) {
+            PortInfo portInfo = new PortInfoImpl(bindingId, portName,
+                getServiceName());
+            handlerChain = handlerResolver.getHandlerChain(portInfo);
+        } else {
+            handlerChain = new ArrayList<Handler>();
+        }
+
+        // create binding
+        if (bindingId.toString().equals(SOAPBinding.SOAP11HTTP_BINDING) ||
+            bindingId.toString().equals(SOAPBinding.SOAP11HTTP_MTOM_BINDING) ||
+            bindingId.toString().equals(SOAPBinding.SOAP12HTTP_BINDING) ||
+            bindingId.toString().equals(SOAPBinding.SOAP12HTTP_MTOM_BINDING)) {
+            SOAPBindingImpl bindingImpl = new SOAPBindingImpl(handlerChain,
+                bindingId, getServiceName());
+            Set<String> roles = serviceContext.getRoles(portName);
+            if (roles != null) {
+                bindingImpl.setRoles(roles);
+            }
+            provider._setBinding(bindingImpl);
+        } else if (bindingId.equals(HTTPBinding.HTTP_BINDING)) {
+            provider._setBinding(new HTTPBindingImpl(handlerChain));
+        }
+    }
+
+
+    private Dispatch createDispatchClazz(QName port, Class clazz, Service.Mode mode) throws WebServiceException {
+        PortInfoBase dispatchPort = dispatchPorts.get(port);
+        if (dispatchPort != null) {
+            DispatchBase dBase = new DispatchBase((PortInfoBase) dispatchPort, clazz, (Service.Mode) mode, this);
+            setBindingOnProvider(dBase, port, dBase._getBindingId());
+            return dBase;
+        } else {
+            throw new WebServiceException("Port must be defined in order to create Dispatch");
+        }
+    }
+
+    private Dispatch createDispatchJAXB(QName port, JAXBContext jaxbContext, Service.Mode mode) throws WebServiceException {
+        PortInfoBase dispatchPort = dispatchPorts.get(port);
+        if (dispatchPort != null) {
+            DispatchBase dBase = new DispatchBase((PortInfoBase) dispatchPort, jaxbContext, mode, this);
+            setBindingOnProvider(dBase, port, dBase._getBindingId());
+            return dBase;
+        } else {
+            throw new WebServiceException("Port must be defined in order to create Dispatch");
+        }
+    }
+
+    private URL getWsdlLocation() {
+        return serviceContext.getWsdlContext().getWsdlLocation();
+    }
+
+    private Object buildEndpointIFProxy(QName portQName, Class portInterface)
+        throws WebServiceException {
+
+        EndpointIFContext eif = completeEndpointIFContext(serviceContext, portQName, portInterface);
+
+        //apply parameter bindings
+        RuntimeModel model = eif.getRuntimeContext().getModel();
+        if (portQName != null) {
+            Binding binding = getWSDLBinding(portQName);
+            eif.setBindingID(binding.getBindingId());
+            model.applyParameterBinding(binding);
+        }
+
+        //needs cleaning up
+        EndpointIFInvocationHandler handler =
+            new EndpointIFInvocationHandler(portInterface,
+                eif, this, getServiceName()); //need handler registry passed in here
+        setBindingOnProvider(handler, portQName, handler._getBindingId());
+
+        Object proxy = Proxy.newProxyInstance(portInterface.getClassLoader(),
+            new Class[]{
+                portInterface, BindingProvider.class,
+                BindingProviderProperties.class,
+                com.sun.xml.internal.ws.spi.runtime.StubBase.class
+            }, handler);
+        handler.setProxy((Object) proxy);
+        return (BindingProvider) proxy;
+    }
+
+    Binding getWSDLBinding(QName portQName) {
+        return serviceContext.getWsdlContext().getWsdlBinding(serviceContext.getServiceName(), portQName);
+    }
+
+    private EndpointIFContext completeEndpointIFContext(ServiceContext serviceContext, QName portQName, Class portInterface) {
+
+        EndpointIFContext context = serviceContext.getEndpointIFContext(portInterface.getName());
+        WSDLContext wscontext = serviceContext.getWsdlContext();
+        if (wscontext != null) {
+            String endpoint = wscontext.getEndpoint(serviceContext.getServiceName(), portQName);
+            String bindingID = wscontext.getBindingID(
+                serviceContext.getServiceName(), portQName);
+            context.setServiceName(serviceContext.getServiceName());
+            context.setPortInfo(portQName, endpoint, bindingID);
+        }
+        return context;
+    }
+
+    class DaemonThreadFactory implements ThreadFactory {
+        public Thread newThread(Runnable r) {
+            Thread daemonThread = new Thread(r);
+            daemonThread.setDaemon(Boolean.TRUE);
+            return daemonThread;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/DispatchBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/DispatchBase.java
new file mode 100644
index 0000000..85a7fe4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/DispatchBase.java
@@ -0,0 +1,710 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.client.dispatch;
+
+import static javax.xml.ws.Service.Mode.MESSAGE;
+import static javax.xml.ws.Service.Mode.*;
+import static javax.xml.ws.Service.*;
+
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.binding.soap.SOAPBindingImpl;
+import com.sun.xml.internal.ws.client.*;
+import com.sun.xml.internal.ws.client.dispatch.impl.DispatchContactInfoList;
+import com.sun.xml.internal.ws.client.dispatch.impl.DispatchDelegate;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.pept.Delegate;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.spi.runtime.ClientTransportFactory;
+import com.sun.xml.internal.ws.transport.http.client.HttpClientTransportFactory;
+
+import javax.activation.DataSource;
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.namespace.QName;
+import javax.xml.soap.MessageFactory;
+import javax.xml.soap.SOAPConstants;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.transform.Source;
+import javax.xml.ws.*;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.http.HTTPBinding;
+import javax.xml.ws.http.HTTPException;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.ws.soap.SOAPFaultException;
+import java.util.Map;
+import java.util.concurrent.Executor;
+import java.util.concurrent.Future;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
+import java.util.logging.Logger;
+
+
+/**
+ * The <code>javax.xml.ws.Dispatch</code> interface provides support
+ * for the dynamic invocation of a service endpoint operation using XML
+ * constructs or JAXB objects. The <code>javax.xml.ws.Service</code>
+ * interface acts as a factory for the creation of <code>Dispatch</code>
+ * instances.
+ *
+ * @author WS Development Team
+ */
+
+public class DispatchBase implements BindingProvider, InternalBindingProvider,
+    Dispatch {
+
+    public DispatchBase(PortInfoBase port, Class aClass, Service.Mode mode, WSServiceDelegate service) {
+        this(port, mode, null, aClass, service);
+    }
+
+    public DispatchBase(PortInfoBase port, JAXBContext jaxbContext, Service.Mode mode, WSServiceDelegate service) {
+        this(port, mode, jaxbContext, null, service);
+    }
+
+    DispatchBase(PortInfoBase port, Service.Mode mode, JAXBContext context, Class clazz, WSServiceDelegate service) {
+        _delegate = new DispatchDelegate(new DispatchContactInfoList());
+        _mode = mode;
+        _portInfo = port;
+        _jaxbContext = context;
+        _clazz = clazz;
+        _service = service;
+    }
+
+    /**
+     * Invoke a service operation synchronously.
+     * <p/>
+     * The client is responsible for ensuring that the <code>msg</code> object
+     * is formed according to the requirements of the protocol binding in use.
+     *
+     * @param msg An object that will form the payload of
+     *            the message used to invoke the operation. Must be an instance of
+     *            either <code>javax.xml.transform.Source</code> or a JAXB object. If
+     *            <code>msg</code> is an instance of a JAXB object then the request
+     *            context must have the <code>javax.xml.ws.binding.context</code>
+     *            property set.
+     * @return The response to the operation invocation. The object is
+     *         either an instance of <code>javax.xml.transform.Source</code>
+     *         or a JAXB object.
+     * @throws javax.xml.ws.WebServiceException
+     *          If there is any error in the configuration of
+     *          the <code>Dispatch</code> instance
+     * @throws javax.xml.ws.WebServiceException
+     *          If an error occurs when using a supplied
+     *          JAXBContext to marshall msg or unmarshall the response. The cause of
+     *          the WebServiceException is the original JAXBException.
+     */
+    public Object invoke(Object msg)
+        throws WebServiceException {
+
+        MessageStruct messageStruct = setupMessageStruct(msg);
+        messageStruct.setMEP(MessageStruct.REQUEST_RESPONSE_MEP);
+        return sendAndReceive(messageStruct);
+    }
+
+    /**
+     * Invoke a service operation asynchronously.  The
+     * method returns without waiting for the response to the operation
+     * invocation, the results of the operation are obtained by polling the
+     * returned <code>Response</code>.
+     * <p/>
+     * The client is responsible for ensuring that the <code>msg</code> object
+     * when marshalled is formed according to the requirements of the protocol
+     * binding in use.
+     *
+     * @param msg An object that, when marshalled, will form the payload of
+     *            the message used to invoke the operation. Must be an instance of
+     *            either <code>javax.xml.transform.Source</code> or a JAXB object. If
+     *            <code>msg</code> is an instance of a JAXB object then the request
+     *            context must have the <code>javax.xml.ws.binding.context</code>
+     *            property set.
+     * @return The response to the operation invocation. The object
+     *         returned by <code>Response.get()</code> is
+     *         either an instance of <code>javax.xml.transform.Source</code>
+     *         or a JAXB object.
+     * @throws javax.xml.ws.WebServiceException
+     *          If there is any error in the configuration of
+     *          the <code>Dispatch</code> instance
+     * @throws javax.xml.ws.WebServiceException
+     *          If an error occurs when using a supplied
+     *          JAXBContext to marshall msg. The cause of
+     *          the WebServicException is the original JAXBException.
+     */
+    public Response<Object> invokeAsync(Object msg)
+        throws WebServiceException {
+
+        MessageStruct messageStruct = setupMessageStruct(msg);
+        messageStruct.setMEP(MessageStruct.ASYNC_POLL_MEP);
+        Object result = sendAsync(messageStruct);
+        if (result instanceof Response)
+            return (Response<Object>) result;
+        else
+            throw (RuntimeException) result;
+    }
+
+
+    /**
+     * Invoke a service operation asynchronously. The
+     * method returns without waiting for the response to the operation
+     * invocation, the results of the operation are communicated to the client
+     * via the passed in handler.
+     * <p/>
+     * The client is responsible for ensuring that the <code>msg</code> object
+     * when marshalled is formed according to the requirements of the protocol
+     * binding in use.
+     *
+     * @param msg     An object that, when marshalled, will form the payload of
+     *                the message used to invoke the operation. Must be an instance of
+     *                either <code>javax.xml.transform.Source</code> or a JAXB object. If
+     *                <code>msg</code> is an instance of a JAXB object then the request
+     *                context must have the <code>javax.xml.ws.binding.context</code>
+     *                property set.
+     * @param handler The handler object that will receive the
+     *                response to the operation invocation. The object
+     *                returned by <code>Response.get()</code> is
+     *                either an instance of
+     *                <code>javax.xml.transform.Source</code> or a JAXB object.
+     * @return A <code>Future</code> object that may be used to check the status
+     *         of the operation invocation. This object must not be used to try to
+     *         obtain the results of the operation - the object returned from
+     *         <code>Future<?>.get()</code> is implementation dependent
+     *         and any use of it will result in non-portable behaviour.
+     * @throws javax.xml.ws.WebServiceException
+     *          If there is any error in the configuration of
+     *          the <code>Dispatch</code> instance
+     * @throws javax.xml.ws.WebServiceException
+     *          If an error occurs when using a supplied
+     *          JAXBContext to marshall msg. The cause of
+     *          the WebServiceException is the original JAXBException.
+     */
+    public Future<?> invokeAsync(java.lang.Object msg, AsyncHandler handler) {
+
+        MessageStruct messageStruct = setupMessageStruct(msg);
+        if (handler != null) {
+            messageStruct.setMetaData(BindingProviderProperties.JAXWS_CLIENT_ASYNC_HANDLER, (Object) new AsyncHandlerService(handler, getCurrentExecutor()));
+        } else
+            throw new WebServiceException("AsyncHandler argument is null. " +
+                "AsyncHandler is required for asynchronous callback invocations ");
+
+        messageStruct.setMEP(MessageStruct.ASYNC_CALLBACK_MEP);
+        Object result = sendAsync(messageStruct);
+        if (result instanceof WSFuture)
+            return (Future<Object>) result;
+        else
+            throw (RuntimeException) result;
+    }
+
+    /**
+     * Invokes a service operation using the one-way
+     * interaction mode. The operation invocation is logically non-blocking,
+     * subject to the capabilities of the underlying protocol, no results
+     * are returned. When
+     * the protocol in use is SOAP/HTTP, this method must block until
+     * an HTTP response code has been received or an error occurs.
+     * <p/>
+     * The client is responsible for ensuring that the <code>msg</code> object
+     * when marshalled is formed according to the requirements of the protocol
+     * binding in use.
+     *
+     * @param msg An object that, when marshalled, will form the payload of
+     *            the message used to invoke the operation. Must be an instance of
+     *            either <code>javax.xml.transform.Source</code> or a JAXB object. If
+     *            <code>msg</code> is an instance of a JAXB object then the request
+     *            context must have the <code>javax.xml.ws.binding.context</code>
+     *            property set.
+     * @throws javax.xml.ws.WebServiceException
+     *          If there is any error in the configuration of
+     *          the <code>Dispatch</code> instance or if an error occurs during the
+     *          invocation.
+     * @throws javax.xml.ws.WebServiceException
+     *          If an error occurs when using a supplied
+     *          JAXBContext to marshall msg. The cause of
+     *          the WebServiceException is the original JAXBException.
+     */
+
+    public void invokeOneWay(Object msg) {
+
+        MessageStruct messageStruct = setupMessageStruct(msg);
+        messageStruct.setMEP(MessageStruct.ONE_WAY_MEP);
+        sendOneWay(messageStruct);
+    }
+
+    private boolean hasJAXBContext(Object msg, MessageStruct messageStruct) {
+        RequestContext requestContext = (RequestContext) getRequestContext();
+        if (_jaxbContext != null) {
+            requestContext.put(BindingProviderProperties.JAXB_CONTEXT_PROPERTY, _jaxbContext);
+            return true;
+        }
+        return false;
+    }
+
+    public void _setDelegate(Delegate delegate) {
+        _delegate = delegate;
+    }
+
+    public Delegate _getDelegate() {
+        return _delegate;
+    }
+
+    public static void setDefaultTransportFactory(ClientTransportFactory factory) {
+        defaultTransportFactory = factory;
+    }
+
+    public static ClientTransportFactory getDefaultTransportFactory() {
+        if (defaultTransportFactory == null)
+            defaultTransportFactory = new HttpClientTransportFactory();
+        return defaultTransportFactory;
+    }
+
+    public ClientTransportFactory _getTransportFactory() {
+        _transportFactory =
+            (ClientTransportFactory) getRequestContext().get(BindingProviderProperties.CLIENT_TRANSPORT_FACTORY);
+
+        if (_transportFactory == null) {
+            _transportFactory = new HttpClientTransportFactory();
+        }
+        return _transportFactory;
+    }
+
+    public void _setTransportFactory(com.sun.xml.internal.ws.spi.runtime.ClientTransportFactory f) {
+        getRequestContext().put(BindingProviderProperties.CLIENT_TRANSPORT_FACTORY, f);
+        _transportFactory = (ClientTransportFactory) f;
+    }
+
+    private Object sendAndReceive(MessageStruct messageStruct) {
+        Object response = null;
+
+        _delegate.send(messageStruct);
+        response = messageStruct.getResponse();
+        updateResponseContext(messageStruct);
+        //((ContextMap) getRequestContext()).clear();
+        switch (messageStruct.getResponseType()) {
+
+            case MessageStruct.NORMAL_RESPONSE:
+                //not sure where this belongs yet - but for now-
+                break;
+            case MessageStruct.CHECKED_EXCEPTION_RESPONSE:
+                if (response instanceof SOAPFaultException)
+                    throw (SOAPFaultException) response;
+                if (response instanceof SOAPFaultInfo) {
+                    SOAPFaultInfo soapFaultInfo = (SOAPFaultInfo) response;
+                    JAXBException jbe = null;
+                    if (soapFaultInfo.getString().contains("javax.xml.bind")) {
+                        jbe = new JAXBException(soapFaultInfo.getString());
+                        //do I need to put this in a webservice exception
+                        SOAPFaultException sfe = new SOAPFaultException(soapFaultInfo.getSOAPFault());
+                        sfe.initCause(jbe);
+                    } else
+                        throw new SOAPFaultException(soapFaultInfo.getSOAPFault());
+                } else if (response instanceof HTTPException) {
+                    throw (HTTPException) response;
+                } else if (response instanceof RuntimeException)
+                    throw (RuntimeException) response;
+            case MessageStruct.UNCHECKED_EXCEPTION_RESPONSE:
+                if (response instanceof SOAPFaultException) {
+                    throw (SOAPFaultException) response;
+                } else if (response instanceof HTTPException) {
+                    throw (HTTPException) response;
+                } else if (response instanceof RuntimeException) {
+                    throw (RuntimeException) response;
+                }
+                break;   //just break and return response
+            default:
+                if (response != null) //must be some kind of exception
+                    throw new WebServiceException("Client side exception - examine cause ", (Exception) response);
+        }
+        return response;
+    }
+
+    private Object sendAsync(MessageStruct messageStruct)
+        throws WebServiceException {
+        Object response = null;
+        _lock = new ReentrantLock();
+        _lock.lock();
+        try {
+            _delegate.send(messageStruct);
+            response = messageStruct.getResponse();
+        } catch (Throwable t) {
+            throw (RuntimeException) t;
+        } finally {
+            _lock.unlock();
+        }
+        return response;
+    }
+
+    private void sendOneWay(MessageStruct messageStruct) {
+
+        _delegate.send(messageStruct);
+        Object response = messageStruct.getResponse();
+        //no exceptions should be returned from server but
+        //exceptions may be returned from the client
+        switch (messageStruct.getResponseType()) {
+            case MessageStruct.NORMAL_RESPONSE:
+                break;
+            case MessageStruct.CHECKED_EXCEPTION_RESPONSE:
+            case MessageStruct.UNCHECKED_EXCEPTION_RESPONSE:
+                //before invocation
+                if (response instanceof RuntimeException)
+                    throw (RuntimeException) response;
+            default:
+                throw new RuntimeException("Client side Exception ");
+        }
+    }
+
+    private MessageStruct setupMessageStruct(Object msg) throws WebServiceException {
+        MessageStruct messageStruct = _delegate.getMessageStruct();
+
+        if (msg != null) {
+            MessageFactory factory = null;
+            if (((msg instanceof Source) && _mode == MESSAGE) &&
+                (!_getBindingId().toString().equals(HTTPBinding.HTTP_BINDING)))
+            {
+                try {
+
+                    if (_getBindingId().toString().equals(SOAPBinding.SOAP12HTTP_BINDING))
+                        factory = MessageFactory.newInstance(SOAPConstants.SOAP_1_2_PROTOCOL);
+                    else
+                        factory = MessageFactory.newInstance(SOAPConstants.SOAP_1_1_PROTOCOL);
+
+                    SOAPMessage message = factory.createMessage();
+                    message.getSOAPPart().setContent((Source) msg);
+                    message.saveChanges();
+                    msg = message;
+                } catch (SOAPException se) {
+                    throw new WebServiceException(se);
+                }
+            }
+
+            //setMessageStruct(messageStruct, msg);
+
+        } else {
+            //todo - needs to be a get request
+            if (!isValidNullParameter(msg))
+                throw new WebServiceException("This is not a valid request ");
+        }
+        setMessageStruct(messageStruct, msg);
+        return messageStruct;
+    }
+
+    private void setMessageStruct(MessageStruct messageStruct, Object msg) {
+        messageStruct.setData(new Object[]{msg});
+        setMetadata(getRequestContext(), msg, messageStruct);
+        //set mtom threshold value to
+        Object mtomThreshold = getRequestContext().get(BindingProviderProperties.MTOM_THRESHOLOD_VALUE);
+        messageStruct.setMetaData(BindingProviderProperties.MTOM_THRESHOLOD_VALUE, mtomThreshold);
+
+        // Set MTOM processing for XML requests only
+        String bindingId =
+            (getBinding() instanceof SOAPBinding)?
+                ((SOAPBindingImpl)binding).getBindingId().toString():HTTPBinding.HTTP_BINDING;
+        if (bindingId.equals(SOAPBinding.SOAP11HTTP_MTOM_BINDING)||
+        bindingId.equals(SOAPBinding.SOAP12HTTP_MTOM_BINDING))
+           messageStruct.setMetaData("com.sun.xml.internal.ws.mtom.enabled", ((SOAPBindingImpl)getBinding()).isMTOMEnabled());
+
+        // Initialize content negotiation property
+        ContentNegotiation.initialize(getRequestContext(), messageStruct);
+    }
+
+    private void updateResponseContext(MessageStruct messageStruct) {
+        ResponseContext responseContext = (ResponseContext)
+            messageStruct.getMetaData(BindingProviderProperties.JAXWS_RESPONSE_CONTEXT_PROPERTY);
+        setResponseContext(responseContext);
+    }
+
+    private void setMetadata(Map jaxwsContext, Object obj, MessageStruct messageStruct) {
+
+        jaxwsContext.put(BindingProviderProperties.JAXWS_CLIENT_HANDLE_PROPERTY, this);
+
+        if (jaxwsContext.get(BindingProvider.ENDPOINT_ADDRESS_PROPERTY) == null)
+            jaxwsContext.put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, _portInfo.getTargetEndpoint());
+
+        jaxwsContext.put(BindingProviderProperties.BINDING_ID_PROPERTY, _getBindingId().toString());
+        if (_jaxbContext != null)
+            jaxwsContext.put(BindingProviderProperties.JAXB_CONTEXT_PROPERTY, _jaxbContext);
+        messageStruct.setMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY,
+            jaxwsContext);
+
+        messageStruct.setMetaData(DispatchContext.DISPATCH_MESSAGE_MODE, _mode);
+        if (_clazz != null)
+            messageStruct.setMetaData(DispatchContext.DISPATCH_MESSAGE_CLASS, _clazz);
+
+        DispatchContext context = setDispatchContext(jaxwsContext, obj, _mode);
+        messageStruct.setMetaData(BindingProviderProperties.DISPATCH_CONTEXT, context);
+    }
+
+    public Binding getBinding() {
+        return (Binding) binding;
+    }
+
+    public void _setBinding(BindingImpl binding) {
+        this.binding = binding;
+    }
+
+    // default for now is soap binding
+    public String _getBindingId() {
+        _bindingId = _portInfo.getBindingId();
+        if (_bindingId == null) {
+            _bindingId = SOAPBinding.SOAP11HTTP_BINDING;
+        }
+        return _bindingId;
+    }
+
+
+    /**
+     * Get the jaxwsContext that is used in processing request messages.
+     * <p/>
+     * Modifications to the request context do not affect asynchronous
+     * operations that have already been started.
+     *
+     * @return The jaxwsContext that is used in processing request messages.
+     */
+    public Map getRequestContext() {
+        if (_requestContext == null)
+            _requestContext = new RequestContext(this);
+
+        return _requestContext;
+    }
+
+    private void setResponseContext(ResponseContext context) {
+        _responseContext = context;
+    }
+
+    /**
+     * Get the jaxwsContext that resulted from processing a response message.
+     * <p/>
+     * The returned context is for the most recently completed synchronous
+     * operation. Subsequent synchronous operation invocations overwrite the
+     * response context. Asynchronous operations return their response context
+     * via the Response interface.
+     *
+     * @return The jaxwsContext that is used in processing request messages.
+     */
+    public Map getResponseContext() {
+        if (_responseContext == null)
+            _responseContext = new ResponseContext(this);
+        return _responseContext;
+    }
+
+    public DispatchContext setDispatchContext(Map jaxwsContext, Object obj, Service.Mode mode) {
+
+        DispatchContext context = new DispatchContext();
+        context.setProperty(DispatchContext.DISPATCH_MESSAGE_MODE, mode);
+
+        if (obj != null) {
+            if (obj instanceof Source) {
+                context.setProperty(DispatchContext.DISPATCH_MESSAGE_CLASS,
+                    DispatchContext.MessageClass.SOURCE);
+            } else if (obj instanceof SOAPMessage) {
+                context.setProperty(DispatchContext.DISPATCH_MESSAGE_CLASS,
+                    DispatchContext.MessageClass.SOAPMESSAGE);
+            } else if ((obj instanceof DataSource) &&
+                _getBindingId().toString().equals(HTTPBinding.HTTP_BINDING)) {
+                context.setProperty(DispatchContext.DISPATCH_MESSAGE_CLASS,
+                    DispatchContext.MessageClass.DATASOURCE);
+
+            } else if (_jaxbContext != null) {
+                context.setProperty(DispatchContext.DISPATCH_MESSAGE_CLASS,
+                    DispatchContext.MessageClass.JAXBOBJECT);
+            } else {
+                if (!_getBindingId().toString().equals(HTTPBinding.HTTP_BINDING))
+                    throw new WebServiceException("Object is not a javax.xml.transform.Source or there is no JAXB Context");
+            }
+        }
+
+        if (_clazz != null) {
+            if (_clazz.isAssignableFrom(Source.class)) {
+                if (mode == PAYLOAD) {
+                    if (_getBindingId().toString().equals(HTTPBinding.HTTP_BINDING))
+                        context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.HTTP_SOURCE_PAYLOAD);
+                    else
+                        context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.SOURCE_PAYLOAD);
+                } else if (mode == MESSAGE) {
+                    if (_getBindingId().toString().equals(HTTPBinding.HTTP_BINDING))
+                        context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.HTTP_SOURCE_MESSAGE);
+                    else
+                        context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.SOURCE_MESSAGE);
+                }
+            } else if (_clazz.isAssignableFrom(SOAPMessage.class)) {
+                if (mode == PAYLOAD) {
+                    throw new WebServiceException("SOAPMessages must be Service.Mode.MESSAGE. ");
+                } else if (mode == MESSAGE)
+                    context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.SOAPMESSAGE_MESSAGE);
+            } else if (_clazz.isAssignableFrom(DataSource.class)) {
+                if (mode == PAYLOAD)
+                    throw new WebServiceException("Can not have a Datahandler class with mode PAYLOAD");
+                    //context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.HTTP_DATASOURCE_PAYLOAD);
+                else if (mode == MESSAGE)
+                    context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.HTTP_DATASOURCE_MESSAGE);
+            } else {
+                context.setProperty(DispatchContext.DISPATCH_MESSAGE_CLASS, _clazz);
+            }
+        } else if (hasJAXBContext(obj, null)) {
+            if (mode == PAYLOAD) {
+                if (_getBindingId().toString().equals(HTTPBinding.HTTP_BINDING))
+                    context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.HTTP_JAXB_PAYLOAD);
+                else
+                    context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.JAXB_PAYLOAD);
+            } else if (mode == MESSAGE) {
+                if (_getBindingId().toString().equals(HTTPBinding.HTTP_BINDING))
+                    throw new WebServiceException(" Can not have a JAXB object with mode MESSAGE");
+                    //context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.HTTP_JAXB_MESSAGE);
+                else
+                    context.setProperty(DispatchContext.DISPATCH_MESSAGE, DispatchContext.MessageType.JAXB_MESSAGE);
+            }
+        }
+
+        return context;
+    }
+
+    Executor getCurrentExecutor() {
+        return _service.getExecutor();
+    }
+
+    public QName getServiceName() {
+        if (_service != null)
+            return _service.getServiceName();
+        return null;
+    }
+
+    public QName getPortName() {
+        if (_portInfo != null)
+            return _portInfo.getName();
+        return null;
+    }
+
+    private boolean isValidNullParameter(Object msg) {
+        if (msg != null)
+            return true;
+
+        String method = (String) getRequestContext().get(MessageContext.HTTP_REQUEST_METHOD);
+        if (method == null)
+            method = "POST";
+
+        String bindingId = _getBindingId().toString();
+        if (("POST".equalsIgnoreCase(method))) {
+
+            if (SOAPBinding.SOAP11HTTP_BINDING.equals(bindingId) ||
+                SOAPBinding.SOAP11HTTP_MTOM_BINDING.equals(bindingId)) {
+                switch (_mode) {
+                    case MESSAGE:
+                        throw new WebServiceException("SOAP 1.1 Binding with null invocation parameter is not allowed with HTTP POST Request Method in MESSAGE mode");
+                        //return false;
+                    case PAYLOAD:
+                        return true;
+                }
+            } else if (HTTPBinding.HTTP_BINDING.equals(bindingId)) {
+                switch (_mode) {
+                    case MESSAGE:
+                    case PAYLOAD:
+                        throw new WebServiceException("XML/HTTP Binding with null invocation parameter is not allowed with HTTP POST Request Method in MESSAGE or PAYLOAD mode");
+                }
+
+            } else if (SOAPBinding.SOAP12HTTP_BINDING.equals(bindingId) ||
+                SOAPBinding.SOAP12HTTP_MTOM_BINDING.equals(bindingId)) {
+                switch (_mode) {
+                    case MESSAGE:
+                        throw new WebServiceException("SOAP 1.2 Binding with null invocation parameter is not allowed with HTTP POST Request Method in MESSAGE mode");
+                        //return false;
+                    case PAYLOAD:
+                        return true;
+                }
+            }
+
+        } else if ("GET".equalsIgnoreCase(method)) {
+
+            if (SOAPBinding.SOAP12HTTP_BINDING.equals(bindingId) ||
+                SOAPBinding.SOAP12HTTP_MTOM_BINDING.equals(bindingId)) {
+                switch (_mode) {
+                    case MESSAGE:
+                        //return false;
+                        throw new WebServiceException("SOAP 1.2 Binding with null invocation parameter is not allowed with HTTP GET Request Method in MESAGE mode.");
+                    case PAYLOAD:
+                        return true;
+                }
+            } else if (SOAPBinding.SOAP11HTTP_BINDING.equals(bindingId) ||
+                SOAPBinding.SOAP11HTTP_MTOM_BINDING.equals(bindingId)) {
+                switch (_mode) {
+                    case MESSAGE:
+                    case PAYLOAD:
+                        throw new WebServiceException("SOAP 1.1 Binding with null invocation parameter is not allowed with HTTP GET Request Method in either PAYLOAD or MESAGE mode.");
+                        //return false;
+                }
+            } else if (HTTPBinding.HTTP_BINDING.equals(bindingId)) {
+                switch (_mode) {
+                    case MESSAGE:
+                    case PAYLOAD:
+                        return true;
+                }
+            }
+
+        } else if ("DELETE".equalsIgnoreCase(method) || "HEAD".equalsIgnoreCase(method)) {
+
+            if (HTTPBinding.HTTP_BINDING.equals(bindingId)) {
+                switch (_mode) {
+                    case MESSAGE:
+                    case PAYLOAD:
+                        return true;
+                }
+            } else if (SOAPBinding.SOAP12HTTP_BINDING.equals(bindingId) ||
+                SOAPBinding.SOAP12HTTP_MTOM_BINDING.equals(bindingId)) {
+                switch (_mode) {
+                    case MESSAGE:
+                        //return false;
+                        throw new WebServiceException("SOAP 1.2 Binding with null invocation parameter is not allowed with HTTP " + method + " Request Method in MESAGE mode.");
+                    case PAYLOAD:
+                        return true;
+                }
+            } else if (SOAPBinding.SOAP11HTTP_BINDING.equals(bindingId) ||
+                SOAPBinding.SOAP11HTTP_MTOM_BINDING.equals(bindingId)) {
+                //return false;
+                throw new WebServiceException("SOAP 1.1 Binding with null invocation parameter is not allowed with HTTP " + method + " Request Method in either PAYLOAD or MESAGE mode.");
+                //return false;
+            }
+
+        }
+        return false;
+    }
+
+    private static ClientTransportFactory defaultTransportFactory = null;
+    private static final Logger logger =
+        Logger.getLogger(new StringBuffer().append(com.sun.xml.internal.ws.util.Constants.LoggingDomain).append(".client.dispatch").toString());
+
+    protected Map _requestContext;
+    protected Map _responseContext;
+    protected Service.Mode _mode;
+    protected WSServiceDelegate _service;
+    protected Class _clazz;
+    protected JAXBContext _jaxbContext;
+
+    protected Delegate _delegate = null;
+    protected PortInfoBase _portInfo = null;
+
+    protected String _bindingId = null;
+    protected BindingImpl binding;
+
+    private ClientTransportFactory _transportFactory;
+    private Lock _lock;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/DispatchContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/DispatchContext.java
new file mode 100644
index 0000000..6c13d79
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/DispatchContext.java
@@ -0,0 +1,80 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client.dispatch;
+
+import java.util.HashMap;
+
+/**
+ * $author: JAXWS Development Team
+ */
+public class DispatchContext {
+
+    private HashMap dprops = null;
+
+    public DispatchContext() {
+        dprops = new HashMap();
+    }
+
+    public void setProperty(String name, Object value) {
+        dprops.put(name, value);
+    }
+
+    public Object getProperty(String name) {
+        return dprops.get(name);
+    }
+
+    public void removeProperty(String name) {
+        dprops.remove(name);
+    }
+
+    public void clearProperties() {
+        dprops.clear();
+    }
+
+    public static final String DISPATCH_MESSAGE =
+        "com.sun.xml.internal.ws.rt.client.dispatch.messagetype";
+    public static final String DISPATCH_MESSAGE_MODE =
+        "com.sun.xml.internal.ws.rt.client.dispatch.mode";
+    public static final String DISPATCH_MESSAGE_CLASS =
+        "com.sun.xml.internal.ws.rt.client.dispatch.messageclass";
+
+    public enum MessageClass {
+        SOURCE ,JAXBOBJECT, SOAPMESSAGE, DATASOURCE
+    }
+
+    public enum MessageType {
+        JAXB_PAYLOAD,             //SOAP Binding
+        SOURCE_PAYLOAD,
+        JAXB_MESSAGE,
+        SOURCE_MESSAGE ,
+        SOAPMESSAGE_MESSAGE,
+        //HTTP_DATASOURCE_PAYLOAD,  //HTTP Binding
+        HTTP_DATASOURCE_MESSAGE,
+        HTTP_SOURCE_MESSAGE, //can be allowed with an HTTP GET method
+        HTTP_SOURCE_PAYLOAD,
+        HTTP_JAXB_PAYLOAD,
+        //HTTP_JAXB_MESSAGE
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/ResponseImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/ResponseImpl.java
new file mode 100644
index 0000000..b7beeef
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/ResponseImpl.java
@@ -0,0 +1,132 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client.dispatch;
+
+import com.sun.xml.internal.ws.client.AsyncHandlerService;
+import com.sun.xml.internal.ws.client.ResponseContext;
+
+import javax.xml.ws.Response;
+import java.rmi.server.UID;
+import java.util.Map;
+import java.util.concurrent.Callable;
+import java.util.concurrent.FutureTask;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
+import java.util.logging.Logger;
+
+/**
+ * The <code>Response</code> interface provides methods used to obtain the
+ * payload and context a message sent in response to an operation invocation.
+ * For asynchronous operation invocations it provides additional methods to
+ * check the status of the request.
+ *
+ * @author JAXWS Development Team
+ */
+
+
+public class ResponseImpl<T> extends FutureTask<T> implements Response<T> {
+    private static final Logger logger =
+        Logger.getLogger(new StringBuffer().append(com.sun.xml.internal.ws.util.Constants.LoggingDomain).append(".client.dispatch").toString());
+    private UID uid;
+    private Lock _lock;
+    private AsyncHandlerService _handlerService;
+    private ResponseContext _responseContext;
+    private boolean handler;
+
+    public ResponseImpl(Callable<T> callable) {
+        super(callable);
+        _lock = new ReentrantLock();
+    }
+
+    public ResponseImpl(Runnable runable, T result) {
+        super(runable, result);
+        _lock = new ReentrantLock();
+    }
+
+    //protected method need to overide
+    public void setException(Exception ex) {
+        _lock.lock();
+        try {
+            super.setException(ex);
+        } catch (Exception e) {
+        } finally {
+            _lock.unlock();
+        }
+    }
+
+    public void set(T result) {
+        _lock.lock();
+        try {
+            super.set(result);
+        } catch (Exception e) {
+        } finally {
+            _lock.unlock();
+        }
+    }
+
+    /**
+     * Gets the contained response context.
+     *
+     * @return The contained response context. May be <code>null</code> if a
+     *         response is not yet available.
+     */
+    public Map<String, Object> getContext() {
+        if (!isDone()) {
+            return null;
+        } else {
+            return (_responseContext);
+        }
+    }
+
+    public void setResponseContext(Map context) {
+        _responseContext = (ResponseContext) context;
+    }
+
+    public synchronized void setUID(UID id) {
+        uid = id;
+    }
+
+    public synchronized UID getUID() {
+        return uid;
+    }
+
+    public void setHandlerService(AsyncHandlerService handlerService) {
+        _handlerService = handlerService;
+    }
+
+    //got to lock
+
+    public void done() {
+        _lock.lock();
+        try {
+            if (!isCancelled())
+                _handlerService.executeWSFuture();
+
+        } catch (Exception e) {
+        } finally {
+            _lock.unlock();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/DispatchContactInfoList.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/DispatchContactInfoList.java
new file mode 100644
index 0000000..a5deb7d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/DispatchContactInfoList.java
@@ -0,0 +1,73 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.client.dispatch.impl;
+
+import java.util.ArrayList;
+
+import javax.xml.ws.http.HTTPBinding;
+import javax.xml.ws.soap.SOAPBinding;
+
+import com.sun.xml.internal.ws.pept.ept.ContactInfoList;
+import com.sun.xml.internal.ws.pept.ept.ContactInfoListIterator;
+import com.sun.xml.internal.ws.client.ContactInfoBase;
+import com.sun.xml.internal.ws.client.ContactInfoListIteratorBase;
+import com.sun.xml.internal.ws.client.dispatch.impl.protocol.MessageDispatcherHelper;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAP12XMLDecoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAP12XMLEncoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLDecoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLEncoder;
+import com.sun.xml.internal.ws.encoding.xml.XMLDecoder;
+import com.sun.xml.internal.ws.encoding.xml.XMLEncoder;
+import com.sun.xml.internal.ws.protocol.xml.client.XMLMessageDispatcher;
+
+/**
+ * @author: WS Development Team
+ */
+public class DispatchContactInfoList implements ContactInfoList {
+
+    public ContactInfoListIterator iterator() {
+        ArrayList<Object> arrayList = new ArrayList<Object>();
+
+        arrayList.add(new ContactInfoBase(null,
+            new MessageDispatcherHelper(),
+            new SOAPXMLEncoder(),
+            new SOAPXMLDecoder(),SOAPBinding.SOAP11HTTP_BINDING));
+        arrayList.add(new ContactInfoBase(null,
+            new MessageDispatcherHelper(),
+            new SOAP12XMLEncoder(),
+            new SOAP12XMLDecoder(), SOAPBinding.SOAP12HTTP_BINDING));
+        arrayList.add(new ContactInfoBase(null,
+                new XMLMessageDispatcher(),
+                new XMLEncoder(),
+                new XMLDecoder(), HTTPBinding.HTTP_BINDING));
+        /*arrayList.add(new DispatchContactInfo(null,
+                new MessageDispatcherHelper(new DispatchEncoderDecoderUtil()),
+                new SOAPFastEncoder(new DispatchEncoderDecoderUtil()),
+                new SOAPFastDecoder(new DispatchEncoderDecoderUtil())));
+          */
+        return new ContactInfoListIteratorBase(arrayList);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/DispatchDelegate.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/DispatchDelegate.java
new file mode 100644
index 0000000..bb26dba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/DispatchDelegate.java
@@ -0,0 +1,119 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client.dispatch.impl;
+
+import com.sun.xml.internal.ws.pept.ept.ContactInfo;
+import com.sun.xml.internal.ws.pept.ept.ContactInfoList;
+import com.sun.xml.internal.ws.pept.ept.ContactInfoListIterator;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.encoding.soap.internal.DelegateBase;
+import com.sun.xml.internal.ws.client.*;
+
+import javax.xml.ws.BindingProvider;
+import javax.xml.ws.WebServiceException;
+import java.util.logging.Logger;
+import java.util.logging.Level;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+
+/**
+ * @author WS Development Team
+ */
+public class DispatchDelegate extends DelegateBase {
+
+    private static final Logger logger =
+        Logger.getLogger(new StringBuffer().append(com.sun.xml.internal.ws.util.Constants.LoggingDomain).append(".client.dispatch").toString());
+
+    public DispatchDelegate() {
+    }
+
+    public DispatchDelegate(ContactInfoList contactInfoList) {
+        this.contactInfoList = contactInfoList;
+    }
+
+    public void send(MessageStruct messageStruct) {
+        MessageInfo messageInfo = (MessageInfo) messageStruct;
+
+        ContextMap properties = (ContextMap)
+                messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        BindingProvider dispatch = (BindingProvider)properties.get(BindingProviderProperties.JAXWS_CLIENT_HANDLE_PROPERTY);
+
+        if (!contactInfoList.iterator().hasNext())
+            throw new WebServiceException("can't pickup message encoder/decoder, no ContactInfo!");
+
+
+        BindingImpl bi = (BindingImpl)dispatch.getBinding();
+        String bindingId = bi.getBindingId();
+        ContactInfo contactInfo = getContactInfo(contactInfoList, bindingId);
+        messageInfo.setEPTFactory(contactInfo);
+        messageInfo.setConnection(contactInfo.getConnection(messageInfo));
+
+        MessageDispatcher messageDispatcher =
+            contactInfo.getMessageDispatcher(messageInfo);
+        messageDispatcher.send(messageInfo);
+    }
+
+     private ContactInfo getContactInfo(ContactInfoList cil, String bindingId){
+        ContactInfoListIterator iter = cil.iterator();
+        while(iter.hasNext()){
+            ContactInfoBase cib = (ContactInfoBase)iter.next();
+            if(cib.getBindingId().equals(bindingId))
+                return cib;
+        }
+        //return the first one
+        return cil.iterator().next();
+    }
+    /*private ContactInfo getContactInfo(ContactInfoListIterator iterator, MessageStruct messageStruct) {
+        if (!iterator.hasNext())
+            throw new RuntimeException("no next");
+
+        ContactInfo contactInfo = iterator.next();
+        //Todo: use Map
+        //if fast encoding go to next
+         if (isFastEncoding((RequestContext)
+                 messageStruct.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY))) {
+             if (iterator.hasNext())
+                 contactInfo = iterator.next();
+             else {
+                 if (logger.isLoggable(Level.INFO))     //needs localicalization
+                     logger.info("Defaulting to XML Encoding. ");
+                 setDefaultEncoding((RequestContext)
+                         messageStruct.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY));
+             }
+         } else
+             setDefaultEncoding((RequestContext)
+                     messageStruct.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY));
+
+        return contactInfo;
+    }
+ */
+
+     private void setDefaultEncoding(RequestContext requestContext) {
+         requestContext.put(BindingProviderProperties.ACCEPT_ENCODING_PROPERTY,
+                 BindingProviderProperties.XML_ENCODING_VALUE);
+     }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/encoding/DispatchSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/encoding/DispatchSerializer.java
new file mode 100644
index 0000000..e38177d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/encoding/DispatchSerializer.java
@@ -0,0 +1,326 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.client.dispatch.impl.encoding;
+
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBeanInfo;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.SerializationException;
+import com.sun.xml.internal.ws.streaming.Attributes;
+import com.sun.xml.internal.ws.streaming.SourceReaderFactory;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.streaming.XMLStreamWriterFactory;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.namespace.QName;
+import static javax.xml.stream.XMLStreamConstants.*;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.transform.Source;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.ws.WebServiceException;
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.util.logging.Logger;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Set;
+import java.util.HashMap;
+
+/**
+ * @author WS Development Team
+ */
+public final class DispatchSerializer {
+
+    private static final Logger logger =
+        Logger.getLogger(new StringBuffer().append(com.sun.xml.internal.ws.util.Constants.LoggingDomain).append(".client.dispatch").toString());
+
+    private final QName bodyTagName;
+
+    /**
+     * For SOAP 1.0.
+     */
+    public static final DispatchSerializer SOAP_1_0 = new DispatchSerializer(SOAPConstants.QNAME_SOAP_BODY);
+
+    /**
+     * For SOAP 1.2.
+     */
+    public static final DispatchSerializer SOAP_1_2 = new DispatchSerializer(SOAP12Constants.QNAME_SOAP_BODY);
+
+
+    private DispatchSerializer(QName soapBodyTagName) {
+        bodyTagName = soapBodyTagName;
+    }
+
+    public void serialize(Object obj, XMLStreamWriter writer, JAXBContext context) {
+        if (obj instanceof Source)
+            serializeSource(obj, writer);
+        else if (obj instanceof JAXBBeanInfo) {
+            ((JAXBBeanInfo) obj).writeTo(writer);
+        } else
+            throw new WebServiceException("Unable to serialize object type " + obj.getClass().getName());
+        //should not happen
+    }
+
+
+    private static String convertNull(String s) {
+        return (s != null) ? s : "";
+    }
+
+    // this is very very inefficient.
+    //kw-needs lots of cleanup
+    //kw-modifying this in any way will cause dispatch tests sqe failures
+    public Source deserializeSource(XMLStreamReader reader, DispatchUtil dispatchUtil) {
+
+        ByteArrayBuffer baos = new ByteArrayBuffer();
+        XMLStreamWriter writer = XMLStreamWriterFactory.createXMLStreamWriter(baos);
+        dispatchUtil.populatePrefixes(writer);
+        try {
+            while (reader.hasNext()) {
+                int state = reader.getEventType();
+                switch (state) {
+                    case START_ELEMENT:
+
+                        String uri = reader.getNamespaceURI();
+                        String rprefix = reader.getPrefix();
+                        String nlocal = reader.getLocalName();
+                        setWriterPrefixes(rprefix, uri, writer);
+
+                        String prefix = null;
+                        String wprefix = writer.getNamespaceContext().getPrefix(uri);
+                        if ((wprefix != null && !"".equals(wprefix)) && wprefix.length() > 0){
+                            prefix = wprefix;
+                        } else
+                        if ((rprefix != null && !"".equals(rprefix)) && (uri != null && !"null".equals(uri))){
+                            prefix = setWriterPrefixes(reader, uri, writer);
+                        } else {
+                            prefix = convertNull(prefix);
+                            uri = convertNull(uri);
+                        }
+
+                        writer.writeStartElement(prefix, nlocal, uri);
+                        writer.writeNamespace(prefix, uri);
+
+                        Attributes atts = XMLStreamReaderUtil.getAttributes(reader);
+                        writer.flush();
+                        writeAttributes(atts, writer, prefix, uri);
+                        break;
+                    case END_ELEMENT:
+                        writer.writeEndElement();
+                        break;
+                    case CHARACTERS:
+                        writer.writeCharacters(reader.getText());
+
+                }
+                state = XMLStreamReaderUtil.next(reader);
+                if ((reader.getEventType() == END_ELEMENT) && (reader.getName().equals(bodyTagName)))
+                    break;
+            }
+            writer.flush();
+            writer.close();
+            reader.close();
+        } catch (XMLStreamException ex) {
+            ex.printStackTrace();
+        }
+
+        return new StreamSource(baos.newInputStream());
+    }
+
+    private void writeAttributes(Attributes atts, XMLStreamWriter writer, String prefix, String uri) throws XMLStreamException {
+        for (int i = 0; i < atts.getLength(); i++) {
+
+            String value = atts.getValue(i);
+            String localName = atts.getName(i).getLocalPart();
+            String aprefix = atts.getPrefix(i);
+            String auri = atts.getURI(i);
+
+            setWriterPrefix(localName, value, aprefix, writer);
+            if (atts.isNamespaceDeclaration(i)) {
+                writeAttrNamespace(aprefix, auri, writer, localName, prefix, uri, value);
+            } else {
+                writeAttribute(atts, i, writer);
+            }
+        }
+    }
+
+    private void setWriterPrefix(String localName, String value, String aprefix, XMLStreamWriter writer) throws XMLStreamException {
+        if (localName.equals("xsi") &&
+            value.equals("http://www.w3.org/2001/XMLSchema-instance") &&
+            aprefix.equals("xmlns")) {
+            //kw was aa prefix
+            writer.setPrefix(localName, value);
+        }
+    }
+
+    private String setWriterPrefixes(XMLStreamReader reader, String nuri, XMLStreamWriter writer) {
+
+        String prefix = reader.getNamespaceContext().getPrefix(nuri);
+        if (prefix == null)
+            prefix = convertNull(prefix);
+        if (prefix != null && prefix.length() > 0 && nuri != null && !prefix.equals("xmlns"))        {
+            try {
+                writer.setPrefix(prefix, nuri);
+            } catch (Exception e) {
+                e.printStackTrace();
+            }
+        }
+        return prefix;
+    }
+
+    private void setWriterPrefixes(String npre, String nuri, XMLStreamWriter writer) throws XMLStreamException {
+        if ((npre != null && npre.length() > 0) && (nuri.length() > 0 && nuri != null))
+        {
+            if ((npre.equals("null") || nuri.equals("null"))) {
+                writer.setPrefix(npre, nuri);
+            }
+        }
+    }
+
+    private void writeAttrNamespace(String aprefix, String auri, XMLStreamWriter writer, String localName, String prefix, String nuri, String value) throws XMLStreamException {
+        if (aprefix == null || !aprefix.equals("") || (aprefix.equals("xmlns")))
+        {
+            String temp = aprefix;
+            if (auri != null) {
+                String wprefix = writer.getNamespaceContext().getPrefix(auri);
+                if (aprefix.equals("xmlns") && !(localName.equals("xsi"))){
+                    aprefix = prefix;
+                    auri = nuri;
+                } else {
+                    if (wprefix != null && !wprefix.equals("xmlns")) {
+                        aprefix = wprefix;
+                    }
+                }
+                if (aprefix == null)
+                    convertNull(aprefix);
+            }
+
+            writeNamespace(aprefix, prefix, auri, nuri, writer);
+            writeXSINamspece(localName, value, temp, writer, aprefix, auri);
+        }
+    }
+
+    private void writeNamespace(String aprefix, String prefix, String auri, String nuri, XMLStreamWriter writer) throws XMLStreamException {
+        if (!(aprefix.equals(prefix) && auri.equals(nuri))){
+            if (!aprefix.equals("xmlns")) {
+                writer.writeNamespace(aprefix, auri);
+            }
+        }
+    }
+
+    private void writeXSINamspece(String localName, String value, String temp, XMLStreamWriter writer, String aprefix, String auri) throws XMLStreamException {
+        if (localName.equals("xsi") &&
+            value.equals("http://www.w3.org/2001/XMLSchema-instance") &&
+            temp.equals("xmlns")) {
+            writer.setPrefix(localName, value);
+            writer.writeAttribute(aprefix, auri, localName, value);
+        }
+    }
+
+    private void writeAttribute(Attributes atts, int i, XMLStreamWriter writer) throws XMLStreamException {
+        if ((atts.getURI(i) == null) && (atts.getPrefix(i) != null))        {
+            String ns = writer.getNamespaceContext().getNamespaceURI(atts.getURI(i));
+            writer.writeAttribute(atts.getPrefix(i), ns, atts.getLocalName(i),
+                atts.getValue(i));
+        }
+        writer.writeAttribute(atts.getPrefix(i), atts.getURI(i), atts.getLocalName(i), atts.getValue(i));
+    }
+
+    void serializeSource(Object source, XMLStreamWriter writer) {
+        try {
+            XMLStreamReader reader = SourceReaderFactory.createSourceReader((Source) source, true);
+
+            int state;
+            do {
+                state = XMLStreamReaderUtil.next(reader);
+                switch (state) {
+                    case START_ELEMENT:
+                        QName elementName = reader.getName();
+                        String localPart = elementName.getLocalPart();
+                        String namespaceURI = elementName.getNamespaceURI();
+                        String prefix = elementName.getPrefix();
+
+                        writer.writeStartElement(prefix, localPart, namespaceURI);
+
+                        Attributes atts = XMLStreamReaderUtil.getAttributes(reader);
+                        writer.flush();
+                        for (int i = 0; i < atts.getLength(); i++) {
+                            if (atts.isNamespaceDeclaration(i)) {
+                                String value = atts.getValue(i);
+                                String localName = atts.getName(i).getLocalPart();
+                                writer.setPrefix(localName, value);
+                                writer.writeNamespace(localName, value);
+                            } else {
+                                writer.writeAttribute(atts.getPrefix(i), atts.getURI(i),
+                                    atts.getLocalName(i), atts.getValue(i));
+                            }
+                        }
+                        break;
+                    case END_ELEMENT:
+                        writer.writeEndElement();
+                        break;
+                    case CHARACTERS:
+                        writer.writeCharacters(reader.getText());
+                }
+            } while (state != END_DOCUMENT);
+        } catch (XMLStreamException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+//    private void displayDOM(Node node, java.io.OutputStream ostream) {
+//        try {
+//            System.out.println("\n====\n");
+//            javax.xml.transform.TransformerFactory.newInstance().newTransformer().transform(new javax.xml.transform.dom.DOMSource(node),
+//                new javax.xml.transform.stream.StreamResult(ostream));
+//            System.out.println("\n====\n");
+//        } catch (Exception e) {
+//            e.printStackTrace();
+//        }
+//    }
+
+//    private String sourceToXMLString(Source result) {
+//        String xmlResult = null;
+//        try {
+//            TransformerFactory factory = TransformerFactory.newInstance();
+//            Transformer transformer = factory.newTransformer();
+//            transformer.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
+//            transformer.setOutputProperty(OutputKeys.METHOD, "xml");
+//            OutputStream out = new ByteArrayOutputStream();
+//            StreamResult streamResult = new StreamResult();
+//            streamResult.setOutputStream(out);
+//            transformer.transform(result, streamResult);
+//            xmlResult = streamResult.getOutputStream().toString();
+//        } catch (TransformerException e) {
+//            e.printStackTrace();
+//        }
+//        return xmlResult;
+//    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/encoding/DispatchUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/encoding/DispatchUtil.java
new file mode 100644
index 0000000..a67f27a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/encoding/DispatchUtil.java
@@ -0,0 +1,72 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.client.dispatch.impl.encoding;
+
+import com.sun.xml.internal.ws.streaming.XMLStreamWriterFactory;
+
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.namespace.QName;
+import java.util.Map;
+import java.util.HashMap;
+import java.util.Set;
+
+public class DispatchUtil {
+
+    private Map<String, String> namespacePrefixMap;
+
+    public void clearNPMap() {
+        namespacePrefixMap.clear();
+    }
+
+    public void populatePrefixes(XMLStreamWriter writer) {
+        if (!namespacePrefixMap.isEmpty()) {
+            Set<Map.Entry<String, String>> entrys = namespacePrefixMap.entrySet();
+            for (Map.Entry<String, String> entry : entrys) {
+                try {
+                    writer.setPrefix(entry.getValue(), entry.getKey());
+                } catch (XMLStreamException e) {
+                    e.printStackTrace();
+                }
+            }
+        }
+    }
+
+    public void collectPrefixes(XMLStreamReader reader) {
+        if (namespacePrefixMap == null)
+            namespacePrefixMap = new HashMap<String, String>();
+
+        int i = reader.getNamespaceCount();
+        for (int j = 0; j < i; j++){
+            String prefix = reader.getNamespacePrefix(j);
+            String namespace = reader.getNamespaceURI(j);
+            if (prefix.length() > 0 && namespace != null) {
+                namespacePrefixMap.put(namespace, prefix);
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/protocol/MessageDispatcherHelper.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/protocol/MessageDispatcherHelper.java
new file mode 100644
index 0000000..dfab855
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/dispatch/impl/protocol/MessageDispatcherHelper.java
@@ -0,0 +1,76 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.client.dispatch.impl.protocol;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.client.ContextMap;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.protocol.soap.client.SOAPMessageDispatcher;
+
+import javax.xml.ws.BindingProvider;
+import javax.xml.ws.WebServiceException;
+import java.util.logging.Logger;
+
+/**
+ * @author WS Development Team
+ */
+public class MessageDispatcherHelper extends SOAPMessageDispatcher
+    implements BindingProviderProperties {
+
+    private static final Logger logger =
+        Logger.getLogger(new StringBuffer().append(com.sun.xml.internal.ws.util.Constants.LoggingDomain).append(".client.dispatch").toString());
+
+    public MessageDispatcherHelper() {
+        super();
+    }
+
+    @Override
+    protected void setResponseType(Throwable e, MessageInfo messageInfo) {
+        if (e instanceof RuntimeException) {
+            //leave for now- fix later
+            if (e instanceof WebServiceException)
+                messageInfo.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+            else
+                messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+        } else {
+            messageInfo.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+        }
+    }
+
+    @Override
+    protected HandlerChainCaller getHandlerChainCaller(MessageInfo messageInfo) {
+        ContextMap context = (ContextMap)
+            messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        BindingProvider provider = (BindingProvider)
+            context.get(BindingProviderProperties.JAXWS_CLIENT_HANDLE_PROPERTY);
+        BindingImpl binding = (BindingImpl) provider.getBinding();
+        return binding.getHandlerChainCaller();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/client/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/package-info.java
new file mode 100644
index 0000000..7bf1258
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/client/package-info.java
@@ -0,0 +1,273 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *  <h1>JAX-WS 2.0 Client Runtime</h1>
+ * <P>This document describes the architecture of client side
+ * JAX-WS 2.0 runtime.
+ *
+ * <h3>JAX-WS 2.0 Server Client Sequence Diagram</h3>
+ * {@SequenceDiagram
+ *    pobject(U,"user");
+ *   object(A,"EndpointIFInvocationHandler");
+ *   object(B,"DelegateBase");
+ *   object(C,"MessageDispatcher");
+ *   object(D,"Encoder/Decoder");
+ *   object(F,"WSConnection");
+ *   step();
+ *
+ *   message(U,A,"invoke Web Service");
+ *   active(A);
+ *   message(A,A,"invoke");
+ *   active(A);
+ *   step();
+ *   inactive(A);
+ *#    step();
+ *
+ *   message(A,A,"implementSEIMethod");
+ *   active(A);
+ *   step();
+ *   inactive(A);
+ *
+ *   message(A,B,"send");
+ *   active(B);
+ *
+ *   message(B,B,"getContactInfo");
+ *   active(B);
+ *   step();
+ *   inactive(B);
+ *
+ *   message(B,B,"getMessageDispatcher");
+ *   active(B);
+ *   step();
+ *  inactive(B);
+ *
+ *   message(B,C,"send");
+ *   active(C);
+ *#    step();
+ *#    inactive(B);
+ *
+ *#    message(C,C,"doSend");
+ *#    active(C);
+ *#    step();
+ *#    inactive(C);
+ *
+ *#    active(C);
+ *   message(C,D,"toInternalMessage");
+ *   active(D);
+ *   step();
+ *   inactive(D);
+ *
+ *   message(C,D,"toSOAPMessage");
+ *   active(D);
+ *   step();
+ *   inactive(D);
+ *
+ *   message(C,C,"invokeHandlers");
+ *   active(C);
+ *   step();
+ *   inactive(C);
+ *
+ *   message(C,F,"setHeaders");
+ *   active(F);
+ *   step();
+ *   inactive(F);
+ *
+ *   message(C,F,"getOutput");
+ *   active(F);
+ *   step();
+ *   inactive(F);
+ *
+ *   message(C,F,"writeTo");
+ *   active(F);
+ *   step();
+ *   inactive(F);
+ *
+ *#    message(C,C,"receive");
+ *#    active(C);
+ *#    step();
+ *#    inactive(C);
+ *
+ *   message(C,F,"readSOAPMessage");
+ *   active(F);
+ *   step();
+ *   inactive(F);
+ *
+ *   message(C,C,"mustUnderstand");
+ *   active(C);
+ *   step();
+ *   inactive(C);
+ *
+ *  message(C,C,"invokeHandlers");
+ *  active(C);
+ *  step();
+ *  inactive(C);
+ *
+ *  message(C,D,"toInternalMessage");
+ *  active(D);
+ *  step();
+ *  inactive(D);
+ *
+ *#    message(C,C,"doSendAsync");
+ *#    active(C);
+ *#    step();
+ *#    inactive(C);
+ *
+ *#    message(C,C,"sendAsyncReceive");
+ *#    active(C);
+ *#    step();
+ *#    inactive(C);
+ *
+ *   rmessage(C,B,"response");
+ *   inactive(C);
+ *
+ *   rmessage(B,A,"response");
+ *   inactive(B);
+ *
+ *   rmessage(A,U,"response");
+ *   complete(A);
+ * }
+ *
+ * <H3>Message Flow</H3>
+ * {@link com.sun.xml.internal.ws.client.WebService} provides client view of a Web service.
+ * WebService.getPort returns an instance of {@link com.sun.xml.internal.ws.client.EndpointIFInvocationHandler}
+ * with {@link com.sun.pept.ept.ContactInfoList} and {@link com.sun.pept.Delegate}
+ * initialized. A method invocation on the port, obtained from WebService, invokes
+ * {@link com.sun.xml.internal.ws.client.EndpointIFInvocationHandler#invoke}. This method
+ * then creates a {@link com.sun.pept.ept.MessageInfo} and populates the data
+ * (parameters specified by the user) and metadata such as RuntimeContext, RequestContext,
+ * Message Exchange Pattern into this MessageInfo. This method then invokes
+ * {@link com.sun.pept.Delegate#send} and returns the response.
+ * <P></P>
+ * The Delegate.send method iterates through the ContactInfoList and picks up the
+ * correct {@link com.sun.pept.ept.ContactInfo} based upon the binding id of
+ * {@link javax.xml.ws.BindingProvider} and sets it on the MessageInfo. After the
+ * Delegate obtains a specific ContactInfo it uses that ContactInfo to obtain a
+ * protocol-specific {@link com.sun.pept.protocol.MessageDispatcher}. There will be
+ * two types of client-side MessageDispatchers for JAX-WS 2.0 FCS,
+ * {@link com.sun.xml.internal.ws.protocol.soap.client.SOAPMessageDispatcher} and
+ * {@link com.sun.xml.internal.ws.protocol.xml.client.XMLMessageDispatcher}. The Delegate
+ * then invokes {@link com.sun.pept.protocol.MessageDispatcher#send}. The
+ * MessageDispatcher.send method makes a decision about the synchronous and
+ * asynchronous nature of the message exchange pattern and invokes separate methods
+ * accordingly.
+ * <p></P>
+ * The MessageDispatcher uses ContactInfo to obtain
+ * a {@link com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLEncoder} which converts
+ * the MessageInfo to {@link com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage}.
+ * There will be two types of client-side SOAPXMLEncoder for JAX-WS 2.0 FCS,
+ * SOAPXMEncoder for SOAP 1.1 and {@link com.sun.xml.internal.ws.encoding.soap.client.SOAP12XMLEncoder}
+ * for SOAP 1.2. The MessageDispatcher invokes configured handlers and use the
+ * encoder to convert the InternalMessage to a {@link javax.xml.soap.SOAPMessage}.
+ * The metadata from the MessageInfo is classified into {@link javax.xml.soap.MimeHeaders}
+ * of this SOAPMessage and context information for {@link com.sun.xml.internal.ws.spi.runtime.WSConnection}.
+ * The SOAPMessge is then written to the output stream of the WSConnection
+ * obtained from MessageInfo.
+ *<P></P>
+ * The MessageDispatcher.receive method handles the response. The
+ * SOAPMessageDispatcher extracts the SOAPMessage from the input stream of
+ * WSConnection and performs the mustUnderstand processing followed by invocation
+ * of any handlers. The MessageDispatcher uses ContactInfo to obtain a
+ * {@link com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLDecoder} which converts the SOAPMessage
+ * to InternalMessage and then InternalMessage to MessageInfo. There will be two types of
+ * client-side SOAPXMLDecoder for JAX-WS 2.0 FCS, SOAPXMLDencoder for SOAP 1.1 and
+ * {@link com.sun.xml.internal.ws.encoding.soap.client.SOAP12XMLDecoder} for SOAP 1.2. The
+ * response is returned back to the client code via Delegate.
+ *
+ * <H3>External Interactions</H3>
+ * <H4>SAAJ API</H4>
+ * <UL>
+ *      <LI><P>JAX-WS creates SAAJ SOAPMessage from the HttpServletRequest.
+ *      At present, JAX-WS reads all the bytes from the request stream and
+ *      then creates SOAPMessage along with the HTTP headers.</P>
+ * </UL>
+ * <P>MessageFactory(binding).createMessage(MimeHeaders, InputStream)</P>
+ * <UL>
+ *      <LI><P>SOAPMessage parses the content from the stream including MIME
+ *      data</P>
+ *      <LI><P>com.sun.xml.internal.ws.server.SOAPMessageDispatcher::checkHeadersPeekBody()</P>
+ *      <P>SOAPMessage.getSOAPHeader() is used for mustUnderstand processing
+ *      of headers. It further uses
+ *      SOAPHeader.examineMustUnderstandHeaderElements(role)</P>
+ *      <P>SOAPMessage.getSOAPBody().getFistChild() is used for guessing the
+ *      MEP of the request</P>
+ *      <LI><P>com.sun.xml.internal.ws.handler.HandlerChainCaller:insertFaultMessage()</P>
+ *      <P>SOAPMessage.getSOAPPart().getEnvelope() and some other SAAJ calls
+ *      are made to create a fault in the SOAPMessage</P>
+ *      <LI><P>com.sun.xml.internal.ws.handler.LogicalMessageImpl::getPayload()
+ *      interacts with SAAJ to get body from SOAPMessage</P>
+ *      <LI><P>com.sun.xml.internal.ws.encoding.soap.SOAPEncoder.toSOAPMessage(com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage,
+ *      SOAPMessage). There is a scenario where there is SOAPMessage and a
+ *      logical handler sets payload as Source. To write to the stream,
+ *      SOAPMessage.writeTo() is used but before that the body needs to be
+ *      updated with logical handler' Source. Need to verify if this
+ *      scenario is still happening since Handler.close() is changed to take
+ *      MessageContext.</P>
+ *      <LI><P>com.sun.xml.internal.ws.handlerSOAPMessageContextImpl.getHeaders()
+ *      uses SAAJ API to get headers.</P>
+ *      <LI><P>SOAPMessage.writeTo() is used to write response. At present,
+ *      it writes into byte[] and this byte[] is written to
+ *      HttpServletResponse.</P>
+ * </UL>
+ * <H4>JAXB API</H4>
+ * <P>JAX-WS RI uses the JAXB API to marshall/unmarshall user created
+ * JAXB objects with user created {@link javax.xml.bind.JAXBContext JAXBContext}.
+ * Handler, Dispatch in JAX-WS API provide ways for the user to specify his/her own
+ * JAXBContext. {@link com.sun.xml.internal.ws.encoding.jaxb.JAXBTypeSerializer JAXBTypeSerializer} class uses all these methods.</P>
+ * <UL>
+ *      <LI><p>{@link javax.xml.bind.Marshaller#marshal(Object,XMLStreamWriter) Marshaller.marshal(Object,XMLStreamWriter)}</p>
+ *      <LI><P>{@link javax.xml.bind.Marshaller#marshal(Object,Result) Marshaller.marshal(Object, DomResult)}</P>
+ *      <LI><P>{@link javax.xml.bind.Unmarshaller#unmarshal(XMLStreamReader) Object Unmarshaller.unmarshal(XMLStreamReader)}</P>
+ *      <LI><P>{@link javax.xml.bind.Unmarshaller#unmarshal(Source) Object Unmarshaller.unmarshal(Source)}</P>
+ * </UL>
+ * The following two JAXB classes are implemented by JAX-WS to enable/implement MTOM and XOP
+ * <UL>
+ *      <LI><P>{@link javax.xml.bind.attachment.AttachmentMarshaller AttachmentMarshaller}</P>
+ *      <LI><P>{@link javax.xml.bind.attachment.AttachmentUnmarshaller AttachmentUnmarshaller}</P>
+ * </UL>
+ * <H4>JAXB Runtime-API (private contract)</H4>
+ * <P>JAX-WS RI uses these private API for serialization/deserialization
+ * purposes. This private API is used to serialize/deserialize method
+ * parameters at the time of JAXBTypeSerializer class uses all
+ * these methods.</P>
+ * <UL>
+ *      <LI><P>{@link com.sun.xml.internal.bind.api.Bridge#marshal(BridgeContext, Object, XMLStreamWriter) Bridge.marshal(BridgeContext, Object, XMLStreamWriter)}</P>
+ *      <LI><P>{@link com.sun.xml.internal.bind.api.Bridge#marshal(BridgeContext, Object, Node) Bridge.marshal(BridgeContext, Object, Node)}</P>
+ *      <LI><P>{@link com.sun.xml.internal.bind.api.Bridge#unmarshal(BridgeContext, XMLStreamReader) Object Bridge.unmarshal(BridgeContext, XMLStreamReader)}</P>
+ * </UL>
+ *
+ * @ArchitectureDocument
+ **/
+package com.sun.xml.internal.ws.client;
+
+import com.sun.xml.internal.bind.api.BridgeContext;
+
+import javax.xml.ws.Binding;
+import javax.xml.transform.Result;
+import javax.xml.transform.Source;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+
+import org.w3c.dom.Node;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/developer/JAXWSProperties.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/developer/JAXWSProperties.java
new file mode 100644
index 0000000..9dfca16
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/developer/JAXWSProperties.java
@@ -0,0 +1,34 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.developer;
+
+public interface JAXWSProperties {
+        // Some values are split into two strings so that package renaming for
+        // mustang doesn't alter the values. So do not combine them
+    // Content negotiation property: values "none", "pessimistic" and "optimistic"
+    public static final String CONTENT_NEGOTIATION_PROPERTY = "com.sun."+ "xml.ws.client.ContentNegotiation";
+    public static final String MTOM_THRESHOLOD_VALUE =  "com.sun.xml.internal.ws.common.MtomThresholdValue";
+    public static final String HTTP_EXCHANGE = "com.sun.xml.internal.ws.http.exchange";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/EncoderDecoderBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/EncoderDecoderBase.java
new file mode 100644
index 0000000..386f41c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/EncoderDecoderBase.java
@@ -0,0 +1,140 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.bind.api.AccessorException;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.bind.api.RawAccessor;
+import com.sun.xml.internal.ws.encoding.soap.SerializationException;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+
+import javax.xml.bind.JAXBException;
+import java.util.Map;
+
+/**
+ * @author Vivek Pandey
+ *
+ * Base Abstract class to be used for encoding-decoding a given binding.
+ */
+public abstract class EncoderDecoderBase {
+    /**
+     * Creates an internal message based thats binding dependent.
+     *
+     * @param messageInfo
+     * @return the internal message given a messageInfo
+     */
+    public Object toInternalMessage(MessageInfo messageInfo) {
+        throw new UnsupportedOperationException("Not Implementated!");
+    }
+
+    /**
+     * Fills in MessageInfo from binding dependent internal message.
+     *
+     * @param internalMessage
+     * @param messageInfo
+     */
+    public void toMessageInfo(Object internalMessage, MessageInfo messageInfo) {
+        throw new UnsupportedOperationException("Not Implementated!");
+    }
+
+    /**
+     * Get the wrapper child value from a jaxb style wrapper bean.
+     *
+     * @param context
+     *            RuntimeContext to be passed by the encoder/decoder processing
+     *            SOAP message during toMessageInfo()
+     * @param wrapperBean
+     *            The wrapper bean instance
+     * @param nsURI
+     *            namespace of the wrapper child property
+     * @param localName
+     *            local name of the wrapper child property
+     * @return The wrapper child
+     *
+     */
+    protected Object getWrapperChildValue(RuntimeContext context, Object wrapperBean, String nsURI,
+            String localName) {
+        if (wrapperBean == null)
+            return null;
+
+        RawAccessor ra = getRawAccessor(context, wrapperBean.getClass(), nsURI, localName);
+        try {
+            return ra.get(wrapperBean);
+        } catch (AccessorException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    /**
+     * Set the wrapper child value from a jaxb style wrapper bean.
+     *
+     * @param context
+     *            context RuntimeContext to be passed by the encoder/decoder
+     *            processing SOAP message during toMessageInfo()
+     * @param wrapperBean
+     *            The wrapper bean instance
+     * @param value
+     *            value of the wrapper child property
+     * @param nsURI
+     *            namespace of the wrapper child property
+     * @param localName
+     *            localName local name of the wrapper child property
+     */
+    protected void setWrapperChildValue(RuntimeContext context, Object wrapperBean, Object value,
+            String nsURI, String localName) {
+        if (wrapperBean == null)
+            return;
+        RawAccessor ra = getRawAccessor(context, wrapperBean.getClass(), nsURI, localName);
+        try {
+            ra.set(wrapperBean, value);
+        } catch (AccessorException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    private RawAccessor getRawAccessor(RuntimeContext context, Class wrapperBean, String nsURI, String localName){
+        RuntimeModel model = context.getModel();
+        Map<Integer, RawAccessor> map = model.getRawAccessorMap();
+        int id  = getHashCode(wrapperBean, nsURI, localName);
+        RawAccessor ra = map.get(id);
+        if(ra == null){
+            JAXBRIContext jaxbContext = model.getJAXBContext();
+            try {
+                ra = jaxbContext.getElementPropertyAccessor(wrapperBean, nsURI,
+                        localName);
+                map.put(id, ra);
+            } catch (JAXBException e) {
+                throw new SerializationException(e);
+            }
+        }
+        return ra;
+    }
+
+    private int getHashCode(Class bean, String uri, String pfix){
+        return bean.hashCode()+uri.hashCode()+pfix.hashCode();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/JAXWSAttachmentMarshaller.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/JAXWSAttachmentMarshaller.java
new file mode 100644
index 0000000..c95354a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/JAXWSAttachmentMarshaller.java
@@ -0,0 +1,227 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding;
+
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.spi.runtime.MtomCallback;
+import com.sun.xml.internal.ws.util.ByteArrayDataSource;
+
+import javax.activation.DataHandler;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.handler.MessageContext;
+import java.io.ByteArrayInputStream;
+import java.io.UnsupportedEncodingException;
+import java.net.MalformedURLException;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.net.URLEncoder;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.UUID;
+
+/**
+ * @author WS Development Team
+ *
+ *
+ */
+public class JAXWSAttachmentMarshaller extends AttachmentMarshaller {
+
+    public JAXWSAttachmentMarshaller(boolean isXOP){
+        this.isXOP = isXOP;
+    }
+
+    public boolean isXOPPackage() {
+        return isXOP;
+    }
+
+    /**
+     * set the XOP package if the incoming SOAP envelope is a XOP package
+     * @param isXOP
+     */
+    public void setXOPPackage(boolean isXOP){
+        this.isXOP = isXOP;
+    }
+
+    /*
+     * @see AttachmentMarshaller#addMtomAttachment(DataHandler, String, String)
+     */
+    public String addMtomAttachment(DataHandler data, String elementNamespace, String elementName) {
+        if(!isXOP)
+            return null;
+        String cid = encodeCid(elementNamespace);
+        if(cid != null){
+            String cidBracket = '<' + cid + '>';
+            attachments.put(cidBracket, AttachmentBlock.fromDataHandler(cidBracket,data));
+            addToMessageContext(cidBracket, data);
+            if(mtomCallback != null)
+                mtomCallback.addedMtomAttachment(cidBracket, data, elementNamespace, elementName);
+            isXopped = true;
+            cid = "cid:"+cid;
+        }
+        return cid;
+    }
+
+    /**
+     * <p>Consider binary <code>data</code> for optimized binary storage as an attachment.
+     * <p/>
+     * <p>Since content type is not known, the attachment's MIME content type must be set to "application/octet-stream".</p>
+     * <p/>
+     * <p/>
+     * The <code>elementNamespace</code> and <code>elementLocalName</code>
+     * parameters provide the
+     * context that contains the binary data. This information could
+     * be used by the MIME-based package processor to determine if the
+     * binary data should be inlined or optimized as an attachment.
+     *
+     * @param data             represents the data to be attached. Must be non-null. The actual data region is
+     *                         specified by <tt>(data,offset,len)</tt> tuple.
+     * @param mimeType         If the data has an associated MIME type known to JAXB, that is passed
+     *                         as this parameter. If none is known, "application/octet-stream".
+     *                         This parameter may never be null.
+     * @param elementNamespace the namespace URI of the element that encloses the base64Binary data.
+     *                         Can be empty but never null.
+     * @param elementLocalName The local name of the element. Always a non-null valid string.
+     * @return content-id URI, cid, to the attachment containing
+     *         <code>data</code> or null if data should be inlined.
+     * @see #addMtomAttachment(javax.activation.DataHandler, String, String)
+     */
+    public String addMtomAttachment(byte[] data, int offset, int len, String mimeType, String elementNamespace, String elementLocalName) {
+        if(!isXOP)
+            return null;
+
+        //TODO: With performance results we need to find out what length would need optimization
+        if(len < mtomThresholdValue)
+            return null;
+
+        //this will not be needed if saaj exposes api that takes
+        //byte[] actualData = getActualData(data, offset, len);
+
+        String cid = encodeCid(elementNamespace);
+        if(cid != null){
+            String cidBracket = '<' + cid + '>';
+            DataHandler dh = new DataHandler(new ByteArrayDataSource(data, offset, len, "application/octet-stream"));
+            attachments.put(cidBracket, AttachmentBlock.fromDataHandler(cidBracket,dh));
+            addToMessageContext(cidBracket, dh);
+            if(mtomCallback != null)
+                mtomCallback.addedMtomAttachment(cidBracket, dh, elementNamespace, elementLocalName);
+            isXopped = true;
+            cid = "cid:"+cid;
+        }
+        return cid;
+
+    }
+
+    /*
+     * @see AttachmentMarshaller#addSwaRefAttachment(DataHandler)
+     */
+    public String addSwaRefAttachment(DataHandler data) {
+        String cid = encodeCid(null);
+        if(cid != null){
+            String cidBracket = '<' + cid + '>';
+            attachments.put(cidBracket, AttachmentBlock.fromDataHandler("<"+cid+">", data));
+            addToMessageContext(cidBracket, data);
+            isXopped = false;
+            cid = "cid:"+cid;
+        }
+        return cid;
+    }
+
+    private void addToMessageContext(String cid, DataHandler dh){
+        if(hc == null)
+            return;
+        MessageContext ctxt = hc.getMessageContext();
+        if(ctxt == null)
+            return;
+        MessageContextUtil.addMessageAttachment(ctxt, cid, dh);
+    }
+
+    /**
+     *
+     * @param ns
+     * @return
+     */
+    private String encodeCid(String ns){
+        String cid="example.jaxws.sun.com";
+        String name = UUID.randomUUID()+"@";
+        if(ns != null && (ns.length() > 0)){
+            try {
+                URI uri = new URI(ns);
+                String host = uri.toURL().getHost();
+                cid = host;
+            } catch (URISyntaxException e) {
+                e.printStackTrace();
+                return null;
+            } catch (MalformedURLException e) {
+                try {
+                    cid = URLEncoder.encode(ns, "UTF-8");
+                } catch (UnsupportedEncodingException e1) {
+                    throw new WebServiceException(e);
+                }
+            }
+        }
+        return name + cid;
+    }
+
+    /**
+     * Must be called before marshalling any data.
+     * @param attachments Reference to Map from InternalMessage
+     */
+    public void setAttachments(Map<String, AttachmentBlock> attachments){
+        this.attachments = attachments;
+        isXopped = false;
+    }
+
+    public void setHandlerContaxt(HandlerContext hc){
+        this.hc = hc;
+    }
+
+    /**
+     *
+     * @return true if Xopped, false otherwise
+     */
+    public boolean isXopped() {
+        return isXopped;
+    }
+
+    public void setMtomThresholdValue(Integer mtomThresholdValue) {
+        if((mtomThresholdValue != null) && (mtomThresholdValue >=0))
+            this.mtomThresholdValue = mtomThresholdValue;
+    }
+
+    public void setMtomCallback(MtomCallback mtomCallback){
+        this.mtomCallback = mtomCallback;
+    }
+
+    private MtomCallback mtomCallback;
+    private boolean isXOP;
+    private boolean isXopped;
+    private Map<String, AttachmentBlock> attachments;
+    private HandlerContext hc;
+    private int mtomThresholdValue = 1000;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/JAXWSAttachmentUnmarshaller.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/JAXWSAttachmentUnmarshaller.java
new file mode 100644
index 0000000..b7b8964
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/JAXWSAttachmentUnmarshaller.java
@@ -0,0 +1,121 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding;
+
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.util.ASCIIUtility;
+
+import javax.activation.DataHandler;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+import javax.xml.soap.AttachmentPart;
+import javax.xml.soap.SOAPException;
+import javax.xml.ws.WebServiceException;
+import java.util.Map;
+import java.io.IOException;
+import java.io.UnsupportedEncodingException;
+import java.net.URLEncoder;
+import java.net.URLDecoder;
+
+/**
+ * @author Vivek Pandey
+ *
+ * AttachmentUnmarshaller, will be called by jaxb unmarshaller to process xop package.
+ */
+public class JAXWSAttachmentUnmarshaller extends AttachmentUnmarshaller {
+
+    /**
+     *
+     */
+    public JAXWSAttachmentUnmarshaller(){
+    }
+
+    /**
+     *
+     * @param cid
+     * @return a <code>DataHandler</code> for the attachment
+     */
+    public DataHandler getAttachmentAsDataHandler(String cid) {
+        AttachmentBlock ab = attachments.get(decodeCid(cid));
+        if(ab == null)
+            //TODO localize exception message
+            throw new IllegalArgumentException("Attachment corresponding to "+cid+ " not found!");
+        return ab.asDataHandler();
+    }
+
+    /**
+     *
+     * @param cid
+     * @return the attachment as a <code>byte[]</code>
+     */
+    public byte[] getAttachmentAsByteArray(String cid) {
+        AttachmentBlock ab = attachments.get(decodeCid(cid));
+        if(ab == null)
+            throw new IllegalArgumentException("Attachment corresponding to "+cid+ " not found!");
+        return ab.asByteArray();
+    }
+
+    /**
+     *
+     * @return true if XOPPackage
+     */
+    public boolean isXOPPackage() {
+        return isXOP;
+    }
+
+    /**
+     * set the XOP package if the incoming SOAP envelope is a XOP package
+     * @param isXOP
+     */
+    public void setXOPPackage(boolean isXOP){
+        this.isXOP = isXOP;
+    }
+
+    /**
+     * Must be called before marshalling any data.
+     * @param attachments Reference to Map from InternalMessage
+     */
+    public void setAttachments(Map<String, AttachmentBlock> attachments){
+        this.attachments = attachments;
+    }
+
+    /**
+     *
+     * @param cid
+     * @return
+     */
+    private String decodeCid(String cid){
+        if(cid.startsWith("cid:"))
+            cid = cid.substring(4, cid.length());
+//        try {       // Added fix for CR 6456442
+            //return "<"+URLDecoder.decode(cid, "UTF-8")+">";
+            return "<"+cid+">";
+//        } catch (UnsupportedEncodingException e) {
+//            throw new WebServiceException(e);
+//        }
+    }
+
+    private Map<String, AttachmentBlock> attachments;
+    private boolean isXOP;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/internal/InternalEncoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/internal/InternalEncoder.java
new file mode 100644
index 0000000..49ce608
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/internal/InternalEncoder.java
@@ -0,0 +1,34 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.internal;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+
+/**
+ * Payload is converted from one form to the other
+ */
+public interface InternalEncoder {
+    public void toMessageInfo(Object intMessage, MessageInfo mi);
+    public Object toInternalMessage(MessageInfo mi);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBBeanInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBBeanInfo.java
new file mode 100644
index 0000000..87b6c96
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBBeanInfo.java
@@ -0,0 +1,111 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.jaxb;
+
+import com.sun.xml.internal.ws.encoding.soap.SerializationException;
+import com.sun.xml.internal.bind.api.BridgeContext;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.Source;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamReader;
+import java.io.OutputStream;
+
+/**
+ * XML infoset represented as a JAXB object.
+ *
+ * @author WS Development Team
+ */
+public final class JAXBBeanInfo {
+    private final Object jaxbBean;
+    private JAXBContext jaxbContext;
+    private BridgeContext bc;
+    private Marshaller marshaller;
+    private Unmarshaller unmarshaller;
+
+    public JAXBBeanInfo(Object payload, JAXBContext jaxbContext) {
+        this.jaxbBean = payload;
+        this.jaxbContext = jaxbContext;
+    }
+
+    public static JAXBBeanInfo fromSource(Source source, JAXBContext context) {
+        Object obj = JAXBTypeSerializer.deserialize(source, context);
+        return new JAXBBeanInfo(obj, context);
+    }
+
+    public static JAXBBeanInfo fromStAX(XMLStreamReader reader, JAXBContext context) {
+
+        Object obj = JAXBTypeSerializer.deserialize(reader, context);
+        return new JAXBBeanInfo(obj, context);
+    }
+
+    public static JAXBBeanInfo fromStAX(XMLStreamReader reader, JAXBContext context, Unmarshaller um) {
+
+        Object obj = JAXBTypeSerializer.deserialize(reader, context, um);
+        return new JAXBBeanInfo(obj, context);
+    }
+
+
+
+    public Object getBean() {
+        return jaxbBean;
+    }
+
+    public JAXBContext getJAXBContext() {
+        return jaxbContext;
+    }
+
+    /**
+     * Creates a {@link DOMSource} from this JAXB bean.
+     */
+    public DOMSource toDOMSource() {
+        return JAXBTypeSerializer.serialize(jaxbBean,jaxbContext);
+    }
+
+    /**
+     * Writes this bean to StAX.
+     */
+        public void writeTo(XMLStreamWriter w) {
+            if (marshaller != null)
+                JAXBTypeSerializer.serialize(jaxbBean, w, jaxbContext, marshaller);
+            else
+            JAXBTypeSerializer.serialize(jaxbBean, w, jaxbContext);
+        }
+
+        public void writeTo(OutputStream os) {
+            if (marshaller != null)
+                JAXBTypeSerializer.serialize(jaxbBean, os, jaxbContext, marshaller);
+            else
+             JAXBTypeSerializer.serialize(jaxbBean,os,jaxbContext);
+        }
+
+    public void setMarshallers(Marshaller m, Unmarshaller u) {
+        this.marshaller = m;
+        this.unmarshaller = u;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBBridgeInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBBridgeInfo.java
new file mode 100644
index 0000000..64c6d4f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBBridgeInfo.java
@@ -0,0 +1,153 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.jaxb;
+
+import com.sun.xml.internal.bind.api.Bridge;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.ws.encoding.soap.SerializationException;
+import com.sun.xml.internal.ws.encoding.soap.DeserializationException;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+
+import javax.xml.namespace.QName;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.transform.Source;
+import java.io.OutputStream;
+import java.io.InputStream;
+
+import org.w3c.dom.Node;
+
+/**
+ * XML infoset represented as a JAXB object and {@link Bridge}.
+ *
+ * @author WS Development Team
+ */
+public final class JAXBBridgeInfo {
+    private final Bridge bridge;
+    private Object value;
+
+    public JAXBBridgeInfo(Bridge bridge) {
+        this.bridge = bridge;
+    }
+
+    public JAXBBridgeInfo(Bridge bridge, Object value) {
+        this(bridge);
+        this.value = value;
+    }
+
+    public QName getName() {
+        return bridge.getTypeReference().tagName;
+    }
+
+    public TypeReference getType(){
+        return bridge.getTypeReference();
+    }
+
+    public Bridge getBridge() {
+        return bridge;
+    }
+
+    public Object getValue() {
+        return value;
+    }
+
+    public static JAXBBridgeInfo copy(JAXBBridgeInfo payload) {
+        return new JAXBBridgeInfo(payload.getBridge(), payload.getValue());
+    }
+
+    /**
+     * JAXB object is serialized. Note that the BridgeContext is cached per
+     * thread, and JAXBBridgeInfo should contain correct BridgeContext for the
+     * current thread.
+     */
+    public void serialize(BridgeContext bridgeContext, OutputStream os, NamespaceContext nsContext) {
+        try {
+            bridge.marshal(bridgeContext, value, os, nsContext);
+        } catch (JAXBException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    /**
+     * Serialize to StAX.
+     */
+    public void serialize(BridgeContext bridgeContext, XMLStreamWriter writer) {
+        try {
+            bridge.marshal(bridgeContext, value, writer);
+        } catch (JAXBException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    /**
+     * Serialize to DOM.
+     */
+    public void serialize(BridgeContext bridgeContext, Node node) {
+        try {
+            bridge.marshal(bridgeContext, value, node);
+        } catch (JAXBException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    public void deserialize(Source source, BridgeContext bridgeContext) {
+        try {
+            value = bridge.unmarshal(bridgeContext, source);
+        } catch (JAXBException e) {
+            throw new DeserializationException(e);
+        }
+    }
+
+    public void deserialize(InputStream stream, BridgeContext bridgeContext) {
+        try {
+            value = bridge.unmarshal(bridgeContext, stream);
+        } catch (JAXBException e) {
+            throw new DeserializationException(e);
+        }
+    }
+
+    /*
+    * JAXB object is deserialized and is set in JAXBBridgeInfo. Note that
+    * the BridgeContext is cached per thread, and JAXBBridgeInfo should contain
+    * correct BridgeContext for the current thread.
+    */
+    public void deserialize(XMLStreamReader reader, BridgeContext bridgeContext)  {
+        try {
+            value = bridge.unmarshal(bridgeContext, reader);
+
+            // reader could be left on CHARS token rather than </body>
+            if (reader.getEventType() == XMLStreamConstants.CHARACTERS &&
+                    reader.isWhiteSpace()) {
+                XMLStreamReaderUtil.nextContent(reader);
+            }
+        } catch (JAXBException e) {
+            throw new DeserializationException(e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBTypeSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBTypeSerializer.java
new file mode 100644
index 0000000..dc56229
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/JAXBTypeSerializer.java
@@ -0,0 +1,219 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.jaxb;
+
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.bind.v2.runtime.MarshallerImpl;
+import com.sun.xml.internal.ws.encoding.soap.DeserializationException;
+import com.sun.xml.internal.ws.encoding.soap.SerializationException;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.Source;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.dom.DOMSource;
+import java.io.OutputStream;
+
+/**
+ * @author Vivek Pandey
+ */
+public final class JAXBTypeSerializer {
+    private JAXBTypeSerializer() {
+    }    // no instanciation please
+
+    public static void serialize(Object obj, XMLStreamWriter writer, JAXBContext context) {
+
+        try {
+            Marshaller marshaller = context.createMarshaller();
+            marshaller.setProperty("jaxb.fragment", Boolean.TRUE);
+            marshaller.marshal(obj, writer);
+        } catch (RuntimeException e) {
+            throw e;
+        } catch (Exception e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    public static void serialize(Object obj, XMLStreamWriter writer,
+                                 JAXBContext context, Marshaller marshaller) {
+
+        try {
+            if (marshaller == null)
+                marshaller = context.createMarshaller();
+            marshaller.setProperty("jaxb.fragment", Boolean.TRUE);
+            marshaller.marshal(obj, writer);
+        } catch (RuntimeException e) {
+            throw e;
+        } catch (Exception e) {
+            throw new SerializationException(e);
+        }
+    }
+
+
+    /* for FI, it will be a whole document, not fragment
+     * called by setPayload and writeTo methods in XMLMessage class
+     */
+    public static void serializeDocument(Object obj, XMLStreamWriter writer, JAXBContext context) {
+        try {
+            Marshaller marshaller = context.createMarshaller();
+            marshaller.marshal(obj, writer);
+        } catch (RuntimeException e) {
+            throw e;
+        } catch (Exception e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    public static void serialize(Object obj, OutputStream os,
+                                 JAXBContext context, Marshaller marshaller) {
+
+        try {
+            if (marshaller == null)
+                marshaller = context.createMarshaller();
+            marshaller.setProperty("jaxb.fragment", Boolean.TRUE);
+            marshaller.marshal(obj, os);
+        } catch (RuntimeException e) {
+            throw e;
+        } catch (Exception e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    public static void serialize(Object obj, OutputStream os, JAXBContext context) {
+
+        try {
+            Marshaller marshaller = context.createMarshaller();
+            marshaller.setProperty("jaxb.fragment", Boolean.TRUE);
+            marshaller.marshal(obj, os);
+        } catch (RuntimeException e) {
+            throw e;
+        } catch (Exception e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    /*
+    * Marshalls arbitrary type object with the given tag name
+    */
+    public static DOMSource serialize(Object bean, JAXBContext context) {
+        try {
+            Marshaller marshaller = context.createMarshaller();
+            marshaller.setProperty("jaxb.fragment", Boolean.TRUE);
+            DOMResult domResult = new DOMResult();
+            marshaller.marshal(bean, domResult);
+            return new DOMSource(domResult.getNode());
+        } catch (JAXBException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    /*
+    * @see JAXBTypeSerializerIf#deserialize(XMLStreamReader,JAXBContext)
+    */
+    public static Object deserialize(XMLStreamReader reader, JAXBContext context) {
+        Object obj = null;
+        try {
+            Unmarshaller unmarshaller = context.createUnmarshaller();
+            if (reader.getEventType() == XMLStreamConstants.START_ELEMENT)
+                obj = unmarshaller.unmarshal(reader);
+
+            // reader could be left on CHARS token rather than </body>
+            if (reader.getEventType() == XMLStreamConstants.CHARACTERS
+                && reader.isWhiteSpace()) {
+                XMLStreamReaderUtil.nextContent(reader);
+            }
+            return obj;
+
+        } catch (DeserializationException e) {
+            throw e;
+        } catch (Exception e) {
+            throw new DeserializationException(e);
+        }
+    }
+
+    public static Object deserialize(XMLStreamReader reader, JAXBContext context, Unmarshaller bc) {
+        Object obj = null;
+        try {
+            Unmarshaller unmarshaller = context.createUnmarshaller();
+            if (bc != null)
+                unmarshaller.setAttachmentUnmarshaller(bc.getAttachmentUnmarshaller());
+
+            if (reader.getEventType() == XMLStreamConstants.START_ELEMENT)
+                obj = unmarshaller.unmarshal(reader);
+
+            // reader could be left on CHARS token rather than </body>
+            if (reader.getEventType() == XMLStreamConstants.CHARACTERS
+                && reader.isWhiteSpace()) {
+                XMLStreamReaderUtil.nextContent(reader);
+            }
+            return obj;
+
+        } catch (DeserializationException e) {
+            throw e;
+        } catch (Exception e) {
+            throw new DeserializationException(e);
+        }
+    }
+
+    /*
+     * convert JAXB bean as a Source
+     *
+    public static Object toSource(Object obj, JAXBContext context) {
+        try {
+            // Use ctxt to marshall the object
+            ByteArrayOutputStream bos = new ByteArrayOutputStream();
+            Marshaller marshaller = context.createMarshaller();
+            marshaller.setProperty("jaxb.fragment", Boolean.TRUE);
+            marshaller.marshal(obj, bos);
+            ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
+            return new StreamSource(bis);
+        } catch (JAXBException e) {
+            throw new DeserializationException(new LocalizableExceptionAdapter(
+                    e));
+        }
+    }
+    */
+
+    /*
+    * Convert Source object as a JAXB bean
+    */
+    public static Object deserialize(Source source, JAXBContext context) {
+        try {
+            Unmarshaller unmarshaller = context.createUnmarshaller();
+            return unmarshaller.unmarshal(source);
+        } catch (JAXBException e) {
+            throw new DeserializationException(e);
+        }
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/RpcLitPayload.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/RpcLitPayload.java
new file mode 100644
index 0000000..48bfeb7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/RpcLitPayload.java
@@ -0,0 +1,78 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.jaxb;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import javax.xml.namespace.QName;
+
+public class RpcLitPayload {
+    private QName operation;
+    private List<JAXBBridgeInfo> bridgeParameters;
+
+    public RpcLitPayload(QName operation) {
+        this.operation = operation;
+        this.bridgeParameters = new ArrayList<JAXBBridgeInfo>();
+    }
+
+    /* Same as the above one. Need to remove the above constructor.
+    public RpcLitPayload(QName operation, List<JAXBBridgeInfo> parameters) {
+        this.operation = operation;
+        this.bridgeParameters = parameters;
+    }
+     */
+
+    public QName getOperation() {
+        return operation;
+    }
+
+    public List<JAXBBridgeInfo> getBridgeParameters() {
+        return bridgeParameters;
+    }
+
+    public static RpcLitPayload copy(RpcLitPayload payload) {
+        RpcLitPayload newPayload = new RpcLitPayload(payload.getOperation());
+        for(JAXBBridgeInfo param: payload.getBridgeParameters()) {
+            JAXBBridgeInfo newParam = JAXBBridgeInfo.copy(param);
+            newPayload.addParameter(newParam);
+        }
+        return newPayload;
+    }
+
+    public JAXBBridgeInfo getBridgeParameterByName(String name){
+        for(JAXBBridgeInfo param : bridgeParameters) {
+                if (param.getName().getLocalPart().equals(name)) {
+                        return param;
+            }
+        }
+        return null;
+    }
+
+    public void addParameter(JAXBBridgeInfo parameter) {
+        bridgeParameters.add(parameter);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/RpcLitPayloadSerializer.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/RpcLitPayloadSerializer.java
new file mode 100644
index 0000000..94505b0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/jaxb/RpcLitPayloadSerializer.java
@@ -0,0 +1,138 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.jaxb;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.JAXB_OUTPUTSTREAM;
+import com.sun.xml.internal.ws.encoding.soap.DeserializationException;
+import com.sun.xml.internal.ws.encoding.soap.SerializationException;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import java.io.IOException;
+import java.io.OutputStream;
+
+public class RpcLitPayloadSerializer {
+
+    /*
+     * Uses BridgeContext to serialize the rpc/lit payload. First it writes
+     * the operation, and then it serializes each parameter
+     */
+    public static void serialize(RpcLitPayload obj, BridgeContext bridgeContext,
+        MessageInfo messageInfo, XMLStreamWriter writer)
+    {
+        try {
+            QName op = obj.getOperation();
+            String opURI = op.getNamespaceURI();
+
+            writer.writeStartElement("ans", op.getLocalPart(), opURI);
+            writer.setPrefix("ans", opURI);
+            writer.writeNamespace("ans", opURI);
+
+
+            // Pass output stream directly to JAXB when available
+            OutputStream os = (OutputStream) messageInfo.getMetaData(JAXB_OUTPUTSTREAM);
+            if (os != null) {
+                /*
+                 * Make sure that current element is closed before passing the
+                 * output stream to JAXB. Using Zephyr, it suffices to write
+                 * an empty string (TODO: other StAX impls?).
+                 */
+                writer.writeCharacters("");
+
+                // Flush output of StAX serializer
+                writer.flush();
+
+                NamespaceContext nsc = writer.getNamespaceContext();
+
+                // Let JAXB serialize each param to the output stream
+                for (JAXBBridgeInfo param : obj.getBridgeParameters()) {
+                    param.serialize(bridgeContext, os, nsc);
+                }
+            }
+            else {
+                // Otherwise, use a StAX writer
+                for (JAXBBridgeInfo param : obj.getBridgeParameters()) {
+                    param.serialize(bridgeContext, writer);
+                }
+            }
+
+            writer.writeEndElement();            // </ans:operation>
+        }
+        catch (XMLStreamException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    public static void serialize(RpcLitPayload obj, BridgeContext bridgeContext, OutputStream writer) {
+        QName op = obj.getOperation();
+        String opURI = op.getNamespaceURI();
+        String startElm = "<ans:"+op.getLocalPart()+" xmlns:ans=\""+opURI+"\">";
+        String endElm="</ans:"+op.getLocalPart()+">";
+        try {
+            writer.write(startElm.getBytes());
+            for (JAXBBridgeInfo param : obj.getBridgeParameters()) {
+                param.serialize(bridgeContext,writer,null);
+            }
+            writer.write(endElm.getBytes());
+        } catch (IOException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    /*
+     * Uses BridgeContext to deserialize the rpc/lit payload. First it reads
+     * the operation element, and then it deserializes each parameter. If the
+     * expected parameter is not found, it throws an exception
+     */
+    public static void deserialize(XMLStreamReader reader, RpcLitPayload payload,
+        BridgeContext bridgeContext)
+    {
+        XMLStreamReaderUtil.nextElementContent(reader);     // </operation> or <partName>
+        for (JAXBBridgeInfo param: payload.getBridgeParameters()) {
+            // throw exception if the part accessor name is not what we expect
+            QName partName = reader.getName();
+            if (!partName.equals(param.getName())) {
+                throw new DeserializationException("xsd.unexpectedElementName",
+                        new Object[]{param.getName(), partName});
+            }
+            param.deserialize(reader, bridgeContext);
+
+            // reader could be left on CHARS token rather than <partName>
+            if (reader.getEventType() == XMLStreamConstants.CHARACTERS &&
+                    reader.isWhiteSpace()) {
+                XMLStreamReaderUtil.nextContent(reader);
+            }
+        }
+        XMLStreamReaderUtil.nextElementContent(reader);     // </env:body>
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/simpletype/EncoderUtils.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/simpletype/EncoderUtils.java
new file mode 100644
index 0000000..d8af9ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/simpletype/EncoderUtils.java
@@ -0,0 +1,142 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.simpletype;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class EncoderUtils {
+    public static boolean needsCollapsing(String str) {
+        int len = str.length();
+        int spanLen = 0;
+
+        for (int idx = 0; idx < len; ++idx) {
+            if (Character.isWhitespace(str.charAt(idx))) {
+                ++spanLen;
+            } else if (spanLen > 0) {
+                if (spanLen == idx) {
+                    // leading whitespace
+                    return true;
+                } else {
+                    // non-leading, non-trailing whitespace
+                    if (str.charAt(idx - spanLen) != ' ') {
+                        // first whitespace character is not a space
+                        return true;
+                    }
+                    if (spanLen > 1) {
+                        // there is a span of multiple whitespace characters
+                        return true;
+                    }
+                }
+
+                spanLen = 0;
+            }
+        }
+
+        if (spanLen > 0) {
+            // trailing whitespace
+            return true;
+        }
+
+        return false;
+    }
+
+    public static String collapseWhitespace(String str) {
+        if (!needsCollapsing(str)) {
+            return str;
+        }
+
+        // the assumption is that most strings will not need to be collapsed,
+        // so the code below will usually not be reached
+
+        int len = str.length();
+        char[] buf = new char[len];
+        str.getChars(0, len, buf, 0);
+
+        int leadingWSLen = 0;
+        int trailingWSLen = 0;
+        int spanLen = 0;
+
+        for (int idx = 0; idx < len; ++idx) {
+            if (Character.isWhitespace(buf[idx])) {
+                ++spanLen;
+            } else if (spanLen > 0) {
+                if (spanLen == idx) {
+                    // leading whitespace
+                    leadingWSLen = spanLen;
+                } else {
+                    // non-leading, non-trailing whitespace
+
+                    // ensure that the first whitespace character is a space
+                    int firstWSIdx = idx - spanLen;
+                    buf[firstWSIdx] = ' ';
+
+                    if (spanLen > 1) {
+                        // remove all but the first whitespace character
+                        System.arraycopy(
+                            buf,
+                            idx,
+                            buf,
+                            firstWSIdx + 1,
+                            len - idx);
+                        len -= (spanLen - 1);
+                        idx = firstWSIdx + 1;
+                    }
+                }
+
+                spanLen = 0;
+            }
+        }
+
+        if (spanLen > 0) {
+            // trailing whitespace
+            trailingWSLen = spanLen;
+        }
+
+        return new String(
+            buf,
+            leadingWSLen,
+            len - leadingWSLen - trailingWSLen);
+    }
+
+    public static String removeWhitespace(String str) {
+        int len = str.length();
+        StringBuffer buf = new StringBuffer();
+        int firstNonWS = 0;
+        int idx = 0;
+        for (; idx < len; ++idx) {
+            if (Character.isWhitespace(str.charAt(idx))) {
+                if (firstNonWS < idx)
+                    buf.append(str.substring(firstNonWS, idx));
+                firstNonWS = idx + 1;
+            }
+        }
+        if (firstNonWS < idx)
+            buf.append(str.substring(firstNonWS, idx));
+        return buf.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/simpletype/SimpleTypeConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/simpletype/SimpleTypeConstants.java
new file mode 100644
index 0000000..5012dc2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/simpletype/SimpleTypeConstants.java
@@ -0,0 +1,46 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.ws.encoding.simpletype;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.ws.encoding.soap.SerializerConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface SimpleTypeConstants extends SerializerConstants {
+
+    public static final String URI_XSI = SOAPNamespaceConstants.XSI;
+    public static final String URI_XSD = SOAPNamespaceConstants.XSD;
+
+    public static final QName QNAME_XSI_TYPE = new QName(URI_XSI, "type");
+    public static final QName QNAME_XSI_NIL = new QName(URI_XSI, "nil");
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/ClientEncoderDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/ClientEncoderDecoder.java
new file mode 100644
index 0000000..fa0067c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/ClientEncoderDecoder.java
@@ -0,0 +1,343 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.client.RequestContext;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload;
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.FaultReasonText;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAP12FaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.model.CheckedException;
+import com.sun.xml.internal.ws.model.ExceptionType;
+import com.sun.xml.internal.ws.model.JavaMethod;
+import com.sun.xml.internal.ws.model.Parameter;
+import com.sun.xml.internal.ws.model.ParameterBinding;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.model.WrapperParameter;
+import com.sun.xml.internal.ws.model.soap.SOAPBinding;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.util.StringUtils;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.soap.SOAPFaultException;
+import javax.xml.ws.handler.MessageContext;
+import javax.activation.DataHandler;
+import java.lang.reflect.Constructor;
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @author Vivek Pandey
+ *
+ * SOAP Client side encoder/decoder.
+ */
+public class ClientEncoderDecoder extends EncoderDecoder implements InternalEncoder {
+    public ClientEncoderDecoder() {
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.EncoderDecoderBase#toMessageInfo(java.lang.Object, com.sun.pept.ept.MessageInfo)
+     */
+    public void toMessageInfo(Object intMessage, MessageInfo mi) {
+        InternalMessage im = (InternalMessage) intMessage;
+        BodyBlock bodyBlock = im.getBody();
+        RuntimeContext rtContext = (RuntimeContext) mi.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        JavaMethod jm = rtContext.getModel().getJavaMethod(mi.getMethod());
+        mi.setMEP(jm.getMEP());
+
+        Object bodyValue  = (bodyBlock == null) ? null : bodyBlock.getValue();
+
+        if(bodyValue instanceof SOAPFaultInfo){
+            SOAPFaultInfo sfi = (SOAPFaultInfo)bodyValue;
+            Object detail = sfi.getDetail();
+            if(detail == null || detail instanceof javax.xml.soap.Detail) {
+                SOAPFaultException sfe = new SOAPFaultException(sfi.getSOAPFault());
+                mi.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+                mi.setResponse(sfe);
+                return;
+            }
+            JAXBBridgeInfo bi = (JAXBBridgeInfo)detail;
+            CheckedException ce = jm.getCheckedException(bi.getType());
+            Exception ex = createCheckedException(sfi.getString(), ce, bi.getValue());
+            mi.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+            mi.setResponse(ex);
+            return;
+        }
+
+        if(bodyValue instanceof SOAP12FaultInfo){
+            SOAP12FaultInfo sfi = (SOAP12FaultInfo)bodyValue;
+            Object detail = sfi.getDetail();
+            if(detail == null || detail instanceof javax.xml.soap.Detail) {
+//                javax.xml.soap.Detail sfeDetail = null;
+//                if(detail != null)
+//                    sfeDetail = (javax.xml.soap.Detail)detail;
+//                String reason = null;
+//                List<FaultReasonText> frt = sfi.getReasons().getFaultReasonTexts();
+//
+//                //for now we pickup onkly the first Reason Text
+//                if(frt != null && !frt.isEmpty())
+//                    reason = frt.get(0).getValue();
+
+                SOAPFaultException sfe = new SOAPFaultException(sfi.getSOAPFault());
+                mi.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+                mi.setResponse(sfe);
+                return;
+            }
+            JAXBBridgeInfo bi = (JAXBBridgeInfo)detail;
+            CheckedException ce = jm.getCheckedException(bi.getType());
+            String reason = null;
+            List<FaultReasonText> frt = sfi.getReasons().getFaultReasonTexts();
+            //for now we pickup onkly the first Reason Text
+            if(frt != null && !frt.isEmpty())
+                reason = frt.get(0).getValue();
+            Exception ex = createCheckedException(reason, ce, bi.getValue());
+            mi.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+            mi.setResponse(ex);
+            return;
+        }
+
+        // process body/headers/attachments
+        List<HeaderBlock> headers = im.getHeaders();
+        Map<String, AttachmentBlock> attachments = im.getAttachments();
+        Object[] data = mi.getData();
+        SOAPBinding soapBinding = (SOAPBinding)jm.getBinding();
+
+        // TODO: why is the binding determined by the instance?
+        //what happens when client receives unsolicited headers?
+        int bBlocks = (bodyValue != null)?1:0;
+        int hBlocks = (im.getHeaders() != null)?im.getHeaders().size():0;
+        int mBlocks = (im.getAttachments() != null)?im.getAttachments().size():0;
+
+        boolean isResponseAsynWrapper = (bBlocks + hBlocks + mBlocks) > 1;
+
+        //for rpclit there could be more than one parts but only one bodyblock
+        // so we use different rule for rpclit
+        if((bodyValue instanceof RpcLitPayload) && !isResponseAsynWrapper){
+            isResponseAsynWrapper = (((RpcLitPayload)bodyValue).getBridgeParameters().size() > 1);
+        }
+
+        if(jm.isAsync() && isResponseAsynWrapper){
+            Object asyncWrapper = createAsyncResponseClass(jm.getResponseParameters().get(0));
+            if(bodyValue instanceof RpcLitPayload){
+                RpcLitPayload payload = (RpcLitPayload)bodyValue;
+                for(JAXBBridgeInfo bi : payload.getBridgeParameters()){
+                    setAsyncResponseWrapperValue(rtContext, asyncWrapper, bi.getValue(), bi.getType().tagName);
+                }
+            }else {
+                JAXBBridgeInfo value = (JAXBBridgeInfo)bodyValue;
+                setAsyncResponseWrapperValue(rtContext, asyncWrapper, value.getValue(), value.getType().tagName);
+            }
+
+            if(im.getHeaders() != null) {
+                for(HeaderBlock hb : im.getHeaders()){
+                    JAXBBridgeInfo value = (JAXBBridgeInfo)hb.getValue();
+                    setAsyncResponseWrapperValue(rtContext, asyncWrapper, value.getValue(), value.getType().tagName);
+                }
+            }else if(attachments != null){
+                for(String id : attachments.keySet()){
+                    AttachmentBlock ab = attachments.get(id);
+                    if(ab == null)
+                        return;
+                    String part = ab.getWSDLPartName();
+
+                    // TODO: this isn't correct
+                    setAsyncResponseWrapperValue(rtContext, asyncWrapper, ab.asDataHandler(), new QName("", part));
+                }
+            }
+            mi.setResponse(asyncWrapper);
+            return;
+        }else if(jm.isAsync() && ((bBlocks+hBlocks+mBlocks) == 1)){
+            //there is only 1 response part
+            Object value = null;
+            if(bodyValue instanceof RpcLitPayload){
+                RpcLitPayload payload = (RpcLitPayload)bodyValue;
+                for(JAXBBridgeInfo bi:payload.getBridgeParameters()){
+                    value = bi.getValue();
+                    break;
+                }
+            }else{
+                value = ((JAXBBridgeInfo)bodyValue).getValue();
+            }
+
+            if(value != null){
+                mi.setResponse(value);
+                return;
+            }
+
+            if(headers != null){
+                for(HeaderBlock hb : headers){
+                    value = ((JAXBBridgeInfo)hb.getValue()).getValue();
+                    if(value != null){
+                        mi.setResponse(value);
+                        return;
+                    }
+                }
+            }
+
+            if(attachments != null){
+                for(String id:attachments.keySet()){
+                    AttachmentBlock ab = attachments.get(id);
+                    if(ab == null)      continue;
+
+                    // TODO: this isn't correct
+                    mi.setResponse(ab.asDataHandler());
+                    return;
+                }
+            }
+
+            // bBlocks+hBlocks+mBlocks==1, so we shall never get here
+            assert false;
+        }
+
+
+        for (Parameter param : jm.getResponseParameters()) {
+            Object obj = null;
+            ParameterBinding paramBinding = param.getOutBinding();
+            if (paramBinding.isBody()) {
+                //TODO: check if the bodyValue qname is the one we expect!
+                obj = bodyValue;
+            } else if (headers != null && paramBinding.isHeader()) {
+                HeaderBlock header = getHeaderBlock(param.getName(), headers);
+                obj = (header != null) ? header.getValue() : null;
+            } else if (paramBinding.isAttachment()) {
+                obj = getAttachment(rtContext, attachments, param, paramBinding);
+            }
+            Object resp = fillData(rtContext, param, obj, data, soapBinding, paramBinding);
+            if (param.isResponse()) {
+                mi.setResponse(resp);
+            }
+        }
+    }
+
+    private void setAsyncResponseWrapperValue(RuntimeContext rtContext, Object bean, Object value, QName tag){
+        if(value != null){
+            setWrapperChildValue(rtContext, bean, value, tag.getNamespaceURI(), tag.getLocalPart());
+        }
+    }
+
+    private Object createAsyncResponseClass(Parameter parameter) {
+        Class asyncWrapper = (Class)parameter.getTypeReference().type;
+        if(RpcLitPayload.class.isAssignableFrom(asyncWrapper)){
+            WrapperParameter wp = (WrapperParameter)parameter;
+            if(wp.getWrapperChildren().size() > 0){
+                Parameter p = wp.getWrapperChildren().get(0);
+                asyncWrapper = (Class) p.getTypeReference().type;
+            }
+        }
+
+        try {
+            return asyncWrapper.newInstance();
+        } catch(Exception e){
+            throw new SerializationException(e);
+        }
+    }
+
+    private Exception createCheckedException(String message, CheckedException ce, Object detail) {
+        if(ce.getExceptionType().equals(ExceptionType.UserDefined)){
+            return createUserDefinedException(message, ce, detail);
+
+        }
+        Class exceptionClass = ce.getExcpetionClass();
+        try {
+            Constructor constructor = exceptionClass.getConstructor(new Class[]{String.class, (Class) ce.getDetailType().type});
+            Object exception = constructor.newInstance(new Object[]{message, detail});
+            return (Exception)exception;
+        } catch(Exception e){
+            throw new SerializationException(e);
+        }
+    }
+
+    /**
+     * @param message
+     * @param ce
+     * @param detail
+     */
+    private Exception createUserDefinedException(String message, CheckedException ce, Object detail) {
+        Class exceptionClass = ce.getExcpetionClass();
+        try {
+            Constructor constructor = exceptionClass.getConstructor(new Class[]{String.class});
+            Object exception = constructor.newInstance(new Object[]{message});
+            Field[] fields = detail.getClass().getFields();
+            for(Field f : fields){
+                Method m = exceptionClass.getMethod(getWriteMethod(f));
+                m.invoke(exception, new Object[]{f.get(detail)});
+            }
+            return (Exception)exception;
+        } catch(Exception e){
+            throw new SerializationException(e);
+        }
+    }
+
+    /**
+     * @param f
+     */
+    private String getWriteMethod(Field f){
+        return "set" + StringUtils.capitalize(f.getName());
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.EncoderDecoderBase#toInternalMessage(com.sun.pept.ept.MessageInfo)
+     */
+    public InternalMessage toInternalMessage(MessageInfo mi) {
+        RuntimeContext rtContext = (RuntimeContext) mi.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        RuntimeModel model = rtContext.getModel();
+
+        JavaMethod jm = model.getJavaMethod(mi.getMethod());
+        Object[] data = mi.getData();
+        InternalMessage im = new InternalMessage();
+        //copy the attachments from the outbound attachments to InternalMessage
+        RequestContext ctxt = (RequestContext)mi.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        copyAttachmentProperty(ctxt, im);
+        Iterator<Parameter> iter = jm.getRequestParameters().iterator();
+        SOAPBinding soapBinding = (SOAPBinding)jm.getBinding();
+        while (iter.hasNext()) {
+            Parameter param = iter.next();
+            ParameterBinding paramBinding = param.getInBinding();
+            Object obj = createPayload(rtContext, param, data, null, soapBinding, paramBinding);
+            if (paramBinding.isBody()) {
+                im.setBody(new BodyBlock(obj));
+            } else if (paramBinding.isHeader()) {
+                im.addHeader(new HeaderBlock((JAXBBridgeInfo)obj));
+            } else if (paramBinding.isAttachment()) {
+                addAttachmentPart(rtContext, im, obj, param);
+            }
+        }
+        return im;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/DeserializationException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/DeserializationException.java
new file mode 100644
index 0000000..585eaaf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/DeserializationException.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * DeserializationException represents an exception that occurred while
+ * deserializing a Java value from XML.
+ *
+ * @see JAXWSExceptionBase
+ *
+ * @author WS Development Team
+ */
+public class DeserializationException extends JAXWSExceptionBase {
+
+    public DeserializationException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public DeserializationException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public DeserializationException(Localizable arg) {
+        super("nestedDeserializationError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.encoding";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/EncoderDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/EncoderDecoder.java
new file mode 100644
index 0000000..ebbfb4f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/EncoderDecoder.java
@@ -0,0 +1,406 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap;
+
+import com.sun.xml.internal.ws.encoding.EncoderDecoderBase;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload;
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.model.*;
+import com.sun.xml.internal.ws.model.soap.SOAPBinding;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.client.RequestContext;
+
+import javax.activation.DataHandler;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Source;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.WebServiceException;
+import java.awt.Image;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.UnsupportedEncodingException;
+import java.lang.reflect.Type;
+import java.net.URLEncoder;
+import java.util.List;
+import java.util.Map;
+import java.util.UUID;
+
+/**
+ * @author Vivek Pandey
+ *
+ * Base SOAP encoder decoder class.
+ */
+public abstract class EncoderDecoder extends EncoderDecoderBase {
+
+    /**
+     * Fills the data[] which is ordered list of java method parameters.
+     *
+     * @param context
+     *            will be used if needed
+     * @param obj
+     * @param data
+     * @return if the parameter is a return
+     */
+    protected Object fillData(RuntimeContext context, Parameter param, Object obj, Object[] data,
+                              SOAPBinding binding, ParameterBinding paramBinding) {
+        if (param.isWrapperStyle()) {
+            Object resp = null;
+            for (Parameter p : ((WrapperParameter) param).getWrapperChildren()) {
+                QName name = p.getName();
+                Object value = null;
+                if (binding.isDocLit()){
+                    value = super.getWrapperChildValue(context, ((JAXBBridgeInfo)obj).getValue(),
+                                name.getNamespaceURI(), name.getLocalPart());
+                }else if (binding.isRpcLit()){
+                    value = getWrapperChildValue(context, obj, name.getNamespaceURI(), name
+                            .getLocalPart());
+                    if(value == null)
+                        value = setIfPrimitive(p.getTypeReference().type);
+                }
+                if (p.isResponse())
+                    resp = value;
+                else {
+                    if (data[p.getIndex()] != null) {
+                        Parameter.setHolderValue(data[p.getIndex()], value);
+                    } else {
+                        data[p.getIndex()] = p.createHolderValue(value);
+                    }
+                }
+            }
+            return resp;
+        }
+
+        if(!paramBinding.isAttachment()){
+            if(paramBinding.isUnbound())
+                obj = setIfPrimitive(param.getTypeReference().type);
+            else
+                obj = (obj != null)?((JAXBBridgeInfo)obj).getValue():null;
+        }
+        if (param.isResponse()) {
+            if(paramBinding.isUnbound())
+                return setIfPrimitive(param.getTypeReference().type);
+            return obj;
+        } else if (data[param.getIndex()] != null) {
+            Parameter.setHolderValue(data[param.getIndex()], obj);
+        } else {
+            data[param.getIndex()] = param.createHolderValue(obj);
+        }
+        return null;
+    }
+
+    /**
+     * Returns the default values of primitive types. To be called when the object referene by this type is null.
+     * @param type
+     * @return default values of primitive types if type is primitive else null
+     */
+    private Object setIfPrimitive(Type type) {
+        if(type instanceof Class){
+            Class cls = (Class)type;
+            if(cls.isPrimitive()){
+                if(cls.getName().equals(boolean.class.getName())){
+                    return false;
+                }
+                return 0;
+            }
+        }
+        return null;
+    }
+
+    /**
+     * creates the payload to be serilized over the wire. It can be constructed
+     * from the parameters in data[] or from the result.
+     *
+     * @param context
+     *            runtime context. It can be used to get access to the
+     *            JAXBContext.
+     * @param data
+     *            parameters
+     * @param result
+     *            it could be null if there are no response object,for example
+     *            incase of outgoing client message.
+     * @return Payload - decided by the binding used
+     */
+    protected Object createPayload(RuntimeContext context, Parameter param, Object[] data,
+                                   Object result, SOAPBinding binding, ParameterBinding paramBinding) {
+        if(paramBinding.isAttachment()){
+            Object obj = null;
+            if(param.isResponse())
+                obj = result;
+            else
+                obj = param.getHolderValue(data[param.getIndex()]);
+            return obj;
+        }
+        if (binding.isRpcLit() && paramBinding.isBody()) {
+            return createRpcLitPayload(context, (WrapperParameter) param, data, result);
+        }
+        Object obj = createDocLitPayloadValue(context, param, data, result);
+        RuntimeModel model = context.getModel();
+        return new JAXBBridgeInfo(model.getBridge(param.getTypeReference()), obj);
+    }
+
+    /*
+     * Returns the value corresponding to the localName or part accessor from
+     * rpclit structure.
+     *
+     * @see EncoderDecoderBase#getWrapperChildValue(RuntimeContext,
+     *      Object, String, String)
+     */
+    @Override
+    protected Object getWrapperChildValue(RuntimeContext context, Object obj, String nsURI,
+                                          String localName) {
+        RpcLitPayload payload = (RpcLitPayload) obj;
+        JAXBBridgeInfo rpcParam = payload.getBridgeParameterByName(localName);
+        if(rpcParam != null)
+            return rpcParam.getValue();
+        return null;
+    }
+
+    /**
+     * Gives the binding specific object to be serialized.
+     *
+     * @param context
+     * @param data
+     * @param result
+     */
+    private Object createDocLitPayloadValue(RuntimeContext context, Parameter param, Object[] data, Object result) {
+        if (param.isWrapperStyle()) {
+            return createJAXBBeanPayload(context, (WrapperParameter) param, data, result);
+        }
+        return getBarePayload(param, data, result);
+    }
+
+    /**
+     * Gets the HeaderBlock corresponding to the given QName.
+     *
+     * @param name
+     * @param headers
+     * @return the <code>HeaderBlock</code> corresponding to the given
+     * <code>QName name</code>
+     */
+    protected HeaderBlock getHeaderBlock(QName name, List<HeaderBlock> headers) {
+        for (HeaderBlock header : headers) {
+            if (name.equals(header.getName()))
+                return header;
+        }
+        return null;
+    }
+
+    /**
+     * Returns either the value corresponding to the parameter or result.
+     *
+     * @param param
+     * @param data
+     * @param result
+     * @return Either the value of response of the parameter corresponding to
+     *         the parameter index, takes care of Holder.value.
+     *
+     */
+    private Object getBarePayload(Parameter param, Object[] data, Object result) {
+        Object obj = null;
+        if (param.isResponse()) {
+            obj = result;
+        } else {
+            obj = param.getHolderValue(data[param.getIndex()]);
+        }
+        return obj;
+    }
+
+    /**
+     * Creates JAXB style wrapper bean from the parameters or result.
+     *
+     * @param context
+     * @param param
+     *            WrapperParameter
+     * @param data
+     * @param result
+     * @return non-null JAXB style bean.
+     */
+    private Object createJAXBBeanPayload(RuntimeContext context, WrapperParameter param,
+                                         Object[] data, Object result) {
+        Class bean = (Class) param.getTypeReference().type;
+        try {
+            Object obj = bean.newInstance();
+            for( Parameter p : param.getWrapperChildren() ) {
+                Object value;
+                if (p.isResponse())
+                    value = result;
+                else
+                    value = p.getHolderValue(data[p.getIndex()]);
+                QName name = p.getName();
+                setWrapperChildValue(context, obj, value,
+                    name.getNamespaceURI(), name.getLocalPart());
+            }
+            return obj;
+        } catch(Exception e){
+            throw new SerializationException(e);
+        }
+    }
+
+    /**
+     * Creates RpcLitPayload from the parameters or response.
+     *
+     * @param context
+     * @param param
+     * @param data
+     * @param result
+     * @return non-null RpcLitPayload
+     */
+    private Object createRpcLitPayload(RuntimeContext context, WrapperParameter param,
+                                       Object[] data, Object result) {
+        RpcLitPayload payload = new RpcLitPayload(param.getName());
+
+        for  (Parameter p : param.getWrapperChildren()) {
+            if(p.getBinding().isUnbound())
+                continue;
+            Object value = null;
+            if (p.isResponse())
+                value = result;
+            else
+                value = p.getHolderValue(data[p.getIndex()]);
+            checkRPCLitNullableParameter(p, value);
+            RuntimeModel model = context.getModel();
+            JAXBBridgeInfo bi = new JAXBBridgeInfo(model.getBridge(p.getTypeReference()), value);
+            payload.addParameter(bi);
+        }
+        return payload;
+    }
+
+    protected Object getAttachment(RuntimeContext rtContext, Map<String, AttachmentBlock> attachments,
+                                   Parameter param, ParameterBinding paramBinding){
+        try {
+            for (Map.Entry<String,AttachmentBlock> entry : attachments.entrySet()) {
+                AttachmentBlock ab = entry.getValue();
+                String part = ab.getWSDLPartName();
+                // part can be null if the Content-Id is not encoded as per AP 1.0 R2933. Which is ok since there could be attachments
+                // other than WSDL MIME bound
+                if(part == null)
+                    continue;
+
+                if(part.equals(param.getPartName()) || part.equals("<"+param.getPartName())){
+                    Class type = (Class)param.getTypeReference().type;
+
+                    if(DataHandler.class.isAssignableFrom(type))
+                        return ab.asDataHandler();
+                    if(byte[].class==type)
+                        return ab.asByteArray();
+                    if(Source.class.isAssignableFrom(type))
+                        return ab.asSource();
+                    if(Image.class.isAssignableFrom(type))
+                        return ab.asImage();
+                    if(InputStream.class==type)
+                        return ab.asDataHandler().getInputStream();
+                    if(isXMLMimeType(paramBinding.getMimeType())) {
+                        JAXBBridgeInfo bi = (JAXBBridgeInfo)rtContext.getDecoderInfo(param.getName());
+                        ab.deserialize(rtContext.getBridgeContext(),bi);
+                        return bi.getValue();
+                    }
+                }
+            }
+            return null;
+        } catch (IOException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    protected void addAttachmentPart(RuntimeContext rtContext, InternalMessage im, Object obj, Parameter mimeParam){
+        if(obj == null)
+            return;
+        RuntimeModel model = rtContext.getModel();
+        String mimeType = mimeParam.getBinding().getMimeType();
+        String contentId;
+        try {
+            contentId = URLEncoder.encode(mimeParam.getPartName(), "UTF-8")+ '=' +UUID.randomUUID()+"@jaxws.sun.com";
+            contentId="<"+contentId+">";
+        } catch (UnsupportedEncodingException e) {
+            throw new SerializationException(e);
+        }
+
+        AttachmentBlock ab;
+
+        if(obj instanceof DataHandler)
+            ab = AttachmentBlock.fromDataHandler(contentId,(DataHandler)obj);
+        else
+        if(obj instanceof Source)
+            // this is potentially broken, as there's no guarantee this will work.
+            // we should have our own AttachmentBlock implementation for this.
+            ab = AttachmentBlock.fromDataHandler(contentId, new DataHandler(obj,mimeType));
+        else
+        if(obj instanceof byte[])
+            ab = AttachmentBlock.fromByteArray(contentId,(byte[])obj,mimeType);
+        else
+        if(isXMLMimeType(mimeType))
+            ab = AttachmentBlock.fromJAXB(contentId,
+                    new JAXBBridgeInfo(model.getBridge(mimeParam.getTypeReference()), obj),
+                    rtContext, mimeType );
+        else
+            // this is also broken, as there's no guarantee that the object type and the MIME type
+            // matches. But most of the time it matches, so it mostly works.
+            ab = AttachmentBlock.fromDataHandler(contentId,new DataHandler(obj,mimeType));
+
+        //populate the attachment map in the message context
+        HandlerContext hc = rtContext.getHandlerContext();
+        if(hc != null){
+            MessageContext mc = hc.getMessageContext();
+            if(mc != null){
+                MessageContextUtil.addMessageAttachment(mc, ab.getId(), ab.asDataHandler());
+            }
+        }
+
+        im.addAttachment(ab);
+    }
+
+    protected void copyAttachmentProperty(Map<String, Object> ctxt, InternalMessage im) {
+        if(ctxt == null)
+            return;
+        Map<String, DataHandler> attMap = (Map<String, DataHandler>) ctxt.get(MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS);
+        if (attMap == null)
+            return;
+        for (Map.Entry<String, DataHandler> att : attMap.entrySet()) {
+            im.addAttachment(AttachmentBlock.fromDataHandler(att.getKey(), att.getValue()));
+        }
+    }
+
+    private boolean isXMLMimeType(String mimeType){
+        if(mimeType.equals("text/xml") || mimeType.equals("application/xml"))
+            return true;
+        return false;
+    }
+
+    /**
+     * Checks rpclit body parts for nullability
+     */
+    void checkRPCLitNullableParameter(Parameter param, Object value) {
+        if(value == null)
+            throw new WebServiceException("Method Parameter: "+param.getName() +" cannot be null. This is BP 1.1 R2211 violation.");
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAP12Constants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAP12Constants.java
new file mode 100644
index 0000000..1518021
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAP12Constants.java
@@ -0,0 +1,78 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class SOAP12Constants {
+
+    public static final String URI_ENVELOPE = SOAP12NamespaceConstants.ENVELOPE;
+    public static final String URI_ENCODING = "http://schemas.xmlsoap.org/soap/encoding/";
+    public static final String URI_HTTP = SOAP12NamespaceConstants.TRANSPORT_HTTP;
+    public static final String URI_SOAP_RPC = SOAP12NamespaceConstants.SOAP_RPC;
+
+
+    public static final QName QNAME_SOAP_RPC = new QName(URI_SOAP_RPC, "rpc");
+    public static final QName QNAME_SOAP_RESULT = new QName(URI_SOAP_RPC, "result");
+
+    public static final QName QNAME_SOAP_ENVELOPE    = new QName(URI_ENVELOPE, "Envelope");
+    public static final QName QNAME_SOAP_BODY    = new QName(URI_ENVELOPE, "Body");
+    public static final QName QNAME_SOAP_HEADER    = new QName(URI_ENVELOPE, "Header");
+    public static final QName QNAME_ENVELOPE_ENCODINGSTYLE = new QName(URI_ENVELOPE, "encodingStyle");
+    public static final QName QNAME_SOAP_FAULT             = new QName(URI_ENVELOPE, "Fault");
+    public static final QName QNAME_MUSTUNDERSTAND         = new QName(URI_ENVELOPE, "mustUnderstand");
+    public static final QName QNAME_ROLE                   = new QName(URI_ENVELOPE, "role");
+
+    public static final QName QNAME_NOT_UNDERSTOOD         = new QName(URI_ENVELOPE, "NotUnderstood");
+
+    //fault
+    public static final QName QNAME_FAULT_CODE             = new QName(URI_ENVELOPE, "Code");
+    public static final QName QNAME_FAULT_SUBCODE          = new QName(URI_ENVELOPE, "Subcode");
+    public static final QName QNAME_FAULT_VALUE            = new QName(URI_ENVELOPE, "Value");
+    public static final QName QNAME_FAULT_REASON           = new QName(URI_ENVELOPE, "Reason");
+    public static final QName QNAME_FAULT_NODE             = new QName(URI_ENVELOPE, "Node");
+    public static final QName QNAME_FAULT_ROLE             = new QName(URI_ENVELOPE, "Role");
+    public static final QName QNAME_FAULT_DETAIL           = new QName(URI_ENVELOPE, "Detail");
+    public static final QName QNAME_FAULT_REASON_TEXT             = new QName(URI_ENVELOPE, "Text");
+    public final static QName QNAME_UPGRADE                = new QName(URI_ENVELOPE, "Upgrade");
+    public final static QName QNAME_UPGRADE_SUPPORTED_ENVELOPE           = new QName(URI_ENVELOPE, "SupportedEnvelope");
+
+
+    //fault codes
+    public final static QName FAULT_CODE_CLIENT            = new QName(URI_ENVELOPE, "Sender");
+    public final static QName FAULT_CODE_SERVER            = new QName(URI_ENVELOPE, "Receiver");
+    public final static QName FAULT_CODE_MUST_UNDERSTAND   = new QName(URI_ENVELOPE, "MustUnderstand");
+    public final static QName FAULT_CODE_MISUNDERSTOOD   = new QName(URI_ENVELOPE, "Misunderstood");
+    public final static QName FAULT_CODE_VERSION_MISMATCH  = new QName(URI_ENVELOPE, "VersionMismatch");
+    public final static QName FAULT_CODE_DATA_ENCODING_UNKNOWN = new QName(URI_ENVELOPE, "DataEncodingUnknown");
+    public final static QName FAULT_CODE_PROCEDURE_NOT_PRESENT = new QName(URI_ENVELOPE, "ProcedureNotPresent");
+    public final static QName FAULT_CODE_BAD_ARGUMENTS      = new QName(URI_ENVELOPE, "BadArguments");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPConstants.java
new file mode 100644
index 0000000..900b4b0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPConstants.java
@@ -0,0 +1,63 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.ws.encoding.soap;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class SOAPConstants {
+
+    public static final String URI_ENVELOPE = SOAPNamespaceConstants.ENVELOPE;
+    public static final String URI_HTTP = SOAPNamespaceConstants.TRANSPORT_HTTP;
+    public static final String URI_ENCODING  = "http://schemas.xmlsoap.org/soap/encoding/";
+    public static final String NS_WSDL_SOAP = "http://schemas.xmlsoap.org/wsdl/soap/";
+    public static final QName QNAME_ENVELOPE_ENCODINGSTYLE = new QName(URI_ENVELOPE, "encodingStyle");
+
+    public final static QName QNAME_SOAP_ENVELOPE             = new QName(URI_ENVELOPE, "Envelope");
+    public final static QName QNAME_SOAP_HEADER             = new QName(URI_ENVELOPE, "Header");
+    public static final QName QNAME_MUSTUNDERSTAND         = new QName(URI_ENVELOPE, "mustUnderstand");
+    public static final QName QNAME_ROLE                   = new QName(URI_ENVELOPE, "actor");
+    public final static QName QNAME_SOAP_BODY             = new QName(URI_ENVELOPE, "Body");
+    public final static QName QNAME_SOAP_FAULT             = new QName(URI_ENVELOPE, "Fault");
+    public final static QName QNAME_SOAP_FAULT_CODE             = new QName("", "faultcode");
+    public final static QName QNAME_SOAP_FAULT_STRING             = new QName("", "faultstring");
+    public final static QName QNAME_SOAP_FAULT_ACTOR             = new QName("", "faultactor");
+    public final static QName QNAME_SOAP_FAULT_DETAIL             = new QName("", "detail");
+    public final static QName FAULT_CODE_CLIENT            = new QName(URI_ENVELOPE, "Client");
+    public final static QName FAULT_CODE_SERVER            = new QName(URI_ENVELOPE, "Server");
+    public final static QName FAULT_CODE_MUST_UNDERSTAND   = new QName(URI_ENVELOPE, "MustUnderstand");
+
+    public final static QName FAULT_CODE_VERSION_MISMATCH  = new QName(URI_ENVELOPE, "VersionMismatch");
+    public final static QName FAULT_CODE_DATA_ENCODING_UNKNOWN = new QName(URI_ENVELOPE, "DataEncodingUnknown");
+    public final static QName FAULT_CODE_PROCEDURE_NOT_PRESENT = new QName(URI_ENVELOPE, "ProcedureNotPresent");
+    public final static QName FAULT_CODE_BAD_ARGUMENTS      = new QName(URI_ENVELOPE, "BadArguments");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPDecoder.java
new file mode 100644
index 0000000..dc3f09e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPDecoder.java
@@ -0,0 +1,680 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap;
+
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ContentType;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ParseException;
+import com.sun.xml.internal.messaging.saaj.util.ByteInputStream;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentUnmarshaller;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayloadSerializer;
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+import com.sun.xml.internal.ws.model.soap.SOAPRuntimeModel;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.streaming.SourceReaderFactory;
+import com.sun.xml.internal.ws.streaming.XMLReaderException;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderException;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+import com.sun.xml.internal.ws.client.dispatch.DispatchContext;
+import com.sun.xml.internal.ws.client.dispatch.impl.encoding.DispatchUtil;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.util.FastInfosetReflection;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.AttachmentPart;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPFault;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.soap.SOAPPart;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.transform.Source;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.ws.soap.SOAPFaultException;
+import javax.xml.ws.Service;
+import javax.xml.ws.WebServiceException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Set;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import static javax.xml.stream.XMLStreamReader.*;
+import javax.xml.bind.Unmarshaller;
+
+/**
+ * @author WS Development Team
+ */
+public abstract class SOAPDecoder implements Decoder {
+
+    public final static String NOT_UNDERSTOOD_HEADERS =
+        "not-understood soap headers";
+
+    protected static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".soap.decoder");
+
+    protected final static String MUST_UNDERSTAND_FAULT_MESSAGE_STRING =
+        "SOAP must understand error";
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.encoding.Decoder#decode(com.sun.pept.ept.MessageInfo)
+     */
+    public void decode(MessageInfo arg0) {
+        throw new UnsupportedOperationException();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.encoding.Decoder#receieveAndDecode(com.sun.pept.ept.MessageInfo)
+     */
+    public void receiveAndDecode(MessageInfo arg0) {
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * parses and binds headers, body from SOAPMessage.
+     *
+     * @param soapMessage
+     * @return the <code>InternalMessage</code> for the <code>soapMessage</code>
+     */
+    public InternalMessage toInternalMessage(SOAPMessage soapMessage,
+                                             MessageInfo messageInfo) {
+        return null;
+    }
+
+    /**
+     * Returns the roles required for the type of binding. Returns
+     * an empty set if there are none.
+     */
+    public Set<String> getRequiredRoles() {
+        return new HashSet<String>();
+    }
+
+    /**
+     * Parses and binds headers from SOAPMessage.
+     *
+     * @param soapMessage
+     * @param internalMessage
+     * @param messageInfo
+     * @return the InternalMessage representation of the SOAPMessage
+     */
+    public InternalMessage toInternalMessage(SOAPMessage soapMessage,
+                                             InternalMessage internalMessage, MessageInfo messageInfo) {
+        return null;
+    }
+
+    public SOAPMessage toSOAPMessage(MessageInfo messageInfo) {
+        return null;
+    }
+
+    public void toMessageInfo(InternalMessage internalMessage, MessageInfo messageInfo) {
+    }
+
+    protected QName getEnvelopeTag() {
+        return SOAPConstants.QNAME_SOAP_ENVELOPE;
+    }
+
+    protected QName getBodyTag() {
+        return SOAPConstants.QNAME_SOAP_BODY;
+    }
+
+    protected QName getHeaderTag() {
+        return SOAPConstants.QNAME_SOAP_HEADER;
+    }
+
+    protected QName getMUAttrQName() {
+        return SOAPConstants.QNAME_MUSTUNDERSTAND;
+    }
+
+    protected QName getRoleAttrQName() {
+        return SOAPConstants.QNAME_ROLE;
+    }
+
+    protected QName getFaultTag() {
+        return SOAPConstants.QNAME_SOAP_FAULT;
+    }
+
+    protected QName getFaultDetailTag() {
+        return SOAPConstants.QNAME_SOAP_FAULT_DETAIL;
+    }
+
+
+    protected void skipBody(XMLStreamReader reader) {
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getBodyTag());
+        XMLStreamReaderUtil.skipElement(reader);    // Moves to </Body>
+        XMLStreamReaderUtil.nextElementContent(reader);
+    }
+
+    protected void skipHeader(XMLStreamReader reader, MessageInfo messageInfo) {
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        if (!isDispatch(messageInfo))
+            return;
+
+        if (!SOAPNamespaceConstants.TAG_HEADER.equals(reader.getLocalName())) {
+            return;
+        }
+
+        //XMLStreamReaderUtil.verifyTag(reader, getHeaderTag());
+
+        dispatchUtil.collectPrefixes(reader);
+
+        XMLStreamReaderUtil.skipElement(reader);    // Moves to </Header>
+
+        try {
+            reader.next();
+        } catch (Exception ex) {
+            ex.printStackTrace();
+        }
+    }
+
+    protected boolean skipHeader(MessageInfo messageInfo) {
+        if (messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) ==
+            Service.Mode.PAYLOAD) {
+            return true;
+        }
+        return false;
+    }
+
+    /*
+    * skipBody is true, the body is skipped during parsing.
+    */
+    protected void decodeEnvelope(XMLStreamReader reader, InternalMessage request,
+                                  boolean skipBody, MessageInfo messageInfo) {
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getEnvelopeTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+        if (skipHeader(messageInfo))
+            skipHeader(reader, messageInfo);
+        else
+            decodeHeader(reader, messageInfo, request);
+
+
+        if (skipBody) {
+            skipBody(reader);
+        } else {
+            decodeBody(reader, request, messageInfo);
+        }
+
+
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getEnvelopeTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+        XMLStreamReaderUtil.verifyReaderState(reader, END_DOCUMENT);
+    }
+
+    protected void decodeHeader(XMLStreamReader reader, MessageInfo messageInfo,
+                                InternalMessage request) {
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+
+
+        if (!SOAPNamespaceConstants.TAG_HEADER.equals(reader.getLocalName())) {
+            return;
+        }
+        XMLStreamReaderUtil.verifyTag(reader, getHeaderTag());
+        if (isDispatch(messageInfo))
+            dispatchUtil.collectPrefixes(reader);
+        XMLStreamReaderUtil.nextElementContent(reader);
+        while (true) {
+            if (reader.getEventType() == START_ELEMENT) {
+                decodeHeaderElement(reader, messageInfo, request);
+            } else {
+                break;
+            }
+        }
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getHeaderTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+    }
+
+/*
+* If JAXB can deserialize a header, deserialize it.
+* Otherwise, just ignore the header
+*/
+
+    protected void decodeHeaderElement(XMLStreamReader reader, MessageInfo messageInfo,
+                                       InternalMessage msg) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        if (rtCtxt == null) {
+
+            XMLStreamReaderUtil.skipElement(reader);           // Moves to END state
+            XMLStreamReaderUtil.nextElementContent(reader);
+            return;
+        }
+        BridgeContext bridgeContext = rtCtxt.getBridgeContext();
+        Set<QName> knownHeaders = ((SOAPRuntimeModel) rtCtxt.getModel()).getKnownHeaders();
+        QName name = reader.getName();
+        if (knownHeaders != null && knownHeaders.contains(name)) {
+            QName headerName = reader.getName();
+            if (msg.isHeaderPresent(name)) {
+                // More than one instance of header whose QName is mapped to a
+                // method parameter. Generates a runtime error.
+                raiseFault(getSenderFaultCode(), DUPLICATE_HEADER + headerName);
+            }
+            Object decoderInfo = rtCtxt.getDecoderInfo(name);
+            if (decoderInfo != null && decoderInfo instanceof JAXBBridgeInfo) {
+                JAXBBridgeInfo bridgeInfo = (JAXBBridgeInfo) decoderInfo;
+// JAXB leaves on </env:Header> or <nextHeaderElement>
+                bridgeInfo.deserialize(reader, bridgeContext);
+                HeaderBlock headerBlock = new HeaderBlock(bridgeInfo);
+                msg.addHeader(headerBlock);
+            }
+        } else {
+            XMLStreamReaderUtil.skipElement(reader);           // Moves to END state
+            XMLStreamReaderUtil.nextElementContent(reader);
+        }
+    }
+
+    protected void decodeBody(XMLStreamReader reader, InternalMessage response,
+                              MessageInfo messageInfo) {
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getBodyTag());
+        int state = XMLStreamReaderUtil.nextElementContent(reader);
+        decodeBodyContent(reader, response, messageInfo);
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getBodyTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+    }
+
+    protected void decodeBodyContent(XMLStreamReader reader, InternalMessage response,
+                                     MessageInfo messageInfo) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        BridgeContext bridgeContext = rtCtxt.getBridgeContext();
+        decodeDispatchMethod(reader, response, messageInfo);
+        if (reader.getEventType() == START_ELEMENT) {
+            QName name = reader.getName(); // Operation name
+            if (name.getNamespaceURI().equals(getEnvelopeTag().getNamespaceURI()) &&
+                name.getLocalPart().equals(SOAPNamespaceConstants.TAG_FAULT)) {
+                SOAPFaultInfo soapFaultInfo = decodeFault(reader, response, messageInfo);
+                BodyBlock responseBody = new BodyBlock(soapFaultInfo);
+                response.setBody(responseBody);
+            } else {
+                Object decoderInfo = rtCtxt.getDecoderInfo(name);
+                if (decoderInfo != null && decoderInfo instanceof JAXBBridgeInfo)
+                {
+                    JAXBBridgeInfo bridgeInfo = (JAXBBridgeInfo) decoderInfo;
+                    bridgeInfo.deserialize(reader, bridgeContext);
+                    BodyBlock responseBody = new BodyBlock(bridgeInfo);
+                    response.setBody(responseBody);
+                } else
+                if (decoderInfo != null && decoderInfo instanceof RpcLitPayload)
+                {
+                    RpcLitPayload rpcLitPayload = (RpcLitPayload) decoderInfo;
+                    RpcLitPayloadSerializer.deserialize(reader, rpcLitPayload, bridgeContext);
+                    BodyBlock responseBody = new BodyBlock(rpcLitPayload);
+                    response.setBody(responseBody);
+                }
+            }
+        }
+    }
+
+    public void decodeDispatchMethod(XMLStreamReader reader, InternalMessage request, MessageInfo messageInfo) {
+    }
+
+    protected SOAPFaultInfo decodeFault(XMLStreamReader reader, InternalMessage internalMessage,
+                                        MessageInfo messageInfo) {
+        return null;
+    }
+
+/*
+*
+*/
+
+    protected void convertBodyBlock(InternalMessage request, MessageInfo messageInfo) {
+        BodyBlock bodyBlock = request.getBody();
+        if (bodyBlock != null) {
+            Object value = bodyBlock.getValue();
+            if (value instanceof JAXBBridgeInfo || value instanceof RpcLitPayload)
+            {
+                // Nothing to do
+            } else if (value instanceof Source) {
+                Source source = (Source) value;
+                XMLStreamReader reader = SourceReaderFactory.createSourceReader(source, true);
+                XMLStreamReaderUtil.nextElementContent(reader);
+                decodeBodyContent(reader, request, messageInfo);
+            } else {
+                throw new WebServiceException("Shouldn't happen. Unknown type in BodyBlock =" + value.getClass());
+            }
+        }
+    }
+
+    /**
+     * @param mi
+     * @param im
+     * @param message
+     * @throws SOAPException
+     * @throws ParseException
+     */
+    protected void processAttachments(MessageInfo mi, InternalMessage im, SOAPMessage message) throws SOAPException, ParseException, IOException {
+        Iterator iter = message.getAttachments();
+        if (iter.hasNext()) {
+            JAXWSAttachmentUnmarshaller au = null;
+            if (MessageInfoUtil.getRuntimeContext(mi) != null)
+                au = (JAXWSAttachmentUnmarshaller) MessageInfoUtil.getRuntimeContext(mi).getBridgeContext().getAttachmentUnmarshaller();
+            else {
+                //for dispatch
+                Unmarshaller m = (Unmarshaller)mi.getMetaData(BindingProviderProperties.DISPATCH_UNMARSHALLER);
+                if (m != null)
+                    au = (JAXWSAttachmentUnmarshaller) m.getAttachmentUnmarshaller();
+            }
+            if (au != null){
+                au.setXOPPackage(isXOPPackage(message));
+                au.setAttachments(im.getAttachments());
+            }
+        }
+
+        while (iter.hasNext()) {
+            AttachmentPart ap = (AttachmentPart) iter.next();
+            im.addAttachment(AttachmentBlock.fromSAAJ(ap));
+        }
+    }
+
+    /**
+     * From the SOAP message header find out if its a XOP package.
+     *
+     * @param sm
+     * @return
+     * @throws ParseException
+     */
+    private boolean isXOPPackage(SOAPMessage sm) throws ParseException {
+        String ct = getContentType(sm.getSOAPPart());
+        ContentType contentType = new ContentType(ct);
+        String primary = contentType.getPrimaryType();
+        String sub = contentType.getSubType();
+        if (primary.equalsIgnoreCase("application") && sub.equalsIgnoreCase("xop+xml"))
+        {
+            String type = contentType.getParameter("type");
+            if (type.toLowerCase().startsWith("text/xml") || type.toLowerCase().startsWith("application/soap+xml"))
+                return true;
+        }
+        return false;
+    }
+
+    private String getContentType(SOAPPart part) {
+        String[] values = part.getMimeHeader("Content-Type");
+        if (values == null)
+            return null;
+        else
+            return values[0];
+    }
+
+/*
+* It does mustUnderstand processing, and does best guess of MEP
+*
+* Avoids SAAJ call that create DOM.
+*
+*/
+
+    public boolean doMustUnderstandProcessing(SOAPMessage soapMessage,
+                                              MessageInfo mi, HandlerContext handlerContext, boolean getMEP)
+        throws SOAPException, IOException {
+        try {
+            boolean oneway = false;
+            Source source = soapMessage.getSOAPPart().getContent();
+            ByteInputStream bis = null;
+
+            if (source instanceof StreamSource) {
+                StreamSource streamSource = (StreamSource) source;
+                InputStream is = streamSource.getInputStream();
+                if (is != null && is instanceof ByteInputStream) {
+                    bis = ((ByteInputStream) is);
+                } else {
+                    logger.fine("SAAJ StreamSource doesn't have ByteInputStream " + is);
+                }
+            } else if (FastInfosetReflection.isFastInfosetSource(source)) {
+                try {
+                    bis = (ByteInputStream) FastInfosetReflection.
+                            FastInfosetSource_getInputStream(source);
+                }
+                catch (Exception e) {
+                    throw new XMLReaderException("fastinfoset.noImplementation");
+                }
+            } else {
+                logger.fine("Inefficient Use - SOAPMessage is already parsed");
+            }
+
+            XMLStreamReader reader =
+                SourceReaderFactory.createSourceReader(source, true);
+            XMLStreamReaderUtil.nextElementContent(reader);
+            checkMustUnderstandHeaders(reader, mi, handlerContext);
+
+            if (getMEP) {
+                oneway = isOneway(reader, mi);
+            }
+            XMLStreamReaderUtil.close(reader);
+            if (bis != null) {
+                bis.close();            // resets stream; SAAJ has whole stream
+            }
+
+            return oneway;
+        } catch (XMLStreamReaderException xe) {
+            raiseBadXMLFault(handlerContext);
+            throw xe;
+        }
+    }
+
+/*
+* returns Oneway or not. reader is on <Body>
+*
+* Peek into the body and make a best guess as to whether the request
+* is one-way or not. Assume request-response if it cannot be determined.
+*
+*/
+
+    private boolean isOneway(XMLStreamReader reader, MessageInfo mi) {
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getBodyTag());    // <Body>
+        int state = XMLStreamReaderUtil.nextElementContent(reader);
+        QName operationName = null;
+        if (state == START_ELEMENT) {   // handles empty Body i.e. <Body/>
+            operationName = reader.getName();
+        }
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(mi);
+        rtCtxt.setMethodAndMEP(operationName, mi);
+        return (mi.getMEP() == MessageStruct.ONE_WAY_MEP);
+    }
+
+    /*
+     * Does MU processing. reader is on <Envelope>, at the end of this method
+     * leaves it on <Body>. Once the roles and understood headers are
+     * known, this calls a separate method to check the message headers
+     * since a different behavior is expected with different bindings.
+     *
+     * Also assume handler chain caller is null unless one is found.
+     */
+    private void checkMustUnderstandHeaders(XMLStreamReader reader,
+                                            MessageInfo mi, HandlerContext context) {
+
+        // Decode envelope
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        QName got = reader.getName();
+        QName exp = getEnvelopeTag();
+        if (got.getLocalPart().equals(exp.getLocalPart())) {
+            if (!got.getNamespaceURI().equals(exp.getNamespaceURI())) {
+                raiseFault(getVersionMismatchFaultCode(),
+                    "Invalid SOAP envelope version");
+            }
+        }
+        XMLStreamReaderUtil.verifyTag(reader, getEnvelopeTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+
+
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        if (!SOAPNamespaceConstants.TAG_HEADER.equals(reader.getLocalName())) {
+            return;             // No Header, no MU processing
+        }
+        XMLStreamReaderUtil.verifyTag(reader, getHeaderTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(mi);
+
+        // start with just the endpoint roles
+        Set<String> roles = new HashSet<String>();
+        roles.addAll(getRequiredRoles());
+        HandlerChainCaller hcCaller = MessageInfoUtil.getHandlerChainCaller(mi);
+        if (hcCaller != null) {
+            roles.addAll(hcCaller.getRoles());
+        }
+
+        if (logger.isLoggable(Level.FINEST)) {
+            logger.finest("roles:");
+            for (String r : roles) {
+                logger.finest("\t\"" + r + "\"");
+            }
+        }
+
+        // keep set=null if there are no understood headers
+        Set<QName> understoodHeaders = null;
+        if (rtCtxt != null) {
+            SOAPRuntimeModel model = (SOAPRuntimeModel) rtCtxt.getModel();
+            if (model != null && model.getKnownHeaders() != null) {
+                understoodHeaders = new HashSet<QName>(
+                    ((SOAPRuntimeModel) rtCtxt.getModel()).getKnownHeaders());
+            }
+        }
+        if (understoodHeaders == null) {
+            if (hcCaller != null) {
+                understoodHeaders = hcCaller.getUnderstoodHeaders();
+            }
+        } else {
+            if (hcCaller != null) {
+                understoodHeaders.addAll(hcCaller.getUnderstoodHeaders());
+            }
+        }
+
+        if (logger.isLoggable(Level.FINEST)) {
+            logger.finest("understood headers:");
+            if (understoodHeaders == null || understoodHeaders.isEmpty()) {
+                logger.finest("\tnone");
+            } else {
+                for (QName nameX : understoodHeaders) {
+                    logger.finest("\t" + nameX.toString());
+                }
+            }
+        }
+
+        checkHeadersAgainstKnown(reader, roles, understoodHeaders, mi);
+
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getHeaderTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+    }
+
+    /*
+     * This method is overridden for other bindings
+     */
+    protected void checkHeadersAgainstKnown(XMLStreamReader reader,
+                                            Set<String> roles, Set<QName> understoodHeaders, MessageInfo mi) {
+
+        while (true) {
+            if (reader.getEventType() == START_ELEMENT) {
+                // check MU header for each role
+                QName qName = reader.getName();
+                String mu = reader.getAttributeValue(
+                    getMUAttrQName().getNamespaceURI(),
+                    getMUAttrQName().getLocalPart());
+                if (mu != null && (mu.equals("1") ||
+                    mu.equalsIgnoreCase("true"))) {
+                    String role = reader.getAttributeValue(
+                        getRoleAttrQName().getNamespaceURI(),
+                        getRoleAttrQName().getLocalPart());
+                    if (role != null && roles.contains(role)) {
+                        logger.finest("Element=" + qName +
+                            " targeted at=" + role);
+                        if (understoodHeaders == null ||
+                            !understoodHeaders.contains(qName)) {
+                            logger.finest("Element not understood=" + qName);
+
+                            SOAPFault sf = SOAPUtil.createSOAPFault(
+                                MUST_UNDERSTAND_FAULT_MESSAGE_STRING,
+                                SOAPConstants.FAULT_CODE_MUST_UNDERSTAND,
+                                role, null, SOAPBinding.SOAP11HTTP_BINDING);
+                            throw new SOAPFaultException(sf);
+                        }
+                    }
+                }
+                XMLStreamReaderUtil.skipElement(reader);   // Moves to END state
+                XMLStreamReaderUtil.nextElementContent(reader);
+            } else {
+                break;
+            }
+        }
+    }
+
+    protected boolean isDispatch(MessageInfo messageInfo) {
+
+        DispatchContext context = (DispatchContext)
+            messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT);
+        if (context != null)
+            return true;
+        return false;
+    }
+
+    protected String getSOAPMessageCharsetEncoding(SOAPMessage sm) throws SOAPException {
+        String charset = (String) sm.getProperty(SOAPMessage.CHARACTER_SET_ENCODING);
+        return (charset != null) ? charset : "UTF-8";
+    }
+
+    protected final void raiseFault(QName faultCode, String faultString) {
+        throw new SOAPFaultException(SOAPUtil.createSOAPFault(faultString, faultCode, null, null, getBindingId()));
+    }
+
+    protected void raiseBadXMLFault(HandlerContext ctxt) {
+    }
+
+    protected abstract QName getSenderFaultCode();
+
+    protected abstract QName getReceiverFaultCode();
+
+    protected abstract QName getVersionMismatchFaultCode();
+
+    public abstract String getBindingId();
+
+    private final static String DUPLICATE_HEADER =
+        "Duplicate Header in the message:";
+
+    public DispatchUtil getDispatchUtil() {
+        return dispatchUtil;
+    }
+
+    protected DispatchUtil dispatchUtil = new DispatchUtil();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPEPTFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPEPTFactory.java
new file mode 100644
index 0000000..112c49f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPEPTFactory.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap;
+
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.jaxb.*;
+
+/**
+ * Change the name of this class to JaxwsEPTFactory or something else. OR
+ * split into multiple factories.
+ */
+public interface SOAPEPTFactory {
+    public InternalEncoder getInternalEncoder();
+
+        /**
+         * @return the SOAPEncoder
+         */
+        public SOAPEncoder getSOAPEncoder();
+        /**
+         * @return the SOAPDecoder
+         */
+        public SOAPDecoder getSOAPDecoder();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPEncoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPEncoder.java
new file mode 100644
index 0000000..9db33bd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPEncoder.java
@@ -0,0 +1,780 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap;
+
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.client.dispatch.DispatchContext;
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.JAXB_OUTPUTSTREAM;
+import com.sun.xml.internal.ws.client.ContextMap;
+import com.sun.xml.internal.ws.client.RequestContext;
+import com.sun.xml.internal.ws.developer.JAXWSProperties;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentUnmarshaller;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBeanInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayloadSerializer;
+import com.sun.xml.internal.ws.encoding.soap.internal.*;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+import com.sun.xml.internal.ws.handler.SOAPHandlerContext;
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.server.ServerRtException;
+import com.sun.xml.internal.ws.spi.runtime.InternalSoapEncoder;
+import com.sun.xml.internal.ws.spi.runtime.MtomCallback;
+import com.sun.xml.internal.ws.streaming.SourceReaderFactory;
+import com.sun.xml.internal.ws.streaming.XMLStreamWriterFactory;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+import com.sun.xml.internal.ws.util.DOMUtil;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import org.w3c.dom.Document;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.soap.SOAPBody;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.ws.BindingProvider;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.soap.SOAPBinding;
+import java.io.OutputStream;
+import java.nio.ByteBuffer;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @author WS Development Team
+ */
+public abstract class SOAPEncoder implements Encoder, InternalSoapEncoder {
+
+    /*
+     * @see Encoder#encodeAndSend(MessageInfo)
+     */
+    public void encodeAndSend(MessageInfo messageInfo) {
+        throw new UnsupportedOperationException();
+    }
+
+    /*
+     * @see Encoder#encode(MessageInfo)
+     */
+    public ByteBuffer encode(MessageInfo messageInfo) {
+        throw new UnsupportedOperationException();
+    }
+
+    public InternalMessage toInternalMessage(MessageInfo messageInfo) {
+        return null;
+    }
+
+    public DOMSource toDOMSource(JAXBBridgeInfo bridgeInfo, MessageInfo messageInfo) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        BridgeContext bridgeContext = rtCtxt.getBridgeContext();
+        Document doc = DOMUtil.createDom();
+        bridgeInfo.serialize(bridgeContext, doc);
+        return new DOMSource(doc);
+    }
+
+    public DOMSource toDOMSource(RpcLitPayload rpcLitPayload, MessageInfo messageInfo) {
+        try {
+            ByteArrayBuffer baos = new ByteArrayBuffer();
+            XMLStreamWriter writer = XMLStreamWriterFactory.createXMLStreamWriter(baos);
+            writeRpcLitPayload(rpcLitPayload, messageInfo, writer);
+            writer.close();
+            baos.close();
+            Transformer transformer = XmlUtil.newTransformer();
+            StreamSource source = new StreamSource(baos.newInputStream());
+            DOMResult domResult = new DOMResult();
+            transformer.transform(source, domResult);
+            return new DOMSource(domResult.getNode());
+        } catch (TransformerException te) {
+            throw new WebServiceException(te);
+        } catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    public DOMSource toDOMSource(SOAPFaultInfo faultInfo, MessageInfo messageInfo) {
+        try {
+            ByteArrayBuffer baos = new ByteArrayBuffer();
+            XMLStreamWriter writer = XMLStreamWriterFactory.createXMLStreamWriter(baos);
+            writeFault(faultInfo, messageInfo, writer);
+            writer.writeEndDocument();
+            writer.close();
+            baos.close();
+            Transformer transformer = XmlUtil.newTransformer();
+            StreamSource source = new StreamSource(baos.newInputStream());
+            DOMResult domResult = new DOMResult();
+            transformer.transform(source, domResult);
+            return new DOMSource(domResult.getNode());
+        }
+        catch (TransformerException te) {
+            throw new WebServiceException(te);
+        }
+        catch (XMLStreamException xe) {
+            throw new WebServiceException(xe);
+        }
+    }
+
+    protected void writeRpcLitPayload(RpcLitPayload rpcLitPayload, MessageInfo messageInfo,
+                                      XMLStreamWriter writer) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        BridgeContext bridgeContext = rtCtxt.getBridgeContext();
+        RpcLitPayloadSerializer.serialize(rpcLitPayload, bridgeContext, messageInfo, writer);
+    }
+
+    protected void writeRpcLitPayload(RpcLitPayload rpcLitPayload, MessageInfo messageInfo,
+                                      OutputStream writer) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        BridgeContext bridgeContext = rtCtxt.getBridgeContext();
+        RpcLitPayloadSerializer.serialize(rpcLitPayload, bridgeContext, writer);
+    }
+    protected JAXBContext getJAXBContext(MessageInfo messageInfo) {
+            JAXBContext jc = null;
+            RequestContext context = (RequestContext) messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+            if (context != null)
+                jc = (JAXBContext) context.get(BindingProviderProperties.JAXB_CONTEXT_PROPERTY);
+
+            return jc;
+        }
+
+    private void writeJAXBBeanInfo(JAXBBeanInfo beanInfo, MessageInfo messageInfo,
+                                   XMLStreamWriter writer) {
+        // Pass output stream directly to JAXB when available
+        OutputStream os = (OutputStream) messageInfo.getMetaData(JAXB_OUTPUTSTREAM);
+
+        Marshaller m = (Marshaller) messageInfo.getMetaData(BindingProviderProperties.DISPATCH_MARSHALLER);
+        Unmarshaller u = (Unmarshaller) messageInfo.getMetaData(BindingProviderProperties.DISPATCH_UNMARSHALLER);
+        beanInfo.setMarshallers(m, u);
+
+        if (os != null) {
+            try {
+                /*
+                 * Make sure that current element is closed before passing the
+                 * output stream to JAXB. Using Zephyr, it suffices to write
+                 * an empty string (TODO: other StAX impls?).
+                 */
+                writer.writeCharacters("");
+
+                // Flush output of StAX serializer
+                writer.flush();
+            }
+            catch (XMLStreamException e) {
+                throw new WebServiceException(e);
+            }
+
+            beanInfo.writeTo(os);
+
+        } else {
+
+            beanInfo.writeTo(writer);
+        }
+    }
+
+    private void writeJAXBBeanInfo(JAXBBeanInfo beanInfo, OutputStream writer) {
+        beanInfo.writeTo(writer);
+    }
+
+    /*
+    protected void writeJAXBTypeInfo(JAXBTypeInfo typeInfo, XMLStreamWriter writer) {
+        QName name = typeInfo.getName();
+        Object value = typeInfo.getType();
+        writeJAXBTypeInfo(name, value, writer);
+    }
+
+
+    protected void writeJAXBTypeInfo(QName name, Object value, XMLStreamWriter writer) {
+        JAXBContext jaxbContext = encoderDecoderUtil.getJAXBContext();
+        Map<QName, Class> typeMapping = encoderDecoderUtil.getTypeMapping();
+        Class type = typeMapping.get(name);
+        JAXBTypeSerializer.getInstance().serialize(name, type, value,
+                writer, jaxbContext);
+    }
+     */
+
+    protected void writeJAXBBridgeInfo(JAXBBridgeInfo bridgeInfo,
+                                       MessageInfo messageInfo, XMLStreamWriter writer) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        BridgeContext bridgeContext = rtCtxt.getBridgeContext();
+
+        // Pass output stream directly to JAXB when available
+        OutputStream os = (OutputStream) messageInfo.getMetaData(JAXB_OUTPUTSTREAM);
+        if (os != null) {
+            try {
+                /*
+                 * Make sure that current element is closed before passing the
+                 * output stream to JAXB. Using Zephyr, it suffices to write
+                 * an empty string (TODO: other StAX impls?).
+                 */
+                writer.writeCharacters("");
+
+                // Flush output of StAX serializer
+                writer.flush();
+            }
+            catch (XMLStreamException e) {
+                throw new WebServiceException(e);
+            }
+
+            bridgeInfo.serialize(bridgeContext, os, writer.getNamespaceContext());
+        } else {
+            bridgeInfo.serialize(bridgeContext, writer);
+        }
+    }
+
+    protected void writeJAXBBridgeInfo(JAXBBridgeInfo bridgeInfo,
+                                       MessageInfo messageInfo, OutputStream writer) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        BridgeContext bridgeContext = rtCtxt.getBridgeContext();
+        bridgeInfo.serialize(bridgeContext, writer, null);
+    }
+
+
+    public SOAPMessage toSOAPMessage(InternalMessage internalMessage, MessageInfo messageInfo) {
+        return null;
+    }
+
+    /*
+     * Replace the body in SOAPMessage with the BodyBlock of InternalMessage
+     */
+    public SOAPMessage toSOAPMessage(InternalMessage internalMessage,
+                                     SOAPMessage soapMessage) {
+        try {
+            BodyBlock bodyBlock = internalMessage.getBody();
+            if (bodyBlock == null)
+                return soapMessage;
+            Object value = bodyBlock.getValue();
+            if (value == null) {
+                return soapMessage;
+            }
+            if (value instanceof Source) {
+                Source source = (Source) value;
+                SOAPBody body = soapMessage.getSOAPBody();
+                body.removeContents();
+
+                Transformer transformer = XmlUtil.newTransformer();
+                transformer.transform(source, new DOMResult(body));
+            } else {
+                throw new UnsupportedOperationException("Unknown object in BodyBlock:" + value.getClass());
+            }
+            return soapMessage;
+        } catch (Exception e) {
+            throw new ServerRtException("soapencoder.err", new Object[]{e});
+        }
+    }
+
+    public static void serializeReader(XMLStreamReader reader, XMLStreamWriter writer) {
+        try {
+            int state;
+            do {
+                state = reader.next();
+                switch (state) {
+                    case XMLStreamConstants.START_ELEMENT:
+                        /*
+                         * TODO: Is this necessary, shouldn't zephyr return "" instead of
+                         * null for getNamespaceURI() and getPrefix()?
+                         */
+                        String uri = reader.getNamespaceURI();
+                        String prefix = reader.getPrefix();
+                        String localName = reader.getLocalName();
+
+                        if (prefix == null) {
+                            if (uri == null) {
+                                writer.writeStartElement(localName);
+                            } else {
+                                writer.writeStartElement(uri, localName);
+                            }
+                        } else {
+                            assert uri != null;
+
+                            if (prefix.length() > 0) {
+                                /**
+                                 * Before we write the
+                                 */
+                                String writerURI = null;
+                                if (writer.getNamespaceContext() != null)
+                                    writerURI = writer.getNamespaceContext().getNamespaceURI(prefix);
+                                String writerPrefix = writer.getPrefix(uri);
+                                if (declarePrefix(prefix, uri, writerPrefix, writerURI))
+                                {
+                                    writer.writeStartElement(prefix, localName, uri);
+                                    writer.setPrefix(prefix, uri != null ? uri : "");
+                                    writer.writeNamespace(prefix, uri);
+                                } else {
+                                    writer.writeStartElement(prefix, localName, uri);
+                                }
+                            } else {
+                                writer.writeStartElement(prefix, localName, uri);
+                            }
+                        }
+
+                        int n = reader.getNamespaceCount();
+                        // Write namespace declarations
+                        for (int i = 0; i < n; i++) {
+                            String nsPrefix = reader.getNamespacePrefix(i);
+                            if (nsPrefix == null) nsPrefix = "";
+                            // StAX returns null for default ns
+                            String writerURI = null;
+                            if (writer.getNamespaceContext() != null)
+                                writerURI = writer.getNamespaceContext().getNamespaceURI(nsPrefix);
+
+                            // Zephyr: Why is this returning null?
+                            // Compare nsPrefix with prefix because of [1] (above)
+                            String readerURI = reader.getNamespaceURI(i);
+
+                            /**
+                             * write the namespace in 3 conditions
+                             *  - when the namespace URI is not bound to the prefix in writer(writerURI == 0)
+                             *  - when the readerPrefix and writerPrefix are ""
+                             *  - when readerPrefix and writerPrefix are not equal and the URI bound to them
+                             *    are different
+                             */
+                            if (writerURI == null || ((nsPrefix.length() == 0) || (prefix.length() == 0)) ||
+                                (!nsPrefix.equals(prefix) && !writerURI.equals(readerURI)))
+                            {
+                                writer.setPrefix(nsPrefix, readerURI != null ? readerURI : "");
+                                writer.writeNamespace(nsPrefix, readerURI != null ? readerURI : "");
+                            }
+                        }
+
+                        // Write attributes
+                        n = reader.getAttributeCount();
+                        for (int i = 0; i < n; i++) {
+                            String attrPrefix = reader.getAttributePrefix(i);
+                            String attrURI = reader.getAttributeNamespace(i);
+
+                            writer.writeAttribute(attrPrefix != null ? attrPrefix : "",
+                                attrURI != null ? attrURI : "",
+                                reader.getAttributeLocalName(i),
+                                reader.getAttributeValue(i));
+                            // if the attribute prefix is undeclared in current writer scope then declare it
+                            setUndeclaredPrefix(attrPrefix, attrURI, writer);
+                        }
+                        break;
+                    case XMLStreamConstants.END_ELEMENT:
+                        writer.writeEndElement();
+                        break;
+                    case XMLStreamConstants.CHARACTERS:
+                        writer.writeCharacters(reader.getText());
+                }
+            } while (state != XMLStreamConstants.END_DOCUMENT);
+        }
+        catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    /**
+     * sets undeclared prefixes on the writer
+     *
+     * @param prefix
+     * @param writer
+     * @throws XMLStreamException
+     */
+    private static void setUndeclaredPrefix(String prefix, String readerURI, XMLStreamWriter writer) throws XMLStreamException {
+        String writerURI = null;
+        if (writer.getNamespaceContext() != null)
+            writerURI = writer.getNamespaceContext().getNamespaceURI(prefix);
+
+        if (writerURI == null) {
+            writer.setPrefix(prefix, readerURI != null ? readerURI : "");
+            writer.writeNamespace(prefix, readerURI != null ? readerURI : "");
+        }
+    }
+
+    /**
+     * check if we need to declare
+     *
+     * @param rPrefix
+     * @param rUri
+     * @param wPrefix
+     * @param wUri
+     * @return
+     */
+    private static boolean declarePrefix(String rPrefix, String rUri, String wPrefix, String wUri) {
+        if (wUri == null || ((wPrefix != null) && !rPrefix.equals(wPrefix)) ||
+            (rUri != null && !wUri.equals(rUri)))
+            return true;
+        return false;
+    }
+
+    protected void serializeSource(Source source, XMLStreamWriter writer) {
+        try {
+            XMLStreamReader reader = SourceReaderFactory.createSourceReader(source, true);
+            serializeReader(reader, writer);
+            reader.close();
+        }
+        catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    protected void serializeSource(Source source, OutputStream writer) {
+        try {
+            Transformer t = XmlUtil.newTransformer();
+            t.transform(source, new StreamResult(writer));
+        }
+        catch (Exception e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    /*
+     * writes start tag of envelope: <env:Envelope>
+     */
+    protected void startEnvelope(XMLStreamWriter writer) {
+        try {
+            //write SOAP Envelope
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_ENVELOPE, SOAPNamespaceConstants.ENVELOPE);
+            writer.setPrefix(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.ENVELOPE);
+            writer.writeNamespace(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.ENVELOPE);
+        }
+        catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    /*
+     * write the known namespace declaration to the envelope
+     */
+    protected void writeEnvelopeNamespaces(XMLStreamWriter writer, MessageInfo messageInfo)
+        throws XMLStreamException {
+
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        if (rtCtxt != null && rtCtxt.getModel() != null) {
+            writer.setPrefix("xsd", SOAPNamespaceConstants.XSD);
+            writer.writeNamespace("xsd", SOAPNamespaceConstants.XSD);
+            int i = 1;
+            String prefix;
+            for (String namespace : rtCtxt.getModel().getKnownNamespaceURIs()) {
+                prefix = "ns" + i++;
+                writer.setPrefix(prefix, namespace);
+                writer.writeNamespace(prefix, namespace);
+            }
+            writer.writeCharacters("");
+        }
+    }
+
+    /*
+    * writes start tag of Body: <env:Body>
+    */
+    protected void startBody(XMLStreamWriter writer) {
+        try {
+            //write SOAP Body
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_BODY, SOAPNamespaceConstants.ENVELOPE);
+        }
+        catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    /*
+     * writes start tag of Header: <env:Header>
+     */
+    protected void startHeader(XMLStreamWriter writer) {
+        try {
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_HEADER, SOAPNamespaceConstants.ENVELOPE); // <env:Header>
+        }
+        catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    /*
+     * writes multiple header elements in <env:Header> ... </env:Header>
+     */
+    protected void writeHeaders(XMLStreamWriter writer, InternalMessage response,
+                                MessageInfo messageInfo) {
+        try {
+            List<HeaderBlock> headerBlocks = response.getHeaders();
+            if (headerBlocks == null || headerBlocks.isEmpty()) {
+                return;
+            }
+            startHeader(writer); // <env:Header>
+            for (HeaderBlock headerBlock : headerBlocks) {
+                Object value = headerBlock.getValue();
+                if (value != null) {
+                    if (value instanceof JAXBBridgeInfo) {
+                        writeJAXBBridgeInfo((JAXBBridgeInfo) value,
+                            messageInfo, writer);
+                    } else {
+                        throw new SerializationException("unknown.object",
+                            value.getClass().getName());
+                    }
+                } else {
+                    // currently only in soap 1.2
+                    if (headerBlock instanceof SOAP12NotUnderstoodHeaderBlock) {
+                        ((SOAP12NotUnderstoodHeaderBlock) headerBlock).write(
+                            writer);
+                    }
+                }
+            }
+            writer.writeEndElement();                                // </env:Header>
+        }
+        catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    /*
+     * writes <env:Body> ... </env:Body>
+     */
+    protected void writeBody(XMLStreamWriter writer, InternalMessage response,
+                             MessageInfo messageInfo) {
+        try {
+            startBody(writer);
+            BodyBlock bodyBlock = response.getBody();
+            // BodyBlock can be null if there is no part in wsdl:message
+            if (bodyBlock != null) {
+                Object value = bodyBlock.getValue();
+                if (value instanceof JAXBBridgeInfo) {
+                    writeJAXBBridgeInfo((JAXBBridgeInfo) value, messageInfo, writer);
+                } else if (value instanceof RpcLitPayload) {
+                    writeRpcLitPayload((RpcLitPayload) value, messageInfo, writer);
+                } else if (value instanceof Source) {
+                    serializeSource((Source) value, writer);
+                } else if (value instanceof SOAPFaultInfo) {
+                    writeFault((SOAPFaultInfo) value, messageInfo, writer);
+                } else if (value instanceof JAXBBeanInfo) {
+
+                       if (((JAXBBeanInfo)value).getBean() != null && (DispatchContext)
+                    messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT) != null)
+                       writeJAXBBeanInfo((JAXBBeanInfo) value, messageInfo, writer);
+                } else if (value == null && (DispatchContext)
+                    messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT) != null) {
+                    //bug 6400596  -Dispatch and null invocation parameter payload mode
+                    //can skip this here as we want to write and empty SOAPBody
+                    //writeJAXBBeanInfo((JAXBBeanInfo) value, messageInfo, writer);
+                } else {
+                    throw new SerializationException("unknown.object",
+                        value.getClass().getName());
+                }
+            }
+            writer.writeEndElement();                // </env:body>
+        }
+        catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    /**
+     * Pass reference of attachments Map from InternalMessage to JAXWSAttachmentMarshaller.
+     *
+     * @param mi
+     * @param im
+     */
+    public void setAttachmentsMap(MessageInfo mi, InternalMessage im) {
+        Object rtc = mi.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        if (rtc != null) {
+            BridgeContext bc = ((RuntimeContext) rtc).getBridgeContext();
+            if (bc == null)
+                return;
+            JAXWSAttachmentMarshaller am = (JAXWSAttachmentMarshaller) bc.getAttachmentMarshaller();
+            am.setAttachments(im.getAttachments());
+            am.setHandlerContaxt(((RuntimeContext) rtc).getHandlerContext());
+
+            HandlerContext hc = ((RuntimeContext) rtc).getHandlerContext();
+            Object mtomThreshold;
+            if (hc == null) {
+                //to be removed when client guarantees handlerContext
+                mtomThreshold = mi.getMetaData(JAXWSProperties.MTOM_THRESHOLOD_VALUE);
+            } else {
+                mtomThreshold = hc.getMessageContext().get(JAXWSProperties.MTOM_THRESHOLOD_VALUE);
+            }
+            if (mtomThreshold != null)
+                am.setMtomThresholdValue((Integer) mtomThreshold);
+        } else if (mi.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT) != null){
+            ContextMap map = (ContextMap) mi.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+            BindingProvider provider = (BindingProvider)
+                map.get(BindingProviderProperties.JAXWS_CLIENT_HANDLE_PROPERTY);
+
+            JAXBContext jc = (JAXBContext) map.get(BindingProviderProperties.JAXB_CONTEXT_PROPERTY);
+
+            if (jc != null) {
+                try {
+                    Marshaller m = jc.createMarshaller();
+                    Unmarshaller um = jc.createUnmarshaller();
+                    JAXWSAttachmentMarshaller am =
+                        new JAXWSAttachmentMarshaller(((SOAPBinding) provider.getBinding()).isMTOMEnabled());
+                    JAXWSAttachmentUnmarshaller uam = new JAXWSAttachmentUnmarshaller();
+                    am.setAttachments(im.getAttachments());
+                    m.setAttachmentMarshaller(am);
+                    um.setAttachmentUnmarshaller(uam);
+                    mi.setMetaData(BindingProviderProperties.DISPATCH_MARSHALLER, m);
+                    mi.setMetaData(BindingProviderProperties.DISPATCH_UNMARSHALLER, um);
+                    //set handlerContext
+                    am.setHandlerContaxt((SOAPHandlerContext)
+                    mi.getMetaData(BindingProviderProperties.JAXWS_HANDLER_CONTEXT_PROPERTY));
+
+                    HandlerContext hc =
+                        (HandlerContext)mi.getMetaData(BindingProviderProperties.JAXWS_HANDLER_CONTEXT_PROPERTY);
+                    //set XOP optimization to true for jaxb
+                    am.setXOPPackage(((SOAPBinding)provider.getBinding()).isMTOMEnabled());
+                    uam.setXOPPackage(((SOAPBinding)provider.getBinding()).isMTOMEnabled());
+
+                    Object mtomThreshold;
+                    if (hc == null) {
+                        //to be removed when client guarantees handlerContext
+                        mtomThreshold = mi.getMetaData(JAXWSProperties.MTOM_THRESHOLOD_VALUE);
+                    } else {
+                        mtomThreshold = hc.getMessageContext().get(JAXWSProperties.MTOM_THRESHOLOD_VALUE);
+                    }
+                    if (mtomThreshold != null)
+                        am.setMtomThresholdValue((Integer) mtomThreshold);
+                } catch (Exception e) {
+                    throw new WebServiceException(e);
+                }
+
+            }
+
+        }
+    }
+
+    /**
+     * Add all the attachments in the InternalMessage to the SOAPMessage
+     *
+     * @param im
+     * @param msg
+     */
+    protected void processAttachments(InternalMessage im, SOAPMessage msg) throws SOAPException {
+        for (Map.Entry<String, AttachmentBlock> e : im.getAttachments().entrySet()) {
+            AttachmentBlock block = e.getValue();
+            block.addTo(msg);
+        }
+    }
+
+    /*
+    * writes end tag of envelope: </env:Envelope>
+    */
+    protected void endEnvelope(XMLStreamWriter writer) {
+        try {
+            writer.writeEndElement();
+        }
+        catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    protected void writeFault(SOAPFaultInfo instance, MessageInfo messageInfo, XMLStreamWriter writer) {
+        throw new UnsupportedOperationException();
+    }
+
+    protected void writeFault(SOAPFaultInfo instance, MessageInfo messageInfo, OutputStream out) {
+        XMLStreamWriter writer = XMLStreamWriterFactory.createXMLStreamWriter(out);
+        writeFault(instance, messageInfo, writer);
+    }
+
+
+    public void write(Object value, Object obj, OutputStream writer, MtomCallback mtomCallback) {
+        if (!(obj instanceof MessageInfo))
+            throw new SerializationException("incorrect.messageinfo", obj.getClass().getName());
+        MessageInfo mi = (MessageInfo) obj;
+        Object rtc = mi.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        if (rtc != null) {
+            BridgeContext bc = ((RuntimeContext) rtc).getBridgeContext();
+            if (bc != null) {
+                JAXWSAttachmentMarshaller am = (JAXWSAttachmentMarshaller)
+                        ((RuntimeContext) rtc).getBridgeContext().getAttachmentMarshaller();
+                am.setMtomCallback(mtomCallback);
+            }
+        } else {
+            //dispatch
+            Marshaller m = (Marshaller)mi.getMetaData(BindingProviderProperties.DISPATCH_MARSHALLER);
+            if (m != null) {
+                JAXWSAttachmentMarshaller am = (JAXWSAttachmentMarshaller)m.getAttachmentMarshaller();
+                am.setMtomCallback(mtomCallback);
+            }
+        }
+        if (value instanceof JAXBBridgeInfo) {
+            writeJAXBBridgeInfo((JAXBBridgeInfo) value, mi, writer);
+        } else if (value instanceof RpcLitPayload) {
+            writeRpcLitPayload((RpcLitPayload) value, mi, writer);
+        } else if (value instanceof Source) {
+            serializeSource((Source) value, writer);
+        } else if (value instanceof SOAPFaultInfo) {
+            writeFault((SOAPFaultInfo) value, mi, writer);
+        } else if (value instanceof JAXBBeanInfo) {
+            writeJAXBBeanInfo((JAXBBeanInfo) value, writer);
+        } else {
+            throw new SerializationException("unknown.object", value.getClass().getName());
+        }
+    }
+
+    public void write(Object value, Object obj, XMLStreamWriter writer, MtomCallback mtomCallback) {
+        if (!(obj instanceof MessageInfo))
+            throw new SerializationException("incorrect.messageinfo", obj.getClass().getName());
+        MessageInfo mi = (MessageInfo) obj;
+        Object rtc = mi.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        if (rtc != null) {
+            BridgeContext bc = ((RuntimeContext) rtc).getBridgeContext();
+            if (bc != null) {
+                JAXWSAttachmentMarshaller am = (JAXWSAttachmentMarshaller) ((RuntimeContext) rtc).getBridgeContext().getAttachmentMarshaller();
+                am.setMtomCallback(mtomCallback);
+            }
+        } else {
+            //dispatch
+            Marshaller m = (Marshaller)mi.getMetaData(BindingProviderProperties.DISPATCH_MARSHALLER);
+            if (m != null) {
+                JAXWSAttachmentMarshaller am = (JAXWSAttachmentMarshaller)m.getAttachmentMarshaller();
+                am.setMtomCallback(mtomCallback);
+            }
+        }
+        if (value instanceof JAXBBridgeInfo) {
+            writeJAXBBridgeInfo((JAXBBridgeInfo) value, mi, writer);
+        } else if (value instanceof RpcLitPayload) {
+            writeRpcLitPayload((RpcLitPayload) value, mi, writer);
+        } else if (value instanceof Source) {
+            serializeSource((Source) value, writer);
+        } else if (value instanceof SOAPFaultInfo) {
+            writeFault((SOAPFaultInfo) value, mi, writer);
+        } else if (value instanceof JAXBBeanInfo) {
+            writeJAXBBeanInfo((JAXBBeanInfo) value, mi, writer);
+        } else {
+            throw new SerializationException("unknown.object", value.getClass().getName());
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPVersion.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPVersion.java
new file mode 100644
index 0000000..dc6b152
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SOAPVersion.java
@@ -0,0 +1,53 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap;
+
+import javax.xml.ws.soap.SOAPBinding;
+
+
+/**
+ * @author WS Development Team
+ */
+
+public class SOAPVersion {
+
+    private final String version;
+
+    private SOAPVersion(String ver) {
+        this.version = ver;
+    }
+
+    public String toString() {
+        return this.version;
+    }
+
+    public boolean equals(String strVersion) {
+        return version.equals(strVersion);
+    }
+
+    public static final SOAPVersion SOAP_11 = new SOAPVersion(SOAPBinding.SOAP11HTTP_BINDING);
+    public static final SOAPVersion SOAP_12 = new SOAPVersion(SOAPBinding.SOAP12HTTP_BINDING);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SerializationException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SerializationException.java
new file mode 100644
index 0000000..da58eb1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SerializationException.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap;
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * SerializationException represents an exception that occurred while
+ * serializing a Java value as XML.
+ *
+ * @see JAXWSExceptionBase
+ *
+ * @author WS Development Team
+ */
+public class SerializationException extends JAXWSExceptionBase {
+
+    public SerializationException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public SerializationException(Localizable arg) {
+        super("nestedSerializationError", arg);
+    }
+
+    public SerializationException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.encoding";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SerializerConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SerializerConstants.java
new file mode 100644
index 0000000..e6b7cd7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/SerializerConstants.java
@@ -0,0 +1,44 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.ws.encoding.soap;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface SerializerConstants {
+    public static final boolean ENCODE_TYPE             = true;
+    public static final boolean DONT_ENCODE_TYPE        = false;
+    public static final boolean SERIALIZE_AS_REF        = true;
+    public static final boolean DONT_SERIALIZE_AS_REF   = false;
+    public static final boolean REFERENCEABLE           = true;
+    public static final boolean NOT_REFERENCEABLE       = false;
+    public static final boolean NULLABLE                = true;
+    public static final boolean NOT_NULLABLE            = false;
+    public static final boolean REFERENCED_INSTANCE     = true;
+    public static final boolean UNREFERENCED_INSTANCE   = false;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/ServerEncoderDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/ServerEncoderDecoder.java
new file mode 100644
index 0000000..309ebc1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/ServerEncoderDecoder.java
@@ -0,0 +1,236 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.model.CheckedException;
+import com.sun.xml.internal.ws.model.ExceptionType;
+import com.sun.xml.internal.ws.model.JavaMethod;
+import com.sun.xml.internal.ws.model.Parameter;
+import com.sun.xml.internal.ws.model.ParameterBinding;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.model.WrapperParameter;
+import com.sun.xml.internal.ws.model.soap.SOAPBinding;
+import com.sun.xml.internal.ws.model.soap.SOAPRuntimeModel;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.StringUtils;
+
+import javax.xml.ws.Holder;
+import java.lang.reflect.Field;
+import java.lang.reflect.Method;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @author Vivek Pandey
+ *
+ * Server SOAP encoder decoder
+ */
+public class ServerEncoderDecoder extends EncoderDecoder implements InternalEncoder {
+    public ServerEncoderDecoder() {
+    }
+
+    /*
+     * (non-Javadoc)
+     *
+     * @see com.sun.xml.internal.ws.encoding.util.EncoderDecoderBase#toMessageInfo(java.lang.Object,
+     *      com.sun.pept.ept.MessageInfo)
+     */
+    public void toMessageInfo(Object intMessage, MessageInfo mi) {
+        InternalMessage im = (InternalMessage) intMessage;
+        RuntimeContext rtContext = (RuntimeContext) mi.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+
+        BodyBlock bodyBlock = im.getBody();
+        JavaMethod jm = rtContext.getModel().getJavaMethod(mi.getMethod());
+        mi.setMEP(jm.getMEP());
+        List<HeaderBlock> headers = im.getHeaders();
+        Map<String, AttachmentBlock> attachments = im.getAttachments();
+
+        Iterator<Parameter> iter = jm.getRequestParameters().iterator();
+        Object bodyValue = (bodyBlock == null) ? null :  bodyBlock.getValue();
+
+        int numInputParams = jm.getInputParametersCount();
+        Object data[] = new Object[numInputParams];
+        SOAPBinding soapBinding = (SOAPBinding)jm.getBinding();
+        while (iter.hasNext()) {
+            Parameter param = iter.next();
+            ParameterBinding paramBinding = param.getInBinding();
+            Object obj = null;
+            if (paramBinding.isBody()) {
+                obj = bodyValue;
+            } else if (headers != null && paramBinding.isHeader()) {
+                HeaderBlock header = getHeaderBlock(param.getName(), headers);
+                obj = (header != null)?header.getValue():null;
+            } else if (paramBinding.isAttachment()) {
+              obj = getAttachment(rtContext, attachments, param, paramBinding);
+            }
+            fillData(rtContext, param, obj, data, soapBinding, paramBinding);
+        }
+        Iterator<Parameter> resIter = jm.getResponseParameters().iterator();
+        while(resIter.hasNext()){
+            Parameter p = resIter.next();
+            createOUTHolders(p, data);
+        }
+        mi.setData(data);
+    }
+
+    /*
+     * (non-Javadoc)
+     *
+     * @see com.sun.xml.internal.ws.encoding.util.EncoderDecoderBase#toInternalMessage(com.sun.pept.ept.MessageInfo)
+     */
+    public Object toInternalMessage(MessageInfo mi) {
+        RuntimeContext rtContext = MessageInfoUtil.getRuntimeContext(mi);
+        RuntimeModel model = rtContext.getModel();
+        JavaMethod jm = model.getJavaMethod(mi.getMethod());
+        Object[] data = mi.getData();
+        Object result = mi.getResponse();
+        InternalMessage im = new InternalMessage();
+        if(rtContext.getHandlerContext() != null){
+            copyAttachmentProperty(rtContext.getHandlerContext().getMessageContext(), im);
+        }
+        BindingImpl bindingImpl =
+            (BindingImpl)rtContext.getRuntimeEndpointInfo().getBinding();
+        String bindingId = bindingImpl.getBindingId();
+
+        switch (mi.getResponseType()) {
+            case MessageStruct.CHECKED_EXCEPTION_RESPONSE:
+                if(!(result instanceof java.lang.Exception)){
+                    throw new SerializationException("exception.incorrectType", result.getClass().toString());
+                }
+                CheckedException ce = jm.getCheckedException(result.getClass());
+                if(ce == null){
+                    throw new SerializationException("exception.notfound", result.getClass().toString());
+                }
+                Object detail = getDetail(jm.getCheckedException(result.getClass()), result);
+                JAXBBridgeInfo di = new JAXBBridgeInfo(model.getBridge(ce.getDetailType()), detail);
+
+                if (bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_BINDING)) {
+                    SOAPRuntimeModel.createFaultInBody(result, null, di, im);
+                } else if (bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING)){
+                    SOAPRuntimeModel.createSOAP12FaultInBody(result, null, null, di, im);
+                }
+
+                return im;
+            case MessageStruct.UNCHECKED_EXCEPTION_RESPONSE:
+                if (bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_BINDING))
+                    SOAPRuntimeModel.createFaultInBody(result, getActor(), null, im);
+                else if (bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING))
+                    SOAPRuntimeModel.createSOAP12FaultInBody(result, null, null, null, im);
+                return im;
+        }
+
+        SOAPBinding soapBinding = (SOAPBinding)jm.getBinding();
+        Iterator<Parameter> iter = jm.getResponseParameters().iterator();
+        while (iter.hasNext()) {
+            Parameter param = iter.next();
+            ParameterBinding paramBinding = param.getOutBinding();
+            Object obj = createPayload(rtContext, param, data, result, soapBinding, paramBinding);
+            if (paramBinding.isBody()) {
+                im.setBody(new BodyBlock(obj));
+            } else if (paramBinding.isHeader()) {
+                im.addHeader(new HeaderBlock((JAXBBridgeInfo)obj));
+            } else if (paramBinding.isAttachment()) {
+                addAttachmentPart(rtContext, im, obj, param);
+            }
+        }
+        return im;
+    }
+
+    private Object getDetail(CheckedException ce, Object exception) {
+        if(ce.getExceptionType().equals(ExceptionType.UserDefined)){
+            return createDetailFromUserDefinedException(ce, exception);
+        }
+        try {
+            Method m = exception.getClass().getMethod("getFaultInfo");
+            return m.invoke(exception);
+        } catch(Exception e){
+            throw new SerializationException(e);
+        }
+    }
+
+    private Object createDetailFromUserDefinedException(CheckedException ce, Object exception) {
+        Class detailBean = ce.getDetailBean();
+        Field[] fields = detailBean.getDeclaredFields();
+        try {
+            Object detail = detailBean.newInstance();
+            for(Field f : fields){
+                Method em = exception.getClass().getMethod(getReadMethod(f));
+                Method sm = detailBean.getMethod(getWriteMethod(f), em.getReturnType());
+                sm.invoke(detail, em.invoke(exception));
+            }
+            return detail;
+        } catch(Exception e){
+            throw new SerializationException(e);
+        }
+    }
+
+    private String getReadMethod(Field f){
+        if(f.getType().isAssignableFrom(boolean.class))
+            return "is" + StringUtils.capitalize(f.getName());
+        return "get" + StringUtils.capitalize(f.getName());
+    }
+
+    private String getWriteMethod(Field f){
+        return "set" + StringUtils.capitalize(f.getName());
+    }
+
+    /**
+     * @return the actor
+     */
+    public String getActor() {
+        return null;
+    }
+
+    /**
+     * To be used by the incoming message on the server side to set the OUT
+     * holders with Holder instance.
+     *
+     * @param data
+     */
+    private void createOUTHolders(Parameter param, Object[] data) {
+        if(param.isWrapperStyle()){
+            for(Parameter p : ((WrapperParameter)param).getWrapperChildren()){
+                if(!p.isResponse() && p.isOUT())
+                    data[p.getIndex()] = new Holder();
+            }
+            return;
+        }
+        //its BARE
+        if (!param.isResponse() && param.isOUT())
+            data[param.getIndex()] = new Holder();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAP12XMLDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAP12XMLDecoder.java
new file mode 100644
index 0000000..427e783
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAP12XMLDecoder.java
@@ -0,0 +1,350 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.client;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.simpletype.EncoderUtils;
+import com.sun.xml.internal.ws.encoding.soap.DeserializationException;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.FaultCode;
+import com.sun.xml.internal.ws.encoding.soap.message.FaultCodeEnum;
+import com.sun.xml.internal.ws.encoding.soap.message.FaultReason;
+import com.sun.xml.internal.ws.encoding.soap.message.FaultReasonText;
+import com.sun.xml.internal.ws.encoding.soap.message.FaultSubcode;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAP12FaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.model.soap.SOAPRuntimeModel;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import com.sun.xml.internal.ws.client.dispatch.impl.encoding.DispatchSerializer;
+
+import javax.xml.namespace.QName;
+import static javax.xml.stream.XMLStreamConstants.*;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.ws.soap.SOAPBinding;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Locale;
+import java.util.Set;
+import java.util.logging.Logger;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAP12XMLDecoder extends SOAPXMLDecoder {
+
+    //needs further cleanup
+    private static final Logger logger =
+        Logger.getLogger (new StringBuffer ().append (com.sun.xml.internal.ws.util.Constants.LoggingDomain).append (".client.dispatch").toString ());
+
+    public SOAP12XMLDecoder () {
+    }
+
+    protected DispatchSerializer getSerializerInstance (){
+        return DispatchSerializer.SOAP_1_2;
+    }
+
+    /*
+     *
+     * @see SOAPXMLDecoder#decodeFault(XMLStreamReader, InternalMessage, MessageInfo)
+     */
+    @Override
+    protected SOAPFaultInfo decodeFault (XMLStreamReader reader, InternalMessage internalMessage, MessageInfo messageInfo) {
+        XMLStreamReaderUtil.verifyReaderState (reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_SOAP_FAULT);
+
+        // env:Code
+        XMLStreamReaderUtil.nextElementContent (reader);
+        XMLStreamReaderUtil.verifyReaderState (reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_FAULT_CODE);
+        XMLStreamReaderUtil.nextElementContent (reader);
+
+        //env:Value
+        QName faultcode = readFaultValue (reader);
+        FaultCodeEnum codeValue = FaultCodeEnum.get (faultcode);
+        if(codeValue == null)
+            throw new DeserializationException ("unknown fault code:", faultcode.toString ());
+
+
+        //Subcode
+        FaultSubcode subcode = null;
+        if(reader.getEventType () == START_ELEMENT)
+            subcode = readFaultSubcode (reader);
+        FaultCode code = new FaultCode (codeValue, subcode);
+
+        XMLStreamReaderUtil.verifyReaderState (reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_FAULT_CODE);
+        XMLStreamReaderUtil.nextElementContent (reader);
+
+        FaultReason reason = readFaultReason (reader);
+        String node = null;
+        String role = null;
+        Object detail = null;
+
+        QName name = reader.getName ();
+        if(name.equals (SOAP12Constants.QNAME_FAULT_NODE)){
+            node = reader.getText ();
+        }
+
+        if(name.equals (SOAP12Constants.QNAME_FAULT_ROLE)){
+            XMLStreamReaderUtil.nextContent (reader);
+            role = reader.getText ();
+            XMLStreamReaderUtil.nextElementContent (reader);
+            XMLStreamReaderUtil.nextElementContent (reader);
+        }
+
+        if(name.equals (SOAP12Constants.QNAME_FAULT_DETAIL)){
+            //TODO: process encodingStyle attribute information item
+            XMLStreamReaderUtil.nextElementContent (reader);
+            detail = readFaultDetail (reader, messageInfo);
+            XMLStreamReaderUtil.nextElementContent (reader);
+        }
+
+        XMLStreamReaderUtil.verifyReaderState (reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_SOAP_FAULT);
+        XMLStreamReaderUtil.nextElementContent (reader);
+
+        return new SOAP12FaultInfo (code, reason, node, role, detail);
+    }
+
+    protected QName readFaultValue (XMLStreamReader reader){
+        XMLStreamReaderUtil.verifyReaderState (reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_FAULT_VALUE);
+
+        XMLStreamReaderUtil.nextContent (reader);
+
+        String tokens = reader.getText ();
+
+        XMLStreamReaderUtil.next (reader);
+        XMLStreamReaderUtil.verifyReaderState (reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_FAULT_VALUE);
+        XMLStreamReaderUtil.nextElementContent (reader);
+
+        String uri = "";
+        tokens = EncoderUtils.collapseWhitespace (tokens);
+        String prefix = XmlUtil.getPrefix (tokens);
+        if (prefix != null) {
+            uri = reader.getNamespaceURI (prefix);
+            if (uri == null) {
+                throw new DeserializationException ("xsd.unknownPrefix", prefix);
+            }
+        }
+        String localPart = XmlUtil.getLocalPart (tokens);
+        return new QName (uri, localPart);
+    }
+
+    protected FaultSubcode readFaultSubcode (XMLStreamReader reader){
+        FaultSubcode code = null;
+        QName name = reader.getName ();
+        if(name.equals (SOAP12Constants.QNAME_FAULT_SUBCODE)){
+            XMLStreamReaderUtil.nextElementContent (reader);
+            QName faultcode = readFaultValue (reader);
+            FaultSubcode subcode = null;
+            if(reader.getEventType () == START_ELEMENT)
+                subcode = readFaultSubcode (reader);
+            code = new FaultSubcode (faultcode, subcode);
+            XMLStreamReaderUtil.verifyReaderState (reader, END_ELEMENT);
+            XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_FAULT_SUBCODE);
+            XMLStreamReaderUtil.nextElementContent (reader);
+        }
+        return code;
+    }
+
+    protected FaultReason readFaultReason (XMLStreamReader reader){
+        XMLStreamReaderUtil.verifyReaderState (reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_FAULT_REASON);
+        XMLStreamReaderUtil.nextElementContent (reader);
+
+        //soapenv:Text
+        List<FaultReasonText> texts = new ArrayList<FaultReasonText>();
+        readFaultReasonTexts (reader, texts);
+
+        XMLStreamReaderUtil.verifyReaderState (reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_FAULT_REASON);
+        XMLStreamReaderUtil.nextElementContent (reader);
+
+        FaultReasonText[] frt = texts.toArray (new FaultReasonText[0]);
+        return new FaultReason (frt);
+    }
+
+    protected void readFaultReasonTexts (XMLStreamReader reader, List<FaultReasonText> texts) {
+        QName name = reader.getName ();
+        if (!name.equals (SOAP12Constants.QNAME_FAULT_REASON_TEXT)) {
+            return;
+        }
+        String lang = reader.getAttributeValue (SOAP12NamespaceConstants.XML_NS, "lang");
+        //lets be more forgiving, if its null lets assume its 'en'
+        if(lang == null)
+            lang = "en";
+
+        //TODO: what to do when the lang is other than 'en', for example clingon?
+
+        //get the text value
+        XMLStreamReaderUtil.nextContent (reader);
+        String text = null;
+        if (reader.getEventType () == CHARACTERS) {
+            text = reader.getText ();
+            XMLStreamReaderUtil.next (reader);
+        }
+        XMLStreamReaderUtil.verifyReaderState (reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, SOAP12Constants.QNAME_FAULT_REASON_TEXT);
+        XMLStreamReaderUtil.nextElementContent (reader);
+        Locale loc = new Locale(lang);
+
+        texts.add (new FaultReasonText (text, loc));
+
+        //call again to see if there are more soapenv:Text elements
+        readFaultReasonTexts (reader, texts);
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#decodeHeader(com.sun.xml.internal.ws.streaming.XMLStreamReader, com.sun.pept.ept.MessageInfo, com.sun.xml.internal.ws.soap.internal.InternalMessage)
+     */
+    @Override
+    protected void decodeHeader (XMLStreamReader reader, MessageInfo messageInfo, InternalMessage request) {
+        XMLStreamReaderUtil.verifyReaderState (reader, START_ELEMENT);
+        if (!SOAPNamespaceConstants.TAG_HEADER.equals (reader.getLocalName ())) {
+            return;
+        }
+        XMLStreamReaderUtil.verifyTag (reader, getHeaderTag ());
+        XMLStreamReaderUtil.nextElementContent (reader);
+        while (true) {
+            if (reader.getEventType () == START_ELEMENT) {
+                decodeHeaderElement (reader, messageInfo, request);
+            } else {
+                break;
+            }
+        }
+        XMLStreamReaderUtil.verifyReaderState (reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag (reader, getHeaderTag ());
+        XMLStreamReaderUtil.nextElementContent (reader);
+    }
+
+    /*
+     * If JAXB can deserialize a header, deserialize it.
+     * Otherwise, just ignore the header
+     */
+    protected void decodeHeaderElement (XMLStreamReader reader, MessageInfo messageInfo,
+        InternalMessage msg) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext (messageInfo);
+        BridgeContext bridgeContext = rtCtxt.getBridgeContext ();
+        Set<QName> knownHeaders = ((SOAPRuntimeModel) rtCtxt.getModel ()).getKnownHeaders ();
+        QName name = reader.getName ();
+        if (knownHeaders != null && knownHeaders.contains (name)) {
+            QName headerName = reader.getName ();
+            if (msg.isHeaderPresent (name)) {
+                // More than one instance of header whose QName is mapped to a
+                // method parameter. Generates a runtime error.
+                raiseFault (getSenderFaultCode(), "Duplicate Header" + headerName);
+            }
+            Object decoderInfo = rtCtxt.getDecoderInfo (name);
+            if (decoderInfo != null && decoderInfo instanceof JAXBBridgeInfo) {
+                JAXBBridgeInfo bridgeInfo = (JAXBBridgeInfo) decoderInfo;
+                // JAXB leaves on </env:Header> or <nextHeaderElement>
+                bridgeInfo.deserialize(reader,bridgeContext);
+                HeaderBlock headerBlock = new HeaderBlock (bridgeInfo);
+                msg.addHeader (headerBlock);
+            }
+        } else {
+            XMLStreamReaderUtil.skipElement (reader);                 // Moves to END state
+            XMLStreamReaderUtil.nextElementContent (reader);
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#getFaultTag()
+     */
+    @Override
+    protected QName getFaultTag (){
+        return SOAP12Constants.QNAME_SOAP_FAULT;
+    }
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#getBodyTag()
+     */
+    @Override
+    protected QName getBodyTag () {
+        return SOAP12Constants.QNAME_SOAP_BODY;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#getEnvelopeTag()
+     */
+    @Override
+    protected QName getEnvelopeTag () {
+        return SOAP12Constants.QNAME_SOAP_ENVELOPE;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#getHeaderTag()
+     */
+    @Override
+    protected QName getHeaderTag () {
+        return SOAP12Constants.QNAME_SOAP_HEADER;
+    }
+
+    @Override
+    protected QName getMUAttrQName (){
+        return SOAP12Constants.QNAME_MUSTUNDERSTAND;
+    }
+
+    @Override
+    protected QName getRoleAttrQName (){
+        return SOAP12Constants.QNAME_ROLE;
+    }
+
+    @Override
+    protected QName getFaultDetailTag() {
+        return SOAP12Constants.QNAME_FAULT_DETAIL;
+    }
+
+    @Override
+    public String getBindingId() {
+        return SOAPBinding.SOAP12HTTP_BINDING;
+    }
+
+    @Override
+    protected QName getSenderFaultCode() {
+        return SOAP12Constants.FAULT_CODE_SERVER;
+    }
+
+    @Override
+    protected QName getReceiverFaultCode() {
+        return SOAP12Constants.FAULT_CODE_CLIENT;
+    }
+
+    @Override
+    protected QName getVersionMismatchFaultCode() {
+        return SOAP12Constants.FAULT_CODE_VERSION_MISMATCH;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAP12XMLEncoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAP12XMLEncoder.java
new file mode 100644
index 0000000..7f6c360
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAP12XMLEncoder.java
@@ -0,0 +1,135 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.client;
+
+import static java.util.logging.Logger.getLogger;
+
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.JAXWS_CONTEXT_PROPERTY;
+
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.bind.JAXBContext;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+
+import com.sun.xml.internal.ws.client.SenderException;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+
+import java.util.logging.Logger;
+import java.util.List;
+import java.io.ByteArrayOutputStream;
+import java.nio.ByteBuffer;
+import java.lang.reflect.Method;
+
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.*;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAP12XMLEncoder extends SOAPXMLEncoder {
+
+
+    private static final Logger logger =
+           getLogger(new StringBuffer().append(com.sun.xml.internal.ws.util.Constants.LoggingDomain).append(".client.dispatch.util").toString());
+
+    /*
+     * @see SOAPEncoder#startEnvelope(XMLStreamWriter)
+     */
+    @Override
+    protected void startEnvelope(XMLStreamWriter writer) {
+        try {
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_ENVELOPE, SOAP12NamespaceConstants.ENVELOPE);
+            writer.setPrefix(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                             SOAP12NamespaceConstants.ENVELOPE);
+            writer.writeNamespace(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                                  SOAP12NamespaceConstants.ENVELOPE);
+        } catch (XMLStreamException e) {
+            throw new SenderException(e);
+        }
+    }
+
+    /*
+     * @see SOAPEncoder#startBody(XMLStreamWriter)
+     */
+    @Override
+    protected void startBody(XMLStreamWriter writer) {
+        try {
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_BODY, SOAP12NamespaceConstants.ENVELOPE);
+        } catch (XMLStreamException e) {
+            throw new SenderException(e);
+        }
+    }
+
+    /*
+     * @see SOAPEncoder#startHeader(XMLStreamWriter)
+     */
+    @Override
+    protected void startHeader(XMLStreamWriter writer) {
+        try {
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_HEADER,
+                SOAP12NamespaceConstants.ENVELOPE);     // <env:Header>
+        } catch (XMLStreamException e) {
+            throw new SenderException(e);
+        }
+    }
+
+    protected String getContentType(MessageInfo messageInfo,
+        JAXWSAttachmentMarshaller marshaller)
+    {
+        String contentNegotiation = (String)
+            messageInfo.getMetaData(BindingProviderProperties.CONTENT_NEGOTIATION_PROPERTY);
+
+        if (marshaller == null) {
+            marshaller = MessageInfoUtil.getAttachmentMarshaller(messageInfo);
+        }
+
+        if (marshaller != null && marshaller.isXopped()) {
+            return XOP_SOAP12_XML_TYPE_VALUE;
+        }
+        else {
+            return (contentNegotiation == "optimistic") ?
+                FAST_INFOSET_TYPE_SOAP12 : SOAP12_XML_CONTENT_TYPE_VALUE;
+        }
+    }
+
+    /**
+     * This method is used to create the appropriate SOAPMessage (1.1 or 1.2 using SAAJ api).
+     * @return the BindingID associated with this encoder
+     */
+    @Override
+    protected String getBindingId (){
+        return SOAPBinding.SOAP12HTTP_BINDING;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAPXMLDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAPXMLDecoder.java
new file mode 100644
index 0000000..98296ee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAPXMLDecoder.java
@@ -0,0 +1,581 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.client;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.client.RequestContext;
+import com.sun.xml.internal.ws.client.dispatch.DispatchContext;
+import com.sun.xml.internal.ws.client.dispatch.impl.encoding.DispatchSerializer;
+import com.sun.xml.internal.ws.client.dispatch.impl.encoding.DispatchUtil;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBeanInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.simpletype.EncoderUtils;
+import com.sun.xml.internal.ws.encoding.soap.DeserializationException;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAPDecoder;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.streaming.SourceReaderFactory;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.streaming.Attributes;
+import com.sun.xml.internal.ws.streaming.XMLStreamWriterFactory;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPConnectionUtil;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+import com.sun.xml.internal.ws.util.xml.StAXSource;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import com.sun.xml.internal.bind.api.BridgeContext;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.namespace.QName;
+import javax.xml.soap.Detail;
+import javax.xml.soap.MessageFactory;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPMessage;
+import static javax.xml.stream.XMLStreamConstants.*;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.TransformerFactoryConfigurationError;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.Service;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.ws.soap.SOAPFaultException;
+import java.lang.reflect.Method;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.HashMap;
+
+/**
+ * @author WS Development Team
+ */
+
+public class SOAPXMLDecoder extends SOAPDecoder {
+    public SOAPXMLDecoder() {
+    }
+
+    protected DispatchSerializer getSerializerInstance() {
+        return DispatchSerializer.SOAP_1_0;
+    }
+
+    @Override
+    public SOAPMessage toSOAPMessage(MessageInfo messageInfo) {
+        WSConnection connection = (WSConnection) messageInfo.getConnection();
+        return SOAPConnectionUtil.getSOAPMessage(connection, messageInfo, getBindingId());
+    }
+
+    /*protected void decodeBody(XMLStreamReader reader, InternalMessage response,
+                              MessageInfo messageInfo) {
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getBodyTag());
+        int state = XMLStreamReaderUtil.nextElementContent(reader);
+        decodeBodyContent(reader, response, messageInfo);
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getBodyTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+    }
+    */
+
+
+    /*
+    * skipBody is true, the body is skipped during parsing.
+    */
+    protected void decodeEnvelope(XMLStreamReader reader, InternalMessage request,
+                                  boolean skipBody, MessageInfo messageInfo) {
+
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        //XMLStreamReaderUtil.verifyTag(reader, getEnvelopeTag());
+        if (isDispatch(messageInfo))
+           dispatchUtil.collectPrefixes(reader);
+
+        XMLStreamReaderUtil.nextElementContent(reader);
+
+        if (skipHeader(messageInfo)) {
+            //System.out.println("Skipping header");
+            skipHeader(reader, messageInfo);
+        } else {
+            //System.out.println("Decoding header");
+            decodeHeader(reader, messageInfo, request);
+        }
+
+        if (skipBody) {
+            //System.out.println("Skipping body");
+            skipBody(reader);
+        } else {
+            //System.out.println("Decodong body");
+            decodeBody(reader, request, messageInfo);
+        }
+
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getEnvelopeTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+        XMLStreamReaderUtil.verifyReaderState(reader, END_DOCUMENT);
+    }
+
+    private static String convertNull(String s) {
+        return (s != null) ? s : "";
+    }
+
+    //@Override
+    protected void decodeBody(XMLStreamReader reader, InternalMessage response, MessageInfo messageInfo) {
+        DispatchContext context = (DispatchContext) messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT);
+        if (context != null) {
+            //System.out.println("Dispatch context not null");
+            XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+            XMLStreamReaderUtil.verifyTag(reader, getBodyTag());
+            int state = XMLStreamReaderUtil.nextElementContent(reader);
+            // if Body is not empty, then deserialize the Body
+            if (state != END_ELEMENT) {
+                BodyBlock responseBody;
+                QName responseBodyName = reader.getName();   // Operation name
+
+                if (responseBodyName.equals(getFaultTag())) {
+                    SOAPFaultInfo soapFaultInfo = decodeFault(reader, response, messageInfo);
+                    responseBody = new BodyBlock(soapFaultInfo);
+                } else {
+                   // System.out.println("Deserializing body");
+                    JAXBContext jaxbContext = getJAXBContext(messageInfo);
+                    if (jaxbContext == null) {
+                        //System.out.println("JAXBContext == null");
+                        responseBody = new BodyBlock(getSerializerInstance().deserializeSource(reader, dispatchUtil));
+                    } else {
+                        //jaxb will leave reader on ending </body> element
+                        //System.out.println("Doing a jaxb bean");
+                        JAXBBeanInfo jaxBean = null;
+                        Unmarshaller um = (Unmarshaller)messageInfo.getMetaData(BindingProviderProperties.DISPATCH_UNMARSHALLER);
+                        if (um != null)
+                            jaxBean = JAXBBeanInfo.fromStAX(reader, jaxbContext, um);
+                        else
+                            jaxBean = JAXBBeanInfo.fromStAX(reader, jaxbContext);
+
+                        responseBody = new BodyBlock(jaxBean);
+                    }
+                }
+                response.setBody(responseBody);
+            }
+
+            XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+            XMLStreamReaderUtil.verifyTag(reader, getBodyTag());
+            XMLStreamReaderUtil.nextElementContent(reader);
+        } //else
+        else super.decodeBody(reader, response, messageInfo);
+    }
+
+    @Override
+    //Todo:kw 102505
+    public void toMessageInfo(InternalMessage internalMessage, MessageInfo messageInfo) {
+
+        RuntimeContext rtContext =
+            (RuntimeContext) messageInfo.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        if (rtContext != null) {
+            SOAPEPTFactory eptf = (SOAPEPTFactory) messageInfo.getEPTFactory();
+            InternalEncoder encoder = eptf.getInternalEncoder();
+            encoder.toMessageInfo(internalMessage, messageInfo);
+
+        } else {  //here we need to set attachments in response context
+            if (internalMessage != null && internalMessage.getBody() != null) {
+                if (internalMessage.getBody().getValue() instanceof SOAPFaultInfo)
+                {
+                    messageInfo.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+                    messageInfo.setResponse(internalMessage.getBody().getValue());
+                } else
+                if (internalMessage.getBody().getValue() instanceof Exception) {
+                    messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+                    messageInfo.setResponse(internalMessage.getBody().getValue());
+                } else {
+                    messageInfo.setResponseType(MessageStruct.NORMAL_RESPONSE);
+                    setAttachments(internalMessage, messageInfo);
+                    //unfortunately we must do this
+                    if (internalMessage.getBody().getValue() instanceof JAXBBeanInfo)
+                        messageInfo.setResponse(((JAXBBeanInfo) internalMessage.getBody().getValue()).getBean());
+                    else
+                        messageInfo.setResponse(internalMessage.getBody().getValue());
+                }
+            } else
+                messageInfo.setResponseType(MessageStruct.NORMAL_RESPONSE);
+        }
+    }
+
+    private void setAttachments(InternalMessage internalMessage, MessageInfo messageInfo) {
+
+    }
+
+    protected void decodeEnvelope(XMLStreamReader reader, MessageInfo messageInfo) {
+        InternalMessage im = decodeInternalMessage(reader, messageInfo);
+        toMessageInfo(im, messageInfo);
+    }
+
+    protected InternalMessage decodeInternalMessage(XMLStreamReader reader, MessageInfo messageInfo) {
+        InternalMessage response = new InternalMessage();
+
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getEnvelopeTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+        decodeHeader(reader, messageInfo, response);
+        decodeBody(reader, response, messageInfo);
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, getEnvelopeTag());
+        XMLStreamReaderUtil.nextElementContent(reader);
+        XMLStreamReaderUtil.verifyReaderState(reader, END_DOCUMENT);
+
+        return response;
+    }
+
+    @Override
+    public InternalMessage toInternalMessage(SOAPMessage soapMessage, MessageInfo messageInfo) {
+        // TODO handle exceptions, attachments
+        XMLStreamReader reader = null;
+        try {
+            InternalMessage response = new InternalMessage();
+            processAttachments(messageInfo, response, soapMessage);
+            Source source = soapMessage.getSOAPPart().getContent();
+            reader = SourceReaderFactory.createSourceReader(source, true, getSOAPMessageCharsetEncoding(soapMessage));
+            XMLStreamReaderUtil.nextElementContent(reader);
+            decodeEnvelope(reader, response, false, messageInfo);
+            return response;
+        } catch (DeserializationException e) {
+            //e.printStackTrace();
+            throw new WebServiceException(e.getCause());
+        } catch (Exception e) {
+            //e.printStackTrace();
+            throw new WebServiceException(e);
+        } finally {
+            if (reader != null) {
+                XMLStreamReaderUtil.close(reader);
+            }
+        }
+    }
+
+    @Override
+    public InternalMessage toInternalMessage(SOAPMessage soapMessage,
+                                             InternalMessage response, MessageInfo messageInfo) {
+        // TODO handle exceptions, attachments
+        XMLStreamReader reader = null;
+        try {
+            processAttachments(messageInfo, response, soapMessage);
+            Source source = soapMessage.getSOAPPart().getContent();
+            reader = SourceReaderFactory.createSourceReader(source, true, getSOAPMessageCharsetEncoding(soapMessage));
+            XMLStreamReaderUtil.nextElementContent(reader);
+            decodeEnvelope(reader, response, !isDispatch(messageInfo), messageInfo);
+
+            if (!isDispatch(messageInfo))
+                convertBodyBlock(response, messageInfo);
+
+        } catch (DeserializationException e) {
+            //e.printStackTrace();
+            throw new WebServiceException(e.getCause());
+        } catch (Exception e) {
+            //e.printStackTrace();
+            throw new WebServiceException(e);
+        } finally {
+            if (reader != null) {
+                XMLStreamReaderUtil.close(reader);
+            }
+        }
+        return response;
+
+    }
+
+    /**
+     * @return Returns the soap binding - SOAP 1.1 namespace.
+     */
+    public String getSOAPBindingId() {
+        return SOAPConstants.NS_WSDL_SOAP;
+    }
+
+    @Override
+    protected SOAPFaultInfo decodeFault(XMLStreamReader reader, InternalMessage internalMessage,
+                                        MessageInfo messageInfo) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, SOAPConstants.QNAME_SOAP_FAULT);
+        Method methodName = messageInfo.getMethod();
+
+        // faultcode
+        XMLStreamReaderUtil.nextElementContent(reader);
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, SOAPConstants.QNAME_SOAP_FAULT_CODE);
+        XMLStreamReaderUtil.nextContent(reader);
+        QName faultcode;
+        String tokens = reader.getText();
+        String uri = "";
+        tokens = EncoderUtils.collapseWhitespace(tokens);
+        String prefix = XmlUtil.getPrefix(tokens);
+        if (prefix != null) {
+            uri = reader.getNamespaceURI(prefix);
+            if (uri == null) {
+                throw new DeserializationException("xsd.unknownPrefix", prefix);
+            }
+        }
+        String localPart = XmlUtil.getLocalPart(tokens);
+        faultcode = new QName(uri, localPart);
+        XMLStreamReaderUtil.next(reader);
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, SOAPConstants.QNAME_SOAP_FAULT_CODE);
+
+        // faultstring
+        XMLStreamReaderUtil.nextElementContent(reader);
+        XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, SOAPConstants.QNAME_SOAP_FAULT_STRING);
+        XMLStreamReaderUtil.nextContent(reader);
+        String faultstring = "";
+        //reader may give more than one char events so coalesc them all.
+        if (reader.getEventType() == CHARACTERS) {
+            do  {
+               faultstring += reader.getText();
+               XMLStreamReaderUtil.next(reader);
+            }while(reader.getEventType() == CHARACTERS);
+        }
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, SOAPConstants.QNAME_SOAP_FAULT_STRING);
+
+        String faultactor = null;
+        Object faultdetail = null;
+        QName faultName;
+        if (XMLStreamReaderUtil.nextElementContent(reader) == START_ELEMENT) {
+            QName elementName = reader.getName();
+            // faultactor
+            if (elementName.equals(SOAPConstants.QNAME_SOAP_FAULT_ACTOR)) {
+                XMLStreamReaderUtil.nextContent(reader);
+                // faultactor may be empty
+                if (reader.getEventType() == CHARACTERS) {
+                    faultactor = reader.getText();
+                    XMLStreamReaderUtil.next(reader);
+                }
+                XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+                XMLStreamReaderUtil.verifyTag(reader, SOAPConstants.QNAME_SOAP_FAULT_ACTOR);
+                XMLStreamReaderUtil.nextElementContent(reader);
+                elementName = reader.getName();
+            }
+
+            // faultdetail
+            if (elementName.equals(SOAPConstants.QNAME_SOAP_FAULT_DETAIL)) {
+                //skip <detail/>
+                if(XMLStreamReaderUtil.nextContent(reader) == START_ELEMENT){
+                    if (messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT) == null)
+                        faultdetail = readFaultDetail(reader, messageInfo);
+                    else {
+                        XMLStreamReaderUtil.skipElement(reader);
+                        XMLStreamReaderUtil.next(reader);
+                    }
+                }
+                // move from </detail> to </Fault>.
+                XMLStreamReaderUtil.nextContent(reader);
+            } else {
+                if (internalMessage.getHeaders() != null) {
+                    boolean isHeaderFault = false;
+                    // could be a header fault or a protocol exception with no detail
+                    for (HeaderBlock headerBlock : internalMessage.getHeaders())
+                    {
+                        if (rtCtxt.getModel().isKnownFault(headerBlock.getName(), methodName))
+                        {
+                            isHeaderFault = true;
+                            faultdetail = headerBlock.getValue();
+                        }
+                    }
+
+                    // if not a header fault, then it is a protocol exception with no detail
+                    if (!isHeaderFault) {
+                        faultdetail = null;
+                    }
+                    XMLStreamReaderUtil.next(reader);
+                }
+            }
+        } else {
+            // a header fault (with no faultactor)
+            if (internalMessage.getHeaders() != null) {
+                for (HeaderBlock headerBlock : internalMessage.getHeaders()) {
+                    if (rtCtxt.getModel().isKnownFault(headerBlock.getName(), methodName))
+                    {
+                        faultdetail = headerBlock.getValue();
+                    }
+                }
+            }
+        }
+
+
+        SOAPFaultInfo soapFaultInfo = new SOAPFaultInfo(faultstring, faultcode, faultactor, faultdetail, getBindingId());
+
+        // reader could be left on CHARS token rather than </fault>
+        if (reader.getEventType() == CHARACTERS && reader.isWhiteSpace()) {
+            XMLStreamReaderUtil.nextContent(reader);
+        }
+
+        XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+        XMLStreamReaderUtil.verifyTag(reader, SOAPConstants.QNAME_SOAP_FAULT);
+        XMLStreamReaderUtil.nextElementContent(reader);
+
+        return soapFaultInfo;
+    }
+
+    /**
+     * Decodes the fault &lt;detail> into a {@link Detail} object or a JAXB object.
+     * <p/>
+     * Upon entry the cursor must be at the start tag of the first child element of &lt;detail>.
+     * Upon a successful completion, the cursor is left at &lt;/detail>.
+     */
+    protected final Object readFaultDetail(XMLStreamReader reader, MessageInfo mi) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(mi);
+        if (rtCtxt == null){
+            XMLStreamReaderUtil.skipElement(reader);
+            XMLStreamReaderUtil.nextElementContent(reader);
+            return null;
+        }
+        QName faultName = reader.getName();
+        if (rtCtxt.getModel().isKnownFault(faultName, mi.getMethod())) {
+            Object decoderInfo = rtCtxt.getDecoderInfo(faultName);
+            if (decoderInfo != null && decoderInfo instanceof JAXBBridgeInfo) {
+                JAXBBridgeInfo bridgeInfo = (JAXBBridgeInfo) decoderInfo;
+                // JAXB leaves on </env:Header> or <nextHeaderElement>
+                bridgeInfo.deserialize(reader, rtCtxt.getBridgeContext());
+
+                // skip other detail entries
+                int event = reader.getEventType();
+                if (!(event == START_ELEMENT || event == END_ELEMENT)) {
+                    XMLStreamReaderUtil.nextElementContent(reader);
+                }
+                while(reader.getEventType() == START_ELEMENT) {
+                    XMLStreamReaderUtil.skipElement(reader);
+                    XMLStreamReaderUtil.nextElementContent(reader);
+                }
+
+                XMLStreamReaderUtil.verifyReaderState(reader, END_ELEMENT);
+                XMLStreamReaderUtil.verifyTag(reader, getFaultDetailTag());
+                return bridgeInfo;
+            }
+        }
+
+        return decodeFaultDetail(reader);
+    }
+
+    /**
+     * Decodes the fault &lt;detail> into a {@link Detail} object.
+     * <p/>
+     * Upon entry the cursor must be at the start tag of the first child element of &lt;detail>.
+     * Upon a successful completion, the cursor is left at &lt;/detail>.
+     */
+    protected Detail decodeFaultDetail(XMLStreamReader reader) {
+        try {
+            // parse the current element that the reader is pointing to
+            Transformer trans = XmlUtil.newTransformer();
+
+            MessageFactory messageFactory = MessageFactory.newInstance();
+            SOAPMessage soapMessage = messageFactory.createMessage();
+            Detail detail = soapMessage.getSOAPBody().addFault().addDetail();
+
+            // repeatedly copy all the child elements of <detail>.
+            do {
+                trans.transform(new StAXSource(reader, true), new DOMResult(detail));
+            } while (XMLStreamReaderUtil.nextContent(reader) == START_ELEMENT);
+
+            // now we should be at </detail>.
+            return detail;
+        } catch (SOAPException e) {
+            throw new WebServiceException("sender.response.cannotDecodeFaultDetail", e);
+        } catch (TransformerException e) {
+            throw new WebServiceException("sender.response.cannotDecodeFaultDetail", e);
+        } catch (TransformerFactoryConfigurationError e) {
+            throw new WebServiceException("sender.response.cannotDecodeFaultDetail", e);
+        }
+    }
+
+   /* protected static String getCurrentPrefix(XMLStreamReader reader, String tokens, String namespaceURI) {
+        tokens = reader.getText();
+        String uri = "";
+        tokens = EncoderUtils.collapseWhitespace(tokens);
+        String prefix = XmlUtil.getPrefix(tokens);
+        if (prefix != null) {
+            uri = reader.getNamespaceURI(prefix);
+            if (uri == null) {
+                throw new DeserializationException("xsd.unknownPrefix", prefix);
+            }
+        }
+        String localPart = XmlUtil.getLocalPart(tokens);
+        return prefix;
+    }
+    */
+
+    protected JAXBContext getJAXBContext(MessageInfo messageInfo) {
+        JAXBContext jc = null;
+
+        RequestContext requestContext = (RequestContext) messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        if (requestContext != null)
+            // TODO: does this really need to be copied?
+            jc = (JAXBContext) requestContext.copy().get(BindingProviderProperties.JAXB_CONTEXT_PROPERTY);
+        return jc;
+    }
+
+    protected String getBindingId(MessageInfo messageInfo) {
+        RequestContext requestContext = (RequestContext) messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        if (requestContext != null) {
+            String bindingId = (String) requestContext.get(BindingProviderProperties.BINDING_ID_PROPERTY);
+            if (bindingId != null)
+                return bindingId;
+        }
+        return getBindingId();
+    }
+
+
+    @Override
+    public String getBindingId() {
+        return SOAPBinding.SOAP11HTTP_BINDING;
+    }
+
+    @Override
+    protected QName getSenderFaultCode() {
+        return SOAPConstants.FAULT_CODE_SERVER;
+    }
+
+    @Override
+    protected QName getReceiverFaultCode() {
+        return SOAPConstants.FAULT_CODE_CLIENT;
+    }
+
+    @Override
+    protected QName getVersionMismatchFaultCode() {
+        return SOAPConstants.FAULT_CODE_VERSION_MISMATCH;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAPXMLEncoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAPXMLEncoder.java
new file mode 100644
index 0000000..b88045f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/client/SOAPXMLEncoder.java
@@ -0,0 +1,265 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.client;
+
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.*;
+import com.sun.xml.internal.ws.client.RequestContext;
+import com.sun.xml.internal.ws.client.SenderException;
+import com.sun.xml.internal.ws.client.dispatch.DispatchContext;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBeanInfo;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.streaming.XMLStreamWriterFactory;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+
+import javax.activation.DataHandler;
+import javax.xml.bind.JAXBContext;
+import javax.xml.namespace.QName;
+import javax.xml.soap.MimeHeaders;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.Source;
+import javax.xml.ws.Service;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.soap.SOAPBinding;
+import java.io.IOException;
+import java.util.Map;
+import java.util.logging.Logger;
+import static java.util.logging.Logger.getLogger;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPXMLEncoder extends SOAPEncoder {
+
+    private static final Logger logger =
+        getLogger(new StringBuffer().append(com.sun.xml.internal.ws.util.Constants.LoggingDomain).append(".client.dispatch.util").toString());
+
+    public SOAPXMLEncoder() {
+    }
+    /* moved to super
+    protected JAXBContext getJAXBContext(MessageInfo messageInfo) {
+        JAXBContext jc = null;
+        RequestContext context = (RequestContext) messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        if (context != null)
+            jc = (JAXBContext) context.get(BindingProviderProperties.JAXB_CONTEXT_PROPERTY);
+
+        return jc;
+    }
+    */
+    protected boolean skipHeader(MessageInfo messageInfo) {
+        if (messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) ==
+            Service.Mode.PAYLOAD) {
+            return true;
+        }
+        return false;
+    }
+
+    protected QName getHeaderTag() {
+        return SOAPConstants.QNAME_SOAP_HEADER;
+    }
+
+    protected void skipHeader(XMLStreamReader writer) {
+        //XMLStreamReaderUtil.verifyReaderState(reader, START_ELEMENT);
+        //if (!SOAPNamespaceConstants.TAG_HEADER.equals(reader.getLocalName())) {
+        //  return;
+        //}
+        //XMLStreamReaderUtil.verifyTag(reader, getHeaderTag());
+        //XMLStreamReaderUtil.skipElement(reader);    // Moves to </Header>
+        //XMLStreamReaderUtil.nextElementContent(reader);
+    }
+
+    @Override
+    public InternalMessage toInternalMessage(MessageInfo messageInfo) {
+        InternalMessage internalMessage = new InternalMessage();
+        DispatchContext context = (DispatchContext) messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT);
+        if (context != null) {
+            DispatchContext.MessageType type =
+                (DispatchContext.MessageType) context.getProperty(DispatchContext.DISPATCH_MESSAGE);
+            Object[] data = messageInfo.getData();
+            BodyBlock bodyBlock = null;
+            switch (type) {
+                case JAXB_MESSAGE:
+                    break;
+                case JAXB_PAYLOAD:
+                    JAXBBeanInfo jaxbInfo = new JAXBBeanInfo(data[0], getJAXBContext(messageInfo));
+                    bodyBlock = new BodyBlock(jaxbInfo);
+                    break;
+                case SOURCE_PAYLOAD:
+                    data = messageInfo.getData();
+                    bodyBlock = new BodyBlock((Source) data[0]);
+                    break;
+                default:
+            }
+            if (bodyBlock != null)
+                internalMessage.setBody(bodyBlock);
+
+            //look for attachments here
+            Map<String, DataHandler> attMap = (Map<String, DataHandler>) ((Map<String, Object>)
+                messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY)).get(MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS);
+
+            if (attMap != null)
+                for (Map.Entry<String, DataHandler> att : attMap.entrySet()) {
+                    internalMessage.addAttachment(AttachmentBlock.fromDataHandler(att.getKey(), att.getValue()));
+                }
+
+        } else {
+            SOAPEPTFactory eptf = (SOAPEPTFactory) messageInfo.getEPTFactory();
+            InternalEncoder internalEncoder = eptf.getInternalEncoder();
+            //processProperties(messageInfo);
+            return (InternalMessage) internalEncoder.toInternalMessage(messageInfo);
+        }
+        return internalMessage;
+    }
+
+    @Override
+    public SOAPMessage toSOAPMessage(InternalMessage internalMessage,
+                                     MessageInfo messageInfo) {
+        SOAPMessage message = null;
+        XMLStreamWriter writer = null;
+        JAXWSAttachmentMarshaller marshaller = null;
+        boolean xopEnabled = false;
+
+        try {
+            setAttachmentsMap(messageInfo, internalMessage);
+            ByteArrayBuffer bab = new ByteArrayBuffer();
+
+            if (messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY) == "optimistic")
+            {
+                writer = XMLStreamWriterFactory.createFIStreamWriter(bab);
+
+                // Turn XOP off for FI
+                marshaller = MessageInfoUtil.getAttachmentMarshaller(messageInfo);
+                if (marshaller != null) {
+                    xopEnabled = marshaller.isXOPPackage();     // last value
+                    marshaller.setXOPPackage(false);
+                }
+
+            } else {
+                // Store output stream to use in JAXB bridge (not with FI)
+                messageInfo.setMetaData(JAXB_OUTPUTSTREAM, bab);
+                writer = XMLStreamWriterFactory.createXMLStreamWriter(bab);
+            }
+
+            writer.writeStartDocument();
+            startEnvelope(writer);
+            writeEnvelopeNamespaces(writer, messageInfo);
+            if (!skipHeader(messageInfo))
+                writeHeaders(writer, internalMessage, messageInfo);
+            writeBody(writer, internalMessage, messageInfo);
+            endEnvelope(writer);
+            writer.writeEndDocument();
+            writer.close();
+
+            // TODO: Copy the mime headers from messageInfo.METADATA
+            MimeHeaders mh = new MimeHeaders();
+            mh.addHeader("Content-Type", getContentType(messageInfo, marshaller));
+            message = SOAPUtil.createMessage(mh, bab.newInputStream(), getBindingId());
+            processAttachments(internalMessage, message);
+
+            // Restore default XOP processing before returning
+            if (marshaller != null) {
+                marshaller.setXOPPackage(xopEnabled);
+            }
+        }
+        catch (IOException e) {
+            throw new SenderException("sender.request.messageNotReady", e);
+        }
+        catch (SOAPException e) {
+            throw new SenderException(e);
+        }
+        catch (XMLStreamException e) {
+            throw new SenderException(e);
+        }
+        finally {
+            if (writer != null) {
+                try {
+                    writer.close();
+                }
+                catch (XMLStreamException e) {
+                    throw new SenderException(e);
+                }
+            }
+        }
+
+        return message;
+    }
+
+    public InternalMessage createInternalMessage(MessageInfo messageInfo) {
+
+        InternalMessage internalMessage = new InternalMessage();
+        Object response = messageInfo.getResponse();
+
+        BodyBlock bodyBlock = null;
+        if (getJAXBContext(messageInfo) != null) {
+            JAXBBeanInfo jaxbBean = new JAXBBeanInfo(response, getJAXBContext(messageInfo));
+            bodyBlock = new BodyBlock(jaxbBean);
+        } else if (response instanceof Source) {
+            bodyBlock = new BodyBlock((Source) response);
+        }
+
+        internalMessage.setBody(bodyBlock);
+        return internalMessage;
+    }
+
+    protected String getContentType(MessageInfo messageInfo,
+                                    JAXWSAttachmentMarshaller marshaller) {
+        String contentNegotiation = (String)
+            messageInfo.getMetaData(BindingProviderProperties.CONTENT_NEGOTIATION_PROPERTY);
+
+        if (marshaller == null) {
+            marshaller = MessageInfoUtil.getAttachmentMarshaller(messageInfo);
+        }
+
+        if (marshaller != null && marshaller.isXopped()) {
+            return XOP_SOAP11_XML_TYPE_VALUE;
+        } else {
+            return (contentNegotiation == "optimistic") ?
+                FAST_INFOSET_TYPE_SOAP11 : XML_CONTENT_TYPE_VALUE;
+        }
+    }
+
+    /**
+     * This method is used to create the appropriate SOAPMessage (1.1 or 1.2 using SAAJ api).
+     *
+     * @return the BindingID associated with this encoder
+     */
+    protected String getBindingId() {
+        return SOAPBinding.SOAP11HTTP_BINDING;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/AttachmentBlock.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/AttachmentBlock.java
new file mode 100644
index 0000000..951f2ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/AttachmentBlock.java
@@ -0,0 +1,435 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.internal;
+
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.soap.SerializationException;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.util.ASCIIUtility;
+import com.sun.xml.internal.ws.util.ByteArrayDataSource;
+
+import javax.activation.DataHandler;
+import javax.activation.DataSource;
+import javax.imageio.ImageIO;
+import javax.xml.soap.AttachmentPart;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.transform.Source;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.ws.WebServiceException;
+import java.awt.Image;
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.io.UnsupportedEncodingException;
+
+/**
+ * Attachment of {@link InternalMessage}.
+ *
+ * <p>
+ * The key idea behind this class is to hide the actual data representation.
+ * The producer of the object may choose the best format it wants, and then
+ * various accessor methods provide the rest of the stack to chose the format
+ * it wants.
+ *
+ * <p>
+ * When receiving from a network, this allows an {@link AttachmentBlock} object
+ * to be constructed without actually even parsing the attachment. When
+ * sending to a network, this allows the conversion to the byte image to happen
+ * lazily, and directly to the network.
+ *
+ * <p>
+ * Even though most of the data access methods have default implementation,
+ * Implementation classes of this class should override them
+ * so that they can run faster, whenever possible. In particular, the default
+ * implementation of {@link #asInputStream()} and {@link #writeTo(OutputStream)}
+ * has a circular dependency, so at least one must be overridden.
+ *
+ * TODO:
+ *   in the performance critical path of mapping an attachment to a Java type,
+ *   most of the type the Java type to which it binds to is known in advance.
+ *   for this reason, it's better to prepare an 'accessor' object for each
+ *   kind of conversion. In that way we can avoid the computation of this
+ *   in the pritical path, which is redundant.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class AttachmentBlock {
+
+    public static AttachmentBlock fromDataHandler(String cid,DataHandler dh) {
+        return new DataHandlerImpl(cid,dh);
+    }
+
+    public static AttachmentBlock fromSAAJ(AttachmentPart part) {
+        return new SAAJImpl(part);
+    }
+
+    public static AttachmentBlock fromByteArray(String cid,byte[] data, int start, int len, String mimeType ) {
+        return new ByteArrayImpl(cid,data,start,len,mimeType);
+    }
+
+    public static AttachmentBlock fromByteArray(String cid,byte[] data, String mimeType) {
+        return new ByteArrayImpl(cid,data,0,data.length,mimeType);
+    }
+
+    public static AttachmentBlock fromJAXB(String cid, JAXBBridgeInfo bridgeInfo, RuntimeContext rtContext, String mimeType) {
+        return new JAXBImpl(cid,bridgeInfo,rtContext,mimeType);
+    }
+
+    /**
+     * No derived class outside this class.
+     */
+    private AttachmentBlock() {}
+
+    /**
+     * Content ID of the attachment. Uniquely identifies an attachment.
+     */
+    public abstract String getId();
+
+    /**
+     * Gets the WSDL part name of this attachment.
+     *
+     * <p>
+     * According to WSI AP 1.0
+     * <PRE>
+     * 3.8 Value-space of Content-Id Header
+     *   Definition: content-id part encoding
+     *   The "content-id part encoding" consists of the concatenation of:
+     * The value of the name attribute of the wsdl:part element referenced by the mime:content, in which characters disallowed in content-id headers (non-ASCII characters as represented by code points above 0x7F) are escaped as follows:
+     *     o Each disallowed character is converted to UTF-8 as one or more bytes.
+     *     o Any bytes corresponding to a disallowed character are escaped with the URI escaping mechanism (that is, converted to %HH, where HH is the hexadecimal notation of the byte value).
+     *     o The original character is replaced by the resulting character sequence.
+     * The character '=' (0x3D).
+     * A globally unique value such as a UUID.
+     * The character '@' (0x40).
+     * A valid domain name under the authority of the entity constructing the message.
+     * </PRE>
+     *
+     * So a wsdl:part fooPart will be encoded as:
+     *      <fooPart=somereallybignumberlikeauuid@example.com>
+     *
+     * @return null
+     *      if the parsing fails.
+     */
+    public final String getWSDLPartName(){
+        String cId = getId();
+
+        int index = cId.lastIndexOf('@', cId.length());
+        if(index == -1){
+            return null;
+        }
+        String localPart = cId.substring(0, index);
+        index = localPart.lastIndexOf('=', localPart.length());
+        if(index == -1){
+            return null;
+        }
+        try {
+            return java.net.URLDecoder.decode(localPart.substring(0, index), "UTF-8");
+        } catch (UnsupportedEncodingException e) {
+            throw new SerializationException(e);
+        }
+    }
+
+    /**
+     * Gets the MIME content-type of this attachment.
+     */
+    public abstract String getContentType();
+
+    /**
+     * Gets the attachment as an exact-length byte array.
+     */
+    // not so fast but useful default implementation
+    public byte[] asByteArray() {
+        try {
+            return ASCIIUtility.getBytes(asInputStream());
+        } catch (IOException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    /**
+     * Gets the attachment as a {@link DataHandler}.
+     */
+    public abstract DataHandler asDataHandler();
+
+    /**
+     * Gets the attachment as a {@link Source}.
+     * Note that there's no guarantee that the attachment is actually an XML.
+     */
+    public Source asSource() {
+        return new StreamSource(asInputStream());
+    }
+
+    /**
+     * Obtains this attachment as an {@link InputStream}.
+     */
+    // not-so-efficient but useful default implementation.
+    public InputStream asInputStream() {
+        ByteOutputStream bos = new ByteOutputStream();
+        try {
+            writeTo(bos);
+        } catch (IOException e) {
+            throw new WebServiceException(e);
+        }
+        return bos.newInputStream();
+    }
+
+    /**
+     * Deserializes this attachment by using JAXB into {@link JAXBBridgeInfo}.
+     *
+     * TODO: this abstraction is wrong.
+     */
+    public final void deserialize(BridgeContext bc, JAXBBridgeInfo bi) {
+        bi.deserialize(asInputStream(),bc);
+    }
+
+    /**
+     * Adds this attachment as an {@link AttachmentPart} into the given {@link SOAPMessage}.
+     */
+    // not so fast but useful default
+    public void addTo(SOAPMessage msg) throws SOAPException {
+        AttachmentPart part = msg.createAttachmentPart(asDataHandler());
+        part.setContentId(getId());
+        //it may be safe to say the encoding is binary meaning the bytes are not subjected any
+        //specific encoding.
+        part.setMimeHeader("Content-transfer-encoding", "binary");
+        msg.addAttachmentPart(part);
+    }
+
+    /**
+     * Writes the contents of the attachment into the given stream.
+     */
+    // not so fast but useful default
+    public void writeTo(OutputStream os) throws IOException {
+        ASCIIUtility.copyStream(asInputStream(),os);
+    }
+
+    /**
+     * Deserializes this attachment into an {@link Image}.
+     *
+     * @return null if the decoding fails.
+     */
+    public final Image asImage() throws IOException {
+        // technically we should check the MIME type here, but
+        // normally images can be content-sniffed.
+        // so the MIME type check will only make us slower and draconian, both of which
+        // JAXB 2.0 isn't interested.
+        return ImageIO.read(asInputStream());
+    }
+
+
+    /**
+     * {@link AttachmentBlock} stored as SAAJ {@link AttachmentPart}.
+     */
+    private static final class SAAJImpl extends AttachmentBlock {
+        private final AttachmentPart ap;
+
+        public SAAJImpl(AttachmentPart part) {
+            this.ap = part;
+        }
+
+        public String getId() {
+            return ap.getContentId();
+        }
+
+        public String getContentType() {
+            return ap.getContentType();
+        }
+
+        public byte[] asByteArray() {
+            try {
+                return ap.getRawContentBytes();
+            } catch (SOAPException e) {
+                throw new WebServiceException(e);
+            }
+        }
+
+        public DataHandler asDataHandler() {
+            try {
+                return ap.getDataHandler();
+            } catch (SOAPException e) {
+                throw new WebServiceException(e);
+            }
+        }
+
+        public Source asSource() {
+            try {
+                return new StreamSource(ap.getRawContent());
+            } catch (SOAPException e) {
+                throw new WebServiceException(e);
+            }
+        }
+
+        public InputStream asInputStream() {
+            try {
+                return ap.getRawContent();
+            } catch (SOAPException e) {
+                throw new WebServiceException(e);
+            }
+        }
+
+        public void addTo(SOAPMessage msg) {
+            msg.addAttachmentPart(ap);
+        }
+    }
+
+    /**
+     * {@link AttachmentBlock} stored as a {@link DataHandler}.
+     */
+    private static final class DataHandlerImpl extends AttachmentBlock {
+        private final String cid;
+        private final DataHandler dh;
+
+        public DataHandlerImpl(String cid, DataHandler dh) {
+            this.cid = cid;
+            this.dh = dh;
+        }
+
+        public String getId() {
+            return cid;
+        }
+
+        public String getContentType() {
+            return dh.getContentType();
+        }
+
+        public DataHandler asDataHandler() {
+            return dh;
+        }
+
+        public InputStream asInputStream() {
+            try {
+                return dh.getInputStream();
+            } catch (IOException e) {
+                throw new WebServiceException(e);
+            }
+        }
+    }
+
+    private static final class ByteArrayImpl extends AttachmentBlock {
+        private final String cid;
+        private byte[] data;
+        private int start;
+        private int len;
+        private final String mimeType;
+
+        public ByteArrayImpl(String cid, byte[] data, int start, int len, String mimeType) {
+            this.cid = cid;
+            this.data = data;
+            this.start = start;
+            this.len = len;
+            this.mimeType = mimeType;
+        }
+
+        public String getId() {
+            return cid;
+        }
+
+        public String getContentType() {
+            return mimeType;
+        }
+
+        public byte[] asByteArray() {
+            if(start!=0 || len!=data.length) {
+                // if our buffer isn't exact, switch to the exact one
+                byte[] exact = new byte[len];
+                System.arraycopy(data,start,exact,0,len);
+                start = 0;
+                data = exact;
+            }
+            return data;
+        }
+
+        public DataHandler asDataHandler() {
+            return new DataHandler(new ByteArrayDataSource(data,start,len,getContentType()));
+        }
+
+        public InputStream asInputStream() {
+            return new ByteArrayInputStream(data,start,len);
+        }
+
+        public void addTo(SOAPMessage msg) throws SOAPException {
+            AttachmentPart part = msg.createAttachmentPart();
+            part.setRawContentBytes(data,start,len,getContentType());
+            part.setContentId(getId());
+            msg.addAttachmentPart(part);
+        }
+
+        public void writeTo(OutputStream os) throws IOException {
+            os.write(data,start,len);
+        }
+    }
+
+    /**
+     * {@link AttachmentPart} that stores the value as a JAXB object.
+     *
+     * TODO: if it's common for an attahchment to be written more than once,
+     * it's better to cache the marshalled result, as it is expensive operation.
+     */
+    private static final class JAXBImpl extends AttachmentBlock implements DataSource {
+        private final String id;
+        private final JAXBBridgeInfo bridgeInfo;
+        private final RuntimeContext rtContext;
+        private final String type;
+
+        public JAXBImpl(String id, JAXBBridgeInfo bridgeInfo, RuntimeContext rtContext, String type) {
+            this.id = id;
+            this.bridgeInfo = bridgeInfo;
+            this.rtContext = rtContext;
+            this.type = type;
+        }
+
+        public String getId() {
+            return id;
+        }
+
+        public String getContentType() {
+            return type;
+        }
+
+        public DataHandler asDataHandler() {
+            return new DataHandler(this);
+        }
+
+        public InputStream getInputStream() {
+            return asInputStream();
+        }
+
+        public String getName() {
+            return null;
+        }
+
+        public OutputStream getOutputStream() {
+            throw new UnsupportedOperationException();
+        }
+
+        public void writeTo(OutputStream os) {
+            bridgeInfo.serialize(rtContext.getBridgeContext(),os,null);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/BodyBlock.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/BodyBlock.java
new file mode 100644
index 0000000..655486f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/BodyBlock.java
@@ -0,0 +1,86 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.internal;
+
+import javax.xml.transform.Source;
+
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBeanInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAP12FaultInfo;
+
+/**
+ * @author WS Development Team
+ */
+public class BodyBlock {
+
+    private Object value;
+
+    public BodyBlock(Object value) {
+        this.value = value;
+    }
+
+    public BodyBlock(JAXBBeanInfo beanInfo) {
+        this.value = beanInfo;
+    }
+
+    public BodyBlock(JAXBBridgeInfo bridgeInfo) {
+        this.value = bridgeInfo;
+    }
+
+    public BodyBlock(Source source) {
+        setSource(source);
+    }
+
+    public BodyBlock(SOAPFaultInfo faultInfo) {
+        setFaultInfo(faultInfo);
+    }
+
+    public BodyBlock(RpcLitPayload rpcLoad) {
+        this.value = rpcLoad;
+    }
+
+    public void setSource(Source source) {
+        this.value = source;
+    }
+
+    public void setFaultInfo(SOAPFaultInfo faultInfo) {
+        this.value = faultInfo;
+    }
+
+    /**
+     * There is no need to have so many setter to set to an Object. Just setValue is all that we need?
+     * @param value
+     */
+    public void setValue(Object value){
+        this.value = value;
+    }
+    public Object getValue() {
+        return value;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/DelegateBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/DelegateBase.java
new file mode 100644
index 0000000..41f81ee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/DelegateBase.java
@@ -0,0 +1,102 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.internal;
+
+import com.sun.xml.internal.ws.pept.Delegate;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.ept.ContactInfo;
+import com.sun.xml.internal.ws.pept.ept.ContactInfoList;
+import com.sun.xml.internal.ws.pept.ept.ContactInfoListIterator;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.client.ContextMap;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.client.ContactInfoBase;
+import com.sun.xml.internal.ws.client.ContactInfoListImpl;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.client.WSServiceDelegate;
+
+import javax.xml.ws.BindingProvider;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.Service;
+import java.util.Iterator;
+
+/**
+ * @author WS Development Team
+ */
+public class DelegateBase implements Delegate {
+    protected ContactInfoList contactInfoList;
+    protected WSServiceDelegate service;
+
+    public DelegateBase() {
+    }
+
+    public DelegateBase(ContactInfoList contactInfoList) {
+        this.contactInfoList = contactInfoList;
+    }
+
+    public DelegateBase(ContactInfoList cil, WSServiceDelegate service) {
+       this(cil);
+       this.service = service;
+    }
+
+    public MessageStruct getMessageStruct() {
+        return new MessageInfoBase();
+    }
+
+    public void send(MessageStruct messageStruct) {
+        MessageInfo messageInfo = (MessageInfo) messageStruct;
+
+        // ContactInfoListIterator iterator = contactInfoList.iterator();
+        if (!contactInfoList.iterator().hasNext())
+            throw new RuntimeException("can't pickup message encoder/decoder, no ContactInfo!");
+
+        ContextMap properties = (ContextMap)
+                messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        BindingProvider stub = (BindingProvider)properties.get(BindingProviderProperties.JAXWS_CLIENT_HANDLE_PROPERTY);
+
+        BindingImpl bi = (BindingImpl)stub.getBinding();
+        String bindingId = bi.getBindingId();
+        ContactInfo contactInfo = getContactInfo(contactInfoList, bindingId);
+
+        messageInfo.setEPTFactory(contactInfo);
+        MessageDispatcher messageDispatcher = contactInfo.getMessageDispatcher(messageInfo);
+        messageDispatcher.send(messageInfo);
+    }
+
+    private ContactInfo getContactInfo(ContactInfoList cil, String bindingId){
+        ContactInfoListIterator iter = cil.iterator();
+        while(iter.hasNext()){
+            ContactInfoBase cib = (ContactInfoBase)iter.next();
+            if(cib.getBindingId().equals(bindingId))
+                return cib;
+        }
+        //return the first one
+        return cil.iterator().next();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/HeaderBlock.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/HeaderBlock.java
new file mode 100644
index 0000000..cb24f7a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/HeaderBlock.java
@@ -0,0 +1,48 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.internal;
+
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import javax.xml.namespace.QName;
+
+/**
+ * @author WS Development Team
+ */
+public class HeaderBlock {
+
+    private JAXBBridgeInfo value;
+
+    public HeaderBlock(JAXBBridgeInfo bridgeInfo) {
+        this.value = bridgeInfo;
+    }
+
+    public Object getValue() {
+        return value;
+    }
+
+    public QName getName() {
+        return value.getName();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/InternalMessage.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/InternalMessage.java
new file mode 100644
index 0000000..f1eeee8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/InternalMessage.java
@@ -0,0 +1,103 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.internal;
+
+import javax.xml.namespace.QName;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+
+/**
+ * Represents a SOAP message with headers, a body, and attachments.
+ *
+ * @author WS Development Team
+ */
+public class InternalMessage {
+    private List<HeaderBlock> headers;
+    private Set<QName> headerSet;
+    private BodyBlock body;
+    private final Map<String,AttachmentBlock> attachments = new HashMap<String, AttachmentBlock>();
+
+    /**
+     * @return the <code>BodyBlock</code> for this message
+     */
+    public BodyBlock getBody() {
+        return body;
+    }
+
+    public void addHeader(HeaderBlock headerBlock) {
+        if (headers == null) {
+            headers = new ArrayList<HeaderBlock>();
+            headerSet = new HashSet<QName>();
+        }
+        headers.add(headerBlock);
+        headerSet.add(headerBlock.getName());
+    }
+
+    /*
+     * Checks if a header is already present
+     */
+    public boolean isHeaderPresent(QName name) {
+        if (headerSet == null) {
+            return false;
+        }
+        return headerSet.contains(name);
+    }
+
+    /**
+     * @return a <code>List</code> of <code>HeaderBlocks</code associated
+     * with this message
+     */
+    public List<HeaderBlock> getHeaders() {
+        return headers;
+    }
+
+    /**
+     * @param body
+     */
+    public void setBody(BodyBlock body) {
+        this.body = body;
+    }
+
+    public void addAttachment(AttachmentBlock attachment){
+        attachments.put(attachment.getId(),attachment);
+    }
+
+    public AttachmentBlock getAttachment(String contentId){
+        return attachments.get(contentId);
+    }
+
+    /**
+     * @return a <code>Map</code> of contentIds to attachments
+     */
+    public Map<String, AttachmentBlock> getAttachments() {
+        return attachments;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/MessageBlock.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/MessageBlock.java
new file mode 100644
index 0000000..f52633a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/MessageBlock.java
@@ -0,0 +1,75 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.internal;
+
+import javax.xml.namespace.QName;
+
+/**
+ * @author WS Development Team
+ */
+public class MessageBlock {
+    protected QName _name;
+    protected Object _value;
+
+    public MessageBlock() {
+    }
+
+    public MessageBlock(QName name, Object value) {
+        _name = name;
+        _value = value;
+    }
+
+    public MessageBlock(QName name) {
+        _name = name;
+    }
+
+    /**
+     * @return the value of this block
+     */
+    public Object getValue() {
+        return _value;
+    }
+
+    /**
+     * @param element
+     */
+    public void setValue(Object element) {
+        _value = element;
+    }
+
+    /**
+     * @return the <code>QName</code> of this block
+     */
+    public QName getName() {
+        return _name;
+    }
+
+    /**
+     * @param name
+     */
+    public void setName(QName name) {
+        _name = name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/MessageInfoBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/MessageInfoBase.java
new file mode 100644
index 0000000..0828b3f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/MessageInfoBase.java
@@ -0,0 +1,195 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.internal;
+
+import java.lang.reflect.Method;
+import java.util.HashMap;
+import java.util.Map;
+
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+
+/**
+ * @author WS Development Team
+ */
+public class MessageInfoBase implements MessageInfo {
+
+    protected Object[] _data;
+    protected Method _method;
+    protected Map _metadata;
+    protected int _messagePattern;
+    protected Object _response;
+    protected int _responseType;
+    protected EPTFactory _eptFactory;
+    protected MessageDispatcher _messageDispatcher;
+    protected Encoder _encoder;
+    protected Decoder _decoder;
+    protected WSConnection _connection;
+
+    public void setData(Object[] data) {
+        _data = data;
+    }
+
+    public Object[] getData() {
+        return _data;
+    }
+
+    public void setMethod(Method method) {
+        _method = method;
+    }
+
+    public Method getMethod() {
+        return _method;
+    }
+
+    public void setMetaData(Object name, Object value) {
+        if (_metadata == null)
+           _metadata = new HashMap();
+        _metadata.put(name, value);
+    }
+
+    public Object getMetaData(Object name) {
+        Object value = null;
+
+        if ((name != null) && (_metadata != null)) {
+             value = _metadata.get(name);
+        }
+        return value;
+    }
+
+    public int getMEP() {
+        return _messagePattern;
+    }
+
+    public void setMEP(int messagePattern) {
+        _messagePattern = messagePattern;
+    }
+
+    public int getResponseType() {
+        return _responseType;
+    }
+
+    public void setResponseType(int responseType) {
+        _responseType = responseType;
+    }
+
+    public Object getResponse() {
+        return _response;
+    }
+
+    public void setResponse(Object response) {
+        _response = response;
+    }
+
+    public EPTFactory getEPTFactory() {
+        return _eptFactory;
+    }
+
+    public void setEPTFactory(EPTFactory eptFactory) {
+        _eptFactory = eptFactory;
+    }
+
+    /*
+     * @see MessageInfo#getMessageDispatcher()
+     */
+    public MessageDispatcher getMessageDispatcher() {
+        return _messageDispatcher;
+    }
+
+    /*
+     * @see MessageInfo#getEncoder()
+     */
+    public Encoder getEncoder() {
+        return _encoder;
+    }
+
+    /*
+     * @see MessageInfo#getDecoder()
+     */
+    public Decoder getDecoder() {
+        return _decoder;
+    }
+
+    /*
+     * @see MessageInfo#getConnection()
+     */
+    public WSConnection getConnection() {
+        return _connection;
+    }
+
+    /*
+     * @see MessageInfo#setMessageDispatcher(MessageDispatcher)
+     */
+    public void setMessageDispatcher(MessageDispatcher arg0) {
+        this._messageDispatcher = arg0;
+    }
+
+    /*
+     * @see MessageInfo#setEncoder(Encoder)
+     */
+    public void setEncoder(Encoder encoder) {
+        this._encoder = encoder;
+    }
+
+    /*
+     * @see MessageInfo#setDecoder(Decoder)
+     */
+    public void setDecoder(Decoder decoder) {
+        this._decoder = decoder;
+    }
+
+    /*
+     * @see MessageInfo#setConnection(Connection)
+     */
+    public void setConnection(WSConnection connection) {
+        this._connection = connection;
+    }
+
+    public static MessageInfo copy(MessageInfo mi){
+        MessageInfoBase mib = (MessageInfoBase)mi;
+        MessageInfoBase newMi = new MessageInfoBase();
+        if(newMi._data != null){
+            Object[] data = new Object[mib._data.length];
+            int i = 0;
+            for(Object o : mib._data){
+                data[i++] = o;
+            }
+            newMi._data = data;
+        }
+        newMi.setConnection(mi.getConnection());
+        newMi.setMethod(mi.getMethod());
+        newMi.setDecoder(mi.getDecoder());
+        newMi.setEncoder(mi.getEncoder());
+        newMi.setEPTFactory(mi.getEPTFactory());
+        newMi.setMEP(mi.getMEP());
+        newMi._messageDispatcher = mib._messageDispatcher;
+        newMi._metadata = new HashMap(mib._metadata);
+        return (MessageInfo)newMi;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/SOAP12NotUnderstoodHeaderBlock.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/SOAP12NotUnderstoodHeaderBlock.java
new file mode 100644
index 0000000..76d174f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/internal/SOAP12NotUnderstoodHeaderBlock.java
@@ -0,0 +1,72 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.internal;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.ws.WebServiceException;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+
+/**
+ * SOAP 1.2 version of NotUnderstoodHeaderBlock.
+ *
+ * @author WS Development Team
+ */
+public class SOAP12NotUnderstoodHeaderBlock extends HeaderBlock {
+
+    private QName nuHeader;
+
+    // super(null) is a hack in this case
+    public SOAP12NotUnderstoodHeaderBlock(QName header) {
+        super(null);
+        nuHeader = header;
+    }
+
+    public QName getName() {
+        return new QName(SOAP12NamespaceConstants.ENVELOPE,
+            SOAP12NamespaceConstants.TAG_NOT_UNDERSTOOD);
+    }
+
+    public void write(XMLStreamWriter writer) {
+        try {
+            String prefix = "t"; // should not have been used before <header>
+            writer.writeStartElement(
+                SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAP12NamespaceConstants.TAG_NOT_UNDERSTOOD,
+                SOAP12NamespaceConstants.ENVELOPE);
+            writer.writeAttribute(
+                SOAP12NamespaceConstants.ATTR_NOT_UNDERSTOOD_QNAME,
+                prefix + ":" + nuHeader.getLocalPart());
+            writer.writeNamespace(prefix, nuHeader.getNamespaceURI());
+            writer.writeEndElement();
+        } catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultCode.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultCode.java
new file mode 100644
index 0000000..a1342ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultCode.java
@@ -0,0 +1,93 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.namespace.QName;
+import java.util.Iterator;
+
+/**
+ * SOAP 1.2 soapenv:Code
+ *
+ * <soapenv:Fault>
+ *  <soapenv:Code>
+ *      <soapenv:Value>soapenv:Sender</soapenv:Value>
+ *      <soapenv:Subcode>
+ *          <soapenv:Value>ns1:incorectRequest</Value>
+ *          <soapenv:Subcode>
+ *          ...
+ *      </soapenv:Subcode>
+ *  </soapenv:Code>
+ * </soapenv:Fault>
+ *
+ * @author Vivek Pandey
+ */
+public class FaultCode {
+    private FaultCodeEnum value;
+    private FaultSubcode subcode;
+
+    public FaultCode(FaultCodeEnum value, FaultSubcode subcode) {
+        this.value = value;
+        this.subcode = subcode;
+    }
+
+    public FaultCode(FaultCodeEnum value, Iterator<QName> subcodes) {
+        this.value = value;
+        if(subcodes.hasNext()){
+            subcode = new FaultSubcode(subcodes.next(), subcodes);
+        }
+    }
+
+    public FaultCodeEnum getValue() {
+        return value;
+    }
+
+    public FaultSubcode getSubcode() {
+        return subcode;
+    }
+
+    void write(XMLStreamWriter writer) throws XMLStreamException {
+        // <soapenv:Code>
+        writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+            SOAP12Constants.QNAME_FAULT_CODE.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+
+        // <soapenv:Value>
+        writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+            SOAP12Constants.QNAME_FAULT_VALUE.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+
+        writer.writeCharacters(value.getPrefix()+":"+value.getLocalPart());
+        writer.writeEndElement(); // </soapenv:Value>
+
+        // <soapenv:Subcode>...</soapenv:Subcode>
+        if(subcode != null)
+            subcode.write(writer);
+        writer.writeEndElement(); // </soapenv:Code>
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultCodeEnum.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultCodeEnum.java
new file mode 100644
index 0000000..d5b331e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultCodeEnum.java
@@ -0,0 +1,74 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+
+import javax.xml.namespace.QName;
+
+public enum FaultCodeEnum {
+    VersionMismatch(new QName(SOAP12NamespaceConstants.ENVELOPE, "VersionMismatch", SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE)),
+    MustUnderstand(new QName(SOAP12NamespaceConstants.ENVELOPE, "MustUnderstand", SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE)),
+    DataEncodingUnknown(new QName(SOAP12NamespaceConstants.ENVELOPE, "DataEncodingUnknown", SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE)),
+    Sender(new QName(SOAP12NamespaceConstants.ENVELOPE, "Sender", SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE)),
+    Receiver(new QName(SOAP12NamespaceConstants.ENVELOPE, "Receiver", SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE));
+
+    private FaultCodeEnum(QName code){
+        this.code = code;
+    }
+
+    public QName value(){
+        return code;
+    }
+
+    public String getLocalPart(){
+        return code.getLocalPart();
+    }
+
+    public String getNamespaceURI(){
+        return code.getNamespaceURI();
+    }
+
+    public String getPrefix(){
+        return code.getPrefix();
+    }
+
+    public static FaultCodeEnum get(QName soapFaultCode){
+        if(VersionMismatch.code.equals(soapFaultCode))
+            return VersionMismatch;
+        else if(MustUnderstand.code.equals(soapFaultCode))
+            return MustUnderstand;
+        else if(DataEncodingUnknown.code.equals(soapFaultCode))
+            return DataEncodingUnknown;
+        else if(Sender.code.equals(soapFaultCode))
+            return Sender;
+        else if(Receiver.code.equals(soapFaultCode))
+            return Receiver;
+        return null;
+    }
+
+    private final QName code;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultReason.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultReason.java
new file mode 100644
index 0000000..30ff364
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultReason.java
@@ -0,0 +1,70 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import java.util.List;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Arrays;
+
+/**
+ * SOAP 1.2 Fault Reason
+ *  <soapenv:Reason>
+ *      <soapenv:Text xml:lang="en">...</soapenv:Text>
+ *  </soapenv:Reason>
+ *
+ * @author Vivek Pandey
+ */
+public class FaultReason {
+    private List<FaultReasonText> texts;
+
+    public FaultReason(FaultReasonText... texts) {
+        assert(texts == null);
+        this.texts = Arrays.asList(texts);
+    }
+
+    public FaultReason(List<FaultReasonText> textList) {
+        texts = textList;
+    }
+
+    public List<FaultReasonText> getFaultReasonTexts(){
+        return texts;
+    }
+
+    void write(XMLStreamWriter writer) throws XMLStreamException {
+        writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+            SOAP12Constants.QNAME_FAULT_REASON.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+        for(FaultReasonText text:texts){
+            text.write(writer);
+        }
+        writer.writeEndElement();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultReasonText.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultReasonText.java
new file mode 100644
index 0000000..cb28c76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultReasonText.java
@@ -0,0 +1,69 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import java.util.Locale;
+
+/**
+ * <soapenv:Text xmlns:lang="en">
+ * ...
+ * </soapenv:Text>
+ *
+ * @author Vivek Pandey
+ */
+public class FaultReasonText {
+    private Locale language = Locale.getDefault();
+    private String value;
+
+    public FaultReasonText(String value, Locale lang) {
+        if(language != null && !language.equals(""))
+            this.language = lang;
+        this.value = value;
+    }
+
+    public Locale getLanguage() {
+        return language;
+    }
+
+    public String getValue() {
+        return value;
+    }
+
+    void write(XMLStreamWriter writer) throws XMLStreamException {
+        writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAP12Constants.QNAME_FAULT_REASON_TEXT.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+
+        //for now we only generate "en" language
+        writer.writeAttribute("xml", SOAP12NamespaceConstants.XML_NS, "lang", language.getLanguage());
+        writer.writeCharacters(value);
+        writer.writeEndElement();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultSubcode.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultSubcode.java
new file mode 100644
index 0000000..65aca59
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/FaultSubcode.java
@@ -0,0 +1,102 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import java.util.Iterator;
+
+/**
+ * SOAP 1.2 soapenv:Code
+ *
+ * <soapenv:Fault>
+ *  <soapenv:Code>
+ *      <soapenv:Value>soapenv:Sender</soapenv:Value>
+ *      <soapenv:Subcode>
+ *          <soapenv:Value>ns1:incorectRequest</Value>
+ *          <soapenv:Subcode>
+ *          ...
+ *      </soapenv:Subcode>
+ *  </soapenv:Code>
+ * </soapenv:Fault>
+ *
+ * @author Vivek Pandey
+ */
+public class FaultSubcode {
+    private QName value;
+    private FaultSubcode subcode;
+
+    public FaultSubcode(QName value, FaultSubcode subcode) {
+        this.value = value;
+        this.subcode = subcode;
+    }
+
+    public FaultSubcode(QName value, Iterator<QName> subcodes) {
+        this.value = value;
+        if(subcodes.hasNext()){
+            subcode = new FaultSubcode(subcodes.next(), subcodes);
+        }
+    }
+
+    public QName getValue() {
+        return value;
+    }
+
+    public FaultSubcode getSubcode() {
+        return subcode;
+    }
+
+    public FaultSubcode setSubCode(FaultSubcode sc){
+        this.subcode = sc;
+        return subcode;
+    }
+
+    void write(XMLStreamWriter writer) throws XMLStreamException {
+        // <soapenv:Subcode>
+        if(value == null)
+            return;
+        writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+            SOAP12Constants.QNAME_FAULT_SUBCODE.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+
+        // <soapenv:Value>
+        writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+            SOAP12Constants.QNAME_FAULT_VALUE.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+
+        writer.setPrefix(value.getPrefix(), value.getNamespaceURI());
+        if(value.getPrefix().equals(""))
+            writer.writeCharacters(value.getLocalPart());
+        else
+            writer.writeCharacters(value.getPrefix()+":"+value.getLocalPart());
+        writer.writeEndElement(); // </soapenv:Value>
+        if(subcode != null)
+            subcode.write(writer);
+        writer.writeEndElement(); // </soapenv:Subcode>
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAP12FaultInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAP12FaultInfo.java
new file mode 100644
index 0000000..1dec8d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAP12FaultInfo.java
@@ -0,0 +1,241 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBTypeSerializer;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.server.ServerRtException;
+import com.sun.xml.internal.ws.streaming.DOMStreamReader;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.Detail;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPFault;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.soap.SOAPBinding;
+import java.util.Iterator;
+import java.util.List;
+import java.util.ArrayList;
+import java.util.Locale;
+
+import org.w3c.dom.Node;
+
+/**
+ * SOAP 1.2 soap soapFault info class
+ */
+public class SOAP12FaultInfo extends SOAPFaultInfo {
+    private FaultCode code;
+    private FaultReason reason;
+    private String node;
+    private String role;
+    private Object detail;
+
+    public SOAP12FaultInfo(FaultCode code, FaultReason reason, String node, String role, Object detail) {
+        this.code = code;
+        this.reason = reason;
+        this.node = node;
+        this.role = role;
+        this.detail = detail;
+
+        soapFault = SOAPUtil.createSOAPFault(SOAPBinding.SOAP12HTTP_BINDING);
+        setFaultCode();
+        setFaultReason();
+        setFaultNode();
+        setFaultRole();
+        if((detail != null) && (detail instanceof Detail)){
+            Node n = soapFault.getOwnerDocument().importNode((Detail)detail, true);
+            soapFault.appendChild(n);
+        }else{
+            faultBean = (detail != null)?(JAXBBridgeInfo)detail:null;
+        }
+    }
+
+    public SOAP12FaultInfo(SOAPFault fault) {
+        this.soapFault = fault;
+
+        //fault code
+        QName fc = soapFault.getFaultCodeAsQName();
+        Iterator iter = soapFault.getFaultSubcodes();
+        code = new FaultCode(FaultCodeEnum.get(fc), iter);
+
+        try {
+            //fault reason
+            List<FaultReasonText> texts = new ArrayList<FaultReasonText>();
+            iter = soapFault.getFaultReasonLocales();
+            while(iter.hasNext()){
+                Locale lang = (Locale)iter.next();
+                String text = soapFault.getFaultReasonText(lang);
+                texts.add(new FaultReasonText(text, lang));
+            }
+            reason = new FaultReason(texts);
+
+            //node
+            node = soapFault.getFaultNode();
+
+            //role
+            role = soapFault.getFaultRole();
+
+            //detail
+            detail = soapFault.getDetail();
+        } catch (SOAPException e) {
+            e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.
+        }
+    }
+
+    public FaultCode getFaultCode() {
+        return code;
+    }
+
+    public FaultReason getReasons() {
+        return reason;
+    }
+
+    public String getNode() {
+        return node;
+    }
+
+    public String getRole() {
+        return role;
+    }
+
+    private void setFaultRole() {
+        if (soapFault == null || role == null)
+            return;
+        try {
+            soapFault.setFaultRole(role);
+        } catch (SOAPException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    private void setFaultNode() {
+        if (soapFault == null || node == null)
+            return;
+        try {
+            soapFault.setFaultNode(node);
+        } catch (SOAPException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    private void setFaultReason() {
+        if (soapFault == null || reason == null)
+            return;
+        List<FaultReasonText> texts = reason.getFaultReasonTexts();
+        for (FaultReasonText text : texts) {
+            try {
+                soapFault.addFaultReasonText(text.getValue(), text.getLanguage());
+            } catch (SOAPException e) {
+                throw new WebServiceException(e);
+            }
+        }
+    }
+
+    /**
+     * add SOAP 1.2 Fault Code/Subcodes to javax.xml.soap.SOAPFault
+     */
+    private void setFaultCode() {
+        if (soapFault == null || code == null)
+            return;
+        try {
+            soapFault.setFaultCode(code.getValue().value());
+            FaultSubcode fsc = code.getSubcode();
+            while (fsc != null) {
+                soapFault.appendFaultSubcode(fsc.getValue());
+                fsc = fsc.getSubcode();
+            }
+        } catch (SOAPException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+
+    public void write(XMLStreamWriter writer, MessageInfo mi) {
+        try {
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                    SOAP12Constants.QNAME_SOAP_FAULT.getLocalPart(),
+                    SOAP12Constants.QNAME_SOAP_FAULT.getNamespaceURI());
+            // Writing NS since this may be called without writing envelope
+            writer.writeNamespace(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                    SOAP12Constants.QNAME_SOAP_FAULT.getNamespaceURI());
+
+            code.write(writer); //<soapenv:Code> ... </soapenv:Code>
+            reason.write(writer);
+
+
+            //<soapenv:Node>...</soapenv:Node>
+            if (node != null) {
+                writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                        SOAP12Constants.QNAME_FAULT_NODE.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+                writer.writeCharacters(node);
+                writer.writeEndElement();
+            }
+
+            //<soapenv:Role>...</soapenv:Role>
+            if (role != null) {
+                writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                        SOAP12Constants.QNAME_FAULT_ROLE.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+                writer.writeCharacters(role);
+                writer.writeEndElement();
+            }
+
+            //<soapenv:Detail>...</soapenv:Detail>
+            if (detail != null) {
+                // Not RuntimeException, Not header soapFault
+                if (detail instanceof Detail) {
+                    // SOAPFaultException
+                    SOAPEncoder.serializeReader(new DOMStreamReader((Detail) detail), writer);
+                } else if (detail instanceof JAXBBridgeInfo) {
+                    // Service specific exception
+                    startDetailElement(writer);     // <soapenv:Detail>
+                    RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(mi);
+                    BridgeContext bridgeContext = rtCtxt.getBridgeContext();
+                    ((JAXBBridgeInfo) detail).serialize(bridgeContext, writer);
+                    writer.writeEndElement();  // </soapenv:Detail>
+                }
+            }
+            writer.writeEndElement();                // </soapenv:Fault>
+        } catch (XMLStreamException e) {
+            throw new ServerRtException(e);
+        }
+    }
+
+    private void startDetailElement(XMLStreamWriter writer) throws XMLStreamException {
+        writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAP12Constants.QNAME_FAULT_DETAIL.getLocalPart(), SOAP12NamespaceConstants.ENVELOPE);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPFaultInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPFaultInfo.java
new file mode 100644
index 0000000..4252846
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPFaultInfo.java
@@ -0,0 +1,104 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.SOAPFault;
+import javax.xml.soap.Detail;
+import javax.xml.ws.soap.SOAPBinding;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPFaultInfo {
+
+    public SOAPFaultInfo(){}
+    /**
+     * create SOAPFaultInfo with SOAPFault
+     *
+     * @param fault
+     */
+    public SOAPFaultInfo(SOAPFault fault) {
+        this.soapFault = fault;
+    }
+
+    /**
+     * Accessor method to get the fault bean
+     *
+     * @return the JAXBBidgeInfo for this fault
+     */
+    public JAXBBridgeInfo getFaultBean() {
+        return faultBean;
+    }
+
+    /**
+     * creates SOAPFaultInfo, could be SOAP 1.1 or SOAP 1.2 fault.
+     *
+     * @param string
+     * @param code
+     * @param actor
+     * @param detail
+     * @param bindingId
+     */
+    public SOAPFaultInfo(String string, QName code, String actor, Object detail, String bindingId) {
+        if (detail == null || detail instanceof Detail) {
+            Detail det = (detail != null) ? (Detail) detail : null;
+            soapFault = SOAPUtil.createSOAPFault(string, code, actor, det, bindingId);
+        } else {
+            soapFault = SOAPUtil.createSOAPFault(string, code, actor, null, bindingId);
+            faultBean = (JAXBBridgeInfo) detail;
+        }
+    }
+
+    public QName getCode() {
+        return soapFault.getFaultCodeAsQName();
+    }
+
+    public String getString() {
+        return soapFault.getFaultString();
+    }
+
+    public String getActor() {
+        return soapFault.getFaultActor();
+    }
+
+    public Object getDetail() {
+        if (faultBean != null)
+            return faultBean;
+
+        return soapFault.getDetail();
+    }
+
+    public SOAPFault getSOAPFault() {
+        return soapFault;
+    }
+
+    protected SOAPFault soapFault;
+    protected JAXBBridgeInfo faultBean;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPMsgCreateException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPMsgCreateException.java
new file mode 100644
index 0000000..72f4cd1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPMsgCreateException.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPMsgCreateException extends JAXWSExceptionBase {
+
+    public SOAPMsgCreateException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.soap";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPMsgFactoryCreateException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPMsgFactoryCreateException.java
new file mode 100644
index 0000000..63c77c3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/message/SOAPMsgFactoryCreateException.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.message;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPMsgFactoryCreateException extends JAXWSExceptionBase {
+
+    public SOAPMsgFactoryCreateException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.soap";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/ProviderSED.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/ProviderSED.java
new file mode 100644
index 0000000..2aded47
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/ProviderSED.java
@@ -0,0 +1,84 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.server;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.model.soap.SOAPRuntimeModel;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import javax.xml.transform.Source;
+import javax.xml.ws.soap.SOAPBinding;
+
+public class ProviderSED implements InternalEncoder {
+
+    public void toMessageInfo(Object internalMessage, MessageInfo messageInfo) {
+        throw new UnsupportedOperationException();
+    }
+
+    /*
+     * Sets Source in InternalMessage's BodyBlock. If there is an exception
+     * in MessageInfo, it is set as fault in BodyBlock
+     *
+     */
+    public InternalMessage toInternalMessage(MessageInfo messageInfo) {
+        InternalMessage internalMessage = new InternalMessage();
+        switch(messageInfo.getResponseType()) {
+            case MessageStruct.NORMAL_RESPONSE :
+                Object obj = messageInfo.getResponse();
+                if (obj instanceof Source) {
+                    BodyBlock bodyBlock = new BodyBlock((Source)obj);
+                    internalMessage.setBody(bodyBlock);
+                } else {
+                    throw new UnsupportedOperationException();
+                }
+                break;
+
+            case MessageStruct.CHECKED_EXCEPTION_RESPONSE :
+                // invoke() doesn't throw any checked exception
+                // Fallthrough
+
+            case MessageStruct.UNCHECKED_EXCEPTION_RESPONSE :
+                RuntimeContext rtContext = MessageInfoUtil.getRuntimeContext(messageInfo);
+                BindingImpl bindingImpl =
+                    (BindingImpl)rtContext.getRuntimeEndpointInfo().getBinding();
+                String bindingId = bindingImpl.getBindingId();
+                if (bindingId.equals(SOAPBinding.SOAP11HTTP_BINDING)) {
+                    SOAPRuntimeModel.createFaultInBody(messageInfo.getResponse(),
+                            null, null, internalMessage);
+                } else if (bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING)) {
+                    SOAPRuntimeModel.createSOAP12FaultInBody(messageInfo.getResponse(),
+                            null, null, null, internalMessage);
+                }
+                break;
+        }
+        return internalMessage;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAP12XMLDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAP12XMLDecoder.java
new file mode 100644
index 0000000..0666137
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAP12XMLDecoder.java
@@ -0,0 +1,188 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.server;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.SOAPFault;
+import javax.xml.stream.XMLStreamReader;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.SOAP12NotUnderstoodHeaderBlock;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.ws.soap.SOAPFaultException;
+
+import static javax.xml.stream.XMLStreamReader.*;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.streaming.XMLReader;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.server.*;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAP12XMLDecoder extends SOAPXMLDecoder {
+
+    private static final Set<String> requiredRoles = new HashSet<String>();
+
+    public SOAP12XMLDecoder() {
+        requiredRoles.add("http://www.w3.org/2003/05/soap-envelope/role/next");
+        requiredRoles.add("http://www.w3.org/2003/05/soap-envelope/role/ultimateReceiver");
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#decodeHeader(com.sun.xml.internal.ws.streaming.XMLReader, com.sun.pept.ept.MessageInfo, com.sun.xml.internal.ws.soap.internal.InternalMessage)
+     */
+    @Override
+    protected void decodeHeader(XMLStreamReader reader, MessageInfo messageInfo, InternalMessage request) {
+        // TODO Auto-generated method stub
+        super.decodeHeader(reader, messageInfo, request);
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#getBodyTag()
+     */
+    @Override
+    protected QName getBodyTag() {
+        return SOAP12Constants.QNAME_SOAP_BODY;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#getEnvelopeTag()
+     */
+    @Override
+    protected QName getEnvelopeTag() {
+        return SOAP12Constants.QNAME_SOAP_ENVELOPE;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.encoding.soap.SOAPDecoder#getHeaderTag()
+     */
+    @Override
+    protected QName getHeaderTag() {
+        return SOAP12Constants.QNAME_SOAP_HEADER;
+    }
+
+    @Override
+    protected QName getMUAttrQName(){
+        return SOAP12Constants.QNAME_MUSTUNDERSTAND;
+    }
+
+    @Override
+    protected QName getRoleAttrQName(){
+        return SOAP12Constants.QNAME_ROLE;
+    }
+
+    public Set<String> getRequiredRoles() {
+        return requiredRoles;
+    }
+
+    /*
+     * Keep track of all not-understood headers to return
+     * with fault to client. In soap 1.1, the check fails
+     * on the first not-understood header.
+     */
+    @Override
+    protected void checkHeadersAgainstKnown(XMLStreamReader reader,
+        Set<String> roles, Set<QName> understoodHeaders, MessageInfo mi) {
+
+        Set<QName> notUnderstoodHeaders = new HashSet<QName>();
+
+        while (true) {
+            if (reader.getEventType() == START_ELEMENT) {
+                // check MU header for each role
+                QName qName = reader.getName();
+                String mu = reader.getAttributeValue(
+                    getMUAttrQName().getNamespaceURI(),
+                    getMUAttrQName().getLocalPart());
+                if (mu != null && (mu.equals("1") ||
+                    mu.equalsIgnoreCase("true"))) {
+                    String role = reader.getAttributeValue(
+                        getRoleAttrQName().getNamespaceURI(),
+                        getRoleAttrQName().getLocalPart());
+                    if (role != null && roles.contains(role)) {
+                        logger.finest("Element=" + qName +
+                            " targeted at=" + role);
+                        if (understoodHeaders == null ||
+                            !understoodHeaders.contains(qName)) {
+                            logger.finest("Element not understood=" + qName);
+                            notUnderstoodHeaders.add(qName);
+                        }
+                    }
+                }
+                XMLStreamReaderUtil.skipElement(reader);   // Moves to END state
+                XMLStreamReaderUtil.nextElementContent(reader);
+            } else {
+                break;
+            }
+        }
+
+        if (notUnderstoodHeaders.isEmpty()) {
+            return;
+        }
+
+        // need to add headers to fault
+        SOAPFault sf = SOAPUtil.createSOAPFault(
+            MUST_UNDERSTAND_FAULT_MESSAGE_STRING,
+            SOAP12Constants.FAULT_CODE_MUST_UNDERSTAND,
+            null, null, SOAPBinding.SOAP12HTTP_BINDING);
+        Set<HeaderBlock> nuHeaderBlocks = new HashSet<HeaderBlock>();
+        for (QName headerName : notUnderstoodHeaders) {
+            nuHeaderBlocks.add(new SOAP12NotUnderstoodHeaderBlock(headerName));
+        }
+        MessageInfoUtil.setNotUnderstoodHeaders(mi, nuHeaderBlocks);
+        throw new SOAPFaultException(sf);
+    }
+
+    @Override
+    public String getBindingId() {
+        return SOAPBinding.SOAP12HTTP_BINDING;
+    }
+
+    @Override
+    protected QName getSenderFaultCode() {
+        return SOAP12Constants.FAULT_CODE_CLIENT;
+
+    }
+
+    @Override
+    protected QName getReceiverFaultCode() {
+        return SOAP12Constants.FAULT_CODE_SERVER;
+
+    }
+
+    @Override
+    protected QName getVersionMismatchFaultCode() {
+        return SOAP12Constants.FAULT_CODE_VERSION_MISMATCH;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAP12XMLEncoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAP12XMLEncoder.java
new file mode 100644
index 0000000..3612f11
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAP12XMLEncoder.java
@@ -0,0 +1,135 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.server;
+
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.ws.soap.SOAPBinding;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAP12FaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.server.*;
+
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.*;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import javax.xml.ws.handler.MessageContext;
+
+public class SOAP12XMLEncoder extends SOAPXMLEncoder {
+    /*
+     * @see SOAPEncoder#startEnvelope(XMLStreamWriter)
+     */
+    @Override
+    protected void startEnvelope(XMLStreamWriter writer) {
+        try {
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_ENVELOPE, SOAP12NamespaceConstants.ENVELOPE);
+            writer.setPrefix(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                             SOAP12NamespaceConstants.ENVELOPE);
+            writer.writeNamespace(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                                  SOAP12NamespaceConstants.ENVELOPE);
+        }
+        catch (XMLStreamException e) {
+            throw new ServerRtException(e);
+        }
+    }
+
+    /*
+     * @see SOAPEncoder#startBody(XMLStreamWriter)
+     */
+    @Override
+    protected void startBody(XMLStreamWriter writer) {
+        try {
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_BODY, SOAP12NamespaceConstants.ENVELOPE);
+        }
+        catch (XMLStreamException e) {
+            throw new ServerRtException(e);
+        }
+    }
+
+    /*
+     * @see SOAPEncoder#startHeader(XMLStreamWriter)
+     */
+    @Override
+    protected void startHeader(XMLStreamWriter writer) {
+        try {
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPNamespaceConstants.TAG_HEADER, SOAP12NamespaceConstants.ENVELOPE); // <env:Header>
+        }
+        catch (XMLStreamException e) {
+            throw new ServerRtException(e);
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.ws.rt.server.SOAPXMLEncoder#writeFault(com.sun.xml.internal.ws.soap.message.SOAPFaultInfo, com.sun.pept.ept.MessageInfo, com.sun.xml.internal.ws.streaming.XMLStreamWriter)
+     */
+    @Override
+    protected void writeFault(SOAPFaultInfo faultInfo, MessageInfo messageInfo, XMLStreamWriter writer) {
+        if(!(faultInfo instanceof SOAP12FaultInfo))
+            return;
+        // Set a status code for Fault
+        MessageContext ctxt = MessageInfoUtil.getMessageContext(messageInfo);
+        if (MessageContextUtil.getHttpStatusCode(ctxt) == null) {
+            MessageContextUtil.setHttpStatusCode(ctxt, WSConnection.INTERNAL_ERR);
+        }
+
+        ((SOAP12FaultInfo)faultInfo).write(writer, messageInfo);
+    }
+
+    protected String getContentType(MessageInfo messageInfo,
+        JAXWSAttachmentMarshaller marshaller)
+    {
+        String contentNegotiation = (String)
+            messageInfo.getMetaData(BindingProviderProperties.CONTENT_NEGOTIATION_PROPERTY);
+
+        if (marshaller == null) {
+            marshaller = getAttachmentMarshaller(messageInfo);
+        }
+
+        if (marshaller != null && marshaller.isXopped()) {
+            return XOP_SOAP12_XML_TYPE_VALUE;
+        }
+        else {
+            return (contentNegotiation == "optimistic") ?
+                FAST_INFOSET_TYPE_SOAP12 : SOAP12_XML_CONTENT_TYPE_VALUE;
+        }
+    }
+
+    /**
+     * This method is used to create the appropriate SOAPMessage (1.1 or 1.2 using SAAJ api).
+     * @return the BindingID associated with this encoder
+     */
+    protected String getBindingId(){
+        return SOAPBinding.SOAP12HTTP_BINDING;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAPXMLDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAPXMLDecoder.java
new file mode 100644
index 0000000..7c3c149
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAPXMLDecoder.java
@@ -0,0 +1,204 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.server;
+
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.model.JavaMethod;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import java.lang.reflect.Method;
+import java.util.HashSet;
+import java.util.Set;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.soap.SOAPFaultException;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.transform.Source;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamConstants;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAPDecoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.streaming.SourceReaderFactory;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+import com.sun.xml.internal.ws.server.*;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderException;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.ws.handler.MessageContext;
+
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPXMLDecoder extends SOAPDecoder {
+
+    private static final Set<String> requiredRoles = new HashSet<String>();
+    private static final QName emptyBodyName = new QName("");
+
+    public SOAPXMLDecoder() {
+        requiredRoles.add("http://schemas.xmlsoap.org/soap/actor/next");
+        requiredRoles.add("");
+    }
+
+    /*
+     *
+     * @throws ServerRtException
+     * @see SOAPDecoder#toInternalMessage(SOAPMessage)
+     */
+    public InternalMessage toInternalMessage(SOAPMessage soapMessage, MessageInfo messageInfo) {
+        // TODO handle exceptions, attachments
+        XMLStreamReader reader = null;
+        try {
+            InternalMessage request = new InternalMessage();
+            processAttachments(messageInfo, request, soapMessage);
+            Source source = soapMessage.getSOAPPart().getContent();
+            reader = SourceReaderFactory.createSourceReader(source, true,getSOAPMessageCharsetEncoding(soapMessage));
+            XMLStreamReaderUtil.nextElementContent(reader);
+            decodeEnvelope(reader, request, false, messageInfo);
+            return request;
+        } catch(Exception e) {
+            if (isBadXML(e)) {
+                RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+                HandlerContext handlerCtxt = rtCtxt.getHandlerContext();
+                raiseBadXMLFault(handlerCtxt);
+            }
+            throw new ServerRtException("soapdecoder.err", new Object[]{e});
+        } finally {
+            if (reader != null) {
+                XMLStreamReaderUtil.close(reader);
+            }
+        }
+    }
+
+    protected boolean isBadXML(Exception e) {
+        while (e != null) {
+            if (e instanceof XMLStreamException) {
+                return true;
+            }
+            e = (e.getCause() instanceof Exception) ? (Exception)e.getCause() : null;
+        }
+        return false;
+    }
+
+
+    /*
+     * Headers from SOAPMesssage are mapped to HeaderBlocks in InternalMessage
+     * Body from SOAPMessage is skipped
+     * BodyBlock in InternalMessage is converted to JAXBTypeInfo or RpcLitPayload
+     *
+     * @throws ServerRtException
+     * @see SOAPDecoder#toInternalMessage(SOAPMessage, InternalMessage)
+     */
+    public InternalMessage toInternalMessage(SOAPMessage soapMessage,
+            InternalMessage request, MessageInfo messageInfo) {
+
+        // TODO handle exceptions, attachments
+        XMLStreamReader reader = null;
+        try {
+            processAttachments(messageInfo, request, soapMessage);
+            Source source = soapMessage.getSOAPPart().getContent();
+            reader = SourceReaderFactory.createSourceReader(source, true,getSOAPMessageCharsetEncoding(soapMessage));
+            XMLStreamReaderUtil.nextElementContent(reader);
+            decodeEnvelope(reader, request, true, messageInfo);
+            convertBodyBlock(request, messageInfo);
+        } catch(Exception e) {
+            if (isBadXML(e)) {
+                RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+                HandlerContext handlerCtxt = rtCtxt.getHandlerContext();
+                raiseBadXMLFault(handlerCtxt);
+            }
+            throw new ServerRtException("soapdecoder.err", new Object[]{e});
+        } finally {
+            if (reader != null) {
+                XMLStreamReaderUtil.close(reader);
+            }
+        }
+        return request;
+    }
+
+    @Override
+    public void decodeDispatchMethod(XMLStreamReader reader, InternalMessage request, MessageInfo messageInfo) {
+        // Operation's QName. takes care of <body/>
+        QName name = (reader.getEventType() == XMLStreamConstants.START_ELEMENT) ? reader.getName() : emptyBodyName;
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        RuntimeModel rtModel = rtCtxt.getModel();
+        JavaMethod javaMethod = rtModel.getJavaMethod(name);
+        Method method = (javaMethod == null) ? null : javaMethod.getMethod();
+        if (method == null) {
+            raiseFault(getSenderFaultCode(), "Cannot find the dispatch method");
+        }
+        MessageContext msgCtxt = MessageInfoUtil.getMessageContext(messageInfo);
+        if (msgCtxt != null) {
+            String opNsUri = rtModel.getPortTypeName().getNamespaceURI();
+            String opName = javaMethod.getOperationName();
+            MessageContextUtil.setWsdlOperation(msgCtxt, new QName(opNsUri, opName));
+        }
+        messageInfo.setMethod(method);
+    }
+
+    protected SOAPFaultInfo decodeFault(XMLStreamReader reader, InternalMessage internalMessage,
+        MessageInfo messageInfo) {
+        raiseFault(getSenderFaultCode(), "Server cannot handle fault message");
+        return null;
+    }
+
+    @Override
+    protected void raiseBadXMLFault(HandlerContext ctxt) {
+        MessageContextUtil.setHttpStatusCode(ctxt.getMessageContext(), 400);
+        raiseFault(getSenderFaultCode(), "Bad request");
+    }
+
+    public Set<String> getRequiredRoles() {
+        return requiredRoles;
+    }
+
+    @Override
+    public String getBindingId() {
+        return SOAPBinding.SOAP11HTTP_BINDING;
+    }
+
+    @Override
+    protected QName getSenderFaultCode() {
+        return SOAPConstants.FAULT_CODE_CLIENT;
+    }
+
+    @Override
+    protected QName getReceiverFaultCode() {
+        return SOAPConstants.FAULT_CODE_SERVER;
+    }
+
+    @Override
+    protected QName getVersionMismatchFaultCode() {
+        return SOAPConstants.FAULT_CODE_VERSION_MISMATCH;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAPXMLEncoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAPXMLEncoder.java
new file mode 100644
index 0000000..c7268a8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/server/SOAPXMLEncoder.java
@@ -0,0 +1,253 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.soap.server;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.*;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.server.ServerRtException;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.streaming.DOMStreamReader;
+import com.sun.xml.internal.ws.streaming.XMLStreamWriterFactory;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+
+import javax.xml.XMLConstants;
+import javax.xml.namespace.QName;
+import javax.xml.soap.Detail;
+import javax.xml.soap.MimeHeaders;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.soap.SOAPBinding;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPXMLEncoder extends SOAPEncoder {
+
+    protected static final String FAULTCODE_NAME   = "faultcode";
+    protected static final String FAULTSTRING_NAME = "faultstring";
+    protected static final String FAULTACTOR_NAME  = "faultactor";
+    protected static final String DETAIL_NAME      = "detail";
+
+    public SOAPXMLEncoder() {
+    }
+
+    public SOAPMessage toSOAPMessage(InternalMessage response, MessageInfo messageInfo) {
+        XMLStreamWriter writer = null;
+        JAXWSAttachmentMarshaller marshaller = null;
+        boolean xopEnabled = false;
+
+        try {
+            setAttachmentsMap(messageInfo, response);
+            ByteArrayBuffer bab = new ByteArrayBuffer();
+
+            if (messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY) == "optimistic") {
+                writer = XMLStreamWriterFactory.createFIStreamWriter(bab);
+
+                // Turn XOP off for FI
+                marshaller = getAttachmentMarshaller(messageInfo);
+                if (marshaller != null) {
+                    xopEnabled = marshaller.isXOPPackage();     // last value
+                    marshaller.setXOPPackage(false);
+                }
+            }
+            else {
+                // Store output stream to use in JAXB bridge (not with FI)
+                messageInfo.setMetaData(JAXB_OUTPUTSTREAM, bab);
+                writer = XMLStreamWriterFactory.createXMLStreamWriter(bab);
+            }
+
+            writer.writeStartDocument();
+            startEnvelope(writer);
+            writeEnvelopeNamespaces(writer, messageInfo);
+            writeHeaders(writer, response, messageInfo);
+            writeBody(writer, response, messageInfo);
+            endEnvelope(writer);
+            writer.writeEndDocument();
+            writer.close();
+
+            MimeHeaders mh = new MimeHeaders();
+            mh.addHeader("Content-Type", getContentType(messageInfo, marshaller));
+            SOAPMessage msg = SOAPUtil.createMessage(mh, bab.newInputStream(), getBindingId());
+            processAttachments(response, msg);
+
+            // Restore default XOP processing before returning
+            if (marshaller != null) {
+                marshaller.setXOPPackage(xopEnabled);
+            }
+
+            return msg;
+        }
+        catch (Exception e) {
+            throw new ServerRtException("soapencoder.err", new Object[]{e});
+        }
+        finally {
+            if (writer != null) {
+                try {
+                    writer.close();
+                }
+                catch (XMLStreamException e) {
+                    throw new ServerRtException(e);
+                }
+            }
+        }
+    }
+
+    protected JAXWSAttachmentMarshaller getAttachmentMarshaller(MessageInfo messageInfo) {
+        Object rtc = messageInfo.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        if (rtc != null) {
+            BridgeContext bc = ((RuntimeContext) rtc).getBridgeContext();
+            if (bc != null) {
+                return (JAXWSAttachmentMarshaller) bc.getAttachmentMarshaller();
+            }
+        }
+        return null;
+    }
+
+    protected String getContentType(MessageInfo messageInfo,
+        JAXWSAttachmentMarshaller marshaller)
+    {
+        String contentNegotiation = (String)
+            messageInfo.getMetaData(BindingProviderProperties.CONTENT_NEGOTIATION_PROPERTY);
+
+        if (marshaller == null) {
+            marshaller = getAttachmentMarshaller(messageInfo);
+        }
+
+        if (marshaller != null && marshaller.isXopped()) {
+            return XOP_SOAP11_XML_TYPE_VALUE;
+        }
+        else {
+            return (contentNegotiation == "optimistic") ?
+                FAST_INFOSET_TYPE_SOAP11 : XML_CONTENT_TYPE_VALUE;
+        }
+    }
+
+    /*
+     * writes <env:Fault> ... </env:Fault>. JAXB serializes the contents
+     * in the <detail> for service specific exceptions. We serialize protocol
+     * specific exceptions ourselves
+     */
+    protected void writeFault(SOAPFaultInfo instance, MessageInfo messageInfo, XMLStreamWriter writer) {
+        try {
+            // Set a status code for Fault
+            MessageContext ctxt = MessageInfoUtil.getMessageContext(messageInfo);
+            if (MessageContextUtil.getHttpStatusCode(ctxt) == null) {
+                MessageContextUtil.setHttpStatusCode(ctxt, WSConnection.INTERNAL_ERR);
+            }
+
+            writer.writeStartElement(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                SOAPConstants.QNAME_SOAP_FAULT.getLocalPart(),
+                SOAPConstants.QNAME_SOAP_FAULT.getNamespaceURI());
+            // Writing NS since this may be called without writing envelope
+            writer.writeNamespace(SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE,
+                    SOAPConstants.QNAME_SOAP_FAULT.getNamespaceURI());
+
+            writer.writeStartElement(FAULTCODE_NAME);   // <faultcode>
+            String prefix = SOAPNamespaceConstants.NSPREFIX_SOAP_ENVELOPE;
+            QName faultCode = instance.getCode();
+            String nsURI = faultCode.getNamespaceURI();
+            if (!nsURI.equals(SOAPNamespaceConstants.ENVELOPE)) {
+                    // Need to add namespace declaration for this custom fault code
+                if (nsURI.equals(XMLConstants.NULL_NS_URI)) {
+                    prefix = XMLConstants.DEFAULT_NS_PREFIX;
+                } else {
+                    prefix = faultCode.getPrefix();
+                    if (prefix.equals(XMLConstants.DEFAULT_NS_PREFIX)) {
+                        prefix = "ans";
+                    }
+                    writer.setPrefix(prefix, nsURI);
+                    writer.writeNamespace(prefix, nsURI);
+                }
+            }
+            if (prefix.equals(XMLConstants.DEFAULT_NS_PREFIX)) {
+                writer.writeCharacters(instance.getCode().getLocalPart());
+            } else {
+                    writer.writeCharacters(prefix+":"+instance.getCode().getLocalPart());
+            }
+            writer.writeEndElement();                    // </faultcode>
+
+            writer.writeStartElement(FAULTSTRING_NAME);
+            writer.writeCharacters(instance.getString());
+            writer.writeEndElement();
+
+            if (instance.getActor() != null) {
+                writer.writeStartElement(FAULTACTOR_NAME);
+                writer.writeCharacters(instance.getActor());
+                writer.writeEndElement();
+            }
+
+            Object detail = instance.getDetail();
+            if (detail != null) {
+                // Not RuntimeException, Not header fault
+                if (detail instanceof Detail) {
+                    // SOAPFaultException
+                    encodeDetail((Detail)detail, writer);
+                } else if (detail instanceof JAXBBridgeInfo) {
+                    // Service specific exception
+                    writer.writeStartElement(DETAIL_NAME);
+                    writeJAXBBridgeInfo((JAXBBridgeInfo)detail, messageInfo, writer);
+                    writer.writeEndElement();        // </detail>
+                }
+            }
+
+            writer.writeEndElement();                // </env:Fault>
+        }
+        catch (XMLStreamException e) {
+            throw new ServerRtException(e);
+        }
+    }
+
+    /*
+     * Serializes javax.xml.soap.Detail. Detail is of type SOAPElement.
+     * XmlTreeReader is used to traverse the SOAPElement/DOM Node and serializes
+     * the XML.
+     */
+    protected void encodeDetail(Detail detail, XMLStreamWriter writer) {
+        serializeReader(new DOMStreamReader(detail), writer);
+    }
+
+    /**
+     * This method is used to create the appropriate SOAPMessage (1.1 or 1.2 using SAAJ api).
+     * @return the BindingID associated with this encoder
+     */
+    protected String getBindingId(){
+        return SOAPBinding.SOAP11HTTP_BINDING;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/streaming/SOAP12NamespaceConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/streaming/SOAP12NamespaceConstants.java
new file mode 100644
index 0000000..bfd7375
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/streaming/SOAP12NamespaceConstants.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.streaming;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAP12NamespaceConstants {
+    public static final String XML_NS = "http://www.w3.org/XML/1998/namespace";
+    public static final String ENVELOPE =
+        "http://www.w3.org/2003/05/soap-envelope";
+    public static final String ENCODING =
+        "http://www.w3.org/2003/05/soap-encoding";
+    public static final String SOAP_RPC = "http://www.w3.org/2002/06/soap-rpc";
+    public static final String XSD = "http://www.w3.org/2001/XMLSchema";
+    public static final String XSI =
+        "http://www.w3.org/2001/XMLSchema-instance";
+    public static final String TRANSPORT_HTTP =
+        "http://www.w3.org/2003/05/soap/bindings/HTTP/";
+
+    public static final String ACTOR_NEXT = "http://www.w3.org/2003/05/soap-envelope/role/next";
+
+    public static final String ROLE_NEXT =
+        "http://www.w3.org/2003/05/soap-envelope/role/next";
+    public static final String ROLE_NONE = "http://www.w3.org/2003/05/soap-envelope/role/none";
+    public static final String ROLE_ULTIMATE_RECEIVER = "http://www.w3.org/2003/05/soap-envelope/role/ultimateReceiver";
+
+    public static final String SOAP_UPGRADE =
+        "http://www.w3.org/2002/06/soap-upgrade";
+
+    public static final String TAG_ENVELOPE = "Envelope";
+    public static final String TAG_HEADER = "Header";
+    public static final String TAG_BODY = "Body";
+    public static final String TAG_RESULT = "result";
+    public static final String TAG_NOT_UNDERSTOOD = "NotUnderstood";
+
+    public static final String ATTR_ACTOR = "role";
+    public static final String ATTR_MUST_UNDERSTAND = "mustUnderstand";
+    public static final String ATTR_MISUNDERSTOOD = "missUnderstood";
+    public static final String ATTR_ENCODING_STYLE = "encodingStyle";
+    public static final String ATTR_NOT_UNDERSTOOD_QNAME = "qname";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/streaming/SOAPNamespaceConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/streaming/SOAPNamespaceConstants.java
new file mode 100644
index 0000000..f349c9b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/soap/streaming/SOAPNamespaceConstants.java
@@ -0,0 +1,53 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.soap.streaming;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPNamespaceConstants {
+    public static final String NSPREFIX_SOAP_ENVELOPE = "soapenv";
+    public static final String ENVELOPE = "http://schemas.xmlsoap.org/soap/envelope/";
+    public static final String ENCODING =
+        "http://schemas.xmlsoap.org/soap/encoding/";
+    public static final String XSD = "http://www.w3.org/2001/XMLSchema";
+    public static final String XSI =
+        "http://www.w3.org/2001/XMLSchema-instance";
+    public static final String XMLNS = "http://www.w3.org/XML/1998/namespace";
+    public static final String TRANSPORT_HTTP =
+        "http://schemas.xmlsoap.org/soap/http";
+    public static final String ACTOR_NEXT =
+        "http://schemas.xmlsoap.org/soap/actor/next";
+
+    public static final String TAG_ENVELOPE = "Envelope";
+    public static final String TAG_HEADER = "Header";
+    public static final String TAG_BODY = "Body";
+    public static final String TAG_FAULT = "Fault";
+
+    public static final String ATTR_ACTOR = "actor";
+    public static final String ATTR_MUST_UNDERSTAND = "mustUnderstand";
+    public static final String ATTR_ENCODING_STYLE = "encodingStyle";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLDecoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLDecoder.java
new file mode 100644
index 0000000..2298bd9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLDecoder.java
@@ -0,0 +1,116 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.xml;
+import javax.xml.stream.XMLStreamReader;
+
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.*;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+
+import static javax.xml.stream.XMLStreamReader.*;
+import javax.xml.soap.SOAPMessage;
+import java.util.logging.Logger;
+
+
+
+/**
+ * @author WS Development Team
+ */
+public class XMLDecoder implements Decoder {
+
+    private static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".xml.decoder");
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.encoding.Decoder#decode(com.sun.pept.ept.MessageInfo)
+     */
+    public void decode(MessageInfo arg0) {
+        throw new UnsupportedOperationException();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.pept.encoding.Decoder#receieveAndDecode(com.sun.pept.ept.MessageInfo)
+     */
+    public void receiveAndDecode(MessageInfo arg0) {
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * parses and binds body from xmlMessage.
+     * @param xmlMessage
+     * @param messageInfo
+     * @return InternalMessage representation of xmlMessage
+     */
+    public InternalMessage toInternalMessage(XMLMessage xmlMessage,
+                    MessageInfo messageInfo) {
+            return null;
+    }
+
+    /**
+     * Parses and binds xmlMessage.
+     * @param xmlMessage
+     * @param internalMessage
+     * @param messageInfo
+     *
+     */
+    public InternalMessage toInternalMessage(XMLMessage xmlMessage,
+            InternalMessage internalMessage, MessageInfo messageInfo) {
+        return null;
+    }
+
+    public SOAPMessage toSOAPMessage(MessageInfo messageInfo) {
+        return null;
+    }
+
+    public void toMessageInfo(InternalMessage internalMessage, MessageInfo messageInfo) { }
+
+    public void decodeDispatchMethod(XMLStreamReader reader, InternalMessage request, MessageInfo messageInfo) {
+    }
+
+
+    /*
+    *
+    */
+   protected void convertBodyBlock(InternalMessage request, MessageInfo messageInfo) {
+       BodyBlock bodyBlock = request.getBody();
+       if (bodyBlock != null) {
+           Object value = bodyBlock.getValue();
+           if (value instanceof JAXBBeanInfo) {
+               System.out.println("******* NOT HANDLED JAXBBeanInfo ***********");
+           } else if (value instanceof XMLMessage) {
+               XMLMessage xmlMessage = (XMLMessage)value;
+               //XMLStreamReader reader = SourceReaderFactory.createSourceReader(source, true);
+               //XMLStreamReaderUtil.nextElementContent(reader);
+               //decodeBodyContent(reader, request, messageInfo);
+           } else {
+               System.out.println("****** Unknown type in BodyBlock ***** "+value.getClass());
+           }
+       }
+   }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLEPTFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLEPTFactory.java
new file mode 100644
index 0000000..00ca611
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLEPTFactory.java
@@ -0,0 +1,38 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.xml;
+
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+
+/**
+ * Change the name of this class to JaxwsEPTFactory or something else. OR
+ * split into multiple factories.
+ */
+public interface XMLEPTFactory extends EPTFactory {
+    public InternalEncoder getInternalEncoder();
+    public XMLEncoder getXMLEncoder();
+    public XMLDecoder getXMLDecoder();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLEncoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLEncoder.java
new file mode 100644
index 0000000..f14b2d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLEncoder.java
@@ -0,0 +1,87 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.encoding.xml;
+import java.nio.ByteBuffer;
+import javax.xml.stream.XMLStreamWriter;
+
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBeanInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBTypeSerializer;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.server.ServerRtException;
+
+
+
+/**
+ * @author WS Development Team
+ */
+public class XMLEncoder implements Encoder {
+
+    /*
+     * @see com.sun.pept.encoding.Encoder#encodeAndSend(com.sun.pept.ept.MessageInfo)
+     */
+    public void encodeAndSend(MessageInfo messageInfo) {
+        throw new UnsupportedOperationException();
+    }
+
+    /*
+     * @see com.sun.pept.encoding.Encoder#encode(com.sun.pept.ept.MessageInfo)
+     */
+    public ByteBuffer encode(MessageInfo messageInfo) {
+        throw new UnsupportedOperationException();
+    }
+
+    public InternalMessage toInternalMessage(MessageInfo messageInfo) {
+        return null;
+    }
+
+    public XMLMessage toXMLMessage(InternalMessage internalMessage, MessageInfo messageInfo) {
+        return null;
+    }
+
+    /*
+     * Replace the body in SOAPMessage with the BodyBlock of InternalMessage
+     */
+    public XMLMessage toXMLMessage(InternalMessage internalMessage,
+            XMLMessage xmlMessage) {
+        try {
+            BodyBlock bodyBlock = internalMessage.getBody();
+            Object value = bodyBlock.getValue();
+            if (value == null) {
+                return xmlMessage;
+            }
+            if (value instanceof XMLMessage) {
+                return (XMLMessage)value;
+            } else {
+                throw new UnsupportedOperationException("Unknown object in BodyBlock:"+value.getClass());
+            }
+        } catch(Exception e) {
+            throw new ServerRtException("xmlencoder.err", new Object[]{e});
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLMessage.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLMessage.java
new file mode 100644
index 0000000..a2fa69d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/encoding/xml/XMLMessage.java
@@ -0,0 +1,1104 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.encoding.xml;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.MessagingException;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ContentType;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.InternetHeaders;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeBodyPart;
+import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeMultipart;
+import com.sun.xml.internal.messaging.saaj.util.ByteInputStream;
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBTypeSerializer;
+import com.sun.xml.internal.ws.protocol.xml.XMLMessageException;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.streaming.XMLStreamWriterFactory;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+import com.sun.xml.internal.ws.util.FastInfosetReflection;
+import com.sun.xml.internal.ws.util.FastInfosetUtil;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import java.io.BufferedInputStream;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Properties;
+import javax.activation.DataHandler;
+
+import javax.activation.DataSource;
+import javax.xml.bind.JAXBContext;
+import javax.xml.soap.MimeHeaders;
+import javax.xml.transform.OutputKeys;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.http.HTTPException;
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.util.logging.Logger;
+
+/**
+ *
+ * @author WS Developement Team
+ */
+public final class XMLMessage {
+
+    private static final Logger log = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".protocol.xml");
+
+    // So that SAAJ registers DCHs for MIME types
+    static {
+        new com.sun.xml.internal.messaging.saaj.soap.AttachmentPartImpl();
+    }
+
+    private static final int PLAIN_XML_FLAG      = 1;       // 00001
+    private static final int MIME_MULTIPART_FLAG = 2;       // 00010
+    private static final int FI_ENCODED_FLAG     = 16;      // 10000
+
+    private final DataRepresentation data;
+
+    /**
+     * Indicates when Fast Infoset should be used to serialize
+     * this message.
+     */
+    protected boolean useFastInfoset = false;
+
+    /**
+     * Construct a message from an input stream. When messages are
+     * received, there's two parts -- the transport headers and the
+     * message content in a transport specific stream.
+     */
+    public XMLMessage(MimeHeaders headers, final InputStream in) {
+        String ct = null;
+        if (headers != null) {
+            ct = getContentType(headers);
+        }
+        this.data = getData(ct, in);
+        // TODO should headers be set on the data?
+    }
+
+    /**
+     * Finds if the stream has some content or not
+     *
+     * @return null if there is no data
+     *         else stream to be used
+     */
+    private InputStream hasSomeData(InputStream in) throws IOException {
+        if (in != null) {
+            if (in.available() < 1) {
+                if (!in.markSupported()) {
+                    in = new BufferedInputStream(in);
+                }
+                in.mark(1);
+                if (in.read() != -1) {
+                    in.reset();
+                } else {
+                    in = null;          // No data
+                }
+            }
+        }
+        return in;
+    }
+
+    private DataRepresentation getData(final String ct, InputStream in) {
+        DataRepresentation data;
+        try {
+            in = hasSomeData(in);
+            if (in == null) {
+                return new NullContent();
+            }
+            if (ct != null) {
+                ContentType contentType = new ContentType(ct);
+                int contentTypeId = identifyContentType(contentType);
+                boolean isFastInfoset = (contentTypeId & FI_ENCODED_FLAG) > 0;
+                if ((contentTypeId & MIME_MULTIPART_FLAG) != 0) {
+                    data = new XMLMultiPart(ct, in, isFastInfoset);
+                } else if ((contentTypeId & PLAIN_XML_FLAG) != 0 || (contentTypeId & FI_ENCODED_FLAG) != 0) {
+                    data = new XMLSource(in, isFastInfoset);
+                } else {
+                    data = new UnknownContent(ct, in);
+                }
+            } else {
+                data = new NullContent();
+            }
+        } catch(Exception ex) {
+            throw new WebServiceException(ex);
+        }
+        return data;
+    }
+
+
+    public XMLMessage(Source source, boolean useFastInfoset) {
+        this.data = (source == null) ? new NullContent() : new XMLSource(source);
+        this.useFastInfoset = useFastInfoset;
+
+        this.data.getMimeHeaders().addHeader("Content-Type",
+            useFastInfoset ? "application/fastinfoset" : "text/xml");
+    }
+
+    public XMLMessage(Exception err, boolean useFastInfoset) {
+        this.data = new XMLErr(err);
+        this.useFastInfoset = useFastInfoset;
+
+        this.data.getMimeHeaders().addHeader("Content-Type",
+            useFastInfoset ? "application/fastinfoset" : "text/xml");
+    }
+
+    public XMLMessage(DataSource ds, boolean useFastInfoset) {
+        this.useFastInfoset = useFastInfoset;
+        try {
+            this.data = (ds == null) ? new NullContent() : getData(ds.getContentType(), ds.getInputStream());
+        } catch(IOException ioe) {
+            throw new WebServiceException(ioe);
+        }
+
+        String contentType = (ds != null) ? ds.getContentType() : null;
+        contentType =  (contentType == null) ? contentType = "text/xml": contentType;
+        this.data.getMimeHeaders().addHeader("Content-Type",
+            !useFastInfoset ? contentType
+                : contentType.replaceFirst("text/xml", "application/fastinfoset"));
+    }
+
+    public XMLMessage(Object object, JAXBContext context, boolean useFastInfoset) {
+        this.data = (object == null) ? new NullContent() : new XMLJaxb(object, context);
+        this.useFastInfoset = useFastInfoset;
+
+        this.data.getMimeHeaders().addHeader("Content-Type",
+            useFastInfoset ? "application/fastinfoset" : "text/xml");
+    }
+
+
+    public XMLMessage(Source source, Map<String, DataHandler> attachments, boolean useFastInfoset) {
+        if (attachments == null) {
+            this.data = (source == null) ? new NullContent() : new XMLSource(source);
+        } else {
+            if (source == null) {
+                this.data = new UnknownContent(attachments);
+            } else {
+                this.data = new XMLMultiPart(source, attachments, useFastInfoset);
+            }
+        }
+
+        this.useFastInfoset = useFastInfoset;
+        this.data.getMimeHeaders().addHeader("Content-Type",
+            useFastInfoset ? "application/fastinfoset" : "text/xml");
+    }
+
+    public XMLMessage(Object object, JAXBContext context, Map<String, DataHandler> attachments, boolean useFastInfoset) {
+        if (attachments == null) {
+            this.data = (object == null) ? new NullContent() : new XMLJaxb(object, context);
+        } else {
+            if (object == null) {
+                this.data = new UnknownContent(attachments);
+            } else {
+                this.data = new XMLMultiPart(JAXBTypeSerializer.serialize(object, context), attachments, useFastInfoset);
+            }
+        }
+
+        this.useFastInfoset = useFastInfoset;
+        this.data.getMimeHeaders().addHeader("Content-Type",
+            useFastInfoset ? "application/fastinfoset" : "text/xml");
+    }
+
+    /**
+     * Returns true if the underlying encoding of this message is FI.
+     */
+    public boolean isFastInfoset() {
+        return data.isFastInfoset();
+    }
+
+    /**
+     * Returns true if the FI encoding should be used.
+     */
+    public boolean useFastInfoset() {
+        return useFastInfoset;
+    }
+
+    /**
+     * Returns true if the sender of this message accepts FI. Slow, but
+     * should only be called once.
+     */
+    public boolean acceptFastInfoset() {
+        return FastInfosetUtil.isFastInfosetAccepted(getMimeHeaders().getHeader("Accept"));
+    }
+
+    public Source getSource() {
+        return data.getSource();
+    }
+
+    public DataSource getDataSource() {
+        return data.getDataSource();
+    }
+
+    /**
+     * Verify a contentType.
+     *
+     * @return
+     * MIME_MULTIPART_FLAG | PLAIN_XML_FLAG
+     * MIME_MULTIPART_FLAG | FI_ENCODED_FLAG;
+     * PLAIN_XML_FLAG
+     * FI_ENCODED_FLAG
+     *
+     */
+    private static int identifyContentType(ContentType contentType) {
+        String primary = contentType.getPrimaryType();
+        String sub = contentType.getSubType();
+
+        if (primary.equalsIgnoreCase("multipart") && sub.equalsIgnoreCase("related")) {
+            String type = contentType.getParameter("type");
+            if (type != null) {
+                if (isXMLType(type)) {
+                    return MIME_MULTIPART_FLAG | PLAIN_XML_FLAG;
+                } else if (isFastInfosetType(type)) {
+                    return MIME_MULTIPART_FLAG | FI_ENCODED_FLAG;
+                }
+            }
+            return 0;
+        } else if (isXMLType(primary, sub)) {
+            return PLAIN_XML_FLAG;
+        } else if (isFastInfosetType(primary, sub)) {
+            return FI_ENCODED_FLAG;
+        }
+        return 0;
+    }
+
+    protected static boolean isXMLType(String primary, String sub) {
+        return (primary.equalsIgnoreCase("text") || primary.equalsIgnoreCase("application")) && sub.equalsIgnoreCase("xml");
+    }
+
+    protected static boolean isXMLType(String type) {
+        return type.toLowerCase().startsWith("text/xml") ||
+            type.toLowerCase().startsWith("application/xml");
+    }
+
+    protected static boolean isFastInfosetType(String primary, String sub) {
+        return primary.equalsIgnoreCase("application") && sub.equalsIgnoreCase("fastinfoset");
+    }
+
+    protected static boolean isFastInfosetType(String type) {
+        return type.toLowerCase().startsWith("application/fastinfoset");
+    }
+
+    /**
+     * Ideally this should be called just before writing the message
+     */
+    public MimeHeaders getMimeHeaders() {
+        return data.getMimeHeaders();
+    }
+
+    private static String getContentType(MimeHeaders headers) {
+        String[] values = headers.getHeader("Content-Type");
+        return (values == null) ? null : values[0];
+    }
+
+    public int getStatus() {
+        return data.getStatus();
+    }
+
+    public void writeTo(OutputStream out) throws IOException {
+        data.writeTo(out,useFastInfoset);
+    }
+
+    public Source getPayload() {
+        return data.getPayload();
+    }
+
+    public Map<String, DataHandler> getAttachments() {
+        return data.getAttachments();
+    }
+
+    public Object getPayload(JAXBContext context) {
+        // Get a copy of Source using getPayload() and use it to deserialize
+        // to JAXB object
+        return JAXBTypeSerializer.deserialize(getPayload(), context);
+    }
+
+    /**
+     * Defines operations available regardless of the actual in-memory data representation.
+     */
+    private static abstract class DataRepresentation {
+        /**
+         * Can be called multiple times. Typically from XMLLogicalMessageImpl
+         */
+        abstract Source getPayload();
+
+        /**
+         * Should be called only once. Once this is called, don't use this object anymore
+         */
+        abstract void writeTo(OutputStream out,boolean useFastInfoset) throws IOException;
+        /**
+         * Returns true whenever the underlying representation of this message
+         * is a Fast Infoset stream.
+         */
+        abstract boolean isFastInfoset();
+
+        /**
+         * Should be called only once. Once this is called, don't use this object anymore
+         */
+        abstract Source getSource();
+
+        /**
+         * Should be called only once. Once this is called, don't use this object anymore
+         */
+        abstract DataSource getDataSource();
+
+        /**
+         * Should be called only once. Once this is called, don't use this object anymore
+         */
+        abstract Map<String, DataHandler> getAttachments();
+
+        /**
+         * Should contain Content-Type for this message.
+         */
+        abstract MimeHeaders getMimeHeaders();
+        int getStatus() {
+            return WSConnection.OK;
+        }
+    }
+
+
+    /**
+     * Data represented as a multi-part MIME message. It also has XML as
+     * root part
+     *
+     * This class parses {@link MimeMultipart} lazily.
+     */
+    private static final class XMLMultiPart extends DataRepresentation {
+        private DataSource dataSource;
+        private MimeMultipart multipart;
+        private XMLSource xmlSource;
+        private boolean isFastInfoset;
+        private final MimeHeaders headers = new MimeHeaders();
+
+        public XMLMultiPart(final String contentType, final InputStream is, boolean isFastInfoset) {
+            this.isFastInfoset = isFastInfoset;
+            dataSource = new DataSource() {
+                public InputStream getInputStream() {
+                    return is;
+                }
+
+                public OutputStream getOutputStream() {
+                    return null;
+                }
+
+                public String getContentType() {
+                    return contentType;
+                }
+
+                public String getName() {
+                    return "";
+                }
+            };
+        }
+
+        public XMLMultiPart(Source source, final Map<String, DataHandler> atts, boolean isFastInfoset) {
+            this.isFastInfoset = isFastInfoset;
+            multipart = new MimeMultipart("related");
+            multipart.getContentType().setParameter("type", "text/xml");
+
+            // Creates Primary part
+            ByteOutputStream bos = new ByteOutputStream();
+            new XMLSource(source).writeTo(bos, isFastInfoset);
+            InternetHeaders headers = new InternetHeaders();
+            headers.addHeader("Content-Type",
+                isFastInfoset ? "application/fastinfoset" : "text/xml");
+            MimeBodyPart rootPart = new MimeBodyPart(headers, bos.getBytes(),bos.getCount());
+            multipart.addBodyPart(rootPart, 0);
+
+            for(Map.Entry<String, DataHandler> e : atts.entrySet()) {
+                MimeBodyPart part = new MimeBodyPart();
+                part.setDataHandler(e.getValue());
+                multipart.addBodyPart(part);
+            }
+        }
+
+        public XMLMultiPart(DataSource dataSource, boolean isFastInfoset) {
+            this.dataSource = dataSource;
+            this.isFastInfoset = isFastInfoset;
+        }
+
+        public boolean isFastInfoset() {
+            return isFastInfoset;
+        }
+
+        public DataSource getDataSource() {
+            if (dataSource != null) {
+                return dataSource;
+            }
+            else if (multipart != null) {
+                return new DataSource() {
+                    public InputStream getInputStream() {
+                        try {
+                            if (xmlSource != null) {
+                                replaceRootPart(false);
+                            }
+                            ByteOutputStream bos = new ByteOutputStream();
+                            multipart.writeTo(bos);
+                            return bos.newInputStream();
+                        } catch(MessagingException me) {
+                            throw new XMLMessageException("xml.get.ds.err",me);
+                        } catch(IOException ioe) {
+                            throw new XMLMessageException("xml.get.ds.err",ioe);
+                        }
+                    }
+
+                    public OutputStream getOutputStream() {
+                        return null;
+                    }
+
+                    public String getContentType() {
+                        return multipart.getContentType().toString();
+                    }
+
+                    public String getName() {
+                        return "";
+                    }
+                };
+            }
+            return null;
+        }
+
+        private MimeBodyPart getRootPart() {
+            try {
+                convertToMultipart();
+                ContentType contentType = multipart.getContentType();
+                String startParam = contentType.getParameter("start");
+                MimeBodyPart sourcePart = (startParam == null)
+                    ? (MimeBodyPart)multipart.getBodyPart(0)
+                    : (MimeBodyPart)multipart.getBodyPart(startParam);
+                return sourcePart;
+            }
+            catch (MessagingException ex) {
+                throw new XMLMessageException("xml.get.source.err",ex);
+            }
+        }
+
+        private void replaceRootPart(boolean useFastInfoset) {
+            if (xmlSource == null) {
+                return;
+            }
+            try {
+                MimeBodyPart sourcePart = getRootPart();
+                String ctype = sourcePart.getContentType();
+                multipart.removeBodyPart(sourcePart);
+
+                ByteOutputStream bos = new ByteOutputStream();
+                xmlSource.writeTo(bos, useFastInfoset);
+                InternetHeaders headers = new InternetHeaders();
+                headers.addHeader("Content-Type",
+                    useFastInfoset ? "application/fastinfoset" : ctype);
+
+                sourcePart = new MimeBodyPart(headers, bos.getBytes(),bos.getCount());
+                multipart.addBodyPart(sourcePart, 0);
+            }
+            catch (MessagingException ex) {
+                throw new XMLMessageException("xml.get.source.err",ex);
+            }
+        }
+
+        private void convertToMultipart() {
+            if (dataSource != null) {
+                try {
+                    multipart = new MimeMultipart(dataSource,null);
+                    dataSource = null;
+                } catch (MessagingException ex) {
+                    throw new XMLMessageException("xml.get.source.err",ex);
+                }
+            }
+        }
+
+        /**
+         * Returns root part of the MIME message
+         */
+        public Source getSource() {
+            try {
+                // If there is an XMLSource, return that
+                if (xmlSource != null) {
+                    return xmlSource.getPayload();
+                }
+
+                // Otherwise, parse MIME package and find root part
+                convertToMultipart();
+                MimeBodyPart sourcePart = getRootPart();
+                ContentType ctype = new ContentType(sourcePart.getContentType());
+                String baseType = ctype.getBaseType();
+
+                // Return a StreamSource or FastInfosetSource depending on type
+                if (isXMLType(baseType)) {
+                    return new StreamSource(sourcePart.getInputStream());
+                }
+                else if (isFastInfosetType(baseType)) {
+                    return FastInfosetReflection.FastInfosetSource_new(
+                        sourcePart.getInputStream());
+                }
+                else {
+                    throw new XMLMessageException(
+                            "xml.root.part.invalid.Content-Type",
+                            new Object[] {baseType});
+                }
+            } catch (MessagingException ex) {
+                throw new XMLMessageException("xml.get.source.err",ex);
+            } catch (Exception ioe) {
+                throw new XMLMessageException("xml.get.source.err",ioe);
+            }
+        }
+
+        public Source getPayload() {
+            return getSource();
+        }
+
+        public void writeTo(OutputStream out, boolean useFastInfoset) {
+            try {
+                // If a source has been set, ensure MIME parsing
+                if (xmlSource != null) {
+                    convertToMultipart();
+                }
+
+                // Try to use dataSource whenever possible
+                if (dataSource != null) {
+                    // If already encoded correctly, just copy the bytes
+                    if (isFastInfoset == useFastInfoset) {
+                        InputStream is = dataSource.getInputStream();
+                        byte[] buf = new byte[1024];
+                        int len;
+                        while ((len = is.read(buf)) != -1) {
+                            out.write(buf, 0, len);
+                        }
+                        return;     // we're done
+                    }
+                    else {
+                        // Parse MIME and create source for root part
+                        xmlSource = new XMLSource(getSource());
+                    }
+                }
+
+                // Finally, possibly re-encode root part and write it out
+                replaceRootPart(useFastInfoset);
+                multipart.writeTo(out);
+            }
+            catch(Exception e) {
+                throw new WebServiceException(e);
+            }
+        }
+
+        public Map<String, DataHandler> getAttachments() {
+            // If a source has been set, ensure MIME parsing
+            if (xmlSource != null) {
+                convertToMultipart();
+            }
+            try {
+                MimeBodyPart rootPart = getRootPart();
+                Map<String, DataHandler> map = new HashMap<String, DataHandler>();
+                int count = multipart.getCount();
+                for(int i=0; i < count; i++) {
+                    MimeBodyPart part = multipart.getBodyPart(i);
+                    if (part != rootPart) {
+                        map.put(part.getContentID(), part.getDataHandler());
+                    }
+                }
+                return map;
+            } catch (MessagingException ex) {
+                throw new XMLMessageException("xml.get.source.err",ex);
+            }
+        }
+
+        MimeHeaders getMimeHeaders() {
+            headers.removeHeader("Content-Type");
+            if (dataSource != null) {
+                headers.addHeader("Content-Type", dataSource.getContentType());
+            } else {
+                if (multipart != null ) {
+                    headers.addHeader("Content-Type", multipart.getContentType().toString());
+                }
+            }
+            return headers;
+        }
+
+    }
+
+    /**
+     * Data represented as {@link Source}.
+     */
+    public static class XMLSource extends DataRepresentation {
+
+        private Source source;
+        private boolean isFastInfoset;
+        private final MimeHeaders headers = new MimeHeaders();
+
+        public XMLSource(InputStream in, boolean isFastInfoset) throws Exception {
+            this.source = isFastInfoset ?
+                FastInfosetReflection.FastInfosetSource_new(in)
+                : new StreamSource(in);
+            this.isFastInfoset = isFastInfoset;
+        }
+
+        public XMLSource(Source source) {
+            this.source = source;
+            this.isFastInfoset =
+                ((source != null)?(source.getClass() == FastInfosetReflection.fiFastInfosetSource):false);
+        }
+
+        public boolean isFastInfoset() {
+           return isFastInfoset;
+        }
+
+        /*
+         * If there is a ByteInputStream available, then write it to the output
+         * stream. Otherwise, use Transformer to write Source to output stream.
+         */
+        public void writeTo(OutputStream out, boolean useFastInfoset) {
+            try {
+                InputStream is = null;
+                boolean canAvoidTransform = false;
+                if (source instanceof StreamSource) {
+                    is = ((StreamSource)source).getInputStream();
+                    // If use of FI is requested, need to transcode
+                    canAvoidTransform = !useFastInfoset;
+                }
+                else if (source.getClass() == FastInfosetReflection.fiFastInfosetSource) {
+                    is = FastInfosetReflection.FastInfosetSource_getInputStream(source);
+                    // If use of FI is not requested, need to transcode
+                    canAvoidTransform = useFastInfoset;
+                }
+
+                if (canAvoidTransform && is != null && is instanceof ByteInputStream) {
+                    ByteInputStream bis = (ByteInputStream)is;
+                    // Reset the stream
+                    byte[] buf = bis.getBytes();
+                    out.write(buf);
+                    bis.close();
+                    return;
+                }
+
+                // TODO: Use an efficient transformer from SAAJ that knows how to optimally
+                // write to FI results
+                Transformer transformer = XmlUtil.newTransformer();
+                transformer.transform(source,
+                    useFastInfoset ? FastInfosetReflection.FastInfosetResult_new(out)
+                                   : new StreamResult(out));
+            }
+            catch (Exception e) {
+                throw new WebServiceException(e);
+            }
+        }
+
+        public Source getSource() {
+            return source;
+        }
+
+        DataSource getDataSource() {
+            return new DataSource() {
+                public InputStream getInputStream() {
+                    try {
+                        InputStream is = null;
+                        if (source instanceof StreamSource) {
+                            is = ((StreamSource)source).getInputStream();
+                        } else if (source.getClass() == FastInfosetReflection.fiFastInfosetSource) {
+                            is = FastInfosetReflection.FastInfosetSource_getInputStream(source);
+                        }
+                        if (is != null) {
+                            return is;
+                        }
+                        // Copy source to result respecting desired encoding
+                        ByteArrayBuffer bab = new ByteArrayBuffer();
+                        Transformer transformer = XmlUtil.newTransformer();
+                        transformer.transform(source, isFastInfoset() ?
+                            FastInfosetReflection.FastInfosetResult_new(bab)
+                            : new StreamResult(bab));
+                        bab.close();
+                        return bab.newInputStream();
+                    } catch(Exception e) {
+                        throw new WebServiceException(e);
+                    }
+                }
+
+                public OutputStream getOutputStream() {
+                    return null;
+                }
+
+                public String getContentType() {
+                    return isFastInfoset() ? "application/fastinfoset" : "text/xml";
+                }
+
+                public String getName() {
+                    return "";
+                }
+            };
+
+        }
+
+        /*
+        * Usually called from logical handler
+        * If there is a DOMSource, return that. Otherwise, return a copy of
+        * the existing source.
+        */
+        public Source getPayload() {
+            try {
+
+                if (source instanceof DOMSource) {
+                    return source;
+                }
+
+                InputStream is = null;
+
+                if (source instanceof StreamSource) {
+                    is = ((StreamSource)source).getInputStream();
+                }
+                else if (source.getClass() == FastInfosetReflection.fiFastInfosetSource) {
+                    is = FastInfosetReflection.FastInfosetSource_getInputStream(source);
+                }
+
+                if (is != null && is instanceof ByteInputStream) {
+                    ByteInputStream bis = (ByteInputStream)is;
+                                  // Reset the stream
+                    byte[] buf = bis.getBytes();
+
+                    ByteArrayInputStream bais = new ByteArrayInputStream(buf);
+                     bis.close();
+                    return isFastInfoset ?
+                        FastInfosetReflection.FastInfosetSource_new(is)
+                    : new StreamSource(bais);
+
+                }
+
+                // Copy source to result respecting desired encoding
+                ByteArrayBuffer bab = new ByteArrayBuffer();
+                Transformer transformer = XmlUtil.newTransformer();
+                // Adding this to work with empty source. Is it JAXP bug ?
+                Properties oprops = new Properties();
+                oprops.put(OutputKeys.OMIT_XML_DECLARATION, "yes");
+                transformer.setOutputProperties(oprops);
+                transformer.transform(source, isFastInfoset ?
+                    FastInfosetReflection.FastInfosetResult_new(bab)
+                    : new StreamResult(bab));
+                bab.close();
+
+                // Set internal source
+                InputStream bis = (bab.size() == 0) ? null : bab.newInputStream();
+                source = isFastInfoset ?
+                    FastInfosetReflection.FastInfosetSource_new(bis)
+                    : new StreamSource(bis);
+
+                // Return fresh source back to handler
+                bis = bab.newInputStream();
+                return isFastInfoset ?
+                    FastInfosetReflection.FastInfosetSource_new(bis)
+                    : new StreamSource(bis);
+            }
+            catch (Exception e) {
+                throw new WebServiceException(e);
+            }
+        }
+
+        public Map<String, DataHandler> getAttachments() {
+            return null;
+        }
+
+        MimeHeaders getMimeHeaders() {
+            return headers;
+        }
+
+    }
+
+    /**
+     * Data represented as a JAXB object.
+     */
+    public static class XMLJaxb extends DataRepresentation {
+        private final Object object;
+        private final JAXBContext jaxbContext;
+        private final MimeHeaders headers = new MimeHeaders();
+
+        public XMLJaxb(Object object, JAXBContext jaxbContext) {
+            this.object = object;
+            this.jaxbContext = jaxbContext;
+        }
+
+        public void writeTo(OutputStream out, boolean useFastInfoset) {
+            if (useFastInfoset) {
+                JAXBTypeSerializer.serializeDocument(object,
+                    XMLStreamWriterFactory.createFIStreamWriter(out),
+                    jaxbContext);
+            }
+            else {
+                JAXBTypeSerializer.serialize(object, out, jaxbContext);
+            }
+        }
+
+        boolean isFastInfoset() {
+            return false;
+        }
+
+        public Source getSource() {
+            return JAXBTypeSerializer.serialize(object, jaxbContext);
+        }
+
+        DataSource getDataSource() {
+            return new DataSource() {
+                public InputStream getInputStream() {
+                    ByteOutputStream bos = new ByteOutputStream();
+                    JAXBTypeSerializer.serialize(object, bos, jaxbContext);
+                    return bos.newInputStream();
+                }
+
+                public OutputStream getOutputStream() {
+                    return null;
+                }
+
+                public String getContentType() {
+                    return isFastInfoset() ? "application/fastinfoset" : "text/xml";
+                }
+
+                public String getName() {
+                    return "";
+                }
+            };
+        }
+
+        /*
+        * Usually called from logical handler
+        * If there is a DOMSource, return that. Otherwise, return a copy of
+        * the existing source.
+        */
+        public Source getPayload() {
+            return getSource();
+        }
+
+        public Map<String, DataHandler> getAttachments() {
+            return null;
+        }
+
+        MimeHeaders getMimeHeaders() {
+            return headers;
+        }
+
+    }
+
+
+    /**
+     * Don't know about this content. It's conent-type is NOT the XML types
+     * we recognize(text/xml, application/xml, multipart/related;text/xml etc).
+     *
+     * This could be used to represent image/jpeg etc
+     */
+    public static class UnknownContent extends DataRepresentation {
+        private final String ct;
+        private final InputStream in;
+        private final MimeMultipart multipart;
+        private final MimeHeaders headers = new MimeHeaders();
+
+        public UnknownContent(String ct, InputStream in) {
+            this.ct = ct;
+            this.in = in;
+            this.multipart = null;
+        }
+
+        public UnknownContent(Map<String, DataHandler> atts) {
+            this.in = null;
+            multipart = new MimeMultipart("mixed");
+            for(Map.Entry<String, DataHandler> e : atts.entrySet()) {
+                MimeBodyPart part = new MimeBodyPart();
+                part.setDataHandler(e.getValue());
+                multipart.addBodyPart(part);
+            }
+            this.ct = multipart.getContentType().toString();
+        }
+
+        public void writeTo(OutputStream out, boolean useFastInfoset) {
+            try {
+                if (multipart != null) {
+                    multipart.writeTo(out);
+                }
+                byte[] buf = new byte[1024];
+                int len;
+                while ((len = in.read(buf)) != -1) {
+                    out.write(buf, 0, len);
+                }
+            } catch (Exception ex) {
+                throw new WebServiceException(ex);
+            }
+        }
+
+        boolean isFastInfoset() {
+            return false;
+        }
+
+        /**
+         * NO XML content so return null
+         */
+        public Source getSource() {
+            return null;
+        }
+
+        DataSource getDataSource() {
+            return new DataSource() {
+                public InputStream getInputStream() {
+                    if (multipart != null) {
+                        try {
+                            ByteOutputStream bos = new ByteOutputStream();
+                            multipart.writeTo(bos);
+                            return bos.newInputStream();
+                        } catch(Exception ioe) {
+                            throw new WebServiceException(ioe);
+                        }
+                    }
+                    return in;
+                }
+
+                public OutputStream getOutputStream() {
+                    return null;
+                }
+
+                public String getContentType() {
+                    assert ct != null;
+                    return ct;
+                }
+
+                public String getName() {
+                    return "";
+                }
+            };
+        }
+
+        /**
+         * NO XML content so return null
+         */
+        public Source getPayload() {
+            return null;
+        }
+
+        /**
+         * JAXWS doesn't know about this conent. So we treate the whole content
+         * as one payload.
+         */
+        public Map<String, DataHandler> getAttachments() {
+            return null;
+        }
+
+        MimeHeaders getMimeHeaders() {
+            headers.removeHeader("Content-Type");
+            headers.addHeader("Content-Type", ct);
+            return headers;
+        }
+
+    }
+
+    /**
+     * Represents HTTPException or anyother exception
+     */
+    private static final class XMLErr extends DataRepresentation {
+        private final Exception err;
+        private final MimeHeaders headers = new MimeHeaders();
+
+        XMLErr(Exception err) {
+            this.err = err;
+        }
+
+        public Source getPayload() {
+            return null;
+        }
+
+        public Map<String, DataHandler> getAttachments() {
+            return null;
+        }
+
+        public void writeTo(OutputStream out, boolean useFastInfoset) throws IOException {
+            String msg = err.getMessage();
+            if (msg == null) {
+                msg = err.toString();
+            }
+            msg = "<err>"+msg+"</err>";
+
+            if (useFastInfoset) {
+                FastInfosetUtil.transcodeXMLStringToFI(msg, out);
+            } else {
+                out.write(msg.getBytes());
+            }
+        }
+
+        boolean isFastInfoset() {
+            return false;
+        }
+
+        Source getSource() {
+            return null;
+        }
+
+        DataSource getDataSource() {
+            return null;
+        }
+
+        @Override
+        int getStatus() {
+            if (err instanceof HTTPException) {
+                return ((HTTPException)err).getStatusCode();
+            }
+            return WSConnection.INTERNAL_ERR;
+        }
+
+        MimeHeaders getMimeHeaders() {
+            return headers;
+        }
+    }
+
+
+    /**
+     * There is no content to write.
+     */
+    private static final class NullContent extends DataRepresentation {
+        private final MimeHeaders headers = new MimeHeaders();
+
+        public Source getPayload() {
+            return null;
+        }
+
+        public Map<String, DataHandler> getAttachments() {
+            return null;
+        }
+
+        public void writeTo(OutputStream out, boolean useFastInfoset) throws IOException {
+            // Nothing to do
+        }
+
+        boolean isFastInfoset() {
+            return false;
+        }
+
+        Source getSource() {
+            return null;
+        }
+
+        DataSource getDataSource() {
+            return null;
+        }
+
+        MimeHeaders getMimeHeaders() {
+            return headers;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerChainCaller.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerChainCaller.java
new file mode 100644
index 0000000..224a329
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerChainCaller.java
@@ -0,0 +1,1064 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import javax.xml.namespace.QName;
+import javax.xml.soap.SOAPBody;
+import javax.xml.soap.SOAPEnvelope;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPFault;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.ws.LogicalMessage;
+import javax.xml.ws.ProtocolException;
+import javax.xml.ws.handler.Handler;
+import javax.xml.ws.handler.LogicalHandler;
+import javax.xml.ws.handler.LogicalMessageContext;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.handler.soap.SOAPHandler;
+import javax.xml.ws.handler.soap.SOAPMessageContext;
+import javax.xml.ws.http.HTTPException;
+import javax.xml.ws.soap.SOAPFaultException;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAP12Constants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+
+/**
+ * The class stores the actual "chain" of handlers that is called
+ * during a request or response. On the client side, it is created
+ * by a {@link com.sun.xml.internal.ws.binding.BindingImpl} class when a
+ * binding provider is created. On the server side, where a Binding
+ * object may be passed from an outside source, the handler chain
+ * caller may be created by the message dispatcher classes.
+ *
+ * <p>When created, a java.util.List of Handlers is passed in. This list
+ * is sorted into logical and protocol handlers, so the handler order
+ * that is returned from getHandlerChain() may be different from the
+ * original that was passed in.
+ *
+ * <p>At runtime, one of the callHandlers() methods is invoked by the
+ * soap or xml message dispatchers, passing in a {@link HandlerContext}
+ * or {@link XMLHandlerContext} object along with other information
+ * about the current message that is required for proper handler flow.
+ *
+ * <p>Exceptions are logged in many cases here before being rethrown. This
+ * is to help primarily with server side handlers.
+ *
+ * <p>Currently, the handler chain caller checks for a null soap
+ * message context to see if the binding in use is XML/HTTP.
+ *
+ * @see com.sun.xml.internal.ws.binding.BindingImpl
+ * @see com.sun.xml.internal.ws.protocol.soap.client.SOAPMessageDispatcher
+ * @see com.sun.xml.internal.ws.protocol.soap.server.SOAPMessageDispatcher
+ * @see com.sun.xml.internal.ws.protocol.xml.server.XMLMessageDispatcher
+ *
+ * @author WS Development Team
+ */
+public class HandlerChainCaller {
+
+    public static final String HANDLER_CHAIN_CALLER = "handler_chain_caller";
+    public static final String IGNORE_FAULT_PROPERTY =
+        "ignore fault in message";
+
+    private static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".handler");
+
+    // need request or response for Handle interface
+    public enum RequestOrResponse { REQUEST, RESPONSE }
+    public enum Direction { OUTBOUND, INBOUND }
+
+    private Set<QName> understoodHeaders;
+    private List<Handler> handlers; // may be logical/soap mixed
+
+    private List<LogicalHandler> logicalHandlers;
+    private List<SOAPHandler> soapHandlers;
+
+    private Set<String> roles;
+
+    /**
+     * The handlers that are passed in will be sorted into
+     * logical and soap handlers. During this sorting, the
+     * understood headers are also obtained from any soap
+     * handlers.
+     *
+     * @param chain A list of handler objects, which can
+     * be protocol or logical handlers.
+     */
+    public HandlerChainCaller(List<Handler> chain) {
+        if (chain == null) { // should only happen in testing
+            chain = new ArrayList<Handler>();
+        }
+        handlers = chain;
+        logicalHandlers = new ArrayList<LogicalHandler>();
+        soapHandlers = new ArrayList<SOAPHandler>();
+        understoodHeaders = new HashSet<QName>();
+        sortHandlers();
+    }
+
+    /**
+     * This list may be different than the chain that is passed
+     * in since the logical and protocol handlers must be separated.
+     *
+     * @return The list of handlers, sorted by logical and then protocol.
+     */
+    public List<Handler> getHandlerChain() {
+        return handlers;
+    }
+
+    public boolean hasHandlers() {
+        return (handlers.size() != 0);
+    }
+
+    /**
+     * These are set by the SOAPBindingImpl when it creates the
+     * HandlerChainCaller or when new roles are set on the binding.
+     *
+     * @param roles A set of roles strings.
+     */
+    public void setRoles(Set<String> roles) {
+        this.roles = roles;
+    }
+
+    /**
+     * Returns the roles that were passed in by the binding
+     * in the case of soap binding.
+     */
+    public Set<String> getRoles() {
+        return roles;
+    }
+
+    /**
+     * Returns the headers understood by the handlers. This set
+     * is created when the handler chain caller is instantiated and
+     * the handlers are sorted. The set is comprised of headers
+     * returned from SOAPHandler.getHeaders() method calls.
+     *
+     * @return The set of all headers that the handlers declare
+     * that they understand.
+     */
+    public Set<QName> getUnderstoodHeaders() {
+        return understoodHeaders;
+    }
+
+    /**
+     * This method separates the logical and protocol handlers. When
+     * this method returns, the original "handlers" List has been
+     * resorted.
+     */
+    private void sortHandlers() {
+        for (Handler handler : handlers) {
+            if (LogicalHandler.class.isAssignableFrom(handler.getClass())) {
+                logicalHandlers.add((LogicalHandler) handler);
+            } else if (SOAPHandler.class.isAssignableFrom(handler.getClass())) {
+                soapHandlers.add((SOAPHandler) handler);
+                Set<QName> headers = ((SOAPHandler) handler).getHeaders();
+                if (headers != null) {
+                    understoodHeaders.addAll(headers);
+                }
+            } else if (Handler.class.isAssignableFrom(handler.getClass())) {
+                throw new HandlerException(
+                    "cannot.extend.handler.directly",
+                    handler.getClass().toString());
+            } else {
+                throw new HandlerException("handler.not.valid.type",
+                    handler.getClass().toString());
+            }
+        }
+        handlers.clear();
+        handlers.addAll(logicalHandlers);
+        handlers.addAll(soapHandlers);
+    }
+
+    /**
+     * Replace the message in the given message context with a
+     * fault message. If the context already contains a fault
+     * message, then return without changing it.
+     * Also sets the HTTP_RESPONSE_CODE in the context on Server-side.
+     */
+    private void insertFaultMessage(ContextHolder holder,
+        ProtocolException exception) {
+        try {
+            SOAPMessageContext context = holder.getSMC();
+            if (context == null) { // non-soap case
+                LogicalMessageContext lmc = holder.getLMC();
+                LogicalMessage msg = lmc.getMessage();
+                if (msg != null) {
+                    msg.setPayload(null);
+                }
+                //Set Status Code only if it is on server
+                if((Boolean)lmc.get(MessageContext.MESSAGE_OUTBOUND_PROPERTY)){
+                    if (exception instanceof HTTPException) {
+                        lmc.put(MessageContext.HTTP_RESPONSE_CODE,((HTTPException)exception).getStatusCode());
+                    } else {
+                        lmc.put(MessageContext.HTTP_RESPONSE_CODE,WSConnection.INTERNAL_ERR);
+                    }
+                }
+                return;
+            }
+            //Set Status Code only if it is on server
+            if((Boolean)context.get(MessageContext.MESSAGE_OUTBOUND_PROPERTY)){
+                context.put(MessageContext.HTTP_RESPONSE_CODE,WSConnection.INTERNAL_ERR);
+            }
+            SOAPMessage message = context.getMessage();
+            SOAPEnvelope envelope = message.getSOAPPart().getEnvelope();
+            SOAPBody body = envelope.getBody();
+            if (body.hasFault()) {
+                return;
+            }
+            if (envelope.getHeader() != null) {
+                envelope.getHeader().detachNode();
+            }
+
+            body.removeContents();
+            SOAPFault fault = body.addFault();
+            String envelopeNamespace = envelope.getNamespaceURI();
+
+            if (exception instanceof SOAPFaultException) {
+                SOAPFaultException sfe = (SOAPFaultException) exception;
+                SOAPFault userFault = sfe.getFault();
+
+                QName faultCode = userFault.getFaultCodeAsQName();
+                if (faultCode == null) {
+                    faultCode = determineFaultCode(context);
+                }
+                fault.setFaultCode(faultCode);
+
+                String faultString = userFault.getFaultString();
+                if (faultString == null) {
+                    if (sfe.getMessage() != null) {
+                        faultString = sfe.getMessage();
+                    } else {
+                        faultString = sfe.toString();
+                    }
+                }
+                fault.setFaultString(faultString);
+
+                String faultActor = userFault.getFaultActor();
+                if (faultActor == null) {
+                    faultActor = "";
+                }
+                fault.setFaultActor(faultActor);
+
+                if (userFault.getDetail() != null) {
+                    fault.addChildElement(userFault.getDetail());
+                }
+            } else {
+                fault.setFaultCode(determineFaultCode(context));
+                if (exception.getMessage() != null) {
+                    fault.setFaultString(exception.getMessage());
+                } else {
+                    fault.setFaultString(exception.toString());
+                }
+            }
+        } catch (Exception e) {
+            // severe since this is from runtime and not handler
+            logger.log(Level.SEVERE,
+                "exception while creating fault message in handler chain", e);
+            throw new RuntimeException(e);
+        }
+    }
+
+
+
+    /**
+     * <p>The expectation of the rest of the code is that,
+     * if a ProtocolException is thrown from the handler chain,
+     * the message contents reflect the protocol exception.
+     * However, if a new ProtocolException is thrown from
+     * the handleFault method, then the fault should be
+     * ignored and the new exception should be dispatched.
+     *
+     * <p>This method simply sets a property that is checked
+     * by the client and server code when a ProtocolException
+     * is caught. The property can be checked with
+     * {@link MessageContextUtil#ignoreFaultInMessage}
+     */
+    private void addIgnoreFaultProperty(ContextHolder holder) {
+        LogicalMessageContext context = holder.getLMC();
+        context.put(IGNORE_FAULT_PROPERTY, Boolean.TRUE);
+    }
+
+    /**
+     * <p>Figure out if the fault code local part is client,
+     * server, sender, receiver, etc. This is called by
+     * insertFaultMessage.
+     *
+     * <p>This method should only be called when there is a ProtocolException
+     * during request. Reverse the Message direction first,
+     * So this method can use the MESSAGE_OUTBOUND_PROPERTY
+     * to determine whether it is being called on the client
+     * or the server side. If this changes in the spec, then
+     * something else will need to be passed to the method
+     * to determine whether the fault code is client or server.
+     *
+     * <p>For determining soap version, start checking with the
+     * latest version and default to soap 1.1.
+     */
+    private QName determineFaultCode(SOAPMessageContext context)
+        throws SOAPException {
+
+        SOAPEnvelope envelope =
+            context.getMessage().getSOAPPart().getEnvelope();
+        String uri = envelope.getNamespaceURI();
+
+        // client case
+        if (!(Boolean) context.get(
+            MessageContext.MESSAGE_OUTBOUND_PROPERTY)) {
+            if (uri.equals(SOAP12NamespaceConstants.ENVELOPE)) {
+                return SOAP12Constants.FAULT_CODE_CLIENT;
+            }
+            return SOAPConstants.FAULT_CODE_CLIENT;
+        }
+
+        //server case
+        if (uri.equals(SOAP12NamespaceConstants.ENVELOPE)) {
+            return SOAP12Constants.FAULT_CODE_SERVER;
+        }
+        return SOAPConstants.FAULT_CODE_SERVER;
+    }
+
+    /**
+     * <p>Method used to call handlers with a HandlerContext that
+     * may contain logical and protocol handlers. This is the
+     * main entry point for calling the handlers in the case
+     * of SOAP binding. Before calling the handlers, the
+     * handler chain caller will set the outbound property and
+     * the roles on the message context.
+     *
+     * <p>Besides the context object passed in, the other information
+     * is used to control handler execution and closing. See the
+     * handler section of the spec for the rules concering handlers
+     * returning false, throwing exceptions, etc.
+     *
+     * @param direction Inbound or outbound.
+     * @param messageType Request or response.
+     * @param context A soap handler context containing the message.
+     * @param responseExpected A boolean indicating whether or not
+     * a response is expected to the current message (should be false
+     * for responses or one-way requests).
+     *
+     * @return True in the normal case, false if a handler
+     * returned false. This normally means that the runtime
+     * should reverse direction if called during a request.
+     */
+    public boolean callHandlers(Direction direction,
+        RequestOrResponse messageType,
+        SOAPHandlerContext context,
+        boolean responseExpected) {
+
+        return internalCallHandlers(direction, messageType,
+            new ContextHolder(context), responseExpected);
+    }
+
+    /**
+     * Method used to call handlers with a HandlerContext that
+     * may contain logical handlers only. This is the
+     * main entry point for calling the handlers in the case
+     * of http binding. Before calling the handlers, the
+     * handler chain caller will set the outbound property on
+     * the message context.
+     *
+     * <p>Besides the context object passed in, the other information
+     * is used to control handler execution and closing. See the
+     * handler section of the spec for the rules concering handlers
+     * returning false, throwing exceptions, etc.
+     *
+     * @param direction Inbound or outbound.
+     * @param messageType Request or response.
+     * @param context A soap handler context containing the message.
+     * @param responseExpected A boolean indicating whether or not
+     * a response is expected to the current message (should be false
+     * for responses or one-way requests).
+     *
+     * @return True in the normal case, false if a handler
+     * returned false. This normally means that the runtime
+     * should reverse direction if called during a request.
+     */
+    public boolean callHandlers(Direction direction,
+        RequestOrResponse messageType,
+        XMLHandlerContext context,
+        boolean responseExpected) {
+
+        return internalCallHandlers(direction, messageType,
+            new ContextHolder(context), responseExpected);
+    }
+
+    /**
+     * Main runtime method, called internally by the callHandlers()
+     * methods that may be called with HandlerContext or
+     * XMLHandlerContext objects.
+     *
+     * The boolean passed in is whether or not a response is required
+     * for the current message. See section 5.3.2. (todo: this section
+     * is going to change).
+     *
+     * The callLogicalHandlers and callProtocolHandlers methods will
+     * take care of execution once called and return true or false or
+     * throw an exception.
+     */
+    private boolean internalCallHandlers(Direction direction,
+        RequestOrResponse messageType,
+        ContextHolder ch,
+        boolean responseExpected) {
+
+        // set outbound property
+        ch.getLMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,
+            (direction == Direction.OUTBOUND));
+
+        // if there is as soap message context, set roles
+        if (ch.getSMC() != null) {
+            ((SOAPMessageContextImpl) ch.getSMC()).setRoles(getRoles());
+        }
+
+        // call handlers
+        if (direction == Direction.OUTBOUND) {
+            if (callLogicalHandlers(ch, direction, messageType,
+                    responseExpected) == false) {
+                return false;
+            }
+            if (callProtocolHandlers(ch, direction, messageType,
+                    responseExpected) == false) {
+                return false;
+            }
+        } else {
+            if (callProtocolHandlers(ch, direction, messageType,
+                    responseExpected) == false) {
+                return false;
+            }
+            if (callLogicalHandlers(ch, direction, messageType,
+                    responseExpected) == false) {
+                return false;
+            }
+        }
+
+        /*
+         * Close if MEP finished. Server code responsible for closing
+         * handlers if it determines that an incoming request is a
+         * one way message.
+         */
+                if (!responseExpected) {
+            if (messageType == RequestOrResponse.REQUEST) {
+                if (direction == Direction.INBOUND) {
+                    closeHandlersServer(ch);
+                } else {
+                    closeHandlersClient(ch);
+                }
+            } else {
+                if (direction == Direction.INBOUND) {
+                    closeHandlersClient(ch);
+                } else {
+                    closeHandlersServer(ch);
+                }
+            }
+        }
+        return true;
+    }
+
+    /**
+     * This method called by the server when an endpoint has thrown
+     * an exception. This method calls handleFault on the handlers
+     * and closes them. Because this method is called only during
+     * a response after the endpoint has been reached, all of the
+     * handlers have been called during the request and so all are
+     * closed.
+     */
+    public boolean callHandleFault(SOAPHandlerContext context) {
+        ContextHolder ch = new ContextHolder(context);
+        ch.getSMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY, true);
+        ((SOAPMessageContextImpl) ch.getSMC()).setRoles(getRoles());
+
+        int i = 0; // counter for logical handlers
+        int j = 0; // counter for protocol handlers
+        try {
+            while (i < logicalHandlers.size()) {
+                if (logicalHandlers.get(i).handleFault(ch.getLMC()) == false) {
+                    return false;
+                }
+                i++;
+            }
+            while (j < soapHandlers.size()) {
+                if (soapHandlers.get(j).handleFault(ch.getSMC()) == false) {
+                    return false;
+                }
+                j++;
+            }
+        } catch (RuntimeException re) {
+            logger.log(Level.FINER, "exception in handler chain", re);
+            throw re;
+        } finally {
+            closeHandlersServer(ch); // this is always called on server side
+        }
+        return true;
+    }
+
+    /**
+     * This method called by the client when it sees a SOAPFault message.
+     * This method calls handleFault on the handlers and closes them. Because
+     * this method is called only during a response, all of the handlers have
+     * been called during the request and so all are closed.
+     */
+    public boolean callHandleFaultOnClient(SOAPHandlerContext context) {
+        ContextHolder ch = new ContextHolder(context);
+        ch.getSMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY, false);
+        ((SOAPMessageContextImpl) ch.getSMC()).setRoles(getRoles());
+
+        try {
+            for (int i=soapHandlers.size()-1; i>=0; i--) {
+                if (soapHandlers.get(i).handleFault(ch.getSMC()) == false) {
+                    return false;
+                }
+            }
+            for (int i=logicalHandlers.size()-1; i>=0; i--) {
+                if (logicalHandlers.get(i).handleFault(ch.getLMC()) == false) {
+                    return false;
+                }
+            }
+        } catch (RuntimeException re) {
+            logger.log(Level.FINER, "exception in handler chain", re);
+            throw re;
+        } finally {
+            closeHandlersClient(ch);
+        }
+        return true;
+    }
+
+
+    /**
+     * Called from the main callHandlers() method.
+     * Logical message context updated before this method is called.
+     */
+    private boolean callLogicalHandlers(ContextHolder holder,
+        Direction direction, RequestOrResponse type, boolean responseExpected) {
+
+        if (direction == Direction.OUTBOUND) {
+            int i = 0;
+            try {
+                while (i < logicalHandlers.size()) {
+                    if (logicalHandlers.get(i).
+                        handleMessage(holder.getLMC()) == false) {
+                        if (responseExpected) {
+                            // reverse and call handle message
+                            holder.getLMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,false);
+                            callLogicalHandleMessage(holder, i-1, 0);
+                        }
+                        if (type == RequestOrResponse.RESPONSE) {
+                            closeHandlersServer(holder);
+                        } else {
+                            closeLogicalHandlers(holder, i, 0);
+                        }
+                        return false;
+                    }
+                    i++;
+                }
+            } catch (RuntimeException re) {
+                logger.log(Level.FINER, "exception in handler chain", re);
+                if (responseExpected && re instanceof ProtocolException) {
+                    // reverse direction and handle fault
+                    holder.getLMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,false);
+                    insertFaultMessage(holder, (ProtocolException) re);
+                    if (i>0) {
+                        try {
+                            callLogicalHandleFault(holder, i-1, 0);
+                        } catch (ProtocolException re1) {
+                            addIgnoreFaultProperty(holder);
+                            re = re1;
+                        } catch (RuntimeException re2) {
+                            re = re2;
+                        }
+                    }
+                }
+                if (type == RequestOrResponse.RESPONSE) {
+                    closeHandlersServer(holder);
+                } else {
+                    closeLogicalHandlers(holder, i, 0);
+                }
+                throw re;
+            }
+        } else { // inbound case, H(x) -> H(x-1) -> ... H(1) -> H(0)
+            int i = logicalHandlers.size()-1;
+            try {
+                while (i >= 0) {
+                    if (logicalHandlers.get(i).
+                        handleMessage(holder.getLMC()) == false) {
+
+                        if (responseExpected) {
+                            // reverse and call handle message/response
+                            holder.getLMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,true);
+                            callLogicalHandleMessage(holder, i+1,
+                                logicalHandlers.size()-1);
+                            callProtocolHandleMessage(holder, 0,
+                                soapHandlers.size()-1);
+                        }
+                        if (type == RequestOrResponse.RESPONSE) {
+                            closeHandlersClient(holder);
+                        } else {
+                            closeLogicalHandlers(holder, i,
+                                logicalHandlers.size()-1);
+                            closeProtocolHandlers(holder, 0,
+                                soapHandlers.size()-1);
+                        }
+                        return false;
+                    }
+                    i--;
+                }
+            } catch (RuntimeException re) {
+                logger.log(Level.FINER, "exception in handler chain", re);
+                if (responseExpected && re instanceof ProtocolException) {
+                    // reverse direction and handle fault
+                    holder.getLMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,true);
+                    insertFaultMessage(holder, (ProtocolException) re);
+
+                    try {
+                        // if i==size-1, no more logical handlers to call
+                        if (i == logicalHandlers.size()-1 ||
+                            callLogicalHandleFault(holder, i+1,
+                                logicalHandlers.size()-1)) {
+                            callProtocolHandleFault(holder, 0,
+                                soapHandlers.size()-1);
+                        }
+                    } catch (ProtocolException re1) {
+                        addIgnoreFaultProperty(holder);
+                        re = re1;
+                    } catch (RuntimeException re2) {
+                        re = re2;
+                    }
+                }
+                if (type == RequestOrResponse.RESPONSE) {
+                    closeHandlersClient(holder);
+                } else {
+                    closeLogicalHandlers(holder, i, logicalHandlers.size()-1);
+                    closeProtocolHandlers(holder, 0, soapHandlers.size()-1);
+                }
+                throw re;
+            }
+        }
+
+        return true;
+    }
+
+    /**
+     * Called from the main callHandlers() method.
+     * SOAP message context updated before this method is called.
+     */
+    private boolean callProtocolHandlers(ContextHolder holder,
+        Direction direction, RequestOrResponse type, boolean responseExpected) {
+
+        if (direction == Direction.OUTBOUND) {
+            int i = 0;
+            try {
+                while (i<soapHandlers.size()) {
+                    if (soapHandlers.get(i).
+                        handleMessage(holder.getSMC()) == false) {
+
+                        if (responseExpected) {
+                            // reverse and call handle message/response
+                            holder.getSMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,false);
+                            if (i>0) {
+                                callProtocolHandleMessage(holder, i-1, 0);
+                            }
+                            callLogicalHandleMessage(holder,
+                                logicalHandlers.size()-1, 0);
+                        }
+                        if (type == RequestOrResponse.RESPONSE) {
+                            closeHandlersServer(holder);
+                        } else {
+                            closeProtocolHandlers(holder, i, 0);
+                            closeLogicalHandlers(holder,
+                                logicalHandlers.size()-1 , 0);
+                        }
+                        return false;
+                    }
+                    i++;
+                }
+            } catch (RuntimeException re) {
+                logger.log(Level.FINER, "exception in handler chain", re);
+                if (responseExpected && re instanceof ProtocolException) {
+                    // reverse direction and handle fault
+                    holder.getSMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,false);
+                    insertFaultMessage(holder, (ProtocolException) re);
+                    try {
+                        if (i == 0 || // still on first handler
+                            callProtocolHandleFault(holder, i-1, 0)) {
+                            callLogicalHandleFault(holder,
+                                logicalHandlers.size()-1, 0);
+                        }
+                    } catch (ProtocolException re1) {
+                        addIgnoreFaultProperty(holder);
+                        re = re1;
+                    } catch (RuntimeException re2) {
+                        re = re2;
+                    }
+                }
+                if (type == RequestOrResponse.RESPONSE) {
+                    closeHandlersServer(holder);
+                } else {
+                    closeProtocolHandlers(holder, i, 0);
+                    closeLogicalHandlers(holder, logicalHandlers.size()-1, 0);
+                }
+                throw re;
+            }
+        } else { // inbound case, H(x) -> H(x-1) -> ... H(1) -> H(0)
+            int i = soapHandlers.size()-1;
+            try {
+                while (i >= 0) {
+                    if (soapHandlers.get(i).
+                        handleMessage(holder.getSMC()) == false) {
+
+                        // reverse and call handle message/response
+                        holder.getSMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,true);
+                        if (responseExpected && i != soapHandlers.size()-1) {
+                            callProtocolHandleMessage(holder, i+1,
+                                soapHandlers.size()-1);
+                        }
+                        if (type == RequestOrResponse.RESPONSE) {
+                            closeHandlersClient(holder);
+                        } else {
+                            closeProtocolHandlers(holder, i,
+                                soapHandlers.size()-1);
+                        }
+                        return false;
+                    }
+                    i--;
+                }
+            } catch (RuntimeException re) {
+                logger.log(Level.FINER, "exception in handler chain", re);
+                if (responseExpected && re instanceof ProtocolException) {
+                    // reverse direction and handle fault
+                    holder.getSMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY,true);
+                    insertFaultMessage(holder, (ProtocolException) re);
+                    try {
+                        if (i < soapHandlers.size()-1) {
+                            callProtocolHandleFault(holder, i+1,
+                                soapHandlers.size()-1);
+                        }
+                    } catch (ProtocolException re1) {
+                        addIgnoreFaultProperty(holder);
+                        re = re1;
+                    } catch (RuntimeException re2) {
+                        re = re2;
+                    }
+                }
+                if (type == RequestOrResponse.RESPONSE) {
+                    closeHandlersClient(holder);
+                } else {
+                    closeProtocolHandlers(holder, i, soapHandlers.size()-1);
+                }
+                throw re;
+            }
+        }
+        return true;
+    }
+
+    /**
+     * Method called for abnormal processing (for instance, as the
+     * result of a handler returning false during normal processing).
+     * Start and end indices are inclusive.
+     */
+    private void callLogicalHandleMessage(ContextHolder holder,
+            int start, int end) {
+
+        if (logicalHandlers.isEmpty() ||
+            start == -1 ||
+            start == logicalHandlers.size()) {
+            return;
+        }
+        callGenericHandleMessage(logicalHandlers,holder.getLMC(),start,end);
+
+    }
+
+    /**
+     * Method called for abnormal processing (for instance, as the
+     * result of a handler returning false during normal processing).
+     * Start and end indices are inclusive.
+     */
+    private void callProtocolHandleMessage(ContextHolder holder,
+        int start, int end) {
+
+        if (soapHandlers.isEmpty()) {
+            return;
+        }
+        callGenericHandleMessage(soapHandlers,holder.getSMC(),start,end);
+    }
+
+    /**
+     * Utility method for calling handleMessage during abnormal processing(for
+     * instance, as the result of a handler returning false during normal
+     * processing). Start and end indices are inclusive.
+     */
+
+    private <C extends MessageContext> void callGenericHandleMessage(List<? extends Handler> handlerList,
+        C context, int start, int end) {
+        if (handlerList.isEmpty()) {
+            return ;
+        }
+        int i = start;
+        if (start > end) {
+            try {
+                while (i >= end) {
+                    if (handlerList.get(i).handleMessage(context) == false)
+                        return;
+                    i--;
+                }
+            } catch (RuntimeException re) {
+                logger.log(Level.FINER,
+                    "exception in handler chain", re);
+                throw re;
+            }
+        } else {
+            try {
+                while (i <= end) {
+                    if (handlerList.get(i).handleMessage(context) == false)
+                        return ;
+                    i++;
+                }
+            } catch (RuntimeException re) {
+                logger.log(Level.FINER,
+                    "exception in handler chain", re);
+                throw re;
+            }
+        }
+        return;
+    }
+
+    /*
+     * Calls handleFault on the logical handlers. Indices are
+     * inclusive. Exceptions get passed up the chain, and an
+     * exception or return of 'false' ends processing.
+     */
+    private boolean callLogicalHandleFault(ContextHolder holder,
+            int start, int end) {
+
+        return callGenericHandleFault(logicalHandlers,
+            holder.getLMC(), start, end);
+    }
+
+    /**
+     * Calls handleFault on the protocol handlers. Indices are
+     * inclusive. Exceptions get passed up the chain, and an
+     * exception or return of 'false' ends processing.
+     */
+    private boolean callProtocolHandleFault(ContextHolder holder,
+        int start, int end) {
+
+        return callGenericHandleFault(soapHandlers,
+            holder.getSMC(), start, end);
+    }
+
+    /*
+     * Used by callLogicalHandleFault and callProtocolHandleFault.
+     */
+    private <C extends MessageContext> boolean callGenericHandleFault(List<? extends Handler> handlerList,
+        C context, int start, int end) {
+
+        if (handlerList.isEmpty()) {
+            return true;
+        }
+        int i = start;
+        if (start > end) {
+            try {
+                while (i >= end) {
+                    if (handlerList.get(i).
+                            handleFault(context) == false) {
+
+                        return false;
+                    }
+                    i--;
+                }
+            } catch (RuntimeException re) {
+                logger.log(Level.FINER,
+                    "exception in handler chain", re);
+                throw re;
+            }
+        } else {
+            try {
+                while (i <= end) {
+                    if (handlerList.get(i).
+                        handleFault(context) == false) {
+
+                        return false;
+                    }
+                    i++;
+                }
+            } catch (RuntimeException re) {
+                logger.log(Level.FINER,
+                    "exception in handler chain", re);
+                throw re;
+            }
+        }
+        return true;
+    }
+
+    /**
+     * Method that closes protocol handlers and then
+     * logical handlers.
+     */
+    private void closeHandlersClient(ContextHolder holder) {
+        closeProtocolHandlers(holder, soapHandlers.size()-1, 0);
+        closeLogicalHandlers(holder, logicalHandlers.size()-1, 0);
+    }
+
+    /**
+     * Method that closes logical handlers and then
+     * protocol handlers.
+     */
+    private void closeHandlersServer(ContextHolder holder) {
+        closeLogicalHandlers(holder, 0, logicalHandlers.size()-1);
+        closeProtocolHandlers(holder, 0, soapHandlers.size()-1);
+    }
+
+    /**
+     * This version is called by the server code once it determines
+     * that an incoming message is a one-way request.
+     */
+    public void forceCloseHandlersOnServer(SOAPHandlerContext context) {
+        ContextHolder ch = new ContextHolder(context);
+        // only called after an inbound request
+        ch.getSMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY, false);
+        ((SOAPMessageContextImpl) ch.getSMC()).setRoles(getRoles());
+        closeHandlersServer(ch);
+    }
+
+    /**
+     * It is called by the client when an MU fault occurs since the handlerchain
+     * never gets invoked. The direction is an inbound message.
+     */
+    public void forceCloseHandlersOnClient(SOAPHandlerContext context) {
+        ContextHolder ch = new ContextHolder(context);
+
+        // only called after an inbound request
+        ch.getSMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY, false);
+        ((SOAPMessageContextImpl) ch.getSMC()).setRoles(getRoles());
+        closeHandlersClient(ch);
+    }
+
+    /**
+     * Version of forceCloseHandlers(HandlerContext) that is used
+     * by XML binding.
+     */
+    public void forceCloseHandlersOnServer(XMLHandlerContext context) {
+        ContextHolder ch = new ContextHolder(context);
+        // only called after an inbound request
+        ch.getLMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY, false);
+        closeHandlersServer(ch);
+    }
+
+    /**
+     * Version of forceCloseHandlers(HandlerContext) that is used
+     * by XML binding.
+     */
+    public void forceCloseHandlersOnClient(XMLHandlerContext context) {
+        ContextHolder ch = new ContextHolder(context);
+        // only called after an inbound request
+        ch.getLMC().put(MessageContext.MESSAGE_OUTBOUND_PROPERTY, false);
+        closeHandlersClient(ch);
+    }
+
+    private void closeProtocolHandlers(ContextHolder holder,
+        int start, int end) {
+
+        closeGenericHandlers(soapHandlers, holder.getSMC(), start, end);
+    }
+
+    private void closeLogicalHandlers(ContextHolder holder,
+        int start, int end) {
+
+        closeGenericHandlers(logicalHandlers, holder.getLMC(), start, end);
+    }
+
+    /**
+     * Calls close on the handlers from the starting
+     * index through the ending index (inclusive). Made indices
+     * inclusive to allow both directions more easily.
+     */
+    private void closeGenericHandlers(List<? extends Handler> handlerList,
+        MessageContext context, int start, int end) {
+
+        if (handlerList.isEmpty()) {
+            return;
+        }
+        if (start > end) {
+            for (int i=start; i>=end; i--) {
+                try {
+                    handlerList.get(i).close(context);
+                } catch (RuntimeException re) {
+                    logger.log(Level.INFO,
+                        "Exception ignored during close", re);
+                }
+            }
+        } else {
+            for (int i=start; i<=end; i++) {
+                try {
+                    handlerList.get(i).close(context);
+                } catch (RuntimeException re) {
+                    logger.log(Level.INFO,
+                        "Exception ignored during close", re);
+                }
+            }
+        }
+    }
+
+    /**
+     * Used to hold the context objects that are used to get
+     * and set the current message.
+     *
+     * If a HandlerContext is passed in, both logical and soap
+     * handlers are used. If XMLHandlerContext is passed in,
+     * only logical handlers are assumed to be present.
+     */
+    static class ContextHolder {
+
+        boolean logicalOnly;
+        SOAPHandlerContext context;
+        XMLHandlerContext xmlContext;
+
+        ContextHolder(SOAPHandlerContext context) {
+            this.context = context;
+            logicalOnly = false;
+        }
+
+        ContextHolder(XMLHandlerContext xmlContext) {
+            this.xmlContext = xmlContext;
+            logicalOnly = true;
+        }
+
+        LogicalMessageContext getLMC() {
+            return (logicalOnly ? xmlContext.getLogicalMessageContext() :
+                context.getLogicalMessageContext());
+        }
+
+        SOAPMessageContext getSMC() {
+            return (logicalOnly ? null : context.getSOAPMessageContext());
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerChainsModel.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerChainsModel.java
new file mode 100644
index 0000000..1e9680a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerChainsModel.java
@@ -0,0 +1,568 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.handler;
+
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.util.HandlerAnnotationInfo;
+import com.sun.xml.internal.ws.util.JAXWSUtils;
+import com.sun.xml.internal.ws.util.UtilException;
+
+import javax.annotation.PostConstruct;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.ws.handler.Handler;
+import javax.xml.ws.handler.PortInfo;
+import javax.xml.ws.http.HTTPBinding;
+import javax.xml.ws.soap.SOAPBinding;
+import java.lang.reflect.Method;
+import java.util.*;
+import java.util.logging.Logger;
+
+
+public class HandlerChainsModel {
+    private static final Logger logger = Logger.getLogger(
+            com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".util");
+
+    protected Class annotatedClass;
+    protected List<HandlerChainType> handlerChains;
+    protected String id;
+    /** Creates a new instance of HandlerChains */
+    public HandlerChainsModel(Class annotatedClass) {
+        this.annotatedClass = annotatedClass;
+    }
+
+    public List<HandlerChainType> getHandlerChain() {
+        if (handlerChains == null) {
+            handlerChains = new ArrayList<HandlerChainType>();
+        }
+        return handlerChains;
+    }
+
+    public java.lang.String getId() {
+        return id;
+    }
+
+    public void setId(java.lang.String value) {
+        this.id = value;
+    }
+    /**
+     * reader should be on <handler-chains> element
+     */
+    public static HandlerChainsModel parseHandlerConfigFile(Class annotatedClass, XMLStreamReader reader) {
+        ensureProperName(reader,QNAME_HANDLER_CHAINS);
+        HandlerChainsModel handlerModel = new HandlerChainsModel(annotatedClass);
+        List<HandlerChainType> hChains = handlerModel.getHandlerChain();
+        XMLStreamReaderUtil.nextElementContent(reader);
+
+        while (reader.getName().equals(QNAME_HANDLER_CHAIN)) {
+            HandlerChainType hChain = new HandlerChainType();
+            XMLStreamReaderUtil.nextElementContent(reader);
+
+            if (reader.getName().equals(QNAME_CHAIN_PORT_PATTERN)) {
+                QName portNamePattern = XMLStreamReaderUtil.getElementQName(reader);
+                hChain.setPortNamePattern(portNamePattern);
+                XMLStreamReaderUtil.nextElementContent(reader);
+            } else if (reader.getName().equals(QNAME_CHAIN_PROTOCOL_BINDING)) {
+                String bindingList = XMLStreamReaderUtil.getElementText(reader);
+                StringTokenizer stk = new StringTokenizer(bindingList);
+                while(stk.hasMoreTokens()) {
+                    String token = stk.nextToken();
+                    // This will convert tokens into Binding URI
+                    hChain.addProtocolBinding(token);
+                }
+                XMLStreamReaderUtil.nextElementContent(reader);
+            } else if (reader.getName().equals(QNAME_CHAIN_SERVICE_PATTERN)) {
+                QName serviceNamepattern = XMLStreamReaderUtil.getElementQName(reader);
+                hChain.setServiceNamePattern(serviceNamepattern);
+                XMLStreamReaderUtil.nextElementContent(reader);
+            }
+            List<HandlerType> handlers = hChain.getHandlers();
+            // process all <handler> elements
+            while (reader.getName().equals(QNAME_HANDLER)) {
+                HandlerType handler = new HandlerType();
+
+                XMLStreamReaderUtil.nextContent(reader);
+                if (reader.getName().equals(QNAME_HANDLER_NAME)) {
+                    String handlerName =
+                            XMLStreamReaderUtil.getElementText(reader);
+                    handler.setHandlerName(handlerName);
+                    XMLStreamReaderUtil.nextContent(reader);
+                }
+
+                // handler class
+                ensureProperName(reader, QNAME_HANDLER_CLASS);
+                String handlerClass =
+                        XMLStreamReaderUtil.getElementText(reader);
+                handler.setHandlerClass(handlerClass);
+                XMLStreamReaderUtil.nextContent(reader);
+
+                // init params (ignored)
+                while (reader.getName().equals(QNAME_HANDLER_PARAM)) {
+                    skipInitParamElement(reader);
+                }
+
+                // headers (ignored)
+                while (reader.getName().equals(QNAME_HANDLER_HEADER)) {
+                    skipTextElement(reader);
+                }
+
+                // roles (not stored per handler)
+                while (reader.getName().equals(QNAME_HANDLER_ROLE)) {
+                    List<String> soapRoles = handler.getSoapRoles();
+                    soapRoles.add(XMLStreamReaderUtil.getElementText(reader));
+                    XMLStreamReaderUtil.nextContent(reader);
+                }
+
+                handlers.add(handler);
+
+                // move past </handler>
+                ensureProperName(reader, QNAME_HANDLER);
+                XMLStreamReaderUtil.nextContent(reader);
+            }
+
+            // move past </handler-chain>
+            ensureProperName(reader, QNAME_HANDLER_CHAIN);
+            hChains.add(hChain);
+            XMLStreamReaderUtil.nextContent(reader);
+        }
+
+        return handlerModel;
+    }
+
+    /**
+     * <p>This method is called internally by HandlerAnnotationProcessor,
+     * and by
+     * {@link com.sun.xml.internal.ws.transport.http.servlet.RuntimeEndpointInfoParser}
+     * directly when it reaches the handler chains element in the
+     * descriptor file it is parsing.
+     *
+     * @return A HandlerAnnotationInfo object that stores the
+     * handlers and roles.
+     */
+    public static HandlerAnnotationInfo parseHandlerFile(XMLStreamReader reader,
+            ClassLoader classLoader, QName serviceName, QName portName,
+            String bindingId) {
+        ensureProperName(reader,QNAME_HANDLER_CHAINS);
+        HandlerAnnotationInfo info = new HandlerAnnotationInfo();
+
+        XMLStreamReaderUtil.nextElementContent(reader);
+
+        List<Handler> handlerChain = new ArrayList<Handler>();
+        Set<String> roles = new HashSet<String>();
+
+        while (reader.getName().equals(QNAME_HANDLER_CHAIN)) {
+
+            XMLStreamReaderUtil.nextElementContent(reader);
+
+            if (reader.getName().equals(QNAME_CHAIN_PORT_PATTERN)) {
+                if (portName == null) {
+                    logger.warning("handler chain sepcified for port " +
+                            "but port QName passed to parser is null");
+                }
+                boolean parseChain = JAXWSUtils.matchQNames(portName,
+                        XMLStreamReaderUtil.getElementQName(reader));
+                if (!parseChain) {
+                    skipChain(reader);
+                    continue;
+                }
+                XMLStreamReaderUtil.nextElementContent(reader);
+            } else if (reader.getName().equals(QNAME_CHAIN_PROTOCOL_BINDING)) {
+                if (bindingId == null) {
+                    logger.warning("handler chain sepcified for bindingId " +
+                            "but bindingId passed to parser is null");
+                }
+                String bindingConstraint = XMLStreamReaderUtil.getElementText(reader);
+                boolean skipThisChain = true;
+                StringTokenizer stk = new StringTokenizer(bindingConstraint);
+                List<String> bindingList = new ArrayList<String>();
+                while(stk.hasMoreTokens()) {
+                    String tokenOrURI = stk.nextToken();
+                    String binding = tokenBindingMap.get(tokenOrURI);
+                    if(binding == null) {
+                        //Unknown binding or Unknown token, Put it as it is
+                        binding = tokenOrURI;
+                    }
+                    bindingList.add(binding);
+                }
+                if(bindingList.contains(bindingId)){
+                    skipThisChain = false;
+                }
+
+                if (skipThisChain) {
+                    skipChain(reader);
+                    continue;
+                }
+                XMLStreamReaderUtil.nextElementContent(reader);
+            } else if (reader.getName().equals(QNAME_CHAIN_SERVICE_PATTERN)) {
+                if (serviceName == null) {
+                    logger.warning("handler chain sepcified for service " +
+                            "but service QName passed to parser is null");
+                }
+                boolean parseChain = JAXWSUtils.matchQNames(
+                        serviceName,
+                        XMLStreamReaderUtil.getElementQName(reader));
+                if (!parseChain) {
+                    skipChain(reader);
+                    continue;
+                }
+                XMLStreamReaderUtil.nextElementContent(reader);
+            }
+
+            // process all <handler> elements
+            while (reader.getName().equals(QNAME_HANDLER)) {
+                Handler handler = null;
+
+                XMLStreamReaderUtil.nextContent(reader);
+                if (reader.getName().equals(QNAME_HANDLER_NAME)) {
+                    skipTextElement(reader);
+                }
+
+                // handler class
+                ensureProperName(reader, QNAME_HANDLER_CLASS);
+                try {
+                    handler = (Handler) loadClass(classLoader,
+                            XMLStreamReaderUtil.getElementText(reader)).newInstance();
+                } catch (InstantiationException ie){
+                    throw new RuntimeException(ie);
+                } catch (IllegalAccessException e) {
+                    throw new RuntimeException(e);
+                }
+                XMLStreamReaderUtil.nextContent(reader);
+
+                // init params (ignored)
+                while (reader.getName().equals(QNAME_HANDLER_PARAM)) {
+                    skipInitParamElement(reader);
+                }
+
+                // headers (ignored)
+                while (reader.getName().equals(QNAME_HANDLER_HEADER)) {
+                    skipTextElement(reader);
+                }
+
+                // roles (not stored per handler)
+                while (reader.getName().equals(QNAME_HANDLER_ROLE)) {
+                    roles.add(XMLStreamReaderUtil.getElementText(reader));
+                    XMLStreamReaderUtil.nextContent(reader);
+                }
+
+                // call @PostConstruct method on handler if present
+                for (Method method : handler.getClass().getMethods()) {
+                    if (method.getAnnotation(PostConstruct.class) == null) {
+                        continue;
+                    }
+                    try {
+                        method.invoke(handler, new Object [0]);
+                        break;
+                    } catch (Exception e) {
+                        throw new RuntimeException(e);
+                    }
+                }
+
+                handlerChain.add(handler);
+
+                // move past </handler>
+                ensureProperName(reader, QNAME_HANDLER);
+                XMLStreamReaderUtil.nextContent(reader);
+            }
+
+            // move past </handler-chain>
+            ensureProperName(reader, QNAME_HANDLER_CHAIN);
+            XMLStreamReaderUtil.nextContent(reader);
+        }
+
+        info.setHandlers(handlerChain);
+        info.setRoles(roles);
+        return info;
+    }
+
+    public HandlerAnnotationInfo getHandlersForPortInfo(PortInfo info){
+
+        HandlerAnnotationInfo handlerInfo = new HandlerAnnotationInfo();
+        List<Handler> handlerClassList = new ArrayList<Handler>();
+        Set<String> roles = new HashSet<String>();
+
+        for(HandlerChainType hchain : handlerChains) {
+            boolean hchainMatched = false;
+            if((!hchain.isConstraintSet()) ||
+                    JAXWSUtils.matchQNames(info.getServiceName(), hchain.getServiceNamePattern()) ||
+                    JAXWSUtils.matchQNames(info.getPortName(), hchain.getPortNamePattern()) ||
+                    hchain.getProtocolBindings().contains(info.getBindingID()) ){
+                hchainMatched = true;
+
+            }
+            if(hchainMatched) {
+                for(HandlerType handler : hchain.getHandlers()) {
+                    try {
+                        Handler handlerClass = (Handler) loadClass(annotatedClass.getClassLoader(),
+                                handler.getHandlerClass()).newInstance();
+                        callHandlerPostConstruct(handlerClass);
+                        handlerClassList.add(handlerClass);
+                    } catch (InstantiationException ie){
+                        throw new RuntimeException(ie);
+                    } catch (IllegalAccessException e) {
+                        throw new RuntimeException(e);
+                    }
+
+                    roles.addAll(handler.getSoapRoles());
+                }
+
+            }
+        }
+
+        handlerInfo.setHandlers(handlerClassList);
+        handlerInfo.setRoles(roles);
+        return handlerInfo;
+
+    }
+
+    static Class loadClass(ClassLoader loader, String name) {
+        try {
+            return Class.forName(name, true, loader);
+        } catch (ClassNotFoundException e) {
+            throw new UtilException(
+                    "util.handler.class.not.found",
+                    name);
+        }
+    }
+
+    static void callHandlerPostConstruct(Object handlerClass) {
+        // call @PostConstruct method on handler if present
+        for (Method method : handlerClass.getClass().getMethods()) {
+            if (method.getAnnotation(PostConstruct.class) == null) {
+                continue;
+            }
+            try {
+                method.invoke(handlerClass, new Object [0]);
+                break;
+            } catch (Exception e) {
+                throw new RuntimeException(e);
+            }
+        }
+    }
+
+    static void skipChain(XMLStreamReader reader) {
+        while (XMLStreamReaderUtil.nextContent(reader) !=
+                XMLStreamConstants.END_ELEMENT ||
+                !reader.getName().equals(QNAME_HANDLER_CHAIN)) {}
+        XMLStreamReaderUtil.nextElementContent(reader);
+    }
+
+    static void skipTextElement(XMLStreamReader reader) {
+        XMLStreamReaderUtil.nextContent(reader);
+        XMLStreamReaderUtil.nextElementContent(reader);
+        XMLStreamReaderUtil.nextElementContent(reader);
+    }
+
+    static void skipInitParamElement(XMLStreamReader reader) {
+        int state;
+        do {
+            state = XMLStreamReaderUtil.nextContent(reader);
+        } while (state != XMLStreamReader.END_ELEMENT ||
+                !reader.getName().equals(QNAME_HANDLER_PARAM));
+        XMLStreamReaderUtil.nextElementContent(reader);
+    }
+
+    static void ensureProperName(XMLStreamReader reader,
+            QName expectedName) {
+
+        if (!reader.getName().equals(expectedName)) {
+            failWithLocalName("util.parser.wrong.element", reader,
+                    expectedName.getLocalPart());
+        }
+    }
+
+    static void ensureProperName(XMLStreamReader reader, String expectedName) {
+        if (!reader.getLocalName().equals(expectedName)) {
+            failWithLocalName("util.parser.wrong.element", reader,
+                    expectedName);
+        }
+    }
+
+    static void failWithLocalName(String key,
+            XMLStreamReader reader, String arg) {
+        throw new UtilException(key,
+                new Object[] {
+            Integer.toString(reader.getLocation().getLineNumber()),
+            reader.getLocalName(),
+            arg });
+    }
+
+    public static final String PROTOCOL_SOAP11_TOKEN = "##SOAP11_HTTP";
+    public static final String PROTOCOL_SOAP12_TOKEN = "##SOAP12_HTTP";
+    public static final String PROTOCOL_XML_TOKEN = "##XML_HTTP";
+
+    public static final String NS_109 =
+            "http://java.sun.com/xml/ns/javaee";
+    public static final QName QNAME_CHAIN_PORT_PATTERN =
+            new QName(NS_109, "port-name-pattern");
+    public static final QName QNAME_CHAIN_PROTOCOL_BINDING =
+            new QName(NS_109, "protocol-bindings");
+    public static final QName QNAME_CHAIN_SERVICE_PATTERN =
+            new QName(NS_109, "service-name-pattern");
+    public static final QName QNAME_HANDLER_CHAIN =
+            new QName(NS_109, "handler-chain");
+    public static final QName QNAME_HANDLER_CHAINS =
+            new QName(NS_109, "handler-chains");
+    public static final QName QNAME_HANDLER =
+            new QName(NS_109, "handler");
+    public static final QName QNAME_HANDLER_NAME =
+            new QName(NS_109, "handler-name");
+    public static final QName QNAME_HANDLER_CLASS =
+            new QName(NS_109, "handler-class");
+    public static final QName QNAME_HANDLER_PARAM =
+            new QName(NS_109, "init-param");
+    public static final QName QNAME_HANDLER_PARAM_NAME =
+            new QName(NS_109, "param-name");
+    public static final QName QNAME_HANDLER_PARAM_VALUE =
+            new QName(NS_109, "param-value");
+    public static final QName QNAME_HANDLER_HEADER =
+            new QName(NS_109, "soap-header");
+    public static final QName QNAME_HANDLER_ROLE =
+            new QName(NS_109, "soap-role");
+    protected static final Map<String,String> tokenBindingMap;
+    //Populate the token map
+    static {
+        tokenBindingMap = new HashMap<String,String>();
+        tokenBindingMap.put("##SOAP11_HTTP",SOAPBinding.SOAP11HTTP_BINDING);
+        tokenBindingMap.put("##SOAP11_HTTP_MTOM",SOAPBinding.SOAP11HTTP_MTOM_BINDING);
+        tokenBindingMap.put("##SOAP12_HTTP",SOAPBinding.SOAP12HTTP_BINDING);
+        tokenBindingMap.put("##SOAP12_HTTP_MTOM",SOAPBinding.SOAP12HTTP_MTOM_BINDING);
+        tokenBindingMap.put("##XML_HTTP",HTTPBinding.HTTP_BINDING);
+    }
+
+    static class HandlerChainType {
+        //constraints
+        protected QName serviceNamePattern;
+        protected QName portNamePattern;
+        protected List<String> protocolBindings;
+
+        // This flag is set if one of the above constraint is set on handler chain
+        protected boolean constraintSet = false;
+
+        protected List<HandlerType> handlers;
+        protected String id;
+
+
+        /** Creates a new instance of HandlerChain */
+        public HandlerChainType() {
+            protocolBindings = new ArrayList<String>();
+        }
+
+        public void setServiceNamePattern(QName value) {
+            this.serviceNamePattern = value;
+            constraintSet = true;
+        }
+
+        public QName getServiceNamePattern() {
+            return serviceNamePattern;
+        }
+
+        public void setPortNamePattern(QName value) {
+            this.portNamePattern = value;
+            constraintSet = true;
+        }
+
+        public QName getPortNamePattern() {
+            return portNamePattern;
+        }
+
+        public List<java.lang.String> getProtocolBindings() {
+            return this.protocolBindings;
+        }
+
+        public void addProtocolBinding(String tokenorURI){
+            String binding = tokenBindingMap.get(tokenorURI);
+            if(binding == null) {
+                //Unknown binding or Unknown token, Put it as it is
+                binding = tokenorURI;
+            }
+            protocolBindings.add(binding);
+            constraintSet = true;
+        }
+
+        public boolean isConstraintSet() {
+            return constraintSet || !protocolBindings.isEmpty();
+        }
+        public java.lang.String getId() {
+            return id;
+        }
+
+        public void setId(java.lang.String value) {
+            this.id = value;
+        }
+
+        public List<HandlerType> getHandlers() {
+            if (handlers == null) {
+                handlers = new ArrayList<HandlerType>();
+            }
+            return this.handlers;
+        }
+    }
+
+    static class HandlerType {
+        protected String handlerName;
+        protected String handlerClass;
+        protected List<String> soapRoles;
+
+        protected java.lang.String id;
+
+        /** Creates a new instance of HandlerComponent */
+        public HandlerType() {
+        }
+
+        public String getHandlerName() {
+            return handlerName;
+        }
+
+        public void setHandlerName(String value) {
+            this.handlerName = value;
+        }
+
+        public String getHandlerClass() {
+            return handlerClass;
+        }
+
+        public void setHandlerClass(String value) {
+            this.handlerClass = value;
+        }
+
+        public java.lang.String getId() {
+            return id;
+        }
+
+        public void setId(java.lang.String value) {
+            this.id = value;
+        }
+
+        public List<String> getSoapRoles() {
+            if (soapRoles == null) {
+                soapRoles = new ArrayList<String>();
+            }
+            return this.soapRoles;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerContext.java
new file mode 100644
index 0000000..4c5351a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerContext.java
@@ -0,0 +1,174 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+import javax.xml.ws.handler.MessageContext;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.spi.runtime.InternalSoapEncoder;
+import com.sun.xml.internal.ws.spi.runtime.Invoker;
+import java.lang.reflect.Method;
+import java.util.List;
+import java.util.ArrayList;
+
+/**
+ * The HandlerContext is used in the client and server runtime
+ * in {@link com.sun.xml.internal.ws.protocol.soap.client.SOAPMessageDispatcher} and
+ * {@link com.sun.xml.internal.ws.protocol.soap.server.SOAPMessageDispatcher} to hold
+ * information about the current message.
+ *
+ * <p>It stores a {@link com.sun.xml.internal.ws.pept.ept.MessageInfo} and
+ * {@link com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage}
+ * which are used by the rest of the runtime, and provides a bridge
+ * between these and the soap and logical message contexts that
+ * are used by the handlers.
+ *
+ * @see LogicalMessageContextImpl
+ * @see MessageContextImpl
+ * @see SOAPMessageContextImpl
+ *
+ * @author WS Development Team
+ */
+public class HandlerContext {
+
+    private MessageInfo messageInfo;
+    private InternalMessage internalMessage;
+    private MessageContext msgContext;
+
+    private Method method;
+    private Invoker invoker;
+    private String algorithm;
+    private String bindingId;
+
+    public HandlerContext(MessageInfo messageInfo,
+                          InternalMessage internalMessage) {
+        this.messageInfo = messageInfo;
+        this.internalMessage = internalMessage;
+        this.msgContext = new MessageContextImpl();
+        //populateAttachmentMap();
+    }
+
+    /**
+     * @return Returns the soapMessage.
+     */
+    public MessageContext getMessageContext() {
+        return msgContext;
+    }
+
+    public void setMessageContext(MessageContext msgContext) {
+        this.msgContext = msgContext;
+    }
+
+    public InternalMessage getInternalMessage() {
+        return internalMessage;
+    }
+
+    /**
+    * @param internalMessage The internalMessage to set.
+    */
+    public void setInternalMessage(InternalMessage internalMessage) {
+        this.internalMessage = internalMessage;
+        populateAttachmentMap();
+    }
+
+    public MessageInfo getMessageInfo() {
+        return messageInfo;
+    }
+
+    /**
+    * @param messageInfo The messageInfo to set.
+    */
+    public void setMessageInfo(MessageInfo messageInfo) {
+        this.messageInfo = messageInfo;
+    }
+
+    /*
+     * Returns the invocation method
+     */
+    public Method getMethod() {
+        return method;
+    }
+
+    public void setMethod(Method method) {
+        this.method = method;
+    }
+
+    /*
+    * Returns InternalMessage's BodyBlock value. It can be null for empty body.
+    */
+    public Object getBody() {
+        return (internalMessage == null) ? null : ((internalMessage.getBody() == null)?null:internalMessage.getBody().getValue());
+    }
+
+    /*
+    * Returns InternalMessage's HeaderBlock values
+    */
+    public List getHeaders() {
+        List<HeaderBlock> headerBlocks =
+            (internalMessage == null) ? null : internalMessage.getHeaders();
+        if (headerBlocks != null) {
+             List headers = new ArrayList();
+             for (HeaderBlock headerBlock : headerBlocks) {
+                if (headerBlock.getValue() != null) {
+                    headers.add(headerBlock.getValue());
+                }
+             }
+             return headers;
+        }
+        return null;
+    }
+
+    public String getBindingId() {
+        return bindingId;
+    }
+
+    public void setBindingId(String bindingID) {
+        bindingId = bindingID;
+    }
+
+    public void setCanonicalization(String algorithm) {
+        this.algorithm = algorithm;
+    }
+
+    public Invoker getInvoker() {
+        return invoker;
+    }
+
+    public void setInvoker(Invoker invoker) {
+        this.invoker = invoker;
+    }
+
+    public void populateAttachmentMap(){
+        //populate the attachment map
+        if(internalMessage != null){
+            for(AttachmentBlock ab: internalMessage.getAttachments().values()){
+                MessageContextUtil.addMessageAttachment(msgContext, ab.getId(), ab.asDataHandler());
+            }
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerException.java
new file mode 100644
index 0000000..dc07d00
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerException.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.handler;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * Exception thrown by handler-related code. Extends
+ * {@link com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase}
+ * using the appropriate resource bundle.
+ *
+ * @see com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase
+ *
+ * @author WS Development Team
+ */
+public class HandlerException extends JAXWSExceptionBase {
+    public HandlerException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public HandlerException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public HandlerException(Localizable arg) {
+        super("handler.nestedError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.handler";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerResolverImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerResolverImpl.java
new file mode 100644
index 0000000..ed9e253
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/HandlerResolverImpl.java
@@ -0,0 +1,129 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import com.sun.xml.internal.ws.client.ServiceContext;
+import com.sun.xml.internal.ws.util.HandlerAnnotationInfo;
+import com.sun.xml.internal.ws.util.HandlerAnnotationProcessor;
+
+import javax.xml.ws.handler.Handler;
+import javax.xml.ws.handler.HandlerResolver;
+import javax.xml.ws.handler.PortInfo;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+/**
+ * <p>Implementation class of HandlerResolver. This class is a simple
+ * map of PortInfo objects to handler chains. It is used by a
+ * {@link com.sun.xml.internal.ws.client.ServiceContext} object, and can
+ * be replaced by user code with a different class implementing
+ * HandlerResolver. This class is only used on the client side, and
+ * it includes a lot of logging to help when there are issues since
+ * it deals with port names, service names, and bindings. All three
+ * must match when getting a handler chain from the map.
+ *
+ * <p>It is created by the {@link com.sun.xml.internal.ws.client.ServiceContextBuilder}
+ * class and set on the ServiceContext. The ServiceContextBuilder uses
+ * the {@link com.sun.xml.internal.ws.util.HandlerAnnotationProcessor} to create
+ * a handler chain and then it sets the chains on this class and they
+ * are put into the map. The ServiceContext uses the map to set handler
+ * chains on bindings when they are created.
+ *
+ * @see com.sun.xml.internal.ws.client.ServiceContext
+ * @see com.sun.xml.internal.ws.handler.PortInfoImpl
+ *
+ * @author WS Development Team
+ */
+public class HandlerResolverImpl implements HandlerResolver {
+    private HandlerChainsModel handlerModel;
+    private Map<PortInfo, List<Handler>> chainMap;
+    private ServiceContext serviceContext;
+    private static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".handler");
+
+    public HandlerResolverImpl(ServiceContext serviceContext) {
+        this.serviceContext = serviceContext;
+        handlerModel = HandlerAnnotationProcessor.buildHandlerChainsModel(serviceContext.getServiceClass());
+        chainMap = new HashMap<PortInfo, List<Handler>>();
+    }
+
+    /**
+     * API method to return the correct handler chain for a given
+     * PortInfo class.
+     *
+     * @param info A PortInfo object.
+     * @return A list of handler objects. If there is no handler chain
+     * found, it will return an empty list rather than null.
+     */
+    public List<Handler> getHandlerChain(PortInfo info) {
+        //Check in cache first
+        List<Handler> chain = chainMap.get(info);
+
+        if(chain != null)
+            return chain;
+        if(handlerModel != null) {
+            HandlerAnnotationInfo chainInfo = handlerModel.getHandlersForPortInfo(info);
+            if(chainInfo != null) {
+                chain = chainInfo.getHandlers();
+                serviceContext.setRoles(info.getPortName(),chainInfo.getRoles());
+            }
+        }
+        if (chain == null) {
+            if (logger.isLoggable(Level.FINE)) {
+                logGetChain(info);
+            }
+            chain = new ArrayList<Handler>();
+        }
+        // Put it in cache
+        chainMap.put(info,chain);
+        return chain;
+    }
+
+    // logged at fine level
+    private void logGetChain(PortInfo info) {
+        logger.fine("No handler chain found for port info:");
+        logPortInfo(info, Level.FINE);
+        logger.fine("Existing handler chains:");
+        if (chainMap.isEmpty()) {
+            logger.fine("none");
+        } else {
+            for (PortInfo key : chainMap.keySet()) {
+                logger.fine(chainMap.get(key).size() +
+                    " handlers for port info ");
+                logPortInfo(key, Level.FINE);
+            }
+        }
+    }
+
+    private void logPortInfo(PortInfo info, Level level) {
+        logger.log(level, "binding: " + info.getBindingID() +
+            "\nservice: " + info.getServiceName() +
+            "\nport: " + info.getPortName());
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/LogicalMessageContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/LogicalMessageContextImpl.java
new file mode 100644
index 0000000..fba7539
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/LogicalMessageContextImpl.java
@@ -0,0 +1,125 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import java.util.Collection;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.Set;
+
+import javax.xml.ws.LogicalMessage;
+import javax.xml.ws.handler.LogicalMessageContext;
+import javax.xml.ws.handler.MessageContext.Scope;
+import javax.xml.ws.handler.MessageContext;
+
+/**
+ * Implementation of LogicalMessageContext. This class is used at runtime
+ * to pass to the handlers for processing logical messages.
+ *
+ * <p>Class has to defer information to HandlerContext so that properties
+ * are shared between this and SOAPMessageContext.
+ *
+ * @see MessageContextImpl
+ *
+ * @author WS Development Team
+ */
+public class LogicalMessageContextImpl implements LogicalMessageContext {
+
+    SOAPHandlerContext handlerCtxt;
+    MessageContext ctxt;
+
+    public LogicalMessageContextImpl(SOAPHandlerContext handlerCtxt) {
+        this.handlerCtxt = handlerCtxt;
+        ctxt = handlerCtxt.getMessageContext();
+    }
+
+    public HandlerContext getHandlerContext() {
+        return handlerCtxt;
+    }
+
+    public LogicalMessage getMessage() {
+        return new LogicalMessageImpl(handlerCtxt);
+    }
+
+    public void setScope(String name, Scope scope) {
+        ctxt.setScope(name, scope);
+    }
+
+    public Scope getScope(String name) {
+        return ctxt.getScope(name);
+    }
+
+    /* java.util.Map methods below here */
+
+    public void clear() {
+        ctxt.clear();
+    }
+
+    public boolean containsKey(Object obj) {
+        return ctxt.containsKey(obj);
+    }
+
+    public boolean containsValue(Object obj) {
+        return ctxt.containsValue(obj);
+    }
+
+    public Set<Entry<String, Object>> entrySet() {
+        return ctxt.entrySet();
+    }
+
+    public Object get(Object obj) {
+        return ctxt.get(obj);
+    }
+
+    public boolean isEmpty() {
+        return ctxt.isEmpty();
+    }
+
+    public Set<String> keySet() {
+        return ctxt.keySet();
+    }
+
+    public Object put(String str, Object obj) {
+        return ctxt.put(str, obj);
+    }
+
+    public void putAll(Map<? extends String, ? extends Object> map) {
+        ctxt.putAll(map);
+    }
+
+    public Object remove(Object obj) {
+        return ctxt.remove(obj);
+    }
+
+    public int size() {
+        return ctxt.size();
+    }
+
+    public Collection<Object> values() {
+        return ctxt.values();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/LogicalMessageImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/LogicalMessageImpl.java
new file mode 100644
index 0000000..8f412de
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/LogicalMessageImpl.java
@@ -0,0 +1,209 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBeanInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBTypeSerializer;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import java.util.Iterator;
+import javax.xml.soap.SOAPElement;
+import org.w3c.dom.Node;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.ws.LogicalMessage;
+import javax.xml.ws.WebServiceException;
+
+/**
+ * Implementation of LogicalMessage. This class implements the methods
+ * used by LogicalHandlers to get/set the request or response either
+ * as a JAXB object or as javax.xml.transform.Source.
+ *
+ * <p>The {@link HandlerContext} that is passed into the constructor
+ * is used to retrieve the payload of the request or response.
+ *
+ * @see HandlerContext
+ * @see LogicalMessageContextImpl
+ *
+ * @author WS Development Team
+ */
+public class LogicalMessageImpl implements LogicalMessage {
+
+    private SOAPHandlerContext ctxt;
+
+    public LogicalMessageImpl(SOAPHandlerContext ctxt) {
+        this.ctxt = ctxt;
+    }
+
+    /*
+     * If the payload is DOMSource, return it
+     * If the payload is Source/SOAPFaultInfo/JAXBBridgeInfo/JAXBBeanInfo,
+     * convert to DOMSource and return it. DOMSource is also stored in BodyBlock
+     */
+    public Source getPayload() {
+        try {
+            InternalMessage internalMessage = ctxt.getInternalMessage();
+            if (internalMessage == null) {
+                SOAPMessage soapMessage = ctxt.getSOAPMessage();
+                if (soapMessage == null) {
+                    return null;
+                } else {
+                    Iterator it = soapMessage.getSOAPBody().getChildElements();
+                    SOAPElement elem = null;
+                    while(it.hasNext()) {
+                        Node child = (Node)it.next();
+                        if (child instanceof SOAPElement) {
+                            elem = (SOAPElement)child;
+                            break;
+                        }
+                    }
+                    if (elem != null) {
+                        setSource(new DOMSource(elem));
+                    } else {
+                        return null;
+                    }
+                }
+            }
+            internalMessage = ctxt.getInternalMessage();
+            BodyBlock bodyBlock = internalMessage.getBody();
+            if (bodyBlock == null) {
+                return null;
+            } else {
+                Object obj = bodyBlock.getValue();
+                if (obj instanceof DOMSource) {
+                    return (Source)obj;
+                } else if (obj instanceof Source) {
+                    Source source = (Source)obj;
+                    Transformer transformer = XmlUtil.newTransformer();
+                    DOMResult domResult = new DOMResult();
+                    transformer.transform(source, domResult);
+                    DOMSource domSource = new DOMSource(domResult.getNode());
+                    bodyBlock.setSource(domSource);
+                    return domSource;
+                } else if (obj instanceof JAXBBridgeInfo) {
+                    MessageInfo messageInfo = ctxt.getMessageInfo();
+                    SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+                    SOAPEncoder encoder = eptf.getSOAPEncoder();
+                    DOMSource domSource = encoder.toDOMSource((JAXBBridgeInfo)obj, messageInfo);
+                    bodyBlock.setSource(domSource);
+                    return domSource;
+                } else if (obj instanceof JAXBBeanInfo) {
+                    DOMSource domSource = ((JAXBBeanInfo)obj).toDOMSource();
+                    bodyBlock.setSource(domSource);
+                    return domSource;
+                } else if (obj instanceof RpcLitPayload) {
+                    MessageInfo messageInfo = ctxt.getMessageInfo();
+                    SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+                    SOAPEncoder encoder = eptf.getSOAPEncoder();
+                    DOMSource domSource = encoder.toDOMSource((RpcLitPayload)obj, messageInfo);
+                    bodyBlock.setSource(domSource);
+                    return domSource;
+                } else if (obj instanceof SOAPFaultInfo) {
+                    MessageInfo messageInfo = ctxt.getMessageInfo();
+                    SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+                    SOAPEncoder encoder = eptf.getSOAPEncoder();
+                    DOMSource domSource = encoder.toDOMSource((SOAPFaultInfo)obj, messageInfo);
+                    bodyBlock.setSource(domSource);
+                    return domSource;
+                } else {
+                    throw new WebServiceException("Unknown type "+obj.getClass()+" in BodyBlock");
+                }
+            }
+        } catch(TransformerException te) {
+            throw new WebServiceException(te);
+        } catch(SOAPException se) {
+            throw new WebServiceException(se);
+        }
+    }
+
+    /*
+     * Sets the Source as payload in the BodyBlock of InternalMessage.
+     */
+    public void setPayload(Source source) {
+        setSource(source);
+    }
+
+    /*
+     * Converts to DOMSource and keeps it in BodyBlock. Then it unmarshalls this
+     * DOMSource to a jaxb object. Any changes done in jaxb object are lost if
+     * the object isn't set again.
+     */
+    public Object getPayload(JAXBContext jaxbContext) {
+        return JAXBTypeSerializer.deserialize(getPayload(), jaxbContext);
+    }
+
+    /*
+     * The object is marshalled into DOMSource and stored in BodyBlock. If an
+     * error occurs when using the supplied JAXBContext to marshall the
+     * payload, it throws a JAXWSException.
+     */
+    public void setPayload(Object bean, JAXBContext jaxbContext) {
+        Source source;
+        try {
+            source = JAXBTypeSerializer.serialize(bean,jaxbContext);
+        } catch(Exception e) {
+            throw new WebServiceException(e);
+        }
+        setSource(source);              // set Source in BodyBlock
+    }
+
+    public HandlerContext getHandlerContext() {
+        return ctxt;
+    }
+
+    /*
+     * It stores Source in the BodyBlock. If necessary, it creates
+     * InternalMessage, and BodyBlock
+     */
+    private void setSource(Source source) {
+        InternalMessage internalMessage = ctxt.getInternalMessage();
+        if (internalMessage == null) {
+            internalMessage = new InternalMessage();
+            ctxt.setInternalMessage(internalMessage);
+        }
+        BodyBlock bodyBlock = internalMessage.getBody();
+        if (bodyBlock == null) {
+            bodyBlock = new BodyBlock(source);
+            internalMessage.setBody(bodyBlock);
+        } else {
+            bodyBlock.setSource(source);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/MessageContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/MessageContextImpl.java
new file mode 100644
index 0000000..10006c9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/MessageContextImpl.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import java.util.HashMap;
+
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.handler.MessageContext.Scope;
+
+/**
+ * Implementation of MessageContext. This class holds properties as
+ * well as keeping track of their scope.
+ *
+ * @author WS Development Team
+ */
+public class MessageContextImpl extends HashMap<String, Object>
+    implements MessageContext {
+
+    private HashMap<String, Scope> propertyScopes =
+        new HashMap<String, Scope>();
+
+
+    public void setScope(String name, Scope scope) {
+        if (!this.containsKey(name)) {
+            throw new IllegalArgumentException("Illegal use of setScope() on " +
+                    "non-existant property :"+ name);
+        }
+        propertyScopes.put(name, scope);
+    }
+
+    public Scope getScope(String name) {
+        if (!this.containsKey(name)) {
+            throw new IllegalArgumentException("Illegal use of getScope() on " +
+                    "non-existant property :"+ name);
+        }
+        Scope scope = propertyScopes.get(name);
+        if (scope == null) {
+            scope = Scope.HANDLER; // the default
+        }
+        return scope;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/MessageContextUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/MessageContextUtil.java
new file mode 100644
index 0000000..f19f0e4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/MessageContextUtil.java
@@ -0,0 +1,151 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import com.sun.net.httpserver.HttpExchange;
+import com.sun.xml.internal.ws.developer.JAXWSProperties;
+import com.sun.xml.internal.ws.encoding.soap.internal.AttachmentBlock;
+import com.sun.xml.internal.ws.util.ByteArrayDataSource;
+
+import static com.sun.xml.internal.ws.handler.HandlerChainCaller.IGNORE_FAULT_PROPERTY;
+
+import java.util.List;
+import java.util.Map;
+import java.util.HashMap;
+import java.util.Iterator;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.handler.MessageContext.Scope;
+import javax.xml.namespace.QName;
+import javax.xml.soap.AttachmentPart;
+import javax.xml.soap.SOAPException;
+import javax.activation.DataHandler;
+
+
+/**
+ * Utility to manipulate MessageContext properties
+ *
+ * @author WS Development Team
+ */
+public class MessageContextUtil {
+
+    public static Integer getHttpStatusCode(MessageContext ctxt) {
+        return (Integer)ctxt.get(MessageContext.HTTP_RESPONSE_CODE);
+    }
+
+    public static void setHttpStatusCode(MessageContext ctxt, Integer code) {
+        ctxt.put(MessageContext.HTTP_RESPONSE_CODE, code);
+        ctxt.setScope(MessageContext.HTTP_RESPONSE_CODE, Scope.APPLICATION);
+    }
+
+    public static void setQueryString(MessageContext ctxt, String queryString) {
+        ctxt.put(MessageContext.QUERY_STRING, queryString);
+        ctxt.setScope(MessageContext.QUERY_STRING, Scope.APPLICATION);
+    }
+
+    public static void setPathInfo(MessageContext ctxt, String pathInfo) {
+        ctxt.put(MessageContext.PATH_INFO, pathInfo);
+        ctxt.setScope(MessageContext.PATH_INFO, Scope.APPLICATION);
+    }
+
+    public static void setHttpExchange(MessageContext ctxt, HttpExchange exch) {
+        ctxt.put(JAXWSProperties.HTTP_EXCHANGE, exch);
+        ctxt.setScope(JAXWSProperties.HTTP_EXCHANGE, Scope.APPLICATION);
+    }
+
+    public static HttpExchange getHttpExchange(MessageContext ctxt) {
+        return (HttpExchange)ctxt.get(JAXWSProperties.HTTP_EXCHANGE);
+    }
+
+    public static void setHttpRequestMethod(MessageContext ctxt, String method) {
+        ctxt.put(MessageContext.HTTP_REQUEST_METHOD, method);
+        ctxt.setScope(MessageContext.HTTP_REQUEST_METHOD, Scope.APPLICATION);
+    }
+
+    public static void setHttpRequestHeaders(MessageContext ctxt,
+            Map<String, List<String>> headers) {
+        ctxt.put(MessageContext.HTTP_REQUEST_HEADERS, headers);
+        ctxt.setScope(MessageContext.HTTP_REQUEST_HEADERS, Scope.APPLICATION);
+    }
+
+    public static void setHttpResponseHeaders(MessageContext ctxt,
+            Map<String, List<String>> headers) {
+        ctxt.put(MessageContext.HTTP_RESPONSE_HEADERS, headers);
+        ctxt.setScope(MessageContext.HTTP_RESPONSE_HEADERS, Scope.APPLICATION);
+    }
+
+    public static Map<String, List<String>> getHttpResponseHeaders(MessageContext ctxt) {
+        return (Map<String, List<String>>)ctxt.get(MessageContext.HTTP_RESPONSE_HEADERS);
+    }
+
+    public static void setWsdlOperation(MessageContext ctxt, QName name) {
+        ctxt.put(MessageContext.WSDL_OPERATION, name);
+        ctxt.setScope(MessageContext.WSDL_OPERATION, Scope.APPLICATION);
+    }
+
+    private static Map<String, DataHandler> getMessageAttachments(MessageContext ctxt) {
+        String property = MessageContext.INBOUND_MESSAGE_ATTACHMENTS;
+        Boolean out = (Boolean)ctxt.get(MessageContext.MESSAGE_OUTBOUND_PROPERTY);
+        if (out != null && out) {
+            property = MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS;
+        }
+
+        Object att = ctxt.get(property);
+        if(att == null){
+            Map<String, DataHandler> attMap = new HashMap<String, DataHandler>();
+            ctxt.put(property, attMap);
+            ctxt.setScope(property, Scope.APPLICATION);
+            return attMap;
+        }
+        return (Map<String, DataHandler>)att;
+    }
+
+    public static void copyInboundMessageAttachments(MessageContext ctxt, Iterator<AttachmentPart> attachments) throws SOAPException {
+        Map<String, DataHandler> attachMap = getMessageAttachments(ctxt);
+        while(attachments.hasNext()){
+            AttachmentPart ap = attachments.next();
+            DataHandler dh = new DataHandler(new ByteArrayDataSource(ap.getRawContentBytes(), ap.getContentType()));
+            attachMap.put(ap.getContentId(), dh);
+        }
+    }
+
+    public static void addMessageAttachment(MessageContext ctxt, String cid, DataHandler dh){
+        Map<String, DataHandler> attachMap = getMessageAttachments(ctxt);
+        attachMap.put(cid, dh);
+    }
+
+    /*
+     * See HandlerChainCaller for full details. When a ProtocolException
+     * is caught from the handler chain, this method is used to tell
+     * the runtime whether to use the fault in the current message or
+     * use the exception and create a new message.
+     */
+    public static boolean ignoreFaultInMessage(MessageContext context) {
+        if (context.get(IGNORE_FAULT_PROPERTY) == null) {
+            return false;
+        }
+        return (Boolean) context.get(IGNORE_FAULT_PROPERTY);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/PortInfoImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/PortInfoImpl.java
new file mode 100644
index 0000000..eb4cbb7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/PortInfoImpl.java
@@ -0,0 +1,120 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.handler.PortInfo;
+
+/**
+ * <p>Implementation of the PortInfo interface. This is just a simple
+ * class used to hold the info necessary to uniquely identify a port,
+ * including the port name, service name, and binding ID. This class
+ * is only used on the client side.
+ *
+ * <p>An instance is created by
+ * {@link com.sun.xml.internal.ws.client.ServiceContextBuilder} when used to
+ * place a handler chain into the HandlerResolver map. Another is
+ * created later by
+ * {@link com.sun.xml.internal.ws.client.WSServiceDelegate} to retrieve the
+ * necessary handler chain to set on a binding instance.
+ *
+ * @see com.sun.xml.internal.ws.client.ServiceContextBuilder
+ * @see com.sun.xml.internal.ws.client.WSServiceDelegate
+ * @see HandlerResolverImpl
+ *
+ * @author WS Development Team
+ */
+public class PortInfoImpl implements PortInfo {
+
+    private String bindingId;
+    private QName portName;
+    private QName serviceName;
+
+    /**
+     * The class is constructed with the information needed to identify
+     * a port. This information cannot be changed later.
+     *
+     * @param bindingId The binding ID string.
+     * @param portName The QName of the port.
+     * @param serviceName The QName of the service.
+     */
+    public PortInfoImpl(String bindingId, QName portName, QName serviceName) {
+        if (bindingId == null) {
+            throw new RuntimeException("bindingId cannot be null");
+        }
+        if (portName == null) {
+            throw new RuntimeException("portName cannot be null");
+        }
+        if (serviceName == null) {
+            throw new RuntimeException("serviceName cannot be null");
+        }
+        this.bindingId = bindingId;
+        this.portName = portName;
+        this.serviceName = serviceName;
+    }
+
+    public String getBindingID() {
+        return bindingId;
+    }
+
+    public QName getPortName() {
+        return portName;
+    }
+
+    public QName getServiceName() {
+        return serviceName;
+    }
+
+    /**
+     * Object.equals is overridden here so that PortInfo objects
+     * can be compared when using them as keys in the map in
+     * HandlerResolverImpl. This method relies on the equals()
+     * methods of java.lang.String and javax.xml.namespace.QName.
+     *
+     * @param obj The PortInfo object to test for equality.
+     * @return True if they match, and false if they do not or
+     * if the object passed in is not a PortInfo.
+     */
+    public boolean equals(Object obj) {
+        if (obj instanceof PortInfo) {
+            PortInfo info = (PortInfo) obj;
+            if (bindingId.equals(info.getBindingID()) &&
+                portName.equals(info.getPortName()) &&
+                serviceName.equals(info.getServiceName())) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    /**
+     * Needed so PortInfoImpl can be used as a key in a map. This
+     * method just delegates to the hashCode method of java.lang.String.
+     */
+    public int hashCode() {
+        return bindingId.hashCode();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SHDSOAPMessageContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SHDSOAPMessageContext.java
new file mode 100644
index 0000000..1d6a8f0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SHDSOAPMessageContext.java
@@ -0,0 +1,116 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+import java.util.List;
+import com.sun.xml.internal.ws.spi.runtime.MessageContext;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.spi.runtime.InternalSoapEncoder;
+import com.sun.xml.internal.ws.spi.runtime.Invoker;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+
+import java.lang.reflect.Method;
+
+/**
+ * Implementation of SOAPMessageContext. This class is used at runtime
+ * to pass to the handlers for processing soap messages.
+ *
+ * @see MessageContextImpl
+ *
+ * @author WS Development Team
+ */
+public class SHDSOAPMessageContext extends SOAPMessageContextImpl implements com.sun.xml.internal.ws.spi.runtime.SOAPMessageContext {
+
+    SOAPHandlerContext handlerCtxt;
+
+    public SHDSOAPMessageContext(SOAPHandlerContext handlerCtxt) {
+        super(handlerCtxt);
+        this.handlerCtxt = handlerCtxt;
+    }
+
+    /**
+     * If there is a SOAPMessage already, use getSOAPMessage(). Ignore all other
+     * methods
+     */
+    public boolean isAlreadySoap() {
+        return handlerCtxt.getSOAPMessage() != null;
+    }
+
+    /*
+     * Returns InternalMessage's BodyBlock value
+     */
+    public Object getBody() {
+        return handlerCtxt.getBody();
+    }
+
+    /*
+     * Returns InternalMessage's HeaderBlock values
+     */
+    public List getHeaders() {
+        return handlerCtxt.getHeaders();
+    }
+
+    /*
+     * Use this MessageInfo to pass to InternalSoapEncoder write methods
+     */
+    public Object getMessageInfo() {
+        return handlerCtxt.getMessageInfo();
+    }
+
+    /*
+     * Encoder to marshall all JAXWS objects: RpcLitPayload, JAXBBridgeInfo etc
+     */
+    public InternalSoapEncoder getEncoder() {
+        return (InternalSoapEncoder)((SOAPEPTFactory)handlerCtxt.getMessageInfo().getEPTFactory()).getSOAPEncoder();
+    }
+
+    public String getBindingId() {
+        return handlerCtxt.getBindingId();
+    }
+
+    public Method getMethod() {
+        return handlerCtxt.getMethod();
+    }
+
+    public void setCanonicalization(String algorithm) {
+        handlerCtxt.setCanonicalization(algorithm);
+    }
+
+    public Invoker getInvoker() {
+        return handlerCtxt.getInvoker();
+    }
+
+    /**
+     * Returns if MTOM is anbled
+     *
+     * @return true if MTOM is enabled otherwise returns false;
+     */
+    public boolean isMtomEnabled() {
+        JAXWSAttachmentMarshaller am = MessageInfoUtil.getAttachmentMarshaller(handlerCtxt.getMessageInfo());
+        return (am != null)?am.isXOPPackage():false;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SOAPHandlerContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SOAPHandlerContext.java
new file mode 100644
index 0000000..123cd2d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SOAPHandlerContext.java
@@ -0,0 +1,112 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import javax.xml.ws.handler.LogicalMessageContext;
+import javax.xml.soap.SOAPMessage;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.spi.runtime.Invoker;
+import javax.xml.ws.handler.soap.SOAPMessageContext;
+
+/**
+ * The HandlerContext is used in the client and server runtime
+ * in {@link com.sun.xml.internal.ws.protocol.soap.client.SOAPMessageDispatcher} and
+ * {@link com.sun.xml.internal.ws.protocol.soap.server.SOAPMessageDispatcher} to hold
+ * information about the current message.
+ *
+ * <p>It stores a {@link com.sun.xml.internal.ws.pept.ept.MessageInfo} and
+ * {@link com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage}
+ * which are used by the rest of the runtime, and provides a bridge
+ * between these and the soap and logical message contexts that
+ * are used by the handlers.
+ *
+ * @see LogicalMessageContextImpl
+ * @see MessageContextImpl
+ * @see SOAPMessageContextImpl
+ *
+ * @author WS Development Team
+ */
+public class SOAPHandlerContext extends HandlerContext {
+
+    private SOAPMessage soapMessage;
+    private SOAPMessageContext soapContext;
+    private SHDSOAPMessageContext shdsoapContext;
+    private LogicalMessageContext logicalContext;
+
+    public SOAPHandlerContext(MessageInfo messageInfo,
+            InternalMessage internalMessage,
+            SOAPMessage soapMessage) {
+        super(messageInfo, internalMessage);
+        this.soapMessage = soapMessage;
+    }
+
+    public SOAPMessageContext getSOAPMessageContext() {
+        if (soapContext == null) {
+            soapContext = new SOAPMessageContextImpl(this);
+        }
+        return soapContext;
+    }
+
+    public SHDSOAPMessageContext getSHDSOAPMessageContext() {
+        if (shdsoapContext == null) {
+            shdsoapContext = new SHDSOAPMessageContext(this);
+        }
+        return shdsoapContext;
+    }
+
+    public LogicalMessageContext getLogicalMessageContext() {
+        if (logicalContext == null) {
+            logicalContext = new LogicalMessageContextImpl(this);
+        }
+        return logicalContext;
+    }
+
+
+    /**
+     * @return Returns the soapMessage.
+     */
+    public SOAPMessage getSOAPMessage() {
+        return soapMessage;
+    }
+
+
+    /**
+     * @param soapMessage The soapMessage to set.
+     */
+    public void setSOAPMessage(SOAPMessage soapMessage) {
+        this.soapMessage = soapMessage;
+    }
+
+    /**
+     * If there is a SOAPMessage already, use getSOAPMessage(). Ignore all other
+     * methods
+     */
+    public boolean isAlreadySoap() {
+        return getSOAPMessage() != null;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SOAPMessageContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SOAPMessageContextImpl.java
new file mode 100644
index 0000000..44c9996
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/SOAPMessageContextImpl.java
@@ -0,0 +1,224 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBeanInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBTypeSerializer;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.namespace.QName;
+import javax.xml.soap.Name;
+import javax.xml.soap.SOAPFactory;
+import javax.xml.soap.SOAPHeader;
+import javax.xml.soap.SOAPHeaderElement;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.transform.Source;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.handler.soap.SOAPMessageContext;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import org.xml.sax.InputSource;
+
+/**
+ * Implementation of SOAPMessageContext. This class is used at runtime
+ * to pass to the handlers for processing soap messages.
+ *
+ * @see MessageContextImpl
+ *
+ * @author WS Development Team
+ */
+public class SOAPMessageContextImpl implements SOAPMessageContext {
+
+    private SOAPHandlerContext handlerCtxt;
+    private MessageContext ctxt;
+    private Set<String> roles;
+    private static Map<String, Class> allowedTypes = null;
+    private boolean failure;
+
+    public SOAPMessageContextImpl(SOAPHandlerContext handlerCtxt) {
+        this.handlerCtxt = handlerCtxt;
+        this.ctxt = handlerCtxt.getMessageContext();
+        if (allowedTypes == null) {
+            allowedTypes = new HashMap<String, Class>();
+            allowedTypes.put(MessageContext.INBOUND_MESSAGE_ATTACHMENTS, Map.class);
+            allowedTypes.put(MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS, Map.class);
+            allowedTypes.put(MessageContext.WSDL_DESCRIPTION, InputSource.class);
+            allowedTypes.put(MessageContext.WSDL_SERVICE, QName.class);
+            allowedTypes.put(MessageContext.WSDL_PORT, QName.class);
+            allowedTypes.put(MessageContext.WSDL_INTERFACE, QName.class);
+            allowedTypes.put(MessageContext.WSDL_OPERATION, QName.class);
+            allowedTypes.put(MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.class);
+        }
+    }
+
+    public SOAPMessage getMessage() {
+        SOAPMessage soap = handlerCtxt.getSOAPMessage();
+        InternalMessage intr = handlerCtxt.getInternalMessage();
+        if (intr == null && soap != null) {
+            // Not much to do
+        } else if (intr != null && soap != null) {
+            // Overlay BodyBlock of InternalMessage on top of existing SOAPMessage
+            MessageInfo messageInfo = handlerCtxt.getMessageInfo();
+            SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+            soap = eptf.getSOAPEncoder().toSOAPMessage(intr, soap);
+            setMessage(soap);        // It also sets InernalMessage to null
+        } else if (intr != null && soap == null) {
+            // Convert InternalMessage to a SOAPMessage
+            MessageInfo messageInfo = handlerCtxt.getMessageInfo();
+            SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+            soap = eptf.getSOAPEncoder().toSOAPMessage(intr, messageInfo);
+            setMessage(soap);        // It also sets InernalMessage to null
+        } else {
+            throw new WebServiceException("Don't have SOAPMessage");
+        }
+        return soap;
+    }
+
+    public void setMessage(SOAPMessage soapMessage) {
+        handlerCtxt.setSOAPMessage(soapMessage);
+        // current InternalMessage is not valid anymore. So reset it.
+        handlerCtxt.setInternalMessage(null);
+    }
+
+
+    public Object[] getHeaders(QName header, JAXBContext jaxbContext, boolean allRoles) {
+        try {
+            List beanList = new ArrayList();
+            SOAPMessage msg = getMessage();
+            SOAPHeader sHeader = msg.getSOAPHeader();
+            if (sHeader == null) {
+                return new Object[0];
+            }
+            Iterator i = sHeader.getChildElements(header);
+            while(i.hasNext()) {
+                SOAPHeaderElement child = (SOAPHeaderElement)i.next();
+                if(allRoles) {
+                    //If allRoles is true, add all headers
+                    Source source = new DOMSource(child);
+                    beanList.add(JAXBTypeSerializer.deserialize(source, jaxbContext));
+                } else {
+                    //If allRoles is false, add only headers with matching roles and headers with no role
+                    if( (child.getActor() == null)||
+                        (getRoles().contains(child.getActor()))  ) {
+                        Source source = new DOMSource(child);
+                        beanList.add(JAXBTypeSerializer.deserialize(source, jaxbContext));
+                    }
+                }
+            }
+            return beanList.toArray();
+        } catch(Exception e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    public Set<String> getRoles() {
+        return roles;
+    }
+
+    void setRoles(Set<String> roles) {
+        this.roles = roles;
+    }
+
+    private boolean validateProperty(String name, Object value) {
+        if (allowedTypes.containsKey(name)) {
+            Class clazz = allowedTypes.get(name);
+            if (!(clazz.isInstance(value)))
+                throw new HandlerException("handler.messageContext.invalid.class",
+                        new Object[] { value, name });
+        }
+
+        return true;
+    }
+
+    public void setScope(String name, Scope scope) {
+        ctxt.setScope(name, scope);
+    }
+
+    public Scope getScope(String name) {
+        return ctxt.getScope(name);
+    }
+
+    /* java.util.Map methods below here */
+
+    public void clear() {
+        ctxt.clear();
+    }
+
+    public boolean containsKey(Object obj) {
+        return ctxt.containsKey(obj);
+    }
+
+    public boolean containsValue(Object obj) {
+        return ctxt.containsValue(obj);
+    }
+
+    public Set<Entry<String, Object>> entrySet() {
+        return ctxt.entrySet();
+    }
+
+    public Object get(Object obj) {
+        return ctxt.get(obj);
+    }
+
+    public boolean isEmpty() {
+        return ctxt.isEmpty();
+    }
+
+    public Set<String> keySet() {
+        return ctxt.keySet();
+    }
+
+    public Object put(String str, Object obj) {
+        return ctxt.put(str, obj);
+    }
+
+    public void putAll(Map<? extends String, ? extends Object> map) {
+        ctxt.putAll(map);
+    }
+
+    public Object remove(Object obj) {
+        return ctxt.remove(obj);
+    }
+
+    public int size() {
+        return ctxt.size();
+    }
+
+    public Collection<Object> values() {
+        return ctxt.values();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLHandlerContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLHandlerContext.java
new file mode 100644
index 0000000..bd6d48c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLHandlerContext.java
@@ -0,0 +1,124 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import com.sun.xml.internal.ws.spi.runtime.Invoker;
+import java.util.Collection;
+import java.util.Map;
+import java.util.Set;
+import javax.xml.ws.handler.LogicalMessageContext;
+import com.sun.xml.internal.ws.spi.runtime.MessageContext;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.xml.XMLMessage;
+import java.lang.reflect.Method;
+
+
+/**
+ * Version of {@link HandlerContext} for XML/HTTP binding that
+ * only deals with logical messages.
+ *
+ * <p>Class has to defer information to HandlerContext so that properties
+ * are shared between this and SOAPMessageContext.
+ *
+ * @see HandlerContext
+ *
+ * @author WS Development Team
+ * @author WS Development Team
+ */
+public class XMLHandlerContext extends HandlerContext {
+
+    private XMLMessage xmlMessage;
+    private LogicalMessageContext logicalContext;
+    private SHDXMLMessageContext shdXmlContext;
+
+    public XMLHandlerContext(MessageInfo messageInfo,
+            InternalMessage internalMessage,
+            XMLMessage xmlMessage) {
+        super(messageInfo, internalMessage);
+        this.xmlMessage = xmlMessage;
+    }
+
+    public LogicalMessageContext getLogicalMessageContext() {
+        if (logicalContext == null) {
+            logicalContext = new XMLLogicalMessageContextImpl(this);
+        }
+        return logicalContext;
+    }
+
+    /**
+     * @return Returns XMLMessage
+     */
+    public XMLMessage getXMLMessage() {
+        return xmlMessage;
+    }
+
+    /**
+     * @param xmlMessage The xmlMessage to set.
+     */
+    public void setXMLMessage(XMLMessage xmlMessage) {
+        this.xmlMessage = xmlMessage;
+    }
+
+    public SHDXMLMessageContext getSHDXMLMessageContext() {
+        if (shdXmlContext == null) {
+            shdXmlContext = new SHDXMLMessageContext(this);
+        }
+        return shdXmlContext;
+    }
+
+    private static class SHDXMLMessageContext extends XMLLogicalMessageContextImpl implements com.sun.xml.internal.ws.spi.runtime.MessageContext {
+
+        XMLHandlerContext handlerCtxt;
+
+        public SHDXMLMessageContext(XMLHandlerContext handlerCtxt) {
+            super(handlerCtxt);
+            this.handlerCtxt = handlerCtxt;
+        }
+
+        public String getBindingId() {
+            return handlerCtxt.getBindingId();
+        }
+
+        public Method getMethod() {
+            return handlerCtxt.getMethod();
+        }
+
+        public void setCanonicalization(String algorithm) {
+            handlerCtxt.setCanonicalization(algorithm);
+        }
+
+        public Invoker getInvoker() {
+            return handlerCtxt.getInvoker();
+        }
+
+        public boolean isMtomEnabled() {
+            return false;
+        }
+
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLLogicalMessageContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLLogicalMessageContextImpl.java
new file mode 100644
index 0000000..d9708a8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLLogicalMessageContextImpl.java
@@ -0,0 +1,130 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import java.util.Collection;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.Set;
+
+import javax.xml.ws.LogicalMessage;
+import javax.xml.ws.handler.LogicalMessageContext;
+import javax.xml.ws.handler.MessageContext.Scope;
+import javax.xml.ws.handler.MessageContext;
+
+/**
+ * Implementation of LogicalMessageContext that is used in
+ * the XML/HTTP binding. It is similar to LogicalMessageContextImpl
+ * except that the message impl class it uses is a
+ * {@link XMLLogicalMessageImpl} rather than a
+ * {@link LogicalMessageImpl}.
+ *
+ * <p>Class has to defer information to HandlerContext so that properties
+ * are shared between this and SOAPMessageContext.
+ *
+ * @see LogicalMessageImpl
+ * @see XMLHandlerContext
+ * @see XMLLogicalMessageImpl
+ *
+ * @author WS Development Team
+ */
+public class XMLLogicalMessageContextImpl implements LogicalMessageContext {
+
+    private MessageContext ctxt;
+    private XMLHandlerContext handlerCtxt;
+
+    public XMLLogicalMessageContextImpl(XMLHandlerContext handlerCtxt) {
+        this.handlerCtxt = handlerCtxt;
+        ctxt = handlerCtxt.getMessageContext();
+    }
+
+    public XMLHandlerContext getHandlerContext() {
+        return handlerCtxt;
+    }
+
+    public LogicalMessage getMessage() {
+        return new XMLLogicalMessageImpl(handlerCtxt);
+    }
+
+    public void setScope(String name, Scope scope) {
+        ctxt.setScope(name, scope);
+    }
+
+    public Scope getScope(String name) {
+        return ctxt.getScope(name);
+    }
+
+    /* java.util.Map methods below here */
+
+    public void clear() {
+        ctxt.clear();
+    }
+
+    public boolean containsKey(Object obj) {
+        return ctxt.containsKey(obj);
+    }
+
+    public boolean containsValue(Object obj) {
+        return ctxt.containsValue(obj);
+    }
+
+    public Set<Entry<String, Object>> entrySet() {
+        return ctxt.entrySet();
+    }
+
+    public Object get(Object obj) {
+        return ctxt.get(obj);
+    }
+
+    public boolean isEmpty() {
+        return ctxt.isEmpty();
+    }
+
+    public Set<String> keySet() {
+        return ctxt.keySet();
+    }
+
+    public Object put(String str, Object obj) {
+        return ctxt.put(str, obj);
+    }
+
+    public void putAll(Map<? extends String, ? extends Object> map) {
+        ctxt.putAll(map);
+    }
+
+    public Object remove(Object obj) {
+        return ctxt.remove(obj);
+    }
+
+    public int size() {
+        return ctxt.size();
+    }
+
+    public Collection<Object> values() {
+        return ctxt.values();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLLogicalMessageImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLLogicalMessageImpl.java
new file mode 100644
index 0000000..1d89e5f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/XMLLogicalMessageImpl.java
@@ -0,0 +1,91 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.handler;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.ws.LogicalMessage;
+import javax.xml.transform.Source;
+import com.sun.xml.internal.ws.encoding.xml.XMLMessage;
+
+/**
+ * Implementation of LogicalMessage that is used in the
+ * XML/HTTP binding. It is similar to LogicalMessageImpl
+ * except that the context object passed in is an
+ * {@link XMLHandlerContext} rather than a {@link HandlerContext}.
+ *
+ * @see LogicalMessageImpl
+ * @see XMLHandlerContext
+ * @see XMLLogicalMessageContextImpl
+ *
+ * @author WS Development Team
+ */
+public class XMLLogicalMessageImpl implements LogicalMessage {
+
+    private XMLHandlerContext ctxt;
+
+    public XMLLogicalMessageImpl(XMLHandlerContext ctxt) {
+        this.ctxt = ctxt;
+    }
+
+    /*
+     * Gets the source from XMLMessage. XMLMessage gives a copy of existing
+     * data
+     */
+    public Source getPayload() {
+        XMLMessage xmlMessage = ctxt.getXMLMessage();
+        return xmlMessage.getPayload();
+    }
+
+    /*
+     * Sets the Source as payload in XMLMessage
+     */
+    public void setPayload(Source source) {
+        XMLMessage xmlMessage = ctxt.getXMLMessage();
+        xmlMessage = new XMLMessage(source, xmlMessage.getAttachments(), xmlMessage.useFastInfoset());
+        ctxt.setXMLMessage(xmlMessage);
+    }
+
+    /*
+     * Gets XMLMessage data as JAXB bean
+     */
+    public Object getPayload(JAXBContext jaxbContext) {
+        XMLMessage xmlMessage = ctxt.getXMLMessage();
+        return xmlMessage.getPayload(jaxbContext);
+    }
+
+    /*
+     * Sets JAXB bean into XMLMessage
+     */
+    public void setPayload(Object bean, JAXBContext jaxbContext) {
+        XMLMessage xmlMessage = ctxt.getXMLMessage();
+        xmlMessage = new XMLMessage(bean, jaxbContext, xmlMessage.getAttachments(), xmlMessage.useFastInfoset());
+        ctxt.setXMLMessage(xmlMessage);
+    }
+
+    public XMLHandlerContext getHandlerContext() {
+        return ctxt;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/package-info.java
new file mode 100644
index 0000000..945c7cd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/handler/package-info.java
@@ -0,0 +1,101 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * <h1>JAX-WS 2.0 Handler Runtime</h1>
+ * <p>This document describes the architecture of the handler code
+ * in the JAX-WS 2.0 runtime.
+ *
+ * <p>Handlers may be specified by the deployment descriptor on the
+ * server side, or by a wsdl customization or Java annotation. In the
+ * case of a wsdl customization, wsimport will create the Java interface
+ * with the handler chain annotation and will create a handler xml file
+ * to which the annotation points. At runtime, thus, only deployment
+ * descriptors and handler files pointed to by annotations are parsed.
+ * The schema in all cases is the same, and  @HandlerChainAnnotation is
+ * processed by {@link com.sun.xml.internal.ws.util.HandlerAnnotationProcessor}, which
+ * delegates the parsing of handler configuartion file to
+ * {@link com.sun.xml.internal.ws.handler.HandlerChainsModel} .
+ *
+ * <h3>Server side handler creation</h3>
+ *
+ * <p>The deployment descriptor is first parsed, and
+ * {@link com.sun.xml.internal.ws.transport.http.servlet.RuntimeEndpointInfoParser#setHandlersAndRoles}
+ * parses the handler chains xml in the deployment descriptor if present.
+ * It then sets the handlers and roles on the Binding object that has
+ * already been created. Setting the handler chain on the binding does
+ * not automatically create a handler chain caller.
+ *
+ * <p>Later, when
+ * {@link com.sun.xml.internal.ws.server.RuntimeEndpointInfo#init} is parsing the
+ * annotations it checks for handlers on the binding. If there are handlers
+ * already, it skips any further handler processing. In this way, the deployment
+ * descriptor overrides any other handlers. If there are no handlers on
+ * the binding at this point, RuntimeEndpointInfo has the
+ * HandlerAnnotationProcessor parse the handler chain file and then
+ * sets the handlers and roles on the binding.
+ *
+ * <h3>Client side handler creation</h3>
+ *
+ * <p>On the client side, the @HandlerChain annotation on generated Service
+ * class is processed by {@link com.sun.xml.internal.ws.client.ServiceContextBuilder#build}.
+ * If there is @HandlerChain on service class, the ServiceContextBuilder creates
+ * HandlerResolverImpl from that handler file and sets it on the
+ * {@link com.sun.xml.internal.ws.client.ServiceContext}. @HandlerChain annotations on
+ * the SEIs are ignored on the client-side.
+ *
+ * <p>Unlike the server side, there is no binding object already
+ * created when the handlers are parsed. When a binding provider is created, the
+ * {@link com.sun.xml.internal.ws.client.WSServiceDelegate} will use the handler
+ * registry (which may be the HandlerResolverImpl or another handler
+ * resolver set on the service by the user code) to get the handlers to
+ * set on the binding. It will get the roles from the service context and
+ * set those on the binding if it is a soap binding. The relevant method is
+ * {@link com.sun.xml.internal.ws.client.WSServiceDelegate#setBindingOnProvider}
+ *
+ * <h3>Calling the handlers</h3>
+ *
+ * <p>During a request or response, a
+ * {@link com.sun.xml.internal.ws.handler.HandlerChainCaller} is
+ * created by the binding or may be created by a message dispatcher on the
+ * server side (this happens in the http binding right now). In the binding
+ * objects, the handler caller is not created until needed, and it sets
+ * the handlers and roles (if present) on the handler chain caller then.
+ * See {@link com.sun.xml.internal.ws.binding.BindingImpl#getHandlerChainCaller}
+ * and {@link com.sun.xml.internal.ws.binding.soap.SOAPBindingImpl#getHandlerChainCaller}
+ * for more details.
+ *
+ * <p>The handler chain caller does the handler invocation and controls the
+ * flow of the handlers. For details of the code that calls the handler
+ * chain caller, see
+ * {@link com.sun.xml.internal.ws.protocol.soap.client.SOAPMessageDispatcher}
+ * on the client side and
+ * {@link com.sun.xml.internal.ws.protocol.soap.server.SOAPMessageDispatcher} and
+ * {@link com.sun.xml.internal.ws.protocol.xml.server.XMLMessageDispatcher} on the
+ * server side.
+ *
+ * @ArchitectureDocument
+ */
+package com.sun.xml.internal.ws.handler;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/CheckedException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/CheckedException.java
new file mode 100644
index 0000000..ada952c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/CheckedException.java
@@ -0,0 +1,106 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.model;
+
+import com.sun.xml.internal.bind.api.TypeReference;
+import java.lang.reflect.Type;
+
+/**
+ * CheckedException class. Holds the exception class - class that has public
+ * constructor
+ *
+ * <code>public WrapperException()String message, FaultBean){}</code>
+ *
+ * and method
+ *
+ * <code>public FaultBean getFaultInfo();</code>
+ *
+ * @author Vivek Pandey
+ */
+
+public class CheckedException {
+    /**
+     * @param exceptionClass
+     *            Userdefined or WSDL exception class that extends
+     *            java.lang.Exception.
+     * @param detail
+     *            detail or exception bean's TypeReference
+     * @param exceptionType
+     *            either ExceptionType.UserDefined or
+     *            ExceptionType.WSDLException
+     */
+    public CheckedException(Class exceptionClass, TypeReference detail, ExceptionType exceptionType) {
+        this.detail = detail;
+        this.exceptionType = exceptionType;
+        this.exceptionClass = exceptionClass;
+    }
+
+    /**
+     * @return the <code>Class</clode> for this object
+     *
+     */
+    public Class getExcpetionClass() {
+        return exceptionClass;
+    }
+
+    public Class getDetailBean() {
+        return (Class) detail.type;
+    }
+
+    public TypeReference getDetailType() {
+        return detail;
+    }
+
+    public ExceptionType getExceptionType() {
+        return exceptionType;
+    }
+
+    public void setHeaderFault(boolean hf) {
+        this.headerFault = hf;
+    }
+
+    public boolean isHeaderFault() {
+        return headerFault;
+    }
+
+    public void setMessageName(String messageName) {
+        this.messageName = messageName;
+    }
+
+    public String getMessageName() {
+        return messageName;
+    }
+
+    private Class exceptionClass;
+
+    private TypeReference detail;
+
+    private ExceptionType exceptionType;
+
+    private boolean headerFault = false;
+
+    private String messageName;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/ExceptionType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/ExceptionType.java
new file mode 100644
index 0000000..ff7d1eb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/ExceptionType.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model;
+/**
+ * Type of java exception
+ *
+ * @author Vivek Pandey
+ */
+public enum ExceptionType {
+    WSDLException(0), UserDefined(1);
+
+    ExceptionType(int exceptionType){
+        this.exceptionType = exceptionType;
+    }
+
+    public int value() {
+        return exceptionType;
+    }
+    private final int exceptionType;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/JavaMethod.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/JavaMethod.java
new file mode 100644
index 0000000..f4e998a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/JavaMethod.java
@@ -0,0 +1,236 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model;
+
+import java.lang.reflect.Method;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.ws.model.soap.SOAPBinding;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+
+/**
+ * Build this runtime model using java SEI and annotations
+ *
+ * @author Vivek Pandey
+ */
+public class JavaMethod {
+    /**
+     *
+     */
+    public JavaMethod(Method method) {
+        this.method = method;
+    }
+
+    /**
+     * @return Returns the method.
+     */
+    public Method getMethod() {
+        return method;
+    }
+
+    /**
+     * @return Returns the mep.
+     */
+    public int getMEP() {
+        return mep;
+    }
+
+    /**
+     * @param mep
+     *            The mep to set.
+     */
+    public void setMEP(int mep) {
+        this.mep = mep;
+    }
+
+    /**
+     * @return the Binding object
+     */
+    public Object getBinding() {
+        if (binding == null)
+            return new SOAPBinding();
+        return binding;
+    }
+
+    /**
+     * @param binding
+     */
+    public void setBinding(Object binding) {
+        this.binding = binding;
+    }
+
+
+    public void setOperationName(String operationName) {
+        this.operationName = operationName;
+    }
+
+    public String getOperationName() {
+        return operationName;
+    }
+
+
+
+    /**
+     * @return returns unmodifiable list of request parameters
+     */
+    public List<Parameter> getRequestParameters() {
+        return unmReqParams;
+    }
+
+    /**
+     * @return returns unmodifiable list of response parameters
+     */
+    public List<Parameter> getResponseParameters() {
+        return unmResParams;
+    }
+
+    /**
+     * @param p
+     */
+    public void addParameter(Parameter p) {
+        if (p.isIN() || p.isINOUT()) {
+            if (requestParams.contains(p)) {
+                // TODO throw exception
+            }
+            requestParams.add(p);
+        }
+
+        if (p.isOUT() || p.isINOUT()) {
+            // this check is only for out parameters
+            if (requestParams.contains(p)) {
+                // TODO throw exception
+            }
+            responseParams.add(p);
+        }
+    }
+
+    public void addRequestParameter(Parameter p){
+        if (p.isIN() || p.isINOUT()) {
+            requestParams.add(p);
+        }
+    }
+
+    public void addResponseParameter(Parameter p){
+        if (p.isOUT() || p.isINOUT()) {
+            responseParams.add(p);
+        }
+    }
+
+    /**
+     * @return Returns number of java method parameters - that will be all the
+     *         IN, INOUT and OUT holders
+     */
+    public int getInputParametersCount() {
+        int count = 0;
+        for (Parameter param : requestParams) {
+            if (param.isWrapperStyle()) {
+                count += ((WrapperParameter) param).getWrapperChildren().size();
+            } else {
+                count++;
+            }
+        }
+
+        for (Parameter param : responseParams) {
+            if (param.isWrapperStyle()) {
+                for (Parameter wc : ((WrapperParameter) param).getWrapperChildren()) {
+                    if (!wc.isResponse() && wc.isOUT()) {
+                        count++;
+                    }
+                }
+            } else if (!param.isResponse() && param.isOUT()) {
+                count++;
+            }
+        }
+
+        return count;
+    }
+
+    /**
+     * @param ce
+     */
+    public void addException(CheckedException ce) {
+        if (!exceptions.contains(ce))
+            exceptions.add(ce);
+    }
+
+    /**
+     * @param exceptionClass
+     * @return CheckedException corresponding to the exceptionClass. Returns
+     *         null if not found.
+     */
+    public CheckedException getCheckedException(Class exceptionClass) {
+        for (CheckedException ce : exceptions) {
+            if (ce.getExcpetionClass().equals(exceptionClass))
+                return ce;
+        }
+        return null;
+    }
+
+    /**
+     * @return a list of checked Exceptions thrown by this method
+     */
+    public List<CheckedException> getCheckedExceptions(){
+        return Collections.unmodifiableList(exceptions);
+    }
+    /**
+     * @param detailType
+     * @return Gets the CheckedException corresponding to detailType. Returns
+     *         null if no CheckedExcpetion with the detailType found.
+     */
+    public CheckedException getCheckedException(TypeReference detailType) {
+        for (CheckedException ce : exceptions) {
+            TypeReference actual = ce.getDetailType();
+            if (actual.tagName.equals(detailType.tagName)
+                    && actual.type.getClass().getName()
+                            .equals(detailType.type.getClass().getName())) {
+                return ce;
+            }
+        }
+        return null;
+    }
+
+    /**
+     * Returns if the java method MEP is async
+     * @return if this is an Asynch MEP
+     */
+    public boolean isAsync(){
+        return mep == MessageStruct.ASYNC_CALLBACK_MEP || mep == MessageStruct.ASYNC_POLL_MEP;
+    }
+
+    private List<CheckedException> exceptions = new ArrayList<CheckedException>();
+    private Method method;
+    private final List<Parameter> requestParams = new ArrayList<Parameter>();
+    private final List<Parameter> responseParams = new ArrayList<Parameter>();
+    private final List<Parameter> unmReqParams =
+            Collections.unmodifiableList(requestParams);
+    private final List<Parameter> unmResParams =
+            Collections.unmodifiableList(responseParams);
+    private Object binding;
+    private int mep;
+    private String operationName;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/Mode.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/Mode.java
new file mode 100644
index 0000000..3691fce
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/Mode.java
@@ -0,0 +1,41 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.model;
+
+/**
+ * Defines parameter mode, IN, OUT or INOUT
+ *
+ * @author Vivek Pandey
+ */
+
+public enum Mode {
+    IN(0), OUT(1), INOUT(2);
+
+    private Mode(int mode){
+        this.mode = mode;
+    }
+    private final int mode;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/Parameter.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/Parameter.java
new file mode 100644
index 0000000..b02643a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/Parameter.java
@@ -0,0 +1,199 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.model;
+
+import com.sun.xml.internal.bind.api.TypeReference;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.Holder;
+
+/**
+ * runtime Parameter that abstracts the annotated java parameter
+ *
+ * @author Vivek Pandey
+ */
+
+public class Parameter {
+    /**
+     *
+     */
+    public Parameter(TypeReference type, Mode mode, int index) {
+        this.typeReference = type;
+        this.name = type.tagName;
+        this.mode = mode;
+        this.index = index;
+    }
+
+    /**
+     * @return Returns the name.
+     */
+    public QName getName() {
+        return name;
+    }
+
+    /**
+     * @return Returns the TypeReference associated with this Parameter
+     */
+    public TypeReference getTypeReference() {
+        return typeReference;
+    }
+
+    /**
+     * Sometimes we need to overwrite the typeReferenc, such as during patching for rpclit
+     * @see RuntimeModel#applyParameterBinding(com.sun.xml.internal.ws.wsdl.parser.Binding)
+     */
+
+    void setTypeReference(TypeReference type){
+        typeReference = type;
+        name = type.tagName;
+    }
+
+    /**
+     * @return Returns the mode.
+     */
+    public Mode getMode() {
+        return mode;
+    }
+
+    /**
+     * @return Returns the index.
+     */
+    public int getIndex() {
+        return index;
+    }
+
+    /**
+     * @return WrapperStyle == true
+     */
+    public boolean isWrapperStyle() {
+        return false;
+    }
+
+    /**
+     * @return the Binding for this Parameter
+     */
+    public ParameterBinding getBinding() {
+        if(binding == null)
+            return ParameterBinding.BODY;
+        return binding;
+    }
+
+    /**
+     * @param binding
+     */
+    public void setBinding(ParameterBinding binding) {
+        this.binding = binding;
+    }
+
+    public void setInBinding(ParameterBinding binding){
+        this.binding = binding;
+    }
+
+    public void setOutBinding(ParameterBinding binding){
+        this.outBinding = binding;
+    }
+
+    public ParameterBinding getInBinding(){
+        return binding;
+    }
+
+    public ParameterBinding getOutBinding(){
+        if(outBinding == null)
+            return binding;
+        return outBinding;
+    }
+
+    public boolean isIN() {
+        return mode==Mode.IN;
+    }
+
+    public boolean isOUT() {
+        return mode==Mode.OUT;
+    }
+
+    public boolean isINOUT() {
+        return mode==Mode.INOUT;
+    }
+
+    public boolean isResponse() {
+        return index == -1;
+    }
+
+    /**
+     * Creates a holder if applicable else gives the object as it is. To be
+     * called on the inbound message.
+     *
+     * @param value
+     * @return the non-holder value if its Response or IN otherwise creates a
+     *         holder with the passed value and returns it back.
+     *
+     */
+    public Object createHolderValue(Object value) {
+        if (isResponse() || isIN()) {
+            return value;
+        }
+        return new Holder(value);
+    }
+
+    /**
+     * Gets the holder value if applicable. To be called for inbound client side
+     * message.
+     *
+     * @param obj
+     * @return the holder value if applicable.
+     */
+    public Object getHolderValue(Object obj) {
+        if (obj != null && obj instanceof Holder)
+            return ((Holder) obj).value;
+        return obj;
+    }
+
+    public static void setHolderValue(Object obj, Object value) {
+        if (obj instanceof Holder)
+            ((Holder) obj).value = value;
+        else
+            // TODO: this can't be correct
+            obj = value;
+    }
+
+    public String getPartName() {
+        if(partName == null)
+            return name.getLocalPart();
+        return partName;
+    }
+
+    public void setPartName(String partName) {
+        this.partName = partName;
+    }
+
+    protected ParameterBinding binding;
+    protected ParameterBinding outBinding;
+    protected int index;
+    protected Mode mode;
+    protected TypeReference typeReference;
+    protected QName name;
+    protected String partName;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/ParameterBinding.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/ParameterBinding.java
new file mode 100644
index 0000000..ddc3fbb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/ParameterBinding.java
@@ -0,0 +1,114 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model;
+
+/**
+ * Denotes the binding of a parameter.
+ *
+ * <p>
+ * This is somewhat like an enumeration (but it is <b>NOT</b> an enumeration.)
+ *
+ * <p>
+ * The possible values are
+ * BODY, HEADER, UNBOUND, and ATTACHMENT. BODY, HEADER, and UNBOUND
+ * has a singleton semantics, but there are multiple ATTACHMENT instances
+ * as it carries additional MIME type parameter.
+ *
+ * <p>
+ * So don't use '==' for testing the equality.
+ */
+public final class ParameterBinding {
+    /**
+     * Singleton instance that represents 'BODY'
+     */
+    public static final ParameterBinding BODY = new ParameterBinding("BODY",null);
+    /**
+     * Singleton instance that represents 'HEADER'
+     */
+    public static final ParameterBinding HEADER = new ParameterBinding("HEADER",null);
+    /**
+     * Singleton instance that represents 'UNBOUND',
+     * meaning the parameter doesn't have a representation in a SOAP message.
+     */
+    public static final ParameterBinding UNBOUND = new ParameterBinding("UNBOUND",null);
+    /**
+     * Creates an instance that represents the attachment
+     * with a given MIME type.
+     *
+     * <p>
+     * TODO: shall we consider givint the singleton semantics by using
+     * a cache? It's more elegant to do so, but
+     * no where in JAX-WS RI two {@link ParameterBinding}s are compared today,
+     */
+    public static ParameterBinding createAttachment(String mimeType) {
+        return new ParameterBinding("ATTACHMENT",mimeType);
+    }
+
+
+    private String mimeType;
+    private final String name;
+
+    private ParameterBinding(String name,String mimeType) {
+        this.name = name;
+        this.mimeType = mimeType;
+    }
+
+
+
+    public String toString() {
+        return name;
+    }
+
+    /**
+     * Returns the MIME type associated with this binding.
+     *
+     * @throws IllegalStateException
+     *      if this binding doesn't represent an attachment.
+     *      IOW, if {@link #isAttachment()} returns false.
+     * @return
+     *      Can be null, if the MIME type is not known.
+     */
+    public String getMimeType() {
+        if(!isAttachment())
+            throw new IllegalStateException();
+        return mimeType;
+    }
+
+    public boolean isBody(){
+        return this==BODY;
+    }
+
+    public boolean isHeader(){
+        return this==HEADER;
+    }
+
+    public boolean isUnbound(){
+        return this==UNBOUND;
+    }
+
+    public boolean isAttachment(){
+        return name=="ATTACHMENT";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/RuntimeModel.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/RuntimeModel.java
new file mode 100644
index 0000000..888b233
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/RuntimeModel.java
@@ -0,0 +1,621 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.bind.api.Bridge;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.bind.api.RawAccessor;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentUnmarshaller;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.wsdl.parser.Binding;
+import com.sun.xml.internal.ws.wsdl.parser.Part;
+import com.sun.xml.internal.ws.wsdl.parser.BindingOperation;
+import com.sun.xml.internal.ws.wsdl.writer.WSDLGenerator;
+import com.sun.xml.internal.ws.model.soap.SOAPBinding;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.WebServiceException;
+
+import java.lang.reflect.Method;
+import java.security.AccessController;
+import java.security.PrivilegedActionException;
+import java.security.PrivilegedExceptionAction;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+/**
+ * model of the web service.  Used by the runtime marshall/unmarshall
+ * web service invocations
+ *
+ * $author: JAXWS Development Team
+ */
+public abstract class RuntimeModel {
+
+    /**
+     *
+     */
+    public RuntimeModel() {
+        super();
+        // TODO Auto-generated constructor stub
+    }
+
+    public void postProcess() {
+        // should be called only once.
+        if (jaxbContext != null)
+            return;
+        populateMaps();
+        populateAsyncExceptions();
+        createJAXBContext();
+        createDecoderInfo();
+    }
+
+    /**
+     * Populate methodToJM and nameToJM maps.
+     */
+    protected void populateMaps() {
+        for (JavaMethod jm : getJavaMethods()) {
+            put(jm.getMethod(), jm);
+            for (Parameter p : jm.getRequestParameters()) {
+                put(p.getName(), jm);
+            }
+        }
+    }
+
+    protected void populateAsyncExceptions() {
+        for (JavaMethod jm : getJavaMethods()) {
+            int mep = jm.getMEP();
+            if (mep == MessageInfo.ASYNC_CALLBACK_MEP || mep == MessageInfo.ASYNC_POLL_MEP) {
+                String opName = jm.getOperationName();
+                Method m = jm.getMethod();
+                Class[] params = m.getParameterTypes();
+                if (mep == MessageInfo.ASYNC_CALLBACK_MEP) {
+                    params = new Class[params.length-1];
+                    System.arraycopy(m.getParameterTypes(), 0, params, 0, m.getParameterTypes().length-1);
+                }
+                try {
+                    Method om = m.getDeclaringClass().getMethod(opName, params);
+                    JavaMethod jm2 = getJavaMethod(om);
+                    for (CheckedException ce : jm2.getCheckedExceptions()) {
+                        jm.addException(ce);
+                    }
+                } catch (NoSuchMethodException ex) {
+                }
+            }
+        }
+    }
+
+    /**
+     * @return the <code>BridgeContext</code> for this <code>RuntimeModel</code>
+     */
+    public BridgeContext getBridgeContext() {
+        if (jaxbContext == null)
+            return null;
+        BridgeContext bc = bridgeContext.get();
+        if (bc == null) {
+            bc = jaxbContext.createBridgeContext();
+            bc.setAttachmentMarshaller(new JAXWSAttachmentMarshaller(enableMtom));
+            bc.setAttachmentUnmarshaller(new JAXWSAttachmentUnmarshaller());
+            bridgeContext.set(bc);
+        }
+        return bc;
+    }
+
+    /**
+     * @return the <code>JAXBRIContext</code>
+     */
+    public JAXBRIContext getJAXBContext() {
+        return jaxbContext;
+    }
+
+    /**
+     * @return the known namespaces from JAXBRIContext
+     */
+    public List<String> getKnownNamespaceURIs() {
+        return knownNamespaceURIs;
+    }
+
+    /**
+     * @param type
+     * @return the <code>Bridge</code> for the <code>type</code>
+     */
+    public Bridge getBridge(TypeReference type) {
+        return bridgeMap.get(type);
+    }
+
+    /**
+     * @param name
+     * @return either a <code>RpcLitpayload</code> or a <code>JAXBBridgeInfo</code> for
+     * an operation named <code>name</code>
+     */
+    public Object getDecoderInfo(QName name) {
+        Object obj = payloadMap.get(name);
+        if (obj instanceof RpcLitPayload) {
+            return RpcLitPayload.copy((RpcLitPayload) obj);
+        } else if (obj instanceof JAXBBridgeInfo) {
+            return JAXBBridgeInfo.copy((JAXBBridgeInfo) obj);
+        }
+        return null;
+    }
+
+    /**
+     * @param name
+     * @param payload
+     */
+    public void addDecoderInfo(QName name, Object payload) {
+        payloadMap.put(name, payload);
+    }
+
+    /**
+     * @return
+     */
+    private JAXBRIContext createJAXBContext() {
+        final List<TypeReference> types = getAllTypeReferences();
+        final Class[] cls = new Class[types.size()];
+        final String ns = targetNamespace;
+        int i = 0;
+        for (TypeReference type : types) {
+            cls[i++] = (Class) type.type;
+        }
+        try {
+            //jaxbContext = JAXBRIContext.newInstance(cls, types, targetNamespace, false);
+            // Need to avoid doPriv block once JAXB is fixed. Afterwards, use the above
+            jaxbContext = (JAXBRIContext)
+                 AccessController.doPrivileged(new PrivilegedExceptionAction() {
+                     public java.lang.Object run() throws Exception {
+                         return JAXBRIContext.newInstance(cls, types, ns, false);
+                     }
+                 });
+            createBridgeMap(types);
+        } catch (PrivilegedActionException e) {
+            throw new WebServiceException(e.getMessage(), e.getException());
+        }
+        knownNamespaceURIs = new ArrayList<String>();
+        for (String namespace : jaxbContext.getKnownNamespaceURIs()) {
+            if (namespace.length() > 0) {
+                if (!namespace.equals(SOAPNamespaceConstants.XSD) && !namespace.equals(SOAPNamespaceConstants.XMLNS))
+                    knownNamespaceURIs.add(namespace);
+            }
+        }
+
+        return jaxbContext;
+    }
+
+    /**
+     * @return returns non-null list of TypeReference
+     */
+    public List<TypeReference> getAllTypeReferences() {
+        List<TypeReference> types = new ArrayList<TypeReference>();
+        Collection<JavaMethod> methods = methodToJM.values();
+        for (JavaMethod m : methods) {
+            fillTypes(m, types);
+            fillFaultDetailTypes(m, types);
+        }
+        return types;
+    }
+
+    private void fillFaultDetailTypes(JavaMethod m, List<TypeReference> types) {
+        for (CheckedException ce : m.getCheckedExceptions()) {
+            types.add(ce.getDetailType());
+//            addGlobalType(ce.getDetailType());
+        }
+    }
+
+    protected void fillTypes(JavaMethod m, List<TypeReference> types) {
+        addTypes(m.getRequestParameters(), types);
+        addTypes(m.getResponseParameters(), types);
+    }
+
+    private void addTypes(List<Parameter> params, List<TypeReference> types) {
+        for (Parameter p : params) {
+            types.add(p.getTypeReference());
+        }
+    }
+
+    private void createBridgeMap(List<TypeReference> types) {
+        for (TypeReference type : types) {
+            Bridge bridge = jaxbContext.createBridge(type);
+            bridgeMap.put(type, bridge);
+        }
+    }
+
+    /**
+     * @param qname
+     * @return the <code>Method</code> for a given Operation <code>qname</code>
+     */
+    public Method getDispatchMethod(QName qname) {
+        //handle the empty body
+        if (qname == null)
+            qname = emptyBodyName;
+        JavaMethod jm = getJavaMethod(qname);
+        if (jm != null) {
+            return jm.getMethod();
+        }
+        return null;
+    }
+
+    /**
+     * @param name
+     * @param method
+     * @return true if <code>name</code> is the name
+     * of a known fault name for the <code>Method method</code>
+     */
+    public boolean isKnownFault(QName name, Method method) {
+        JavaMethod m = getJavaMethod(method);
+        for (CheckedException ce : m.getCheckedExceptions()) {
+            if (ce.getDetailType().tagName.equals(name))
+                return true;
+        }
+        return false;
+    }
+
+    /**
+     * @param m
+     * @param ex
+     * @return true if <code>ex</code> is a Checked Exception
+     * for <code>Method m</code>
+     */
+    public boolean isCheckedException(Method m, Class ex) {
+        JavaMethod jm = getJavaMethod(m);
+        for (CheckedException ce : jm.getCheckedExceptions()) {
+            if (ce.getExcpetionClass().equals(ex))
+                return true;
+        }
+        return false;
+    }
+
+    /**
+     * @param method
+     * @return the <code>JavaMethod</code> representing the <code>method</code>
+     */
+    public JavaMethod getJavaMethod(Method method) {
+        return methodToJM.get(method);
+    }
+
+    /**
+     * @param name
+     * @return the <code>JavaMethod</code> associated with the
+     * operation named name
+     */
+    public JavaMethod getJavaMethod(QName name) {
+        return nameToJM.get(name);
+    }
+
+    /**
+     * @param jm
+     * @return the <code>QName</code> associated with the
+     * JavaMethod jm
+     */
+    public QName getQNameForJM(JavaMethod jm) {
+        Set<QName> set = nameToJM.keySet();
+        Iterator iter = set.iterator();
+        while (iter.hasNext()){
+            QName key = (QName) iter.next();
+            JavaMethod jmethod = (JavaMethod) nameToJM.get(key);
+            if (jmethod.getOperationName().equals(jm.getOperationName())){
+               return key;
+            }
+        }
+        return null;
+    }
+
+    /**
+     * @return a <code>Collection</code> of <code>JavaMethods</code>
+     * associated with this <code>RuntimeModel</code>
+     */
+    public Collection<JavaMethod> getJavaMethods() {
+        return Collections.unmodifiableList(javaMethods);
+    }
+
+    public void addJavaMethod(JavaMethod jm) {
+        if (jm != null)
+            javaMethods.add(jm);
+    }
+
+    public void applyParameterBinding(Binding wsdlBinding){
+        if(wsdlBinding == null)
+            return;
+        wsdlBinding.finalizeBinding();
+        for(JavaMethod method : javaMethods){
+            if(method.isAsync())
+                continue;
+            boolean isRpclit = ((SOAPBinding)method.getBinding()).isRpcLit();
+            List<Parameter> reqParams = method.getRequestParameters();
+            List<Parameter> reqAttachParams = null;
+            for(Parameter param:reqParams){
+                if(param.isWrapperStyle()){
+                    if(isRpclit){
+                        WrapperParameter reqParam = (WrapperParameter)param;
+                        BindingOperation bo = wsdlBinding.get(method.getOperationName());
+                        if(bo != null && bo.getRequestNamespace() != null){
+                            patchRpclitNamespace(bo.getRequestNamespace(), reqParam);
+                        }
+                        reqAttachParams = applyRpcLitParamBinding(method, reqParam, wsdlBinding, Mode.IN);
+                    }
+                    continue;
+                }
+                String partName = param.getPartName();
+                if(partName == null)
+                    continue;
+                ParameterBinding paramBinding = wsdlBinding.getBinding(method.getOperationName(),
+                        partName, Mode.IN);
+                if(paramBinding != null)
+                    param.setInBinding(paramBinding);
+            }
+
+            List<Parameter> resAttachParams = null;
+            List<Parameter> resParams = method.getResponseParameters();
+            for(Parameter param:resParams){
+                if(param.isWrapperStyle()){
+                    if(isRpclit){
+                        WrapperParameter respParam = (WrapperParameter)param;
+                        BindingOperation bo = wsdlBinding.get(method.getOperationName());
+                        if(bo != null && bo.getResponseNamespace() != null){
+                            patchRpclitNamespace(bo.getResponseNamespace(), respParam);
+                        }
+                        resAttachParams = applyRpcLitParamBinding(method, respParam, wsdlBinding, Mode.OUT);
+                    }
+                    continue;
+                }
+                //if the parameter is not inout and its header=true then dont get binding from WSDL
+//                if(!param.isINOUT() && param.getBinding().isHeader())
+//                    continue;
+                String partName = param.getPartName();
+                if(partName == null)
+                    continue;
+                ParameterBinding paramBinding = wsdlBinding.getBinding(method.getOperationName(),
+                        partName, Mode.OUT);
+                if(paramBinding != null)
+                    param.setOutBinding(paramBinding);
+            }
+            if(reqAttachParams != null){
+                for(Parameter p : reqAttachParams){
+                    method.addRequestParameter(p);
+                }
+            }
+            if(resAttachParams != null){
+                for(Parameter p : resAttachParams){
+                    method.addResponseParameter(p);
+                }
+            }
+
+        }
+    }
+
+    /**
+     * For rpclit wrapper element inside <soapenv:Body>, the targetNamespace should be taked from
+     * the soapbind:body@namespace value. Since no annotations on SEI/impl class captures it so we
+     * need to get it from WSDL and patch it.     *
+     */
+    private void patchRpclitNamespace(String namespace, WrapperParameter param){
+        TypeReference type = param.getTypeReference();
+        TypeReference newType = new TypeReference(
+                new QName(namespace, type.tagName.getLocalPart()), type.type, type.annotations);
+
+        param.setTypeReference(newType);
+    }
+
+
+
+    /**
+     * Applies binding related information to the RpcLitPayload. The payload map is populated correctly.
+     * @param method
+     * @param wrapperParameter
+     * @param wsdlBinding
+     * @param mode
+     * @return
+     *
+     * Returns attachment parameters if/any.
+     */
+    private List<Parameter> applyRpcLitParamBinding(JavaMethod method, WrapperParameter wrapperParameter, Binding wsdlBinding, Mode mode) {
+        String opName = method.getOperationName();
+        RpcLitPayload payload = new RpcLitPayload(wrapperParameter.getName());
+        BindingOperation bo = wsdlBinding.get(opName);
+
+        Map<Integer, Parameter> bodyParams = new HashMap<Integer, Parameter>();
+        List<Parameter> unboundParams = new ArrayList<Parameter>();
+        List<Parameter> attachParams = new ArrayList<Parameter>();
+        for(Parameter param:wrapperParameter.getWrapperChildren()){
+            String partName = param.getPartName();
+            if(partName == null)
+                continue;
+
+            ParameterBinding paramBinding = wsdlBinding.getBinding(opName,
+                    partName, mode);
+            if(paramBinding != null){
+                if(mode == Mode.IN)
+                    param.setInBinding(paramBinding);
+                else if(mode == Mode.OUT)
+                    param.setOutBinding(paramBinding);
+
+                if(paramBinding.isUnbound()){
+                        unboundParams.add(param);
+                } else if(paramBinding.isAttachment()){
+                    attachParams.add(param);
+                }else if(paramBinding.isBody()){
+                    if(bo != null){
+                        Part p = bo.getPart(param.getPartName(), mode);
+                        if(p != null)
+                            bodyParams.put(p.getIndex(), param);
+                        else
+                            bodyParams.put(bodyParams.size(), param);
+                    }else{
+                        bodyParams.put(bodyParams.size(), param);
+                    }
+                }
+            }
+
+        }
+        wrapperParameter.clear();
+        for(int i = 0; i <  bodyParams.size();i++){
+            Parameter p = bodyParams.get(i);
+            wrapperParameter.addWrapperChild(p);
+            if(((mode == Mode.IN) && p.getInBinding().isBody())||
+                    ((mode == Mode.OUT) && p.getOutBinding().isBody())){
+                JAXBBridgeInfo bi = new JAXBBridgeInfo(getBridge(p.getTypeReference()), null);
+                payload.addParameter(bi);
+            }
+        }
+
+        for(Parameter p : attachParams){
+            JAXBBridgeInfo bi = new JAXBBridgeInfo(getBridge(p.getTypeReference()), null);
+            payloadMap.put(p.getName(), bi);
+        }
+
+        //add unbounded parts
+        for(Parameter p:unboundParams){
+            wrapperParameter.addWrapperChild(p);
+        }
+        payloadMap.put(wrapperParameter.getName(), payload);
+        return attachParams;
+    }
+
+
+    /**
+     * @param name
+     * @param jm
+     */
+    protected void put(QName name, JavaMethod jm) {
+        nameToJM.put(name, jm);
+    }
+
+    /**
+     * @param method
+     * @param jm
+     */
+    protected void put(Method method, JavaMethod jm) {
+        methodToJM.put(method, jm);
+    }
+
+    public String getWSDLLocation() {
+        return wsdlLocation;
+    }
+
+    public void setWSDLLocation(String location) {
+        wsdlLocation = location;
+    }
+
+    public QName getServiceQName() {
+        return serviceName;
+    }
+
+    public QName getPortName() {
+        return portName;
+    }
+
+    public QName getPortTypeName() {
+        return portTypeName;
+    }
+
+    public void setServiceQName(QName name) {
+        serviceName = name;
+    }
+
+    public void setPortName(QName name) {
+        portName = name;
+    }
+
+    public void setPortTypeName(QName name) {
+        portTypeName = name;
+    }
+
+    /**
+     * This is the targetNamespace for the WSDL containing the PortType
+     * definition
+     */
+    public void setTargetNamespace(String namespace) {
+        targetNamespace = namespace;
+    }
+
+    /**
+     * This is the targetNamespace for the WSDL containing the PortType
+     * definition
+     */
+    public String getTargetNamespace() {
+        return targetNamespace;
+    }
+
+    /**
+     * Add a global type.  Global types will be used to generate global
+     * elements in the generated schema's
+     * @param typeReference
+     */
+/*    public void addGlobalType(TypeReference typeReference) {
+
+    }*/
+
+    /**
+     * Add a global type.  Global types will be used to generate global
+     * elements in the generated schema's
+     * @return
+     */
+/*    public Collection<TypeReference> getGlobalTypes() {
+        return globalTypes;
+    }*/
+
+
+    /**
+     * Mtom processing is disabled by default. To enable it the RuntimeModel creator must call it to enable it.
+     * @param enableMtom
+     */
+    public void enableMtom(boolean enableMtom){
+        this.enableMtom = enableMtom;
+    }
+
+    public Map<Integer, RawAccessor> getRawAccessorMap() {
+        return rawAccessorMap;
+    }
+
+    protected abstract void createDecoderInfo();
+
+    private boolean enableMtom = false;
+    private ThreadLocal<BridgeContext> bridgeContext = new ThreadLocal<BridgeContext>();
+    protected JAXBRIContext jaxbContext;
+    private String wsdlLocation;
+    private QName serviceName;
+    private QName portName;
+    private QName portTypeName;
+    private Map<Method, JavaMethod> methodToJM = new HashMap<Method, JavaMethod>();
+    private Map<QName, JavaMethod> nameToJM = new HashMap<QName, JavaMethod>();
+    private List<JavaMethod> javaMethods = new ArrayList<JavaMethod>();
+    private final Map<TypeReference, Bridge> bridgeMap = new HashMap<TypeReference, Bridge>();
+    private final Map<QName, Object> payloadMap = new HashMap<QName, Object>();
+    protected final QName emptyBodyName = new QName("");
+    private String targetNamespace = "";
+    private final Map<Integer, RawAccessor> rawAccessorMap = new HashMap<Integer, RawAccessor>();
+    private List<String> knownNamespaceURIs = null;
+//    protected Collection<TypeReference> globalTypes = new ArrayList<TypeReference>();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/WrapperParameter.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/WrapperParameter.java
new file mode 100644
index 0000000..fb5a8ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/WrapperParameter.java
@@ -0,0 +1,88 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+import com.sun.xml.internal.bind.api.TypeReference;
+
+/**
+ * Models Wrapper parameter
+ *
+ * @author Vivek Pandey
+ */
+public class WrapperParameter extends Parameter{
+    public WrapperParameter(TypeReference type, Mode mode, int index) {
+        super(type, mode, index);
+    }
+
+    /*
+     * (non-Javadoc)
+     *
+     * @see com.sun.xml.internal.ws.rt.model.Parameter#isWrapperStyle()
+     */
+    @Override
+    public boolean isWrapperStyle() {
+        return true;
+    }
+
+    /**
+     * @return Returns the wrapperChildren.
+     */
+    public List<Parameter> getWrapperChildren() {
+        return Collections.unmodifiableList(wrapperChildren);
+    }
+
+    /**
+     * @param wrapperChildren
+     *            The wrapperChildren to set.
+     */
+    public void addWrapperChildren(List<Parameter> wrapperChildren) {
+        this.wrapperChildren.addAll(wrapperChildren);
+    }
+
+    /**
+     * @param wrapperChild
+     */
+    public void addWrapperChild(Parameter wrapperChild) {
+        wrapperChildren.add(wrapperChild);
+    }
+
+    /**
+     * removes the wrapper child from the given index
+     * @param index
+     * @return
+     */
+    public Parameter removeWrapperChild(int index){
+        return wrapperChildren.remove(index);
+    }
+
+    public void clear(){
+        wrapperChildren.clear();
+    }
+    protected final List<Parameter> wrapperChildren = new ArrayList<Parameter>();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/SOAPBinding.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/SOAPBinding.java
new file mode 100644
index 0000000..7421be6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/SOAPBinding.java
@@ -0,0 +1,130 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model.soap;
+
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+
+/**
+ * Binding object that represents soap:binding
+ *
+  * @author Vivek Pandey
+ */
+public class SOAPBinding {
+    public SOAPBinding() {
+    }
+
+    public SOAPBinding(SOAPBinding sb){
+        this.use = sb.use;
+        this.style = sb.style;
+        this.soapVersion = sb.soapVersion;
+        this.soapAction = sb.soapAction;
+    }
+
+    /**
+     * @return Returns the use.
+     */
+    public Use getUse() {
+        return use;
+    }
+
+    /**
+     * @param use
+     *            The use to set.
+     */
+    public void setUse(Use use) {
+        this.use = use;
+    }
+
+    /**
+     * @return Returns the style.
+     */
+    public Style getStyle() {
+        return style;
+    }
+
+    /**
+     * @param style
+     *            The style to set.
+     */
+    public void setStyle(Style style) {
+        this.style = style;
+    }
+
+    /**
+     * @param version
+     */
+    public void setSOAPVersion(SOAPVersion version) {
+        this.soapVersion = version;
+    }
+
+    /**
+     * @return the SOAPVersion of this SOAPBinding
+     */
+    public SOAPVersion getSOAPVersion() {
+        return soapVersion;
+    }
+
+    /**
+     * @return true if this is a document/literal SOAPBinding
+     */
+    public boolean isDocLit() {
+        return style.equals(Style.DOCUMENT) && use.equals(Use.LITERAL);
+    }
+
+    /**
+     * @return true if this is a rpc/literal SOAPBinding
+     */
+    public boolean isRpcLit() {
+        return style.equals(Style.RPC) && use.equals(Use.LITERAL);
+    }
+
+    /**
+     * @return the soapAction header value. It's always non-null. soap
+     *         message serializer needs to generated SOAPAction HTTP header with
+     *         the return of this method enclosed in quotes("").
+     */
+    public String getSOAPAction() {
+        if (soapAction == null)
+            return "";
+        return soapAction;
+    }
+
+    /**
+     * @param soapAction
+     *            The soapAction to set.
+     */
+    public void setSOAPAction(String soapAction) {
+        this.soapAction = soapAction;
+    }
+
+    private Style style = Style.DOCUMENT;
+
+    private Use use = Use.LITERAL;
+
+    private SOAPVersion soapVersion = SOAPVersion.SOAP_11;
+
+    private String soapAction;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/SOAPRuntimeModel.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/SOAPRuntimeModel.java
new file mode 100644
index 0000000..58405b5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/SOAPRuntimeModel.java
@@ -0,0 +1,408 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model.soap;
+
+import com.sun.xml.internal.bind.api.RawAccessor;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.messaging.saaj.soap.SOAPVersionMismatchException;
+import com.sun.xml.internal.ws.encoding.jaxb.JAXBBridgeInfo;
+import com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.internal.BodyBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.*;
+import com.sun.xml.internal.ws.model.*;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.server.ServerRtException;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.soap.SOAPFaultException;
+import javax.xml.soap.SOAPFault;
+
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Locale;
+import java.util.Set;
+
+/**
+ * Creates SOAP specific RuntimeModel
+ *
+ * @author Vivek Pandey
+ */
+public class SOAPRuntimeModel extends RuntimeModel {
+
+    protected void createDecoderInfo() {
+        Collection<JavaMethod> methods = getJavaMethods();
+        for (JavaMethod m : methods) {
+            if(m.isAsync())
+                continue;
+            SOAPBinding binding = (SOAPBinding) m.getBinding();
+            setDecoderInfo(m.getRequestParameters(), binding, Mode.IN);
+            setDecoderInfo(m.getResponseParameters(), binding, Mode.OUT);
+            for(CheckedException ce:m.getCheckedExceptions()){
+                JAXBBridgeInfo bi = new JAXBBridgeInfo(getBridge(ce.getDetailType()));
+                addDecoderInfo(ce.getDetailType().tagName, bi);
+            }
+        }
+
+    }
+
+    private void setDecoderInfo(List<Parameter> params, SOAPBinding binding, Mode mode){
+        for (Parameter param : params) {
+            ParameterBinding paramBinding = (mode == Mode.IN)?param.getInBinding():param.getOutBinding();
+            if (paramBinding.isBody() && binding.isRpcLit()) {
+                RpcLitPayload payload = new RpcLitPayload(param.getName());
+                WrapperParameter wp = (WrapperParameter) param;
+                for (Parameter p : wp.getWrapperChildren()) {
+                    if(p.getBinding().isUnbound())
+                        continue;
+                    JAXBBridgeInfo bi = new JAXBBridgeInfo(getBridge(p.getTypeReference()),
+                        null);
+                    payload.addParameter(bi);
+                }
+                addDecoderInfo(param.getName(), payload);
+            } else {
+                JAXBBridgeInfo bi = new JAXBBridgeInfo(getBridge(param.getTypeReference()),
+                    null);
+                addDecoderInfo(param.getName(), bi);
+            }
+        }
+    }
+
+    /*
+     * @see RuntimeModel#populateMaps()
+     */
+    @Override
+    protected void populateMaps() {
+        int emptyBodyCount = 0;
+        for(JavaMethod jm:getJavaMethods()){
+            put(jm.getMethod(), jm);
+            boolean bodyFound = false;
+            for(Parameter p:jm.getRequestParameters()){
+                ParameterBinding binding = p.getBinding();
+                if(binding.isBody()){
+                    put(p.getName(), jm);
+                    bodyFound = true;
+                }
+            }
+            if(!bodyFound){
+                put(emptyBodyName, jm);
+//                System.out.println("added empty body for: "+jm.getMethod().getName());
+                emptyBodyCount++;
+            }
+        }
+        if(emptyBodyCount > 1){
+            //TODO throw exception
+//            System.out.println("Error: Unqiue signature violation - more than 1 empty body!");
+        }
+    }
+
+
+    /*
+     * @see RuntimeModel#fillTypes(JavaMethod, List)
+     */
+    @Override
+    protected void fillTypes(JavaMethod m, List<TypeReference> types) {
+        if(!(m.getBinding() instanceof SOAPBinding)){
+            //TODO throws exception
+            System.out.println("Error: Wrong Binding!");
+            return;
+        }
+        if(((SOAPBinding)m.getBinding()).isDocLit()){
+            super.fillTypes(m, types);
+            return;
+        }
+
+        //else is rpclit
+        addTypes(m.getRequestParameters(), types, Mode.IN);
+        addTypes(m.getResponseParameters(), types, Mode.OUT);
+    }
+
+    /**
+     * @param params
+     * @param types
+     * @param mode
+     */
+    private void addTypes(List<Parameter> params, List<TypeReference> types, Mode mode) {
+        for(Parameter p:params){
+            ParameterBinding binding = (mode == Mode.IN)?p.getInBinding():p.getOutBinding();
+            if(!p.isWrapperStyle()){
+                types.add(p.getTypeReference());
+            }else if(binding.isBody()){
+                List<Parameter> wcParams = ((WrapperParameter)p).getWrapperChildren();
+                for(Parameter wc:wcParams){
+                    types.add(wc.getTypeReference());
+                }
+            }
+        }
+    }
+
+
+    public Set<QName> getKnownHeaders() {
+        Set<QName> headers = new HashSet<QName>();
+        Iterator<JavaMethod> methods = getJavaMethods().iterator();
+        while (methods.hasNext()) {
+            JavaMethod method = methods.next();
+            // fill in request headers
+            Iterator<Parameter> params = method.getRequestParameters().iterator();
+            fillHeaders(params, headers, Mode.IN);
+
+            // fill in response headers
+            params = method.getResponseParameters().iterator();
+            fillHeaders(params, headers, Mode.OUT);
+        }
+        return headers;
+    }
+
+    /**
+     * @param params
+     * @param headers
+     */
+    private void fillHeaders(Iterator<Parameter> params, Set<QName> headers, Mode mode) {
+        while (params.hasNext()) {
+            Parameter param = params.next();
+            ParameterBinding binding = (mode == Mode.IN)?param.getInBinding():param.getOutBinding();
+            QName name = param.getName();
+            if (binding.isHeader() && !headers.contains(name)) {
+                headers.add(name);
+            }
+        }
+    }
+
+    /**
+     * Called by server
+     *
+     * @param obj
+     * @param actor
+     * @param detail
+     * @param internalMsg
+     * @return the InternalMessage for a fault
+     */
+    public static InternalMessage createFaultInBody(Object obj, String actor,
+            Object detail, InternalMessage internalMsg) {
+        SOAPFaultInfo faultInfo;
+        if (obj instanceof SOAPFaultInfo) {
+            faultInfo = (SOAPFaultInfo)obj;
+        } else if (obj instanceof ServerRtException) {
+            Throwable cause = ((ServerRtException)obj).getCause();
+            Throwable th = (cause == null) ? (ServerRtException)obj : cause;
+            faultInfo = createSOAPFaultInfo(th, actor, detail);
+
+        } else if (obj instanceof SOAPFaultException) {
+            SOAPFaultException e = (SOAPFaultException)obj;
+            faultInfo = new SOAPFaultInfo(e.getFault());
+        } else if (obj instanceof SOAPVersionMismatchException) {
+            QName faultCode = SOAPConstants.FAULT_CODE_VERSION_MISMATCH;
+            String faultString = "SOAP envelope version mismatch";
+            faultInfo =
+                new SOAPFaultInfo(faultString, faultCode, actor, null, javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_BINDING);
+        } else if (obj instanceof Exception) {
+            faultInfo = createSOAPFaultInfo((Exception)obj, actor, detail);
+        } else {
+            QName faultCode = SOAPConstants.FAULT_CODE_SERVER;
+            String faultString = "Unknown fault type:"+obj.getClass();
+            faultInfo =
+                new SOAPFaultInfo(faultString, faultCode, actor, null,javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_BINDING);
+        }
+
+        if (internalMsg == null) {
+            internalMsg = new InternalMessage();
+        }
+
+        BodyBlock bodyBlock = internalMsg.getBody();
+        if (bodyBlock == null) {
+            bodyBlock = new BodyBlock(faultInfo);
+            internalMsg.setBody(bodyBlock);
+        } else {
+            bodyBlock.setFaultInfo(faultInfo);
+        }
+
+        return internalMsg;
+    }
+
+    public static InternalMessage createSOAP12FaultInBody(Object obj, String role, String node, Object detail, InternalMessage im) {
+        SOAP12FaultInfo faultInfo;
+        if (obj instanceof SOAP12FaultInfo) {
+            faultInfo = (SOAP12FaultInfo)obj;
+        } else if (obj instanceof ServerRtException) {
+            Throwable cause = ((ServerRtException)obj).getCause();
+            Throwable th = (cause == null) ? (ServerRtException)obj : cause;
+            faultInfo = createSOAP12FaultInfo(th, role, node, detail);
+
+        } else if (obj instanceof SOAPFaultException) {
+            SOAPFaultException e = (SOAPFaultException)obj;
+            faultInfo = new SOAP12FaultInfo(e.getFault());
+        } else if (obj instanceof SOAPVersionMismatchException) {
+            String faultString = "SOAP envelope version mismatch";
+            FaultCode code = new FaultCode(FaultCodeEnum.VersionMismatch, (FaultSubcode) null);
+            FaultReason reason = new FaultReason(new FaultReasonText(faultString, Locale.getDefault()));
+            faultInfo = new SOAP12FaultInfo(code, reason, null, null, null);
+        } else if (obj instanceof Exception) {
+            faultInfo = createSOAP12FaultInfo((Exception)obj, role, node, detail);
+        } else {
+            String faultString = "Unknown fault type:"+obj.getClass();
+            FaultCode code = new FaultCode(FaultCodeEnum.Receiver, (FaultSubcode) null);
+            FaultReason reason = new FaultReason(new FaultReasonText(faultString, Locale.getDefault()));
+            faultInfo = new SOAP12FaultInfo(code, reason, null, null, null);
+        }
+        if (im == null) {
+            im = new InternalMessage();
+        }
+        BodyBlock bodyBlock = im.getBody();
+        if (bodyBlock == null) {
+            bodyBlock = new BodyBlock(faultInfo);
+            im.setBody(bodyBlock);
+        } else {
+            bodyBlock.setValue(faultInfo);
+        }
+        return im;
+    }
+
+    // currently adds not understood header blocks if there are any
+    public static void addHeaders(InternalMessage message, MessageInfo mi) {
+        Set<HeaderBlock> notUnderstoodHeaders =
+            MessageInfoUtil.getNotUnderstoodHeaders(mi);
+        if (notUnderstoodHeaders != null) {
+            for (HeaderBlock block : notUnderstoodHeaders) {
+                message.addHeader(block);
+            }
+        }
+    }
+
+    private static SOAP12FaultInfo createSOAP12FaultInfo(Throwable e, String role, String node, Object detail) {
+        SOAPFaultException soapFaultException = null;
+        FaultCode code = null;
+        FaultReason reason = null;
+        String faultRole = null;
+        String faultNode = null;
+        Throwable cause = e.getCause();
+        if (e instanceof SOAPFaultException) {
+            soapFaultException = (SOAPFaultException)e;
+        } else if (cause != null && cause instanceof SOAPFaultException) {
+            soapFaultException = (SOAPFaultException)e.getCause();
+        }
+        if (soapFaultException != null) {
+            SOAPFault soapFault =  soapFaultException.getFault();
+            code = new FaultCode(FaultCodeEnum.get(soapFault.getFaultCodeAsQName()), (FaultSubcode) null);
+            reason = new FaultReason(new FaultReasonText(soapFault.getFaultString(),
+                    soapFault.getFaultStringLocale()));
+            faultRole = soapFault.getFaultRole();
+            if(faultRole == null)
+                faultRole = role;
+            faultNode = soapFault.getFaultNode();
+            if(faultNode == null)
+                faultNode = node;
+        }
+
+        if (code == null || ((code != null) && code.getValue() == null)) {
+            code = new FaultCode(FaultCodeEnum.Receiver, (FaultSubcode) null);
+        }
+
+        if(reason == null){
+            String faultString = e.getMessage();
+            if (faultString == null) {
+                faultString = e.toString();
+            }
+
+            reason = new FaultReason(new FaultReasonText(faultString, Locale.getDefault()));
+        }
+
+        if ((detail == null) && (soapFaultException != null)) {
+            detail = soapFaultException.getFault().getDetail();
+        }
+
+        return new SOAP12FaultInfo(code, reason, faultRole, faultNode, detail);
+    }
+
+    //TODO: createSOAP12HeaderFault()
+
+
+    /**
+     * @param obj
+     * @param actor
+     * @param detailBlock
+     * @param internalMsg
+     * @return the <code>InteralMessage</code> for a HeaderFault
+     */
+    public static InternalMessage createHeaderFault(Object obj, String actor, JAXBBridgeInfo detailBlock, InternalMessage internalMsg){
+        //its headerfault so, create body fault with no detail. detail object goes as a header block
+        internalMsg = createFaultInBody(obj, actor, null, internalMsg);
+        HeaderBlock hdrBlock = new HeaderBlock(detailBlock);
+        internalMsg.addHeader(hdrBlock);
+        return internalMsg;
+    }
+
+    /**
+     * @param e
+     * @param actor
+     * @param detail
+     * @return
+     */
+    private static SOAPFaultInfo createSOAPFaultInfo(Throwable e, String actor,
+            Object detail) {
+//        e.printStackTrace();
+        SOAPFaultException soapFaultException = null;
+        QName faultCode = null;
+        String faultString = null;
+        String faultActor = null;
+        Throwable cause = e.getCause();
+        if (e instanceof SOAPFaultException) {
+            soapFaultException = (SOAPFaultException)e;
+        } else if (cause != null && cause instanceof SOAPFaultException) {
+            soapFaultException = (SOAPFaultException)e.getCause();
+        }
+        if (soapFaultException != null) {
+            faultCode = soapFaultException.getFault().getFaultCodeAsQName();
+            faultString = soapFaultException.getFault().getFaultString();
+            faultActor = soapFaultException.getFault().getFaultActor();
+        }
+
+        if (faultCode == null) {
+            faultCode = SOAPConstants.FAULT_CODE_SERVER;
+        }
+
+        if (faultString == null) {
+            faultString = e.getMessage();
+            if (faultString == null) {
+                faultString = e.toString();
+            }
+        }
+
+        if (faultActor == null) {
+            faultActor = actor;
+        }
+
+        if (detail == null && soapFaultException != null) {
+            detail = soapFaultException.getFault().getDetail();
+        }
+
+        return new SOAPFaultInfo(faultString, faultCode, faultActor, detail, javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_BINDING);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/Style.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/Style.java
new file mode 100644
index 0000000..bd5c20c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/Style.java
@@ -0,0 +1,44 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model.soap;
+
+/**
+ * @author Vivek Pandey
+ *
+ * TODO To change the template for this generated type comment go to
+ * Window - Preferences - Java - Code Style - Code Templates
+ */
+public enum Style {
+    DOCUMENT(0), RPC(1);
+
+    private Style(int style){
+        this.style = style;
+    }
+
+    public int value() {
+        return style;
+    }
+    private final int style;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/Use.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/Use.java
new file mode 100644
index 0000000..b99847c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/model/soap/Use.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.model.soap;
+
+/**
+ * @author Vivek Pandey
+ *
+ */
+public enum Use {
+    LITERAL(0), ENCODED(1);
+
+    private Use(int use){
+        this.use = use;
+    }
+
+    public int value() {
+        return use;
+    }
+    private final int use;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/modeler/RuntimeModeler.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/modeler/RuntimeModeler.java
new file mode 100644
index 0000000..63a2e4f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/modeler/RuntimeModeler.java
@@ -0,0 +1,1370 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.modeler;
+
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.bind.api.TypeReference;
+import com.sun.xml.internal.bind.v2.model.nav.Navigator;
+import com.sun.xml.internal.ws.binding.soap.SOAPBindingImpl;
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+import com.sun.xml.internal.ws.model.JavaMethod;
+import com.sun.xml.internal.ws.model.Mode;
+import com.sun.xml.internal.ws.model.CheckedException;
+import com.sun.xml.internal.ws.model.ExceptionType;
+import com.sun.xml.internal.ws.model.Parameter;
+import com.sun.xml.internal.ws.model.ParameterBinding;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.model.WrapperParameter;
+import com.sun.xml.internal.ws.model.soap.SOAPRuntimeModel;
+import com.sun.xml.internal.ws.model.soap.Style;
+import com.sun.xml.internal.ws.wsdl.parser.BindingOperation;
+import com.sun.xml.internal.ws.wsdl.parser.Part;
+
+import javax.jws.HandlerChain;
+import javax.jws.Oneway;
+import javax.jws.WebMethod;
+import javax.jws.WebParam;
+import javax.jws.WebResult;
+import javax.jws.WebService;
+import javax.jws.soap.SOAPBinding;
+import javax.xml.namespace.QName;
+import javax.xml.ws.AsyncHandler;
+import javax.xml.ws.Holder;
+import javax.xml.ws.RequestWrapper;
+import javax.xml.ws.Response;
+import javax.xml.ws.ResponseWrapper;
+import javax.xml.ws.WebFault;
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Method;
+import java.lang.reflect.Modifier;
+import java.lang.reflect.ParameterizedType;
+import java.lang.reflect.Type;
+import java.rmi.RemoteException;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.StringTokenizer;
+import java.util.concurrent.Future;
+import javax.xml.ws.BindingType;
+import javax.xml.ws.http.HTTPBinding;
+
+import java.security.AccessController;
+import java.security.PrivilegedAction;
+
+/**
+ * Creates a runtime model of a SEI (portClass).
+ *
+ * @author WS Developement Team
+ */
+public class RuntimeModeler {
+    private String bindingId;
+    private Class portClass;
+    private RuntimeModel runtimeModel;
+    private com.sun.xml.internal.ws.model.soap.SOAPBinding defaultBinding;
+    private String packageName;
+    private String targetNamespace;
+    private boolean isWrapped = true;
+    private boolean usesWebMethod = false;
+    private ClassLoader classLoader = null;
+    private Object implementor;
+    private com.sun.xml.internal.ws.wsdl.parser.Binding binding;
+    private QName serviceName;
+    private QName portName;
+    private Map<Class, Boolean> classUsesWebMethod = new HashMap<Class, Boolean>();
+
+    /**
+     *
+     */
+    public static final String PD_JAXWS_PACKAGE_PD  = ".jaxws.";
+    /**
+     *
+     */
+    public static final String JAXWS_PACKAGE_PD     = "jaxws.";
+    public static final String RESPONSE             = "Response";
+    public static final String RETURN               = "return";
+    public static final String BEAN                 = "Bean";
+    public static final String SERVICE              = "Service";
+    public static final String PORT                 = "Port";
+    public static final Class HOLDER_CLASS = Holder.class;
+    public static final Class REMOTE_EXCEPTION_CLASS = RemoteException.class;
+    public static final Class RPC_LIT_PAYLOAD_CLASS = com.sun.xml.internal.ws.encoding.jaxb.RpcLitPayload.class;
+
+    /**
+     * creates an instance of RunTimeModeler given a <code>portClass</code> and <code>bindingId</code>
+     * @param portClass The SEI class to be modeled.
+     * @param serviceName The ServiceName to use instead of one calculated from the implementation class
+     * @param bindingId The binding identifier to be used when modeling the <code>portClass</code>.
+     */
+    public RuntimeModeler(Class portClass, QName serviceName, String bindingId) {
+        this.portClass = portClass;
+        this.serviceName = serviceName;
+        this.bindingId = bindingId;
+    }
+
+    /**
+     *
+     * creates an instance of RunTimeModeler given a <code>sei</code> and <code>binding</code>
+     * @param sei The SEI class to be modeled.
+     * @param serviceName The ServiceName to use instead of one calculated from the implementation class
+     * @param binding The Binding representing WSDL Binding for the given port to be used when modeling the
+     * <code>sei</code>.
+     */
+    public RuntimeModeler(Class sei, QName serviceName, com.sun.xml.internal.ws.wsdl.parser.Binding binding){
+        this.portClass = sei;
+        this.serviceName = serviceName;
+        this.bindingId = binding.getBindingId();
+        this.binding = binding;
+    }
+
+    /**
+     * creates an instance of RunTimeModeler given a <code>portClass</code> and <code>bindingId</code>
+     * implementor object's class may not be portClass, as it could be proxy to
+     * portClass webmethods.
+     *
+     * @param portClass The SEI class to be modeled.
+     * @param implementor The object on which service methods are invoked
+     * @param serviceName The ServiceName to use instead of one calculated from the implementation class
+     * @param bindingId The binding identifier to be used when modeling the <code>portClass</code>.
+     */
+    public RuntimeModeler(Class portClass, Object implementor, QName serviceName, String bindingId) {
+        this(portClass, serviceName, bindingId);
+        this.implementor = implementor;
+    }
+
+    /**
+     * creates an instance of RunTimeModeler given a <code>sei</code> class and <code>binding</code>
+     * implementor object's class may not be sei Class, as it could be proxy to
+     * sei webmethods.
+     *
+     * @param portClass The SEI class to be modeled.
+     * @param implementor The object on which service methods are invoked
+     * @param binding The Binding representing WSDL Binding for the given port to be used when modeling the
+     * <code>sei</code>.
+     */
+    public RuntimeModeler(Class portClass, Object implementor, QName serviceName, com.sun.xml.internal.ws.wsdl.parser.Binding binding) {
+        this(portClass, serviceName, binding);
+        this.implementor = implementor;
+    }
+
+
+    /**
+     * sets the classloader to be used when loading classes by the <code>RuntimeModeler</code>.
+     * @param classLoader ClassLoader used to load classes
+     */
+    public void setClassLoader(ClassLoader classLoader) {
+        this.classLoader = classLoader;
+    }
+
+    /**
+     * sets the PortName to be used by the <code>RuntimeModeler</code>.
+     * @param portName The PortName to be used instead of the PortName
+     * retrieved via annotations
+     */
+    public void setPortName(QName portName) {
+        this.portName = portName;
+    }
+
+    private static <T> T getPrivClassAnnotation(final Class clazz, final Class T) {
+        return (T)AccessController.doPrivileged(new PrivilegedAction() {
+           public Object run() {
+               return clazz.getAnnotation(T);
+           }
+        });
+    }
+
+    private static <T> T getPrivMethodAnnotation(final Method method, final Class T) {
+        return (T)AccessController.doPrivileged(new PrivilegedAction() {
+           public Object run() {
+               return method.getAnnotation(T);
+           }
+        });
+    }
+
+    private static Annotation[][] getPrivParameterAnnotations(final Method method) {
+        return (Annotation[][])AccessController.doPrivileged(new PrivilegedAction() {
+           public Object run() {
+               return method.getParameterAnnotations();
+           }
+        });
+    }
+
+    //currently has many local vars which will be eliminated after debugging issues
+    //first draft
+    /**
+     * builds the runtime model from the <code>portClass</code> using the binding ID <code>bindingId</code>.
+     * @return the runtime model for the <code>portClass</code>.
+     */
+    public RuntimeModel buildRuntimeModel() {
+        runtimeModel = new SOAPRuntimeModel();
+        Class clazz = portClass;
+        WebService webService = getPrivClassAnnotation(portClass, WebService.class);
+        if (webService == null) {
+            throw new RuntimeModelerException("runtime.modeler.no.webservice.annotation",
+                                       new Object[] {portClass.getCanonicalName()});
+        }
+        if (webService.endpointInterface().length() > 0) {
+            clazz = getClass(webService.endpointInterface());
+            WebService seiService = getPrivClassAnnotation(clazz, WebService.class);
+            if (seiService == null) {
+                throw new RuntimeModelerException("runtime.modeler.endpoint.interface.no.webservice",
+                                    new Object[] {webService.endpointInterface()});
+            }
+        }
+        if (serviceName == null)
+            serviceName = getServiceName(portClass);
+        runtimeModel.setServiceQName(serviceName);
+
+        String portLocalName  = portClass.getSimpleName()+PORT;
+        if (webService.portName().length() >0) {
+            portLocalName = webService.portName();
+        } else if (webService.name().length() >0) {
+            portLocalName = webService.name()+PORT;
+        }
+
+        if (portName == null)
+            portName = new QName(serviceName.getNamespaceURI(), portLocalName);
+
+        if (!portName.getNamespaceURI().equals(serviceName.getNamespaceURI())) {
+            throw new RuntimeModelerException("runtime.modeler.portname.servicename.namespace.mismatch",
+                    new Object[] {serviceName, portName});
+        }
+        runtimeModel.setPortName(portName);
+
+        processClass(clazz);
+        if (runtimeModel.getJavaMethods().size() == 0)
+            throw new RuntimeModelerException("runtime.modeler.no.operations",
+                    new Object[] {portClass.getName().toString()});
+        runtimeModel.postProcess();
+        return runtimeModel;
+    }
+
+    /**
+     * utility method to load classes
+     * @param className the name of the class to load
+     * @return the class specified by <code>className</code>
+     */
+    protected Class getClass(String className) {
+        try {
+            if (classLoader == null)
+                return Thread.currentThread().getContextClassLoader().loadClass(className);
+            else
+                return classLoader.loadClass(className);
+        } catch (ClassNotFoundException e) {
+            throw new RuntimeModelerException("runtime.modeler.class.not.found",
+                             new Object[] {className});
+        }
+    }
+
+    protected void setUsesWebMethod(Class clazz, Boolean usesWebMethod) {
+//        System.out.println("class: "+clazz.getName()+" uses WebMethod: "+usesWebMethod);
+        classUsesWebMethod.put(clazz, usesWebMethod);
+    }
+
+    protected void determineWebMethodUse(Class clazz) {
+        if (clazz == null)
+            return;
+        if (clazz.isInterface()) {
+            setUsesWebMethod(clazz, false);
+        }
+        else {
+            WebMethod webMethod;
+            boolean hasWebMethod = false;
+            for (Method method : clazz.getMethods()) {
+                if (!method.getDeclaringClass().equals(clazz))
+                    continue;
+                webMethod = getPrivMethodAnnotation(method, WebMethod.class);
+                if (webMethod != null &&
+                    !webMethod.exclude()) {
+                    hasWebMethod = true;
+                    break;
+                }
+            }
+            setUsesWebMethod(clazz, hasWebMethod);
+        }
+        determineWebMethodUse(clazz.getSuperclass());
+    }
+
+    void processClass(Class clazz) {
+        determineWebMethodUse(clazz);
+        WebService webService = getPrivClassAnnotation(clazz, WebService.class);
+        String portTypeLocalName  = clazz.getSimpleName();
+        if (webService.name().length() >0)
+            portTypeLocalName = webService.name();
+
+
+        targetNamespace = webService.targetNamespace();
+        packageName = null;
+        if (clazz.getPackage() != null)
+            packageName = clazz.getPackage().getName();
+        if (targetNamespace.length() == 0) {
+            targetNamespace = getNamespace(packageName);
+        }
+        runtimeModel.setTargetNamespace(targetNamespace);
+        QName portTypeName = new QName(targetNamespace, portTypeLocalName);
+        runtimeModel.setPortTypeName(portTypeName);
+        runtimeModel.setWSDLLocation(webService.wsdlLocation());
+
+        javax.jws.soap.SOAPBinding soapBinding = getPrivClassAnnotation(clazz, javax.jws.soap.SOAPBinding.class);
+        if (soapBinding != null) {
+            isWrapped = soapBinding.parameterStyle().equals(
+                javax.jws.soap.SOAPBinding.ParameterStyle.WRAPPED);
+        }
+        defaultBinding = createBinding(soapBinding);
+        /*
+         * if clazz != portClass then there is an SEI.  If there is an
+         * SEI, then all methods should be processed.  However, if there is
+         * no SEI, and the implementation class uses at least one
+         * WebMethod annotation, then only methods with this annotation
+         * will be processed.
+         */
+/*        if (clazz == portClass) {
+            WebMethod webMethod;
+            for (Method method : clazz.getMethods()) {
+                webMethod = getPrivMethodAnnotation(method, WebMethod.class);
+                if (webMethod != null &&
+                    !webMethod.exclude()) {
+                    usesWebMethod = true;
+                    break;
+                }
+            }
+        }*/
+
+        for (Method method : clazz.getMethods()) {
+            if (method.getDeclaringClass().equals(Object.class) ||
+                !isWebMethod(method, clazz)) {
+                continue;
+            }
+            processMethod(method, webService);
+        }
+    }
+
+    protected boolean isWebMethod(Method method, Class clazz) {
+        if (clazz.isInterface()) {
+            return true;
+        }
+        Class declClass = method.getDeclaringClass();
+        boolean declHasWebService = getPrivClassAnnotation(declClass, WebService.class) != null;
+        WebMethod webMethod = getPrivMethodAnnotation(method, WebMethod.class);
+        if (webMethod != null &&
+            webMethod.exclude() == false &&
+            declHasWebService) {
+            return true;
+        }
+        if (declHasWebService &&
+            !classUsesWebMethod.get(declClass)) {
+            return true;
+        }
+        return false;
+    }
+
+    /**
+     * creates a runtime model <code>SOAPBinding</code> from a <code>javax.jws.soap.SOAPBinding</code> object
+     * @param soapBinding the <code>javax.jws.soap.SOAPBinding</code> to model
+     * @return returns the runtime model SOAPBinding corresponding to <code>soapBinding</code>
+     */
+    protected com.sun.xml.internal.ws.model.soap.SOAPBinding createBinding(javax.jws.soap.SOAPBinding soapBinding) {
+        com.sun.xml.internal.ws.model.soap.SOAPBinding rtSOAPBinding =
+            new com.sun.xml.internal.ws.model.soap.SOAPBinding();
+        Style style = (soapBinding == null ||
+            soapBinding.style().equals(javax.jws.soap.SOAPBinding.Style.DOCUMENT)) ?
+            Style.DOCUMENT : Style.RPC;
+        rtSOAPBinding.setStyle(style);
+        //default soap version is 1.1, change it to soap 1.2 if the binding id says so
+        if(SOAPVersion.SOAP_12.equals(bindingId))
+            rtSOAPBinding.setSOAPVersion(SOAPVersion.SOAP_12);
+        return rtSOAPBinding;
+    }
+
+    /**
+     * gets the namespace <code>String</code> for a given <code>packageName</code>
+     * @param packageName the name of the package used to find a namespace
+     * @return the namespace for the specified <code>packageName</code>
+     */
+    public static String getNamespace(String packageName) {
+        if (packageName == null || packageName.length() == 0)
+            return null;
+
+        StringTokenizer tokenizer = new StringTokenizer(packageName, ".");
+        String[] tokens;
+        if (tokenizer.countTokens() == 0) {
+            tokens = new String[0];
+        } else {
+            tokens = new String[tokenizer.countTokens()];
+            for (int i=tokenizer.countTokens()-1; i >= 0; i--) {
+                tokens[i] = tokenizer.nextToken();
+            }
+        }
+        StringBuffer namespace = new StringBuffer("http://");
+        String dot = "";
+        for (int i=0; i<tokens.length; i++) {
+            if (i==1)
+                dot = ".";
+            namespace.append(dot+tokens[i]);
+        }
+        namespace.append('/');
+        return namespace.toString();
+    }
+
+    /**
+     * creates the runtime model for a method on the <code>portClass</code>
+     * @param method the method to model
+     * @param webService the instance of the <code>WebService</code> annotation on the <code>portClass</code>
+     */
+    protected void processMethod(Method method, WebService webService) {
+        if (!Modifier.isPublic(method.getModifiers())) {
+            return;
+        }
+
+        WebMethod webMethod = getPrivMethodAnnotation(method, WebMethod.class);
+        if (webMethod != null && webMethod.exclude())
+            return;
+
+        // If one WebMethod is used, then only methods with WebMethod will be
+        // processed.
+        if (usesWebMethod && webMethod == null) {
+            return;
+        }
+
+        // Use implementor to find the exact invocation method as implementor
+        // could be a proxy to portClass object
+        JavaMethod javaMethod;
+        Class implementorClass = (implementor != null)
+            ? implementor.getClass() : portClass;
+        if (method.getDeclaringClass().equals(implementorClass)) {
+            javaMethod = new JavaMethod(method);
+        } else {
+            try {
+                Method tmpMethod = implementorClass.getMethod(method.getName(),
+                    method.getParameterTypes());
+                javaMethod = new JavaMethod(tmpMethod);
+            } catch (NoSuchMethodException e) {
+                throw new RuntimeModelerException("runtime.modeler.method.not.found",
+                    new Object[] {method.getName(), portClass.getName()});
+            }
+        }
+        String methodName = method.getName();
+        int modifier = method.getModifiers();
+        //use for checking
+
+        //set MEP -oneway, async, req/resp
+        int mep = getMEP(method);
+        javaMethod.setMEP(mep);
+
+        String action = null;
+        String operationName = method.getName();
+        if (webMethod != null ) {
+            action = webMethod.action();
+            operationName = webMethod.operationName().length() > 0 ?
+                webMethod.operationName() :
+                operationName;
+        }
+        javaMethod.setOperationName(operationName);
+        SOAPBinding methodBinding =
+            method.getAnnotation(SOAPBinding.class);
+        if (methodBinding == null && !method.getDeclaringClass().equals(portClass)) {
+            if (!method.getDeclaringClass().isInterface()) {
+                methodBinding = method.getDeclaringClass().getAnnotation(SOAPBinding.class);
+            }
+        }
+        boolean methodIsWrapped = isWrapped;
+        Style style = defaultBinding.getStyle();
+        if (methodBinding != null) {
+            com.sun.xml.internal.ws.model.soap.SOAPBinding mySOAPBinding = createBinding(methodBinding);
+            style = mySOAPBinding.getStyle();
+            if (action != null)
+                mySOAPBinding.setSOAPAction(action);
+            methodIsWrapped = methodBinding.parameterStyle().equals(
+                javax.jws.soap.SOAPBinding.ParameterStyle.WRAPPED);
+            javaMethod.setBinding(mySOAPBinding);
+        } else {
+            com.sun.xml.internal.ws.model.soap.SOAPBinding sb = new com.sun.xml.internal.ws.model.soap.SOAPBinding(defaultBinding);
+            if (action != null)
+                sb.setSOAPAction(action);
+            else
+                sb.setSOAPAction("");
+            javaMethod.setBinding(sb);
+        }
+        if (!methodIsWrapped) {
+            processDocBareMethod(javaMethod, methodName, webMethod, operationName,
+                method, webService);
+        } else if (style.equals(Style.DOCUMENT)) {
+            processDocWrappedMethod(javaMethod, methodName, webMethod, operationName,
+                method, webService);
+        } else {
+            processRpcMethod(javaMethod, methodName, webMethod, operationName,
+                method, webService);
+        }
+        runtimeModel.addJavaMethod(javaMethod);
+    }
+
+    private int getMEP(Method m){
+        if (m.isAnnotationPresent(Oneway.class)) {
+            return MessageStruct.ONE_WAY_MEP;
+        }
+        if(Response.class.isAssignableFrom(m.getReturnType())){
+            return MessageStruct.ASYNC_POLL_MEP;
+        }else if(Future.class.isAssignableFrom(m.getReturnType())){
+            return MessageStruct.ASYNC_CALLBACK_MEP;
+        }
+        return MessageStruct.REQUEST_RESPONSE_MEP;
+    }
+
+    /**
+     * models a document/literal wrapped method
+     * @param javaMethod the runtime model <code>JavaMethod</code> instance being created
+     * @param methodName the runtime model <code>JavaMethod</code> instance being created
+     * @param webMethod the runtime model <code>JavaMethod</code> instance being created
+     * @param operationName the runtime model <code>JavaMethod</code> instance being created
+     * @param method the <code>method</code> to model
+     * @param webService The <code>WebService</code> annotation instance on the <code>portClass</code>
+     */
+    protected void processDocWrappedMethod(JavaMethod javaMethod, String methodName,
+                                           WebMethod webMethod, String operationName, Method method, WebService webService) {
+        boolean isOneway = method.isAnnotationPresent(Oneway.class);
+        RequestWrapper reqWrapper = method.getAnnotation(RequestWrapper.class);
+        ResponseWrapper resWrapper = method.getAnnotation(ResponseWrapper.class);
+        String beanPackage = packageName + PD_JAXWS_PACKAGE_PD;
+        if (packageName == null || (packageName != null && packageName.length() == 0))
+            beanPackage = JAXWS_PACKAGE_PD;
+        String requestClassName = null;
+        if(reqWrapper != null && reqWrapper.className().length()>0){
+            requestClassName = reqWrapper.className();
+        }else{
+            requestClassName = beanPackage + capitalize(method.getName());
+        }
+
+
+        String responseClassName = null;
+        if(resWrapper != null && resWrapper.className().length()>0){
+            responseClassName = resWrapper.className();
+        }else{
+            responseClassName = beanPackage + capitalize(method.getName()) + RESPONSE;
+        }
+
+        Class requestClass = getClass(requestClassName);
+
+        String reqName = operationName;
+        String reqNamespace = targetNamespace;
+        if (reqWrapper != null) {
+            if (reqWrapper.targetNamespace().length() > 0)
+                reqNamespace = reqWrapper.targetNamespace();
+            if (reqWrapper.localName().length() > 0)
+                reqName = reqWrapper.localName();
+        }
+        QName reqElementName = new QName(reqNamespace, reqName);
+
+        Class responseClass = null;
+        QName resElementName = null;
+        String resName = operationName+"Response";
+        String resNamespace = targetNamespace;
+        if (!isOneway) {
+            responseClass = getClass(responseClassName);
+            if (resWrapper != null) {
+                if (resWrapper.targetNamespace().length() > 0)
+                    resNamespace = resWrapper.targetNamespace();
+                if (resWrapper.localName().length() > 0)
+                    resName = resWrapper.localName();
+            }
+        }
+        resElementName = new QName(resNamespace, resName);
+
+        TypeReference typeRef =
+                new TypeReference(reqElementName, requestClass, new Annotation[0]);
+        WrapperParameter requestWrapper = new WrapperParameter(typeRef,
+            com.sun.xml.internal.ws.model.Mode.IN, 0);
+        requestWrapper.setBinding(ParameterBinding.BODY);
+        javaMethod.addParameter(requestWrapper);
+        WrapperParameter responseWrapper = null;
+        if (!isOneway) {
+            typeRef = new TypeReference(resElementName, responseClass,
+                                        new Annotation[0]);
+            responseWrapper = new WrapperParameter(typeRef,
+                com.sun.xml.internal.ws.model.Mode.OUT, -1);
+            javaMethod.addParameter(responseWrapper);
+            responseWrapper.setBinding(ParameterBinding.BODY);
+        }
+
+        // return value
+        String resultName = null;
+        String resultTNS = "";
+        QName resultQName = null;
+        WebResult webResult = method.getAnnotation(WebResult.class);
+        Class returnType = method.getReturnType();
+        boolean isResultHeader = false;
+        if (webResult != null) {
+            if (webResult.name().length() > 0)
+                resultName = webResult.name();
+            else
+                resultName = RETURN;
+            resultTNS = webResult.targetNamespace();
+            isResultHeader = webResult.header();
+            if (resultTNS.length() == 0 && webResult.header()) {
+                // headers must have a namespace
+                resultTNS = targetNamespace;
+            }
+            resultQName = new QName(resultTNS, resultName);
+        } else if (!isOneway && !returnType.getName().equals("void") && !javaMethod.isAsync()) {
+            if(resultQName == null){
+                resultQName = new QName(resultTNS, RETURN);
+            }
+        }
+
+        if(javaMethod.isAsync()){
+            returnType = getAsyncReturnType(method, returnType);
+            resultQName = new QName(RETURN);
+        }
+
+        if (!isOneway && (returnType != null) && (!returnType.getName().equals("void"))) {
+            Class returnClazz = returnType;
+            Annotation[] rann = method.getAnnotations();
+            if (resultQName.getLocalPart() != null) {
+                TypeReference rTypeReference = new TypeReference(resultQName, returnType, rann);
+                Parameter returnParameter = new Parameter(rTypeReference, com.sun.xml.internal.ws.model.Mode.OUT, -1);
+                if (isResultHeader) {
+                    returnParameter.setBinding(ParameterBinding.HEADER);
+                    javaMethod.addParameter(returnParameter);
+                } else {
+                    returnParameter.setBinding(ParameterBinding.BODY);
+                    responseWrapper.addWrapperChild(returnParameter);
+                }
+            }
+        }
+
+        //get WebParam
+        Class<?>[] parameterTypes = method.getParameterTypes();
+        Type[] genericParameterTypes = method.getGenericParameterTypes();
+        Annotation[][] pannotations = getPrivParameterAnnotations(method);
+        int pos = 0;
+        QName paramQName = null;
+        for (Class clazzType : parameterTypes) {
+            String partName=null;
+            Parameter param = null;
+            String paramName = "arg"+pos;
+            String paramNamespace = "";
+            boolean isHeader = false;
+
+            if(javaMethod.isAsync() && AsyncHandler.class.isAssignableFrom(clazzType)){
+                continue;
+            }
+
+            boolean isHolder = HOLDER_CLASS.isAssignableFrom(clazzType);
+            //set the actual type argument of Holder in the TypeReference
+            if (isHolder) {
+                if(clazzType.getName().equals(Holder.class.getName())){
+                    clazzType = Navigator.REFLECTION.erasure(((ParameterizedType)genericParameterTypes[pos]).getActualTypeArguments()[0]);
+                }
+            }
+            com.sun.xml.internal.ws.model.Mode paramMode = isHolder ?
+                com.sun.xml.internal.ws.model.Mode.INOUT :
+                com.sun.xml.internal.ws.model.Mode.IN;
+            for (Annotation annotation : pannotations[pos]) {
+                if (annotation.annotationType() == javax.jws.WebParam.class) {
+                    javax.jws.WebParam webParam = (javax.jws.WebParam) annotation;
+                    if (webParam.name().length() > 0)
+                        paramName = webParam.name();
+                    isHeader = webParam.header();
+                    if(webParam.partName().length() > 0)
+                        partName = webParam.partName();
+                    else
+                        partName = paramName;
+                    if (isHeader) // headers cannot be in empty namespace
+                        paramNamespace = targetNamespace;
+                    if (!webParam.targetNamespace().equals("")) {
+                        paramNamespace = webParam.targetNamespace();
+                    }
+                    WebParam.Mode mode = webParam.mode();
+                    if (isHolder && mode == javax.jws.WebParam.Mode.IN)
+                        mode = javax.jws.WebParam.Mode.INOUT;
+                    paramMode = (mode == javax.jws.WebParam.Mode.IN) ? com.sun.xml.internal.ws.model.Mode.IN :
+                        (mode == javax.jws.WebParam.Mode.INOUT) ? com.sun.xml.internal.ws.model.Mode.INOUT :
+                        com.sun.xml.internal.ws.model.Mode.OUT;
+                    break;
+                }
+            }
+            paramQName = new QName(paramNamespace, paramName);
+            typeRef =
+                new TypeReference(paramQName, clazzType, pannotations[pos]);
+            param = new Parameter(typeRef, paramMode, pos++);
+            if (isHeader) {
+                param.setBinding(ParameterBinding.HEADER);
+                javaMethod.addParameter(param);
+                param.setPartName(partName);
+            } else {
+                param.setBinding(ParameterBinding.BODY);
+                if (!paramMode.equals(com.sun.xml.internal.ws.model.Mode.OUT)) {
+                    requestWrapper.addWrapperChild(param);
+                }
+                if (!paramMode.equals(com.sun.xml.internal.ws.model.Mode.IN)) {
+                    if (isOneway) {
+                        throw new RuntimeModelerException("runtime.modeler.oneway.operation.no.out.parameters",
+                                new Object[] {portClass.getCanonicalName(), methodName});
+                    }
+                    responseWrapper.addWrapperChild(param);
+                }
+            }
+        }
+        processExceptions(javaMethod, method);
+    }
+
+
+    /**
+     * models a rpc/literal method
+     * @param javaMethod the runtime model <code>JavaMethod</code> instance being created
+     * @param methodName the name of the <code>method</code> being modeled.
+     * @param webMethod the <code>WebMethod</code> annotations instance on the <code>method</code>
+     * @param operationName the WSDL operation name for this <code>method</code>
+     * @param method the runtime model <code>JavaMethod</code> instance being created
+     * @param webService the runtime model <code>JavaMethod</code> instance being created
+     */
+    protected void processRpcMethod(JavaMethod javaMethod, String methodName,
+                                    WebMethod webMethod, String operationName, Method method, WebService webService) {
+        boolean isOneway = method.isAnnotationPresent(Oneway.class);
+        //build ordered list
+        Map<Integer, Parameter> resRpcParams = new HashMap<Integer, Parameter>();
+        Map<Integer, Parameter> reqRpcParams = new HashMap<Integer, Parameter>();
+
+        //Lets take the service namespace and overwrite it with the one we get it from wsdl
+        String reqNamespace = targetNamespace;
+        String respNamespace = targetNamespace;
+        if(binding != null){
+            binding.finalizeBinding();
+            BindingOperation op = binding.get(operationName);
+            if(op != null){
+                //it cant be null, but lets not fail and try to work with service namespce
+                if(op.getRequestNamespace() != null){
+                    reqNamespace = op.getRequestNamespace();
+                }
+
+                //it cant be null, but lets not fail and try to work with service namespce
+                if(op.getResponseNamespace() != null){
+                    respNamespace = op.getResponseNamespace();
+                }
+            }
+        }
+
+        QName reqElementName = new QName(reqNamespace, operationName);
+        QName resElementName = null;
+        if (!isOneway) {
+            resElementName = new QName(respNamespace, operationName+RESPONSE);
+        }
+
+        TypeReference typeRef =
+                new TypeReference(reqElementName, RPC_LIT_PAYLOAD_CLASS, new Annotation[0]);
+        WrapperParameter requestWrapper = new WrapperParameter(typeRef,
+            com.sun.xml.internal.ws.model.Mode.IN, 0);
+        requestWrapper.setInBinding(ParameterBinding.BODY);
+        javaMethod.addParameter(requestWrapper);
+        WrapperParameter responseWrapper = null;
+        if (!isOneway) {
+            typeRef = new TypeReference(resElementName, RPC_LIT_PAYLOAD_CLASS,
+                                        new Annotation[0]);
+            responseWrapper = new WrapperParameter(typeRef,
+                com.sun.xml.internal.ws.model.Mode.OUT, -1);
+            responseWrapper.setOutBinding(ParameterBinding.BODY);
+            javaMethod.addParameter(responseWrapper);
+        }
+
+        Class returnType = method.getReturnType();
+        String resultName = RETURN;
+        String resultTNS = targetNamespace;
+        String resultPartName = resultName;
+        QName resultQName = null;
+        boolean isResultHeader = false;
+        WebResult webResult = method.getAnnotation(WebResult.class);
+
+        if (webResult != null) {
+            isResultHeader = webResult.header();
+            if (webResult.name().length() > 0)
+                resultName = webResult.name();
+            else
+                resultName = RETURN;
+            if (webResult.partName().length() > 0) {
+                resultPartName = webResult.partName();
+                if (!isResultHeader)
+                    resultName = resultPartName;
+            } else
+                resultPartName = resultName;
+            if (webResult.targetNamespace().length() > 0)
+                resultTNS = webResult.targetNamespace();
+            isResultHeader = webResult.header();
+        }
+        if (isResultHeader)
+            resultQName = new QName(resultTNS, resultName);
+        else
+            resultQName = new QName(resultName);
+
+        if(javaMethod.isAsync()){
+            returnType = getAsyncReturnType(method, returnType);
+        }
+
+        if (!isOneway && (returnType != null) && (!returnType.getName().equals("void"))) {
+            Class returnClazz = returnType;
+            Annotation[] rann = method.getAnnotations();
+            TypeReference rTypeReference = new TypeReference(resultQName, returnType, rann);
+            Parameter returnParameter = new Parameter(rTypeReference, com.sun.xml.internal.ws.model.Mode.OUT, -1);
+            returnParameter.setPartName(resultPartName);
+            if(isResultHeader){
+                returnParameter.setBinding(ParameterBinding.HEADER);
+                javaMethod.addParameter(returnParameter);
+            }else{
+                ParameterBinding rb = getBinding(binding, operationName, resultPartName, false, com.sun.xml.internal.ws.model.Mode.OUT);
+                returnParameter.setBinding(rb);
+                if(rb.isBody() || rb.isUnbound()){
+                    Part p = getPart(operationName, resultPartName, Mode.OUT);
+                    if(p == null)
+                        resRpcParams.put(resRpcParams.size(), returnParameter);
+                    else
+                        resRpcParams.put(p.getIndex(), returnParameter);
+                    //responseWrapper.addWrapperChild(returnParameter);
+                }else{
+                    javaMethod.addParameter(returnParameter);
+                }
+            }
+        }
+
+        //get WebParam
+        Class<?>[] parameterTypes = method.getParameterTypes();
+        Type[] genericParameterTypes = method.getGenericParameterTypes();
+        Annotation[][] pannotations = getPrivParameterAnnotations(method);
+        int pos = 0;
+        QName paramQName = null;
+        for (Class clazzType : parameterTypes) {
+            Parameter param = null;
+            String paramName = "";
+            String paramNamespace = "";
+            String partName = "";
+            boolean isHeader = false;
+
+            if(javaMethod.isAsync() && AsyncHandler.class.isAssignableFrom(clazzType)){
+                continue;
+            }
+
+            boolean isHolder = HOLDER_CLASS.isAssignableFrom(clazzType);
+            //set the actual type argument of Holder in the TypeReference
+            if (isHolder) {
+                if (clazzType.getName().equals(Holder.class.getName()))
+                    clazzType = Navigator.REFLECTION.erasure(((ParameterizedType)genericParameterTypes[pos]).getActualTypeArguments()[0]);
+            }
+            com.sun.xml.internal.ws.model.Mode paramMode = isHolder ?
+                com.sun.xml.internal.ws.model.Mode.INOUT :
+                com.sun.xml.internal.ws.model.Mode.IN;
+            for (Annotation annotation : pannotations[pos]) {
+                if (annotation.annotationType() == javax.jws.WebParam.class) {
+                    javax.jws.WebParam webParam = (javax.jws.WebParam) annotation;
+                    paramName = webParam.name();
+                    partName = webParam.partName();
+                    isHeader = webParam.header();
+                    WebParam.Mode mode = webParam.mode();
+                    paramNamespace = webParam.targetNamespace();
+                    if (isHolder && mode == javax.jws.WebParam.Mode.IN)
+                        mode = javax.jws.WebParam.Mode.INOUT;
+                    paramMode = (mode == javax.jws.WebParam.Mode.IN) ? com.sun.xml.internal.ws.model.Mode.IN :
+                        (mode == javax.jws.WebParam.Mode.INOUT) ? com.sun.xml.internal.ws.model.Mode.INOUT :
+                        com.sun.xml.internal.ws.model.Mode.OUT;
+                    break;
+                }
+            }
+
+            if (paramName.length() == 0) {
+                paramName = "arg"+pos;
+            }
+            if (partName.length() == 0) {
+                partName = paramName;
+            } else if (!isHeader) {
+                paramName = partName;
+            }
+            if (partName.length() == 0) {
+                partName = paramName;
+            }
+
+            if (!isHeader) {
+                //its rpclit body param, set namespace to ""
+                paramQName = new QName("", paramName);
+            } else {
+                if (paramNamespace.length() == 0)
+                    paramNamespace = targetNamespace;
+                paramQName = new QName(paramNamespace, paramName);
+            }
+            typeRef =
+                new TypeReference(paramQName, clazzType, pannotations[pos]);
+
+            param = new Parameter(typeRef, paramMode, pos++);
+            param.setPartName(partName);
+
+            if(paramMode == Mode.INOUT){
+                ParameterBinding pb = getBinding(binding, operationName, partName, isHeader, Mode.IN);
+                param.setInBinding(pb);
+                pb = getBinding(binding, operationName, partName, isHeader, Mode.OUT);
+                param.setOutBinding(pb);
+            }else{
+                if (isHeader) {
+                    param.setBinding(ParameterBinding.HEADER);
+                } else {
+                    ParameterBinding pb = getBinding(binding, operationName, partName, false, paramMode);
+                    param.setBinding(pb);
+                }
+            }
+            if(param.getInBinding().isBody()){
+                if(!param.isOUT()){
+                    Part p = getPart(operationName, partName, Mode.IN);
+                    if(p == null)
+                        reqRpcParams.put(reqRpcParams.size(), param);
+                    else
+                        reqRpcParams.put(p.getIndex(), param);
+                    //requestWrapper.addWrapperChild(param);
+                }
+
+                if(!param.isIN()){
+                    if (isOneway) {
+                            throw new RuntimeModelerException("runtime.modeler.oneway.operation.no.out.parameters",
+                                    new Object[] {portClass.getCanonicalName(), methodName});
+                    }
+                    Part p = getPart(operationName, partName, Mode.OUT);
+                    if(p == null)
+                        resRpcParams.put(resRpcParams.size(), param);
+                    else
+                        resRpcParams.put(p.getIndex(), param);
+//                        responseWrapper.addWrapperChild(param);
+                }
+            }else{
+                javaMethod.addParameter(param);
+            }
+        }
+        for(int i = 0; i < reqRpcParams.size();i++)
+            requestWrapper.addWrapperChild(reqRpcParams.get(i));
+        for(int i = 0; i < resRpcParams.size();i++)
+            responseWrapper.addWrapperChild(resRpcParams.get(i));
+        processExceptions(javaMethod, method);
+    }
+
+    /**
+     * models the exceptions thrown by <code>method</code> and adds them to the <code>javaMethod</code>
+     * runtime model object
+     * @param javaMethod the runtime model object to add the exception model objects to
+     * @param method the <code>method</code> from which to find the exceptions to model
+     */
+    protected void processExceptions(JavaMethod javaMethod, Method method) {
+        for (Type exception : method.getGenericExceptionTypes()) {
+            if (REMOTE_EXCEPTION_CLASS.isAssignableFrom((Class)exception))
+                continue;
+            Class exceptionBean;
+            Annotation[] anns;
+            WebFault webFault = getPrivClassAnnotation((Class)exception, WebFault.class);
+            Method faultInfoMethod = getWSDLExceptionFaultInfo((Class)exception);
+            ExceptionType exceptionType = ExceptionType.WSDLException;
+            String namespace = targetNamespace;
+            String name = ((Class)exception).getSimpleName();
+            String beanPackage = packageName + PD_JAXWS_PACKAGE_PD;
+            String className = beanPackage+ name + BEAN;
+            if (webFault != null) {
+                if (webFault.faultBean().length()>0)
+                    className = webFault.faultBean();
+                if (webFault.name().length()>0)
+                    name = webFault.name();
+                if (webFault.targetNamespace().length()>0)
+                    namespace = webFault.targetNamespace();
+            }
+            if (faultInfoMethod == null)  {
+                exceptionBean = getClass(className);
+                exceptionType = ExceptionType.UserDefined;
+                anns = exceptionBean.getAnnotations();
+
+            } else {
+                exceptionBean = faultInfoMethod.getReturnType();
+                anns = faultInfoMethod.getAnnotations();
+            }
+            QName faultName = new QName(namespace, name);
+            TypeReference typeRef = new TypeReference(faultName, exceptionBean,
+                anns);
+            CheckedException checkedException =
+                new CheckedException((Class)exception, typeRef, exceptionType);
+            checkedException.setMessageName(((Class)exception).getSimpleName());
+            javaMethod.addException(checkedException);
+        }
+    }
+
+    /**
+     * returns the method that corresponds to "getFaultInfo".  Returns null if this is not an
+     * exception generated from a WSDL
+     * @param exception the class to search for the "getFaultInfo" method
+     * @return the method named "getFaultInfo" if this is an exception generated from WSDL or an
+     * exception that contains the <code>WebFault</code> annotation.  Otherwise it returns null
+     */
+    protected Method getWSDLExceptionFaultInfo(Class exception) {
+        if (getPrivClassAnnotation(exception, WebFault.class) == null)
+            return null;
+        try {
+            Method getFaultInfo = exception.getMethod("getFaultInfo", new Class[0]);
+            return getFaultInfo;
+        } catch (NoSuchMethodException e) {
+            return null;
+        }
+    }
+
+    /**
+     * models a document/literal bare method
+     * @param javaMethod the runtime model <code>JavaMethod</code> instance being created
+     * @param methodName the runtime model <code>JavaMethod</code> instance being created
+     * @param webMethod the runtime model <code>JavaMethod</code> instance being created
+     * @param operationName the runtime model <code>JavaMethod</code> instance being created
+     * @param method the runtime model <code>JavaMethod</code> instance being created
+     * @param webService the runtime model <code>JavaMethod</code> instance being created
+     */
+    protected void processDocBareMethod(JavaMethod javaMethod, String methodName,
+                                        WebMethod webMethod, String operationName, Method method, WebService webService) {
+
+        String resultName = operationName+RESPONSE;
+        String resultTNS = targetNamespace;
+        String resultPartName = null;
+        boolean isResultHeader = false;
+        WebResult webResult = method.getAnnotation(WebResult.class);
+        if (webResult != null) {
+            if (webResult.name().length() > 0)
+                resultName = webResult.name();
+            if (webResult.targetNamespace().length() > 0)
+                resultTNS = webResult.targetNamespace();
+            resultPartName = webResult.partName();
+            isResultHeader = webResult.header();
+        }
+        Class returnType = method.getReturnType();
+
+        if(javaMethod.isAsync()){
+            returnType = getAsyncReturnType(method, returnType);
+        }
+
+        QName responseQName = null;
+        if ((returnType != null) && (!returnType.getName().equals("void"))) {
+            Class returnClazz = returnType;
+            Annotation[] rann = method.getAnnotations();
+            QName rqname = null;
+            if (resultName != null) {
+                responseQName = new QName(resultTNS, resultName);
+                TypeReference rTypeReference = new TypeReference(responseQName, returnType, rann);
+                Parameter returnParameter = new Parameter(rTypeReference, com.sun.xml.internal.ws.model.Mode.OUT, -1);
+
+                if(resultPartName == null || (resultPartName.length() == 0)){
+                    resultPartName = resultName;
+                }
+                returnParameter.setPartName(resultPartName);
+                if(isResultHeader){
+                    returnParameter.setBinding(ParameterBinding.HEADER);
+                }else{
+                    ParameterBinding rb = getBinding(binding, operationName, resultPartName, false, com.sun.xml.internal.ws.model.Mode.OUT);
+                    returnParameter.setBinding(rb);
+                }
+                javaMethod.addParameter(returnParameter);
+            }
+        }
+
+        //get WebParam
+        Class<?>[] parameterTypes = method.getParameterTypes();
+        Type[] genericParameterTypes = method.getGenericParameterTypes();
+        Annotation[][] pannotations = getPrivParameterAnnotations(method);
+        QName requestQName = null;
+        int pos = 0;
+        for (Class clazzType : parameterTypes) {
+            Parameter param = null;
+            String paramName = operationName; //method.getName();
+            String partName = null;
+            String requestNamespace = targetNamespace;
+            boolean isHeader = false;
+
+            //async
+            if(javaMethod.isAsync() && AsyncHandler.class.isAssignableFrom(clazzType)){
+                continue;
+            }
+
+            boolean isHolder = HOLDER_CLASS.isAssignableFrom(clazzType);
+            //set the actual type argument of Holder in the TypeReference
+            if (isHolder) {
+                if (clazzType.getName().equals(Holder.class.getName()))
+                    clazzType = Navigator.REFLECTION.erasure(((ParameterizedType)genericParameterTypes[pos]).getActualTypeArguments()[0]);
+            }
+
+            com.sun.xml.internal.ws.model.Mode paramMode = isHolder ?
+                com.sun.xml.internal.ws.model.Mode.INOUT :
+                com.sun.xml.internal.ws.model.Mode.IN;
+            for (Annotation annotation : pannotations[pos]) {
+                if (annotation.annotationType() == javax.jws.WebParam.class) {
+                    javax.jws.WebParam webParam = (javax.jws.WebParam) annotation;
+                    if (webParam.name().length() > 0)
+                        paramName = webParam.name();
+                    partName = webParam.partName();
+                    if (!webParam.targetNamespace().equals("")) {
+                        requestNamespace = webParam.targetNamespace();
+                    }
+                    isHeader = webParam.header();
+                    WebParam.Mode mode = webParam.mode();
+                    if (isHolder && mode == javax.jws.WebParam.Mode.IN)
+                        mode = javax.jws.WebParam.Mode.INOUT;
+                    paramMode = (mode == javax.jws.WebParam.Mode.IN) ? com.sun.xml.internal.ws.model.Mode.IN :
+                        (mode == javax.jws.WebParam.Mode.INOUT) ? com.sun.xml.internal.ws.model.Mode.INOUT :
+                        com.sun.xml.internal.ws.model.Mode.OUT;
+                    break;
+                }
+            }
+
+            requestQName = new QName(requestNamespace, paramName);
+            //doclit/wrapped
+            TypeReference typeRef = //operationName with upper 1 char
+                new TypeReference(requestQName, clazzType,
+                    pannotations[pos]);
+
+            param = new Parameter(typeRef, paramMode, pos++);
+            if(partName == null || (partName.length() == 0)){
+                    partName = paramName;
+            }
+            param.setPartName(partName);
+            if(paramMode == com.sun.xml.internal.ws.model.Mode.INOUT){
+                ParameterBinding pb = getBinding(binding, operationName, partName, isHeader, com.sun.xml.internal.ws.model.Mode.IN);
+                param.setInBinding(pb);
+                pb = getBinding(binding, operationName, partName, isHeader, com.sun.xml.internal.ws.model.Mode.OUT);
+                param.setOutBinding(pb);
+            }else{
+                if (isHeader){
+                    param.setBinding(ParameterBinding.HEADER);
+                }else{
+                    ParameterBinding pb = getBinding(binding, operationName, partName, false, paramMode);
+                    param.setBinding(pb);
+                }
+            }
+            javaMethod.addParameter(param);
+        }
+        processExceptions(javaMethod, method);
+    }
+
+    private Class getAsyncReturnType(Method method, Class returnType) {
+        if(Response.class.isAssignableFrom(returnType)){
+            Type ret = method.getGenericReturnType();
+            return Navigator.REFLECTION.erasure(((ParameterizedType)ret).getActualTypeArguments()[0]);
+        }else{
+            Type[] types = method.getGenericParameterTypes();
+            Class[] params = method.getParameterTypes();
+            int i = 0;
+            for(Class cls : params){
+                if(AsyncHandler.class.isAssignableFrom(cls)){
+                    return Navigator.REFLECTION.erasure(((ParameterizedType)types[i]).getActualTypeArguments()[0]);
+                }
+                i++;
+            }
+        }
+        return returnType;
+    }
+
+    /**
+     * utility to capitalize the first letter in a string
+     * @param name the string to capitalize
+     * @return the capitalized string
+     */
+    public static String capitalize(String name) {
+        if (name == null || name.length() == 0) {
+            return name;
+        }
+        char chars[] = name.toCharArray();
+        chars[0] = Character.toUpperCase(chars[0]);
+        return new String(chars);
+    }
+
+    /*
+    * Return service QName
+    */
+    /**
+     * gets the <code>wsdl:serviceName</code> for a given implementation class
+     * @param implClass the implementation class
+     * @return the <code>wsdl:serviceName</code> for the <code>implClass</code>
+     */
+    public static QName getServiceName(Class implClass) {
+        if (implClass.isInterface()) {
+            throw new RuntimeModelerException("runtime.modeler.cannot.get.serviceName.from.interface",
+                                    new Object[] {implClass.getCanonicalName()});
+        }
+
+        String name = implClass.getSimpleName()+SERVICE;
+        String packageName = null;
+        if (implClass.getPackage() != null)
+            packageName = implClass.getPackage().getName();
+
+        WebService webService =
+            (WebService)implClass.getAnnotation(WebService.class);
+        if (webService == null) {
+            throw new RuntimeModelerException("runtime.modeler.no.webservice.annotation",
+                                    new Object[] {implClass.getCanonicalName()});
+        }
+        if (webService.serviceName().length() > 0) {
+            name = webService.serviceName();
+        }
+        String targetNamespace = getNamespace(packageName);
+        if (webService.targetNamespace().length() > 0) {
+            targetNamespace = webService.targetNamespace();
+        } else if (targetNamespace == null) {
+            throw new RuntimeModelerException("runtime.modeler.no.package",
+                             new Object[] {implClass.getName()});
+        }
+
+
+
+        return new QName(targetNamespace, name);
+    }
+
+    /**
+     * gets the <code>wsdl:portName</code> for a given implementation class
+     * @param implClass the implementation class
+     * @param targetNamespace Namespace URI for service name
+     * @return the <code>wsdl:portName</code> for the <code>implClass</code>
+     */
+    public static QName getPortName(Class implClass, String targetNamespace) {
+        WebService webService =
+            (WebService)implClass.getAnnotation(WebService.class);
+        if (webService == null) {
+            throw new RuntimeModelerException("runtime.modeler.no.webservice.annotation",
+                new Object[] {implClass.getCanonicalName()});
+        }
+        String name = null;
+        if (webService.portName().length() > 0) {
+            name = webService.portName();
+        } else if (webService.name().length() > 0) {
+            name = webService.name()+PORT;
+        } else {
+            name = implClass.getSimpleName()+PORT;
+        }
+
+        if (targetNamespace == null) {
+            if (webService.targetNamespace().length() > 0) {
+                targetNamespace = webService.targetNamespace();
+            } else {
+                String packageName = null;
+                if (implClass.getPackage() != null) {
+                    packageName = implClass.getPackage().getName();
+                }
+                targetNamespace = getNamespace(packageName);
+                if (targetNamespace == null) {
+                    throw new RuntimeModelerException("runtime.modeler.no.package",
+                        new Object[] {implClass.getName()});
+                }
+            }
+
+        }
+
+        return new QName(targetNamespace, name);
+    }
+
+    /**
+     * Gives portType QName from implementatorClass or SEI
+     * @param  implOrSeiClass cant be null
+     * @return  <code>wsdl:portType@name</code>, null if it could not find the annotated class.
+     */
+    public static QName getPortTypeName(Class implOrSeiClass){
+        assert(implOrSeiClass != null);
+        Class clazz = implOrSeiClass;
+        WebService webService = null;
+        if (!implOrSeiClass.isAnnotationPresent(javax.jws.WebService.class))
+                throw new RuntimeModelerException("runtime.modeler.no.webservice.annotation",
+                                           new Object[] {implOrSeiClass.getCanonicalName()});
+
+        if (!implOrSeiClass.isInterface()) {
+            webService = (WebService) implOrSeiClass.getAnnotation(WebService.class);
+            String epi = webService.endpointInterface();
+            if (epi.length() > 0) {
+                try {
+                    clazz = Thread.currentThread().getContextClassLoader().loadClass(epi);
+                } catch (ClassNotFoundException e) {
+                    throw new RuntimeModelerException("runtime.modeler.class.not.found",
+                                 new Object[] {epi});
+                }
+                if (!clazz.isAnnotationPresent(javax.jws.WebService.class)) {
+                    throw new RuntimeModelerException("runtime.modeler.endpoint.interface.no.webservice",
+                                        new Object[] {webService.endpointInterface()});
+                }
+            }
+        }
+
+        webService = (WebService) clazz.getAnnotation(WebService.class);
+        String name = webService.name();
+        if(name.length() == 0){
+            name = clazz.getSimpleName();
+        }
+
+        String tns = webService.targetNamespace();
+        if (tns.length() == 0)
+            tns = getNamespace(clazz.getPackage().getName());
+        if (tns == null) {
+            throw new RuntimeModelerException("runtime.modeler.no.package",
+                new Object[] {clazz.getName()});
+        }
+        return new QName(tns, name);
+    }
+
+    public static String getBindingId(Class implClass) {
+        BindingType bindingType =
+            (BindingType)implClass.getAnnotation(BindingType.class);
+        if (bindingType != null) {
+            String bindingId = bindingType.value();
+            if (bindingId.length() > 0) {
+                if (!bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_BINDING)
+                    && !bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_MTOM_BINDING)
+                    && !bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING)
+                    && !bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_MTOM_BINDING)
+                    && !bindingId.equals(HTTPBinding.HTTP_BINDING)
+                    && !bindingId.equals(SOAPBindingImpl.X_SOAP12HTTP_BINDING)) {
+                    throw new IllegalArgumentException("Wrong binding id "+bindingId+" in @BindingType");
+                }
+                return bindingId;
+            }
+        }
+        return null;
+    }
+
+    private ParameterBinding getBinding(com.sun.xml.internal.ws.wsdl.parser.Binding binding, String operation, String part, boolean isHeader, Mode mode){
+        if(binding == null){
+            if(isHeader)
+                return ParameterBinding.HEADER;
+            else
+                return ParameterBinding.BODY;
+        }
+        BindingOperation bo = binding.get(operation);
+
+        //if the binding Operation corresponding to the operation is not found in the WSDL then
+        //throw the exception
+        if(bo == null){
+            throw new RuntimeModelerException("runtime.operation.noBinding", operation, portName);
+        }
+
+        return binding.getBinding(bo, part, mode);
+    }
+
+    private Part getPart(String opName, String partName, Mode mode){
+        if(binding != null){
+            BindingOperation bo = binding.get(opName);
+            if(bo != null)
+                return bo.getPart(partName, mode);
+        }
+        return null;
+    }
+
+
+    public String getBindingId() {
+        return bindingId;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/modeler/RuntimeModelerException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/modeler/RuntimeModelerException.java
new file mode 100644
index 0000000..b91227a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/modeler/RuntimeModelerException.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.modeler;
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * RuntimeModelerException represents an exception that occurred while
+ * serializing a Java value as XML.
+ *
+ * @see JAXWSExceptionBase
+ *
+ * @author WS Development Team
+ */
+public class RuntimeModelerException extends JAXWSExceptionBase {
+
+    public RuntimeModelerException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public RuntimeModelerException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public RuntimeModelerException(Localizable arg) {
+        super("nestedModelerError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.modeler";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/package-info.java
new file mode 100644
index 0000000..33128e3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/package-info.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *
+ * <P>This document describes the architecture of JAX-WS 2.0 runtime. JAX-WS is
+ * the aggregating component of what is called the integrated Stack
+ * (I-Stack). The I-Stack consists of JAX-WS, JAX-B, StAX, SAAJ and Fast
+ * Infoset. JAX-B is the databinding component of the stack. StAX is the
+ * Streaming XML parser used by the stack. SAAJ is used for its
+ * attachment support with SOAP messages and to allow handler developers
+ * to gain access to the SOAP message via a standard interface. Fast
+ * Infoset is a binary encoding of XML that can improve performance.</P>
+ * <P>JAX-WS 2.0 was originally called JAX-RPC 2.0 and was hence
+ * developed from the JAX-RPC 1.1 code base. JAX-WS has been
+ * significanlty rearchitected to for extensibility going forward by
+ * incorporating and implementing concepts from <A HREF="pept.html">PEPT</A>.
+ * PEPT presents four main components presentation, encoding, protocol
+ * and transport. Ideally each of these components would not be
+ * dependent on another, however, due to time constraints an optimal
+ * PEPT implementation was not possible and thus some of the PEPT
+ * boundaries have been blurred. Future versions of JAX-WS may sharpen
+ * these boundaries when possible.</P>
+ * <P>The remainder of this document will describe the JAX-WS runtime
+ * architecture from the client and server perspectives.</P>
+ *
+ * <p>
+ * <dl>
+ *  <dt>{@link com.sun.xml.internal.ws.server Server}
+ *  <dd>
+ *    The server side portion of the JAX-WS runtime.
+ *
+ *  <dt>{@link com.sun.xml.internal.ws.client Client}
+ *  <dd>
+ *    The client side portion of the JAX-WS runtime.
+ *
+ * </dl>
+ *
+ * @ArchitectureDocument
+ **/
+package com.sun.xml.internal.ws;
+
+//import javax.xml.ws.Binding;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/Delegate.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/Delegate.java
new file mode 100644
index 0000000..2bcced9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/Delegate.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "Delegate.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept;
+
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface Delegate {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a MessageStruct with ...
+ * </p>
+ */
+    public MessageStruct getMessageStruct();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param message ...
+ * </p>
+ */
+    public void send(MessageStruct message);
+
+} // end Delegate
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/encoding/Decoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/encoding/Decoder.java
new file mode 100644
index 0000000..3f30243
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/encoding/Decoder.java
@@ -0,0 +1,67 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "Decoder.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.encoding;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface Decoder {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageInfo ...
+ * </p>
+ */
+    public void decode(MessageInfo messageInfo);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageInfo ...
+ * </p>
+ */
+    public void receiveAndDecode(MessageInfo messageInfo);
+
+} // end Decoder
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/encoding/Encoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/encoding/Encoder.java
new file mode 100644
index 0000000..cf3e0a4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/encoding/Encoder.java
@@ -0,0 +1,68 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "Encoder.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.encoding;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import java.nio.ByteBuffer;
+
+/**
+ * <p>
+ *
+ * @author Arun Gupta
+ * </p>
+ */
+public interface Encoder {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageInfo ...
+ * </p>
+ */
+    public void encodeAndSend(MessageInfo messageInfo);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a ByteBuffer with ...
+ * </p><p>
+ * @param messageInfo ...
+ * </p>
+ */
+    public ByteBuffer encode(MessageInfo messageInfo);
+
+} // end Encoder
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/Acceptor.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/Acceptor.java
new file mode 100644
index 0000000..ffcaa40
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/Acceptor.java
@@ -0,0 +1,51 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "Acceptor.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.ept;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface Acceptor extends EPTFactory {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p>
+ */
+    public void accept();
+
+} // end Acceptor
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfo.java
new file mode 100644
index 0000000..e89ff0b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfo.java
@@ -0,0 +1,55 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "ContactInfo.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.ept;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface ContactInfo extends EPTFactory {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Connection with ...
+ * </p><p>
+ * @param messageInfo ...
+ * </p>
+ */
+    public WSConnection getConnection(MessageInfo messageInfo);
+
+} // end ContactInfo
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfoList.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfoList.java
new file mode 100644
index 0000000..b1e3868
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfoList.java
@@ -0,0 +1,52 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "ContactInfoList.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.ept;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface ContactInfoList {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a ContactInfoListIterator with ...
+ * </p>
+ */
+    public ContactInfoListIterator iterator();
+
+} // end ContactInfoList
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfoListIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfoListIterator.java
new file mode 100644
index 0000000..2810db6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/ContactInfoListIterator.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "ContactInfoListIterator.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.ept;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface ContactInfoListIterator {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a boolean with ...
+ * </p>
+ */
+    public boolean hasNext();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a ContactInfo with ...
+ * </p>
+ */
+    public ContactInfo next();
+
+} // end ContactInfoListIterator
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/EPTFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/EPTFactory.java
new file mode 100644
index 0000000..44fc0b4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/EPTFactory.java
@@ -0,0 +1,104 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "EPTFactory.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.ept;
+
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.presentation.TargetFinder;
+import com.sun.xml.internal.ws.pept.protocol.Interceptors;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface EPTFactory {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a MessageDispatcher with ...
+ * </p><p>
+ * @param messageInfo ...
+ * </p>
+ */
+    public MessageDispatcher getMessageDispatcher(MessageInfo messageInfo);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Encoder with ...
+ * </p><p>
+ * @param messageInfo ...
+ * </p>
+ */
+    public Encoder getEncoder(MessageInfo messageInfo);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Decoder with ...
+ * </p><p>
+ * @param messageInfo ...
+ * </p>
+ */
+    public Decoder getDecoder(MessageInfo messageInfo);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Interceptors with ...
+ * </p><p>
+ * @param x ...
+ * </p>
+ */
+    public Interceptors getInterceptors(MessageInfo x);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a TargetFinder with ...
+ * </p><p>
+ * @param x ...
+ * </p>
+ */
+    public TargetFinder getTargetFinder(MessageInfo x);
+
+} // end EPTFactory
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/MessageInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/MessageInfo.java
new file mode 100644
index 0000000..af6d518
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/ept/MessageInfo.java
@@ -0,0 +1,149 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "MessageInfo.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.ept;
+
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface MessageInfo extends MessageStruct {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a EPTFactory with ...
+ * </p>
+ */
+    public EPTFactory getEPTFactory();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a MessageDispatcher with ...
+ * </p>
+ */
+    public MessageDispatcher getMessageDispatcher();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Encoder with ...
+ * </p>
+ */
+    public Encoder getEncoder();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Decoder with ...
+ * </p>
+ */
+    public Decoder getDecoder();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Connection with ...
+ * </p>
+ */
+    public WSConnection getConnection();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param eptFactory ...
+ * </p>
+ */
+    public void setEPTFactory(EPTFactory eptFactory);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageDispatcher ...
+ * </p>
+ */
+    public void setMessageDispatcher(MessageDispatcher messageDispatcher);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param encoder ...
+ * </p>
+ */
+    public void setEncoder(Encoder encoder);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param decoder ...
+ * </p>
+ */
+    public void setDecoder(Decoder decoder);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param connection ...
+ * </p>
+ */
+    public void setConnection(WSConnection connection);
+
+} // end MessageInfo
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/MessageStruct.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/MessageStruct.java
new file mode 100644
index 0000000..58021ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/MessageStruct.java
@@ -0,0 +1,222 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "MessageStruct.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.presentation;
+
+import java.lang.reflect.Method;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface MessageStruct {
+
+  ///////////////////////////////////////
+  //attributes
+
+
+/**
+ * <p>
+ * Represents ...
+ * </p>
+ */
+    public static final int NORMAL_RESPONSE = 0;
+
+/**
+ * <p>
+ * Represents ...
+ * </p>
+ */
+    public static final int CHECKED_EXCEPTION_RESPONSE = 1;
+
+/**
+ * <p>
+ * Represents ...
+ * </p>
+ */
+    public static final int UNCHECKED_EXCEPTION_RESPONSE = 2;
+
+/**
+ * <p>
+ * Represents ...
+ * </p>
+ */
+    public static final int REQUEST_RESPONSE_MEP = 1;
+
+/**
+ * <p>
+ * Represents ...
+ * </p>
+ */
+    public static final int ONE_WAY_MEP = 2;
+
+/**
+ * <p>
+ * Represents ...
+ * </p>
+ */
+    public static final int ASYNC_POLL_MEP = 3;
+
+/**
+ * <p>
+ * Represents ...
+ * </p>
+ */
+    public static final int ASYNC_CALLBACK_MEP = 4;
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @param data ...
+ * </p><p>
+ *
+ * </p>
+ */
+    public void setData(Object[] data);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Object[] with ...
+ * </p>
+ */
+    public Object[] getData();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param name ...
+ * </p><p>
+ * @param value ...
+ * </p>
+ */
+    public void setMetaData(Object name, Object value);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Object with ...
+ * </p><p>
+ * @param name ...
+ * </p>
+ */
+    public Object getMetaData(Object name);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageExchangePattern ...
+ * </p>
+ */
+    public void setMEP(int messageExchangePattern);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a int with ...
+ * </p>
+ */
+    public int getMEP();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a int with ...
+ * </p>
+ */
+    public int getResponseType();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param responseType ...
+ * </p>
+ */
+    public void setResponseType(int responseType);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Object with ...
+ * </p>
+ */
+    public Object getResponse();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param response ...
+ * </p>
+ */
+    public void setResponse(Object response);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param method ...
+ * </p>
+ */
+    public void setMethod(Method method);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Method with ...
+ * </p>
+ */
+    public Method getMethod();
+
+} // end MessageStruct
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/Stub.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/Stub.java
new file mode 100644
index 0000000..2667efb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/Stub.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "Stub.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.presentation;
+
+import com.sun.xml.internal.ws.pept.Delegate;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface Stub {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param delegate ...
+ * </p>
+ */
+    public void _setDelegate(Delegate delegate);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Delegate with ...
+ * </p>
+ */
+    public Delegate _getDelegate();
+
+} // end Stub
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/TargetFinder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/TargetFinder.java
new file mode 100644
index 0000000..c1dbe94
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/TargetFinder.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "TargetFinder.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.presentation;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface TargetFinder {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Tie with ...
+ * </p><p>
+ * @param x ...
+ * </p>
+ */
+    public Tie findTarget(MessageInfo x);
+
+} // end TargetFinder
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/Tie.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/Tie.java
new file mode 100644
index 0000000..217e77a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/presentation/Tie.java
@@ -0,0 +1,76 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "Tie.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.presentation;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface Tie {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param servant ...
+ * </p>
+ */
+    public void _setServant(Object servant);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * @return a Object with ...
+ * </p>
+ */
+    public Object _getServant();
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageInfo ...
+ * </p>
+ */
+    public void _invoke(MessageInfo messageInfo);
+
+} // end Tie
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/protocol/Interceptors.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/protocol/Interceptors.java
new file mode 100644
index 0000000..d03f86e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/protocol/Interceptors.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "Interceptors.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.protocol;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface Interceptors {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageInfo ...
+ * </p>
+ */
+    public void interceptMessage(MessageInfo messageInfo);
+
+} // end Interceptors
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/protocol/MessageDispatcher.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/protocol/MessageDispatcher.java
new file mode 100644
index 0000000..7a48dee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/pept/protocol/MessageDispatcher.java
@@ -0,0 +1,67 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+/** Java interface "MessageDispatcher.java" generated from Poseidon for UML.
+ *  Poseidon for UML is developed by <A HREF="http://www.gentleware.com">Gentleware</A>.
+ *  Generated with <A HREF="http://jakarta.apache.org/velocity/">velocity</A> template engine.
+ */
+package com.sun.xml.internal.ws.pept.protocol;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+
+/**
+ * <p>
+ *
+ * @author Dr. Harold Carr
+ * </p>
+ */
+public interface MessageDispatcher {
+
+  ///////////////////////////////////////
+  // operations
+
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageInfo ...
+ * </p>
+ */
+    public void send(MessageInfo messageInfo);
+/**
+ * <p>
+ * Does ...
+ * </p><p>
+ *
+ * </p><p>
+ *
+ * @param messageInfo ...
+ * </p>
+ */
+    public void receive(MessageInfo messageInfo);
+
+} // end MessageDispatcher
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/client/SOAPMessageDispatcher.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/client/SOAPMessageDispatcher.java
new file mode 100644
index 0000000..9e1b960
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/client/SOAPMessageDispatcher.java
@@ -0,0 +1,1012 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.protocol.soap.client;
+
+import com.sun.xml.internal.messaging.saaj.soap.MessageImpl;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.client.AsyncHandlerService;
+import com.sun.xml.internal.ws.client.ContextMap;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.*;
+import com.sun.xml.internal.ws.client.EndpointIFInvocationHandler;
+import com.sun.xml.internal.ws.client.EndpointIFContext;
+import com.sun.xml.internal.ws.client.RequestContext;
+import com.sun.xml.internal.ws.client.ResponseContext;
+import com.sun.xml.internal.ws.client.WSFuture;
+import com.sun.xml.internal.ws.client.dispatch.DispatchContext;
+import com.sun.xml.internal.ws.client.dispatch.ResponseImpl;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAP12XMLEncoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLDecoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLEncoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.internal.MessageInfoBase;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller.Direction;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller.RequestOrResponse;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.handler.SOAPHandlerContext;
+import com.sun.xml.internal.ws.model.JavaMethod;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.spi.runtime.ClientTransportFactory;
+import com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegate;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.transport.http.client.HttpClientTransportFactory;
+import com.sun.xml.internal.ws.util.Base64Util;
+import com.sun.xml.internal.ws.util.FastInfosetUtil;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPConnectionUtil;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import com.sun.xml.internal.ws.wsdl.parser.BindingOperation;
+import javax.activation.DataHandler;
+import javax.xml.bind.JAXBException;
+import javax.xml.namespace.QName;
+import javax.xml.soap.MimeHeader;
+import javax.xml.soap.SOAPBody;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPFactory;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.soap.SOAPPart;
+import javax.xml.transform.Source;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.ws.Binding;
+import javax.xml.ws.BindingProvider;
+import javax.xml.ws.ProtocolException;
+import javax.xml.ws.Service;
+import javax.xml.ws.Response;
+import javax.xml.ws.WebServiceException;
+import static javax.xml.ws.BindingProvider.PASSWORD_PROPERTY;
+import static javax.xml.ws.BindingProvider.USERNAME_PROPERTY;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.handler.soap.SOAPMessageContext;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.ws.soap.SOAPFaultException;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.lang.reflect.Proxy;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.concurrent.Callable;
+import java.util.concurrent.FutureTask;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
+import java.util.concurrent.ThreadFactory;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+
+/**
+ * Client-side SOAP protocol-specific {@link com.sun.pept.protocol.MessageDispatcher}
+ *
+ * @author WS Development Team
+ */
+public class SOAPMessageDispatcher implements MessageDispatcher {
+
+    protected static final int MAX_THREAD_POOL_SIZE = 3;
+
+    protected static final long AWAIT_TERMINATION_TIME = 10L;
+
+    protected ExecutorService executorService;
+
+    private final static String MUST_UNDERSTAND_FAULT_MESSAGE_STRING = "SOAP must understand error";
+
+    /**
+     * Default constructor
+     */
+    public SOAPMessageDispatcher() {
+    }
+
+    /*
+     * Invokes doSendAsync method if the message exchange pattern is asynchronous, otherwise
+     * invokes doSend method.
+     *
+     * @see com.sun.pept.protocol.MessageDispatcher#send(com.sun.pept.ept.MessageInfo)
+     */
+    public void send(MessageInfo messageInfo) {
+        if (isAsync(messageInfo)) {
+            doSendAsync(messageInfo);
+        } else {
+            doSend(messageInfo);
+        }
+    }
+
+    /**
+     * Orchestrates the sending of a synchronous request
+     */
+    protected SOAPMessage doSend(MessageInfo messageInfo) {
+        //change from LogicalEPTFactory to ContactInfoBase - should be changed back when we have things working
+        EPTFactory contactInfo = messageInfo.getEPTFactory();
+        SOAPXMLEncoder encoder = (SOAPXMLEncoder) contactInfo.getEncoder(messageInfo);
+        SOAPMessage sm = null;
+        boolean handlerResult = true;
+        boolean isRequestResponse = (messageInfo.getMEP() == MessageStruct.REQUEST_RESPONSE_MEP);
+
+        try {
+            if (messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) == Service.Mode.MESSAGE)
+            {
+                sm = (SOAPMessage) messageInfo.getData()[0];
+                // Ensure supplied message is encoded according to conneg
+                FastInfosetUtil.ensureCorrectEncoding(messageInfo, sm);
+            }
+
+            SOAPHandlerContext handlerContext = null;
+            InternalMessage im = encoder.toInternalMessage(messageInfo);
+
+            HandlerChainCaller caller = getHandlerChainCaller(messageInfo);
+            if (caller.hasHandlers()) {
+                im = preHandlerOutboundHook(sm, im);
+                handlerContext = new SOAPHandlerContext(messageInfo, im, sm);
+
+                //this is needed so that attachments are compied from RESPONSE_MESSAGE_ATTACHMEMTN PROPERTY
+                handlerContext.getMessageContext().put(
+                    MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.TRUE);
+
+                encoder.setAttachmentsMap(messageInfo, im);
+                updateMessageContext(messageInfo, handlerContext);
+
+                //now that the MESSAGE_OUTBOUND_PROPERTY is set so populate the attachemnts
+                handlerContext.populateAttachmentMap();
+
+                JAXWSAttachmentMarshaller am = MessageInfoUtil.getAttachmentMarshaller(messageInfo);
+                boolean isXopped = false;
+                //there are handlers so disable Xop encoding if enabled, so that they dont
+                // see xop:Include reference
+                if ((am != null) && am.isXOPPackage()) {
+                    isXopped = am.isXOPPackage();
+                    am.setXOPPackage(false);
+                }
+                handlerResult = callHandlersOnRequest(handlerContext);
+                // now put back the old value
+                if ((am != null)) {
+                    am.setXOPPackage(isXopped);
+                }
+
+                sm = handlerContext.getSOAPMessage();
+                postHandlerOutboundHook(messageInfo, handlerContext, sm);
+                if (sm == null) {
+                    sm = encoder.toSOAPMessage(handlerContext.getInternalMessage(), messageInfo);
+                }
+
+                // the only case where no message is sent
+                if (isRequestResponse && !handlerResult) {
+                    SOAPXMLDecoder decoder = (SOAPXMLDecoder) contactInfo.getDecoder(messageInfo);
+                    im = decoder.toInternalMessage(sm, messageInfo);
+                    decoder.toMessageInfo(im, messageInfo);
+                    return sm;
+                }
+            }
+
+            // Setting encoder here is necessary for calls to getBindingId()
+            messageInfo.setEncoder(encoder);
+
+            SystemHandlerDelegate systemHandlerDelegate =
+                ((com.sun.xml.internal.ws.spi.runtime.Binding) getBinding(messageInfo)).
+                    getSystemHandlerDelegate();
+            if (systemHandlerDelegate != null) {
+                if (handlerContext == null) {
+                    handlerContext = new SOAPHandlerContext(messageInfo, im, sm);
+                    //this is needed so that attachments are compied from RESPONSE_MESSAGE_ATTACHMEMTN PROPERTY
+                    handlerContext.getMessageContext().put(
+                        MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.TRUE);
+
+                    //now that the MESSAGE_OUTBOUND_PROPERTY is set so populate the attachemnts
+                    handlerContext.populateAttachmentMap();
+
+                    updateMessageContext(messageInfo, handlerContext);
+                }
+
+                encoder.setAttachmentsMap(messageInfo, im);
+                //already used im, we can set that to null
+                if ((sm != null) && (im != null))
+                    handlerContext.setInternalMessage(null);
+
+
+                handlerContext.getBindingId();
+                systemHandlerDelegate.processRequest(
+                    handlerContext.getSHDSOAPMessageContext());
+                sm = handlerContext.getSOAPMessage();
+            }
+
+            if (sm == null){
+                sm = encoder.toSOAPMessage(im, messageInfo);
+                if (handlerContext == null)
+                    handlerContext = new SOAPHandlerContext(messageInfo, im, sm);
+                updateMessageContext(messageInfo, handlerContext);
+            }
+
+
+            Map<String, Object> context = processMetadata(messageInfo, sm);
+
+            setConnection(messageInfo, context);
+
+            if (!isAsync(messageInfo)) {
+                WSConnection connection = (WSConnection) messageInfo.getConnection();
+
+                logRequestMessage(sm, messageInfo);
+                SOAPConnectionUtil.sendResponse(connection, sm);
+            }
+
+            if (isRequestResponse) {
+                receive(messageInfo);
+            } else if (isOneway(messageInfo)) {
+                checkReturnStatus(messageInfo);
+            }
+        } catch (WebServiceException wse) {
+            setResponseType(wse, messageInfo);
+            messageInfo.setResponse(wse);
+        } catch (Throwable e) {
+            RuntimeException ex = (RuntimeException) e;
+            setResponseType(ex, messageInfo);
+            messageInfo.setResponse(ex);
+        }
+        return sm;
+    }
+
+
+    private boolean isOneway(MessageInfo messageInfo) {
+        return messageInfo.getMEP() == MessageStruct.ONE_WAY_MEP ? true : false;
+    }
+
+    /**
+     * Process and classify the metadata in MIME headers or message context. <String,String> data
+     * is copied into MIME headers and the remaining metadata is passed in message context to the
+     * transport layer.
+     *
+     * @param messageInfo
+     * @param soapMessage
+     */
+    protected Map<String, Object> processMetadata(MessageInfo messageInfo, SOAPMessage soapMessage) {
+        Map<String, Object> messageContext = new HashMap<String, Object>();
+        List<String> header = new ArrayList<String>();
+
+        ContextMap properties = (ContextMap) messageInfo.getMetaData(JAXWS_CONTEXT_PROPERTY);
+
+        if (messageInfo.getMEP() == MessageStruct.ONE_WAY_MEP)
+            messageContext.put(ONE_WAY_OPERATION, "true");
+
+        String soapAction = null;
+        boolean useSoapAction = false;
+
+        // process the properties
+        if (properties != null) {
+            for (Iterator names = properties.getPropertyNames(); names.hasNext();)
+            {
+                String propName = (String) names.next();
+
+                // consume PEPT-specific properties
+                if (propName.equals(ClientTransportFactory.class.getName())) {
+                    messageContext.put(CLIENT_TRANSPORT_FACTORY, (ClientTransportFactory) properties.get(propName));
+                } else if (propName.equals(USERNAME_PROPERTY)) {
+                    String credentials = (String) properties.get(USERNAME_PROPERTY);
+                    if (credentials != null) {
+                        credentials += ":";
+                        String password = (String) properties.get(PASSWORD_PROPERTY);
+                        if (password != null)
+                            credentials += password;
+
+                        try {
+                            credentials = Base64Util.encode(credentials.getBytes());
+                        } catch (Exception ex) {
+                            throw new WebServiceException(ex);
+                        }
+                        soapMessage.getMimeHeaders().addHeader("Authorization", "Basic " + credentials);
+                    }
+                } else
+                if (propName.equals(BindingProvider.SOAPACTION_USE_PROPERTY)) {
+                    useSoapAction = ((Boolean)
+                        properties.get(BindingProvider.SOAPACTION_USE_PROPERTY)).booleanValue();
+                    if (useSoapAction)
+                        soapAction = (String)
+                            properties.get(BindingProvider.SOAPACTION_URI_PROPERTY);
+                } else {
+                    messageContext.put(propName, properties.get(propName));
+                }
+            }
+        }
+
+        // Set accept header depending on content negotiation property
+        String contentNegotiation = (String) messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY);
+
+        String bindingId = getBindingId(messageInfo);
+        if (bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING) || bindingId.equals(SOAPBinding.SOAP12HTTP_MTOM_BINDING))
+        {
+            soapMessage.getMimeHeaders().setHeader(ACCEPT_PROPERTY,
+                contentNegotiation != "none" ? SOAP12_XML_FI_ACCEPT_VALUE : SOAP12_XML_ACCEPT_VALUE);
+        } else {
+            soapMessage.getMimeHeaders().setHeader(ACCEPT_PROPERTY,
+                contentNegotiation != "none" ? XML_FI_ACCEPT_VALUE : XML_ACCEPT_VALUE);
+        }
+
+        messageContext.put(BINDING_ID_PROPERTY, bindingId);
+
+        // SOAPAction: MIME header
+        RuntimeContext runtimeContext = (RuntimeContext) messageInfo.getMetaData(JAXWS_RUNTIME_CONTEXT);
+        if (runtimeContext != null) {
+            JavaMethod javaMethod = runtimeContext.getModel().getJavaMethod(messageInfo.getMethod());
+            if (javaMethod != null) {
+                soapAction = ((com.sun.xml.internal.ws.model.soap.SOAPBinding) javaMethod.getBinding()).getSOAPAction();
+                header.clear();
+                if (bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING) || bindingId.equals(SOAPBinding.SOAP12HTTP_MTOM_BINDING))
+                {
+                    if ((soapAction != null) && (soapAction.length() > 0)) {
+                        ((MessageImpl) soapMessage).setAction(soapAction);
+                    }
+                } else {
+                    if (soapAction == null) {
+                        soapMessage.getMimeHeaders().addHeader("SOAPAction", "\"\"");
+                    } else {
+                        soapMessage.getMimeHeaders().addHeader("SOAPAction", "\"" + soapAction + "\"");
+                    }
+                }
+            }
+        } else
+        if (messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT) != null)
+        {
+            //bug fix 6344358
+            header.clear();
+            if (bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING) || bindingId.equals(SOAPBinding.SOAP12HTTP_MTOM_BINDING))
+            {
+                if ((soapAction != null) && (soapAction.length() > 0)) {
+                    ((MessageImpl) soapMessage).setAction(soapAction);
+                }
+            } else {
+                if (soapAction == null) {
+                    soapMessage.getMimeHeaders().addHeader("SOAPAction", "\"\"");
+                } else {
+                    soapMessage.getMimeHeaders().addHeader("SOAPAction", "\"" + soapAction + "\"");
+                }
+            }
+        }
+
+        return messageContext;
+    }
+
+    protected void setConnection(MessageInfo messageInfo, Map<String, Object> context) {
+        ClientTransportFactory clientTransportFactory = (ClientTransportFactory) context.get(CLIENT_TRANSPORT_FACTORY);
+        WSConnection connection = null;
+        if (clientTransportFactory == null) {
+            clientTransportFactory = new HttpClientTransportFactory();
+            context.put(CLIENT_TRANSPORT_FACTORY, clientTransportFactory);
+        }
+        connection = clientTransportFactory.create(context);
+        messageInfo.setConnection(connection);
+    }
+
+    protected void setResponseType(Throwable e, MessageInfo messageInfo) {
+        if (e instanceof RuntimeException) {
+            messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+        } else {
+            messageInfo.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+        }
+        messageInfo.setResponse(e);
+    }
+
+    public void checkReturnStatus(MessageInfo messageInfo) {
+        WSConnection connection = (WSConnection) messageInfo.getConnection();
+        Map<String, List<String>> headers = connection.getHeaders();
+        if (connection.getStatus() != 202 && connection.getStatus() != 200) {
+            Logger.getAnonymousLogger().log(Level.SEVERE, "HTTP status code for oneway: expected 202 or 200, got " + connection.getStatus());
+//            System.out.println("status: "+connection.getStatus());
+        }
+    }
+
+    /*
+    * Orchestrates the receiving of a synchronous response
+    *
+    * @see com.sun.pept.protocol.MessageDispatcher#receive(com.sun.pept.ept.MessageInfo)
+    *
+    * todo: exception handling with possible saaj error below
+    */
+    public void receive(MessageInfo messageInfo) {
+        // change from LogicalEPTFactory to ContactInfoBase - should be changed back when we have things working
+        EPTFactory contactInfo = messageInfo.getEPTFactory();
+        //LogicalEPTFactory contactInfo = (LogicalEPTFactory) messageInfo.getEPTFactory();
+
+        SOAPXMLDecoder decoder = (SOAPXMLDecoder) contactInfo.getDecoder(messageInfo);
+
+
+        SOAPMessage sm = null;
+        try {
+            sm = decoder.toSOAPMessage(messageInfo);
+        } catch (RuntimeException e) {
+            //if there is a transport error HTTP status code and response Headers
+            //need to be populated into messageContext and requestContext
+            //bug 6373688
+            setContexts(messageInfo, sm);
+            throw e;
+        }
+        // Content negotiation logic
+        String contentNegotiationType = (String) messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY);
+        // If XML request
+        if (contentNegotiationType == "pessimistic") {
+            try {
+                if (((com.sun.xml.internal.messaging.saaj.soap.MessageImpl) sm).isFastInfoset())
+                {
+                    Map requestContext = (Map) messageInfo.getMetaData(JAXWS_CONTEXT_PROPERTY);
+                    // Further requests will be send using FI
+                    requestContext.put(CONTENT_NEGOTIATION_PROPERTY, "optimistic");
+                }
+            }
+            catch (ClassCastException e) {
+                // Content negotiation fails
+            }
+        }
+
+        try {
+            logResponseMessage(sm, messageInfo);
+        } catch (Exception ex) {
+            throw new RuntimeException(ex);
+        }
+        SOAPHandlerContext handlerContext = getInboundHandlerContext(messageInfo, sm);
+        WSConnection con = (WSConnection) messageInfo.getConnection();
+        MessageContextUtil.setHttpStatusCode(handlerContext.getMessageContext(),
+            con.getStatus());
+        MessageContextUtil.setHttpResponseHeaders(handlerContext.getMessageContext(),
+            con.getHeaders());
+
+        //set the handlerContext to RuntimeContext
+        RuntimeContext rtContext = MessageInfoUtil.getRuntimeContext(messageInfo);
+        if (rtContext != null)
+            rtContext.setHandlerContext(handlerContext);
+
+        handlerContext.getMessageContext().put(
+            MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.FALSE);
+        //set MESSAGE_ATTACHMENTS property
+        MessageContext msgCtxt = MessageInfoUtil.getMessageContext(messageInfo);
+        if (msgCtxt != null) {
+            try {
+                //clear the attMap on this messageContext, its from request
+                Map<String, DataHandler> attMap = (Map<String, DataHandler>) msgCtxt.get(MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS);
+                if (attMap != null)
+                    attMap.clear();
+                MessageContextUtil.copyInboundMessageAttachments(msgCtxt, sm.getAttachments());
+            } catch (SOAPException e) {
+                throw new RuntimeException(e);
+            }
+        }
+
+        SystemHandlerDelegate systemHandlerDelegate =
+            ((com.sun.xml.internal.ws.spi.runtime.Binding) getBinding(messageInfo)).
+                getSystemHandlerDelegate();
+        if (systemHandlerDelegate != null) {
+//            handlerContext.getMessageContext().put(
+//                MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.FALSE);
+            try {
+                systemHandlerDelegate.processResponse(handlerContext.getSHDSOAPMessageContext());
+            } catch (Exception e) {
+                throw new RuntimeException(e);
+            }
+        }
+
+        try {
+            MessageInfoUtil.setHandlerChainCaller(messageInfo,
+                getHandlerChainCaller(messageInfo));
+            decoder.doMustUnderstandProcessing(sm, messageInfo, handlerContext, false);
+        } catch (SOAPException se) { // unusual saaj error
+            throw new RuntimeException(se);
+        } catch (IOException ie) { // unusual saaj error
+            throw new RuntimeException(ie);
+        } catch (SOAPFaultException sfe) {
+            closeAllHandlers(handlerContext);
+            throw sfe;
+        }
+
+        HandlerChainCaller caller = getHandlerChainCaller(messageInfo);
+        if (caller.hasHandlers()) {
+            callHandlersOnResponse(handlerContext);
+            postHandlerInboundHook(messageInfo, handlerContext, sm);
+        }
+
+        SOAPXMLEncoder encoder = (SOAPXMLEncoder) contactInfo.getEncoder(messageInfo);
+
+        InternalMessage im = handlerContext.getInternalMessage();
+        if (messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) == Service.Mode.MESSAGE)
+            im = null;
+        if (im == null) {
+            im = decoder.toInternalMessage(sm, messageInfo);
+        } else {
+            im = decoder.toInternalMessage(sm, im, messageInfo);
+        }
+        decoder.toMessageInfo(im, messageInfo);
+        updateResponseContext(messageInfo, handlerContext);
+        if (messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) == Service.Mode.MESSAGE)
+        {
+            messageInfo.setResponse(sm);
+            postReceiveAndDecodeHook(messageInfo);
+        }
+    }
+
+    private void setContexts(MessageInfo messageInfo, SOAPMessage sm) {
+        WSConnection con = (WSConnection) messageInfo.getConnection();
+        SOAPHandlerContext handlerContext = getInboundHandlerContext(messageInfo, sm);
+        MessageContextUtil.setHttpStatusCode(handlerContext.getMessageContext(),
+            con.getStatus());
+        updateResponseContext(messageInfo, handlerContext);
+    }
+
+
+    private SOAPHandlerContext getInboundHandlerContext(MessageInfo messageInfo, SOAPMessage sm) {
+        SOAPHandlerContext handlerContext = (SOAPHandlerContext) messageInfo
+            .getMetaData(BindingProviderProperties.JAXWS_HANDLER_CONTEXT_PROPERTY);
+        if (handlerContext != null) {
+            handlerContext.setSOAPMessage(sm);
+            handlerContext.setInternalMessage(null);
+        } else
+            handlerContext = new SOAPHandlerContext(messageInfo, null, sm);
+        return handlerContext;
+    }
+
+    /**
+     * Orchestrates the sending of an asynchronous request
+     */
+    protected void doSendAsync(final MessageInfo messageInfo) {
+        try { // should have already been caught
+            preSendHook(messageInfo);
+            SOAPMessage sm = doSend(messageInfo);
+            postSendHook(messageInfo);
+
+            //pass a copy of MessageInfo to the future task,so that no conflicts
+            //due to threading happens
+            Response r = sendAsyncReceive(MessageInfoBase.copy(messageInfo), sm);
+            if (executorService == null) {
+                executorService =
+                    Executors.newFixedThreadPool(MAX_THREAD_POOL_SIZE, new DaemonThreadFactory());
+            }
+
+            AsyncHandlerService service = (AsyncHandlerService) messageInfo
+                .getMetaData(BindingProviderProperties.JAXWS_CLIENT_ASYNC_HANDLER);
+            WSFuture wsfuture = null;
+            if (service != null) {
+                wsfuture = service.setupAsyncCallback(r);
+                ((ResponseImpl) r).setUID(service.getUID());
+                ((ResponseImpl) r).setHandlerService(service);
+            }
+
+            executorService.execute((FutureTask) r);
+            if (service == null)
+                messageInfo.setResponse(r);
+            else
+                messageInfo.setResponse(wsfuture);
+        } catch (Throwable e) {
+            messageInfo.setResponse(e);
+        }
+    }
+
+    /**
+     * Orchestrates the receiving of an asynchronous response
+     */
+    protected Response<Object> sendAsyncReceive(final MessageInfo messageInfo, final SOAPMessage sm) {
+
+        final AsyncHandlerService handler = (AsyncHandlerService) messageInfo
+            .getMetaData(BindingProviderProperties.JAXWS_CLIENT_ASYNC_HANDLER);
+        final boolean callback = (messageInfo.getMEP() == MessageStruct.ASYNC_CALLBACK_MEP) ? true
+            : false;
+        if (callback && (handler == null))
+            throw new WebServiceException("Asynchronous callback invocation, but no handler - AsyncHandler required");
+
+        final Response r = new ResponseImpl<Object>(new Callable<Object>() {
+
+            public Object call() throws Exception {
+                // get connection and do http.invoke()
+                try {
+                    final WSConnection connection = (WSConnection) messageInfo.getConnection();
+                    logRequestMessage(sm, messageInfo);
+                    SOAPConnectionUtil.sendResponse(connection, sm);
+                } catch (Throwable t) {
+                    messageInfo.setResponse(t);
+                    messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+                }
+                // receive response
+                preReceiveHook(messageInfo);
+                try {
+                    receive(messageInfo);
+                } catch (Exception ex) {
+                    messageInfo.setResponse(ex);
+                }
+                postReceiveHook(messageInfo);
+
+                if (messageInfo.getResponse() instanceof Exception)
+                    throw (Exception) messageInfo.getResponse();
+                return messageInfo.getResponse();
+            }
+        });
+        messageInfo.setMetaData(JAXWS_CLIENT_ASYNC_RESPONSE_CONTEXT, r);
+        return r;
+    }
+
+
+    protected boolean callHandlersOnRequest(SOAPHandlerContext handlerContext) {
+        try {
+            HandlerChainCaller caller = getHandlerChainCaller(handlerContext.getMessageInfo());
+            boolean responseExpected = (handlerContext.getMessageInfo().getMEP() != MessageStruct.ONE_WAY_MEP);
+            return caller.callHandlers(Direction.OUTBOUND, RequestOrResponse.REQUEST, handlerContext,
+                responseExpected);
+        } catch (ProtocolException pe) {
+            if (MessageContextUtil.ignoreFaultInMessage(
+                handlerContext.getMessageContext())) {
+                // Ignore fault in this case and use exception.
+                throw pe;
+            } else
+                return false;
+        } catch (WebServiceException wse) {
+            throw wse;
+        } catch (RuntimeException re) {
+            // handlers are expected to be able to throw RE
+            throw new WebServiceException(re);
+        }
+    }
+
+    /*
+     * User's handler can throw RuntimeExceptions
+     * (e.g., a ProtocolException).
+     * Need to wrap any RuntimeException (other than WebServiceException) in
+     * WebServiceException.
+     */
+    protected boolean callHandlersOnResponse(SOAPHandlerContext handlerContext) {
+        HandlerChainCaller caller =
+            getHandlerChainCaller(handlerContext.getMessageInfo());
+        try {
+            int httpResponseCode = (Integer) handlerContext.getMessageContext().get(
+                    MessageContext.HTTP_RESPONSE_CODE);
+            if(httpResponseCode != 200 && httpResponseCode != 202) {
+                //Check if it is a fault message
+                SOAPMessage sm = handlerContext.getSOAPMessage();
+                if((sm != null) && sm.getSOAPBody().hasFault())
+                    return caller.callHandleFaultOnClient(handlerContext);
+            }
+
+            return caller.callHandlers(Direction.INBOUND,
+                RequestOrResponse.RESPONSE, handlerContext, false);
+        } catch (SOAPException se) {
+            throw new WebServiceException(se);
+        } catch (WebServiceException wse) {
+            throw wse;
+        } catch (RuntimeException re) {
+            // handlers are expected to be able to throw RE
+            throw new WebServiceException(re);
+        }
+    }
+
+    protected Binding getBinding(MessageInfo messageInfo) {
+        ContextMap context = (ContextMap) ((MessageInfoBase) messageInfo)
+            .getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        BindingProvider provider = (BindingProvider) context
+            .get(JAXWS_CLIENT_HANDLE_PROPERTY);
+        return provider.getBinding();
+    }
+
+    protected HandlerChainCaller getHandlerChainCaller(MessageInfo messageInfo) {
+        BindingImpl binding = (BindingImpl) getBinding(messageInfo);
+        return binding.getHandlerChainCaller();
+    }
+
+    private void updateSOAPMessage(Object value, SOAPMessage sm) {
+        try {
+            if (value instanceof Source) {
+                SOAPBody sb = sm.getSOAPPart().getEnvelope().getBody();
+                sb.removeContents();
+                XmlUtil.newTransformer().transform((Source) value, new DOMResult(sb));
+                sm.saveChanges();
+            }
+        } catch (SOAPException e) {
+            throw new RuntimeException(e);
+        } catch (TransformerException e) {
+            throw new RuntimeException(e);
+        }
+    }
+
+
+    protected void updateMessageContext(MessageInfo messageInfo, SOAPHandlerContext context) {
+        SOAPMessageContext messageContext = context.getSOAPMessageContext();
+        messageInfo.setMetaData(BindingProviderProperties.JAXWS_HANDLER_CONTEXT_PROPERTY, context);
+        RequestContext ctxt = (RequestContext) messageInfo
+            .getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        Iterator i = ctxt.copy().getPropertyNames();
+        while (i.hasNext()) {
+            String name = (String) i.next();
+            Object value = ctxt.get(name);
+            messageContext.put(name, value);
+        }
+
+        BindingProvider provider = (BindingProvider) context.getMessageContext()
+            .get(JAXWS_CLIENT_HANDLE_PROPERTY);
+
+        QName portTypeQName = null;
+        if (provider != null) {
+            if (Proxy.isProxyClass(provider.getClass())) {
+
+                EndpointIFInvocationHandler invocationHandler = (EndpointIFInvocationHandler) Proxy.getInvocationHandler(provider);
+                EndpointIFContext endpointContext = invocationHandler.getEndpointContext();
+                portTypeQName = invocationHandler.getWSDLPortTypeQName();
+
+                messageContext.put(MessageContext.WSDL_SERVICE, invocationHandler.getServiceQName());
+                messageContext.put(MessageContext.WSDL_PORT, endpointContext.getPortName());
+
+                context.setBindingId(endpointContext.getBindingID().toString());
+
+                RuntimeContext rtContext = (RuntimeContext) messageInfo.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+                if (rtContext != null) {   //should never be
+                    RuntimeModel model = rtContext.getModel();
+                    JavaMethod javaMethod = model.getJavaMethod(messageInfo.getMethod());
+                    String opname = javaMethod.getOperationName();
+                    if (portTypeQName != null) {
+                        String tns = portTypeQName.getNamespaceURI();
+                        messageContext.put(MessageContext.WSDL_OPERATION, new QName(tns,opname));
+                    }
+                }
+                //set handlerContext
+                rtContext.setHandlerContext(context);
+            }
+        }
+
+        //now get value for ContentNegotiation
+        Object prop = messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY);
+        if (prop != null) {
+            messageContext.put(CONTENT_NEGOTIATION_PROPERTY, prop);
+        }
+    }
+
+    protected void updateResponseContext(MessageInfo messageInfo,
+                                         SOAPHandlerContext context) {
+        SOAPMessageContext messageContext = context.getSOAPMessageContext();
+        RequestContext rc = (RequestContext) messageInfo.getMetaData(JAXWS_CONTEXT_PROPERTY);
+        BindingProvider provider = (BindingProvider) rc.get(JAXWS_CLIENT_HANDLE_PROPERTY);
+        ResponseContext responseContext = new ResponseContext(provider);
+        for (String name : messageContext.keySet()) {
+            MessageContext.Scope scope = messageContext.getScope(name);
+            if (MessageContext.Scope.APPLICATION == scope) {
+                Object value = messageContext.get(name);
+                responseContext.put(name, value);
+            }
+        }
+        ResponseImpl asyncResponse = (ResponseImpl) messageInfo.getMetaData(
+            JAXWS_CLIENT_ASYNC_RESPONSE_CONTEXT);
+        if (asyncResponse != null) {
+            asyncResponse.setResponseContext(responseContext.copy());
+        } else {
+            messageInfo.setMetaData(JAXWS_RESPONSE_CONTEXT_PROPERTY,
+                responseContext.copy());
+        }
+    }
+
+    /**
+     * @return true if message exchange pattern indicates asynchronous, otherwise returns false
+     */
+    protected boolean isAsync(MessageInfo messageInfo) {
+        if ((messageInfo.getMEP() == MessageStruct.ASYNC_POLL_MEP)
+            || (messageInfo.getMEP() == MessageStruct.ASYNC_CALLBACK_MEP)) {
+            return true;
+        }
+        return false;
+    }
+
+    private void preSendHook(MessageInfo messageInfo) {
+    }
+
+    private void preReceiveHook(MessageInfo messageInfo) {
+    }
+
+    private void postSendHook(MessageInfo messageInfo) {
+        if (messageInfo.getResponseType() != MessageStruct.NORMAL_RESPONSE) {
+            postReceiveHook(messageInfo);
+            throw (WebServiceException) messageInfo.getResponse();
+        }
+    }
+
+    private void postReceiveAndDecodeHook(MessageInfo messageInfo) {
+        DispatchContext dispatchContext = (DispatchContext) messageInfo
+            .getMetaData(BindingProviderProperties.DISPATCH_CONTEXT);
+        if ((messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) == Service.Mode.MESSAGE)
+            && (dispatchContext.getProperty(DispatchContext.DISPATCH_MESSAGE) == DispatchContext.MessageType.SOURCE_MESSAGE))
+        {
+            Object response = messageInfo.getResponse();
+            if (response instanceof SOAPMessage) {
+                SOAPPart part = ((SOAPMessage) response).getSOAPPart();
+                try {
+                    messageInfo.setResponse(part.getContent());
+                } catch (SOAPException e) {
+                    throw new RuntimeException(e);
+                }
+            }
+        }
+    }
+
+    private void postReceiveHook(MessageInfo messageInfo) {
+        // postReceiveHook exaimines the result for an exception
+        // or SOAPFaultInfo - it will set appropriate
+        // asynchronous exceptions
+        Object response = messageInfo.getResponse();
+        switch (messageInfo.getResponseType()) {
+            case MessageStruct.NORMAL_RESPONSE:
+                // not sure where this belongs yet - but for now-
+                return;
+            case MessageStruct.CHECKED_EXCEPTION_RESPONSE:
+                if (response instanceof SOAPFaultInfo) {
+                    SOAPFaultInfo soapFaultInfo = (SOAPFaultInfo) response;
+                    JAXBException jbe = null;
+                    if (soapFaultInfo.getString().contains("javax.xml.bind")) {
+                        jbe = new JAXBException(soapFaultInfo.getString());
+                        // do I need to put this in a jaxws exception
+                    }
+                    SOAPFaultException sfe = new SOAPFaultException(soapFaultInfo.getSOAPFault());
+                    if (jbe != null)
+                        sfe.initCause(jbe);
+                    messageInfo.setResponse((SOAPFaultException) sfe);
+                }
+                return;
+            case MessageStruct.UNCHECKED_EXCEPTION_RESPONSE:
+                if (response instanceof SOAPFaultException) {
+                    messageInfo.setResponse((SOAPFaultException) response);
+                } else {
+
+                    if (response instanceof Exception) {
+                        RuntimeException jex = (RuntimeException) response;
+                        messageInfo.setResponse(jex);
+                    }
+                }
+                return;
+            default:
+                messageInfo.setResponse(response);
+        }
+    }
+
+    private InternalMessage preHandlerOutboundHook(SOAPMessage sm, InternalMessage im) {
+        if ((sm != null) && (im != null))
+            im = null;
+        return im;
+    }
+
+    private void postHandlerOutboundHook(MessageInfo messageInfo, SOAPHandlerContext handlerContext, SOAPMessage sm) {
+        if (messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) == Service.Mode.MESSAGE)
+        {
+            InternalMessage im = handlerContext.getInternalMessage();
+            if (im != null) {
+                Object value = im.getBody().getValue();
+                updateSOAPMessage(value, sm);
+                im = null;
+            } else
+                try {
+                    sm.saveChanges();
+                } catch (SOAPException e) {
+                    throw new RuntimeException(e);
+                }
+        }
+    }
+
+    private void postHandlerInboundHook(MessageInfo messageInfo, SOAPHandlerContext handlerContext, SOAPMessage sm) {
+        if ((messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) == Service.Mode.MESSAGE) ||
+            (messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_MODE) == Service.Mode.PAYLOAD))
+        {
+            InternalMessage im = handlerContext.getInternalMessage();
+            if (im != null) {
+                Object value = im.getBody().getValue();
+                updateSOAPMessage(value, sm);
+                im = null;
+            } else
+                try {
+                    sm.saveChanges();
+                } catch (SOAPException e) {
+                    throw new RuntimeException(e);
+                }
+        }
+    }
+
+
+    private void closeAllHandlers(SOAPHandlerContext context) {
+        HandlerChainCaller caller = getHandlerChainCaller(context.getMessageInfo());
+        if (caller != null && caller.hasHandlers()) {
+            caller.forceCloseHandlersOnClient(context);
+        }
+    }
+
+    /**
+     * This method is used to create the appropriate SOAPMessage (1.1 or 1.2 using SAAJ api).
+     *
+     * @return the BindingId associated with messageInfo
+     */
+    protected String getBindingId(MessageInfo messageInfo) {
+        SOAPEncoder encoder = (SOAPEncoder) messageInfo.getEncoder();
+        if (encoder instanceof SOAP12XMLEncoder)
+            return SOAPBinding.SOAP12HTTP_BINDING;
+        else
+            return SOAPBinding.SOAP11HTTP_BINDING;
+    }
+
+    /**
+     * Logs the SOAP request message
+     */
+    protected void logRequestMessage(SOAPMessage soapMessage, MessageInfo messageInfo)
+        throws IOException, SOAPException {
+
+        OutputStream out = ((WSConnection) messageInfo.getConnection()).getDebug();
+
+        if (out != null) {
+            String s = "******************\nRequest\n";
+            out.write(s.getBytes());
+            for (Iterator iter =
+                soapMessage.getMimeHeaders().getAllHeaders();
+                 iter.hasNext();
+                ) {
+                MimeHeader header = (MimeHeader) iter.next();
+                s = header.getName() + ": " + header.getValue() + "\n";
+                out.write(s.getBytes());
+            }
+            out.flush();
+            soapMessage.writeTo(out);
+            s = "\n";
+            out.write(s.getBytes());
+            out.flush();
+        }
+    }
+
+    /**
+     * Logs the SOAP response message
+     */
+    protected void logResponseMessage(SOAPMessage response, MessageInfo messageInfo)
+        throws IOException, SOAPException {
+
+        OutputStream out = ((WSConnection) messageInfo.getConnection()).getDebug();
+        if (out != null) {
+            String s = "Response\n";
+            out.write(s.getBytes());
+            s =
+                "Http Status Code: "
+                    + ((WSConnection) messageInfo.getConnection()).getStatus()
+                    + "\n\n";
+            out.write(s.getBytes());
+            for (Iterator iter =
+                response.getMimeHeaders().getAllHeaders();
+                 iter.hasNext();
+                ) {
+                MimeHeader header = (MimeHeader) iter.next();
+                s = header.getName() + ": " + header.getValue() + "\n";
+                out.write(s.getBytes());
+            }
+            out.flush();
+            response.writeTo(out);
+            s = "******************\n\n";
+            out.write(s.getBytes());
+        }
+    }
+
+    class DaemonThreadFactory implements ThreadFactory {
+        public Thread newThread(Runnable r) {
+            Thread daemonThread = new Thread(r);
+            daemonThread.setDaemon(Boolean.TRUE);
+            return daemonThread;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/server/ProviderSOAPMD.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/server/ProviderSOAPMD.java
new file mode 100644
index 0000000..17db072
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/server/ProviderSOAPMD.java
@@ -0,0 +1,153 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.protocol.soap.server;
+
+import javax.xml.ws.Service;
+import javax.xml.soap.SOAPException;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.transform.Source;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.handler.SOAPHandlerContext;
+import com.sun.xml.internal.ws.handler.LogicalMessageImpl;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.server.ServerRtException;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPUtil;
+import com.sun.xml.internal.ws.util.FastInfosetUtil;
+
+import static com.sun.xml.internal.ws.developer.JAXWSProperties.*;
+import com.sun.xml.internal.ws.server.provider.ProviderModel;
+import com.sun.xml.internal.ws.server.provider.ProviderPeptTie;
+
+public class ProviderSOAPMD extends SOAPMessageDispatcher {
+
+    /*
+     * Fill the parameters, method in MessageInfo for Provider interface.
+     * invoke(Source, HandlerContext) to Object[]
+     * invoke(SOAPMessage, HandlerContext) to Object[]
+     */
+    @Override
+    protected void toMessageInfo(MessageInfo messageInfo, SOAPHandlerContext context) {
+        Object[] data = new Object[1];
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        Class providerClass = endpointInfo.getImplementorClass();
+        ProviderModel model = endpointInfo.getProviderModel();
+        boolean isSource = model.isSource();
+        Service.Mode mode = model.getServiceMode();
+
+        if (mode == Service.Mode.PAYLOAD) {
+            if (isSource) {
+                data[0] = new LogicalMessageImpl(context).getPayload();
+            }
+            // else doesn't happen and it is checked while creating the model
+        } else {
+            InternalMessage internalMessage = context.getInternalMessage();
+            SOAPMessage soapMessage = context.getSOAPMessage();
+            try {
+                if (internalMessage != null) {
+                    // SOAPMessage's body is replaced by InternalMessage's BodyBlock
+                    SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+                    SOAPEncoder encoder = eptf.getSOAPEncoder();
+                    soapMessage = encoder.toSOAPMessage(internalMessage, soapMessage);
+                }
+                if (isSource) {
+                    // Get SOAPMessage's SOAPPart as Source
+                    data[0]= soapMessage.getSOAPPart().getContent();
+                } else {
+                    data[0] = soapMessage;
+                }
+            } catch(Exception e) {
+                messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+                messageInfo.setResponse(e);
+            }
+        }
+        messageInfo.setData(data);
+        messageInfo.setMethod(ProviderPeptTie.invoke_Method);
+    }
+
+    /*
+     * MessageInfo contains the endpoint invocation results. If the endpoint
+     * returns a SOAPMessage, just set the object in HandlerContext. If the
+     * endpoint returns a Source in Mode.MESSAGE, it is converted to SOAPMessage
+     * and set in HandlerContext. If the endpoint returns a Source in
+     * Mode.PAYLOAD, it is set in InternalMessage, and InternalMessage is set
+     * in HandlerContext
+     */
+    @Override
+    protected void setResponseInContext(MessageInfo messageInfo,
+            SOAPHandlerContext context)
+    {
+        Object obj = messageInfo.getResponse();
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        Class providerClass = endpointInfo.getImplementorClass();
+        ProviderModel model = endpointInfo.getProviderModel();
+        Service.Mode mode = model.getServiceMode();
+
+        if (messageInfo.getResponseType() == MessageInfo.NORMAL_RESPONSE &&
+                mode == Service.Mode.MESSAGE) {
+            SOAPMessage soapMessage = null;
+            if (obj instanceof SOAPMessage) {
+                soapMessage = (SOAPMessage)obj;
+            } else {
+                // put Source into SOAPPart of SOAPMessage
+                try {
+                    Source source = (Source)obj;
+                    String bindingId = ((BindingImpl)endpointInfo.getBinding()).getBindingId();
+                    soapMessage = SOAPUtil.createMessage(bindingId);
+                    soapMessage.getSOAPPart().setContent(source);
+                } catch(SOAPException e) {
+                    throw new ServerRtException("soapencoder.err", new Object[]{e});
+                }
+            }
+
+            // Ensure message is encoded according to conneg
+            FastInfosetUtil.ensureCorrectEncoding(messageInfo, soapMessage);
+
+            context.setSOAPMessage(soapMessage);
+            context.setInternalMessage(null);
+        }
+        else {
+            // set Source or any Exception in InternalMessage's BodyBlock
+            SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+            InternalEncoder ine = eptf.getInternalEncoder();
+            InternalMessage internalMessage =
+                (InternalMessage)ine.toInternalMessage(messageInfo);
+            // set handler context
+            context.setInternalMessage(internalMessage);
+            context.setSOAPMessage(null);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/server/SOAPMessageDispatcher.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/server/SOAPMessageDispatcher.java
new file mode 100644
index 0000000..7eb6b9c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/soap/server/SOAPMessageDispatcher.java
@@ -0,0 +1,632 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.protocol.soap.server;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.pept.presentation.TargetFinder;
+import com.sun.xml.internal.ws.pept.presentation.Tie;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.binding.soap.SOAPBindingImpl;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAPDecoder;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPFaultInfo;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller.Direction;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller.RequestOrResponse;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.handler.SOAPHandlerContext;
+import com.sun.xml.internal.ws.model.soap.SOAPRuntimeModel;
+import com.sun.xml.internal.ws.server.AppMsgContextImpl;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.server.ServerRtException;
+import com.sun.xml.internal.ws.spi.runtime.Invoker;
+import com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegate;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.spi.runtime.WebServiceContext;
+import com.sun.xml.internal.ws.util.FastInfosetUtil;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.util.SOAPConnectionUtil;
+
+import javax.xml.namespace.QName;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.ws.Binding;
+import javax.xml.ws.ProtocolException;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.handler.MessageContext.Scope;
+
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.ws.soap.SOAPFaultException;
+import java.lang.reflect.Method;
+import java.util.List;
+import java.util.Map;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.CONTENT_NEGOTIATION_PROPERTY;
+
+public class SOAPMessageDispatcher implements MessageDispatcher {
+
+    private static final String[] contentTypes = {
+            "text/xml", "application/soap+xml", "application/xop+xml",
+            "application/fastinfoset", "application/soap+fastinfoset" };
+
+    private static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".server.soapmd");
+
+    public SOAPMessageDispatcher() {
+    }
+
+    public void send(MessageInfo messageInfo) {
+        // Not required for server
+        throw new UnsupportedOperationException();
+    }
+
+    public void receive(MessageInfo messageInfo) {
+        // Checks the Content-Type to send unsupported media error
+        try {
+            checkContentType(messageInfo);
+        } catch(ServerRtException e) {
+            SOAPConnectionUtil.sendKnownError(messageInfo,
+                    WSConnection.UNSUPPORTED_MEDIA);
+            return;
+        }
+
+        // Gets request stream from WSConnection and creates SOAP message
+        SOAPMessage soapMessage = null;
+        try {
+            soapMessage = getSOAPMessage(messageInfo);
+        } catch(Exception e) {
+            sendResponseError(messageInfo, e);
+            return;
+        }
+
+        // Set it before response is sent on transport. If transport creates
+        // any exception, this can be used not to send again
+        boolean sent = false;
+        try {
+
+            // Content negotiation logic
+            try {
+                // If FI is accepted by client, set property to optimistic
+                if (((com.sun.xml.internal.messaging.saaj.soap.MessageImpl) soapMessage).acceptFastInfoset()) {
+                    messageInfo.setMetaData(CONTENT_NEGOTIATION_PROPERTY, "optimistic");
+                }
+            }
+            catch (ClassCastException e) {
+                // Content negotiation fails
+            }
+
+            // context holds MessageInfo, InternalMessage, SOAPMessage
+            SOAPHandlerContext context = new SOAPHandlerContext(messageInfo, null,
+                soapMessage);
+            // WebServiceContext's MessageContext is set into HandlerContext
+            updateHandlerContext(messageInfo, context);
+            context.getMessageContext().put(
+                    MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.FALSE);
+            //set MESSAGE_ATTACHMENTS property
+            MessageContext msgCtxt = MessageInfoUtil.getMessageContext(messageInfo);
+            if (msgCtxt != null) {
+                MessageContextUtil.copyInboundMessageAttachments(msgCtxt, soapMessage.getAttachments());
+            }
+            SystemHandlerDelegate shd = getSystemHandlerDelegate(messageInfo);
+            SoapInvoker implementor = new SoapInvoker(messageInfo, soapMessage,
+                context, shd);
+            try {
+                if (shd == null) {
+                    // Invokes request handler chain, endpoint, response handler chain
+                    implementor.invoke();
+                } else {
+                    context.setInvoker(implementor);
+                    if (shd.processRequest(context.getSHDSOAPMessageContext())) {
+                        implementor.invoke();
+                        context.getMessageContext().put(
+                            MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.TRUE);
+                        shd.processResponse(context.getSHDSOAPMessageContext());
+                    }
+                }
+            } finally {
+                sent = implementor.isSent();    // response is sent or not
+            }
+            if (!isOneway(messageInfo)) {
+                makeSOAPMessage(messageInfo, context);
+                sent = true;
+                sendResponse(messageInfo, context);
+            } else if (!sent) {
+                // Oneway and request handler chain reversed the execution direction
+                sent = true;
+                sendResponseOneway(messageInfo);
+            }
+        } catch(Exception e) {
+            e.printStackTrace();
+            logger.log(Level.SEVERE, e.getMessage(), e);
+            if (!sent) {
+                sendResponseError(messageInfo, e);
+            }
+        }
+        assert sent;            // Make sure response is sent
+    }
+
+    /*
+     * This decodes the SOAPMessage into InternalMessage. Then InternalMessage
+     * is converted to java method and parameters and populates them into
+     * MessageInfo.
+     *
+     */
+    protected void toMessageInfo(MessageInfo messageInfo, SOAPHandlerContext context) {
+        InternalMessage internalMessage = context.getInternalMessage();
+        try {
+            SOAPMessage soapMessage = context.getSOAPMessage();
+            if (internalMessage == null) {
+                // Bind headers, body from SOAPMessage
+                SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+                SOAPDecoder decoder = eptf.getSOAPDecoder();
+                internalMessage = decoder.toInternalMessage(soapMessage, messageInfo);
+            } else {
+                // Bind headers from SOAPMessage
+                SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+                SOAPDecoder decoder = eptf.getSOAPDecoder();
+                internalMessage = decoder.toInternalMessage(soapMessage, internalMessage, messageInfo);
+            }
+            //setup JAXWSAttachmentMarshaller for outgoing attachments
+            SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+            SOAPEncoder encoder = eptf.getSOAPEncoder();
+            encoder.setAttachmentsMap(messageInfo, internalMessage);
+
+        } catch(Exception e) {
+            logger.log(Level.SEVERE, e.getMessage(), e);
+            messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+            messageInfo.setResponse(e);
+        }
+        // InternalMessage to MessageInfo
+        if (!isFailure(messageInfo)) {
+            SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+            eptf.getInternalEncoder().toMessageInfo(internalMessage, messageInfo);
+            Binding binding = MessageInfoUtil.getRuntimeContext(messageInfo).getRuntimeEndpointInfo().getBinding();
+            String bindingId = (binding != null)?((SOAPBindingImpl)binding).getBindingId():SOAPBinding.SOAP11HTTP_BINDING;
+
+            if (messageInfo.getMethod() == null) {
+                messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+                SOAPFaultInfo faultInfo = new SOAPFaultInfo(
+                            "Cannot find dispatch method",
+                            SOAPConstants.FAULT_CODE_SERVER,
+                            null, null, bindingId);
+                messageInfo.setResponse(faultInfo);
+            }
+        }
+    }
+
+    /*
+     * Creates SOAPMessage from the connection's request stream
+     */
+    private SOAPMessage getSOAPMessage(MessageInfo messageInfo) {
+        WSConnection con = (WSConnection)messageInfo.getConnection();
+        return SOAPConnectionUtil.getSOAPMessage(con, messageInfo, null);
+    }
+
+    /*
+     * Checks against known Content-Type headers
+     */
+    private void checkContentType(MessageInfo mi) {
+        WSConnection con = (WSConnection)mi.getConnection();
+        Map<String, List<String>> headers = con.getHeaders();
+        List<String> cts = headers.get("Content-Type");
+        if (cts != null && cts.size() > 0) {
+            String ct = cts.get(0);
+            for(String contentType : contentTypes) {
+                if (ct.indexOf(contentType) != -1) {
+                    return;
+                }
+            }
+        }
+        throw new ServerRtException("Incorrect Content-Type="+cts);
+    }
+
+    /*
+     * Sets the WebServiceContext with correct MessageContext which contains
+     * APPLICATION scope properties
+     */
+    protected void updateWebServiceContext(MessageInfo messageInfo, SOAPHandlerContext hc) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        //rtCtxt.setHandlerContext(hc);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        WebServiceContext wsContext = endpointInfo.getWebServiceContext();
+        hc.getMessageContext().put(CONTENT_NEGOTIATION_PROPERTY,
+                messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY));
+        hc.getMessageContext().setScope(CONTENT_NEGOTIATION_PROPERTY, Scope.APPLICATION);
+        if (wsContext != null) {
+            AppMsgContextImpl appCtxt = new AppMsgContextImpl(hc.getMessageContext());
+            wsContext.setMessageContext(appCtxt);
+        }
+    }
+
+    /*
+     * Invokes the endpoint. For Provider endpoints, whether the operation is
+     * oneway or not known only after the endpoint is invoked. ProviderSOAPMD
+     * overrides this and sends the response message on transport for oneway
+     * operations.
+     *
+     * @return true if response is sent on transport
+     */
+    protected void invokeEndpoint(MessageInfo messageInfo, SOAPHandlerContext hc) {
+        TargetFinder targetFinder =
+            messageInfo.getEPTFactory().getTargetFinder(messageInfo);
+        Tie tie = targetFinder.findTarget(messageInfo);
+        tie._invoke(messageInfo);
+    }
+
+    /**
+     * Converts java method parameters, and return value to InternalMessage.
+     * It calls response handlers. At the end, the context has either
+     * InternalMessage or SOAPMessage
+     *
+     */
+    protected void getResponse(MessageInfo messageInfo, SOAPHandlerContext context) {
+        setResponseInContext(messageInfo, context);
+        try {
+            HandlerChainCaller handlerCaller =
+                getCallerFromMessageInfo(messageInfo);
+            if (handlerCaller != null && handlerCaller.hasHandlers()) {
+                int messageType = messageInfo.getResponseType();
+                if (messageType == MessageInfo.CHECKED_EXCEPTION_RESPONSE ||
+                    messageType == MessageInfo.UNCHECKED_EXCEPTION_RESPONSE) {
+
+                    callHandleFault(handlerCaller, context);
+                } else {
+                    //there are handlers so disable Xop encoding if enabled, so that they dont
+                    // see xop:Include reference
+                    JAXWSAttachmentMarshaller am = MessageInfoUtil.getAttachmentMarshaller(messageInfo);
+                    boolean isXopped = false;
+                    if((am != null) && am.isXOPPackage()){
+                        isXopped = am.isXOPPackage();
+                        am.setXOPPackage(false);
+                    }
+                    callHandlersOnResponse(handlerCaller, context);
+                    // now put back the old value
+                    if((am != null)){
+                        am.setXOPPackage(isXopped);
+                    }
+                }
+            }
+        } catch(Exception e) {
+            logger.log(Level.SEVERE, e.getMessage(), e);
+            createInternalMessageForException(messageInfo, e, context);
+        }
+    }
+
+    /*
+     *
+     *
+     *
+     */
+    private boolean createInternalMessageForException(MessageInfo messageInfo,
+            Exception e, SOAPHandlerContext context) {
+        boolean soap12 = false;
+        RuntimeEndpointInfo rei = MessageInfoUtil.getRuntimeContext(
+            messageInfo).getRuntimeEndpointInfo();
+        String id = ((SOAPBindingImpl)rei.getBinding()).getBindingId();
+        InternalMessage internalMessage = null;
+        if (id.equals(SOAPBinding.SOAP11HTTP_BINDING)) {
+            internalMessage = SOAPRuntimeModel.createFaultInBody(
+                e, null, null, null);
+        } else if (id.equals(SOAPBinding.SOAP12HTTP_BINDING)) {
+            internalMessage = SOAPRuntimeModel.createSOAP12FaultInBody(
+                e, null, null, null, null);
+            soap12 = true;
+        }
+        context.setInternalMessage(internalMessage);
+        context.setSOAPMessage(null);
+        return soap12;
+    }
+
+    private void makeSOAPMessage(MessageInfo messageInfo, SOAPHandlerContext context) {
+        InternalMessage internalMessage = context.getInternalMessage();
+        if (internalMessage != null) {
+            SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+            SOAPEncoder encoder = eptf.getSOAPEncoder();
+            SOAPMessage soapMesage = encoder.toSOAPMessage(internalMessage, messageInfo);
+            context.setSOAPMessage(soapMesage);
+            context.setInternalMessage(null);
+        }
+    }
+
+    /*
+     * MessageInfo contains the endpoint invocation results. The information
+     * is converted to InternalMessage or SOAPMessage and set in HandlerContext
+     */
+    protected void setResponseInContext(MessageInfo messageInfo,
+            SOAPHandlerContext context) {
+        // MessageInfo to InternalMessage
+        SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+        InternalMessage internalMessage = (InternalMessage)eptf.getInternalEncoder().toInternalMessage(
+                messageInfo);
+        // set handler context
+        context.setInternalMessage(internalMessage);
+        context.setSOAPMessage(null);
+    }
+
+    /*
+     * Sends SOAPMessage response on the connection
+     */
+    private void sendResponse(MessageInfo messageInfo, SOAPHandlerContext ctxt) {
+        SOAPMessage soapMessage = ctxt.getSOAPMessage();
+        WSConnection con = (WSConnection)messageInfo.getConnection();
+        Integer status = MessageContextUtil.getHttpStatusCode(ctxt.getMessageContext());
+        int statusCode = (status == null) ? WSConnection.OK : status;
+        SOAPConnectionUtil.setStatus(con, statusCode);
+        SOAPConnectionUtil.sendResponse(con, soapMessage);
+    }
+
+    protected void sendResponseOneway(MessageInfo messageInfo) {
+        SOAPConnectionUtil.sendResponseOneway(messageInfo);
+    }
+
+    private void sendResponseError(MessageInfo messageInfo, Exception e) {
+        e.printStackTrace();
+        WSConnection con = (WSConnection)messageInfo.getConnection();
+        Binding binding = MessageInfoUtil.getRuntimeContext(messageInfo).getRuntimeEndpointInfo().getBinding();
+        String bindingId = ((SOAPBindingImpl)binding).getBindingId();
+        SOAPConnectionUtil.sendResponseError(con, bindingId);
+    }
+
+    /*
+     * Calls inbound handlers. It also calls outbound handlers incase flow is
+     * reversed. If the handler throws a ProtocolException, SOAP message is
+     * already set in the context. Otherwise, it creates InternalMessage,
+     * and that is used to create SOAPMessage.
+     *
+     * returns whether to invoke endpoint or not.
+     */
+    private boolean callHandlersOnRequest(MessageInfo messageInfo,
+        SOAPHandlerContext context, boolean responseExpected) {
+
+        boolean skipEndpoint = false;
+        HandlerChainCaller handlerCaller =
+            getCallerFromMessageInfo(messageInfo);
+
+        if (handlerCaller != null && handlerCaller.hasHandlers()) {
+            try {
+                skipEndpoint = !handlerCaller.callHandlers(Direction.INBOUND,
+                    RequestOrResponse.REQUEST, context, responseExpected);
+            } catch(ProtocolException pe) {
+                skipEndpoint = true;
+                if (MessageContextUtil.ignoreFaultInMessage(
+                    context.getMessageContext())) {
+                    // don't use the fault, use the exception
+                    createInternalMessageForException(messageInfo, pe, context);
+                }
+            } catch(RuntimeException re) {
+                skipEndpoint = true;
+                createInternalMessageForException(messageInfo, re, context);
+            }
+        }
+        return skipEndpoint;
+    }
+
+    private HandlerChainCaller getCallerFromMessageInfo(MessageInfo info) {
+        RuntimeContext context = (RuntimeContext) info.getMetaData(
+                BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        BindingImpl binding = (BindingImpl)context.getRuntimeEndpointInfo().getBinding();
+        if (binding.hasHandlers()) {
+            HandlerChainCaller caller = binding.getHandlerChainCaller();
+            MessageInfoUtil.setHandlerChainCaller(info, caller);
+            return caller;
+        }
+        return null;
+    }
+
+    /**
+     *
+     * Invokes response handler chain
+     */
+    protected boolean callHandlersOnResponse(HandlerChainCaller caller,
+        SOAPHandlerContext context) {
+
+        return caller.callHandlers(Direction.OUTBOUND,
+            RequestOrResponse.RESPONSE, context, false);
+    }
+
+    /**
+     * Used when the endpoint throws an exception. HandleFault is called
+     * on the server handlers rather than handleMessage.
+     */
+    protected boolean  callHandleFault(HandlerChainCaller caller, SOAPHandlerContext context) {
+        return caller.callHandleFault(context);
+    }
+
+    /**
+     * Server does not know if a message is one-way until after
+     * the handler chain has finished processing the request. If
+     * it is a one-way message, have the handler chain caller
+     * call close on the handlers.
+     */
+    private void closeHandlers(MessageInfo info, SOAPHandlerContext context) {
+        HandlerChainCaller handlerCaller = getCallerFromMessageInfo(info);
+        if (handlerCaller != null && handlerCaller.hasHandlers()) {
+            handlerCaller.forceCloseHandlersOnServer(context);
+        }
+    }
+
+    private static boolean isFailure(MessageInfo messageInfo) {
+        return (messageInfo.getResponseType() == MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+    }
+
+    public static boolean isOneway(MessageInfo messageInfo) {
+        return (messageInfo.getMEP() == MessageStruct.ONE_WAY_MEP);
+    }
+
+
+    /**
+     * Sets MessageContext into HandlerContext and sets HandlerContext in
+     * RuntimeContext
+     */
+    private void updateHandlerContext(MessageInfo messageInfo,
+            SOAPHandlerContext context) {
+        MessageInfoUtil.getRuntimeContext(messageInfo).setHandlerContext(context);
+        RuntimeEndpointInfo endpointInfo =
+            MessageInfoUtil.getRuntimeContext(messageInfo).getRuntimeEndpointInfo();
+        context.setBindingId(((BindingImpl)endpointInfo.getBinding()).getActualBindingId());
+        WebServiceContext wsContext = endpointInfo.getWebServiceContext();
+        if (wsContext != null) {
+            context.setMessageContext(wsContext.getMessageContext());
+        }
+    }
+
+    /**
+     * Gets SystemHandlerDelegate from endpoint's Binding
+     */
+    private SystemHandlerDelegate getSystemHandlerDelegate(MessageInfo mi) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(mi);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        return endpointInfo.getBinding().getSystemHandlerDelegate();
+    }
+
+    /**
+     * Invokes request handler chain, endpoint and response handler chain.
+     * Separated as a separate class, so that SHD can call this in doPriv()
+     * block.
+     */
+    private class SoapInvoker implements Invoker {
+
+        MessageInfo messageInfo;
+        SOAPMessage soapMessage;
+        SOAPHandlerContext context;
+        boolean skipEndpoint;
+        SystemHandlerDelegate shd;
+        boolean sent;
+
+        SoapInvoker(MessageInfo messageInfo, SOAPMessage soapMessage,
+                SOAPHandlerContext context, SystemHandlerDelegate shd) {
+            this.messageInfo = messageInfo;
+            this.soapMessage = soapMessage;
+            this.context = context;
+            this.shd = shd;
+        }
+
+        public void invoke() throws Exception {
+            boolean peekOneWay = false;
+            if (!skipEndpoint) {
+                try {
+                    SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+                    SOAPDecoder decoder = eptf.getSOAPDecoder();
+
+                    // add handler chain caller to message info
+                    getCallerFromMessageInfo(messageInfo);
+                    peekOneWay = decoder.doMustUnderstandProcessing(soapMessage,
+                            messageInfo, context, true);
+                    context.setMethod(messageInfo.getMethod());
+                } catch (SOAPFaultException e) {
+                    skipEndpoint = true;
+                    boolean soap12 = createInternalMessageForException(messageInfo, e, context);
+                    SOAPRuntimeModel.addHeaders(context.getInternalMessage(),
+                            messageInfo);
+                }
+            }
+
+            // Call inbound handlers. It also calls outbound handlers incase of
+            // reversal of flow.
+            if (!skipEndpoint) {
+                skipEndpoint = callHandlersOnRequest(
+                    messageInfo, context, !peekOneWay);
+            }
+
+            if (skipEndpoint) {
+                soapMessage = context.getSOAPMessage();
+                if (soapMessage == null) {
+                    InternalMessage internalMessage = context.getInternalMessage();
+                    SOAPEPTFactory eptf = (SOAPEPTFactory)messageInfo.getEPTFactory();
+                    SOAPEncoder encoder = eptf.getSOAPEncoder();
+                    soapMessage = encoder.toSOAPMessage(internalMessage, messageInfo);
+                }
+
+                // Ensure message is encoded according to conneg
+                FastInfosetUtil.ensureCorrectEncoding(messageInfo, soapMessage);
+
+                context.setSOAPMessage(soapMessage);
+                context.setInternalMessage(null);
+            } else {
+                toMessageInfo(messageInfo, context);
+
+                if (isOneway(messageInfo)) {
+                    sent = true;
+                    sendResponseOneway(messageInfo);
+                    if (!peekOneWay) { // handler chain didn't already clos
+                        closeHandlers(messageInfo, context);
+                    }
+                }
+
+                if (!isFailure(messageInfo)) {
+                    if (shd != null) {
+                        shd.preInvokeEndpointHook(context.getSHDSOAPMessageContext());
+                    }
+                    updateWebServiceContext(messageInfo, context);
+                    invokeEndpoint(messageInfo, context);
+                    // For Provider endpoints Oneway is known only after executing endpoint
+                    if (!sent && isOneway(messageInfo)) {
+                        sent = true;
+                        sendResponseOneway(messageInfo);
+                    }
+                    context.getMessageContext().put(
+                        MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.TRUE);
+                }
+
+                if (isOneway(messageInfo)) {
+                    if (isFailure(messageInfo)) {
+                        // Just log the error. Not much to do
+                    }
+                } else {
+                    getResponse(messageInfo, context);
+                }
+            }
+        }
+
+        /**
+         * Gets the dispatch method in the endpoint for the payload's QName
+         *
+         * @return dispatch method
+         */
+        public Method getMethod(QName name) {
+            RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+            return rtCtxt.getDispatchMethod(name, messageInfo);
+        }
+
+        /*
+         * Is the message sent on transport. Happens when the operation is oneway
+         *
+         * @return true if the message is sent
+         *        false otherwise
+         */
+        public boolean isSent() {
+            return sent;
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/XMLMessageException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/XMLMessageException.java
new file mode 100644
index 0000000..e1ec8b7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/XMLMessageException.java
@@ -0,0 +1,52 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.protocol.xml;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * @author WS Development Team
+ */
+public class XMLMessageException extends JAXWSExceptionBase {
+
+    public XMLMessageException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public XMLMessageException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public XMLMessageException(Localizable arg) {
+        super("server.rt.err", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.xmlmessage";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/client/XMLMessageDispatcher.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/client/XMLMessageDispatcher.java
new file mode 100644
index 0000000..489a75c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/client/XMLMessageDispatcher.java
@@ -0,0 +1,976 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.protocol.xml.client;
+
+import com.sun.xml.internal.messaging.saaj.packaging.mime.MessagingException;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.client.*;
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.*;
+import com.sun.xml.internal.ws.client.dispatch.DispatchContext;
+import com.sun.xml.internal.ws.client.dispatch.ResponseImpl;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAP12XMLEncoder;
+import com.sun.xml.internal.ws.encoding.soap.client.SOAPXMLEncoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.MessageInfoBase;
+import com.sun.xml.internal.ws.encoding.xml.XMLEncoder;
+import com.sun.xml.internal.ws.encoding.xml.XMLMessage;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller.Direction;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller.RequestOrResponse;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.handler.XMLHandlerContext;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+import com.sun.xml.internal.ws.model.JavaMethod;
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.spi.runtime.ClientTransportFactory;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.transport.http.client.HttpClientTransportFactory;
+import com.sun.xml.internal.ws.util.Base64Util;
+import com.sun.xml.internal.ws.util.XMLConnectionUtil;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+import javax.activation.DataSource;
+import javax.activation.DataHandler;
+import javax.xml.bind.JAXBContext;
+import javax.xml.soap.MimeHeader;
+import javax.xml.soap.MimeHeaders;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.ws.*;
+import static javax.xml.ws.BindingProvider.PASSWORD_PROPERTY;
+import static javax.xml.ws.BindingProvider.USERNAME_PROPERTY;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.http.HTTPBinding;
+import javax.xml.ws.http.HTTPException;
+import javax.xml.ws.soap.SOAPBinding;
+import java.io.*;
+import java.net.HttpURLConnection;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.util.*;
+import java.util.concurrent.*;
+
+/**
+ * Client-side XML-based message dispatcher {@link com.sun.xml.internal.ws.pept.protocol.MessageDispatcher}
+ *
+ * @author WS Development Team
+ */
+public class XMLMessageDispatcher implements MessageDispatcher {
+
+    protected static final int MAX_THREAD_POOL_SIZE = 3;
+    protected static final long AWAIT_TERMINATION_TIME = 10L;
+
+    protected ExecutorService executorService = null;
+
+
+    /**
+     * Default constructor
+     */
+
+    public XMLMessageDispatcher() {
+    }
+
+    /*
+     * Invokes doSendAsync method if the message exchange pattern is asynchronous, otherwise
+     * invokes doSend method.
+     *
+     * @see com.sun.pept.protocol.MessageDispatcher#send(com.sun.pept.ept.MessageInfo)
+     */
+    public void send(MessageInfo messageInfo) {
+        if (isAsync(messageInfo)) {
+            doSendAsync(messageInfo);
+        } else {
+            doSend(messageInfo);
+        }
+    }
+
+    /**
+     * Orchestrates the sending of a synchronous request
+     */
+    protected XMLMessage doSend(MessageInfo messageInfo) {
+        //change from LogicalEPTFactory to ContactInfoBase - should be changed back when we have things working
+        EPTFactory contactInfo = messageInfo.getEPTFactory();
+        XMLEncoder encoder = (XMLEncoder) contactInfo.getEncoder(messageInfo);
+
+        boolean handlerResult = true;
+        boolean isRequestResponse = (messageInfo.getMEP() == MessageStruct.REQUEST_RESPONSE_MEP);
+
+        DispatchContext dispatchContext = (DispatchContext) messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT);
+
+        if (!isHTTPMessageType(dispatchContext)) {
+            throw new WebServiceException("Mode not allowed with HTTP Binding. Must use other Service.mode");
+        }
+
+        XMLMessage xm = makeXMLMessage(messageInfo);
+
+        try {
+            HandlerChainCaller caller = getHandlerChainCaller(messageInfo);
+            if (caller.hasHandlers()) {
+                XMLHandlerContext handlerContext = new XMLHandlerContext(
+                    messageInfo, null, xm);
+                updateMessageContext(messageInfo, handlerContext);
+                handlerResult = callHandlersOnRequest(handlerContext);
+                updateXMLMessage(handlerContext);
+                xm = handlerContext.getXMLMessage();
+                if (xm == null) {
+                    xm = encoder.toXMLMessage(
+                        handlerContext.getInternalMessage(), messageInfo);
+                }
+
+                // the only case where no message is sent
+                if (isRequestResponse && !handlerResult) {
+                    return xm;
+                }
+            }
+
+            // Setting encoder here is necessary for calls to getBindingId()
+//            messageInfo.setEncoder(encoder);
+            Map<String, Object> context = processMetadata(messageInfo, xm);
+
+            // set the MIME headers on connection headers
+            Map<String, List<String>> ch = new HashMap<String, List<String>>();
+            for (Iterator iter = xm.getMimeHeaders().getAllHeaders(); iter.hasNext();)
+            {
+                List<String> h = new ArrayList<String>();
+                MimeHeader mh = (MimeHeader) iter.next();
+
+                h.clear();
+                h.add(mh.getValue());
+                ch.put(mh.getName(), h);
+            }
+
+            setConnection(messageInfo, context);
+            ((WSConnection) messageInfo.getConnection()).setHeaders(ch);
+
+            if (!isAsync(messageInfo)) {
+                WSConnection connection = (WSConnection) messageInfo.getConnection();
+                //logRequestMessage(xm, messageInfo);
+                XMLConnectionUtil.sendResponse(connection, xm);
+            }
+
+            // if handlerResult is false, the receive has already happened
+            if (isRequestResponse && handlerResult) {
+                receive(messageInfo);
+                postReceiveHook(messageInfo);
+            }
+        } catch (Throwable e) {
+            setResponseType(e, messageInfo);
+            messageInfo.setResponse(e);
+        }
+        return xm;
+    }
+
+    /**
+     * Process and classify the metadata in MIME headers or message context. <String,String> data
+     * is copied into MIME headers and the remaining metadata is passed in message context to the
+     * transport layer.
+     *
+     * @param messageInfo
+     * @param xm
+     */
+    protected Map<String, Object> processMetadata(MessageInfo messageInfo, XMLMessage xm) {
+        Map<String, Object> messageContext = new HashMap<String, Object>();
+        List<String> header = new ArrayList<String>();
+
+        ContextMap properties = (ContextMap)
+            messageInfo.getMetaData(JAXWS_CONTEXT_PROPERTY);
+        DispatchContext dcontext = (DispatchContext)
+            messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT);
+        if (isHTTPMessageType(dcontext)) {
+            setHTTPContext(messageContext, dcontext, properties);
+        }
+
+        if (messageInfo.getMEP() == MessageStruct.ONE_WAY_MEP)
+            messageContext.put(ONE_WAY_OPERATION, "true");
+
+        // process the properties
+        if (properties != null) {
+            for (Iterator names = properties.getPropertyNames(); names.hasNext();)
+            {
+                String propName = (String) names.next();
+
+                // consume PEPT-specific properties
+                if (propName.equals(ClientTransportFactory.class.getName())) {
+                    messageContext.put(CLIENT_TRANSPORT_FACTORY, (ClientTransportFactory) properties.get(propName));
+                } else if (propName.equals(USERNAME_PROPERTY)) {
+                    String credentials = (String) properties.get(USERNAME_PROPERTY);
+                    if (credentials != null) {
+                        credentials += ":";
+                        String password = (String) properties.get(PASSWORD_PROPERTY);
+                        if (password != null)
+                            credentials += password;
+
+                        try {
+                            credentials = Base64Util.encode(credentials.getBytes());
+                        } catch (Exception ex) {
+                            throw new WebServiceException(ex);
+                        }
+                        xm.getMimeHeaders().addHeader("Authorization", "Basic " + credentials);
+                    }
+                } else
+                if (propName.equals(BindingProvider.SESSION_MAINTAIN_PROPERTY))
+                {
+                    Object maintainSession = properties.get(BindingProvider.SESSION_MAINTAIN_PROPERTY);
+                    if (maintainSession != null && maintainSession.equals(Boolean.TRUE))
+                    {
+                        Object cookieJar = properties.get(HTTP_COOKIE_JAR);
+                        if (cookieJar != null)
+                            messageContext.put(HTTP_COOKIE_JAR, cookieJar);
+                    }
+                } else {
+                    messageContext.put(propName, properties.get(propName));
+                }
+            }
+        }
+
+        // Set accept header depending on content negotiation property
+        String contentNegotiation = (String)
+            messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY);
+
+        String bindingId = getBindingId(messageInfo);
+
+        if (bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING)) {
+            xm.getMimeHeaders().addHeader(ACCEPT_PROPERTY,
+                contentNegotiation != "none" ? SOAP12_XML_FI_ACCEPT_VALUE : SOAP12_XML_ACCEPT_VALUE);
+        } else {
+            xm.getMimeHeaders().addHeader(ACCEPT_PROPERTY,
+                contentNegotiation != "none" ? XML_FI_ACCEPT_VALUE : XML_ACCEPT_VALUE);
+        }
+
+        //setRequestHeaders
+        Map<String, List<String>> requestHeaders = (Map)
+            properties.get(MessageContext.HTTP_REQUEST_HEADERS);
+        //requestHeaders.
+        setMimeHeaders(requestHeaders, xm);
+
+        messageContext.put(BINDING_ID_PROPERTY, bindingId);
+
+        // SOAPAction: MIME header
+        RuntimeContext runtimeContext = (RuntimeContext) messageInfo.getMetaData(JAXWS_RUNTIME_CONTEXT);
+        if (runtimeContext != null) {
+            JavaMethod javaMethod = runtimeContext.getModel().getJavaMethod(messageInfo.getMethod());
+            if (javaMethod != null) {
+                String soapAction = ((com.sun.xml.internal.ws.model.soap.SOAPBinding) javaMethod.getBinding()).getSOAPAction();
+                header.clear();
+                if (soapAction == null) {
+                    xm.getMimeHeaders().addHeader("SOAPAction", "\"\"");
+                } else {
+                    xm.getMimeHeaders().addHeader("SOAPAction", soapAction);
+                }
+            }
+        }
+
+        return messageContext;
+    }
+
+
+
+    protected void setConnection(MessageInfo messageInfo, Map<String, Object> context) {
+        ClientTransportFactory clientTransportFactory = (ClientTransportFactory) context.get(CLIENT_TRANSPORT_FACTORY);
+        WSConnection connection = null;
+        if (clientTransportFactory == null) {
+            clientTransportFactory = new HttpClientTransportFactory();
+        }
+        connection = clientTransportFactory.create(context);
+        messageInfo.setConnection(connection);
+    }
+
+    protected void setResponseType(Throwable e, MessageInfo messageInfo) {
+        //e.printStackTrace();
+        if (e instanceof RuntimeException) {
+            messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+            if (e instanceof ClientTransportException) {
+                Throwable temp = e;
+                e = new WebServiceException(temp.getMessage(), temp);
+            }
+        } else {
+            messageInfo.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+        }
+        messageInfo.setResponse(e);
+    }
+
+    /*
+     * Orchestrates the receiving of a synchronous response
+     *
+     * @see com.sun.pept.protocol.MessageDispatcher#receive(com.sun.pept.ept.MessageInfo)
+     *
+     * todo: exception handling with possible saaj error below
+     */
+    public void receive(MessageInfo messageInfo) {
+        // change from LogicalEPTFactory to ContactInfoBase - should be changed back when we have things working
+        EPTFactory contactInfo = messageInfo.getEPTFactory();
+
+        XMLMessage xm = getXMLMessage(messageInfo);
+
+        // Content negotiation logic
+        String contentNegotiation = (String) messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY);
+        // If XML request
+        if (contentNegotiation == "pessimistic") {
+            try {
+                if (xm.isFastInfoset()) {
+                    Map requestContext = (Map) messageInfo.getMetaData(JAXWS_CONTEXT_PROPERTY);
+                    // Further requests will be send using FI
+                    requestContext.put(CONTENT_NEGOTIATION_PROPERTY, "optimistic");
+                }
+            }
+            catch (ClassCastException e) {
+                // Content negotiation fails
+            }
+        }
+
+        try {
+            //logResponseMessage(xm, messageInfo);
+        } catch (Exception ex) {
+            throw new WebServiceException(ex);
+        }
+
+        XMLHandlerContext handlerContext =
+            getInboundHandlerContext(messageInfo, xm);
+
+        HandlerChainCaller caller = getHandlerChainCaller(messageInfo);
+        if (caller.hasHandlers()) {
+            callHandlersOnResponse(handlerContext);
+            xm = handlerContext.getXMLMessage();
+        }
+
+        //set messageInfo response with appropriate result
+        //at same time sets ResponseContext
+        setResponse(messageInfo, xm, handlerContext);
+    }
+
+    private void setResponse(MessageInfo messageInfo, XMLMessage xm, HandlerContext handlerContext) {
+
+        Map<String, DataHandler> attachments = getAttachments(handlerContext, xm);
+
+        updateResponseContext(messageInfo, (XMLHandlerContext)handlerContext, attachments);
+
+        DispatchContext dispatchContext = (DispatchContext) messageInfo.getMetaData(BindingProviderProperties.DISPATCH_CONTEXT);
+        DispatchContext.MessageType msgtype = (DispatchContext.MessageType) dispatchContext.getProperty(DispatchContext.DISPATCH_MESSAGE);
+        if (msgtype != null) {
+            switch ((DispatchContext.MessageType) msgtype) {
+                case HTTP_SOURCE_MESSAGE:
+                    messageInfo.setResponse(xm.getSource());
+                    break;
+                case HTTP_SOURCE_PAYLOAD:
+                    messageInfo.setResponse(xm.getSource());
+                    break;
+                case HTTP_JAXB_PAYLOAD:
+                    messageInfo.setResponse(xm.getPayload(getJAXBContext(messageInfo)));
+                    break;
+                case HTTP_DATASOURCE_MESSAGE:
+                    if (xm.getDataSource() != null)
+                        messageInfo.setResponse(xm.getDataSource());
+                    break;
+                default:
+                    throw new WebServiceException("Unknown invocation return object ");
+            }
+        } else {
+            //tbd just assume source for now
+            throw new WebServiceException("Unknown invocation return object");
+        }
+
+    }
+
+    private Map<String, DataHandler> getAttachments(HandlerContext handlerContext, XMLMessage xm) {
+        //are there attachments on the MessageContext properties ? Handlers
+        Map<String, DataHandler> attmc = (Map<String, DataHandler>)
+            handlerContext.getMessageContext().get(MessageContext.INBOUND_MESSAGE_ATTACHMENTS);
+        //can we get it from XMLMessage as well?
+        Map<String, DataHandler> attxm = xm.getAttachments();
+
+        Map<String, DataHandler> attachments = new HashMap<String, DataHandler>();
+        if (attxm != null && attmc != null) {
+            attachments.putAll(attxm);
+            attachments.putAll(attmc);
+        } else if (attxm != null) {
+            attachments.putAll(attxm);
+        } else if (attmc != null)
+            attachments.putAll(attmc);
+        else {
+            attachments = null; //gc it
+            return null;
+        }
+        return attachments;
+    }
+
+    private XMLHandlerContext getInboundHandlerContext(
+        MessageInfo messageInfo, XMLMessage xm) {
+        XMLHandlerContext handlerContext = (XMLHandlerContext) messageInfo
+            .getMetaData(BindingProviderProperties.JAXWS_HANDLER_CONTEXT_PROPERTY);
+        if (handlerContext != null) {
+            handlerContext.setXMLMessage(xm);
+            handlerContext.setInternalMessage(null);
+        } else {
+            handlerContext = new XMLHandlerContext(messageInfo, null, xm);
+        }
+        return handlerContext;
+    }
+
+    /**
+     * Orchestrates the sending of an asynchronous request
+     */
+    protected void doSendAsync(final MessageInfo messageInfo) {
+        try { // should have already been caught
+            preSendHook(messageInfo);
+            XMLMessage xm = doSend(messageInfo);
+            postSendHook(messageInfo);
+
+            //pass a copy of MessageInfo to the future task,so that no conflicts
+            //due to threading happens
+            Response r = sendAsyncReceive(MessageInfoBase.copy(messageInfo), xm);
+            if (executorService == null) {
+                executorService =
+                    Executors.newFixedThreadPool(MAX_THREAD_POOL_SIZE, new DaemonThreadFactory());
+            }
+
+            AsyncHandlerService service = (AsyncHandlerService) messageInfo
+                .getMetaData(BindingProviderProperties.JAXWS_CLIENT_ASYNC_HANDLER);
+            WSFuture wsfuture = null;
+            if (service != null) {
+                wsfuture = service.setupAsyncCallback(r);
+                ((ResponseImpl) r).setUID(service.getUID());
+                ((ResponseImpl) r).setHandlerService(service);
+            }
+            executorService.execute((FutureTask) r);
+            if (service == null)
+                messageInfo.setResponse(r);
+            else
+                messageInfo.setResponse(wsfuture);
+
+        } catch (Throwable e) {
+            messageInfo.setResponse(e);
+        }
+    }
+
+    /**
+     * Orchestrates the receiving of an asynchronous response
+     */
+    protected Response<Object> sendAsyncReceive(final MessageInfo messageInfo, final XMLMessage xm) {
+
+        final AsyncHandlerService handler = (AsyncHandlerService) messageInfo
+            .getMetaData(BindingProviderProperties.JAXWS_CLIENT_ASYNC_HANDLER);
+        final boolean callback = (messageInfo.getMEP() == MessageStruct.ASYNC_CALLBACK_MEP) ? true
+            : false;
+        if (callback && (handler == null))
+            throw new WebServiceException("Asynchronous callback invocation, but no handler - AsyncHandler required");
+
+        final Response r = new ResponseImpl<Object>(new Callable<Object>() {
+
+            public Object call() throws Exception {
+                // get connection and do http.invoke()
+                try {
+                    final WSConnection connection = (WSConnection) messageInfo.getConnection();
+                    //logRequestMessage(xm, messageInfo);
+                    XMLConnectionUtil.sendResponse(connection, xm);
+                } catch (Throwable t) {
+                    messageInfo.setResponse(t);
+                    messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+                }
+                // receive response
+                preReceiveHook(messageInfo);
+                try {
+                    receive(messageInfo);
+                } catch (Exception ex) {
+                    messageInfo.setResponse(ex);
+                }
+                postReceiveHook(messageInfo);
+
+                if (messageInfo.getResponse() instanceof Exception)
+                    throw (Exception) messageInfo.getResponse();
+                return messageInfo.getResponse();
+            }
+        });
+        messageInfo.setMetaData(JAXWS_CLIENT_ASYNC_RESPONSE_CONTEXT, r);
+        return r;
+    }
+
+    protected boolean callHandlersOnRequest(XMLHandlerContext handlerContext) {
+
+        HandlerChainCaller caller = getHandlerChainCaller(
+            handlerContext.getMessageInfo());
+        boolean responseExpected = (handlerContext.getMessageInfo().getMEP() !=
+            MessageStruct.ONE_WAY_MEP);
+        try {
+            return caller.callHandlers(Direction.OUTBOUND,
+                RequestOrResponse.REQUEST, handlerContext, responseExpected);
+        } catch (ProtocolException pe) {
+            if (MessageContextUtil.ignoreFaultInMessage(
+                handlerContext.getMessageContext())) {
+                // Ignore fault in this case and use exception.
+                throw pe;
+            } else
+                return false;
+        } catch (WebServiceException wse) {
+            throw wse;
+        } catch (RuntimeException re) {
+            // handlers are expected to be able to throw RE
+            throw new WebServiceException(re);
+        }
+    }
+
+    /*
+    * User's handler can throw a RuntimeExceptions
+    * (e.g., a ProtocolException).
+    * Need to wrap any RuntimeException (other than WebServiceException) in
+    * WebServiceException.
+    */
+    protected boolean callHandlersOnResponse(XMLHandlerContext handlerContext) {
+        HandlerChainCaller caller = getHandlerChainCaller(
+            handlerContext.getMessageInfo());
+        try {
+            return caller.callHandlers(Direction.INBOUND,
+                RequestOrResponse.RESPONSE, handlerContext, false);
+        } catch (WebServiceException wse) {
+            throw wse;
+        } catch (RuntimeException re) {
+            // handlers are expected to be able to throw RE
+            throw new WebServiceException(re);
+        }
+    }
+
+    protected Binding getBinding(MessageInfo messageInfo) {
+        ContextMap context = (ContextMap) ((MessageInfoBase) messageInfo)
+            .getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        BindingProvider provider = (BindingProvider) context
+            .get(BindingProviderProperties.JAXWS_CLIENT_HANDLE_PROPERTY);
+        return provider.getBinding();
+    }
+
+    protected HandlerChainCaller getHandlerChainCaller(MessageInfo messageInfo) {
+        BindingImpl binding = (BindingImpl) getBinding(messageInfo);
+        return binding.getHandlerChainCaller();
+    }
+
+    protected void updateMessageContext(MessageInfo messageInfo,
+                                        XMLHandlerContext context) {
+
+        MessageContext messageContext = context.getMessageContext();
+        messageInfo.setMetaData(
+            BindingProviderProperties.JAXWS_HANDLER_CONTEXT_PROPERTY, context);
+        RequestContext ctxt = (RequestContext) messageInfo
+            .getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        Iterator i = ctxt.copy().getPropertyNames();
+        while (i.hasNext()) {
+            String name = (String) i.next();
+            Object value = ctxt.get(name);
+            messageContext.put(name, value);
+        }
+    }
+
+    protected void updateResponseContext(MessageInfo messageInfo,
+                                         XMLHandlerContext context, Map<String, DataHandler> attachments) {
+
+
+        MessageContext messageContext = context.getMessageContext();
+        BindingProvider provider = (BindingProvider)
+            messageContext.get(JAXWS_CLIENT_HANDLE_PROPERTY);
+        ResponseContext responseContext = new ResponseContext(provider);
+        for (String name : messageContext.keySet()) {
+            MessageContext.Scope scope = messageContext.getScope(name);
+            if (MessageContext.Scope.APPLICATION == scope) {
+                Object value = messageContext.get(name);
+                responseContext.put(name, value);
+            }
+        }
+
+        //let's update status code
+        MessageContext mc =  context.getMessageContext();
+        WSConnection con = messageInfo.getConnection();
+        Map<String, List<String>> headers = con.getHeaders();
+
+        responseContext.put(MessageContext.HTTP_RESPONSE_HEADERS, headers);
+        responseContext.put(MessageContext.HTTP_RESPONSE_CODE, con.getStatus());
+
+        //attachments for ResponseContext
+        if (attachments != null)
+           responseContext.put(MessageContext.INBOUND_MESSAGE_ATTACHMENTS, attachments);
+
+        ResponseImpl asyncResponse = (ResponseImpl) messageInfo.getMetaData(
+            JAXWS_CLIENT_ASYNC_RESPONSE_CONTEXT);
+        if (asyncResponse != null) {
+            asyncResponse.setResponseContext(responseContext.copy());
+        } else {
+            messageInfo.setMetaData(JAXWS_RESPONSE_CONTEXT_PROPERTY,
+                responseContext.copy());
+        }
+    }
+
+    /**
+     * @return true if message exchange pattern indicates asynchronous, otherwise returns false
+     */
+    protected boolean isAsync(MessageInfo messageInfo) {
+        if ((messageInfo.getMEP() == MessageStruct.ASYNC_POLL_MEP)
+            || (messageInfo.getMEP() == MessageStruct.ASYNC_CALLBACK_MEP)) {
+            return true;
+        }
+        return false;
+    }
+
+    private void preSendHook(MessageInfo messageInfo) {
+    }
+
+    private void preReceiveHook(MessageInfo messageInfo) {
+    }
+
+    private void postSendHook(MessageInfo messageInfo) {
+        if (messageInfo.getResponseType() != MessageStruct.NORMAL_RESPONSE) {
+            postReceiveHook(messageInfo);
+            throw (WebServiceException) messageInfo.getResponse();
+        }
+    }
+
+    private void postReceiveAndDecodeHook(MessageInfo messageInfo) {
+    }
+
+    private void postReceiveHook(MessageInfo messageInfo) {
+
+        if (messageInfo.getMEP() == MessageStruct.ONE_WAY_MEP)
+            return;
+        Object response = messageInfo.getResponse();
+        if (response instanceof StreamSource) {
+            InputStream is = ((StreamSource) response).getInputStream();
+
+            Transformer transformer = XmlUtil.newTransformer();
+            try {
+                ByteArrayOutputStream out = new ByteArrayOutputStream(is.available());
+                if (out.size() > 0) {
+                    transformer.transform((StreamSource) response,
+                        new StreamResult(out));
+                    byte[] bytes = out.toByteArray();
+                    //could do to string
+                    if (new String(bytes).indexOf("HTTPException") > -1)
+                        throw new HTTPException(HttpURLConnection.HTTP_INTERNAL_ERROR);
+                    else {
+                        InputStream bis = new ByteArrayInputStream(bytes);
+                        messageInfo.setResponse(new StreamSource(bis));
+                    }
+                }
+            } catch (TransformerException e) {
+                throw new WebServiceException(e);
+            } catch (IOException e) {
+                throw new WebServiceException(e);
+            }
+        }
+        switch (messageInfo.getResponseType()) {
+            case MessageStruct.NORMAL_RESPONSE:
+                // not sure where this belongs yet - but for now-
+                return;
+            case MessageStruct.CHECKED_EXCEPTION_RESPONSE:
+                if (response instanceof Exception) {
+                    throw new HTTPException(HttpURLConnection.HTTP_INTERNAL_ERROR);
+                }
+                return;
+            case MessageStruct.UNCHECKED_EXCEPTION_RESPONSE:
+                if (response instanceof ProtocolException) {
+                    throw new HTTPException(HttpURLConnection.HTTP_INTERNAL_ERROR);
+                } else {
+                    WebServiceException jex = null;
+                    if (response instanceof Exception) {
+                        throw new WebServiceException((Exception) response);
+                    }
+                    messageInfo.setResponse(response);
+                }
+                return;
+            default:
+                messageInfo.setResponse(response);
+        }
+    }
+
+    private void closeAllHandlers(XMLHandlerContext context) {
+        HandlerChainCaller caller = getHandlerChainCaller(
+            context.getMessageInfo());
+        if (caller != null && caller.hasHandlers()) {
+            caller.forceCloseHandlersOnClient(context);
+        }
+    }
+
+    /**
+     * This method is used to create the appropriate SOAPMessage (1.1 or 1.2 using SAAJ api).
+     *
+     * @return the BindingId associated with messageInfo
+     */
+    protected String getBindingId(MessageInfo messageInfo) {
+        SOAPEncoder encoder = (SOAPEncoder) messageInfo.getEncoder();
+        if (encoder instanceof SOAPXMLEncoder)
+            return SOAPBinding.SOAP11HTTP_BINDING;
+        else if (encoder instanceof SOAP12XMLEncoder)
+            return SOAPBinding.SOAP12HTTP_BINDING;
+        else
+            return HTTPBinding.HTTP_BINDING;
+    }
+
+    /**
+     * Logs the SOAP request message
+     */
+    protected void logRequestMessage(XMLMessage request, MessageInfo messageInfo)
+        throws IOException, MessagingException, TransformerException {
+
+        OutputStream out = ((WSConnection) messageInfo.getConnection()).getDebug();
+
+        if (out != null) {
+            String s = "******************\nRequest\n";
+            out.write(s.getBytes());
+            for (Iterator iter =
+                request.getMimeHeaders().getAllHeaders();
+                 iter.hasNext();
+                ) {
+                MimeHeader header = (MimeHeader) iter.next();
+                s = header.getName() + ": " + header.getValue() + "\n";
+                out.write(s.getBytes());
+            }
+            out.flush();
+            request.writeTo(out);
+            s = "\n";
+            out.write(s.getBytes());
+            out.flush();
+        }
+    }
+
+    /**
+     * Logs the SOAP response message
+     */
+    protected void logResponseMessage(XMLMessage response, MessageInfo messageInfo)
+        throws IOException, MessagingException, TransformerException {
+
+        OutputStream out = ((WSConnection) messageInfo.getConnection()).getDebug();
+
+        if (out != null) {
+            String s = "Response\n";
+            out.write(s.getBytes());
+            s =
+                "Http Status Code: "
+                    + ((WSConnection) messageInfo.getConnection()).getStatus()
+                    + "\n\n";
+            out.write(s.getBytes());
+            for (Iterator iter =
+                response.getMimeHeaders().getAllHeaders();
+                 iter.hasNext();
+                ) {
+                MimeHeader header = (MimeHeader) iter.next();
+                s = header.getName() + ": " + header.getValue() + "\n";
+                out.write(s.getBytes());
+            }
+            out.flush();
+            response.writeTo(out);
+            s = "******************\n\n";
+            out.write(s.getBytes());
+        }
+    }
+
+    /*
+    * Gets XMLMessage from the connection
+    */
+    private XMLMessage getXMLMessage(MessageInfo messageInfo) {
+        WSConnection con = (WSConnection) messageInfo.getConnection();
+        return XMLConnectionUtil.getXMLMessage(con, messageInfo);
+    }
+
+    protected JAXBContext getJAXBContext(MessageInfo messageInfo) {
+        JAXBContext jc = null;
+        RequestContext context = (RequestContext) messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        if (context != null)
+            jc = (JAXBContext) context.get(BindingProviderProperties.JAXB_CONTEXT_PROPERTY);
+
+        return jc;
+    }
+
+    public void setHTTPContext(Map<String, Object> messageContext, DispatchContext dispatchContext, Map requestContext) {
+
+        if (requestContext.get(MessageContext.HTTP_REQUEST_METHOD) != null)
+            messageContext.put(MessageContext.HTTP_REQUEST_METHOD, requestContext.get(MessageContext.HTTP_REQUEST_METHOD));
+        if (requestContext.get(MessageContext.HTTP_REQUEST_HEADERS) != null)
+            messageContext.put(MessageContext.HTTP_REQUEST_HEADERS, requestContext.get(MessageContext.HTTP_REQUEST_HEADERS));
+
+        //resolve endpoint look for query parameters, pathInfo
+        String origEndpoint = (String) requestContext.get(BindingProvider.ENDPOINT_ADDRESS_PROPERTY);
+
+        String pathInfo = null;
+        String queryString = null;
+        if (requestContext.get(MessageContext.PATH_INFO) != null) {
+            pathInfo = (String) requestContext.get(MessageContext.PATH_INFO);
+        }
+        if (requestContext.get(MessageContext.QUERY_STRING) != null) {
+            queryString = (String) requestContext.get(MessageContext.QUERY_STRING);
+        }
+
+        String resolvedEndpoint = null;
+        if (pathInfo != null || queryString != null) {
+            pathInfo = checkPath(pathInfo);
+            queryString = checkQuery(queryString);
+            if (origEndpoint != null) {
+                try {
+                    URI endpointURI = new URI(origEndpoint);
+                    resolvedEndpoint = resolveURI(endpointURI, pathInfo, queryString);
+                } catch (URISyntaxException e) {
+                    resolvedEndpoint = origEndpoint;
+                }
+            }
+
+            requestContext.put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, resolvedEndpoint);
+            messageContext.put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, resolvedEndpoint);
+        }
+    }
+
+    protected String resolveURI(URI endpointURI, String pathInfo, String queryString) {
+        String query = null;
+        String fragment = null;
+        if (queryString != null) {
+            URI result = endpointURI.resolve(queryString);
+            query = result.getQuery();
+            fragment = result.getFragment();
+        }
+        //String path = (pathInfo != null) ? endpointURI.getPath() + pathInfo : endpointURI.getPath();
+        String path = (pathInfo != null) ? pathInfo : endpointURI.getPath();
+        try {
+            URI temp = new URI(null, null, path, query, fragment);
+            return endpointURI.resolve(temp).toString();
+        } catch (URISyntaxException e) {
+            e.printStackTrace();
+        }
+        return endpointURI.toString();
+    }
+
+    private String checkPath(String path) {
+        //does it begin with /
+        return (path == null || path.startsWith("/")) ? path : "/" + path;
+    }
+
+    private String checkQuery(String query) {
+        //does it begin with ?
+        return (query == null || query.startsWith("?")) ? query : "?" + query;
+    }
+
+    protected boolean isHTTPMessageType(DispatchContext dispatchContext) {
+
+        DispatchContext.MessageType type = (DispatchContext.MessageType)
+            dispatchContext.getProperty(DispatchContext.DISPATCH_MESSAGE);
+
+        if ((type == DispatchContext.MessageType.HTTP_DATASOURCE_MESSAGE) ||
+            //(type == DispatchContext.MessageType.HTTP_DATASOURCE_PAYLOAD) ||
+            (type == DispatchContext.MessageType.HTTP_SOURCE_MESSAGE) ||
+            (type == DispatchContext.MessageType.HTTP_SOURCE_PAYLOAD) ||
+            //(type == DispatchContext.MessageType.HTTP_JAXB_MESSAGE) ||
+            (type == DispatchContext.MessageType.HTTP_JAXB_PAYLOAD))
+            return true;
+
+        return false;
+    }
+
+    protected XMLMessage makeXMLMessage
+        (MessageInfo
+            messageInfo) {
+
+        XMLMessage xm = null;
+
+        Class clazz = (Class)
+            messageInfo.getMetaData(DispatchContext.DISPATCH_MESSAGE_CLASS);
+
+        Map<String, Object> context = (Map<String, Object>)
+            messageInfo.getMetaData(BindingProviderProperties.JAXWS_CONTEXT_PROPERTY);
+        Map<String, DataHandler> attachments = (context != null) ?
+            (Map<String, DataHandler> )context.get(MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS) : null;
+
+        // Determine if Fast Infoset is to be used
+        boolean useFastInfoset =
+            (messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY) == "optimistic");
+
+        Object object = messageInfo.getData()[0];
+
+        if (clazz != null && clazz.isAssignableFrom(Source.class)) {
+            //xm = new XMLMessage((Source) object, useFastInfoset);
+            xm = new XMLMessage((Source) object, attachments, useFastInfoset);
+        } else if (clazz != null && clazz.isAssignableFrom(DataSource.class)) {
+            xm = new XMLMessage((DataSource) object, useFastInfoset);
+        } else {
+            xm = new XMLMessage(object, getJAXBContext(messageInfo), attachments, useFastInfoset);
+            //xm = new XMLMessage(object, getJAXBContext(messageInfo), useFastInfoset);
+        }
+
+        return xm;
+    }
+
+     private void setMimeHeaders(Map<String, List<String>> requestHeaders, XMLMessage xm) {
+
+        if ((requestHeaders != null) && (!requestHeaders.isEmpty())) {
+            Set<Map.Entry<String, List<String>>> headerSet = requestHeaders.entrySet();
+            Iterator<Map.Entry<String, List<String>>> iter = headerSet.iterator();
+            while (iter.hasNext()) {
+                Map.Entry<String,List<String>> entry =iter.next();
+                MimeHeaders headers = xm.getMimeHeaders();
+                String[] values = entry.getValue().toArray(new String[entry.getValue().size()] );;
+                StringBuffer buf = new StringBuffer(250);
+                if (values.length > 0)
+                   buf.append(values[0]);
+                else break;
+                for (int i = 1; i < values.length - 1; i++){
+                    buf.append(values[i]);
+                }
+
+                headers.addHeader(entry.getKey(), buf.toString());
+            }
+        }
+    }
+
+    private XMLMessage updateXMLMessage(XMLHandlerContext context) {
+    // Create a new XMLMessage from existing message and OUTBOUND attachments property
+        MessageContext msgCtxt = context.getMessageContext();
+        Map<String, DataHandler> atts = (Map<String, DataHandler>)msgCtxt.get(
+                MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS);
+        if (atts != null) {
+            XMLMessage xmlMessage = context.getXMLMessage();
+            if (xmlMessage != null) {
+                Map<String, DataHandler> allAtts = xmlMessage.getAttachments();
+                if (allAtts != null) {
+                    allAtts.putAll(atts);
+                } else {
+                    allAtts = atts;
+                }
+                context.setXMLMessage(new XMLMessage(xmlMessage.getSource(), allAtts,
+                    xmlMessage.isFastInfoset()));
+            } else {
+                //can I make a message w/o src
+            }
+
+        }
+        return context.getXMLMessage();
+    }
+
+
+    class DaemonThreadFactory implements ThreadFactory {
+        public Thread newThread(Runnable r) {
+            Thread daemonThread = new Thread(r);
+            daemonThread.setDaemon(Boolean.TRUE);
+            return daemonThread;
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/server/ProviderXMLMD.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/server/ProviderXMLMD.java
new file mode 100644
index 0000000..5254777
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/server/ProviderXMLMD.java
@@ -0,0 +1,114 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.protocol.xml.server;
+
+import com.sun.xml.internal.ws.server.provider.ProviderModel;
+import javax.xml.ws.Provider;
+import javax.xml.ws.Service;
+import javax.xml.ws.ServiceMode;
+import javax.xml.transform.Source;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.encoding.xml.XMLMessage;
+import com.sun.xml.internal.ws.handler.XMLHandlerContext;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.server.provider.ProviderPeptTie;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import javax.activation.DataSource;
+
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.*;
+
+/**
+ * @author WS Development Team
+ *
+ */
+
+public class ProviderXMLMD extends XMLMessageDispatcher {
+
+    /*
+     * Fill the parameters, method in MessageInfo for Provider interface.
+     * invoke(Source, XMLHandlerContext) to Object[]
+     * invoke(SOAPMessage, XMLHandlerContext) to Object[]
+     */
+    @Override
+    protected void toMessageInfo(MessageInfo messageInfo, XMLHandlerContext context) {
+        Object[] data = new Object[1];
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        Provider provider = (Provider)endpointInfo.getImplementor();
+        Class providerClass = provider.getClass();
+        ProviderModel model = endpointInfo.getProviderModel();
+        boolean isSource = model.isSource();
+        Service.Mode mode = model.getServiceMode();
+        XMLMessage xmlMessage = context.getXMLMessage();
+        try {
+            if (isSource) {
+                data[0] = xmlMessage.getSource();
+            } else {
+                data[0] = xmlMessage.getDataSource();
+            }
+        } catch(Exception e) {
+            messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+            messageInfo.setResponse(e);
+        }
+        messageInfo.setData(data);
+        messageInfo.setMethod(ProviderPeptTie.invoke_Method);
+    }
+
+    /*
+     * MessageInfo contains the endpoint invocation results. If the endpoint
+     * returns a SOAPMessage, just set the object in HandlerContext. If the
+     * endpoint returns a Source in Mode.MESSAGE, it is converted to SOAPMessage
+     * and set in HandlerContext. If the endpoint returns a Source in
+     * Mode.PAYLOAD, it is set in InternalMessage, and InternalMessage is set
+     * in HandlerContext
+     */
+    @Override
+    protected void setResponseInContext(MessageInfo messageInfo,
+            XMLHandlerContext context) {
+        Object obj = messageInfo.getResponse();
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        Provider provider = (Provider)endpointInfo.getImplementor();
+        Class providerClass = provider.getClass();
+
+        boolean useFastInfoset =
+            messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY) == "optimistic";
+
+        XMLMessage xmlMessage = null;
+        if (messageInfo.getResponseType() == MessageInfo.NORMAL_RESPONSE) {
+            xmlMessage = (obj instanceof DataSource)
+                ? new XMLMessage((DataSource)obj, useFastInfoset)
+                : new XMLMessage((Source)obj, useFastInfoset);
+        } else {
+            xmlMessage = new XMLMessage((Exception)obj, useFastInfoset);
+        }
+        context.setXMLMessage(xmlMessage);
+        context.setInternalMessage(null);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/server/XMLMessageDispatcher.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/server/XMLMessageDispatcher.java
new file mode 100644
index 0000000..ec7fd59
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/protocol/xml/server/XMLMessageDispatcher.java
@@ -0,0 +1,512 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.protocol.xml.server;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.pept.presentation.TargetFinder;
+import com.sun.xml.internal.ws.pept.presentation.Tie;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.encoding.xml.XMLMessage;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller.Direction;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller.RequestOrResponse;
+import com.sun.xml.internal.ws.handler.XMLHandlerContext;
+import com.sun.xml.internal.ws.server.provider.ProviderModel;
+import com.sun.xml.internal.ws.server.provider.ProviderPeptTie;
+import com.sun.xml.internal.ws.spi.runtime.Invoker;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import java.io.IOException;
+import java.lang.reflect.Method;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import javax.activation.DataHandler;
+import javax.xml.namespace.QName;
+import javax.xml.soap.MimeHeader;
+import javax.xml.soap.MimeHeaders;
+import javax.xml.ws.Binding;
+import javax.xml.ws.handler.MessageContext;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import com.sun.xml.internal.ws.server.*;
+import com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegate;
+import com.sun.xml.internal.ws.spi.runtime.WebServiceContext;
+import com.sun.xml.internal.ws.util.XMLConnectionUtil;
+import javax.xml.ws.handler.MessageContext.Scope;
+
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.CONTENT_NEGOTIATION_PROPERTY;
+
+/**
+ * @author WS Development Team
+ *
+ */
+public abstract class XMLMessageDispatcher implements MessageDispatcher {
+
+    private static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".server.xmlmd");
+
+    public XMLMessageDispatcher() {
+    }
+
+    public void send(MessageInfo messageInfo) {
+        // Not required for server
+        throw new UnsupportedOperationException();
+    }
+
+    // TODO: need to work the exception logic
+    public void receive(MessageInfo messageInfo) {
+        XMLMessage xmlMessage = null;
+        try {
+            xmlMessage = getXMLMessage(messageInfo);
+        } catch(Exception e) {
+            sendResponseError(messageInfo, e);
+            return;
+        }
+        // Set it before response is sent on transport. If transport creates
+        // any exception, this can be used not to send again
+        boolean sent = false;
+        try {
+
+            // If FI is accepted by client, set property to optimistic
+            if (xmlMessage.acceptFastInfoset()) {
+                messageInfo.setMetaData(CONTENT_NEGOTIATION_PROPERTY, "optimistic");
+            }
+
+            XMLHandlerContext context = new XMLHandlerContext(messageInfo, null,
+                xmlMessage);
+            updateHandlerContext(messageInfo, context);
+
+
+            SystemHandlerDelegate shd = getSystemHandlerDelegate(messageInfo);
+            XmlInvoker implementor = new XmlInvoker(messageInfo, xmlMessage,
+                context, shd);
+            try {
+                if (shd == null) {
+                    // Invokes request handler chain, endpoint, response handler chain
+                    implementor.invoke();
+                } else {
+                    context.setInvoker(implementor);
+                    if (shd.processRequest(context.getSHDXMLMessageContext())) {
+                        implementor.invoke();
+                        context.getMessageContext().put(
+                            MessageContext.MESSAGE_OUTBOUND_PROPERTY, Boolean.TRUE);
+                        shd.processResponse(context.getSHDXMLMessageContext());
+                    }
+                }
+            } finally {
+                sent = implementor.isSent();    // response is sent or not
+            }
+            if (!isOneway(messageInfo)) {
+                sent = true;
+                sendResponse(messageInfo, context);
+            } else if (!sent) {
+                // Oneway and request handler chain reversed the execution direction
+                sent = true;
+                sendResponseOneway(messageInfo);
+            }
+        } catch(Exception e) {
+            e.printStackTrace();
+            logger.log(Level.SEVERE, e.getMessage(), e);
+            if (!sent) {
+                sendResponseError(messageInfo, e);
+            }
+        }
+        assert sent;            // Make sure response is sent
+    }
+
+    protected abstract void toMessageInfo(MessageInfo messageInfo, XMLHandlerContext context);
+
+    /*
+     * Gets XMLMessage from the connection
+     */
+    private XMLMessage getXMLMessage(MessageInfo messageInfo) {
+        WSConnection con = (WSConnection)messageInfo.getConnection();
+        return XMLConnectionUtil.getXMLMessage(con, messageInfo);
+    }
+
+    /**
+     * Invokes the endpoint
+     *
+     * In this case, Oneway is known only after invoking the endpoint. For other
+     * endpoints, the HTTP response code is sent before invoking the endpoint.
+     * This is taken care here after invoking the endpoint.
+     */
+    private void invokeEndpoint(MessageInfo messageInfo, XMLHandlerContext hc) {
+        TargetFinder targetFinder =
+            messageInfo.getEPTFactory().getTargetFinder(messageInfo);
+        Tie tie = targetFinder.findTarget(messageInfo);
+        tie._invoke(messageInfo);
+    }
+
+    protected XMLMessage getResponse(MessageInfo messageInfo, XMLHandlerContext context) {
+        setResponseInContext(messageInfo, context);
+        try {
+            HandlerChainCaller handlerCaller =
+                getCallerFromMessageInfo(messageInfo);
+            if (handlerCaller != null && handlerCaller.hasHandlers()) {
+                int messageType = messageInfo.getResponseType();
+                if (messageType == MessageInfo.CHECKED_EXCEPTION_RESPONSE ||
+                    messageType == MessageInfo.UNCHECKED_EXCEPTION_RESPONSE) {
+
+                    callHandleFault(handlerCaller, context);
+                } else {
+                    callHandlersOnResponse(handlerCaller, context);
+                }
+            }
+        } catch(Exception e) {
+            logger.log(Level.SEVERE, e.getMessage(), e);
+            boolean useFastInfoset =
+                messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY) == "optimistic";
+            XMLMessage xmlMessage = new XMLMessage(e, useFastInfoset);
+            context.setXMLMessage(xmlMessage);
+        }
+        // Create a new XMLMessage from existing message and OUTBOUND attachments property
+        MessageContext msgCtxt = context.getMessageContext();
+        Map<String, DataHandler> atts = (Map<String, DataHandler>)msgCtxt.get(
+                MessageContext.OUTBOUND_MESSAGE_ATTACHMENTS);
+        if (atts != null) {
+            XMLMessage xmlMessage = context.getXMLMessage();
+            Map<String, DataHandler> allAtts = xmlMessage.getAttachments();
+            if (allAtts != null) {
+                allAtts.putAll(atts);
+            } else {
+                allAtts = atts;
+            }
+            xmlMessage = new XMLMessage(xmlMessage.getSource(), allAtts,
+                    xmlMessage.isFastInfoset());
+            context.setXMLMessage(xmlMessage);
+        }
+        return context.getXMLMessage();
+    }
+
+    /*
+     * MessageInfo contains the endpoint invocation results. The information
+     * is converted to XMLMessage and is set in HandlerContext
+     */
+    protected abstract void setResponseInContext(MessageInfo messageInfo,
+            XMLHandlerContext context);
+
+    /**
+     * Sends XMLMessage response on the connection
+     */
+    private void sendResponse(MessageInfo messageInfo, XMLHandlerContext ctxt)
+    throws IOException {
+        XMLMessage xmlMessage = ctxt.getXMLMessage();
+        MessageContext msgCtxt = ctxt.getMessageContext();
+        WSConnection con = messageInfo.getConnection();
+
+        // See if MessageContext.HTTP_STATUS_CODE is present
+        Integer status = MessageContextUtil.getHttpStatusCode(msgCtxt);
+        int statusCode = (status == null) ? xmlMessage.getStatus() : status;
+
+
+        Map<String, List<String>> headers = new HashMap<String, List<String>>();
+
+        // put all headers from MessageContext.HTTP_RESPONSE_HEADERS
+        Map<String, List<String>> ctxtHdrs = MessageContextUtil.getHttpResponseHeaders(msgCtxt);
+        if (ctxtHdrs != null) {
+            headers.putAll(ctxtHdrs);
+        }
+        // put all headers from XMLMessage
+        MimeHeaders mhs = xmlMessage.getMimeHeaders();
+        Iterator i = mhs.getAllHeaders();
+        while (i.hasNext()) {
+            MimeHeader mh = (MimeHeader) i.next();
+            String name = mh.getName();
+            List<String> values = headers.get(name);
+            if (values == null) {
+                values = new ArrayList<String>();
+                headers.put(name, values);
+            }
+            values.add(mh.getValue());
+        }
+
+        // Set HTTP status code
+        con.setStatus(statusCode);
+        // put response headers on the connection
+        con.setHeaders(headers);
+        // Write contents on the connection
+        xmlMessage.writeTo(con.getOutput());
+        con.closeOutput();
+    }
+
+    protected void sendResponseOneway(MessageInfo messageInfo) {
+        WSConnection con = (WSConnection)messageInfo.getConnection();
+        XMLConnectionUtil.sendResponseOneway(con);
+    }
+
+    private void sendResponseError(MessageInfo messageInfo, Exception e) {
+        logger.log(Level.SEVERE, e.getMessage(), e);
+        WSConnection con = (WSConnection)messageInfo.getConnection();
+        XMLConnectionUtil.sendResponseError(con, messageInfo);
+    }
+
+
+
+    /**
+     * Calls inbound handlers. It also calls outbound handlers incase flow is
+     * reversed. If the handler throws a ProtocolException, SOAP message is
+     * already set in the context. Otherwise, it creates InternalMessage,
+     * and that is used to create SOAPMessage.
+     *
+     * returns whether to invoke endpoint or not.
+     */
+    private boolean callHandlersOnRequest(MessageInfo messageInfo,
+        XMLHandlerContext context, boolean responseExpected) {
+
+        boolean skipEndpoint = false;
+        HandlerChainCaller handlerCaller =
+            getCallerFromMessageInfo(messageInfo);
+
+        if (handlerCaller != null && handlerCaller.hasHandlers()) {
+            skipEndpoint = !handlerCaller.callHandlers(Direction.INBOUND,
+                RequestOrResponse.REQUEST, context, responseExpected);
+        }
+        return skipEndpoint;
+    }
+
+    /**
+     * Use this to find out if handlers are there in the execution path or not
+     *
+     * @return true if there are handlers in execution path
+     *         falst otherwise
+     */
+    private boolean hasHandlers(MessageInfo messageInfo) {
+        HandlerChainCaller handlerCaller =
+            getCallerFromMessageInfo(messageInfo);
+        return (handlerCaller != null && handlerCaller.hasHandlers()) ? true : false;
+    }
+
+    private HandlerChainCaller getCallerFromMessageInfo(MessageInfo info) {
+        HandlerChainCaller caller = MessageInfoUtil.getHandlerChainCaller(info);
+        if (caller == null) {
+            RuntimeContext context = (RuntimeContext)
+                info.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+            Binding binding = context.getRuntimeEndpointInfo().getBinding();
+            caller = new HandlerChainCaller(binding.getHandlerChain());
+            MessageInfoUtil.setHandlerChainCaller(info, caller);
+        }
+        return caller;
+    }
+
+    protected boolean callHandlersOnResponse(HandlerChainCaller caller,
+        XMLHandlerContext context) {
+
+        return caller.callHandlers(Direction.OUTBOUND,
+            RequestOrResponse.RESPONSE, context, false);
+    }
+
+    /*
+     * Used when the endpoint throws an exception. HandleFault is called
+     * on the server handlers rather than handleMessage.
+     */
+    protected boolean  callHandleFault(HandlerChainCaller caller, XMLHandlerContext context) {
+        /*
+        return caller.callHandleFault(context);
+         */
+        return false;
+    }
+
+    /*
+     * Server does not know if a message is one-way until after
+     * the handler chain has finished processing the request. If
+     * it is a one-way message, have the handler chain caller
+     * call close on the handlers.
+     */
+    private void closeHandlers(MessageInfo info, XMLHandlerContext context) {
+        HandlerChainCaller handlerCaller = getCallerFromMessageInfo(info);
+        if (handlerCaller != null && handlerCaller.hasHandlers()) {
+            handlerCaller.forceCloseHandlersOnServer(context);
+        }
+    }
+
+    private static boolean isFailure(MessageInfo messageInfo) {
+        return (messageInfo.getResponseType() == MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+    }
+
+    public static boolean isOneway(MessageInfo messageInfo) {
+        return (messageInfo.getMEP() == MessageStruct.ONE_WAY_MEP);
+    }
+
+    /*
+     * Sets the WebServiceContext with correct MessageContext which contains
+     * APPLICATION scope properties
+     */
+    protected void updateWebServiceContext(MessageInfo messageInfo, XMLHandlerContext hc) {
+        RuntimeEndpointInfo endpointInfo =
+            MessageInfoUtil.getRuntimeContext(messageInfo).getRuntimeEndpointInfo();
+        WebServiceContext wsContext = endpointInfo.getWebServiceContext();
+        if (wsContext != null) {
+            AppMsgContextImpl appCtxt = new AppMsgContextImpl(hc.getMessageContext());
+            wsContext.setMessageContext(appCtxt);
+        }
+    }
+
+    /**
+     * copy from message info to handler context
+     */
+    private void updateHandlerContext(MessageInfo messageInfo,
+            XMLHandlerContext context) {
+
+        RuntimeEndpointInfo endpointInfo =
+            MessageInfoUtil.getRuntimeContext(messageInfo).getRuntimeEndpointInfo();
+        WebServiceContext wsContext = endpointInfo.getWebServiceContext();
+        if (wsContext != null) {
+            context.setMessageContext(wsContext.getMessageContext());
+        }
+    }
+
+    private SystemHandlerDelegate getSystemHandlerDelegate(MessageInfo mi) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(mi);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        return endpointInfo.getBinding().getSystemHandlerDelegate();
+    }
+
+    /**
+     * This breaks the XMLMessage into source and attachments. A new XMLMessage
+     * is created with source and is set in XMLHandlerContext. The attachments
+     * are set in MessageContext as INBOUND attachments.
+     */
+    private void setInboundAttachments(MessageInfo messageInfo, XMLHandlerContext context) {
+        if (hasHandlers(messageInfo)) {
+            XMLMessage xmlMessage = context.getXMLMessage();
+            Map<String, DataHandler> atts = xmlMessage.getAttachments();
+            if (atts != null) {
+                MessageContext msgCtxt = context.getMessageContext();
+                msgCtxt.put(MessageContext.INBOUND_MESSAGE_ATTACHMENTS, atts);
+                msgCtxt.setScope(MessageContext.INBOUND_MESSAGE_ATTACHMENTS, MessageContext.Scope.APPLICATION);
+                xmlMessage = new XMLMessage(xmlMessage.getSource(), xmlMessage.isFastInfoset());
+                context.setXMLMessage(xmlMessage);
+            }
+        }
+    }
+
+    /**
+     * This creates a new XMLMessage from existing source and inbound attachments.
+     * inbound attachements cannot be there if there are no handlers.
+     * If the endpoint is Provider<Source>, it doesn't create a new message.
+     */
+    private void processInboundAttachments(MessageInfo messageInfo, XMLHandlerContext context) {
+        if (hasHandlers(messageInfo)) {
+            RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+            RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+            ProviderModel model = endpointInfo.getProviderModel();
+            boolean isSource = model.isSource();
+            if (!isSource) {
+                XMLMessage xmlMessage = context.getXMLMessage();
+                MessageContext msgCtxt = context.getMessageContext();
+                Map<String, DataHandler> atts = (Map<String, DataHandler>)
+                    msgCtxt.get(MessageContext.INBOUND_MESSAGE_ATTACHMENTS);
+                xmlMessage = new XMLMessage(xmlMessage.getSource(), atts, xmlMessage.isFastInfoset());
+                context.setXMLMessage(xmlMessage);
+            }
+        }
+    }
+
+    /**
+     * Invokes request handler chain, endpoint and response handler chain.
+     * Separated as a separate class, so that SHD can call this in doPriv()
+     * block.
+     */
+    private class XmlInvoker implements Invoker {
+
+        MessageInfo messageInfo;
+        XMLMessage xmlMessage;
+        XMLHandlerContext context;
+        SystemHandlerDelegate shd;
+        boolean sent;
+
+        XmlInvoker(MessageInfo messageInfo, XMLMessage xmlMessage,
+                XMLHandlerContext context, SystemHandlerDelegate shd) {
+            this.messageInfo = messageInfo;
+            this.xmlMessage = xmlMessage;
+            this.context = context;
+            this.shd = shd;
+        }
+
+        public void invoke() throws Exception {
+            boolean skipEndpoint = false;
+
+            // Sets INBOUND_MESSAGE_ATTACHMENTS in MessageContext
+            setInboundAttachments(messageInfo, context);
+            // Call inbound handlers. It also calls outbound handlers incase of
+            // reversal of flow.
+            skipEndpoint = callHandlersOnRequest(messageInfo, context, true);
+
+            if (!skipEndpoint) {
+                // new XMLMessage is created using INBOUND_MESSAGE_ATTACHMENTS
+                // in MessageContext
+                processInboundAttachments(messageInfo, context);
+                toMessageInfo(messageInfo, context);
+                if (!isFailure(messageInfo)) {
+                    if (shd != null) {
+                        shd.preInvokeEndpointHook(context.getSHDXMLMessageContext());
+                    }
+                    updateWebServiceContext(messageInfo, context);
+                    invokeEndpoint(messageInfo, context);
+                     // For Provider endpoints Oneway is known only after executing endpoint
+                    if (!sent && isOneway(messageInfo)) {
+                        sent = true;
+                        sendResponseOneway(messageInfo);
+                    }
+                }
+
+                if (isOneway(messageInfo)) {
+                    if (isFailure(messageInfo)) {
+                        // Just log the error. Not much to do
+                    }
+                } else {
+                    updateHandlerContext(messageInfo, context);
+                    xmlMessage = getResponse(messageInfo, context);
+                    context.setXMLMessage(xmlMessage);
+                }
+            }
+        }
+
+        /**
+         * Gets the dispatch method in the endpoint for the payload's QName
+         *
+         * @return dispatch method
+         */
+        public Method getMethod(QName name) {
+            return ProviderPeptTie.invoke_Method;
+        }
+
+        /*
+         * Is the message sent on transport. Happens when the operation is oneway
+         *
+         * @return true if the message is sent
+         *        false otherwise
+         */
+        public boolean isSent() {
+            return sent;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/client.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/client.properties
new file mode 100644
index 0000000..ceb5b87
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/client.properties
@@ -0,0 +1,43 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+http.client.cannot.connect=cannot connect to server: {0}
+http.client.failed=HTTP transport error: {0}
+local.client.failed=local transport error: {0}
+http.client.cannotCreateMessageFactory=cannot create message factory
+http.client.unauthorized=request requires HTTP authentication: {0}
+http.not.found=HTTP Status-Code 404: Not Found - {0}
+http.status.code=HTTP Status-Code {0}: {1}
+invalid.port.name={0} is not a valid port. Valid ports:{1}
+invalid.binding.id=Invalid binding id: {0}. Must be: {1}
+invalid.soap.role.none=Cannot set SOAP 1.2 role "none"
+non.logical.handler.set=Cannot set {0} on binding. Handler must be a LogicalHandler.
+runtime.parser.wsdl.invalidElement=invalid element \"{1}\" in the WSDL (line {0})
+service.noServiceName=Can't create service! Service name must be non-null
+service.noWSDLUrl=No wsdl metadata with the Service, can't create proxy! Try creating Service by providing a WSDL URL
+service.invalidPort=Port {0} is not found in service {1} in the wsdl {2}
+service.noPortName=No corresponding port found for the service interface {0} in {1}
+service.invalidServiceName=Cannot create Service instance, service {0} not found in the WSDL {1}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/dispatch.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/dispatch.properties
new file mode 100644
index 0000000..3ab8314
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/dispatch.properties
@@ -0,0 +1,25 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/encoding.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/encoding.properties
new file mode 100644
index 0000000..f70e8e7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/encoding.properties
@@ -0,0 +1,40 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+#nested
+nestedSerializationError=serialization error: {0}
+nestedDeserializationError=deserialization error: {0}
+nestedEncodingError=encoding error: {0}
+
+
+#EncoderDecoder
+exception.notfound=exception class: {0} not found in the model!
+exception.incorrectType=incorrect type. Expected java.lang.Exception, found {0}
+incorrect.messageinfo=can't write object! unexpected type: {0}
+unknown.object=don\'t know how to write object: {0}
+xsd.unknownPrefix=unknown prefix \"{0}\"
+xsd.unexpectedElementName=unexpected element name: expected={0}, actual: {1}
+mime.contentId.part=Can't associated the Content-ID \"{0}\" to a WSDL part, the Content-Id might not be formatted as per R2933 defined in AP 1.0.  
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/handler.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/handler.properties
new file mode 100644
index 0000000..407634d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/handler.properties
@@ -0,0 +1,32 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+handler.nestedError=handler error: {0}
+handler.chain.contains.handler.only=A HandlerChain can only contain Handler instances: {0}
+cannot.instantiate.handler=Unable to instantiate handler: {0} because: {1}
+cannot.extend.handler.directly=Handler {0} must implement LogicalHandler or SOAPHandler.
+handler.not.valid.type= {0} does not implement one of the handler interfaces.
+handler.messageContext.invalid.class= \"{0}\" is not an allowed value for the property \"{1}\"
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/httpserver.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/httpserver.properties
new file mode 100644
index 0000000..c738f31
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/httpserver.properties
@@ -0,0 +1,29 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+html.title=Web Services
+html.notFound=<h1>404 Not Found: {0}</h1>
+unexpected.http.method=Cannot handle HTTP method: {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/modeler.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/modeler.properties
new file mode 100644
index 0000000..b5d31b0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/modeler.properties
@@ -0,0 +1,38 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+nestedModelernError=runtime modeler error: {0}
+
+runtime.modeler.no.webservice.annotation=A WebService annotation is not present on class: {0}
+runtime.modeler.endpoint.interface.no.webservice=The Endpoint Interface: {0} does not have WebService Annotation
+runtime.modeler.class.not.found=class: {0} could not be found
+runtime.modeler.method.not.found=method: {0} could not be found on class: {1}
+runtime.modeler.oneway.operation.no.out.parameters=oneway operation should not have out parameters class: {0} method: {1}
+runtime.modeler.cannot.get.serviceName.from.interface=The serviceName cannot be retrieved from an interface.  class {0}
+runtime.modeler.portname.servicename.namespace.mismatch=The namespace of the serviceName \"{0}\" and the namespace of the portName \"{1}\" must match
+runtime.modeler.no.package=A @WebService.targetNamespace must be specified on classes with no package.  Class: {0}
+runtime.modeler.no.operations=The web service defined by the class {0} does not contain any valid WebMethods.
+runtime.operation.noBinding=Binding for operation {0} in port {1} not found! Probably WSDL doesn't contain binding for this operation.
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/sender.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/sender.properties
new file mode 100644
index 0000000..54b039a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/sender.properties
@@ -0,0 +1,30 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+sender.nestedError=sender error: {0}
+sender.request.messageNotReady=message not ready to be sent
+sender.response.cannotDecodeFaultDetail=fault detail cannot be decoded
+sender.request.illegalValueForContentNegotiation=illegal value for content negotiation property \"{0}\"
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/server.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/server.properties
new file mode 100644
index 0000000..8aa1529
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/server.properties
@@ -0,0 +1,79 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+soapdecoder.err=Error in decoding SOAP Message
+server.rt.err=Server Runtime Error: {0}
+soapencoder.err=Error in encoding SOAP Message
+
+annotation.only.once=Only one method should have the annotation \"{0}\"
+not.zero.parameters=Method \"{0}\" shouldn''t have any arguments
+
+wrong.field.type=Incorrect type for field \"{0}\"
+wrong.no.parameters=Incorrect no of arguments for method \"{0}\"
+wrong.parameter.type=Incorrect argument types for method \"{0}\"
+
+can.not.generate.wsdl=Cannot generate WSDL for binding \"{0}\"
+generate.non.standard.wsdl=Generating non-standard WSDL for the specified binding
+null.implementor=Implementor cannot be null
+
+runtime.wsdl.patcher=error while patching WSDL related document
+
+not.implement.provider=Class \"{0}\" doesn't implement Provider
+wsdl.required=wsdl is required
+service.name.required=Service QName is not found
+port.name.required=Port QName is not found
+wrong.tns.for.port=Port namespace {0} doesn't match Service namespace {1}
+
+already.http.server=There is already a HTTP server at : {0} 
+already.https.server=There is already a HTTPS server at : {0}
+not.HttpContext.type=Required com.sun.net.httpserver.HttpContext. Got : {0}
+
+cannot.load.wsdl=WSDL cannot be loaded from given location : {0}
+
+not.primary.wsdl=WSDL specified by wsdlLocation={0} is not a primary WSDL.
+duplicate.primary.wsdl=Metadata has more than one WSDL that has Service definiton for the endpoint. WSDL={0} is one such WSDL.
+duplicate.abstract.wsdl=Metadata has more than one WSDL that has PortType definiton for the endpoint. WSDL={0} is one such WSDL.
+no.ws.annotation=Endpoint implementation {0} doesn''t have @WebService or @WebServiceProvider annotation
+both.ws.annotations=Endpoint implementation {0} cannot have both @WebService and @WebServiceProvider annotations
+
+runtime.parser.wrong.wsdl.location=Incorrect WSDL localtion: {0}. It should start with WEB-INF/wsdl
+runtime.parser.classNotFound=class not found in runtime descriptor: {0}
+runtime.parser.xmlReader=error parsing runtime descriptor: {0}
+runtime.parser.invalidReaderState=error parsing runtime descriptor: {0}
+runtime.parser.unexpectedContent=unexpected content in runtime descriptor (line {0})
+runtime.parser.invalidElement=invalid element \"{1}\" in runtime descriptor (line {0})
+runtime.parser.invalidAttributeValue=invalid value for attribute \"{2}\" of element \"{1}\" in runtime descriptor (line {0})
+runtime.parser.invalidVersionNumber=unsupported runtime descriptor version: {2}
+runtime.parser.missing.attribute=missing attribute \"{2}\" in element \"{1}\" of runtime descriptor (line {0})
+runtime.parser.invalid.attribute.value=invalid attribute value \"{1}\" in runtime descriptor (line {0})
+runtime.parser.missing.attribute.no.line=missing attribute \"{2}\" in element \"{1}\" of runtime descriptor
+runtime.parser.wrong.element=found element \"{1}\", expected \"{2}\" in runtime descriptor (line {0})
+runtime.parser.wsdl=exception during WSDL parsing: {0}
+runtime.saxparser.exception={0}\n{1}
+runtime.parser.wsdl.noservice=can\'t apply binding! service {0} not found in the WSDL {1}
+runtime.parser.wsdl.nobinding=can\'t apply binding! no binding found for binding ID {0] for service {1} in WSDL {2}
+runtime.parser.wsdl.multiplebinding=multiple bindings found for binding ID {0} for service {1} in WSDL {2}
+runtime.parser.wsdl.incorrectserviceport=could not get binding from WSDL! service: {0} or port {1} not found in the WSDL {2}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/soap.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/soap.properties
new file mode 100644
index 0000000..b9aafe4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/soap.properties
@@ -0,0 +1,31 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+soap.msg.create.err=Couldn''t create SOAP message due to exception: {0}
+soap.msg.factory.create.err=Couldn''t create SOAP message factory due to exception: {0}
+soap.protocol.invalidFaultCode=Invalid fault code: {0}
+soap.factory.create.err=Couldn''t create SOAP factory due to exception: {0}
+soap.fault.create.err=Couldn''t create SOAP Fault due to exception: {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/streaming.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/streaming.properties
new file mode 100644
index 0000000..59bd9b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/streaming.properties
@@ -0,0 +1,50 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+streaming.ioException=XML parsing error: {0}
+streaming.parseException=XML parsing error: {0}
+
+xmlreader.illegalStateEncountered=XML reader internal error: illegal state ({0})
+xmlreader.unexpectedCharacterContent=XML reader error: unexpected character content: \"{0}\"
+xmlreader.ioException=XML reader error: {0}
+xmlreader.parseException=XML parsing error: {0}
+xmlreader.nestedError=XML reader error: {0}
+
+xmlwriter.noPrefixForURI=XML writer error: no prefix for URI: \"{0}\"
+xmlwriter.ioException=XML writer error: {0}
+xmlwriter.nestedError=XML writer error: {0}
+xmlreader.unexpectedState=unexpected XML reader state. expected: {0} but found: {1}
+xmlreader.unexpectedState.message=unexpected XML reader state. expected: {0} but found: {1}. {2}
+xmlreader.unexpectedState.tag=unexpected XML tag. expected: {0} but found: {1}
+
+xmlrecorder.recording.ended=no more recorded elements available
+
+stax.cantCreate=Unable to create StAX reader or writer
+staxreader.xmlstreamexception=XML stream reader exception: {0}
+
+fastinfoset.noImplementation=Unable to locate compatible implementation of Fast Infoset in classpath
+
+sourcereader.invalidSource=Unable to create reader from source \"{0}\"
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/util.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/util.properties
new file mode 100644
index 0000000..8834ab8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/util.properties
@@ -0,0 +1,33 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+util.handler.no.webservice.annotation="A WebService annotation is not present on class: {0}"
+util.handler.endpoint.interface.no.webservice="The Endpoint Interface: {0} does not have WebService Annotation"
+util.handler.class.not.found="Class: {0} could not be found"
+util.handler.cannot.combine.soapmessagehandlers=You must use HanlderChain annotation, not SOAPMessageHandlers
+util.parser.wrong.element=found element \"{1}\", expected \"{2}\" in handler chain configuration (line {0})
+util.failed.to.find.handlerchain.file=Could not find handler chain file {1} for class {0}
+util.failed.to.parse.handlerchain.file=Could not parse handler chain file {1} for class {0}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/wsservlet.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/wsservlet.properties
new file mode 100644
index 0000000..cf2db70
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/wsservlet.properties
@@ -0,0 +1,234 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+# the following properties are used by the http package
+listener.parsingFailed=WSSERVLET11: failed to parse runtime descriptor: {0}
+JAXRPCSERVLET11.diag.cause.1=WSRuntimeInfoParser cauld not parse sun-jaxws.xml runtime descriptor
+WSSERVLET11.diag.check.1=Please check the sun-jaxws.xml file to make sure it is correct
+WSSERVLET11.diag.cause.2=The sun-jaxws.xml runtime deployment descriptor may be missing
+WSSERVLET11.diag.check.2=Please check the jaxrpc-ri.xml file to make sure it is present in the war file
+
+
+listener.info.initialize=WSSERVLET12: JAX-WS context listener initializing
+WSSERVLET12.diag.cause.1=Context listener starting
+WSSERVLET12.diag.check.1=Normal web service startup
+
+listener.info.destroy=WSSERVLET13: JAX-WS context listener destroyed
+WSSERVLET13.diag.cause.1=Context listener shutdown
+WSSERVLET13.diag.check.1=Normal web service shutdown
+
+servlet.info.initialize=WSSERVLET14: JAX-WS servlet initializing
+WSSERVLET14.diag.cause.1=Web Services servlet starting up.
+WSSERVLET14.diag.check.1=Normal Web Service deployment. Deployment of service complete.
+
+servlet.info.destroy=WSSERVLET15: JAX-WS servlet destroyed
+WSSERVLET15.diag.cause.1=Web Services servlet shutdown.
+WSSERVLET15.diag.check.1=Normal Web service undeployment. Undeployment complete.
+
+servlet.warning.missingContextInformation=WSSERVLET16: missing context information
+WSSERVLET16.diag.cause.1=The jaxrpc-ri.xml file may be missing from the war file
+WSSERVLET16.diag.check.1=Unjar the service war file; check to see that the jaxrpc-ri-runtime.xml file is present
+
+
+servlet.warning.duplicateEndpointName=WSSERVLET17: duplicate endpoint name
+WSSERVLET17.diag.cause.1=Two or more endpoints with the same name where found in the jaxrpc-ri.xml runtime descriptor
+WSSERVLET17.diag.check.1=Note that this may cause problems with service deployment
+
+
+servlet.info.emptyRequestMessage=WSSERVLET18: got empty request message
+WSSERVLET18.diag.cause.1=Message sent by client is empty
+WSSERVLET18.diag.check.1=This may or may not be intentional. If not examine client program for errors.
+
+servlet.trace.gotRequestForEndpoint=WSSERVLET19: got request for endpoint: {0}
+WSSERVLET19.diag.cause.1=Client request for this endpoint arrived
+WSSERVLET19.diag.check.1=Informational message only. Normal operation.
+
+servlet.error.noImplementorForEndpoint=WSSERVLET20: no implementor for endpoint: {0}
+WSSERVLET20.diag.cause.1=Implementation for this service can not be found
+WSSERVLET20.diag.check.1=Unzip the war, are the tie and serializer classes found?
+
+servlet.trace.invokingImplementor=WSSERVLET21: invoking implementor: {0}
+WSSERVLET21.diag.cause.1=The Web service is being invoked
+WSSERVLET21.diag.check.1=Normal web service invocation.
+
+servlet.error.noEndpointSpecified=WSSERVLET22: no endpoint specified
+WSSERVLET22.diag.cause.1=A request was invoked with no endpoint
+WSSERVLET22.diag.check.1=Set endpoint with stub.setTargetEndpoint property
+
+servlet.error.noResponseMessage=WSSERVLET23: no response message
+WSSERVLET23.diag.cause.1=The request generated no response from the service
+WSSERVLET23.diag.check.1=If a response was expected, check that a request message was actually sent
+WSSERVLET23.diag.cause.1=The request generated no response from the service
+WSSERVLET23.diag.check.2=The request may be malformed and be accepted by the service, yet did not generate a response
+
+servlet.trace.writingFaultResponse=WSSERVLET24: writing fault response
+WSSERVLET24.diag.cause.1=SOAPFault message is being returned to the client.
+WSSERVLET24.diag.check.1=Tracing message fault recorded.
+
+servlet.trace.writingSuccessResponse=WSSERVLET25: writing success response
+WSSERVLET25.diag.cause.1=SOAPMessage response is being returned to client
+WSSERVLET25.diag.check.1=Tracing message, normal response.
+
+servlet.warning.duplicateEndpointUrlPattern=WSSERVLET26: duplicate URL pattern in endpoint: {0}
+WSSERVLET26.diag.cause.1=The endpoint URL is a duplicate
+WSSERVLET26.diag.check.1=This may cause a problem, please remove duplicate endpoints
+
+servlet.warning.ignoringImplicitUrlPattern=WSSERVLET27: unsupported implicit URL pattern in endpoint: {0}
+WSSERVLET27.diag.cause.1=Implicit URLS are not supported in this realease
+WSSERVLET27.diag.check.1=Remove the implicit URL
+
+servlet.faultstring.missingPort=WSSERVLET28: Missing port information
+WSSERVLET28.diag.cause.1=Target endpoint is null
+WSSERVLET28.diag.check.1=Set target endpoint with stub.setTargetEndpoint() property.
+
+servlet.faultstring.portNotFound=WSSERVLET29: Port not found ({0})
+WSSERVLET29.diag.cause.1=A port is specified, but a corresponding service implementation is not found
+WSSERVLET29.diag.check.1=Is the port valid? Unzip the war file and make sure the tie and serializers are present
+
+servlet.faultstring.internalServerError=WSSERVLET30: Internal server error ({0})
+WSSERVLET30.diag.cause.1=There was a server error processing the request
+WSSERVLET30.diag.check.1=This could be due to a number of causes. Check the server log file for exceptions.
+
+error.servlet.caughtThrowableWhileRecovering=WSSERVLET51: caught throwable while recovering from a previous exception: {0}
+WSSERVLET51.diag.cause.1=Service processing of the request generated an exception; while attempting to return a SOAPPFaultMessage a thowable was again generated
+WSSERVLET51.diag.check.1=Check the server.xml log file for exception information
+
+error.servlet.caughtThrowable=WSSERVLET49: caught throwable: {0}
+WSSERVLET49.diag.cause.1=Service processing of the request generated an exception; while attempting to return a SOAPFaultMessage a thowable was again generated
+WSSERVLET49.diag.check.1=Check the server.xml log file for exception information
+
+error.servlet.caughtThrowableInInit=WSSERVLET50: caught throwable during servlet initialization: {0}
+WSSERVLET50.diag.cause.1=WS runtime sun-jaxws.xml or web.xml may be incorrect
+WSSERVLET50.diag.check.1=Verify that sun-jaxws.xml and web.xml are correct in the service war file
+WSSERVLET50.diag.cause.2=Application server deployment descriptors may be incorrect
+WSSERVLET50.diag.check.2=Verify that Application server deployment descriptors are correct in the service war file
+WSSERVLET50.diag.cause.3=There may some Application Server initialization problems
+WSSERVLET50.diag.check.3=Check the server.xml file in the domain directory for failures
+
+publisher.info.applyingTransformation=WSSERVLET31: applying transformation with actual address: {0}
+WSSERVLET31.diag.cause.1=Transformation being applied
+WSSERVLET31.diag.check.1=Normal operation
+
+publisher.info.generatingWSDL=WSSERVLET32: generating WSDL for endpoint: {0}
+WSSERVLET32.diag.cause.1=WSDL being generated
+WSSERVLET32.diag.check.1=Normal Operation.
+
+exception.cannotCreateTransformer=WSSERVLET33: cannot create transformer
+WSSERVLET33.diag.cause.1=When publishing the service wsdl, the http location is patched with the deployed location/endpoint using XSLT transformation. The transformer could not be created to do the transformation.
+WSSERVLET33.diag.check.1=There maybe a tranformation engine being used that is not compatible. Make sure you are using the correct transformer and version.
+WSSERVLET33.diag.cause.2=When publishing the service wsdl, the http location is patched with the deployed location/endpoint using XSLT transformation. The transformer could not be created to do the transformation.
+WSSERVLET33.diag.check.2=There maybe a tranformation engine may not be supported or compatible. Check the server.xml file for exceptions.
+
+
+exception.transformationFailed=WSSERVLET34: transformation failed : {0}
+WSSERVLET34.diag.cause.1=The location patching on the wsdl failed when attempting to transform.
+WSSERVLET34.diag.check.1=Check the log file(s) for more detailed errors/exceptions.
+
+exception.templateCreationFailed=WSSERVLET35: failed to create a template object
+WSSERVLET35.diag.cause.1=A XSLT stylesheet template is create for the wsdl location patching using transformation. Template create failed.
+WSSERVLET35.diag.check.1=An exception was thrown during creation of the template. View exception and stacktrace for more details.
+
+servlet.html.method=WSSERVLET63: must use Post for this type of request
+WSSERVLET63.diag.cause.1=Web service requests must use HTTP POST method: WSI BP 1.0
+WSSERVLET63.diag.check.1=Make sure that your HTTP client is using POST requests, not GET requests
+
+
+servlet.faultstring.invalidContentType=WSSERVLET64: Invalid Content-Type, text/xml required
+WSSERVLET64.diag.cause.1=Web service requests must be a content type text/xml: WSI BP 1.0
+WSSERVLET64.diag.check.1=Make sure the client request is using text/xml
+
+error.implementorFactory.newInstanceFailed=WSSERVLET43: failed to instantiate service implementor for port \"{0}\"
+WSSERVLET43.diag.cause.1=Instantiation of the web service failed.
+WSSERVLET43.diag.check.1=Make sure web service is available and public. Examine exception for more details
+
+error.implementorFactory.servantInitFailed=WSSERVLET44: failed to initialize the service implementor for port \"{0}\"
+WSSERVLET44.diag.cause.1=The web service was instantiated, however, it could not be initialized
+WSSERVLET44.diag.check.1=Check the exception for more details. Make sure all the configuration files are correct.
+
+#not used by anything currently
+servlet.faultstring.invalidSOAPAction=WSSERVLET65: Invalid Header SOAPAction required
+WSSERVLET65.diag.cause.1=SOAP Action is required
+WSSERVLET65.diag.check.1=Add SOAPAction and appropriate value
+
+servlet.html.title= Web Services
+servlet.html.title2=<h1>Web Services</h1>
+servlet.html.noInfoAvailable=<p>No JAX-WS context information available.</p>
+servlet.html.columnHeader.portName=Port Name
+servlet.html.columnHeader.status=Status
+servlet.html.columnHeader.information=Information
+servlet.html.status.active=ACTIVE
+servlet.html.status.error=ERROR
+servlet.html.information.table=<table border\='0'><tr><td>Address\:</td><td>{0}</td></tr><tr><td>WSDL\:</td><td><a href\="{3}">{3}</a></td></tr><tr><td>Port QName\:</td><td>{1}</td></tr><tr><td>Implementation class\:</td><td>{2}</td></tr></table>
+servlet.html.notFound=<h1>404 Not Found: {0}</h1>
+
+
+#
+#
+# all the following properties are used by the http/ea package
+# these properties are not longer used as http/ea is no longer used
+#
+error.implementorFactory.noConfiguration=WSSERVLET36: no configuration specified
+error.implementorFactory.noInputStream=WSSERVLET37: no configuration specified
+error.implementorRegistry.unknownName=WSSERVLET38: unknown port name: {0}
+error.implementorRegistry.cannotReadConfiguration=WSSERVLET39: cannot read configuration
+error.implementorRegistry.classNotFound=WSSERVLET40: class not found: {0}
+error.implementorRegistry.incompleteInformation=WSSERVLET41: configuration information is incomplete
+error.implementorRegistry.duplicateName=WSSERVLET42: duplicate port name: {0}
+
+error.implementorRegistry.fileNotFound=WSSERVLET45: file not found: {0}
+error.wsdlPublisher.cannotReadConfiguration=WSSERVLET46: cannot read configuration
+error.servlet.init.config.parameter.missing=WSSERVLET47: cannot find configuration parameter: \"{0}\"
+error.servlet.init.config.fileNotFound=WSSERVLET48: config file: \"{0}\" not found
+#
+
+error.servlet.noImplementorForPort=WSSERVLET52: no implementor registered for port: {0}
+error.servlet.noPortSpecified=WSSERVLET53: no port specified in HTTP POST request URL
+error.servlet.noResponseWasProduced=WSSERVLET54: no response was produced (internal error)
+#
+info.servlet.gotEmptyRequestMessage=WSSERVLET55: got empty request message
+info.servlet.initializing=WSSERVLET56: JAX-WS servlet: init
+info.servlet.destroying=WSSERVLET57: JAX-WS servlet: destroy
+#
+trace.servlet.requestForPortNamed=WSSERVLET58: got request for port: {0}
+trace.servlet.handingRequestOverToImplementor=WSSERVLET59: handing request over to implementor: {0}
+trace.servlet.gotResponseFromImplementor=WSSERVLET60: got response from implementor: {0}
+trace.servlet.writingFaultResponse=WSSERVLET61: writing fault response
+trace.servlet.writingSuccessResponse=WSSERVLET62: writing success response
+#
+html.nonRootPage.title= Web Service
+html.nonRootPage.body1= <p>A Web Service is installed at this URL.</p>
+html.nonRootPage.body2= <p>Invalid request URI.</p><p>Please check your deployment information.</p>
+html.nonRootPage.body3a= <p>Please refer to <a href=\'
+html.nonRootPage.body3b= \'>this page</a> for information about the deployed services.</p>
+html.wsdlPage.title= Web Service
+html.wsdlPage.noWsdl=<p>No WSDL document available for publishing.</p><p>Please check your deployment information.</p>
+html.rootPage.title= Web Service
+html.rootPage.body1=<p>A Web Service is installed at this URL.</p>
+html.rootPage.body2a=<p>It supports the following ports:
+html.rootPage.body2b=</p>
+html.rootPage.body3a=<p>A WSDL description of these ports is available <a href='
+html.rootPage.body3b='>here.</a></p>
+html.rootPage.body4=<p>This endpoint is incorrectly configured. Please check the location and contents of the configuration file.</p>
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/xmlmessage.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/xmlmessage.properties
new file mode 100644
index 0000000..177f013
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/resources/xmlmessage.properties
@@ -0,0 +1,37 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+xml.null.headers=Invalid argument. MimeHeaders=null
+xml.no.Content-Type=MimeHeaders doesn't contain Content-Type header
+xml.unknown.Content-Type=Unrecognized Content-Type
+xml.cannot.internalize.message=Cannot create XMLMessage
+xml.root.part.invalid.Content-Type= Bad Content-Type for Root Part : {0}
+xml.get.source.err=Couldn't return Source
+xml.set.payload.err=Couldn't set Payload in XMLMessage
+xml.get.ds.err=Couldn't get DataSource
+xml.content-type.mustbe.multipart=Content-Type needs to be Multipart/Related and with type=text/xml
+xml.invalid.content-type=Invalid Content-Type: {0}
+xml.Content-Type.parse.err=Error while parsing MimeHeaders for Content-Type
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/AppMsgContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/AppMsgContextImpl.java
new file mode 100644
index 0000000..c49326d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/AppMsgContextImpl.java
@@ -0,0 +1,158 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server;
+import javax.xml.ws.handler.MessageContext;
+import java.lang.reflect.Method;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.Set;
+import javax.xml.ws.handler.MessageContext.Scope;
+
+public class AppMsgContextImpl implements MessageContext {
+
+    private MessageContext ctxt;
+    private Map<String, Object> appContext; // properties in APPLICATION scope
+
+    private void init() {
+        if (appContext == null) {
+            appContext = new HashMap<String, Object>();
+            Iterator<Entry<String, Object>> i = ctxt.entrySet().iterator();
+            while(i.hasNext()) {
+                Entry<String, Object> entry = i.next();
+                if (ctxt.getScope(entry.getKey()) == Scope.APPLICATION) {
+                    appContext.put(entry.getKey(), entry.getValue());
+                }
+            }
+        }
+    }
+
+    public AppMsgContextImpl(MessageContext ctxt) {
+        this.ctxt = ctxt;
+    }
+
+    /* java.util.Map methods below here */
+
+    public void clear() {
+        init();
+        Set<Entry<String, Object>> props = appContext.entrySet();
+        for (Entry<String, Object> prop : props) {
+            ctxt.remove(prop.getKey());
+        }
+        appContext.clear();
+    }
+
+    public boolean containsKey(Object obj) {
+        init();
+        return appContext.containsKey(obj);
+    }
+
+    public boolean containsValue(Object obj) {
+        init();
+        return appContext.containsValue(obj);
+    }
+
+    public Set<Entry<String, Object>> entrySet() {
+        init();
+        return appContext.entrySet();
+    }
+
+    public Object get(Object obj) {
+        init();
+        return appContext.get(obj);
+    }
+
+    public boolean isEmpty() {
+        init();
+        return appContext.isEmpty();
+    }
+
+    public Set<String> keySet() {
+        init();
+        return appContext.keySet();
+    }
+
+    public Object put(String str, Object obj) {
+        init();
+        Scope scope = null;
+        try {
+            scope = ctxt.getScope(str);
+        } catch(IllegalArgumentException ie) {
+            // It's okay, MessageContext didn't have this property
+        }
+        if (scope != null && scope == Scope.HANDLER) {
+            throw new IllegalArgumentException(
+                    "Cannot overwrite property in HANDLER scope");
+        }
+        ctxt.put(str, obj);
+        ctxt.setScope(str, Scope.APPLICATION);
+        return appContext.put(str, obj);
+    }
+
+    public void putAll(Map<? extends String, ? extends Object> map) {
+        init();
+        Set<? extends Entry<? extends String, ? extends Object>> props = map.entrySet();
+        for(Entry<? extends String, ? extends Object> prop : props) {
+            put(prop.getKey(), prop.getValue());
+        }
+    }
+
+    public Object remove(Object key) {
+        init();
+        Scope scope = null;
+        try {
+            scope = ctxt.getScope((String)key);
+        } catch(IllegalArgumentException ie) {
+            // It's okay, MessageContext didn't have this property
+        }
+        if (scope != null && scope == Scope.HANDLER) {
+            throw new IllegalArgumentException(
+                    "Cannot remove property in HANDLER scope");
+        }
+        ctxt.remove(key);
+        return appContext.remove(key);
+    }
+
+    public int size() {
+        init();
+        return appContext.size();
+    }
+
+    public Collection<Object> values() {
+        init();
+        return appContext.values();
+    }
+
+    public void setScope(String name, Scope scope) {
+
+    }
+
+    public Scope getScope(String name) {
+        return null;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/DocInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/DocInfo.java
new file mode 100644
index 0000000..f613999
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/DocInfo.java
@@ -0,0 +1,100 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server;
+import com.sun.xml.internal.ws.wsdl.parser.Service;
+import java.io.InputStream;
+import java.net.URL;
+
+
+public interface DocInfo {
+
+    public enum DOC_TYPE { WSDL, SCHEMA, OTHER };
+
+    /*
+     * The implemenation needs to work for multiple invocations of this method
+     */
+    public InputStream getDoc();
+
+    /*
+     * @return wsdl=a, xsd=c etc
+     */
+    public String getQueryString();
+
+    /*
+     * set wsdl=a, xsd=c etc as queryString
+     */
+    public void setQueryString(String queryString);
+
+    /*
+     * Sets document type : WSDL, or Schema ?
+     */
+    public void setDocType(DOC_TYPE docType);
+
+    /*
+     * return document type : WSDL, or Schema ?
+     */
+    public DOC_TYPE getDocType();
+
+    /*
+     * Sets targetNamespace of WSDL, and schema
+     */
+    public void setTargetNamespace(String ns);
+
+    /*
+     * Sets targetNamespace of WSDL, and schema
+     */
+    public String getTargetNamespace();
+
+    /*
+     * Sets if the endpoint service is defined in this document
+     */
+    public void setService(Service service);
+
+    /*
+     * returns true if endpoint service is present in this document
+     */
+    public Service getService();
+
+    /*
+     * Sets if the endpoint Port Type is defined in this document
+     */
+    public void setHavingPortType(boolean portType);
+
+    /*
+     * returns true if endpoint PortType is present in this document
+     */
+    public boolean isHavingPortType();
+
+    /*
+     * @return /WEB-INF/wsdl/xxx.wsdl
+     */
+    public String getPath();
+
+    /*
+     * @return URL for /WEB-INF/wsdl/xxx.wsdl
+     */
+    public URL getUrl();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/EPTFactoryBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/EPTFactoryBase.java
new file mode 100644
index 0000000..845c0bc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/EPTFactoryBase.java
@@ -0,0 +1,116 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server;
+
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.TargetFinder;
+import com.sun.xml.internal.ws.pept.protocol.Interceptors;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.soap.SOAPDecoder;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEPTFactory;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+
+/**
+ * @author WS Development Team
+ */
+public class EPTFactoryBase implements EPTFactory, SOAPEPTFactory {
+    private Encoder encoder;
+    private Decoder decoder;
+    private SOAPEncoder soapEncoder;
+    private SOAPDecoder soapDecoder;
+    private InternalEncoder internalEncoder;
+    private TargetFinder targetFinder;
+    private MessageDispatcher messageDispatcher;
+
+    public EPTFactoryBase(Encoder encoder, Decoder decoder,
+            TargetFinder targetFinder, MessageDispatcher messageDispatcher) {
+        this.encoder = encoder;
+        this.decoder = decoder;
+        this.targetFinder = targetFinder;
+        this.messageDispatcher = messageDispatcher;
+    }
+
+    public EPTFactoryBase(SOAPEncoder soapEncoder, SOAPDecoder soapDecoder,
+                          InternalEncoder internalEncoder,
+                          TargetFinder targetFinder, MessageDispatcher messageDispatcher) {
+        this.encoder = null;
+        this.decoder = null;
+        this.soapEncoder = soapEncoder;
+        this.soapDecoder = soapDecoder;
+        this.internalEncoder = internalEncoder;
+        this.targetFinder = targetFinder;
+        this.messageDispatcher = messageDispatcher;
+    }
+
+    public Encoder getEncoder(MessageInfo messageInfo) {
+        messageInfo.setEncoder(encoder);
+        return messageInfo.getEncoder();
+    }
+
+    public Decoder getDecoder(MessageInfo messageInfo) {
+        messageInfo.setDecoder(decoder);
+        return messageInfo.getDecoder();
+    }
+
+    public TargetFinder getTargetFinder(MessageInfo messageInfo) {
+        return targetFinder;
+    }
+
+    public MessageDispatcher getMessageDispatcher(MessageInfo messageInfo) {
+        messageInfo.setMessageDispatcher(messageDispatcher);
+        return messageDispatcher;
+    }
+
+    /*
+     * @see EPTFactory#getInterceptors(com.sun.istack.internal.pept.ept.MessageInfo)
+     */
+    public Interceptors getInterceptors(MessageInfo x) {
+        return null;
+    }
+
+    /*
+     * @see LogicalEPTFactory#getSoapEncoder()
+     */
+    public SOAPEncoder getSOAPEncoder() {
+        return soapEncoder;
+    }
+
+    /*
+     * @see LogicalEPTFactory#getSoapDecoder()
+     */
+    public SOAPDecoder getSOAPDecoder() {
+        return soapDecoder;
+    }
+
+    public InternalEncoder getInternalEncoder() {
+        return internalEncoder;
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/EPTFactoryFactoryBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/EPTFactoryFactoryBase.java
new file mode 100644
index 0000000..9b6c129
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/EPTFactoryFactoryBase.java
@@ -0,0 +1,148 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server;
+
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.TargetFinder;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.soap.SOAPDecoder;
+import com.sun.xml.internal.ws.encoding.soap.SOAPEncoder;
+import com.sun.xml.internal.ws.encoding.soap.ServerEncoderDecoder;
+import com.sun.xml.internal.ws.protocol.soap.server.ProviderSOAPMD;
+import com.sun.xml.internal.ws.spi.runtime.MessageContext;
+import javax.xml.ws.Provider;
+import javax.xml.ws.soap.SOAPBinding;
+
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.server.provider.ProviderPeptTie;
+import com.sun.xml.internal.ws.encoding.soap.server.ProviderSED;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.protocol.soap.server.SOAPMessageDispatcher;
+import com.sun.xml.internal.ws.encoding.soap.server.SOAP12XMLDecoder;
+import com.sun.xml.internal.ws.encoding.soap.server.SOAP12XMLEncoder;
+import com.sun.xml.internal.ws.encoding.soap.server.SOAPXMLDecoder;
+import com.sun.xml.internal.ws.encoding.soap.server.SOAPXMLEncoder;
+import com.sun.xml.internal.ws.encoding.xml.XMLDecoder;
+import com.sun.xml.internal.ws.encoding.xml.XMLEncoder;
+import com.sun.xml.internal.ws.protocol.xml.server.ProviderXMLMD;
+import javax.xml.ws.http.HTTPBinding;
+
+/**
+ * factory for creating the appropriate EPTFactory given the BindingId from the EndpointInfo
+ * in the RuntimeContext of the MessageInfo
+ * Based on MessageInfo data(Binding, Implementor) it selects one the static EPTFactories
+ * using Binding information
+ * Has a static EPTFactory object for each particular binding.
+ * EPTFactories are reused for all the requests.
+ * Has static provider EPTFactory objects.
+ * The provider EPTFactories are reused for all the requests.
+ * The factories reuse encoder, decoder, message dispatcher objects since these objects
+ * are Stateless. They are reused for all the requests.
+ *
+ * @author WS Development Team
+ */
+public abstract class EPTFactoryFactoryBase {
+
+    public static final ProviderSOAPMD providerMessageDispatcher =
+        new ProviderSOAPMD();
+    public static final SOAPEncoder soap11Encoder = new SOAPXMLEncoder();
+    public static final SOAPDecoder soap11Decoder = new SOAPXMLDecoder();
+    public static final SOAPEncoder soap12Encoder = new SOAP12XMLEncoder();
+    public static final SOAPDecoder soap12Decoder = new SOAP12XMLDecoder();
+
+    public static final XMLEncoder xmlEncoder = null; //new XMLEncoder();
+    public static final XMLDecoder xmlDecoder = null; //new XMLDecoder();
+
+    public static final SOAPMessageDispatcher soap11MessageDispatcher =
+        new SOAPMessageDispatcher();
+    public static final MessageDispatcher providerXmlMD =
+        new ProviderXMLMD();
+    public static final InternalEncoder internalSED = new ServerEncoderDecoder();
+    public static final InternalEncoder providerSED = new ProviderSED();
+    public static final TargetFinder providerTargetFinder =
+            new TargetFinderImpl(new ProviderPeptTie());
+    public static final TargetFinder targetFinder =
+            new TargetFinderImpl(new PeptTie());
+
+    public static final EPTFactory providerSoap11 =
+            new EPTFactoryBase(soap11Encoder, soap11Decoder,
+                    providerSED, providerTargetFinder,
+                providerMessageDispatcher);
+
+    public static final EPTFactory providerSoap12 =
+            new EPTFactoryBase(soap12Encoder, soap12Decoder,
+                    providerSED, providerTargetFinder,
+                providerMessageDispatcher);
+
+    public static final EPTFactory soap11 =
+            new EPTFactoryBase(
+                soap11Encoder, soap11Decoder,
+                    internalSED, targetFinder,
+                soap11MessageDispatcher);
+
+    public static final EPTFactory soap12 =
+            new EPTFactoryBase(
+                soap12Encoder, soap12Decoder,
+                    internalSED, targetFinder,
+                soap11MessageDispatcher);
+
+    public static final EPTFactory providerXml =
+        new XMLEPTFactoryImpl(
+            xmlEncoder, xmlDecoder,
+                providerSED, providerTargetFinder,
+            providerXmlMD);
+
+    /**
+     * Choose correct EPTFactory. MessageInfo contains all the needed
+     * information like Binding, WSConnection to make that decision.
+     * @param mi the MessageInfo object to obtain the BindingID from.
+     * @return returns the appropriate EPTFactory for the BindingID in the mi
+     */
+    public static EPTFactory getEPTFactory(MessageInfo mi) {
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(mi);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        String bindingId = ((BindingImpl)endpointInfo.getBinding()).getBindingId();
+        if(bindingId.equals(SOAPBinding.SOAP11HTTP_BINDING)){
+            if (endpointInfo.getImplementor() instanceof Provider) {
+                return providerSoap11;
+            } else {
+                return soap11;
+            }
+        }else if(bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING)){
+            if (endpointInfo.getImplementor() instanceof Provider) {
+                return providerSoap12;
+            } else {
+                return soap12;
+            }
+        } else if(bindingId.equals(HTTPBinding.HTTP_BINDING)){
+            if (endpointInfo.getImplementor() instanceof Provider) {
+                return providerXml;
+            }
+        }
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/PeptTie.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/PeptTie.java
new file mode 100644
index 0000000..ec7fd5f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/PeptTie.java
@@ -0,0 +1,93 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server;
+
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.ws.pept.presentation.Tie;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+/**
+ * Creates a Stateless Tie object so that it is created only once and reused.
+ */
+public class PeptTie implements Tie {
+
+    private static final Logger logger = Logger.getLogger(
+            com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".server.PeptTie");
+
+    public void _setServant(Object servant) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Object _getServant() {
+        throw new UnsupportedOperationException();
+    }
+
+    /*
+     * @see Tie#_invoke(MessageInfo)
+     */
+    public void _invoke(MessageInfo messageInfo) {
+        Object[] oa = messageInfo.getData();
+        Method method = messageInfo.getMethod();
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        Object servant = endpointInfo.getImplementor();
+        try {
+            Object ret = method.invoke(servant, oa);
+            messageInfo.setResponseType(MessageStruct.NORMAL_RESPONSE);
+            messageInfo.setResponse(ret);
+        } catch (IllegalArgumentException e) {
+            setRuntimeException(messageInfo, e);
+        } catch (IllegalAccessException e) {
+            setRuntimeException(messageInfo, e);
+        } catch (InvocationTargetException e) {
+            Throwable cause = e.getCause();
+            if (cause != null) {
+                if (!(cause instanceof RuntimeException) && cause instanceof Exception ) {
+                    // Service specific exception
+                    messageInfo.setResponseType(
+                            MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+                    messageInfo.setResponse(cause);
+                } else {
+                    setRuntimeException(messageInfo, cause);
+                }
+            } else {
+                setRuntimeException(messageInfo, e);
+            }
+        }
+    }
+
+    private void setRuntimeException(MessageInfo messageInfo, Throwable e) {
+        logger.log(Level.SEVERE, e.getMessage(), e);
+        messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+        messageInfo.setResponse(e);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/RuntimeContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/RuntimeContext.java
new file mode 100644
index 0000000..cd42fc9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/RuntimeContext.java
@@ -0,0 +1,124 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server;
+
+import java.lang.reflect.Method;
+
+import javax.xml.namespace.QName;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+
+
+
+
+/**
+ * $author: WS Development Team
+ */
+public class RuntimeContext {
+
+    public RuntimeContext(RuntimeModel model) {
+        this.model = model;
+    }
+
+    /**
+     * @return Returns the model.
+     */
+    public RuntimeModel getModel() {
+        return model;
+    }
+
+    /**
+     * @return Returns info about endpoint
+     */
+    public RuntimeEndpointInfo getRuntimeEndpointInfo() {
+        return endpointInfo;
+    }
+
+    /**
+     * sets info about endpoint
+     */
+    public void setRuntimeEndpointInfo(RuntimeEndpointInfo endpointInfo) {
+        this.endpointInfo = endpointInfo;
+    }
+
+    /**
+     * @param name
+     * @param mi
+     * @return the <code>Method</code> associated with the operation named name
+     */
+    public Method getDispatchMethod(QName name, MessageInfo mi) {
+        return getDispatchMethod(name);
+    }
+
+    /**
+     * @param name
+     * @return the <code>Method</code> associated with the operation named name
+     */
+    public Method getDispatchMethod(QName name){
+        return model.getDispatchMethod(name);
+    }
+
+    /**
+     * @param qname
+     * @param mi
+     */
+    public void setMethodAndMEP(QName qname, MessageInfo mi) {
+        if (model != null) {
+            mi.setMethod(model.getDispatchMethod(qname));
+
+            // if null, default MEP is ok
+            if (qname != null && model.getJavaMethod(qname) != null) {
+                mi.setMEP(model.getJavaMethod(qname).getMEP());
+            }
+        }
+    }
+
+    /**
+     * @param name
+     * @return the decoder Info associated with operation named name
+     */
+    public Object getDecoderInfo(QName name) {
+        return model.getDecoderInfo(name);
+    }
+
+    public BridgeContext getBridgeContext() {
+        return (model != null)?model.getBridgeContext():null;
+    }
+
+    public HandlerContext getHandlerContext() {
+        return handlerContext;
+    }
+
+    public void setHandlerContext(HandlerContext handlerContext) {
+        this.handlerContext = handlerContext;
+    }
+
+    private RuntimeModel model;
+    private HandlerContext handlerContext;
+    private RuntimeEndpointInfo endpointInfo;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/RuntimeEndpointInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/RuntimeEndpointInfo.java
new file mode 100644
index 0000000..229ea69
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/RuntimeEndpointInfo.java
@@ -0,0 +1,846 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.server;
+
+import com.sun.xml.internal.ws.server.provider.ProviderModel;
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Field;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.net.URL;
+import java.security.AccessController;
+import java.security.PrivilegedActionException;
+import java.security.PrivilegedExceptionAction;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.logging.Logger;
+import java.io.IOException;
+import java.util.Map.Entry;
+import java.util.concurrent.Executor;
+
+import javax.annotation.Resource;
+import javax.jws.WebService;
+import javax.xml.namespace.QName;
+import javax.xml.ws.Provider;
+import javax.xml.ws.handler.Handler;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.transform.Source;
+import javax.annotation.PostConstruct;
+import javax.annotation.PreDestroy;
+import javax.xml.ws.WebServiceProvider;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.ws.Endpoint;
+
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.binding.soap.SOAPBindingImpl;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.modeler.RuntimeModeler;
+import com.sun.xml.internal.ws.server.DocInfo.DOC_TYPE;
+import com.sun.xml.internal.ws.spi.runtime.Binding;
+import com.sun.xml.internal.ws.spi.runtime.WebServiceContext;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.xml.internal.ws.util.localization.Localizer;
+import com.sun.xml.internal.ws.util.HandlerAnnotationInfo;
+import com.sun.xml.internal.ws.util.HandlerAnnotationProcessor;
+import com.sun.xml.internal.ws.wsdl.parser.RuntimeWSDLParser;
+import com.sun.xml.internal.ws.wsdl.parser.Service;
+import com.sun.xml.internal.ws.wsdl.parser.WSDLDocument;
+import com.sun.xml.internal.ws.wsdl.writer.WSDLGenerator;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.SAXException;
+
+
+
+
+/**
+ * modeled after the javax.xml.ws.Endpoint class in API.
+ * Contains all the information about Binding, handler chain, Implementor object,
+ * WSDL & Schema Metadata
+ * @author WS Development Team
+ */
+public class RuntimeEndpointInfo implements com.sun.xml.internal.ws.spi.runtime.RuntimeEndpointInfo {
+
+    private String name;
+    private QName portName;
+    private QName serviceName;
+    private String wsdlFileName;
+    private boolean deployed;
+    private String urlPattern;
+    private List<Source> metadata;
+    private Binding binding;
+    private RuntimeModel runtimeModel;
+    private Object implementor;
+    private Class implementorClass;
+    private Map<String, DocInfo> docs;      // /WEB-INF/wsdl/xxx.wsdl -> DocInfo
+    private Map<String, DocInfo> query2Doc;     // (wsdl=a) --> DocInfo
+    private WebServiceContext wsContext;
+    private boolean beginServiceDone;
+    private boolean endServiceDone;
+    private boolean injectedContext;
+    private URL wsdlUrl;
+    private EntityResolver wsdlResolver;
+    private QName portTypeName;
+    private Integer mtomThreshold;
+    private static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".server.endpoint");
+    private static final Localizer localizer = new Localizer();
+    private static final LocalizableMessageFactory messageFactory =
+        new LocalizableMessageFactory("com.sun.xml.internal.ws.resources.server");
+    private WebService ws;
+    private WebServiceProvider wsProvider;
+    private ProviderModel providerModel;
+
+    public String getName() {
+        return name;
+    }
+
+    public void setName(String s) {
+        name = s;
+    }
+
+    public String getWSDLFileName() {
+        return wsdlFileName;
+    }
+
+    public void setWSDLFileName(String s) {
+        wsdlFileName = s;
+    }
+
+    /**
+     * set the URL for primary WSDL, and an EntityResolver to resolve all
+     * imports/references
+     */
+    public void setWsdlInfo(URL wsdlUrl, EntityResolver wsdlResolver) {
+        this.wsdlUrl = wsdlUrl;
+        this.wsdlResolver = wsdlResolver;
+    }
+
+    public EntityResolver getWsdlResolver() {
+        return wsdlResolver;
+    }
+
+    public URL getWsdlUrl() {
+        return wsdlUrl;
+    }
+
+    public boolean isDeployed() {
+        return deployed;
+    }
+
+    public void createProviderModel() {
+        providerModel = new ProviderModel(implementorClass, binding);
+    }
+
+    public void createSEIModel() {
+        // Create runtime model for non Provider endpoints
+
+        // wsdlURL will be null, means we will generate WSDL. Hence no need to apply
+        // bindings or need to look in the WSDL
+        if(wsdlUrl == null){
+            RuntimeModeler rap = new RuntimeModeler(getImplementorClass(),
+                getImplementor(), getServiceName(), ((BindingImpl)binding).getBindingId());
+            if (getPortName() != null) {
+                rap.setPortName(getPortName());
+            }
+            runtimeModel = rap.buildRuntimeModel();
+        }else {
+            try {
+                WSDLDocument wsdlDoc = RuntimeWSDLParser.parse(getWsdlUrl(), getWsdlResolver());
+                com.sun.xml.internal.ws.wsdl.parser.Binding wsdlBinding = null;
+                if(serviceName == null)
+                    serviceName = RuntimeModeler.getServiceName(getImplementorClass());
+                if(getPortName() != null){
+                    wsdlBinding = wsdlDoc.getBinding(getServiceName(), getPortName());
+                    if(wsdlBinding == null)
+                        throw new ServerRtException("runtime.parser.wsdl.incorrectserviceport", new Object[]{serviceName, portName, getWsdlUrl()});
+                }else{
+                    Service service = wsdlDoc.getService(serviceName);
+                    if(service == null)
+                        throw new ServerRtException("runtime.parser.wsdl.noservice", new Object[]{serviceName, getWsdlUrl()});
+
+                    String bindingId = ((BindingImpl)binding).getBindingId();
+                    List<com.sun.xml.internal.ws.wsdl.parser.Binding> bindings = wsdlDoc.getBindings(service, bindingId);
+                    if(bindings.size() == 0)
+                        throw new ServerRtException("runtime.parser.wsdl.nobinding", new Object[]{bindingId, serviceName, getWsdlUrl()});
+
+                    if(bindings.size() > 1)
+                        throw new ServerRtException("runtime.parser.wsdl.multiplebinding", new Object[]{bindingId, serviceName, getWsdlUrl()});
+                }
+                //now we got the Binding so lets build the model
+                RuntimeModeler rap = new RuntimeModeler(getImplementorClass(), getImplementor(), getServiceName(), wsdlBinding);
+                if (getPortName() != null) {
+                    rap.setPortName(getPortName());
+                }
+                runtimeModel = rap.buildRuntimeModel();
+            } catch (IOException e) {
+                throw new ServerRtException("runtime.parser.wsdl", getWsdlUrl().toString());
+            } catch (XMLStreamException e) {
+                throw new ServerRtException("runtime.saxparser.exception",
+                        new Object[]{e.getMessage(), e.getLocation()});
+            } catch (SAXException e) {
+                throw new ServerRtException("runtime.parser.wsdl", getWsdlUrl().toString());
+            }
+        }
+    }
+
+
+    public boolean isProviderEndpoint() {
+        Annotation ann = getImplementorClass().getAnnotation(
+            WebServiceProvider.class);
+        return (ann != null);
+    }
+
+    /*
+     * If serviceName is not already set via DD or programmatically, it uses
+     * annotations on implementorClass to set ServiceName.
+     */
+    public void doServiceNameProcessing() {
+        if (getServiceName() == null) {
+            if (isProviderEndpoint()) {
+                WebServiceProvider wsProvider =
+                    (WebServiceProvider)getImplementorClass().getAnnotation(
+                        WebServiceProvider.class);
+                String tns = wsProvider.targetNamespace();
+                String local = wsProvider.serviceName();
+                // create QName("", ""), if the above values are default
+                setServiceName(new QName(tns, local));
+            } else {
+                setServiceName(RuntimeModeler.getServiceName(getImplementorClass()));
+            }
+        }
+    }
+
+    /*
+     * If portName is not already set via DD or programmatically, it uses
+     * annotations on implementorClass to set PortName.
+     */
+    public void doPortNameProcessing() {
+        if (getPortName() == null) {
+            if (isProviderEndpoint()) {
+                WebServiceProvider wsProvider =
+                    (WebServiceProvider)getImplementorClass().getAnnotation(
+                        WebServiceProvider.class);
+                String tns = wsProvider.targetNamespace();
+                String local = wsProvider.portName();
+                // create QName("", ""), if the above values are default
+                setPortName(new QName(tns, local));
+
+            } else {
+                setPortName(RuntimeModeler.getPortName(getImplementorClass(),
+                    getServiceName().getNamespaceURI()));
+            }
+        } else {
+            String serviceNS = getServiceName().getNamespaceURI();
+            String portNS = getPortName().getNamespaceURI();
+            if (!serviceNS.equals(portNS)) {
+                throw new ServerRtException("wrong.tns.for.port",
+                    new Object[] { portNS, serviceNS });
+
+            }
+        }
+    }
+
+    /*
+     * Sets PortType QName
+     */
+    public void doPortTypeNameProcessing() {
+        if (getPortTypeName() == null) {
+            if (!isProviderEndpoint()) {
+                setPortTypeName(RuntimeModeler.getPortTypeName(getImplementorClass()));
+            }
+        }
+    }
+
+
+    /**
+     * creates a RuntimeModel using @link com.sun.xml.internal.ws.modeler.RuntimeModeler.
+     * The modeler creates the model by reading annotations on ImplementorClassobject.
+     * RuntimeModel is read only and is accessed from multiple threads afterwards.
+
+     */
+    public void init() {
+        if (implementor == null) {
+            throw new ServerRtException("null.implementor");
+        }
+        if (implementorClass == null) {
+            setImplementorClass(getImplementor().getClass());
+        }
+
+        // verify if implementor class has @WebService or @WebServiceProvider
+        verifyImplementorClass();
+
+        // ServiceName processing
+        doServiceNameProcessing();
+
+        // Port Name processing
+        doPortNameProcessing();
+
+        // PortType Name processing
+        //doPortTypeNameProcessing();
+
+        // setting a default binding
+        if (binding == null) {
+            String bindingId = RuntimeModeler.getBindingId(getImplementorClass());
+            setBinding(new SOAPBindingImpl(SOAPBinding.SOAP11HTTP_BINDING));
+        }
+
+        if (isProviderEndpoint()) {
+            checkProvider();
+            createProviderModel();
+        } else {
+            // Create runtime model for non Provider endpoints
+            createSEIModel();
+            if (getServiceName() == null) {
+                setServiceName(runtimeModel.getServiceQName());
+            }
+            if (getPortName() == null) {
+                setPortName(runtimeModel.getPortName());
+            }
+            //set mtom processing
+            if(binding instanceof SOAPBindingImpl){
+                runtimeModel.enableMtom(((SOAPBinding)binding).isMTOMEnabled());
+            }
+        }
+        // Process @HandlerChain, if handler-chain is not set via Deployment
+        // Descriptor
+        if (getBinding().getHandlerChain() == null) {
+                String bindingId = ((BindingImpl) binding).getActualBindingId();
+                HandlerAnnotationInfo chainInfo =
+                    HandlerAnnotationProcessor.buildHandlerInfo(
+                    implementorClass, getServiceName(),
+                    getPortName(), bindingId);
+                if (chainInfo != null) {
+                    getBinding().setHandlerChain(chainInfo.getHandlers());
+                    if (getBinding() instanceof SOAPBinding) {
+                        ((SOAPBinding) getBinding()).setRoles(
+                            chainInfo.getRoles());
+                    }
+                }
+        }
+        deployed = true;
+    }
+
+    public boolean needWSDLGeneration() {
+        if (isProviderEndpoint()) {
+            return false;
+        }
+        return (getWsdlUrl() == null);
+    }
+
+    /*
+     * Generates the WSDL and XML Schema for the endpoint if necessary
+     * It generates WSDL only for SOAP1.1, and for XSOAP1.2 bindings
+     */
+    public void generateWSDL() {
+        BindingImpl bindingImpl = (BindingImpl)getBinding();
+        String bindingId = bindingImpl.getActualBindingId();
+        if (!bindingId.equals(SOAPBinding.SOAP11HTTP_BINDING) &&
+            !bindingId.equals(SOAPBinding.SOAP11HTTP_MTOM_BINDING) &&
+            !bindingId.equals(SOAPBindingImpl.X_SOAP12HTTP_BINDING)) {
+            throw new ServerRtException("can.not.generate.wsdl", bindingId);
+        }
+
+        if (bindingId.equals(SOAPBindingImpl.X_SOAP12HTTP_BINDING)) {
+            String msg = localizer.localize(
+                messageFactory.getMessage("generate.non.standard.wsdl"));
+            logger.warning(msg);
+        }
+
+        // Generate WSDL and schema documents using runtime model
+        if (getDocMetadata() == null) {
+            setMetadata(new HashMap<String, DocInfo>());
+        }
+        WSDLGenResolver wsdlResolver = new WSDLGenResolver(getDocMetadata());
+        WSDLGenerator wsdlGen = new WSDLGenerator(runtimeModel, wsdlResolver,
+                ((BindingImpl)binding).getBindingId());
+        try {
+            wsdlGen.doGeneration();
+        } catch(Exception e) {
+            throw new ServerRtException("server.rt.err",e);
+        }
+        setWSDLFileName(wsdlResolver.getWSDLFile());
+    }
+
+    /*
+     * Provider endpoint validation
+     */
+    private void checkProvider() {
+        if (!Provider.class.isAssignableFrom(getImplementorClass())) {
+            throw new ServerRtException("not.implement.provider",
+                new Object[] {getImplementorClass()});
+        }
+    }
+
+    public QName getPortName() {
+        return portName;
+    }
+
+    public void setPortName(QName n) {
+        portName = n;
+    }
+
+    public QName getPortTypeName() {
+        return portTypeName;
+    }
+
+    public void setPortTypeName(QName n) {
+        portTypeName = n;
+    }
+
+    public QName getServiceName() {
+        return serviceName;
+    }
+
+    public void setServiceName(QName n) {
+        serviceName = n;
+    }
+
+    public String getUrlPattern() {
+        return urlPattern;
+    }
+
+    public String getUrlPatternWithoutStar() {
+        if (urlPattern.endsWith("/*")) {
+            return urlPattern.substring(0, urlPattern.length() - 2);
+        } else {
+            return urlPattern;
+        }
+    }
+
+
+    public void setUrlPattern(String s) {
+        urlPattern = s;
+    }
+
+    public void setBinding(Binding binding){
+        this.binding = binding;
+    }
+
+    public Binding getBinding() {
+        return binding;
+    }
+
+    public java.util.List<Source> getMetadata() {
+        return metadata;
+    }
+
+    public void setMetadata(java.util.List<Source> metadata) {
+
+        this.metadata = metadata;
+    }
+
+    public RuntimeModel getRuntimeModel() {
+        return runtimeModel;
+    }
+
+    public Object getImplementor() {
+        return implementor;
+    }
+
+    public void setImplementor(Object implementor) {
+        this.implementor = implementor;
+    }
+
+    public Class getImplementorClass() {
+        if (implementorClass == null) {
+            implementorClass = implementor.getClass();
+        }
+        return implementorClass;
+    }
+
+    public void setImplementorClass(Class implementorClass) {
+        this.implementorClass = implementorClass;
+    }
+
+    public void setMetadata(Map<String, DocInfo> docs) {
+        this.docs = docs;
+    }
+
+    private void updateQuery2DocInfo() {
+        // update (wsdl, xsd=1 )-->DocInfo map
+        if (query2Doc != null) {
+            query2Doc.clear();
+        } else {
+            query2Doc = new HashMap<String, DocInfo>();
+        }
+        Set<Map.Entry<String, DocInfo>> entries = docs.entrySet();
+        for(Map.Entry<String, DocInfo> entry : entries) {
+            DocInfo docInfo = entry.getValue();
+            // Check to handle ?WSDL
+            if (docInfo.getQueryString().equals("wsdl")) {
+                query2Doc.put("WSDL", docInfo);
+            }
+            query2Doc.put(docInfo.getQueryString(), docInfo);
+        }
+    }
+
+    public WebServiceContext getWebServiceContext() {
+        return wsContext;
+    }
+
+    public void setWebServiceContext(WebServiceContext wsContext) {
+        this.wsContext = wsContext;
+    }
+
+
+    /*
+     * key - /WEB-INF/wsdl/xxx.wsdl
+     */
+    public Map<String, DocInfo> getDocMetadata() {
+        return docs;
+    }
+
+    /*
+     * path - /WEB-INF/wsdl/xxx.wsdl
+     * return - xsd=a | wsdl | wsdl=b etc
+     */
+    public String getQueryString(URL url) {
+        Set<Entry<String, DocInfo>> entries = getDocMetadata().entrySet();
+        for(Entry<String, DocInfo> entry : entries) {
+            // URLs are not matching. servlet container bug ?
+            if (entry.getValue().getUrl().toString().equals(url.toString())) {
+                return entry.getValue().getQueryString();
+            }
+        }
+        return null;
+    }
+
+    /*
+     * queryString - xsd=a | wsdl | wsdl=b etc
+     * return - /WEB-INF/wsdl/xxx.wsdl
+     */
+    public String getPath(String queryString) {
+        if (query2Doc != null) {
+            DocInfo docInfo = query2Doc.get(queryString);
+            return (docInfo == null) ? null : docInfo.getUrl().toString();
+        }
+        return null;
+    }
+
+    /*
+     * Injects the WebServiceContext. Called from Servlet.init(), or
+     * Endpoint.publish(). Used synchronized because multiple servlet
+     * instances may call this in their init()
+     */
+    public synchronized void injectContext()
+    throws IllegalAccessException, InvocationTargetException {
+        if (injectedContext) {
+            return;
+        }
+        try {
+            doFieldsInjection();
+            doMethodsInjection();
+        } finally {
+            injectedContext = true;
+        }
+    }
+
+    private void doFieldsInjection() {
+        Class c = getImplementorClass();
+        Field[] fields = c.getDeclaredFields();
+        for(final Field field: fields) {
+            Resource resource = field.getAnnotation(Resource.class);
+            if (resource != null) {
+                Class resourceType = resource.type();
+                Class fieldType = field.getType();
+                if (resourceType.equals(Object.class)) {
+                    if (fieldType.equals(javax.xml.ws.WebServiceContext.class)) {
+                        injectField(field);
+                    }
+                } else if (resourceType.equals(javax.xml.ws.WebServiceContext.class)) {
+                    if (fieldType.isAssignableFrom(javax.xml.ws.WebServiceContext.class)) {
+                        injectField(field);
+                    } else {
+                        throw new ServerRtException("wrong.field.type",
+                            field.getName());
+                    }
+                }
+            }
+        }
+    }
+
+    private void doMethodsInjection() {
+        Class c = getImplementorClass();
+        Method[] methods = c.getDeclaredMethods();
+        for(final Method method : methods) {
+            Resource resource = method.getAnnotation(Resource.class);
+            if (resource != null) {
+                Class[] paramTypes = method.getParameterTypes();
+                if (paramTypes.length != 1) {
+                    throw new ServerRtException("wrong.no.parameters",
+                        method.getName());
+                }
+                Class resourceType = resource.type();
+                Class argType = paramTypes[0];
+                if (resourceType.equals(Object.class)
+                    && argType.equals(javax.xml.ws.WebServiceContext.class)) {
+                    invokeMethod(method, new Object[] { wsContext });
+                } else if (resourceType.equals(javax.xml.ws.WebServiceContext.class)) {
+                    if (argType.isAssignableFrom(javax.xml.ws.WebServiceContext.class)) {
+                        invokeMethod(method, new Object[] { wsContext });
+                    } else {
+                        throw new ServerRtException("wrong.parameter.type",
+                            method.getName());
+                    }
+                }
+            }
+        }
+    }
+
+    /*
+     * injects a resource into a Field
+     */
+    private void injectField(final Field field) {
+        try {
+            AccessController.doPrivileged(new PrivilegedExceptionAction() {
+                public Object run() throws IllegalAccessException,
+                    InvocationTargetException {
+                    if (!field.isAccessible()) {
+                        field.setAccessible(true);
+                    }
+                    field.set(implementor, wsContext);
+                    return null;
+                }
+            });
+        } catch(PrivilegedActionException e) {
+            throw new ServerRtException("server.rt.err",e.getException());
+        }
+    }
+
+    /*
+     * Helper method to invoke a Method
+     */
+    private void invokeMethod(final Method method, final Object[] args) {
+        try {
+            AccessController.doPrivileged(new PrivilegedExceptionAction() {
+                public Object run() throws IllegalAccessException,
+                InvocationTargetException {
+                    if (!method.isAccessible()) {
+                        method.setAccessible(true);
+                    }
+                    method.invoke(implementor, args);
+                    return null;
+                }
+            });
+        } catch(PrivilegedActionException e) {
+            throw new ServerRtException("server.rt.err",e.getException());
+        }
+    }
+
+    /*
+     * Calls the first method in the implementor object that has @BeginService
+     * annotation. Servlet.init(), or Endpoint.publish() may call this. Used
+     * synchronized because multiple servlet instances may call this in their
+     * init()
+     */
+    public synchronized void beginService() {
+        if (beginServiceDone) {
+            return;                 // Already called for this endpoint object
+        }
+        try {
+            invokeOnceMethod(PostConstruct.class);
+        } finally {
+            beginServiceDone = true;
+        }
+    }
+
+    /*
+     * Calls the first method in the implementor object that has @EndService
+     * annotation. Servlet.destory(), or Endpoint.stop() may call this. Used
+     * synchronized because multiple servlet instances may call this in their
+     * destroy()
+     */
+    public synchronized void endService() {
+        if (endServiceDone) {
+            return;                 // Already called for this endpoint object
+        }
+        try {
+            invokeOnceMethod(PreDestroy.class);
+            destroy();
+        } finally {
+            endServiceDone = true;
+        }
+    }
+
+    /*
+     * Helper method to invoke methods which don't take any arguments
+     * Also the annType annotation should be set only on one method
+     */
+    private void invokeOnceMethod(Class annType) {
+        Class c = getImplementorClass();
+        Method[] methods = c.getDeclaredMethods();
+        boolean once = false;
+        for(final Method method : methods) {
+            if (method.getAnnotation(annType) != null) {
+                if (once) {
+                    // Err: Multiple methods have annType annotation
+                    throw new ServerRtException("annotation.only.once",
+                        new Object[] { annType } );
+                }
+                if (method.getParameterTypes().length != 0) {
+                    throw new ServerRtException("not.zero.parameters",
+                        method.getName());
+                }
+                invokeMethod(method, new Object[]{ });
+                once = true;
+            }
+        }
+    }
+
+    /*
+     * Called when the container calls endService(). Used for any
+     * cleanup. Currently calls @PreDestroy method on existing
+     * handlers. This should not throw an exception, but we ignore
+     * it if it happens and continue with the next handler.
+     */
+    public void destroy() {
+        Binding binding = getBinding();
+        if (binding != null) {
+            List<Handler> handlers = binding.getHandlerChain();
+            if (handlers != null) {
+                for (Handler handler : handlers) {
+                    for (Method method : handler.getClass().getMethods()) {
+                        if (method.getAnnotation(PreDestroy.class) == null) {
+                            continue;
+                        }
+                        try {
+                            method.invoke(handler, new Object [0]);
+                        } catch (Exception e) {
+                            logger.warning("exception ignored from handler " +
+                                "@PreDestroy method: " +
+                                e.getMessage());
+                        }
+                        break;
+                    }
+                }
+            }
+        }
+    }
+
+    /**
+     * @return returns null if no motm-threshold-value is specified in the descriptor
+     */
+
+    public Integer getMtomThreshold() {
+        return mtomThreshold;
+    }
+
+    public void setMtomThreshold(int mtomThreshold) {
+        this.mtomThreshold = mtomThreshold;
+    }
+
+    // Fill DocInfo with document info : WSDL or Schema, targetNS etc.
+    public static void fillDocInfo(RuntimeEndpointInfo endpointInfo)
+    throws XMLStreamException {
+        Map<String, DocInfo> metadata = endpointInfo.getDocMetadata();
+        if (metadata != null) {
+            for(Entry<String, DocInfo> entry: metadata.entrySet()) {
+                RuntimeWSDLParser.fillDocInfo(entry.getValue(),
+                    endpointInfo.getServiceName(),
+                    endpointInfo.getPortTypeName());
+            }
+        }
+    }
+
+    public static void publishWSDLDocs(RuntimeEndpointInfo endpointInfo) {
+        // Set queryString for the documents
+        Map<String, DocInfo> docs = endpointInfo.getDocMetadata();
+        if (docs == null) {
+            return;
+        }
+        Set<Entry<String, DocInfo>> entries = docs.entrySet();
+        List<String> wsdlSystemIds = new ArrayList<String>();
+        List<String> schemaSystemIds = new ArrayList<String>();
+        for(Entry<String, DocInfo> entry : entries) {
+            DocInfo docInfo = (DocInfo)entry.getValue();
+            DOC_TYPE docType = docInfo.getDocType();
+            String query = docInfo.getQueryString();
+            if (query == null && docType != null) {
+                switch(docType) {
+                    case WSDL :
+                        wsdlSystemIds.add(entry.getKey());
+                        break;
+                    case SCHEMA :
+                        schemaSystemIds.add(entry.getKey());
+                        break;
+                    case OTHER :
+                        //(docInfo.getUrl()+" is not a WSDL or Schema file.");
+                }
+            }
+        }
+
+        Collections.sort(wsdlSystemIds);
+        int wsdlnum = 1;
+        for(String wsdlSystemId : wsdlSystemIds) {
+            DocInfo docInfo = docs.get(wsdlSystemId);
+            docInfo.setQueryString("wsdl="+(wsdlnum++));
+        }
+        Collections.sort(schemaSystemIds);
+        int xsdnum = 1;
+        for(String schemaSystemId : schemaSystemIds) {
+            DocInfo docInfo = docs.get(schemaSystemId);
+            docInfo.setQueryString("xsd="+(xsdnum++));
+        }
+        endpointInfo.updateQuery2DocInfo();
+    }
+
+    public void verifyImplementorClass() {
+        if (wsProvider == null) {
+            wsProvider = (WebServiceProvider)implementorClass.getAnnotation(
+                    WebServiceProvider.class);
+        }
+        if (ws == null) {
+            ws = (WebService)implementorClass.getAnnotation(WebService.class);
+        }
+        if (wsProvider == null && ws == null) {
+            throw new ServerRtException("no.ws.annotation", implementorClass);
+
+        }
+        if (wsProvider != null && ws != null) {
+            throw new ServerRtException("both.ws.annotations", implementorClass);
+        }
+    }
+
+    public String getWsdlLocation() {
+        if (wsProvider != null && wsProvider.wsdlLocation().length() > 0) {
+            return wsProvider.wsdlLocation();
+        } else if (ws != null && ws.wsdlLocation().length() > 0) {
+            return ws.wsdlLocation();
+        }
+        return null;
+    }
+
+    public ProviderModel getProviderModel() {
+        return providerModel;
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/ServerPropertyConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/ServerPropertyConstants.java
new file mode 100644
index 0000000..faf011b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/ServerPropertyConstants.java
@@ -0,0 +1,40 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server;
+
+/**
+ * @author Vivek Pandey
+ *
+ * Defines server side constants
+ *
+ */
+public interface ServerPropertyConstants {
+    /*public static final String ATTACHMENT_CONTEXT =
+        "com.sun.xml.internal.ws.attachment.AttachmentContext";*/
+    public static final String SET_ATTACHMENT_PROPERTY =
+        "com.sun.xml.internal.ws.attachment.SetAttachmentContext";
+    public static final String GET_ATTACHMENT_PROPERTY =
+        "com.sun.xml.internal.ws.attachment.GetAttachmentContext";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/ServerRtException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/ServerRtException.java
new file mode 100644
index 0000000..9552210
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/ServerRtException.java
@@ -0,0 +1,54 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.server;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ */
+public class ServerRtException extends JAXWSExceptionBase {
+
+    public ServerRtException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public ServerRtException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public ServerRtException(Localizable arg) {
+        super("server.rt.err", arg);
+    }
+
+    /* (non-Javadoc)
+     * @see JAXWSExceptionBase#getResourceBundleName()
+     */
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.server";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/TargetFinderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/TargetFinderImpl.java
new file mode 100644
index 0000000..bc6b577
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/TargetFinderImpl.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+//
+// Created       : 2004 Apr 09 (Fri) 06:16:58 by Harold Carr.
+// Last Modified : 2004 May 03 (Mon) 17:28:38 by Harold Carr.
+//
+
+package com.sun.xml.internal.ws.server;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.TargetFinder;
+import com.sun.xml.internal.ws.pept.presentation.Tie;
+
+public class TargetFinderImpl implements TargetFinder {
+
+    private Tie tie;
+
+    public TargetFinderImpl(Tie tie) {
+        this.tie = tie;
+    }
+
+    public Tie findTarget(MessageInfo messageInfo) {
+        return tie;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/Tie.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/Tie.java
new file mode 100644
index 0000000..1357397
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/Tie.java
@@ -0,0 +1,110 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.server;
+
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.ws.handler.MessageContext.Scope;
+import com.sun.xml.internal.ws.pept.Delegate;
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.encoding.soap.internal.DelegateBase;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+import com.sun.xml.internal.ws.developer.JAXWSProperties;
+
+/**
+ * Entry point for all server requests.
+ *
+ * @author WS Development Team
+ */
+public class Tie implements com.sun.xml.internal.ws.spi.runtime.Tie {
+
+    /**
+     * Common entry point for server runtime. <br>
+     * Creates a MessageInfo for every Request/Response.<br>
+     * Creates a RuntimeContext for every Request/Response and sets that as a metadata in
+     * MessageInfo. Doesn't create any other metadata on MessageInfo. If anything is needed,
+     * that can be created on RuntimeContext<br>
+     * EPTFactoryFactoryBase is used to select a correct EPTFactory<br>
+     * Calls MessageDispatcher.receive(MessageInfo). <br>
+     * MessageDispatcher orchestrates all the flow: reading from WSConnection,
+     * decodes message to parameters, invoking implementor, encodes parameters to message,
+     * and writing to WSConnection
+     *
+     * @param connection encapsulates multiple transports
+     * @param endpoint has all the information about target endpoint
+     * @throws Exception throws Exception if any error occurs
+     */
+    public void handle(WSConnection connection,
+        com.sun.xml.internal.ws.spi.runtime.RuntimeEndpointInfo endpoint)
+    throws Exception {
+
+        // Create MessageInfo. MessageInfo holds all the info for this request
+        Delegate delegate = new DelegateBase();
+        MessageInfo messageInfo = (MessageInfo)delegate.getMessageStruct();
+
+        // Create runtime context, runtime model for dynamic runtime
+        RuntimeEndpointInfo endpointInfo = (RuntimeEndpointInfo)endpoint;
+        RuntimeModel runtimeModel = endpointInfo.getRuntimeModel();
+        RuntimeContext runtimeContext = new RuntimeContext(runtimeModel);
+        runtimeContext.setRuntimeEndpointInfo(endpointInfo);
+
+        // Update MessageContext
+        MessageContext msgCtxt =
+            endpointInfo.getWebServiceContext().getMessageContext();
+        updateMessageContext(endpointInfo, msgCtxt);
+
+        // Set runtime context on MessageInfo
+        MessageInfoUtil.setRuntimeContext(messageInfo, runtimeContext);
+        messageInfo.setConnection(connection);
+
+        // Select EPTFactory based on binding, and transport
+        EPTFactory eptFactory = EPTFactoryFactoryBase.getEPTFactory(messageInfo);
+        messageInfo.setEPTFactory(eptFactory);
+
+        // MessageDispatcher archestrates the flow
+        MessageDispatcher messageDispatcher =
+            messageInfo.getEPTFactory().getMessageDispatcher(messageInfo);
+        messageDispatcher.receive(messageInfo);
+    }
+
+    /**
+     * Updates MessageContext object with Service, and Port QNames
+     */
+    private void updateMessageContext( RuntimeEndpointInfo endpoint,
+        MessageContext ctxt) {
+
+        ctxt.put(MessageContext.WSDL_SERVICE, endpoint.getServiceName());
+        ctxt.setScope(MessageContext.WSDL_SERVICE, Scope.APPLICATION);
+        ctxt.put(MessageContext.WSDL_PORT, endpoint.getPortName());
+        ctxt.setScope(MessageContext.WSDL_PORT, Scope.APPLICATION);
+        ctxt.put(JAXWSProperties.MTOM_THRESHOLOD_VALUE, endpoint.getMtomThreshold());
+        ctxt.setScope(JAXWSProperties.MTOM_THRESHOLOD_VALUE, Scope.APPLICATION);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/WSDLGenResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/WSDLGenResolver.java
new file mode 100644
index 0000000..4992bff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/WSDLGenResolver.java
@@ -0,0 +1,254 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.server;
+
+import com.sun.xml.internal.ws.server.DocInfo.DOC_TYPE;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+import com.sun.xml.internal.ws.wsdl.parser.Service;
+import com.sun.xml.internal.ws.wsdl.writer.WSDLOutputResolver;
+
+import javax.xml.transform.Result;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.ws.Holder;
+import java.io.InputStream;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.Set;
+
+/**
+ * @author WS Development Team
+ */
+
+public class WSDLGenResolver implements WSDLOutputResolver {
+
+    private Map<String, DocInfo> docs;
+    private DocInfo abstractWsdl;
+    private DocInfo concreteWsdl;
+    private Map<String, List<String>> nsMapping;    // targetNS -> system id list
+
+    public WSDLGenResolver(Map<String, DocInfo> docs) {
+        this.docs = docs;
+        nsMapping = new HashMap<String, List<String>>();
+        Set<Entry<String, DocInfo>> docEntries = docs.entrySet();
+        for(Entry<String, DocInfo> entry : docEntries) {
+            DocInfo docInfo = entry.getValue();
+            if (docInfo.isHavingPortType()) {
+                abstractWsdl = docInfo;
+            }
+            if (docInfo.getDocType() == DOC_TYPE.SCHEMA) {
+                List<String> sysIds = nsMapping.get(docInfo.getTargetNamespace());
+                if (sysIds == null) {
+                    sysIds = new ArrayList<String>();
+                    nsMapping.put(docInfo.getTargetNamespace(), sysIds);
+                }
+                sysIds.add(docInfo.getUrl().toString());
+            }
+        }
+    }
+
+    public String getWSDLFile() {
+        return concreteWsdl.getUrl().toString();
+    }
+
+    public Map<String, DocInfo> getDocs() {
+        return docs;
+    }
+
+    /*
+    public Result getWSDLOutput(String suggestedFileName) {
+        ByteArrayOutputStream bout = new ByteArrayOutputStream();
+
+        StreamDocInfo docInfo = new StreamDocInfo(suggestedFileName, bout);
+
+        if (wsdlFile == null) {
+            docInfo.setQueryString("wsdl");
+            wsdlFile = suggestedFileName;
+        } else {
+            docInfo.setQueryString("wsdl="+suggestedFileName);
+        }
+        docs.put(docInfo.getPath(),  docInfo);
+
+        StreamResult result = new StreamResult();
+        result.setOutputStream(bout);
+        result.setSystemId(suggestedFileName);
+        return result;
+    }
+     */
+
+    public Result getSchemaOutput(String namespaceUri, String suggestedFileName) {
+        ByteArrayBuffer bout = new ByteArrayBuffer();
+
+        StreamDocInfo docInfo = new StreamDocInfo(suggestedFileName, bout);
+        docInfo.setQueryString("xsd="+suggestedFileName);
+        docInfo.setDocType(DOC_TYPE.SCHEMA);
+        docs.put(docInfo.getUrl().toString(),  docInfo);
+
+        StreamResult result = new StreamResult();
+        result.setOutputStream(bout);
+        result.setSystemId(docInfo.getUrl().toString());
+        return result;
+    }
+
+    /*
+     * return null if concrete WSDL need not be generated
+     */
+    public Result getWSDLOutput(String filename) {
+        ByteArrayBuffer bout = new ByteArrayBuffer();
+        StreamDocInfo docInfo = new StreamDocInfo(filename, bout);
+        docInfo.setDocType(DOC_TYPE.WSDL);
+        docInfo.setQueryString("wsdl");
+        concreteWsdl = docInfo;
+        docs.put(docInfo.getUrl().toString(),  docInfo);
+        StreamResult result = new StreamResult();
+        result.setOutputStream(bout);
+        result.setSystemId(docInfo.getUrl().toString());
+        return result;
+    }
+
+    /*
+     * Updates filename if the suggested filename need to be changed in
+     * wsdl:import
+     *
+     * return null if abstract WSDL need not be generated
+     */
+    public Result getAbstractWSDLOutput(Holder<String> filename) {
+        if (abstractWsdl != null) {
+            filename.value = abstractWsdl.getUrl().toString();
+            return null;                // Don't generate abstract WSDL
+        }
+        ByteArrayBuffer bout = new ByteArrayBuffer();
+        StreamDocInfo abstractWsdl = new StreamDocInfo(filename.value, bout);
+        abstractWsdl.setDocType(DOC_TYPE.WSDL);
+        //abstractWsdl.setQueryString("wsdl="+filename.value);
+        docs.put(abstractWsdl.getUrl().toString(),  abstractWsdl);
+        StreamResult result = new StreamResult();
+        result.setOutputStream(bout);
+        result.setSystemId(abstractWsdl.getUrl().toString());
+        return result;
+    }
+
+    /*
+     * Updates filename if the suggested filename need to be changed in
+     * xsd:import
+     *
+     * return null if schema need not be generated
+     */
+    public Result getSchemaOutput(String namespace, Holder<String> filename) {
+        List<String> schemas = nsMapping.get(namespace);
+        if (schemas != null) {
+            if (schemas.size() > 1) {
+                throw new ServerRtException("server.rt.err",
+                    "More than one schema for the target namespace "+namespace);
+            }
+            filename.value = schemas.get(0);
+            return null;            // Don't generate schema
+        }
+        ByteArrayBuffer bout = new ByteArrayBuffer();
+        StreamDocInfo docInfo = new StreamDocInfo(filename.value, bout);
+        docInfo.setDocType(DOC_TYPE.SCHEMA);
+        //docInfo.setQueryString("xsd="+filename.value);
+        docs.put(docInfo.getUrl().toString(),  docInfo);
+        StreamResult result = new StreamResult();
+        result.setOutputStream(bout);
+        result.setSystemId(docInfo.getUrl().toString());
+        return result;
+    }
+
+    private static class StreamDocInfo implements DocInfo {
+        private ByteArrayBuffer bout;
+        private String resource;
+        private String queryString;
+                private DOC_TYPE docType;
+
+        public StreamDocInfo(String resource, ByteArrayBuffer bout) {
+            this.resource = resource;
+            this.bout = bout;
+        }
+
+        public InputStream getDoc() {
+            bout.close();
+            return bout.newInputStream();
+        }
+
+        public String getPath() {
+            return resource;
+        }
+
+        public URL getUrl() {
+            try {
+                return new URL("file:///"+resource);
+            } catch(Exception e) {
+
+            }
+            return null;
+        }
+
+        public String getQueryString() {
+            return queryString;
+        }
+
+        public void setQueryString(String queryString) {
+            this.queryString = queryString;
+        }
+
+        public void setDocType(DOC_TYPE docType) {
+                        this.docType = docType;
+        }
+
+        public DOC_TYPE getDocType() {
+            return docType;
+        }
+
+        public void setTargetNamespace(String ns) {
+
+        }
+
+        public String getTargetNamespace() {
+            return null;
+        }
+
+        public void setService(Service service) {
+
+        }
+
+        public Service getService() {
+            return null;
+        }
+
+        public void setHavingPortType(boolean portType) {
+
+        }
+
+        public boolean isHavingPortType() {
+            return false;
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/WSDLPatcher.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/WSDLPatcher.java
new file mode 100644
index 0000000..10d6b3e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/WSDLPatcher.java
@@ -0,0 +1,303 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.server;
+import com.sun.xml.internal.ws.wsdl.parser.WSDLConstants;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.logging.Logger;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLEventFactory;
+import javax.xml.stream.XMLEventReader;
+import javax.xml.stream.XMLEventWriter;
+import javax.xml.stream.XMLInputFactory;
+import javax.xml.stream.XMLOutputFactory;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.events.Attribute;
+import javax.xml.stream.events.StartElement;
+import javax.xml.stream.events.StartDocument;
+import javax.xml.stream.events.XMLEvent;
+public class WSDLPatcher {
+
+    private static final String NS_XSD = "http://www.w3.org/2001/XMLSchema";
+    private static final QName QNAME_SCHEMA = new QName(NS_XSD, "schema");
+    private static final QName SCHEMA_INCLUDE_QNAME = new QName(NS_XSD, "include");
+    private static final QName SCHEMA_IMPORT_QNAME = new QName(NS_XSD, "import");
+    private static final QName ATTR_NAME_QNAME = new QName("", "name");
+    private static final QName ATTR_TARGETNS_QNAME =
+            new QName("", "targetNamespace");
+    private static final QName WSDL_LOCATION_QNAME = new QName("", "location");
+    private static final QName SCHEMA_LOCATION_QNAME =
+            new QName("", "schemaLocation");
+
+    private static final XMLEventFactory eventFactory =
+            XMLEventFactory.newInstance();
+    private static final XMLOutputFactory outputFactory =
+            XMLOutputFactory.newInstance();
+    private static final XMLInputFactory inputFactory =
+            XMLInputFactory.newInstance();
+
+    private static final Logger logger =
+        Logger.getLogger(
+            com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".wsdl.patcher");
+
+    private DocInfo docInfo;
+    private String baseAddress;
+    private RuntimeEndpointInfo targetEndpoint;
+    private List<RuntimeEndpointInfo> endpoints;
+
+    /*
+     * inPath - /WEB-INF/wsdl/xxx.wsdl
+     * baseAddress - http://host:port/context/
+     */
+    public WSDLPatcher(DocInfo docInfo, String baseAddress,
+            RuntimeEndpointInfo targetEndpoint,
+            List<RuntimeEndpointInfo> endpoints) {
+        this.docInfo = docInfo;
+        this.baseAddress = baseAddress;
+        this.targetEndpoint = targetEndpoint;
+        this.endpoints = endpoints;
+    }
+
+    /*
+     * import, include, soap:address locations are patched
+     * caller needs to take care of closing of the streams
+     */
+    public void patchDoc(InputStream in, OutputStream out) {
+        XMLEventReader reader = null;
+        XMLEventWriter writer = null;
+        try {
+            reader = inputFactory.createXMLEventReader(in);
+            StartElement start = null;
+            QName serviceName = null;
+            QName portName = null;
+            String targetNamespace = null;
+            while(reader.hasNext()) {
+                XMLEvent event = reader.nextEvent();
+                if (event.isStartDocument()) {
+                    StartDocument sd = (StartDocument)event;
+                    String encoding = sd.encodingSet()
+                        ? sd.getCharacterEncodingScheme()
+                        : null;
+                    writer = (encoding != null)
+                        ? outputFactory.createXMLEventWriter(out, encoding)
+                        : outputFactory.createXMLEventWriter(out);
+               } else if (event.isStartElement()) {
+                    start = event.asStartElement();
+                    QName name = start.getName();
+                    if (name.equals(SCHEMA_INCLUDE_QNAME)) {
+                        event = handleSchemaInclude(start);
+                    } else if (name.equals(SCHEMA_IMPORT_QNAME)) {
+                        event = handleSchemaImport(start);
+                    } else if (name.equals(WSDLConstants.QNAME_IMPORT)) {
+                        event = handleWSDLImport(start);
+                    } else if (name.equals(WSDLConstants.NS_SOAP_BINDING_ADDRESS) ||
+                            name.equals(WSDLConstants.NS_SOAP12_BINDING_ADDRESS)) {
+                        event = handleSoapAddress(serviceName, portName, start);
+                    } else if (name.equals(WSDLConstants.QNAME_DEFINITIONS)) {
+                        Attribute attr = start.getAttributeByName(ATTR_TARGETNS_QNAME);
+                        if (attr != null) {
+                            targetNamespace = attr.getValue();
+                        }
+                    } else if (name.equals(WSDLConstants.QNAME_SERVICE)) {
+                        Attribute attr = start.getAttributeByName(ATTR_NAME_QNAME);
+                        if (attr != null) {
+                            serviceName = new QName(targetNamespace, attr.getValue());
+                        }
+                    } else if (name.equals(WSDLConstants.QNAME_PORT)) {
+                        Attribute attr = start.getAttributeByName(ATTR_NAME_QNAME);
+                        if (attr != null) {
+                            portName = new QName(targetNamespace, attr.getValue());
+                        }
+                    }
+                } else if (event.isEndElement()) {
+                    start = null;
+                }
+                writer.add(event);
+            }
+        } catch (XMLStreamException e) {
+            throw new ServerRtException("runtime.wsdl.patcher",e);
+        } finally {
+            if (reader != null) {
+                try {
+                    reader.close();
+                } catch(XMLStreamException e) {
+                    e.printStackTrace();
+                }
+            }
+            if (writer != null) {
+                try {
+                    writer.close();
+                } catch(XMLStreamException e) {
+                    e.printStackTrace();
+                }
+            }
+        }
+    }
+
+    /*
+     * return patchedlocation  null if we don't how to patch this location
+     */
+    private String getPatchedImportLocation(String relPath) {
+        try {
+            URL relUrl = new URL(docInfo.getUrl(), relPath);
+            String query = targetEndpoint.getQueryString(relUrl);
+            if (query == null) {
+                return null;
+            }
+            String abs = baseAddress+targetEndpoint.getUrlPatternWithoutStar()+"?"+query;
+            return abs;
+        } catch(MalformedURLException mue) {
+            return null;
+        }
+    }
+
+    private XMLEvent patchImport(StartElement startElement, QName location)
+    throws XMLStreamException {
+        Attribute locationAttr = startElement.getAttributeByName(location);
+        if (locationAttr == null) {
+            return startElement;
+        }
+
+        List<Attribute> newAttrs = new ArrayList<Attribute>();
+        Iterator i = startElement.getAttributes();
+        while(i.hasNext()) {
+            Attribute attr = (Attribute)i.next();
+            String file = attr.getValue();
+            if (attr.getName().equals(location)) {
+                String relPath = attr.getValue();
+                //if (isPatchable(relPath)) {
+                    String absPath = getPatchedImportLocation(relPath);
+                    if (absPath == null) {
+                        //logger.warning("Couldn't fix the relative location:"+relPath);
+                        return startElement;        // Not patching
+                    }
+                    logger.fine("Fixing the relative location:"+relPath
+                            +" with absolute location:"+absPath);
+                    Attribute newAttr = eventFactory.createAttribute(
+                        location, absPath);
+                    newAttrs.add(newAttr);
+                    continue;
+                //}
+            }
+            newAttrs.add(attr);
+        }
+        XMLEvent event = eventFactory.createStartElement(
+                startElement.getName().getPrefix(),
+                startElement.getName().getNamespaceURI(),
+                startElement.getName().getLocalPart(),
+                newAttrs.iterator(),
+                startElement.getNamespaces(),
+                startElement.getNamespaceContext());
+        return event;
+    }
+
+    /*
+     * <schema:import> element is patched with correct uri and
+     * returns a new element
+     */
+    private XMLEvent handleSchemaImport(StartElement startElement)
+    throws XMLStreamException {
+        return patchImport(startElement, SCHEMA_LOCATION_QNAME);
+    }
+
+    /*
+     * <schema:include> element is patched with correct uri and
+     * returns a new element
+     */
+    private XMLEvent handleSchemaInclude(StartElement startElement)
+    throws XMLStreamException {
+        return patchImport(startElement, SCHEMA_LOCATION_QNAME);
+    }
+
+    /*
+     * <wsdl:import> element is patched with correct uri and
+     * returns a new element
+     */
+    private XMLEvent handleWSDLImport(StartElement startElement)
+    throws XMLStreamException {
+        return patchImport(startElement, WSDL_LOCATION_QNAME);
+    }
+
+    /*
+     * <soap:address> element is patched with correct endpoint address and
+     * returns a new element
+     */
+    private XMLEvent handleSoapAddress(QName service, QName port,
+            StartElement startElement) throws XMLStreamException {
+
+        List<Attribute> newAttrs = new ArrayList<Attribute>();
+        Iterator i = startElement.getAttributes();
+        while(i.hasNext()) {
+            Attribute attr = (Attribute)i.next();
+            String file = attr.getValue();
+            if (attr.getName().equals(WSDL_LOCATION_QNAME)) {
+                String value = getAddressLocation(service, port);
+                if (value == null) {
+                    return startElement;        // Not patching
+                }
+                logger.fine("Fixing service:"+service+ " port:"+port
+                        + " address with "+value);
+                Attribute newAttr = eventFactory.createAttribute(
+                        WSDL_LOCATION_QNAME, value);
+                newAttrs.add(newAttr);
+                continue;
+            }
+            newAttrs.add(attr);
+        }
+        XMLEvent event = eventFactory.createStartElement(
+                startElement.getName().getPrefix(),
+                startElement.getName().getNamespaceURI(),
+                startElement.getName().getLocalPart(),
+                newAttrs.iterator(),
+                startElement.getNamespaces(),
+                startElement.getNamespaceContext());
+        return event;
+    }
+
+    /*
+     * For the given service, port names it matches the correct endpoint and
+     * reutrns its endpoint address
+     */
+    private String getAddressLocation(QName docServiceName, QName docPortName) {
+        for(RuntimeEndpointInfo endpointInfo : endpoints) {
+            QName serviceName = endpointInfo.getServiceName();
+            QName portName = endpointInfo.getPortName();
+            if (serviceName != null && portName != null
+                    && docServiceName != null && docPortName != null
+                    && serviceName.equals(docServiceName)
+                    && docPortName.equals(portName)) {
+                return baseAddress+endpointInfo.getUrlPatternWithoutStar();
+            }
+        }
+        return null;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/XMLEPTFactoryImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/XMLEPTFactoryImpl.java
new file mode 100644
index 0000000..38c4a5a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/XMLEPTFactoryImpl.java
@@ -0,0 +1,115 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server;
+
+import com.sun.xml.internal.ws.pept.encoding.Decoder;
+import com.sun.xml.internal.ws.pept.encoding.Encoder;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.TargetFinder;
+import com.sun.xml.internal.ws.pept.protocol.Interceptors;
+import com.sun.xml.internal.ws.pept.protocol.MessageDispatcher;
+import com.sun.xml.internal.ws.encoding.internal.InternalEncoder;
+import com.sun.xml.internal.ws.encoding.xml.XMLDecoder;
+import com.sun.xml.internal.ws.encoding.xml.XMLEPTFactory;
+import com.sun.xml.internal.ws.encoding.xml.XMLEncoder;
+
+/**
+ * @author WS Development Team
+ */
+public class XMLEPTFactoryImpl implements XMLEPTFactory {
+    private Encoder encoder;
+    private Decoder decoder;
+    private XMLEncoder xmlEncoder;
+    private XMLDecoder xmlDecoder;
+    private InternalEncoder internalEncoder;
+    private TargetFinder targetFinder;
+    private MessageDispatcher messageDispatcher;
+
+    public XMLEPTFactoryImpl(Encoder encoder, Decoder decoder,
+            TargetFinder targetFinder, MessageDispatcher messageDispatcher) {
+        this.encoder = encoder;
+        this.decoder = decoder;
+        this.targetFinder = targetFinder;
+        this.messageDispatcher = messageDispatcher;
+    }
+
+    public XMLEPTFactoryImpl(XMLEncoder xmlEncoder, XMLDecoder xmlDecoder,
+                             InternalEncoder internalEncoder,
+                             TargetFinder targetFinder, MessageDispatcher messageDispatcher) {
+        this.xmlEncoder = xmlEncoder;
+        this.xmlDecoder = xmlDecoder;
+        this.encoder = null;
+        this.decoder = null;
+        this.internalEncoder = internalEncoder;
+        this.targetFinder = targetFinder;
+        this.messageDispatcher = messageDispatcher;
+    }
+
+    public Encoder getEncoder(MessageInfo messageInfo) {
+        messageInfo.setEncoder(encoder);
+        return messageInfo.getEncoder();
+    }
+
+    public Decoder getDecoder(MessageInfo messageInfo) {
+        messageInfo.setDecoder(decoder);
+        return messageInfo.getDecoder();
+    }
+
+    public TargetFinder getTargetFinder(MessageInfo messageInfo) {
+        return targetFinder;
+    }
+
+    public MessageDispatcher getMessageDispatcher(MessageInfo messageInfo) {
+        messageInfo.setMessageDispatcher(messageDispatcher);
+        return messageDispatcher;
+    }
+
+    /*
+     * @see com.sun.istack.internal.pept.ept.EPTFactory#getInterceptors(com.sun.istack.internal.pept.ept.MessageInfo)
+     */
+    public Interceptors getInterceptors(MessageInfo x) {
+        return null;
+    }
+
+    /*
+     * @see com.sun.xml.internal.ws.encoding.jaxb.LogicalEPTFactory#getSoapEncoder()
+     */
+    public XMLEncoder getXMLEncoder() {
+        return xmlEncoder;
+    }
+
+    /*
+     * @see com.sun.xml.internal.ws.encoding.jaxb.LogicalEPTFactory#getSoapDecoder()
+     */
+    public XMLDecoder getXMLDecoder() {
+        return xmlDecoder;
+    }
+
+    public InternalEncoder getInternalEncoder() {
+        return internalEncoder;
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/package-info.java
new file mode 100644
index 0000000..268ce3a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/package-info.java
@@ -0,0 +1,246 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ * <h1>JAX-WS 2.0 Server Runtime</h1>
+ * <P>This document describes the architecture of server side
+ * JAX-WS 2.0 runtime. </p>
+ *
+ * <h3>JAX-WS 2.0 Server Runtime Sequence Diagram</h3>
+ * {@SequenceDiagram
+      pobject(U,"user");
+      object(A,"WSConnection");
+      object(B,"Tie");
+      object(E,"MessageDispatcher");
+      object(F,"EPTFactoryFactoryBase");
+      object(G,"Endpoint");
+      step();
+
+      message(U,A,"invoke Web Service");
+      active(A);
+      message(A,A,"getRuntimeEndpointInfo");
+      active(A);
+      step();
+      inactive(A);
+
+      message(A,B,"handle");
+      active(B);
+#      inactive(A);
+
+      message(B,B,"createMessageInfo");
+      active(B);
+      step();
+      inactive(B);
+
+      message(B,B,"createRuntimeContext");
+      active(B);
+      step();
+      inactive(B);
+
+      message(B,F,"getEPTFactory");
+      active(F);
+      step();
+      inactive(F);
+
+      message(B,B,"getMessageDispatcher");
+      active(B);
+      step();
+      inactive(B);
+
+      message(B,E,"receive");
+      active(E);
+      inactive(B);
+#      complete(B);
+
+      message(E,E,"mustUnderstand");
+      active(E);
+      step();
+      inactive(E);
+
+      message(E,E,"createSOAPMessage");
+      active(E);
+      step();
+      inactive(E);
+
+      message(E,E,"invokeHandlers");
+      active(E);
+      step();
+      inactive(E);
+
+      message(E,E,"createInternalMessage");
+      active(E);
+      step();
+      inactive(E);
+
+      message(E,G,"invoke endpoint");
+      active(G);
+#      step();
+      rmessage(G,E,"response");
+#      complete(G);
+      inactive(G);
+
+      message(E,E,"createInternalMessage");
+      active(E);
+      step();
+      inactive(E);
+
+      message(E,E,"createSOAPMessage");
+      active(E);
+      step();
+      inactive(E);
+
+      message(E,E,"invokeHandlers");
+      active(E);
+      step();
+      inactive(E);
+
+#      active(A);
+      rmessage(E,A,"response");
+#      complete(E);
+#inactive(E);
+
+      active(A);
+#      complete(E);
+inactive(E);
+#      rmessage(A,U,"response");
+#      complete(E);
+#      complete(A);
+      complete(A);
+ * }
+ *
+ *
+ *
+ * <H3>Message Flow</H3>
+ * <P>A Web Service invocation starts with either the
+ * {@link com.sun.xml.internal.ws.transport.http.servlet.WSServletDelegate WSServletDelegate}
+ * or the {@link com.sun.xml.internal.ws.transport.http.server.ServerConnectionImpl ServerConnectionImpl}.
+ * Both of these classes find the appropriate {@link com.sun.xml.internal.ws.server.RuntimeEndpointInfo RuntimeEndpointInfo}
+ * and invokes the {@link com.sun.xml.internal.ws.server.Tie#handle(com.sun.xml.internal.ws.spi.runtime.WSConnection,
+ * com.sun.xml.internal.ws.spi.runtime.RuntimeEndpointInfo) Tie.handle}
+ * method. This method first creates a {@link com.sun.pept.ept.MessageInfo MessageInfo}
+ * used to gather inforrmation about the message to be received. A
+ * {@link com.sun.xml.internal.ws.server.RuntimeContext RuntimeContext}
+ * is then created with the MessageInfo and the {@link com.sun.xml.internal.ws.model.RuntimeModel RuntimeModel}
+ * retrieved from the RuntimeEndpointInfo. The RuntimeContext is then
+ * stored in the MessageInfo. The {@link com.sun.pept.ept.EPTFactory EPTFactory}
+ * is retrieved from the {@link com.sun.xml.internal.ws.server.EPTFactoryFactoryBase EPTFactoryFactoryBase}
+ * and also placed in the MessagInfo. A {@link com.sun.pept.protocol.MessageDispatcher MessageDispatcher}
+ * is then created and the receive method is invoked. There will be two
+ * types of MessageDispatchers for JAX-WS 2.0 FCS, SOAPMessageDispatcher
+ * (one for client and one for the server) and an XMLMessageDispatcher
+ * (one for the client and one for the server).</P>
+ * <P>The MessageDispatcher.receive method orchestrates the receiving of
+ * a Message. The SOAPMessageDispatcher first converts the MessageInfo
+ * to a SOAPMessage. The SOAPMessageDispatcher then does mustUnderstand
+ * processing followed by an invocation of any handlers. The SOAPMessage
+ * is then converted to an InternalMessage and stored in the
+ * MessageInfo. The converting of the SOAPMessage to an InternalMessage
+ * is done using the decoder retrieved from the EPTFactory that is
+ * contained in the MessageInfo. Once the SOAPMessage has been converted
+ * to an InternalMessage the endpoint implementation is invoked via
+ * reflection from the Method stored in the MessageInfo. The return
+ * value of the method call is then stored in the InternalMessage. An
+ * internalMessage is then created from the MessageInfo. The SOAPEncoder
+ * is retrieved from the EPTFactory stored in the MessageInfo. The
+ * SOAPEncoder.toSOAPMessage is then invoked to create a SOAPMessage
+ * from the InternalMessage. A WSConnection is then retrieved from the
+ * MessageInfo and the SOAPMessage is returned over that WSConnection.</P>
+ * <P><BR>
+ * </P>
+ * <H3>External Interactions</H3>
+ * <H4>SAAJ API</H4>
+ * <UL>
+ *      <LI><P>JAX-WS creates SAAJ javax.xml.soap.SOAPMessage
+ *      from the HttpServletRequest.
+ *      At present, JAX-WS reads all the bytes from the request stream and
+ *      then creates SOAPMessage along with the HTTP headers.</P>
+ * </UL>
+ * <P>javax.xml.soap.MessageFactory(binding).createMessage(MimeHeaders, InputStream)</P>
+ * <UL>
+ *      <LI><P>SOAPMessage parses the content from the stream including MIME
+ *      data</P>
+ *      <LI><P>com.sun.xml.internal.ws.server.SOAPMessageDispatcher::checkHeadersPeekBody()</P>
+ *      <P>SOAPMessage.getSOAPHeader() is used for mustUnderstand processing
+ *      of headers. It further uses
+ *      javax.xml.soap.SOAPHeader.examineMustUnderstandHeaderElements(role)</P>
+ *      <P>SOAPMessage.getSOAPBody().getFistChild() is used for guessing the
+ *      MEP of the request</P>
+ *      <LI><P>com.sun.xml.internal.ws.handler.HandlerChainCaller:insertFaultMessage()</P>
+ *      <P>SOAPMessage.getSOAPPart().getEnvelope() and some other SAAJ calls
+ *      are made to create a fault in the SOAPMessage</P>
+ *      <LI><P>com.sun.xml.internal.ws.handler.LogicalMessageImpl::getPayload()
+ *      interacts with SAAJ to get body from SOAPMessage</P>
+ *      <LI><P>com.sun.xml.internal.ws.encoding.soap.SOAPEncoder.toSOAPMessage(com.sun.xml.internal.ws.encoding.soap.internal.InternalMessage,
+ *      SOAPMessage). There is a scenario where there is SOAPMessage and a
+ *      logical handler sets payload as Source. To write to the stream,
+ *      SOAPMessage.writeTo() is used but before that the body needs to be
+ *      updated with logical handler' Source. Need to verify if this
+ *      scenario is still happening since Handler.close() is changed to take
+ *      MessageContext.</P>
+ *      <LI><P>com.sun.xml.internal.ws.handlerSOAPMessageContextImpl.getHeaders()
+ *      uses SAAJ API to get headers.</P>
+ *      <LI><P>SOAPMessage.writeTo() is used to write response. At present,
+ *      it writes into byte[] and this byte[] is written to
+ *      HttpServletResponse.</P>
+ * </UL>
+ * <H4>JAXB API</H4>
+ * <P>JAX-WS RI uses the JAXB API to marshall/unmarshall user created
+ * JAXB objects with user created {@link javax.xml.bind.JAXBContext JAXBContext}.
+ * Handler, Dispatch in JAX-WS API provide ways for the user to specify his/her own
+ * JAXBContext. {@link com.sun.xml.internal.ws.encoding.jaxb.JAXBTypeSerializer JAXBTypeSerializer} class uses all these methods.</P>
+ * <UL>
+ *      <LI><p>{@link javax.xml.bind.Marshaller#marshal(Object,XMLStreamWriter) Marshaller.marshal(Object,XMLStreamWriter)}</p>
+ *      <LI><P>{@link javax.xml.bind.Marshaller#marshal(Object,Result) Marshaller.marshal(Object, DomResult)}</P>
+ *      <LI><P>{@link javax.xml.bind.Unmarshaller#unmarshal(XMLStreamReader) Object Unmarshaller.unmarshal(XMLStreamReader)}</P>
+ *      <LI><P>{@link javax.xml.bind.Unmarshaller#unmarshal(Source) Object Unmarshaller.unmarshal(Source)}</P>
+ * </UL>
+ * The following two JAXB classes are implemented by JAX-WS to enable/implement MTOM and XOP
+ * <UL>
+ *      <LI><P>{@link javax.xml.bind.attachment.AttachmentMarshaller AttachmentMarshaller}</P>
+ *      <LI><P>{@link javax.xml.bind.attachment.AttachmentUnmarshaller AttachmentUnmarshaller}</P>
+ * </UL>
+ * <H4>JAXB Runtime-API (private contract)</H4>
+ * <P>JAX-WS RI uses these private API for serialization/deserialization
+ * purposes. This private API is used to serialize/deserialize method
+ * parameters at the time of JAXBTypeSerializer class uses all
+ * these methods.</P>
+ * <UL>
+ *      <LI><P>{@link com.sun.xml.internal.bind.api.Bridge#marshal(BridgeContext, Object, XMLStreamWriter) Bridge.marshal(BridgeContext, Object, XMLStreamWriter)}</P>
+ *      <LI><P>{@link com.sun.xml.internal.bind.api.Bridge#marshal(BridgeContext, Object, Node) Bridge.marshal(BridgeContext, Object, Node)}</P>
+ *      <LI><P>{@link com.sun.xml.internal.bind.api.Bridge#unmarshal(BridgeContext, XMLStreamReader) Object Bridge.unmarshal(BridgeContext, XMLStreamReader)}</P>
+ * </UL>
+ *
+ * @ArchitectureDocument
+ **/
+package com.sun.xml.internal.ws.server;
+
+import com.sun.xml.internal.bind.api.BridgeContext;
+
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.Source;
+import javax.xml.transform.Result;
+
+import org.w3c.dom.Node;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/provider/ProviderModel.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/provider/ProviderModel.java
new file mode 100644
index 0000000..2a22578
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/provider/ProviderModel.java
@@ -0,0 +1,119 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server.provider;
+
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import java.lang.reflect.ParameterizedType;
+import javax.activation.DataSource;
+import javax.xml.ws.Binding;
+import javax.xml.ws.Provider;
+import com.sun.xml.internal.ws.server.PeptTie;
+import java.lang.reflect.Type;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.transform.Source;
+import javax.xml.ws.Service;
+import javax.xml.ws.ServiceMode;
+import javax.xml.ws.soap.SOAPBinding;
+
+
+/**
+ * Keeps the runtime information like Service.Mode and erasure of Provider class
+ * about Provider endpoint. It proccess annotations to find about Service.Mode
+ * It also finds about parameterized type(e.g. Source, SOAPMessage, DataSource)
+ * of endpoint class.
+ *
+ */
+public class ProviderModel {
+
+    private final boolean isSource;
+    private final Service.Mode mode;
+
+    public ProviderModel(Class implementorClass, Binding binding) {
+        assert implementorClass != null;
+        assert binding != null;
+
+        mode = getServiceMode(implementorClass);
+        Class otherClass = (binding instanceof SOAPBinding)
+            ? SOAPMessage.class : DataSource.class;
+        isSource = isSource(implementorClass, otherClass);
+        if (mode == Service.Mode.PAYLOAD && !isSource) {
+            // Illegal to have PAYLOAD && SOAPMessage
+            // Illegal to have PAYLOAD && DataSource
+            throw new IllegalArgumentException(
+                "Illeagal combination - Mode.PAYLOAD and Provider<"+otherClass.getName()+">");
+        }
+    }
+
+    public boolean isSource() {
+        return isSource;
+    }
+
+    public Service.Mode getServiceMode() {
+        return mode;
+    }
+
+    /**
+     * Is it PAYLOAD or MESSAGE ??
+     */
+    private static Service.Mode getServiceMode(Class c) {
+        ServiceMode mode = (ServiceMode)c.getAnnotation(ServiceMode.class);
+        if (mode == null) {
+            return Service.Mode.PAYLOAD;
+        }
+        return mode.value();
+    }
+
+    /**
+     * Is it Provider<Source> ? Finds whether the parameterized type is
+     * Source.class or not.
+     *
+     * @param c provider endpoint class
+     * @param otherClass Typically SOAPMessage.class or DataSource.class
+     * @return true if c's parameterized type is Source
+     *         false otherwise
+     * @throws IllegalArgumentException if it is not
+     *         Provider<Source> or Provider<otherClass>
+     *
+     */
+    private static boolean isSource(Class c, Class otherClass) {
+        Type base = JAXBRIContext.getBaseType(c, Provider.class);
+        assert base != null;
+        if (base instanceof ParameterizedType) {
+            ParameterizedType pt = (ParameterizedType)base;
+            Type[] types = pt.getActualTypeArguments();
+            if (types[0] instanceof Class && Source.class.isAssignableFrom((Class)types[0])) {
+                return true;
+            }
+            if (types[0] instanceof Class && otherClass.isAssignableFrom((Class)types[0])) {
+                return false;
+            }
+        }
+        throw new IllegalArgumentException(
+            "Endpoint should implement Provider<"+Source.class.getName()+
+                "> or Provider<"+otherClass.getName()+">");
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/server/provider/ProviderPeptTie.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/provider/ProviderPeptTie.java
new file mode 100644
index 0000000..c5d5de4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/server/provider/ProviderPeptTie.java
@@ -0,0 +1,86 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.server.provider;
+
+import java.lang.reflect.Method;
+import javax.xml.ws.Provider;
+import javax.xml.ws.WebServiceException;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import com.sun.xml.internal.ws.server.PeptTie;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.util.MessageInfoUtil;
+
+
+/**
+ * Creates a Stateless Tie object so that it is created only once and reused.
+ */
+public class ProviderPeptTie extends PeptTie {
+
+    private static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".server.ProviderPeptTie");
+
+    public static final Method invoke_Method;
+    static {
+        try {
+            Class[] methodParams = { Object.class };
+            invoke_Method = (Provider.class).getMethod("invoke", methodParams);
+        } catch (NoSuchMethodException e) {
+            throw new WebServiceException(e.getMessage(), e);
+        }
+    };
+
+    /*
+     * @see Tie#_invoke(MessageInfo)
+     */
+    public void _invoke(MessageInfo messageInfo) {
+        Object[] oa = messageInfo.getData();
+        RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(messageInfo);
+        RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+        Provider servant = (Provider)endpointInfo.getImplementor();
+        try {
+            Object response = servant.invoke(oa[0]);
+            messageInfo.setResponse(response);
+            messageInfo.setResponseType(MessageStruct.NORMAL_RESPONSE);
+            if (response == null) {
+                messageInfo.setMEP(MessageStruct.ONE_WAY_MEP);
+            } else {
+                messageInfo.setMEP(MessageStruct.REQUEST_RESPONSE_MEP);
+            }
+        } catch (RuntimeException e) {
+            logger.log(Level.SEVERE, e.getMessage(), e);
+            messageInfo.setResponseType(MessageStruct.UNCHECKED_EXCEPTION_RESPONSE);
+            messageInfo.setResponse(e);
+        } catch (Exception e) {
+            messageInfo.setResponseType(MessageStruct.CHECKED_EXCEPTION_RESPONSE);
+            messageInfo.setResponse(e);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/ProviderImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/ProviderImpl.java
new file mode 100644
index 0000000..2fd37f6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/ProviderImpl.java
@@ -0,0 +1,66 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi;
+
+
+import com.sun.xml.internal.ws.client.WSServiceDelegate;
+import com.sun.xml.internal.ws.transport.http.server.EndpointImpl;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.Endpoint;
+import javax.xml.ws.spi.Provider;
+import javax.xml.ws.spi.ServiceDelegate;
+import java.security.AccessController;
+import java.security.PrivilegedAction;
+
+/**
+ * @author WS Development Team
+ */
+public class ProviderImpl extends Provider {
+
+    @Override
+    public Endpoint createEndpoint(String bindingId, Object implementor) {
+        return new EndpointImpl(bindingId, implementor);
+    }
+
+    @Override
+    public ServiceDelegate createServiceDelegate(
+         java.net.URL wsdlDocumentLocation,
+         QName serviceName, Class serviceClass) {
+
+
+
+         return new WSServiceDelegate(wsdlDocumentLocation, serviceName, serviceClass);
+    }
+
+    @Override
+    public Endpoint createAndPublishEndpoint(String address,
+                                             Object implementor) {
+        Endpoint endpoint = new EndpointImpl(null, implementor);
+        endpoint.publish(address);
+        return endpoint;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Binding.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Binding.java
new file mode 100644
index 0000000..a13e2d0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Binding.java
@@ -0,0 +1,37 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.spi.runtime;
+
+/** The <code>Binding</code> is the spi interface that extends the base interface
+ *  for JAX-WS protocol bindings.
+ * This interface is implemented by com.sun.xml.internal.ws.client.Binding.
+**/
+public interface Binding extends javax.xml.ws.Binding {
+
+  public SystemHandlerDelegate getSystemHandlerDelegate();
+
+  public void setSystemHandlerDelegate(SystemHandlerDelegate delegate);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/ClientTransportFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/ClientTransportFactory.java
new file mode 100644
index 0000000..602d427
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/ClientTransportFactory.java
@@ -0,0 +1,35 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+import java.util.Map;
+
+/**
+ * This class is implemented by
+ * com.sun.xml.internal.ws.client.ClientTransportFactory
+ */
+public interface ClientTransportFactory {
+    public WSConnection create(Map<String, Object> context);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/ClientTransportFactoryTypes.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/ClientTransportFactoryTypes.java
new file mode 100644
index 0000000..ff8d364
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/ClientTransportFactoryTypes.java
@@ -0,0 +1,33 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+/**
+ * This defines the types of ClientTransportFactory
+ */
+public interface ClientTransportFactoryTypes {
+    public static final int HTTP  = 0;
+    public static final int LOCAL = 1;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/InternalSoapEncoder.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/InternalSoapEncoder.java
new file mode 100644
index 0000000..78db370
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/InternalSoapEncoder.java
@@ -0,0 +1,57 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.spi.runtime;
+
+import javax.xml.stream.XMLStreamWriter;
+import java.io.OutputStream;
+
+/**
+ * SOAPEncoder to encode JAXWS runtime objects. Using this caller could optimize
+ * SOAPMessage creation and not use JAXWS default encoding of SOAPMessage
+ */
+public interface InternalSoapEncoder {
+    /**
+     *  Writes an object to output stream
+     * @param obj payload to be written
+     * @param messageInfo object containing informations to help JAXWS write the objects. Get
+     *        this object from SOAPMessageContext.getMessageInfo()
+     * @param out stream to write to
+     * @param mtomCallback callback is called if there any attachments while
+     *                     encoding the object
+     */
+    public void write(Object obj, Object messageInfo, OutputStream out, MtomCallback mtomCallback);
+
+    /**
+     * Writes an object to output stream
+     * @param obj payload to be written
+     * @param messageInfo object containing informations to help JAXWS write the objects. Get
+     *        this object from SOAPMessageContext.getMessageInfo()
+     * @param out stream writer to write to
+     * @param mtomCallback callback is called if there any attachments while
+     *                     encoding the object
+     */
+    public void write(Object obj, Object messageInfo, XMLStreamWriter out, MtomCallback mtomCallback);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Invoker.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Invoker.java
new file mode 100644
index 0000000..e26a43c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Invoker.java
@@ -0,0 +1,49 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+import java.lang.reflect.Method;
+import javax.xml.namespace.QName;
+
+/**
+ * Complete invocation of webservice can be done using this object. So this
+ * object can be wrapped in other blocks to provide certain context(for e.g.
+ * can be wrapped in doAsPrivileged())
+ *
+ * @author WS Development Team
+ */
+public interface Invoker {
+    /**
+     * Invokes request handler chain, endpoint, response handler chain
+     */
+    public void invoke() throws Exception;
+
+    /**
+     * It gives java methods for a give operation name
+     *
+     * @return corresponding java method for operation name, otherwise null
+     */
+    public Method getMethod(QName name);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/MessageContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/MessageContext.java
new file mode 100644
index 0000000..4a3158e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/MessageContext.java
@@ -0,0 +1,67 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+import java.lang.reflect.Method;
+
+/**
+ * Enhanced API' MessageContext with some extra properties
+ */
+public interface MessageContext extends javax.xml.ws.handler.MessageContext {
+    /**
+     * Returns binding id defined in API
+     * @return bindingId is one of these values:
+     * javax.xml.ws.soap.SOAPBinding.SOAP11HTTP_BINDING,
+     * javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING,
+     * javax.xml.ws.http.HTTPBinding.HTTP_BINDING
+     */
+    public String getBindingId();
+
+    /**
+     * Returns the invocation method.
+     *
+     * @return invocation method, null if the model doesn't know
+     */
+    public Method getMethod();
+
+    /**
+     * Sets cannonicalization algorithm that is used while writing JAXB objects
+     *
+     */
+    public void setCanonicalization(String algorithm);
+
+    /**
+     * Returns the Invoker
+     *
+     * @return Invoker
+     */
+    public Invoker getInvoker();
+
+    /**
+     * Returns if MTOM is anbled
+     * @return true if MTOM is enabled otherwise returns false;
+     */
+    public boolean isMtomEnabled();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/MtomCallback.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/MtomCallback.java
new file mode 100644
index 0000000..7802095
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/MtomCallback.java
@@ -0,0 +1,44 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+import javax.activation.DataHandler;
+
+/**
+ * MTOM callback class that is passed to InternalSoapEncoder.write() to get notification when
+ * mtom attachment is added or the message is xopped.
+ */
+public interface MtomCallback {
+    /**
+     * This method provides the content-id that will be set to Content-ID MIME header, the
+     * element which will be xop encoded by JAXB.
+     *
+     * @param contentId
+     * @param attachment
+     * @param elementTargetNamespace
+     * @param elementLocalName
+     */
+    public void addedMtomAttachment(String contentId, DataHandler attachment, String elementTargetNamespace, String elementLocalName);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/RuntimeEndpointInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/RuntimeEndpointInfo.java
new file mode 100644
index 0000000..442ad01
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/RuntimeEndpointInfo.java
@@ -0,0 +1,130 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+import java.net.URL;
+import javax.xml.namespace.QName;
+import org.xml.sax.EntityResolver;
+
+/**
+ * This captures all the required information (e.g: handlers, binding, endpoint
+ * object, proxy for endpoint object etc.) about the endpoint.
+ */
+public interface RuntimeEndpointInfo {
+
+    /**
+     * Returns the name of the endpoint
+     * @return name of the endpoint
+     */
+    public String getName();
+
+    /**
+     * sets the name of the endpoint
+     */
+    public void setName(String name);
+
+    /**
+     * Builds runtime model from implementor object.
+     */
+    public void init();
+
+    /**
+     * Destroys any state in this object
+     */
+    public void destroy();
+
+    /**
+     * This object is used for method invocations. It could be actual
+     * implementor or a proxy object. This must be set before calling deploy().
+     */
+    public void setImplementor(Object implementor);
+
+    /**
+     * implementorClass should have <code>@WebService</code> or
+     * <code>@WebServiceProvider</code> annotation.
+     * Dynamic model is created using this object. If this is not set, implementor's
+     * class is used to create the model.
+     */
+    public void setImplementorClass(Class implementorClass);
+
+    /**
+     * Returns actual Endpoint Object where method invocation is done
+     *
+     * @return Object Gets the endpoint implementation object or a proxy
+     */
+    public Object getImplementor();
+
+    /**
+     * Returns the set implementorClass
+     *
+     * @return implementor's class that has the annotations
+     */
+    public Class getImplementorClass();
+
+    /**
+     * Returns the binding for this endpoint
+     *
+     * @return Binding Returns the binding for this endpoint.
+     */
+    public Binding getBinding();
+
+    /**
+     * sets the binding for this endpoint. If there are handlers, set them on
+     * the binding object.
+     */
+    public void setBinding(Binding binding);
+
+    /**
+     * Returns the WebServiceContext of this endpoint
+     *
+     * @return WebServiceContext Returns the WebServiceContext of this endpoint.
+     */
+    public WebServiceContext getWebServiceContext();
+
+    /**
+     * sets the WebServiceContext for this endpoint.
+     */
+    public void setWebServiceContext(WebServiceContext wsContext);
+
+    /**
+     * set the URL for primary WSDL, and a resolver to resolve entities like
+     * WSDL, imports/references. A resolver for XML catalog can be created using
+     * WSRtObjectFactory.createResolver(URL catalogURL).
+     */
+    public void setWsdlInfo(URL wsdlUrl, EntityResolver resolver);
+
+    /**
+     * Set service name from DD. If it is null, @WebService, @WebServiceProvider
+     * annotations are used to get service name
+     */
+    public void setServiceName(QName name);
+
+    /**
+     * Set port name from DD. If it is null, @WebService, @WebServiceProvider
+     * annotations are used to get port name
+     */
+    public void setPortName(QName name);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SOAPMessageContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SOAPMessageContext.java
new file mode 100644
index 0000000..c6bc173
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SOAPMessageContext.java
@@ -0,0 +1,66 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+import java.util.List;
+
+/**
+ * This enhances API's SOAPMessageContext and provides internal representation
+ * of SOAPMessage so that it can be encoded optimally
+ */
+public interface SOAPMessageContext
+    extends javax.xml.ws.handler.soap.SOAPMessageContext, MessageContext {
+
+    /**
+     * If there is a SOAPMessage already, use getSOAPMessage(). Ignore all other methods
+     * @return
+     */
+    public boolean isAlreadySoap();
+
+    /**
+     * Returns InternalMessage's BodyBlock value
+     * @return
+     */
+    public Object getBody();
+
+    /**
+     * Returns InternalMessage's HeaderBlock values
+     * @return
+     */
+    public List getHeaders();
+
+    /**
+     * Use this object to pass to InternalSoapEncoder write methods
+     * @return object containg information thats used by InternalEncoderDecoder write methods.
+     *
+     */
+    public Object getMessageInfo();
+
+    /**
+     * Returns to marshall all JAXWS objects: RpcLitPayload, JAXBBridgeInfo etc
+     * @return
+     */
+    public InternalSoapEncoder getEncoder();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/StubBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/StubBase.java
new file mode 100644
index 0000000..cbc2a4c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/StubBase.java
@@ -0,0 +1,34 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+
+/**
+ * This class is implemented by
+ * com.sun.xml.internal.ws.client.StubBase
+ */
+public interface StubBase {
+    public void _setTransportFactory(ClientTransportFactory f);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SystemHandlerDelegate.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SystemHandlerDelegate.java
new file mode 100644
index 0000000..508a3ab
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SystemHandlerDelegate.java
@@ -0,0 +1,114 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+
+/**
+ * A SystemHandlerDelegate is used to inject system level functionality into a
+ * message processing runtime. The methods of this interface are invoked by
+ * the client and enpoint message dispatchers of the message processing
+ * runtime.
+ *
+ * @author WS Development Team
+ */
+
+public interface SystemHandlerDelegate {
+
+   /**
+    * Called by both client and endpoint message dispatchers to activate
+    * injected request message processing.
+    * When called by a client side message dispatcher, this method must be
+    * called just before the message (associated with the MessageContext)
+    * is sent. When called by the message dispatcher at an endpoint, this
+    * method must be called before MustUnderstand processing on the
+    * associated message.
+    *
+    * @param messageContext when called by a SOAPBinding the argument
+    * must be an instanceof com.sun.xml.internal.ws.spi.runtime.SOAPMessageContext, and
+    * when called by a SOAPBinding at an endpoint, the argument must
+    * be an instanceof com.sun.xml.internal.ws.spi.runtime.SOAPMessageContext and the
+    * Invoker (on the context) must be available for use on the server by the
+    * delegate. An argument SOAPMessageContext passed to this method by an endpoint
+    * dispatcher, must have values assigned for the following MessageContext
+    * properties.
+    * <ul>
+    * <li>MessageContext.SERVLET_REQUEST
+    * <li>MessageContext.SERVLET_RESPONSE
+    * <li>MessageContext.SERVLET_SESSION
+    * <li>MessageContext.SERVLET_CONTEXT
+    * </ul>
+    * @return true if processing by the delegate was such that the caller
+    * should continue with its normal message processing. Returns false when
+    * the delegate has established, in the MessageContext,
+    * the response message to be sent. When this method returns
+    * false, the calling message dispatcher must return the response message
+    * without performing MustUnderstand processing and without invoking the
+    * endpoint. Only delegates called by endpoint side message dispatchers
+    * may return false
+    *
+    * @throws java.lang.Exception when the processing by the delegate failed
+    * without yielding a response message; in which case, the caller shall
+    * determine how to process the error.
+    *
+    */
+    public boolean processRequest(MessageContext messageContext) throws Exception;
+
+   /**
+    * Called by both client and endpoint message dispatchers to activate
+    * injected response message processing.
+    * When called by the message dispatcher at the client, this method must be
+    * called before MustUnderstand processing on the received message
+    * (associated with the MessageContext). When called by the message
+    * dispatcher at an endpoint, this method must be called after the
+    * endpoint has been invoked, and just before the associated response
+    * message is sent. In the special case where invocation of the endpoint
+    * caused an Exception to be thrown, this method must not be called.
+    *
+    * @param messageContext when called by a SOAPBinding the argument
+    * must be an instanceof com.sun.xml.internal.ws.spi.runtime.SOAPMessageContext.
+    *
+    * @throws java.lang.Exception when the processing by the delegate failed.
+    * In this case, the caller must not send the response message but shall
+    * otherwise determine how to process the error.
+    */
+    public void processResponse(MessageContext messageContext) throws Exception;
+
+   /**
+    * This method must be called by an endpoint message dispatcher after
+    * MustUnderstand processing and before endpoint invocation.
+    *
+    * @param messageContext when called by a SOAPBinding the argument
+    * must be an instanceof com.sun.xml.internal.ws.spi.runtime.SOAPMessageContext, and
+    * must have values assigned for the following MessageContext
+    * properties.
+    * <ul>
+    * <li>MessageContext.SERVLET_REQUEST
+    * <li>MessageContext.SERVLET_RESPONSE
+    * <li>MessageContext.SERVLET_SESSION
+    * <li>MessageContext.SERVLET_CONTEXT
+    * </ul>
+     */
+    public void preInvokeEndpointHook(MessageContext messageContext);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SystemHandlerDelegateFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SystemHandlerDelegateFactory.java
new file mode 100644
index 0000000..1d7b840
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/SystemHandlerDelegateFactory.java
@@ -0,0 +1,143 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+import javax.xml.ws.WebServiceException;
+import javax.xml.namespace.QName;
+import static java.lang.Class.forName;
+import static java.lang.Thread.currentThread;
+import java.util.HashMap;
+
+public abstract class SystemHandlerDelegateFactory {
+
+    private final static String DEFAULT_FACTORY_NAME =
+        "com.sun.xml.internal.xwss.SystemHandlerDelegateFactory";
+
+    private static String factoryName;
+
+    private static HashMap factoryMap;
+
+    static {
+        init();
+    }
+
+    private static synchronized void init() {
+        factoryName = DEFAULT_FACTORY_NAME;
+        factoryMap = new HashMap();
+    };
+
+    // foctory implementations that maintain a map of serviceName to
+    // would override this method
+    /**
+    * Used by the Appserver on client and server sides
+    * factory implementations that maintain a map of serviceName to
+    * factory
+    * @param serviceName when called by the SOAPBindingImpl to
+    * create the SystemHandlerDelegate. serviceName must be
+    * a QName
+    * @return com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegate
+    * @throws java.lang.Exception when the create failed.
+    */
+    public SystemHandlerDelegate getDelegate(QName serviceName) {
+        return create();
+    }
+
+    /**
+    * Used by the Appserver and xws-security on client and server sides
+    * factory implementations that maintain a map of serviceName to
+    * factory
+    * @return com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegate
+    * @throws java.lang.Exception when the create failed.
+    */
+    public abstract SystemHandlerDelegate create();
+
+    //currently not used
+    public abstract boolean isEnabled(MessageContext messageContext);
+
+    // factory name can be set to null, in which case,
+    // the default factory will be disabled.
+    /**
+    * Used by the Appserver on client and server sides
+    * factoryName can be set to null, in which case the defaultFactory will be
+    * disabled
+    * @param name when called by the SOAPBindingImpl to
+    * create the SystemHandlerDelegate. serviceName must be
+    * a String
+    */
+    public static synchronized void setFactoryName(String name) {
+        factoryName = name;
+    }
+
+    /**
+    * Used by the Appserver on client and server sides
+    * factoryName can be set to null, in which case the defaultFactory will be
+    * disabled and will be null on return
+    * @return java.lang.String - name of factory
+    */
+    public static synchronized String getFactoryName() {
+        return factoryName;
+    }
+    /**
+    * Used by the JAX-WS implementation on client and server sides
+    * to load the SystemHandlerDelegateFactory
+    * @return com.sun.xml.internal.ws.spi.runtime.SystemHandlerDelegateFactory
+    * @throws javax.xml.ws.WebServiceException when the load fails.
+    */
+    public static synchronized SystemHandlerDelegateFactory getFactory() {
+
+        SystemHandlerDelegateFactory factory =
+            (SystemHandlerDelegateFactory) factoryMap.get(factoryName);
+
+        if (factory != null || factoryMap.containsKey(factoryName)) {
+            return factory;
+        } else {
+
+            Class clazz = null;
+            try {
+                ClassLoader loader = currentThread().getContextClassLoader();
+
+                if (loader == null) {
+                    clazz = forName(factoryName);
+                } else {
+                    clazz = loader.loadClass(factoryName);
+                }
+
+                if (clazz != null) {
+                    factory = (SystemHandlerDelegateFactory) clazz.newInstance();
+                }
+            } catch (ClassNotFoundException e) {
+                factory = null;
+                // e.printStackTrace(); //todo:need to add log
+            } catch (Exception x) {
+                throw new WebServiceException(x);
+            } finally {
+                // stores null factory values in map to prevent
+                // repeated class loading and instantiation errors.
+                factoryMap.put(factoryName, factory);
+            }
+        }
+        return factory;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Tie.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Tie.java
new file mode 100644
index 0000000..2649d80
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/Tie.java
@@ -0,0 +1,41 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+/**
+ * Entry point to JAXWS server side runtime
+ */
+public interface Tie {
+
+    /**
+     * Reads a Web Service request for RuntimeEndpointInfo from WSConnection
+     * and sends a response. Set <code>WebServiceContext</code> with a filled-in
+     * </code>MessageContext</code> on <code>RuntimeEndpointInfo</code> before
+     * calling this.
+     */
+    public void handle(WSConnection con, RuntimeEndpointInfo endpoint)
+    throws Exception;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/WSConnection.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/WSConnection.java
new file mode 100644
index 0000000..b103e26
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/WSConnection.java
@@ -0,0 +1,107 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.util.List;
+import java.util.Map;
+
+
+/**
+ * Captures many transports that are used to talk with WS endpoints.
+ *
+ * For endpoints deployed in light weight http server in J2SE, the implemenation
+ * of this class uses HttpTransaction to read from or write to stream.
+ *
+ * For endpoints deployed in servlet container, the implementation of this
+ * class uses HttpServletRequest to read a request, and uses HttpServletResponse
+ * to write response.
+ *
+ * This also works for local transport, JMS transport.
+ *
+ * Runtime can access to the implementation of this interface using
+ * messageInfo.getConnection()
+ *
+ */
+
+public interface WSConnection {
+
+    public static final int OK=200;
+    public static final int ONEWAY=202;
+    public static final int UNSUPPORTED_MEDIA=415;
+    public static final int MALFORMED_XML=400;
+    public static final int INTERNAL_ERR=500;
+
+    /**
+     * returns transport headers
+     * @return transport headers
+     */
+    public Map<String,List<String>> getHeaders();
+
+    /**
+     * sets transport headers
+     */
+    public void setHeaders(Map<String,List<String>> headers);
+
+    /**
+     * sets the transport status code like <code>OK</code>
+     */
+    public void setStatus(int status);
+
+    /**
+     * @return return the status code
+     */
+    public int getStatus();
+
+    /**
+     * Transport's underlying input stream
+     * @return Transport's underlying input stream
+     */
+    public InputStream getInput();
+
+    /**
+     * Closes transport's input stream
+     */
+    public void closeInput();
+
+    /**
+     * Transport's underlying output stream
+     * @return Transport's underlying output stream
+     */
+    public OutputStream getOutput();
+
+    /**
+     * Closes transport's output stream
+     */
+    public void closeOutput();
+
+    public OutputStream getDebug();
+
+    /**
+     * Closes transport connection
+     */
+    public void close();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/WebServiceContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/WebServiceContext.java
new file mode 100644
index 0000000..0ddec49
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/WebServiceContext.java
@@ -0,0 +1,39 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.spi.runtime;
+
+import javax.xml.ws.handler.MessageContext;
+
+/**
+ * Enhanced API WebServiceContext that contains a method to set MessageContext
+ */
+public interface WebServiceContext extends javax.xml.ws.WebServiceContext {
+
+    /**
+     * Sets SPI's MessageContext
+     */
+    public void setMessageContext(MessageContext ctxt);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/package-info.java
new file mode 100644
index 0000000..0162dbf
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/spi/runtime/package-info.java
@@ -0,0 +1,33 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *
+ * <P>This document describes the SPI for the JAX-WS 2.0 runtime.
+ *  Applications can use this SPI to interact with the runtime at
+ *  various points to get access to information and to perform
+ *  various operations such as security etc.
+*/
+package com.sun.xml.internal.ws.spi.runtime;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/Attributes.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/Attributes.java
new file mode 100644
index 0000000..4128acb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/Attributes.java
@@ -0,0 +1,131 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import javax.xml.namespace.QName;
+
+/**
+ * <p> The Attributes interface is essentially a version of the
+ * org.xml.sax.Attributes interface modified to use the JAX-WS QName class.</p>
+ *
+ * <p> Although namespace declarations can appear in the attribute list, the
+ * actual values of the local name and URI properties are
+ * implementation-specific. </p>
+ *
+ * <p> Applications that need to iterate through all the attributes can use the
+ * {@link #isNamespaceDeclaration} method to identify namespace declarations
+ * and skip them. </p>
+ *
+ * <p> Also, the URI property of an attribute will never be null. The value
+ * "" (empty string) is used for the URI of non-qualified attributes. </p>
+ *
+ * @author WS Development Team
+ */
+public interface Attributes {
+
+    /**
+     * Return the number of attributes in the list.
+     *
+     */
+    public int getLength();
+
+    /**
+     * Return true if the attribute at the given index is a namespace
+     * declaration.
+     *
+     * <p> Implementations are encouraged to optimize this method by taking into
+     * account their internal representations of attributes. </p>
+     *
+     */
+    public boolean isNamespaceDeclaration(int index);
+
+    /**
+     * Look up an attribute's QName by index.
+     *
+     */
+    public QName getName(int index);
+
+    /**
+     * Look up an attribute's URI by index.
+     *
+     */
+    public String getURI(int index);
+
+    /**
+     * Look up an attribute's local name by index.
+     * If attribute is a namespace declaration, result
+     * is expected including "xmlns:".
+     */
+    public String getLocalName(int index);
+
+    /**
+     * Look up an attribute's prefix by index.
+     *
+     */
+    public String getPrefix(int index);
+
+    /**
+     * Look up an attribute's value by index.
+     *
+     */
+    public String getValue(int index);
+
+    /**
+     * Look up the index of an attribute by QName.
+     *
+     */
+    public int getIndex(QName name);
+
+    /**
+     * Look up the index of an attribute by URI and local name.
+     *
+     */
+    public int getIndex(String uri, String localName);
+
+    /**
+     * Look up the index of an attribute by local name.
+     *
+     */
+    public int getIndex(String localName);
+
+    /**
+     * Look up the value of an attribute by QName.
+     *
+     */
+    public String getValue(QName name);
+
+    /**
+     * Look up the value of an attribute by URI and local name.
+     *
+     */
+    public String getValue(String uri, String localName);
+
+    /**
+     * Look up the value of an attribute by local name.
+     *
+     */
+    public String getValue(String localName);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/DOMStreamReader.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/DOMStreamReader.java
new file mode 100644
index 0000000..3fd2c85
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/DOMStreamReader.java
@@ -0,0 +1,726 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import java.util.List;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.Collections;
+
+import org.w3c.dom.*;
+import static org.w3c.dom.Node.*;
+import javax.xml.namespace.QName;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.stream.Location;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamException;
+
+/**
+ *
+ * Create an XMLStreamReader on top of a DOM level 2 tree. It a DOM level
+ * 1 tree is passed, each method will attempt to return the correct value
+ * by using <code>getNodeName()</code>.
+ *
+ * @author Santiago.PericasGeertsen@sun.com
+ */
+public class DOMStreamReader implements XMLStreamReader, NamespaceContext {
+
+    /**
+     * Current DOM node being traversed.
+     */
+    Node _current;
+
+    /**
+     * Starting node of the subtree being traversed.
+     */
+    Node _start;
+
+    /**
+     * Named mapping for attributes and NS decls for the current node.
+     */
+    NamedNodeMap _namedNodeMap;
+
+    /**
+     * List of attributes extracted from <code>_namedNodeMap</code>.
+     */
+    List<Attr> _currentAttributes = new ArrayList<Attr>();
+
+    /**
+     * List of namespace declarations extracted from <code>_namedNodeMap</code>
+     */
+    List<Attr> _currentNamespaces = new ArrayList<Attr>();
+
+    /**
+     * Flag indicating if <code>_namedNodeMap</code> is already split into
+     * <code>_currentAttributes</code> and <code>_currentNamespaces</code>
+     */
+    boolean _needAttributesSplit;
+
+    /**
+     * State of this reader. Any of the valid states defined in StAX'
+     * XMLStreamConstants class.
+     */
+    int _state;
+
+    /**
+     * Dummy Location instance returned in <code>getLocation</code>.
+     */
+    private static Location dummyLocation = new Location() {
+        public int getCharacterOffset() {
+            return -1;
+        }
+        public int getColumnNumber() {
+            return -1;
+        }
+        public int getLineNumber() {
+            return -1;
+        }
+        public String getPublicId() {
+            return null;
+        }
+        public String getSystemId() {
+            return null;
+        }
+    };
+
+    public DOMStreamReader() {
+    }
+
+    public DOMStreamReader(Node node) {
+        setCurrentNode(node);
+    }
+
+    public void setCurrentNode(Node node) {
+        _start = _current = node;
+        _state = START_DOCUMENT;
+        // verifyDOMIntegrity(node);
+        // displayDOM(node, System.out);
+    }
+
+    public void close() throws javax.xml.stream.XMLStreamException {
+    }
+
+
+    private void splitAttributes() {
+        if (!_needAttributesSplit) return;
+
+        // Clear attribute and namespace lists
+        _currentAttributes.clear();
+        _currentNamespaces.clear();
+
+        _namedNodeMap = _current.getAttributes();
+        if (_namedNodeMap != null) {
+            final int n = _namedNodeMap.getLength();
+            for (int i = 0; i < n; i++) {
+                final Attr attr = (Attr) _namedNodeMap.item(i);
+                final String attrName = attr.getNodeName();
+                if (attrName.startsWith("xmlns:") || attrName.equals("xmlns")) {     // NS decl?
+                    _currentNamespaces.add(attr);
+                }
+                else {
+                    _currentAttributes.add(attr);
+                }
+            }
+        }
+        _needAttributesSplit = false;
+    }
+
+    public int getAttributeCount() {
+        if (_state == START_ELEMENT) {
+            splitAttributes();
+            return _currentAttributes.size();
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributeCount() called in illegal state");
+    }
+
+    /**
+     * Return an attribute's local name. Handle the case of DOM level 1 nodes.
+     */
+    public String getAttributeLocalName(int index) {
+        if (_state == START_ELEMENT) {
+            splitAttributes();
+
+            String localName = _currentAttributes.get(index).getLocalName();
+            return (localName != null) ? localName :
+                QName.valueOf(_currentAttributes.get(index).getNodeName()).getLocalPart();
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributeLocalName() called in illegal state");
+    }
+
+    /**
+     * Return an attribute's qname. Handle the case of DOM level 1 nodes.
+     */
+    public QName getAttributeName(int index) {
+        if (_state == START_ELEMENT) {
+            splitAttributes();
+
+            Node attr = _currentAttributes.get(index);
+            String localName = attr.getLocalName();
+            if (localName != null) {
+                String prefix = attr.getPrefix();
+                String uri = attr.getNamespaceURI();
+                return new QName(uri != null ? uri : "", localName,
+                    prefix != null ? prefix : "");
+            }
+            else {
+                return QName.valueOf(attr.getNodeName());
+            }
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributeName() called in illegal state");
+    }
+
+    public String getAttributeNamespace(int index) {
+        if (_state == START_ELEMENT) {
+            splitAttributes();
+            String uri = _currentAttributes.get(index).getNamespaceURI();
+            return uri != null ? uri : "";
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributeNamespace() called in illegal state");
+    }
+
+    public String getAttributePrefix(int index) {
+        if (_state == START_ELEMENT) {
+            splitAttributes();
+            String prefix = _currentAttributes.get(index).getPrefix();
+            return prefix != null ? prefix : "";
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributePrefix() called in illegal state");
+    }
+
+    public String getAttributeType(int index) {
+        if (_state == START_ELEMENT) {
+            return "CDATA";
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributeType() called in illegal state");
+    }
+
+    public String getAttributeValue(int index) {
+        if (_state == START_ELEMENT) {
+            splitAttributes();
+            return _currentAttributes.get(index).getNodeValue();
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributeValue() called in illegal state");
+    }
+
+    public String getAttributeValue(String namespaceURI, String localName) {
+        if (_state == START_ELEMENT) {
+            splitAttributes();
+            if (_namedNodeMap != null) {
+                Node attr = _namedNodeMap.getNamedItemNS(namespaceURI, localName);
+                return attr != null ? attr.getNodeValue() : null;
+            }
+            return null;
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributeValue() called in illegal state");
+    }
+
+    public String getCharacterEncodingScheme() {
+        return null;
+    }
+
+    public String getElementText() throws javax.xml.stream.XMLStreamException {
+        throw new RuntimeException("DOMStreamReader: getElementText() not implemented");
+    }
+
+    public String getEncoding() {
+        return null;
+    }
+
+    public int getEventType() {
+        return _state;
+    }
+
+    /**
+     * Return an element's local name. Handle the case of DOM level 1 nodes.
+     */
+    public String getLocalName() {
+        if (_state == START_ELEMENT || _state == END_ELEMENT) {
+            String localName = _current.getLocalName();
+            return localName != null ? localName :
+                QName.valueOf(_current.getNodeName()).getLocalPart();
+        }
+        else if (_state == ENTITY_REFERENCE) {
+            return _current.getNodeName();
+        }
+        throw new IllegalStateException("DOMStreamReader: getAttributeValue() called in illegal state");
+    }
+
+    public javax.xml.stream.Location getLocation() {
+        return dummyLocation;
+    }
+
+    /**
+     * Return an element's qname. Handle the case of DOM level 1 nodes.
+     */
+    public javax.xml.namespace.QName getName() {
+        if (_state == START_ELEMENT || _state == END_ELEMENT) {
+            String localName = _current.getLocalName();
+            if (localName != null) {
+                String prefix = _current.getPrefix();
+                String uri = _current.getNamespaceURI();
+                return new QName(uri != null ? uri : "", localName,
+                    prefix != null ? prefix : "");
+            }
+            else {
+                return QName.valueOf(_current.getNodeName());
+            }
+        }
+        throw new IllegalStateException("DOMStreamReader: getName() called in illegal state");
+    }
+
+    public NamespaceContext getNamespaceContext() {
+        return this;
+    }
+
+    public int getNamespaceCount() {
+        if (_state == START_ELEMENT || _state == END_ELEMENT) {
+            splitAttributes();
+            return _currentNamespaces.size();
+        }
+        throw new IllegalStateException("DOMStreamReader: getNamespaceCount() called in illegal state");
+    }
+
+    public String getNamespacePrefix(int index) {
+        if (_state == START_ELEMENT || _state == END_ELEMENT) {
+            splitAttributes();
+
+            Attr attr = _currentNamespaces.get(index);
+            String result = attr.getLocalName();
+            if (result == null) {
+                result = QName.valueOf(attr.getNodeName()).getLocalPart();
+            }
+            return result.equals("xmlns") ? null : result;
+        }
+        throw new IllegalStateException("DOMStreamReader: getNamespacePrefix() called in illegal state");
+    }
+
+    public String getNamespaceURI() {
+        if (_state == START_ELEMENT || _state == END_ELEMENT) {
+            String uri = _current.getNamespaceURI();
+            return uri != null ? uri : "";
+        }
+        return null;
+    }
+
+    public String getNamespaceURI(int index) {
+        if (_state == START_ELEMENT || _state == END_ELEMENT) {
+            splitAttributes();
+            return _currentNamespaces.get(index).getValue();
+        }
+        throw new IllegalStateException("DOMStreamReader: getNamespaceURI(int) called in illegal state");
+    }
+
+    /**
+     * This method is not particularly fast, but shouldn't be called very
+     * often. If we start to use it more, we should keep track of the
+     * NS declarations using a NamespaceContext implementation instead.
+     */
+    public String getNamespaceURI(String prefix) {
+        if (prefix == null) {
+            throw new IllegalArgumentException("DOMStreamReader: getNamespaceURI(String) call with a null prefix");
+        }
+        else if (prefix.equals("xml")) {
+            return "http://www.w3.org/XML/1998/namespace";
+        }
+        else if (prefix.equals("xmlns")) {
+            return "http://www.w3.org/2000/xmlns/";
+        }
+        else {
+            int type;
+
+            // Find nearest element node
+            Node node = _current;
+            while ((type = node.getNodeType()) != DOCUMENT_NODE
+                    && type != ELEMENT_NODE) {
+                node = node.getParentNode();
+            }
+
+            boolean isDefault = (prefix.length() == 0);
+
+            while (node.getNodeType() != DOCUMENT_NODE) {
+                // Is ns declaration on this element?
+                NamedNodeMap namedNodeMap = node.getAttributes();
+                Attr attr = isDefault ? (Attr) namedNodeMap.getNamedItem("xmlns") :
+                                        (Attr) namedNodeMap.getNamedItem("xmlns:" + prefix);
+                if (attr != null) {
+                    return attr.getValue();
+                }
+                node = node.getParentNode();
+            }
+            return null;
+        }
+    }
+
+    public String getPrefix(String nsUri) {
+        if (nsUri == null) {
+            throw new IllegalArgumentException("DOMStreamReader: getPrefix(String) call with a null namespace URI");
+        }
+        else if (nsUri.equals("http://www.w3.org/XML/1998/namespace")) {
+            return "xml";
+        }
+        else if (nsUri.equals("http://www.w3.org/2000/xmlns/")) {
+            return "xmlns";
+        }
+        else {
+            int type;
+
+            // Find nearest element node
+            Node node = _current;
+            while ((type = node.getNodeType()) != DOCUMENT_NODE
+                    && type != ELEMENT_NODE) {
+                node = node.getParentNode();
+            }
+
+            while (node.getNodeType() != DOCUMENT_NODE) {
+                // Is ns declaration on this element?
+                NamedNodeMap namedNodeMap = node.getAttributes();
+                for( int i=namedNodeMap.getLength()-1; i>=0; i-- ) {
+                    Attr attr = (Attr)namedNodeMap.item(i);
+
+                    String attrName = attr.getNodeName();
+                    if (attrName.startsWith("xmlns:") || attrName.equals("xmlns")) {     // NS decl?
+                        if(attr.getValue().equals(nsUri)) {
+                            if(attrName.equals("xmlns"))
+                                return "";
+                            String localName = attr.getLocalName();
+                            return (localName != null) ? localName :
+                                QName.valueOf(attrName).getLocalPart();
+                        }
+                    }
+                }
+                node = node.getParentNode();
+            }
+            return null;
+        }
+    }
+
+    public Iterator getPrefixes(String nsUri) {
+        // This is an incorrect implementation,
+        // but AFAIK it's not used in the JAX-WS runtime
+        String prefix = getPrefix(nsUri);
+        if(prefix==null)    return Collections.emptyList().iterator();
+        else                return Collections.singletonList(prefix).iterator();
+    }
+
+    public String getPIData() {
+        if (_state == PROCESSING_INSTRUCTION) {
+            return ((ProcessingInstruction) _current).getData();
+        }
+        return null;
+    }
+
+    public String getPITarget() {
+        if (_state == PROCESSING_INSTRUCTION) {
+            return ((ProcessingInstruction) _current).getTarget();
+        }
+        return null;
+    }
+
+    public String getPrefix() {
+        if (_state == START_ELEMENT || _state == END_ELEMENT) {
+            String prefix = _current.getPrefix();
+            return prefix != null ? prefix : "";
+        }
+        return null;
+    }
+
+    public Object getProperty(String str) throws IllegalArgumentException {
+        return null;
+    }
+
+    public String getText() {
+        if (_state == CHARACTERS || _state == CDATA || _state == COMMENT ||
+                _state == ENTITY_REFERENCE) {
+            return _current.getNodeValue();
+        }
+        throw new IllegalStateException("DOMStreamReader: getTextLength() called in illegal state");
+    }
+
+    public char[] getTextCharacters() {
+        return getText().toCharArray();
+    }
+
+    public int getTextCharacters(int sourceStart, char[] target, int targetStart,
+                                 int targetLength) throws javax.xml.stream.XMLStreamException
+    {
+        char[] text = getTextCharacters();
+        System.arraycopy(text, sourceStart, target, targetStart, targetLength);
+        return Math.min(targetLength, text.length - sourceStart);
+    }
+
+    public int getTextLength() {
+        if (_state == CHARACTERS || _state == CDATA || _state == COMMENT ||
+                _state == ENTITY_REFERENCE) {
+            return _current.getNodeValue().length();
+        }
+        throw new IllegalStateException("DOMStreamReader: getTextLength() called in illegal state");
+    }
+
+    public int getTextStart() {
+        if (_state == CHARACTERS || _state == CDATA || _state == COMMENT ||
+                _state == ENTITY_REFERENCE) {
+            return 0;
+        }
+        throw new IllegalStateException("DOMStreamReader: getTextStart() called in illegal state");
+    }
+
+    public String getVersion() {
+        return null;
+    }
+
+    public boolean hasName() {
+        return (_state == START_ELEMENT || _state == END_ELEMENT);
+    }
+
+    public boolean hasNext() throws javax.xml.stream.XMLStreamException {
+        return (_state != END_DOCUMENT);
+    }
+
+    public boolean hasText() {
+        if (_state == CHARACTERS || _state == CDATA || _state == COMMENT ||
+                _state == ENTITY_REFERENCE) {
+            return (_current.getNodeValue().trim().length() > 0);
+        }
+        return false;
+    }
+
+    public boolean isAttributeSpecified(int param) {
+        return false;
+    }
+
+    public boolean isCharacters() {
+        return (_state == CHARACTERS);
+    }
+
+    public boolean isEndElement() {
+        return (_state == END_ELEMENT);
+    }
+
+    public boolean isStandalone() {
+        return true;
+    }
+
+    public boolean isStartElement() {
+        return (_state == START_ELEMENT);
+    }
+
+    public boolean isWhiteSpace() {
+        final int nodeType = _current.getNodeType();
+        if (nodeType == Node.TEXT_NODE || nodeType == Node.CDATA_SECTION_NODE) {
+            return (_current.getNodeValue().trim().length() == 0);
+        }
+        return false;
+    }
+
+    private static int mapNodeTypeToState(int nodetype) {
+        switch (nodetype) {
+            case CDATA_SECTION_NODE:
+                return CDATA;
+            case COMMENT_NODE:
+                return COMMENT;
+            case ELEMENT_NODE:
+                return START_ELEMENT;
+            case ENTITY_NODE:
+                return ENTITY_DECLARATION;
+            case ENTITY_REFERENCE_NODE:
+                return ENTITY_REFERENCE;
+            case NOTATION_NODE:
+                return NOTATION_DECLARATION;
+            case PROCESSING_INSTRUCTION_NODE:
+                return PROCESSING_INSTRUCTION;
+            case TEXT_NODE:
+                return CHARACTERS;
+            default:
+                throw new RuntimeException("DOMStreamReader: Unexpected node type");
+        }
+    }
+
+    public int next() throws javax.xml.stream.XMLStreamException {
+        Node child;
+
+        // Indicate that attributes still need processing
+        _needAttributesSplit = true;
+
+        switch (_state) {
+            case END_DOCUMENT:
+                throw new IllegalStateException("DOMStreamReader: Calling next() at END_DOCUMENT");
+            case START_DOCUMENT:
+                // Don't skip document element if this is a fragment
+                if (_current.getNodeType() == ELEMENT_NODE) {
+                    return (_state = START_ELEMENT);
+                }
+
+                child = _current.getFirstChild();
+                if (child == null) {
+                    return (_state = END_DOCUMENT);
+                }
+                else {
+                    _current = child;
+                    return (_state = mapNodeTypeToState(_current.getNodeType()));
+                }
+            case START_ELEMENT:
+                /*
+                 * SAAJ tree may contain multiple adjacent text nodes.  Normalization
+                 * is very expensive, so we should think about changing SAAJ instead!
+                 */
+                _current.normalize();
+
+                child = _current.getFirstChild();
+                if (child == null) {
+                    return (_state = END_ELEMENT);
+                }
+                else {
+                    _current = child;
+                    return (_state = mapNodeTypeToState(_current.getNodeType()));
+                }
+            case CHARACTERS:
+            case COMMENT:
+            case CDATA:
+            case ENTITY_REFERENCE:
+            case PROCESSING_INSTRUCTION:
+            case END_ELEMENT:
+                // If at the end of this fragment, then terminate traversal
+                if (_current == _start) {
+                    return (_state = END_DOCUMENT);
+                }
+
+                Node sibling = _current.getNextSibling();
+                if (sibling == null) {
+                    _current = _current.getParentNode();
+                    // getParentNode() returns null for fragments
+                    _state = (_current == null || _current.getNodeType() == DOCUMENT_NODE) ?
+                             END_DOCUMENT : END_ELEMENT;
+                    return _state;
+                }
+                else {
+                    _current = sibling;
+                    return (_state = mapNodeTypeToState(_current.getNodeType()));
+                }
+            case DTD:
+            case ATTRIBUTE:
+            case NAMESPACE:
+            default:
+                throw new RuntimeException("DOMStreamReader: Unexpected internal state");
+        }
+    }
+
+    public int nextTag() throws javax.xml.stream.XMLStreamException {
+        int eventType = next();
+        while (eventType == CHARACTERS && isWhiteSpace()
+               || eventType == CDATA && isWhiteSpace()
+               || eventType == SPACE
+               || eventType == PROCESSING_INSTRUCTION
+               || eventType == COMMENT)
+        {
+            eventType = next();
+        }
+        if (eventType != START_ELEMENT && eventType != END_ELEMENT) {
+            throw new XMLStreamException("DOMStreamReader: Expected start or end tag");
+        }
+        return eventType;
+    }
+
+    public void require(int type, String namespaceURI, String localName)
+        throws javax.xml.stream.XMLStreamException
+    {
+        if (type != _state) {
+            throw new XMLStreamException("DOMStreamReader: Required event type not found");
+        }
+        if (namespaceURI != null && !namespaceURI.equals(getNamespaceURI())) {
+            throw new XMLStreamException("DOMStreamReader: Required namespaceURI not found");
+        }
+        if (localName != null && !localName.equals(getLocalName())) {
+            throw new XMLStreamException("DOMStreamReader: Required localName not found");
+        }
+    }
+
+    public boolean standaloneSet() {
+        return true;
+    }
+
+
+
+    // -- Debugging ------------------------------------------------------
+
+    private static void displayDOM(Node node, java.io.OutputStream ostream) {
+        try {
+            System.out.println("\n====\n");
+            javax.xml.transform.TransformerFactory.newInstance().newTransformer().transform(
+                new javax.xml.transform.dom.DOMSource(node),
+                new javax.xml.transform.stream.StreamResult(ostream));
+            System.out.println("\n====\n");
+        }
+        catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
+
+    private static void verifyDOMIntegrity(Node node) {
+        switch (node.getNodeType()) {
+            case ELEMENT_NODE:
+            case ATTRIBUTE_NODE:
+
+                // DOM level 1?
+                if (node.getLocalName() == null) {
+                    System.out.println("WARNING: DOM level 1 node found");
+                    System.out.println(" -> node.getNodeName() = " + node.getNodeName());
+                    System.out.println(" -> node.getNamespaceURI() = " + node.getNamespaceURI());
+                    System.out.println(" -> node.getLocalName() = " + node.getLocalName());
+                    System.out.println(" -> node.getPrefix() = " + node.getPrefix());
+                }
+
+                if (node.getNodeType() == ATTRIBUTE_NODE) return;
+
+                NamedNodeMap attrs = ((Element) node).getAttributes();
+                for (int i = 0; i < attrs.getLength(); i++) {
+                    verifyDOMIntegrity(attrs.item(i));
+                }
+            case DOCUMENT_NODE:
+                NodeList children = node.getChildNodes();
+                for (int i = 0; i < children.getLength(); i++) {
+                    verifyDOMIntegrity(children.item(i));
+                }
+        }
+    }
+
+    static public void main(String[] args) throws Exception {
+        String sample = "<?xml version='1.0' encoding='UTF-8'?><env:Envelope xmlns:env='http://schemas.xmlsoap.org/soap/envelope/'><env:Body><env:Fault><faultcode>env:Server</faultcode><faultstring>Internal server error</faultstring></env:Fault></env:Body></env:Envelope>";
+        javax.xml.parsers.DocumentBuilderFactory dbf = javax.xml.parsers.DocumentBuilderFactory.newInstance();
+        dbf.setNamespaceAware(true);
+        javax.xml.parsers.DocumentBuilder db = dbf.newDocumentBuilder();
+        Document dd = db.parse(new java.io.ByteArrayInputStream(sample.getBytes("UTF-8")));
+
+        DOMStreamReader dsr = new DOMStreamReader(dd);
+        while (dsr.hasNext()) {
+            System.out.println("dsr.next() = " + dsr.next());
+            if (dsr.getEventType() == START_ELEMENT || dsr.getEventType() == END_ELEMENT) {
+                System.out.println("dsr.getName = " + dsr.getName());
+                if (dsr.getEventType() == START_ELEMENT)
+                    System.out.println("dsr.getAttributeCount() = " + dsr.getAttributeCount());
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/PrefixFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/PrefixFactory.java
new file mode 100644
index 0000000..cafcc63
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/PrefixFactory.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+/**
+ * <p> Interface for prefix factories. </p>
+ *
+ * <p> A prefix factory is able to create a new prefix for a URI that
+ * was encountered for the first time when writing a document
+ * using an XMLWriter. </p>
+ *
+ * @author WS Development Team
+ */
+public interface PrefixFactory {
+    /**
+     * Return a brand new prefix for the given URI.
+     */
+    public String getPrefix(String uri);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/PrefixFactoryImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/PrefixFactoryImpl.java
new file mode 100644
index 0000000..31103b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/PrefixFactoryImpl.java
@@ -0,0 +1,63 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * <p> A prefix factory that caches the prefixes it creates. </p>
+ *
+ * @author WS Development Team
+ */
+public class PrefixFactoryImpl implements PrefixFactory {
+
+    public PrefixFactoryImpl(String base) {
+        _base = base;
+        _next = 1;
+    }
+
+    public String getPrefix(String uri) {
+        String prefix = null;
+
+        if (_cachedUriToPrefixMap == null) {
+            _cachedUriToPrefixMap = new HashMap();
+        } else {
+            prefix = (String) _cachedUriToPrefixMap.get(uri);
+        }
+
+        if (prefix == null) {
+            prefix = _base + Integer.toString(_next++);
+            _cachedUriToPrefixMap.put(uri, prefix);
+        }
+
+        return prefix;
+    }
+
+    private String _base;
+    private int _next;
+    private Map _cachedUriToPrefixMap;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/SourceReaderFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/SourceReaderFactory.java
new file mode 100644
index 0000000..49af586
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/SourceReaderFactory.java
@@ -0,0 +1,122 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import com.sun.xml.internal.ws.util.FastInfosetReflection;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+import java.io.Reader;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.sax.SAXSource;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.stream.XMLStreamReader;
+
+/**
+ * @author Santiago.PericasGeertsen@sun.com
+ */
+public class SourceReaderFactory {
+
+    /**
+     * Thread variable used to store DOMStreamReader for current thread.
+     */
+    static ThreadLocal<DOMStreamReader> domStreamReader =
+        new ThreadLocal<DOMStreamReader>();
+
+    public static XMLStreamReader createSourceReader(Source source,
+        boolean rejectDTDs)
+    {
+        return createSourceReader(source, rejectDTDs, null);
+    }
+
+    public static XMLStreamReader createSourceReader(Source source,
+        boolean rejectDTDs, String charsetName)
+    {
+        try {
+            if (source instanceof StreamSource) {
+                StreamSource streamSource = (StreamSource) source;
+                InputStream is = streamSource.getInputStream();
+
+                if (is != null) {
+                    // Wrap input stream in Reader if charset is specified
+                    if (charsetName != null) {
+                        return XMLStreamReaderFactory.createXMLStreamReader(
+                            new InputStreamReader(is, charsetName), rejectDTDs);
+                    }
+                    else {
+                        return XMLStreamReaderFactory.createXMLStreamReader(is,
+                            rejectDTDs);
+                    }
+                }
+                else {
+                    Reader reader = streamSource.getReader();
+                    if (reader != null) {
+                        return XMLStreamReaderFactory.createXMLStreamReader(reader,
+                            rejectDTDs);
+                    }
+                    else {
+                        throw new XMLReaderException("sourceReader.invalidSource",
+                            new Object[] { source.getClass().getName() });
+                    }
+                }
+            }
+            else if (FastInfosetReflection.isFastInfosetSource(source)) {
+                return XMLStreamReaderFactory.createFIStreamReader((InputStream)
+                    FastInfosetReflection.FastInfosetSource_getInputStream(source));
+            }
+            else if (source instanceof DOMSource) {
+                DOMStreamReader dsr = domStreamReader.get();
+                if (dsr == null) {
+                    domStreamReader.set(dsr = new DOMStreamReader());
+                }
+                dsr.setCurrentNode(((DOMSource) source).getNode());
+                return dsr;
+            }
+            else if (source instanceof SAXSource) {
+                // TODO: need SAX to StAX adapter here -- Use transformer for now
+                Transformer tx =  XmlUtil.newTransformer();
+                DOMResult domResult = new DOMResult();
+                tx.transform(source, domResult);
+                return createSourceReader(
+                    new DOMSource(domResult.getNode()),
+                    rejectDTDs);
+            }
+            else {
+                throw new XMLReaderException("sourceReader.invalidSource",
+                    new Object[] { source.getClass().getName() });
+            }
+        }
+        catch (Exception e) {
+            throw new XMLReaderException(e);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/TidyXMLStreamReader.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/TidyXMLStreamReader.java
new file mode 100644
index 0000000..bf638c8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/TidyXMLStreamReader.java
@@ -0,0 +1,237 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.Location;
+import javax.xml.namespace.NamespaceContext;
+import javax.xml.namespace.QName;
+import javax.xml.ws.WebServiceException;
+import java.io.Closeable;
+import java.io.IOException;
+
+/**
+ * Wrapper over XMLStreamReader. It will be used primarily to cleaup the resources such as closure on InputStream/Reader.
+ *
+ * @author Vivek Pandey
+ */
+public class TidyXMLStreamReader implements XMLStreamReader{
+    private final XMLStreamReader reader;
+    private final Closeable closeableSource;
+
+    public TidyXMLStreamReader(XMLStreamReader reader, Closeable closeableSource) {
+        this.reader = reader;
+        this.closeableSource = closeableSource;
+    }
+
+    public int getAttributeCount() {
+        return reader.getAttributeCount();
+    }
+
+    public int getEventType() {
+        return reader.getEventType();
+    }
+
+    public int getNamespaceCount() {
+        return reader.getNamespaceCount();
+    }
+
+    public int getTextLength() {
+        return reader.getTextLength();
+    }
+
+    public int getTextStart() {
+        return reader.getTextStart();
+    }
+
+    public int next() throws XMLStreamException {
+        return reader.next();
+    }
+
+    public int nextTag() throws XMLStreamException {
+        return reader.nextTag();
+    }
+
+    public void close() throws XMLStreamException {
+        reader.close();
+        try {
+            closeableSource.close();
+        } catch (IOException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    public boolean hasName() {
+        return reader.hasName();
+    }
+
+    public boolean hasNext() throws XMLStreamException {
+        return reader.hasNext();
+    }
+
+    public boolean hasText() {
+        return reader.hasText();
+    }
+
+    public boolean isCharacters() {
+        return reader.isCharacters();
+    }
+
+    public boolean isEndElement() {
+        return reader.isEndElement();
+    }
+
+    public boolean isStandalone() {
+        return reader.isStandalone();
+    }
+
+    public boolean isStartElement() {
+        return reader.isStartElement();
+    }
+
+    public boolean isWhiteSpace() {
+        return reader.isWhiteSpace();
+    }
+
+    public boolean standaloneSet() {
+        return reader.standaloneSet();
+    }
+
+    public char[] getTextCharacters() {
+        return reader.getTextCharacters();
+    }
+
+    public boolean isAttributeSpecified(int i) {
+        return reader.isAttributeSpecified(i);
+    }
+
+    public int getTextCharacters(int i, char[] chars, int i1, int i2) throws XMLStreamException {
+        return reader.getTextCharacters(i, chars, i1, i2);
+    }
+
+    public String getCharacterEncodingScheme() {
+        return reader.getCharacterEncodingScheme();
+    }
+
+    public String getElementText() throws XMLStreamException {
+        return reader.getElementText();
+    }
+
+    public String getEncoding() {
+        return reader.getEncoding();
+    }
+
+    public String getLocalName() {
+        return reader.getLocalName();
+    }
+
+    public String getNamespaceURI() {
+        return reader.getNamespaceURI();
+    }
+
+    public String getPIData() {
+        return reader.getPIData();
+    }
+
+    public String getPITarget() {
+        return reader.getPITarget();
+    }
+
+    public String getPrefix() {
+        return reader.getPrefix();
+    }
+
+    public String getText() {
+        return reader.getText();
+    }
+
+    public String getVersion() {
+        return reader.getVersion();
+    }
+
+    public String getAttributeLocalName(int i) {
+        return reader.getAttributeLocalName(i);
+    }
+
+    public String getAttributeNamespace(int i) {
+        return reader.getAttributeNamespace(i);
+    }
+
+    public String getAttributePrefix(int i) {
+        return reader.getAttributePrefix(i);
+    }
+
+    public String getAttributeType(int i) {
+        return reader.getAttributeType(i);
+    }
+
+    public String getAttributeValue(int i) {
+        return reader.getAttributeValue(i);
+    }
+
+    public String getNamespacePrefix(int i) {
+        return reader.getNamespacePrefix(i);
+    }
+
+    public String getNamespaceURI(int i) {
+        return reader.getNamespaceURI(i);
+    }
+
+    public NamespaceContext getNamespaceContext() {
+        return reader.getNamespaceContext();
+    }
+
+    public QName getName() {
+        return reader.getName();
+    }
+
+    public QName getAttributeName(int i) {
+        return reader.getAttributeName(i);
+    }
+
+    public Location getLocation() {
+        return reader.getLocation();
+    }
+
+    public Object getProperty(String s) throws IllegalArgumentException {
+        return reader.getProperty(s);
+    }
+
+    public void require(int i, String s, String s1) throws XMLStreamException {
+        reader.require(i, s, s1);
+    }
+
+    public String getNamespaceURI(String s) {
+        return reader.getNamespaceURI(s);
+    }
+
+    public String getAttributeValue(String s, String s1) {
+        return reader.getAttributeValue(s, s1);
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLReader.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLReader.java
new file mode 100644
index 0000000..aa24b76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLReader.java
@@ -0,0 +1,228 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+/**
+ * <p> XMLReader provides a high-level streaming parser interface
+ * for reading XML documents. </p>
+ *
+ * <p> The {@link #next} method is used to read events from the XML document. </p>
+ *
+ * <p> Each time it is called, {@link #next} returns the new state of the reader. </p>
+ *
+ * <p> Possible states are: BOF, the initial state, START, denoting the start
+ * tag of an element, END, denoting the end tag of an element, CHARS, denoting
+ * the character content of an element, PI, denoting a processing instruction,
+ * EOF, denoting the end of the document. </p>
+ *
+ * <p> Depending on the state the reader is in, one or more of the following
+ * query methods will be meaningful: {@link #getName}, {@link #getURI},
+ * {@link #getLocalName}, {@link #getAttributes}, {@link #getValue}. </p>
+ *
+ * <p> Elements visited by a XMLReader are tagged with unique IDs. The ID of the
+ * current element can be found by calling {@link #getElementId}. </p>
+ *
+ * <p> A XMLReader is always namespace-aware, and keeps track of the namespace
+ * declarations which are in scope at any time during streaming. The
+ * {@link #getURI(java.lang.String)} method can be used to find the URI
+ * associated to a given prefix in the current scope. </p>
+ *
+ * <p> XMLReaders can be created using a {@link XMLReaderFactory}. </p>
+ *
+ * <p> Some utility methods, {@link #nextContent} and {@link #nextElementContent}
+ * make it possible to ignore whitespace and processing instructions with
+ * minimum impact on the client code. </p>
+ *
+ * <p> Similarly, the {@link #skipElement} and {@link #skipElement(int elementId)}
+ * methods allow to skip to the end tag of an element ignoring all its content. </p>
+ *
+ * <p> Finally, the {@link #recordElement} method can be invoked when the XMLReader
+ * is positioned on the start tag of an element to record the element's contents
+ * so that they can be played back later. </p>
+ *
+ * @see XMLReaderFactory
+ *
+ * @author WS Development Team
+ */
+public interface XMLReader {
+    /**
+     * The initial state of a XMLReader.
+     */
+    public static final int BOF = 0;
+
+    /**
+     * The state denoting the start tag of an element.
+     */
+    public static final int START = 1;
+
+    /**
+     * The state denoting the end tag of an element.
+     */
+    public static final int END = 2;
+
+    /**
+     * The state denoting the character content of an element.
+     */
+    public static final int CHARS = 3;
+
+    /**
+     * The state denoting a processing instruction.
+     */
+    public static final int PI = 4;
+
+    /**
+     * The state denoting that the end of the document has been reached.
+     */
+    public static final int EOF = 5;
+
+    /**
+     * Return the next state of the XMLReader.
+     *
+     * The return value is one of: START, END, CHARS, PI, EOF.
+     */
+    public int next();
+
+    /*
+    * Return the next state of the XMLReader.
+    *
+    * <p> Whitespace character content and processing instructions are ignored. </p>
+    *
+    * <p> The return value is one of: START, END, CHARS, EOF. </p>
+    */
+    public int nextContent();
+
+    /**
+     * Return the next state of the XMLReader.
+     *
+     * <p> Whitespace character content, processing instructions are ignored.
+     * Non-whitespace character content triggers an exception. </p>
+     *
+     * <p> The return value is one of: START, END, EOF. </p>
+     */
+    public int nextElementContent();
+
+    /**
+     * Return the current state of the XMLReader.
+     *
+     */
+    public int getState();
+
+    /**
+     * Return the current qualified name.
+     *
+     * <p> Meaningful only when the state is one of: START, END. </p>
+     */
+    public QName getName();
+
+    /**
+     * Return the current URI.
+     *
+     * <p> Meaningful only when the state is one of: START, END. </p>
+     */
+    public String getURI();
+
+    /**
+     * Return the current local name.
+     *
+     * <p> Meaningful only when the state is one of: START, END, PI. </p>
+     */
+    public String getLocalName();
+
+    /**
+     * Return the current attribute list. In the jaxws implementation,
+     * this list also includes namespace declarations.
+     *
+     * <p> Meaningful only when the state is one of: START. </p>
+     *
+     * <p> The returned {@link Attributes} object belong to the XMLReader and is
+     * only guaranteed to be valid until the {@link #next} method is called,
+     * directly or indirectly.</p>
+     */
+    public Attributes getAttributes();
+
+    /**
+     * Return the current value.
+     *
+     * <p> Meaningful only when the state is one of: CHARS, PI. </p>
+     */
+    public String getValue();
+
+    /**
+     * Return the current element ID.
+     */
+    public int getElementId();
+
+    /**
+     * Return the current line number.
+     *
+     * <p> Due to aggressive parsing, this value may be off by a few lines. </p>
+     */
+    public int getLineNumber();
+
+    /**
+     * Return the URI for the given prefix.
+     *
+     * <p> If there is no namespace declaration in scope for the given
+     * prefix, return null. </p>
+     */
+    public String getURI(String prefix);
+
+    /**
+     * Return an iterator on all prefixes in scope, except for the default prefix.
+     *
+     */
+    public Iterator getPrefixes();
+
+    /**
+     * Records the current element and leaves the reader positioned on its end tag.
+     *
+     * <p> The XMLReader must be positioned on the start tag of the element.
+     * The returned reader will play back all events starting with the
+     * start tag of the element and ending with its end tag. </p>
+     */
+    public XMLReader recordElement();
+
+    /**
+     * Skip all nodes up to the end tag of the element with the current element ID.
+     */
+    public void skipElement();
+
+    /**
+     * Skip all nodes up to the end tag of the element with the given element ID.
+     */
+    public void skipElement(int elementId);
+
+    /**
+     * Close the XMLReader.
+     *
+     * <p> All subsequent calls to {@link #next} will return EOF. </p>
+     */
+    public void close();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLReaderException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLReaderException.java
new file mode 100644
index 0000000..449ae13
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLReaderException.java
@@ -0,0 +1,57 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * <p> XMLReaderException represents an exception that occurred while reading an
+ * XML document. </p>
+ *
+ * @see XMLReader
+ * @see JAXWSExceptionBase
+ *
+ * @author WS Development Team
+ */
+public class XMLReaderException extends JAXWSExceptionBase {
+
+    public XMLReaderException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public XMLReaderException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public XMLReaderException(Localizable arg) {
+        super("xmlreader.nestedError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.streaming";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderException.java
new file mode 100644
index 0000000..ce51423
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderException.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * <p> XMLStream ReaderException represents an exception that occurred while reading an
+ * XML document. </p>
+ *
+ * @see JAXWSExceptionBase
+ *
+ * @author WS Development Team
+ */
+public class XMLStreamReaderException extends JAXWSExceptionBase {
+
+    public XMLStreamReaderException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public XMLStreamReaderException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public XMLStreamReaderException(Localizable arg) {
+        super("xmlreader.nestedError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.streaming";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderFactory.java
new file mode 100644
index 0000000..713af62
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderFactory.java
@@ -0,0 +1,259 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import org.xml.sax.InputSource;
+
+import javax.xml.stream.XMLInputFactory;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.Reader;
+import java.lang.reflect.Constructor;
+import java.lang.reflect.Method;
+import java.net.URL;
+import java.net.MalformedURLException;
+
+import com.sun.xml.internal.ws.util.SunStAXReflection;
+import com.sun.xml.internal.ws.util.FastInfosetReflection;
+
+/**
+ * <p>A factory to create XML and FI parsers.</p>
+ *
+ * @author Santiago.PericasGeertsen@sun.com
+ */
+public class XMLStreamReaderFactory {
+
+    /**
+     * StAX input factory shared by all threads.
+     */
+    static XMLInputFactory xmlInputFactory;
+
+    /**
+     * FI stream reader for each thread.
+     */
+    static ThreadLocal fiStreamReader = new ThreadLocal();
+
+    /**
+     * Zephyr's stream reader for each thread.
+     */
+    static ThreadLocal xmlStreamReader = new ThreadLocal();
+
+    static {
+        // Use StAX pluggability layer to get factory instance
+        xmlInputFactory = XMLInputFactory.newInstance();
+        xmlInputFactory.setProperty(XMLInputFactory.IS_NAMESPACE_AWARE, Boolean.TRUE);
+
+        try {
+            // Turn OFF internal factory caching in Zephyr -- not thread safe
+            xmlInputFactory.setProperty("reuse-instance", Boolean.FALSE);
+        }
+        catch (IllegalArgumentException e) {
+            // falls through
+        }
+    }
+
+    // -- XML ------------------------------------------------------------
+
+    /**
+     * Returns a fresh StAX parser created from an InputSource. Use this
+     * method when concurrent instances are needed within a single thread.
+     *
+     * TODO: Reject DTDs?
+     */
+    public static XMLStreamReader createFreshXMLStreamReader(InputSource source,
+        boolean rejectDTDs) {
+        try {
+            synchronized (xmlInputFactory) {
+                // Char stream available?
+                if (source.getCharacterStream() != null) {
+                    return xmlInputFactory.createXMLStreamReader(
+                        source.getSystemId(), source.getCharacterStream());
+                }
+
+                // Byte stream available?
+                if (source.getByteStream() != null) {
+                    return xmlInputFactory.createXMLStreamReader(
+                        source.getSystemId(), source.getByteStream());
+                }
+
+                // Otherwise, open URI
+                return xmlInputFactory.createXMLStreamReader(source.getSystemId(),
+                    new URL(source.getSystemId()).openStream());
+            }
+        }
+        catch (Exception e) {
+            throw new XMLReaderException("stax.cantCreate",e);
+        }
+    }
+
+    /**
+     * This factory method would be used for example when caller wants to close the stream.
+     */
+    public static XMLStreamReader createFreshXMLStreamReader(String systemId, InputStream stream) {
+        try {
+            synchronized (xmlInputFactory) {
+                // Otherwise, open URI
+                return xmlInputFactory.createXMLStreamReader(systemId,
+                    stream);
+            }
+        }
+        catch (Exception e) {
+            throw new XMLReaderException("stax.cantCreate",e);
+        }
+    }
+
+    /**
+     * This factory method would be used for example when caller wants to close the stream.
+     */
+    public static XMLStreamReader createFreshXMLStreamReader(String systemId, Reader reader) {
+        try {
+            synchronized (xmlInputFactory) {
+                // Otherwise, open URI
+                return xmlInputFactory.createXMLStreamReader(systemId,
+                    reader);
+            }
+        }
+        catch (Exception e) {
+            throw new XMLReaderException("stax.cantCreate",e);
+        }
+    }
+
+
+
+    /**
+     * Returns a StAX parser from an InputStream.
+     *
+     * TODO: Reject DTDs?
+     */
+    public static XMLStreamReader createXMLStreamReader(InputStream in,
+        boolean rejectDTDs) {
+        return createXMLStreamReader(null, in, rejectDTDs);
+    }
+
+    /**
+     * Returns a StAX parser from an InputStream. Attemps to re-use parsers if
+     * underlying representation is Zephyr.
+     *
+     * TODO: Reject DTDs?
+     */
+    public static XMLStreamReader createXMLStreamReader(String systemId,
+        InputStream in, boolean rejectDTDs) {
+        try {
+            // If using Zephyr, try re-using the last instance
+            if (SunStAXReflection.XMLReaderImpl_setInputSource != null) {
+                Object xsr = xmlStreamReader.get();
+                if (xsr == null) {
+                    synchronized (xmlInputFactory) {
+                        xmlStreamReader.set(
+                            xsr = xmlInputFactory.createXMLStreamReader(systemId, in));
+                    }
+                }
+                else {
+                    SunStAXReflection.XMLReaderImpl_reset.invoke(xsr);
+                    InputSource inputSource = new InputSource(in);
+                    inputSource.setSystemId(systemId);
+                    SunStAXReflection.XMLReaderImpl_setInputSource.invoke(xsr, inputSource);
+                }
+                return (XMLStreamReader) xsr;
+            }
+            else {
+                synchronized (xmlInputFactory) {
+                    return xmlInputFactory.createXMLStreamReader(systemId, in);
+                }
+            }
+        } catch (Exception e) {
+            throw new XMLReaderException("stax.cantCreate",e);
+        }
+    }
+
+    /**
+     * Returns a StAX parser from a Reader. Attemps to re-use parsers if
+     * underlying representation is Zephyr.
+     *
+     * TODO: Reject DTDs?
+     */
+    public static XMLStreamReader createXMLStreamReader(Reader reader,
+        boolean rejectDTDs) {
+        try {
+            // If using Zephyr, try re-using the last instance
+            if (SunStAXReflection.XMLReaderImpl_setInputSource != null) {
+                Object xsr = xmlStreamReader.get();
+                if (xsr == null) {
+                    synchronized (xmlInputFactory) {
+                        xmlStreamReader.set(
+                            xsr = xmlInputFactory.createXMLStreamReader(reader));
+                    }
+                }
+                else {
+                    SunStAXReflection.XMLReaderImpl_reset.invoke(xsr);
+                    SunStAXReflection.XMLReaderImpl_setInputSource.invoke(xsr, new InputSource(reader));
+                }
+                return (XMLStreamReader) xsr;
+            }
+            else {
+                synchronized (xmlInputFactory) {
+                    return xmlInputFactory.createXMLStreamReader(reader);
+                }
+            }
+        }
+        catch (Exception e) {
+            throw new XMLReaderException("stax.cantCreate",e);
+        }
+    }
+
+    // -- Fast Infoset ---------------------------------------------------
+
+    public static XMLStreamReader createFIStreamReader(InputSource source) {
+        return createFIStreamReader(source.getByteStream());
+    }
+
+    /**
+     * Returns the FI parser allocated for this thread.
+     */
+    public static XMLStreamReader createFIStreamReader(InputStream in) {
+        // Check if compatible implementation of FI was found
+        if (FastInfosetReflection.fiStAXDocumentParser_new == null) {
+            throw new XMLReaderException("fastinfoset.noImplementation");
+        }
+
+        try {
+            Object sdp = fiStreamReader.get();
+            if (sdp == null) {
+                // Do not use StAX pluggable layer for FI
+                fiStreamReader.set(sdp = FastInfosetReflection.fiStAXDocumentParser_new.newInstance());
+                FastInfosetReflection.fiStAXDocumentParser_setStringInterning.invoke(sdp, Boolean.TRUE);
+            }
+            FastInfosetReflection.fiStAXDocumentParser_setInputStream.invoke(sdp, in);
+            return (XMLStreamReader) sdp;
+        }
+        catch (Exception e) {
+            throw new XMLStreamReaderException(e);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderUtil.java
new file mode 100644
index 0000000..d67765d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamReaderUtil.java
@@ -0,0 +1,449 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.SOAPConstants;
+
+import static javax.xml.stream.XMLStreamConstants.*;
+import java.util.Map;
+import java.util.HashMap;
+
+/**
+ * <p> XMLStreamReaderUtil provides some utility methods intended to be used
+ * in conjunction with a StAX XMLStreamReader. </p>
+ *
+ * @author WS Development Team
+ */
+public class XMLStreamReaderUtil {
+
+    private XMLStreamReaderUtil() {
+    }
+
+    public static void close(XMLStreamReader reader) {
+        try {
+            reader.close();
+        }
+        catch (XMLStreamException e) {
+            throw wrapException(e);
+        }
+    }
+
+    public static int next(XMLStreamReader reader) {
+        try {
+            int readerEvent = reader.next();
+
+            while (readerEvent != END_DOCUMENT) {
+                switch (readerEvent) {
+                    case START_ELEMENT:
+                    case END_ELEMENT:
+                    case CDATA:
+                    case CHARACTERS:
+                    case PROCESSING_INSTRUCTION:
+                        return readerEvent;
+                    default:
+                        // falls through ignoring event
+                }
+                readerEvent = reader.next();
+            }
+
+            return readerEvent;
+        }
+        catch (XMLStreamException e) {
+            throw wrapException(e);
+        }
+    }
+
+    public static int nextElementContent(XMLStreamReader reader) {
+        int state = nextContent(reader);
+        if (state == CHARACTERS) {
+            throw new XMLStreamReaderException(
+                "xmlreader.unexpectedCharacterContent", reader.getText());
+        }
+        return state;
+    }
+
+    public static int nextContent(XMLStreamReader reader) {
+        for (;;) {
+            int state = next(reader);
+            switch (state) {
+                case START_ELEMENT:
+                case END_ELEMENT:
+                case END_DOCUMENT:
+                    return state;
+                case CHARACTERS:
+                    if (!reader.isWhiteSpace()) {
+                        return CHARACTERS;
+                    }
+            }
+        }
+    }
+
+    /**
+     * Skip current element, leaving the cursor at END_ELEMENT of
+     * current element.
+     */
+    public static void skipElement(XMLStreamReader reader) {
+        assert reader.getEventType() == START_ELEMENT;
+        skipTags(reader, true);
+        assert reader.getEventType() == END_ELEMENT;
+    }
+
+    /**
+     * Skip following siblings, leaving cursor at END_ELEMENT of
+     * parent element.
+     */
+    public static void skipSiblings(XMLStreamReader reader, QName parent) {
+        skipTags(reader, reader.getName().equals(parent));
+        assert reader.getEventType() == END_ELEMENT;
+    }
+
+    private static void skipTags(XMLStreamReader reader, boolean exitCondition) {
+        try {
+            int state, tags = 0;
+            while ((state = reader.next()) != END_DOCUMENT) {
+                if (state == START_ELEMENT) {
+                    tags++;
+                }
+                else if (state == END_ELEMENT) {
+                    if (tags == 0 && exitCondition) return;
+                    tags--;
+                }
+            }
+        }
+        catch (XMLStreamException e) {
+            throw wrapException(e);
+        }
+    }
+
+    /*
+    * Get the text of an element
+    */
+    public static String getElementText(XMLStreamReader reader) {
+        try {
+            return reader.getElementText();
+        } catch (XMLStreamException e) {
+            throw wrapException(e);
+        }
+    }
+
+    /*
+    * Get a QName with 'someUri' and 'localname' from an
+    * element of qname type:
+    * <xyz xmlns:ns1="someUri">ns1:localname</xyz>
+    */
+    public static QName getElementQName(XMLStreamReader reader) {
+        try {
+            String text = reader.getElementText();
+            String prefix = text.substring(0, text.indexOf(':'));
+            String namespaceURI = reader.getNamespaceURI(prefix);
+            if (namespaceURI == null) {
+                namespaceURI = "";
+            }
+            String localPart = text.substring(
+                text.indexOf(':') + 1,  text.length());
+            return new QName(namespaceURI, localPart);
+        } catch (XMLStreamException e) {
+            throw wrapException(e);
+        }
+    }
+
+    /**
+     * Read all attributes into an data structure. Note that this method cannot
+     * be called multiple times to get the same list of attributes.
+     */
+    public static Attributes getAttributes(XMLStreamReader reader) {
+        return (reader.getEventType() == reader.START_ELEMENT ||
+                reader.getEventType() == reader.ATTRIBUTE) ?
+                new AttributesImpl(reader) : null;
+    }
+
+    public static void verifyReaderState(XMLStreamReader reader, int expectedState) {
+        int state = reader.getEventType();
+        if (state != expectedState) {
+            throw new XMLStreamReaderException(
+                "xmlreader.unexpectedState",
+                new Object[] {
+                    getStateName(expectedState), getStateName(state) });
+        }
+    }
+
+    public static void verifyTag(XMLStreamReader reader, QName name) {
+        if (!name.equals(reader.getName())) {
+            throw new XMLStreamReaderException(
+                "xmlreader.unexpectedState.tag",
+                    name,
+                    reader.getName());
+        }
+    }
+
+    public static String getStateName(XMLStreamReader reader) {
+        return getStateName(reader.getEventType());
+    }
+
+    public static String getStateName(int state) {
+        switch (state) {
+            case ATTRIBUTE:
+                return "ATTRIBUTE";
+            case CDATA:
+                return "CDATA";
+            case CHARACTERS:
+                return "CHARACTERS";
+            case COMMENT:
+                return "COMMENT";
+            case DTD:
+                return "DTD";
+            case END_DOCUMENT:
+                return "END_DOCUMENT";
+            case END_ELEMENT:
+                return "END_ELEMENT";
+            case ENTITY_DECLARATION:
+                return "ENTITY_DECLARATION";
+            case ENTITY_REFERENCE:
+                return "ENTITY_REFERENCE";
+            case NAMESPACE:
+                return "NAMESPACE";
+            case NOTATION_DECLARATION:
+                return "NOTATION_DECLARATION";
+            case PROCESSING_INSTRUCTION:
+                return "PROCESSING_INSTRUCTION";
+            case SPACE:
+                return "SPACE";
+            case START_DOCUMENT:
+                return "START_DOCUMENT";
+            case START_ELEMENT:
+                return "START_ELEMENT";
+            default :
+                return "UNKNOWN";
+        }
+    }
+
+    private static XMLStreamReaderException wrapException(XMLStreamException e) {
+        return new XMLStreamReaderException("xmlreader.ioException",e);
+    }
+
+    // -- Auxiliary classes ----------------------------------------------
+
+    /**
+     * AttributesImpl class copied from old StAXReader. This class is used to implement
+     * getAttributes() on a StAX Reader.
+     */
+    public static class AttributesImpl implements Attributes {
+
+        static final String XMLNS_NAMESPACE_URI = "http://www.w3.org/2000/xmlns/";
+
+        static class AttributeInfo {
+
+            private QName name;
+            private String value;
+
+            public AttributeInfo(QName name, String value) {
+                this.name = name;
+                if (value == null) {
+                    // e.g., <return xmlns=""> -- stax returns null
+                    this.value = "";
+                } else {
+                    this.value = value;
+                }
+            }
+
+            QName getName() {
+                return name;
+            }
+
+            String getValue() {
+                return value;
+            }
+
+            /*
+             * Return "xmlns:" as part of name if namespace.
+             */
+            String getLocalName() {
+                if (isNamespaceDeclaration()) {
+                    if (name.getLocalPart().equals("")) {
+                        return "xmlns";
+                    }
+                    return "xmlns:" + name.getLocalPart();
+                }
+                return name.getLocalPart();
+            }
+
+            boolean isNamespaceDeclaration() {
+                return (name.getNamespaceURI() == XMLNS_NAMESPACE_URI);
+            }
+        }
+
+        // stores qname and value for each attribute
+        AttributeInfo [] atInfos;
+
+        /*
+         * Will create a list that contains the namespace declarations
+         * as well as the other attributes.
+         */
+        public AttributesImpl(XMLStreamReader reader) {
+            if (reader == null) {
+
+                // this is the case when we call getAttributes() on the
+                // reader when it is not on a start tag
+                atInfos = new AttributeInfo[0];
+            } else {
+
+                // this is the normal case
+                int index = 0;
+                String namespacePrefix = null;
+                int namespaceCount = reader.getNamespaceCount();
+                int attributeCount = reader.getAttributeCount();
+                atInfos = new AttributeInfo[namespaceCount + attributeCount];
+                for (int i=0; i<namespaceCount; i++) {
+                    namespacePrefix = reader.getNamespacePrefix(i);
+
+                    // will be null if default prefix. QName can't take null
+                    if (namespacePrefix == null) {
+                        namespacePrefix = "";
+                    }
+                    atInfos[index++] = new AttributeInfo(
+                        new QName(XMLNS_NAMESPACE_URI,
+                            namespacePrefix,
+                            "xmlns"),
+                        reader.getNamespaceURI(i));
+                }
+                for (int i=0; i<attributeCount; i++) {
+                    atInfos[index++] = new AttributeInfo(
+                        reader.getAttributeName(i),
+                        reader.getAttributeValue(i));
+                }
+            }
+        }
+
+        public int getLength() {
+            return atInfos.length;
+        }
+
+        public String getLocalName(int index) {
+            if (index >= 0 && index < atInfos.length) {
+                return atInfos[index].getLocalName();
+            }
+            return null;
+        }
+
+        public QName getName(int index) {
+            if (index >= 0 && index < atInfos.length) {
+                return atInfos[index].getName();
+            }
+            return null;
+        }
+
+        public String getPrefix(int index) {
+            if (index >= 0 && index < atInfos.length) {
+                return atInfos[index].getName().getPrefix();
+            }
+            return null;
+        }
+
+        public String getURI(int index) {
+            if (index >= 0 && index < atInfos.length) {
+                return atInfos[index].getName().getNamespaceURI();
+            }
+            return null;
+        }
+
+        public String getValue(int index) {
+            if (index >= 0 && index < atInfos.length) {
+                return atInfos[index].getValue();
+            }
+            return null;
+        }
+
+        public String getValue(QName name) {
+            int index = getIndex(name);
+            if (index != -1) {
+                return atInfos[index].getValue();
+            }
+            return null;
+        }
+
+        public String getValue(String localName) {
+            int index = getIndex(localName);
+            if (index != -1) {
+                return atInfos[index].getValue();
+            }
+            return null;
+        }
+
+        public String getValue(String uri, String localName) {
+            int index = getIndex(uri, localName);
+            if (index != -1) {
+                return atInfos[index].getValue();
+            }
+            return null;
+        }
+
+        public boolean isNamespaceDeclaration(int index) {
+            if (index >= 0 && index < atInfos.length) {
+                return atInfos[index].isNamespaceDeclaration();
+            }
+            return false;
+        }
+
+        public int getIndex(QName name) {
+            for (int i=0; i<atInfos.length; i++) {
+                if (atInfos[i].getName().equals(name)) {
+                    return i;
+                }
+            }
+            return -1;
+        }
+
+        public int getIndex(String localName) {
+            for (int i=0; i<atInfos.length; i++) {
+                if (atInfos[i].getName().getLocalPart().equals(localName)) {
+                    return i;
+                }
+            }
+            return -1;
+        }
+
+        public int getIndex(String uri, String localName) {
+            QName qName;
+            for (int i=0; i<atInfos.length; i++) {
+                qName = atInfos[i].getName();
+                if (qName.getNamespaceURI().equals(uri) &&
+                    qName.getLocalPart().equals(localName)) {
+
+                    return i;
+                }
+            }
+            return -1;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterException.java
new file mode 100644
index 0000000..32f9383
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterException.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * <p> XMLWriterException represents an exception that occurred while writing
+ * an XML document. </p>
+ *
+ * @see JAXWSExceptionBase
+ *
+ * @author WS Development Team
+ */
+public class XMLStreamWriterException extends JAXWSExceptionBase {
+
+    public XMLStreamWriterException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public XMLStreamWriterException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public XMLStreamWriterException(Localizable arg) {
+        super("xmlwriter.nestedError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.streaming";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterFactory.java
new file mode 100644
index 0000000..db86418
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterFactory.java
@@ -0,0 +1,118 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import com.sun.xml.internal.ws.util.FastInfosetReflection;
+import java.io.OutputStream;
+import java.lang.reflect.Method;
+import java.lang.reflect.Constructor;
+
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLOutputFactory;
+
+/**
+ * <p>A factory to create XML and FI serializers.</p>
+ *
+ * @author Santiago.PericasGeertsen@sun.com
+ */
+public class XMLStreamWriterFactory {
+
+    /**
+     * StAX input factory shared by all threads.
+     */
+    static XMLOutputFactory xmlOutputFactory;
+
+    /**
+     * FI stream writer for each thread.
+     */
+    static ThreadLocal fiStreamWriter = new ThreadLocal();
+
+    static {
+        // Use StAX pluggability layer to get factory instance
+        xmlOutputFactory = XMLOutputFactory.newInstance();
+    }
+
+    // -- XML ------------------------------------------------------------
+
+    public static XMLStreamWriter createXMLStreamWriter(OutputStream out) {
+        return createXMLStreamWriter(out, "UTF-8");
+    }
+
+    public static XMLStreamWriter createXMLStreamWriter(OutputStream out, String encoding) {
+        return createXMLStreamWriter(out, encoding, true);
+    }
+
+    /**
+     * TODO: declare?
+     * TODO: Use thread locals and reset() when using Zephyr
+     */
+    public static XMLStreamWriter createXMLStreamWriter(OutputStream out,
+        String encoding, boolean declare)
+    {
+        try {
+            // Assume StAX factory implementation is not thread-safe
+            synchronized (xmlOutputFactory) {
+                return xmlOutputFactory.createXMLStreamWriter(out, encoding);
+            }
+        }
+        catch (Exception e) {
+            throw new XMLReaderException("stax.cantCreate",e);
+        }
+    }
+
+    // -- Fast Infoset ---------------------------------------------------
+
+    public static XMLStreamWriter createFIStreamWriter(OutputStream out) {
+        return createFIStreamWriter(out, "UTF-8");
+    }
+
+    public static XMLStreamWriter createFIStreamWriter(OutputStream out, String encoding) {
+        return createFIStreamWriter(out, encoding, true);
+    }
+
+    public static XMLStreamWriter createFIStreamWriter(OutputStream out,
+        String encoding, boolean declare)
+    {
+        // Check if compatible implementation of FI was found
+        if (FastInfosetReflection.fiStAXDocumentSerializer_new == null) {
+            throw new XMLReaderException("fastinfoset.noImplementation");
+        }
+
+        try {
+            Object sds = fiStreamWriter.get();
+            if (sds == null) {
+                // Do not use StAX pluggable layer for FI
+                fiStreamWriter.set(sds = FastInfosetReflection.fiStAXDocumentSerializer_new.newInstance());
+            }
+            FastInfosetReflection.fiStAXDocumentSerializer_setOutputStream.invoke(sds, out);
+            FastInfosetReflection.fiStAXDocumentSerializer_setEncoding.invoke(sds, encoding);
+            return (XMLStreamWriter) sds;
+        }  catch (Exception e) {
+            throw new XMLStreamWriterException(e);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterUtil.java
new file mode 100644
index 0000000..4050522
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/streaming/XMLStreamWriterUtil.java
@@ -0,0 +1,71 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.streaming;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.stream.XMLStreamException;
+
+/**
+ * <p>XMLStreamWriterUtil provides some utility methods intended to be used
+ * in conjunction with a StAX XMLStreamWriter. </p>
+ *
+ * @author Santiago.PericasGeertsen@sun.com
+ */
+public class XMLStreamWriterUtil {
+
+    private XMLStreamWriterUtil() {
+    }
+
+
+    public static String encodeQName(XMLStreamWriter writer, QName qname,
+        PrefixFactory prefixFactory)
+    {
+        // NOTE: Here it is assumed that we do not serialize using default
+        // namespace declarations and therefore that writer.getPrefix will
+        // never return ""
+
+        try {
+            String namespaceURI = qname.getNamespaceURI();
+            String localPart = qname.getLocalPart();
+
+            if (namespaceURI == null || namespaceURI.equals("")) {
+                return localPart;
+            }
+            else {
+                String prefix = writer.getPrefix(namespaceURI);
+                if (prefix == null) {
+                    prefix = prefixFactory.getPrefix(namespaceURI);
+                    writer.writeNamespace(prefix, namespaceURI);
+                }
+                return prefix + ":" + localPart;
+            }
+        }
+        catch (XMLStreamException e) {
+            throw new RuntimeException(e);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/Headers.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/Headers.java
new file mode 100644
index 0000000..fcad032
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/Headers.java
@@ -0,0 +1,213 @@
+
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport;
+
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.LinkedList;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.io.*;
+
+/**
+ * HTTP request and response headers are represented by this class which implements
+ * the interface {@link java.util.Map}&lt;
+ * {@link java.lang.String},{@link java.util.List}&lt;{@link java.lang.String}&gt;&gt;.
+ * The keys are case-insensitive Strings representing the header names and
+ * the value associated with each key is a {@link List}&lt;{@link String}&gt; with one
+ * element for each occurence of the header name in the request or response.
+ * <p>
+ * For example, if a response header instance contains one key "HeaderName" with two values "value1 and value2"
+ * then this object is output as two header lines:
+ * <blockquote><pre>
+ * HeaderName: value1
+ * HeaderName: value2
+ * </blockquote></pre>
+ * <p>
+ * All the normal {@link java.util.Map} methods are provided, but the following
+ * additional convenience methods are most likely to be used:
+ * <ul>
+ * <li>{@link #getFirst(String)} returns a single valued header or the first value of
+ * a multi-valued header.</li>
+ * <li>{@link #add(String,String)} adds the given header value to the list for the given key</li>
+ * <li>{@link #set(String,String)} sets the given header field to the single value given
+ * overwriting any existing values in the value list.
+ * </ul><p>
+ * All methods in this class accept <code>null</code> values for keys and values. However, null
+ * keys will never will be present in HTTP request headers, and will not be output/sent in response headers.
+ * Null values can be represented as either a null entry for the key (i.e. the list is null) or
+ * where the key has a list, but one (or more) of the list's values is null. Null values are output
+ * as a header line containing the key but no associated value.
+ * @since 1.6
+ */
+public class Headers implements Map<String,List<String>> {
+
+    HashMap<String,List<String>> map;
+
+    public Headers () {
+        map = new HashMap<String,List<String>>(32);
+    }
+
+    /* Normalize the key by converting to following form.
+     * First char upper case, rest lower case.
+     * key is presumed to be ASCII
+     */
+    private String normalize (String key) {
+        if (key == null) {
+            return null;
+        }
+        int len = key.length();
+        if (len == 0) {
+            return key;
+        }
+        char[] b = new char [len];
+        String s = null;
+            b = key.toCharArray();
+            if (b[0] >= 'a' && b[0] <= 'z') {
+                b[0] = (char)(b[0] - ('a' - 'A'));
+            }
+            for (int i=1; i<len; i++) {
+                if (b[i] >= 'A' && b[i] <= 'Z') {
+                    b[i] = (char) (b[i] + ('a' - 'A'));
+                }
+            }
+            s = new String (b);
+        return s;
+    }
+
+    public int size() {
+        return map.size();
+    }
+
+    public boolean isEmpty() {
+        return map.isEmpty();
+    }
+
+    public boolean containsKey(Object key) {
+        if (key == null) {
+            return false;
+        }
+        if (!(key instanceof String)) {
+            return false;
+        }
+        return map.containsKey (normalize((String)key));
+    }
+
+    public boolean containsValue(Object value) {
+        return map.containsValue(value);
+    }
+
+    public List<String> get(Object key) {
+        return map.get(normalize((String)key));
+    }
+
+    /**
+     * returns the first value from the List of String values
+     * for the given key (if at least one exists).
+     * @param key the key to search for
+     * @return the first string value associated with the key
+     */
+    public String getFirst (String key) {
+        List<String> l = map.get(normalize((String)key));
+        if (l == null) {
+            return null;
+        }
+        return l.get(0);
+    }
+
+    public List<String> put(String key, List<String> value) {
+        return map.put (normalize(key), value);
+    }
+
+    /**
+     * adds the given value to the list of headers
+     * for the given key. If the mapping does not
+     * already exist, then it is created
+     * @param key the header name
+     * @param value the header value to add to the header
+     */
+    public void add (String key, String value) {
+        String k = normalize(key);
+        List<String> l = map.get(k);
+        if (l == null) {
+            l = new LinkedList<String>();
+            map.put(k,l);
+        }
+        l.add (value);
+    }
+
+    /**
+     * sets the given value as the sole header value
+     * for the given key. If the mapping does not
+     * already exist, then it is created
+     * @param key the header name
+     * @param value the header value to set.
+     */
+    public void set (String key, String value) {
+        LinkedList<String> l = new LinkedList<String>();
+        l.add (value);
+        put (key, l);
+    }
+
+
+    public List<String> remove(Object key) {
+        return map.remove(normalize((String)key));
+    }
+
+    public void putAll(Map<? extends String,? extends List<String>> t)  {
+        map.putAll (t);
+    }
+
+    public void clear() {
+        map.clear();
+    }
+
+    public Set<String> keySet() {
+        return map.keySet();
+    }
+
+    public Collection<List<String>> values() {
+        return map.values();
+    }
+
+    public Set<Map.Entry<String, List<String>>> entrySet() {
+        return map.entrySet();
+    }
+
+    public boolean equals(Object o) {
+        return map.equals(o);
+    }
+
+    public int hashCode() {
+        return map.hashCode();
+    }
+
+    public String toString() {
+        return map.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/WSConnectionImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/WSConnectionImpl.java
new file mode 100644
index 0000000..b7334a3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/WSConnectionImpl.java
@@ -0,0 +1,189 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport;
+
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.nio.ByteBuffer;
+import java.util.List;
+import java.util.ArrayList;
+import java.util.Map;
+import java.util.HashMap;
+
+import com.sun.xml.internal.ws.client.ClientTransportException;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+
+/**
+ * Abstract class for WSConnection. All client-side and server-side
+ * transports should extend this class and override appropriate methods.
+ *
+ * @author WS Development Team
+ */
+public abstract class WSConnectionImpl implements WSConnection {
+    Map<String, List<String>> headers = null;
+    public OutputStream debugStream = null;
+    public OutputStream outputStream = null;
+    public InputStream inputStream = null;
+    int statusCode;
+
+    /** Creates a new instance of WSConnectionImpl */
+    public WSConnectionImpl () {
+    }
+
+    public int getStatus () {
+        return statusCode;
+    }
+
+    public void setStatus (int statusCode) {
+        this.statusCode = statusCode;
+    }
+
+    public OutputStream getDebug () {
+        return debugStream;
+    }
+
+    /**
+     * @return outputStream
+     *
+     * Returns the OutputStream on which the outbound message is written.
+     * Any stream or connection initialization, pre-processing is done here.
+     */
+    public OutputStream getOutput() {
+        return outputStream;
+    }
+
+    /**
+     * @return inputStream
+     *
+     * Returns the InputStream on which the inbound message is received.
+     * Any post-processing of message is done here.
+     */
+    public InputStream getInput() {
+        return inputStream;
+    }
+
+    public Map<String, List<String>> getHeaders () {
+        return headers;
+    }
+
+    public void setHeaders (Map<String, List<String>> headers) {
+        this.headers = headers;
+    }
+
+    /**
+     * Write connection headers in HTTP syntax using \r\n as a
+     * separator.
+     */
+    public void writeHeaders(OutputStream os) {
+        try {
+            byte[] newLine = "\r\n".getBytes("us-ascii");
+
+            // Write all headers ala HTTP (only first list entry serialized)
+            Map<String, List<String>> headers = getHeaders();
+            for (String header : headers.keySet()) {
+                os.write((header + ":" +
+                    headers.get(header).get(0)).getBytes("us-ascii"));
+                os.write(newLine);
+            }
+
+            // Write empty line as in HTTP
+            os.write(newLine);
+        }
+        catch (Exception ex) {
+            throw new ClientTransportException("local.client.failed",ex);
+        }
+    }
+
+    /**
+     * Read and consume connection headers in HTTP syntax using
+     * \r\n as a separator.
+     */
+    public void readHeaders(InputStream is) {
+        try {
+            int c1, c2;
+            StringBuffer line = new StringBuffer();
+
+            if (headers == null) {
+                headers = new HashMap<String, List<String>>();
+            }
+            else {
+                headers.clear();
+            }
+
+            // Read headers until finding a \r\n line
+            while ((c1 = is.read()) != -1) {
+                if (c1 == '\r') {
+                    c2 = is.read();
+                    assert c2 != -1;
+
+                    if (c2 == '\n') {
+                        String s = line.toString();
+                        if (s.length() == 0) {
+                            break;  // found \r\n line
+                        }
+                        else {
+                            int k  = s.indexOf(':');
+                            assert k > 0;
+                            ArrayList<String> value = new ArrayList<String>();
+                            value.add(s.substring(k + 1));
+                            headers.put(s.substring(0, k), value);
+                            line.setLength(0);      // clear line buffer
+                        }
+                    }
+                    else {
+                        line.append((char) c1).append((char) c2);
+                    }
+                }
+                else {
+                    line.append((char) c1);
+                }
+            }
+        }
+        catch (Exception ex) {
+            throw new ClientTransportException("local.client.failed",ex);
+        }
+    }
+
+    public void closeOutput() {
+        try {
+            if (outputStream != null) {
+                outputStream.flush();
+                outputStream.close();
+            }
+        } catch (IOException ex) {
+            ex.printStackTrace();
+        }
+    }
+
+    public void closeInput() {
+    }
+
+    public void close() {
+
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/CookieJar.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/CookieJar.java
new file mode 100644
index 0000000..103e69d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/CookieJar.java
@@ -0,0 +1,416 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.client;
+
+import java.net.HttpURLConnection;
+import java.net.URL;
+import java.net.URLConnection;
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.util.Vector;
+
+/**
+ * Generic class to hold onto HTTP cookies.  Can record, retrieve, and
+ * persistently store cookies associated with particular URLs.
+ *
+ * @author WS Development Team
+ */
+public class CookieJar {
+
+    // The representation of cookies is relatively simple right now:
+    // a hash table with key being the domain and the value being
+    // a vector of cookies for that domain.
+    // REMIND: create this on demand in the future
+    private transient Hashtable<String,Vector<HttpCookie>> cookieJar = new Hashtable<String, Vector<HttpCookie>>();
+
+    /**
+     * Create a new, empty cookie jar.
+     */
+    public CookieJar() {
+    }
+
+    /**
+     * Records any cookies which have been sent as part of an HTTP response.
+     * The connection parameter must be already have been opened, so that
+     * the response headers are available.  It's ok to pass a non-HTTP
+     * URL connection, or one which does not have any set-cookie headers.
+     */
+
+
+    public synchronized void recordAnyCookies(URLConnection connection) {
+
+        HttpURLConnection httpConn = (HttpURLConnection) connection;
+        String headerKey;
+
+        for (int hi = 1;
+            (headerKey = httpConn.getHeaderFieldKey(hi)) != null;
+            hi++) {
+            if (headerKey.equalsIgnoreCase("set-cookie")) {
+                String cookieValue = httpConn.getHeaderField(hi);
+
+                recordCookie(httpConn, cookieValue);
+            }
+        }
+    }
+
+    /**
+     * Create a cookie from the cookie, and use the HttpURLConnection to
+     * fill in unspecified values in the cookie with defaults.
+     */
+    private void recordCookie(HttpURLConnection httpConn, String cookieValue) {
+
+        HttpCookie cookie = new HttpCookie(httpConn.getURL(), cookieValue);
+
+        // First, check to make sure the cookie's domain matches the
+        // server's, and has the required number of '.'s
+        String twodot[] = { "com", "edu", "net", "org", "gov", "mil", "int" };
+        String domain = cookie.getDomain();
+
+        if (domain == null) {
+            return;
+        }
+
+        domain = domain.toLowerCase();
+
+        String host = httpConn.getURL().getHost();
+
+        host = host.toLowerCase();
+
+        boolean domainOK = host.equals(domain);
+
+        if (!domainOK && host.endsWith(domain)) {
+            int dotsNeeded = 2;
+
+            for (int i = 0; i < twodot.length; i++) {
+                if (domain.endsWith(twodot[i])) {
+                    dotsNeeded = 1;
+                }
+            }
+
+            int lastChar = domain.length();
+
+            for (;(lastChar > 0) && (dotsNeeded > 0); dotsNeeded--) {
+                lastChar = domain.lastIndexOf('.', lastChar - 1);
+            }
+
+            if (lastChar > 0) {
+                domainOK = true;
+            }
+        }
+
+        if (domainOK) {
+            recordCookie(cookie);
+        }
+    }
+
+    /**
+     * Record the cookie in the in-memory container of cookies.  If there
+     * is already a cookie which is in the exact same domain with the
+     * exact same
+     */
+    private void recordCookie(HttpCookie cookie) {
+        recordCookieToJar(cookie, cookieJar, true);
+    }
+
+
+    /**
+     * Adds a Cookie for a given URL to the Cookie Jar.
+     * <P>
+     * New connections to the given URL will include the Cookie.
+     * <P>
+     * It allows to add Cookie information, to the Cookie jar, received
+     * by other mean.
+     * <P>
+     *
+     * @param url the URL to bind the Cookie to.
+     *
+     * @param cookieHeader String defining the Cookie:
+     *        <P>
+     *        &lt;name&gt;=&lt;value&gt;[;expires=<WHEN>]
+     *        [;path=<PATH>][;domain=<DOMAIN>][;secure]
+     *        <P>
+     *        Refer to <A HREF=
+     *          "http://home.netscape.com/newsref/std/cookie_spec.htm">
+     *        Netscape Cookie specification</A> for the complete documentation.
+     *
+     */
+    private void setCookie(URL url, String cookieHeader) {
+
+        HttpCookie cookie = new HttpCookie(url, cookieHeader);
+
+        this.recordCookie(cookie);
+    }
+
+    //
+    // Records the given cookie to the desired jar.  If doNotify is true,
+    // tell globals to inform interested parties.  It *only* makes since for
+    // doNotify to be true if jar is the static jar (i.e. Cookies.cookieJar).
+    //
+    //
+    private void recordCookieToJar(
+        HttpCookie cookie,
+        Hashtable<String,Vector<HttpCookie>> jar,
+        boolean doNotify) {
+
+        if (shouldRejectCookie(cookie)) {
+            return;
+        }
+
+        String domain = cookie.getDomain().toLowerCase();
+        Vector<HttpCookie> cookieList = jar.get(domain);
+
+        if (cookieList == null) {
+            cookieList = new Vector<HttpCookie>();
+        }
+
+        if (addOrReplaceCookie(cookieList, cookie, doNotify)) {
+            jar.put(domain, cookieList);
+        }
+    }
+
+    /**
+     * Scans the vector of cookies looking for an exact match with the
+     * given cookie.  Replaces it if there is one, otherwise adds
+     * one at the end.  The vector is presumed to have cookies which all
+     * have the same domain, so the domain of the cookie is not checked.
+     * <p>
+     * If doNotify is true, we'll do a vetoable notification of changing the
+     * cookie.  This <b>only</b> makes since if the jar being operated on
+     * is Cookies.cookieJar.
+     * <p>
+     * If this is called, it is assumed that the cookie jar is exclusively
+     * held by the current thread.
+     *
+     * @return true if the cookie is actually set
+     */
+    private boolean addOrReplaceCookie(
+        Vector<HttpCookie> cookies,
+        final HttpCookie cookie,
+        boolean doNotify) {
+
+        int numCookies = cookies.size();
+        String path = cookie.getPath();
+        String name = cookie.getName();
+        HttpCookie replaced = null;
+        int replacedIndex = -1;
+
+        for (int i = 0; i < numCookies; i++) {
+            HttpCookie existingCookie = cookies.elementAt(i);
+            String existingPath = existingCookie.getPath();
+
+            if (path.equals(existingPath)) {
+                String existingName = existingCookie.getName();
+
+                if (name.equals(existingName)) {
+
+                    // need to replace this one!
+                    replaced = existingCookie;
+                    replacedIndex = i;
+
+                    break;
+                }
+            }
+        }
+
+        // Do the replace
+        if (replaced != null) {
+            cookies.setElementAt(cookie, replacedIndex);
+        } else {
+            cookies.addElement(cookie);
+        }
+
+        return true;
+    }
+
+    /**
+     * Predicate function which returns true if the cookie appears to be
+     * invalid somehow and should not be added to the cookie set.
+     */
+    private boolean shouldRejectCookie(HttpCookie cookie) {
+
+        // REMIND: implement per http-state-mgmt Internet Draft
+        return false;
+    }
+
+    // ab oct/17/01 - added synchronized
+    public synchronized void applyRelevantCookies(URLConnection connection) {
+        this.applyRelevantCookies(connection.getURL(), connection);
+    }
+
+    private void applyRelevantCookies(URL url, URLConnection connection) {
+
+        HttpURLConnection httpConn = (HttpURLConnection) connection;
+        String host = url.getHost();
+
+        applyCookiesForHost(host, url, httpConn);
+
+        // REMIND: should be careful about IP addresses here.
+        int index;
+
+        while ((index = host.indexOf('.', 1)) >= 0) {
+
+            // trim off everything up to, and including the dot.
+            host = host.substring(index + 1);
+
+            applyCookiesForHost(host, url, httpConn);
+        }
+    }
+
+    /**
+     * Host may be a FQDN, or a partial domain name starting with a dot.
+     * Adds any cookies which match the host and path to the
+     * cookie set on the URL connection.
+     */
+    private void applyCookiesForHost(
+        String host,
+        URL url,
+        HttpURLConnection httpConn) {
+
+        //System.out.println("X0"+cookieJar.size());
+        Vector<HttpCookie> cookieList = cookieJar.get(host);
+
+        if (cookieList == null) {
+
+            // Hax.debugln("no matching hosts" + host);
+            return;
+        }
+
+        //System.out.println("X1"+cookieList.size());
+        String path = url.getFile();
+        int queryInd = path.indexOf('?');
+
+        if (queryInd > 0) {
+
+            // strip off the part following the ?
+            path = path.substring(0, queryInd);
+        }
+
+        Enumeration<HttpCookie> cookies = cookieList.elements();
+        Vector<HttpCookie> cookiesToSend = new Vector<HttpCookie>(10);
+
+        while (cookies.hasMoreElements()) {
+            HttpCookie cookie = cookies.nextElement();
+            String cookiePath = cookie.getPath();
+
+            if (path.startsWith(cookiePath)) {
+
+                // larrylf: Actually, my documentation (from Netscape)
+                // says that /foo should
+                // match /foobar and /foo/bar.  Yuck!!!
+                if (!cookie.hasExpired()) {
+                    cookiesToSend.addElement(cookie);
+                }
+
+                /*
+                   We're keeping this piece of commented out code around just in
+                   case we decide to put it back.  the spec does specify the above.
+
+
+                                int cookiePathLen = cookiePath.length();
+
+                                // verify that /foo does not match /foobar by mistake
+                                if ((path.length() == cookiePathLen)
+                                    || (path.length() > cookiePathLen &&
+                                        path.charAt(cookiePathLen) == '/')) {
+
+                                    // We have a matching cookie!
+
+                                    if (!cookie.hasExpired()) {
+                                        cookiesToSend.addElement(cookie);
+                                    }
+                                }
+                */
+            }
+        }
+
+        // Now, sort the cookies in most to least specific order
+        // Yes, its the deaded bubblesort!!
+        // (it should be a small vector, so perf is not an issue...)
+        if (cookiesToSend.size() > 1) {
+            for (int i = 0; i < cookiesToSend.size() - 1; i++) {
+                HttpCookie headC = cookiesToSend.elementAt(i);
+                String head = headC.getPath();
+
+                // This little excercise is a cheap way to get
+                // '/foo' to read more specfic then '/'
+                if (!head.endsWith("/")) {
+                    head = head + "/";
+                }
+
+                for (int j = i + 1; j < cookiesToSend.size(); j++) {
+                    HttpCookie scanC = cookiesToSend.elementAt(j);
+                    String scan = scanC.getPath();
+
+                    if (!scan.endsWith("/")) {
+                        scan = scan + "/";
+                    }
+
+                    int headCount = 0;
+                    int index = -1;
+
+                    while ((index = head.indexOf('/', index + 1)) != -1) {
+                        headCount++;
+                    }
+
+                    index = -1;
+
+                    int scanCount = 0;
+
+                    while ((index = scan.indexOf('/', index + 1)) != -1) {
+                        scanCount++;
+                    }
+
+                    if (scanCount > headCount) {
+                        cookiesToSend.setElementAt(headC, j);
+                        cookiesToSend.setElementAt(scanC, i);
+
+                        headC = scanC;
+                        head = scan;
+                    }
+                }
+            }
+        }
+
+        // And send the sorted cookies...
+        cookies = cookiesToSend.elements();
+
+        String cookieStr = null;
+
+        while (cookies.hasMoreElements()) {
+            HttpCookie cookie = cookies.nextElement();
+
+            if (cookieStr == null) {
+                cookieStr = cookie.getNameValue();
+            } else {
+                cookieStr = cookieStr + "; " + cookie.getNameValue();
+            }
+        }
+
+        if (cookieStr != null) {
+            httpConn.setRequestProperty("Cookie", cookieStr);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpClientTransport.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpClientTransport.java
new file mode 100644
index 0000000..0972723
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpClientTransport.java
@@ -0,0 +1,482 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.client;
+
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.*;
+import com.sun.xml.internal.ws.client.ClientTransportException;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.transport.WSConnectionImpl;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+
+import javax.net.ssl.HostnameVerifier;
+import javax.net.ssl.HttpsURLConnection;
+import javax.net.ssl.SSLSession;
+import javax.xml.ws.BindingProvider;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.http.HTTPBinding;
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.soap.MessageFactory;
+import javax.xml.soap.MimeHeader;
+import javax.xml.soap.MimeHeaders;
+import javax.xml.soap.SOAPConstants;
+import static javax.xml.ws.BindingProvider.ENDPOINT_ADDRESS_PROPERTY;
+import static javax.xml.ws.BindingProvider.SESSION_MAINTAIN_PROPERTY;
+import javax.xml.ws.soap.SOAPBinding;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.net.HttpURLConnection;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @author WS Development Team
+ */
+public class HttpClientTransport extends WSConnectionImpl {
+
+    private static String LAST_ENDPOINT = "";
+    private static boolean redirect = true;
+    private static final int START_REDIRECT_COUNT = 3;
+    private static int redirectCount = START_REDIRECT_COUNT;
+    int statusCode;
+    private Map<String, List<String>> respHeaders = null;
+
+    public HttpClientTransport() {
+        this(null, new HashMap<String, Object>());
+    }
+
+    public HttpClientTransport(OutputStream logStream, Map<String, Object> context) {
+        this.context = context;
+        _logStream = logStream;
+
+        String bindingId = (String) context.get(BINDING_ID_PROPERTY);
+        try {
+            if (bindingId == null)
+                bindingId = SOAPBinding.SOAP11HTTP_BINDING;
+
+            if (bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING))
+                _messageFactory = MessageFactory.newInstance(SOAPConstants.SOAP_1_2_PROTOCOL);
+            else
+                _messageFactory = MessageFactory.newInstance(SOAPConstants.SOAP_1_1_PROTOCOL);
+
+            endpoint = (String) context.get(ENDPOINT_ADDRESS_PROPERTY);
+        } catch (Exception e) {
+            throw new ClientTransportException("http.client.cannotCreateMessageFactory");
+        }
+    }
+
+    /**
+     * Prepare the stream for HTTP request
+     */
+    @Override
+    public OutputStream getOutput() {
+        try {
+            httpConnection = createHttpConnection(endpoint, context);
+            cookieJar = sendCookieAsNeeded();
+
+            // how to incorporate redirect processing: message dispatcher does not seem to tbe right place
+            String requestMethod = httpConnection.getRequestMethod();
+            boolean skipOut = ("GET".equalsIgnoreCase(requestMethod) ||
+                "HEAD".equalsIgnoreCase(requestMethod) ||
+                "DELETE".equalsIgnoreCase(requestMethod));
+            if (!skipOut)
+                outputStream = httpConnection.getOutputStream();
+            //if use getOutputStream method set as "POST"
+            //but for "Get" request no need to get outputStream
+            connectForResponse();
+
+        } catch (Exception ex) {
+            throw new ClientTransportException("http.client.failed", ex);
+        }
+
+        return outputStream;
+    }
+
+    /**
+     * Get the response from HTTP connection and prepare the input stream for response
+     */
+    @Override
+    public InputStream getInput() {
+        // response processing
+
+        InputStream in;
+        try {
+            in = readResponse();
+        } catch (IOException e) {
+            if (statusCode == HttpURLConnection.HTTP_NO_CONTENT
+                || (isFailure
+                && statusCode != HttpURLConnection.HTTP_INTERNAL_ERROR)) {
+                try {
+                    throw new ClientTransportException("http.status.code",
+                        statusCode, httpConnection.getResponseMessage());
+                } catch (IOException ex) {
+                    throw new ClientTransportException("http.status.code",
+                        statusCode, ex);
+                }
+            }
+            throw new ClientTransportException("http.client.failed",
+                e.getMessage());
+        }
+        httpConnection = null;
+
+        return in;
+    }
+
+    @Override
+    public OutputStream getDebug() {
+        return _logStream;
+    }
+
+    @Override
+    public Map<String, List<String>> getHeaders() {
+        if (respHeaders != null) {
+            return respHeaders;
+        }
+        try {
+            isFailure = checkResponseCode();
+
+            respHeaders = collectResponseMimeHeaders();
+
+            saveCookieAsNeeded(cookieJar);
+            setHeaders(respHeaders);
+
+            return respHeaders;
+        } catch (IOException e) {
+            if (statusCode == HttpURLConnection.HTTP_NO_CONTENT
+                || (isFailure
+                && statusCode != HttpURLConnection.HTTP_INTERNAL_ERROR)) {
+                try {
+                    throw new ClientTransportException("http.status.code",
+                        new Object[]{
+                            statusCode,
+                            httpConnection.getResponseMessage()});
+                } catch (IOException ex) {
+                    throw new ClientTransportException("http.status.code",
+                        new Object[]{
+                            statusCode,
+                            ex});
+                }
+            }
+            throw new ClientTransportException("http.client.failed",
+                e.getMessage());
+        }
+
+    }
+
+//    public void invoke(String endpoint, SOAPMessageContext context)
+//            throws ClientTransportException {
+
+//        try {
+//            int statusCode = httpConnection.getResponseCode();
+//
+//            //http URL redirection does not redirect http requests
+//            //to an https endpoint probably due to a bug in the jdk
+//            //or by intent - to workaround this if an error code
+//            //of HTTP_MOVED_TEMP or HTTP_MOVED_PERM is received then
+//            //the jaxws client will reinvoke the original request
+//            //to the new endpoint - kw bug 4890118
+//            if (checkForRedirect(statusCode)) {
+//                redirectRequest(httpConnection, context);
+//                return;
+//            }
+//    }
+
+    protected InputStream readResponse()
+        throws IOException {
+        InputStream contentIn =
+            (isFailure
+                ? httpConnection.getErrorStream()
+                : httpConnection.getInputStream());
+
+        ByteArrayBuffer bab = new ByteArrayBuffer();
+        if (contentIn != null) { // is this really possible?
+            bab.write(contentIn);
+            bab.close();
+        }
+
+        int length =
+            httpConnection.getContentLength() == -1
+                ? bab.size()
+                : httpConnection.getContentLength();
+
+        return bab.newInputStream(0, length);
+    }
+
+    protected Map<String, List<String>> collectResponseMimeHeaders() {
+        /*
+        MimeHeaders mimeHeaders = new MimeHeaders();
+        for (int i = 1; ; ++i) {
+            String key = httpConnection.getHeaderFieldKey(i);
+            if (key == null) {
+                break;
+            }
+            String value = httpConnection.getHeaderField(i);
+            try {
+                mimeHeaders.addHeader(key, value);
+            } catch (IllegalArgumentException e) {
+                // ignore headers that are illegal in MIME
+            }
+        }
+
+        Map<String, List<String>> headers = new HashMap<String, List<String>>();
+        for (Iterator iter = mimeHeaders.getAllHeaders(); iter.hasNext();) {
+            MimeHeader header = (MimeHeader)iter.next();
+            List<String> h = new ArrayList<String>();
+            h.add(header.getValue());
+            headers.put (header.getName (), h);
+        }
+        return headers;
+         */
+        return httpConnection.getHeaderFields();
+    }
+
+    protected void connectForResponse()
+        throws IOException {
+
+        httpConnection.connect();
+    }
+
+    /*
+     * Will throw an exception instead of returning 'false' if there is no
+     * return message to be processed (i.e., in the case of an UNAUTHORIZED
+     * response from the servlet or 404 not found)
+     */
+    protected boolean checkResponseCode()
+        throws IOException {
+        boolean isFailure = false;
+        try {
+
+            statusCode = httpConnection.getResponseCode();
+            setStatus(statusCode);
+
+            if ((httpConnection.getResponseCode()
+                == HttpURLConnection.HTTP_INTERNAL_ERROR)) {
+                isFailure = true;
+                //added HTTP_ACCEPT for 1-way operations
+            } else if (
+                httpConnection.getResponseCode()
+                    == HttpURLConnection.HTTP_UNAUTHORIZED) {
+
+                // no soap message returned, so skip reading message and throw exception
+                throw new ClientTransportException("http.client.unauthorized",
+                    httpConnection.getResponseMessage());
+            } else if (
+                httpConnection.getResponseCode()
+                    == HttpURLConnection.HTTP_NOT_FOUND) {
+
+                // no message returned, so skip reading message and throw exception
+                throw new ClientTransportException("http.not.found",
+                    httpConnection.getResponseMessage());
+            } else if (
+                (statusCode == HttpURLConnection.HTTP_MOVED_TEMP) ||
+                    (statusCode == HttpURLConnection.HTTP_MOVED_PERM)) {
+                isFailure = true;
+
+                if (!redirect || (redirectCount <= 0)) {
+                    throw new ClientTransportException("http.status.code",
+                        new Object[]{
+                            statusCode,
+                            getStatusMessage(httpConnection)});
+                }
+            } else if (
+                statusCode < 200 || (statusCode >= 303 && statusCode < 500)) {
+                throw new ClientTransportException("http.status.code",
+                    new Object[]{
+                        statusCode,
+                        getStatusMessage(httpConnection)});
+            } else if (statusCode >= 500) {
+                isFailure = true;
+            }
+        } catch (IOException e) {
+            throw new WebServiceException(e);
+            // on JDK1.3.1_01, we end up here, but then getResponseCode() succeeds!
+//            if (httpConnection.getResponseCode()
+//                    == HttpURLConnection.HTTP_INTERNAL_ERROR) {
+//                isFailure = true;
+//            } else {
+//                throw e;
+//            }
+        }
+
+        return isFailure;
+    }
+
+    protected String getStatusMessage(HttpURLConnection httpConnection)
+        throws IOException {
+        int statusCode = httpConnection.getResponseCode();
+        String message = httpConnection.getResponseMessage();
+        if (statusCode == HttpURLConnection.HTTP_CREATED
+            || (statusCode >= HttpURLConnection.HTTP_MULT_CHOICE
+            && statusCode != HttpURLConnection.HTTP_NOT_MODIFIED
+            && statusCode < HttpURLConnection.HTTP_BAD_REQUEST)) {
+            String location = httpConnection.getHeaderField("Location");
+            if (location != null)
+                message += " - Location: " + location;
+        }
+        return message;
+    }
+
+    protected CookieJar sendCookieAsNeeded() {
+        Boolean shouldMaintainSessionProperty =
+            (Boolean) context.get(SESSION_MAINTAIN_PROPERTY);
+        if (shouldMaintainSessionProperty == null) {
+            return null;
+        }
+        if (shouldMaintainSessionProperty.booleanValue()) {
+            CookieJar cookieJar = (CookieJar) context.get(HTTP_COOKIE_JAR);
+            if (cookieJar == null) {
+                cookieJar = new CookieJar();
+
+                // need to store in binding's context so it is not lost
+                BindingProvider bp =
+                    (BindingProvider) context.get(JAXWS_CLIENT_HANDLE_PROPERTY);
+                bp.getRequestContext().put(HTTP_COOKIE_JAR, cookieJar);
+            }
+            cookieJar.applyRelevantCookies(httpConnection);
+            return cookieJar;
+        } else {
+            return null;
+        }
+    }
+
+    protected void saveCookieAsNeeded(CookieJar cookieJar) {
+        if (cookieJar != null) {
+            cookieJar.recordAnyCookies(httpConnection);
+        }
+    }
+
+    protected HttpURLConnection createHttpConnection(String endpoint,
+                                                     Map<String, Object> context)
+        throws IOException {
+
+        boolean verification = false;
+        // does the client want client hostname verification by the service
+        String verificationProperty =
+            (String) context.get(HOSTNAME_VERIFICATION_PROPERTY);
+        if (verificationProperty != null) {
+            if (verificationProperty.equalsIgnoreCase("true"))
+                verification = true;
+        }
+
+        // does the client want request redirection to occur
+        String redirectProperty =
+            (String) context.get(REDIRECT_REQUEST_PROPERTY);
+        if (redirectProperty != null) {
+            if (redirectProperty.equalsIgnoreCase("false"))
+                redirect = false;
+        }
+
+        checkEndpoints(endpoint);
+
+        HttpURLConnection httpConnection = createConnection(endpoint);
+
+        if (!verification) {
+            // for https hostname verification  - turn off by default
+            if (httpConnection instanceof HttpsURLConnection) {
+                ((HttpsURLConnection) httpConnection).setHostnameVerifier(new HttpClientVerifier());
+            }
+        }
+
+        // allow interaction with the web page - user may have to supply
+        // username, password id web page is accessed from web browser
+        httpConnection.setAllowUserInteraction(true);
+        // enable input, output streams
+        httpConnection.setDoOutput(true);
+        httpConnection.setDoInput(true);
+        // the soap message is always sent as a Http POST
+        // HTTP Get is disallowed by BP 1.0
+        // needed for XML/HTTPBinding and SOAP12Binding
+        // for xml/http binding other methods are allowed.
+        // for Soap 1.2 "GET" is allowed.
+        String method = "POST";
+        String requestMethod = (String) context.get(MessageContext.HTTP_REQUEST_METHOD);
+        if (context.get(BindingProviderProperties.BINDING_ID_PROPERTY).equals(HTTPBinding.HTTP_BINDING)){
+            method = (requestMethod != null)?requestMethod:method;
+        } else if
+            (context.get(BindingProviderProperties.BINDING_ID_PROPERTY).equals(SOAPBinding.SOAP12HTTP_BINDING) &&
+            "GET".equalsIgnoreCase(requestMethod)) {
+            method = (requestMethod != null)?requestMethod:method;
+        }
+        ((HttpURLConnection)httpConnection).setRequestMethod(method);
+
+        Integer reqTimeout = (Integer)context.get(BindingProviderProperties.REQUEST_TIMEOUT);
+        if (reqTimeout != null) {
+            httpConnection.setReadTimeout(reqTimeout);
+        }
+
+        // set the properties on HttpURLConnection
+        for (Map.Entry entry : super.getHeaders().entrySet()) {
+            httpConnection.addRequestProperty((String) entry.getKey(), ((List<String>) entry.getValue()).get(0));
+        }
+
+        return httpConnection;
+    }
+
+    private java.net.HttpURLConnection createConnection(String endpoint)
+        throws IOException {
+        return (HttpURLConnection) new URL(endpoint).openConnection();
+    }
+
+//    private void redirectRequest(HttpURLConnection httpConnection, SOAPMessageContext context) {
+//        String redirectEndpoint = httpConnection.getHeaderField("Location");
+//        if (redirectEndpoint != null) {
+//            httpConnection.disconnect();
+//            invoke(redirectEndpoint, context);
+//        } else
+//            System.out.println("redirection Failed");
+//    }
+
+    private boolean checkForRedirect(int statusCode) {
+        return (((statusCode == 301) || (statusCode == 302)) && redirect && (redirectCount-- > 0));
+    }
+
+    private void checkEndpoints(String currentEndpoint) {
+        if (!LAST_ENDPOINT.equalsIgnoreCase(currentEndpoint)) {
+            redirectCount = START_REDIRECT_COUNT;
+            LAST_ENDPOINT = currentEndpoint;
+        }
+    }
+
+    // overide default SSL HttpClientVerifier to always return true
+    // effectively overiding Hostname client verification when using SSL
+    static class HttpClientVerifier implements HostnameVerifier {
+        public boolean verify(String s, SSLSession sslSession) {
+            return true;
+        }
+    }
+
+    private MessageFactory _messageFactory;
+    HttpURLConnection httpConnection = null;
+    String endpoint = null;
+    Map<String, Object> context = null;
+    CookieJar cookieJar = null;
+    boolean isFailure = false;
+    OutputStream _logStream = null;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpClientTransportFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpClientTransportFactory.java
new file mode 100644
index 0000000..a0209ec
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpClientTransportFactory.java
@@ -0,0 +1,69 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.client;
+
+import java.io.OutputStream;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import java.util.Map;
+
+import javax.xml.ws.soap.SOAPBinding;
+
+import static com.sun.xml.internal.ws.client.BindingProviderProperties.BINDING_ID_PROPERTY;
+import com.sun.xml.internal.ws.spi.runtime.ClientTransportFactory;
+import java.util.HashMap;
+
+/**
+ * @author WS Development Team
+ */
+public class HttpClientTransportFactory implements ClientTransportFactory {
+
+
+    public HttpClientTransportFactory() {
+        this(null);
+    }
+
+    public HttpClientTransportFactory(OutputStream logStream) {
+        _logStream = logStream;
+    }
+
+    /*
+    public WSConnection create() {
+        Map<String, Object> context = new HashMap<String, Object>();
+        context.put(BINDING_ID_PROPERTY, SOAPBinding.SOAP11HTTP_BINDING);
+
+        return new HttpClientTransport(_logStream, context);
+    }
+     */
+
+    /**
+     * Binding Id, Endpoint address and other metadata is in the property bag
+     */
+    public WSConnection create(Map<String, Object> context) {
+        return new HttpClientTransport(_logStream, context);
+    }
+
+    private OutputStream _logStream;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpCookie.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpCookie.java
new file mode 100644
index 0000000..8688791
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/HttpCookie.java
@@ -0,0 +1,260 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.client;
+
+import java.net.URL;
+import java.util.Date;
+import java.util.StringTokenizer;
+
+/**
+ * An object which represents an HTTP cookie.  Can be constructed by
+ * parsing a string from the set-cookie: header.
+ *
+ * Syntax: Set-Cookie: NAME=VALUE; expires=DATE;
+ *             path=PATH; domain=DOMAIN_NAME; secure
+ *
+ * All but the first field are optional.
+ *
+ * @author WS Development Team
+ */
+public class HttpCookie {
+
+    private Date expirationDate = null;
+    private String nameAndValue;
+    private String path;
+    private String domain;
+    private boolean isSecure = false;
+
+    public HttpCookie(String cookieString) {
+        parseCookieString(cookieString);
+    }
+
+    //
+    // Constructor for use by the bean
+    //
+    public HttpCookie(
+        Date expirationDate,
+        String nameAndValue,
+        String path,
+        String domain,
+        boolean isSecure) {
+
+        this.expirationDate = expirationDate;
+        this.nameAndValue = nameAndValue;
+        this.path = path;
+        this.domain = stripPort(domain);
+        this.isSecure = isSecure;
+    }
+
+    public HttpCookie(URL url, String cookieString) {
+        parseCookieString(cookieString);
+        applyDefaults(url);
+    }
+
+    /**
+     * Fills in default values for domain, path, etc. from the URL
+     * after creation of the cookie.
+     */
+    private void applyDefaults(URL url) {
+
+        if (domain == null) {
+            domain = url.getHost();
+
+            // REMIND: record the port
+        }
+
+        if (path == null) {
+            path = url.getFile();
+
+            // The documentation for cookies say that the path is
+            // by default, the path of the document, not the filename of the
+            // document.  This could be read as not including that document
+            // name itself, just its path (this is how NetScape inteprets it)
+            // so amputate the document name!
+            int last = path.lastIndexOf("/");
+
+            if (last > -1) {
+                path = path.substring(0, last);
+            }
+        }
+    }
+
+    private String stripPort(String domainName) {
+
+        int index = domainName.indexOf(':');
+
+        if (index == -1) {
+            return domainName;
+        }
+
+        return domainName.substring(0, index);
+    }
+
+    /**
+     * Parse the given string into its individual components, recording them
+     * in the member variables of this object.
+     */
+    private void parseCookieString(String cookieString) {
+
+        StringTokenizer tokens = new StringTokenizer(cookieString, ";");
+
+        if (!tokens.hasMoreTokens()) {
+
+            // REMIND: make this robust against parse errors
+        }
+
+        nameAndValue = tokens.nextToken().trim();
+
+        while (tokens.hasMoreTokens()) {
+            String token = tokens.nextToken().trim();
+
+            if (token.equalsIgnoreCase("secure")) {
+                isSecure = true;
+            } else {
+                int equIndex = token.indexOf("=");
+
+                if (equIndex < 0) {
+                    continue;
+
+                    // REMIND: malformed cookie
+                }
+
+                String attr = token.substring(0, equIndex);
+                String val = token.substring(equIndex + 1);
+
+                if (attr.equalsIgnoreCase("path")) {
+                    path = val;
+                } else if (attr.equalsIgnoreCase("domain")) {
+                    if (val.indexOf(".") == 0) {
+
+                        // spec seems to allow for setting the domain in
+                        // the form 'domain=.eng.sun.com'.  We want to
+                        // trim off the leading '.' so we can allow for
+                        // both leading dot and non leading dot forms
+                        // without duplicate storage.
+                        domain = stripPort(val.substring(1));
+                    } else {
+                        domain = stripPort(val);
+                    }
+                } else if (attr.equalsIgnoreCase("expires")) {
+                    expirationDate = parseExpireDate(val);
+                } else {
+
+                    // unknown attribute -- do nothing
+                }
+            }
+        }
+    }
+
+    //======================================================================
+    //
+    // Accessor functions
+    //
+    public String getNameValue() {
+        return nameAndValue;
+    }
+
+    /**
+     * Returns just the name part of the cookie
+     */
+    public String getName() {
+
+        int index = nameAndValue.indexOf("=");
+
+        return nameAndValue.substring(0, index);
+    }
+
+    /**
+     * Returns the domain of the cookie as it was presented
+     */
+    public String getDomain() {
+
+        // REMIND: add port here if appropriate
+        return domain;
+    }
+
+    public String getPath() {
+        return path;
+    }
+
+    public Date getExpirationDate() {
+        return expirationDate;
+    }
+
+    boolean hasExpired() {
+
+        if (expirationDate == null) {
+            return false;
+        }
+
+        return (expirationDate.getTime() <= System.currentTimeMillis());
+    }
+
+    /**
+     * Returns true if the cookie has an expiration date (meaning it's
+     * persistent), and if the date nas not expired;
+     */
+    boolean isSaveable() {
+        return (expirationDate != null)
+            && (expirationDate.getTime() > System.currentTimeMillis());
+    }
+
+    public boolean isSecure() {
+        return isSecure;
+    }
+
+    private Date parseExpireDate(String dateString) {
+
+        // format is wdy, DD-Mon-yyyy HH:mm:ss GMT
+        RfcDateParser parser = new RfcDateParser(dateString);
+        Date theDate = parser.getDate();
+
+        return theDate;
+    }
+
+    public String toString() {
+
+        String result = nameAndValue;
+
+        if (expirationDate != null) {
+            result += "; expires=" + expirationDate;
+        }
+
+        if (path != null) {
+            result += "; path=" + path;
+        }
+
+        if (domain != null) {
+            result += "; domain=" + domain;
+        }
+
+        if (isSecure) {
+            result += "; secure";
+        }
+
+        return result;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/RfcDateParser.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/RfcDateParser.java
new file mode 100644
index 0000000..1170ed5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/client/RfcDateParser.java
@@ -0,0 +1,115 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.client;
+
+import java.text.SimpleDateFormat;
+import java.util.Date;
+import java.util.Locale;
+import java.util.TimeZone;
+
+/**
+ * A parser for date strings commonly found in http and email headers that
+ * follow various RFC conventions.  Given a date-string, the parser will
+ * attempt to parse it by trying matches with a set of patterns, returning
+ * null on failure, a Date object on success.
+ *
+ * @author WS Development Team
+ */
+public class RfcDateParser {
+
+    private static final String debugProp = "hotjava.debug.RfcDateParser";
+    private boolean isGMT = false;
+    static final String[] standardFormats =
+        { "EEEE', 'dd-MMM-yy HH:mm:ss z", // RFC 850 (obsoleted by 1036)
+        "EEEE', 'dd-MMM-yy HH:mm:ss", // ditto but no tz. Happens too often
+        "EEE', 'dd-MMM-yyyy HH:mm:ss z", // RFC 822/1123
+        "EEE', 'dd MMM yyyy HH:mm:ss z", // REMIND what rfc? Apache/1.1
+        "EEEE', 'dd MMM yyyy HH:mm:ss z", // REMIND what rfc? Apache/1.1
+        "EEE', 'dd MMM yyyy hh:mm:ss z", // REMIND what rfc? Apache/1.1
+        "EEEE', 'dd MMM yyyy hh:mm:ss z", // REMIND what rfc? Apache/1.1
+        "EEE MMM dd HH:mm:ss z yyyy", // Date's string output format
+        "EEE MMM dd HH:mm:ss yyyy", // ANSI C asctime format()
+        "EEE', 'dd-MMM-yy HH:mm:ss", // No time zone 2 digit year RFC 1123
+        "EEE', 'dd-MMM-yyyy HH:mm:ss" // No time zone RFC 822/1123
+    };
+    static final String[] gmtStandardFormats =
+        { "EEEE',' dd-MMM-yy HH:mm:ss 'GMT'", // RFC 850 (obsoleted by 1036)
+        "EEE',' dd-MMM-yyyy HH:mm:ss 'GMT'", // RFC 822/1123
+        "EEE',' dd MMM yyyy HH:mm:ss 'GMT'", // REMIND what rfc? Apache/1.1
+        "EEEE',' dd MMM yyyy HH:mm:ss 'GMT'", // REMIND what rfc? Apache/1.1
+        "EEE',' dd MMM yyyy hh:mm:ss 'GMT'", // REMIND what rfc? Apache/1.1
+        "EEEE',' dd MMM yyyy hh:mm:ss 'GMT'", // REMIND what rfc? Apache/1.1
+        "EEE MMM dd HH:mm:ss 'GMT' yyyy" // Date's string output format
+    };
+    String dateString;
+
+    public RfcDateParser(String dateString) {
+
+        this.dateString = dateString.trim();
+
+        if (this.dateString.indexOf("GMT") != -1) {
+            isGMT = true;
+        }
+    }
+
+    public Date getDate() {
+
+        // format is wdy, DD-Mon-yyyy HH:mm:ss GMT
+        int arrayLen =
+            isGMT ? gmtStandardFormats.length : standardFormats.length;
+
+        for (int i = 0; i < arrayLen; i++) {
+            Date d;
+
+            if (isGMT) {
+                d = tryParsing(gmtStandardFormats[i]);
+            } else {
+                d = tryParsing(standardFormats[i]);
+            }
+
+            if (d != null) {
+                return d;
+            }
+        }
+
+        return null;
+    }
+
+    private Date tryParsing(String format) {
+
+        SimpleDateFormat df = new SimpleDateFormat(format, Locale.US);
+
+        if (isGMT) {
+            df.setTimeZone(TimeZone.getTimeZone("GMT"));
+        }
+
+        try {
+            return df.parse(dateString);
+        } catch (Exception e) {
+            return null;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointDocInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointDocInfo.java
new file mode 100644
index 0000000..561b9ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointDocInfo.java
@@ -0,0 +1,101 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.transport.http.server;
+
+import com.sun.xml.internal.ws.server.DocInfo;
+import com.sun.xml.internal.ws.wsdl.parser.Service;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+
+import java.io.ByteArrayInputStream;
+import java.io.InputStream;
+import java.net.URL;
+
+public class EndpointDocInfo implements DocInfo {
+    private URL resourceUrl;
+    private String queryString;
+    private ByteArrayBuffer buf;
+    private DOC_TYPE docType;
+    private String tns;
+    private Service service;
+    private boolean portType;
+
+    public EndpointDocInfo(URL resourceUrl, ByteArrayBuffer buf) {
+        this.resourceUrl = resourceUrl;
+        this.buf = buf;
+    }
+
+    public InputStream getDoc() {
+        return buf.newInputStream();
+    }
+
+    public String getPath() {
+        return null;
+    }
+
+    public String getQueryString() {
+        return queryString;
+    }
+
+    public void setQueryString(String queryString) {
+        this.queryString = queryString;
+    }
+
+    public void setDocType(DOC_TYPE docType) {
+        this.docType = docType;
+    }
+
+    public DOC_TYPE getDocType() {
+        return docType;
+    }
+
+    public void setTargetNamespace(String tns) {
+        this.tns = tns;
+    }
+
+    public String getTargetNamespace() {
+        return tns;
+    }
+
+    public void setService(Service service) {
+        this.service = service;
+    }
+
+    public Service getService() {
+        return service;
+    }
+
+    public void setHavingPortType(boolean portType) {
+        this.portType = portType;
+    }
+
+    public boolean isHavingPortType() {
+        return portType;
+    }
+
+    public URL getUrl() {
+        return resourceUrl;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointEntityResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointEntityResolver.java
new file mode 100644
index 0000000..cdad48b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointEntityResolver.java
@@ -0,0 +1,76 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.server;
+
+import com.sun.xml.internal.messaging.saaj.util.ByteInputStream;
+import com.sun.xml.internal.ws.server.DocInfo;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.Map;
+import javax.xml.transform.Source;
+import javax.xml.transform.stream.StreamSource;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+/**
+ *
+ * @author WS Developement Team
+ */
+public class EndpointEntityResolver implements EntityResolver {
+
+    private EntityResolver catalogResolver;
+    private Map<String, DocInfo> metadata;
+
+    /*
+     * Assumes Source objects can be reused multiple times
+     */
+    public EndpointEntityResolver(Map<String, DocInfo> metadata) {
+        this.metadata = metadata;
+        catalogResolver = XmlUtil.createDefaultCatalogResolver();
+    }
+
+    /*
+     * It resolves the systemId in the metadata first. If it is not found, then
+     * it tries to resolve in catalog
+     */
+    public InputSource resolveEntity (String publicId, String systemId)
+        throws SAXException, IOException {
+        if (systemId != null) {
+            DocInfo docInfo = metadata.get(systemId);
+            if (docInfo != null) {
+                InputStream in = docInfo.getDoc();
+                InputSource is = new InputSource(in);
+                is.setSystemId(systemId);
+                return is;
+            }
+        }
+        return catalogResolver.resolveEntity(publicId, systemId);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointImpl.java
new file mode 100644
index 0000000..1c6615a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/EndpointImpl.java
@@ -0,0 +1,177 @@
+
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.server;
+
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import java.net.MalformedURLException;
+import java.net.URL;
+
+import javax.xml.ws.Endpoint;
+import javax.xml.ws.Binding;
+import javax.xml.transform.Source;
+import java.util.Map;
+import java.util.concurrent.Executor;
+import javax.xml.ws.WebServicePermission;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class EndpointImpl extends Endpoint {
+
+    private static final WebServicePermission ENDPOINT_PUBLISH_PERMISSION =
+        new WebServicePermission("publishEndpoint");
+    private Object actualEndpoint;        // Don't declare as HttpEndpoint type
+    private Executor executor;
+    private boolean published;
+    private boolean stopped;
+    private final com.sun.xml.internal.ws.spi.runtime.Binding binding;
+    private final Object implementor;
+    private Map<String, Object> properties;
+    private java.util.List<Source> metadata;
+
+    public EndpointImpl(String bindingId, Object impl) {
+        this.implementor = impl;
+        this.binding = BindingImpl.getBinding(bindingId, impl.getClass(), null, false);
+    }
+
+    public Binding getBinding() {
+        return binding;
+    }
+
+    public Object getImplementor() {
+        return implementor;
+    }
+
+    public void publish(String address) {
+        canPublish();
+        URL url;
+        try {
+            url = new URL(address);
+        } catch (MalformedURLException ex) {
+            throw new IllegalArgumentException("Cannot create URL for this address "+address);
+        }
+        if (!url.getProtocol().equals("http")) {
+            throw new IllegalArgumentException(url.getProtocol()+" protocol based address is not supported");
+        }
+        if (!url.getPath().startsWith("/")) {
+            throw new IllegalArgumentException("Incorrect WebService address="+address+
+                    ". The address's path should start with /");
+        }
+        checkPlatform();
+        // Don't load HttpEndpoint class before as it may load HttpServer classes
+        actualEndpoint = new HttpEndpoint(implementor, binding, metadata, properties, executor);
+        ((HttpEndpoint)actualEndpoint).publish(address);
+        published = true;
+    }
+
+    public void publish(Object serverContext) {
+        canPublish();
+        checkPlatform();
+        if (!com.sun.net.httpserver.HttpContext.class.isAssignableFrom(serverContext.getClass())) {
+            throw new IllegalArgumentException(serverContext.getClass()+" is not a supported context.");
+        }
+        // Don't load HttpEndpoint class before as it may load HttpServer classes
+        actualEndpoint = new HttpEndpoint(implementor, binding, metadata, properties, executor);
+        ((HttpEndpoint)actualEndpoint).publish(serverContext);
+        published = true;
+    }
+
+    public void stop() {
+        if (published) {
+            ((HttpEndpoint)actualEndpoint).stop();
+            published = false;
+            stopped = true;
+        }
+    }
+
+    public boolean isPublished() {
+        return published;
+    }
+
+    private void canPublish() {
+        if (published) {
+            throw new IllegalStateException(
+                "Cannot publish this endpoint. Endpoint has been already published.");
+        }
+        if (stopped) {
+            throw new IllegalStateException(
+                "Cannot publish this endpoint. Endpoint has been already stopped.");
+        }
+    }
+
+    public java.util.List<Source> getMetadata() {
+        return metadata;
+    }
+
+    public void setMetadata(java.util.List<Source> metadata) {
+        if (published) {
+            throw new IllegalStateException("Cannot set Metadata. Endpoint is already published");
+        }
+        this.metadata = metadata;
+    }
+
+    public Executor getExecutor() {
+        return executor;
+    }
+
+    public void setExecutor(Executor executor) {
+        this.executor = executor;
+    }
+
+    public Map<String, Object> getProperties() {
+        return properties;
+    }
+
+    public void setProperties(Map<String, Object> map) {
+        this.properties = map;
+    }
+
+    /**
+     * Checks the permission of "publishEndpoint" before accessing HTTP classes.
+     * Also it checks if there is an available HTTP server implementation.
+     */
+    private void checkPlatform() {
+
+        // Checks permission for "publishEndpoint"
+        SecurityManager sm = System.getSecurityManager();
+        if (sm != null) {
+            sm.checkPermission(ENDPOINT_PUBLISH_PERMISSION);
+        }
+
+        // See if HttpServer implementation is available
+        try {
+            Class.forName("com.sun.net.httpserver.HttpServer");
+        } catch(Exception e) {
+            throw new UnsupportedOperationException("NOT SUPPORTED");
+        }
+
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/HttpEndpoint.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/HttpEndpoint.java
new file mode 100644
index 0000000..6f2d872
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/HttpEndpoint.java
@@ -0,0 +1,313 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.server;
+
+import com.sun.net.httpserver.HttpContext;
+import com.sun.xml.internal.ws.server.DocInfo;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.server.ServerRtException;
+import com.sun.xml.internal.ws.server.Tie;
+import com.sun.xml.internal.ws.spi.runtime.WebServiceContext;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.concurrent.Executor;
+import javax.xml.transform.stream.StreamSource;
+import org.xml.sax.EntityResolver;
+
+import javax.xml.namespace.QName;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.ws.Endpoint;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.logging.Logger;
+import com.sun.xml.internal.ws.spi.runtime.Binding;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class HttpEndpoint {
+
+    private static final Logger logger =
+        Logger.getLogger(
+            com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".server.http");
+
+    private String address;
+    private HttpContext httpContext;
+    private final RuntimeEndpointInfo endpointInfo;
+    private String primaryWsdl;
+    private Executor executor;
+    private final Map<String, Object> properties;
+
+    private static final int MAX_THREADS = 5;
+
+    public HttpEndpoint(Object implementor, Binding binding, List<Source>metadata, Map<String, Object> properties, Executor executor) {
+        endpointInfo = new RuntimeEndpointInfo();
+        endpointInfo.setImplementor(implementor);
+        endpointInfo.setImplementorClass(implementor.getClass());
+        endpointInfo.setBinding(binding);
+        endpointInfo.setUrlPattern("");
+        endpointInfo.setMetadata(metadata);
+        this.properties = properties;
+        this.executor = executor;
+    }
+
+    /**
+     * If Service Name is in properties, set it on RuntimeEndpointInfo
+     */
+    private void setServiceName() {
+        if (properties != null) {
+            QName serviceName = (QName)properties.get(Endpoint.WSDL_SERVICE);
+            if (serviceName != null) {
+                endpointInfo.setServiceName(serviceName);
+            }
+        }
+    }
+
+    /**
+     * If Port Name is in properties, set it on RuntimeEndpointInfo
+     */
+    private void setPortName() {
+        if (properties != null) {
+            QName portName = (QName)properties.get(Endpoint.WSDL_PORT);
+            if (portName != null) {
+                endpointInfo.setPortName(portName);
+            }
+        }
+    }
+
+    /**
+     * Convert metadata sources using identity transform. So that we can
+     * reuse the Source object multiple times.
+     */
+    private void setDocInfo() throws MalformedURLException {
+        List<Source> metadata = endpointInfo.getMetadata();
+
+        // Takes care of @WebService, @WebServiceProvider's wsdlLocation
+        String wsdlLocation = endpointInfo.getWsdlLocation();
+        if (wsdlLocation != null) {
+            ClassLoader cl = endpointInfo.getImplementorClass().getClassLoader();
+            URL url = cl.getResource(wsdlLocation);
+            if (url == null) {
+                throw new ServerRtException("cannot.load.wsdl", wsdlLocation);
+            } else {
+                Source source = null;
+                try {
+                    source = new StreamSource(url.openStream());
+                } catch(IOException ioe) {
+                    throw new ServerRtException("server.rt.err", ioe);
+                }
+                primaryWsdl = url.toExternalForm();
+                source.setSystemId(primaryWsdl);
+                if (metadata == null) {
+                    metadata = new ArrayList<Source>();
+                    endpointInfo.setMetadata(metadata);
+                }
+                metadata.add(source);
+            }
+        }
+
+        // Creates DocInfo for each metdata Source
+        if (metadata != null) {
+            Map<String, DocInfo> newMetadata = new HashMap<String, DocInfo>();
+            Transformer transformer = XmlUtil.newTransformer();
+            for(Source source: metadata) {
+                ByteArrayBuffer baos = new ByteArrayBuffer();
+                try {
+                    transformer.transform(source, new StreamResult(baos));
+                    baos.close();
+                } catch (TransformerException te) {
+                    throw new ServerRtException("server.rt.err",te);
+                }
+                String systemId = source.getSystemId();
+                URL url;
+                try {
+                    url = new URL(systemId);
+                } catch(MalformedURLException me) {
+                    logger.severe("Metadata Source's systemId="+systemId+
+                            " is incorrect. Provide a correct one");
+                    throw me;
+                }
+                EndpointDocInfo docInfo = new EndpointDocInfo(url, baos);
+                DocInfo old = newMetadata.put(systemId, docInfo);
+                if (old != null) {
+                    logger.warning("Duplicate Source objects for systemId="+systemId+" in metadata");
+                }
+            }
+            endpointInfo.setMetadata(newMetadata);
+        }
+    }
+
+    /**
+     * Finds primary WSDL
+     */
+    private void findPrimaryWSDL() throws Exception {
+        Map<String, DocInfo> metadata = endpointInfo.getDocMetadata();
+        // Checks whether the wsdlLocation resource is a primary wsdl
+        if (primaryWsdl != null) {
+            DocInfo docInfo = metadata.get(primaryWsdl);
+            if (docInfo.getService() == null) {
+                throw new ServerRtException("not.primary.wsdl", primaryWsdl);
+            }
+        }
+        // Checks whether metadata contains duplicate primary wsdls or abstract wsdsl
+        if (metadata != null) {
+            boolean concreteWsdl = false;
+            boolean abstractWsdl = false;
+            for(Entry<String, DocInfo> entry: metadata.entrySet()) {
+                DocInfo docInfo = entry.getValue();
+                if (docInfo.getService() != null) {
+                    if (!concreteWsdl) {
+                        concreteWsdl = true;
+                    } else {
+                        throw new ServerRtException("duplicate.primary.wsdl", entry.getKey());
+                    }
+                }
+                if (docInfo.isHavingPortType()) {
+                    if (!abstractWsdl) {
+                        abstractWsdl = true;
+                    } else {
+                        throw new ServerRtException("duplicate.abstract.wsdl", entry.getKey());
+                    }
+                }
+            }
+        }
+        if (metadata != null) {
+            for(Entry<String, DocInfo> entry: metadata.entrySet()) {
+                DocInfo docInfo = entry.getValue();
+                if (docInfo.getService() != null) {
+                    // Donot generate any WSDL or Schema document
+                    URL wsdlUrl = new URL(entry.getKey());
+                    EntityResolver resolver = new EndpointEntityResolver(metadata);
+                    endpointInfo.setWsdlInfo(wsdlUrl, resolver);
+                    docInfo.setQueryString("wsdl");
+                    break;
+                }
+            }
+        }
+    }
+
+    /**
+     * Fills RuntimeEndpointInfo with ServiceName, and PortName from properties
+     */
+    public void fillEndpointInfo() throws Exception {
+        // set Service Name from properties on RuntimeEndpointInfo
+        setServiceName();
+
+        // set Port Name from properties on RuntimeEndpointInfo
+        setPortName();
+
+        // Sets the correct Service Name
+        endpointInfo.doServiceNameProcessing();
+
+        // Sets the correct Port Name
+        endpointInfo.doPortNameProcessing();
+
+        // Sets the PortType Name
+        endpointInfo.doPortTypeNameProcessing();
+
+        // Creates DocInfo from metadata and sets it on RuntimeEndpointinfo
+        setDocInfo();
+
+        // Fill DocInfo with docuent info : WSDL or Schema, targetNS etc.
+        RuntimeEndpointInfo.fillDocInfo(endpointInfo);
+
+        // Finds primary WSDL from metadata documents
+        findPrimaryWSDL();
+
+    }
+
+    /**
+     * Generates necessary WSDL and Schema documents
+     */
+    public void generateWSDLDocs() {
+        if (endpointInfo.needWSDLGeneration()) {
+            endpointInfo.generateWSDL();
+        }
+    }
+
+    public void publish(String address) {
+        try {
+            this.address = address;
+            httpContext = ServerMgr.getInstance().createContext(address);
+            try {
+                publish(httpContext);
+            } catch(Exception e) {
+                ServerMgr.getInstance().removeContext(httpContext);
+                throw e;
+            }
+        } catch(Exception e) {
+            throw new ServerRtException("server.rt.err", e );
+        }
+    }
+
+    public void publish(Object serverContext) {
+        this.httpContext = (HttpContext)serverContext;
+        try {
+            publish(httpContext);
+        } catch(Exception e) {
+            throw new ServerRtException("server.rt.err", new Object[] { e } );
+        }
+    }
+
+    public void stop() {
+        if (address == null) {
+            // Application created its own HttpContext
+            httpContext.getServer().removeContext(httpContext);
+        } else {
+            // Remove HttpContext created by JAXWS runtime
+            ServerMgr.getInstance().removeContext(httpContext);
+        }
+
+        // Invoke WebService Life cycle method
+        endpointInfo.endService();
+    }
+
+    private void publish (HttpContext context) throws Exception {
+        endpointInfo.verifyImplementorClass();
+        fillEndpointInfo();
+        endpointInfo.init();
+        generateWSDLDocs();
+        RuntimeEndpointInfo.publishWSDLDocs(endpointInfo);
+        logger.fine("Doc Metadata="+endpointInfo.getDocMetadata());
+        WebServiceContext wsContext = new WebServiceContextImpl();
+        endpointInfo.setWebServiceContext(wsContext);
+        endpointInfo.injectContext();
+        endpointInfo.beginService();
+        Tie tie = new Tie();
+        context.setHandler(new WSHttpHandler(tie, endpointInfo, executor));
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/ServerConnectionImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/ServerConnectionImpl.java
new file mode 100644
index 0000000..960d312
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/ServerConnectionImpl.java
@@ -0,0 +1,255 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.server;
+
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.nio.ByteBuffer;
+
+import com.sun.xml.internal.ws.pept.ept.EPTFactory;
+import com.sun.xml.internal.ws.transport.WSConnectionImpl;
+import com.sun.net.httpserver.HttpExchange;
+
+import java.net.HttpURLConnection;
+import java.util.ArrayList;
+import java.util.Enumeration;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+
+/**
+ * <code>com.sun.xml.internal.ws.spi.runtime.WSConnection</code> used with Java SE endpoints
+ *
+ * @author WS Development Team
+ */
+public class ServerConnectionImpl extends WSConnectionImpl {
+
+    private HttpExchange httpExchange;
+    private int status;
+    private Map<String,List<String>> requestHeaders;
+    private Map<String,List<String>> responseHeaders;
+    private NoCloseInputStream is;
+    private NoCloseOutputStream out;
+    private boolean closedInput;
+    private boolean closedOutput;
+
+    public ServerConnectionImpl(HttpExchange httpTransaction) {
+        this.httpExchange = httpTransaction;
+    }
+
+    public Map<String,List<String>> getHeaders() {
+        return httpExchange.getRequestHeaders();
+    }
+
+    /**
+     * sets response headers.
+     */
+    public void setHeaders(Map<String,List<String>> headers) {
+        responseHeaders = headers;
+    }
+
+    public void setStatus(int status) {
+        this.status = status;
+    }
+
+    /**
+     * sets HTTP status code
+     */
+    public int getStatus() {
+        if (status == 0) {
+            status = HttpURLConnection.HTTP_INTERNAL_ERROR;
+        }
+        return status;
+    }
+
+    public InputStream getInput() {
+        if (is == null) {
+            is = new NoCloseInputStream(httpExchange.getRequestBody());
+        }
+        return is;
+    }
+
+    public OutputStream getOutput() {
+        if (out == null) {
+            try {
+                closeInput();
+                int len = 0;
+                if (responseHeaders != null) {
+                    for(Map.Entry <String, List<String>> entry : responseHeaders.entrySet()) {
+                        String name = entry.getKey();
+                        List<String> values = entry.getValue();
+                        if (name.equals("Content-Length")) {
+                            // No need to add this header
+                            len = Integer.valueOf(values.get(0));
+                        } else {
+                            for(String value : values) {
+                                httpExchange.getResponseHeaders().add(name, value);
+                            }
+                        }
+                    }
+                }
+
+                // write HTTP status code, and headers
+                httpExchange.sendResponseHeaders(getStatus(), len);
+                out = new NoCloseOutputStream(httpExchange.getResponseBody());
+            } catch(IOException ioe) {
+                ioe.printStackTrace();
+            }
+        }
+        return out;
+    }
+
+    public void closeOutput() {
+        if (out != null) {
+            try {
+                out.getOutputStream().close();
+                closedOutput = true;
+            } catch (IOException ex) {
+                ex.printStackTrace();
+            }
+        }
+        out = null;
+    }
+
+    public void closeInput() {
+        if (is != null) {
+            try {
+                // Read everything from request and close it
+                byte[] buf = new byte[1024];
+                while (is.read(buf) != -1) {
+                }
+                is.getInputStream().close();
+                closedInput = true;
+            } catch (IOException ex) {
+                ex.printStackTrace();
+            }
+        }
+        is = null;
+    }
+
+    public void close() {
+        httpExchange.close();
+    }
+
+    private static class NoCloseInputStream extends InputStream {
+        private InputStream is;
+
+        public NoCloseInputStream(InputStream is) {
+            this.is = is;
+        }
+
+        @Override
+        public int read() throws IOException {
+            return is.read();
+        }
+
+        @Override
+        public void close() throws IOException {
+            // Intentionally left empty. use closeInput() to close
+        }
+
+        public InputStream getInputStream() {
+            return is;
+        }
+
+        @Override
+        public int read(byte b[]) throws IOException {
+            return is.read(b);
+        }
+
+        @Override
+        public int read(byte b[], int off, int len) throws IOException {
+            return is.read(b, off, len);
+        }
+
+        @Override
+        public long skip(long n) throws IOException {
+            return is.skip(n);
+        }
+
+        @Override
+        public int available() throws IOException {
+            return is.available();
+        }
+
+        @Override
+        public void mark(int readlimit) {
+            is.mark(readlimit);
+        }
+
+
+        @Override
+        public void reset() throws IOException {
+            is.reset();
+        }
+
+        @Override
+        public boolean markSupported() {
+            return is.markSupported();
+        }
+    }
+
+    private static class NoCloseOutputStream extends OutputStream {
+        private OutputStream out;
+
+        public NoCloseOutputStream(OutputStream out) {
+            this.out = out;
+        }
+
+        @Override
+        public void write(int ch) throws IOException {
+            out.write(ch);
+        }
+
+        @Override
+        public void close() throws IOException {
+            // Intentionally left empty. use closeOutput() to close
+        }
+
+        @Override
+        public void write(byte b[]) throws IOException {
+            out.write(b);
+        }
+
+        @Override
+        public void write(byte b[], int off, int len) throws IOException {
+            out.write(b, off, len);
+        }
+
+        @Override
+        public void flush() throws IOException {
+            out.flush();
+        }
+
+        public OutputStream getOutputStream() {
+            return out;
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/ServerMgr.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/ServerMgr.java
new file mode 100644
index 0000000..5c871ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/ServerMgr.java
@@ -0,0 +1,148 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.transport.http.server;
+
+import com.sun.net.httpserver.HttpContext;
+import com.sun.net.httpserver.HttpServer;
+import com.sun.net.httpserver.HttpsConfigurator;
+import com.sun.net.httpserver.HttpsServer;
+import com.sun.xml.internal.ws.server.ServerRtException;
+import java.net.InetSocketAddress;
+import java.net.URL;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
+import java.util.logging.Logger;
+import javax.net.ssl.SSLContext;
+
+/**
+ * Manages all the WebService HTTP servers created by JAXWS runtime.
+ *
+ * @author WS Development Team
+ */
+public class ServerMgr {
+
+    private static final ServerMgr serverMgr = new ServerMgr();
+    private static final Logger logger =
+        Logger.getLogger(
+            com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".server.http");
+    private Map<InetSocketAddress, ServerState> servers = new HashMap();
+
+    protected ServerMgr() {
+    }
+
+    public static ServerMgr getInstance() {
+        return serverMgr;
+    }
+
+    /*
+     * Creates a HttpContext at the given address. If there is already a server
+     * it uses that server to create a context. Otherwise, it creates a new
+     * HTTP server. This sever is added to servers Map.
+     */
+    public HttpContext createContext(String address) {
+        try {
+            HttpServer server = null;
+            ServerState state = null;
+            boolean started = false;
+            URL url = new URL(address);
+            int port = url.getPort();
+            if (port == -1) {
+                port = url.getDefaultPort();
+            }
+            InetSocketAddress inetAddress = new InetSocketAddress(url.getHost(),
+                    url.getPort());
+            synchronized(servers) {
+                state = servers.get(inetAddress);
+                if (state == null) {
+                    logger.fine("Creating new HTTP Server at "+inetAddress);
+                    server = HttpServer.create(inetAddress, 5);
+                    server.setExecutor(Executors.newFixedThreadPool(5));
+                    logger.fine("Creating HTTP Context at = "+url.getPath());
+                    HttpContext context = server.createContext(url.getPath());
+                    server.start();
+                    logger.fine("HTTP server started = "+inetAddress);
+                    state = new ServerState(server);
+                    servers.put(inetAddress, state);
+                    return context;
+                }
+            }
+            server = state.getServer();
+            logger.fine("Creating HTTP Context at = "+url.getPath());
+            HttpContext context = server.createContext(url.getPath());
+            state.oneMoreContext();
+            return context;
+        } catch(Exception e) {
+            throw new ServerRtException("server.rt.err",e );
+        }
+    }
+
+    /*
+     * Removes a context. If the server doesn't have anymore contexts, it
+     * would stop the server and server is removed from servers Map.
+     */
+    public void removeContext(HttpContext context) {
+        InetSocketAddress inetAddress = context.getServer().getAddress();
+        synchronized(servers) {
+            ServerState state = servers.get(inetAddress);
+            int instances = state.noOfContexts();
+            if (instances < 2) {
+                ((ExecutorService)state.getServer().getExecutor()).shutdown();
+                state.getServer().stop(0);
+                servers.remove(inetAddress);
+            } else {
+                state.getServer().removeContext(context);
+                state.oneLessContext();
+            }
+        }
+    }
+
+    private static class ServerState {
+        private HttpServer server;
+        private int instances;
+
+        ServerState(HttpServer server) {
+            this.server = server;
+            this.instances = 1;
+        }
+
+        public HttpServer getServer() {
+            return server;
+        }
+
+        public void oneMoreContext() {
+            ++instances;
+        }
+
+        public void oneLessContext() {
+            --instances;
+        }
+
+        public int noOfContexts() {
+            return instances;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/WSHttpHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/WSHttpHandler.java
new file mode 100644
index 0000000..e66bb5e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/WSHttpHandler.java
@@ -0,0 +1,287 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.http.server;
+
+import com.sun.net.httpserver.HttpHandler;
+import com.sun.net.httpserver.HttpExchange;
+import com.sun.net.httpserver.HttpsExchange;
+import com.sun.xml.internal.ws.handler.MessageContextImpl;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import com.sun.xml.internal.ws.server.DocInfo;
+import com.sun.xml.internal.ws.server.WSDLPatcher;
+import java.util.concurrent.Executor;
+import javax.xml.ws.handler.MessageContext;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.server.Tie;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.spi.runtime.WebServiceContext;
+import com.sun.xml.internal.ws.transport.Headers;
+import com.sun.xml.internal.ws.util.localization.LocalizableMessageFactory;
+import com.sun.xml.internal.ws.util.localization.Localizer;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.io.PrintWriter;
+import java.net.HttpURLConnection;
+import java.net.URI;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.logging.Logger;
+
+/**
+ * Implementation of HttpContext's HttpHandler. HttpServer calls this when there
+ * is request that matches the context path. Then the handler processes
+ * HttpExchange and sends appropriate response
+ *
+ * @author WS Development Team
+ */
+public class WSHttpHandler implements HttpHandler {
+
+    private static final String GET_METHOD = "GET";
+    private static final String POST_METHOD = "POST";
+    private static final String HEAD_METHOD = "HEAD";
+    private static final String PUT_METHOD = "PUT";
+    private static final String DELETE_METHOD = "DELETE";
+    private static final String HTML_CONTENT_TYPE = "text/html";
+    private static final String XML_CONTENT_TYPE = "text/xml";
+    private static final String CONTENT_TYPE_HEADER = "Content-Type";
+
+    private static final Logger logger =
+        Logger.getLogger(
+            com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".server.http");
+    private static final Localizer localizer = new Localizer();
+    private static final LocalizableMessageFactory messageFactory =
+        new LocalizableMessageFactory("com.sun.xml.internal.ws.resources.httpserver");
+
+    private final RuntimeEndpointInfo endpointInfo;
+    private final Tie tie;
+    private final Executor executor;
+
+    public WSHttpHandler(Tie tie, RuntimeEndpointInfo endpointInfo, Executor executor) {
+        this.tie = tie;
+        this.endpointInfo = endpointInfo;
+        this.executor = executor;
+    }
+
+    /**
+     * Called by HttpServer when there is a matching request for the context
+     */
+    public void handle(HttpExchange msg) {
+        logger.fine("Received HTTP request:"+msg.getRequestURI());
+        if (executor != null) {
+            // Use endpoint's Executor to handle request
+            executor.execute(new HttpHandlerRunnable(msg));
+        } else {
+            handleExchange(msg);
+        }
+    }
+
+    /**
+     * Handles the HTTP request for GET, POST
+     *
+     */
+    private void handleExchange(HttpExchange msg) {
+        try {
+            String method = msg.getRequestMethod();
+            if (method.equals(GET_METHOD)) {
+                String queryString = msg.getRequestURI().getQuery();
+                logger.fine("Query String for request ="+queryString);
+                if (queryString != null &&
+                    (queryString.equals("WSDL") || queryString.equals("wsdl")
+                    || queryString.startsWith("wsdl=") || queryString.startsWith("xsd="))) {
+                    // Handles WSDL, Schema documents
+                    processDocRequest(msg);
+                } else {
+                    process(msg);
+                }
+            } else if (method.equals(POST_METHOD) || method.equals(HEAD_METHOD)
+                        || method.equals(PUT_METHOD) || method.equals(DELETE_METHOD)) {
+                process(msg);
+            } else {
+                logger.warning(
+                    localizer.localize(
+                        messageFactory.getMessage(
+                            "unexpected.http.method", method)));
+                msg.close();
+            }
+        } catch(Exception e) {
+            e.printStackTrace();
+        }
+    }
+
+    /**
+     * Wrapping the processing of request in a Runnable so that it can be
+     * executed in Executor.
+     */
+    class HttpHandlerRunnable implements Runnable {
+        final HttpExchange msg;
+
+        HttpHandlerRunnable(HttpExchange msg) {
+            this.msg = msg;
+        }
+
+        public void run() {
+            handleExchange(msg);
+        }
+    }
+
+    /**
+     * Handles POST requests
+     */
+    private void process(HttpExchange msg) {
+        WSConnection con = new ServerConnectionImpl(msg);
+        try {
+            MessageContext msgCtxt = new MessageContextImpl();
+            WebServiceContext wsContext = endpointInfo.getWebServiceContext();
+            wsContext.setMessageContext(msgCtxt);
+            MessageContextUtil.setHttpRequestMethod(msgCtxt, msg.getRequestMethod());
+            MessageContextUtil.setHttpRequestHeaders(msgCtxt, con.getHeaders());
+            MessageContextUtil.setHttpExchange(msgCtxt, msg);
+            URI requestUri = msg.getRequestURI();
+            String query = requestUri.getQuery();
+            if (query != null) {
+                MessageContextUtil.setQueryString(msgCtxt, query);
+            }
+            String reqPath = requestUri.getPath();
+            String ctxtPath = msg.getHttpContext().getPath();
+            if (reqPath.length() > ctxtPath.length()) {
+                String extraPath = reqPath.substring(ctxtPath.length());
+                MessageContextUtil.setPathInfo(msgCtxt, extraPath);
+            }
+            tie.handle(con, endpointInfo);
+        } catch(Exception e) {
+            e.printStackTrace();
+        } finally {
+            con.close();
+        }
+    }
+
+    /**
+     * Handles GET requests for WSDL and Schema docuemnts
+     */
+    public void processDocRequest(HttpExchange msg) {
+        WSConnection con = new ServerConnectionImpl(msg);
+        try {
+            con.getInput();
+            String queryString = msg.getRequestURI().getQuery();
+            String inPath = endpointInfo.getPath(queryString);
+            if (inPath == null) {
+                String message =
+                    localizer.localize(
+                        messageFactory.getMessage("html.notFound",
+                            "Invalid Request ="+msg.getRequestURI()));
+                writeErrorPage(con, HttpURLConnection.HTTP_NOT_FOUND, message);
+                return;
+            }
+            DocInfo docInfo = endpointInfo.getDocMetadata().get(inPath);
+            if (docInfo == null) {
+                String message =
+                    localizer.localize(
+                        messageFactory.getMessage("html.notFound",
+                            "Invalid Request ="+msg.getRequestURI()));
+                writeErrorPage(con, HttpURLConnection.HTTP_NOT_FOUND, message);
+                return;
+            }
+
+            InputStream docStream = null;
+            try {
+                Map<String, List<String>> reqHeaders = con.getHeaders();
+                List<String> hostHeader = reqHeaders.get("Host");
+
+                Headers respHeaders = new Headers();
+                respHeaders.add(CONTENT_TYPE_HEADER, XML_CONTENT_TYPE);
+                con.setHeaders(respHeaders);
+                con.setStatus(HttpURLConnection.HTTP_OK);
+                OutputStream os = con.getOutput();
+
+                List<RuntimeEndpointInfo> endpoints = new ArrayList<RuntimeEndpointInfo>();
+                endpoints.add(endpointInfo);
+
+                StringBuffer strBuf = new StringBuffer();
+                strBuf.append((msg instanceof HttpsExchange) ? "https" : "http");
+                strBuf.append("://");
+                if (hostHeader != null) {
+                    strBuf.append(hostHeader.get(0));   // Uses Host header
+                } else {
+                    strBuf.append(msg.getLocalAddress().getHostName());
+                    strBuf.append(":");
+                    strBuf.append(msg.getLocalAddress().getPort());
+                }
+                strBuf.append(msg.getRequestURI().getPath());
+                String address = strBuf.toString();
+                logger.fine("Address ="+address);
+                WSDLPatcher patcher = new WSDLPatcher(docInfo, address,
+                        endpointInfo, endpoints);
+                docStream = docInfo.getDoc();
+                patcher.patchDoc(docStream, os);
+            } finally {
+                closeInputStream(docStream);
+                con.closeOutput();
+            }
+        } finally {
+            con.close();
+        }
+    }
+
+    /**
+     * writes error html page
+     */
+    private void writeErrorPage(WSConnection con, int status, String message) {
+        try {
+            Map<String,List<String>> headers = new HashMap<String, List<String>>();
+            List<String> ctHeader = new ArrayList<String>();
+            ctHeader.add(HTML_CONTENT_TYPE);
+            headers.put(CONTENT_TYPE_HEADER, ctHeader);
+            con.setHeaders(headers);
+            con.setStatus(status);
+            OutputStream outputStream = con.getOutput();
+            PrintWriter out = new PrintWriter(outputStream);
+            out.println("<html><head><title>");
+            out.println(
+                localizer.localize(
+                    messageFactory.getMessage("html.title")));
+            out.println("</title></head><body>");
+            out.println(message);
+            out.println("</body></html>");
+            out.close();
+        } finally {
+            con.closeOutput();
+        }
+    }
+
+    private static void closeInputStream(InputStream is) {
+        if (is != null) {
+            try {
+                is.close();
+            } catch(IOException ioe) {
+                ioe.printStackTrace();
+            }
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/WebServiceContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/WebServiceContextImpl.java
new file mode 100644
index 0000000..a652e65
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/http/server/WebServiceContextImpl.java
@@ -0,0 +1,63 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.transport.http.server;
+import com.sun.net.httpserver.HttpExchange;
+import com.sun.xml.internal.ws.handler.MessageContextUtil;
+import java.security.Principal;
+import com.sun.xml.internal.ws.spi.runtime.WebServiceContext;
+import javax.xml.ws.handler.MessageContext;
+
+
+public class WebServiceContextImpl implements WebServiceContext  {
+
+    public ThreadLocal msgContext = new ThreadLocal();
+
+    public MessageContext getMessageContext() {
+        MessageContext ctxt = (MessageContext)msgContext.get();
+        if (ctxt == null) {
+            throw new IllegalStateException();
+        }
+        return ctxt;
+    }
+
+    public void setMessageContext(MessageContext ctxt) {
+        msgContext.set(ctxt);
+    }
+
+    public Principal getUserPrincipal() {
+        MessageContext ctxt = (MessageContext)msgContext.get();
+        if (ctxt != null) {
+            HttpExchange req = MessageContextUtil.getHttpExchange(ctxt);
+            return (req != null) ? req.getPrincipal() : null;
+        }
+        throw new IllegalStateException();
+    }
+
+
+    public boolean isUserInRole(String role) {
+        return false;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/LocalMessage.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/LocalMessage.java
new file mode 100644
index 0000000..be979ac
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/LocalMessage.java
@@ -0,0 +1,60 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.local;
+
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+
+import java.io.ByteArrayOutputStream;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @author WS Development Team
+ */
+public class LocalMessage {
+    ByteArrayBuffer baos;
+    Map<String, List<String>> headers;
+
+    public LocalMessage () {
+    }
+
+    public ByteArrayBuffer getOutput() {
+        return baos;
+    }
+
+    public void setOutput(ByteArrayBuffer baos) {
+        this.baos = baos;
+    }
+
+    public Map<String, List<String>> getHeaders() {
+        return headers;
+    }
+
+    public void setHeaders(Map<String, List<String>> headers) {
+        this.headers = headers;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/client/LocalClientTransport.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/client/LocalClientTransport.java
new file mode 100644
index 0000000..28178f0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/client/LocalClientTransport.java
@@ -0,0 +1,167 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.local.client;
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.OutputStream;
+import com.sun.xml.internal.ws.client.ClientTransportException;
+import com.sun.xml.internal.ws.handler.MessageContextImpl;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.server.Tie;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.spi.runtime.WebServiceContext;
+import com.sun.xml.internal.ws.transport.WSConnectionImpl;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+
+import java.io.InputStream;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.HashSet;
+import java.net.HttpURLConnection;
+import java.net.ProtocolException;
+
+import com.sun.xml.internal.ws.transport.local.server.LocalConnectionImpl;
+import com.sun.xml.internal.ws.transport.local.LocalMessage;
+
+import static com.sun.xml.internal.ws.developer.JAXWSProperties.CONTENT_NEGOTIATION_PROPERTY;
+
+import javax.xml.ws.http.HTTPException;
+
+/**
+ * @author WS Development Team
+ */
+public class LocalClientTransport extends WSConnectionImpl {
+
+    private RuntimeEndpointInfo endpointInfo;
+    private Tie tie = new Tie();
+    LocalMessage lm = new LocalMessage();
+
+    //this class is used primarily for debugging purposes
+    public LocalClientTransport(RuntimeEndpointInfo endpointInfo) {
+        this(endpointInfo, null);
+    }
+
+    public LocalClientTransport(RuntimeEndpointInfo endpointInfo,
+                                OutputStream logStream) {
+        this.endpointInfo = endpointInfo;
+        debugStream = logStream;
+    }
+
+
+    @Override
+    public OutputStream getOutput() {
+        try {
+            lm.setOutput(new ByteArrayBuffer());
+            return lm.getOutput();
+        }
+        catch (Exception ex) {
+            throw new ClientTransportException("local.client.failed",ex);
+        }
+    }
+
+    private static void checkMessageContentType(WSConnection con, boolean response) {
+        String negotiation = System.getProperty(CONTENT_NEGOTIATION_PROPERTY, "none").intern();
+        String contentType = con.getHeaders().get("Content-Type").get(0);
+
+        // Use indexOf() to handle Multipart/related types
+        if (negotiation == "none") {
+            // OK only if XML
+            if (contentType.indexOf("text/xml") < 0 &&
+                   contentType.indexOf("application/soap+xml") < 0 &&
+                   contentType.indexOf("application/xop+xml") < 0)
+            {
+                throw new RuntimeException("Invalid content type '" + contentType
+                    + "' with content negotiation set to '" + negotiation + "'.");
+            }
+        }
+        else if (negotiation == "optimistic") {
+            // OK only if FI
+            if (contentType.indexOf("application/fastinfoset") < 0 &&
+                   contentType.indexOf("application/soap+fastinfoset") < 0)
+            {
+                throw new RuntimeException("Invalid content type '" + contentType
+                    + "' with content negotiation set to '" + negotiation + "'.");
+            }
+        }
+        else if (negotiation == "pessimistic") {
+            // OK if FI request is anything and response is FI
+            if (response &&
+                    contentType.indexOf("application/fastinfoset") < 0 &&
+                    contentType.indexOf("application/soap+fastinfoset") < 0)
+            {
+                throw new RuntimeException("Invalid content type '" + contentType
+                    + "' with content negotiation set to '" + negotiation + "'.");
+            }
+        }
+    }
+
+    @Override
+    public void closeOutput() {
+        super.closeOutput();
+        WSConnection con = new LocalConnectionImpl(lm);
+
+        // Copy headers for content negotiation
+        con.setHeaders(getHeaders());
+
+        // Check request content type based on negotiation property
+        checkMessageContentType(this, false);
+
+        try {
+            // Set a MessageContext per invocation
+            WebServiceContext wsContext = endpointInfo.getWebServiceContext();
+            wsContext.setMessageContext(new MessageContextImpl());
+            tie.handle(con, endpointInfo);
+
+            checkMessageContentType(con, true);
+        }
+        catch (Exception ex) {
+            new ProtocolException("Server side Exception:" + ex);
+        }
+    }
+
+    @Override
+    public InputStream getInput() {
+        try {
+            return lm.getOutput().newInputStream();
+        }
+        catch (Exception ex) {
+            throw new ClientTransportException("local.client.failed",ex);
+        }
+    }
+
+    @Override
+    public void setHeaders(Map<String, List<String>> headers) {
+        lm.setHeaders(headers);
+    }
+
+    @Override
+    public Map<String, List<String>> getHeaders() {
+        return lm.getHeaders();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/client/LocalClientTransportFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/client/LocalClientTransportFactory.java
new file mode 100644
index 0000000..f1eb52f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/client/LocalClientTransportFactory.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.local.client;
+
+import java.io.OutputStream;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.spi.runtime.ClientTransportFactory;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+
+import java.util.Map;
+
+/**
+ * @author WS Development Team
+ */
+public class LocalClientTransportFactory implements ClientTransportFactory {
+    private RuntimeEndpointInfo endpointInfo;
+    private OutputStream logStream;
+
+    //this class is used primarily for debugging purposes
+    public LocalClientTransportFactory(RuntimeEndpointInfo endpointInfo) {
+        this(endpointInfo, null);
+    }
+
+    public LocalClientTransportFactory(RuntimeEndpointInfo endpointInfo,
+        OutputStream logStream) {
+        this.endpointInfo = endpointInfo;
+        this.logStream = logStream;
+    }
+
+    public WSConnection create() {
+        return create(null);
+    }
+
+    public WSConnection create(Map<String, Object> context) {
+        return new LocalClientTransport(endpointInfo, logStream);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/server/LocalConnectionImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/server/LocalConnectionImpl.java
new file mode 100644
index 0000000..8d411c2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/server/LocalConnectionImpl.java
@@ -0,0 +1,74 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.transport.local.server;
+import java.util.List;
+import java.util.Map;
+import com.sun.xml.internal.ws.transport.WSConnectionImpl;
+import com.sun.xml.internal.ws.transport.local.LocalMessage;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+
+import java.io.InputStream;
+import java.io.OutputStream;
+
+
+/**
+ * @author WS Development Team
+ *
+ * Server-side Local transport implementation
+ */
+public class LocalConnectionImpl extends WSConnectionImpl {
+    private int status;
+    private LocalMessage lm;
+
+    public LocalConnectionImpl (LocalMessage localMessage) {
+        this.lm = localMessage;
+    }
+
+    public Map<String,List<String>> getHeaders () {
+        return lm.getHeaders ();
+    }
+
+    /**
+     * sets response headers.
+     */
+    public void setHeaders (Map<String,List<String>> headers) {
+        lm.setHeaders (headers);
+    }
+
+    public void setStatus (int status) {
+        this.status = status;
+    }
+
+    public InputStream getInput () {
+        return lm.getOutput().newInputStream();
+    }
+
+    public OutputStream getOutput () {
+        ByteArrayBuffer bab = new ByteArrayBuffer();
+        lm.setOutput(bab);
+        return bab;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/server/LocalWSContextImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/server/LocalWSContextImpl.java
new file mode 100644
index 0000000..d312277
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/transport/local/server/LocalWSContextImpl.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.transport.local.server;
+import java.security.Principal;
+import com.sun.xml.internal.ws.spi.runtime.WebServiceContext;
+import javax.xml.ws.handler.MessageContext;
+
+
+public class LocalWSContextImpl implements WebServiceContext  {
+
+    public static ThreadLocal msgContext = new ThreadLocal();
+
+    public MessageContext getMessageContext() {
+        MessageContext ctxt = (MessageContext)msgContext.get();
+        if (ctxt == null) {
+            throw new IllegalStateException();
+        }
+        return ctxt;
+    }
+
+    public void setMessageContext(MessageContext ctxt) {
+        msgContext.set(ctxt);
+    }
+
+    public Principal getUserPrincipal() {
+        return null;
+    }
+
+
+    public boolean isUserInRole(String role) {
+        return false;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ASCIIUtility.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ASCIIUtility.java
new file mode 100644
index 0000000..dedbf1f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ASCIIUtility.java
@@ -0,0 +1,147 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.util;
+
+import java.io.InputStream;
+import java.io.IOException;
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.OutputStream;
+
+/**
+ * Copied from mail.jar.
+ */
+public class ASCIIUtility {
+    // Private constructor so that this class is not instantiated
+    private ASCIIUtility() { }
+
+
+    /**
+     * Convert the bytes within the specified range of the given byte
+     * array into a signed integer in the given radix . The range extends
+     * from <code>start</code> till, but not including <code>end</code>. <p>
+     *
+     * Based on java.lang.Integer.parseInt()
+     */
+    public static int parseInt(byte[] b, int start, int end, int radix)
+        throws NumberFormatException {
+        if (b == null)
+            throw new NumberFormatException("null");
+
+        int result = 0;
+        boolean negative = false;
+        int i = start;
+        int limit;
+        int multmin;
+        int digit;
+
+        if (end > start) {
+            if (b[i] == '-') {
+                negative = true;
+                limit = Integer.MIN_VALUE;
+                i++;
+            } else {
+                limit = -Integer.MAX_VALUE;
+            }
+            multmin = limit / radix;
+            if (i < end) {
+                digit = Character.digit((char)b[i++], radix);
+                if (digit < 0) {
+                    throw new NumberFormatException(
+                    "illegal number: " + toString(b, start, end)
+                    );
+                } else {
+                    result = -digit;
+                }
+            }
+            while (i < end) {
+                // Accumulating negatively avoids surprises near MAX_VALUE
+                digit = Character.digit((char)b[i++], radix);
+                if (digit < 0) {
+                    throw new NumberFormatException("illegal number");
+                }
+                if (result < multmin) {
+                    throw new NumberFormatException("illegal number");
+                }
+                result *= radix;
+                if (result < limit + digit) {
+                    throw new NumberFormatException("illegal number");
+                }
+                result -= digit;
+            }
+        } else {
+            throw new NumberFormatException("illegal number");
+        }
+        if (negative) {
+            if (i > start + 1) {
+                return result;
+            } else {    /* Only got "-" */
+                throw new NumberFormatException("illegal number");
+            }
+        } else {
+            return -result;
+        }
+    }
+
+    /**
+     * Convert the bytes within the specified range of the given byte
+     * array into a String. The range extends from <code>start</code>
+     * till, but not including <code>end</code>. <p>
+     */
+    public static String toString(byte[] b, int start, int end) {
+        int size = end - start;
+        char[] theChars = new char[size];
+
+        for (int i = 0, j = start; i < size; )
+            theChars[i++] = (char)(b[j++]&0xff);
+
+        return new String(theChars);
+    }
+
+    public static byte[] getBytes(String s) {
+        char [] chars= s.toCharArray();
+        int size = chars.length;
+        byte[] bytes = new byte[size];
+
+        for (int i = 0; i < size;)
+            bytes[i] = (byte) chars[i++];
+        return bytes;
+    }
+
+    public static byte[] getBytes(InputStream is) throws IOException {
+        ByteArrayBuffer bab = new ByteArrayBuffer();
+        bab.write(is);
+        return bab.toByteArray();
+    }
+
+    public static void copyStream(InputStream is, OutputStream out) throws IOException {
+        int size = 1024;
+        byte[] buf = new byte[size];
+        int len;
+
+        while ((len = is.read(buf, 0, size)) != -1)
+            out.write(buf, 0, len);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Base64Util.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Base64Util.java
new file mode 100644
index 0000000..6772878
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Base64Util.java
@@ -0,0 +1,177 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.util;
+
+/**
+ *
+ * @author jitu
+ */
+public class Base64Util {
+
+    protected static final char encodeBase64[] = {
+        'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M',
+        'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z',
+        'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm',
+        'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
+        '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '+', '/'
+    };
+
+    protected static final int decodeBase64[] = {
+        /*'+'*/ 62,
+        -1, -1, -1,
+        /*'/'*/ 63,
+        /*'0'*/ 52,
+        /*'1'*/ 53,
+        /*'2'*/ 54,
+        /*'3'*/ 55,
+        /*'4'*/ 56,
+        /*'5'*/ 57,
+        /*'6'*/ 58,
+        /*'7'*/ 59,
+        /*'8'*/ 60,
+        /*'9'*/ 61,
+        -1, -1, -1, -1, -1, -1, -1,
+        /*'A'*/ 0,
+        /*'B'*/ 1,
+        /*'C'*/ 2,
+        /*'D'*/ 3,
+        /*'E'*/ 4,
+        /*'F'*/ 5,
+        /*'G'*/ 6,
+        /*'H'*/ 7,
+        /*'I'*/ 8,
+        /*'J'*/ 9,
+        /*'K'*/ 10,
+        /*'L'*/ 11,
+        /*'M'*/ 12,
+        /*'N'*/ 13,
+        /*'O'*/ 14,
+        /*'P'*/ 15,
+        /*'Q'*/ 16,
+        /*'R'*/ 17,
+        /*'S'*/ 18,
+        /*'T'*/ 19,
+        /*'U'*/ 20,
+        /*'V'*/ 21,
+        /*'W'*/ 22,
+        /*'X'*/ 23,
+        /*'Y'*/ 24,
+        /*'Z'*/ 25,
+        -1, -1, -1, -1, -1, -1,
+        /*'a'*/ 26,
+        /*'b'*/ 27,
+        /*'c'*/ 28,
+        /*'d'*/ 29,
+        /*'e'*/ 30,
+        /*'f'*/ 31,
+        /*'g'*/ 32,
+        /*'h'*/ 33,
+        /*'i'*/ 34,
+        /*'j'*/ 35,
+        /*'k'*/ 36,
+        /*'l'*/ 37,
+        /*'m'*/ 38,
+        /*'n'*/ 39,
+        /*'o'*/ 40,
+        /*'p'*/ 41,
+        /*'q'*/ 42,
+        /*'r'*/ 43,
+        /*'s'*/ 44,
+        /*'t'*/ 45,
+        /*'u'*/ 46,
+        /*'v'*/ 47,
+        /*'w'*/ 48,
+        /*'x'*/ 49,
+        /*'y'*/ 50,
+        /*'z'*/ 51
+    };
+
+    public static String encode(byte[] value)
+        throws Exception {
+
+        if (value == null) {
+            return null;
+        }
+        if (value.length == 0) {
+            return "";
+        }
+        int blockCount = value.length / 3;
+        int partialBlockLength = value.length % 3;
+
+        if (partialBlockLength != 0) {
+            ++blockCount;
+        }
+
+        int encodedLength = blockCount * 4;
+        StringBuffer encodedValue = new StringBuffer(encodedLength);
+
+        int idx = 0;
+        for (int i = 0; i < blockCount; ++i) {
+            int b1 = value[idx++];
+            int b2 = (idx < value.length) ? value[idx++] : 0;
+            int b3 = (idx < value.length) ? value[idx++] : 0;
+
+            if (b1 < 0) {
+                b1 += 256;
+            }
+            if (b2 < 0) {
+                b2 += 256;
+            }
+            if (b3 < 0) {
+                b3 += 256;
+            }
+
+            char encodedChar;
+
+            encodedChar = encodeBase64[b1 >> 2];
+            encodedValue.append(encodedChar);
+
+            encodedChar = encodeBase64[((b1 & 0x03) << 4) | (b2 >> 4)];
+            encodedValue.append(encodedChar);
+
+            encodedChar = encodeBase64[((b2 & 0x0f) << 2) | (b3 >> 6)];
+            encodedValue.append(encodedChar);
+
+            encodedChar = encodeBase64[b3 & 0x3f];
+            encodedValue.append(encodedChar);
+        }
+
+        switch (partialBlockLength) {
+            case 0 :
+                // do nothing
+                break;
+            case 1 :
+                encodedValue.setCharAt(encodedLength - 1, '=');
+                encodedValue.setCharAt(encodedLength - 2, '=');
+                break;
+            case 2 :
+                encodedValue.setCharAt(encodedLength - 1, '=');
+                break;
+        }
+
+        return encodedValue.toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ByteArrayBuffer.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ByteArrayBuffer.java
new file mode 100644
index 0000000..35dfe43
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ByteArrayBuffer.java
@@ -0,0 +1,174 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+
+/**
+ * Read/write buffer that stores a sequence of bytes.
+ *
+ * <p>
+ * It works in a way similar to {@link ByteArrayOutputStream} but
+ * this class works better in the following ways:
+ *
+ * <ol>
+ *  <li>no synchronization
+ *  <li>offers a {@link #newInputStream()} that creates a new {@link InputStream}
+ *      that won't cause buffer reallocation.
+ *  <li>less parameter correctness checking
+ *  <li>offers a {@link #write(InputStream)} method that reads the entirety of the
+ *      given {@link InputStream} without using a temporary buffer.
+ * </ol>
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ByteArrayBuffer extends OutputStream {
+    /**
+     * The buffer where data is stored.
+     */
+    private byte buf[];
+
+    /**
+     * The number of valid bytes in the buffer.
+     */
+    private int count;
+
+    /**
+     * Creates a new byte array output stream. The buffer capacity is
+     * initially 32 bytes, though its size increases if necessary.
+     */
+    public ByteArrayBuffer() {
+        this(32);
+    }
+
+    /**
+     * Creates a new byte array output stream, with a buffer capacity of
+     * the specified size, in bytes.
+     *
+     * @param size the initial size.
+     * @throws IllegalArgumentException if size is negative.
+     */
+    public ByteArrayBuffer(int size) {
+        if (size <= 0)
+            throw new IllegalArgumentException();
+        buf = new byte[size];
+    }
+
+    public ByteArrayBuffer(byte[] data) {
+        this.buf = data;
+    }
+
+    /**
+     * Reads all the data of the given {@link InputStream} and appends them
+     * into this buffer.
+     *
+     * @throws IOException
+     *      if the read operation fails with an {@link IOException}.
+     */
+    public void write(InputStream in) throws IOException {
+        while(true) {
+            int cap = buf.length-count;     // the remaining buffer space
+            int sz = in.read(buf,count,cap);
+            if(sz<0)    return;     // hit EOS
+            count += sz;
+
+
+            if(cap==sz)
+                ensureCapacity(buf.length*2);   // buffer filled up.
+        }
+    }
+
+    public void write(int b) {
+        int newcount = count + 1;
+        ensureCapacity(newcount);
+        buf[count] = (byte) b;
+        count = newcount;
+    }
+
+    public void write(byte b[], int off, int len) {
+        int newcount = count + len;
+        ensureCapacity(newcount);
+        System.arraycopy(b, off, buf, count, len);
+        count = newcount;
+    }
+
+    private void ensureCapacity(int newcount) {
+        if (newcount > buf.length) {
+            byte newbuf[] = new byte[Math.max(buf.length << 1, newcount)];
+            System.arraycopy(buf, 0, newbuf, 0, count);
+            buf = newbuf;
+        }
+    }
+
+    public void writeTo(OutputStream out) throws IOException {
+        out.write(buf, 0, count);
+    }
+
+    public void reset() {
+        count = 0;
+    }
+
+    /**
+     * Gets the <b>copy</b> of exact-size byte[] that represents the written data.
+     *
+     * <p>
+     * Since this method needs to allocate a new byte[], this method will be costly.
+     *
+     * @deprecated
+     *      this method causes a buffer reallocation. Use it only when
+     *      you have to.
+     */
+    public byte toByteArray()[] {
+        byte newbuf[] = new byte[count];
+        System.arraycopy(buf, 0, newbuf, 0, count);
+        return newbuf;
+    }
+
+    public int size() {
+        return count;
+    }
+
+    public void close() {
+    }
+
+    /**
+     * Creates a new {@link InputStream} that reads from this buffer.
+     */
+    public InputStream newInputStream() {
+        return new ByteArrayInputStream(buf,0,count);
+    }
+
+    /**
+     * Creates a new {@link InputStream} that reads a part of this bfufer.
+     */
+    public InputStream newInputStream(int start, int length) {
+        return new ByteArrayInputStream(buf,start,length);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ByteArrayDataSource.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ByteArrayDataSource.java
new file mode 100644
index 0000000..9463e63
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/ByteArrayDataSource.java
@@ -0,0 +1,75 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.util;
+
+import java.io.ByteArrayInputStream;
+import java.io.InputStream;
+import java.io.OutputStream;
+
+import javax.activation.DataSource;
+
+/**
+ * {@link DataSource} backed by a byte buffer.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ByteArrayDataSource implements DataSource {
+
+    private final String contentType;
+    private final byte[] buf;
+    private final int start;
+    private final int len;
+
+    public ByteArrayDataSource(byte[] buf, String contentType) {
+        this(buf,0,buf.length,contentType);
+    }
+    public ByteArrayDataSource(byte[] buf, int length, String contentType) {
+        this(buf,0,length,contentType);
+    }
+    public ByteArrayDataSource(byte[] buf, int start, int length, String contentType) {
+        this.buf = buf;
+        this.start = start;
+        this.len = length;
+        this.contentType = contentType;
+    }
+
+    public String getContentType() {
+        if(contentType==null)
+            return "application/octet-stream";
+        return contentType;
+    }
+
+    public InputStream getInputStream() {
+        return new ByteArrayInputStream(buf,start,len);
+    }
+
+    public String getName() {
+        return null;
+    }
+
+    public OutputStream getOutputStream() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Constants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Constants.java
new file mode 100644
index 0000000..7c44119
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Constants.java
@@ -0,0 +1,40 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+/**
+ * This holds generic constants information for the whole JAX-WS SI.
+ *
+ * @author WS Development Team
+ */
+
+public class Constants {
+    /**
+     * WS SI Logging Domain
+     */
+    public static final String LoggingDomain =
+        "javax.enterprise.resource.webservices.jaxws";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/DOMUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/DOMUtil.java
new file mode 100644
index 0000000..a9de941
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/DOMUtil.java
@@ -0,0 +1,89 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import org.w3c.dom.Document;
+import org.w3c.dom.Node;
+import org.xml.sax.SAXException;
+
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.FactoryConfigurationError;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.transform.Source;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.dom.DOMResult;
+import java.io.InputStream;
+import java.io.IOException;
+
+/**
+ * $author: JAXWS Development Team
+ */
+public class DOMUtil {
+
+    private static DocumentBuilder db;
+
+    /**
+     * Creates a new DOM document.
+     */
+    public static Document createDom() {
+        synchronized (DOMUtil.class) {
+            if (db == null) {
+                try {
+                    DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+                    dbf.setNamespaceAware(true);
+                    db = dbf.newDocumentBuilder();
+                } catch (ParserConfigurationException e) {
+                    throw new FactoryConfigurationError(e);
+                }
+            }
+            return db.newDocument();
+        }
+    }
+
+    public static Node createDOMNode(InputStream inputStream) {
+
+        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+        dbf.setNamespaceAware(true);
+        dbf.setValidating(false);
+        try {
+            DocumentBuilder builder = dbf.newDocumentBuilder();
+            try {
+                return builder.parse(inputStream);
+            } catch (SAXException e) {
+                e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.
+            } catch (IOException e) {
+                e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.
+            }
+        } catch (ParserConfigurationException pce) {
+            IllegalArgumentException iae = new IllegalArgumentException(pce.getMessage());
+            iae.initCause(pce);
+            throw iae;
+        }
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/FastInfosetReflection.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/FastInfosetReflection.java
new file mode 100644
index 0000000..c938deb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/FastInfosetReflection.java
@@ -0,0 +1,289 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.lang.reflect.Constructor;
+import java.lang.reflect.Method;
+import javax.xml.transform.Result;
+import javax.xml.transform.Source;
+import org.w3c.dom.Document;
+import org.w3c.dom.Node;
+
+
+/**
+ *
+ * @author Santiago.PericasGeertsen@sun.com
+ * @author Paul.Sandoz@sun.com
+ */
+public class FastInfosetReflection {
+    /**
+     *
+     */
+    public static ClassLoader fiClassLoader;
+
+    /**
+     * FI StAXDocumentParser constructor using reflection.
+     */
+    public static Constructor fiStAXDocumentParser_new;
+
+    /**
+     * FI <code>StAXDocumentParser.setInputStream()</code> method via reflection.
+     */
+    public static Method fiStAXDocumentParser_setInputStream;
+
+    /**
+     * FI <code>StAXDocumentParser.setStringInterning()</code> method via reflection.
+     */
+    public static Method fiStAXDocumentParser_setStringInterning;
+
+    /**
+     * FI StAXDocumentSerializer constructor using reflection.
+     */
+    public static Constructor fiStAXDocumentSerializer_new;
+
+    /**
+     * FI <code>StAXDocumentSerializer.setOutputStream()</code> method via reflection.
+     */
+    public static Method fiStAXDocumentSerializer_setOutputStream;
+
+    /**
+     * FI <code>StAXDocumentSerializer.setEncoding()</code> method via reflection.
+     */
+    public static Method fiStAXDocumentSerializer_setEncoding;
+
+    /**
+     * FI DOMDocumentParser constructor using reflection.
+     */
+    public static Constructor fiDOMDocumentParser_new;
+
+    /**
+     * FI <code>DOMDocumentParser.parse()</code> method via reflection.
+     */
+    public static Method fiDOMDocumentParser_parse;
+
+    /**
+     * FI DOMDocumentSerializer constructor using reflection.
+     */
+    public static Constructor fiDOMDocumentSerializer_new;
+
+    /**
+     * FI <code>FastInfosetSource.serialize(Document)</code> method via reflection.
+     */
+    public static Method fiDOMDocumentSerializer_serialize;
+
+    /**
+     * FI <code>FastInfosetSource.setOutputStream(OutputStream)</code> method via reflection.
+     */
+    public static Method fiDOMDocumentSerializer_setOutputStream;
+
+    /**
+     * FI FastInfosetSource class.
+     */
+    public static Class fiFastInfosetSource;
+
+    /**
+     * FI FastInfosetSource constructor using reflection.
+     */
+    public static Constructor fiFastInfosetSource_new;
+
+    /**
+     * FI <code>FastInfosetSource.getInputStream()</code> method via reflection.
+     */
+    public static Method fiFastInfosetSource_getInputStream;
+
+    /**
+     * FI <code>FastInfosetSource.setInputSTream()</code> method via reflection.
+     */
+    public static Method fiFastInfosetSource_setInputStream;
+
+    /**
+     * FI FastInfosetResult class using reflection.
+     */
+    public static Class fiFastInfosetResult;
+
+    /**
+     * FI FastInfosetResult constructor using reflection.
+     */
+    public static Constructor fiFastInfosetResult_new;
+
+    /**
+     * FI <code>FastInfosetResult.getOutputSTream()</code> method via reflection.
+     */
+    public static Method fiFastInfosetResult_getOutputStream;
+
+    static {
+        // Use reflection to avoid static dependency with FI jar
+        try {
+            Class clazz = null;
+            clazz = Class.forName("com.sun.xml.internal.fastinfoset.stax.StAXDocumentParser");
+            fiStAXDocumentParser_new = clazz.getConstructor();
+            fiStAXDocumentParser_setInputStream =
+                clazz.getMethod("setInputStream", java.io.InputStream.class);
+            fiStAXDocumentParser_setStringInterning =
+                clazz.getMethod("setStringInterning", boolean.class);
+
+            clazz =
+                Class.forName("com.sun.xml.internal.fastinfoset.stax.StAXDocumentSerializer");
+            fiStAXDocumentSerializer_new = clazz.getConstructor();
+            fiStAXDocumentSerializer_setOutputStream =
+                clazz.getMethod("setOutputStream", java.io.OutputStream.class);
+            fiStAXDocumentSerializer_setEncoding =
+                clazz.getMethod("setEncoding", String.class);
+
+            clazz =
+                Class.forName("com.sun.xml.internal.fastinfoset.dom.DOMDocumentParser");
+            fiDOMDocumentParser_new = clazz.getConstructor();
+            fiDOMDocumentParser_parse = clazz.getMethod("parse",
+                new Class[] { org.w3c.dom.Document.class, java.io.InputStream.class });
+
+            clazz = Class.forName("com.sun.xml.internal.fastinfoset.dom.DOMDocumentSerializer");
+            fiDOMDocumentSerializer_new = clazz.getConstructor();
+            fiDOMDocumentSerializer_serialize = clazz.getMethod("serialize",
+                new Class[] { org.w3c.dom.Node.class });
+            fiDOMDocumentSerializer_setOutputStream = clazz.getMethod("setOutputStream",
+                new Class[] { java.io.OutputStream.class });
+
+            fiFastInfosetSource = clazz = Class.forName("com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSource");
+            fiFastInfosetSource_new = clazz.getConstructor(
+                new Class[] { java.io.InputStream.class });
+            fiFastInfosetSource_getInputStream = clazz.getMethod("getInputStream");
+            fiFastInfosetSource_setInputStream = clazz.getMethod("setInputStream",
+                new Class[] { java.io.InputStream.class });
+
+            fiFastInfosetResult = clazz = Class.forName("com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetResult");
+            fiFastInfosetResult_new = clazz.getConstructor(
+                new Class[] { java.io.OutputStream.class });
+            fiFastInfosetResult_getOutputStream = clazz.getMethod("getOutputStream");
+        }
+        catch (Exception e) {
+            // falls through
+        }
+    }
+
+    // -- DOMDocumentParser ----------------------------------------------
+
+    public static Object DOMDocumentParser_new() throws Exception {
+        if (fiDOMDocumentParser_new == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return fiDOMDocumentParser_new.newInstance();
+    }
+
+    public static void DOMDocumentParser_parse(Object parser,
+        Document d, InputStream s) throws Exception
+    {
+        if (fiDOMDocumentParser_parse == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        fiDOMDocumentParser_parse.invoke(parser, d, s);
+    }
+
+    // -- DOMDocumentSerializer-------------------------------------------
+
+    public static Object DOMDocumentSerializer_new() throws Exception {
+        if (fiDOMDocumentSerializer_new == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return fiDOMDocumentSerializer_new.newInstance();
+    }
+
+    public static void DOMDocumentSerializer_serialize(Object serializer, Node node)
+        throws Exception
+    {
+        if (fiDOMDocumentSerializer_serialize == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        fiDOMDocumentSerializer_serialize.invoke(serializer, node);
+    }
+
+    public static void DOMDocumentSerializer_setOutputStream(Object serializer,
+        OutputStream os) throws Exception
+    {
+        if (fiDOMDocumentSerializer_setOutputStream == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        fiDOMDocumentSerializer_setOutputStream.invoke(serializer, os);
+    }
+
+    // -- FastInfosetSource ----------------------------------------------
+
+    public static boolean isFastInfosetSource(Source source) {
+        return source.getClass() == fiFastInfosetSource;
+    }
+
+    public static Source FastInfosetSource_new(InputStream is)
+        throws Exception
+    {
+        if (fiFastInfosetSource_new == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return (Source) fiFastInfosetSource_new.newInstance(is);
+    }
+
+    public static InputStream FastInfosetSource_getInputStream(Source source)
+        throws Exception
+    {
+        if (fiFastInfosetSource_getInputStream == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return (InputStream) fiFastInfosetSource_getInputStream.invoke(source);
+    }
+
+    public static void FastInfosetSource_setInputStream(Source source,
+        InputStream is) throws Exception
+    {
+        if (fiFastInfosetSource_setInputStream == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        fiFastInfosetSource_setInputStream.invoke(source, is);
+    }
+
+    // -- FastInfosetResult ----------------------------------------------
+
+    public static boolean isFastInfosetResult(Result result) {
+        return result.getClass() == fiFastInfosetResult;
+    }
+
+    public static Result FastInfosetResult_new(OutputStream os)
+        throws Exception
+    {
+        if (fiFastInfosetResult_new == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return (Result) fiFastInfosetResult_new.newInstance(os);
+    }
+
+    public static OutputStream FastInfosetResult_getOutputStream(Result result)
+        throws Exception
+    {
+        if (fiFastInfosetResult_getOutputStream == null) {
+            throw new RuntimeException("Unable to locate Fast Infoset implementation");
+        }
+        return (OutputStream) fiFastInfosetResult_getOutputStream.invoke(result);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/FastInfosetUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/FastInfosetUtil.java
new file mode 100644
index 0000000..7c95a08
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/FastInfosetUtil.java
@@ -0,0 +1,103 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import java.io.OutputStream;
+import java.io.StringReader;
+import java.util.List;
+import java.util.StringTokenizer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.soap.SOAPException;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.messaging.saaj.soap.MessageImpl;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+import static com.sun.xml.internal.ws.developer.JAXWSProperties.CONTENT_NEGOTIATION_PROPERTY;
+
+public class FastInfosetUtil {
+
+    public static boolean isFastInfosetAccepted(String[] accepts) {
+        if (accepts != null) {
+            for (String accept : accepts) {
+                if (isFastInfosetAccepted(accept)) {
+                    return true;
+                }
+            }
+        }
+        return false;
+    }
+
+    public static boolean isFastInfosetAccepted(String accept) {
+        StringTokenizer st = new StringTokenizer(accept, ",");
+        while (st.hasMoreTokens()) {
+            final String token = st.nextToken().trim();
+            if (token.equalsIgnoreCase("application/fastinfoset")) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    public static String getFastInfosetFromAccept(List<String> accepts) {
+        for (String accept : accepts) {
+            StringTokenizer st = new StringTokenizer(accept, ",");
+            while (st.hasMoreTokens()) {
+                final String token = st.nextToken().trim();
+                if (token.equalsIgnoreCase("application/fastinfoset")) {
+                    return "application/fastinfoset";
+                }
+                if (token.equalsIgnoreCase("application/soap+fastinfoset")) {
+                    return "application/soap+fastinfoset";
+                }
+            }
+        }
+        return null;
+    }
+
+    public static void transcodeXMLStringToFI(String xml, OutputStream out) {
+        try {
+            XmlUtil.newTransformer().transform(
+                new StreamSource(new java.io.StringReader(xml)),
+                FastInfosetReflection.FastInfosetResult_new(out));
+        }
+        catch (Exception e) {
+            // Ignore
+        }
+    }
+
+    public static void ensureCorrectEncoding(MessageInfo messageInfo,
+        SOAPMessage message)
+    {
+        String conneg = (String) messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY);
+        if (conneg == "optimistic") {
+            ((MessageImpl) message).setIsFastInfoset(true);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/HandlerAnnotationInfo.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/HandlerAnnotationInfo.java
new file mode 100644
index 0000000..167bfd9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/HandlerAnnotationInfo.java
@@ -0,0 +1,83 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.util;
+
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.ws.handler.Handler;
+
+/**
+ * Used to hold a list of handlers and a set of roles from an
+ * annotated endpoint. At runtime, these are created by the
+ * HandlerAnnotationProcessor at the request of client and
+ * server code to create the handler chains.
+ *
+ * @see com.sun.xml.internal.ws.util.HandlerAnnotationProcessor
+ *
+ * @author JAX-WS Development Team
+ */
+public class HandlerAnnotationInfo {
+
+    private List<Handler> handlers;
+    private Set<String> roles;
+
+    /**
+     * Return the handlers specified by the handler chain descriptor.
+     *
+     * @return A list of jax-ws handler objects.
+     */
+    public List<Handler> getHandlers() {
+        return handlers;
+    }
+
+    /**
+     * This method should only be called by HandlerAnnotationProcessor.
+     *
+     * @param handlers The handlers specified by the handler chain descriptor.
+     */
+    public void setHandlers(List<Handler> handlers) {
+        this.handlers = handlers;
+    }
+
+    /**
+     * Return the roles contained in the handler chain descriptor.
+     *
+     * @return A set of roles.
+     */
+    public Set<String> getRoles() {
+        return roles;
+    }
+
+    /**
+     * This method should only be called by HandlerAnnotationProcessor.
+     *
+     * @param roles The roles contained in the handler chain descriptor.
+     */
+    public void setRoles(Set<String> roles) {
+        this.roles = roles;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/HandlerAnnotationProcessor.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/HandlerAnnotationProcessor.java
new file mode 100644
index 0000000..8b71f0c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/HandlerAnnotationProcessor.java
@@ -0,0 +1,193 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.util;
+
+import com.sun.xml.internal.ws.handler.HandlerChainsModel;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderFactory;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+
+import javax.jws.HandlerChain;
+import javax.jws.WebService;
+import javax.jws.soap.SOAPMessageHandlers;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.ws.Provider;
+import javax.xml.ws.Service;
+import java.io.IOException;
+import java.io.InputStream;
+import java.net.URL;
+import java.util.logging.Logger;
+
+/**
+ * <p>Used by client and server side to create handler information
+ * from annotated class. The public methods all return a
+ * HandlerChainInfo that contains the handlers and role information
+ * needed at runtime.
+ *
+ * <p>All of the handler chain descriptors follow the same schema,
+ * whether they are wsdl customizations, handler files specified
+ * by an annotation, or are included in the sun-jaxws.xml file.
+ * So this class is used for all handler xml information. The
+ * two public entry points are
+ * {@link HandlerAnnotationProcessor#buildHandlerInfo}, called
+ * when you have an annotated class that points to a file, and
+ * {@link HandlerAnnotationProcessor#parseHandlerFile}, called
+ * when the file reader already exists.
+ *
+ * <p>The methods in the class are static so that it may called
+ * from the runtime statically.
+ *
+ * @see com.sun.xml.internal.ws.util.HandlerAnnotationInfo
+ *
+ * @author JAX-WS Development Team
+ */
+public class HandlerAnnotationProcessor {
+
+    private static final Logger logger = Logger.getLogger(
+        com.sun.xml.internal.ws.util.Constants.LoggingDomain + ".util");
+
+    /**
+     * <p>This method is called by
+     * {@link com.sun.xml.internal.ws.client.ServiceContextBuilder} and
+     * {@link com.sun.xml.internal.ws.server.RuntimeEndpointInfo} when
+     * they have an annotated class.
+     *
+     * <p>If there is no handler chain annotation on the class,
+     * this method will return null. Otherwise it will load the
+     * class and call the parseHandlerFile method to read the
+     * information.
+     *
+     * @return A HandlerAnnotationInfo object that stores the
+     * handlers and roles. Will return null if the class passed
+     * in has no handler chain annotation.
+     */
+    public static HandlerAnnotationInfo buildHandlerInfo(Class clazz,
+        QName serviceName, QName portName, String bindingId) {
+
+//        clazz = checkClass(clazz);
+        HandlerChain handlerChain =
+            (HandlerChain) clazz.getAnnotation(HandlerChain.class);
+        if (handlerChain == null) {
+            clazz = getSEI(clazz);
+            if (clazz != null)
+            handlerChain =
+                (HandlerChain) clazz.getAnnotation(HandlerChain.class);
+            if (handlerChain == null)
+                return null;
+        }
+
+        if (clazz.getAnnotation(SOAPMessageHandlers.class) != null) {
+            throw new UtilException(
+                "util.handler.cannot.combine.soapmessagehandlers");
+        }
+        InputStream iStream = getFileAsStream(clazz, handlerChain);
+        XMLStreamReader reader =
+            XMLStreamReaderFactory.createXMLStreamReader(iStream, true);
+        XMLStreamReaderUtil.nextElementContent(reader);
+        return HandlerChainsModel.parseHandlerFile(reader, clazz.getClassLoader(),
+            serviceName, portName, bindingId);
+    }
+
+    public static HandlerChainsModel buildHandlerChainsModel(final Class clazz) {
+        if(clazz == null) {
+            return null;
+        }
+        HandlerChain handlerChain =
+            (HandlerChain) clazz.getAnnotation(HandlerChain.class);
+        if(handlerChain == null)
+            return null;
+        InputStream iStream = getFileAsStream(clazz, handlerChain);
+        XMLStreamReader reader =
+            XMLStreamReaderFactory.createXMLStreamReader(iStream, true);
+        XMLStreamReaderUtil.nextElementContent(reader);
+        return HandlerChainsModel.parseHandlerConfigFile(clazz, reader);
+    }
+
+    static Class getClass(String className) {
+        try {
+            return Thread.currentThread().getContextClassLoader().loadClass(
+                className);
+        } catch (ClassNotFoundException e) {
+            throw new UtilException("util.handler.class.not.found",
+                new Object[] {className});
+        }
+    }
+
+    static Class getSEI(Class clazz) {
+        if (Provider.class.isAssignableFrom(clazz)) {
+            //No SEI for Provider Implementation
+            return null;
+        }
+        if (Service.class.isAssignableFrom(clazz)) {
+            //No SEI for Service class
+            return null;
+        }
+        if (!clazz.isAnnotationPresent(WebService.class)) {
+            throw new UtilException("util.handler.no.webservice.annotation",
+                new Object[] {clazz.getCanonicalName()});
+        }
+
+        WebService webService =
+            (WebService) clazz.getAnnotation(WebService.class);
+
+        String ei = webService.endpointInterface();
+        if (ei.length() > 0) {
+            clazz = getClass(webService.endpointInterface());
+            if (!clazz.isAnnotationPresent(WebService.class)) {
+                throw new UtilException("util.handler.endpoint.interface.no.webservice",
+                                    new Object[] {webService.endpointInterface()});
+            }
+            return clazz;
+        }
+        return null;
+    }
+
+    static InputStream getFileAsStream(Class clazz, HandlerChain chain) {
+        URL url = clazz.getResource(chain.file());
+        if (url == null) {
+            url = Thread.currentThread().getContextClassLoader().
+                getResource(chain.file());
+        }
+        if (url == null) {
+            String tmp = clazz.getPackage().getName();
+            tmp = tmp.replace('.', '/');
+            tmp += "/" + chain.file();
+            url =
+                Thread.currentThread().getContextClassLoader().getResource(tmp);
+        }
+        if (url == null) {
+            throw new UtilException("util.failed.to.find.handlerchain.file",
+                new Object[] {clazz.getName(), chain.file()});
+        }
+        try {
+            return url.openStream();
+        } catch (IOException e) {
+            throw new UtilException("util.failed.to.parse.handlerchain.file",
+                new Object[] {clazz.getName(), chain.file()});
+        }
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/JAXWSUtils.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/JAXWSUtils.java
new file mode 100644
index 0000000..a4e2a1d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/JAXWSUtils.java
@@ -0,0 +1,132 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import java.util.UUID;
+import java.util.regex.Pattern;
+import java.net.URL;
+import java.net.MalformedURLException;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.io.File;
+import java.io.IOException;
+
+import javax.xml.namespace.QName;
+
+/**
+ * @author Vivek Pandey
+ *
+ * Wrapper utility class to be used from the generated code or run time.
+ */
+public final class JAXWSUtils {
+    public static String getUUID(){
+         return UUID.randomUUID().toString();
+    }
+
+
+
+    public static String getFileOrURLName(String fileOrURL) {
+        try{
+            try {
+                return escapeSpace(new URL(fileOrURL).toExternalForm());
+            } catch (MalformedURLException e) {
+                return new File(fileOrURL).getCanonicalFile().toURL().toExternalForm();
+            }
+        } catch (Exception e) {
+            // try it as an URL
+            return fileOrURL;
+        }
+    }
+
+    public static URL getFileOrURL(String fileOrURL) throws IOException {
+        try {
+            return new URL(fileOrURL);
+        } catch (MalformedURLException e) {
+            return new File(fileOrURL).toURL();
+        }
+    }
+    private static String escapeSpace( String url ) {
+        // URLEncoder didn't work.
+        StringBuffer buf = new StringBuffer();
+        for (int i = 0; i < url.length(); i++) {
+            // TODO: not sure if this is the only character that needs to be escaped.
+            if (url.charAt(i) == ' ')
+                buf.append("%20");
+            else
+                buf.append(url.charAt(i));
+        }
+        return buf.toString();
+    }
+
+    public static String absolutize(String name) {
+        // absolutize all the system IDs in the input,
+        // so that we can map system IDs to DOM trees.
+        try {
+            URL baseURL = new File(".").getCanonicalFile().toURL();
+            return new URL(baseURL, name).toExternalForm();
+        } catch( IOException e ) {
+            ; // ignore
+        }
+        return name;
+    }
+
+    /**
+     * Checks if the system ID is absolute.
+     */
+    public static  void checkAbsoluteness(String systemId) {
+        // we need to be able to handle system IDs like "urn:foo", which java.net.URL can't process,
+        // but OTOH we also need to be able to process system IDs like "file://a b c/def.xsd",
+        // which java.net.URI can't process. So for now, let's fail only if both of them fail.
+        // eventually we need a proper URI class that works for us.
+        try {
+            new URL(systemId);
+        } catch( MalformedURLException _ ) {
+            try {
+                new URI(systemId);
+            } catch (URISyntaxException e ) {
+                throw new IllegalArgumentException("system ID '"+systemId+"' isn't absolute",e);
+            }
+        }
+    }
+
+    /*
+     * To match, both QNames must have the same namespace and the local
+     * part of the target must match the local part of the 'pattern'
+     * QName, which may contain wildcard characters.
+     */
+    public static boolean matchQNames(QName target, QName pattern) {
+        if ((target == null) || (pattern == null))  {
+            // if no service or port is in descriptor
+            return false;
+        }
+        if (pattern.getNamespaceURI().equals(target.getNamespaceURI())) {
+            String regex = pattern.getLocalPart().replaceAll("\\*",  ".*");
+            return Pattern.matches(regex, target.getLocalPart());
+        }
+        return false;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/MessageInfoUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/MessageInfoUtil.java
new file mode 100644
index 0000000..8036df9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/MessageInfoUtil.java
@@ -0,0 +1,106 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.util;
+
+import com.sun.xml.internal.bind.api.BridgeContext;
+import com.sun.xml.internal.ws.client.BindingProviderProperties;
+import com.sun.xml.internal.ws.encoding.JAXWSAttachmentMarshaller;
+import com.sun.xml.internal.ws.encoding.soap.SOAPDecoder;
+import com.sun.xml.internal.ws.encoding.soap.internal.HeaderBlock;
+import com.sun.xml.internal.ws.handler.HandlerChainCaller;
+import com.sun.xml.internal.ws.handler.HandlerContext;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+
+import javax.xml.ws.handler.MessageContext;
+import javax.xml.bind.Marshaller;
+import java.util.Set;
+
+/**
+ * @author WS RI Development Team
+ */
+public class MessageInfoUtil {
+
+    public static void setRuntimeContext(MessageInfo messageInfo,
+                                         RuntimeContext runtimeContext) {
+        messageInfo.setMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT, runtimeContext);
+    }
+
+    public static RuntimeContext getRuntimeContext(MessageInfo messageInfo) {
+        return (RuntimeContext) messageInfo.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+    }
+
+    public static MessageContext getMessageContext(MessageInfo messageInfo) {
+        RuntimeContext rtCtxt = getRuntimeContext(messageInfo);
+        HandlerContext hdCtxt = null;
+        if (rtCtxt != null)
+            hdCtxt = rtCtxt.getHandlerContext();
+        else
+            hdCtxt = (HandlerContext)
+                messageInfo.getMetaData(BindingProviderProperties.JAXWS_HANDLER_CONTEXT_PROPERTY);
+        return (hdCtxt == null) ? null : hdCtxt.getMessageContext();
+    }
+
+    public static HandlerChainCaller getHandlerChainCaller(
+        MessageInfo messageInfo) {
+        return (HandlerChainCaller) messageInfo.getMetaData(
+            HandlerChainCaller.HANDLER_CHAIN_CALLER);
+    }
+
+    public static void setHandlerChainCaller(MessageInfo messageInfo,
+                                             HandlerChainCaller caller) {
+        messageInfo.setMetaData(HandlerChainCaller.HANDLER_CHAIN_CALLER,
+            caller);
+    }
+
+    public static JAXWSAttachmentMarshaller getAttachmentMarshaller(MessageInfo messageInfo) {
+        Object rtc = messageInfo.getMetaData(BindingProviderProperties.JAXWS_RUNTIME_CONTEXT);
+        if (rtc != null) {
+            BridgeContext bc = ((RuntimeContext) rtc).getBridgeContext();
+            if (bc != null) {
+                return (JAXWSAttachmentMarshaller) bc.getAttachmentMarshaller();
+            }
+        } else {
+             Marshaller m = (Marshaller)messageInfo.getMetaData(BindingProviderProperties.DISPATCH_MARSHALLER);
+            if (m != null) {
+                return (JAXWSAttachmentMarshaller) m.getAttachmentMarshaller();
+            }
+        }
+        return null;
+    }
+
+    public static void setNotUnderstoodHeaders(MessageInfo messageInfo,
+                                               Set<HeaderBlock> headers) {
+
+        messageInfo.setMetaData(SOAPDecoder.NOT_UNDERSTOOD_HEADERS, headers);
+    }
+
+    public static Set<HeaderBlock> getNotUnderstoodHeaders(
+        MessageInfo messageInfo) {
+
+        return (Set<HeaderBlock>) messageInfo.getMetaData(
+            SOAPDecoder.NOT_UNDERSTOOD_HEADERS);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/NamespaceSupport.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/NamespaceSupport.java
new file mode 100644
index 0000000..bb8de46
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/NamespaceSupport.java
@@ -0,0 +1,748 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import java.util.ArrayList;
+import java.util.EmptyStackException;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+
+/**
+ * Encapsulate Namespace logic for use by SAX drivers.
+ *
+ * <blockquote>
+ * <em>This module, both source code and documentation, is in the
+ * Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
+ * </blockquote>
+ *
+ * <p>This class encapsulates the logic of Namespace processing:
+ * it tracks the declarations currently in force for each context
+ * and automatically processes qualified XML 1.0 names into their
+ * Namespace parts; it can also be used in reverse for generating
+ * XML 1.0 from Namespaces.</p>
+ *
+ * <p>Namespace support objects are reusable, but the reset method
+ * must be invoked between each session.</p>
+ *
+ * <p>Here is a simple session:</p>
+ *
+ * <pre>
+ * String parts[] = new String[3];
+ * NamespaceSupport support = new NamespaceSupport();
+ *
+ * support.pushContext();
+ * support.declarePrefix("", "http://www.w3.org/1999/xhtml");
+ * support.declarePrefix("dc", "http://www.purl.org/dc#");
+ *
+ * String parts[] = support.processName("p", parts, false);
+ * System.out.println("Namespace URI: " + parts[0]);
+ * System.out.println("Local name: " + parts[1]);
+ * System.out.println("Raw name: " + parts[2]);
+
+ * String parts[] = support.processName("dc:title", parts, false);
+ * System.out.println("Namespace URI: " + parts[0]);
+ * System.out.println("Local name: " + parts[1]);
+ * System.out.println("Raw name: " + parts[2]);
+
+ * support.popContext();
+ * </pre>
+ *
+ * <p>Note that this class is optimized for the use case where most
+ * elements do not contain Namespace declarations: if the same
+ * prefix/URI mapping is repeated for each context (for example), this
+ * class will be somewhat less efficient.</p>
+ *
+ * @author David Megginson
+ * @author WS Development Team
+ */
+public class NamespaceSupport {
+
+    /* added two new methods, slideContextUp() and slideContextDown()
+     * needed to implement the revised streaming parser class (Parser2)
+     */
+
+    ////////////////////////////////////////////////////////////////////
+    // Constants.
+    ////////////////////////////////////////////////////////////////////
+
+    /**
+     * The XML Namespace as a constant.
+     *
+     * <p>This is the Namespace URI that is automatically mapped
+     * to the "xml" prefix.</p>
+     */
+    public final static String XMLNS = "http://www.w3.org/XML/1998/namespace";
+
+    /**
+     * An empty enumeration.
+     */
+    private final static Iterator EMPTY_ENUMERATION =
+        new ArrayList().iterator();
+
+    ////////////////////////////////////////////////////////////////////
+    // Constructor.
+    ////////////////////////////////////////////////////////////////////
+
+    /**
+     * Create a new Namespace support object.
+     */
+    public NamespaceSupport() {
+        reset();
+    }
+
+    // PBG May 6 2002 added a copy constructor to support recording
+    public NamespaceSupport(NamespaceSupport that) {
+        contexts = new Context[that.contexts.length];
+        currentContext = null;
+        contextPos = that.contextPos;
+
+        Context currentParent = null;
+
+        for (int i = 0; i < that.contexts.length; i++) {
+            Context thatContext = that.contexts[i];
+
+            if (thatContext == null) {
+                contexts[i] = null;
+                continue;
+            }
+
+            Context thisContext = new Context(thatContext, currentParent);
+            contexts[i] = thisContext;
+            if (that.currentContext == thatContext) {
+                currentContext = thisContext;
+            }
+
+            currentParent = thisContext;
+        }
+    }
+
+    ////////////////////////////////////////////////////////////////////
+    // Context management.
+    ////////////////////////////////////////////////////////////////////
+
+    /**
+     * Reset this Namespace support object for reuse.
+     *
+     * <p>It is necessary to invoke this method before reusing the
+     * Namespace support object for a new session.</p>
+     */
+    public void reset() {
+        contexts = new Context[32];
+        contextPos = 0;
+        contexts[contextPos] = currentContext = new Context();
+        currentContext.declarePrefix("xml", XMLNS);
+    }
+
+    /**
+     * Start a new Namespace context.
+     *
+     * <p>Normally, you should push a new context at the beginning
+     * of each XML element: the new context will automatically inherit
+     * the declarations of its parent context, but it will also keep
+     * track of which declarations were made within this context.</p>
+     *
+     * <p>The Namespace support object always starts with a base context
+     * already in force: in this context, only the "xml" prefix is
+     * declared.</p>
+     *
+     * @see #popContext
+     */
+    public void pushContext() {
+        int max = contexts.length;
+        contextPos++;
+
+        // Extend the array if necessary
+        if (contextPos >= max) {
+            Context newContexts[] = new Context[max * 2];
+            System.arraycopy(contexts, 0, newContexts, 0, max);
+            contexts = newContexts;
+        }
+
+        // Allocate the context if necessary.
+        currentContext = contexts[contextPos];
+        if (currentContext == null) {
+            contexts[contextPos] = currentContext = new Context();
+        }
+
+        // Set the parent, if any.
+        if (contextPos > 0) {
+            currentContext.setParent(contexts[contextPos - 1]);
+        }
+    }
+
+    /**
+     * Revert to the previous Namespace context.
+     *
+     * <p>Normally, you should pop the context at the end of each
+     * XML element.  After popping the context, all Namespace prefix
+     * mappings that were previously in force are restored.</p>
+     *
+     * <p>You must not attempt to declare additional Namespace
+     * prefixes after popping a context, unless you push another
+     * context first.</p>
+     *
+     * @see #pushContext
+     */
+    public void popContext() {
+        contextPos--;
+        if (contextPos < 0) {
+            throw new EmptyStackException();
+        }
+        currentContext = contexts[contextPos];
+    }
+
+    /*
+     * added for the revised streaming parser class (Parser2)
+     * Move the context artificially up one level (i.e. contracting it).
+     */
+    public void slideContextUp() {
+        contextPos--;
+        currentContext = contexts[contextPos];
+    }
+
+    /*
+     * added for the revised streaming parser class (Parser2)
+     * Move the context artificially down one level (i.e. expanding it).
+     */
+    public void slideContextDown() {
+        contextPos++;
+
+        if (contexts[contextPos] == null) {
+            // trying to slide to a context that was never created
+            contexts[contextPos] = contexts[contextPos - 1];
+        }
+
+        currentContext = contexts[contextPos];
+    }
+
+    ////////////////////////////////////////////////////////////////////
+    // Operations within a context.
+    ////////////////////////////////////////////////////////////////////
+
+    /**
+     * Declare a Namespace prefix.
+     *
+     * <p>This method declares a prefix in the current Namespace
+     * context; the prefix will remain in force until this context
+     * is popped, unless it is shadowed in a descendant context.</p>
+     *
+     * <p>To declare a default Namespace, use the empty string.  The
+     * prefix must not be "xml" or "xmlns".</p>
+     *
+     * <p>Note that you must <em>not</em> declare a prefix after
+     * you've pushed and popped another Namespace.</p>
+     *
+     * <p>Note that there is an asymmetry in this library: while {@link
+     * #getPrefix getPrefix} will not return the default "" prefix,
+     * even if you have declared one; to check for a default prefix,
+     * you have to look it up explicitly using {@link #getURI getURI}.
+     * This asymmetry exists to make it easier to look up prefixes
+     * for attribute names, where the default prefix is not allowed.</p>
+     *
+     * @param prefix The prefix to declare, or null for the empty
+     *        string.
+     * @param uri The Namespace URI to associate with the prefix.
+     * @return true if the prefix was legal, false otherwise
+     * @see #processName
+     * @see #getURI
+     * @see #getPrefix
+     */
+    public boolean declarePrefix(String prefix, String uri) {
+        // bugfix#: 4989753
+        if ((prefix.equals("xml") && !uri.equals(SOAPNamespaceConstants.XMLNS))
+            || prefix.equals("xmlns")) {
+            return false;
+        } else {
+            currentContext.declarePrefix(prefix, uri);
+            return true;
+        }
+    }
+
+    /**
+     * Process a raw XML 1.0 name.
+     *
+     * <p>This method processes a raw XML 1.0 name in the current
+     * context by removing the prefix and looking it up among the
+     * prefixes currently declared.  The return value will be the
+     * array supplied by the caller, filled in as follows:</p>
+     *
+     * <dl>
+     * <dt>parts[0]</dt>
+     * <dd>The Namespace URI, or an empty string if none is
+     *  in use.</dd>
+     * <dt>parts[1]</dt>
+     * <dd>The local name (without prefix).</dd>
+     * <dt>parts[2]</dt>
+     * <dd>The original raw name.</dd>
+     * </dl>
+     *
+     * <p>All of the strings in the array will be internalized.  If
+     * the raw name has a prefix that has not been declared, then
+     * the return value will be null.</p>
+     *
+     * <p>Note that attribute names are processed differently than
+     * element names: an unprefixed element name will received the
+     * default Namespace (if any), while an unprefixed element name
+     * will not.</p>
+     *
+     * @param qName The raw XML 1.0 name to be processed.
+     * @param parts An array supplied by the caller, capable of
+     *        holding at least three members.
+     * @param isAttribute A flag indicating whether this is an
+     *        attribute name (true) or an element name (false).
+     * @return The supplied array holding three internalized strings
+     *        representing the Namespace URI (or empty string), the
+     *        local name, and the raw XML 1.0 name; or null if there
+     *        is an undeclared prefix.
+     * @see #declarePrefix
+     * @see java.lang.String#intern */
+    public String[] processName(
+        String qName,
+        String parts[],
+        boolean isAttribute) {
+        String myParts[] = currentContext.processName(qName, isAttribute);
+        if (myParts == null) {
+            return null;
+        } else {
+            parts[0] = myParts[0];
+            parts[1] = myParts[1];
+            parts[2] = myParts[2];
+            return parts;
+        }
+    }
+
+    /**
+     * Look up a prefix and get the currently-mapped Namespace URI.
+     *
+     * <p>This method looks up the prefix in the current context.
+     * Use the empty string ("") for the default Namespace.</p>
+     *
+     * @param prefix The prefix to look up.
+     * @return The associated Namespace URI, or null if the prefix
+     *         is undeclared in this context.
+     * @see #getPrefix
+     * @see #getPrefixes
+     */
+    public String getURI(String prefix) {
+        return currentContext.getURI(prefix);
+    }
+
+    /**
+     * Return an enumeration of all prefixes currently declared.
+     *
+     * <p><strong>Note:</strong> if there is a default prefix, it will not be
+     * returned in this enumeration; check for the default prefix
+     * using the {@link #getURI getURI} with an argument of "".</p>
+     *
+     * @return An enumeration of all prefixes declared in the
+     *         current context except for the empty (default)
+     *         prefix.
+     * @see #getDeclaredPrefixes
+     * @see #getURI
+     */
+    public Iterator getPrefixes() {
+        return currentContext.getPrefixes();
+    }
+
+    /**
+     * Return one of the prefixes mapped to a Namespace URI.
+     *
+     * <p>If more than one prefix is currently mapped to the same
+     * URI, this method will make an arbitrary selection; if you
+     * want all of the prefixes, use the {@link #getPrefixes}
+     * method instead.</p>
+     *
+     * <p><strong>Note:</strong> this will never return the empty (default) prefix;
+     * to check for a default prefix, use the {@link #getURI getURI}
+     * method with an argument of "".</p>
+     *
+     * @param uri The Namespace URI.
+     * @return One of the prefixes currently mapped to the URI supplied,
+     *         or null if none is mapped or if the URI is assigned to
+     *         the default Namespace.
+     * @see #getPrefixes(java.lang.String)
+     * @see #getURI
+     */
+    public String getPrefix(String uri) {
+        return currentContext.getPrefix(uri);
+    }
+
+    /**
+     * Return an enumeration of all prefixes currently declared for a URI.
+     *
+     * <p>This method returns prefixes mapped to a specific Namespace
+     * URI.  The xml: prefix will be included.  If you want only one
+     * prefix that's mapped to the Namespace URI, and you don't care
+     * which one you get, use the {@link #getPrefix getPrefix}
+     *  method instead.</p>
+     *
+     * <p><strong>Note:</strong> the empty (default) prefix is <em>never</em> included
+     * in this enumeration; to check for the presence of a default
+     * Namespace, use the {@link #getURI getURI} method with an
+     * argument of "".</p>
+     *
+     * @param uri The Namespace URI.
+     * @return An enumeration of all prefixes declared in the
+     *         current context.
+     * @see #getPrefix
+     * @see #getDeclaredPrefixes
+     * @see #getURI
+     */
+    public Iterator getPrefixes(String uri) {
+        List prefixes = new ArrayList();
+        Iterator allPrefixes = getPrefixes();
+        while (allPrefixes.hasNext()) {
+            String prefix = (String) allPrefixes.next();
+            if (uri.equals(getURI(prefix))) {
+                prefixes.add(prefix);
+            }
+        }
+        return prefixes.iterator();
+    }
+
+    /**
+     * Return an enumeration of all prefixes declared in this context.
+     *
+     * <p>The empty (default) prefix will be included in this
+     * enumeration; note that this behaviour differs from that of
+     * {@link #getPrefix} and {@link #getPrefixes}.</p>
+     *
+     * @return An enumeration of all prefixes declared in this
+     *         context.
+     * @see #getPrefixes
+     * @see #getURI
+     */
+    public Iterator getDeclaredPrefixes() {
+        return currentContext.getDeclaredPrefixes();
+    }
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    private Context contexts[];
+    private Context currentContext;
+    private int contextPos;
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal classes.
+    ////////////////////////////////////////////////////////////////////
+
+    /**
+     * Internal class for a single Namespace context.
+     *
+     * <p>This module caches and reuses Namespace contexts, so the number
+     * allocated will be equal to the element depth of the document, not to the
+     * total number of elements (i.e. 5-10 rather than tens of thousands).</p>
+     */
+    final static class Context {
+
+        /**
+         * Create the root-level Namespace context.
+         */
+        Context() {
+            copyTables();
+        }
+        // PGB May 6 2002 added copy constructor
+        Context(Context that, Context newParent) {
+            if (that == null) {
+                copyTables();
+                return;
+            }
+
+            if (newParent != null && !that.tablesDirty) {
+                prefixTable =
+                    that.prefixTable == that.parent.prefixTable
+                        ? newParent.prefixTable
+                        : (HashMap) that.prefixTable.clone();
+
+                uriTable =
+                    that.uriTable == that.parent.uriTable
+                        ? newParent.uriTable
+                        : (HashMap) that.uriTable.clone();
+                elementNameTable =
+                    that.elementNameTable == that.parent.elementNameTable
+                        ? newParent.elementNameTable
+                        : (HashMap) that.elementNameTable.clone();
+                attributeNameTable =
+                    that.attributeNameTable == that.parent.attributeNameTable
+                        ? newParent.attributeNameTable
+                        : (HashMap) that.attributeNameTable.clone();
+                defaultNS =
+                    that.defaultNS == that.parent.defaultNS
+                        ? newParent.defaultNS
+                        : that.defaultNS;
+            } else {
+                prefixTable = (HashMap) that.prefixTable.clone();
+                uriTable = (HashMap) that.uriTable.clone();
+                elementNameTable = (HashMap) that.elementNameTable.clone();
+                attributeNameTable = (HashMap) that.attributeNameTable.clone();
+                defaultNS = that.defaultNS;
+            }
+
+            tablesDirty = that.tablesDirty;
+            parent = newParent;
+            declarations =
+                that.declarations == null
+                    ? null
+                    : (ArrayList) that.declarations.clone();
+        }
+
+        /**
+         * (Re)set the parent of this Namespace context.
+         *
+         * @param parent The parent Namespace context object.
+         */
+        void setParent(Context parent) {
+            this.parent = parent;
+            declarations = null;
+            prefixTable = parent.prefixTable;
+            uriTable = parent.uriTable;
+            elementNameTable = parent.elementNameTable;
+            attributeNameTable = parent.attributeNameTable;
+            defaultNS = parent.defaultNS;
+            tablesDirty = false;
+        }
+
+        /**
+         * Declare a Namespace prefix for this context.
+         *
+         * @param prefix The prefix to declare.
+         * @param uri The associated Namespace URI.
+         * @see org.xml.sax.helpers.NamespaceSupport#declarePrefix
+         */
+        void declarePrefix(String prefix, String uri) {
+            // Lazy processing...
+            if (!tablesDirty) {
+                copyTables();
+            }
+            if (declarations == null) {
+                declarations = new ArrayList();
+            }
+
+            prefix = prefix.intern();
+            uri = uri.intern();
+            if ("".equals(prefix)) {
+                if ("".equals(uri)) {
+                    defaultNS = null;
+                } else {
+                    defaultNS = uri;
+                }
+            } else {
+                prefixTable.put(prefix, uri);
+                uriTable.put(uri, prefix); // may wipe out another prefix
+            }
+            declarations.add(prefix);
+        }
+
+        /**
+         * Process a raw XML 1.0 name in this context.
+         *
+         * @param qName The raw XML 1.0 name.
+         * @param isAttribute true if this is an attribute name.
+         * @return An array of three strings containing the
+         *         URI part (or empty string), the local part,
+         *         and the raw name, all internalized, or null
+         *         if there is an undeclared prefix.
+         * @see org.xml.sax.helpers.NamespaceSupport#processName
+         */
+        String[] processName(String qName, boolean isAttribute) {
+            String name[];
+            Map table;
+
+            // Select the appropriate table.
+            if (isAttribute) {
+                table = elementNameTable;
+            } else {
+                table = attributeNameTable;
+            }
+
+            // Start by looking in the cache, and
+            // return immediately if the name
+            // is already known in this content
+            name = (String[]) table.get(qName);
+            if (name != null) {
+                return name;
+            }
+
+            // We haven't seen this name in this
+            // context before.
+            name = new String[3];
+            int index = qName.indexOf(':');
+
+            // No prefix.
+            if (index == -1) {
+                if (isAttribute || defaultNS == null) {
+                    name[0] = "";
+                } else {
+                    name[0] = defaultNS;
+                }
+                name[1] = qName.intern();
+                name[2] = name[1];
+            }
+
+            // Prefix
+            else {
+                String prefix = qName.substring(0, index);
+                String local = qName.substring(index + 1);
+                String uri;
+                if ("".equals(prefix)) {
+                    uri = defaultNS;
+                } else {
+                    uri = (String) prefixTable.get(prefix);
+                }
+                if (uri == null) {
+                    return null;
+                }
+                name[0] = uri;
+                name[1] = local.intern();
+                name[2] = qName.intern();
+            }
+
+            // Save in the cache for future use.
+            table.put(name[2], name);
+            tablesDirty = true;
+            return name;
+        }
+
+        /**
+         * Look up the URI associated with a prefix in this context.
+         *
+         * @param prefix The prefix to look up.
+         * @return The associated Namespace URI, or null if none is
+         *         declared.
+         * @see org.xml.sax.helpers.NamespaceSupport#getURI
+         */
+        String getURI(String prefix) {
+            if ("".equals(prefix)) {
+                return defaultNS;
+            } else if (prefixTable == null) {
+                return null;
+            } else {
+                return (String) prefixTable.get(prefix);
+            }
+        }
+
+        /**
+         * Look up one of the prefixes associated with a URI in this context.
+         *
+         * <p>Since many prefixes may be mapped to the same URI,
+         * the return value may be unreliable.</p>
+         *
+         * @param uri The URI to look up.
+         * @return The associated prefix, or null if none is declared.
+         * @see org.xml.sax.helpers.NamespaceSupport#getPrefix
+         */
+        String getPrefix(String uri) {
+            if (uriTable == null) {
+                return null;
+            } else {
+                return (String) uriTable.get(uri);
+            }
+        }
+
+        /**
+         * Return an enumeration of prefixes declared in this context.
+         *
+         * @return An enumeration of prefixes (possibly empty).
+         * @see org.xml.sax.helpers.NamespaceSupport#getDeclaredPrefixes
+         */
+        Iterator getDeclaredPrefixes() {
+            if (declarations == null) {
+                return EMPTY_ENUMERATION;
+            } else {
+                return declarations.iterator();
+            }
+        }
+
+        /**
+         * Return an enumeration of all prefixes currently in force.
+         *
+         * <p>The default prefix, if in force, is <em>not</em>
+         * returned, and will have to be checked for separately.</p>
+         *
+         * @return An enumeration of prefixes (never empty).
+         * @see org.xml.sax.helpers.NamespaceSupport#getPrefixes
+         */
+        Iterator getPrefixes() {
+            if (prefixTable == null) {
+                return EMPTY_ENUMERATION;
+            } else {
+                return prefixTable.keySet().iterator();
+            }
+        }
+
+        ////////////////////////////////////////////////////////////////
+        // Internal methods.
+        ////////////////////////////////////////////////////////////////
+
+        /**
+         * Copy on write for the internal tables in this context.
+         *
+         * <p>This class is optimized for the normal case where most
+         * elements do not contain Namespace declarations.</p>
+         */
+        private void copyTables() {
+            if (prefixTable != null) {
+                prefixTable = (HashMap) prefixTable.clone();
+            } else {
+                prefixTable = new HashMap();
+            }
+            if (uriTable != null) {
+                uriTable = (HashMap) uriTable.clone();
+            } else {
+                uriTable = new HashMap();
+            }
+            elementNameTable = new HashMap();
+            attributeNameTable = new HashMap();
+            tablesDirty = true;
+        }
+
+        ////////////////////////////////////////////////////////////////
+        // Protected state.
+        ////////////////////////////////////////////////////////////////
+
+        HashMap prefixTable;
+        HashMap uriTable;
+        // PBG May 6 2002 changed these two from Map to HashMap
+        HashMap elementNameTable;
+        HashMap attributeNameTable;
+        String defaultNS = null;
+
+        ////////////////////////////////////////////////////////////////
+        // Internal state.
+        ////////////////////////////////////////////////////////////////
+
+        // PBG May 6 2002 changed this from List to ArrayList
+        private ArrayList declarations = null;
+        private boolean tablesDirty = false;
+        private Context parent = null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/NullIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/NullIterator.java
new file mode 100644
index 0000000..531c5b6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/NullIterator.java
@@ -0,0 +1,58 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import java.util.Iterator;
+import java.util.NoSuchElementException;
+
+/**
+ * An Iterator on an empty collection.
+ *
+ * @author WS Development Team
+ */
+public final class NullIterator implements Iterator {
+
+    public static NullIterator getInstance() {
+        return _instance;
+    }
+
+    private static final NullIterator _instance = new NullIterator();
+
+    private NullIterator() {
+    }
+
+    public boolean hasNext() {
+        return false;
+    }
+
+    public Object next() {
+        throw new NoSuchElementException();
+    }
+
+    public void remove() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/RuntimeVersion.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/RuntimeVersion.java
new file mode 100644
index 0000000..38b47ff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/RuntimeVersion.java
@@ -0,0 +1,37 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+/**
+ * Obtains the version number of the JAX-WS runtime.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public abstract class RuntimeVersion {
+    private RuntimeVersion() {}    // no instanciation please
+
+    public static final Version VERSION = Version.create(RuntimeVersion.class.getResourceAsStream("version.properties"));
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SOAPConnectionUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SOAPConnectionUtil.java
new file mode 100644
index 0000000..29b801b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SOAPConnectionUtil.java
@@ -0,0 +1,217 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.messaging.saaj.util.ByteInputStream;
+import com.sun.xml.internal.ws.binding.BindingImpl;
+import com.sun.xml.internal.ws.server.RuntimeContext;
+import com.sun.xml.internal.ws.server.RuntimeEndpointInfo;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+
+import javax.xml.soap.MimeHeader;
+import javax.xml.soap.MimeHeaders;
+import javax.xml.soap.SOAPMessage;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.soap.SOAPBinding;
+
+import java.io.ByteArrayOutputStream;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+import java.nio.ByteBuffer;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Locale;
+import java.util.Map;
+
+import static com.sun.xml.internal.ws.developer.JAXWSProperties.CONTENT_NEGOTIATION_PROPERTY;
+
+/**
+ * @author WS Development Team
+ */
+public class SOAPConnectionUtil {
+
+    public static SOAPMessage getSOAPMessage(WSConnection con, MessageInfo mi, String bindingId) {
+        try {
+            Map<String, List<String>> headers = con.getHeaders();
+            MimeHeaders mh = new MimeHeaders();
+            if (headers != null)
+                for (Map.Entry<String, List<String>> entry : headers.entrySet()) {
+                    String name = entry.getKey();
+                    for (String value : entry.getValue()) {
+                        try {
+                            mh.addHeader(name, value);
+                        } catch(IllegalArgumentException ie) {
+                            // Not a mime header. Ignore it.
+                        }
+                    }
+                }
+            RuntimeContext rtCtxt = MessageInfoUtil.getRuntimeContext(mi);
+            if (rtCtxt != null) {
+                RuntimeEndpointInfo endpointInfo = rtCtxt.getRuntimeEndpointInfo();
+                if (bindingId == null)
+                    bindingId = ((BindingImpl) endpointInfo.getBinding()).getBindingId();
+            }
+            SOAPMessage soapMessage = SOAPUtil.createMessage(mh,
+                con.getInput(), bindingId);
+            return soapMessage;
+        } catch (Exception e) {
+//            e.printStackTrace();
+            throw new WebServiceException(e);
+        }
+    }
+
+    private static void send(WSConnection con, SOAPMessage soapMessage) {
+        try {
+            if (soapMessage.saveRequired()) {
+                soapMessage.saveChanges();
+            }
+            Map<String, List<String>> headers = new HashMap<String, List<String>>();
+            MimeHeaders mhs = soapMessage.getMimeHeaders();
+            Iterator i = mhs.getAllHeaders();
+            while (i.hasNext()) {
+                MimeHeader mh = (MimeHeader) i.next();
+                String name = mh.getName();
+                List<String> values = headers.get(name);
+                if (values == null) {
+                    values = new ArrayList<String>();
+                    headers.put(name, values);
+                }
+                values.add(mh.getValue());
+            }
+            con.setHeaders(headers);
+            soapMessage.writeTo(con.getOutput());
+            con.closeOutput();
+        } catch (Exception e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    public static void sendResponse(WSConnection con, SOAPMessage soapMessage) {
+        //setStatus(con, WSConnection.OK);
+        send(con, soapMessage);
+    }
+
+    public static void sendKnownError(MessageInfo messageInfo, int status) {
+        WSConnection con = (WSConnection)messageInfo.getConnection();
+        setStatus(con, status);
+        con.getOutput();
+        con.closeOutput();
+    }
+
+    public static void sendResponseOneway(MessageInfo messageInfo) {
+        WSConnection con = (WSConnection)messageInfo.getConnection();
+        setStatus(con, WSConnection.ONEWAY);
+        con.getOutput();
+
+        // Ensure conneg is completed even if no data is sent back
+        if (messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY) == "optimistic") {
+            List<String> acceptList = null;
+            List<String> contentTypeList = null;
+            Map<String, List<String>> headers = con.getHeaders();
+
+            // Go through the entries because a gets are case sensitive
+            for (Map.Entry<String, List<String>> entry : headers.entrySet()) {
+                if (entry.getKey().equalsIgnoreCase("content-type")) {
+                    contentTypeList = entry.getValue();
+                }
+                else if (entry.getKey().equalsIgnoreCase("accept")) {
+                    acceptList = entry.getValue();
+                }
+            }
+
+            // If content-type is FI, FI must be listed in the accept header
+            assert contentTypeList != null && acceptList != null;
+
+            // Use FI MIME type based on Accept header
+            contentTypeList.set(0,
+                FastInfosetUtil.getFastInfosetFromAccept(acceptList));
+        }
+
+        con.closeOutput();
+    }
+
+    public static void sendResponseError(WSConnection con, String bindingId) {
+        try {
+            SOAPMessage message = SOAPUtil.createMessage(bindingId);
+            ByteArrayBuffer bufferedStream = new ByteArrayBuffer();
+            Writer writer = new OutputStreamWriter(bufferedStream, "UTF-8");
+            if(bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING))
+                writer.write(DEFAULT_SERVER_ERROR_SOAP12_ENVELOPE);
+            else
+                writer.write(DEFAULT_SERVER_ERROR_ENVELOPE);
+            writer.close();
+            message.getSOAPPart().setContent(new StreamSource(bufferedStream.newInputStream()));
+            setStatus(con, WSConnection.INTERNAL_ERR);
+            send(con, message);
+        } catch (Exception e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    public static Map<String, List<String>> getHeaders(WSConnection con) {
+        return con.getHeaders();
+    }
+
+    /**
+     * sets response headers.
+     */
+    public static void setHeaders(WSConnection con,
+                                  Map<String, List<String>> headers) {
+        con.setHeaders(headers);
+    }
+
+    public static void setStatus(WSConnection con, int status) {
+        con.setStatus(status);
+    }
+
+    private final static String DEFAULT_SERVER_ERROR_ENVELOPE =
+        "<?xml version='1.0' encoding='UTF-8'?>"
+        + "<env:Envelope xmlns:env=\"http://schemas.xmlsoap.org/soap/envelope/\">"
+        + "<env:Body>"
+        + "<env:Fault>"
+        + "<faultcode>env:Server</faultcode>"
+        + "<faultstring>Internal server error</faultstring>"
+        + "</env:Fault>"
+        + "</env:Body>"
+        + "</env:Envelope>";
+
+    private final static String DEFAULT_SERVER_ERROR_SOAP12_ENVELOPE =
+        "<?xml version='1.0' encoding='UTF-8'?>"
+        + "<env:Envelope xmlns:env=\"http://www.w3.org/2003/05/soap-envelope\">"
+        + "<env:Body>"
+        + "<env:Fault>"
+        + "<env:Code><env:Value>env:Receiver</env:Value></env:Code>"
+        + "<env:Reason><env:Text lang=\""+ Locale.getDefault().getLanguage() +"\">"
+        + "Internal server error</env:Text></env:Reason>"
+        + "</env:Fault>"
+        + "</env:Body>"
+        + "</env:Envelope>";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SOAPUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SOAPUtil.java
new file mode 100644
index 0000000..cc87a66
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SOAPUtil.java
@@ -0,0 +1,187 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPMsgCreateException;
+import com.sun.xml.internal.ws.encoding.soap.message.SOAPMsgFactoryCreateException;
+import java.io.IOException;
+import java.io.InputStream;
+import javax.xml.soap.*;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.*;
+import org.w3c.dom.Node;
+
+/**
+ * $author: JAXWS Development Team
+ */
+
+/**
+ * Has utility methods to create SOAPMessage
+ */
+public class SOAPUtil {
+
+    private static final MessageFactory soap11messageFactory =
+            createMessageFactory(SOAPConstants.SOAP_1_1_PROTOCOL);
+    private static final MessageFactory soap12messageFactory =
+            createMessageFactory(SOAPConstants.SOAP_1_2_PROTOCOL);
+    private static final SOAPFactory soap11Factory = createSOAPFactory(SOAPConstants.SOAP_1_1_PROTOCOL);
+    private static final SOAPFactory soap12Factory = createSOAPFactory(SOAPConstants.SOAP_1_2_PROTOCOL);
+
+    private static SOAPFactory createSOAPFactory(String soapProtocol) {
+        try {
+            return SOAPFactory.newInstance(soapProtocol);
+        } catch(SOAPException e) {
+            throw new SOAPMsgFactoryCreateException(
+                "soap.factory.create.err",
+                new Object[] { e });
+        }
+    }
+
+    /**
+     *
+     * @param bindingId
+     * @return
+     *          returns SOAPFactor for SOAP 1.2 if bindingID equals SOAP1.2 HTTP binding else
+     *          SOAPFactory for SOAP 1.1
+     */
+    public static SOAPFactory getSOAPFactory(String bindingId){
+        if(bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING)){
+            return soap12Factory;
+        }
+        return soap11Factory;
+    }
+
+    public static SOAPFault createSOAPFault(String bindingId){
+        if(bindingId == null)
+            bindingId = SOAPBinding.SOAP11HTTP_BINDING;
+         try {
+            if(bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING))
+                return soap12Factory.createFault();
+            return soap11Factory.createFault();
+        } catch (SOAPException e) {
+            throw new SOAPMsgFactoryCreateException(
+                "soap.fault.create.err",
+                new Object[] { e });
+        }
+    }
+
+    /**
+     * Creates SOAP 1.1 or SOAP 1.2 SOAPFault based on the bindingId
+     * @param msg
+     * @param code
+     * @param actor
+     * @param detail
+     * @return the created SOAPFault
+     */
+    public static SOAPFault createSOAPFault(String msg, QName code, String actor, Detail detail, String bindingId){
+        if(bindingId == null)
+            bindingId = SOAPBinding.SOAP11HTTP_BINDING;
+        try {
+            SOAPFault fault = null;
+            if(bindingId.equals(SOAPBinding.SOAP12HTTP_BINDING))
+                fault = soap12Factory.createFault(msg, code);
+            else if(bindingId.equals(SOAPBinding.SOAP11HTTP_BINDING))
+                fault = soap11Factory.createFault(msg, code);
+            if(actor != null)
+                fault.setFaultActor(actor);
+            if(detail != null){
+                Node n = fault.getOwnerDocument().importNode(detail, true);
+                fault.appendChild(n);
+            }
+            return fault;
+        } catch (SOAPException e) {
+            throw new SOAPMsgFactoryCreateException(
+                "soap.fault.create.err",
+                new Object[] { e });
+        }
+    }
+
+    public static SOAPMessage createMessage() {
+        return createMessage(SOAPBinding.SOAP11HTTP_BINDING);
+    }
+
+    /**
+     *
+     * @param binding
+     * @return a <code>SOAPMessage</code> associated with <code>binding</code>
+     */
+    public static SOAPMessage createMessage(String binding) {
+        try {
+            return getMessageFactory(binding).createMessage();
+        } catch (SOAPException e) {
+            throw new SOAPMsgCreateException(
+                    "soap.msg.create.err",
+                    new Object[] { e });
+        }
+    }
+
+    /**
+     *
+     * @param binding
+     * @param headers
+     * @param in
+     * @return <code>SOAPMessage</code> with <code>MimeHeaders</code> from an
+     *         <code>InputStream</code> and binding.
+     * @throws IOException
+     */
+    public static SOAPMessage createMessage(MimeHeaders headers, InputStream in,
+            String binding) throws IOException {
+        try {
+            return getMessageFactory(binding).createMessage(headers, in);
+        } catch (SOAPException e) {
+            throw new SOAPMsgCreateException(
+                    "soap.msg.create.err",
+                    new Object[] { e });
+        }
+    }
+
+    public static SOAPMessage createMessage(MimeHeaders headers, InputStream in)
+    throws IOException {
+        return createMessage(headers, in, SOAPBinding.SOAP11HTTP_BINDING);
+    }
+
+    public static MessageFactory getMessageFactory(String binding) {
+        if (binding.equals(SOAPBinding.SOAP11HTTP_BINDING)) {
+            return soap11messageFactory;
+        } else if (binding.equals(SOAPBinding.SOAP12HTTP_BINDING)) {
+            return soap12messageFactory;
+        }
+        return soap11messageFactory;
+    }
+
+    private static MessageFactory createMessageFactory(String bindingId) {
+        try {
+            return MessageFactory.newInstance(bindingId);
+        } catch(SOAPException e) {
+            throw new SOAPMsgFactoryCreateException(
+                "soap.msg.factory.create.err",
+                new Object[] { e });
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/StringUtils.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/StringUtils.java
new file mode 100644
index 0000000..8a8fa6f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/StringUtils.java
@@ -0,0 +1,79 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public class StringUtils {
+
+    /**
+     * Utility method to take a string and convert it to normal Java variable
+     * name capitalization.  This normally means converting the first
+     * character from upper case to lower case, but in the (unusual) special
+     * case when there is more than one character and both the first and
+     * second characters are upper case, we leave it alone.
+     * <p>
+     * Thus "FooBah" becomes "fooBah" and "X" becomes "x", but "URL" stays
+     * as "URL".
+     *
+     * @param  name The string to be decapitalized.
+     * @return  The decapitalized version of the string.
+     */
+    public static String decapitalize(String name) {
+        if (name == null || name.length() == 0) {
+            return name;
+        }
+        if (name.length() > 1 &&
+            Character.isUpperCase(name.charAt(1)) &&
+            Character.isUpperCase(name.charAt(0))) {
+
+            return name;
+        }
+        char chars[] = name.toCharArray();
+        chars[0] = Character.toLowerCase(chars[0]);
+        return new String(chars);
+    }
+
+    /**
+     * Utility method to take a string and convert it to normal a string
+     * with the first character in upper case.
+     * <p>
+     * Thus "fooBah" becomes "FooBah" and "x" becomes "X".\
+     *
+     * @param  name The string to be capitalized.
+     * @return  The capitalized version of the string.
+     */
+    public static String capitalize(String name) {
+        if (name == null || name.length() == 0) {
+            return name;
+        }
+        char chars[] = name.toCharArray();
+        chars[0] = Character.toUpperCase(chars[0]);
+        return new String(chars);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SunStAXReflection.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SunStAXReflection.java
new file mode 100644
index 0000000..cb13e6a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/SunStAXReflection.java
@@ -0,0 +1,55 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import java.lang.reflect.Method;
+
+public class SunStAXReflection {
+    /**
+     * Sun StAX impl <code>XMLReaderImpl.setInputSource()</code> method via reflection.
+     */
+    public static Method XMLReaderImpl_setInputSource;
+
+    /**
+     * Sun StAX impl <code>XMLReaderImpl.reset()</code> method via reflection.
+     */
+    public static Method XMLReaderImpl_reset;
+
+    static {
+        try {
+            Class clazz = Class.forName("com.sun.xml.internal.stream.XMLReaderImpl");
+            // Are we running on top of JAXP 1.4?
+            if (clazz == null) {
+                clazz = Class.forName("com.sun.xml.internal.stream.XMLStreamReaderImpl");
+            }
+            XMLReaderImpl_setInputSource =
+                clazz.getMethod("setInputSource", org.xml.sax.InputSource.class);
+            XMLReaderImpl_reset = clazz.getMethod("reset");
+        } catch (Exception e) {
+            // falls through
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/UtilException.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/UtilException.java
new file mode 100644
index 0000000..f044315
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/UtilException.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import com.sun.xml.internal.ws.util.exception.JAXWSExceptionBase;
+import com.sun.xml.internal.ws.util.localization.Localizable;
+
+/**
+ * UtilException represents an exception that occurred while
+ * one of the util classes is operating.
+ *
+ * @see JAXWSExceptionBase
+ *
+ * @author JAX-WS Development Team
+ */
+public class UtilException extends JAXWSExceptionBase {
+    public UtilException(String key, Object... args) {
+        super(key, args);
+    }
+
+    public UtilException(Throwable throwable) {
+        super(throwable);
+    }
+
+    public UtilException(Localizable arg) {
+        super("nestedUtilError", arg);
+    }
+
+    public String getResourceBundleName() {
+        return "com.sun.xml.internal.ws.resources.util";
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Version.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Version.java
new file mode 100644
index 0000000..6fc7005
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/Version.java
@@ -0,0 +1,74 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+import java.io.InputStream;
+import java.io.IOException;
+import java.util.Properties;
+
+/**
+ * Represents the version information.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class Version {
+    /**
+     * Represents the build id, which is a string like "b13" or "hudson-250".
+     */
+    public final String BUILD_ID;
+    /**
+     * Represents the complete version string, such as "JAX-WS RI 2.0-b19"
+     */
+    public final String BUILD_VERSION;
+    /**
+     * Represents the major JAX-WS version, such as "2.0".
+     */
+    public final String MAJOR_VERSION;
+
+    private Version(String buildId, String buildVersion, String majorVersion) {
+        this.BUILD_ID = fixNull(buildId);
+        this.BUILD_VERSION = fixNull(buildVersion);
+        this.MAJOR_VERSION = fixNull(majorVersion);
+    }
+
+    public static Version create(InputStream is) {
+        Properties props = new Properties();
+        try {
+            props.load(is);
+        } catch (IOException e) {
+            // ignore even if the property was not found. we'll treat everything as unknown
+        }
+        return new Version(
+            props.getProperty("build-id"),
+            props.getProperty("build-version"),
+            props.getProperty("major-version"));
+    }
+
+    private String fixNull(String v) {
+        if(v==null) return "unknown";
+        return v;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/VersionUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/VersionUtil.java
new file mode 100644
index 0000000..a93ca29c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/VersionUtil.java
@@ -0,0 +1,167 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.util;
+
+import java.util.StringTokenizer;
+
+
+/**
+ * Provides some version utilities.
+ *
+ * @author JAX-WS Development Team
+ */
+
+public final class VersionUtil {
+
+    public static boolean isVersion20(String version) {
+        return JAXWS_VERSION_20.equals(version);
+    }
+
+    /**
+     * @param version
+     * @return true if version is a 2.0 version
+     */
+    public static boolean isValidVersion(String version) {
+        return isVersion20(version);
+    }
+
+    public static String getValidVersionString() {
+        return JAXWS_VERSION_20;
+    }
+
+    /**
+     * BugFix# 4948171
+     * Method getCanonicalVersion.
+     *
+     * Converts a given version to the format "a.b.c.d"
+     * a - major version
+     * b - minor version
+     * c - minor minor version
+     * d - patch version
+     *
+     * @return int[] Canonical version number
+     */
+    public static int[] getCanonicalVersion(String version) {
+        int[] canonicalVersion = new int[4];
+
+        // initialize the default version numbers
+        canonicalVersion[0] = 1;
+        canonicalVersion[1] = 1;
+        canonicalVersion[2] = 0;
+        canonicalVersion[3] = 0;
+
+        final String DASH_DELIM = "_";
+        final String DOT_DELIM = ".";
+
+        StringTokenizer tokenizer =
+                new StringTokenizer(version, DOT_DELIM);
+        String token = tokenizer.nextToken();
+
+        // first token is major version and must not have "_"
+        canonicalVersion[0] = Integer.parseInt(token);
+
+        // resolve the minor version
+        token = tokenizer.nextToken();
+        if (token.indexOf(DASH_DELIM) == -1) {
+            // a.b
+            canonicalVersion[1] = Integer.parseInt(token);
+        } else {
+            // a.b_c
+            StringTokenizer subTokenizer =
+                    new StringTokenizer(token, DASH_DELIM);
+            canonicalVersion[1] = Integer.parseInt(subTokenizer.nextToken());
+            // leave minorMinor default
+
+            canonicalVersion[3] = Integer.parseInt(subTokenizer.nextToken());
+        }
+
+        // resolve the minorMinor and patch version, if any
+        if (tokenizer.hasMoreTokens()) {
+            token = tokenizer.nextToken();
+            if (token.indexOf(DASH_DELIM) == -1) {
+                // minorMinor
+                canonicalVersion[2] = Integer.parseInt(token);
+
+                // resolve patch, if any
+                if (tokenizer.hasMoreTokens())
+                    canonicalVersion[3] = Integer.parseInt(tokenizer.nextToken());
+            } else {
+                // a.b.c_d
+                StringTokenizer subTokenizer =
+                        new StringTokenizer(token, DASH_DELIM);
+                // minorMinor
+                canonicalVersion[2] = Integer.parseInt(subTokenizer.nextToken());
+
+                // patch
+                canonicalVersion[3] = Integer.parseInt(subTokenizer.nextToken());
+            }
+        }
+
+        return canonicalVersion;
+    }
+
+    /**
+     *
+     * @param version1
+     * @param version2
+     * @return -1, 0 or 1 based upon the comparison results
+     * -1 if version1 is less than version2
+     * 0 if version1 is equal to version2
+     * 1 if version1 is greater than version2
+     */
+    public static int compare(String version1, String version2) {
+        int[] canonicalVersion1 = getCanonicalVersion(version1);
+        int[] canonicalVersion2 = getCanonicalVersion(version2);
+
+        if (canonicalVersion1[0] < canonicalVersion2[0]) {
+            return -1;
+        } else if (canonicalVersion1[0] > canonicalVersion2[0]) {
+            return 1;
+        } else {
+            if (canonicalVersion1[1] < canonicalVersion2[1]) {
+                return -1;
+            } else if (canonicalVersion1[1] > canonicalVersion2[1]) {
+                return 1;
+            } else {
+                if (canonicalVersion1[2] < canonicalVersion2[2]) {
+                    return -1;
+                } else if (canonicalVersion1[2] > canonicalVersion2[2]) {
+                    return 1;
+                } else {
+                    if (canonicalVersion1[3] < canonicalVersion2[3]) {
+                        return -1;
+                } else if (canonicalVersion1[3] > canonicalVersion2[3]) {
+                    return 1;
+                } else
+                    return 0;
+                }
+            }
+        }
+    }
+
+    public static final String JAXWS_VERSION_20 = "2.0";
+    // the latest version is default
+    public static final String JAXWS_VERSION_DEFAULT = JAXWS_VERSION_20;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/XMLConnectionUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/XMLConnectionUtil.java
new file mode 100644
index 0000000..d00a78b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/XMLConnectionUtil.java
@@ -0,0 +1,149 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util;
+
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.http.HTTPException;
+import javax.xml.soap.MimeHeader;
+import javax.xml.soap.MimeHeaders;
+import com.sun.xml.internal.ws.spi.runtime.WSConnection;
+import com.sun.xml.internal.ws.pept.ept.MessageInfo;
+import com.sun.xml.internal.ws.encoding.xml.XMLMessage;
+import java.io.ByteArrayInputStream;
+import java.net.HttpURLConnection;
+import javax.xml.transform.stream.StreamSource;
+
+import static com.sun.xml.internal.ws.developer.JAXWSProperties.CONTENT_NEGOTIATION_PROPERTY;
+
+/**
+ * @author WS Development Team
+ */
+public class XMLConnectionUtil {
+
+    public static XMLMessage getXMLMessage(WSConnection con, MessageInfo mi) {
+        try {
+            Map<String, List<String>> headers = con.getHeaders();
+            MimeHeaders mh = new MimeHeaders();
+            if (headers != null) {
+                for (Map.Entry<String, List<String>> entry : headers.entrySet())
+                {
+                    String name = entry.getKey();
+                    for (String value : entry.getValue()) {
+                        try {
+                            mh.addHeader(name, value);
+                        } catch (IllegalArgumentException ie) {
+                            // Not a mime header. Ignore it.
+                        }
+                    }
+                }
+            }
+            return new XMLMessage(mh, con.getInput());
+        } catch (Exception e) {
+            throw (HTTPException)new HTTPException(HttpURLConnection.HTTP_INTERNAL_ERROR).initCause(e);
+        }
+    }
+
+    private static void send(WSConnection con, XMLMessage xmlMessage) {
+        try {
+            Map<String, List<String>> headers = new HashMap<String, List<String>>();
+            MimeHeaders mhs = xmlMessage.getMimeHeaders();
+            Iterator i = mhs.getAllHeaders();
+            while (i.hasNext()) {
+                MimeHeader mh = (MimeHeader) i.next();
+                String name = mh.getName();
+                List<String> values = headers.get(name);
+                if (values == null) {
+                    values = new ArrayList<String>();
+                    headers.put(name, values);
+                }
+                values.add(mh.getValue());
+            }
+            con.setHeaders(headers);
+            xmlMessage.writeTo(con.getOutput());
+
+        } catch (Exception e) {
+            throw (HTTPException)new HTTPException(HttpURLConnection.HTTP_INTERNAL_ERROR).initCause(e);
+        }
+        try {
+            con.closeOutput();
+        } catch (Exception e) {
+            throw (HTTPException)new HTTPException(HttpURLConnection.HTTP_INTERNAL_ERROR).initCause(e);
+        }
+    }
+
+    public static void sendResponse(WSConnection con, XMLMessage xmlMessage) {
+        setStatus(con, xmlMessage.getStatus());
+        send(con, xmlMessage);
+    }
+
+    public static void sendResponseOneway(WSConnection con) {
+        setStatus(con, WSConnection.ONEWAY);
+        con.getOutput();
+        con.closeOutput();
+    }
+
+    public static void sendResponseError(WSConnection con, MessageInfo messageInfo) {
+        try {
+            StreamSource source = new StreamSource(
+                new ByteArrayInputStream(DEFAULT_SERVER_ERROR.getBytes()));
+            String conneg = (String) messageInfo.getMetaData(CONTENT_NEGOTIATION_PROPERTY);
+            XMLMessage message = new XMLMessage(source, conneg == "optimistic");
+            setStatus(con, WSConnection.INTERNAL_ERR);
+            send(con, message);
+        }
+        catch (Exception e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    public static Map<String, List<String>> getHeaders(WSConnection con) {
+        return con.getHeaders();
+    }
+
+    /**
+     * sets response headers.
+     */
+    public static void setHeaders(WSConnection con,
+                                  Map<String, List<String>> headers) {
+        con.setHeaders(headers);
+    }
+
+    public static void setStatus(WSConnection con, int status) {
+        con.setStatus(status);
+    }
+
+    private final static String DEFAULT_SERVER_ERROR =
+        "<?xml version='1.0' encoding='UTF-8'?>"
+            + "<err>Internal Server Error</err>";
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/exception/JAXWSExceptionBase.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/exception/JAXWSExceptionBase.java
new file mode 100644
index 0000000..cf0696e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/exception/JAXWSExceptionBase.java
@@ -0,0 +1,89 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.exception;
+
+import com.sun.xml.internal.ws.util.localization.Localizable;
+import com.sun.xml.internal.ws.util.localization.Localizer;
+
+import javax.xml.ws.WebServiceException;
+
+/**
+ * Represents a {@link WebServiceException} with
+ * localizable message.
+ *
+ * @author WS Development Team
+ */
+public abstract class JAXWSExceptionBase
+    extends WebServiceException implements Localizable {
+
+    private final String key;
+    private final Object[] args;
+
+    protected JAXWSExceptionBase(String key, Object... args) {
+        super(findNestedException(args));
+        if(args==null)  args = new Object[0];
+        this.key = key;
+        this.args = args;
+    }
+
+    /**
+     * Creates a new exception that wraps the specified exception.
+     */
+    protected JAXWSExceptionBase(Throwable throwable) {
+        super(throwable);
+        this.key = Localizable.NOT_LOCALIZABLE;
+        this.args = new Object[]{throwable.toString()};
+    }
+
+    private static Throwable findNestedException(Object[] args) {
+        if (args == null)
+            return null;
+
+        for( Object o : args )
+            if(o instanceof Throwable)
+                return (Throwable)o;
+        return null;
+    }
+
+    public String getKey() {
+        return key;
+    }
+
+    public Object[] getArguments() {
+        return args;
+    }
+
+    public String toString() {
+        // for debug purposes only
+        //return getClass().getName() + " (" + getKey() + ")";
+        return getMessage();
+    }
+
+    public String getMessage() {
+        Localizer localizer = new Localizer();
+        return localizer.localize(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/Localizable.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/Localizable.java
new file mode 100644
index 0000000..f470122
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/Localizable.java
@@ -0,0 +1,63 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.localization;
+
+/**
+ * Localizable message.
+ *
+ * @author WS Development Team
+ */
+public interface Localizable {
+    /**
+     * Gets the key in the resource bundle.
+     *
+     * @return
+     *      if this method returns {@link #NOT_LOCALIZABLE},
+     *      that means the message is not localizable, and
+     *      the first item of {@link #getArguments()} array
+     *      holds a String.
+     */
+    public String getKey();
+
+    /**
+     * Returns the arguments for message formatting.
+     *
+     * @return
+     *      can be an array of length 0 but never be null.
+     */
+    public Object[] getArguments();
+    public String getResourceBundleName();
+
+
+    /**
+     * Special constant that represents a message that
+     * is not localizable.
+     *
+     * <p>
+     * Use of "new" is to create an unique instance.
+     */
+    public static final String NOT_LOCALIZABLE = new String("\u0000");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/LocalizableMessage.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/LocalizableMessage.java
new file mode 100644
index 0000000..3fe9be3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/LocalizableMessage.java
@@ -0,0 +1,56 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.localization;
+
+/**
+ * @author WS Development Team
+ */
+public final class LocalizableMessage implements Localizable {
+
+    private final String _bundlename;
+    private final String _key;
+    private final Object[] _args;
+
+    public LocalizableMessage(String bundlename, String key, Object... args) {
+        _bundlename = bundlename;
+        _key = key;
+        if(args==null)
+            args = new Object[0];
+        _args = args;
+    }
+
+    public String getKey() {
+        return _key;
+    }
+
+    public Object[] getArguments() {
+        return _args;
+    }
+
+    public String getResourceBundleName() {
+        return _bundlename;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/LocalizableMessageFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/LocalizableMessageFactory.java
new file mode 100644
index 0000000..5533ab0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/LocalizableMessageFactory.java
@@ -0,0 +1,43 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.localization;
+
+/**
+ * @author WS Development Team
+ */
+public class LocalizableMessageFactory {
+
+    private final String _bundlename;
+
+    public LocalizableMessageFactory(String bundlename) {
+        _bundlename = bundlename;
+    }
+
+    public Localizable getMessage(String key, Object... args) {
+        return new LocalizableMessage(_bundlename, key, args);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/Localizer.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/Localizer.java
new file mode 100644
index 0000000..c671a41
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/Localizer.java
@@ -0,0 +1,151 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.localization;
+
+import java.text.MessageFormat;
+import java.util.HashMap;
+import java.util.Locale;
+import java.util.MissingResourceException;
+import java.util.ResourceBundle;
+
+/**
+ * Localizes the {@link Localizable} into a message
+ * by using a configured {@link Locale}.
+ *
+ * @author WS Development Team
+ */
+public class Localizer {
+
+    private final Locale _locale;
+    private final HashMap _resourceBundles;
+
+    public Localizer() {
+        this(Locale.getDefault());
+    }
+
+    public Localizer(Locale l) {
+        _locale = l;
+        _resourceBundles = new HashMap();
+    }
+
+    public Locale getLocale() {
+        return _locale;
+    }
+
+    public String localize(Localizable l) {
+        String bundlename = l.getResourceBundleName();
+
+        try {
+            ResourceBundle bundle =
+                (ResourceBundle) _resourceBundles.get(bundlename);
+
+            if (bundle == null) {
+                try {
+                    bundle = ResourceBundle.getBundle(bundlename, _locale);
+                } catch (MissingResourceException e) {
+                    // work around a bug in the com.sun.enterprise.deployment.WebBundleArchivist:
+                    //   all files with an extension different from .class (hence all the .properties files)
+                    //   get copied to the top level directory instead of being in the package where they
+                    //   are defined
+                    // so, since we can't find the bundle under its proper name, we look for it under
+                    //   the top-level package
+
+                    int i = bundlename.lastIndexOf('.');
+                    if (i != -1) {
+                        String alternateBundleName =
+                            bundlename.substring(i + 1);
+                        try {
+                            bundle =
+                                ResourceBundle.getBundle(
+                                    alternateBundleName,
+                                    _locale);
+                        } catch (MissingResourceException e2) {
+                            // give up
+                            return getDefaultMessage(l);
+                        }
+                    }
+                }
+
+                _resourceBundles.put(bundlename, bundle);
+            }
+
+            if (bundle == null) {
+                return getDefaultMessage(l);
+            }
+
+            String key = l.getKey();
+            if(key==Localizable.NOT_LOCALIZABLE) {
+                // this message is not localizable
+                return (String)l.getArguments()[0];
+            }
+
+
+            if (key == null)
+                key = "undefined";
+
+            String msg;
+            try {
+                msg = bundle.getString(key);
+            } catch (MissingResourceException e) {
+                // notice that this may throw a MissingResourceException of its own (caught below)
+                msg = bundle.getString("undefined");
+            }
+
+            // localize all arguments to the given localizable object
+            Object[] args = l.getArguments();
+            for (int i = 0; i < args.length; ++i) {
+                if (args[i] instanceof Localizable)
+                    args[i] = localize((Localizable) args[i]);
+            }
+
+            String message = MessageFormat.format(msg, args);
+            return message;
+
+        } catch (MissingResourceException e) {
+            return getDefaultMessage(l);
+        }
+
+    }
+
+    private String getDefaultMessage(Localizable l) {
+        String key = l.getKey();
+        Object[] args = l.getArguments();
+        StringBuilder sb = new StringBuilder();
+        sb.append("[failed to localize] ");
+        sb.append(key);
+        if (args != null) {
+            sb.append('(');
+            for (int i = 0; i < args.length; ++i) {
+                if (i != 0)
+                    sb.append(", ");
+                sb.append(String.valueOf(args[i]));
+            }
+            sb.append(')');
+        }
+        return sb.toString();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/NullLocalizable.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/NullLocalizable.java
new file mode 100644
index 0000000..e8f57f2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/localization/NullLocalizable.java
@@ -0,0 +1,51 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.localization;
+
+/**
+ * {@link Localizable} that wraps a non-localizable string.
+ *
+ * @author WS Development Team
+ */
+public final class NullLocalizable implements Localizable {
+    private final String msg;
+
+    public NullLocalizable(String msg) {
+        if(msg==null)
+            throw new IllegalArgumentException();
+        this.msg = msg;
+    }
+
+    public String getKey() {
+        return Localizable.NOT_LOCALIZABLE;
+    }
+    public Object[] getArguments() {
+        return new Object[]{msg};
+    }
+    public String getResourceBundleName() {
+        return "";
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/resources/Messages_en.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/resources/Messages_en.properties
new file mode 100644
index 0000000..67d84a4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/resources/Messages_en.properties
@@ -0,0 +1,244 @@
+#
+# Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.  Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+# 
+
+#
+# English diagnostic messages (and fragments) for Sun's XML parser.
+#
+# P-NNN ... parser messages
+# F-NNN ... message fragments (sometimes associated with more
+#       than one message, but usually just with one)
+# V-NNN ... validation related messages
+#
+# Most messages can be produced in only one way.
+#
+
+
+#
+# Generic parsing messages, not specific to validation
+#
+P-000 = No parser input source!
+P-001 = Illegal character at end of document, &#x{0};
+P-002 = Expansion of entity "&{0};" is not well formed
+P-003 = Premature end of input
+P-004 = Missing whitespace {0}
+P-005 = Only whitespace allowed {0}
+
+    #
+    # unadorned "missing whitespace", with P-004 only
+    #
+    F-000 = after element name declaration
+    F-001 = between attribute name and type
+    F-002 = after NOTATION type name
+    F-003 = between attribute type and default value
+    F-004 = after #FIXED
+    F-005 = after <!ENTITY declaration
+    F-006 = after % in parameter entity declaration
+    F-007 = after entity name
+    F-008 = before SYSTEM literal URI
+    F-009 = after PUBLIC keyword
+    # F-010 ... identifier can be reused
+    F-011 = after notation name
+    # F-012 ... identifier can be reused
+    # F-013 ... identifier can be reused
+
+    #
+    # in declaration, in "S Name", with P-004 and P-005
+    #
+    F-014 = before name in <!DOCTYPE declaration
+    F-015 = before name in <!ELEMENT declaration
+    F-016 = before name in <!ATTLIST declaration
+    F-017 = before name in <!ENTITY declaration
+    F-018 = before NDATA notation name in <!ENTITY declaration
+    F-019 = before name in <!NOTATION declaration
+
+P-006 = Name tokens must not start with "{0}" characters
+P-007 = Value must be quoted
+P-008 = Next character must be "{0}" {1} {2}
+
+    F-020 = terminating reference to entity
+    F-021 = terminating reference to parameter entity
+    F-022 = terminating comment
+    F-023 = in XML Declaration
+    F-024 = terminating internal DTD subset
+    F-025 = terminating <!DOCTYPE ...> declaration
+    F-026 = after attribute name
+    F-027 = terminating element
+    F-028 = starting content model for element
+    F-029 = starting list of attribute NOTATIONS
+    F-030 = beginning condition DTD subset
+    F-031 = terminating <!ENTITY ...> declaration
+    F-032 = terminating <!NOTATION ...> declaration
+
+P-009 = Illegal character or entity reference syntax
+
+P-010 = Only external parameter entities may use "%{0};" in entity values
+P-011 = Illegal parameter entity reference syntax
+P-012 = Use "&lt;" for "<" in attribute values
+P-013 = Illegal reference to external entity "&{0};" in attribute
+P-014 = Reference to undefined entity "&{0};"
+P-015 = Expecting quoted value for {0}
+
+    F-033 = PUBLIC identifier
+    F-034 = SYSTEM identifier
+    F-035 = attribute value {0}
+
+P-016 = Illegal character in PUBLIC identifier:  "{0}"
+P-017 = End of entity while processing comment
+P-018 = Processing instruction target is missing
+P-019 = XML declaration may only begin entities
+
+P-020 = Illegal processing instruction target:  "{0}"
+P-021 = End of input inside processing instruction
+P-022 = Illegal processing instruction name, or missing whitespace
+P-023 = Illegal character "&#x{0};" ({1}) at end of XML Declaration
+P-024 = Expected "{0}=..."
+P-025 = XML version "{0}" should be declared
+P-026 = Illegal XML version string "{0}"
+P-027 = XML version "{0}" is recognized, but not "{1}"
+P-028 = Internal DTD subset must not have "<![..." constructs
+P-029 = Standalone declaration must be "yes" or "no", not "{0}"
+
+P-030 = Whitespace required before attributes
+P-031 = Attribute names must not start with "{0}" characters
+P-032 = Attribute "{0}" already appeared in this tag
+P-033 = Illegal xml:lang value "{0}"
+P-034 = Expected "</{0}>" to terminate element starting on line {1}
+P-035 = End of entity not allowed; an end tag is missing
+P-036 = ">" must terminate <!ELEMENT {0} ...> declaration, not "{1}"
+P-037 = Sequence content model must not contain "{0}"
+P-038 = Choice content model must not contain "{0}"
+P-039 = No content model may contain "{0}"
+
+P-040 = Need right parenthesis or "{1}" in content model, not "{0}"
+P-041 = Need right parenthesis, ",", or "|" in content model, not "{0}"
+P-042 = Illegal mixed content model for "{0}", next char = &#x{1};
+P-043 = Mixed content model for "{0}" must end with ")*", not "{1}"
+P-044 = Either an attribute declaration or ">" is expected, not "{0}"
+P-045 = Illegal type (starts with "{1}") for attribute "{0}"
+P-046 = Need keyword in conditional DTD section
+P-047 = Unterminated conditional DTD section
+P-048 = Only INCLUDE and IGNORE are allowed, not "{0}"
+P-049 = Illegal decimal character reference
+
+P-050 = Illegal hexadecimal character reference
+P-051 = Illegal XML character &#x{0};
+P-052 = Internal entity "&{0};" has characters after content
+P-053 = Unparsed entities such as "&{0};" must not be included
+P-054 = Using original entity definition for "&{0};"
+P-055 = Relative URI "{0}"; can not be resolved without a document URI
+P-056 = URI "{0}" has a fragment ID
+P-057 = Need "?>" to terminate XML declaration
+P-058 = External entity "&{0};" has characters after content
+P-059 = External parameter entity "%{0};" has characters after markup
+
+P-060 = Illegal character "{0}" in encoding name
+P-061 = Declared encoding "{0}" does not match actual one "{1}"; \
+    this might not be an error
+P-062 = Notation must be PUBLIC or SYSTEM
+P-063 = Using first definition of notation "{0}"
+P-064 = Premature end of parameter entity "%{0};"
+P-065 = Entity Resolver did not provide SYSTEM id; may affect relative URIs
+# P-066 ... ID available
+P-067 = Document root element is missing
+P-068 = Notation name is required
+P-069 = Expansion of entity "{0}" is recursive
+
+P-070 = Malformed second part of surrogate pair:  &#x{0};
+P-071 = Illegal XML character:  &#x{0};
+P-072 = Character data cannot have "]]>"
+P-073 = EOF while parsing <![CDATA[ section
+P-074 = Illegal Unicode surrogate pair:  &#x{0}; &#x{1};
+P-075 = Unsupported encoding: "{0}" (line number may be too low)
+P-076 = Character conversion error: "{0}" (line number may be too low)
+P-077 = Maximum symbol length ({0} characters) exceeded
+P-078 = No messages for locale "{0}" are available
+P-079 = The content beginning "<{1}" is not legal markup \
+    Perhaps the "{1}" (&#{0};) character should be a letter
+
+P-080 = Parameter entity references must not appear within \
+    markup declarations in the internal DTD subset
+P-081 = Incomplete Unicode surrogate pair:  &#x{0}
+
+P-082 = Trying to access null attributes
+P-083 = Illegal stack state
+P-084 = Undeclared namespace prefix of element "{0}"
+P-085 = DTD detected
+P-086 = Illegal namespace prefix "{0}"; prefix "xml" cannot be bound to any namespace other than its usual namespace
+
+#
+# Validation messages, won't normally show up unless validation is
+# being performed.  Note that V-022 relates to a spec bug:  there
+# are both a WFC and VC on undefined PEs.  If that's a WVC violation
+# there's no need for the VC, ever; and "standalone" would then affect
+# WF-ness.  For the moment this assumes it's to be a VC not a WFC
+#
+V-000 = Validation is disabled
+V-001 = Valid documents must have a <!DOCTYPE declaration
+V-002 = This document is standalone, so it must not refer to "&{0};"
+V-003 = Undeclared notation "{0}" is used by an <!ENTITY...> declaration
+V-004 = Undeclared notation "{0}" is used by an <!ATTLIST...> declaration
+V-005 = Element type "{0}" is not declared
+V-006 = Root element type is "{0}", but was declared to be "{1}"
+V-007 = Attribute "{0}" is not declared for element "{1}"
+V-008 = Attribute "{0}" of element "{1}" must only have value "{2}"
+V-009 = Attribute value for "{0}" is #REQUIRED
+
+V-010 = This document is standalone, \
+    so attribute "{0}" must not be defaulted
+V-011 = This document is standalone, \
+    so element "{0}" must not have ignorable whitespace
+V-012 = Element "{0}" was already declared
+V-013 = Parameter entities must not contain partial declarations
+V-014 = Parameter entity nesting error in content model for "{0}"
+V-015 = Mixed content model repeats element "{0}"
+V-016 = This element already has an ID attribute, "{0}"
+V-017 = ID attribute "{0}" must not be #FIXED
+V-018 = ID attribute "{0}" must not be defaulted
+V-019 = This document is standalone; this attribute needs to be pre-normalized
+
+V-020 = Parameter entities must not contain partial conditional DTD sections
+V-021 = Parameter entities must not contain partial comments
+V-022 = Reference to undefined parameter entity "%{0};"
+V-023 = This document is standalone; this ignorable CDATA whitespace is forbidden
+V-024 = No element has an ID attribute with value "{0}"
+V-025 = ID values must be XML names; "{0}" is not a name
+V-026 = Another element already has an ID attribute with value "{0}"
+V-027 = IDREF/IDREFS values must be XML names; "{0}" is not a name
+V-028 = NMTOKEN/NMTOKENS values must be XML name tokens; "{0}" is not one
+V-029 = Value "{0}" is not one of the enumerated values for this attribute
+
+V-030 = Attribute value "{0}" does not name a notation
+V-031 = Attribute value "{0}" does not name an unparsed entity
+V-032 = NMTOKENS attributes must have at least one value
+V-033 = EMPTY content models must have no content
+V-034 = Element "{0}" does not allow "{1}" -- {2}
+V-035 = Element "{0}" allows no further input; "{1}" is not allowed
+V-036 = Element "{0}" does not allow "{1}" here
+V-037 = Element "{0}" does not allow text
+V-038 = Element "{0}" requires additional elements
+V-039 = IDREFS attributes must have at least one value
+
+V-040 = ENTITIES attributes must have at least one value
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/version.properties b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/version.properties
new file mode 100644
index 0000000..106fba4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/version.properties
@@ -0,0 +1,4 @@
+build-id=b08
+build-version=JAX-WS RI 2.0_03-b08-fcs
+major-version=2.0_03
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/CDATA.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/CDATA.java
new file mode 100644
index 0000000..09cea48
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/CDATA.java
@@ -0,0 +1,58 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.xml;
+
+/**
+ * @author WS Development Team
+ */
+public final class CDATA {
+
+    public CDATA(String text) {
+        _text = text;
+    }
+
+    public String getText() {
+        return _text;
+    }
+
+    public boolean equals(Object obj) {
+        if (obj == null)
+            return false;
+
+        if (!(obj instanceof CDATA))
+            return false;
+
+        CDATA cdata = (CDATA) obj;
+
+        return this._text.equals(cdata._text);
+    }
+
+    public int hashCode() {
+        return _text.hashCode();
+    }
+
+    private String _text;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/NamedNodeMapIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/NamedNodeMapIterator.java
new file mode 100644
index 0000000..9d3fcf3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/NamedNodeMapIterator.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.xml;
+
+import java.util.Iterator;
+
+import org.w3c.dom.NamedNodeMap;
+
+/**
+ * @author WS Development Team
+ */
+public class NamedNodeMapIterator implements Iterator {
+
+    protected NamedNodeMap _map;
+    protected int _index;
+
+    public NamedNodeMapIterator(NamedNodeMap map) {
+        _map = map;
+        _index = 0;
+    }
+
+    public boolean hasNext() {
+        if (_map == null)
+            return false;
+        return _index < _map.getLength();
+    }
+
+    public Object next() {
+        Object obj = _map.item(_index);
+        if (obj != null)
+            ++_index;
+        return obj;
+    }
+
+    public void remove() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/NodeListIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/NodeListIterator.java
new file mode 100644
index 0000000..c747a94
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/NodeListIterator.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.xml;
+
+import java.util.Iterator;
+
+import org.w3c.dom.NodeList;
+
+/**
+ * @author WS Development Team
+ */
+public class NodeListIterator implements Iterator {
+
+    protected NodeList _list;
+    protected int _index;
+
+    public NodeListIterator(NodeList list) {
+        _list = list;
+        _index = 0;
+    }
+
+    public boolean hasNext() {
+        if (_list == null)
+            return false;
+        return _index < _list.getLength();
+    }
+
+    public Object next() {
+        Object obj = _list.item(_index);
+        if (obj != null)
+            ++_index;
+        return obj;
+    }
+
+    public void remove() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/StAXSource.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/StAXSource.java
new file mode 100644
index 0000000..eccce23
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/StAXSource.java
@@ -0,0 +1,254 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.xml;
+
+import org.xml.sax.ContentHandler;
+import org.xml.sax.DTDHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXNotRecognizedException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.transform.sax.SAXSource;
+
+/**
+ * A JAXP {@link javax.xml.transform.Source} implementation that wraps
+ * the specified {@link javax.xml.stream.XMLStreamReader} or
+ * {@link javax.xml.stream.XMLEventReader} for use by applications that
+ * expext a {@link javax.xml.transform.Source}.
+ *
+ * <p>
+ * The fact that StAXSource derives from SAXSource is an implementation
+ * detail. Thus in general applications are strongly discouraged from
+ * accessing methods defined on SAXSource. In particular:
+ *
+ * <ul>
+ *   <li> The setXMLReader and setInputSource methods shall never be called.</li>
+ *   <li> The XMLReader object obtained by the getXMLReader method shall
+ *        be used only for parsing the InputSource object returned by
+ *        the getInputSource method.</li>
+ *   <li> The InputSource object obtained by the getInputSource method shall
+ *        be used only for being parsed by the XMLReader object returned by
+ *        the getXMLReader method.</li>
+ * </ul>
+ *
+ * <p>
+ * Example:
+ *
+ * <pre>
+    // create a StAXSource
+    XMLStreamReader reader = XMLInputFactory.newInstance().createXMLStreamReader(new FileReader(args[0]));
+    Source staxSource = new StAXSource(reader);
+
+    // createa StreamResult
+    Result streamResult = new StreamResult(System.out);
+
+    // run the transform
+    TransformerFactory.newInstance().newTransformer().transform(staxSource, streamResult);
+ * </pre>
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+public class StAXSource extends SAXSource {
+
+    // StAX to SAX converter that will read from StAX and produce SAX
+    // this object will be wrapped by the XMLReader exposed to the client
+    private final XMLStreamReaderToContentHandler reader;
+
+    // SAX allows ContentHandler to be changed during the parsing,
+    // but JAXB doesn't. So this repeater will sit between those
+    // two components.
+    private XMLFilterImpl repeater = new XMLFilterImpl();
+
+    // this object will pretend as an XMLReader.
+    // no matter what parameter is specified to the parse method,
+    // it will just read from the StAX reader.
+    private final XMLReader pseudoParser = new XMLReader() {
+        public boolean getFeature(String name) throws SAXNotRecognizedException {
+            throw new SAXNotRecognizedException(name);
+        }
+
+        public void setFeature(String name, boolean value) throws SAXNotRecognizedException {
+            throw new SAXNotRecognizedException(name);
+        }
+
+        public Object getProperty(String name) throws SAXNotRecognizedException {
+            if( "http://xml.org/sax/properties/lexical-handler".equals(name) ) {
+                return lexicalHandler;
+            }
+            throw new SAXNotRecognizedException(name);
+        }
+
+        public void setProperty(String name, Object value) throws SAXNotRecognizedException {
+            if( "http://xml.org/sax/properties/lexical-handler".equals(name) ) {
+                this.lexicalHandler = (LexicalHandler)value;
+                return;
+            }
+            throw new SAXNotRecognizedException(name);
+        }
+
+        private LexicalHandler lexicalHandler;
+
+        // we will store this value but never use it by ourselves.
+        private EntityResolver entityResolver;
+        public void setEntityResolver(EntityResolver resolver) {
+            this.entityResolver = resolver;
+        }
+        public EntityResolver getEntityResolver() {
+            return entityResolver;
+        }
+
+        private DTDHandler dtdHandler;
+        public void setDTDHandler(DTDHandler handler) {
+            this.dtdHandler = handler;
+        }
+        public DTDHandler getDTDHandler() {
+            return dtdHandler;
+        }
+
+        public void setContentHandler(ContentHandler handler) {
+            repeater.setContentHandler(handler);
+        }
+        public ContentHandler getContentHandler() {
+            return repeater.getContentHandler();
+        }
+
+        private ErrorHandler errorHandler;
+        public void setErrorHandler(ErrorHandler handler) {
+            this.errorHandler = handler;
+        }
+        public ErrorHandler getErrorHandler() {
+            return errorHandler;
+        }
+
+        public void parse(InputSource input) throws SAXException {
+            parse();
+        }
+
+        public void parse(String systemId) throws SAXException {
+            parse();
+        }
+
+        public void parse() throws SAXException {
+            // parses from a StAX reader and generates SAX events which
+            // go through the repeater and are forwarded to the appropriate
+            // component
+            try {
+                reader.bridge();
+            } catch( XMLStreamException e ) {
+                // wrap it in a SAXException
+                SAXParseException se =
+                    new SAXParseException(
+                        e.getMessage(),
+                        null,
+                        null,
+                        e.getLocation().getLineNumber(),
+                        e.getLocation().getColumnNumber(),
+                        e);
+
+                // if the consumer sets an error handler, it is our responsibility
+                // to notify it.
+                if(errorHandler!=null)
+                    errorHandler.fatalError(se);
+
+                // this is a fatal error. Even if the error handler
+                // returns, we will abort anyway.
+                throw se;
+
+            }
+        }
+    };
+
+    /**
+     * Creates a new {@link javax.xml.transform.Source} for the given
+     * {@link XMLStreamReader}.
+     *
+     * The XMLStreamReader must be pointing at either a
+     * {@link javax.xml.stream.XMLStreamConstants#START_DOCUMENT} or
+     * {@link javax.xml.stream.XMLStreamConstants#START_ELEMENT} event.
+     *
+     * @param reader XMLStreamReader that will be exposed as a Source
+     * @throws IllegalArgumentException iff the reader is null
+     * @throws IllegalStateException iff the reader is not pointing at either a
+     * START_DOCUMENT or START_ELEMENT event
+     */
+    public StAXSource(XMLStreamReader reader, boolean eagerQuit) {
+        if( reader == null )
+            throw new IllegalArgumentException();
+
+        int eventType = reader.getEventType();
+        if (!(eventType == XMLStreamConstants.START_DOCUMENT)
+            && !(eventType == XMLStreamConstants.START_ELEMENT)) {
+            throw new IllegalStateException();
+        }
+
+        this.reader = new XMLStreamReaderToContentHandler(reader,repeater,eagerQuit);
+
+        super.setXMLReader(pseudoParser);
+        // pass a dummy InputSource. We don't care
+        super.setInputSource(new InputSource());
+    }
+
+//    /**
+//     * Creates a new {@link javax.xml.transform.Source} for the given
+//     * {@link XMLEventReader}.
+//     *
+//     * The XMLEventReader must be pointing at either a
+//     * {@link javax.xml.stream.XMLStreamConstants#START_DOCUMENT} or
+//     * {@link javax.xml.stream.XMLStreamConstants#START_ELEMENT} event.
+//     *
+//     * @param reader XMLEventReader that will be exposed as a Source
+//     * @throws IllegalArgumentException iff the reader is null
+//     * @throws IllegalStateException iff the reader is not pointing at either a
+//     * START_DOCUEMENT or START_ELEMENT event
+//     */
+//    public StAXSource(XMLEventReader reader) {
+//        if( reader == null )
+//            throw new IllegalArgumentException();
+//
+//        // TODO: detect IllegalStateException for START_ELEMENT|DOCUMENT
+//        // bugid 5046340 - peek not implemented
+//        // XMLEvent event = staxEventReader.peek();
+//
+//        this.reader =
+//            new XMLEventReaderToContentHandler(
+//                reader,
+//                repeater);
+//
+//        super.setXMLReader(pseudoParser);
+//        // pass a dummy InputSource. We don't care
+//        super.setInputSource(new InputSource());
+//    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/XMLStreamReaderToContentHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/XMLStreamReaderToContentHandler.java
new file mode 100644
index 0000000..5c544fc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/XMLStreamReaderToContentHandler.java
@@ -0,0 +1,345 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.xml;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.helpers.AttributesImpl;
+
+/**
+ * This is a simple utility class that adapts StAX events from an
+ * {@link XMLStreamReader} to SAX events on a
+ * {@link ContentHandler}, bridging between the two
+ * parser technologies.
+ *
+ * @author Ryan.Shoemaker@Sun.COM
+ */
+public class XMLStreamReaderToContentHandler {
+
+    // StAX event source
+    private final XMLStreamReader staxStreamReader;
+
+    // SAX event sink
+    private final ContentHandler saxHandler;
+
+    // if true, when the conversion is completed, leave the cursor to the last
+    // event that was fired (such as end element)
+    private boolean eagerQuit;
+
+    /**
+     * Construct a new StAX to SAX adapter that will convert a StAX event
+     * stream into a SAX event stream.
+     *
+     * @param staxCore
+     *                StAX event source
+     * @param saxCore
+     *                SAXevent sink
+     */
+    public XMLStreamReaderToContentHandler(XMLStreamReader staxCore, ContentHandler saxCore, boolean eagerQuit) {
+        this.staxStreamReader = staxCore;
+        this.saxHandler = saxCore;
+        this.eagerQuit = eagerQuit;
+    }
+
+    /*
+     * @see StAXReaderToContentHandler#bridge()
+     */
+    public void bridge() throws XMLStreamException {
+
+        try {
+            // remembers the nest level of elements to know when we are done.
+            int depth=0;
+
+            // if the parser is at the start tag, proceed to the first element
+            int event = staxStreamReader.getEventType();
+            if(event == XMLStreamConstants.START_DOCUMENT) {
+                // nextTag doesn't correctly handle DTDs
+                while( !staxStreamReader.isStartElement() )
+                    event = staxStreamReader.next();
+            }
+
+
+            if( event!=XMLStreamConstants.START_ELEMENT)
+                throw new IllegalStateException("The current event is not START_ELEMENT\n but " + event);
+
+            handleStartDocument();
+
+            OUTER:
+            do {
+                // These are all of the events listed in the javadoc for
+                // XMLEvent.
+                // The spec only really describes 11 of them.
+                switch (event) {
+                    case XMLStreamConstants.START_ELEMENT :
+                        depth++;
+                        handleStartElement();
+                        break;
+                    case XMLStreamConstants.END_ELEMENT :
+                        handleEndElement();
+                        depth--;
+                        if(depth==0 && eagerQuit)
+                            break OUTER;
+                        break;
+                    case XMLStreamConstants.CHARACTERS :
+                        handleCharacters();
+                        break;
+                    case XMLStreamConstants.ENTITY_REFERENCE :
+                        handleEntityReference();
+                        break;
+                    case XMLStreamConstants.PROCESSING_INSTRUCTION :
+                        handlePI();
+                        break;
+                    case XMLStreamConstants.COMMENT :
+                        handleComment();
+                        break;
+                    case XMLStreamConstants.DTD :
+                        handleDTD();
+                        break;
+                    case XMLStreamConstants.ATTRIBUTE :
+                        handleAttribute();
+                        break;
+                    case XMLStreamConstants.NAMESPACE :
+                        handleNamespace();
+                        break;
+                    case XMLStreamConstants.CDATA :
+                        handleCDATA();
+                        break;
+                    case XMLStreamConstants.ENTITY_DECLARATION :
+                        handleEntityDecl();
+                        break;
+                    case XMLStreamConstants.NOTATION_DECLARATION :
+                        handleNotationDecl();
+                        break;
+                    case XMLStreamConstants.SPACE :
+                        handleSpace();
+                        break;
+                    default :
+                        throw new InternalError("processing event: " + event);
+                }
+
+                event=staxStreamReader.next();
+            } while (depth!=0);
+
+            handleEndDocument();
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private void handleEndDocument() throws SAXException {
+        saxHandler.endDocument();
+    }
+
+    private void handleStartDocument() throws SAXException {
+        saxHandler.setDocumentLocator(new Locator() {
+            public int getColumnNumber() {
+                return staxStreamReader.getLocation().getColumnNumber();
+            }
+            public int getLineNumber() {
+                return staxStreamReader.getLocation().getLineNumber();
+            }
+            public String getPublicId() {
+                return staxStreamReader.getLocation().getPublicId();
+            }
+            public String getSystemId() {
+                return staxStreamReader.getLocation().getSystemId();
+            }
+        });
+        saxHandler.startDocument();
+    }
+
+    private void handlePI() throws XMLStreamException {
+        try {
+            saxHandler.processingInstruction(
+                staxStreamReader.getPITarget(),
+                staxStreamReader.getPIData());
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private void handleCharacters() throws XMLStreamException {
+        try {
+            saxHandler.characters(
+                staxStreamReader.getTextCharacters(),
+                staxStreamReader.getTextStart(),
+                staxStreamReader.getTextLength() );
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private void handleEndElement() throws XMLStreamException {
+        QName qName = staxStreamReader.getName();
+
+        try {
+            // fire endElement
+            saxHandler.endElement(
+                qName.getNamespaceURI(),
+                qName.getLocalPart(),
+                qName.toString());
+
+            // end namespace bindings
+            int nsCount = staxStreamReader.getNamespaceCount();
+            for (int i = nsCount - 1; i >= 0; i--) {
+                String prefix = staxStreamReader.getNamespacePrefix(i);
+                if (prefix == null) { // true for default namespace
+                    prefix = "";
+                }
+                saxHandler.endPrefixMapping(prefix);
+            }
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private void handleStartElement() throws XMLStreamException {
+
+        try {
+            // start namespace bindings
+            int nsCount = staxStreamReader.getNamespaceCount();
+            for (int i = 0; i < nsCount; i++) {
+                saxHandler.startPrefixMapping(
+                    fixNull(staxStreamReader.getNamespacePrefix(i)),
+                    fixNull(staxStreamReader.getNamespaceURI(i)));
+            }
+
+            // fire startElement
+            QName qName = staxStreamReader.getName();
+            String prefix = qName.getPrefix();
+            String rawname;
+            if(prefix==null || prefix.length()==0)
+                rawname = qName.getLocalPart();
+            else
+                rawname = prefix + ':' + qName.getLocalPart();
+            Attributes attrs = getAttributes();
+            saxHandler.startElement(
+                qName.getNamespaceURI(),
+                qName.getLocalPart(),
+                rawname,
+                attrs);
+        } catch (SAXException e) {
+            throw new XMLStreamException(e);
+        }
+    }
+
+    private static String fixNull(String s) {
+        if(s==null)     return "";
+        else            return s;
+    }
+
+    /**
+     * Get the attributes associated with the given START_ELEMENT or ATTRIBUTE
+     * StAXevent.
+     *
+     * @return the StAX attributes converted to an org.xml.sax.Attributes
+     */
+    private Attributes getAttributes() {
+        AttributesImpl attrs = new AttributesImpl();
+
+        int eventType = staxStreamReader.getEventType();
+        if (eventType != XMLStreamConstants.ATTRIBUTE
+            && eventType != XMLStreamConstants.START_ELEMENT) {
+            throw new InternalError(
+                "getAttributes() attempting to process: " + eventType);
+        }
+
+        // in SAX, namespace declarations are not part of attributes by default.
+        // (there's a property to control that, but as far as we are concerned
+        // we don't use it.) So don't add xmlns:* to attributes.
+
+        // gather non-namespace attrs
+        for (int i = 0; i < staxStreamReader.getAttributeCount(); i++) {
+            String uri = staxStreamReader.getAttributeNamespace(i);
+            if(uri==null)   uri="";
+            String localName = staxStreamReader.getAttributeLocalName(i);
+            String prefix = staxStreamReader.getAttributePrefix(i);
+            String qName;
+            if(prefix==null || prefix.length()==0)
+                qName = localName;
+            else
+                qName = prefix + ':' + localName;
+            String type = staxStreamReader.getAttributeType(i);
+            String value = staxStreamReader.getAttributeValue(i);
+
+            attrs.addAttribute(uri, localName, qName, type, value);
+        }
+
+        return attrs;
+    }
+
+    private void handleNamespace() {
+        // no-op ???
+        // namespace events don't normally occur outside of a startElement
+        // or endElement
+    }
+
+    private void handleAttribute() {
+        // no-op ???
+        // attribute events don't normally occur outside of a startElement
+        // or endElement
+    }
+
+    private void handleDTD() {
+        // no-op ???
+        // it seems like we need to pass this info along, but how?
+    }
+
+    private void handleComment() {
+        // no-op ???
+    }
+
+    private void handleEntityReference() {
+        // no-op ???
+    }
+
+    private void handleSpace() {
+        // no-op ???
+        // this event is listed in the javadoc, but not in the spec.
+    }
+
+    private void handleNotationDecl() {
+        // no-op ???
+        // this event is listed in the javadoc, but not in the spec.
+    }
+
+    private void handleEntityDecl() {
+        // no-op ???
+        // this event is listed in the javadoc, but not in the spec.
+    }
+
+    private void handleCDATA() {
+        // no-op ???
+        // this event is listed in the javadoc, but not in the spec.
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/XmlUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/XmlUtil.java
new file mode 100644
index 0000000..6019eba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/util/xml/XmlUtil.java
@@ -0,0 +1,234 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.util.xml;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStreamWriter;
+import java.io.Writer;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.StringTokenizer;
+
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerConfigurationException;
+import javax.xml.transform.TransformerFactory;
+
+import org.w3c.dom.Attr;
+import org.w3c.dom.Element;
+import org.w3c.dom.EntityReference;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+import org.w3c.dom.Text;
+
+import com.sun.xml.internal.ws.server.ServerRtException;
+import com.sun.xml.internal.ws.util.ByteArrayBuffer;
+
+import java.net.URL;
+import java.util.Enumeration;
+import javax.xml.ws.WebServiceException;
+import com.sun.org.apache.xml.internal.resolver.CatalogManager;
+import com.sun.org.apache.xml.internal.resolver.tools.CatalogResolver;
+import org.xml.sax.EntityResolver;
+
+/**
+ * @author WS Development Team
+ */
+public class XmlUtil {
+
+    public static String getPrefix(String s) {
+        int i = s.indexOf(':');
+        if (i == -1)
+            return null;
+        return s.substring(0, i);
+    }
+
+    public static String getLocalPart(String s) {
+        int i = s.indexOf(':');
+        if (i == -1)
+            return s;
+        return s.substring(i + 1);
+    }
+
+
+
+    public static String getAttributeOrNull(Element e, String name) {
+        Attr a = e.getAttributeNode(name);
+        if (a == null)
+            return null;
+        return a.getValue();
+    }
+
+    public static String getAttributeNSOrNull(
+        Element e,
+        String name,
+        String nsURI) {
+        Attr a = e.getAttributeNodeNS(nsURI, name);
+        if (a == null)
+            return null;
+        return a.getValue();
+    }
+
+/*    public static boolean matchesTagNS(Element e, String tag, String nsURI) {
+        try {
+            return e.getLocalName().equals(tag)
+                && e.getNamespaceURI().equals(nsURI);
+        } catch (NullPointerException npe) {
+
+            // localname not null since parsing would fail before here
+            throw new WSDLParseException(
+                "null.namespace.found",
+                e.getLocalName());
+        }
+    }
+
+    public static boolean matchesTagNS(
+        Element e,
+        javax.xml.namespace.QName name) {
+        try {
+            return e.getLocalName().equals(name.getLocalPart())
+                && e.getNamespaceURI().equals(name.getNamespaceURI());
+        } catch (NullPointerException npe) {
+
+            // localname not null since parsing would fail before here
+            throw new WSDLParseException(
+                "null.namespace.found",
+                e.getLocalName());
+        }
+    }*/
+
+    public static Iterator getAllChildren(Element element) {
+        return new NodeListIterator(element.getChildNodes());
+    }
+
+    public static Iterator getAllAttributes(Element element) {
+        return new NamedNodeMapIterator(element.getAttributes());
+    }
+
+    public static List<String> parseTokenList(String tokenList) {
+        List<String> result = new ArrayList<String>();
+        StringTokenizer tokenizer = new StringTokenizer(tokenList, " ");
+        while (tokenizer.hasMoreTokens()) {
+            result.add(tokenizer.nextToken());
+        }
+        return result;
+    }
+
+    public static String getTextForNode(Node node) {
+        StringBuffer sb = new StringBuffer();
+
+        NodeList children = node.getChildNodes();
+        if (children.getLength() == 0)
+            return null;
+
+        for (int i = 0; i < children.getLength(); ++i) {
+            Node n = children.item(i);
+
+            if (n instanceof Text)
+                sb.append(n.getNodeValue());
+            else if (n instanceof EntityReference) {
+                String s = getTextForNode(n);
+                if (s == null)
+                    return null;
+                else
+                    sb.append(s);
+            } else
+                return null;
+        }
+
+        return sb.toString();
+    }
+
+    public static InputStream getUTF8Stream(String s) {
+        try {
+            ByteArrayBuffer bab = new ByteArrayBuffer();
+            Writer w = new OutputStreamWriter(bab, "utf-8");
+            w.write(s);
+            w.close();
+            return bab.newInputStream();
+        } catch (IOException e) {
+            throw new RuntimeException("should not happen");
+        }
+    }
+
+    static final TransformerFactory transformerFactory = TransformerFactory.newInstance();
+
+    public static Transformer newTransformer() {
+        try {
+            return transformerFactory.newTransformer();
+        } catch (TransformerConfigurationException tex) {
+            throw new IllegalStateException("Unable to create a JAXP transformer");
+        }
+    }
+
+    /*
+     * Gets an EntityResolver using XML catalog
+     */
+    public static EntityResolver createEntityResolver(URL catalogUrl) {
+        // set up a manager
+        CatalogManager manager = new CatalogManager();
+        manager.setIgnoreMissingProperties(true);
+        try {
+            if (catalogUrl != null) {
+                manager.getCatalog().parseCatalog(catalogUrl);
+            }
+        } catch (IOException e) {
+            throw new ServerRtException("server.rt.err",e);
+        }
+        return new CatalogResolver(manager);
+    }
+
+    /**
+     * Gets a default EntityResolver for catalog at META-INF/jaxws-catalog.xml
+     */
+    public static EntityResolver createDefaultCatalogResolver() {
+
+        // set up a manager
+        CatalogManager manager = new CatalogManager();
+        manager.setIgnoreMissingProperties(true);
+
+        // parse the catalog
+        ClassLoader cl = Thread.currentThread().getContextClassLoader();
+        Enumeration<URL> catalogEnum;
+        try {
+            if (cl == null) {
+                catalogEnum = ClassLoader.getSystemResources("META-INF/jax-ws-catalog.xml");
+            } else {
+                catalogEnum = cl.getResources("META-INF/jax-ws-catalog.xml");
+            }
+
+            while(catalogEnum.hasMoreElements()) {
+                URL url = catalogEnum.nextElement();
+                manager.getCatalog().parseCatalog(url);
+            }
+        } catch (IOException e) {
+            throw new WebServiceException(e);
+        }
+
+        return new CatalogResolver(manager);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/WSDLContext.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/WSDLContext.java
new file mode 100644
index 0000000..bceac71
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/WSDLContext.java
@@ -0,0 +1,177 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl;
+
+import com.sun.xml.internal.ws.wsdl.parser.*;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.SAXException;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.ws.WebServiceException;
+import javax.xml.ws.soap.SOAPBinding;
+
+import java.io.IOException;
+import java.net.URL;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Set;
+
+/**
+ * $author: JAXWS Development Team
+ */
+public class WSDLContext {
+    private final URL orgWsdlLocation;
+    private String targetNamespace;
+    private final WSDLDocument wsdlDoc;
+
+    /**
+     * Creates a {@link WSDLContext} by parsing the given wsdl file.
+     */
+    public WSDLContext(URL wsdlDocumentLocation, EntityResolver entityResolver) throws WebServiceException {
+        //must get binding information
+        assert entityResolver != null;
+
+        if (wsdlDocumentLocation == null)
+            throw new WebServiceException("No WSDL location Information present, error");
+
+        orgWsdlLocation = wsdlDocumentLocation;
+        try {
+            wsdlDoc = RuntimeWSDLParser.parse(wsdlDocumentLocation, entityResolver);
+        } catch (IOException e) {
+            throw new WebServiceException(e);
+        } catch (XMLStreamException e) {
+            throw new WebServiceException(e);
+        } catch (SAXException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    public URL getWsdlLocation() {
+        return orgWsdlLocation;
+    }
+
+    public String getOrigURLPath() {
+        return orgWsdlLocation.getPath();
+    }
+
+    public QName getServiceQName() {
+        return wsdlDoc.getFirstServiceName();
+    }
+
+    public boolean contains(QName serviceName) {
+        return (wsdlDoc.getServices().containsKey(serviceName));
+    }
+
+    //just get the first one for now
+    public String getEndpoint(QName serviceName) {
+        if (serviceName == null)
+            throw new WebServiceException("Service unknown, can not identify ports for an unknown Service.");
+        Service service = wsdlDoc.getService(serviceName);
+        String endpoint = null;
+        if (service != null) {
+            Iterator<Map.Entry<QName, Port>> iter = service.entrySet().iterator();
+            if (iter.hasNext()) {
+                Port port = iter.next().getValue();
+                endpoint = port.getAddress();
+            }
+        }
+        if (endpoint == null)
+            throw new WebServiceException("Endpoint not found. Check WSDL file to verify endpoint was provided.");
+        return endpoint;
+    }
+
+    //just get the first one for now
+    public QName getPortName() {
+        return wsdlDoc.getFirstPortName();
+    }
+
+    public String getBindingID(QName serviceName, QName portName) {
+        return getWsdlDocument().getBindingId(serviceName, portName);
+    }
+
+    public String getTargetNamespace() {
+        return targetNamespace;
+    }
+
+    public void setTargetNamespace(String tns) {
+        targetNamespace = tns;
+    }
+
+    public Set<QName> getPortsAsSet(QName serviceName) {
+        Service service = wsdlDoc.getService(serviceName);
+        if (service != null) {
+            return service.keySet();
+        }
+        return null;
+    }
+
+
+    public boolean contains(QName serviceName, QName portName) {
+        Service service = wsdlDoc.getService(serviceName);
+        if (service != null) {
+
+            Iterator<Map.Entry<QName, Port>> iter = service.entrySet().iterator();
+            while (iter.hasNext()) {
+                Port port = iter.next().getValue();
+                if (port.getName().equals(portName))
+                    return true;
+            }
+        }
+        return false;
+    }
+
+    public QName getFirstServiceName() {
+        return wsdlDoc.getFirstServiceName();
+    }
+
+    public Set<QName> getAllServiceNames() {
+        return wsdlDoc.getServices().keySet();
+    }
+
+    public WSDLDocument getWsdlDocument() {
+        return wsdlDoc;
+    }
+
+    public Binding getWsdlBinding(QName service, QName port) {
+        if (wsdlDoc == null)
+            return null;
+        return wsdlDoc.getBinding(service, port);
+    }
+
+    public String getEndpoint(QName serviceName, QName portQName) {
+        Service service = wsdlDoc.getService(serviceName);
+        if (service != null) {
+            Port p = service.get(portQName);
+            if (p != null)
+                return p.getAddress();
+            else
+                throw new WebServiceException("No ports found for service " + serviceName);
+        } else {
+            throw new WebServiceException("Service unknown, can not identify ports for an unknown Service.");
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Binding.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Binding.java
new file mode 100644
index 0000000..fd95ec9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Binding.java
@@ -0,0 +1,116 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import com.sun.xml.internal.ws.model.Mode;
+import com.sun.xml.internal.ws.model.ParameterBinding;
+
+import javax.xml.namespace.QName;
+import java.util.HashMap;
+
+public class Binding extends HashMap<String, BindingOperation> {
+    private QName name;
+    private QName portTypeName;
+    private PortType portType;
+    private String bindingId;
+    private WSDLDocument wsdlDoc;
+    private boolean finalized = false;
+
+    public Binding(QName name, QName portTypeName) {
+        super();
+        this.name = name;
+        this.portTypeName = portTypeName;
+    }
+
+    public QName getName() {
+        return name;
+    }
+
+    public QName getPortTypeName(){
+        return portTypeName;
+    }
+
+    public PortType getPortType() {
+        return portType;
+    }
+
+    public void setPortType(PortType portType) {
+        this.portType = portType;
+    }
+
+    public String getBindingId() {
+        return bindingId;
+    }
+
+    public void setBindingId(String bindingId) {
+        this.bindingId = bindingId;
+    }
+
+    public void setWsdlDocument(WSDLDocument wsdlDoc) {
+        this.wsdlDoc = wsdlDoc;
+    }
+
+    public ParameterBinding getBinding(String operation, String part, Mode mode){
+        BindingOperation op = get(operation);
+        if(op == null){
+            //TODO throw exception
+            return null;
+        }
+        if((Mode.IN == mode)||(Mode.INOUT == mode))
+            return op.getInputBinding(part);
+        else
+            return op.getOutputBinding(part);
+    }
+
+    /**
+     * Gives binding for a given {@link BindingOperation} a wsdl part and {@link Mode}
+     * @param op  must be non-null
+     * @param part must be non-null
+     * @param mode must be non-null
+     * @return  parameter Binding, null the binding could not be determined.
+     */
+    public ParameterBinding getBinding(BindingOperation op, String part, Mode mode){
+        if((Mode.IN == mode)||(Mode.INOUT == mode))
+            return op.getInputBinding(part);
+        else
+            return op.getOutputBinding(part);
+    }
+
+    public String getMimeType(String operation, String part, Mode mode){
+        BindingOperation op = get(operation);
+        if(Mode.IN == mode)
+            return op.getMimeTypeForInputPart(part);
+        else
+            return op.getMimeTypeForOutputPart(part);
+    }
+
+    public void finalizeBinding(){
+        if(!finalized){
+            wsdlDoc.finalizeBinding(this);
+            finalized = true;
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/BindingOperation.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/BindingOperation.java
new file mode 100644
index 0000000..c301ad9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/BindingOperation.java
@@ -0,0 +1,175 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import com.sun.xml.internal.ws.model.ParameterBinding;
+import com.sun.xml.internal.ws.model.Mode;
+
+import javax.xml.ws.Response;
+import java.util.HashMap;
+import java.util.Map;
+
+public class BindingOperation {
+    private String name;
+
+    // map of wsdl:part to the binding
+    private Map<String, ParameterBinding> inputParts;
+    private Map<String, ParameterBinding> outputParts;
+    private Map<String, String> inputMimeTypes;
+    private Map<String, String> outputMimeTypes;
+
+    private boolean explicitInputSOAPBodyParts = false;
+    private boolean explicitOutputSOAPBodyParts = false;
+
+    private Boolean emptyInputBody;
+    private Boolean emptyOutputBody;
+
+    private Map<String, Part> inParts;
+    private Map<String, Part> outParts;
+
+
+    /**
+     *
+     * @param name wsdl:operation name qualified value
+     */
+    public BindingOperation(String name) {
+        this.name = name;
+        inputParts = new HashMap<String, ParameterBinding>();
+        outputParts = new HashMap<String, ParameterBinding>();
+        inputMimeTypes = new HashMap<String, String>();
+        outputMimeTypes = new HashMap<String, String>();
+        inParts = new HashMap<String, Part>();
+        outParts = new HashMap<String, Part>();
+    }
+
+    public String getName(){
+        return name;
+    }
+
+    public Part getPart(String partName, Mode mode){
+        if(mode.equals(Mode.IN)){
+            return inParts.get(partName);
+        }else if(mode.equals(Mode.OUT)){
+            return outParts.get(partName);
+        }
+        return null;
+    }
+
+    public void addPart(Part part, Mode mode){
+        if(mode.equals(Mode.IN))
+            inParts.put(part.getName(), part);
+        else if(mode.equals(Mode.OUT))
+            outParts.put(part.getName(), part);
+    }
+
+    public Map<String, ParameterBinding> getInputParts() {
+        return inputParts;
+    }
+
+    public Map<String, ParameterBinding> getOutputParts() {
+        return outputParts;
+    }
+
+    public Map<String, String> getInputMimeTypes() {
+        return inputMimeTypes;
+    }
+
+    public Map<String, String> getOutputMimeTypes() {
+        return outputMimeTypes;
+    }
+
+    public ParameterBinding getInputBinding(String part){
+        if(emptyInputBody == null){
+            if(inputParts.get(" ") != null)
+                emptyInputBody = true;
+            else
+                emptyInputBody = false;
+        }
+        ParameterBinding block = inputParts.get(part);
+        if(block == null){
+            if(explicitInputSOAPBodyParts || emptyInputBody)
+                return ParameterBinding.UNBOUND;
+            return ParameterBinding.BODY;
+        }
+
+        return block;
+    }
+
+    public ParameterBinding getOutputBinding(String part){
+        if(emptyOutputBody == null){
+            if(outputParts.get(" ") != null)
+                emptyOutputBody = true;
+            else
+                emptyOutputBody = false;
+        }
+        ParameterBinding block = outputParts.get(part);
+        if(block == null){
+            if(explicitOutputSOAPBodyParts || emptyOutputBody)
+                return ParameterBinding.UNBOUND;
+            return ParameterBinding.BODY;
+        }
+
+        return block;
+    }
+
+    public String getMimeTypeForInputPart(String part){
+        return inputMimeTypes.get(part);
+    }
+
+    public String getMimeTypeForOutputPart(String part){
+        return outputMimeTypes.get(part);
+    }
+
+    public void setInputExplicitBodyParts(boolean b) {
+        explicitInputSOAPBodyParts = b;
+    }
+
+    public void setOutputExplicitBodyParts(boolean b) {
+        explicitOutputSOAPBodyParts = b;
+    }
+
+    String reqNamespace;
+    String respNamespace;
+
+    /**
+     * For rpclit gives namespace value on soapbinding:body@namespace
+     *
+     * @return   non-null for rpclit and null for doclit
+     * @see com.sun.xml.internal.ws.modeler.RuntimeModeler#processRpcMethod(com.sun.xml.internal.ws.model.JavaMethod, String, javax.jws.WebMethod, String, java.lang.reflect.Method, javax.jws.WebService)
+     */
+    public String getRequestNamespace(){
+        return reqNamespace;
+    }
+
+    /**
+     * For rpclit gives namespace value on soapbinding:body@namespace
+     *
+     * @return   non-null for rpclit and null for doclit
+     *      * @see com.sun.xml.internal.ws.modeler.RuntimeModeler#processRpcMethod(com.sun.xml.internal.ws.model.JavaMethod, String, javax.jws.WebMethod, String, java.lang.reflect.Method, javax.jws.WebService)
+     */
+    public String getResponseNamespace(){
+        return respNamespace;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/MIMEConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/MIMEConstants.java
new file mode 100644
index 0000000..12e1220
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/MIMEConstants.java
@@ -0,0 +1,40 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import javax.xml.namespace.QName;
+
+
+public interface MIMEConstants {
+    // namespace URIs
+    public static String NS_WSDL_MIME = "http://schemas.xmlsoap.org/wsdl/mime/";
+
+    // QNames
+    public static QName QNAME_CONTENT = new QName(NS_WSDL_MIME, "content");
+    public static QName QNAME_MULTIPART_RELATED =
+        new QName(NS_WSDL_MIME, "multipartRelated");
+    public static QName QNAME_PART = new QName(NS_WSDL_MIME, "part");
+    public static QName QNAME_MIME_XML = new QName(NS_WSDL_MIME, "mimeXml");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Message.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Message.java
new file mode 100644
index 0000000..cd1fb34
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Message.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import javax.xml.namespace.QName;
+import java.util.HashMap;
+import java.util.TreeMap;
+import java.util.LinkedHashSet;
+
+public class Message extends LinkedHashSet<String>{
+    private QName name;
+
+    /**
+     * @param name wsdl:message name attribute qualified name
+     */
+    public Message(QName name) {
+        this.name = name;
+    }
+
+    public QName getName() {
+        return name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/ParserUtil.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/ParserUtil.java
new file mode 100644
index 0000000..cb5d142
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/ParserUtil.java
@@ -0,0 +1,120 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+
+import com.sun.xml.internal.ws.streaming.Attributes;
+import com.sun.xml.internal.ws.streaming.XMLReader;
+import com.sun.xml.internal.ws.streaming.XMLReaderException;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+
+
+import java.io.File;
+import java.net.MalformedURLException;
+import java.net.URL;
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamReader;
+
+
+/**
+ * @author WS Development Team
+ */
+public class ParserUtil {
+    public static String getAttribute(XMLStreamReader reader, String name) {
+        return reader.getAttributeValue(null, name);
+    }
+
+    public static void verifyTag(XMLReader reader, QName name) {
+        if (!name.equals(reader.getName())) {
+            throw new XMLReaderException("xmlreader.unexpectedState.tag",
+                new Object[] { name, reader.getName() });
+        }
+    }
+
+    public static QName getQName(XMLStreamReader reader, String tag){
+        String localName = XmlUtil.getLocalPart(tag);
+        String pfix = XmlUtil.getPrefix(tag);
+        String uri = reader.getNamespaceURI(pfix);
+        return new QName(uri, localName);
+    }
+
+    public static String getMandatoryNonEmptyAttribute(XMLStreamReader reader,
+        String name) {
+//        String value = getAttribute(reader, name);
+        String value = reader.getAttributeValue(null, name);
+
+        if (value == null) {
+            failWithLocalName("client.missing.attribute", reader, name);
+        } else if (value.equals("")) {
+            failWithLocalName("client.invalidAttributeValue", reader, name);
+        }
+
+        return value;
+    }
+
+    public static void fail(String key, XMLReader reader) {
+        //throw new WebServicesClientException(key,
+        //        Integer.toString(reader.getLineNumber()));
+    }
+
+    public static void failWithFullName(String key, XMLReader reader) {
+        //throw new WebServicesClientException(key,
+        //new Object[]{
+        //  Integer.toString(reader.getLineNumber()),
+        //  reader.getName().toString()});
+    }
+
+    public static void failWithFullName(String key, XMLStreamReader reader) {
+//        throw new WebServicesClientException(key,
+//        new Object[]{
+//          Integer.toString(reader.getLineNumber()),
+//          reader.getName().toString()});
+    }
+
+    public static void failWithLocalName(String key, XMLStreamReader reader) {
+        //throw new WebServicesClientException(key,
+        //        new Object[]{
+        //           Integer.toString(reader.getLineNumber()),
+        //          reader.getLocalName()});
+    }
+
+    public static void failWithLocalName(String key, XMLReader reader,
+        String arg) {
+        //throw new WebServicesClientException(key,
+        //      new Object[]{
+        //          Integer.toString(reader.getLineNumber()),
+        //          reader.getLocalName(),
+        //          arg});
+    }
+
+    public static void failWithLocalName(String key, XMLStreamReader reader,
+        String arg) {
+        //throw new WebServicesClientException(key,
+        //      new Object[]{
+        //          Integer.toString(reader.getLineNumber()),
+        //          reader.getLocalName(),
+        //          arg});
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Part.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Part.java
new file mode 100644
index 0000000..7bca3d3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Part.java
@@ -0,0 +1,51 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import com.sun.xml.internal.ws.model.ParameterBinding;
+
+public class Part {
+    private String name;
+    private ParameterBinding binding;
+    private int index;
+
+    public Part(String name, ParameterBinding binding, int index) {
+        this.name = name;
+        this.binding = binding;
+        this.index = index;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public ParameterBinding getBinding() {
+        return binding;
+    }
+
+    public int getIndex() {
+        return index;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Port.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Port.java
new file mode 100644
index 0000000..e03a5de
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Port.java
@@ -0,0 +1,62 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import javax.xml.namespace.QName;
+
+public class Port {
+    private QName name;
+    private String address;
+    private QName bindingName;
+    private Binding binding;
+
+    public Port(QName name, QName binding, String address) {
+        this.name = name;
+        this.bindingName = binding;
+        this.address = address;
+    }
+
+    public QName getName() {
+        return name;
+    }
+
+    public QName getBindingName() {
+        return bindingName;
+    }
+
+    public String getAddress() {
+        return address;
+    }
+
+    public Binding getBinding() {
+        return binding;
+    }
+
+    public void setBinding(Binding binding) {
+        this.binding = binding;
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/PortType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/PortType.java
new file mode 100644
index 0000000..5f74557
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/PortType.java
@@ -0,0 +1,41 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import javax.xml.namespace.QName;
+import java.util.HashMap;
+
+public class PortType extends HashMap<String, PortTypeOperation>{
+    private QName name;
+
+    public PortType(QName name) {
+        super();
+        this.name = name;
+    }
+
+    public QName getName() {
+        return name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/PortTypeOperation.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/PortTypeOperation.java
new file mode 100644
index 0000000..689dd4b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/PortTypeOperation.java
@@ -0,0 +1,76 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import javax.xml.namespace.QName;
+
+public class PortTypeOperation{
+    private QName name;
+    private String parameterOrder;
+    private QName inputMessage;
+    private QName outputMessage;
+    private QName faultMessage;
+
+    public PortTypeOperation(QName name) {
+        this.name = name;
+    }
+
+    public QName getName() {
+        return name;
+    }
+
+    public String getParameterOrder() {
+        return parameterOrder;
+    }
+
+    public void setParameterOrder(String parameterOrder) {
+        this.parameterOrder = parameterOrder;
+    }
+
+    public QName getInputMessage() {
+        return inputMessage;
+    }
+
+    public void setInputMessage(QName inputMessage) {
+        this.inputMessage = inputMessage;
+    }
+
+    public QName getOutputMessage() {
+        return outputMessage;
+    }
+
+    public void setOutputMessage(QName outputMessage) {
+        this.outputMessage = outputMessage;
+    }
+
+    public QName getFaultMessage() {
+        return faultMessage;
+    }
+
+    public void setFaultMessage(QName faultMessage) {
+        this.faultMessage = faultMessage;
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/RuntimeWSDLParser.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/RuntimeWSDLParser.java
new file mode 100644
index 0000000..7589016
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/RuntimeWSDLParser.java
@@ -0,0 +1,561 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.wsdl.parser;
+import com.sun.xml.internal.ws.model.ParameterBinding;
+import com.sun.xml.internal.ws.server.DocInfo;
+import com.sun.xml.internal.ws.server.DocInfo.DOC_TYPE;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderFactory;
+import com.sun.xml.internal.ws.streaming.XMLStreamReaderUtil;
+import com.sun.xml.internal.ws.streaming.TidyXMLStreamReader;
+import com.sun.xml.internal.ws.util.xml.XmlUtil;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.ws.soap.SOAPBinding;
+import javax.xml.ws.WebServiceException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.Reader;
+import java.net.URL;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.HashSet;
+
+public class RuntimeWSDLParser {
+    private final WSDLDocument wsdlDoc = new WSDLDocument();
+    /**
+     * Target namespace URI of the WSDL that we are currently parsing.
+     */
+    private String targetNamespace;
+    /**
+     * System IDs of WSDLs that are already read.
+     */
+    private final Set<String> importedWSDLs = new HashSet<String>();
+    /**
+     * Must not be null.
+     */
+    private final EntityResolver resolver;
+
+    public static WSDLDocument parse(URL wsdlLoc, EntityResolver resolver) throws IOException, XMLStreamException, SAXException {
+        assert resolver!=null;
+        RuntimeWSDLParser parser = new RuntimeWSDLParser(resolver);
+        parser.parseWSDL(wsdlLoc);
+        return parser.wsdlDoc;
+    }
+
+    /*
+     * Fills DocInfo with Document type(WSDL, or schema),
+     * Service Name, Port Type name, targetNamespace for the document.
+     *
+     * Don't follow imports
+     */
+    public static void fillDocInfo(DocInfo docInfo, QName serviceName,
+        QName portTypeName) throws XMLStreamException {
+
+        RuntimeWSDLParser parser = new RuntimeWSDLParser(null);
+        InputSource source = new InputSource(docInfo.getDoc());
+
+        XMLStreamReader reader = createReader(source);
+        try {
+            XMLStreamReaderUtil.nextElementContent(reader);
+
+            if(reader.getName().equals(WSDLConstants.QNAME_SCHEMA)){
+                docInfo.setDocType(DOC_TYPE.SCHEMA);
+                String tns = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_TNS);
+                docInfo.setTargetNamespace(tns);
+                return;
+            }else if (reader.getName().equals(WSDLConstants.QNAME_DEFINITIONS)) {
+                docInfo.setDocType(DOC_TYPE.WSDL);
+                String tns = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_TNS);
+                parser.targetNamespace = tns;
+                docInfo.setTargetNamespace(tns);
+            }else{
+                docInfo.setDocType(DOC_TYPE.OTHER);
+                return;
+            }
+
+            while (XMLStreamReaderUtil.nextElementContent(reader) !=
+                    XMLStreamConstants.END_ELEMENT) {
+                 if(reader.getEventType() == XMLStreamConstants.END_DOCUMENT)
+                    break;
+
+                QName name = reader.getName();
+                if (WSDLConstants.QNAME_PORT_TYPE.equals(name)) {
+                    String pn = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_NAME);
+                    if (portTypeName != null) {
+                        if(portTypeName.getLocalPart().equals(pn) && portTypeName.getNamespaceURI().equals(docInfo.getTargetNamespace())) {
+                            docInfo.setHavingPortType(true);
+                        }
+                    }
+                    XMLStreamReaderUtil.skipElement(reader);
+                } else if (WSDLConstants.QNAME_SERVICE.equals(name)) {
+                    String sn = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_NAME);
+                    QName sqn = new QName(docInfo.getTargetNamespace(), sn);
+                    if(serviceName.equals(sqn)) {
+                        parser.parseService(reader);
+                        docInfo.setService(parser.wsdlDoc.getService(sqn));
+                        if(reader.getEventType() != XMLStreamConstants.END_ELEMENT)
+                            XMLStreamReaderUtil.next(reader);
+                    } else {
+                        XMLStreamReaderUtil.skipElement(reader);
+                    }
+                } else{
+                    XMLStreamReaderUtil.skipElement(reader);
+                }
+            }
+        } finally {
+            reader.close();
+        }
+    }
+
+    private RuntimeWSDLParser(EntityResolver resolver) {
+        this.resolver = resolver;
+    }
+
+    /**
+     * Make sure to return a "fresh" reader each time it is called because
+     * more than one active reader may be needed within a single thread
+     * to parse a WSDL file.
+     */
+    private static XMLStreamReader createReader(InputSource source) {
+        // Char stream available?
+        if (source.getCharacterStream() != null) {
+            Reader reader = source.getCharacterStream();
+            return new TidyXMLStreamReader(XMLStreamReaderFactory.createFreshXMLStreamReader(source.getSystemId(), reader), reader);
+        }
+
+        // Byte stream available?
+        if (source.getByteStream() != null) {
+            InputStream stream = source.getByteStream();
+            return new TidyXMLStreamReader(XMLStreamReaderFactory.createFreshXMLStreamReader(source.getSystemId(), stream), stream);
+        }
+
+        // Otherwise, open URI
+        try {
+            InputStream stream = new URL(source.getSystemId()).openStream();
+            return new TidyXMLStreamReader(XMLStreamReaderFactory.createFreshXMLStreamReader(source.getSystemId(), stream), stream);
+        } catch (IOException e) {
+            throw new WebServiceException(e);
+        }
+    }
+
+    private void parseWSDL(URL wsdlLoc) throws XMLStreamException, IOException, SAXException {
+
+//        String systemId = wsdlLoc.toExternalForm();
+//        InputSource source = resolver.resolveEntity(null,systemId);
+//        if(source==null)
+//            source = new InputSource(systemId);
+
+        InputSource source = resolver.resolveEntity(null,wsdlLoc.toExternalForm());
+        if(source==null)
+            source = new InputSource(wsdlLoc.toExternalForm());  // default resolution
+        else
+            if(source.getSystemId()==null)
+                // ideally entity resolvers should be giving us the system ID for the resource
+                // (or otherwise we won't be able to resolve references within this imported WSDL correctly),
+                // but if none is given, the system ID before the entity resolution is better than nothing.
+                source.setSystemId(wsdlLoc.toExternalForm());
+
+        // avoid processing the same WSDL twice.
+        if(!importedWSDLs.add(source.getSystemId()))
+            return;
+
+
+        XMLStreamReader reader = createReader(source);
+        XMLStreamReaderUtil.nextElementContent(reader);
+
+        //wsdl:definition
+        if (!reader.getName().equals(WSDLConstants.QNAME_DEFINITIONS)) {
+            ParserUtil.failWithFullName("runtime.parser.wsdl.invalidElement", reader);
+        }
+
+        //get the targetNamespace of the service
+        String tns = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_TNS);
+
+        final String oldTargetNamespace = targetNamespace;
+        targetNamespace = tns;
+
+        while (XMLStreamReaderUtil.nextElementContent(reader) !=
+                XMLStreamConstants.END_ELEMENT) {
+             if(reader.getEventType() == XMLStreamConstants.END_DOCUMENT)
+                break;
+
+            QName name = reader.getName();
+            if (WSDLConstants.QNAME_IMPORT.equals(name)) {
+                parseImport(wsdlLoc, reader);
+            } else if(WSDLConstants.QNAME_MESSAGE.equals(name)){
+                parseMessage(reader);
+            } else if(WSDLConstants.QNAME_PORT_TYPE.equals(name)){
+                parsePortType(reader);
+            } else if (WSDLConstants.QNAME_BINDING.equals(name)) {
+                parseBinding(reader);
+            } else if (WSDLConstants.QNAME_SERVICE.equals(name)) {
+                parseService(reader);
+            } else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+        targetNamespace = oldTargetNamespace;
+        reader.close();
+    }
+
+    private void parseService(XMLStreamReader reader) {
+        String serviceName = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_NAME);
+        Service service = new Service(new QName(targetNamespace, serviceName));
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if(WSDLConstants.QNAME_PORT.equals(name)){
+                parsePort(reader, service);
+                if(reader.getEventType() != XMLStreamConstants.END_ELEMENT)
+                    XMLStreamReaderUtil.next(reader);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+        wsdlDoc.addService(service);
+    }
+
+    private static void parsePort(XMLStreamReader reader, Service service) {
+        String portName = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_NAME);
+        String binding = ParserUtil.getMandatoryNonEmptyAttribute(reader, "binding");
+        QName bindingName = ParserUtil.getQName(reader, binding);
+        String location = null;
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if(SOAPConstants.QNAME_ADDRESS.equals(name)||SOAPConstants.QNAME_SOAP12ADDRESS.equals(name)){
+                location = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_LOCATION);
+                XMLStreamReaderUtil.next(reader);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+        QName portQName = new QName(service.getName().getNamespaceURI(), portName);
+        service.put(portQName, new Port(portQName, bindingName, location));
+    }
+
+    private void parseBinding(XMLStreamReader reader) {
+        String bindingName = ParserUtil.getMandatoryNonEmptyAttribute(reader, "name");
+        String portTypeName = ParserUtil.getMandatoryNonEmptyAttribute(reader, "type");
+        if((bindingName == null) || (portTypeName == null)){
+            //TODO: throw exception?
+            //skip wsdl:binding element for now
+            XMLStreamReaderUtil.skipElement(reader);
+            return;
+        }
+        Binding binding = new Binding(new QName(targetNamespace, bindingName),
+                ParserUtil.getQName(reader, portTypeName));
+        binding.setWsdlDocument(wsdlDoc);
+        wsdlDoc.addBinding(binding);
+
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if (WSDLConstants.NS_SOAP_BINDING.equals(name)) {
+                binding.setBindingId(SOAPBinding.SOAP11HTTP_BINDING);
+                XMLStreamReaderUtil.next(reader);
+            } else if (WSDLConstants.NS_SOAP12_BINDING.equals(name)) {
+                binding.setBindingId(SOAPBinding.SOAP12HTTP_BINDING);
+                XMLStreamReaderUtil.next(reader);
+            } else if (WSDLConstants.QNAME_OPERATION.equals(name)) {
+                parseBindingOperation(reader, binding);
+            }else{
+               XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+    }
+
+    private static void parseBindingOperation(XMLStreamReader reader, Binding binding) {
+        String bindingOpName = ParserUtil.getMandatoryNonEmptyAttribute(reader, "name");
+        if(bindingOpName == null){
+            //TODO: throw exception?
+            //skip wsdl:binding element for now
+            XMLStreamReaderUtil.skipElement(reader);
+            return;
+        }
+
+        BindingOperation bindingOp = new BindingOperation(bindingOpName);
+        binding.put(bindingOpName, bindingOp);
+
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if (WSDLConstants.QNAME_INPUT.equals(name)) {
+                parseInputBinding(reader, bindingOp);
+            }else if(WSDLConstants.QNAME_OUTPUT.equals(name)){
+                parseOutputBinding(reader, bindingOp);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+    }
+
+    private static void parseInputBinding(XMLStreamReader reader, BindingOperation bindingOp) {
+        boolean bodyFound = false;
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if((SOAPConstants.QNAME_BODY.equals(name) || SOAPConstants.QNAME_SOAP12BODY.equals(name)) && !bodyFound){
+                bodyFound = true;
+                bindingOp.setInputExplicitBodyParts(parseSOAPBodyBinding(reader, bindingOp, BindingMode.INPUT));
+                goToEnd(reader);
+            }else if((SOAPConstants.QNAME_HEADER.equals(name) || SOAPConstants.QNAME_SOAP12HEADER.equals(name))){
+                parseSOAPHeaderBinding(reader, bindingOp.getInputParts());
+            }else if(MIMEConstants.QNAME_MULTIPART_RELATED.equals(name)){
+                parseMimeMultipartBinding(reader, bindingOp, BindingMode.INPUT);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+
+        }
+    }
+
+    private static void parseOutputBinding(XMLStreamReader reader, BindingOperation bindingOp) {
+        boolean bodyFound = false;
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if((SOAPConstants.QNAME_BODY.equals(name) || SOAPConstants.QNAME_SOAP12BODY.equals(name)) && !bodyFound){
+                bodyFound = true;
+                bindingOp.setOutputExplicitBodyParts(parseSOAPBodyBinding(reader, bindingOp, BindingMode.OUTPUT));
+                goToEnd(reader);
+            }else if((SOAPConstants.QNAME_HEADER.equals(name) || SOAPConstants.QNAME_SOAP12HEADER.equals(name))){
+                parseSOAPHeaderBinding(reader, bindingOp.getOutputParts());
+            }else if(MIMEConstants.QNAME_MULTIPART_RELATED.equals(name)){
+                parseMimeMultipartBinding(reader, bindingOp, BindingMode.OUTPUT);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+
+        }
+    }
+
+    private static boolean parseSOAPBodyBinding(XMLStreamReader reader, BindingOperation op, BindingMode mode){
+        String namespace = reader.getAttributeValue(null, "namespace");
+        if(mode == BindingMode.INPUT){
+            op.reqNamespace = namespace;
+            return parseSOAPBodyBinding(reader, op.getInputParts());
+        }
+        //resp
+        op.respNamespace = namespace;
+        return parseSOAPBodyBinding(reader, op.getOutputParts());
+    }
+
+    /**
+     * Returns true if body has explicit parts declaration
+     */
+    private static boolean parseSOAPBodyBinding(XMLStreamReader reader, Map<String, ParameterBinding> parts){
+        String partsString = reader.getAttributeValue(null, "parts");
+        if(partsString != null){
+            List<String> partsList = XmlUtil.parseTokenList(partsString);
+            if(partsList.isEmpty()){
+                parts.put(" ", ParameterBinding.BODY);
+            }else{
+                for(String part:partsList){
+                    parts.put(part, ParameterBinding.BODY);
+                }
+            }
+            return true;
+        }
+        return false;
+    }
+
+    private static void parseSOAPHeaderBinding(XMLStreamReader reader, Map<String,ParameterBinding> parts){
+        String part = reader.getAttributeValue(null, "part");
+        //if(part == null| part.equals("")||message == null || message.equals("")){
+        if(part == null| part.equals("")){
+            return;
+        }
+
+        //lets not worry about message attribute for now, probably additional headers wont be there
+        //String message = reader.getAttributeValue(null, "message");
+        //QName msgName = ParserUtil.getQName(reader, message);
+        parts.put(part, ParameterBinding.HEADER);
+        goToEnd(reader);
+    }
+
+
+    private enum BindingMode {INPUT, OUTPUT};
+
+    private static void parseMimeMultipartBinding(XMLStreamReader reader, BindingOperation op, BindingMode mode){
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if(MIMEConstants.QNAME_PART.equals(name)){
+                parseMIMEPart(reader, op, mode);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+
+    }
+
+    private static void parseMIMEPart(XMLStreamReader reader, BindingOperation op, BindingMode mode) {
+        boolean bodyFound = false;
+        Map<String,ParameterBinding> parts = null;
+        Map<String,String> mimeTypes = null;
+        if(mode == BindingMode.INPUT){
+            parts = op.getInputParts();
+            mimeTypes = op.getInputMimeTypes();
+        }else{
+            parts = op.getOutputParts();
+            mimeTypes = op.getOutputMimeTypes();
+        }
+
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if(SOAPConstants.QNAME_BODY.equals(name) && !bodyFound){
+                bodyFound = true;
+                parseSOAPBodyBinding(reader, op, mode);
+                XMLStreamReaderUtil.next(reader);
+            }else if(SOAPConstants.QNAME_HEADER.equals(name)){
+                bodyFound = true;
+                parseSOAPHeaderBinding(reader, parts);
+                XMLStreamReaderUtil.next(reader);
+            }else if(MIMEConstants.QNAME_CONTENT.equals(name)){
+                String part = reader.getAttributeValue(null, "part");
+                String type = reader.getAttributeValue(null, "type");
+                if((part == null) || (type == null)){
+                    XMLStreamReaderUtil.skipElement(reader);
+                    continue;
+                }
+                ParameterBinding sb = ParameterBinding.createAttachment(type);
+                parts.put(part, sb);
+                //mimeTypes.put(part, type);
+                XMLStreamReaderUtil.next(reader);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+    }
+
+    protected void parseImport(URL baseURL, XMLStreamReader reader) throws IOException, SAXException, XMLStreamException {
+        // expand to the absolute URL of the imported WSDL.
+        String importLocation =
+                ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_LOCATION);
+        URL importURL = new URL(baseURL,importLocation);
+        parseWSDL(importURL);
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT){
+            XMLStreamReaderUtil.skipElement(reader);
+        }
+    }
+
+    private void parsePortType(XMLStreamReader reader) {
+        String portTypeName = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_NAME);
+        if(portTypeName == null){
+            //TODO: throw exception?
+            //skip wsdl:portType element for now
+            XMLStreamReaderUtil.skipElement(reader);
+            return;
+        }
+        PortType portType = new PortType(new QName(targetNamespace, portTypeName));
+        wsdlDoc.addPortType(portType);
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if(WSDLConstants.QNAME_OPERATION.equals(name)){
+                parsePortTypeOperation(reader, portType);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+    }
+
+    private void parsePortTypeOperation(XMLStreamReader reader, PortType portType) {
+        String operationName = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_NAME);
+        if(operationName == null){
+            //TODO: throw exception?
+            //skip wsdl:portType element for now
+            XMLStreamReaderUtil.skipElement(reader);
+            return;
+        }
+
+        QName operationQName = new QName(portType.getName().getNamespaceURI(), operationName);
+        PortTypeOperation operation = new PortTypeOperation(operationQName);
+        String parameterOrder = ParserUtil.getAttribute(reader, "parameterOrder");
+        operation.setParameterOrder(parameterOrder);
+        portType.put(operationName, operation);
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if(name.equals(WSDLConstants.QNAME_INPUT)){
+                parsePortTypeOperationInput(reader, operation);
+            }else if(name.equals(WSDLConstants.QNAME_OUTPUT)){
+                parsePortTypeOperationOutput(reader, operation);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+    }
+
+    private void parsePortTypeOperationInput(XMLStreamReader reader, PortTypeOperation operation) {
+        String msg = ParserUtil.getAttribute(reader, "message");
+        QName msgName = ParserUtil.getQName(reader, msg);
+        operation.setInputMessage(msgName);
+        goToEnd(reader);
+    }
+
+    private void parsePortTypeOperationOutput(XMLStreamReader reader, PortTypeOperation operation) {
+        String msg = ParserUtil.getAttribute(reader, "message");
+        QName msgName = ParserUtil.getQName(reader, msg);
+        operation.setOutputMessage(msgName);
+        goToEnd(reader);
+    }
+
+    private void parseMessage(XMLStreamReader reader) {
+        String msgName = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_NAME);
+        Message msg = new Message(new QName(targetNamespace, msgName));
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT) {
+            QName name = reader.getName();
+            if (WSDLConstants.QNAME_PART.equals(name)) {
+                String part = ParserUtil.getMandatoryNonEmptyAttribute(reader, WSDLConstants.ATTR_NAME);
+//                String desc = null;
+//                int index = reader.getAttributeCount();
+//                for (int i = 0; i < index; i++) {
+//                    if (reader.getAttributeName(i).equals("element") || reader.getAttributeName(i).equals("type")) {
+//                        desc = reader.getAttributeValue(i);
+//                        break;
+//                    }
+//                }
+//                if (desc == null)
+//                    continue;
+                msg.add(part);
+                if(reader.getEventType() != XMLStreamConstants.END_ELEMENT)
+                    goToEnd(reader);
+            }else{
+                XMLStreamReaderUtil.skipElement(reader);
+            }
+        }
+        wsdlDoc.addMessage(msg);
+        if(reader.getEventType() != XMLStreamConstants.END_ELEMENT)
+            goToEnd(reader);
+    }
+
+    private static void goToEnd(XMLStreamReader reader){
+        while (XMLStreamReaderUtil.nextElementContent(reader) != XMLStreamConstants.END_ELEMENT){
+            XMLStreamReaderUtil.skipElement(reader);
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/SOAPConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/SOAPConstants.java
new file mode 100644
index 0000000..991ebef
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/SOAPConstants.java
@@ -0,0 +1,70 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+
+import javax.xml.namespace.QName;
+
+public interface SOAPConstants {
+
+    // namespace URIs
+    public static final String URI_ENVELOPE = SOAPNamespaceConstants.ENVELOPE;
+    public static final String URI_ENVELOPE12 = SOAP12NamespaceConstants.ENVELOPE;
+
+    public static final String NS_WSDL_SOAP =
+        "http://schemas.xmlsoap.org/wsdl/soap/";
+
+    public static final String NS_WSDL_SOAP12 =
+        "http://schemas.xmlsoap.org/wsdl/soap12/";
+
+    public static final String NS_SOAP_ENCODING = "http://schemas.xmlsoap.org/soap/encoding/";
+
+    // other URIs
+    public final String URI_SOAP_TRANSPORT_HTTP =
+        "http://schemas.xmlsoap.org/soap/http";
+
+    // QNames
+    public static final QName QNAME_ADDRESS =
+        new QName(NS_WSDL_SOAP, "address");
+    public static final QName QNAME_SOAP12ADDRESS =
+        new QName(NS_WSDL_SOAP12, "address");
+    public static final QName QNAME_BINDING =
+        new QName(NS_WSDL_SOAP, "binding");
+    public static final QName QNAME_BODY = new QName(NS_WSDL_SOAP, "body");
+    public static final QName QNAME_SOAP12BODY = new QName(NS_WSDL_SOAP12, "body");
+    public static final QName QNAME_FAULT = new QName(NS_WSDL_SOAP, "fault");
+    public static final QName QNAME_HEADER = new QName(NS_WSDL_SOAP, "header");
+    public static final QName QNAME_SOAP12HEADER = new QName(NS_WSDL_SOAP12, "header");
+    public static final QName QNAME_HEADERFAULT =
+        new QName(NS_WSDL_SOAP, "headerfault");
+    public static final QName QNAME_OPERATION =
+        new QName(NS_WSDL_SOAP, "operation");
+    public static final QName QNAME_MUSTUNDERSTAND =
+        new QName(URI_ENVELOPE, "mustUnderstand");
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Service.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Service.java
new file mode 100644
index 0000000..ba557be
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/Service.java
@@ -0,0 +1,43 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import javax.xml.namespace.QName;
+import java.util.HashMap;
+import java.util.LinkedHashMap;
+import java.util.List;
+
+public class Service extends LinkedHashMap<QName, Port> {
+    private QName name;
+
+    public Service(QName name) {
+        super();
+        this.name = name;
+    }
+
+    public QName getName() {
+        return name;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/WSDLConstants.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/WSDLConstants.java
new file mode 100644
index 0000000..115f6f3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/WSDLConstants.java
@@ -0,0 +1,81 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import javax.xml.namespace.QName;
+
+
+/**
+ * Interface defining WSDL-related constants.
+ *
+ * @author WS Development Team
+ */
+public interface WSDLConstants {
+    // namespace URIs
+    public static final String NS_XMLNS = "http://www.w3.org/2001/XMLSchema";
+    public static final String NS_WSDL = "http://schemas.xmlsoap.org/wsdl/";
+    public static final String NS_SOAP11_HTTP_BINDING = "http://schemas.xmlsoap.org/soap/http";
+
+    public static final QName QNAME_SCHEMA = new QName(NS_XMLNS, "schema");
+
+    // QNames
+    public static final QName QNAME_BINDING = new QName(NS_WSDL, "binding");
+    public static final QName QNAME_DEFINITIONS = new QName(NS_WSDL, "definitions");
+    public static final QName QNAME_DOCUMENTATION = new QName(NS_WSDL, "documentation");
+    public static final QName NS_SOAP_BINDING_ADDRESS = new QName("http://schemas.xmlsoap.org/wsdl/soap/",
+            "address");
+    public static final QName NS_SOAP_BINDING = new QName("http://schemas.xmlsoap.org/wsdl/soap/",
+            "binding");
+    public static final QName NS_SOAP12_BINDING = new QName("http://schemas.xmlsoap.org/wsdl/soap12/",
+            "binding");
+    public static final QName NS_SOAP12_BINDING_ADDRESS = new QName("http://schemas.xmlsoap.org/wsdl/soap12/",
+            "address");
+
+    //public static final QName QNAME_FAULT = new QName(NS_WSDL, "fault");
+    public static final QName QNAME_IMPORT = new QName(NS_WSDL, "import");
+
+    //public static final QName QNAME_INPUT = new QName(NS_WSDL, "input");
+    public static final QName QNAME_MESSAGE = new QName(NS_WSDL, "message");
+    public static final QName QNAME_PART = new QName(NS_WSDL, "part");
+    public static final QName QNAME_OPERATION = new QName(NS_WSDL, "operation");
+    public static final QName QNAME_INPUT = new QName(NS_WSDL, "input");
+    public static final QName QNAME_OUTPUT = new QName(NS_WSDL, "output");
+
+    //public static final QName QNAME_OUTPUT = new QName(NS_WSDL, "output");
+    //public static final QName QNAME_PART = new QName(NS_WSDL, "part");
+    public static final QName QNAME_PORT = new QName(NS_WSDL, "port");
+    public static final QName QNAME_ADDRESS = new QName(NS_WSDL, "address");
+    public static final QName QNAME_PORT_TYPE = new QName(NS_WSDL, "portType");
+    public static final QName QNAME_FAULT = new QName(NS_WSDL, "fault");
+    public static final QName QNAME_SERVICE = new QName(NS_WSDL, "service");
+    public static final QName QNAME_TYPES = new QName(NS_WSDL, "types");
+
+    public static final String ATTR_TRANSPORT = "transport";
+    public static final String ATTR_LOCATION = "location";
+    public static final String ATTR_NAME = "name";
+    public static final String ATTR_TNS = "targetNamespace";
+
+    //public static final QName QNAME_ATTR_ARRAY_TYPE = new QName(NS_WSDL, "arrayType");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/WSDLDocument.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/WSDLDocument.java
new file mode 100644
index 0000000..612ffe7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/parser/WSDLDocument.java
@@ -0,0 +1,253 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.ws.wsdl.parser;
+
+import com.sun.xml.internal.ws.model.ParameterBinding;
+import com.sun.xml.internal.ws.model.Mode;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.soap.SOAPBinding;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.LinkedHashMap;
+import java.util.List;
+import java.util.Map;
+
+public class WSDLDocument {
+    protected Map<QName, Message> messages;
+    protected Map<QName, PortType> portTypes;
+    protected Map<QName, Binding> bindings;
+    protected Map<QName, Service> services;
+
+    public WSDLDocument() {
+        messages = new HashMap<QName, Message>();
+        portTypes = new HashMap<QName, PortType>();
+        bindings = new HashMap<QName, Binding>();
+        services = new LinkedHashMap<QName, Service>();
+    }
+
+    public void addMessage(Message msg){
+        messages.put(msg.getName(), msg);
+    }
+
+    public Message getMessage(QName name){
+        return messages.get(name);
+    }
+
+    public void addPortType(PortType pt){
+        portTypes.put(pt.getName(), pt);
+    }
+
+    public PortType getPortType(QName name){
+        return portTypes.get(name);
+    }
+
+    public void addBinding(Binding binding){
+        bindings.put(binding.getName(), binding);
+    }
+
+    public Binding getBinding(QName name){
+        return bindings.get(name);
+    }
+
+    public void addService(Service svc){
+        services.put(svc.getName(), svc);
+    }
+
+    public Service getService(QName name){
+        return services.get(name);
+    }
+
+    public Map<QName, Service> getServices(){
+        return services;
+    }
+
+    /**
+     * Returns the first service QName from insertion order
+     * @return
+     */
+    public QName getFirstServiceName(){
+        if(services.isEmpty())
+            return null;
+        return services.values().iterator().next().getName();
+    }
+
+    /**
+     * Returns first port QName from first service as per the insertion order
+     * @return
+     */
+    public QName getFirstPortName(){
+        if(services.isEmpty())
+            return null;
+        Service service = services.values().iterator().next();
+        Iterator<QName> iter = service.keySet().iterator();
+        QName port = (iter.hasNext())?iter.next():null;
+        return port;
+    }
+
+    private Port getFirstPort(){
+        if(services.isEmpty())
+            return null;
+        Service service = services.values().iterator().next();
+        Collection<Port> coll = service.values();
+        Port port = (coll != null)?((coll.iterator().hasNext())?coll.iterator().next():null):null;
+        return port;
+    }
+
+
+    /**
+     * Returns biningId of the first port
+     * @return
+     */
+    public String getBindingId(){
+        Port port = getFirstPort();
+        if(port == null)
+            return null;
+        Binding binding = bindings.get(port.getBindingName());
+        if(binding == null)
+            return null;
+        return binding.getBindingId();
+    }
+
+    /**
+     * Gives the binding Id of the given service and port
+     * @param service
+     * @param port
+     * @return
+     */
+    public String getBindingId(QName service, QName port){
+        Service s = services.get(service);
+        if(s != null){
+            Port p = s.get(port);
+            if(p != null){
+                Binding b = bindings.get(p.getBindingName());
+                if(b != null)
+                    return b.getBindingId();
+            }
+
+        }
+        return null;
+    }
+
+     /**
+     *
+     * @param serviceName non-null service QName
+     * @param portName    non-null port QName
+     * @return
+     *          BindingOperation on success otherwise null. throws NPE if any of the parameters null
+     */
+    public Binding getBinding(QName serviceName, QName portName){
+        Service service = services.get(serviceName);
+        if(service != null){
+            Port port = service.get(portName);
+            if(port != null){
+                QName bindingName = port.getBindingName();
+                return bindings.get(bindingName);
+            }
+        }
+        return null;
+    }
+
+    /**
+     * Returns the bindings for the given bindingId
+     * @param service  non-null service
+     * @param bindingId  non-null binding id
+     * @return
+     */
+    public List<Binding> getBindings(Service service, String bindingId){
+        List<Binding> bs = new ArrayList<Binding>();
+        Collection<Port> ports = service.values();
+        if(ports.isEmpty())
+            return bs;
+        for(Port port:ports){
+            Binding b = bindings.get(port.getName());
+            if(b == null)
+                return bs;
+            if(b.equals(bindingId))
+                bs.add(b);
+        }
+        return bs;
+    }
+
+    public QName getPortName(QName serviceName, QName portType){
+        Service service = services.get(serviceName);
+        for(Port port:service.values()){
+            QName bindingName = port.getBindingName();
+            assert (bindingName != null);
+            Binding binding = bindings.get(bindingName);
+            QName ptName = binding.getPortTypeName();
+            assert (ptName != null);
+            if(ptName.equals(portType))
+                return port.getName();
+        }
+        return null;
+    }
+
+    public void finalizeBinding(Binding binding){
+        assert(binding != null);
+        QName portTypeName = binding.getPortTypeName();
+        if(portTypeName == null)
+            return;
+        PortType pt = portTypes.get(portTypeName);
+        if(pt == null)
+            return;
+        for(String op:binding.keySet()){
+            PortTypeOperation pto = pt.get(op);
+            if(pto == null)
+                return;
+            QName inMsgName = pto.getInputMessage();
+            if(inMsgName == null)
+                continue;
+            Message inMsg = messages.get(inMsgName);
+            BindingOperation bo = binding.get(op);
+            int bodyindex = 0;
+            if(inMsg != null){
+                for(String name:inMsg){
+                    ParameterBinding pb = bo.getInputBinding(name);
+                    if(pb.isBody()){
+                        bo.addPart(new Part(name, pb, bodyindex++), Mode.IN);
+                    }
+                }
+            }
+            bodyindex=0;
+            QName outMsgName = pto.getOutputMessage();
+            if(outMsgName == null)
+                continue;
+            Message outMsg = messages.get(outMsgName);
+            if(outMsg!= null){
+                for(String name:outMsg){
+                    ParameterBinding pb = bo.getOutputBinding(name);
+                    if(pb.isBody()){
+                        bo.addPart(new Part(name, pb, bodyindex++), Mode.OUT);
+                    }
+                }
+            }
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/WSDLGenerator.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/WSDLGenerator.java
new file mode 100644
index 0000000..045d085
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/WSDLGenerator.java
@@ -0,0 +1,892 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer;
+
+
+import com.sun.xml.internal.ws.pept.presentation.MessageStruct;
+import com.sun.xml.internal.bind.api.JAXBRIContext;
+import static com.sun.xml.internal.bind.v2.schemagen.Util.*;
+import com.sun.xml.internal.txw2.TXW;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.output.ResultFactory;
+import com.sun.xml.internal.txw2.output.XmlSerializer;
+import com.sun.xml.internal.ws.encoding.soap.SOAPVersion;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
+import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
+import com.sun.xml.internal.ws.model.CheckedException;
+import com.sun.xml.internal.ws.model.JavaMethod;
+import com.sun.xml.internal.ws.model.Parameter;
+import com.sun.xml.internal.ws.model.ParameterBinding;
+import com.sun.xml.internal.ws.model.RuntimeModel;
+import com.sun.xml.internal.ws.model.WrapperParameter;
+import com.sun.xml.internal.ws.model.soap.SOAPBinding;
+import com.sun.xml.internal.ws.model.soap.Style;
+import com.sun.xml.internal.ws.model.soap.Use;
+import com.sun.xml.internal.ws.wsdl.parser.SOAPConstants;
+import com.sun.xml.internal.ws.wsdl.parser.WSDLConstants;
+import com.sun.xml.internal.ws.wsdl.writer.document.Binding;
+import com.sun.xml.internal.ws.wsdl.writer.document.BindingOperationType;
+import com.sun.xml.internal.ws.wsdl.writer.document.Definitions;
+import com.sun.xml.internal.ws.wsdl.writer.document.Fault;
+import com.sun.xml.internal.ws.wsdl.writer.document.FaultType;
+import com.sun.xml.internal.ws.wsdl.writer.document.Import;
+import com.sun.xml.internal.ws.wsdl.writer.document.Message;
+import com.sun.xml.internal.ws.wsdl.writer.document.Operation;
+import com.sun.xml.internal.ws.wsdl.writer.document.ParamType;
+import com.sun.xml.internal.ws.wsdl.writer.document.Port;
+import com.sun.xml.internal.ws.wsdl.writer.document.PortType;
+import com.sun.xml.internal.ws.wsdl.writer.document.Service;
+import com.sun.xml.internal.ws.wsdl.writer.document.Types;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.Body;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.Header;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPAddress;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPFault;
+
+import javax.xml.bind.SchemaOutputResolver;
+import javax.xml.namespace.QName;
+import javax.xml.transform.Result;
+import javax.xml.ws.Holder;
+import javax.xml.ws.WebServiceException;
+import java.io.IOException;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+
+/**
+ * Class used to generate WSDLs from a <code>RunTimeModel</code>
+ *
+ * @author WS Development Team
+ */
+public class WSDLGenerator {
+    private JAXWSOutputSchemaResolver resolver;
+    private WSDLOutputResolver wsdlResolver = null;
+    private RuntimeModel model;
+    private Definitions serviceDefinitions;
+    private Definitions portDefinitions;
+    private Types types;
+    public static final String DOT_WSDL         = ".wsdl";
+    public static final String RESPONSE         = "Response";
+    public static final String PARAMETERS       = "parameters";
+    public static final String RESULT           = "parameters";
+    public static final String UNWRAPPABLE_RESULT  = "result";
+    public static final String WSDL_NAMESPACE   = WSDLConstants.NS_WSDL;
+    public static final String WSDL_PREFIX      = "wsdl";
+    public static final String XSD_NAMESPACE    = SOAPNamespaceConstants.XSD;
+    public static final String XSD_PREFIX       = "xsd";
+    public static final String SOAP11_NAMESPACE = SOAPConstants.NS_WSDL_SOAP;
+    public static final String SOAP12_NAMESPACE = SOAPConstants.NS_WSDL_SOAP12;
+    public static final String SOAP_PREFIX      = "soap";
+    public static final String SOAP12_PREFIX    = "soap12";
+    public static final String TNS_PREFIX       = "tns";
+    public static final String BINDING          = "Binding";
+    public static final String SOAP_HTTP_TRANSPORT = SOAPNamespaceConstants.TRANSPORT_HTTP;
+    public static final String SOAP12_HTTP_TRANSPORT = SOAP12NamespaceConstants.TRANSPORT_HTTP;
+    public static final String DOCUMENT         = "document";
+    public static final String RPC              = "rpc";
+    public static final String LITERAL          = "literal";
+    public static final String REPLACE_WITH_ACTUAL_URL = "REPLACE_WITH_ACTUAL_URL";
+    private Set<QName> processedExceptions = new HashSet<QName>();
+    private String bindingId;
+    private String wsdlLocation;
+    private String portWSDLID;
+    private String schemaPrefix;
+
+
+    public WSDLGenerator(RuntimeModel model, WSDLOutputResolver wsdlResolver, String bindingId) {
+        this.model = model;
+        resolver = new JAXWSOutputSchemaResolver();
+        this.wsdlResolver = wsdlResolver;
+        this.bindingId = bindingId;
+    }
+
+    public void doGeneration() {
+        XmlSerializer serviceWriter;
+        XmlSerializer portWriter = null;
+        String fileName = JAXBRIContext.mangleNameToClassName(model.getServiceQName().getLocalPart());
+//        System.out.println("concrete name: "+ fileName);
+        Result result = wsdlResolver.getWSDLOutput(fileName+DOT_WSDL);
+        if (result == null)
+            return;
+        wsdlLocation = result.getSystemId();
+        serviceWriter = ResultFactory.createSerializer(result);
+        if (model.getServiceQName().getNamespaceURI().equals(model.getTargetNamespace())) {
+            portWriter = serviceWriter;
+            schemaPrefix = fileName+"_";
+        } else {
+            String wsdlName = JAXBRIContext.mangleNameToClassName(model.getPortTypeName().getLocalPart());
+            if (wsdlName.equals(fileName))
+                wsdlName += "PortType";
+//            System.out.println("abstract name: "+ wsdlName);
+            Holder<String> absWSDLName = new Holder<String>();
+            absWSDLName.value = wsdlName+DOT_WSDL;
+//            System.out.println("absWSDLName.value: "+ absWSDLName.value);
+            result = wsdlResolver.getAbstractWSDLOutput(absWSDLName);
+//            System.out.println("absWSDLName.value: "+ absWSDLName.value);
+//             schemaPrefix = model.getJAXBContext().mangleNameToClassName(portWSDLID)+"_";
+
+            if (result != null) {
+                portWSDLID = result.getSystemId();
+                if (portWSDLID.equals(wsdlLocation)) {
+                    portWriter = serviceWriter;
+                } else {
+                    portWriter = ResultFactory.createSerializer(result);
+                }
+            } else {
+                portWSDLID = absWSDLName.value;
+            }
+            schemaPrefix = new java.io.File(portWSDLID).getName();
+            int idx = schemaPrefix.lastIndexOf('.');
+            if (idx > 0)
+                schemaPrefix = schemaPrefix.substring(0, idx);
+            schemaPrefix = JAXBRIContext.mangleNameToClassName(schemaPrefix)+"_";
+//            System.out.println("portWSDLID: "+ portWSDLID);
+//            schemaPrefix = model.getJAXBContext().mangleNameToClassName(portWSDLID)+"_";
+//            System.out.println("schemaPrefix: "+ schemaPrefix);
+        }
+        generateDocument(serviceWriter, portWriter);
+    }
+
+    private void generateDocument(XmlSerializer serviceStream, XmlSerializer portStream) {
+        serviceDefinitions = TXW.create(Definitions.class, serviceStream);
+        serviceDefinitions._namespace(WSDL_NAMESPACE, "");//WSDL_PREFIX);
+        serviceDefinitions._namespace(XSD_NAMESPACE, XSD_PREFIX);
+        serviceDefinitions.targetNamespace(model.getServiceQName().getNamespaceURI());
+        serviceDefinitions._namespace(model.getServiceQName().getNamespaceURI(), TNS_PREFIX);
+        if(bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING))
+            serviceDefinitions._namespace(SOAP12_NAMESPACE, SOAP12_PREFIX);
+        else
+            serviceDefinitions._namespace(SOAP11_NAMESPACE, SOAP_PREFIX);
+        serviceDefinitions.name(model.getServiceQName().getLocalPart());
+        if (serviceStream != portStream && portStream != null) {
+            // generate an abstract and concrete wsdl
+            portDefinitions = TXW.create(Definitions.class, portStream);
+            portDefinitions._namespace(WSDL_NAMESPACE, "");//WSDL_PREFIX);
+            portDefinitions._namespace(XSD_NAMESPACE, XSD_PREFIX);
+            if (model.getTargetNamespace() != null) {
+                portDefinitions.targetNamespace(model.getTargetNamespace());
+                portDefinitions._namespace(model.getTargetNamespace(), TNS_PREFIX);
+            }
+
+            String schemaLoc = relativize(portWSDLID, wsdlLocation);
+            Import _import = serviceDefinitions._import().namespace(model.getTargetNamespace());
+            _import.location(schemaLoc);
+        } else if (portStream != null) {
+            // abstract and concrete are the same
+            portDefinitions = serviceDefinitions;
+        } else {
+            // import a provided abstract wsdl
+            String schemaLoc = relativize(portWSDLID, wsdlLocation);
+            Import _import = serviceDefinitions._import().namespace(model.getTargetNamespace());
+            _import.location(schemaLoc);
+        }
+
+        if (portDefinitions != null) {
+            generateTypes();
+            generateMessages();
+            generatePortType();
+        }
+        generateBinding();
+        generateService();
+        serviceDefinitions.commit();
+        if (portDefinitions != null && portDefinitions != serviceDefinitions)
+            portDefinitions.commit();
+    }
+
+
+
+    protected void generateTypes() {
+        types = portDefinitions.types();
+        if (model.getJAXBContext() != null) {
+            try {
+                model.getJAXBContext().generateSchema(resolver);
+            } catch (IOException e) {
+                // TODO locallize and wrap this
+                e.printStackTrace();
+                throw new WebServiceException(e.getMessage());
+            }
+        }
+    }
+
+    protected void generateMessages() {
+        for (JavaMethod method : model.getJavaMethods()) {
+            if (method.getBinding() instanceof SOAPBinding)
+                generateSOAPMessages(method, (SOAPBinding)method.getBinding());
+        }
+    }
+
+    protected void generateSOAPMessages(JavaMethod method, SOAPBinding binding) {
+        boolean isDoclit = binding.isDocLit();
+        Message message = portDefinitions.message().name(method.getOperationName());
+        com.sun.xml.internal.ws.wsdl.writer.document.Part part;
+        JAXBRIContext jaxbContext = model.getJAXBContext();
+        boolean unwrappable = true;
+        for (Parameter param : method.getRequestParameters()) {
+            if (isDoclit) {
+                if (isHeaderParameter(param))
+                    unwrappable = false;
+                if (param.isWrapperStyle()) {
+                    part = message.part().name(PARAMETERS);
+                    part.element(param.getName());
+                } else {
+                    part = message.part().name(param.getPartName());
+                    part.element(param.getName());
+                }
+            } else {
+                if (param.isWrapperStyle()) {
+                    for (Parameter childParam : ((WrapperParameter)param).getWrapperChildren()) {
+                        part = message.part().name(childParam.getPartName());
+                        part.type(jaxbContext.getTypeName(childParam.getTypeReference()));
+                    }
+                } else {
+                    part = message.part().name(param.getPartName());
+                    part.element(param.getName());
+                }
+            }
+        }
+        if (method.getMEP() != MessageStruct.ONE_WAY_MEP) {
+            message = portDefinitions.message().name(method.getOperationName()+RESPONSE);
+            if (unwrappable) {
+                for (Parameter param : method.getResponseParameters()) {
+                   if (isHeaderParameter(param))
+                       unwrappable = false;
+                }
+            }
+
+            for (Parameter param : method.getResponseParameters()) {
+                if (isDoclit) {
+                    if (param.isWrapperStyle()) {
+                        // if its not really wrapper style dont use the same name as input message
+                        if (unwrappable)
+                            part = message.part().name(RESULT);
+                        else
+                            part = message.part().name(UNWRAPPABLE_RESULT);
+                        part.element(param.getName());
+                    } else {
+                        part = message.part().name(param.getPartName());
+                        part.element(param.getName());
+                    }
+                } else {
+                    if (param.isWrapperStyle()) {
+                        for (Parameter childParam : ((WrapperParameter)param).getWrapperChildren()) {
+                            part = message.part().name(childParam.getPartName());
+                            part.type(jaxbContext.getTypeName(childParam.getTypeReference()));
+                        }
+                    } else {
+                        part = message.part().name(param.getPartName());
+                        part.element(param.getName());
+                    }
+                }
+            }
+        }
+        for (CheckedException exception : method.getCheckedExceptions()) {
+            QName tagName = exception.getDetailType().tagName;
+//            if (processedExceptions.contains(tagName))
+//                continue;
+//            message = portDefinitions.message().name(tagName.getLocalPart());
+            String messageName = exception.getMessageName();
+            QName messageQName = new QName(model.getTargetNamespace(), messageName);
+            if (processedExceptions.contains(messageQName))
+                continue;
+            message = portDefinitions.message().name(messageName);
+
+            part = message.part().name("fault");//tagName.getLocalPart());
+            part.element(tagName);
+//            processedExceptions.add(tagName);
+            processedExceptions.add(messageQName);
+        }
+    }
+
+    protected void generatePortType() {
+
+        PortType portType = portDefinitions.portType().name(model.getPortTypeName().getLocalPart());
+        for (JavaMethod method : model.getJavaMethods()) {
+            Operation operation = portType.operation().name(method.getOperationName());
+            generateParameterOrder(operation, method);
+            switch (method.getMEP()) {
+                case MessageStruct.REQUEST_RESPONSE_MEP:
+                    // input message
+                    generateInputMessage(operation, method);
+                    // output message
+                    generateOutputMessage(operation, method);
+                    break;
+                case MessageStruct.ONE_WAY_MEP:
+                    generateInputMessage(operation, method);
+                    break;
+            }
+            // faults
+            for (CheckedException exception : method.getCheckedExceptions()) {
+                QName tagName = exception.getDetailType().tagName;
+//                QName messageName = new QName(model.getTargetNamespace(), tagName.getLocalPart());
+//                FaultType paramType = operation.fault().name(tagName.getLocalPart()).message(messageName);
+                QName messageName = new QName(model.getTargetNamespace(), exception.getMessageName());
+                FaultType paramType = operation.fault().name(exception.getMessageName()).message(messageName);
+            }
+        }
+    }
+
+    protected boolean isWrapperStyle(JavaMethod method) {
+        if (method.getRequestParameters().size() > 0) {
+            Parameter param = method.getRequestParameters().iterator().next();
+            return param.isWrapperStyle();
+        }
+        return false;
+    }
+
+    protected boolean isRpcLit(JavaMethod method) {
+        if (method.getBinding() instanceof SOAPBinding) {
+            if (((SOAPBinding)method.getBinding()).getStyle().equals(Style.RPC))
+                return true;
+        }
+        return false;
+    }
+
+    protected void generateParameterOrder(Operation operation, JavaMethod method) {
+        if (method.getMEP() == MessageStruct.ONE_WAY_MEP)
+            return;
+        if (isRpcLit(method))
+            generateRpcParameterOrder(operation, method);
+        else
+            generateDocumentParameterOrder(operation, method);
+    }
+
+    protected void generateRpcParameterOrder(Operation operation, JavaMethod method) {
+        String partName;
+        StringBuffer paramOrder = new StringBuffer();
+        Set<String> partNames = new HashSet<String>();
+        List<Parameter> sortedParams = sortMethodParameters(method);
+        int i = 0;
+        for (Parameter parameter : sortedParams) {
+            if (parameter.getIndex() >= 0) {
+               partName = parameter.getPartName();
+                if (!partNames.contains(partName)) {
+                    if (i++ > 0)
+                        paramOrder.append(' ');
+                    paramOrder.append(partName);
+                    partNames.add(partName);
+                }
+            }
+        }
+        operation.parameterOrder(paramOrder.toString());
+    }
+
+
+    protected void generateDocumentParameterOrder(Operation operation, JavaMethod method) {
+        String partName;
+        StringBuffer paramOrder = new StringBuffer();
+        Set<String> partNames = new HashSet<String>();
+        List<Parameter> sortedParams = sortMethodParameters(method);
+        boolean isWrapperStyle = isWrapperStyle(method);
+        int i = 0;
+        for (Parameter parameter : sortedParams) {
+//            System.out.println("param: "+parameter.getIndex()+" name: "+parameter.getName().getLocalPart());
+            if (parameter.getIndex() < 0)
+                continue;
+            if (isWrapperStyle && isBodyParameter(parameter)) {
+//                System.out.println("isWrapper and is body");
+                if (method.getRequestParameters().contains(parameter))
+                    partName = PARAMETERS;
+                else {
+                    // really make sure this is a wrapper style wsdl we are creating
+                    partName = RESPONSE;
+                }
+            } else {
+               partName = parameter.getPartName();
+            }
+            if (!partNames.contains(partName)) {
+                if (i++ > 0)
+                    paramOrder.append(' ');
+                paramOrder.append(partName);
+                partNames.add(partName);
+            }
+        }
+        if (i>1) {
+            operation.parameterOrder(paramOrder.toString());
+        }
+    }
+
+    protected List<Parameter> sortMethodParameters(JavaMethod method) {
+        Set<Parameter> paramSet = new HashSet<Parameter>();
+        List<Parameter> sortedParams = new ArrayList<Parameter>();
+        if (isRpcLit(method)) {
+            for (Parameter param : method.getRequestParameters()) {
+                if (param instanceof WrapperParameter) {
+                    paramSet.addAll(((WrapperParameter)param).getWrapperChildren());
+                } else {
+                    paramSet.add(param);
+                }
+            }
+            for (Parameter param : method.getResponseParameters()) {
+                if (param instanceof WrapperParameter) {
+                    paramSet.addAll(((WrapperParameter)param).getWrapperChildren());
+                } else {
+                    paramSet.add(param);
+                }
+            }
+        } else  {
+            paramSet.addAll(method.getRequestParameters());
+            paramSet.addAll(method.getResponseParameters());
+        }
+        Iterator<Parameter>params = paramSet.iterator();
+        if (paramSet.size() == 0)
+            return sortedParams;
+        Parameter param = params.next();
+        sortedParams.add(param);
+        Parameter sortedParam;
+        int pos;
+        for (int i=1; i<paramSet.size();i++) {
+            param = params.next();
+            for (pos=0; pos<i; pos++) {
+                sortedParam = sortedParams.get(pos);
+                if (param.getIndex() == sortedParam.getIndex() &&
+                    param instanceof WrapperParameter)
+                    break;
+                if (param.getIndex() < sortedParam.getIndex()) {
+                    break;
+                }
+            }
+            sortedParams.add(pos, param);
+        }
+        return sortedParams;
+    }
+
+    protected boolean isBodyParameter(Parameter parameter) {
+        ParameterBinding paramBinding = parameter.getBinding();
+        return paramBinding.isBody();
+    }
+
+    protected boolean isHeaderParameter(Parameter parameter) {
+        ParameterBinding paramBinding = parameter.getBinding();
+        return paramBinding.isHeader();
+    }
+
+    protected boolean isAttachmentParameter(Parameter parameter) {
+        ParameterBinding paramBinding = parameter.getBinding();
+        return paramBinding.isAttachment();
+    }
+
+
+    protected void generateBinding() {
+        Binding binding = serviceDefinitions.binding().name(model.getPortName().getLocalPart()+BINDING);
+        binding.type(model.getPortTypeName());
+        boolean first = true;
+        for (JavaMethod method : model.getJavaMethods()) {
+            if (first) {
+                if (method.getBinding() instanceof SOAPBinding) {
+                    SOAPBinding sBinding = (SOAPBinding)method.getBinding();
+                    SOAPVersion soapVersion = sBinding.getSOAPVersion();
+
+                    if(soapVersion.equals(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING)){
+                        com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPBinding soapBinding = binding.soap12Binding();
+                        soapBinding.transport(SOAP12_HTTP_TRANSPORT);
+                        if (sBinding.getStyle().equals(Style.DOCUMENT))
+                            soapBinding.style(DOCUMENT);
+                        else
+                            soapBinding.style(RPC);
+                    }else{
+                        com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPBinding soapBinding = binding.soapBinding();
+                        soapBinding.transport(SOAP_HTTP_TRANSPORT);
+                        if (sBinding.getStyle().equals(Style.DOCUMENT))
+                            soapBinding.style(DOCUMENT);
+                        else
+                            soapBinding.style(RPC);
+                    }
+                }
+                first = false;
+            }
+            if(bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING))
+                generateSOAP12BindingOperation(method, binding);
+            else
+                generateBindingOperation(method, binding);
+        }
+    }
+
+    protected void generateBindingOperation(JavaMethod method, Binding binding) {
+        BindingOperationType operation = binding.operation().name(method.getOperationName());
+        String targetNamespace = model.getTargetNamespace();
+        QName requestMessage = new QName(targetNamespace, method.getOperationName());
+        QName responseMessage = new QName(targetNamespace, method.getOperationName()+RESPONSE);
+        if (method.getBinding() instanceof SOAPBinding) {
+            List<Parameter> bodyParams = new ArrayList<Parameter>();
+            List<Parameter> headerParams = new ArrayList<Parameter>();
+            splitParameters(bodyParams, headerParams, method.getRequestParameters());
+            SOAPBinding soapBinding = (SOAPBinding)method.getBinding();
+            operation.soapOperation().soapAction(soapBinding.getSOAPAction());
+
+            // input
+            TypedXmlWriter input = operation.input();
+            BodyType body = input._element(Body.class);
+            boolean isRpc = soapBinding.getStyle().equals(Style.RPC);
+            if (soapBinding.getUse().equals(Use.LITERAL)) {
+                body.use(LITERAL);
+                if (headerParams.size() > 0) {
+                    if (bodyParams.size() > 0) {
+                        Parameter param = bodyParams.iterator().next();
+                        if (isRpc) {
+                            StringBuffer parts = new StringBuffer();
+                            int i=0;
+                            for (Parameter parameter : ((WrapperParameter)param).getWrapperChildren()) {
+                                if (i++>0)
+                                    parts.append(' ');
+                                parts.append(parameter.getPartName());
+                            }
+                            body.parts(parts.toString());
+                        } else if (param.isWrapperStyle()) {
+                            body.parts(PARAMETERS);
+                        } else {
+                           body.parts(param.getPartName());
+                        }
+                    } else {
+                        body.parts("");
+                    }
+                    generateSOAPHeaders(input, headerParams, requestMessage);
+                }
+                if (isRpc) {
+                    body.namespace(method.getRequestParameters().iterator().next().getName().getNamespaceURI());
+                }
+            } else {
+                // TODO localize this
+                throw new WebServiceException("encoded use is not supported");
+            }
+
+            if (method.getMEP() != MessageStruct.ONE_WAY_MEP) {
+                boolean unwrappable = headerParams.size() == 0;
+                // output
+                bodyParams.clear();
+                headerParams.clear();
+                splitParameters(bodyParams, headerParams, method.getResponseParameters());
+                unwrappable = unwrappable ? headerParams.size() == 0 : unwrappable;
+                TypedXmlWriter output = operation.output();
+                body = output._element(Body.class);
+                body.use(LITERAL);
+                if (headerParams.size() > 0) {
+                    String parts = "";
+                    if (bodyParams.size() > 0) {
+                        Parameter param = bodyParams.iterator().next();
+                        if (isRpc) {
+                            int i=0;
+                            for (Parameter parameter : ((WrapperParameter)param).getWrapperChildren()) {
+                                if (i++>0)
+                                    parts += " ";
+                                parts += parameter.getPartName();
+                            }
+                        } else {
+                            if (param != null) {
+                                if (param.isWrapperStyle()) {
+                                    // if its not really wrapper style dont use the same name as input message
+                                    if (unwrappable)
+                                        parts = RESULT;
+                                    else
+                                        parts = UNWRAPPABLE_RESULT;
+                                } else {
+                                    parts = param.getPartName();
+                                }
+                            }
+                        }
+                    }
+                    body.parts(parts);
+                    generateSOAPHeaders(output, headerParams, responseMessage);
+                }
+                if (isRpc) {
+                    body.namespace(method.getRequestParameters().iterator().next().getName().getNamespaceURI());
+                }
+            }
+            for (CheckedException exception : method.getCheckedExceptions()) {
+//                QName tagName = exception.getDetailType().tagName;
+//                Fault fault = operation.fault().name(tagName.getLocalPart());
+//                SOAPFault soapFault = fault._element(SOAPFault.class).name(tagName.getLocalPart());
+                Fault fault = operation.fault().name(exception.getMessageName());
+                SOAPFault soapFault = fault._element(SOAPFault.class).name(exception.getMessageName());
+                soapFault.use(LITERAL);
+            }
+        }
+    }
+
+    protected void generateSOAP12BindingOperation(JavaMethod method, Binding binding) {
+        BindingOperationType operation = binding.operation().name(method.getOperationName());
+        String targetNamespace = model.getTargetNamespace();
+        QName requestMessage = new QName(targetNamespace, method.getOperationName());
+        QName responseMessage = new QName(targetNamespace, method.getOperationName()+RESPONSE);
+        if (method.getBinding() instanceof SOAPBinding) {
+            List<Parameter> bodyParams = new ArrayList<Parameter>();
+            List<Parameter> headerParams = new ArrayList<Parameter>();
+            splitParameters(bodyParams, headerParams, method.getRequestParameters());
+            SOAPBinding soapBinding = (SOAPBinding)method.getBinding();
+            operation.soap12Operation().soapAction(soapBinding.getSOAPAction());
+
+            // input
+            TypedXmlWriter input = operation.input();
+
+            com.sun.xml.internal.ws.wsdl.writer.document.soap12.BodyType body = input._element(com.sun.xml.internal.ws.wsdl.writer.document.soap12.Body.class);
+            boolean isRpc = soapBinding.getStyle().equals(Style.RPC);
+            if (soapBinding.getUse().equals(Use.LITERAL)) {
+                body.use(LITERAL);
+                if (headerParams.size() > 0) {
+                    if (bodyParams.size() > 0) {
+                        Parameter param = bodyParams.iterator().next();
+                        if (isRpc) {
+                            StringBuffer parts = new StringBuffer();
+                            int i=0;
+                            for (Parameter parameter : ((WrapperParameter)param).getWrapperChildren()) {
+                                if (i++>0)
+                                    parts.append(' ');
+                                parts.append(parameter.getPartName());
+                            }
+                            body.parts(parts.toString());
+                        } else if (param.isWrapperStyle()) {
+                            body.parts(PARAMETERS);
+                        } else {
+                           body.parts(param.getPartName());
+                        }
+                    } else {
+                        body.parts("");
+                    }
+                    generateSOAP12Headers(input, headerParams, requestMessage);
+                }
+                if (isRpc) {
+                    body.namespace(method.getRequestParameters().iterator().next().getName().getNamespaceURI());
+                }
+            } else {
+                // TODO localize this
+                throw new WebServiceException("encoded use is not supported");
+            }
+
+            if (method.getMEP() != MessageStruct.ONE_WAY_MEP) {
+                // output
+                boolean unwrappable = headerParams.size() == 0;
+                bodyParams.clear();
+                headerParams.clear();
+                splitParameters(bodyParams, headerParams, method.getResponseParameters());
+                unwrappable = unwrappable ? headerParams.size() == 0 : unwrappable;
+                TypedXmlWriter output = operation.output();
+                body = output._element(com.sun.xml.internal.ws.wsdl.writer.document.soap12.Body.class);
+                body.use(LITERAL);
+                if (headerParams.size() > 0) {
+                    if (bodyParams.size() > 0) {
+                        Parameter param = bodyParams.iterator().next();
+                        if (isRpc) {
+                            String parts = "";
+                            int i=0;
+                            for (Parameter parameter : ((WrapperParameter)param).getWrapperChildren()) {
+                                if (i++>0)
+                                    parts += " ";
+                                parts += parameter.getPartName();
+                            }
+                            body.parts(parts);
+                        } else if (param.isWrapperStyle()) {
+                            // if its not really wrapper style dont use the same name as input message
+                            if (unwrappable)
+                                body.parts(RESULT);
+                            else
+                                body.parts(UNWRAPPABLE_RESULT);
+                        } else {
+                            body.parts(param.getPartName());
+                        }
+                    } else {
+                        body.parts("");
+                    }
+                    generateSOAP12Headers(output, headerParams, responseMessage);
+                }
+                if (isRpc) {
+                    body.namespace(method.getRequestParameters().iterator().next().getName().getNamespaceURI());
+                }
+            }
+            for (CheckedException exception : method.getCheckedExceptions()) {
+//                QName tagName = exception.getDetailType().tagName;
+//                Fault fault = operation.fault().name(tagName.getLocalPart());
+//                com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPFault soapFault = fault._element(com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPFault.class).name(tagName.getLocalPart());
+                Fault fault = operation.fault().name(exception.getMessageName());
+                com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPFault soapFault = fault._element(com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPFault.class).name(exception.getMessageName());
+                soapFault.use(LITERAL);
+            }
+        }
+    }
+
+    protected void splitParameters(List<Parameter> bodyParams, List<Parameter>headerParams, List<Parameter>params) {
+        for (Parameter parameter : params) {
+            if (isBodyParameter(parameter)) {
+                bodyParams.add(parameter);
+            } else {
+                headerParams.add(parameter);
+            }
+        }
+    }
+
+    protected void generateSOAPHeaders(TypedXmlWriter writer, List<Parameter> parameters, QName message) {
+
+        for (Parameter headerParam : parameters) {
+            Header header = writer._element(Header.class);
+            header.message(message);
+            header.part(headerParam.getPartName());
+            header.use(LITERAL);
+        }
+    }
+
+    protected void generateSOAP12Headers(TypedXmlWriter writer, List<Parameter> parameters, QName message) {
+
+        for (Parameter headerParam : parameters) {
+            com.sun.xml.internal.ws.wsdl.writer.document.soap12.Header header = writer._element(com.sun.xml.internal.ws.wsdl.writer.document.soap12.Header.class);
+            header.message(message);
+
+
+            header.part(headerParam.getPartName());
+            header.use(LITERAL);
+        }
+    }
+
+    protected void generateService() {
+        QName portQName = model.getPortName();
+        QName serviceQName = model.getServiceQName();
+        Service service = serviceDefinitions.service().name(serviceQName.getLocalPart());
+        Port port = service.port().name(portQName.getLocalPart());
+        port.binding(new QName(serviceQName.getNamespaceURI(), portQName.getLocalPart()+BINDING));
+        if (model.getJavaMethods().size() == 0)
+            return;
+        if (model.getJavaMethods().iterator().next().getBinding() instanceof SOAPBinding) {
+            if(bindingId.equals(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING)){
+                com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPAddress address = port._element(com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPAddress.class);
+                address.location(REPLACE_WITH_ACTUAL_URL);
+            }else{
+                SOAPAddress address = port._element(SOAPAddress.class);
+                address.location(REPLACE_WITH_ACTUAL_URL);
+            }
+        }
+    }
+
+    protected void generateInputMessage(Operation operation, JavaMethod method) {
+        ParamType paramType = operation.input();
+        paramType.message(new QName(model.getTargetNamespace(), method.getOperationName()));
+    }
+
+    protected void generateOutputMessage(Operation operation, JavaMethod method) {
+        ParamType paramType = operation.output();
+        paramType.message(new QName(model.getTargetNamespace(), method.getOperationName()+RESPONSE));
+    }
+
+    public Result createOutputFile(String namespaceUri, String suggestedFileName) throws IOException {
+        Result result;
+        if (namespaceUri.equals("")) {
+            return null;
+        }
+        com.sun.xml.internal.ws.wsdl.writer.document.xsd.Import _import = types.schema()._import().namespace(namespaceUri);
+
+        Holder<String> fileNameHolder = new Holder<String>();
+        fileNameHolder.value = schemaPrefix+suggestedFileName;
+        result = wsdlResolver.getSchemaOutput(namespaceUri, fileNameHolder);
+//        System.out.println("schema file: "+fileNameHolder.value);
+//        System.out.println("result: "+result);
+        String schemaLoc;
+        if (result == null)
+            schemaLoc = fileNameHolder.value;
+        else
+            schemaLoc = relativize(result.getSystemId(), wsdlLocation);
+//        System.out.println("schemaLoca: "+schemaLoc);
+        _import.schemaLocation(schemaLoc);
+        return result;
+    }
+
+   /**
+     * Relativizes a URI by using another URI (base URI.)
+     *
+     * <p>
+     * For example, {@code relative("http://www.sun.com/abc/def","http://www.sun.com/pqr/stu") => "../abc/def"}
+     *
+     * <p>
+     * This method only works on hierarchical URI's, not opaque URI's (refer to the
+     * <a href="http://java.sun.com/j2se/1.5.0/docs/api/java/net/URI.html">java.net.URI</a>
+     * javadoc for complete definitions of these terms.
+     *
+     * <p>
+     * This method will not normalize the relative URI.
+     *
+     * @return the relative URI or the original URI if a relative one could not be computed
+     */
+    protected static String relativize(String uri, String baseUri) {
+        try {
+            assert uri!=null;
+
+            if(baseUri==null)   return uri;
+
+            URI theUri = new URI(escapeURI(uri));
+            URI theBaseUri = new URI(escapeURI(baseUri));
+
+            if (theUri.isOpaque() || theBaseUri.isOpaque())
+                return uri;
+
+            if (!equalsIgnoreCase(theUri.getScheme(), theBaseUri.getScheme()) ||
+                    !equal(theUri.getAuthority(), theBaseUri.getAuthority()))
+                return uri;
+
+            String uriPath = theUri.getPath();
+            String basePath = theBaseUri.getPath();
+
+            // normalize base path
+            if (!basePath.endsWith("/")) {
+                basePath = normalizeUriPath(basePath);
+            }
+
+            if( uriPath.equals(basePath))
+                return ".";
+
+            String relPath = calculateRelativePath(uriPath, basePath);
+
+            if (relPath == null)
+                return uri; // recursion found no commonality in the two uris at all
+            StringBuffer relUri = new StringBuffer();
+            relUri.append(relPath);
+            if (theUri.getQuery() != null)
+                relUri.append('?').append(theUri.getQuery());
+            if (theUri.getFragment() != null)
+                relUri.append('#').append(theUri.getFragment());
+
+            return relUri.toString();
+        } catch (URISyntaxException e) {
+            throw new InternalError("Error escaping one of these uris:\n\t"+uri+"\n\t"+baseUri);
+        }
+    }
+
+    private static String calculateRelativePath(String uri, String base) {
+        if (base == null) {
+            return null;
+        }
+        if (uri.startsWith(base)) {
+            return uri.substring(base.length());
+        } else {
+            return "../" + calculateRelativePath(uri, getParentUriPath(base));
+        }
+    }
+
+
+    protected class JAXWSOutputSchemaResolver extends SchemaOutputResolver {
+        public Result createOutput(String namespaceUri, String suggestedFileName) throws IOException {
+            return createOutputFile(namespaceUri, suggestedFileName);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/WSDLOutputResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/WSDLOutputResolver.java
new file mode 100644
index 0000000..2007f12
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/WSDLOutputResolver.java
@@ -0,0 +1,54 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer;
+
+import javax.xml.transform.Result;
+import javax.xml.ws.Holder;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface WSDLOutputResolver {
+    public Result getWSDLOutput(String suggestedFilename);
+
+    /*
+     * Updates filename if the suggested filename need to be changed in
+     * wsdl:import
+     *
+     * return null if abstract WSDL need not be generated
+     */
+    public Result getAbstractWSDLOutput(Holder<String> filename);
+
+    /*
+     * Updates filename if the suggested filename need to be changed in
+     * xsd:import
+     *
+     * return null if schema need not be generated
+     */
+    public Result getSchemaOutput(String namespace, Holder<String> filename);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Binding.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Binding.java
new file mode 100644
index 0000000..fd2f07d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Binding.java
@@ -0,0 +1,58 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPBinding;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("binding")
+public interface Binding
+    extends TypedXmlWriter, StartWithExtensionsType
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Binding type(QName value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Binding name(String value);
+
+    @XmlElement
+    public BindingOperationType operation();
+
+    @XmlElement(value="binding",ns="http://schemas.xmlsoap.org/wsdl/soap/")
+    public SOAPBinding soapBinding();
+
+    @XmlElement(value="binding",ns="http://schemas.xmlsoap.org/wsdl/soap12/")
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPBinding soap12Binding();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/BindingOperationType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/BindingOperationType.java
new file mode 100644
index 0000000..47c4b32
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/BindingOperationType.java
@@ -0,0 +1,61 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Fault;
+import com.sun.xml.internal.ws.wsdl.writer.document.StartWithExtensionsType;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPOperation;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface BindingOperationType
+    extends TypedXmlWriter, StartWithExtensionsType
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.BindingOperationType name(String value);
+
+    @XmlElement(value="operation",ns="http://schemas.xmlsoap.org/wsdl/soap/")
+    public SOAPOperation soapOperation();
+
+    @XmlElement(value="operation",ns="http://schemas.xmlsoap.org/wsdl/soap12/")
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPOperation soap12Operation();
+
+    @XmlElement
+    public Fault fault();
+
+    @XmlElement
+    public StartWithExtensionsType output();
+
+    @XmlElement
+    public StartWithExtensionsType input();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Definitions.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Definitions.java
new file mode 100644
index 0000000..bfe69d1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Definitions.java
@@ -0,0 +1,65 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("definitions")
+public interface Definitions
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Definitions name(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Definitions targetNamespace(String value);
+
+    @XmlElement
+    public Service service();
+
+    @XmlElement
+    public Binding binding();
+
+    @XmlElement
+    public PortType portType();
+
+    @XmlElement
+    public Message message();
+
+    @XmlElement
+    public Types types();
+
+    @XmlElement("import")
+    public Import _import();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Documented.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Documented.java
new file mode 100644
index 0000000..5bb5de3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Documented.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface Documented
+    extends TypedXmlWriter
+{
+
+
+    @XmlElement
+    public com.sun.xml.internal.ws.wsdl.writer.document.Documented documentation(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Fault.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Fault.java
new file mode 100644
index 0000000..cbee537
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Fault.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.StartWithExtensionsType;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("fault")
+public interface Fault
+    extends TypedXmlWriter, StartWithExtensionsType
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Fault name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/FaultType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/FaultType.java
new file mode 100644
index 0000000..530b6bc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/FaultType.java
@@ -0,0 +1,43 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+
+public interface FaultType
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.FaultType message(QName value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.FaultType name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Import.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Import.java
new file mode 100644
index 0000000..527ac8a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Import.java
@@ -0,0 +1,48 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("import")
+public interface Import
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Import location(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Import namespace(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Message.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Message.java
new file mode 100644
index 0000000..0213113
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Message.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("message")
+public interface Message
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Message name(String value);
+
+    @XmlElement
+    public Part part();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/OpenAtts.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/OpenAtts.java
new file mode 100644
index 0000000..6b1923a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/OpenAtts.java
@@ -0,0 +1,35 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface OpenAtts extends TypedXmlWriter, Documented {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Operation.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Operation.java
new file mode 100644
index 0000000..85ab882
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Operation.java
@@ -0,0 +1,68 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("operation")
+public interface Operation
+    extends TypedXmlWriter, Documented
+{
+
+/*
+    @XmlElement("notification-operation")
+    public NotificationOperation notificationOperation();
+
+    @XmlElement("solicit-response-operation")
+    public SolicitResponseOperation solicitResponseOperation();
+
+    @XmlElement("request-response-operation")
+    public RequestResponseOperation requestResponseOperation();
+
+    @XmlElement("one-way-operation")
+    public OneWayOperation oneWayOperation();
+*/
+    @XmlElement
+    public ParamType input();
+
+    @XmlElement
+    public ParamType output();
+
+    @XmlElement
+    public FaultType fault();
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Operation name(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Operation parameterOrder(String value);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/ParamType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/ParamType.java
new file mode 100644
index 0000000..1da1812
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/ParamType.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface ParamType
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.ParamType message(QName value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.ParamType name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Part.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Part.java
new file mode 100644
index 0000000..e02b851
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Part.java
@@ -0,0 +1,52 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.OpenAtts;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("part")
+public interface Part
+    extends TypedXmlWriter, OpenAtts
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Part element(QName value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Part type(QName value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Part name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Port.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Port.java
new file mode 100644
index 0000000..2fca0a1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Port.java
@@ -0,0 +1,52 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("port")
+public interface Port
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Port name(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Port arrayType(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Port binding(QName value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/PortType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/PortType.java
new file mode 100644
index 0000000..b26c7de
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/PortType.java
@@ -0,0 +1,49 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+import com.sun.xml.internal.ws.wsdl.writer.document.Operation;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("portType")
+public interface PortType
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.PortType name(String value);
+
+    @XmlElement
+    public Operation operation();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Service.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Service.java
new file mode 100644
index 0000000..dd067e9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Service.java
@@ -0,0 +1,49 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+import com.sun.xml.internal.ws.wsdl.writer.document.Port;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("service")
+public interface Service
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.Service name(String value);
+
+    @XmlElement
+    public Port port();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/StartWithExtensionsType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/StartWithExtensionsType.java
new file mode 100644
index 0000000..ab664c9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/StartWithExtensionsType.java
@@ -0,0 +1,36 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface StartWithExtensionsType extends TypedXmlWriter, Documented {
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Types.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Types.java
new file mode 100644
index 0000000..3872199
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/Types.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+import com.sun.xml.internal.ws.wsdl.writer.document.xsd.Schema;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("types")
+public interface Types
+    extends TypedXmlWriter, Documented
+{
+    @XmlElement(value="schema",ns="http://www.w3.org/2001/XMLSchema")
+    public Schema schema();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Address.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Address.java
new file mode 100644
index 0000000..f803410
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Address.java
@@ -0,0 +1,46 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.ws.wsdl.writer.document.http;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("address")
+public interface Address
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.http.Address location(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Binding.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Binding.java
new file mode 100644
index 0000000..401ec75
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Binding.java
@@ -0,0 +1,46 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.ws.wsdl.writer.document.http;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("binding")
+public interface Binding
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.http.Binding verb(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Operation.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Operation.java
new file mode 100644
index 0000000..1ba7c0b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/Operation.java
@@ -0,0 +1,46 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package com.sun.xml.internal.ws.wsdl.writer.document.http;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("operation")
+public interface Operation
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.http.Operation location(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/package-info.java
new file mode 100644
index 0000000..a3f611f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/http/package-info.java
@@ -0,0 +1,33 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+
+/**
+ *
+ * @author WS Development Team
+ */
+@com.sun.xml.internal.txw2.annotation.XmlNamespace("http://schemas.xmlsoap.org/wsdl/http/")
+package com.sun.xml.internal.ws.wsdl.writer.document.http;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/package-info.java
new file mode 100644
index 0000000..e868187
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/package-info.java
@@ -0,0 +1,31 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *
+ * @author WS Development Team
+ */
+@com.sun.xml.internal.txw2.annotation.XmlNamespace("http://schemas.xmlsoap.org/wsdl/")
+package com.sun.xml.internal.ws.wsdl.writer.document;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/Body.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/Body.java
new file mode 100644
index 0000000..ece9955
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/Body.java
@@ -0,0 +1,41 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("body")
+public interface Body
+    extends TypedXmlWriter, BodyType
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/BodyType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/BodyType.java
new file mode 100644
index 0000000..b3013ca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/BodyType.java
@@ -0,0 +1,51 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface BodyType
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType encodingStyle(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType namespace(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType use(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType parts(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/Header.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/Header.java
new file mode 100644
index 0000000..563ba27
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/Header.java
@@ -0,0 +1,53 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.HeaderFault;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("header")
+public interface Header
+    extends TypedXmlWriter, BodyType
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.Header message(QName value);
+
+    @XmlElement
+    public HeaderFault headerFault();
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType part(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/HeaderFault.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/HeaderFault.java
new file mode 100644
index 0000000..173e6ef
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/HeaderFault.java
@@ -0,0 +1,46 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("headerFault")
+public interface HeaderFault
+    extends TypedXmlWriter, BodyType
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.HeaderFault message(QName value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPAddress.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPAddress.java
new file mode 100644
index 0000000..32f4afe
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPAddress.java
@@ -0,0 +1,44 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("address")
+public interface SOAPAddress
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPAddress location(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPBinding.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPBinding.java
new file mode 100644
index 0000000..e949766
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPBinding.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("binding")
+public interface SOAPBinding
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPBinding transport(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPBinding style(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPFault.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPFault.java
new file mode 100644
index 0000000..75d3652
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPFault.java
@@ -0,0 +1,43 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.soap.BodyType;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("fault")
+public interface SOAPFault
+    extends TypedXmlWriter, BodyType
+{
+   @XmlAttribute
+   public SOAPFault name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPOperation.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPOperation.java
new file mode 100644
index 0000000..fc94fe6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/SOAPOperation.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("operation")
+public interface SOAPOperation
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPOperation soapAction(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap.SOAPOperation style(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/package-info.java
new file mode 100644
index 0000000..cc8794e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap/package-info.java
@@ -0,0 +1,31 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *
+ * @author WS Development Team
+ */
+@com.sun.xml.internal.txw2.annotation.XmlNamespace("http://schemas.xmlsoap.org/wsdl/soap/")
+package com.sun.xml.internal.ws.wsdl.writer.document.soap;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/Body.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/Body.java
new file mode 100644
index 0000000..913c25e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/Body.java
@@ -0,0 +1,40 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("body")
+public interface Body
+    extends TypedXmlWriter, BodyType
+{
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/BodyType.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/BodyType.java
new file mode 100644
index 0000000..9840648
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/BodyType.java
@@ -0,0 +1,51 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+
+/**
+ *
+ * @author WS Development Team
+ */
+public interface BodyType
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.BodyType encodingStyle(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.BodyType namespace(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.BodyType use(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.BodyType parts(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/Header.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/Header.java
new file mode 100644
index 0000000..48d4cda
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/Header.java
@@ -0,0 +1,51 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("header")
+public interface Header
+    extends TypedXmlWriter, BodyType
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.Header message(QName value);
+
+    @XmlElement
+    public HeaderFault headerFault();
+
+    @XmlAttribute
+    public BodyType part(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/HeaderFault.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/HeaderFault.java
new file mode 100644
index 0000000..0587f67
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/HeaderFault.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
+
+import javax.xml.namespace.QName;
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("headerFault")
+public interface HeaderFault
+    extends TypedXmlWriter, BodyType
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.HeaderFault message(QName value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPAddress.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPAddress.java
new file mode 100644
index 0000000..51adfab
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPAddress.java
@@ -0,0 +1,44 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("address")
+public interface SOAPAddress
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPAddress location(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPBinding.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPBinding.java
new file mode 100644
index 0000000..6f39f76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPBinding.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("binding")
+public interface SOAPBinding
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPBinding transport(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPBinding style(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPFault.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPFault.java
new file mode 100644
index 0000000..30f2e3f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPFault.java
@@ -0,0 +1,42 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("fault")
+public interface SOAPFault
+    extends TypedXmlWriter, BodyType
+{
+   @XmlAttribute
+   public SOAPFault name(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPOperation.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPOperation.java
new file mode 100644
index 0000000..539dbc3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/SOAPOperation.java
@@ -0,0 +1,47 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("operation")
+public interface SOAPOperation
+    extends TypedXmlWriter
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPOperation soapAction(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.soap12.SOAPOperation style(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/package-info.java
new file mode 100644
index 0000000..932a52a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/soap12/package-info.java
@@ -0,0 +1,31 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *
+ * @author WS Development Team
+ */
+@com.sun.xml.internal.txw2.annotation.XmlNamespace("http://schemas.xmlsoap.org/wsdl/soap12/")
+package com.sun.xml.internal.ws.wsdl.writer.document.soap12;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/Import.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/Import.java
new file mode 100644
index 0000000..4d1a8b1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/Import.java
@@ -0,0 +1,49 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.xsd;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+import com.sun.xml.internal.ws.wsdl.writer.document.*;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("import")
+public interface Import
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.xsd.Import schemaLocation(String value);
+
+    @XmlAttribute
+    public com.sun.xml.internal.ws.wsdl.writer.document.xsd.Import namespace(String value);
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/Schema.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/Schema.java
new file mode 100644
index 0000000..82bae2b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/Schema.java
@@ -0,0 +1,45 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.ws.wsdl.writer.document.xsd;
+
+import com.sun.xml.internal.txw2.TypedXmlWriter;
+import com.sun.xml.internal.txw2.annotation.XmlAttribute;
+import com.sun.xml.internal.txw2.annotation.XmlElement;
+import com.sun.xml.internal.ws.wsdl.writer.document.Documented;
+import com.sun.xml.internal.ws.wsdl.writer.document.*;
+
+/**
+ *
+ * @author WS Development Team
+ */
+@XmlElement("schema")
+public interface Schema
+    extends TypedXmlWriter, Documented
+{
+
+
+    @XmlElement("import")
+    public Import _import();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/package-info.java b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/package-info.java
new file mode 100644
index 0000000..739b469
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/ws/wsdl/writer/document/xsd/package-info.java
@@ -0,0 +1,31 @@
+/*
+ * Portions Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/**
+ *
+ * @author WS Development Team
+ */
+@com.sun.xml.internal.txw2.annotation.XmlNamespace("http://www.w3.org/2001/XMLSchema")
+package com.sun.xml.internal.ws.wsdl.writer.document.xsd;
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/ForeignAttributes.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/ForeignAttributes.java
new file mode 100644
index 0000000..1a3313c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/ForeignAttributes.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.Locator;
+import org.relaxng.datatype.ValidationContext;
+
+/**
+ * Foreign attributes on schema elements.
+ *
+ * <p>
+ * This is not a schema component as defined in the spec,
+ * but this is often useful for a schema processing application.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface ForeignAttributes extends Attributes {
+    /**
+     * Returns context information of the element to which foreign attributes
+     * are attached.
+     *
+     * <p>
+     * For example, this can be used to resolve relative references to other resources
+     * (by using {@link ValidationContext#getBaseUri()}) or to resolve
+     * namespace prefixes in the attribute values (by using {@link ValidationContext#resolveNamespacePrefix(String)}.
+     *
+     * @return
+     *      always non-null.
+     */
+    ValidationContext getContext();
+
+    /**
+     * Returns the location of the element to which foreign attributes
+     * are attached.
+     */
+    Locator getLocator();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAnnotation.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAnnotation.java
new file mode 100644
index 0000000..c979022
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAnnotation.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import org.xml.sax.Locator;
+import com.sun.xml.internal.xsom.parser.AnnotationParser;
+
+/**
+ * <a href="http://www.w3.org/TR/xmlschema-1/#Annotation_details">
+ * XML Schema annotation</a>.
+ *
+ *
+ */
+public interface XSAnnotation
+{
+    /**
+     * Obtains the application-parsed annotation.
+     * <p>
+     * annotations are parsed by the user-specified
+     * {@link AnnotationParser}.
+     *
+     * @return may return null
+     */
+    Object getAnnotation();
+
+    /**
+     * Returns a location information of the annotation.
+     */
+    Locator getLocator();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttContainer.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttContainer.java
new file mode 100644
index 0000000..ce6bdfa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttContainer.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import java.util.Iterator;
+import java.util.Collection;
+
+/**
+ * Common aspect of {@link XSComplexType} and {@link XSAttGroupDecl}
+ * as the container of attribute uses/attribute groups.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSAttContainer extends XSDeclaration {
+    XSWildcard getAttributeWildcard();
+
+    /**
+     * Looks for the attribute use with the specified name from
+     * all the attribute uses that are directly/indirectly
+     * referenced from this component.
+     *
+     * <p>
+     * This is the exact implementation of the "attribute use"
+     * schema component.
+     */
+    XSAttributeUse getAttributeUse( String nsURI, String localName );
+
+    /**
+     * Lists all the attribute uses that are directly/indirectly
+     * referenced from this component.
+     *
+     * <p>
+     * This is the exact implementation of the "attribute use"
+     * schema component.
+     */
+    Iterator<? extends XSAttributeUse> iterateAttributeUses();
+
+    /**
+     * Gets all the attribute uses.
+     */
+    Collection<? extends XSAttributeUse> getAttributeUses();
+
+    /**
+     * Looks for the attribute use with the specified name from
+     * the attribute uses which are declared in this complex type.
+     *
+     * This does not include att uses declared in att groups that
+     * are referenced from this complex type, nor does include
+     * att uses declared in base types.
+     */
+    XSAttributeUse getDeclaredAttributeUse( String nsURI, String localName );
+
+    /**
+     * Lists all the attribute uses that are declared in this complex type.
+     */
+    Iterator<? extends XSAttributeUse> iterateDeclaredAttributeUses();
+
+    /**
+     * Lists all the attribute uses that are declared in this complex type.
+     */
+    Collection<? extends XSAttributeUse> getDeclaredAttributeUses();
+
+
+    /**
+     * Iterates all AttGroups which are directly referenced from
+     * this component.
+     */
+    Iterator<? extends XSAttGroupDecl> iterateAttGroups();
+
+    /**
+     * Iterates all AttGroups which are directly referenced from
+     * this component.
+     */
+    Collection<? extends XSAttGroupDecl> getAttGroups();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttGroupDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttGroupDecl.java
new file mode 100644
index 0000000..e85a098
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttGroupDecl.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Attribute group declaration.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSAttGroupDecl extends XSAttContainer {
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttributeDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttributeDecl.java
new file mode 100644
index 0000000..e49327d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttributeDecl.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Attribute declaration.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSAttributeDecl extends XSDeclaration
+{
+    XSSimpleType getType();
+
+    XmlString getDefaultValue();
+    XmlString getFixedValue();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttributeUse.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttributeUse.java
new file mode 100644
index 0000000..7363ab7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSAttributeUse.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import org.relaxng.datatype.ValidationContext;
+
+/**
+ * Attribute use.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSAttributeUse extends XSComponent
+{
+    boolean isRequired();
+    XSAttributeDecl getDecl();
+
+    /**
+     * Gets the default value of this attribute use, if one is specified.
+     *
+     * Note that if a default value is specified in the attribute
+     * declaration, this method returns that value.
+     */
+    XmlString getDefaultValue();
+
+    /**
+     * Gets the fixed value of this attribute use, if one is specified.
+     *
+     * Note that if a fixed value is specified in the attribute
+     * declaration, this method returns that value.
+     */
+    XmlString getFixedValue();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSComplexType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSComplexType.java
new file mode 100644
index 0000000..34745ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSComplexType.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+
+/**
+ * Complex type.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSComplexType extends XSType, XSAttContainer
+{
+    /**
+     * Checks if this complex type is declared as an abstract type.
+     */
+    boolean isAbstract();
+
+    boolean isFinal(int derivationMethod);
+    /**
+     * Roughly corresponds to the block attribute. But see the spec
+     * for gory detail.
+     */
+    boolean isSubstitutionProhibited(int method);
+
+    /**
+     * Gets the scope of this complex type.
+     * This is not a property defined in the schema spec.
+     *
+     * @return
+     *      null if this complex type is global. Otherwise
+     *      return the element declaration that contains this anonymous
+     *      complex type.
+     */
+    XSElementDecl getScope();
+
+    /**
+     * The content of this complex type.
+     *
+     * @return
+     *      always non-null.
+     */
+    XSContentType getContentType();
+
+    /**
+     * Gets the explicit content of a complex type with a complex content
+     * that was derived by extension.
+     *
+     * <p>
+     * Informally, the "explicit content" is the portion of the
+     * content model added in this derivation. IOW, it's a delta between
+     * the base complex type and this complex type.
+     *
+     * <p>
+     * For example, when a complex type T2 derives fom T1, then:
+     * <pre>
+     * content type of T2 = SEQUENCE( content type of T1, explicit content of T2 )
+     * </pre>
+     *
+     * @return
+     *      If this complex type is derived by restriction or has a
+     *      simple content, this method returns null.
+     *      IOW, this method only works for a complex type with
+     *      a complex content derived by extension from another complex type.
+     */
+    XSContentType getExplicitContent();
+
+    // meaningful only if getContentType returns particles
+    boolean isMixed();
+
+    /**
+     * If this {@link XSComplexType} is redefined by another complex type,
+     * return that component.
+     *
+     * @return null
+     *      if this component has not been redefined.
+     */
+    public XSComplexType getRedefinedBy();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSComponent.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSComponent.java
new file mode 100644
index 0000000..4b702c3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSComponent.java
@@ -0,0 +1,112 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import com.sun.xml.internal.xsom.parser.SchemaDocument;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.List;
+
+/**
+ * Base interface for all the schema components.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSComponent
+{
+    /** Gets the annotation associated to this component, if any. */
+    XSAnnotation getAnnotation();
+
+    /**
+     * Gets the foreign attributes on this schema component.
+     *
+     * <p>
+     * In general, a schema component may match multiple elements
+     * in a schema document, and those elements can individually
+     * carry foreign attributes.
+     *
+     * <p>
+     * This method returns a list of {@link ForeignAttributes}, where
+     * each {@link ForeignAttributes} object represent foreign attributes
+     * on one element.
+     *
+     * @return
+     *      can be an empty list but never be null.
+     */
+    List<? extends ForeignAttributes> getForeignAttributes();
+
+    /**
+     * Gets the foreign attribute of the given name, or null if not found.
+     *
+     * <p>
+     * If multiple occurences of the same attribute is found,
+     * this method returns the first one.
+     *
+     * @see #getForeignAttributes()
+     */
+    String getForeignAttribute(String nsUri, String localName);
+
+    /**
+     * Gets the locator that indicates the source location where
+     * this component is created from, or null if no information is
+     * available.
+     */
+    Locator getLocator();
+
+    /**
+     * Gets a reference to the {@link XSSchema} object to which this component
+     * belongs.
+     * <p>
+     * In case of <code>XSEmpty</code> component, this method
+     * returns null since there is no owner component.
+     */
+    XSSchema getOwnerSchema();
+
+    /**
+     * Gets the {@link SchemaDocument} that indicates which document this component
+     * was defined in.
+     *
+     * @return
+     *      null for components that are built-in to XML Schema, such
+     *      as anyType, or "empty" {@link XSContentType}. This method also
+     *      returns null for {@link XSSchema}.
+     *      For all other user-defined
+     *      components this method returns non-null, even if they are local.
+     */
+    SchemaDocument getSourceDocument();
+
+    /**
+     * Accepts a visitor.
+     */
+    void visit( XSVisitor visitor );
+    /**
+     * Accepts a functor.
+     */
+    <T> T apply( XSFunction<T> function );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSContentType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSContentType.java
new file mode 100644
index 0000000..045844e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSContentType.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import com.sun.xml.internal.xsom.visitor.XSContentTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor;
+
+/**
+ * Content of a complex type.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSContentType extends XSComponent
+{
+    /**
+     * Equivalent of <code>(this instanceof XSSimpleType)?this:null</code>
+     */
+    XSSimpleType asSimpleType();
+    /**
+     * Equivalent of <code>(this instanceof XSParticle)?this:null</code>
+     */
+    XSParticle asParticle();
+    /**
+     * If this content type represents the empty content, return <code>this</code>,
+     * otherwise null.
+     */
+    XSContentType asEmpty();
+
+    <T> T apply( XSContentTypeFunction<T> function );
+    void visit( XSContentTypeVisitor visitor );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSDeclaration.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSDeclaration.java
new file mode 100644
index 0000000..9d17f48
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSDeclaration.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Base interface of all "declarations".
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSDeclaration extends XSComponent
+{
+    /**
+     * Target namespace to which this component belongs.
+     * <code>""</code> is used to represent the default no namespace.
+     */
+    String getTargetNamespace();
+
+    /**
+     * Gets the (local) name of the declaration.
+     */
+    String getName();
+
+    /**
+     * @deprecated use the isGlobal method, which always returns
+     * the opposite of this function. Or the isLocal method.
+     */
+    boolean isAnonymous();
+
+    /**
+     * Returns true if this declaration is a global declaration.
+     *
+     * Global declarations are those declaration that can be enumerated
+     * through the schema object.
+     */
+    boolean isGlobal();
+
+    /**
+     * Returns true if this declaration is a local declaration.
+     * Equivalent of <code>!isGlobal()</code>
+     */
+    boolean isLocal();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSElementDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSElementDecl.java
new file mode 100644
index 0000000..cecd1ad
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSElementDecl.java
@@ -0,0 +1,135 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import java.util.List;
+import java.util.Set;
+
+/**
+ * Element declaration.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSElementDecl extends XSDeclaration, XSTerm
+{
+    XSType getType();
+
+    boolean isNillable();
+
+    XSElementDecl getSubstAffiliation();
+
+    /**
+     * Returns all the {@link XSIdentityConstraint}s in this element decl.
+     *
+     * @return
+     *      never null, but can be empty.
+     */
+    List<XSIdentityConstraint> getIdentityConstraints();
+
+    /**
+     * Checks the substitution excluded property of the schema component.
+     *
+     * IOW, this checks the value of the <code>final</code> attribute
+     * (plus <code>finalDefault</code>).
+     *
+     * @param method
+     *      Possible values are {@link XSType.EXTENSION} or
+     *      <code>XSType.RESTRICTION</code>.
+     */
+    boolean isSubstitutionExcluded(int method);
+
+    /**
+     * Checks the diallowed substitution property of the schema component.
+     *
+     * IOW, this checks the value of the <code>block</code> attribute
+     * (plus <code>blockDefault</code>).
+     *
+     * @param method
+     *      Possible values are {@link XSType.EXTENSION},
+     *      <code>XSType.RESTRICTION</code>, or <code>XSType.SUBSTITUTION</code>
+     */
+    boolean isSubstitutionDisallowed(int method);
+
+    boolean isAbstract();
+
+    /**
+     * Returns the element declarations that can substitute
+     * this element.
+     *
+     * <p>
+     * IOW, this set returns all the element decls that satisfies
+     * <a href="http://www.w3.org/TR/xmlschema-1/#cos-equiv-derived-ok-rec">
+     * the "Substitution Group OK" constraint.
+     * </a>
+     *
+     * @return
+     *      nun-null valid array. The return value always contains this element
+     *      decl itself.
+     *
+     * @deprecated
+     *      this method allocates a new array every time, so it could be
+     *      inefficient when working with a large schema. Use
+     *      {@link #getSubstitutables()} instead.
+     */
+    XSElementDecl[] listSubstitutables();
+
+    /**
+     * Returns the element declarations that can substitute
+     * this element.
+     *
+     * <p>
+     * IOW, this set returns all the element decls that satisfies
+     * <a href="http://www.w3.org/TR/xmlschema-1/#cos-equiv-derived-ok-rec">
+     * the "Substitution Group OK" constraint.
+     * </a>
+     *
+     * <p>
+     * Note that the above clause does <em>NOT</em> check for
+     * abstract elements. So abstract elements may still show up
+     * in the returned set.
+     *
+     * @return
+     *      nun-null unmodifiable list.
+     *      The returned list always contains this element decl itself.
+     */
+    Set<? extends XSElementDecl> getSubstitutables();
+
+    /**
+     * Returns true if this element declaration can be validly substituted
+     * by the given declaration.
+     *
+     * <p>
+     * Just a short cut of <tt>getSubstitutables().contain(e);</tt>
+     */
+    boolean canBeSubstitutedBy(XSElementDecl e);
+
+    // TODO: identitiy constraints
+    // TODO: scope
+
+    XmlString getDefaultValue();
+    XmlString getFixedValue();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSFacet.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSFacet.java
new file mode 100644
index 0000000..c8c834b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSFacet.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Facet for a simple type.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSFacet extends XSComponent
+{
+    /** Gets the name of the facet, such as "length". */
+    String getName();
+
+    /** Gets the value of the facet. */
+    XmlString getValue();
+
+    /** Returns true if this facet is "fixed". */
+    boolean isFixed();
+
+
+    // well-known facet name constants
+    final static String FACET_LENGTH            = "length";
+    final static String FACET_MINLENGTH         = "minLength";
+    final static String FACET_MAXLENGTH         = "maxLength";
+    final static String FACET_PATTERN           = "pattern";
+    final static String FACET_ENUMERATION       = "enumeration";
+    final static String FACET_TOTALDIGITS       = "totalDigits";
+    final static String FACET_FRACTIONDIGITS    = "fractionDigits";
+    final static String FACET_MININCLUSIVE      = "minInclusive";
+    final static String FACET_MAXINCLUSIVE      = "maxInclusive";
+    final static String FACET_MINEXCLUSIVE      = "minExclusive";
+    final static String FACET_MAXEXCLUSIVE      = "maxExclusive";
+    final static String FACET_WHITESPACE        = "whiteSpace";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSIdentityConstraint.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSIdentityConstraint.java
new file mode 100644
index 0000000..3f86629
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSIdentityConstraint.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import java.util.List;
+
+/**
+ * Identity constraint.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface XSIdentityConstraint extends XSComponent {
+
+    /**
+     * Gets the {@link XSElementDecl} that owns this identity constraint.
+     *
+     * @return
+     *      never null.
+     */
+    XSElementDecl getParent();
+
+    /**
+     * Name of the identity constraint.
+     *
+     * A name uniquely identifies this {@link XSIdentityConstraint} within
+     * the namespace.
+     *
+     * @return
+     *      never null.
+     */
+    String getName();
+
+    /**
+     * Target namespace of the identity constraint.
+     *
+     * Just short for <code>getParent().getTargetNamespace()</code>.
+     */
+    String getTargetNamespace();
+
+    /**
+     * Returns the type of the identity constraint.
+     *
+     * @return
+     *      either {@link #KEY},{@link #KEYREF}, or {@link #UNIQUE}.
+     */
+    short getCategory();
+
+    final short KEY = 0;
+    final short KEYREF = 1;
+    final short UNIQUE = 2;
+
+    /**
+     * Returns the selector XPath expression as string.
+     *
+     * @return
+     *      never null.
+     */
+    XSXPath getSelector();
+
+    /**
+     * Returns the list of field XPaths.
+     *
+     * @return
+     *      a non-empty read-only list of {@link String}s,
+     *      each representing the XPath.
+     */
+    List<XSXPath> getFields();
+
+    /**
+     * If this is {@link #KEYREF}, returns the key {@link XSIdentityConstraint}
+     * being referenced.
+     *
+     * @return
+     *      always non-null (when {@link #getCategory()}=={@link #KEYREF}).
+     * @throws IllegalStateException
+     *      if {@link #getCategory()}!={@link #KEYREF}
+     */
+    XSIdentityConstraint getReferencedKey();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSListSimpleType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSListSimpleType.java
new file mode 100644
index 0000000..8de5496
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSListSimpleType.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * List simple type.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSListSimpleType extends XSSimpleType
+{
+    XSSimpleType getItemType();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSModelGroup.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSModelGroup.java
new file mode 100644
index 0000000..3b6a2f8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSModelGroup.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Model group.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSModelGroup extends XSComponent, XSTerm, Iterable<XSParticle>
+{
+    /**
+     * Type-safe enumeration for kind of model groups.
+     * Constants are defined in the {@link XSModelGroup} interface.
+     */
+    public static enum Compositor {
+        ALL("all"),CHOICE("choice"),SEQUENCE("sequence");
+
+        private Compositor(String _value) {
+            this.value = _value;
+        }
+
+        private final String value;
+        /**
+         * Returns the human-readable compositor name.
+         *
+         * @return
+         *      Either "all", "sequence", or "choice".
+         */
+        public String toString() {
+            return value;
+        }
+    }
+    /**
+     * A constant that represents "all" compositor.
+     */
+    static final Compositor ALL = Compositor.ALL;
+    /**
+     * A constant that represents "sequence" compositor.
+     */
+    static final Compositor SEQUENCE = Compositor.SEQUENCE;
+    /**
+     * A constant that represents "choice" compositor.
+     */
+    static final Compositor CHOICE = Compositor.CHOICE;
+
+    Compositor getCompositor();
+
+    /**
+     * Gets <i>i</i>-ith child.
+     */
+    XSParticle getChild(int idx);
+    /**
+     * Gets the number of children.
+     */
+    int getSize();
+
+    /**
+     * Gets all the children in one array.
+     */
+    XSParticle[] getChildren();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSModelGroupDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSModelGroupDecl.java
new file mode 100644
index 0000000..b27b6d9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSModelGroupDecl.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+
+/**
+ * Named model group declaration.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSModelGroupDecl extends XSDeclaration, XSTerm
+{
+    /**
+     * Gets the body of this declaration.
+     */
+    XSModelGroup getModelGroup();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSNotation.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSNotation.java
new file mode 100644
index 0000000..7ff6601
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSNotation.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Notation declaration.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSNotation extends XSDeclaration {
+    String getPublicId();
+    String getSystemId();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSParticle.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSParticle.java
new file mode 100644
index 0000000..f6c5229
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSParticle.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Particle schema component.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSParticle extends XSContentType
+{
+    int getMinOccurs();
+    /**
+     * Gets the max occurs property.
+     *
+     * @return
+     *      {@link UNBOUNDED} will be returned if the value
+     *      is "unbounded".
+     */
+    int getMaxOccurs();
+
+    /**
+     * True if the maxOccurs is neither 0 or 1.
+     */
+    boolean isRepeated();
+
+    public static final int UNBOUNDED = -1;
+
+    XSTerm getTerm();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSRestrictionSimpleType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSRestrictionSimpleType.java
new file mode 100644
index 0000000..06e1bdc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSRestrictionSimpleType.java
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import java.util.Iterator;
+import java.util.Collection;
+import java.util.List;
+
+/**
+ * Restriction simple type.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSRestrictionSimpleType extends XSSimpleType {
+    // TODO
+
+    /** Iterates facets that are specified in this step of derivation. */
+    public Iterator<XSFacet> iterateDeclaredFacets();
+
+    public Collection<? extends XSFacet> getDeclaredFacets();
+
+    /**
+     * Gets the declared facet object of the given name.
+     *
+     * <p>
+     * This method returns a facet object that is added in this
+     * type and does not recursively check the ancestors.
+     *
+     * <p>
+     * For those facets that can have multiple values
+     * (pattern facets and enumeration facets), this method
+     * will return only the first one.
+     *
+     * @return
+     *      Null if the facet is not specified in the last step
+     *      of derivation.
+     */
+    XSFacet getDeclaredFacet( String name );
+
+    /**
+     * Gets the declared facets of the given name.
+     *
+     * This method is for those facets (such as 'pattern') that
+     * can be specified multiple times on a simple type.
+     *
+     * @return
+     *      can be empty but never be null.
+     */
+    List<XSFacet> getDeclaredFacets( String name );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSchema.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSchema.java
new file mode 100644
index 0000000..f21d0d8
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSchema.java
@@ -0,0 +1,132 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import com.sun.xml.internal.xsom.parser.SchemaDocument;
+
+import java.util.Iterator;
+import java.util.Map;
+
+/**
+ * Schema.
+ *
+ * Container of declarations that belong to the same target namespace.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSSchema extends XSComponent
+{
+    /**
+     * Gets the target namespace of the schema.
+     *
+     * @return
+     *      can be empty, but never be null.
+     */
+    String getTargetNamespace();
+
+    /**
+     * Gets all the {@link XSAttributeDecl}s in this schema
+     * keyed by their local names.
+     */
+    Map<String,XSAttributeDecl> getAttributeDecls();
+    Iterator<XSAttributeDecl> iterateAttributeDecls();
+    XSAttributeDecl getAttributeDecl(String localName);
+
+    /**
+     * Gets all the {@link XSElementDecl}s in this schema.
+     */
+    Map<String,XSElementDecl> getElementDecls();
+    Iterator<XSElementDecl> iterateElementDecls();
+    XSElementDecl getElementDecl(String localName);
+
+    /**
+     * Gets all the {@link XSAttGroupDecl}s in this schema.
+     */
+    Map<String,XSAttGroupDecl> getAttGroupDecls();
+    Iterator<XSAttGroupDecl> iterateAttGroupDecls();
+    XSAttGroupDecl getAttGroupDecl(String localName);
+
+    /**
+     * Gets all the {@link XSModelGroupDecl}s in this schema.
+     */
+    Map<String,XSModelGroupDecl> getModelGroupDecls();
+    Iterator<XSModelGroupDecl> iterateModelGroupDecls();
+    XSModelGroupDecl getModelGroupDecl(String localName);
+
+    /**
+     * Gets all the {@link XSType}s in this schema (union of
+     * {@link #getSimpleTypes()} and {@link #getComplexTypes()}
+     */
+    Map<String,XSType> getTypes();
+    Iterator<XSType> iterateTypes();
+    XSType getType(String localName);
+
+    /**
+     * Gets all the {@link XSSimpleType}s in this schema.
+     */
+    Map<String,XSSimpleType> getSimpleTypes();
+    Iterator<XSSimpleType> iterateSimpleTypes();
+    XSSimpleType getSimpleType(String localName);
+
+    /**
+     * Gets all the {@link XSComplexType}s in this schema.
+     */
+    Map<String,XSComplexType> getComplexTypes();
+    Iterator<XSComplexType> iterateComplexTypes();
+    XSComplexType getComplexType(String localName);
+
+    /**
+     * Gets all the {@link XSNotation}s in this schema.
+     */
+    Map<String,XSNotation> getNotations();
+    Iterator<XSNotation> iterateNotations();
+    XSNotation getNotation(String localName);
+
+    /**
+     * Gets all the {@link XSIdentityConstraint}s in this schema,
+     * keyed by their names.
+     */
+    Map<String,XSIdentityConstraint> getIdentityConstraints();
+
+    /**
+     * Gets the identity constraint of the given name, or null if not found.
+     */
+    XSIdentityConstraint getIdentityConstraint(String localName);
+
+    /**
+     * Sine an {@link XSSchema} is not necessarily defined in
+     * one schema document (for example one schema can span across
+     * many documents through &lt;xs:include>s.),
+     * so this method always returns null.
+     *
+     * @deprecated
+     *      Since this method always returns null, if you are calling
+     *      this method from {@link XSSchema} and not from {@link XSComponent},
+     *      there's something wrong with your code.
+     */
+    SchemaDocument getSourceDocument();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSchemaSet.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSchemaSet.java
new file mode 100644
index 0000000..9d944f4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSchemaSet.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import java.util.Iterator;
+import java.util.Collection;
+
+/**
+ * Set of {@link XSSchema} objects.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSSchemaSet
+{
+    XSSchema getSchema(String targetNamespace);
+    XSSchema getSchema(int idx);
+    int getSchemaSize();
+    Iterator<XSSchema> iterateSchema();
+
+    /**
+     * Gets all {@link XSSchema}s in a single collection.
+     */
+    Collection<XSSchema> getSchemas();
+
+    XSType getType(String namespaceURI, String localName);
+    XSSimpleType getSimpleType(String namespaceURI, String localName);
+    XSAttributeDecl getAttributeDecl(String namespaceURI, String localName);
+    XSElementDecl getElementDecl(String namespaceURI, String localName);
+    XSModelGroupDecl getModelGroupDecl(String namespaceURI, String localName);
+    XSAttGroupDecl getAttGroupDecl(String namespaceURI, String localName);
+    XSComplexType getComplexType(String namespaceURI, String localName);
+    XSIdentityConstraint getIdentityConstraint(String namespaceURI, String localName);
+
+    /** Iterates all element declarations in all the schemas. */
+    Iterator<XSElementDecl> iterateElementDecls();
+    /** Iterates all type definitions in all the schemas. */
+    Iterator<XSType> iterateTypes();
+    /** Iterates all atribute declarations in all the schemas. */
+    Iterator<XSAttributeDecl> iterateAttributeDecls();
+    /** Iterates all attribute group declarations in all the schemas. */
+    Iterator<XSAttGroupDecl> iterateAttGroupDecls();
+    /** Iterates all model group declarations in all the schemas. */
+    Iterator<XSModelGroupDecl> iterateModelGroupDecls();
+    /** Iterates all simple type definitions in all the schemas. */
+    Iterator<XSSimpleType> iterateSimpleTypes();
+    /** Iterates all complex type definitions in all the schemas. */
+    Iterator<XSComplexType> iterateComplexTypes();
+    /** Iterates all notation declarations in all the schemas. */
+    Iterator<XSNotation> iterateNotations();
+    /**
+     * Iterates all identity constraints in all the schemas.
+     */
+    Iterator<XSIdentityConstraint> iterateIdentityConstraints();
+
+    // conceptually static methods
+    XSComplexType getAnyType();
+    XSSimpleType getAnySimpleType();
+    XSContentType getEmpty();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSimpleType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSimpleType.java
new file mode 100644
index 0000000..40b37f9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSSimpleType.java
@@ -0,0 +1,119 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor;
+
+/**
+ * Simple type.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSSimpleType extends XSType, XSContentType
+{
+    /**
+     * Gets the base type as XSSimpleType.
+     *
+     * Equivalent to
+     * <code>
+     * (XSSimpleType)getBaseType()
+     * </code>
+     * Since this is a simple type, we know that the base type
+     * is also a simple type.
+     *
+     * The only exception is xs:anySimpleType, which has xs:anyType
+     * as the base type.
+     *
+     * @return
+     *      null if this is xs:anySimpleType. Otherwise non-null.
+     */
+    XSSimpleType getSimpleBaseType();
+
+    /**
+     * Gets the variety of this simple type.
+     */
+    XSVariety getVariety();
+
+    /**
+     * Returns true if this type definition is marked as 'final'
+     * with respect to the given {@link XSVariety}.
+     *
+     * @return
+     *      true if the type is marked final.
+     */
+    boolean isFinal(XSVariety v);
+
+    /**
+     * If this {@link XSSimpleType} is redefined by another simple type,
+     * return that component.
+     *
+     * @return null
+     *      if this component has not been redefined.
+     */
+    public XSSimpleType getRedefinedBy();
+
+    /**
+     * Gets the effective facet object of the given name.
+     *
+     * <p>
+     * For example, if a simple type "foo" is derived from
+     * xs:string by restriction with the "maxLength" facet and
+     * another simple type "bar" is derived from "foo" by
+     * restriction with another "maxLength" facet, this method
+     * will return the latter one, because that is the most
+     * restrictive, effective facet.
+     *
+     * <p>
+     * For those facets that can have multiple values
+     * (pattern facets and enumeration facets), this method
+     * will return only the first one.
+     * TODO: allow clients to access all of them by some means.
+     *
+     * @return
+     *      If this datatype has a facet of the given name,
+     *      return that object. If the facet is not specified
+     *      anywhere in its derivation chain, null will be returned.
+     */
+    XSFacet getFacet( String name );
+
+
+
+    void visit( XSSimpleTypeVisitor visitor );
+    <T> T apply( XSSimpleTypeFunction<T> function );
+
+    /** Returns true if <code>this instanceof XSRestrictionSimpleType</code>. */
+    boolean isRestriction();
+    /** Returns true if <code>this instanceof XSListSimpleType</code>. */
+    boolean isList();
+    /** Returns true if <code>this instanceof XSUnionSimpleType</code>. */
+    boolean isUnion();
+
+    XSRestrictionSimpleType asRestriction();
+    XSListSimpleType asList();
+    XSUnionSimpleType asUnion();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSTerm.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSTerm.java
new file mode 100644
index 0000000..0ea325d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSTerm.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import com.sun.xml.internal.xsom.visitor.XSTermFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+import com.sun.xml.internal.xsom.visitor.XSTermFunctionWithParam;
+
+/**
+ * A component that can be referenced from {@link XSParticle}
+ *
+ * This interface provides a set of type check functions (<code>isXXX</code>),
+ * which are essentially:
+ *
+ * <pre>
+ * boolean isXXX() {
+ *     return this instanceof XXX;
+ * }
+ * <pre>
+ *
+ * and a set of cast functions (<code>asXXX</code>), which are
+ * essentially:
+ *
+ * <pre>
+ * XXX asXXX() {
+ *     if(isXXX())  return (XXX)this;
+ *     else          return null;
+ * }
+ * </pre>
+ */
+public interface XSTerm extends XSComponent
+{
+    void visit( XSTermVisitor visitor );
+    <T> T apply( XSTermFunction<T> function );
+    <T,P> T apply( XSTermFunctionWithParam<T,P> function, P param );
+
+    // cast functions
+    boolean isWildcard();
+    boolean isModelGroupDecl();
+    boolean isModelGroup();
+    boolean isElementDecl();
+
+    XSWildcard asWildcard();
+    XSModelGroupDecl asModelGroupDecl();
+    XSModelGroup asModelGroup();
+    XSElementDecl asElementDecl();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSType.java
new file mode 100644
index 0000000..f782ae2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSType.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Base interface for {@link XSComplexType} and {@link XSSimpleType}.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSType extends XSDeclaration {
+    /**
+     * Returns the base type of this type.
+     *
+     * Note that if this type represents <tt>xs:anyType</tt>, this method returns itself.
+     * This is awkward as an API, but it follows the schema specification.
+     *
+     * @return  always non-null.
+     */
+    XSType getBaseType();
+
+    final static int EXTENSION = 1;
+    final static int RESTRICTION = 2;
+    final static int SUBSTITUTION = 4;
+
+    int getDerivationMethod();
+
+    /** Returns true if <code>this instanceof XSSimpleType</code>. */
+    boolean isSimpleType();
+    /** Returns true if <code>this instanceof XSComplexType</code>. */
+    boolean isComplexType();
+
+    /**
+     * Lists up types that can substitute this type by using xsi:type.
+     * Includes this type itself.
+     * <p>
+     * This method honors the block flag.
+     */
+    XSType[] listSubstitutables();
+
+    /**
+     * If this {@link XSType} is redefined by another type,
+     * return that component.
+     *
+     * @return null
+     *      if this component has not been redefined.
+     */
+    XSType getRedefinedBy();
+
+    /**
+     * Returns the number of complex types that redefine this component.
+     *
+     * <p>
+     * For example, if A is redefined by B and B is redefined by C,
+     * A.getRedefinedCount()==2, B.getRedefinedCount()==1, and
+     * C.getRedefinedCount()==0.
+     */
+    int getRedefinedCount();
+
+
+    /** Casts this object to XSSimpleType if possible, otherwise returns null. */
+    XSSimpleType asSimpleType();
+    /** Casts this object to XSComplexType if possible, otherwise returns null. */
+    XSComplexType asComplexType();
+
+    /**
+     * Returns true if this type is derived from the specified type.
+     *
+     * <p>
+     * Note that <tt>t.isDerivedFrom(t)</tt> returns true.
+     */
+    boolean isDerivedFrom( XSType t );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSUnionSimpleType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSUnionSimpleType.java
new file mode 100644
index 0000000..6d0c10e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSUnionSimpleType.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Union simple type.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSUnionSimpleType extends XSSimpleType, Iterable<XSSimpleType>
+{
+    XSSimpleType getMember(int idx);
+    int getMemberSize();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSVariety.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSVariety.java
new file mode 100644
index 0000000..9eeb41c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSVariety.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Constants that represent variety of simple types.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke,kawaguchi@sun.com)
+ */
+public final class XSVariety {
+    public static final XSVariety ATOMIC = new XSVariety("atomic");
+    public static final XSVariety UNION  = new XSVariety("union");
+    public static final XSVariety LIST   = new XSVariety("list");
+
+    private XSVariety(String _name) { this.name=_name; }
+    private final String name;
+    public String toString() { return name; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSWildcard.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSWildcard.java
new file mode 100644
index 0000000..49f30bb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSWildcard.java
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import java.util.Iterator;
+import java.util.Collection;
+
+import com.sun.xml.internal.xsom.visitor.XSWildcardFunction;
+import com.sun.xml.internal.xsom.visitor.XSWildcardVisitor;
+
+/**
+ * Wildcard schema component (used for both attribute wildcard
+ * and element wildcard.)
+ *
+ * XSWildcard interface can always be downcasted to either
+ * Any, Other, or Union.
+ */
+public interface XSWildcard extends XSComponent, XSTerm
+{
+    static final int LAX = 1;
+    static final int STRTICT = 2;
+    static final int SKIP = 3;
+    /**
+     * Gets the processing mode.
+     *
+     * @return
+     *      Either LAX, STRICT, or SKIP.
+     */
+    int getMode();
+
+    /**
+     * Returns true if the specified namespace URI is valid
+     * wrt this wildcard.
+     *
+     * @param namespaceURI
+     *      Use the empty string to test the default no-namespace.
+     */
+    boolean acceptsNamespace(String namespaceURI);
+
+    /** Visitor support. */
+    void visit(XSWildcardVisitor visitor);
+    <T> T apply(XSWildcardFunction<T> function);
+
+    /**
+     * <code>##any</code> wildcard.
+     */
+    interface Any extends XSWildcard {
+    }
+    /**
+     * <code>##other</code> wildcard.
+     */
+    interface Other extends XSWildcard {
+        /**
+         * Gets the namespace URI excluded from this wildcard.
+         */
+        String getOtherNamespace();
+    }
+    /**
+     * Wildcard of a set of namespace URIs.
+     */
+    interface Union extends XSWildcard {
+        /**
+         * Short for <code>getNamespaces().iterator()</code>
+         */
+        Iterator<String> iterateNamespaces();
+
+        /**
+         * Read-only list of namespace URIs.
+         */
+        Collection<String> getNamespaces();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSXPath.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSXPath.java
new file mode 100644
index 0000000..d58af40
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XSXPath.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+/**
+ * Selector or field of {@link XSIdentityConstraint}.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public interface XSXPath extends XSComponent  {
+
+    /**
+     * Returns the {@link XSIdentityConstraint} to which
+     * this XPath belongs to.
+     *
+     * @return
+     *      never null.
+     */
+    XSIdentityConstraint getParent();
+
+    /**
+     * Gets the XPath as a string.
+     *
+     * @return
+     *      never null.
+     */
+    XmlString getXPath();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/XmlString.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XmlString.java
new file mode 100644
index 0000000..f118f6a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/XmlString.java
@@ -0,0 +1,117 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom;
+
+import org.relaxng.datatype.ValidationContext;
+
+/**
+ * String with in-scope namespace binding information.
+ *
+ * <p>
+ * In a general case, text (PCDATA/attributes) that appear in XML schema
+ * cannot be correctly interpreted unless you also have in-scope namespace
+ * binding (a case in point is QName.) Therefore, it's convenient to
+ * handle the lexical representation and the in-scope namespace binding
+ * in a pair.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class XmlString {
+    /**
+     * Textual value. AKA lexical representation.
+     */
+    public final String value;
+
+    /**
+     * Used to resole in-scope namespace bindings.
+     */
+    public final ValidationContext context;
+
+    /**
+     * Creates a new {@link XmlString} from a lexical representation and in-scope namespaces.
+     */
+    public XmlString(String value, ValidationContext context) {
+        this.value = value;
+        this.context = context;
+        if(context==null)
+            throw new IllegalArgumentException();
+    }
+
+    /**
+     * Creates a new {@link XmlString} with empty in-scope namespace bindings.
+     */
+    public XmlString(String value) {
+        this(value,NULL_CONTEXT);
+    }
+
+    /**
+     * Resolves a namespace prefix to the corresponding namespace URI.
+     *
+     * This method is used for resolving prefixes in the {@link #value}
+     * (such as when {@link #value} represents a QName type.)
+     *
+     * <p>
+     * If the prefix is "" (empty string), the method
+     * returns the default namespace URI.
+     *
+     * <p>
+     * If the prefix is "xml", then the method returns
+     * "http://www.w3.org/XML/1998/namespace",
+     * as defined in the XML Namespaces Recommendation.
+     *
+     * @return
+     *          namespace URI of this prefix.
+     *          If the specified prefix is not declared,
+     *          the implementation returns null.
+     */
+    public final String resolvePrefix(String prefix) {
+        return context.resolveNamespacePrefix(prefix);
+    }
+
+    public String toString() {
+        return value;
+    }
+
+    private static final ValidationContext NULL_CONTEXT = new ValidationContext() {
+        public String resolveNamespacePrefix(String s) {
+            if(s.length()==0)   return "";
+            if(s.equals("xml")) return "http://www.w3.org/XML/1998/namespace";
+            return null;
+        }
+
+        public String getBaseUri() {
+            return null;
+        }
+
+        public boolean isUnparsedEntity(String s) {
+            return false;
+        }
+
+        public boolean isNotation(String s) {
+            return false;
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AnnotationImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AnnotationImpl.java
new file mode 100644
index 0000000..2cdd394
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AnnotationImpl.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import org.xml.sax.Locator;
+
+public class AnnotationImpl implements XSAnnotation
+{
+    private final Object annotation;
+    public Object getAnnotation() { return annotation; }
+
+    private final Locator locator;
+    public Locator getLocator() { return locator; }
+
+    public AnnotationImpl( Object o, Locator _loc ) {
+        this.annotation = o;
+        this.locator = _loc;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttGroupDeclImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttGroupDeclImpl.java
new file mode 100644
index 0000000..5bcedff
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttGroupDeclImpl.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.impl.parser.DelayedRef;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Iterator;
+
+public class AttGroupDeclImpl extends AttributesHolder implements XSAttGroupDecl
+{
+    public AttGroupDeclImpl( SchemaDocumentImpl _parent, AnnotationImpl _annon,
+        Locator _loc, ForeignAttributesImpl _fa, String _name, WildcardImpl _wildcard ) {
+
+        this(_parent,_annon,_loc,_fa,_name);
+        setWildcard(_wildcard);
+    }
+
+    public AttGroupDeclImpl( SchemaDocumentImpl _parent, AnnotationImpl _annon,
+        Locator _loc, ForeignAttributesImpl _fa, String _name ) {
+
+        super(_parent,_annon,_loc,_fa,_name,false);
+    }
+
+
+    private WildcardImpl wildcard;
+    public void setWildcard( WildcardImpl wc ) { wildcard=wc; }
+    public XSWildcard getAttributeWildcard() { return wildcard; }
+
+    public XSAttributeUse getAttributeUse( String nsURI, String localName ) {
+        UName name = new UName(nsURI,localName);
+        XSAttributeUse o=null;
+
+        Iterator itr = iterateAttGroups();
+        while(itr.hasNext() && o==null)
+            o = ((XSAttGroupDecl)itr.next()).getAttributeUse(nsURI,localName);
+
+        if(o==null)     o = attributes.get(name);
+
+        return o;
+    }
+
+    public void redefine( AttGroupDeclImpl ag ) {
+        for (Iterator itr = attGroups.iterator(); itr.hasNext();) {
+            DelayedRef.AttGroup r = (DelayedRef.AttGroup) itr.next();
+            r.redefine(ag);
+        }
+    }
+
+    public void visit( XSVisitor visitor ) {
+        visitor.attGroupDecl(this);
+    }
+    public Object apply( XSFunction function ) {
+        return function.attGroupDecl(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributeDeclImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributeDeclImpl.java
new file mode 100644
index 0000000..1b786b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributeDeclImpl.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XmlString;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+public class AttributeDeclImpl extends DeclarationImpl implements XSAttributeDecl, Ref.Attribute
+{
+    public AttributeDeclImpl( SchemaDocumentImpl owner,
+        String _targetNamespace, String _name,
+        AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa, boolean _anonymous,
+        XmlString _defValue, XmlString _fixedValue,
+        Ref.SimpleType _type ) {
+
+        super(owner,_annon,_loc,_fa,_targetNamespace,_name,_anonymous);
+
+        if(_name==null) // assertion failed.
+            throw new IllegalArgumentException();
+
+        this.defaultValue = _defValue;
+        this.fixedValue = _fixedValue;
+        this.type = _type;
+    }
+
+    private final Ref.SimpleType type;
+    public XSSimpleType getType() { return type.getType(); }
+
+    private final XmlString defaultValue;
+    public XmlString getDefaultValue() { return defaultValue; }
+
+    private final XmlString fixedValue;
+    public XmlString getFixedValue() { return fixedValue; }
+
+    public void visit( XSVisitor visitor ) {
+        visitor.attributeDecl(this);
+    }
+    public Object apply( XSFunction function ) {
+        return function.attributeDecl(this);
+    }
+
+
+    // Ref.Attribute implementation
+    public XSAttributeDecl getAttribute() { return this; }
+ }
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributeUseImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributeUseImpl.java
new file mode 100644
index 0000000..a5aad56
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributeUseImpl.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XmlString;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+public class AttributeUseImpl extends ComponentImpl implements XSAttributeUse
+{
+    public AttributeUseImpl( SchemaDocumentImpl owner, AnnotationImpl ann, Locator loc, ForeignAttributesImpl fa, Ref.Attribute _decl,
+        XmlString def, XmlString fixed, boolean req ) {
+
+        super(owner,ann,loc,fa);
+
+        this.att = _decl;
+        this.defaultValue = def;
+        this.fixedValue = fixed;
+        this.required = req;
+    }
+
+    private final Ref.Attribute att;
+    public XSAttributeDecl getDecl() { return att.getAttribute(); }
+
+    private final XmlString defaultValue;
+    public XmlString getDefaultValue() {
+        if( defaultValue!=null )    return defaultValue;
+        else                        return getDecl().getDefaultValue();
+    }
+
+    private final XmlString fixedValue;
+    public XmlString getFixedValue() {
+        if( fixedValue!=null )      return fixedValue;
+        else                        return getDecl().getFixedValue();
+    }
+
+    private final boolean required;
+    public boolean isRequired() { return required; }
+
+    public Object apply( XSFunction f ) {
+        return f.attributeUse(this);
+    }
+    public void visit( XSVisitor v ) {
+        v.attributeUse(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributesHolder.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributesHolder.java
new file mode 100644
index 0000000..6116c76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/AttributesHolder.java
@@ -0,0 +1,124 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import org.xml.sax.Locator;
+
+import java.util.AbstractSet;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeMap;
+
+public abstract class AttributesHolder extends DeclarationImpl {
+
+    protected AttributesHolder( SchemaDocumentImpl _parent, AnnotationImpl _annon,
+        Locator loc, ForeignAttributesImpl _fa, String _name, boolean _anonymous ) {
+
+        super(_parent,_annon,loc,_fa,_parent.getTargetNamespace(),_name,_anonymous);
+    }
+
+    /** set the local wildcard. */
+    public abstract void setWildcard(WildcardImpl wc);
+
+    /**
+     * Local attribute use.
+     * It has to be {@link TreeMap} or otherwise we cannot guarantee
+     * the order of iteration.
+     */
+    protected final Map<UName,AttributeUseImpl> attributes = new TreeMap<UName,AttributeUseImpl>(UName.comparator);
+    public void addAttributeUse( UName name, AttributeUseImpl a ) {
+        attributes.put( name, a );
+    }
+    /** prohibited attributes. */
+    protected final Set<UName> prohibitedAtts = new HashSet<UName>();
+    public void addProhibitedAttribute( UName name ) {
+        prohibitedAtts.add(name);
+    }
+    public List<XSAttributeUse> getAttributeUses() {
+        // TODO: this is fairly inefficient
+        List<XSAttributeUse> v = new ArrayList<XSAttributeUse>();
+        v.addAll(attributes.values());
+        for( XSAttGroupDecl agd : getAttGroups() )
+            v.addAll(agd.getAttributeUses());
+        return v;
+    }
+    public Iterator<XSAttributeUse> iterateAttributeUses() {
+        return getAttributeUses().iterator();
+    }
+
+
+
+    public XSAttributeUse getDeclaredAttributeUse( String nsURI, String localName ) {
+        return attributes.get(new UName(nsURI,localName));
+    }
+
+    public Iterator<AttributeUseImpl> iterateDeclaredAttributeUses() {
+        return attributes.values().iterator();
+    }
+
+    public Collection<AttributeUseImpl> getDeclaredAttributeUses() {
+        return attributes.values();
+    }
+
+
+    /** {@link Ref.AttGroup}s that are directly refered from this. */
+    protected final Set<Ref.AttGroup> attGroups = new HashSet<Ref.AttGroup>();
+
+    public void addAttGroup( Ref.AttGroup a ) { attGroups.add(a); }
+
+    // Iterates all AttGroups which are directly referenced from this component
+    // this does not iterate att groups referenced from the base type
+    public Iterator<XSAttGroupDecl> iterateAttGroups() {
+        return new Iterator<XSAttGroupDecl>() {
+            private final Iterator<Ref.AttGroup> itr = attGroups.iterator();
+            public boolean hasNext() { return itr.hasNext(); }
+            public XSAttGroupDecl next() {
+                return itr.next().get();
+            }
+            public void remove() { itr.remove(); }
+        };
+    }
+
+    public Set<XSAttGroupDecl> getAttGroups() {
+        return new AbstractSet<XSAttGroupDecl>() {
+            public Iterator<XSAttGroupDecl> iterator() {
+                return iterateAttGroups();
+            }
+
+            public int size() {
+                return attGroups.size();
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ComplexTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ComplexTypeImpl.java
new file mode 100644
index 0000000..81e90c4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ComplexTypeImpl.java
@@ -0,0 +1,250 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.impl.parser.DelayedRef;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.impl.util.ConcatIterator;
+import com.sun.xml.internal.xsom.impl.util.FilterIterator;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Iterator;
+
+public class ComplexTypeImpl extends AttributesHolder implements XSComplexType, Ref.ComplexType
+{
+    public ComplexTypeImpl( SchemaDocumentImpl _parent,
+        AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+        String _name, boolean _anonymous,
+
+        boolean _abstract, int _derivationMethod,
+        Ref.Type _base, int _final, int _block, boolean _mixed ) {
+
+        super(_parent,_annon,_loc,_fa,_name,_anonymous);
+
+        if(_base==null)
+            throw new IllegalArgumentException();
+
+        this._abstract = _abstract;
+        this.derivationMethod = _derivationMethod;
+        this.baseType = _base;
+        this.finalValue = _final;
+        this.blockValue = _block;
+        this.mixed = _mixed;
+    }
+
+    public XSComplexType asComplexType(){ return this; }
+
+    public boolean isDerivedFrom(XSType t) {
+        XSType x = this;
+        while(true) {
+            if(t==x)
+                return true;
+            XSType s = x.getBaseType();
+            if(s==x)
+                return false;
+            x = s;
+        }
+    }
+
+    public XSSimpleType  asSimpleType()    { return null; }
+    public final boolean isSimpleType() { return false; }
+    public final boolean isComplexType(){ return true; }
+
+    private int derivationMethod;
+    public int getDerivationMethod() { return derivationMethod; }
+
+    private Ref.Type baseType;
+    public XSType getBaseType() { return baseType.getType(); }
+
+    /**
+     * Called when this complex type redefines the specified complex type.
+     */
+    public void redefine( ComplexTypeImpl ct ) {
+        if( baseType instanceof DelayedRef )
+            ((DelayedRef)baseType).redefine(ct);
+        else
+            this.baseType = ct;
+        ct.redefinedBy = this;
+        redefiningCount = (short)(ct.redefiningCount+1);
+    }
+
+    /**
+     * Number of times this component redefines other components.
+     */
+    private short redefiningCount = 0;
+
+    private ComplexTypeImpl redefinedBy = null;
+
+    public XSComplexType getRedefinedBy() {
+        return redefinedBy;
+    }
+
+    public int getRedefinedCount() {
+        int i=0;
+        for( ComplexTypeImpl ct=this.redefinedBy; ct!=null; ct=ct.redefinedBy)
+            i++;
+        return i;
+    }
+
+
+    private XSElementDecl scope;
+    public XSElementDecl getScope() { return scope; }
+    public void setScope( XSElementDecl _scope ) { this.scope=_scope; }
+
+    private final boolean _abstract;
+    public boolean isAbstract() { return _abstract; }
+
+    private WildcardImpl localAttWildcard;
+    /**
+     * Set the local attribute wildcard.
+     */
+    public void setWildcard( WildcardImpl wc ) {
+        this.localAttWildcard = wc;
+    }
+    public XSWildcard getAttributeWildcard() {
+        WildcardImpl complete = localAttWildcard;
+
+        Iterator itr = iterateAttGroups();
+        while( itr.hasNext() ) {
+            WildcardImpl w = (WildcardImpl)((XSAttGroupDecl)itr.next()).getAttributeWildcard();
+
+            if(w==null)     continue;
+
+            if(complete==null)
+                complete = w;
+            else
+                // TODO: the spec says it's intersection,
+                // but I think it has to be union.
+                complete = complete.union(ownerDocument,w);
+        }
+
+        if( getDerivationMethod()==RESTRICTION )    return complete;
+
+        WildcardImpl base=null;
+        XSType baseType = getBaseType();
+        if(baseType.asComplexType()!=null)
+            base = (WildcardImpl)baseType.asComplexType().getAttributeWildcard();
+
+        if(complete==null)  return base;
+        if(base==null)      return complete;
+
+        return complete.union(ownerDocument,base);
+    }
+
+    private final int finalValue;
+    public boolean isFinal( int derivationMethod ) {
+        return (finalValue&derivationMethod)!=0;
+    }
+
+    private final int blockValue;
+    public boolean isSubstitutionProhibited( int method ) {
+        return (blockValue&method)!=0;
+    }
+
+
+    private Ref.ContentType contentType;
+    public void setContentType( Ref.ContentType v ) { contentType = v; }
+    public XSContentType getContentType() { return contentType.getContentType(); }
+
+    private XSContentType explicitContent;
+    public void setExplicitContent( XSContentType v ) {
+        this.explicitContent = v;
+    }
+    public XSContentType getExplicitContent() { return explicitContent; }
+
+    private final boolean mixed;
+    public boolean isMixed() { return mixed; }
+
+
+
+
+    public XSAttributeUse getAttributeUse( String nsURI, String localName ) {
+        UName name = new UName(nsURI,localName);
+
+        if(prohibitedAtts.contains(name))       return null;
+
+        XSAttributeUse o = attributes.get(name);
+
+
+        if(o==null) {
+            Iterator itr = iterateAttGroups();
+            while(itr.hasNext() && o==null)
+                o = ((XSAttGroupDecl)itr.next()).getAttributeUse(nsURI,localName);
+        }
+
+        if(o==null) {
+            XSType base = getBaseType();
+            if(base.asComplexType()!=null)
+                o = base.asComplexType().getAttributeUse(nsURI,localName);
+        }
+
+        return o;
+    }
+
+    public Iterator iterateAttributeUses() {
+
+        XSComplexType baseType = getBaseType().asComplexType();
+
+        if( baseType==null )    return super.iterateAttributeUses();
+
+        return new ConcatIterator(
+            new FilterIterator(baseType.iterateAttributeUses()) {
+                protected boolean allows( Object o ) {
+                    XSAttributeDecl u = ((XSAttributeUse)o).getDecl();
+                    UName n = new UName(u.getTargetNamespace(),u.getName());
+                    return !prohibitedAtts.contains(n);
+                }
+            },
+            super.iterateAttributeUses() );
+    }
+
+
+    public XSType[] listSubstitutables() {
+        return Util.listSubstitutables(this);
+    }
+
+
+
+    public void visit( XSVisitor visitor ) {
+        visitor.complexType(this);
+    }
+    public <T> T apply( XSFunction<T> function ) {
+        return function.complexType(this);
+    }
+
+    // Ref.ComplexType implementation
+    public XSComplexType getType() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ComponentImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ComponentImpl.java
new file mode 100644
index 0000000..546cb85
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ComponentImpl.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.parser.SchemaDocument;
+import org.xml.sax.Locator;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+public abstract class ComponentImpl implements XSComponent
+{
+    protected ComponentImpl( SchemaDocumentImpl _owner, AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl fa ) {
+        this.ownerDocument = _owner;
+        this.annotation = _annon;
+        this.locator = _loc;
+        this.foreignAttributes = fa;
+    }
+
+    protected final SchemaDocumentImpl ownerDocument;
+    public SchemaImpl getOwnerSchema() {
+        if(ownerDocument==null)
+            return null;
+        else
+            return ownerDocument.getSchema();
+    }
+
+    public SchemaDocument getSourceDocument() {
+        return ownerDocument;
+    }
+
+    private final AnnotationImpl annotation;
+    public final XSAnnotation getAnnotation() { return annotation; }
+
+    private final Locator locator;
+    public final Locator getLocator() { return locator; }
+
+    /**
+     * Either {@link ForeignAttributesImpl} or {@link List}.
+     *
+     * Initially it's {@link ForeignAttributesImpl}, but it's lazily turned into
+     * a list when necessary.
+     */
+    private Object foreignAttributes;
+
+    public List getForeignAttributes() {
+        Object t = foreignAttributes;
+
+        if(t==null)
+            return Collections.EMPTY_LIST;
+
+        if(t instanceof List)
+            return (List)t;
+
+        t = foreignAttributes = convertToList((ForeignAttributesImpl)t);
+        return (List)t;
+    }
+
+    public String getForeignAttribute(String nsUri, String localName) {
+        for( ForeignAttributesImpl fa : (List<ForeignAttributesImpl>)getForeignAttributes() ) {
+            String v = fa.getValue(nsUri,localName);
+            if(v!=null) return v;
+        }
+        return null;
+    }
+
+    private List convertToList(ForeignAttributesImpl fa) {
+        List lst = new ArrayList();
+        while(fa!=null) {
+            lst.add(fa);
+            fa = fa.next;
+        }
+        return Collections.unmodifiableList(lst);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Const.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Const.java
new file mode 100644
index 0000000..49cc7b7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Const.java
@@ -0,0 +1,32 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+public class Const
+{
+    /** Namespace URI of XML Schema. */
+    public static final String schemaNamespace = "http://www.w3.org/2001/XMLSchema";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ContentTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ContentTypeImpl.java
new file mode 100644
index 0000000..5625ebb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ContentTypeImpl.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSContentType;
+
+/**
+ * Marker interface that says this implementation
+ * implements XSContentType.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface ContentTypeImpl extends Ref.ContentType, XSContentType {
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/DeclarationImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/DeclarationImpl.java
new file mode 100644
index 0000000..7b6ee46
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/DeclarationImpl.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSDeclaration;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.util.NameGetter;
+import org.xml.sax.Locator;
+
+abstract class DeclarationImpl extends ComponentImpl implements XSDeclaration
+{
+    DeclarationImpl( SchemaDocumentImpl owner,
+        AnnotationImpl _annon, Locator loc, ForeignAttributesImpl fa,
+        String _targetNamespace, String _name,    boolean _anonymous ) {
+
+        super(owner,_annon,loc,fa);
+        this.targetNamespace = _targetNamespace;
+        this.name = _name;
+        this.anonymous = _anonymous;
+    }
+
+    private final String name;
+    public String getName() { return name; }
+
+    private final String targetNamespace;
+    public String getTargetNamespace() { return targetNamespace; }
+
+    private final boolean anonymous;
+    /** @deprecated */
+    public boolean isAnonymous() { return anonymous; }
+
+    public final boolean isGlobal() { return !isAnonymous(); }
+    public final boolean isLocal() { return isAnonymous(); }
+
+
+    public String toString() {
+        return NameGetter.get(this)+" "+getName();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ElementDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ElementDecl.java
new file mode 100644
index 0000000..6213726
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ElementDecl.java
@@ -0,0 +1,228 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XmlString;
+import com.sun.xml.internal.xsom.impl.parser.PatcherManager;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermFunctionWithParam;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Collections;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+public class ElementDecl extends DeclarationImpl implements XSElementDecl, Ref.Term
+{
+    public ElementDecl( PatcherManager reader, SchemaDocumentImpl owner,
+        AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl fa,
+        String _tns, String _name, boolean _anonymous,
+
+        XmlString _defv, XmlString _fixedv,
+        boolean _nillable, boolean _abstract,
+        Ref.Type _type, Ref.Element _substHead,
+        int _substDisallowed, int _substExcluded,
+        List<IdentityConstraintImpl> idConstraints ) {
+
+        super(owner,_annon,_loc,fa,_tns,_name,_anonymous);
+
+        this.defaultValue = _defv;
+        this.fixedValue = _fixedv;
+        this.nillable = _nillable;
+        this._abstract = _abstract;
+        this.type = _type;
+        this.substHead = _substHead;
+        this.substDisallowed = _substDisallowed;
+        this.substExcluded = _substExcluded;
+        this.idConstraints = Collections.unmodifiableList((List<? extends XSIdentityConstraint>)idConstraints);
+
+        for (IdentityConstraintImpl idc : idConstraints)
+            idc.setParent(this);
+
+        if(type==null)
+            throw new IllegalArgumentException();
+    }
+
+    private XmlString defaultValue;
+    public XmlString getDefaultValue() { return defaultValue; }
+
+    private XmlString fixedValue;
+    public XmlString getFixedValue() { return fixedValue; }
+
+    private boolean nillable;
+    public boolean isNillable() { return nillable; }
+
+    private boolean _abstract;
+    public boolean isAbstract() { return _abstract; }
+
+    private Ref.Type type;
+    public XSType getType() { return type.getType(); }
+
+    private Ref.Element substHead;
+    public XSElementDecl getSubstAffiliation() {
+        if(substHead==null)     return null;
+        return substHead.get();
+    }
+
+    private int substDisallowed;
+    public boolean isSubstitutionDisallowed( int method ) {
+        return (substDisallowed&method)!=0;
+    }
+
+    private int substExcluded;
+    public boolean isSubstitutionExcluded( int method ) {
+        return (substExcluded&method)!=0;
+    }
+
+    private final List<XSIdentityConstraint> idConstraints;
+    public List<XSIdentityConstraint> getIdentityConstraints() {
+        return idConstraints;
+    }
+
+
+    /**
+     * @deprecated
+     */
+    public XSElementDecl[] listSubstitutables() {
+        Set<? extends XSElementDecl> s = getSubstitutables();
+        return s.toArray(new XSElementDecl[s.size()]);
+    }
+
+    /** Set that represents element decls that can substitute this element. */
+    private Set<XSElementDecl> substitutables = null;
+
+    /** Unmodifieable view of {@link #substitutables}. */
+    private Set<XSElementDecl> substitutablesView = null;
+
+    public Set<? extends XSElementDecl> getSubstitutables() {
+        if( substitutables==null ) {
+            // if the field is null by the time this method
+            // is called, it means this element is substitutable by itself only.
+            substitutables = substitutablesView = Collections.singleton((XSElementDecl)this);
+        }
+        return substitutablesView;
+    }
+
+    protected void addSubstitutable( ElementDecl decl ) {
+        if( substitutables==null ) {
+            substitutables = new HashSet<XSElementDecl>();
+            substitutables.add(this);
+            substitutablesView = Collections.unmodifiableSet(substitutables);
+        }
+        substitutables.add(decl);
+    }
+
+
+    public void updateSubstitutabilityMap() {
+        ElementDecl parent = this;
+        XSType type = this.getType();
+
+        boolean rused = false;
+        boolean eused = false;
+
+        while( (parent=(ElementDecl)parent.getSubstAffiliation())!=null ) {
+
+            if(parent.isSubstitutionDisallowed(XSType.SUBSTITUTION))
+                continue;
+
+            boolean rd = parent.isSubstitutionDisallowed(XSType.RESTRICTION);
+            boolean ed = parent.isSubstitutionDisallowed(XSType.EXTENSION);
+
+            if( (rd && rused) || ( ed && eused ) )   continue;
+
+            XSType parentType = parent.getType();
+            while(type!=parentType) {
+                if(type.getDerivationMethod()==XSType.RESTRICTION)  rused = true;
+                else                                                eused = true;
+
+                type = type.getBaseType();
+                if(type==null)  // parentType and type doesn't share the common base type. a bug in the schema.
+                    break;
+
+                if( type.isComplexType() ) {
+                    rd |= type.asComplexType().isSubstitutionProhibited(XSType.RESTRICTION);
+                    ed |= type.asComplexType().isSubstitutionProhibited(XSType.EXTENSION);
+                }
+            }
+
+            if( (rd && rused) || ( ed && eused ) )   continue;
+
+            // this element can substitute "parent"
+            parent.addSubstitutable(this);
+        }
+    }
+
+    public boolean canBeSubstitutedBy(XSElementDecl e) {
+        return getSubstitutables().contains(e);
+    }
+
+    public boolean isWildcard()                 { return false; }
+    public boolean isModelGroupDecl()           { return false; }
+    public boolean isModelGroup()               { return false; }
+    public boolean isElementDecl()              { return true; }
+
+    public XSWildcard asWildcard()              { return null; }
+    public XSModelGroupDecl asModelGroupDecl()  { return null; }
+    public XSModelGroup asModelGroup()          { return null; }
+    public XSElementDecl asElementDecl()        { return this; }
+
+
+
+
+    public void visit( XSVisitor visitor ) {
+        visitor.elementDecl(this);
+    }
+    public void visit( XSTermVisitor visitor ) {
+        visitor.elementDecl(this);
+    }
+    public Object apply( XSTermFunction function ) {
+        return function.elementDecl(this);
+    }
+
+    public <T,P> T apply(XSTermFunctionWithParam<T, P> function, P param) {
+        return function.elementDecl(this,param);
+    }
+
+    public Object apply( XSFunction function ) {
+        return function.elementDecl(this);
+    }
+
+
+    // Ref.Term implementation
+    public XSTerm getTerm() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/EmptyImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/EmptyImpl.java
new file mode 100644
index 0000000..0180390
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/EmptyImpl.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+
+/**
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class EmptyImpl extends ComponentImpl implements ContentTypeImpl {
+    public EmptyImpl() { super(null,null,null,null); }
+
+    public XSSimpleType asSimpleType()  { return null; }
+    public XSParticle asParticle()      { return null; }
+    public XSContentType asEmpty()      { return this; }
+
+    public Object apply( XSContentTypeFunction function ) {
+        return function.empty(this);
+    }
+    public Object apply( XSFunction function ) {
+        return function.empty(this);
+    }
+    public void visit( XSVisitor visitor ) {
+        visitor.empty(this);
+    }
+    public void visit( XSContentTypeVisitor visitor ) {
+        visitor.empty(this);
+    }
+
+    public XSContentType getContentType() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/FacetImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/FacetImpl.java
new file mode 100644
index 0000000..40997ba
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/FacetImpl.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XmlString;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+public class FacetImpl extends ComponentImpl implements XSFacet {
+    public FacetImpl( SchemaDocumentImpl owner, AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+        String _name, XmlString _value, boolean _fixed ) {
+
+        super(owner,_annon,_loc,_fa);
+
+        this.name = _name;
+        this.value = _value;
+        this.fixed = _fixed;
+    }
+
+    private final String name;
+    public String getName() { return name; }
+
+    private final XmlString value;
+    public XmlString getValue() { return value; }
+
+    private boolean fixed;
+    public boolean isFixed() { return fixed; }
+
+
+    public void visit( XSVisitor visitor ) {
+        visitor.facet(this);
+    }
+    public Object apply( XSFunction function ) {
+        return function.facet(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ForeignAttributesImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ForeignAttributesImpl.java
new file mode 100644
index 0000000..a6f346d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ForeignAttributesImpl.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.ForeignAttributes;
+import org.relaxng.datatype.ValidationContext;
+import org.xml.sax.Locator;
+import org.xml.sax.helpers.AttributesImpl;
+
+/**
+ * Remembers foreign attributes.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class ForeignAttributesImpl extends AttributesImpl implements ForeignAttributes {
+    private final ValidationContext context;
+    private final Locator locator;
+    /**
+     * {@link ForeignAttributes} forms a linked list.
+     */
+    final ForeignAttributesImpl next;
+
+    public ForeignAttributesImpl(ValidationContext context, Locator locator, ForeignAttributesImpl next) {
+        this.context = context;
+        this.locator = locator;
+        this.next = next;
+    }
+
+    public ValidationContext getContext() {
+        return context;
+    }
+
+    public Locator getLocator() {
+        return locator;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/IdentityConstraintImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/IdentityConstraintImpl.java
new file mode 100644
index 0000000..3e27d30
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/IdentityConstraintImpl.java
@@ -0,0 +1,116 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Collections;
+import java.util.List;
+
+/**
+ * {@link XSIdentityConstraint} implementation.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class IdentityConstraintImpl extends ComponentImpl implements XSIdentityConstraint, Ref.IdentityConstraint {
+
+    private XSElementDecl parent;
+    private final short category;
+    private final String name;
+    private final XSXPath selector;
+    private final List<XSXPath> fields;
+    private final Ref.IdentityConstraint refer;
+
+    public IdentityConstraintImpl(SchemaDocumentImpl _owner, AnnotationImpl _annon, Locator _loc,
+        ForeignAttributesImpl fa, short category, String name, XPathImpl selector,
+        List<XPathImpl> fields, Ref.IdentityConstraint refer) {
+
+        super(_owner, _annon, _loc, fa);
+        this.category = category;
+        this.name = name;
+        this.selector = selector;
+        selector.setParent(this);
+        this.fields = Collections.unmodifiableList((List<? extends XSXPath>)fields);
+        for( XPathImpl xp : fields )
+            xp.setParent(this);
+        this.refer = refer;
+    }
+
+
+    public void visit(XSVisitor visitor) {
+        visitor.identityConstraint(this);
+    }
+
+    public <T> T apply(XSFunction<T> function) {
+        return function.identityConstraint(this);
+    }
+
+    public void setParent(ElementDecl parent) {
+        this.parent = parent;
+        parent.getOwnerSchema().addIdentityConstraint(this);
+    }
+
+    public XSElementDecl getParent() {
+        return parent;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public String getTargetNamespace() {
+        return getParent().getTargetNamespace();
+    }
+
+    public short getCategory() {
+        return category;
+    }
+
+    public XSXPath getSelector() {
+        return selector;
+    }
+
+    public List<XSXPath> getFields() {
+        return fields;
+    }
+
+    public XSIdentityConstraint getReferencedKey() {
+        if(category==KEYREF)
+            return refer.get();
+        else
+            throw new IllegalStateException("not a keyref");
+    }
+
+    public XSIdentityConstraint get() {
+        return this;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ListSimpleTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ListSimpleTypeImpl.java
new file mode 100644
index 0000000..22a0399
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ListSimpleTypeImpl.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSVariety;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Set;
+
+public class ListSimpleTypeImpl extends SimpleTypeImpl implements XSListSimpleType
+{
+    public ListSimpleTypeImpl( SchemaDocumentImpl _parent,
+                               AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+                               String _name, boolean _anonymous, Set<XSVariety> finalSet,
+                               Ref.SimpleType _itemType ) {
+
+        super(_parent,_annon,_loc,_fa,_name,_anonymous, finalSet,
+            _parent.getSchema().parent.anySimpleType);
+
+        this.itemType = _itemType;
+    }
+
+    private final Ref.SimpleType itemType;
+    public XSSimpleType getItemType() { return itemType.getType(); }
+
+    public void visit( XSSimpleTypeVisitor visitor ) {
+        visitor.listSimpleType(this);
+    }
+    public Object apply( XSSimpleTypeFunction function ) {
+        return function.listSimpleType(this);
+    }
+
+    // list type by itself doesn't have any facet. */
+    public XSFacet getFacet( String name ) { return null; }
+
+    public XSVariety getVariety() { return XSVariety.LIST; }
+
+    public boolean isList() { return true; }
+    public XSListSimpleType asList() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ModelGroupDeclImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ModelGroupDeclImpl.java
new file mode 100644
index 0000000..02ece89
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ModelGroupDeclImpl.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermFunctionWithParam;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+public class ModelGroupDeclImpl extends DeclarationImpl implements XSModelGroupDecl, Ref.Term
+{
+    public ModelGroupDeclImpl( SchemaDocumentImpl owner,
+        AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+        String _targetNamespace, String _name,
+        ModelGroupImpl _modelGroup ) {
+
+        super(owner,_annon,_loc,_fa,_targetNamespace,_name,false);
+        this.modelGroup = _modelGroup;
+
+        if(modelGroup==null)
+            throw new IllegalArgumentException();
+    }
+
+    private final ModelGroupImpl modelGroup;
+    public XSModelGroup getModelGroup() { return modelGroup; }
+
+    /**
+     * This component is a redefinition of "oldMG". Fix up the internal state
+     * as such.
+     */
+    public void redefine( ModelGroupDeclImpl oldMG ) {
+        modelGroup.redefine(oldMG);
+    }
+
+
+    public void visit( XSVisitor visitor ) {
+        visitor.modelGroupDecl(this);
+    }
+    public void visit( XSTermVisitor visitor ) {
+        visitor.modelGroupDecl(this);
+    }
+    public Object apply( XSTermFunction function ) {
+        return function.modelGroupDecl(this);
+    }
+
+    public <T,P> T apply(XSTermFunctionWithParam<T, P> function, P param) {
+        return function.modelGroupDecl(this,param);
+    }
+
+    public Object apply( XSFunction function ) {
+        return function.modelGroupDecl(this);
+    }
+
+
+    public boolean isWildcard()                 { return false; }
+    public boolean isModelGroupDecl()           { return true; }
+    public boolean isModelGroup()               { return false; }
+    public boolean isElementDecl()              { return false; }
+
+    public XSWildcard asWildcard()              { return null; }
+    public XSModelGroupDecl asModelGroupDecl()  { return this; }
+    public XSModelGroup asModelGroup()          { return null; }
+    public XSElementDecl asElementDecl()        { return null; }
+
+
+    // Ref.Term implementation
+    public XSTerm getTerm() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ModelGroupImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ModelGroupImpl.java
new file mode 100644
index 0000000..1e8bb75
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ModelGroupImpl.java
@@ -0,0 +1,114 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermFunctionWithParam;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Arrays;
+import java.util.Iterator;
+
+public class ModelGroupImpl extends ComponentImpl implements XSModelGroup, Ref.Term
+{
+    public ModelGroupImpl( SchemaDocumentImpl owner, AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+                           Compositor _compositor, ParticleImpl[] _children ) {
+
+        super(owner,_annon,_loc,_fa);
+        this.compositor = _compositor;
+        this.children = _children;
+
+        if(compositor==null)
+            throw new IllegalArgumentException();
+        for( int i=children.length-1; i>=0; i-- )
+            if(children[i]==null)
+                throw new IllegalArgumentException();
+    }
+
+    private final ParticleImpl[] children;
+    public ParticleImpl getChild( int idx ) { return children[idx]; }
+    public int getSize() { return children.length; }
+
+    public ParticleImpl[] getChildren() { return children; }
+
+
+    private final Compositor compositor;
+    public Compositor getCompositor() { return compositor; }
+
+
+    public void redefine(ModelGroupDeclImpl oldMG) {
+        for (ParticleImpl p : children)
+            p.redefine(oldMG);
+    }
+
+    public Iterator<XSParticle> iterator() {
+        return Arrays.asList((XSParticle[])children).iterator();
+    }
+
+
+    public boolean isWildcard()                 { return false; }
+    public boolean isModelGroupDecl()           { return false; }
+    public boolean isModelGroup()               { return true; }
+    public boolean isElementDecl()              { return false; }
+
+    public XSWildcard asWildcard()              { return null; }
+    public XSModelGroupDecl asModelGroupDecl()  { return null; }
+    public XSModelGroup asModelGroup()          { return this; }
+    public XSElementDecl asElementDecl()        { return null; }
+
+
+
+    public void visit( XSVisitor visitor ) {
+        visitor.modelGroup(this);
+    }
+    public void visit( XSTermVisitor visitor ) {
+        visitor.modelGroup(this);
+    }
+    public Object apply( XSTermFunction function ) {
+        return function.modelGroup(this);
+    }
+
+    public <T,P> T apply(XSTermFunctionWithParam<T, P> function, P param) {
+        return function.modelGroup(this,param);
+    }
+
+    public Object apply( XSFunction function ) {
+        return function.modelGroup(this);
+    }
+
+    // Ref.Term implementation
+    public XSTerm getTerm() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/NotationImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/NotationImpl.java
new file mode 100644
index 0000000..d6d8d75
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/NotationImpl.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+/**
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class NotationImpl extends DeclarationImpl implements XSNotation {
+
+    public NotationImpl( SchemaDocumentImpl owner, AnnotationImpl _annon,
+        Locator _loc, ForeignAttributesImpl _fa, String _name,
+        String _publicId, String _systemId ) {
+        super(owner,_annon,_loc,_fa,owner.getTargetNamespace(),_name,false);
+
+        this.publicId = _publicId;
+        this.systemId = _systemId;
+    }
+
+    private final String publicId;
+    private final String systemId;
+
+    public String getPublicId() { return publicId; }
+    public String getSystemId() { return systemId; }
+
+    public void visit(XSVisitor visitor) {
+        visitor.notation(this);
+    }
+
+    public Object apply(XSFunction function) {
+        return function.notation(this);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ParticleImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ParticleImpl.java
new file mode 100644
index 0000000..7bebc20
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/ParticleImpl.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.impl.parser.DelayedRef;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.parser.SchemaDocument;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.List;
+
+public class ParticleImpl extends ComponentImpl implements XSParticle, ContentTypeImpl
+{
+    public ParticleImpl( SchemaDocumentImpl owner, AnnotationImpl _ann,
+        Ref.Term _term, Locator _loc, int _maxOccurs, int _minOccurs ) {
+
+        super(owner,_ann,_loc,null);
+        this.term = _term;
+        this.maxOccurs = _maxOccurs;
+        this.minOccurs = _minOccurs;
+    }
+    public ParticleImpl( SchemaDocumentImpl owner, AnnotationImpl _ann, Ref.Term _term, Locator _loc ) {
+        this(owner,_ann,_term,_loc,1,1);
+    }
+
+    private Ref.Term term;
+    public XSTerm getTerm() { return term.getTerm(); }
+
+    private int maxOccurs;
+    public int getMaxOccurs() { return maxOccurs; }
+
+    public boolean isRepeated() {
+        return maxOccurs!=0 && maxOccurs!=1;
+    }
+
+    private int minOccurs;
+    public int getMinOccurs() { return minOccurs; }
+
+
+    public void redefine(ModelGroupDeclImpl oldMG) {
+        if( term instanceof ModelGroupImpl ) {
+            ((ModelGroupImpl)term).redefine(oldMG);
+            return;
+        }
+        if( term instanceof DelayedRef.ModelGroup ) {
+            ((DelayedRef)term).redefine(oldMG);
+        }
+    }
+
+
+    public XSSimpleType asSimpleType()  { return null; }
+    public XSParticle asParticle()      { return this; }
+    public XSContentType asEmpty()      { return null; }
+
+
+    public final Object apply( XSFunction function ) {
+        return function.particle(this);
+    }
+    public final Object apply( XSContentTypeFunction function ) {
+        return function.particle(this);
+    }
+    public final void visit( XSVisitor visitor ) {
+        visitor.particle(this);
+    }
+    public final void visit( XSContentTypeVisitor visitor ) {
+        visitor.particle(this);
+    }
+
+    // Ref.ContentType implementation
+    public XSContentType getContentType() { return this; }
+
+    /**
+     * Foreign attribuets are considered to be on terms.
+     *
+     * REVISIT: is this a good design?
+     */
+    public List getForeignAttributes() {
+        return getTerm().getForeignAttributes();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Ref.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Ref.java
new file mode 100644
index 0000000..6f963ae
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Ref.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSType;
+
+/**
+ * Reference to other schema components.
+ *
+ * <p>
+ * There are mainly two different types of references. One is
+ * the direct reference, which is only possible when schema components
+ * are already available when references are made.
+ * The other is the lazy reference, which keeps references by names
+ * and later look for the component by name.
+ *
+ * <p>
+ * This class defines interfaces that define the behavior of such
+ * references and classes that implement direct reference semantics.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class Ref {
+
+    public static interface Term {
+        /** Obtains a reference as a term. */
+        XSTerm getTerm();
+    }
+
+    public static interface Type {
+        /** Obtains a reference as a type. */
+        XSType getType();
+    }
+
+    public static interface ContentType {
+        XSContentType getContentType();
+    }
+
+    public static interface SimpleType extends Ref.Type {
+        public XSSimpleType getType();
+    }
+
+    public static interface ComplexType extends Ref.Type {
+        public XSComplexType getType();
+    }
+
+    public static interface Attribute {
+        XSAttributeDecl getAttribute();
+    }
+
+    public static interface AttGroup {
+        XSAttGroupDecl get();
+    }
+
+    public static interface Element extends Term {
+        XSElementDecl get();
+    }
+
+    public static interface IdentityConstraint {
+        XSIdentityConstraint get();
+    }
+//
+//
+//    private static void _assert( boolean b ) {
+//        if(!b)
+//            throw new InternalError("assertion failed");
+//    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/RestrictionSimpleTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/RestrictionSimpleTypeImpl.java
new file mode 100644
index 0000000..3bc538a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/RestrictionSimpleTypeImpl.java
@@ -0,0 +1,102 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSVariety;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor;
+import org.xml.sax.Locator;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Set;
+
+public class RestrictionSimpleTypeImpl extends SimpleTypeImpl implements XSRestrictionSimpleType {
+
+    public RestrictionSimpleTypeImpl( SchemaDocumentImpl _parent,
+                                      AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+                                      String _name, boolean _anonymous, Set<XSVariety> finalSet,
+                                      Ref.SimpleType _baseType ) {
+
+        super( _parent, _annon, _loc, _fa, _name, _anonymous, finalSet, _baseType );
+    }
+
+
+    private final List<XSFacet> facets = new ArrayList<XSFacet>();
+    public void addFacet( XSFacet facet ) {
+        facets.add(facet);
+    }
+    public Iterator<XSFacet> iterateDeclaredFacets() {
+        return facets.iterator();
+    }
+
+    public Collection<? extends XSFacet> getDeclaredFacets() {
+        return facets;
+    }
+
+    public XSFacet getDeclaredFacet( String name ) {
+        int len = facets.size();
+        for( int i=0; i<len; i++ ) {
+            XSFacet f = facets.get(i);
+            if(f.getName().equals(name))
+                return f;
+        }
+        return null;
+    }
+
+    public List<XSFacet> getDeclaredFacets(String name) {
+        List<XSFacet> r = new ArrayList<XSFacet>();
+        for( XSFacet f : facets )
+            if(f.getName().equals(name))
+                r.add(f);
+        return r;
+    }
+
+    public XSFacet getFacet( String name ) {
+        XSFacet f = getDeclaredFacet(name);
+        if(f!=null)     return f;
+
+        // none was found on this datatype. check the base type.
+        return getSimpleBaseType().getFacet(name);
+    }
+
+    public XSVariety getVariety() { return getSimpleBaseType().getVariety(); }
+
+    public void visit( XSSimpleTypeVisitor visitor ) {
+        visitor.restrictionSimpleType(this);
+    }
+    public Object apply( XSSimpleTypeFunction function ) {
+        return function.restrictionSimpleType(this);
+    }
+
+    public boolean isRestriction() { return true; }
+    public XSRestrictionSimpleType asRestriction() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SchemaImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SchemaImpl.java
new file mode 100644
index 0000000..f1f60d9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SchemaImpl.java
@@ -0,0 +1,275 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.ForeignAttributes;
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.parser.SchemaDocument;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+public class SchemaImpl implements XSSchema
+{
+    public SchemaImpl(SchemaSetImpl _parent, Locator loc, String tns) {
+        if (tns == null)
+            // the empty string must be used.
+            throw new IllegalArgumentException();
+        this.targetNamespace = tns;
+        this.parent = _parent;
+        this.locator = loc;
+    }
+
+    public SchemaDocument getSourceDocument() {
+        return null;
+    }
+
+    protected final SchemaSetImpl parent;
+    public SchemaSetImpl getParent() {
+        return parent;
+    }
+
+    private final String targetNamespace;
+    public String getTargetNamespace() {
+        return targetNamespace;
+    }
+
+    public XSSchema getOwnerSchema() {
+        return this;
+    }
+
+    private XSAnnotation annotation;
+    public void setAnnotation(XSAnnotation a) {
+        annotation = a;
+    }
+    public XSAnnotation getAnnotation() {
+        return annotation;
+    }
+
+    // it's difficult to determine the source location for the schema
+    // component as one schema can be defined across multiple files.
+    // so this locator might not correctly reflect all the locations
+    // where the schema is defined.
+    // but partial information would be better than nothing.
+
+    private final Locator locator;
+    public Locator getLocator() {
+        return locator;
+    }
+
+
+    private final Map<String,XSAttributeDecl> atts = new HashMap<String,XSAttributeDecl>();
+    private final Map<String,XSAttributeDecl> attsView = Collections.unmodifiableMap(atts);
+    public void addAttributeDecl(XSAttributeDecl newDecl) {
+        atts.put(newDecl.getName(), newDecl);
+    }
+    public Map<String,XSAttributeDecl> getAttributeDecls() {
+        return attsView;
+    }
+    public XSAttributeDecl getAttributeDecl(String name) {
+        return atts.get(name);
+    }
+    public Iterator<XSAttributeDecl> iterateAttributeDecls() {
+        return atts.values().iterator();
+    }
+
+    private final Map<String,XSElementDecl> elems = new HashMap<String,XSElementDecl>();
+    private final Map<String,XSElementDecl> elemsView = Collections.unmodifiableMap(elems);
+    public void addElementDecl(XSElementDecl newDecl) {
+        elems.put(newDecl.getName(), newDecl);
+    }
+    public Map<String,XSElementDecl> getElementDecls() {
+        return elemsView;
+    }
+    public XSElementDecl getElementDecl(String name) {
+        return elems.get(name);
+    }
+    public Iterator<XSElementDecl> iterateElementDecls() {
+        return elems.values().iterator();
+    }
+
+    private final Map<String,XSAttGroupDecl> attGroups = new HashMap<String,XSAttGroupDecl>();
+    private final Map<String,XSAttGroupDecl> attGroupsView = Collections.unmodifiableMap(attGroups);
+    public void addAttGroupDecl(XSAttGroupDecl newDecl) {
+        attGroups.put(newDecl.getName(), newDecl);
+    }
+    public Map<String,XSAttGroupDecl> getAttGroupDecls() {
+        return attGroupsView;
+    }
+    public XSAttGroupDecl getAttGroupDecl(String name) {
+        return attGroups.get(name);
+    }
+    public Iterator<XSAttGroupDecl> iterateAttGroupDecls() {
+        return attGroups.values().iterator();
+    }
+
+
+    private final Map<String,XSNotation> notations = new HashMap<String,XSNotation>();
+    private final Map<String,XSNotation> notationsView = Collections.unmodifiableMap(notations);
+    public void addNotation( XSNotation newDecl ) {
+        notations.put( newDecl.getName(), newDecl );
+    }
+    public Map<String,XSNotation> getNotations() {
+        return notationsView;
+    }
+    public XSNotation getNotation( String name ) {
+        return notations.get(name);
+    }
+    public Iterator<XSNotation> iterateNotations() {
+        return notations.values().iterator();
+    }
+
+    private final Map<String,XSModelGroupDecl> modelGroups = new HashMap<String,XSModelGroupDecl>();
+    private final Map<String,XSModelGroupDecl> modelGroupsView = Collections.unmodifiableMap(modelGroups);
+    public void addModelGroupDecl(XSModelGroupDecl newDecl) {
+        modelGroups.put(newDecl.getName(), newDecl);
+    }
+    public Map<String,XSModelGroupDecl> getModelGroupDecls() {
+        return modelGroupsView;
+    }
+    public XSModelGroupDecl getModelGroupDecl(String name) {
+        return modelGroups.get(name);
+    }
+    public Iterator<XSModelGroupDecl> iterateModelGroupDecls() {
+        return modelGroups.values().iterator();
+    }
+
+
+    private final Map<String,XSIdentityConstraint> idConstraints = new HashMap<String,XSIdentityConstraint>();
+    private final Map<String,XSIdentityConstraint> idConstraintsView = Collections.unmodifiableMap(idConstraints);
+
+    protected void addIdentityConstraint(IdentityConstraintImpl c) {
+        idConstraints.put(c.getName(),c);
+    }
+
+    public Map<String, XSIdentityConstraint> getIdentityConstraints() {
+        return idConstraintsView;
+    }
+
+    public XSIdentityConstraint getIdentityConstraint(String localName) {
+        return idConstraints.get(localName);
+    }
+
+    private final Map<String,XSType> allTypes = new HashMap<String,XSType>();
+    private final Map<String,XSType> allTypesView = Collections.unmodifiableMap(allTypes);
+
+    private final Map<String,XSSimpleType> simpleTypes = new HashMap<String,XSSimpleType>();
+    private final Map<String,XSSimpleType> simpleTypesView = Collections.unmodifiableMap(simpleTypes);
+    public void addSimpleType(XSSimpleType newDecl) {
+        simpleTypes.put(newDecl.getName(), newDecl);
+        allTypes.put(newDecl.getName(), newDecl);
+    }
+    public Map<String,XSSimpleType> getSimpleTypes() {
+        return simpleTypesView;
+    }
+    public XSSimpleType getSimpleType(String name) {
+        return simpleTypes.get(name);
+    }
+    public Iterator<XSSimpleType> iterateSimpleTypes() {
+        return simpleTypes.values().iterator();
+    }
+
+    private final Map<String,XSComplexType> complexTypes = new HashMap<String,XSComplexType>();
+    private final Map<String,XSComplexType> complexTypesView = Collections.unmodifiableMap(complexTypes);
+    public void addComplexType(XSComplexType newDecl) {
+        complexTypes.put(newDecl.getName(), newDecl);
+        allTypes.put(newDecl.getName(), newDecl);
+    }
+    public Map<String,XSComplexType> getComplexTypes() {
+        return complexTypesView;
+    }
+    public XSComplexType getComplexType(String name) {
+        return complexTypes.get(name);
+    }
+    public Iterator<XSComplexType> iterateComplexTypes() {
+        return complexTypes.values().iterator();
+    }
+
+    public Map<String,XSType> getTypes() {
+        return allTypesView;
+    }
+    public XSType getType(String name) {
+        return allTypes.get(name);
+    }
+    public Iterator<XSType> iterateTypes() {
+        return allTypes.values().iterator();
+    }
+
+    public void visit(XSVisitor visitor) {
+        visitor.schema(this);
+    }
+
+    public Object apply(XSFunction function) {
+        return function.schema(this);
+    }
+
+    /**
+     * Lazily created list of {@link ForeignAttributesImpl}s.
+     */
+    private List<ForeignAttributes> foreignAttributes = null;
+    private List<ForeignAttributes> readOnlyForeignAttributes = null;
+
+    public void addForeignAttributes(ForeignAttributesImpl fa) {
+        if(foreignAttributes==null)
+            foreignAttributes = new ArrayList<ForeignAttributes>();
+        foreignAttributes.add(fa);
+    }
+
+    public List<ForeignAttributes> getForeignAttributes() {
+        if(readOnlyForeignAttributes==null) {
+            if(foreignAttributes==null)
+                readOnlyForeignAttributes = Collections.EMPTY_LIST;
+            else
+                readOnlyForeignAttributes = Collections.unmodifiableList(foreignAttributes);
+        }
+        return readOnlyForeignAttributes;
+    }
+
+    public String getForeignAttribute(String nsUri, String localName) {
+        for( ForeignAttributes fa : getForeignAttributes() ) {
+            String v = fa.getValue(nsUri,localName);
+            if(v!=null) return v;
+        }
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SchemaSetImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SchemaSetImpl.java
new file mode 100644
index 0000000..4212bc6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SchemaSetImpl.java
@@ -0,0 +1,385 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+import com.sun.xml.internal.xsom.XSVariety;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.NoSuchElementException;
+import java.util.Vector;
+
+public class SchemaSetImpl implements XSSchemaSet
+{
+    private final Map<String,XSSchema> schemas = new HashMap<String,XSSchema>();
+    private final Vector<XSSchema> schemas2 = new Vector<XSSchema>();
+    private final List<XSSchema> readonlySchemaList = Collections.unmodifiableList(schemas2);
+
+    /**
+     * Gets a reference to the existing schema or creates a new one
+     * if none exists yet.
+     */
+    public SchemaImpl createSchema(String targetNamespace, Locator location) {
+        SchemaImpl obj = (SchemaImpl)schemas.get(targetNamespace);
+        if (obj == null) {
+            obj = new SchemaImpl(this, location, targetNamespace);
+            schemas.put(targetNamespace, obj);
+            schemas2.add(obj);
+        }
+        return obj;
+    }
+
+    public int getSchemaSize() {
+        return schemas.size();
+    }
+    public XSSchema getSchema(String targetNamespace) {
+        return schemas.get(targetNamespace);
+    }
+    public XSSchema getSchema(int idx) {
+        return schemas2.get(idx);
+    }
+    public Iterator<XSSchema> iterateSchema() {
+        return schemas2.iterator();
+    }
+
+    public final Collection<XSSchema> getSchemas() {
+        return readonlySchemaList;
+    }
+
+    public XSType getType(String ns, String localName) {
+        XSSchema schema = getSchema(ns);
+        if(schema==null)    return null;
+
+        return schema.getType(localName);
+    }
+
+    public XSSimpleType getSimpleType( String ns, String localName ) {
+        XSSchema schema = getSchema(ns);
+        if(schema==null)    return null;
+
+        return schema.getSimpleType(localName);
+    }
+
+    public XSElementDecl getElementDecl( String ns, String localName ) {
+        XSSchema schema = getSchema(ns);
+        if(schema==null)    return null;
+
+        return schema.getElementDecl(localName);
+    }
+
+    public XSAttributeDecl getAttributeDecl( String ns, String localName ) {
+        XSSchema schema = getSchema(ns);
+        if(schema==null)    return null;
+
+        return schema.getAttributeDecl(localName);
+    }
+
+    public XSModelGroupDecl getModelGroupDecl( String ns, String localName ) {
+        XSSchema schema = getSchema(ns);
+        if(schema==null)    return null;
+
+        return schema.getModelGroupDecl(localName);
+    }
+
+    public XSAttGroupDecl getAttGroupDecl( String ns, String localName ) {
+        XSSchema schema = getSchema(ns);
+        if(schema==null)    return null;
+
+        return schema.getAttGroupDecl(localName);
+    }
+
+    public XSComplexType getComplexType( String ns, String localName ) {
+        XSSchema schema = getSchema(ns);
+        if(schema==null)    return null;
+
+        return schema.getComplexType(localName);
+    }
+
+    public XSIdentityConstraint getIdentityConstraint(String ns, String localName) {
+        XSSchema schema = getSchema(ns);
+        if(schema==null)    return null;
+
+        return schema.getIdentityConstraint(localName);
+    }
+
+    private abstract class MultiSchemaIterator<T> implements Iterator<T> {
+        private Iterator<XSSchema> sitr = iterateSchema();
+        private Iterator<T> citr = null;
+        /** The object to be returned from the next method. */
+        private T next;
+
+        public void remove() { throw new UnsupportedOperationException(); }
+        public boolean hasNext() {
+            getNext();
+            return next!=null;
+        }
+        public T next() {
+            getNext();
+            T r = next;
+            next = null;
+            return r;
+        }
+        private void getNext() {
+            if(next!=null)  return;
+
+            if(citr!=null && citr.hasNext()) {
+                next = citr.next();
+                return;
+            }
+            // citr is empty
+            if(sitr.hasNext()) {
+                citr = nextIterator(sitr.next());
+                getNext();
+            }
+            // else
+            //      no more object
+        }
+
+        protected abstract Iterator<T> nextIterator( XSSchema s );
+    }
+
+    public Iterator iterateElementDecls() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.iterateElementDecls();
+            }
+        };
+    }
+
+    public Iterator iterateTypes() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.iterateTypes();
+            }
+        };
+    }
+
+    public Iterator iterateAttributeDecls() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.iterateAttributeDecls();
+            }
+        };
+    }
+    public Iterator iterateAttGroupDecls() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.iterateAttGroupDecls();
+            }
+        };
+    }
+    public Iterator iterateModelGroupDecls() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.iterateModelGroupDecls();
+            }
+        };
+    }
+    public Iterator iterateSimpleTypes() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.iterateSimpleTypes();
+            }
+        };
+    }
+    public Iterator iterateComplexTypes() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.iterateComplexTypes();
+            }
+        };
+    }
+    public Iterator iterateNotations() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.iterateNotations();
+            }
+        };
+    }
+
+    public Iterator<XSIdentityConstraint> iterateIdentityConstraints() {
+        return new MultiSchemaIterator() {
+            protected Iterator nextIterator( XSSchema xs ) {
+                return xs.getIdentityConstraints().values().iterator();
+            }
+        };
+    }
+
+
+    public final EmptyImpl empty = new EmptyImpl();
+    public XSContentType getEmpty() { return empty; }
+
+    public XSSimpleType getAnySimpleType() { return anySimpleType; }
+    public final AnySimpleType anySimpleType = new AnySimpleType();
+    private class AnySimpleType extends DeclarationImpl
+        implements XSRestrictionSimpleType, Ref.SimpleType {
+
+        AnySimpleType() {
+            super(null,null,null,null,"http://www.w3.org/2001/XMLSchema","anySimpleType",false);
+        }
+        public SchemaImpl getOwnerSchema() {
+            return createSchema("http://www.w3.org/2001/XMLSchema",null);
+        }
+        public XSSimpleType asSimpleType() { return this; }
+        public XSComplexType asComplexType() { return null; }
+
+        public boolean isDerivedFrom(XSType t) {
+            return t==this || t==anyType;
+        }
+
+        public boolean isSimpleType()       { return true; }
+        public boolean isComplexType()      { return false; }
+        public XSContentType asEmpty() { return null; }
+        public XSParticle asParticle() { return null; }
+        public XSType getBaseType() { return anyType; }
+        public XSSimpleType getSimpleBaseType() { return null; }
+        public int getDerivationMethod() { return RESTRICTION; }
+        public Iterator iterateDeclaredFacets() { return emptyIterator; }
+        public Collection<? extends XSFacet> getDeclaredFacets() { return Collections.EMPTY_LIST; }
+        public void visit( XSSimpleTypeVisitor visitor ) {visitor.restrictionSimpleType(this); }
+        public void visit( XSContentTypeVisitor visitor ) {visitor.simpleType(this); }
+        public void visit( XSVisitor visitor ) {visitor.simpleType(this); }
+        public <T> T apply( XSSimpleTypeFunction<T> f ) {return f.restrictionSimpleType(this); }
+        public <T> T apply( XSContentTypeFunction<T> f ) { return f.simpleType(this); }
+        public <T> T apply( XSFunction<T> f ) { return f.simpleType(this); }
+        public XSVariety getVariety() { return XSVariety.ATOMIC; }
+        public XSFacet getFacet(String name) { return null; }
+        public XSFacet getDeclaredFacet(String name) { return null; }
+        public List<XSFacet> getDeclaredFacets(String name) { return Collections.EMPTY_LIST; }
+
+        public boolean isRestriction() { return true; }
+        public boolean isList() { return false; }
+        public boolean isUnion() { return false; }
+        public boolean isFinal(XSVariety v) { return false; }
+        public XSRestrictionSimpleType asRestriction() { return this; }
+        public XSListSimpleType asList() { return null; }
+        public XSUnionSimpleType asUnion() { return null; }
+        public XSSimpleType getType() { return this; } // Ref.SimpleType implementation
+        public XSSimpleType getRedefinedBy() { return null; }
+        public int getRedefinedCount() { return 0; }
+
+        public XSType[] listSubstitutables() {
+            return Util.listSubstitutables(this);
+        }
+    };
+
+    public XSComplexType getAnyType() { return anyType; }
+    public final AnyType anyType = new AnyType();
+    private class AnyType extends DeclarationImpl implements XSComplexType, Ref.Type {
+        AnyType() {
+            super(null,null,null,null,"http://www.w3.org/2001/XMLSchema","anyType",false);
+        }
+        public SchemaImpl getOwnerSchema() {
+            return createSchema("http://www.w3.org/2001/XMLSchema",null);
+        }
+        public boolean isAbstract() { return false; }
+        public XSWildcard getAttributeWildcard() { return anyWildcard; }
+        public XSAttributeUse getAttributeUse( String nsURI, String localName ) { return null; }
+        public Iterator iterateAttributeUses() { return emptyIterator; }
+        public XSAttributeUse getDeclaredAttributeUse( String nsURI, String localName ) { return null; }
+        public Iterator iterateDeclaredAttributeUses() { return emptyIterator; }
+        public Iterator iterateAttGroups() { return emptyIterator; }
+        public Collection<XSAttributeUse> getAttributeUses() { return Collections.EMPTY_LIST; }
+        public Collection<? extends XSAttributeUse> getDeclaredAttributeUses() { return Collections.EMPTY_LIST; }
+        public Collection<? extends XSAttGroupDecl> getAttGroups() { return Collections.EMPTY_LIST; }
+        public boolean isFinal( int i ) { return false; }
+        public boolean isSubstitutionProhibited( int i ) { return false; }
+        public boolean isMixed() { return true; }
+        public XSContentType getContentType() { return contentType; }
+        public XSContentType getExplicitContent() { return null; }
+        public XSType getBaseType() { return this; }
+        public XSSimpleType asSimpleType() { return null; }
+        public XSComplexType asComplexType() { return this; }
+
+        public boolean isDerivedFrom(XSType t) {
+            return t==this;
+        }
+
+        public boolean isSimpleType()       { return false; }
+        public boolean isComplexType()      { return true; }
+        public XSContentType asEmpty() { return null; }
+        public int getDerivationMethod() { return XSType.RESTRICTION; }
+
+        public XSElementDecl getScope() { return null; }
+        public void visit( XSVisitor visitor ) { visitor.complexType(this); }
+        public <T> T apply( XSFunction<T> f ) { return f.complexType(this); }
+
+        public XSType getType() { return this; } // Ref.Type implementation
+
+        public XSComplexType getRedefinedBy() { return null; }
+        public int getRedefinedCount() { return 0; }
+
+        public XSType[] listSubstitutables() {
+            return Util.listSubstitutables(this);
+        }
+
+        private final WildcardImpl anyWildcard = new WildcardImpl.Any(null,null,null,null,XSWildcard.SKIP);
+        private final XSContentType contentType = new ParticleImpl( null, null,
+                new ModelGroupImpl(null, null, null, null,XSModelGroup.SEQUENCE, new ParticleImpl[]{
+                    new ParticleImpl( null, null,
+                        anyWildcard, null,
+                        XSParticle.UNBOUNDED, 0 )
+                })
+                ,null,1,1);
+    };
+
+    private static final Iterator emptyIterator = new Iterator() {
+        public boolean hasNext() { return false; }
+        public Object next() { throw new NoSuchElementException(); }
+        public void remove() { throw new UnsupportedOperationException(); }
+    };
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SimpleTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SimpleTypeImpl.java
new file mode 100644
index 0000000..f267bdc
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/SimpleTypeImpl.java
@@ -0,0 +1,156 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+import com.sun.xml.internal.xsom.XSVariety;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Set;
+
+public abstract class SimpleTypeImpl extends DeclarationImpl
+    implements XSSimpleType, ContentTypeImpl, Ref.SimpleType
+{
+    SimpleTypeImpl(
+        SchemaDocumentImpl _parent,
+        AnnotationImpl _annon,
+        Locator _loc,
+        ForeignAttributesImpl _fa,
+        String _name,
+        boolean _anonymous,
+        Set<XSVariety> finalSet,
+        Ref.SimpleType _baseType) {
+
+        super(_parent, _annon, _loc, _fa, _parent.getTargetNamespace(), _name, _anonymous);
+
+        this.baseType = _baseType;
+        this.finalSet = finalSet;
+    }
+
+    private Ref.SimpleType baseType;
+
+    public XSType[] listSubstitutables() {
+        return Util.listSubstitutables(this);
+    }
+
+    public void redefine( SimpleTypeImpl st ) {
+        baseType = st;
+        st.redefinedBy = this;
+        redefiningCount = (short)(st.redefiningCount+1);
+    }
+
+    /**
+     * Number of times this component redefines other components.
+     */
+    private short redefiningCount = 0;
+
+    private SimpleTypeImpl redefinedBy = null;
+
+    public XSSimpleType getRedefinedBy() {
+        return redefinedBy;
+    }
+
+    public int getRedefinedCount() {
+        int i=0;
+        for( SimpleTypeImpl st =this.redefinedBy; st !=null; st =st.redefinedBy)
+            i++;
+        return i;
+    }
+
+    public XSType getBaseType() { return baseType.getType(); }
+    public XSSimpleType getSimpleBaseType() { return baseType.getType(); }
+
+    private final Set<XSVariety> finalSet;
+
+    public boolean isFinal(XSVariety v) {
+        return finalSet.contains(v);
+    }
+
+
+    public final int getDerivationMethod() { return XSType.RESTRICTION; }
+
+
+    public final XSSimpleType asSimpleType()  { return this; }
+    public final XSComplexType asComplexType(){ return null; }
+
+    public boolean isDerivedFrom(XSType t) {
+        XSType x = this;
+        while(true) {
+            if(t==x)
+                return true;
+            XSType s = x.getBaseType();
+            if(s==x)
+                return false;
+            x = s;
+        }
+    }
+
+    public final boolean isSimpleType()       { return true; }
+    public final boolean isComplexType()      { return false; }
+    public final XSParticle asParticle()      { return null; }
+    public final XSContentType asEmpty()      { return null; }
+
+
+    public boolean isRestriction() { return false; }
+    public boolean isList() { return false; }
+    public boolean isUnion() { return false; }
+    public XSRestrictionSimpleType asRestriction() { return null; }
+    public XSListSimpleType asList() { return null; }
+    public XSUnionSimpleType asUnion() { return null; }
+
+
+
+
+    public final void visit( XSVisitor visitor ) {
+        visitor.simpleType(this);
+    }
+    public final void visit( XSContentTypeVisitor visitor ) {
+        visitor.simpleType(this);
+    }
+    public final Object apply( XSFunction function ) {
+        return function.simpleType(this);
+    }
+    public final Object apply( XSContentTypeFunction function ) {
+        return function.simpleType(this);
+    }
+
+    // Ref.ContentType implementation
+    public XSContentType getContentType() { return this; }
+    // Ref.SimpleType implementation
+    public XSSimpleType getType() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/UName.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/UName.java
new file mode 100644
index 0000000..f79905c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/UName.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import java.util.Comparator;
+
+/**
+ * UName.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public final class UName {
+    /**
+     * @param _nsUri
+     *      Use "" to indicate the no namespace.
+     */
+    public UName( String _nsUri, String _localName, String _qname ) {
+        if(_nsUri==null || _localName==null || _qname==null) {
+            throw new NullPointerException(_nsUri+" "+_localName+" "+_qname);
+        }
+        this.nsUri = _nsUri.intern();
+        this.localName = _localName.intern();
+        this.qname = _qname.intern();
+    }
+
+    public UName( String nsUri, String localName ) {
+        this(nsUri,localName,localName);
+    }
+
+    private final String nsUri;
+    private final String localName;
+    private final String qname;
+
+    public String getName() { return localName; }
+    public String getNamespaceURI() { return nsUri; }
+    public String getQualifiedName() { return qname; }
+
+    /**
+     * Compares {@link UName}s by their names.
+     */
+    public static final Comparator comparator = new Comparator() {
+        public int compare(Object o1, Object o2) {
+            UName lhs = (UName)o1;
+            UName rhs = (UName)o2;
+            int r = lhs.nsUri.compareTo(rhs.nsUri);
+            if(r!=0)    return r;
+            return lhs.localName.compareTo(rhs.localName);
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/UnionSimpleTypeImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/UnionSimpleTypeImpl.java
new file mode 100644
index 0000000..afe8bd6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/UnionSimpleTypeImpl.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+import com.sun.xml.internal.xsom.XSVariety;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeFunction;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Iterator;
+import java.util.Set;
+
+public class UnionSimpleTypeImpl extends SimpleTypeImpl implements XSUnionSimpleType
+{
+    public UnionSimpleTypeImpl( SchemaDocumentImpl _parent,
+                                AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+                                String _name, boolean _anonymous, Set<XSVariety> finalSet,
+                                Ref.SimpleType[] _members ) {
+
+        super(_parent,_annon,_loc,_fa,_name,_anonymous, finalSet,
+            _parent.getSchema().parent.anySimpleType);
+
+        this.memberTypes = _members;
+    }
+
+    private final Ref.SimpleType[] memberTypes;
+    public XSSimpleType getMember( int idx ) { return memberTypes[idx].getType(); }
+    public int getMemberSize() { return memberTypes.length; }
+
+    public Iterator<XSSimpleType> iterator() {
+        return new Iterator<XSSimpleType>() {
+            int idx=0;
+            public boolean hasNext() {
+                return idx<memberTypes.length;
+            }
+
+            public XSSimpleType next() {
+                return memberTypes[idx++].getType();
+            }
+
+            public void remove() {
+                throw new UnsupportedOperationException();
+            }
+        };
+    }
+
+    public void visit( XSSimpleTypeVisitor visitor ) {
+        visitor.unionSimpleType(this);
+    }
+    public Object apply( XSSimpleTypeFunction function ) {
+        return function.unionSimpleType(this);
+    }
+
+    // union type by itself doesn't have any facet. */
+    public XSFacet getFacet( String name ) { return null; }
+
+    public XSVariety getVariety() { return XSVariety.LIST; }
+
+    public boolean isUnion() { return true; }
+    public XSUnionSimpleType asUnion() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Util.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Util.java
new file mode 100644
index 0000000..15a6f5a
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/Util.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSType;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Set;
+
+/**
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class Util {
+    private static XSType[] listDirectSubstitutables( XSType _this ) {
+        ArrayList r = new ArrayList();
+
+        // TODO: handle @block
+        Iterator itr = ((SchemaImpl)_this.getOwnerSchema()).parent.iterateTypes();
+        while( itr.hasNext() ) {
+            XSType t = (XSType)itr.next();
+            if( t.getBaseType()==_this )
+                r.add(t);
+        }
+        return (XSType[]) r.toArray(new XSType[r.size()]);
+    }
+
+    public static XSType[] listSubstitutables( XSType _this ) {
+        Set substitables = new HashSet();
+        buildSubstitutables( _this, substitables );
+        return (XSType[]) substitables.toArray(new XSType[substitables.size()]);
+    }
+
+    public static void buildSubstitutables( XSType _this, Set substitutables ) {
+        if( _this.isLocal() )    return;
+        buildSubstitutables( _this, _this, substitutables );
+    }
+
+    private static void buildSubstitutables( XSType head, XSType _this, Set substitutables ) {
+        if(!isSubstitutable(head,_this))
+            return;    // no derived type of _this can substitute head.
+
+        if(substitutables.add(_this)) {
+            XSType[] child = listDirectSubstitutables(_this);
+            for( int i=0; i<child.length; i++ )
+                buildSubstitutables( head, child[i], substitutables );
+        }
+    }
+
+    /**
+     * Implements
+     * <code>Validation Rule: Schema-Validity Assessment (Element) 1.2.1.2.4</code>
+     */
+    private static boolean isSubstitutable( XSType _base, XSType derived ) {
+        // too ugly to the point that it's almost unbearable.
+        // I mean, it's not even transitive. Thus we end up calling this method
+        // for each candidate
+        if( _base.isComplexType() ) {
+            XSComplexType base = _base.asComplexType();
+
+            for( ; base!=derived; derived=derived.getBaseType() ) {
+                if( base.isSubstitutionProhibited( derived.getDerivationMethod() ) )
+                    return false;    // Type Derivation OK (Complex)-1
+            }
+            return true;
+        } else {
+            // simple type don't have any @block
+            return true;
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/WildcardImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/WildcardImpl.java
new file mode 100644
index 0000000..b019803
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/WildcardImpl.java
@@ -0,0 +1,199 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermFunction;
+import com.sun.xml.internal.xsom.visitor.XSTermFunctionWithParam;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import com.sun.xml.internal.xsom.visitor.XSWildcardFunction;
+import com.sun.xml.internal.xsom.visitor.XSWildcardVisitor;
+import org.xml.sax.Locator;
+
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Set;
+
+public abstract class WildcardImpl extends ComponentImpl implements XSWildcard, Ref.Term
+{
+    protected WildcardImpl( SchemaDocumentImpl owner, AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa, int _mode ) {
+        super(owner,_annon,_loc,_fa);
+        this.mode = _mode;
+    }
+
+    private final int mode;
+    public int getMode() { return mode; }
+
+    // compute the union
+    public WildcardImpl union( SchemaDocumentImpl owner, WildcardImpl rhs ) {
+        if(this instanceof Any || rhs instanceof Any)
+            return new Any(owner,null,null,null,mode);
+
+        if(this instanceof Finite && rhs instanceof Finite) {
+            Set<String> values = new HashSet<String>();
+            values.addAll( ((Finite)this).names );
+            values.addAll( ((Finite)rhs ).names );
+            return new Finite(owner,null,null,null,values,mode);
+        }
+
+        if(this instanceof Other && rhs instanceof Other) {
+            if( ((Other)this).otherNamespace.equals(
+                ((Other)rhs).otherNamespace) )
+                return new Other(owner,null,null,null, ((Other)this).otherNamespace, mode );
+            else
+                // this somewhat strange rule is indeed in the spec
+                return new Other(owner,null,null,null, "", mode );
+        }
+
+        Other o;
+        Finite f;
+
+        if( this instanceof Other ) {
+            o=(Other)this; f=(Finite)rhs;
+        } else {
+            o=(Other)rhs; f=(Finite)this;
+        }
+
+        if(f.names.contains(o.otherNamespace))
+            return new Any(owner,null,null,null,mode);
+        else
+            return new Other(owner,null,null,null,o.otherNamespace,mode);
+    }
+
+
+
+    public final static class Any extends WildcardImpl implements XSWildcard.Any {
+        public Any( SchemaDocumentImpl owner, AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa, int _mode ) {
+            super(owner,_annon,_loc,_fa,_mode);
+        }
+
+        public boolean acceptsNamespace( String namespaceURI ) {
+            return true;
+        }
+        public void visit( XSWildcardVisitor visitor ) {
+            visitor.any(this);
+        }
+        public Object apply( XSWildcardFunction function ) {
+            return function.any(this);
+        }
+    }
+
+    public final static class Other extends WildcardImpl implements XSWildcard.Other {
+        public Other( SchemaDocumentImpl owner, AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+                    String otherNamespace, int _mode ) {
+            super(owner,_annon,_loc,_fa,_mode);
+            this.otherNamespace = otherNamespace;
+        }
+
+        private final String otherNamespace;
+
+        public String getOtherNamespace() { return otherNamespace; }
+
+        public boolean acceptsNamespace( String namespaceURI ) {
+            return !namespaceURI.equals(otherNamespace);
+        }
+
+        public void visit( XSWildcardVisitor visitor ) {
+            visitor.other(this);
+        }
+        public Object apply( XSWildcardFunction function ) {
+            return function.other(this);
+        }
+    }
+
+    public final static class Finite extends WildcardImpl implements XSWildcard.Union {
+        public Finite( SchemaDocumentImpl owner, AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl _fa,
+                    Set<String> ns, int _mode ) {
+            super(owner,_annon,_loc,_fa,_mode);
+            names = ns;
+            namesView = Collections.unmodifiableSet(names);
+        }
+
+        private final Set<String> names;
+        private final Set<String> namesView;
+
+        public Iterator<String> iterateNamespaces() {
+            return names.iterator();
+        }
+
+        public Collection<String> getNamespaces() {
+            return namesView;
+        }
+
+        public boolean acceptsNamespace( String namespaceURI ) {
+            return names.contains(namespaceURI);
+        }
+
+        public void visit( XSWildcardVisitor visitor ) {
+            visitor.union(this);
+        }
+        public Object apply( XSWildcardFunction function ) {
+            return function.union(this);
+        }
+    }
+
+    public final void visit( XSVisitor visitor ) {
+        visitor.wildcard(this);
+    }
+    public final void visit( XSTermVisitor visitor ) {
+        visitor.wildcard(this);
+    }
+    public Object apply( XSTermFunction function ) {
+        return function.wildcard(this);
+    }
+
+    public <T,P> T apply(XSTermFunctionWithParam<T, P> function, P param) {
+        return function.wildcard(this,param);
+    }
+
+    public Object apply( XSFunction function ) {
+        return function.wildcard(this);
+    }
+
+
+    public boolean isWildcard()                 { return true; }
+    public boolean isModelGroupDecl()           { return false; }
+    public boolean isModelGroup()               { return false; }
+    public boolean isElementDecl()              { return false; }
+
+    public XSWildcard asWildcard()              { return this; }
+    public XSModelGroupDecl asModelGroupDecl()  { return null; }
+    public XSModelGroup asModelGroup()          { return null; }
+    public XSElementDecl asElementDecl()        { return null; }
+
+
+    // Ref.Term implementation
+    public XSTerm getTerm() { return this; }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/XPathImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/XPathImpl.java
new file mode 100644
index 0000000..c1fdf50
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/XPathImpl.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl;
+
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.XmlString;
+import com.sun.xml.internal.xsom.impl.parser.SchemaDocumentImpl;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+/**
+ * @author Kohsuke Kawaguchi
+ */
+public class XPathImpl extends ComponentImpl implements XSXPath {
+    private XSIdentityConstraint parent;
+    private final XmlString xpath;
+
+    public XPathImpl(SchemaDocumentImpl _owner, AnnotationImpl _annon, Locator _loc, ForeignAttributesImpl fa, XmlString xpath) {
+        super(_owner, _annon, _loc, fa);
+        this.xpath = xpath;
+    }
+
+    public void setParent(XSIdentityConstraint parent) {
+        this.parent = parent;
+    }
+
+    public XSIdentityConstraint getParent() {
+        return parent;
+    }
+
+    public XmlString getXPath() {
+        return xpath;
+    }
+
+    public void visit(XSVisitor visitor) {
+        visitor.xpath(this);
+    }
+
+    public <T> T apply(XSFunction<T> function) {
+        return function.xpath(this);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/package.html b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/package.html
new file mode 100644
index 0000000..bb877ed
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/package.html
@@ -0,0 +1,3 @@
+<html><body>
+Implementation of the <code>com.sun.xml.xsom</code> package.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/DefaultAnnotationParser.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/DefaultAnnotationParser.java
new file mode 100644
index 0000000..1b00022
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/DefaultAnnotationParser.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.parser;
+
+import com.sun.xml.internal.xsom.parser.AnnotationContext;
+import com.sun.xml.internal.xsom.parser.AnnotationParser;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.helpers.DefaultHandler;
+
+/**
+ * AnnotationParser that just ignores annotation.
+ *
+ * <p>
+ * This class doesn't have any state. So it should be used as a singleton.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+class DefaultAnnotationParser extends AnnotationParser {
+
+    private DefaultAnnotationParser() {}
+
+    public static final AnnotationParser theInstance = new DefaultAnnotationParser();
+
+    public ContentHandler getContentHandler(
+        AnnotationContext contest, String elementName,
+        ErrorHandler errorHandler, EntityResolver entityResolver ) {
+        return new DefaultHandler();
+    }
+
+    public Object getResult( Object existing ) {
+        return null;
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/DelayedRef.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/DelayedRef.java
new file mode 100644
index 0000000..ec2f1db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/DelayedRef.java
@@ -0,0 +1,256 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.parser;
+
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSDeclaration;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSTerm;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.impl.Ref;
+import com.sun.xml.internal.xsom.impl.SchemaImpl;
+import com.sun.xml.internal.xsom.impl.UName;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+/**
+ * Reference by name.
+ *
+ * UName will be later resolved to a target object,
+ * after all the schemas are parsed.
+ */
+public abstract class DelayedRef implements Patch {
+    DelayedRef( PatcherManager _manager, Locator _source,
+        SchemaImpl _schema, UName _name ) {
+
+        this.schema = _schema.getParent();
+        this.manager = _manager;
+        this.name = _name;
+        this.source = _source;
+
+        if(name==null)  throw new InternalError();
+
+        manager.addPatcher(this);
+    }
+
+    /**
+     * Patch implementation. Makes sure that the name resolves
+     * to a schema component.
+     */
+    public void run() throws SAXException {
+        if(ref==null)    // redefinition can set ref without actually resolving the reference
+            resolve();
+        manager = null;     // avoid keeping the reference too long
+        name = null;
+        source = null;
+    }
+
+
+    protected final XSSchemaSet schema;
+    private PatcherManager manager;
+    private UName name;
+    /** location in the source file where this reference was made. */
+    private Locator source;
+
+    protected abstract Object resolveReference( UName name );
+    protected abstract String getErrorProperty();
+
+    private Object ref=null;
+    protected final Object _get() {
+        if(ref==null)   throw new InternalError("unresolved reference");
+        return ref;
+    }
+
+    private void resolve() throws SAXException {
+        ref = resolveReference(name);
+        if(ref==null)
+            manager.reportError(
+                Messages.format(getErrorProperty(),name.getQualifiedName()),
+                source );
+    }
+
+    /**
+     * If this reference refers to the given declaration,
+     * resolve the reference now. This is used to implement redefinition.
+     */
+    public void redefine(XSDeclaration d) {
+        if( !d.getTargetNamespace().equals(name.getNamespaceURI())
+        ||  !d.getName().equals(name.getName()) )
+            return;
+
+        ref = d;
+        manager = null;
+        name = null;
+        source = null;
+    }
+
+
+    public static class Type extends DelayedRef implements Ref.Type {
+        public Type( PatcherManager manager, Locator loc, SchemaImpl schema, UName name ) {
+            super(manager,loc,schema,name);
+        }
+        protected Object resolveReference( UName name ) {
+            Object o = super.schema.getSimpleType(
+                name.getNamespaceURI(), name.getName() );
+            if(o!=null)     return o;
+
+            return super.schema.getComplexType(
+                name.getNamespaceURI(),
+                name.getName());
+        }
+        protected String getErrorProperty() {
+            return Messages.ERR_UNDEFINED_TYPE;
+        }
+
+        public XSType getType() { return (XSType)super._get(); }
+    }
+
+    public static class SimpleType extends DelayedRef implements Ref.SimpleType {
+        public SimpleType( PatcherManager manager, Locator loc, SchemaImpl schema, UName name ) {
+            super(manager,loc,schema,name);
+        }
+        public XSSimpleType getType() { return (XSSimpleType)_get(); }
+
+        protected Object resolveReference( UName name ) {
+            return super.schema.getSimpleType(
+                name.getNamespaceURI(),
+                name.getName());
+        }
+
+        protected String getErrorProperty() {
+            return Messages.ERR_UNDEFINED_SIMPLETYPE;
+        }
+    }
+
+    public static class ComplexType extends DelayedRef implements Ref.ComplexType {
+        public ComplexType( PatcherManager manager, Locator loc, SchemaImpl schema, UName name ) {
+            super(manager,loc,schema,name);
+        }
+        protected Object resolveReference( UName name ) {
+            return super.schema.getComplexType(
+                name.getNamespaceURI(),
+                name.getName());
+        }
+
+        protected String getErrorProperty() {
+            return Messages.ERR_UNDEFINED_COMPLEXTYPE;
+        }
+
+        public XSComplexType getType() { return (XSComplexType)super._get(); }
+    }
+
+    public static class Element extends DelayedRef implements Ref.Element {
+        public Element( PatcherManager manager, Locator loc, SchemaImpl schema, UName name ) {
+            super(manager,loc,schema,name);
+        }
+        protected Object resolveReference( UName name ) {
+            return super.schema.getElementDecl(
+                name.getNamespaceURI(),
+                name.getName());
+        }
+
+        protected String getErrorProperty() {
+            return Messages.ERR_UNDEFINED_ELEMENT;
+        }
+
+        public XSElementDecl get() { return (XSElementDecl)super._get(); }
+        public XSTerm getTerm() { return get(); }
+    }
+
+    public static class ModelGroup extends DelayedRef implements Ref.Term {
+        public ModelGroup( PatcherManager manager, Locator loc, SchemaImpl schema, UName name ) {
+            super(manager,loc,schema,name);
+        }
+        protected Object resolveReference( UName name ) {
+            return super.schema.getModelGroupDecl(
+                name.getNamespaceURI(),
+                name.getName());
+        }
+
+        protected String getErrorProperty() {
+            return Messages.ERR_UNDEFINED_MODELGROUP;
+        }
+
+        public XSModelGroupDecl get() { return (XSModelGroupDecl)super._get(); }
+        public XSTerm getTerm() { return get(); }
+    }
+
+    public static class AttGroup extends DelayedRef implements Ref.AttGroup {
+        public AttGroup( PatcherManager manager, Locator loc, SchemaImpl schema, UName name ) {
+            super(manager,loc,schema,name);
+        }
+        protected Object resolveReference( UName name ) {
+            return super.schema.getAttGroupDecl(
+                name.getNamespaceURI(),
+                name.getName());
+        }
+
+        protected String getErrorProperty() {
+            return Messages.ERR_UNDEFINED_ATTRIBUTEGROUP;
+        }
+
+        public XSAttGroupDecl get() { return (XSAttGroupDecl)super._get(); }
+    }
+
+    public static class Attribute extends DelayedRef implements Ref.Attribute {
+        public Attribute( PatcherManager manager, Locator loc, SchemaImpl schema, UName name ) {
+            super(manager,loc,schema,name);
+        }
+        protected Object resolveReference( UName name ) {
+            return super.schema.getAttributeDecl(
+                name.getNamespaceURI(),
+                name.getName());
+        }
+
+        protected String getErrorProperty() {
+            return Messages.ERR_UNDEFINED_ATTRIBUTE;
+        }
+
+        public XSAttributeDecl getAttribute() { return (XSAttributeDecl)super._get(); }
+    }
+
+    public static class IdentityConstraint extends DelayedRef implements Ref.IdentityConstraint {
+        public IdentityConstraint( PatcherManager manager, Locator loc, SchemaImpl schema, UName name ) {
+            super(manager,loc,schema,name);
+        }
+        protected Object resolveReference( UName name ) {
+            return super.schema.getIdentityConstraint(
+                name.getNamespaceURI(),
+                name.getName());
+        }
+
+        protected String getErrorProperty() {
+            return Messages.ERR_UNDEFINED_IDENTITY_CONSTRAINT;
+        }
+
+        public XSIdentityConstraint get() { return (XSIdentityConstraint)super._get(); }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages.java
new file mode 100644
index 0000000..a70389f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.parser;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+public class Messages
+{
+    /** Loads a string resource and formats it with specified arguments. */
+    public static String format( String property, Object... args ) {
+        String text = ResourceBundle.getBundle(
+            Messages.class.getName()).getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+//
+//
+// Message resources
+//
+//
+    public static final String ERR_UNDEFINED_SIMPLETYPE =
+        "UndefinedSimpleType"; // arg:1
+    public static final String ERR_UNDEFINED_COMPLEXTYPE =
+        "UndefinedCompplexType"; // arg:1
+    public static final String ERR_UNDEFINED_TYPE =
+        "UndefinedType"; // arg:1
+    public static final String ERR_UNDEFINED_ELEMENT =
+        "UndefinedElement"; // arg:1
+    public static final String ERR_UNDEFINED_MODELGROUP =
+        "UndefinedModelGroup"; // arg:1
+    public static final String ERR_UNDEFINED_ATTRIBUTE =
+        "UndefinedAttribute"; // arg:1
+    public static final String ERR_UNDEFINED_ATTRIBUTEGROUP =
+        "UndefinedAttributeGroup"; // arg:1
+    public static final String ERR_UNDEFINED_IDENTITY_CONSTRAINT =
+        "UndefinedIdentityConstraint"; // arg:1
+    public static final String ERR_UNDEFINED_PREFIX =
+        "UndefinedPrefix"; // arg:1
+
+    public static final String ERR_DOUBLE_DEFINITION =
+        "DoubleDefinition"; // arg:1
+    public static final String ERR_DOUBLE_DEFINITION_ORIGINAL =
+        "DoubleDefinition.Original"; // arg:0
+
+    public static final String ERR_MISSING_SCHEMALOCATION =
+        "MissingSchemaLocation"; // arg:0
+
+    public static final String ERR_ENTITY_RESOLUTION_FAILURE =
+        "EntityResolutionFailure"; // arg:2
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages.properties b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages.properties
new file mode 100644
index 0000000..a288f4f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages.properties
@@ -0,0 +1,46 @@
+UndefinedSimpleType = \
+	undefined simple type ''{0}''
+
+UndefinedCompplexType = \
+	undefined complex type ''{0}''
+
+UndefinedType = \
+	undefined simple or complex type ''{0}''
+
+UndefinedElement = \
+	undefined element declaration ''{0}''
+
+UndefinedModelGroup = \
+	undefined model group ''{0}''
+
+UndefinedAttribute = \
+	undefined attribute ''{0}''
+
+UndefinedAttributeGroup = \
+	undefined attribute group ''{0}''
+
+UndefinedIdentityConstraint = \
+    undefined identity constraint ''{0}''
+
+UndefinedPrefix = \
+	unbounded prefix ''{0}''
+
+UnexpectedTargetnamespace.Include = \
+	the target namespace of the included schema "{0}" doesn''t agree with the expected value "{1}"
+
+UnexpectedTargetnamespace.Import = \
+	the target namespace of the imported schema "{0}" doesn''t agree with the expected value "{1}"
+
+DoubleDefinition = \
+	''{0}'' is already defined
+
+DoubleDefinition.Original = \
+	(related to above error) the first definition appears here
+	
+MissingSchemaLocation = \
+	a "schemaLocation" attribute is required
+
+EntityResolutionFailure = \
+	failed to retrieve ''{0}'': {1}
+	
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages_ja.properties b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages_ja.properties
new file mode 100644
index 0000000..4443274
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Messages_ja.properties
@@ -0,0 +1,45 @@
+UndefinedSimpleType = \
+	\u672A\u5B9A\u7FA9\u306E\u30B7\u30F3\u30D7\u30EB\u30BF\u30A4\u30D7''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UndefinedCompplexType = \
+	\u672A\u5B9A\u7FA9\u306E\u30B3\u30F3\u30D7\u30EC\u30C3\u30AF\u30B9\u30BF\u30A4\u30D7''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UndefinedType = \
+	\u672A\u5B9A\u7FA9\u306E\u578B''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UndefinedElement = \
+	\u672A\u5B9A\u7FA9\u306E\u8981\u7D20''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UndefinedModelGroup = \
+	\u672A\u5B9A\u7FA9\u306E\u30E2\u30C7\u30EB\u30B0\u30EB\u30FC\u30D7''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UndefinedAttribute = \
+	\u672A\u5B9A\u7FA9\u306E\u5C5E\u6027''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UndefinedAttributeGroup = \
+	\u672A\u5B9A\u7FA9\u306E\u5C5E\u6027\u30B0\u30EB\u30FC\u30D7''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UndefinedIdentityConstraint = \
+	\u672A\u5B9A\u7FA9\u306E\u4E00\u610F\u6027\u5236\u7D04''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UndefinedPrefix = \
+	xmlns\u5BA3\u8A00\u306E\u3055\u308C\u3066\u3044\u306A\u3044\u30D7\u30EC\u30D5\u30A3\u30C3\u30AF\u30B9''{0}''\u304C\u4F7F\u308F\u308C\u3066\u3044\u307E\u3059
+
+UnexpectedTargetnamespace.Include = \
+	include\u3057\u305F\u5074\u3068\u3055\u308C\u305F\u5074\u306EtargetNamespace\u5C5E\u6027\u306E\u5024\u304C\u98DF\u3044\u9055\u3063\u3066\u3044\u307E\u3059({0}\u3068{1})
+
+UnexpectedTargetnamespace.Import = \
+	import\u3057\u305F\u5074\u3068\u3055\u308C\u305F\u5074\u306EtargetNamespace\u5C5E\u6027\u306E\u5024\u304C\u98DF\u3044\u9055\u3063\u3066\u3044\u307E\u3059({0}\u3068{1})
+
+DoubleDefinition = \
+	''{0}''\u306F\u65E2\u306B\u5B9A\u7FA9\u3055\u308C\u3066\u3044\u307E\u3059
+
+DoubleDefinition.Original = \
+	\uFF08\u4E0A\u306E\u30A8\u30E9\u30FC\u306B\u95A2\u9023\uFF09\u5143\u3005\u306E\u5B9A\u7FA9\u306F\u3053\u3053\u3067\u884C\u308F\u308C\u3066\u3044\u307E\u3059
+
+MissingSchemaLocation = \
+	schemaLocation\u5C5E\u6027\u304C\u6307\u5B9A\u3055\u308C\u3066\u3044\u307E\u305B\u3093
+
+EntityResolutionFailure = \
+	''{0}''\u3092\u8AAD\u307F\u8FBC\u3081\u307E\u305B\u3093: {1}
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/NGCCRuntimeEx.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/NGCCRuntimeEx.java
new file mode 100644
index 0000000..339383c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/NGCCRuntimeEx.java
@@ -0,0 +1,492 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.parser;
+
+import com.sun.xml.internal.xsom.XSDeclaration;
+import com.sun.xml.internal.xsom.XmlString;
+import com.sun.xml.internal.xsom.impl.ForeignAttributesImpl;
+import com.sun.xml.internal.xsom.impl.SchemaImpl;
+import com.sun.xml.internal.xsom.impl.UName;
+import com.sun.xml.internal.xsom.impl.parser.state.NGCCRuntime;
+import com.sun.xml.internal.xsom.impl.parser.state.Schema;
+import com.sun.xml.internal.xsom.impl.util.Uri;
+import com.sun.xml.internal.xsom.parser.AnnotationParser;
+import org.relaxng.datatype.ValidationContext;
+import org.xml.sax.Attributes;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.helpers.LocatorImpl;
+
+import java.io.IOException;
+import java.text.MessageFormat;
+import java.util.Stack;
+
+/**
+ * NGCCRuntime extended with various utility methods for
+ * parsing XML Schema.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class NGCCRuntimeEx extends NGCCRuntime implements PatcherManager {
+
+    /** coordinator. */
+    public final ParserContext parser;
+
+    /** The schema currently being parsed. */
+    public SchemaImpl currentSchema;
+
+    /** The @finalDefault value of the current schema. */
+    public int finalDefault = 0;
+    /** The @blockDefault value of the current schema. */
+    public int blockDefault = 0;
+
+    /**
+     * The @elementFormDefault value of the current schema.
+     * True if local elements are qualified by default.
+     */
+    public boolean elementFormDefault = false;
+
+    /**
+     * The @attributeFormDefault value of the current schema.
+     * True if local attributes are qualified by default.
+     */
+    public boolean attributeFormDefault = false;
+
+    /**
+     * True if the current schema is in a chameleon mode.
+     * This changes the way QNames are interpreted.
+     *
+     * Life is very miserable with XML Schema, as you see.
+     */
+    public boolean chameleonMode = false;
+
+    /**
+     * URI that identifies the schema document.
+     * Maybe null if the system ID is not available.
+     */
+    private String documentSystemId;
+
+    /**
+     * Keep the local name of elements encountered so far.
+     * This information is passed to AnnotationParser as
+     * context information
+     */
+    private final Stack<String> elementNames = new Stack<String>();
+
+    /**
+     * Points to the schema document (the parser of it) that included/imported
+     * this schema.
+     */
+    private final NGCCRuntimeEx referer;
+
+    /**
+     * Points to the {@link SchemaDocumentImpl} that represents the
+     * schema document being parsed.
+     */
+    public SchemaDocumentImpl document;
+
+    NGCCRuntimeEx( ParserContext _parser ) {
+        this(_parser,false,null);
+    }
+
+    private NGCCRuntimeEx( ParserContext _parser, boolean chameleonMode, NGCCRuntimeEx referer ) {
+        this.parser = _parser;
+        this.chameleonMode = chameleonMode;
+        this.referer = referer;
+
+        // set up the default namespace binding
+        currentContext = new Context("","",null);
+        currentContext = new Context("xml","http://www.w3.org/XML/1998/namespace",currentContext);
+    }
+
+    public void checkDoubleDefError( XSDeclaration c ) throws SAXException {
+        if(c==null) return;
+        reportError( Messages.format(Messages.ERR_DOUBLE_DEFINITION,c.getName()) );
+        reportError( Messages.format(Messages.ERR_DOUBLE_DEFINITION_ORIGINAL), c.getLocator() );
+    }
+
+
+
+    /* registers a patcher that will run after all the parsing has finished. */
+    public void addPatcher( Patch patcher ) {
+        parser.patcherManager.addPatcher(patcher);
+    }
+    public void reportError( String msg, Locator loc ) throws SAXException {
+        parser.patcherManager.reportError(msg,loc);
+    }
+    public void reportError( String msg ) throws SAXException {
+        reportError(msg,getLocator());
+    }
+
+
+    /**
+     * Resolves relative URI found in the document.
+     *
+     * @param namespaceURI
+     *      passed to the entity resolver.
+     * @param relativeUri
+     *      value of the schemaLocation attribute. Can be null.
+     *
+     * @return
+     *      non-null if {@link EntityResolver} returned an {@link InputSource},
+     *      or if the relativeUri parameter seems to be pointing to something.
+     *      Otherwise it returns null, in which case import/include should be abandoned.
+     */
+    private InputSource resolveRelativeURL( String namespaceURI, String relativeUri ) throws SAXException {
+        try {
+            String baseUri = getLocator().getSystemId();
+            if(baseUri==null)
+                // if the base URI is not available, the document system ID is
+                // better than nothing.
+                baseUri=documentSystemId;
+
+            String systemId = null;
+            if(relativeUri!=null)
+                systemId = Uri.resolve(baseUri,relativeUri);
+
+            EntityResolver er = parser.getEntityResolver();
+            if(er!=null) {
+                InputSource is = er.resolveEntity(namespaceURI,systemId);
+                if(is!=null)
+                    return is;
+            }
+
+            if(systemId!=null)
+                return new InputSource(systemId);
+            else
+                return null;
+        } catch (IOException e) {
+            SAXParseException se = new SAXParseException(e.getMessage(),getLocator(),e);
+            parser.errorHandler.error(se);
+            return null;
+        }
+    }
+
+    /** Includes the specified schema. */
+    public void includeSchema( String schemaLocation ) throws SAXException {
+        NGCCRuntimeEx runtime = new NGCCRuntimeEx(parser,chameleonMode,this);
+        runtime.currentSchema = this.currentSchema;
+        runtime.blockDefault = this.blockDefault;
+        runtime.finalDefault = this.finalDefault;
+
+        if( schemaLocation==null ) {
+            SAXParseException e = new SAXParseException(
+                Messages.format( Messages.ERR_MISSING_SCHEMALOCATION ), getLocator() );
+            parser.errorHandler.fatalError(e);
+            throw e;
+        }
+
+        runtime.parseEntity( resolveRelativeURL(null,schemaLocation),
+            true, currentSchema.getTargetNamespace(), getLocator() );
+    }
+
+    /** Imports the specified schema. */
+    public void importSchema( String ns, String schemaLocation ) throws SAXException {
+        NGCCRuntimeEx newRuntime = new NGCCRuntimeEx(parser,false,this);
+        InputSource source = resolveRelativeURL(ns,schemaLocation);
+        if(source!=null)
+            newRuntime.parseEntity( source, false, ns, getLocator() );
+        // if source == null,
+        // we can't locate this document. Let's just hope that
+        // we already have the schema components for this schema
+        // or we will receive them in the future.
+    }
+
+    /**
+     * Called when a new document is being parsed and checks
+     * if the document has already been parsed before.
+     *
+     * <p>
+     * Used to avoid recursive inclusion. Note that the same
+     * document will be parsed multiple times if they are for different
+     * target namespaces.
+     *
+     * <h2>Document Graph Model</h2>
+     * <p>
+     * The challenge we are facing here is that you have a graph of
+     * documents that reference each other. Each document has an unique
+     * URI to identify themselves, and references are done by using those.
+     * The graph may contain cycles.
+     *
+     * <p>
+     * Our goal here is to parse all the documents in the graph, without
+     * parsing the same document twice. This method implements this check.
+     *
+     * <p>
+     * One complication is the chameleon schema; a document can be parsed
+     * multiple times if they are under different target namespaces.
+     *
+     * <p>
+     * Also, note that when you resolve relative URIs in the @schemaLocation,
+     * their base URI is *NOT* the URI of the document.
+     *
+     * @return true if the document has already been processed and thus
+     *      needs to be skipped.
+     */
+    public boolean hasAlreadyBeenRead() {
+        if( documentSystemId!=null ) {
+            if( documentSystemId.startsWith("file:///") )
+                // change file:///abc to file:/abc
+                // JDK File.toURL method produces the latter, but according to RFC
+                // I don't think that's a valid URL. Since two different ways of
+                // producing URLs could produce those two different forms,
+                // we need to canonicalize one to the other.
+                documentSystemId = "file:/"+documentSystemId.substring(8);
+        } else {
+            // if the system Id is not provided, we can't test the identity,
+            // so we have no choice but to read it.
+            // the newly created SchemaDocumentImpl will be unique one
+        }
+
+        assert document ==null;
+        document = new SchemaDocumentImpl( currentSchema, documentSystemId );
+
+        SchemaDocumentImpl existing = parser.parsedDocuments.get(document);
+        if(existing==null) {
+            parser.parsedDocuments.put(document,document);
+        } else {
+            document = existing;
+        }
+
+        assert document !=null;
+
+        if(referer!=null) {
+            assert referer.document !=null : "referer "+referer.documentSystemId+" has docIdentity==null";
+            referer.document.references.add(this.document);
+            this.document.referers.add(referer.document);
+        }
+
+        return existing!=null;
+    }
+
+    /**
+     * Parses the specified entity.
+     *
+     * @param importLocation
+     *      The source location of the import/include statement.
+     *      Used for reporting errors.
+     */
+    public void parseEntity( InputSource source, boolean includeMode, String expectedNamespace, Locator importLocation )
+            throws SAXException {
+
+        documentSystemId = source.getSystemId();
+//        System.out.println("parsing "+baseUri);
+
+
+
+        try {
+            Schema s = new Schema(this,includeMode,expectedNamespace);
+            setRootHandler(s);
+
+            try {
+                parser.parser.parse(source,this,
+                    getErrorHandler(),
+                    parser.getEntityResolver());
+            } catch( IOException e ) {
+                SAXParseException se = new SAXParseException(
+                    e.toString(),importLocation,e);
+                parser.errorHandler.fatalError(se);
+                throw se;
+            }
+        } catch( SAXException e ) {
+            parser.setErrorFlag();
+            throw e;
+        }
+    }
+
+    /**
+     * Creates a new instance of annotation parser.
+     */
+    public AnnotationParser createAnnotationParser() {
+        if(parser.getAnnotationParserFactory()==null)
+            return DefaultAnnotationParser.theInstance;
+        else
+            return parser.getAnnotationParserFactory().create();
+    }
+
+    /**
+     * Gets the element name that contains the annotation element.
+     * This method works correctly only when called by the annotation handler.
+     */
+    public String getAnnotationContextElementName() {
+        return elementNames.get( elementNames.size()-2 );
+    }
+
+    /** Creates a copy of the current locator object. */
+    public Locator copyLocator() {
+        return new LocatorImpl(getLocator());
+    }
+
+    public ErrorHandler getErrorHandler() {
+        return parser.errorHandler;
+    }
+
+    public void onEnterElementConsumed(String uri, String localName, String qname, Attributes atts)
+        throws SAXException {
+        super.onEnterElementConsumed(uri, localName, qname, atts);
+        elementNames.push(localName);
+    }
+
+    public void onLeaveElementConsumed(String uri, String localName, String qname) throws SAXException {
+        super.onLeaveElementConsumed(uri, localName, qname);
+        elementNames.pop();
+    }
+
+
+
+//
+//
+// ValidationContext implementation
+//
+//
+    // this object lives longer than the parser itself,
+    // so it's important for this object not to have any reference
+    // to the parser.
+    private static class Context implements ValidationContext {
+        Context( String _prefix, String _uri, Context _context ) {
+            this.previous = _context;
+            this.prefix = _prefix;
+            this.uri = _uri;
+        }
+
+        public String resolveNamespacePrefix(String p) {
+            if(p.equals(prefix))    return uri;
+            if(previous==null)      return null;
+            else                    return previous.resolveNamespacePrefix(p);
+        }
+
+        private final String prefix;
+        private final String uri;
+        private final Context previous;
+
+        // XSDLib don't use those methods, so we cut a corner here.
+        public String getBaseUri() { return null; }
+        public boolean isNotation(String arg0) { return false; }
+        public boolean isUnparsedEntity(String arg0) { return false; }
+    }
+
+    private Context currentContext=null;
+
+    /** Returns an immutable snapshot of the current context. */
+    public ValidationContext createValidationContext() {
+        return currentContext;
+    }
+
+    public XmlString createXmlString(String value) {
+        if(value==null)     return null;
+        else    return new XmlString(value,createValidationContext());
+    }
+
+    public void startPrefixMapping( String prefix, String uri ) throws SAXException {
+        super.startPrefixMapping(prefix,uri);
+        currentContext = new Context(prefix,uri,currentContext);
+    }
+    public void endPrefixMapping( String prefix ) throws SAXException {
+        super.endPrefixMapping(prefix);
+        currentContext = currentContext.previous;
+    }
+
+
+
+
+
+//
+//
+// Utility functions
+//
+//
+
+
+    /** Parses UName under the given context. */
+    public UName parseUName( String qname ) throws SAXException {
+        int idx = qname.indexOf(':');
+        if(idx<0) {
+            String uri = resolveNamespacePrefix("");
+
+            // chamelon behavior. ugly...
+            if( uri.equals("") && chameleonMode )
+                uri = currentSchema.getTargetNamespace();
+
+            // this is guaranteed to resolve
+            return new UName(uri,qname,qname);
+        } else {
+            String prefix = qname.substring(0,idx);
+            String uri = currentContext.resolveNamespacePrefix(prefix);
+            if(uri==null) {
+                // prefix failed to resolve.
+                reportError(Messages.format(
+                    Messages.ERR_UNDEFINED_PREFIX,prefix));
+                uri="undefined"; // replace with a dummy
+            }
+            return new UName( uri, qname.substring(idx+1), qname );
+        }
+    }
+
+    public boolean parseBoolean(String v) {
+        if(v==null) return false;
+        v=v.trim();
+        return v.equals("true") || v.equals("1");
+    }
+
+
+    protected void unexpectedX(String token) throws SAXException {
+        SAXParseException e = new SAXParseException(MessageFormat.format(
+            "Unexpected {0} appears at line {1} column {2}",
+                token,
+                getLocator().getLineNumber(),
+                getLocator().getColumnNumber()),
+            getLocator());
+
+        parser.errorHandler.fatalError(e);
+        throw e;    // we will abort anyway
+    }
+
+    public ForeignAttributesImpl parseForeignAttributes( ForeignAttributesImpl next ) {
+        ForeignAttributesImpl impl = new ForeignAttributesImpl(createValidationContext(),copyLocator(),next);
+
+        Attributes atts = getCurrentAttributes();
+        for( int i=0; i<atts.getLength(); i++ ) {
+            if(atts.getURI(i).length()>0) {
+                impl.addAttribute(
+                    atts.getURI(i),
+                    atts.getLocalName(i),
+                    atts.getQName(i),
+                    atts.getType(i),
+                    atts.getValue(i)
+                );
+            }
+        }
+
+        return impl;
+    }
+
+
+    public static final String XMLSchemaNSURI = "http://www.w3.org/2001/XMLSchema";
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/ParserContext.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/ParserContext.java
new file mode 100644
index 0000000..99f984d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/ParserContext.java
@@ -0,0 +1,202 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.parser;
+
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.impl.ElementDecl;
+import com.sun.xml.internal.xsom.impl.SchemaImpl;
+import com.sun.xml.internal.xsom.impl.SchemaSetImpl;
+import com.sun.xml.internal.xsom.parser.AnnotationParserFactory;
+import com.sun.xml.internal.xsom.parser.XMLParser;
+import com.sun.xml.internal.xsom.parser.XSOMParser;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Vector;
+
+/**
+ * Provides context information to be used by {@link NGCCRuntimeEx}s.
+ *
+ * <p>
+ * This class does the actual processing for {@link XSOMParser},
+ * but to hide the details from the public API, this class in
+ * a different package.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ParserContext {
+
+    /** SchemaSet to which a newly parsed schema is put in. */
+    public final SchemaSetImpl schemaSet = new SchemaSetImpl();
+
+    private final XSOMParser owner;
+
+    final XMLParser parser;
+
+
+    private final Vector<Patch> patchers = new Vector<Patch>();
+
+    /**
+     * Documents that are parsed already. Used to avoid cyclic inclusion/double
+     * inclusion of schemas. Set of {@link SchemaDocumentImpl}s.
+     *
+     * The actual data structure is map from {@link SchemaDocumentImpl} to itself,
+     * so that we can access the {@link SchemaDocumentImpl} itself.
+     */
+    public final Map<SchemaDocumentImpl, SchemaDocumentImpl> parsedDocuments = new HashMap<SchemaDocumentImpl, SchemaDocumentImpl>();
+
+
+    public ParserContext( XSOMParser owner, XMLParser parser ) {
+        this.owner = owner;
+        this.parser = parser;
+
+        try {
+            parse(new InputSource(ParserContext.class.getResource("datatypes.xsd").toExternalForm()));
+
+            SchemaImpl xs = (SchemaImpl)
+                schemaSet.getSchema("http://www.w3.org/2001/XMLSchema");
+            xs.addSimpleType(schemaSet.anySimpleType);
+            xs.addComplexType(schemaSet.anyType);
+        } catch( SAXException e ) {
+            // this must be a bug of XSOM
+            if(e.getException()!=null)
+                e.getException().printStackTrace();
+            else
+                e.printStackTrace();
+            throw new InternalError();
+        }
+    }
+
+    public EntityResolver getEntityResolver() {
+        return owner.getEntityResolver();
+    }
+
+    public AnnotationParserFactory getAnnotationParserFactory() {
+        return owner.getAnnotationParserFactory();
+    }
+
+    /**
+     * Parses a new XML Schema document.
+     */
+    public void parse( InputSource source ) throws SAXException {
+        newNGCCRuntime().parseEntity(source,false,null,null);
+    }
+
+
+    public XSSchemaSet getResult() throws SAXException {
+        // run all the patchers
+        for (Patch patcher : patchers)
+            patcher.run();
+        patchers.clear();
+
+        // build the element substitutability map
+        Iterator itr = schemaSet.iterateElementDecls();
+        while(itr.hasNext())
+            ((ElementDecl)itr.next()).updateSubstitutabilityMap();
+
+        if(hadError)    return null;
+        else            return schemaSet;
+    }
+
+    public NGCCRuntimeEx newNGCCRuntime() {
+        return new NGCCRuntimeEx(this);
+    }
+
+
+
+    /** Once an error is detected, this flag is set to true. */
+    private boolean hadError = false;
+
+    /** Turns on the error flag. */
+    void setErrorFlag() { hadError=true; }
+
+    /**
+     * PatchManager implementation, which is accessible only from
+     * NGCCRuntimEx.
+     */
+    final PatcherManager patcherManager = new PatcherManager() {
+        public void addPatcher( Patch patch ) {
+            patchers.add(patch);
+        }
+        public void reportError( String msg, Locator src ) throws SAXException {
+            // set a flag to true to avoid returning a corrupted object.
+            setErrorFlag();
+
+            SAXParseException e = new SAXParseException(msg,src);
+            if(errorHandler==null)
+                throw e;
+            else
+                errorHandler.error(e);
+        }
+    };
+
+    /**
+     * ErrorHandler proxy to turn on the hadError flag when an error
+     * is found.
+     */
+    final ErrorHandler errorHandler = new ErrorHandler() {
+        private ErrorHandler getErrorHandler() {
+            if( owner.getErrorHandler()==null )
+                return noopHandler;
+            else
+                return owner.getErrorHandler();
+        }
+
+        public void warning(SAXParseException e) throws SAXException {
+            getErrorHandler().warning(e);
+        }
+
+        public void error(SAXParseException e) throws SAXException {
+            setErrorFlag();
+            getErrorHandler().error(e);
+        }
+
+        public void fatalError(SAXParseException e) throws SAXException {
+            setErrorFlag();
+            getErrorHandler().fatalError(e);
+        }
+    };
+
+    /**
+     * {@link ErrorHandler} that does nothing.
+     */
+    final ErrorHandler noopHandler = new ErrorHandler() {
+        public void warning(SAXParseException e) {
+        }
+        public void error(SAXParseException e) {
+        }
+        public void fatalError(SAXParseException e) {
+            setErrorFlag();
+        }
+    };
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Patch.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Patch.java
new file mode 100644
index 0000000..98225ee
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/Patch.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.parser;
+
+import org.xml.sax.SAXException;
+
+/**
+ * Patch program that runs later to "fix" references among components.
+ *
+ * The only difference from the Runnable interface is that this interface
+ * allows the program to throw a SAXException.
+ */
+public interface Patch {
+    void run() throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/PatcherManager.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/PatcherManager.java
new file mode 100644
index 0000000..3458d95
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/PatcherManager.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.parser;
+
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+
+/**
+ * Manages patchers.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface PatcherManager {
+    void addPatcher( Patch p );
+    /**
+     * Reports an error during the parsing.
+     *
+     * @param source
+     *      location of the error in the source file, or null if
+     *      it's unavailable.
+     */
+    void reportError( String message, Locator source ) throws SAXException;
+
+
+    public interface Patcher {
+        void run() throws SAXException;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SAXParserFactoryAdaptor.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SAXParserFactoryAdaptor.java
new file mode 100644
index 0000000..93acba9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SAXParserFactoryAdaptor.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.parser;
+
+import com.sun.xml.internal.xsom.parser.XMLParser;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.XMLFilterImpl;
+import org.xml.sax.helpers.XMLReaderAdapter;
+
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.parsers.SAXParser;
+import javax.xml.parsers.SAXParserFactory;
+import java.io.IOException;
+
+
+/**
+ * {@link SAXParserFactory} implementation that ultimately
+ * uses {@link XMLParser} to parse documents.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class SAXParserFactoryAdaptor extends SAXParserFactory {
+
+    private final XMLParser parser;
+
+    public SAXParserFactoryAdaptor( XMLParser _parser ) {
+        this.parser = _parser;
+    }
+
+    public SAXParser newSAXParser() throws ParserConfigurationException, SAXException {
+        return new SAXParserImpl();
+    }
+
+    public void setFeature(String name, boolean value) {
+        ;
+    }
+
+    public boolean getFeature(String name) {
+        return false;
+    }
+
+    private class SAXParserImpl extends SAXParser
+    {
+        private final XMLReaderImpl reader = new XMLReaderImpl();
+
+        /**
+         * @deprecated
+         */
+        public org.xml.sax.Parser getParser() throws SAXException {
+            return new XMLReaderAdapter(reader);
+        }
+
+        public XMLReader getXMLReader() throws SAXException {
+            return reader;
+        }
+
+        public boolean isNamespaceAware() {
+            return true;
+        }
+
+        public boolean isValidating() {
+            return false;
+        }
+
+        public void setProperty(String name, Object value) {
+        }
+
+        public Object getProperty(String name) {
+            return null;
+        }
+    }
+
+    private class XMLReaderImpl extends XMLFilterImpl
+    {
+        public void parse(InputSource input) throws IOException, SAXException {
+            parser.parse(input,this,this,this);
+        }
+
+        public void parse(String systemId) throws IOException, SAXException {
+            parser.parse(new InputSource(systemId),this,this,this);
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SchemaDocumentImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SchemaDocumentImpl.java
new file mode 100644
index 0000000..cea2ab9
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SchemaDocumentImpl.java
@@ -0,0 +1,125 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.parser;
+
+import com.sun.xml.internal.xsom.impl.SchemaImpl;
+import com.sun.xml.internal.xsom.parser.SchemaDocument;
+
+import java.util.Collections;
+import java.util.HashSet;
+import java.util.Set;
+
+/**
+ * {@link SchemaDocument} implementation.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public final class SchemaDocumentImpl implements SchemaDocument
+{
+    private final SchemaImpl schema;
+
+    /**
+     * URI of the schema document to be parsed. Can be null.
+     */
+    private final String schemaDocumentURI;
+
+    /**
+     * {@link SchemaDocumentImpl}s that are referenced from this document.
+     */
+    final Set<SchemaDocumentImpl> references = new HashSet<SchemaDocumentImpl>();
+
+    /**
+     * {@link SchemaDocumentImpl}s that are referencing this document.
+     */
+    final Set<SchemaDocumentImpl> referers = new HashSet<SchemaDocumentImpl>();
+
+    protected SchemaDocumentImpl(SchemaImpl schema, String _schemaDocumentURI) {
+        this.schema = schema;
+        this.schemaDocumentURI = _schemaDocumentURI;
+    }
+
+    public String getSystemId() {
+        return schemaDocumentURI;
+    }
+
+    public String getTargetNamespace() {
+        return schema.getTargetNamespace();
+    }
+
+    public SchemaImpl getSchema() {
+        return schema;
+    }
+
+    public Set<SchemaDocument> getReferencedDocuments() {
+        return Collections.<SchemaDocument>unmodifiableSet(references);
+    }
+
+    public Set<SchemaDocument> getIncludedDocuments() {
+        return getImportedDocuments(this.getTargetNamespace());
+    }
+
+    public Set<SchemaDocument> getImportedDocuments(String targetNamespace) {
+        if(targetNamespace==null)
+            throw new IllegalArgumentException();
+        Set<SchemaDocument> r = new HashSet<SchemaDocument>();
+        for (SchemaDocumentImpl doc : references) {
+            if(doc.getTargetNamespace().equals(targetNamespace))
+                r.add(doc);
+        }
+        return Collections.unmodifiableSet(r);
+    }
+
+    public boolean includes(SchemaDocument doc) {
+        if(!references.contains(doc))
+            return false;
+        return doc.getSchema()==schema;
+    }
+
+    public boolean imports(SchemaDocument doc) {
+        if(!references.contains(doc))
+            return false;
+        return doc.getSchema()!=schema;
+    }
+
+    public Set<SchemaDocument> getReferers() {
+        return Collections.<SchemaDocument>unmodifiableSet(referers);
+    }
+
+    public boolean equals(Object o) {
+        SchemaDocumentImpl rhs = (SchemaDocumentImpl) o;
+
+        if( this.schemaDocumentURI==null || rhs.schemaDocumentURI==null)
+            return this==rhs;
+        if(!schemaDocumentURI.equals(rhs.schemaDocumentURI) )
+            return false;
+        return this.schema==rhs.schema;
+    }
+    public int hashCode() {
+        if(schemaDocumentURI==null)
+            return super.hashCode();
+        return schemaDocumentURI.hashCode()^this.schema.hashCode();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SubstGroupBaseTypeRef.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SubstGroupBaseTypeRef.java
new file mode 100644
index 0000000..adc9047
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/SubstGroupBaseTypeRef.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.parser;
+
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.impl.Ref;
+
+/**
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class SubstGroupBaseTypeRef implements Ref.Type {
+    private final Ref.Element e;
+
+    public SubstGroupBaseTypeRef( Ref.Element _e ) {
+        this.e = _e;
+    }
+
+    public XSType getType() {
+        return e.get().getType();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/datatypes.xsd b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/datatypes.xsd
new file mode 100644
index 0000000..ba81ced
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/datatypes.xsd
@@ -0,0 +1,365 @@
+<?xml version='1.0'?>
+
+<!--
+ Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+ This code is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License version 2 only, as
+ published by the Free Software Foundation.  Sun designates this
+ particular file as subject to the "Classpath" exception as provided
+ by Sun in the LICENSE file that accompanied this code.
+
+ This code is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ version 2 for more details (a copy is included in the LICENSE file that
+ accompanied this code).
+
+ You should have received a copy of the GNU General Public License version
+ 2 along with this work; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+ Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ CA 95054 USA or visit www.sun.com if you need additional information or
+ have any questions.
+-->
+
+<!-- XML Schema schema for XML Schemas: Part 2: Datatypes -->
+<!--
+	This file is fed to XSOM to build schema components for built-in datatypes.
+	This file is *NOT* for validating the source schema files.
+-->
+<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
+        targetNamespace="http://www.w3.org/2001/XMLSchema"
+        version="Id: datatypes.xsd,v 1.52 2001/04/27 11:49:21 ht Exp "
+        elementFormDefault="qualified"
+        blockDefault="#all"
+        xml:lang="en">
+
+  <xs:simpleType name="string" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="preserve" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="boolean" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse" fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="float" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse" fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="double" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="decimal" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+   </xs:simpleType>
+
+   <xs:simpleType name="duration" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+   </xs:simpleType>
+
+ <xs:simpleType name="dateTime" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="time" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="date" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="gYearMonth" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="gYear" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+ <xs:simpleType name="gMonthDay" >
+    <xs:restriction base="xs:anySimpleType">
+         <xs:whiteSpace value="collapse" fixed="true"
+                />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="gDay" >
+    <xs:restriction base="xs:anySimpleType">
+         <xs:whiteSpace value="collapse"  fixed="true"
+                />
+    </xs:restriction>
+  </xs:simpleType>
+
+ <xs:simpleType name="gMonth" >
+    <xs:restriction base="xs:anySimpleType">
+         <xs:whiteSpace value="collapse"  fixed="true"
+                />
+    </xs:restriction>
+  </xs:simpleType>
+
+   <xs:simpleType name="hexBinary" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse" fixed="true"
+        />
+    </xs:restriction>
+   </xs:simpleType>
+ 
+ <xs:simpleType name="base64Binary" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse" fixed="true"
+        />
+    </xs:restriction>
+   </xs:simpleType>
+
+   <xs:simpleType name="anyURI" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+   </xs:simpleType>
+
+  <xs:simpleType name="QName" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+   <xs:simpleType name="NOTATION" >
+    <xs:restriction base="xs:anySimpleType">
+      <xs:whiteSpace value="collapse"  fixed="true"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="normalizedString" >
+    <xs:restriction base="xs:string">
+      <xs:whiteSpace value="replace"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+  
+  <xs:simpleType name="token" >
+    <xs:restriction base="xs:normalizedString">
+      <xs:whiteSpace value="collapse" />
+    </xs:restriction>
+  </xs:simpleType>
+  
+  <xs:simpleType name="language" >
+    <xs:restriction base="xs:token">
+      <xs:pattern
+        value="([a-zA-Z]{2}|[iI]-[a-zA-Z]+|[xX]-[a-zA-Z]{1,8})(-[a-zA-Z]{1,8})*"
+                >
+        <xs:annotation>
+          <xs:documentation
+                source="http://www.w3.org/TR/REC-xml#NT-LanguageID">
+            pattern specifies the content of section 2.12 of XML 1.0e2
+            and RFC 1766
+          </xs:documentation>
+        </xs:annotation>
+      </xs:pattern>
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="IDREFS" >
+    <xs:restriction>
+      <xs:simpleType>
+        <xs:list itemType="xs:IDREF"/>    
+      </xs:simpleType>
+        <xs:minLength value="1" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="ENTITIES" >
+    <xs:restriction>
+      <xs:simpleType>
+        <xs:list itemType="xs:ENTITY"/>
+      </xs:simpleType>
+        <xs:minLength value="1" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="NMTOKEN" >
+    <xs:restriction base="xs:token">
+      <xs:pattern value="\c+" >
+        <xs:annotation>
+          <xs:documentation
+                source="http://www.w3.org/TR/REC-xml#NT-Nmtoken">
+            pattern matches production 7 from the XML spec
+          </xs:documentation>
+        </xs:annotation>
+      </xs:pattern>
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="NMTOKENS" >
+    <xs:restriction>
+      <xs:simpleType>
+        <xs:list itemType="xs:NMTOKEN"/>
+      </xs:simpleType>
+        <xs:minLength value="1" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="Name" >
+    <xs:restriction base="xs:token">
+      <xs:pattern value="\i\c*" >
+        <xs:annotation>
+          <xs:documentation
+                        source="http://www.w3.org/TR/REC-xml#NT-Name">
+            pattern matches production 5 from the XML spec
+          </xs:documentation>
+        </xs:annotation>
+      </xs:pattern>
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="NCName" >
+    <xs:restriction base="xs:Name">
+      <xs:pattern value="[\i-[:]][\c-[:]]*" >
+        <xs:annotation>
+          <xs:documentation
+                source="http://www.w3.org/TR/REC-xml-names/#NT-NCName">
+            pattern matches production 4 from the Namespaces in XML spec
+          </xs:documentation>
+        </xs:annotation>
+      </xs:pattern>
+    </xs:restriction>
+  </xs:simpleType>
+
+   <xs:simpleType name="ID" >
+    <xs:restriction base="xs:NCName"/>
+   </xs:simpleType>
+
+   <xs:simpleType name="IDREF" >
+    <xs:restriction base="xs:NCName"/>
+   </xs:simpleType>
+
+   <xs:simpleType name="ENTITY" >
+    <xs:restriction base="xs:NCName"/>
+   </xs:simpleType>
+
+  <xs:simpleType name="integer" >
+    <xs:restriction base="xs:decimal">
+      <xs:fractionDigits value="0" fixed="true" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="nonPositiveInteger" >
+    <xs:restriction base="xs:integer">
+      <xs:maxInclusive value="0" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="negativeInteger" >
+    <xs:restriction base="xs:nonPositiveInteger">
+      <xs:maxInclusive value="-1" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="long" >
+    <xs:restriction base="xs:integer">
+      <xs:minInclusive value="-9223372036854775808" />
+      <xs:maxInclusive value="9223372036854775807" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="int" >
+    <xs:restriction base="xs:long">
+      <xs:minInclusive value="-2147483648" />
+      <xs:maxInclusive value="2147483647" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="short" >
+    <xs:restriction base="xs:int">
+      <xs:minInclusive value="-32768" />
+      <xs:maxInclusive value="32767" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="byte" >
+    <xs:restriction base="xs:short">
+      <xs:minInclusive value="-128" />
+      <xs:maxInclusive value="127" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="nonNegativeInteger" >
+    <xs:restriction base="xs:integer">
+      <xs:minInclusive value="0" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="unsignedLong" >
+    <xs:restriction base="xs:nonNegativeInteger">
+      <xs:maxInclusive value="18446744073709551615"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="unsignedInt" >
+    <xs:restriction base="xs:unsignedLong">
+      <xs:maxInclusive value="4294967295"
+        />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="unsignedShort" >
+    <xs:restriction base="xs:unsignedInt">
+      <xs:maxInclusive value="65535" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="unsignedByte" >
+    <xs:restriction base="xs:unsignedShort">
+      <xs:maxInclusive value="255" />
+    </xs:restriction>
+  </xs:simpleType>
+
+  <xs:simpleType name="positiveInteger" >
+    <xs:restriction base="xs:nonNegativeInteger">
+      <xs:minInclusive value="1" />
+    </xs:restriction>
+  </xs:simpleType>
+
+
+</xs:schema>
+
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/package.html b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/package.html
new file mode 100644
index 0000000..95405cb
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/package.html
@@ -0,0 +1,3 @@
+<html><body>
+Parser that reads XML Schema documents and builds an <code>XSSchemaSet</code> object.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/AttributesImpl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/AttributesImpl.java
new file mode 100644
index 0000000..f0ab667
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/AttributesImpl.java
@@ -0,0 +1,625 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+// AttributesImpl.java - default implementation of Attributes.
+// Written by David Megginson, sax@megginson.com
+// NO WARRANTY!  This class is in the public domain.
+
+// $Id: AttributesImpl.java,v 1.4 2002/09/29 02:55:48 okajima Exp $
+
+//fixed bug at removeAttribute!! by Daisuke OKAJIMA 2002.4.21
+
+package com.sun.xml.internal.xsom.impl.parser.state;
+
+import org.xml.sax.Attributes;
+
+
+/**
+ * Default implementation of the Attributes interface.
+ *
+ * <blockquote>
+ * <em>This module, both source code and documentation, is in the
+ * Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
+ * </blockquote>
+ *
+ * <p>This class provides a default implementation of the SAX2
+ * {@link org.xml.sax.Attributes Attributes} interface, with the
+ * addition of manipulators so that the list can be modified or
+ * reused.</p>
+ *
+ * <p>There are two typical uses of this class:</p>
+ *
+ * <ol>
+ * <li>to take a persistent snapshot of an Attributes object
+ *  in a {@link org.xml.sax.ContentHandler#startElement startElement} event; or</li>
+ * <li>to construct or modify an Attributes object in a SAX2 driver or filter.</li>
+ * </ol>
+ *
+ * <p>This class replaces the now-deprecated SAX1 {@link
+ * org.xml.sax.helpers.AttributeListImpl AttributeListImpl}
+ * class; in addition to supporting the updated Attributes
+ * interface rather than the deprecated {@link org.xml.sax.AttributeList
+ * AttributeList} interface, it also includes a much more efficient
+ * implementation using a single array rather than a set of Vectors.</p>
+ *
+ * @since SAX 2.0
+ * @author David Megginson,
+ *         <a href="mailto:sax@megginson.com">sax@megginson.com</a>
+ */
+public class AttributesImpl implements Attributes
+{
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Constructors.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Construct a new, empty AttributesImpl object.
+     */
+    public AttributesImpl ()
+    {
+    length = 0;
+    data = null;
+    }
+
+
+    /**
+     * Copy an existing Attributes object.
+     *
+     * <p>This constructor is especially useful inside a
+     * {@link org.xml.sax.ContentHandler#startElement startElement} event.</p>
+     *
+     * @param atts The existing Attributes object.
+     */
+    public AttributesImpl (Attributes atts)
+    {
+    setAttributes(atts);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Implementation of org.xml.sax.Attributes.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Return the number of attributes in the list.
+     *
+     * @return The number of attributes in the list.
+     * @see org.xml.sax.Attributes#getLength
+     */
+    public int getLength ()
+    {
+    return length;
+    }
+
+
+    /**
+     * Return an attribute's Namespace URI.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The Namespace URI, the empty string if none is
+     *         available, or null if the index is out of range.
+     * @see org.xml.sax.Attributes#getURI
+     */
+    public String getURI (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Return an attribute's local name.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's local name, the empty string if
+     *         none is available, or null if the index if out of range.
+     * @see org.xml.sax.Attributes#getLocalName
+     */
+    public String getLocalName (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5+1];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Return an attribute's qualified (prefixed) name.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's qualified name, the empty string if
+     *         none is available, or null if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getQName
+     */
+    public String getQName (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5+2];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Return an attribute's type by index.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's type, "CDATA" if the type is unknown, or null
+     *         if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getType(int)
+     */
+    public String getType (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5+3];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Return an attribute's value by index.
+     *
+     * @param index The attribute's index (zero-based).
+     * @return The attribute's value or null if the index is out of bounds.
+     * @see org.xml.sax.Attributes#getValue(int)
+     */
+    public String getValue (int index)
+    {
+    if (index >= 0 && index < length) {
+        return data[index*5+4];
+    } else {
+        return null;
+    }
+    }
+
+
+    /**
+     * Look up an attribute's index by Namespace name.
+     *
+     * <p>In many cases, it will be more efficient to look up the name once and
+     * use the index query methods rather than using the name query methods
+     * repeatedly.</p>
+     *
+     * @param uri The attribute's Namespace URI, or the empty
+     *        string if none is available.
+     * @param localName The attribute's local name.
+     * @return The attribute's index, or -1 if none matches.
+     * @see org.xml.sax.Attributes#getIndex(java.lang.String,java.lang.String)
+     */
+    public int getIndex (String uri, String localName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i].equals(uri) && data[i+1].equals(localName)) {
+        return i / 5;
+        }
+    }
+    return -1;
+    }
+
+
+    /**
+     * Look up an attribute's index by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's index, or -1 if none matches.
+     * @see org.xml.sax.Attributes#getIndex(java.lang.String)
+     */
+    public int getIndex (String qName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i+2].equals(qName)) {
+        return i / 5;
+        }
+    }
+    return -1;
+    }
+
+
+    /**
+     * Look up an attribute's type by Namespace-qualified name.
+     *
+     * @param uri The Namespace URI, or the empty string for a name
+     *        with no explicit Namespace URI.
+     * @param localName The local name.
+     * @return The attribute's type, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getType(java.lang.String,java.lang.String)
+     */
+    public String getType (String uri, String localName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i].equals(uri) && data[i+1].equals(localName)) {
+        return data[i+3];
+        }
+    }
+    return null;
+    }
+
+
+    /**
+     * Look up an attribute's type by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's type, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getType(java.lang.String)
+     */
+    public String getType (String qName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i+2].equals(qName)) {
+        return data[i+3];
+        }
+    }
+    return null;
+    }
+
+
+    /**
+     * Look up an attribute's value by Namespace-qualified name.
+     *
+     * @param uri The Namespace URI, or the empty string for a name
+     *        with no explicit Namespace URI.
+     * @param localName The local name.
+     * @return The attribute's value, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getValue(java.lang.String,java.lang.String)
+     */
+    public String getValue (String uri, String localName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i].equals(uri) && data[i+1].equals(localName)) {
+        return data[i+4];
+        }
+    }
+    return null;
+    }
+
+
+    /**
+     * Look up an attribute's value by qualified (prefixed) name.
+     *
+     * @param qName The qualified name.
+     * @return The attribute's value, or null if there is no
+     *         matching attribute.
+     * @see org.xml.sax.Attributes#getValue(java.lang.String)
+     */
+    public String getValue (String qName)
+    {
+    int max = length * 5;
+    for (int i = 0; i < max; i += 5) {
+        if (data[i+2].equals(qName)) {
+        return data[i+4];
+        }
+    }
+    return null;
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Manipulators.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Clear the attribute list for reuse.
+     *
+     * <p>Note that no memory is actually freed by this call:
+     * the current arrays are kept so that they can be
+     * reused.</p>
+     */
+    public void clear ()
+    {
+    length = 0;
+    }
+
+
+    /**
+     * Copy an entire Attributes object.
+     *
+     * <p>It may be more efficient to reuse an existing object
+     * rather than constantly allocating new ones.</p>
+     *
+     * @param atts The attributes to copy.
+     */
+    public void setAttributes (Attributes atts)
+    {
+    clear();
+    length = atts.getLength();
+    data = new String[length*5];
+    for (int i = 0; i < length; i++) {
+        data[i*5] = atts.getURI(i);
+        data[i*5+1] = atts.getLocalName(i);
+        data[i*5+2] = atts.getQName(i);
+        data[i*5+3] = atts.getType(i);
+        data[i*5+4] = atts.getValue(i);
+    }
+    }
+
+
+    /**
+     * Add an attribute to the end of the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * to see if the attribute is already in the list: that is
+     * the responsibility of the application.</p>
+     *
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified (prefixed) name, or the empty string
+     *        if qualified names are not available.
+     * @param type The attribute type as a string.
+     * @param value The attribute value.
+     */
+    public void addAttribute (String uri, String localName, String qName,
+                  String type, String value)
+    {
+    ensureCapacity(length+1);
+    data[length*5] = uri;
+    data[length*5+1] = localName;
+    data[length*5+2] = qName;
+    data[length*5+3] = type;
+    data[length*5+4] = value;
+    length++;
+    }
+
+
+    /**
+     * Set an attribute in the list.
+     *
+     * <p>For the sake of speed, this method does no checking
+     * for name conflicts or well-formedness: such checks are the
+     * responsibility of the application.</p>
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param uri The Namespace URI, or the empty string if
+     *        none is available or Namespace processing is not
+     *        being performed.
+     * @param localName The local name, or the empty string if
+     *        Namespace processing is not being performed.
+     * @param qName The qualified name, or the empty string
+     *        if qualified names are not available.
+     * @param type The attribute type as a string.
+     * @param value The attribute value.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setAttribute (int index, String uri, String localName,
+                  String qName, String type, String value)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5] = uri;
+        data[index*5+1] = localName;
+        data[index*5+2] = qName;
+        data[index*5+3] = type;
+        data[index*5+4] = value;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Remove an attribute from the list.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void removeAttribute (int index)
+    {
+        if (index >= 0 && index < length) {
+            if (index < length - 1) {
+                System.arraycopy(data, (index+1)*5, data, index*5,
+                         (length-index-1)*5);
+            }
+            length--;
+        } else {
+            badIndex(index);
+        }
+    }
+
+
+    /**
+     * Set the Namespace URI of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param uri The attribute's Namespace URI, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setURI (int index, String uri)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5] = uri;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Set the local name of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param localName The attribute's local name, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setLocalName (int index, String localName)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5+1] = localName;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Set the qualified name of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param qName The attribute's qualified name, or the empty
+     *        string for none.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setQName (int index, String qName)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5+2] = qName;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Set the type of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param type The attribute's type.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setType (int index, String type)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5+3] = type;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+    /**
+     * Set the value of a specific attribute.
+     *
+     * @param index The index of the attribute (zero-based).
+     * @param value The attribute's value.
+     * @exception java.lang.ArrayIndexOutOfBoundsException When the
+     *            supplied index does not point to an attribute
+     *            in the list.
+     */
+    public void setValue (int index, String value)
+    {
+    if (index >= 0 && index < length) {
+        data[index*5+4] = value;
+    } else {
+        badIndex(index);
+    }
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal methods.
+    ////////////////////////////////////////////////////////////////////
+
+
+    /**
+     * Ensure the internal array's capacity.
+     *
+     * @param n The minimum number of attributes that the array must
+     *        be able to hold.
+     */
+    private void ensureCapacity (int n)
+    {
+    if (n > 0 && (data == null || data.length==0)) {
+        data = new String[25];
+    }
+
+    int max = data.length;
+    if (max >= n * 5) {
+        return;
+    }
+
+
+    while (max < n * 5) {
+        max *= 2;
+    }
+    String newData[] = new String[max];
+    System.arraycopy(data, 0, newData, 0, length*5);
+    data = newData;
+    }
+
+
+    /**
+     * Report a bad array index in a manipulator.
+     *
+     * @param index The index to report.
+     * @exception java.lang.ArrayIndexOutOfBoundsException Always.
+     */
+    private void badIndex (int index)
+    throws ArrayIndexOutOfBoundsException
+    {
+    String msg =
+        "Attempt to modify attribute at illegal index: " + index;
+    throw new ArrayIndexOutOfBoundsException(msg);
+    }
+
+
+
+    ////////////////////////////////////////////////////////////////////
+    // Internal state.
+    ////////////////////////////////////////////////////////////////////
+
+    int length;
+    String data [];
+
+}
+
+// end of AttributesImpl.java
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCEventReceiver.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCEventReceiver.java
new file mode 100644
index 0000000..ae2c48b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCEventReceiver.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.parser.state;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ *
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface NGCCEventReceiver {
+    void enterElement(String uri, String localName, String qname,Attributes atts) throws SAXException;
+    void leaveElement(String uri, String localName, String qname) throws SAXException;
+    void text(String value) throws SAXException;
+    void enterAttribute(String uri, String localName, String qname) throws SAXException;
+    void leaveAttribute(String uri, String localName, String qname) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCEventSource.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCEventSource.java
new file mode 100644
index 0000000..2fe9b57
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCEventSource.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.parser.state;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ *
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public interface NGCCEventSource {
+    /**
+     * Replaces an old handler with a new handler, and returns
+     * ID of the EventReceiver thread.
+     */
+    int replace( NGCCEventReceiver _old, NGCCEventReceiver _new );
+
+    /** Sends an enter element event to the specified EventReceiver thread. */
+    void sendEnterElement( int receiverThreadId, String uri, String local, String qname, Attributes atts ) throws SAXException;
+
+    void sendLeaveElement( int receiverThreadId, String uri, String local, String qname ) throws SAXException;
+    void sendEnterAttribute( int receiverThreadId, String uri, String local, String qname ) throws SAXException;
+    void sendLeaveAttribute( int receiverThreadId, String uri, String local, String qname ) throws SAXException;
+    void sendText( int receiverThreadId, String value ) throws SAXException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCHandler.java
new file mode 100644
index 0000000..42bf262
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCHandler.java
@@ -0,0 +1,190 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.parser.state;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ *
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class NGCCHandler implements NGCCEventReceiver {
+    protected NGCCHandler( NGCCEventSource source, NGCCHandler parent, int parentCookie ) {
+
+        _parent = parent;
+        _source = source;
+        _cookie = parentCookie;
+    }
+
+    /**
+     * Parent NGCCHandler, if any.
+     * If this is the root handler, this field will be null.
+     */
+    protected final NGCCHandler _parent;
+
+    /**
+     * Event source.
+     */
+    protected final NGCCEventSource _source;
+
+    /**
+     * This method will be implemented by the generated code
+     * and returns a reference to the current runtime.
+     */
+    protected abstract NGCCRuntime getRuntime();
+
+    /**
+     * Cookie assigned by the parent.
+     *
+     * This value will be passed to the onChildCompleted handler
+     * of the parent.
+     */
+    protected final int _cookie;
+
+    // used to copy parameters to (enter|leave)(Element|Attribute) events.
+    //protected String localName,uri,qname;
+
+
+    /**
+     * Notifies the completion of a child object.
+     *
+     * @param result
+     *      The parsing result of the child state.
+     * @param cookie
+     *      The cookie value passed to the child object
+     *      when it is created.
+     * @param needAttCheck
+     *      This flag is true when the callee needs to call the
+     *      processAttribute method to check attribute transitions.
+     *      This flag is set to false when this method is triggered by
+     *      attribute transition.
+     */
+    protected abstract void onChildCompleted( Object result, int cookie, boolean needAttCheck ) throws SAXException;
+
+//
+//
+// spawns a new child object from event handlers.
+//
+//
+    public void spawnChildFromEnterElement( NGCCEventReceiver child,
+        String uri, String localname, String qname, Attributes atts) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendEnterElement(id,uri,localname,qname,atts);
+    }
+    public void spawnChildFromEnterAttribute( NGCCEventReceiver child,
+        String uri, String localname, String qname) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendEnterAttribute(id,uri,localname,qname);
+    }
+    public void spawnChildFromLeaveElement( NGCCEventReceiver child,
+        String uri, String localname, String qname) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendLeaveElement(id,uri,localname,qname);
+    }
+    public void spawnChildFromLeaveAttribute( NGCCEventReceiver child,
+        String uri, String localname, String qname) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendLeaveAttribute(id,uri,localname,qname);
+    }
+    public void spawnChildFromText( NGCCEventReceiver child,
+        String value) throws SAXException {
+
+        int id = _source.replace(this,child);
+        _source.sendText(id,value);
+    }
+
+//
+//
+// reverts to the parent object from the child handler
+//
+//
+    public void revertToParentFromEnterElement( Object result, int cookie,
+        String uri,String local,String qname, Attributes atts ) throws SAXException {
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendEnterElement(id,uri,local,qname,atts);
+    }
+    public void revertToParentFromLeaveElement( Object result, int cookie,
+        String uri,String local,String qname ) throws SAXException {
+
+        if(uri==NGCCRuntime.IMPOSSIBLE && uri==local && uri==qname && _parent==null )
+            // all the handlers are properly finalized.
+            // quit now, because we don't have any more NGCCHandler.
+            // see the endDocument handler for detail
+            return;
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendLeaveElement(id,uri,local,qname);
+    }
+    public void revertToParentFromEnterAttribute( Object result, int cookie,
+        String uri,String local,String qname ) throws SAXException {
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendEnterAttribute(id,uri,local,qname);
+    }
+    public void revertToParentFromLeaveAttribute( Object result, int cookie,
+        String uri,String local,String qname ) throws SAXException {
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendLeaveAttribute(id,uri,local,qname);
+    }
+    public void revertToParentFromText( Object result, int cookie,
+        String text ) throws SAXException {
+
+        int id = _source.replace(this,_parent);
+        _parent.onChildCompleted(result,cookie,true);
+        _source.sendText(id,text);
+    }
+
+
+//
+//
+// error handler
+//
+//
+    public void unexpectedEnterElement(String qname) throws SAXException {
+        getRuntime().unexpectedX('<'+qname+'>');
+    }
+    public void unexpectedLeaveElement(String qname) throws SAXException {
+        getRuntime().unexpectedX("</"+qname+'>');
+    }
+    public void unexpectedEnterAttribute(String qname) throws SAXException {
+        getRuntime().unexpectedX('@'+qname);
+    }
+    public void unexpectedLeaveAttribute(String qname) throws SAXException {
+        getRuntime().unexpectedX("/@"+qname);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCInterleaveFilter.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCInterleaveFilter.java
new file mode 100644
index 0000000..774ac7b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCInterleaveFilter.java
@@ -0,0 +1,350 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.parser.state;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.SAXException;
+
+/**
+ * Dispatches incoming events into sub handlers appropriately
+ * so that the interleaving semantics will be correctly realized.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public abstract class NGCCInterleaveFilter implements NGCCEventSource, NGCCEventReceiver {
+    protected NGCCInterleaveFilter( NGCCHandler parent, int cookie ) {
+        this._parent = parent;
+        this._cookie = cookie;
+    }
+
+    protected void setHandlers( NGCCEventReceiver[] receivers ) {
+        this._receivers = receivers;
+    }
+
+    /** event receiverse. */
+    protected NGCCEventReceiver[] _receivers;
+
+    public int replace(NGCCEventReceiver oldHandler, NGCCEventReceiver newHandler) {
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]==oldHandler ) {
+                _receivers[i]=newHandler;
+                return i;
+            }
+        throw new InternalError(); // a bug in RelaxNGCC.
+    }
+
+
+    /** Parent handler. */
+    private final NGCCHandler _parent;
+    /** Cookie given by the parent. */
+    private final int _cookie;
+
+
+
+//
+//
+// event handler
+//
+//
+    /**
+     * Receiver that is being locked and therefore receives all the events.
+     * <pre><xmp>
+     * <interleave>
+     *   <element name="foo"/>
+     *   <element name="bar">
+     *     <element name="foo"/>
+     *   </element>
+     * </interlaeve>
+     * </xmp></pre>
+     * When processing inside the bar element, this receiver is
+     * "locked" so that it can correctly receive its child foo element.
+     */
+    private int lockedReceiver;
+    /**
+     * Nest level. Lock will be release when the lockCount becomes 0.
+     */
+    private int lockCount=0;
+
+    public void enterElement(
+        String uri, String localName, String qname,Attributes atts) throws SAXException {
+
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if(lockCount++==0) {
+            lockedReceiver = findReceiverOfElement(uri,localName);
+            if(lockedReceiver==-1) {
+                // we can't process this token. join.
+                joinByEnterElement(null,uri,localName,qname,atts);
+                return;
+            }
+        }
+
+        _receivers[lockedReceiver].enterElement(uri,localName,qname,atts);
+    }
+    public void leaveElement(String uri, String localName, String qname) throws SAXException {
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if( lockCount-- == 0 )
+            joinByLeaveElement(null,uri,localName,qname);
+        else
+            _receivers[lockedReceiver].leaveElement(uri,localName,qname);
+    }
+    public void enterAttribute(String uri, String localName, String qname) throws SAXException {
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if(lockCount++==0) {
+            lockedReceiver = findReceiverOfAttribute(uri,localName);
+            if(lockedReceiver==-1) {
+                // we can't process this token. join.
+                joinByEnterAttribute(null,uri,localName,qname);
+                return;
+            }
+        }
+
+        _receivers[lockedReceiver].enterAttribute(uri,localName,qname);
+    }
+    public void leaveAttribute(String uri, String localName, String qname) throws SAXException {
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if( lockCount-- == 0 )
+            joinByLeaveAttribute(null,uri,localName,qname);
+        else
+            _receivers[lockedReceiver].leaveAttribute(uri,localName,qname);
+    }
+    public void text(String value) throws SAXException {
+        if(isJoining)   return; // ignore any token if we are joining. See joinByXXXX.
+
+        if(lockCount!=0)
+            _receivers[lockedReceiver].text(value);
+        else {
+            int receiver = findReceiverOfText();
+            if(receiver!=-1)    _receivers[receiver].text(value);
+            else                joinByText(null,value);
+        }
+    }
+
+
+
+    /**
+     * Implemented by the generated code to determine the handler
+     * that can receive the given element.
+     *
+     * @return
+     *      Thread ID of the receiver that can handle this event,
+     *      or -1 if none.
+     */
+    protected abstract int findReceiverOfElement( String uri, String local );
+
+    /**
+     * Returns the handler that can receive the given attribute, or null.
+     */
+    protected abstract int findReceiverOfAttribute( String uri, String local );
+
+    /**
+     * Returns the handler that can receive text events, or null.
+     */
+    protected abstract int findReceiverOfText();
+
+
+
+
+//
+//
+// join method
+//
+//
+
+
+    /**
+     * Set to true when this handler is in the process of
+     * joining all branches.
+     */
+    private boolean isJoining = false;
+
+    /**
+     * Joins all the child receivers.
+     *
+     * <p>
+     * This method is called by a child receiver when it sees
+     * something that it cannot handle, or by this object itself
+     * when it sees an event that it can't process.
+     *
+     * <p>
+     * This method forces children to move to its final state,
+     * then revert to the parent.
+     *
+     * @param source
+     *      If this method is called by one of the child receivers,
+     *      the receiver object. If this method is called by itself,
+     *      null.
+     */
+    public void joinByEnterElement( NGCCEventReceiver source,
+        String uri, String local, String qname, Attributes atts ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].enterElement(uri,local,qname,atts);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.enterElement(uri,local,qname,atts);
+    }
+
+    public void joinByLeaveElement( NGCCEventReceiver source,
+        String uri, String local, String qname ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].leaveElement(uri,local,qname);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.leaveElement(uri,local,qname);
+    }
+
+    public void joinByEnterAttribute( NGCCEventReceiver source,
+        String uri, String local, String qname ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].enterAttribute(uri,local,qname);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.enterAttribute(uri,local,qname);
+    }
+
+    public void joinByLeaveAttribute( NGCCEventReceiver source,
+        String uri, String local, String qname ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].leaveAttribute(uri,local,qname);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.leaveAttribute(uri,local,qname);
+    }
+
+    public void joinByText( NGCCEventReceiver source,
+        String value ) throws SAXException {
+
+        if(isJoining)   return; // we are already in the process of joining. ignore.
+        isJoining = true;
+
+        // send special token to the rest of the branches.
+        // these branches don't understand this token, so they will
+        // try to move to a final state and send the token back to us,
+        // which this object will ignore (because isJoining==true)
+        // Otherwise branches will find an error.
+        for( int i=0; i<_receivers.length; i++ )
+            if( _receivers[i]!=source )
+                _receivers[i].text(value);
+
+        // revert to the parent
+        _parent._source.replace(this,_parent);
+        _parent.onChildCompleted(null,_cookie,true);
+        // send this event to the parent
+        _parent.text(value);
+    }
+
+
+
+//
+//
+// event dispatching methods
+//
+//
+
+    public void sendEnterAttribute( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        _receivers[threadId].enterAttribute(uri,local,qname);
+    }
+
+    public void sendEnterElement( int threadId,
+        String uri, String local, String qname, Attributes atts) throws SAXException {
+
+        _receivers[threadId].enterElement(uri,local,qname,atts);
+    }
+
+    public void sendLeaveAttribute( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        _receivers[threadId].leaveAttribute(uri,local,qname);
+    }
+
+    public void sendLeaveElement( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        _receivers[threadId].leaveElement(uri,local,qname);
+    }
+
+    public void sendText(int threadId, String value) throws SAXException {
+        _receivers[threadId].text(value);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCRuntime.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCRuntime.java
new file mode 100644
index 0000000..b8627db
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/NGCCRuntime.java
@@ -0,0 +1,554 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.parser.state;
+
+import java.text.MessageFormat;
+import java.util.ArrayList;
+import java.util.Stack;
+import java.util.StringTokenizer;
+
+import org.xml.sax.Attributes;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Runtime Engine for RELAXNGCC execution.
+ *
+ * This class has the following functionalities:
+ *
+ * <ol>
+ *  <li>Managing a stack of NGCCHandler objects and
+ *      switching between them appropriately.
+ *
+ *  <li>Keep track of all Attributes.
+ *
+ *  <li>manage mapping between namespace URIs and prefixes.
+ *
+ *  <li>TODO: provide support for interleaving.
+ *
+ * @author Kohsuke Kawaguchi (kk@kohsuke.org)
+ */
+public class NGCCRuntime implements ContentHandler, NGCCEventSource {
+
+    public NGCCRuntime() {
+        reset();
+    }
+
+    /**
+     * Sets the root handler, which will be used to parse the
+     * root element.
+     * <p>
+     * This method can be called right after the object is created
+     * or the reset method is called. You can't replace the root
+     * handler while parsing is in progress.
+     * <p>
+     * Usually a generated class that corresponds to the &lt;start>
+     * pattern will be used as the root handler, but any NGCCHandler
+     * can be a root handler.
+     *
+     * @exception IllegalStateException
+     *      If this method is called but it doesn't satisfy the
+     *      pre-condition stated above.
+     */
+    public void setRootHandler( NGCCHandler rootHandler ) {
+        if(currentHandler!=null)
+            throw new IllegalStateException();
+        currentHandler = rootHandler;
+    }
+
+
+    /**
+     * Cleans up all the data structure so that the object can be reused later.
+     * Normally, applications do not need to call this method directly,
+     *
+     * as the runtime resets itself after the endDocument method.
+     */
+    public void reset() {
+        attStack.clear();
+        currentAtts = null;
+        currentHandler = null;
+        indent=0;
+        locator = null;
+        namespaces.clear();
+        needIndent = true;
+        redirect = null;
+        redirectionDepth = 0;
+        text = new StringBuffer();
+
+        // add a dummy attributes at the bottom as a "centinel."
+        attStack.push(new AttributesImpl());
+    }
+
+    // current content handler can be acccessed via set/getContentHandler.
+
+    private Locator locator;
+    public void setDocumentLocator( Locator _loc ) { this.locator=_loc; }
+    /**
+     * Gets the source location of the current event.
+     *
+     * <p>
+     * One can call this method from RelaxNGCC handlers to access
+     * the line number information. Note that to
+     */
+    public Locator getLocator() { return locator; }
+
+
+    /** stack of {@link Attributes}. */
+    private final Stack attStack = new Stack();
+    /** current attributes set. always equal to attStack.peek() */
+    private AttributesImpl currentAtts;
+
+    /**
+     * Attributes that belong to the current element.
+     * <p>
+     * It's generally not recommended for applications to use
+     * this method. RelaxNGCC internally removes processed attributes,
+     * so this doesn't correctly reflect all the attributes an element
+     * carries.
+     */
+    public Attributes getCurrentAttributes() {
+        return currentAtts;
+    }
+
+    /** accumulated text. */
+    private StringBuffer text = new StringBuffer();
+
+
+
+
+    /** The current NGCCHandler. Always equals to handlerStack.peek() */
+    private NGCCEventReceiver currentHandler;
+
+    public int replace( NGCCEventReceiver o, NGCCEventReceiver n ) {
+        if(o!=currentHandler)
+            throw new IllegalStateException();  // bug of RelaxNGCC
+        currentHandler = n;
+
+        return 0;   // we only have one thread.
+    }
+
+    /**
+     * Processes buffered text.
+     *
+     * This method will be called by the start/endElement event to process
+     * buffered text as a text event.
+     *
+     * <p>
+     * Whitespace handling is a tricky business. Consider the following
+     * schema fragment:
+     *
+     * <xmp>
+     * <element name="foo">
+     *   <choice>
+     *     <element name="bar"><empty/></element>
+     *     <text/>
+     *   </choice>
+     * </element>
+     * </xmp>
+     *
+     * Assume we hit the following instance:
+     * <xmp>
+     * <foo> <bar/></foo>
+     * </xmp>
+     *
+     * Then this first space needs to be ignored (for otherwise, we will
+     * end up treating this space as the match to &lt;text/> and won't
+     * be able to process &lt;bar>.)
+     *
+     * Now assume the following instance:
+     * <xmp>
+     * <foo/>
+     * </xmp>
+     *
+     * This time, we need to treat this empty string as a text, for
+     * otherwise we won't be able to accept this instance.
+     *
+     * <p>
+     * This is very difficult to solve in general, but one seemingly
+     * easy solution is to use the type of next event. If a text is
+     * followed by a start tag, it follows from the constraint on
+     * RELAX NG that that text must be either whitespaces or a match
+     * to &lt;text/>.
+     *
+     * <p>
+     * On the contrary, if a text is followed by a end tag, then it
+     * cannot be whitespace unless the content model can accept empty,
+     * in which case sending a text event will be harmlessly ignored
+     * by the NGCCHandler.
+     *
+     * <p>
+     * Thus this method take one parameter, which controls the
+     * behavior of this method.
+     *
+     * <p>
+     * TODO: according to the constraint of RELAX NG, if characters
+     * follow an end tag, then they must be either whitespaces or
+     * must match to &lt;text/>.
+     *
+     * @param   possiblyWhitespace
+     *      True if the buffered character can be ignorabale. False if
+     *      it needs to be consumed.
+     */
+    private void processPendingText(boolean ignorable) throws SAXException {
+        if(ignorable && text.toString().trim().length()==0)
+            ; // ignore. See the above javadoc comment for the description
+        else
+            currentHandler.text(text.toString());   // otherwise consume this token
+
+        // truncate StringBuffer, but avoid excessive allocation.
+        if(text.length()>1024)  text = new StringBuffer();
+        else                    text.setLength(0);
+    }
+
+    public void processList( String str ) throws SAXException {
+        StringTokenizer t = new StringTokenizer(str, " \t\r\n");
+        while(t.hasMoreTokens())
+            currentHandler.text(t.nextToken());
+    }
+
+    public void startElement(String uri, String localname, String qname, Attributes atts)
+            throws SAXException {
+
+        if(redirect!=null) {
+            redirect.startElement(uri,localname,qname,atts);
+            redirectionDepth++;
+        } else {
+            processPendingText(true);
+    //        System.out.println("startElement:"+localname+"->"+_attrStack.size());
+            currentHandler.enterElement(uri, localname, qname, atts);
+        }
+    }
+
+    /**
+     * Called by the generated handler code when an enter element
+     * event is consumed.
+     *
+     * <p>
+     * Pushes a new attribute set.
+     *
+     * <p>
+     * Note that attributes are NOT pushed at the startElement method,
+     * because the processing of the enterElement event can trigger
+     * other attribute events and etc.
+     * <p>
+     * This method will be called from one of handlers when it truely
+     * consumes the enterElement event.
+     */
+    public void onEnterElementConsumed(
+        String uri, String localName, String qname,Attributes atts) throws SAXException {
+        attStack.push(currentAtts=new AttributesImpl(atts));
+        nsEffectiveStack.push( new Integer(nsEffectivePtr) );
+        nsEffectivePtr = namespaces.size();
+    }
+
+    public void onLeaveElementConsumed(String uri, String localName, String qname) throws SAXException {
+        attStack.pop();
+        if(attStack.isEmpty())
+            currentAtts = null;
+        else
+            currentAtts = (AttributesImpl)attStack.peek();
+        nsEffectivePtr = ((Integer)nsEffectiveStack.pop()).intValue();
+    }
+
+    public void endElement(String uri, String localname, String qname)
+            throws SAXException {
+
+        if(redirect!=null) {
+            redirect.endElement(uri,localname,qname);
+            redirectionDepth--;
+
+            if(redirectionDepth!=0)
+                return;
+
+            // finished redirection.
+            for( int i=0; i<namespaces.size(); i+=2 )
+                redirect.endPrefixMapping((String)namespaces.get(i));
+            redirect.endDocument();
+
+            redirect = null;
+            // then process this element normally
+        }
+
+        processPendingText(false);
+
+        currentHandler.leaveElement(uri, localname, qname);
+//        System.out.println("endElement:"+localname);
+    }
+
+    public void characters(char[] ch, int start, int length) throws SAXException {
+        if(redirect!=null)
+            redirect.characters(ch,start,length);
+        else
+            text.append(ch,start,length);
+    }
+    public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
+        if(redirect!=null)
+            redirect.ignorableWhitespace(ch,start,length);
+        else
+            text.append(ch,start,length);
+    }
+
+    public int getAttributeIndex(String uri, String localname) {
+        return currentAtts.getIndex(uri, localname);
+    }
+    public void consumeAttribute(int index) throws SAXException {
+        final String uri    = currentAtts.getURI(index);
+        final String local  = currentAtts.getLocalName(index);
+        final String qname  = currentAtts.getQName(index);
+        final String value  = currentAtts.getValue(index);
+        currentAtts.removeAttribute(index);
+
+        currentHandler.enterAttribute(uri,local,qname);
+        currentHandler.text(value);
+        currentHandler.leaveAttribute(uri,local,qname);
+    }
+
+
+    public void startPrefixMapping( String prefix, String uri ) throws SAXException {
+        if(redirect!=null)
+            redirect.startPrefixMapping(prefix,uri);
+        else {
+            namespaces.add(prefix);
+            namespaces.add(uri);
+        }
+    }
+
+    public void endPrefixMapping( String prefix ) throws SAXException {
+        if(redirect!=null)
+            redirect.endPrefixMapping(prefix);
+        else {
+            namespaces.remove(namespaces.size()-1);
+            namespaces.remove(namespaces.size()-1);
+        }
+    }
+
+    public void skippedEntity( String name ) throws SAXException {
+        if(redirect!=null)
+            redirect.skippedEntity(name);
+    }
+
+    public void processingInstruction( String target, String data ) throws SAXException {
+        if(redirect!=null)
+            redirect.processingInstruction(target,data);
+    }
+
+    /** Impossible token. This value can never be a valid XML name. */
+    static final String IMPOSSIBLE = "\u0000";
+
+    public void endDocument() throws SAXException {
+        // consume the special "end document" token so that all the handlers
+        // currently at the stack will revert to their respective parents.
+        //
+        // this is necessary to handle a grammar like
+        // <start><ref name="X"/></start>
+        // <define name="X">
+        //   <element name="root"><empty/></element>
+        // </define>
+        //
+        // With this grammar, when the endElement event is consumed, two handlers
+        // are on the stack (because a child object won't revert to its parent
+        // unless it sees a next event.)
+
+        // pass around an "impossible" token.
+        currentHandler.leaveElement(IMPOSSIBLE,IMPOSSIBLE,IMPOSSIBLE);
+
+        reset();
+    }
+    public void startDocument() {}
+
+
+
+
+//
+//
+// event dispatching methods
+//
+//
+
+    public void sendEnterAttribute( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        currentHandler.enterAttribute(uri,local,qname);
+    }
+
+    public void sendEnterElement( int threadId,
+        String uri, String local, String qname, Attributes atts) throws SAXException {
+
+        currentHandler.enterElement(uri,local,qname,atts);
+    }
+
+    public void sendLeaveAttribute( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        currentHandler.leaveAttribute(uri,local,qname);
+    }
+
+    public void sendLeaveElement( int threadId,
+        String uri, String local, String qname) throws SAXException {
+
+        currentHandler.leaveElement(uri,local,qname);
+    }
+
+    public void sendText(int threadId, String value) throws SAXException {
+        currentHandler.text(value);
+    }
+
+
+//
+//
+// redirection of SAX2 events.
+//
+//
+    /** When redirecting a sub-tree, this value will be non-null. */
+    private ContentHandler redirect = null;
+
+    /**
+     * Counts the depth of the elements when we are re-directing
+     * a sub-tree to another ContentHandler.
+     */
+    private int redirectionDepth = 0;
+
+    /**
+     * This method can be called only from the enterElement handler.
+     * The sub-tree rooted at the new element will be redirected
+     * to the specified ContentHandler.
+     *
+     * <p>
+     * Currently active NGCCHandler will only receive the leaveElement
+     * event of the newly started element.
+     *
+     * @param   uri,local,qname
+     *      Parameters passed to the enter element event. Used to
+     *      simulate the startElement event for the new ContentHandler.
+     */
+    public void redirectSubtree( ContentHandler child,
+        String uri, String local, String qname ) throws SAXException {
+
+        redirect = child;
+        redirect.setDocumentLocator(locator);
+        redirect.startDocument();
+
+        // TODO: when a prefix is re-bound to something else,
+        // the following code is potentially dangerous. It should be
+        // modified to report active bindings only.
+        for( int i=0; i<namespaces.size(); i+=2 )
+            redirect.startPrefixMapping(
+                (String)namespaces.get(i),
+                (String)namespaces.get(i+1)
+            );
+
+        redirect.startElement(uri,local,qname,currentAtts);
+        redirectionDepth=1;
+    }
+
+//
+//
+// validation context implementation
+//
+//
+    /** in-scope namespace mapping.
+     * namespaces[2n  ] := prefix
+     * namespaces[2n+1] := namespace URI */
+    private final ArrayList namespaces = new ArrayList();
+    /**
+     * Index on the namespaces array, which points to
+     * the top of the effective bindings. Because of the
+     * timing difference between the startPrefixMapping method
+     * and the execution of the corresponding actions,
+     * this value can be different from <code>namespaces.size()</code>.
+     * <p>
+     * For example, consider the following schema:
+     * <pre><xmp>
+     *  <oneOrMore>
+     *   <element name="foo"><empty/></element>
+     *  </oneOrMore>
+     *  code fragment X
+     *  <element name="bob"/>
+     * </xmp></pre>
+     * Code fragment X is executed after we see a startElement event,
+     * but at this time the namespaces variable already include new
+     * namespace bindings declared on "bob".
+     */
+    private int nsEffectivePtr=0;
+
+    /**
+     * Stack to preserve old nsEffectivePtr values.
+     */
+    private final Stack nsEffectiveStack = new Stack();
+
+    public String resolveNamespacePrefix( String prefix ) {
+        for( int i = nsEffectivePtr-2; i>=0; i-=2 )
+            if( namespaces.get(i).equals(prefix) )
+                return (String)namespaces.get(i+1);
+
+        // no binding was found.
+        if(prefix.equals(""))   return "";  // return the default no-namespace
+        if(prefix.equals("xml"))    // pre-defined xml prefix
+            return "http://www.w3.org/XML/1998/namespace";
+        else    return null;    // prefix undefined
+    }
+
+
+// error reporting
+    protected void unexpectedX(String token) throws SAXException {
+        throw new SAXParseException(MessageFormat.format(
+            "Unexpected {0} appears at line {1} column {2}",
+            new Object[]{
+                token,
+                new Integer(getLocator().getLineNumber()),
+                new Integer(getLocator().getColumnNumber()) }),
+            getLocator());
+    }
+
+
+
+
+//
+//
+// trace functions
+//
+//
+    private int indent=0;
+    private boolean needIndent=true;
+    private void printIndent() {
+        for( int i=0; i<indent; i++ )
+            System.out.print("  ");
+    }
+    public void trace( String s ) {
+        if(needIndent) {
+            needIndent=false;
+            printIndent();
+        }
+        System.out.print(s);
+    }
+    public void traceln( String s ) {
+        trace(s);
+        trace("\n");
+        needIndent=true;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/Schema.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/Schema.java
new file mode 100644
index 0000000..ac50629
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/Schema.java
@@ -0,0 +1,1315 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+import javax.xml.parsers.SAXParserFactory;
+import org.xml.sax.XMLReader;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+public class Schema extends NGCCHandler {
+    private Integer finalDefault;
+    private boolean efd;
+    private boolean afd;
+    private Integer blockDefault;
+    private ForeignAttributesImpl fa;
+    private boolean includeMode;
+    private AnnotationImpl anno;
+    private ComplexTypeImpl ct;
+    private ElementDecl e;
+    private String defaultValue;
+    private XSNotation notation;
+    private AttGroupDeclImpl ag;
+    private String fixedValue;
+    private ModelGroupDeclImpl group;
+    private AttributeDeclImpl ad;
+    private SimpleTypeImpl st;
+    private String expectedNamespace;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public Schema(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, boolean _includeMode, String _expectedNamespace) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.includeMode = _includeMode;
+        this.expectedNamespace = _expectedNamespace;
+        $_ngcc_current_state = 57;
+    }
+
+    public Schema(NGCCRuntimeEx runtime, boolean _includeMode, String _expectedNamespace) {
+        this(null, runtime, runtime, -1, _includeMode, _expectedNamespace);
+    }
+
+    private void action0()throws SAXException {
+        $runtime.checkDoubleDefError( $runtime.currentSchema.getAttGroupDecl(ag.getName()) );
+            $runtime.currentSchema.addAttGroupDecl(ag);
+}
+
+    private void action1()throws SAXException {
+        $runtime.currentSchema.addNotation(notation);
+}
+
+    private void action2()throws SAXException {
+        $runtime.checkDoubleDefError( $runtime.currentSchema.getModelGroupDecl(group.getName()) );
+            $runtime.currentSchema.addModelGroupDecl(group);
+}
+
+    private void action3()throws SAXException {
+        $runtime.checkDoubleDefError( $runtime.currentSchema.getAttributeDecl(ad.getName()) );
+            $runtime.currentSchema.addAttributeDecl(ad);
+}
+
+    private void action4()throws SAXException {
+        locator = $runtime.copyLocator();
+            defaultValue = null;
+            fixedValue = null;
+}
+
+    private void action5()throws SAXException {
+        $runtime.checkDoubleDefError( $runtime.currentSchema.getType(ct.getName()) );
+            $runtime.currentSchema.addComplexType(ct);
+}
+
+    private void action6()throws SAXException {
+        $runtime.checkDoubleDefError( $runtime.currentSchema.getType(st.getName()) );
+            $runtime.currentSchema.addSimpleType(st);
+}
+
+    private void action7()throws SAXException {
+        $runtime.checkDoubleDefError( $runtime.currentSchema.getElementDecl(e.getName()) );
+            $runtime.currentSchema.addElementDecl(e);
+}
+
+    private void action8()throws SAXException {
+        locator = $runtime.copyLocator();
+}
+
+    private void action9()throws SAXException {
+        $runtime.currentSchema.setAnnotation(anno);
+}
+
+    private void action10()throws SAXException {
+        $runtime.currentSchema.addForeignAttributes(fa);
+}
+
+    private void action11()throws SAXException {
+        $runtime.finalDefault=this.finalDefault.intValue();
+}
+
+    private void action12()throws SAXException {
+        $runtime.blockDefault=this.blockDefault.intValue();
+}
+
+    private void action13()throws SAXException {
+        $runtime.elementFormDefault = efd;
+}
+
+    private void action14()throws SAXException {
+        $runtime.attributeFormDefault = afd;
+}
+
+    private void action15()throws SAXException {
+        Attributes test = $runtime.getCurrentAttributes();
+        String tns = test.getValue("targetNamespace");
+
+      if(!includeMode) {
+        // importing
+        if(tns==null) tns=""; // if not present, then the empty namespace
+        $runtime.currentSchema = $runtime.parser.schemaSet.createSchema(tns,$runtime.copyLocator());
+        if(expectedNamespace!=null && !expectedNamespace.equals(tns)) {
+          $runtime.reportError(
+            Messages.format("UnexpectedTargetnamespace.Import", tns, expectedNamespace, tns ),
+            $runtime.getLocator());
+        }
+      } else {
+        // including
+
+        // check the consistency of @targetNamespace.
+        // @targetNamespace must be null or equal to the target namespace of the schema
+        if(tns!=null && expectedNamespace!=null && !expectedNamespace.equals(tns)) {
+          $runtime.reportError(
+            Messages.format("UnexpectedTargetnamespace.Include", tns, expectedNamespace, tns ) );
+        }
+        if(tns==null)
+          $runtime.chameleonMode = true;
+      }
+
+      // multiple inclusion test.
+      if( $runtime.hasAlreadyBeenRead() ) {
+          // skip this document
+          $runtime.redirectSubtree(new DefaultHandler(),"","","" );
+          return;
+      }
+
+      anno = (AnnotationImpl)$runtime.currentSchema.getAnnotation();
+      $runtime.blockDefault = 0;
+      $runtime.finalDefault = 0;
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 45:
+            {
+                if(($ai = $runtime.getAttributeIndex("","elementFormDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 41;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 57:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("schema"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action15();
+                    $_ngcc_current_state = 53;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 174, anno,AnnotationContext.SCHEMA);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("include"))) {
+                        NGCCHandler h = new includeDecl(this, super._source, $runtime, 175);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("import"))) {
+                            NGCCHandler h = new importDecl(this, super._source, $runtime, 176);
+                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                        }
+                        else {
+                            if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("redefine"))) {
+                                NGCCHandler h = new redefine(this, super._source, $runtime, 177);
+                                spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                            }
+                            else {
+                                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) {
+                                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                                    action8();
+                                    $_ngcc_current_state = 27;
+                                }
+                                else {
+                                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                                        NGCCHandler h = new simpleType(this, super._source, $runtime, 179);
+                                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                    }
+                                    else {
+                                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                                            NGCCHandler h = new complexType(this, super._source, $runtime, 180);
+                                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                        }
+                                        else {
+                                            if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) {
+                                                $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                                                action4();
+                                                $_ngcc_current_state = 16;
+                                            }
+                                            else {
+                                                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) {
+                                                    NGCCHandler h = new group(this, super._source, $runtime, 182);
+                                                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                                }
+                                                else {
+                                                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("notation"))) {
+                                                        NGCCHandler h = new notation(this, super._source, $runtime, 183);
+                                                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                                    }
+                                                    else {
+                                                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                                                            NGCCHandler h = new attributeGroupDecl(this, super._source, $runtime, 184);
+                                                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                                        }
+                                                        else {
+                                                            $_ngcc_current_state = 1;
+                                                            $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                                                        }
+                                                    }
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 11:
+            {
+                if((($ai = $runtime.getAttributeIndex("","name"))>=0 || ($ai = $runtime.getAttributeIndex("","form"))>=0)) {
+                    NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 80, locator,false,defaultValue,fixedValue);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 27:
+            {
+                if((($ai = $runtime.getAttributeIndex("","form"))>=0 || (($ai = $runtime.getAttributeIndex("","default"))>=0 || (($ai = $runtime.getAttributeIndex("","final"))>=0 || (($ai = $runtime.getAttributeIndex("","abstract"))>=0 || (($ai = $runtime.getAttributeIndex("","fixed"))>=0 || (($ai = $runtime.getAttributeIndex("","block"))>=0 || ($ai = $runtime.getAttributeIndex("","name"))>=0))))))) {
+                    NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 163, anno,AnnotationContext.SCHEMA);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("include"))) {
+                        NGCCHandler h = new includeDecl(this, super._source, $runtime, 164);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("import"))) {
+                            NGCCHandler h = new importDecl(this, super._source, $runtime, 165);
+                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                        }
+                        else {
+                            if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("redefine"))) {
+                                NGCCHandler h = new redefine(this, super._source, $runtime, 166);
+                                spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                            }
+                            else {
+                                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) {
+                                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                                    action8();
+                                    $_ngcc_current_state = 27;
+                                }
+                                else {
+                                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                                        NGCCHandler h = new simpleType(this, super._source, $runtime, 168);
+                                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                    }
+                                    else {
+                                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                                            NGCCHandler h = new complexType(this, super._source, $runtime, 169);
+                                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                        }
+                                        else {
+                                            if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) {
+                                                $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                                                action4();
+                                                $_ngcc_current_state = 16;
+                                            }
+                                            else {
+                                                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) {
+                                                    NGCCHandler h = new group(this, super._source, $runtime, 171);
+                                                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                                }
+                                                else {
+                                                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("notation"))) {
+                                                        NGCCHandler h = new notation(this, super._source, $runtime, 172);
+                                                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                                    }
+                                                    else {
+                                                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                                                            NGCCHandler h = new attributeGroupDecl(this, super._source, $runtime, 173);
+                                                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                                        }
+                                                        else {
+                                                            unexpectedEnterElement($__qname);
+                                                        }
+                                                    }
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 41:
+            {
+                if(($ai = $runtime.getAttributeIndex("","blockDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 37;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 36:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("notation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("redefine")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("import")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("include")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))))))))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 186, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 49:
+            {
+                if(($ai = $runtime.getAttributeIndex("","attributeFormDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 45;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 16:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 12;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 37:
+            {
+                if(($ai = $runtime.getAttributeIndex("","finalDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 36;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 53:
+            {
+                if(($ai = $runtime.getAttributeIndex("","targetNamespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 49;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 45:
+            {
+                if(($ai = $runtime.getAttributeIndex("","elementFormDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 41;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 26:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","name"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) || (($ai = $runtime.getAttributeIndex("","form"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))))) {
+                    NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 80, locator,false,defaultValue,fixedValue);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 27:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","form"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","default"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","final"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","abstract"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","fixed"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","block"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || (($ai = $runtime.getAttributeIndex("","name"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")))))))))) {
+                    NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("schema"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 41:
+            {
+                if(($ai = $runtime.getAttributeIndex("","blockDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 37;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 36:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("schema"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 186, null);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 49:
+            {
+                if(($ai = $runtime.getAttributeIndex("","attributeFormDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 45;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 16:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 12;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 37:
+            {
+                if(($ai = $runtime.getAttributeIndex("","finalDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 36;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 53:
+            {
+                if(($ai = $runtime.getAttributeIndex("","targetNamespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 49;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 45:
+            {
+                if(($__uri.equals("") && $__local.equals("elementFormDefault"))) {
+                    $_ngcc_current_state = 47;
+                }
+                else {
+                    $_ngcc_current_state = 41;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 41:
+            {
+                if(($__uri.equals("") && $__local.equals("blockDefault"))) {
+                    $_ngcc_current_state = 43;
+                }
+                else {
+                    $_ngcc_current_state = 37;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($__uri.equals("") && $__local.equals("fixed"))) {
+                    $_ngcc_current_state = 14;
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 49:
+            {
+                if(($__uri.equals("") && $__local.equals("attributeFormDefault"))) {
+                    $_ngcc_current_state = 51;
+                }
+                else {
+                    $_ngcc_current_state = 45;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 16:
+            {
+                if(($__uri.equals("") && $__local.equals("default"))) {
+                    $_ngcc_current_state = 18;
+                }
+                else {
+                    $_ngcc_current_state = 12;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 37:
+            {
+                if(($__uri.equals("") && $__local.equals("finalDefault"))) {
+                    $_ngcc_current_state = 39;
+                }
+                else {
+                    $_ngcc_current_state = 36;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 53:
+            {
+                if(($__uri.equals("") && $__local.equals("targetNamespace"))) {
+                    $_ngcc_current_state = 55;
+                }
+                else {
+                    $_ngcc_current_state = 49;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if((($__uri.equals("") && $__local.equals("name")) || ($__uri.equals("") && $__local.equals("form")))) {
+                    NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 80, locator,false,defaultValue,fixedValue);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 27:
+            {
+                if((($__uri.equals("") && $__local.equals("form")) || (($__uri.equals("") && $__local.equals("default")) || (($__uri.equals("") && $__local.equals("final")) || (($__uri.equals("") && $__local.equals("abstract")) || (($__uri.equals("") && $__local.equals("fixed")) || (($__uri.equals("") && $__local.equals("block")) || ($__uri.equals("") && $__local.equals("name"))))))))) {
+                    NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 45:
+            {
+                $_ngcc_current_state = 41;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 12:
+            {
+                $_ngcc_current_state = 11;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 46:
+            {
+                if(($__uri.equals("") && $__local.equals("elementFormDefault"))) {
+                    $_ngcc_current_state = 41;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 42:
+            {
+                if(($__uri.equals("") && $__local.equals("blockDefault"))) {
+                    $_ngcc_current_state = 37;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($__uri.equals("") && $__local.equals("fixed"))) {
+                    $_ngcc_current_state = 11;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 38:
+            {
+                if(($__uri.equals("") && $__local.equals("finalDefault"))) {
+                    $_ngcc_current_state = 36;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 41:
+            {
+                $_ngcc_current_state = 37;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 17:
+            {
+                if(($__uri.equals("") && $__local.equals("default"))) {
+                    $_ngcc_current_state = 12;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 49:
+            {
+                $_ngcc_current_state = 45;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 16:
+            {
+                $_ngcc_current_state = 12;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 37:
+            {
+                $_ngcc_current_state = 36;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 53:
+            {
+                $_ngcc_current_state = 49;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 54:
+            {
+                if(($__uri.equals("") && $__local.equals("targetNamespace"))) {
+                    $_ngcc_current_state = 49;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 50:
+            {
+                if(($__uri.equals("") && $__local.equals("attributeFormDefault"))) {
+                    $_ngcc_current_state = 45;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 14:
+            {
+                fixedValue = $value;
+                $_ngcc_current_state = 13;
+            }
+            break;
+        case 45:
+            {
+                if(($ai = $runtime.getAttributeIndex("","elementFormDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 41;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 43:
+            {
+                NGCCHandler h = new ersSet(this, super._source, $runtime, 193);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                    NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 80, locator,false,defaultValue,fixedValue);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                        NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 80, locator,false,defaultValue,fixedValue);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 39:
+            {
+                NGCCHandler h = new erSet(this, super._source, $runtime, 188);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 27:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                        NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                        spawnChildFromText(h, $value);
+                    }
+                    else {
+                        if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                            NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                            spawnChildFromText(h, $value);
+                        }
+                        else {
+                            if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                                NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                                spawnChildFromText(h, $value);
+                            }
+                            else {
+                                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                                    NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                                    spawnChildFromText(h, $value);
+                                }
+                                else {
+                                    if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                                        NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                                        spawnChildFromText(h, $value);
+                                    }
+                                    else {
+                                        if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                                            NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 98, locator,true);
+                                            spawnChildFromText(h, $value);
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 41:
+            {
+                if(($ai = $runtime.getAttributeIndex("","blockDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 37;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 47:
+            {
+                if($value.equals("unqualified")) {
+                    NGCCHandler h = new qualification(this, super._source, $runtime, 198);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if($value.equals("qualified")) {
+                        NGCCHandler h = new qualification(this, super._source, $runtime, 198);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 51:
+            {
+                if($value.equals("unqualified")) {
+                    NGCCHandler h = new qualification(this, super._source, $runtime, 203);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if($value.equals("qualified")) {
+                        NGCCHandler h = new qualification(this, super._source, $runtime, 203);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 49:
+            {
+                if(($ai = $runtime.getAttributeIndex("","attributeFormDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 45;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 16:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 12;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 18:
+            {
+                defaultValue = $value;
+                $_ngcc_current_state = 17;
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        case 37:
+            {
+                if(($ai = $runtime.getAttributeIndex("","finalDefault"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 36;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 53:
+            {
+                if(($ai = $runtime.getAttributeIndex("","targetNamespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 49;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 55:
+            {
+                $_ngcc_current_state = 54;
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 80:
+            {
+                ad = ((AttributeDeclImpl)$__result__);
+                action3();
+                $_ngcc_current_state = 10;
+            }
+            break;
+        case 98:
+            {
+                e = ((ElementDecl)$__result__);
+                action7();
+                $_ngcc_current_state = 26;
+            }
+            break;
+        case 163:
+            {
+                anno = ((AnnotationImpl)$__result__);
+                action9();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 164:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 165:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 166:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 168:
+            {
+                st = ((SimpleTypeImpl)$__result__);
+                action6();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 169:
+            {
+                ct = ((ComplexTypeImpl)$__result__);
+                action5();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 171:
+            {
+                group = ((ModelGroupDeclImpl)$__result__);
+                action2();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 172:
+            {
+                notation = ((XSNotation)$__result__);
+                action1();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 173:
+            {
+                ag = ((AttGroupDeclImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 198:
+            {
+                efd = ((Boolean)$__result__).booleanValue();
+                action13();
+                $_ngcc_current_state = 46;
+            }
+            break;
+        case 203:
+            {
+                afd = ((Boolean)$__result__).booleanValue();
+                action14();
+                $_ngcc_current_state = 50;
+            }
+            break;
+        case 186:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                action10();
+                $_ngcc_current_state = 2;
+            }
+            break;
+        case 174:
+            {
+                anno = ((AnnotationImpl)$__result__);
+                action9();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 175:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 176:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 177:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 179:
+            {
+                st = ((SimpleTypeImpl)$__result__);
+                action6();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 180:
+            {
+                ct = ((ComplexTypeImpl)$__result__);
+                action5();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 182:
+            {
+                group = ((ModelGroupDeclImpl)$__result__);
+                action2();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 183:
+            {
+                notation = ((XSNotation)$__result__);
+                action1();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 184:
+            {
+                ag = ((AttGroupDeclImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 193:
+            {
+                blockDefault = ((Integer)$__result__);
+                action12();
+                $_ngcc_current_state = 42;
+            }
+            break;
+        case 188:
+            {
+                finalDefault = ((Integer)$__result__);
+                action11();
+                $_ngcc_current_state = 38;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private String tns=null;  // it defaults to the no namespace.
+      private Locator locator;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_List.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_List.java
new file mode 100644
index 0000000..e8af9f5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_List.java
@@ -0,0 +1,389 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class SimpleType_List extends NGCCHandler {
+    private Locator locator;
+    private AnnotationImpl annotation;
+    private String name;
+    private UName itemTypeName;
+    private Set finalSet;
+    private ForeignAttributesImpl fa;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public SimpleType_List(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, AnnotationImpl _annotation, Locator _locator, ForeignAttributesImpl _fa, String _name, Set _finalSet) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.annotation = _annotation;
+        this.locator = _locator;
+        this.fa = _fa;
+        this.name = _name;
+        this.finalSet = _finalSet;
+        $_ngcc_current_state = 10;
+    }
+
+    public SimpleType_List(NGCCRuntimeEx runtime, AnnotationImpl _annotation, Locator _locator, ForeignAttributesImpl _fa, String _name, Set _finalSet) {
+        this(null, runtime, runtime, -1, _annotation, _locator, _fa, _name, _finalSet);
+    }
+
+    private void action0()throws SAXException {
+
+        result = new ListSimpleTypeImpl(
+                $runtime.document, annotation, locator, fa,
+                name, name==null, finalSet, itemType );
+
+}
+
+    private void action1()throws SAXException {
+
+                itemType = new DelayedRef.SimpleType(
+                        $runtime, lloc, $runtime.currentSchema, itemTypeName);
+
+}
+
+    private void action2()throws SAXException {
+        lloc=$runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                if(($ai = $runtime.getAttributeIndex("","itemType"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                        NGCCHandler h = new simpleType(this, super._source, $runtime, 219);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        unexpectedEnterElement($__qname);
+                    }
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 10:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("list"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action2();
+                    $_ngcc_current_state = 9;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 225, annotation,AnnotationContext.SIMPLETYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 9:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || ((($ai = $runtime.getAttributeIndex("","itemType"))>=0 && (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 227, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                if(($ai = $runtime.getAttributeIndex("","itemType"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("list"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                    action0();
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 9:
+            {
+                if((($ai = $runtime.getAttributeIndex("","itemType"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("list")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 227, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                if(($__uri.equals("") && $__local.equals("itemType"))) {
+                    $_ngcc_current_state = 5;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 9:
+            {
+                if(($__uri.equals("") && $__local.equals("itemType"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 227, fa);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                if(($__uri.equals("") && $__local.equals("itemType"))) {
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 221);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 2:
+            {
+                if(($ai = $runtime.getAttributeIndex("","itemType"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 7:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 9:
+            {
+                if(($ai = $runtime.getAttributeIndex("","itemType"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 227, fa);
+                    spawnChildFromText(h, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 221:
+            {
+                itemTypeName = ((UName)$__result__);
+                action1();
+                $_ngcc_current_state = 4;
+            }
+            break;
+        case 219:
+            {
+                itemType = ((SimpleTypeImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 227:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 7;
+            }
+            break;
+        case 225:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 2;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+                /** computed simple type object */
+                private ListSimpleTypeImpl result;
+
+                // reference to the base type
+                private Ref.SimpleType itemType;
+
+                // locator of <list>
+                private Locator lloc;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_Restriction.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_Restriction.java
new file mode 100644
index 0000000..4b9bb65
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_Restriction.java
@@ -0,0 +1,490 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class SimpleType_Restriction extends NGCCHandler {
+    private Locator locator;
+    private AnnotationImpl annotation;
+    private String name;
+    private UName baseTypeName;
+    private Set finalSet;
+    private ForeignAttributesImpl fa;
+    private XSFacet facet;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public SimpleType_Restriction(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, AnnotationImpl _annotation, Locator _locator, ForeignAttributesImpl _fa, String _name, Set _finalSet) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.annotation = _annotation;
+        this.locator = _locator;
+        this.fa = _fa;
+        this.name = _name;
+        this.finalSet = _finalSet;
+        $_ngcc_current_state = 13;
+    }
+
+    public SimpleType_Restriction(NGCCRuntimeEx runtime, AnnotationImpl _annotation, Locator _locator, ForeignAttributesImpl _fa, String _name, Set _finalSet) {
+        this(null, runtime, runtime, -1, _annotation, _locator, _fa, _name, _finalSet);
+    }
+
+    private void action0()throws SAXException {
+
+                result.addFacet(facet);
+
+}
+
+    private void action1()throws SAXException {
+
+        result = new RestrictionSimpleTypeImpl(
+                                        $runtime.document, annotation, locator, fa, name, name==null, finalSet, baseType );
+
+}
+
+    private void action2()throws SAXException {
+
+            baseType = new DelayedRef.SimpleType(
+              $runtime, rloc, $runtime.currentSchema, baseTypeName );
+
+}
+
+    private void action3()throws SAXException {
+        rloc=$runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 604, annotation,AnnotationContext.SIMPLETYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 5;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 13:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action3();
+                    $_ngcc_current_state = 12;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 4:
+            {
+                action1();
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 1:
+            {
+                if((((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern")))) {
+                    NGCCHandler h = new facet(this, super._source, $runtime, 593);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if((((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern")))) {
+                    NGCCHandler h = new facet(this, super._source, $runtime, 594);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 12:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType")) || (($ai = $runtime.getAttributeIndex("","base"))>=0 && ((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType")) || (((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern")))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 606, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                        NGCCHandler h = new simpleType(this, super._source, $runtime, 598);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        unexpectedEnterElement($__qname);
+                    }
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                $_ngcc_current_state = 5;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                action1();
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 12:
+            {
+                if((($ai = $runtime.getAttributeIndex("","base"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 606, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                $_ngcc_current_state = 5;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                action1();
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 12:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 606, fa);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 8;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                $_ngcc_current_state = 5;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                action1();
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 4;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                $_ngcc_current_state = 5;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 4:
+            {
+                action1();
+                $_ngcc_current_state = 2;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 8:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 600);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 12:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 606, fa);
+                    spawnChildFromText(h, $value);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 604:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 5;
+            }
+            break;
+        case 593:
+            {
+                facet = ((XSFacet)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 606:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 10;
+            }
+            break;
+        case 598:
+            {
+                baseType = ((SimpleTypeImpl)$__result__);
+                $_ngcc_current_state = 4;
+            }
+            break;
+        case 594:
+            {
+                facet = ((XSFacet)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 600:
+            {
+                baseTypeName = ((UName)$__result__);
+                action2();
+                $_ngcc_current_state = 7;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+                /** computed simple type object */
+                private RestrictionSimpleTypeImpl result;
+
+                // reference to the base type
+                private Ref.SimpleType baseType;
+
+                // location of restriction
+                private Locator rloc;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_Union.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_Union.java
new file mode 100644
index 0000000..9fe2e0e
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/SimpleType_Union.java
@@ -0,0 +1,464 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+import java.util.Vector;
+
+
+class SimpleType_Union extends NGCCHandler {
+    private Locator locator;
+    private AnnotationImpl annotation;
+    private String __text;
+    private UName memberTypeName;
+    private String name;
+    private Set finalSet;
+    private ForeignAttributesImpl fa;
+    private SimpleTypeImpl anonymousMemberType;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public SimpleType_Union(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, AnnotationImpl _annotation, Locator _locator, ForeignAttributesImpl _fa, String _name, Set _finalSet) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.annotation = _annotation;
+        this.locator = _locator;
+        this.fa = _fa;
+        this.name = _name;
+        this.finalSet = _finalSet;
+        $_ngcc_current_state = 12;
+    }
+
+    public SimpleType_Union(NGCCRuntimeEx runtime, AnnotationImpl _annotation, Locator _locator, ForeignAttributesImpl _fa, String _name, Set _finalSet) {
+        this(null, runtime, runtime, -1, _annotation, _locator, _fa, _name, _finalSet);
+    }
+
+    private void action0()throws SAXException {
+
+                        result = new UnionSimpleTypeImpl(
+                                $runtime.document, annotation, locator, fa, name, name==null, finalSet,
+                                (Ref.SimpleType[])members.toArray(new Ref.SimpleType[members.size()]) );
+
+}
+
+    private void action1()throws SAXException {
+
+          members.add(anonymousMemberType);
+
+}
+
+    private void action2()throws SAXException {
+
+                members.add( new DelayedRef.SimpleType(
+                                $runtime, uloc, $runtime.currentSchema, memberTypeName));
+
+}
+
+    private void action3()throws SAXException {
+        $runtime.processList(__text);}
+
+    private void action4()throws SAXException {
+        uloc=$runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                    NGCCHandler h = new simpleType(this, super._source, $runtime, 631);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 637, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","memberTypes"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 6;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("union"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action4();
+                    $_ngcc_current_state = 7;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                    NGCCHandler h = new simpleType(this, super._source, $runtime, 632);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 4:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 635, annotation,AnnotationContext.SIMPLETYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("union"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                    action0();
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("union"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 637, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","memberTypes"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 6;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("") && $__local.equals("memberTypes"))) {
+                    $_ngcc_current_state = 10;
+                }
+                else {
+                    $_ngcc_current_state = 6;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                if(($__uri.equals("") && $__local.equals("memberTypes"))) {
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                $_ngcc_current_state = 6;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 9:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 639);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 8:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 640);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","memberTypes"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 6;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 10:
+            {
+                __text = $value;
+                $_ngcc_current_state = 9;
+                action3();
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 637:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 4;
+            }
+            break;
+        case 640:
+            {
+                memberTypeName = ((UName)$__result__);
+                action2();
+                $_ngcc_current_state = 8;
+            }
+            break;
+        case 631:
+            {
+                anonymousMemberType = ((SimpleTypeImpl)$__result__);
+                action1();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 639:
+            {
+                memberTypeName = ((UName)$__result__);
+                action2();
+                $_ngcc_current_state = 8;
+            }
+            break;
+        case 632:
+            {
+                anonymousMemberType = ((SimpleTypeImpl)$__result__);
+                action1();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 635:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 2;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+                /** computed simple type object */
+                private UnionSimpleTypeImpl result;
+
+                // Vector of Ref.SimpleType
+                private final Vector members = new Vector();
+
+                // locator of <union>
+                private Locator uloc;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/annotation.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/annotation.java
new file mode 100644
index 0000000..7423a23
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/annotation.java
@@ -0,0 +1,213 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+import com.sun.xml.internal.xsom.parser.AnnotationParser;
+
+
+class annotation extends NGCCHandler {
+    private AnnotationContext context;
+    private AnnotationImpl existing;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public annotation(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, AnnotationImpl _existing, AnnotationContext _context) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.existing = _existing;
+        this.context = _context;
+        $_ngcc_current_state = 2;
+    }
+
+    public annotation(NGCCRuntimeEx runtime, AnnotationImpl _existing, AnnotationContext _context) {
+        this(null, runtime, runtime, -1, _existing, _context);
+    }
+
+    private void action0()throws SAXException {
+
+        locator = $runtime.copyLocator();
+        parser = $runtime.createAnnotationParser();
+        $runtime.redirectSubtree(parser.getContentHandler(
+            context,
+            $runtime.getAnnotationContextElementName(),
+            $runtime.getErrorHandler(),
+            $runtime.parser.getEntityResolver()
+          ), $uri, $localName, $qname );
+
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action0();
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private AnnotationParser parser;
+      private Locator locator;
+
+      public AnnotationImpl makeResult() {
+        Object e = null;
+        if(existing!=null)  e=existing.getAnnotation();
+
+        return new AnnotationImpl( parser.getResult(e),locator);
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeDeclBody.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeDeclBody.java
new file mode 100644
index 0000000..d445573
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeDeclBody.java
@@ -0,0 +1,541 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class attributeDeclBody extends NGCCHandler {
+    private String name;
+    private ForeignAttributesImpl fa;
+    private AnnotationImpl annotation;
+    private Locator locator;
+    private boolean isLocal;
+    private String defaultValue;
+    private UName typeName;
+    private String fixedValue;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public attributeDeclBody(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, Locator _locator, boolean _isLocal, String _defaultValue, String _fixedValue) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.locator = _locator;
+        this.isLocal = _isLocal;
+        this.defaultValue = _defaultValue;
+        this.fixedValue = _fixedValue;
+        $_ngcc_current_state = 13;
+    }
+
+    public attributeDeclBody(NGCCRuntimeEx runtime, Locator _locator, boolean _isLocal, String _defaultValue, String _fixedValue) {
+        this(null, runtime, runtime, -1, _locator, _isLocal, _defaultValue, _fixedValue);
+    }
+
+    private void action0()throws SAXException {
+
+          type = new DelayedRef.SimpleType(
+            $runtime, locator, $runtime.currentSchema, typeName );
+
+}
+
+    private void action1()throws SAXException {
+        formSpecified = true;
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 7:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 686, null,AnnotationContext.ATTRIBUTE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","type"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                        NGCCHandler h = new simpleType(this, super._source, $runtime, 677);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        $_ngcc_current_state = 0;
+                        $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                    }
+                }
+            }
+            break;
+        case 9:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || ((($ai = $runtime.getAttributeIndex("","type"))>=0 && (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 12;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 7:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","type"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 9:
+            {
+                if(($ai = $runtime.getAttributeIndex("","type"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 12;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 7:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("") && $__local.equals("type"))) {
+                    $_ngcc_current_state = 5;
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 9:
+            {
+                if(($__uri.equals("") && $__local.equals("type"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 11;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($__uri.equals("") && $__local.equals("form"))) {
+                    $_ngcc_current_state = 15;
+                }
+                else {
+                    $_ngcc_current_state = 12;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 14:
+            {
+                if(($__uri.equals("") && $__local.equals("form"))) {
+                    $_ngcc_current_state = 12;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                if(($__uri.equals("") && $__local.equals("type"))) {
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 10:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 9;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 9:
+            {
+                NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                spawnChildFromLeaveAttribute(h, $__uri, $__local, $__qname);
+            }
+            break;
+        case 13:
+            {
+                $_ngcc_current_state = 12;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 7:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","type"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 9:
+            {
+                if(($ai = $runtime.getAttributeIndex("","type"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 688, fa);
+                    spawnChildFromText(h, $value);
+                }
+            }
+            break;
+        case 11:
+            {
+                name = $value;
+                $_ngcc_current_state = 10;
+            }
+            break;
+        case 12:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 5:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 679);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 15:
+            {
+                if($value.equals("unqualified")) {
+                    NGCCHandler h = new qualification(this, super._source, $runtime, 693);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if($value.equals("qualified")) {
+                        NGCCHandler h = new qualification(this, super._source, $runtime, 693);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 12;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 677:
+            {
+                type = ((SimpleTypeImpl)$__result__);
+                $_ngcc_current_state = 0;
+            }
+            break;
+        case 688:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 7;
+            }
+            break;
+        case 693:
+            {
+                form = ((Boolean)$__result__).booleanValue();
+                action1();
+                $_ngcc_current_state = 14;
+            }
+            break;
+        case 679:
+            {
+                typeName = ((UName)$__result__);
+                action0();
+                $_ngcc_current_state = 4;
+            }
+            break;
+        case 686:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return((($_ngcc_current_state == 7) || (($_ngcc_current_state == 0) || ($_ngcc_current_state == 1))));
+    }
+
+
+      private boolean form;
+      private boolean formSpecified = false;
+
+      private AttributeDeclImpl makeResult() {
+
+        if(type==null)
+          // type defaults to anySimpleType
+          type = $runtime.parser.schemaSet.anySimpleType;
+
+        if(!formSpecified) form = $runtime.attributeFormDefault;
+          // global attributes are always qualified
+          if(!isLocal)       form = true;
+
+        String tns;
+        if(form==true)  tns = $runtime.currentSchema.getTargetNamespace();
+        else            tns = "";
+
+        // proper handling of anonymous types
+        return new AttributeDeclImpl( $runtime.document, tns, name,
+          annotation, locator, fa, isLocal,
+          $runtime.createXmlString(defaultValue),
+          $runtime.createXmlString(fixedValue),
+          type );
+      }
+      private Ref.SimpleType type;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeGroupDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeGroupDecl.java
new file mode 100644
index 0000000..a7c4395
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeGroupDecl.java
@@ -0,0 +1,458 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class attributeGroupDecl extends NGCCHandler {
+    private AnnotationImpl annotation;
+    private String name;
+    private ForeignAttributesImpl fa;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public attributeGroupDecl(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 14;
+    }
+
+    public attributeGroupDecl(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+
+        result = new AttGroupDeclImpl(
+          $runtime.document, annotation, locator, fa, name );
+
+}
+
+    private void action1()throws SAXException {
+        locator=$runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 360, null,AnnotationContext.ATTRIBUTE_GROUP);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 3;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 6:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute")))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 362, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","id"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 6;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 14:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action1();
+                    $_ngcc_current_state = 13;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 3:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 2:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))))) {
+                    NGCCHandler h = new attributeUses(this, super._source, $runtime, 357, result);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 362, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","id"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 6;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 3:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                    NGCCHandler h = new attributeUses(this, super._source, $runtime, 357, result);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("") && $__local.equals("id"))) {
+                    $_ngcc_current_state = 9;
+                }
+                else {
+                    $_ngcc_current_state = 6;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 12;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 3:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 8:
+            {
+                if(($__uri.equals("") && $__local.equals("id"))) {
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                $_ngcc_current_state = 6;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 3:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 11:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 7;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 12:
+            {
+                name = $value;
+                $_ngcc_current_state = 11;
+            }
+            break;
+        case 7:
+            {
+                if(($ai = $runtime.getAttributeIndex("","id"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 6;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 9:
+            {
+                $_ngcc_current_state = 8;
+            }
+            break;
+        case 3:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 360:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 3;
+            }
+            break;
+        case 362:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 4;
+            }
+            break;
+        case 357:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private AttGroupDeclImpl result;
+      private Locator locator;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeUses.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeUses.java
new file mode 100644
index 0000000..f070b6f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/attributeUses.java
@@ -0,0 +1,961 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class attributeUses extends NGCCHandler {
+    private String use;
+    private AttributesHolder owner;
+    private ForeignAttributesImpl fa;
+    private WildcardImpl wildcard;
+    private AnnotationImpl annotation;
+    private UName attDeclName;
+    private AttributeDeclImpl anonymousDecl;
+    private String defaultValue;
+    private String fixedValue;
+    private UName groupName;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public attributeUses(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, AttributesHolder _owner) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.owner = _owner;
+        $_ngcc_current_state = 5;
+    }
+
+    public attributeUses(NGCCRuntimeEx runtime, AttributesHolder _owner) {
+        this(null, runtime, runtime, -1, _owner);
+    }
+
+    private void action0()throws SAXException {
+
+          owner.setWildcard(wildcard);
+
+}
+
+    private void action1()throws SAXException {
+        wloc = $runtime.copyLocator();
+}
+
+    private void action2()throws SAXException {
+
+            owner.addAttGroup(new DelayedRef.AttGroup(
+              $runtime, locator, $runtime.currentSchema, groupName ));
+
+}
+
+    private void action3()throws SAXException {
+        locator=$runtime.copyLocator();
+}
+
+    private void action4()throws SAXException {
+
+            if("prohibited".equals(use))
+              owner.addProhibitedAttribute(attDeclName);
+            else
+              owner.addAttributeUse(attDeclName,
+                new AttributeUseImpl( $runtime.document, annotation,locator,fa,decl,
+                  $runtime.createXmlString(defaultValue),
+                  $runtime.createXmlString(fixedValue),
+                  "required".equals(use)));
+
+}
+
+    private void action5()throws SAXException {
+
+                  decl = new DelayedRef.Attribute(
+                    $runtime, locator, $runtime.currentSchema, attDeclName );
+
+}
+
+    private void action6()throws SAXException {
+
+                decl = anonymousDecl;
+                attDeclName = new UName(
+                  anonymousDecl.getTargetNamespace(),
+                  anonymousDecl.getName());
+                defaultValue = null;
+                fixedValue = null;
+
+}
+
+    private void action7()throws SAXException {
+
+            locator=$runtime.copyLocator();
+            use=null;
+            defaultValue=null;
+            fixedValue=null;
+            decl=null;
+            annotation=null;
+
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 25:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 17;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action7();
+                    $_ngcc_current_state = 33;
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                        $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                        action3();
+                        $_ngcc_current_state = 13;
+                    }
+                    else {
+                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))) {
+                            $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                            action1();
+                            $_ngcc_current_state = 3;
+                        }
+                        else {
+                            $_ngcc_current_state = 0;
+                            $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                        }
+                    }
+                }
+            }
+            break;
+        case 8:
+            {
+                action2();
+                $_ngcc_current_state = 7;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 16:
+            {
+                action4();
+                $_ngcc_current_state = 15;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 17:
+            {
+                if((($ai = $runtime.getAttributeIndex("","name"))>=0 || ($ai = $runtime.getAttributeIndex("","form"))>=0)) {
+                    NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 42, locator,true,defaultValue,fixedValue);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                        $runtime.consumeAttribute($ai);
+                        $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        unexpectedEnterElement($__qname);
+                    }
+                }
+            }
+            break;
+        case 9:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 24, null,AnnotationContext.ATTRIBUTE_USE);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 8;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 29:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 25;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 19:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 35, null,AnnotationContext.ATTRIBUTE_USE);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 18;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 33:
+            {
+                if(($ai = $runtime.getAttributeIndex("","use"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 29;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action7();
+                    $_ngcc_current_state = 33;
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                        $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                        action3();
+                        $_ngcc_current_state = 13;
+                    }
+                    else {
+                        $_ngcc_current_state = 1;
+                        $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                    }
+                }
+            }
+            break;
+        case 3:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($ai = $runtime.getAttributeIndex("","namespace"))>=0 || ($ai = $runtime.getAttributeIndex("","processContents"))>=0))) {
+                    NGCCHandler h = new wildcardBody(this, super._source, $runtime, 17, wloc);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 25:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 17;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 18:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 33, null);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                action2();
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 16:
+            {
+                action4();
+                $_ngcc_current_state = 15;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 17:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","name"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) || (($ai = $runtime.getAttributeIndex("","form"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))))) {
+                    NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 42, locator,true,defaultValue,fixedValue);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                        $runtime.consumeAttribute($ai);
+                        $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                    }
+                    else {
+                        unexpectedLeaveElement($__qname);
+                    }
+                }
+            }
+            break;
+        case 9:
+            {
+                $_ngcc_current_state = 8;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 29:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 25;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 19:
+            {
+                $_ngcc_current_state = 18;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 33:
+            {
+                if(($ai = $runtime.getAttributeIndex("","use"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 29;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 15:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 3:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","namespace"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))) || ((($ai = $runtime.getAttributeIndex("","processContents"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))))) {
+                    NGCCHandler h = new wildcardBody(this, super._source, $runtime, 17, wloc);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 25:
+            {
+                if(($__uri.equals("") && $__local.equals("fixed"))) {
+                    $_ngcc_current_state = 27;
+                }
+                else {
+                    $_ngcc_current_state = 17;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                action2();
+                $_ngcc_current_state = 7;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 16:
+            {
+                action4();
+                $_ngcc_current_state = 15;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 17:
+            {
+                if((($__uri.equals("") && $__local.equals("name")) || ($__uri.equals("") && $__local.equals("form")))) {
+                    NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 42, locator,true,defaultValue,fixedValue);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    if(($__uri.equals("") && $__local.equals("ref"))) {
+                        $_ngcc_current_state = 22;
+                    }
+                    else {
+                        unexpectedEnterAttribute($__qname);
+                    }
+                }
+            }
+            break;
+        case 9:
+            {
+                $_ngcc_current_state = 8;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 29:
+            {
+                if(($__uri.equals("") && $__local.equals("default"))) {
+                    $_ngcc_current_state = 31;
+                }
+                else {
+                    $_ngcc_current_state = 25;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 19:
+            {
+                $_ngcc_current_state = 18;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 33:
+            {
+                if(($__uri.equals("") && $__local.equals("use"))) {
+                    $_ngcc_current_state = 35;
+                }
+                else {
+                    $_ngcc_current_state = 29;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 3:
+            {
+                if((($__uri.equals("") && $__local.equals("namespace")) || ($__uri.equals("") && $__local.equals("processContents")))) {
+                    NGCCHandler h = new wildcardBody(this, super._source, $runtime, 17, wloc);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($__uri.equals("") && $__local.equals("ref"))) {
+                    $_ngcc_current_state = 12;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 25:
+            {
+                $_ngcc_current_state = 17;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 34:
+            {
+                if(($__uri.equals("") && $__local.equals("use"))) {
+                    $_ngcc_current_state = 29;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                action2();
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 16:
+            {
+                action4();
+                $_ngcc_current_state = 15;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 9:
+            {
+                $_ngcc_current_state = 8;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 11:
+            {
+                if(($__uri.equals("") && $__local.equals("ref"))) {
+                    $_ngcc_current_state = 9;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 29:
+            {
+                $_ngcc_current_state = 25;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 19:
+            {
+                $_ngcc_current_state = 18;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 33:
+            {
+                $_ngcc_current_state = 29;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 30:
+            {
+                if(($__uri.equals("") && $__local.equals("default"))) {
+                    $_ngcc_current_state = 25;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 21:
+            {
+                if(($__uri.equals("") && $__local.equals("ref"))) {
+                    $_ngcc_current_state = 19;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 26:
+            {
+                if(($__uri.equals("") && $__local.equals("fixed"))) {
+                    $_ngcc_current_state = 17;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 25:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 17;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 12:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 27);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 31:
+            {
+                defaultValue = $value;
+                $_ngcc_current_state = 30;
+            }
+            break;
+        case 22:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 38);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 8:
+            {
+                action2();
+                $_ngcc_current_state = 7;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 16:
+            {
+                action4();
+                $_ngcc_current_state = 15;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 35:
+            {
+                use = $value;
+                $_ngcc_current_state = 34;
+            }
+            break;
+        case 17:
+            {
+                if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                    NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 42, locator,true,defaultValue,fixedValue);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                        NGCCHandler h = new attributeDeclBody(this, super._source, $runtime, 42, locator,true,defaultValue,fixedValue);
+                        spawnChildFromText(h, $value);
+                    }
+                    else {
+                        if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                            $runtime.consumeAttribute($ai);
+                            $runtime.sendText(super._cookie, $value);
+                        }
+                    }
+                }
+            }
+            break;
+        case 9:
+            {
+                $_ngcc_current_state = 8;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        case 29:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 25;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 19:
+            {
+                $_ngcc_current_state = 18;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 33:
+            {
+                if(($ai = $runtime.getAttributeIndex("","use"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 29;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 3:
+            {
+                if(($ai = $runtime.getAttributeIndex("","processContents"))>=0) {
+                    NGCCHandler h = new wildcardBody(this, super._source, $runtime, 17, wloc);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                        NGCCHandler h = new wildcardBody(this, super._source, $runtime, 17, wloc);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 5:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 27:
+            {
+                fixedValue = $value;
+                $_ngcc_current_state = 26;
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 33:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 16;
+            }
+            break;
+        case 27:
+            {
+                groupName = ((UName)$__result__);
+                $_ngcc_current_state = 11;
+            }
+            break;
+        case 38:
+            {
+                attDeclName = ((UName)$__result__);
+                action5();
+                $_ngcc_current_state = 21;
+            }
+            break;
+        case 42:
+            {
+                anonymousDecl = ((AttributeDeclImpl)$__result__);
+                action6();
+                $_ngcc_current_state = 16;
+            }
+            break;
+        case 24:
+            {
+                $_ngcc_current_state = 8;
+            }
+            break;
+        case 35:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 18;
+            }
+            break;
+        case 17:
+            {
+                wildcard = ((WildcardImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 2;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return((($_ngcc_current_state == 5) || (($_ngcc_current_state == 0) || ($_ngcc_current_state == 1))));
+    }
+
+
+      private Ref.Attribute decl;
+      private Locator wloc; // locator for wildcards
+      private Locator locator;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/complexType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/complexType.java
new file mode 100644
index 0000000..cf75ef0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/complexType.java
@@ -0,0 +1,2013 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class complexType extends NGCCHandler {
+    private Integer finalValue;
+    private String name;
+    private String abstractValue;
+    private Integer blockValue;
+    private XSFacet facet;
+    private ForeignAttributesImpl fa;
+    private AnnotationImpl annotation;
+    private ContentTypeImpl explicitContent;
+    private UName baseTypeName;
+    private String mixedValue;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public complexType(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 88;
+    }
+
+    public complexType(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+
+            result.setContentType(explicitContent);
+
+}
+
+    private void action1()throws SAXException {
+
+            baseType = $runtime.parser.schemaSet.anyType;
+            makeResult(XSType.RESTRICTION);
+
+}
+
+    private void action2()throws SAXException {
+
+                result.setExplicitContent(explicitContent);
+                result.setContentType(
+                  buildComplexExtensionContentModel(explicitContent));
+
+}
+
+    private void action3()throws SAXException {
+
+                  baseType = new DelayedRef.Type(
+                    $runtime, locator2, $runtime.currentSchema, baseTypeName );
+                  makeResult(XSType.EXTENSION);
+
+}
+
+    private void action4()throws SAXException {
+        locator2 = $runtime.copyLocator();
+}
+
+    private void action5()throws SAXException {
+
+                result.setContentType(explicitContent);
+
+}
+
+    private void action6()throws SAXException {
+
+                  baseType = new DelayedRef.Type(
+                    $runtime, locator2, $runtime.currentSchema, baseTypeName );
+                  makeResult(XSType.RESTRICTION);
+
+}
+
+    private void action7()throws SAXException {
+        locator2 = $runtime.copyLocator();
+}
+
+    private void action8()throws SAXException {
+
+                contentType = new BaseContentRef(baseType);
+                makeResult(XSType.EXTENSION);
+                result.setContentType(contentType);
+
+}
+
+    private void action9()throws SAXException {
+
+                  baseType = new DelayedRef.Type(
+                    $runtime, locator2, $runtime.currentSchema, baseTypeName );
+
+}
+
+    private void action10()throws SAXException {
+        locator2 = $runtime.copyLocator();
+}
+
+    private void action11()throws SAXException {
+
+                makeResult(XSType.RESTRICTION);
+                result.setContentType(contentType);
+
+}
+
+    private void action12()throws SAXException {
+        contentSimpleType.addFacet(facet);
+}
+
+    private void action13()throws SAXException {
+
+                if(baseContentType==null) {
+                  // contentType of the base type, which must be a complex type
+                  baseContentType = new BaseContentSimpleTypeRef(baseType);
+                }
+
+                contentSimpleType = new RestrictionSimpleTypeImpl(
+                  $runtime.document, null/*?*/, locator2, null,
+                  null, true, Collections.EMPTY_SET, baseContentType );
+                contentType = contentSimpleType;
+
+}
+
+    private void action14()throws SAXException {
+
+                  baseType = new DelayedRef.Type(
+                    $runtime, locator2, $runtime.currentSchema, baseTypeName );
+
+}
+
+    private void action15()throws SAXException {
+        locator2 = $runtime.copyLocator();
+}
+
+    private void action16()throws SAXException {
+        locator = $runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 49:
+            {
+                if((((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern")))) {
+                    NGCCHandler h = new facet(this, super._source, $runtime, 538);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 48;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 38:
+            {
+                action8();
+                $_ngcc_current_state = 37;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 59:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 24:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 39:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 525, annotation,AnnotationContext.COMPLEXTYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 38;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 84:
+            {
+                if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 80;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 9:
+            {
+                if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))))))))) {
+                    NGCCHandler h = new complexType_complexContent_body(this, super._source, $runtime, 488, result);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 52:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                    NGCCHandler h = new simpleType(this, super._source, $runtime, 542);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 51;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 51:
+            {
+                action13();
+                $_ngcc_current_state = 49;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 21:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute")))))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 503, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 28:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 512, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 88:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action16();
+                    $_ngcc_current_state = 84;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 68:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 67;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 47:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))))) {
+                    NGCCHandler h = new attributeUses(this, super._source, $runtime, 534, result);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 80:
+            {
+                if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 76;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 61:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 554, annotation,AnnotationContext.COMPLEXTYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 35;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 37:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))))) {
+                    NGCCHandler h = new attributeUses(this, super._source, $runtime, 522, result);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 56:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType")) || ((((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute")))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 547, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 76:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 72;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 67:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexContent")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleContent")))))))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 564, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action7();
+                    $_ngcc_current_state = 24;
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension"))) {
+                        $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                        action4();
+                        $_ngcc_current_state = 15;
+                    }
+                    else {
+                        unexpectedEnterElement($__qname);
+                    }
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleContent"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 63;
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexContent"))) {
+                        $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                        $_ngcc_current_state = 29;
+                    }
+                    else {
+                        if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))))))))) {
+                            action1();
+                            NGCCHandler h = new complexType_complexContent_body(this, super._source, $runtime, 485, result);
+                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                        }
+                        else {
+                            unexpectedEnterElement($__qname);
+                        }
+                    }
+                }
+            }
+            break;
+        case 12:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute")))))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 492, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 41:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute")))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 527, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 19:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 501, annotation,AnnotationContext.COMPLEXTYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 18;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 35:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action15();
+                    $_ngcc_current_state = 59;
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension"))) {
+                        $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                        action10();
+                        $_ngcc_current_state = 44;
+                    }
+                    else {
+                        unexpectedEnterElement($__qname);
+                    }
+                }
+            }
+            break;
+        case 48:
+            {
+                if((((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern")))) {
+                    NGCCHandler h = new facet(this, super._source, $runtime, 537);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    action11();
+                    $_ngcc_current_state = 47;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 15:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 65:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 562, null,AnnotationContext.COMPLEXTYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 18:
+            {
+                if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))))))))) {
+                    NGCCHandler h = new complexType_complexContent_body(this, super._source, $runtime, 499, result);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 63:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 556, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 26:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 510, annotation,AnnotationContext.COMPLEXTYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 7;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 29:
+            {
+                if(($ai = $runtime.getAttributeIndex("","mixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 28;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 54:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 545, annotation,AnnotationContext.COMPLEXTYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 52;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 72:
+            {
+                if(($ai = $runtime.getAttributeIndex("","mixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 68;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 490, annotation,AnnotationContext.COMPLEXTYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 9;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 44:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 49:
+            {
+                $_ngcc_current_state = 48;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 38:
+            {
+                action8();
+                $_ngcc_current_state = 37;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 59:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 24:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 39:
+            {
+                $_ngcc_current_state = 38;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 84:
+            {
+                if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 80;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 36:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 34;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 9:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension"))) {
+                    NGCCHandler h = new complexType_complexContent_body(this, super._source, $runtime, 488, result);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 52:
+            {
+                $_ngcc_current_state = 51;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 51:
+            {
+                action13();
+                $_ngcc_current_state = 49;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 34:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleContent"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 21:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 503, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 68:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 67;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 61:
+            {
+                $_ngcc_current_state = 35;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 80:
+            {
+                if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 76;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 47:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    NGCCHandler h = new attributeUses(this, super._source, $runtime, 534, result);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 17:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 37:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension"))) {
+                    NGCCHandler h = new attributeUses(this, super._source, $runtime, 522, result);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexContent"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 56:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 547, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 76:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 72;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 67:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 564, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                    action1();
+                    NGCCHandler h = new complexType_complexContent_body(this, super._source, $runtime, 485, result);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 492, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 19:
+            {
+                $_ngcc_current_state = 18;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 41:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("extension"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 527, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 48:
+            {
+                action11();
+                $_ngcc_current_state = 47;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 15:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 65:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 18:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    NGCCHandler h = new complexType_complexContent_body(this, super._source, $runtime, 499, result);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 46:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 34;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 26:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 29:
+            {
+                if(($ai = $runtime.getAttributeIndex("","mixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 28;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 54:
+            {
+                $_ngcc_current_state = 52;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 72:
+            {
+                if(($ai = $runtime.getAttributeIndex("","mixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 68;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                $_ngcc_current_state = 9;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 44:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 76:
+            {
+                if(($__uri.equals("") && $__local.equals("final"))) {
+                    $_ngcc_current_state = 78;
+                }
+                else {
+                    $_ngcc_current_state = 72;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 49:
+            {
+                $_ngcc_current_state = 48;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 38:
+            {
+                action8();
+                $_ngcc_current_state = 37;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 59:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 58;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 19:
+            {
+                $_ngcc_current_state = 18;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 24:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 23;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 39:
+            {
+                $_ngcc_current_state = 38;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 48:
+            {
+                action11();
+                $_ngcc_current_state = 47;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 84:
+            {
+                if(($__uri.equals("") && $__local.equals("abstract"))) {
+                    $_ngcc_current_state = 86;
+                }
+                else {
+                    $_ngcc_current_state = 80;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 52:
+            {
+                $_ngcc_current_state = 51;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 15:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 14;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 51:
+            {
+                action13();
+                $_ngcc_current_state = 49;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 65:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 68:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 70;
+                }
+                else {
+                    $_ngcc_current_state = 67;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 61:
+            {
+                $_ngcc_current_state = 35;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 80:
+            {
+                if(($__uri.equals("") && $__local.equals("block"))) {
+                    $_ngcc_current_state = 82;
+                }
+                else {
+                    $_ngcc_current_state = 76;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 26:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 29:
+            {
+                if(($__uri.equals("") && $__local.equals("mixed"))) {
+                    $_ngcc_current_state = 31;
+                }
+                else {
+                    $_ngcc_current_state = 28;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 54:
+            {
+                $_ngcc_current_state = 52;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 72:
+            {
+                if(($__uri.equals("") && $__local.equals("mixed"))) {
+                    $_ngcc_current_state = 74;
+                }
+                else {
+                    $_ngcc_current_state = 68;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                $_ngcc_current_state = 9;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 44:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 43;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 13:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 12;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 49:
+            {
+                $_ngcc_current_state = 48;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 38:
+            {
+                action8();
+                $_ngcc_current_state = 37;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 39:
+            {
+                $_ngcc_current_state = 38;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 84:
+            {
+                $_ngcc_current_state = 80;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 73:
+            {
+                if(($__uri.equals("") && $__local.equals("mixed"))) {
+                    $_ngcc_current_state = 68;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 52:
+            {
+                $_ngcc_current_state = 51;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 51:
+            {
+                action13();
+                $_ngcc_current_state = 49;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 77:
+            {
+                if(($__uri.equals("") && $__local.equals("final"))) {
+                    $_ngcc_current_state = 72;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 68:
+            {
+                $_ngcc_current_state = 67;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 80:
+            {
+                $_ngcc_current_state = 76;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 61:
+            {
+                $_ngcc_current_state = 35;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 76:
+            {
+                $_ngcc_current_state = 72;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 30:
+            {
+                if(($__uri.equals("") && $__local.equals("mixed"))) {
+                    $_ngcc_current_state = 28;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 57:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 56;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 19:
+            {
+                $_ngcc_current_state = 18;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 48:
+            {
+                action11();
+                $_ngcc_current_state = 47;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 69:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 67;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 65:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 42:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 41;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 85:
+            {
+                if(($__uri.equals("") && $__local.equals("abstract"))) {
+                    $_ngcc_current_state = 80;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 22:
+            {
+                if(($__uri.equals("") && $__local.equals("base"))) {
+                    $_ngcc_current_state = 21;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 26:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 29:
+            {
+                $_ngcc_current_state = 28;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 54:
+            {
+                $_ngcc_current_state = 52;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 72:
+            {
+                $_ngcc_current_state = 68;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 81:
+            {
+                if(($__uri.equals("") && $__local.equals("block"))) {
+                    $_ngcc_current_state = 76;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                $_ngcc_current_state = 9;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 49:
+            {
+                $_ngcc_current_state = 48;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 38:
+            {
+                action8();
+                $_ngcc_current_state = 37;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 59:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 43:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 529);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 24:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 39:
+            {
+                $_ngcc_current_state = 38;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 84:
+            {
+                if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 80;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 14:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 494);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 74:
+            {
+                mixedValue = $value;
+                $_ngcc_current_state = 73;
+            }
+            break;
+        case 52:
+            {
+                $_ngcc_current_state = 51;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 51:
+            {
+                action13();
+                $_ngcc_current_state = 49;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 70:
+            {
+                name = $value;
+                $_ngcc_current_state = 69;
+            }
+            break;
+        case 82:
+            {
+                NGCCHandler h = new erSet(this, super._source, $runtime, 581);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 68:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 67;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 80:
+            {
+                if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 76;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 61:
+            {
+                $_ngcc_current_state = 35;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 78:
+            {
+                NGCCHandler h = new erSet(this, super._source, $runtime, 576);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 58:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 549);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 76:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 72;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 19:
+            {
+                $_ngcc_current_state = 18;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 48:
+            {
+                action11();
+                $_ngcc_current_state = 47;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 23:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 505);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 31:
+            {
+                mixedValue = $value;
+                $_ngcc_current_state = 30;
+            }
+            break;
+        case 15:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 65:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 86:
+            {
+                abstractValue = $value;
+                $_ngcc_current_state = 85;
+            }
+            break;
+        case 26:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 29:
+            {
+                if(($ai = $runtime.getAttributeIndex("","mixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 28;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 54:
+            {
+                $_ngcc_current_state = 52;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 72:
+            {
+                if(($ai = $runtime.getAttributeIndex("","mixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 68;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 10:
+            {
+                $_ngcc_current_state = 9;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 44:
+            {
+                if(($ai = $runtime.getAttributeIndex("","base"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 529:
+            {
+                baseTypeName = ((UName)$__result__);
+                action9();
+                $_ngcc_current_state = 42;
+            }
+            break;
+        case 488:
+            {
+                explicitContent = ((ContentTypeImpl)$__result__);
+                action2();
+                $_ngcc_current_state = 8;
+            }
+            break;
+        case 534:
+            {
+                $_ngcc_current_state = 46;
+            }
+            break;
+        case 492:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 10;
+            }
+            break;
+        case 501:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 18;
+            }
+            break;
+        case 527:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 39;
+            }
+            break;
+        case 499:
+            {
+                explicitContent = ((ContentTypeImpl)$__result__);
+                action5();
+                $_ngcc_current_state = 17;
+            }
+            break;
+        case 545:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 52;
+            }
+            break;
+        case 538:
+            {
+                facet = ((XSFacet)$__result__);
+                action12();
+                $_ngcc_current_state = 48;
+            }
+            break;
+        case 525:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 38;
+            }
+            break;
+        case 494:
+            {
+                baseTypeName = ((UName)$__result__);
+                action3();
+                $_ngcc_current_state = 13;
+            }
+            break;
+        case 542:
+            {
+                baseContentType = ((SimpleTypeImpl)$__result__);
+                $_ngcc_current_state = 51;
+            }
+            break;
+        case 503:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 19;
+            }
+            break;
+        case 512:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 26;
+            }
+            break;
+        case 581:
+            {
+                blockValue = ((Integer)$__result__);
+                $_ngcc_current_state = 81;
+            }
+            break;
+        case 554:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 35;
+            }
+            break;
+        case 576:
+            {
+                finalValue = ((Integer)$__result__);
+                $_ngcc_current_state = 77;
+            }
+            break;
+        case 549:
+            {
+                baseTypeName = ((UName)$__result__);
+                action14();
+                $_ngcc_current_state = 57;
+            }
+            break;
+        case 522:
+            {
+                $_ngcc_current_state = 36;
+            }
+            break;
+        case 547:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 54;
+            }
+            break;
+        case 564:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 65;
+            }
+            break;
+        case 485:
+            {
+                explicitContent = ((ContentTypeImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 537:
+            {
+                facet = ((XSFacet)$__result__);
+                action12();
+                $_ngcc_current_state = 48;
+            }
+            break;
+        case 505:
+            {
+                baseTypeName = ((UName)$__result__);
+                action6();
+                $_ngcc_current_state = 22;
+            }
+            break;
+        case 562:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 2;
+            }
+            break;
+        case 556:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 61;
+            }
+            break;
+        case 510:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 7;
+            }
+            break;
+        case 490:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 9;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private ComplexTypeImpl result;
+      private Ref.Type baseType;
+      private Ref.ContentType contentType;
+
+      // local variables for simpleContent/restriction
+      private Ref.SimpleType baseContentType;
+      private RestrictionSimpleTypeImpl contentSimpleType;
+
+      private Locator locator,locator2;
+
+      private static class BaseContentSimpleTypeRef implements Ref.SimpleType {
+        private final Ref.Type baseType;
+        private BaseContentSimpleTypeRef(Ref.Type _baseType ) { this.baseType = _baseType; }
+        public XSSimpleType getType() {
+          return (XSSimpleType)((XSComplexType)baseType.getType()).getContentType();
+        }
+      };
+      private static class BaseContentRef implements Ref.ContentType {
+        private final Ref.Type baseType;
+        private BaseContentRef(Ref.Type _baseType ) { this.baseType = _baseType; }
+        public XSContentType getContentType() {
+            XSType t = baseType.getType();
+            if(t.asComplexType()!=null)
+                return t.asComplexType().getContentType();
+            else
+                return t.asSimpleType();
+        }
+      };
+
+
+      // baseType and contentType must be computed before calling this method.
+      private void makeResult( int derivationMethod ) {
+
+        if(finalValue==null)
+          finalValue = new Integer($runtime.finalDefault);
+        if(blockValue==null)
+          blockValue = new Integer($runtime.blockDefault);
+
+        result = new ComplexTypeImpl(
+            $runtime.document,
+            annotation,
+            locator,
+            fa,
+            name,
+            name==null,
+            $runtime.parseBoolean(abstractValue),
+            derivationMethod,
+            baseType,
+            finalValue.intValue(),
+            blockValue.intValue(),
+            $runtime.parseBoolean(mixedValue)
+        );
+      }
+
+      // I had to make them static inner classes (as opposed to anonymous ones),
+      // so that they will not keep references to parser.
+
+      private static class BaseComplexTypeContentRef implements Ref.ContentType {
+        private final Ref.Type baseType;
+        private BaseComplexTypeContentRef(Ref.Type _baseType) { this.baseType = _baseType; }
+        public XSContentType getContentType() {
+            return ((XSComplexType)baseType.getType()).getContentType();
+        }
+      }
+      private static class InheritBaseContentTypeRef implements Ref.ContentType {
+        private final Ref.Type baseType;
+        private final XSContentType empty;
+        private final XSContentType expContent;
+        private final SchemaDocumentImpl currentDocument;
+        private InheritBaseContentTypeRef(
+          Ref.Type _baseType,XSContentType _explicitContent,NGCCRuntimeEx $runtime) {
+
+          this.baseType = _baseType;
+          this.currentDocument = $runtime.document;
+          expContent = _explicitContent;
+          this.empty = $runtime.parser.schemaSet.empty;
+        }
+          public XSContentType getContentType() {
+              XSContentType baseContentType =
+                  ((XSComplexType)baseType.getType()).getContentType();
+              if(baseContentType==empty)
+                  return expContent;
+              else
+                  return new ParticleImpl( currentDocument, null, new ModelGroupImpl(
+                    currentDocument,
+                      null, null, null, XSModelGroup.SEQUENCE,
+                      new ParticleImpl[]{
+                          (ParticleImpl)baseContentType,
+                          (ParticleImpl)expContent}), null );
+          }
+      };
+
+      private Ref.ContentType buildComplexExtensionContentModel( XSContentType explicitContent ) {
+
+        if(explicitContent==$runtime.parser.schemaSet.empty)
+          return new BaseComplexTypeContentRef(baseType);
+        else
+          return new InheritBaseContentTypeRef(baseType,explicitContent,$runtime);
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/complexType_complexContent_body.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/complexType_complexContent_body.java
new file mode 100644
index 0000000..8ade208
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/complexType_complexContent_body.java
@@ -0,0 +1,255 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class complexType_complexContent_body extends NGCCHandler {
+    private AttributesHolder owner;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public complexType_complexContent_body(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, AttributesHolder _owner) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.owner = _owner;
+        $_ngcc_current_state = 2;
+    }
+
+    public complexType_complexContent_body(NGCCRuntimeEx runtime, AttributesHolder _owner) {
+        this(null, runtime, runtime, -1, _owner);
+    }
+
+    private void action0()throws SAXException {
+        if(particle==null)
+          particle = $runtime.parser.schemaSet.empty;
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attribute")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("anyAttribute"))))) {
+                    NGCCHandler h = new attributeUses(this, super._source, $runtime, 608, owner);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    NGCCHandler h = new attributeUses(this, super._source, $runtime, 608, owner);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 2:
+            {
+                if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")))))) {
+                    NGCCHandler h = new particle(this, super._source, $runtime, 610);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(particle, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                NGCCHandler h = new attributeUses(this, super._source, $runtime, 608, owner);
+                spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(particle, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                NGCCHandler h = new attributeUses(this, super._source, $runtime, 608, owner);
+                spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(particle, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                NGCCHandler h = new attributeUses(this, super._source, $runtime, 608, owner);
+                spawnChildFromLeaveAttribute(h, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(particle, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                NGCCHandler h = new attributeUses(this, super._source, $runtime, 608, owner);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(particle, super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 608:
+            {
+                action0();
+                $_ngcc_current_state = 0;
+            }
+            break;
+        case 610:
+            {
+                particle = ((ParticleImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private ContentTypeImpl particle;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/elementDeclBody.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/elementDeclBody.java
new file mode 100644
index 0000000..37eee58
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/elementDeclBody.java
@@ -0,0 +1,1177 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class elementDeclBody extends NGCCHandler {
+    private Integer finalValue;
+    private String name;
+    private String nillable;
+    private String abstractValue;
+    private Integer blockValue;
+    private ForeignAttributesImpl fa;
+    private AnnotationImpl annotation;
+    private Locator locator;
+    private String defaultValue;
+    private IdentityConstraintImpl idc;
+    private boolean isGlobal;
+    private String fixedValue;
+    private UName typeName;
+    private UName substRef;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public elementDeclBody(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, Locator _locator, boolean _isGlobal) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.locator = _locator;
+        this.isGlobal = _isGlobal;
+        $_ngcc_current_state = 48;
+    }
+
+    public elementDeclBody(NGCCRuntimeEx runtime, Locator _locator, boolean _isGlobal) {
+        this(null, runtime, runtime, -1, _locator, _isGlobal);
+    }
+
+    private void action0()throws SAXException {
+        idcs.add(idc);
+}
+
+    private void action1()throws SAXException {
+
+            type = new DelayedRef.Type(
+              $runtime, locator, $runtime.currentSchema, typeName );
+
+}
+
+    private void action2()throws SAXException {
+
+          substHeadRef = new DelayedRef.Element(
+            $runtime, locator, $runtime.currentSchema, substRef );
+
+}
+
+    private void action3()throws SAXException {
+        formSpecified = true;
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 3:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                    NGCCHandler h = new simpleType(this, super._source, $runtime, 412);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                        NGCCHandler h = new complexType(this, super._source, $runtime, 413);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        if(($ai = $runtime.getAttributeIndex("","type"))>=0) {
+                            $runtime.consumeAttribute($ai);
+                            $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                        }
+                        else {
+                            $_ngcc_current_state = 1;
+                            $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                        }
+                    }
+                }
+            }
+            break;
+        case 23:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 36:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 32;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 48:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","form"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","default"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","abstract"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","final"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","fixed"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","block"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || (($ai = $runtime.getAttributeIndex("","name"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))))))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 28:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 24;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","substitutionGroup"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 44:
+            {
+                if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 40;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 17:
+            {
+                if(($ai = $runtime.getAttributeIndex("","nillable"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 13;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 40:
+            {
+                if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 36;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 32:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 28;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 417, null,AnnotationContext.ELEMENT_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 3;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 24:
+            {
+                if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 23;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique")))) {
+                    NGCCHandler h = new identityConstraint(this, super._source, $runtime, 400);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique")))) {
+                    NGCCHandler h = new identityConstraint(this, super._source, $runtime, 399);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 3:
+            {
+                if(($ai = $runtime.getAttributeIndex("","type"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 23:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 36:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 32;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 48:
+            {
+                if((($ai = $runtime.getAttributeIndex("","form"))>=0 || (($ai = $runtime.getAttributeIndex("","default"))>=0 || (($ai = $runtime.getAttributeIndex("","abstract"))>=0 || (($ai = $runtime.getAttributeIndex("","final"))>=0 || (($ai = $runtime.getAttributeIndex("","fixed"))>=0 || (($ai = $runtime.getAttributeIndex("","block"))>=0 || ($ai = $runtime.getAttributeIndex("","name"))>=0))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 28:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 24;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","substitutionGroup"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 44:
+            {
+                if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 40;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 17:
+            {
+                if(($ai = $runtime.getAttributeIndex("","nillable"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 13;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 40:
+            {
+                if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 36;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 32:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 28;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 24:
+            {
+                if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 23;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 3:
+            {
+                if(($__uri.equals("") && $__local.equals("type"))) {
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 23:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 22;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 36:
+            {
+                if(($__uri.equals("") && $__local.equals("final"))) {
+                    $_ngcc_current_state = 38;
+                }
+                else {
+                    $_ngcc_current_state = 32;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 48:
+            {
+                if((($__uri.equals("") && $__local.equals("form")) || (($__uri.equals("") && $__local.equals("default")) || (($__uri.equals("") && $__local.equals("abstract")) || (($__uri.equals("") && $__local.equals("final")) || (($__uri.equals("") && $__local.equals("fixed")) || (($__uri.equals("") && $__local.equals("block")) || ($__uri.equals("") && $__local.equals("name"))))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 28:
+            {
+                if(($__uri.equals("") && $__local.equals("fixed"))) {
+                    $_ngcc_current_state = 30;
+                }
+                else {
+                    $_ngcc_current_state = 24;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($__uri.equals("") && $__local.equals("substitutionGroup"))) {
+                    $_ngcc_current_state = 15;
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 44:
+            {
+                if(($__uri.equals("") && $__local.equals("abstract"))) {
+                    $_ngcc_current_state = 46;
+                }
+                else {
+                    $_ngcc_current_state = 40;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 17:
+            {
+                if(($__uri.equals("") && $__local.equals("nillable"))) {
+                    $_ngcc_current_state = 19;
+                }
+                else {
+                    $_ngcc_current_state = 13;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 40:
+            {
+                if(($__uri.equals("") && $__local.equals("block"))) {
+                    $_ngcc_current_state = 42;
+                }
+                else {
+                    $_ngcc_current_state = 36;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 32:
+            {
+                if(($__uri.equals("") && $__local.equals("default"))) {
+                    $_ngcc_current_state = 34;
+                }
+                else {
+                    $_ngcc_current_state = 28;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 24:
+            {
+                if(($__uri.equals("") && $__local.equals("form"))) {
+                    $_ngcc_current_state = 26;
+                }
+                else {
+                    $_ngcc_current_state = 23;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 3:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 14:
+            {
+                if(($__uri.equals("") && $__local.equals("substitutionGroup"))) {
+                    $_ngcc_current_state = 11;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 45:
+            {
+                if(($__uri.equals("") && $__local.equals("abstract"))) {
+                    $_ngcc_current_state = 40;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 36:
+            {
+                $_ngcc_current_state = 32;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 28:
+            {
+                $_ngcc_current_state = 24;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 33:
+            {
+                if(($__uri.equals("") && $__local.equals("default"))) {
+                    $_ngcc_current_state = 28;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 25:
+            {
+                if(($__uri.equals("") && $__local.equals("form"))) {
+                    $_ngcc_current_state = 23;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 29:
+            {
+                if(($__uri.equals("") && $__local.equals("fixed"))) {
+                    $_ngcc_current_state = 24;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 37:
+            {
+                if(($__uri.equals("") && $__local.equals("final"))) {
+                    $_ngcc_current_state = 32;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                $_ngcc_current_state = 11;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 44:
+            {
+                $_ngcc_current_state = 40;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 18:
+            {
+                if(($__uri.equals("") && $__local.equals("nillable"))) {
+                    $_ngcc_current_state = 13;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 17:
+            {
+                $_ngcc_current_state = 13;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 40:
+            {
+                $_ngcc_current_state = 36;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 41:
+            {
+                if(($__uri.equals("") && $__local.equals("block"))) {
+                    $_ngcc_current_state = 36;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($__uri.equals("") && $__local.equals("type"))) {
+                    $_ngcc_current_state = 1;
+                    action1();
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 32:
+            {
+                $_ngcc_current_state = 28;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 24:
+            {
+                $_ngcc_current_state = 23;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 21:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 17;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 38:
+            {
+                NGCCHandler h = new erSet(this, super._source, $runtime, 448);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 3:
+            {
+                if(($ai = $runtime.getAttributeIndex("","type"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 6:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 403);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 46:
+            {
+                abstractValue = $value;
+                $_ngcc_current_state = 45;
+            }
+            break;
+        case 26:
+            {
+                if($value.equals("unqualified")) {
+                    NGCCHandler h = new qualification(this, super._source, $runtime, 433);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if($value.equals("qualified")) {
+                        NGCCHandler h = new qualification(this, super._source, $runtime, 433);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 23:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 15:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 420);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 48:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                        NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                        spawnChildFromText(h, $value);
+                    }
+                    else {
+                        if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                            NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                            spawnChildFromText(h, $value);
+                        }
+                        else {
+                            if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                                NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                                spawnChildFromText(h, $value);
+                            }
+                            else {
+                                if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                                    spawnChildFromText(h, $value);
+                                }
+                                else {
+                                    if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                                        NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                                        spawnChildFromText(h, $value);
+                                    }
+                                    else {
+                                        if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                                            NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 462, fa);
+                                            spawnChildFromText(h, $value);
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 36:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 32;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 28:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 24;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","substitutionGroup"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 19:
+            {
+                nillable = $value;
+                $_ngcc_current_state = 18;
+            }
+            break;
+        case 34:
+            {
+                defaultValue = $value;
+                $_ngcc_current_state = 33;
+            }
+            break;
+        case 44:
+            {
+                if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 40;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 22:
+            {
+                name = $value;
+                $_ngcc_current_state = 21;
+            }
+            break;
+        case 17:
+            {
+                if(($ai = $runtime.getAttributeIndex("","nillable"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 13;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 40:
+            {
+                if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 36;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 30:
+            {
+                fixedValue = $value;
+                $_ngcc_current_state = 29;
+            }
+            break;
+        case 32:
+            {
+                if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 28;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 42:
+            {
+                NGCCHandler h = new ersSet(this, super._source, $runtime, 453);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 24:
+            {
+                if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 23;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 3;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 412:
+            {
+                type = ((SimpleTypeImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 413:
+            {
+                type = ((ComplexTypeImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 453:
+            {
+                blockValue = ((Integer)$__result__);
+                $_ngcc_current_state = 41;
+            }
+            break;
+        case 417:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 3;
+            }
+            break;
+        case 400:
+            {
+                idc = ((IdentityConstraintImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 0;
+            }
+            break;
+        case 448:
+            {
+                finalValue = ((Integer)$__result__);
+                $_ngcc_current_state = 37;
+            }
+            break;
+        case 403:
+            {
+                typeName = ((UName)$__result__);
+                $_ngcc_current_state = 5;
+            }
+            break;
+        case 433:
+            {
+                form = ((Boolean)$__result__).booleanValue();
+                action3();
+                $_ngcc_current_state = 25;
+            }
+            break;
+        case 462:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 44;
+            }
+            break;
+        case 420:
+            {
+                substRef = ((UName)$__result__);
+                action2();
+                $_ngcc_current_state = 14;
+            }
+            break;
+        case 399:
+            {
+                idc = ((IdentityConstraintImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 0;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return((($_ngcc_current_state == 0) || (($_ngcc_current_state == 17) || (($_ngcc_current_state == 13) || (($_ngcc_current_state == 1) || (($_ngcc_current_state == 11) || ($_ngcc_current_state == 3)))))));
+    }
+
+
+      private boolean form;
+      private boolean formSpecified;
+      private Ref.Type type;
+      private List idcs = new ArrayList();  // identity constraints
+
+      private DelayedRef.Element substHeadRef;
+
+      private ElementDecl makeResult() {
+        if(finalValue==null)
+          finalValue = new Integer($runtime.finalDefault);
+        if(blockValue==null)
+          blockValue = new Integer($runtime.blockDefault);
+
+        if(!formSpecified)
+          form = $runtime.elementFormDefault;
+        if(isGlobal)  // global elements are always qualified
+          form = true;
+
+        String tns;
+        if(form)    tns = $runtime.currentSchema.getTargetNamespace();
+        else        tns = "";
+
+        if( type==null ) {
+                if( substHeadRef!=null )
+                        type = new SubstGroupBaseTypeRef(substHeadRef);
+                else
+                        type = $runtime.parser.schemaSet.anyType;
+        }
+
+        ElementDecl ed = new ElementDecl(
+            $runtime,
+            $runtime.document,
+            annotation,
+            locator,
+            fa,
+            tns,
+            name,
+            !isGlobal,
+            $runtime.createXmlString(defaultValue),
+            $runtime.createXmlString(fixedValue),
+            $runtime.parseBoolean(nillable),
+            $runtime.parseBoolean(abstractValue),
+            type,
+            substHeadRef,
+            blockValue.intValue(),
+            finalValue.intValue(),
+            idcs);
+
+        // if this element has anonymous complex type, it will be set here.
+        if(type instanceof ComplexTypeImpl)
+          ((ComplexTypeImpl)type).setScope(ed);
+        return ed;
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/erSet.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/erSet.java
new file mode 100644
index 0000000..d874414
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/erSet.java
@@ -0,0 +1,183 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class erSet extends NGCCHandler {
+    private String v;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public erSet(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 1;
+    }
+
+    public erSet(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        case 1:
+            {
+                v = $value;
+                $_ngcc_current_state = 0;
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private Integer makeResult() {
+        if(v==null)     return new Integer($runtime.finalDefault);
+
+        if(v.indexOf("#all")!=-1)
+            return new Integer(XSType.EXTENSION|XSType.RESTRICTION);
+
+        int r = 0;
+
+        if(v.indexOf("extension")!=-1)      r|=XSType.EXTENSION;
+        if(v.indexOf("restriction")!=-1)    r|=XSType.RESTRICTION;
+
+        return new Integer(r);
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/ersSet.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/ersSet.java
new file mode 100644
index 0000000..4be0001
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/ersSet.java
@@ -0,0 +1,185 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class ersSet extends NGCCHandler {
+    private String v;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public ersSet(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 1;
+    }
+
+    public ersSet(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        case 1:
+            {
+                v = $value;
+                $_ngcc_current_state = 0;
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private Integer makeResult() {
+        if(v==null)     return new Integer($runtime.blockDefault);
+
+        if(v.indexOf("#all")!=-1)
+            return new Integer(
+              XSType.EXTENSION|XSType.RESTRICTION|XSType.SUBSTITUTION);
+
+        int r = 0;
+
+        if(v.indexOf("extension")!=-1)      r|=XSType.EXTENSION;
+        if(v.indexOf("restriction")!=-1)    r|=XSType.RESTRICTION;
+        if(v.indexOf("substitution")!=-1)   r|=XSType.SUBSTITUTION;
+
+        return new Integer(r);
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/facet.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/facet.java
new file mode 100644
index 0000000..f4e8bb2
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/facet.java
@@ -0,0 +1,400 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class facet extends NGCCHandler {
+    private AnnotationImpl annotation;
+    private String fixed;
+    private String value;
+    private ForeignAttributesImpl fa;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public facet(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 12;
+    }
+
+    public facet(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+
+        result = new FacetImpl( $runtime.document,
+                annotation, locator, fa, $localName/*name of the facet*/,
+                $runtime.createXmlString(value), $runtime.parseBoolean(fixed) );
+
+}
+
+    private void action1()throws SAXException {
+        locator=$runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 276, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 4;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 12:
+            {
+                if((((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern")))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action1();
+                    $_ngcc_current_state = 11;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","value"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 274, null,AnnotationContext.SIMPLETYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if((((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 276, fa);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 4;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","value"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if((((((((((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minExclusive")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxExclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxInclusive"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("totalDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("fractionDigits"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("length"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("maxLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("minLength"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("enumeration"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("whiteSpace"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("pattern")))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                    action0();
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                if(($__uri.equals("") && $__local.equals("fixed"))) {
+                    $_ngcc_current_state = 7;
+                }
+                else {
+                    $_ngcc_current_state = 4;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($__uri.equals("") && $__local.equals("value"))) {
+                    $_ngcc_current_state = 10;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                $_ngcc_current_state = 4;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 9:
+            {
+                if(($__uri.equals("") && $__local.equals("value"))) {
+                    $_ngcc_current_state = 5;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("") && $__local.equals("fixed"))) {
+                    $_ngcc_current_state = 4;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                value = $value;
+                $_ngcc_current_state = 9;
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 4;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","value"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 7:
+            {
+                fixed = $value;
+                $_ngcc_current_state = 6;
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 276:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 2;
+            }
+            break;
+        case 274:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+                private FacetImpl result;
+                private Locator locator;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/foreignAttributes.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/foreignAttributes.java
new file mode 100644
index 0000000..69c3dd7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/foreignAttributes.java
@@ -0,0 +1,168 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class foreignAttributes extends NGCCHandler {
+    private ForeignAttributesImpl current;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public foreignAttributes(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, ForeignAttributesImpl _current) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.current = _current;
+        $_ngcc_current_state = 0;
+    }
+
+    public foreignAttributes(NGCCRuntimeEx runtime, ForeignAttributesImpl _current) {
+        this(null, runtime, runtime, -1, _current);
+    }
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      ForeignAttributesImpl makeResult() {
+        return $runtime.parseForeignAttributes(current);
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/group.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/group.java
new file mode 100644
index 0000000..c107ce1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/group.java
@@ -0,0 +1,450 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class group extends NGCCHandler {
+    private AnnotationImpl annotation;
+    private String name;
+    private ModelGroupImpl term;
+    private ForeignAttributesImpl fa;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public group(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 15;
+    }
+
+    public group(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+
+        result = new ModelGroupDeclImpl( $runtime.document,
+                annotation, loc, fa,
+                $runtime.currentSchema.getTargetNamespace(),
+                                name,
+                                term
+                        );
+
+}
+
+    private void action1()throws SAXException {
+
+        mloc = $runtime.copyLocator();
+        compositorName = $localName;
+
+}
+
+    private void action2()throws SAXException {
+        loc = $runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 467, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 3:
+            {
+                if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))))))) {
+                    NGCCHandler h = new modelGroupBody(this, super._source, $runtime, 465, mloc,compositorName);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 469, null,AnnotationContext.MODELGROUP_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 5;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 4:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 3;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 15:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action2();
+                    $_ngcc_current_state = 11;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ID"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                    action0();
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 3:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) {
+                    NGCCHandler h = new modelGroupBody(this, super._source, $runtime, 465, mloc,compositorName);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                $_ngcc_current_state = 5;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ID"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                $_ngcc_current_state = 5;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 10:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 9;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($__uri.equals("") && $__local.equals("ID"))) {
+                    $_ngcc_current_state = 13;
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 8:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                $_ngcc_current_state = 5;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 12:
+            {
+                if(($__uri.equals("") && $__local.equals("ID"))) {
+                    $_ngcc_current_state = 10;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 10;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 6:
+            {
+                $_ngcc_current_state = 5;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 13:
+            {
+                $_ngcc_current_state = 12;
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ID"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 9:
+            {
+                name = $value;
+                $_ngcc_current_state = 8;
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 465:
+            {
+                term = ((ModelGroupImpl)$__result__);
+                $_ngcc_current_state = 2;
+            }
+            break;
+        case 467:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                action1();
+                $_ngcc_current_state = 4;
+            }
+            break;
+        case 469:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 5;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+                private ModelGroupDeclImpl result;
+                private Locator loc,mloc;
+                private String compositorName;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/identityConstraint.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/identityConstraint.java
new file mode 100644
index 0000000..4ed35a7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/identityConstraint.java
@@ -0,0 +1,593 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class identityConstraint extends NGCCHandler {
+    private String name;
+    private UName ref;
+    private ForeignAttributesImpl fa;
+    private AnnotationImpl ann;
+    private XPathImpl field;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public identityConstraint(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 18;
+    }
+
+    public identityConstraint(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+        fields.add(field);
+}
+
+    private void action1()throws SAXException {
+
+            refer = new DelayedRef.IdentityConstraint(
+              $runtime, $runtime.copyLocator(), $runtime.currentSchema, ref );
+
+}
+
+    private void action2()throws SAXException {
+        if($localName.equals("key"))
+        category = XSIdentityConstraint.KEY;
+      else
+      if($localName.equals("keyref"))
+        category = XSIdentityConstraint.KEYREF;
+      else
+      if($localName.equals("unique"))
+        category = XSIdentityConstraint.UNIQUE;
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 17:
+            {
+                if((($ai = $runtime.getAttributeIndex("","name"))>=0 && (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("selector")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 665, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","refer"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 8;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("field"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 3;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    NGCCHandler h = new xpath(this, super._source, $runtime, 652);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 4:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("field"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 3;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 655, null,AnnotationContext.IDENTITY_CONSTRAINT);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 7;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 3:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    NGCCHandler h = new xpath(this, super._source, $runtime, 648);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 16:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 18:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique")))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action2();
+                    $_ngcc_current_state = 17;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("selector"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 17:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 665, null);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","refer"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 8;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique")))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if((($ai = $runtime.getAttributeIndex("","xpath"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("selector")))) {
+                    NGCCHandler h = new xpath(this, super._source, $runtime, 652);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 3:
+            {
+                if((($ai = $runtime.getAttributeIndex("","xpath"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("field")))) {
+                    NGCCHandler h = new xpath(this, super._source, $runtime, 648);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 16:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("field"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("selector"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 4;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 17:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 665, null);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($__uri.equals("") && $__local.equals("refer"))) {
+                    $_ngcc_current_state = 12;
+                }
+                else {
+                    $_ngcc_current_state = 8;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("") && $__local.equals("xpath"))) {
+                    NGCCHandler h = new xpath(this, super._source, $runtime, 652);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 3:
+            {
+                if(($__uri.equals("") && $__local.equals("xpath"))) {
+                    NGCCHandler h = new xpath(this, super._source, $runtime, 648);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 16:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 15;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                $_ngcc_current_state = 8;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 14:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 10;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($__uri.equals("") && $__local.equals("refer"))) {
+                    $_ngcc_current_state = 8;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 17:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 665, null);
+                    spawnChildFromText(h, $value);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","refer"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 8;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 12:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 658);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    NGCCHandler h = new xpath(this, super._source, $runtime, 652);
+                    spawnChildFromText(h, $value);
+                }
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 3:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    NGCCHandler h = new xpath(this, super._source, $runtime, 648);
+                    spawnChildFromText(h, $value);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        case 16:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 15:
+            {
+                name = $value;
+                $_ngcc_current_state = 14;
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 652:
+            {
+                selector = ((XPathImpl)$__result__);
+                $_ngcc_current_state = 5;
+            }
+            break;
+        case 658:
+            {
+                ref = ((UName)$__result__);
+                action1();
+                $_ngcc_current_state = 11;
+            }
+            break;
+        case 648:
+            {
+                field = ((XPathImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 2;
+            }
+            break;
+        case 665:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 16;
+            }
+            break;
+        case 655:
+            {
+                ann = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 7;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private short category;
+      private List fields = new ArrayList();
+      private XPathImpl selector;
+      private DelayedRef.IdentityConstraint refer = null;
+
+      private IdentityConstraintImpl makeResult() {
+        return new IdentityConstraintImpl($runtime.document,ann,$runtime.copyLocator(),fa,
+          category,name,selector,fields,refer);
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/importDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/importDecl.java
new file mode 100644
index 0000000..cc05296
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/importDecl.java
@@ -0,0 +1,373 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class importDecl extends NGCCHandler {
+    private String ns;
+    private String schemaLocation;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public importDecl(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 12;
+    }
+
+    public importDecl(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+
+                        if(ns==null)    ns="";
+        $runtime.importSchema( ns,schemaLocation );
+
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 12:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("import"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 8;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 3, null,AnnotationContext.SCHEMA);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 8:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 4;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("import"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                    action0();
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 4;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($__uri.equals("") && $__local.equals("schemaLocation"))) {
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                if(($__uri.equals("") && $__local.equals("namespace"))) {
+                    $_ngcc_current_state = 10;
+                }
+                else {
+                    $_ngcc_current_state = 4;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 5:
+            {
+                if(($__uri.equals("") && $__local.equals("schemaLocation"))) {
+                    $_ngcc_current_state = 2;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 9:
+            {
+                if(($__uri.equals("") && $__local.equals("namespace"))) {
+                    $_ngcc_current_state = 4;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 4;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 6:
+            {
+                schemaLocation = $value;
+                $_ngcc_current_state = 5;
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        case 8:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 4;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 10:
+            {
+                ns = $value;
+                $_ngcc_current_state = 9;
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 3:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/includeDecl.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/includeDecl.java
new file mode 100644
index 0000000..b3bac6b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/includeDecl.java
@@ -0,0 +1,287 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class includeDecl extends NGCCHandler {
+    private String schemaLocation;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public includeDecl(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 7;
+    }
+
+    public includeDecl(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+        $runtime.includeSchema( schemaLocation );
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("include"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 231, null,AnnotationContext.SCHEMA);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("include"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                    action0();
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("") && $__local.equals("schemaLocation"))) {
+                    $_ngcc_current_state = 5;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($__uri.equals("") && $__local.equals("schemaLocation"))) {
+                    $_ngcc_current_state = 2;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 5:
+            {
+                schemaLocation = $value;
+                $_ngcc_current_state = 4;
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 231:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/modelGroupBody.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/modelGroupBody.java
new file mode 100644
index 0000000..503f921
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/modelGroupBody.java
@@ -0,0 +1,369 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+import java.util.Vector;
+
+
+class modelGroupBody extends NGCCHandler {
+    private AnnotationImpl annotation;
+    private String compositorName;
+    private Locator locator;
+    private ParticleImpl childParticle;
+    private ForeignAttributesImpl fa;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public modelGroupBody(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, Locator _locator, String _compositorName) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.locator = _locator;
+        this.compositorName = _compositorName;
+        $_ngcc_current_state = 6;
+    }
+
+    public modelGroupBody(NGCCRuntimeEx runtime, Locator _locator, String _compositorName) {
+        this(null, runtime, runtime, -1, _locator, _compositorName);
+    }
+
+    private void action0()throws SAXException {
+
+      XSModelGroup.Compositor compositor = null;
+      if(compositorName.equals("all"))      compositor = XSModelGroup.ALL;
+      if(compositorName.equals("sequence")) compositor = XSModelGroup.SEQUENCE;
+      if(compositorName.equals("choice"))   compositor = XSModelGroup.CHOICE;
+      if(compositor==null)
+        throw new InternalError("unable to process "+compositorName);
+
+      result = new ModelGroupImpl( $runtime.document, annotation, locator, fa, compositor,
+            (ParticleImpl[])particles.toArray(new ParticleImpl[0]));
+
+}
+
+    private void action1()throws SAXException {
+
+        particles.add(childParticle);
+
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")))))) {
+                    NGCCHandler h = new particle(this, super._source, $runtime, 669);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    action0();
+                    $_ngcc_current_state = 0;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 2:
+            {
+                if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")))))) {
+                    NGCCHandler h = new particle(this, super._source, $runtime, 670);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 4:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 673, null,AnnotationContext.MODELGROUP);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 6:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 675, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 675, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                action0();
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 675, null);
+                spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                action0();
+                $_ngcc_current_state = 0;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 675, null);
+                spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                action0();
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 675, null);
+                spawnChildFromLeaveAttribute(h, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                action0();
+                $_ngcc_current_state = 0;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 6:
+            {
+                NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 675, null);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 669:
+            {
+                childParticle = ((ParticleImpl)$__result__);
+                action1();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 670:
+            {
+                childParticle = ((ParticleImpl)$__result__);
+                action1();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 675:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 4;
+            }
+            break;
+        case 673:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 2;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return((($_ngcc_current_state == 0) || (($_ngcc_current_state == 4) || (($_ngcc_current_state == 2) || ($_ngcc_current_state == 1)))));
+    }
+
+
+                private ModelGroupImpl result;
+
+                private final List particles = new ArrayList();
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/notation.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/notation.java
new file mode 100644
index 0000000..be82d82
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/notation.java
@@ -0,0 +1,469 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class notation extends NGCCHandler {
+    private String name;
+    private String pub;
+    private ForeignAttributesImpl fa;
+    private String sys;
+    private AnnotationImpl ann;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public notation(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 15;
+    }
+
+    public notation(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+        loc = $runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($ai = $runtime.getAttributeIndex("","system"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 614, null,AnnotationContext.NOTATION);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 14:
+            {
+                if((($ai = $runtime.getAttributeIndex("","name"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 627, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 15:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("notation"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action0();
+                    $_ngcc_current_state = 14;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","public"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($ai = $runtime.getAttributeIndex("","system"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 14:
+            {
+                if((($ai = $runtime.getAttributeIndex("","name"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("notation")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 627, null);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("notation"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","public"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($__uri.equals("") && $__local.equals("system"))) {
+                    $_ngcc_current_state = 6;
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 14:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 627, null);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 13:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 12;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($__uri.equals("") && $__local.equals("public"))) {
+                    $_ngcc_current_state = 9;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 11:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 10;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 5:
+            {
+                if(($__uri.equals("") && $__local.equals("system"))) {
+                    $_ngcc_current_state = 2;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                if(($__uri.equals("") && $__local.equals("public"))) {
+                    $_ngcc_current_state = 4;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 4:
+            {
+                if(($ai = $runtime.getAttributeIndex("","system"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 2;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 9:
+            {
+                pub = $value;
+                $_ngcc_current_state = 8;
+            }
+            break;
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 14:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 627, null);
+                    spawnChildFromText(h, $value);
+                }
+            }
+            break;
+        case 12:
+            {
+                name = $value;
+                $_ngcc_current_state = 11;
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        case 13:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($ai = $runtime.getAttributeIndex("","public"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 6:
+            {
+                sys = $value;
+                $_ngcc_current_state = 5;
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 614:
+            {
+                ann = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 627:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 13;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+      private Locator loc;
+      private XSNotation makeResult() {
+        return new NotationImpl( $runtime.document,ann,loc,fa,name,pub,sys);
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/occurs.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/occurs.java
new file mode 100644
index 0000000..9796eca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/occurs.java
@@ -0,0 +1,324 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class occurs extends NGCCHandler {
+    private String v;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public occurs(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 5;
+    }
+
+    public occurs(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+        min = Integer.parseInt(v);
+}
+
+    private void action1()throws SAXException {
+        max=-1;
+}
+
+    private void action2()throws SAXException {
+        max = Integer.parseInt(v);
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","minOccurs"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","minOccurs"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                if(($__uri.equals("") && $__local.equals("maxOccurs"))) {
+                    $_ngcc_current_state = 7;
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("") && $__local.equals("minOccurs"))) {
+                    $_ngcc_current_state = 3;
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("") && $__local.equals("minOccurs"))) {
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("") && $__local.equals("maxOccurs"))) {
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 7:
+            {
+                if($value.equals("unbounded")) {
+                    $_ngcc_current_state = 6;
+                    action1();
+                }
+                else {
+                    v = $value;
+                    $_ngcc_current_state = 6;
+                    action2();
+                }
+            }
+            break;
+        case 3:
+            {
+                v = $value;
+                $_ngcc_current_state = 2;
+                action0();
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","minOccurs"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return((($_ngcc_current_state == 1) || (($_ngcc_current_state == 0) || ($_ngcc_current_state == 5))));
+    }
+
+
+      int max=1;
+      int min=1;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/particle.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/particle.java
new file mode 100644
index 0000000..d223207
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/particle.java
@@ -0,0 +1,1012 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class particle extends NGCCHandler {
+    private AnnotationImpl annotation;
+    private ElementDecl anonymousElementDecl;
+    private WildcardImpl wcBody;
+    private ModelGroupImpl term;
+    private UName elementTypeName;
+    private occurs occurs;
+    private UName groupName;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public particle(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 1;
+    }
+
+    public particle(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+
+          result = new ParticleImpl( $runtime.document, null, wcBody, wloc, occurs.max, occurs.min );
+
+}
+
+    private void action1()throws SAXException {
+        wloc = $runtime.copyLocator();
+}
+
+    private void action2()throws SAXException {
+
+              result = new ParticleImpl( $runtime.document, null,
+                anonymousElementDecl,
+                loc, occurs.max, occurs.min );
+
+}
+
+    private void action3()throws SAXException {
+
+              result = new ParticleImpl( $runtime.document, annotation, new DelayedRef.Element(
+                  $runtime, loc, $runtime.currentSchema, elementTypeName ),
+                  loc, occurs.max, occurs.min );
+
+}
+
+    private void action4()throws SAXException {
+        loc = $runtime.copyLocator();
+}
+
+    private void action5()throws SAXException {
+
+          result = new ParticleImpl( $runtime.document, annotation, new DelayedRef.ModelGroup(
+              $runtime, loc, $runtime.currentSchema, groupName ),
+            loc, occurs.max, occurs.min );
+
+}
+
+    private void action6()throws SAXException {
+        loc = $runtime.copyLocator();
+}
+
+    private void action7()throws SAXException {
+
+            result = new ParticleImpl( $runtime.document, null, term, loc, occurs.max, occurs.min );
+
+}
+
+    private void action8()throws SAXException {
+
+          compositorName = $localName;
+          loc = $runtime.copyLocator();
+
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                action3();
+                $_ngcc_current_state = 7;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 16:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","form"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","minOccurs"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","default"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","final"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","abstract"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","fixed"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","block"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","ref"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || ((($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) || (($ai = $runtime.getAttributeIndex("","name"))>=0 && (((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("key")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("keyref"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("unique"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))))))))))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action8();
+                    $_ngcc_current_state = 30;
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) {
+                        $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                        action6();
+                        $_ngcc_current_state = 26;
+                    }
+                    else {
+                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) {
+                            $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                            action4();
+                            $_ngcc_current_state = 16;
+                        }
+                        else {
+                            if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))) {
+                                $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                                action1();
+                                $_ngcc_current_state = 4;
+                            }
+                            else {
+                                unexpectedEnterElement($__qname);
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 11:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 323, null,AnnotationContext.PARTICLE);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 21:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 335, null,AnnotationContext.PARTICLE);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 20;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 4:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || ((($ai = $runtime.getAttributeIndex("","namespace"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) || ((($ai = $runtime.getAttributeIndex("","minOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) || ((($ai = $runtime.getAttributeIndex("","processContents"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) || (($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 315);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if((($ai = $runtime.getAttributeIndex("","form"))>=0 || (($ai = $runtime.getAttributeIndex("","default"))>=0 || (($ai = $runtime.getAttributeIndex("","final"))>=0 || (($ai = $runtime.getAttributeIndex("","abstract"))>=0 || (($ai = $runtime.getAttributeIndex("","fixed"))>=0 || (($ai = $runtime.getAttributeIndex("","block"))>=0 || ($ai = $runtime.getAttributeIndex("","name"))>=0))))))) {
+                        NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        unexpectedEnterElement($__qname);
+                    }
+                }
+            }
+            break;
+        case 3:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($ai = $runtime.getAttributeIndex("","namespace"))>=0 || ($ai = $runtime.getAttributeIndex("","processContents"))>=0))) {
+                    NGCCHandler h = new wildcardBody(this, super._source, $runtime, 314, wloc);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 30:
+            {
+                if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || ((($ai = $runtime.getAttributeIndex("","minOccurs"))>=0 && ((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) || ((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))))) || ((($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0 && ((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) || ((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))))))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 345);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 20:
+            {
+                action5();
+                $_ngcc_current_state = 19;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 29:
+            {
+                if((((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))))))) {
+                    NGCCHandler h = new modelGroupBody(this, super._source, $runtime, 344, loc,compositorName);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 25:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 26:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","minOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) || ((($ai = $runtime.getAttributeIndex("","ref"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) || (($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 340);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                action3();
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 16:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","form"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","minOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","default"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","final"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","abstract"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","fixed"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","block"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","ref"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || (($ai = $runtime.getAttributeIndex("","name"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))))))))))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 10;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 21:
+            {
+                $_ngcc_current_state = 20;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 19:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 4:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","namespace"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))) || ((($ai = $runtime.getAttributeIndex("","minOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))) || ((($ai = $runtime.getAttributeIndex("","processContents"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")) || (($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any")))))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 315);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    if(((($ai = $runtime.getAttributeIndex("","form"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","default"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","final"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","abstract"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","fixed"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || ((($ai = $runtime.getAttributeIndex("","block"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) || (($ai = $runtime.getAttributeIndex("","name"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element")))))))))) {
+                        NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                        spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                    }
+                    else {
+                        unexpectedLeaveElement($__qname);
+                    }
+                }
+            }
+            break;
+        case 7:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("element"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 28:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 3:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","namespace"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))) || ((($ai = $runtime.getAttributeIndex("","processContents"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))))) {
+                    NGCCHandler h = new wildcardBody(this, super._source, $runtime, 314, wloc);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 30:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","minOccurs"))>=0 && ((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) || ((($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0 && ((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) || ((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 345);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("any"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 20:
+            {
+                action5();
+                $_ngcc_current_state = 19;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 29:
+            {
+                if(((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("all")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("choice"))) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("sequence")))) {
+                    NGCCHandler h = new modelGroupBody(this, super._source, $runtime, 344, loc,compositorName);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 25:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 26:
+            {
+                if(((($ai = $runtime.getAttributeIndex("","minOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) || ((($ai = $runtime.getAttributeIndex("","ref"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) || (($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group")))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 340);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                action3();
+                $_ngcc_current_state = 7;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 3:
+            {
+                if((($__uri.equals("") && $__local.equals("namespace")) || ($__uri.equals("") && $__local.equals("processContents")))) {
+                    NGCCHandler h = new wildcardBody(this, super._source, $runtime, 314, wloc);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 30:
+            {
+                if((($__uri.equals("") && $__local.equals("minOccurs")) || ($__uri.equals("") && $__local.equals("maxOccurs")))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 345);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 16:
+            {
+                if((($__uri.equals("") && $__local.equals("form")) || (($__uri.equals("") && $__local.equals("minOccurs")) || (($__uri.equals("") && $__local.equals("default")) || (($__uri.equals("") && $__local.equals("final")) || (($__uri.equals("") && $__local.equals("abstract")) || (($__uri.equals("") && $__local.equals("fixed")) || (($__uri.equals("") && $__local.equals("block")) || (($__uri.equals("") && $__local.equals("ref")) || (($__uri.equals("") && $__local.equals("maxOccurs")) || ($__uri.equals("") && $__local.equals("name")))))))))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 21:
+            {
+                $_ngcc_current_state = 20;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 10;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 20:
+            {
+                action5();
+                $_ngcc_current_state = 19;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 25:
+            {
+                if(($__uri.equals("") && $__local.equals("ref"))) {
+                    $_ngcc_current_state = 24;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 4:
+            {
+                if((($__uri.equals("") && $__local.equals("namespace")) || (($__uri.equals("") && $__local.equals("minOccurs")) || (($__uri.equals("") && $__local.equals("processContents")) || ($__uri.equals("") && $__local.equals("maxOccurs")))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 315);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                if(($__uri.equals("") && $__local.equals("ref"))) {
+                    $_ngcc_current_state = 14;
+                }
+                else {
+                    if((($__uri.equals("") && $__local.equals("form")) || (($__uri.equals("") && $__local.equals("default")) || (($__uri.equals("") && $__local.equals("final")) || (($__uri.equals("") && $__local.equals("abstract")) || (($__uri.equals("") && $__local.equals("fixed")) || (($__uri.equals("") && $__local.equals("block")) || ($__uri.equals("") && $__local.equals("name"))))))))) {
+                        NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                        spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                    }
+                    else {
+                        unexpectedEnterAttribute($__qname);
+                    }
+                }
+            }
+            break;
+        case 26:
+            {
+                if((($__uri.equals("") && $__local.equals("minOccurs")) || (($__uri.equals("") && $__local.equals("ref")) || ($__uri.equals("") && $__local.equals("maxOccurs"))))) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 340);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                action3();
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 23:
+            {
+                if(($__uri.equals("") && $__local.equals("ref"))) {
+                    $_ngcc_current_state = 21;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 21:
+            {
+                $_ngcc_current_state = 20;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 10;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 20:
+            {
+                action5();
+                $_ngcc_current_state = 19;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 13:
+            {
+                if(($__uri.equals("") && $__local.equals("ref"))) {
+                    $_ngcc_current_state = 11;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 10:
+            {
+                action3();
+                $_ngcc_current_state = 7;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 16:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0) {
+                        NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                        spawnChildFromText(h, $value);
+                    }
+                    else {
+                        if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                            NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                            spawnChildFromText(h, $value);
+                        }
+                        else {
+                            if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                                NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                                spawnChildFromText(h, $value);
+                            }
+                            else {
+                                if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                                    NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                                    spawnChildFromText(h, $value);
+                                }
+                                else {
+                                    if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                                        NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                                        spawnChildFromText(h, $value);
+                                    }
+                                    else {
+                                        if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                                            NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                                            spawnChildFromText(h, $value);
+                                        }
+                                        else {
+                                            if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                                                NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                                                spawnChildFromText(h, $value);
+                                            }
+                                            else {
+                                                if(($ai = $runtime.getAttributeIndex("","minOccurs"))>=0) {
+                                                    NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                                                    spawnChildFromText(h, $value);
+                                                }
+                                                else {
+                                                    if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                                                        NGCCHandler h = new occurs(this, super._source, $runtime, 329);
+                                                        spawnChildFromText(h, $value);
+                                                    }
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 10;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 21:
+            {
+                $_ngcc_current_state = 20;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 4:
+            {
+                if(($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 315);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","processContents"))>=0) {
+                        NGCCHandler h = new occurs(this, super._source, $runtime, 315);
+                        spawnChildFromText(h, $value);
+                    }
+                    else {
+                        if(($ai = $runtime.getAttributeIndex("","minOccurs"))>=0) {
+                            NGCCHandler h = new occurs(this, super._source, $runtime, 315);
+                            spawnChildFromText(h, $value);
+                        }
+                        else {
+                            if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                                NGCCHandler h = new occurs(this, super._source, $runtime, 315);
+                                spawnChildFromText(h, $value);
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 8:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                        NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                        spawnChildFromText(h, $value);
+                    }
+                    else {
+                        if(($ai = $runtime.getAttributeIndex("","block"))>=0) {
+                            NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                            spawnChildFromText(h, $value);
+                        }
+                        else {
+                            if(($ai = $runtime.getAttributeIndex("","fixed"))>=0) {
+                                NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                                spawnChildFromText(h, $value);
+                            }
+                            else {
+                                if(($ai = $runtime.getAttributeIndex("","abstract"))>=0) {
+                                    NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                                    spawnChildFromText(h, $value);
+                                }
+                                else {
+                                    if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                                        NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                                        spawnChildFromText(h, $value);
+                                    }
+                                    else {
+                                        if(($ai = $runtime.getAttributeIndex("","default"))>=0) {
+                                            NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                                            spawnChildFromText(h, $value);
+                                        }
+                                        else {
+                                            if(($ai = $runtime.getAttributeIndex("","form"))>=0) {
+                                                NGCCHandler h = new elementDeclBody(this, super._source, $runtime, 320, loc,false);
+                                                spawnChildFromText(h, $value);
+                                            }
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 3:
+            {
+                if(($ai = $runtime.getAttributeIndex("","processContents"))>=0) {
+                    NGCCHandler h = new wildcardBody(this, super._source, $runtime, 314, wloc);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                        NGCCHandler h = new wildcardBody(this, super._source, $runtime, 314, wloc);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 30:
+            {
+                if(($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 345);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","minOccurs"))>=0) {
+                        NGCCHandler h = new occurs(this, super._source, $runtime, 345);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 24:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 338);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 20:
+            {
+                action5();
+                $_ngcc_current_state = 19;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 25:
+            {
+                if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 14:
+            {
+                NGCCHandler h = new qname(this, super._source, $runtime, 326);
+                spawnChildFromText(h, $value);
+            }
+            break;
+        case 26:
+            {
+                if(($ai = $runtime.getAttributeIndex("","maxOccurs"))>=0) {
+                    NGCCHandler h = new occurs(this, super._source, $runtime, 340);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","ref"))>=0) {
+                        NGCCHandler h = new occurs(this, super._source, $runtime, 340);
+                        spawnChildFromText(h, $value);
+                    }
+                    else {
+                        if(($ai = $runtime.getAttributeIndex("","minOccurs"))>=0) {
+                            NGCCHandler h = new occurs(this, super._source, $runtime, 340);
+                            spawnChildFromText(h, $value);
+                        }
+                    }
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 323:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 10;
+            }
+            break;
+        case 320:
+            {
+                anonymousElementDecl = ((ElementDecl)$__result__);
+                action2();
+                $_ngcc_current_state = 7;
+            }
+            break;
+        case 314:
+            {
+                wcBody = ((WildcardImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 2;
+            }
+            break;
+        case 345:
+            {
+                occurs = ((occurs)$__result__);
+                $_ngcc_current_state = 29;
+            }
+            break;
+        case 338:
+            {
+                groupName = ((UName)$__result__);
+                $_ngcc_current_state = 23;
+            }
+            break;
+        case 344:
+            {
+                term = ((ModelGroupImpl)$__result__);
+                action7();
+                $_ngcc_current_state = 28;
+            }
+            break;
+        case 326:
+            {
+                elementTypeName = ((UName)$__result__);
+                $_ngcc_current_state = 13;
+            }
+            break;
+        case 329:
+            {
+                occurs = ((occurs)$__result__);
+                $_ngcc_current_state = 8;
+            }
+            break;
+        case 335:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 20;
+            }
+            break;
+        case 315:
+            {
+                occurs = ((occurs)$__result__);
+                $_ngcc_current_state = 3;
+            }
+            break;
+        case 340:
+            {
+                occurs = ((occurs)$__result__);
+                $_ngcc_current_state = 25;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+        private Locator wloc;
+        private Locator loc;
+      private ParticleImpl result;
+      private String compositorName;
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/qname.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/qname.java
new file mode 100644
index 0000000..053bbd6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/qname.java
@@ -0,0 +1,169 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class qname extends NGCCHandler {
+    private String qvalue;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public qname(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 1;
+    }
+
+    public qname(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement($runtime.parseUName(qvalue), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveElement($runtime.parseUName(qvalue), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute($runtime.parseUName(qvalue), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute($runtime.parseUName(qvalue), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                qvalue = $value;
+                $_ngcc_current_state = 0;
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText($runtime.parseUName(qvalue), super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/qualification.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/qualification.java
new file mode 100644
index 0000000..9f4a054
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/qualification.java
@@ -0,0 +1,177 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class qualification extends NGCCHandler {
+    private String text;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public qualification(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 1;
+    }
+
+    public qualification(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterElement(new Boolean(text.trim().equals("qualified")), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveElement(new Boolean(text.trim().equals("qualified")), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromEnterAttribute(new Boolean(text.trim().equals("qualified")), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(new Boolean(text.trim().equals("qualified")), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 0:
+            {
+                revertToParentFromText(new Boolean(text.trim().equals("qualified")), super._cookie, $value);
+            }
+            break;
+        case 1:
+            {
+                if($value.equals("qualified")) {
+                    text = $value;
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    if($value.equals("unqualified")) {
+                        text = $value;
+                        $_ngcc_current_state = 0;
+                    }
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/redefine.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/redefine.java
new file mode 100644
index 0000000..4856095
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/redefine.java
@@ -0,0 +1,451 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class redefine extends NGCCHandler {
+    private String schemaLocation;
+    private ModelGroupDeclImpl newGrp;
+    private AttGroupDeclImpl newAg;
+    private SimpleTypeImpl newSt;
+    private ComplexTypeImpl newCt;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public redefine(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 15;
+    }
+
+    public redefine(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+        XSAttGroupDecl oldAg = $runtime.currentSchema.getAttGroupDecl(newAg.getName());
+            if(oldAg==null) {
+              $runtime.reportError( Messages.format(Messages.ERR_UNDEFINED_ATTRIBUTEGROUP,newAg.getName()) );
+            } else {
+              newAg.redefine((AttGroupDeclImpl)oldAg);
+              $runtime.currentSchema.addAttGroupDecl(newAg);
+            }
+}
+
+    private void action1()throws SAXException {
+        XSModelGroupDecl oldGrp = $runtime.currentSchema.getModelGroupDecl(newGrp.getName());
+            if(oldGrp==null) {
+              $runtime.reportError( Messages.format(Messages.ERR_UNDEFINED_MODELGROUP,newGrp.getName()) );
+            } else {
+              newGrp.redefine((ModelGroupDeclImpl)oldGrp);
+              $runtime.currentSchema.addModelGroupDecl(newGrp);
+            }
+}
+
+    private void action2()throws SAXException {
+        XSComplexType oldCt = $runtime.currentSchema.getComplexType(newCt.getName());
+            if(oldCt==null) {
+              $runtime.reportError( Messages.format(Messages.ERR_UNDEFINED_COMPLEXTYPE,newCt.getName()) );
+            } else {
+              newCt.redefine((ComplexTypeImpl)oldCt);
+              $runtime.currentSchema.addComplexType(newCt);
+            }
+}
+
+    private void action3()throws SAXException {
+        XSSimpleType oldSt = $runtime.currentSchema.getSimpleType(newSt.getName());
+            if(oldSt==null) {
+              $runtime.reportError( Messages.format(Messages.ERR_UNDEFINED_SIMPLETYPE,newSt.getName()) );
+            } else {
+              newSt.redefine((SimpleTypeImpl)oldSt);
+              $runtime.currentSchema.addSimpleType(newSt);
+            }
+}
+
+    private void action4()throws SAXException {
+        $runtime.includeSchema( schemaLocation );
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 262, null,AnnotationContext.SCHEMA);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                        NGCCHandler h = new simpleType(this, super._source, $runtime, 263);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                            NGCCHandler h = new complexType(this, super._source, $runtime, 264);
+                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                        }
+                        else {
+                            if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) {
+                                NGCCHandler h = new group(this, super._source, $runtime, 265);
+                                spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                            }
+                            else {
+                                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                                    NGCCHandler h = new attributeGroupDecl(this, super._source, $runtime, 266);
+                                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                }
+                                else {
+                                    $_ngcc_current_state = 1;
+                                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 14:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 257, null,AnnotationContext.SCHEMA);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                        NGCCHandler h = new simpleType(this, super._source, $runtime, 258);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("complexType"))) {
+                            NGCCHandler h = new complexType(this, super._source, $runtime, 259);
+                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                        }
+                        else {
+                            if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("group"))) {
+                                NGCCHandler h = new group(this, super._source, $runtime, 260);
+                                spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                            }
+                            else {
+                                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("attributeGroup"))) {
+                                    NGCCHandler h = new attributeGroupDecl(this, super._source, $runtime, 261);
+                                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                                }
+                                else {
+                                    unexpectedEnterElement($__qname);
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(this, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 15:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("redefine"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    $_ngcc_current_state = 14;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 14:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("redefine"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 14:
+            {
+                if(($__uri.equals("") && $__local.equals("schemaLocation"))) {
+                    $_ngcc_current_state = 13;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 12:
+            {
+                if(($__uri.equals("") && $__local.equals("schemaLocation"))) {
+                    $_ngcc_current_state = 2;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(this, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 2:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 14:
+            {
+                if(($ai = $runtime.getAttributeIndex("","schemaLocation"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 13:
+            {
+                schemaLocation = $value;
+                $_ngcc_current_state = 12;
+                action4();
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(this, super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 262:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 263:
+            {
+                newSt = ((SimpleTypeImpl)$__result__);
+                action3();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 264:
+            {
+                newCt = ((ComplexTypeImpl)$__result__);
+                action2();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 265:
+            {
+                newGrp = ((ModelGroupDeclImpl)$__result__);
+                action1();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 266:
+            {
+                newAg = ((AttGroupDeclImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 257:
+            {
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 258:
+            {
+                newSt = ((SimpleTypeImpl)$__result__);
+                action3();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 259:
+            {
+                newCt = ((ComplexTypeImpl)$__result__);
+                action2();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 260:
+            {
+                newGrp = ((ModelGroupDeclImpl)$__result__);
+                action1();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 261:
+            {
+                newAg = ((AttGroupDeclImpl)$__result__);
+                action0();
+                $_ngcc_current_state = 1;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/simpleType.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/simpleType.java
new file mode 100644
index 0000000..f28d540
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/simpleType.java
@@ -0,0 +1,503 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class simpleType extends NGCCHandler {
+    private AnnotationImpl annotation;
+    private String name;
+    private ForeignAttributesImpl fa;
+    private String finalValue;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public simpleType(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 19;
+    }
+
+    public simpleType(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    private void action0()throws SAXException {
+        finalSet = makeFinalSet(finalValue);
+}
+
+    private void action1()throws SAXException {
+        locator=$runtime.copyLocator();
+}
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(result, super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 15:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 19:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                    $runtime.onEnterElementConsumed($__uri, $__local, $__qname, $attrs);
+                    action1();
+                    $_ngcc_current_state = 15;
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction"))) {
+                    NGCCHandler h = new SimpleType_Restriction(this, super._source, $runtime, 379, annotation,locator,fa,name,finalSet);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("list"))) {
+                        NGCCHandler h = new SimpleType_List(this, super._source, $runtime, 380, annotation,locator,fa,name,finalSet);
+                        spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                    }
+                    else {
+                        if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("union"))) {
+                            NGCCHandler h = new SimpleType_Union(this, super._source, $runtime, 374, annotation,locator,fa,name,finalSet);
+                            spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                        }
+                        else {
+                            unexpectedEnterElement($__qname);
+                        }
+                    }
+                }
+            }
+            break;
+        case 10:
+            {
+                if((($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("union")) || (($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("restriction")) || ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("list")))))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 385, fa);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 383, null,AnnotationContext.SIMPLETYPE_DECL);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 7;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 7:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 15:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("simpleType"))) {
+                    $runtime.onLeaveElementConsumed($__uri, $__local, $__qname);
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 11:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 13;
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 15:
+            {
+                if(($__uri.equals("") && $__local.equals("final"))) {
+                    $_ngcc_current_state = 17;
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 7:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 12:
+            {
+                if(($__uri.equals("") && $__local.equals("name"))) {
+                    $_ngcc_current_state = 10;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 11:
+            {
+                $_ngcc_current_state = 10;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(result, super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 15:
+            {
+                $_ngcc_current_state = 11;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 16:
+            {
+                if(($__uri.equals("") && $__local.equals("final"))) {
+                    $_ngcc_current_state = 11;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 7:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 13:
+            {
+                name = $value;
+                $_ngcc_current_state = 12;
+            }
+            break;
+        case 17:
+            {
+                finalValue = $value;
+                $_ngcc_current_state = 16;
+            }
+            break;
+        case 11:
+            {
+                if(($ai = $runtime.getAttributeIndex("","name"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 10;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(result, super._cookie, $value);
+            }
+            break;
+        case 15:
+            {
+                if(($ai = $runtime.getAttributeIndex("","final"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 11;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 8:
+            {
+                $_ngcc_current_state = 7;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 7:
+            {
+                action0();
+                $_ngcc_current_state = 2;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 383:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 7;
+            }
+            break;
+        case 379:
+            {
+                result = ((RestrictionSimpleTypeImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 380:
+            {
+                result = ((ListSimpleTypeImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 374:
+            {
+                result = ((UnionSimpleTypeImpl)$__result__);
+                $_ngcc_current_state = 1;
+            }
+            break;
+        case 385:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 8;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return(($_ngcc_current_state == 0));
+    }
+
+
+                /** computed simple type object */
+                private SimpleTypeImpl result;
+
+                private Locator locator;
+
+      private Set finalSet;
+
+      private Set makeFinalSet(String finalValue) {
+        if(finalValue==null)
+          return Collections.EMPTY_SET;
+
+        Set s = new HashSet();
+        StringTokenizer tokens = new StringTokenizer(finalValue);
+        while(tokens.hasMoreTokens()) {
+          String token = tokens.nextToken();
+          if(token.equals("#all")) {
+            s.add(XSVariety.ATOMIC);
+            s.add(XSVariety.UNION);
+            s.add(XSVariety.LIST);
+          }
+          if(token.equals("list")) {
+            s.add(XSVariety.LIST);
+          }
+          if(token.equals("union")) {
+            s.add(XSVariety.UNION);
+          }
+          if(token.equals("restriction")) {
+            s.add(XSVariety.ATOMIC);
+          }
+        }
+        return s;
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/wildcardBody.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/wildcardBody.java
new file mode 100644
index 0000000..f30b0d4
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/wildcardBody.java
@@ -0,0 +1,445 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+import java.util.StringTokenizer;
+      import java.util.HashSet;
+
+
+class wildcardBody extends NGCCHandler {
+    private AnnotationImpl annotation;
+    private Locator locator;
+    private String modeValue;
+    private String ns;
+    private ForeignAttributesImpl fa;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public wildcardBody(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie, Locator _locator) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        this.locator = _locator;
+        $_ngcc_current_state = 10;
+    }
+
+    public wildcardBody(NGCCRuntimeEx runtime, Locator _locator) {
+        this(null, runtime, runtime, -1, _locator);
+    }
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 9:
+            {
+                if((($ai = $runtime.getAttributeIndex("","namespace"))>=0 || ($ai = $runtime.getAttributeIndex("","processContents"))>=0)) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 10:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 298, null,AnnotationContext.WILDCARD);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 9;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","processContents"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 9:
+            {
+                if((($ai = $runtime.getAttributeIndex("","namespace"))>=0 || ($ai = $runtime.getAttributeIndex("","processContents"))>=0)) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                $_ngcc_current_state = 9;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","processContents"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if(($__uri.equals("") && $__local.equals("namespace"))) {
+                    $_ngcc_current_state = 3;
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 9:
+            {
+                if((($__uri.equals("") && $__local.equals("namespace")) || ($__uri.equals("") && $__local.equals("processContents")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        case 10:
+            {
+                $_ngcc_current_state = 9;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 5:
+            {
+                if(($__uri.equals("") && $__local.equals("processContents"))) {
+                    $_ngcc_current_state = 7;
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 6:
+            {
+                if(($__uri.equals("") && $__local.equals("processContents"))) {
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 2:
+            {
+                if(($__uri.equals("") && $__local.equals("namespace"))) {
+                    $_ngcc_current_state = 0;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 9:
+            {
+                NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                spawnChildFromLeaveAttribute(h, $__uri, $__local, $__qname);
+            }
+            break;
+        case 10:
+            {
+                $_ngcc_current_state = 9;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 5:
+            {
+                $_ngcc_current_state = 1;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 3:
+            {
+                ns = $value;
+                $_ngcc_current_state = 2;
+            }
+            break;
+        case 7:
+            {
+                modeValue = $value;
+                $_ngcc_current_state = 6;
+            }
+            break;
+        case 1:
+            {
+                if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        case 9:
+            {
+                if(($ai = $runtime.getAttributeIndex("","processContents"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                    spawnChildFromText(h, $value);
+                }
+                else {
+                    if(($ai = $runtime.getAttributeIndex("","namespace"))>=0) {
+                        NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                        spawnChildFromText(h, $value);
+                    }
+                    else {
+                        NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 296, null);
+                        spawnChildFromText(h, $value);
+                    }
+                }
+            }
+            break;
+        case 10:
+            {
+                $_ngcc_current_state = 9;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","processContents"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+                else {
+                    $_ngcc_current_state = 1;
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 296:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 5;
+            }
+            break;
+        case 298:
+            {
+                annotation = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 9;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return((($_ngcc_current_state == 5) || (($_ngcc_current_state == 0) || ($_ngcc_current_state == 1))));
+    }
+
+
+      private WildcardImpl makeResult() {
+        if(modeValue==null) modeValue="strict";
+
+        int mode=-1;
+        if(modeValue.equals("strict"))      mode = XSWildcard.STRTICT;
+        if(modeValue.equals("lax"))         mode = XSWildcard.LAX;
+        if(modeValue.equals("skip"))        mode = XSWildcard.SKIP;
+        if(mode==-1)        throw new InternalError();
+
+        if(ns==null || ns.equals("##any"))
+            return new WildcardImpl.Any( $runtime.document, annotation,locator,fa,mode);
+
+        if(ns.equals("##other"))
+            return new WildcardImpl.Other( $runtime.document,
+                annotation,locator,fa,
+                $runtime.currentSchema.getTargetNamespace(),mode);
+
+        StringTokenizer tokens = new StringTokenizer(ns);
+        HashSet s = new HashSet();
+        while(tokens.hasMoreTokens()) {
+            String ns = tokens.nextToken();
+            if(ns.equals("##local")) ns="";
+            if(ns.equals("##targetNamespace")) ns=$runtime.currentSchema.getTargetNamespace();
+            s.add(ns);
+        }
+
+        return new WildcardImpl.Finite( $runtime.document, annotation,locator,fa,s,mode);
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/xpath.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/xpath.java
new file mode 100644
index 0000000..66e47fa
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/parser/state/xpath.java
@@ -0,0 +1,315 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* this file is generated by RelaxNGCC */
+package com.sun.xml.internal.xsom.impl.parser.state;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.Attributes;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+
+    import com.sun.xml.internal.xsom.*;
+    import com.sun.xml.internal.xsom.parser.*;
+    import com.sun.xml.internal.xsom.impl.*;
+    import com.sun.xml.internal.xsom.impl.parser.*;
+    import org.xml.sax.Locator;
+    import org.xml.sax.ContentHandler;
+    import org.xml.sax.helpers.*;
+    import java.util.*;
+
+
+
+class xpath extends NGCCHandler {
+    private String xpath;
+    private ForeignAttributesImpl fa;
+    private AnnotationImpl ann;
+    protected final NGCCRuntimeEx $runtime;
+    private int $_ngcc_current_state;
+    protected String $uri;
+    protected String $localName;
+    protected String $qname;
+
+    public final NGCCRuntime getRuntime() {
+        return($runtime);
+    }
+
+    public xpath(NGCCHandler parent, NGCCEventSource source, NGCCRuntimeEx runtime, int cookie) {
+        super(source, parent, cookie);
+        $runtime = runtime;
+        $_ngcc_current_state = 6;
+    }
+
+    public xpath(NGCCRuntimeEx runtime) {
+        this(null, runtime, runtime, -1);
+    }
+
+    public void enterElement(String $__uri, String $__local, String $__qname, Attributes $attrs) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                if(($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation"))) {
+                    NGCCHandler h = new annotation(this, super._source, $runtime, 66, null,AnnotationContext.XPATH);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    $_ngcc_current_state = 0;
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendEnterElement(super._cookie, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterElement(makeResult(), super._cookie, $__uri, $__local, $__qname, $attrs);
+            }
+            break;
+        case 6:
+            {
+                if((($ai = $runtime.getAttributeIndex("","xpath"))>=0 && ($__uri.equals("http://www.w3.org/2001/XMLSchema") && $__local.equals("annotation")))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 71, null);
+                    spawnChildFromEnterElement(h, $__uri, $__local, $__qname, $attrs);
+                }
+                else {
+                    unexpectedEnterElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveElement(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendLeaveElement(super._cookie, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveElement(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 71, null);
+                    spawnChildFromLeaveElement(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedLeaveElement($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveElement($__qname);
+            }
+            break;
+        }
+    }
+
+    public void enterAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendEnterAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 5:
+            {
+                if(($__uri.equals("") && $__local.equals("xpath"))) {
+                    $_ngcc_current_state = 4;
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromEnterAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 6:
+            {
+                if(($__uri.equals("") && $__local.equals("xpath"))) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 71, null);
+                    spawnChildFromEnterAttribute(h, $__uri, $__local, $__qname);
+                }
+                else {
+                    unexpectedEnterAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedEnterAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void leaveAttribute(String $__uri, String $__local, String $__qname) throws SAXException {
+        int $ai;
+        $uri = $__uri;
+        $localName = $__local;
+        $qname = $__qname;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendLeaveAttribute(super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromLeaveAttribute(makeResult(), super._cookie, $__uri, $__local, $__qname);
+            }
+            break;
+        case 3:
+            {
+                if(($__uri.equals("") && $__local.equals("xpath"))) {
+                    $_ngcc_current_state = 1;
+                }
+                else {
+                    unexpectedLeaveAttribute($__qname);
+                }
+            }
+            break;
+        default:
+            {
+                unexpectedLeaveAttribute($__qname);
+            }
+            break;
+        }
+    }
+
+    public void text(String $value) throws SAXException {
+        int $ai;
+        switch($_ngcc_current_state) {
+        case 1:
+            {
+                $_ngcc_current_state = 0;
+                $runtime.sendText(super._cookie, $value);
+            }
+            break;
+        case 4:
+            {
+                xpath = $value;
+                $_ngcc_current_state = 3;
+            }
+            break;
+        case 5:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    $runtime.consumeAttribute($ai);
+                    $runtime.sendText(super._cookie, $value);
+                }
+            }
+            break;
+        case 0:
+            {
+                revertToParentFromText(makeResult(), super._cookie, $value);
+            }
+            break;
+        case 6:
+            {
+                if(($ai = $runtime.getAttributeIndex("","xpath"))>=0) {
+                    NGCCHandler h = new foreignAttributes(this, super._source, $runtime, 71, null);
+                    spawnChildFromText(h, $value);
+                }
+            }
+            break;
+        }
+    }
+
+    public void onChildCompleted(Object $__result__, int $__cookie__, boolean $__needAttCheck__)throws SAXException {
+        switch($__cookie__) {
+        case 66:
+            {
+                ann = ((AnnotationImpl)$__result__);
+                $_ngcc_current_state = 0;
+            }
+            break;
+        case 71:
+            {
+                fa = ((ForeignAttributesImpl)$__result__);
+                $_ngcc_current_state = 5;
+            }
+            break;
+        }
+    }
+
+    public boolean accepted() {
+        return((($_ngcc_current_state == 0) || ($_ngcc_current_state == 1)));
+    }
+
+
+      private XPathImpl makeResult() {
+        return new XPathImpl($runtime.document,ann,$runtime.copyLocator(),fa,
+          $runtime.createXmlString(xpath));
+      }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/ConcatIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/ConcatIterator.java
new file mode 100644
index 0000000..8009e76
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/ConcatIterator.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.util;
+
+import java.util.Iterator;
+
+/**
+ *
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class ConcatIterator implements Iterator {
+
+    private Iterator lhs,rhs;
+
+    public ConcatIterator(Iterator _lhs, Iterator _rhs) {
+        this.lhs = _lhs;
+        this.rhs = _rhs;
+    }
+
+    public boolean hasNext() {
+        if( lhs!=null ) {
+            if( lhs.hasNext() ) return true;
+            lhs = null; // no more item in lhs
+        }
+        return rhs.hasNext();
+    }
+
+    public Object next() {
+        if( lhs!=null )     return lhs.next();
+        else                return rhs.next();
+    }
+
+    public void remove() {
+        if( lhs!=null )     lhs.remove();
+        else                rhs.remove();
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/DraconianErrorHandler.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/DraconianErrorHandler.java
new file mode 100644
index 0000000..3ba74b0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/DraconianErrorHandler.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.util;
+
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Aborts on the first error.
+ */
+public class DraconianErrorHandler implements ErrorHandler {
+    public void error( SAXParseException e ) throws SAXException {
+        throw e;
+    }
+    public void fatalError( SAXParseException e ) throws SAXException {
+        throw e;
+    }
+    public void warning( SAXParseException e ) {}
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/FilterIterator.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/FilterIterator.java
new file mode 100644
index 0000000..bb91970
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/FilterIterator.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.util;
+
+import java.util.Iterator;
+
+/**
+ * {@link Iterator} that works as a filter to another {@link Iterator}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class FilterIterator implements Iterator {
+
+    private final Iterator core;
+    private Object next;
+
+    protected FilterIterator( Iterator core ) {
+        this.core = core;
+    }
+
+    /**
+     * Implemented by the derived class to filter objects.
+     *
+     * @return true
+     *      to let the iterator return the object to the client.
+     */
+    protected abstract boolean allows( Object o );
+
+    public boolean hasNext() {
+        while(next==null && core.hasNext()) {
+            // fetch next
+            Object o = core.next();
+            if( allows(o) )
+                next = o;
+        }
+        return next!=null;
+    }
+
+    public Object next() {
+        Object r = next;
+        next = null;
+        return r;
+    }
+
+    public void remove() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/ResourceEntityResolver.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/ResourceEntityResolver.java
new file mode 100644
index 0000000..d0bf149
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/ResourceEntityResolver.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.util;
+
+import org.xml.sax.EntityResolver;
+import org.xml.sax.InputSource;
+
+public class ResourceEntityResolver implements EntityResolver {
+    public ResourceEntityResolver( Class _base ) {
+        this.base = _base;
+    }
+
+    private final Class base;
+
+    public InputSource resolveEntity( String publicId, String systemId ) {
+        return new InputSource(base.getResourceAsStream(systemId));
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/SchemaTreeTraverser.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/SchemaTreeTraverser.java
new file mode 100644
index 0000000..efee6e5
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/SchemaTreeTraverser.java
@@ -0,0 +1,1006 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.impl.util;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.impl.Const;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+import org.xml.sax.Locator;
+
+import javax.swing.Box;
+import javax.swing.Icon;
+import javax.swing.JLabel;
+import javax.swing.JPanel;
+import javax.swing.JTree;
+import javax.swing.tree.DefaultMutableTreeNode;
+import javax.swing.tree.DefaultTreeModel;
+import javax.swing.tree.TreeCellRenderer;
+import java.awt.Color;
+import java.awt.Component;
+import java.awt.FlowLayout;
+import java.awt.Font;
+import java.awt.Graphics;
+import java.text.MessageFormat;
+import java.util.Iterator;
+
+/**
+ * Generates approximated tree model for XML from a schema component. This is
+ * not intended to be a fully-fledged round-trippable tree model.
+ *
+ * <h2>Usage of this class</h2>
+ *
+ * <ol> <li>Create a new instance.</li> <li>Call {@link
+ * #visit(com.sun.xml.internal.xsom.XSSchemaSet)} function on your schema set.>/li>
+ * <li>Retrieve the model using {@link #getModel()}. </li></ol>
+ *
+ * Every node in the resulting tree is a {@link SchemaTreeTraverser.SchemaTreeNode},
+ * and the model itself is {@link SchemaTreeTraverser.SchemaTreeModel}. You can
+ * use {@link SchemaTreeTraverser.SchemaTreeCellRenderer} as a cell renderer for
+ * your tree.
+ *
+ * @author Kirill Grouchnikov (kirillcool@yahoo.com)
+ */
+public class SchemaTreeTraverser implements XSVisitor, XSSimpleTypeVisitor {
+    /**
+     * The associated tree model.
+     */
+    private SchemaTreeModel model;
+
+    /**
+     * The current node in the tree.
+     */
+    private SchemaTreeNode currNode;
+
+    /**
+     * Tree model for schema hierarchy tree.
+     *
+     * @author Kirill Grouchnikov
+     */
+    public static final class SchemaTreeModel extends DefaultTreeModel {
+        /**
+         * A simple constructor. Is made private to allow creating the root node
+         * first.
+         *
+         * @param root The root node.
+         */
+        private SchemaTreeModel(SchemaRootNode root) {
+            super(root);
+        }
+
+        /**
+         * A factory method for creating a new empty tree.
+         *
+         * @return New empty tree model.
+         */
+        public static SchemaTreeModel getInstance() {
+            SchemaRootNode root = new SchemaRootNode();
+            return new SchemaTreeModel(root);
+        }
+
+        public void addSchemaNode(SchemaTreeNode node) {
+            ((SchemaRootNode) this.root).add(node);
+        }
+    }
+
+    /**
+     * The node of the schema hierarchy tree.
+     *
+     * @author Kirill Grouchnikov
+     */
+    public static class SchemaTreeNode extends DefaultMutableTreeNode {
+        /**
+         * File name of the corresponding schema artifact.
+         */
+        private String fileName;
+
+        /**
+         * Line number of the corresponding schema artifact.
+         */
+        private int lineNumber;
+
+        /**
+         * The caption of the corresponding artifact.
+         */
+        private String artifactName;
+
+        /**
+         * Simple constructor.
+         *
+         * @param artifactName Artifact name.
+         * @param locator      Artifact locator.
+         */
+        public SchemaTreeNode(String artifactName, Locator locator) {
+            this.artifactName = artifactName;
+            if (locator == null) {
+                this.fileName = null;
+            }
+            else {
+                String filename = locator.getSystemId();
+                filename = filename.replaceAll("\u002520", " ");
+                // strip leading protocol
+                if (filename.startsWith("file:/")) {
+                    filename = filename.substring(6);
+                }
+
+                this.fileName = filename;
+                this.lineNumber = locator.getLineNumber() - 1;
+            }
+        }
+
+        /**
+         * Returns the caption for <code>this</code> node.
+         *
+         * @return The caption for <code>this</code> node.
+         */
+        public String getCaption() {
+            return this.artifactName;
+        }
+
+        /**
+         * @return Returns the file name of the corresponding schema artifact.
+         */
+        public String getFileName() {
+            return fileName;
+        }
+
+        /**
+         * @param fileName The file name of the corresponding schema artifact to
+         *                 set.
+         */
+        public void setFileName(String fileName) {
+            this.fileName = fileName;
+        }
+
+        /**
+         * @return Returns the line number of the corresponding schema
+         *         artifact.
+         */
+        public int getLineNumber() {
+            return lineNumber;
+        }
+
+        /**
+         * @param lineNumber The line number of the corresponding schema
+         *                   artifact to set.
+         */
+        public void setLineNumber(int lineNumber) {
+            this.lineNumber = lineNumber;
+        }
+    }
+
+    /**
+     * The root node of the schema hierarchy tree.
+     *
+     * @author Kirill Grouchnikov
+     */
+    public static class SchemaRootNode extends SchemaTreeNode {
+        /**
+         * A simple constructor.
+         */
+        public SchemaRootNode() {
+            super("Schema set", null);
+        }
+    }
+
+
+    /**
+     * Sample cell renderer for the schema tree.
+     *
+     * @author Kirill Grouchnikov
+     */
+    public static class SchemaTreeCellRenderer extends JPanel implements
+            TreeCellRenderer {
+        /**
+         * The icon label.
+         */
+        protected final JLabel iconLabel;
+
+        /**
+         * The text label
+         */
+        protected final JLabel nameLabel;
+
+        /**
+         * The selection indicator.
+         */
+        private boolean isSelected;
+
+        /**
+         * Background color for selected cells (light brown).
+         */
+        public final Color selectedBackground = new Color(255, 244, 232);
+
+
+        /**
+         * Foreground color for selected cells, both text and border (dark
+         * brown).
+         */
+        public final Color selectedForeground = new Color(64, 32, 0);
+
+        /**
+         * Default font for the text label.
+         */
+        public final Font nameFont = new Font("Arial", Font.BOLD, 12);
+
+
+        /**
+         * Simple constructor.
+         */
+        public SchemaTreeCellRenderer() {
+            FlowLayout fl = new FlowLayout(FlowLayout.LEFT, 1, 1);
+            this.setLayout(fl);
+            this.iconLabel = new JLabel();
+            this.iconLabel.setOpaque(false);
+            this.iconLabel.setBorder(null);
+            this.add(this.iconLabel);
+
+            // add some space
+            this.add(Box.createHorizontalStrut(5));
+
+            this.nameLabel = new JLabel();
+            this.nameLabel.setOpaque(false);
+            this.nameLabel.setBorder(null);
+            this.nameLabel.setFont(nameFont);
+            this.add(this.nameLabel);
+
+            this.isSelected = false;
+
+            this.setOpaque(false);
+            this.setBorder(null);
+        }
+
+        /*
+         * (non-Javadoc)
+         *
+         * @see javax.swing.JComponent#paintComponent(java.awt.Graphics)
+         */
+        public final void paintComponent(Graphics g) {
+            int width = this.getWidth();
+            int height = this.getHeight();
+            if (this.isSelected) {
+                g.setColor(selectedBackground);
+                g.fillRect(0, 0, width - 1, height - 1);
+                g.setColor(selectedForeground);
+                g.drawRect(0, 0, width - 1, height - 1);
+            }
+            super.paintComponent(g);
+        }
+
+        /**
+         * Sets values for the icon and text of <code>this</code> renderer.
+         *
+         * @param icon     Icon to show.
+         * @param caption  Text to show.
+         * @param selected Selection indicator. If <code>true</code>, the
+         *                 renderer will be shown with different background and
+         *                 border settings.
+         */
+        protected final void setValues(Icon icon, String caption,
+                                       boolean selected) {
+
+            this.iconLabel.setIcon(icon);
+            this.nameLabel.setText(caption);
+
+            this.isSelected = selected;
+            if (selected) {
+                this.nameLabel.setForeground(selectedForeground);
+            }
+            else {
+                this.nameLabel.setForeground(Color.black);
+            }
+        }
+
+        /* (non-Javadoc)
+         * @see javax.swing.tree.TreeCellRenderer#getTreeCellRendererComponent(javax.swing.JTree, java.lang.Object, boolean, boolean, boolean, int, boolean)
+         */
+        public final Component getTreeCellRendererComponent(JTree tree, Object value,
+                                                            boolean selected, boolean expanded, boolean leaf, int row,
+                                                            boolean hasFocus) {
+            if (value instanceof SchemaTreeNode) {
+                SchemaTreeNode stn = (SchemaTreeNode) value;
+
+                this.setValues(null, stn.getCaption(), selected);
+                return this;
+            }
+            throw new IllegalStateException("Unknown node");
+        }
+    }
+
+
+    /**
+     * Simple constructor.
+     */
+    public SchemaTreeTraverser() {
+        this.model = SchemaTreeModel.getInstance();
+        this.currNode = (SchemaTreeNode) this.model.getRoot();
+    }
+
+    /**
+     * Retrieves the tree model of <code>this</code> traverser.
+     *
+     * @return Tree model of <code>this</code> traverser.
+     */
+    public SchemaTreeModel getModel() {
+        return model;
+    }
+
+    /**
+     * Visits the root schema set.
+     *
+     * @param s Root schema set.
+     */
+    public void visit(XSSchemaSet s) {
+        for (XSSchema schema : s.getSchemas()) {
+            schema(schema);
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#schema(com.sun.xml.internal.xsom.XSSchema)
+     */
+    public void schema(XSSchema s) {
+        // QUICK HACK: don't print the built-in components
+        if (s.getTargetNamespace().equals(Const.schemaNamespace)) {
+            return;
+        }
+
+        SchemaTreeNode newNode = new SchemaTreeNode("Schema "
+                + s.getLocator().getSystemId(), s.getLocator());
+        this.currNode = newNode;
+        this.model.addSchemaNode(newNode);
+
+        for (XSAttGroupDecl groupDecl : s.getAttGroupDecls().values()) {
+            attGroupDecl(groupDecl);
+        }
+
+        for (XSAttributeDecl attrDecl : s.getAttributeDecls().values()) {
+            attributeDecl(attrDecl);
+        }
+
+        for (XSComplexType complexType : s.getComplexTypes().values()) {
+            complexType(complexType);
+        }
+
+        for (XSElementDecl elementDecl : s.getElementDecls().values()) {
+            elementDecl(elementDecl);
+        }
+
+        for (XSModelGroupDecl modelGroupDecl : s.getModelGroupDecls().values()) {
+            modelGroupDecl(modelGroupDecl);
+        }
+
+        for (XSSimpleType simpleType : s.getSimpleTypes().values()) {
+            simpleType(simpleType);
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#attGroupDecl(com.sun.xml.internal.xsom.XSAttGroupDecl)
+     */
+    public void attGroupDecl(XSAttGroupDecl decl) {
+        SchemaTreeNode newNode = new SchemaTreeNode("Attribute group \""
+                + decl.getName() + "\"", decl.getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        Iterator itr;
+
+        itr = decl.iterateAttGroups();
+        while (itr.hasNext()) {
+            dumpRef((XSAttGroupDecl) itr.next());
+        }
+
+        itr = decl.iterateDeclaredAttributeUses();
+        while (itr.hasNext()) {
+            attributeUse((XSAttributeUse) itr.next());
+        }
+
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /**
+     * Creates node of attribute group decalration reference.
+     *
+     * @param decl Attribute group decalration reference.
+     */
+    public void dumpRef(XSAttGroupDecl decl) {
+        SchemaTreeNode newNode = new SchemaTreeNode("Attribute group ref \"{"
+                + decl.getTargetNamespace() + "}" + decl.getName() + "\"", decl
+                .getLocator());
+        this.currNode.add(newNode);
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#attributeUse(com.sun.xml.internal.xsom.XSAttributeUse)
+     */
+    public void attributeUse(XSAttributeUse use) {
+        XSAttributeDecl decl = use.getDecl();
+
+        String additionalAtts = "";
+
+        if (use.isRequired()) {
+            additionalAtts += " use=\"required\"";
+        }
+        if (use.getFixedValue() != null
+                && use.getDecl().getFixedValue() == null) {
+            additionalAtts += " fixed=\"" + use.getFixedValue() + "\"";
+        }
+        if (use.getDefaultValue() != null
+                && use.getDecl().getDefaultValue() == null) {
+            additionalAtts += " default=\"" + use.getDefaultValue() + "\"";
+        }
+
+        if (decl.isLocal()) {
+            // this is anonymous attribute use
+            dump(decl, additionalAtts);
+        }
+        else {
+            // reference to a global one
+            String str = MessageFormat.format(
+                    "Attribute ref \"'{'{0}'}'{1}{2}\"", new Object[]{
+                        decl.getTargetNamespace(), decl.getName(),
+                        additionalAtts});
+            SchemaTreeNode newNode = new SchemaTreeNode(str, decl.getLocator());
+            this.currNode.add(newNode);
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#attributeDecl(com.sun.xml.internal.xsom.XSAttributeDecl)
+     */
+    public void attributeDecl(XSAttributeDecl decl) {
+        dump(decl, "");
+    }
+
+    /**
+     * Creates node for attribute declaration with additional attributes.
+     *
+     * @param decl           Attribute declaration.
+     * @param additionalAtts Additional attributes.
+     */
+    private void dump(XSAttributeDecl decl, String additionalAtts) {
+        XSSimpleType type = decl.getType();
+
+        String str = MessageFormat.format("Attribute \"{0}\"{1}{2}{3}{4}",
+                new Object[]{
+                    decl.getName(),
+                    additionalAtts,
+                    type.isLocal() ? "" : MessageFormat.format(
+                            " type=\"'{'{0}'}'{1}\"", new Object[]{
+                                type.getTargetNamespace(),
+                                type.getName()}),
+                    decl.getFixedValue() == null ? "" : " fixed=\""
+                + decl.getFixedValue() + "\"",
+                    decl.getDefaultValue() == null ? "" : " default=\""
+                + decl.getDefaultValue() + "\""});
+
+        SchemaTreeNode newNode = new SchemaTreeNode(str, decl.getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        if (type.isLocal()) {
+            simpleType(type);
+        }
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor#simpleType(com.sun.xml.internal.xsom.XSSimpleType)
+     */
+    public void simpleType(XSSimpleType type) {
+
+        String str = MessageFormat.format("Simple type {0}",
+                new Object[]{type.isLocal() ? "" : " name=\""
+                + type.getName() + "\""});
+
+        SchemaTreeNode newNode = new SchemaTreeNode(str, type.getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        type.visit((XSSimpleTypeVisitor) this);
+
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor#listSimpleType(com.sun.xml.internal.xsom.XSListSimpleType)
+     */
+    public void listSimpleType(XSListSimpleType type) {
+        XSSimpleType itemType = type.getItemType();
+
+        if (itemType.isLocal()) {
+            SchemaTreeNode newNode = new SchemaTreeNode("List", type
+                    .getLocator());
+            this.currNode.add(newNode);
+            this.currNode = newNode;
+            simpleType(itemType);
+            this.currNode = (SchemaTreeNode) this.currNode.getParent();
+        }
+        else {
+            // global type
+            String str = MessageFormat.format("List itemType=\"'{'{0}'}'{1}\"",
+                    new Object[]{itemType.getTargetNamespace(),
+                                 itemType.getName()});
+            SchemaTreeNode newNode = new SchemaTreeNode(str, itemType
+                    .getLocator());
+            this.currNode.add(newNode);
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor#unionSimpleType(com.sun.xml.internal.xsom.XSUnionSimpleType)
+     */
+    public void unionSimpleType(XSUnionSimpleType type) {
+        final int len = type.getMemberSize();
+        StringBuffer ref = new StringBuffer();
+
+        for (int i = 0; i < len; i++) {
+            XSSimpleType member = type.getMember(i);
+            if (member.isGlobal()) {
+                ref.append(MessageFormat.format(" '{'{0}'}'{1}",
+                        new Object[]{
+                            member.getTargetNamespace(),
+                            member.getName()}));
+            }
+        }
+
+        String name = (ref.length() == 0) ? "Union" : ("Union memberTypes=\""
+                + ref + "\"");
+        SchemaTreeNode newNode = new SchemaTreeNode(name, type.getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        for (int i = 0; i < len; i++) {
+            XSSimpleType member = type.getMember(i);
+            if (member.isLocal()) {
+                simpleType(member);
+            }
+        }
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor#restrictionSimpleType(com.sun.xml.internal.xsom.XSRestrictionSimpleType)
+     */
+    public void restrictionSimpleType(XSRestrictionSimpleType type) {
+
+        if (type.getBaseType() == null) {
+            // don't print anySimpleType
+            if (!type.getName().equals("anySimpleType")) {
+                throw new InternalError();
+            }
+            if (!Const.schemaNamespace.equals(type.getTargetNamespace())) {
+                throw new InternalError();
+            }
+            return;
+        }
+
+        XSSimpleType baseType = type.getSimpleBaseType();
+
+        String str = MessageFormat.format("Restriction {0}",
+                new Object[]{baseType.isLocal() ? "" : " base=\"{"
+                + baseType.getTargetNamespace() + "}"
+                + baseType.getName() + "\""});
+
+        SchemaTreeNode newNode = new SchemaTreeNode(str, baseType.getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        if (baseType.isLocal()) {
+            simpleType(baseType);
+        }
+
+        Iterator itr = type.iterateDeclaredFacets();
+        while (itr.hasNext()) {
+            facet((XSFacet) itr.next());
+        }
+
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#facet(com.sun.xml.internal.xsom.XSFacet)
+     */
+    public void facet(XSFacet facet) {
+        SchemaTreeNode newNode = new SchemaTreeNode(MessageFormat.format(
+                "{0} value=\"{1}\"", new Object[]{facet.getName(),
+                                                  facet.getValue(), }),
+                facet.getLocator());
+        this.currNode.add(newNode);
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#notation(com.sun.xml.internal.xsom.XSNotation)
+     */
+    public void notation(XSNotation notation) {
+        SchemaTreeNode newNode = new SchemaTreeNode(MessageFormat.format(
+                "Notation name='\"0}\" public =\"{1}\" system=\"{2}\"",
+                new Object[]{notation.getName(), notation.getPublicId(),
+                             notation.getSystemId()}), notation.getLocator());
+        this.currNode.add(newNode);
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#complexType(com.sun.xml.internal.xsom.XSComplexType)
+     */
+    public void complexType(XSComplexType type) {
+        SchemaTreeNode newNode = new SchemaTreeNode(MessageFormat.format(
+                "ComplexType {0}", new Object[]{type.isLocal() ? ""
+                : " name=\"" + type.getName() + "\""}), type
+                .getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        // TODO: wildcard
+
+        if (type.getContentType().asSimpleType() != null) {
+            // simple content
+            SchemaTreeNode newNode2 = new SchemaTreeNode("Simple content", type
+                    .getContentType().getLocator());
+            this.currNode.add(newNode2);
+            this.currNode = newNode2;
+
+            XSType baseType = type.getBaseType();
+
+            if (type.getDerivationMethod() == XSType.RESTRICTION) {
+                // restriction
+                String str = MessageFormat.format(
+                        "Restriction base=\"<{0}>{1}\"", new Object[]{
+                            baseType.getTargetNamespace(),
+                            baseType.getName()});
+                SchemaTreeNode newNode3 = new SchemaTreeNode(str, baseType
+                        .getLocator());
+                this.currNode.add(newNode3);
+                this.currNode = newNode3;
+
+                dumpComplexTypeAttribute(type);
+
+                this.currNode = (SchemaTreeNode) this.currNode.getParent();
+            }
+            else {
+                // extension
+                String str = MessageFormat.format(
+                        "Extension base=\"<{0}>{1}\"", new Object[]{
+                            baseType.getTargetNamespace(),
+                            baseType.getName()});
+                SchemaTreeNode newNode3 = new SchemaTreeNode(str, baseType
+                        .getLocator());
+                this.currNode.add(newNode3);
+                this.currNode = newNode3;
+
+                // check if have redefine tag
+                if ((type.getTargetNamespace().compareTo(
+                        baseType.getTargetNamespace()) ==
+                        0)
+                        && (type.getName().compareTo(baseType.getName()) == 0)) {
+                    SchemaTreeNode newNodeRedefine = new SchemaTreeNode(
+                            "redefine", type
+                            .getLocator());
+                    this.currNode.add(newNodeRedefine);
+                    this.currNode = newNodeRedefine;
+                    baseType.visit(this);
+                    this.currNode =
+                            (SchemaTreeNode) newNodeRedefine.getParent();
+                }
+
+                dumpComplexTypeAttribute(type);
+
+                this.currNode = (SchemaTreeNode) this.currNode.getParent();
+            }
+
+            this.currNode = (SchemaTreeNode) this.currNode.getParent();
+        }
+        else {
+            // complex content
+            SchemaTreeNode newNode2 = new SchemaTreeNode("Complex content",
+                    type.getContentType().getLocator());
+            this.currNode.add(newNode2);
+            this.currNode = newNode2;
+
+            XSComplexType baseType = type.getBaseType().asComplexType();
+
+            if (type.getDerivationMethod() == XSType.RESTRICTION) {
+                // restriction
+                String str = MessageFormat.format(
+                        "Restriction base=\"<{0}>{1}\"", new Object[]{
+                            baseType.getTargetNamespace(),
+                            baseType.getName()});
+                SchemaTreeNode newNode3 = new SchemaTreeNode(str,
+                        baseType.getLocator());
+                this.currNode.add(newNode3);
+                this.currNode = newNode3;
+
+                type.getContentType().visit(this);
+                dumpComplexTypeAttribute(type);
+
+                this.currNode = (SchemaTreeNode) this.currNode.getParent();
+            }
+            else {
+                // extension
+                String str = MessageFormat.format(
+                        "Extension base=\"'{'{0}'}'{1}\"", new Object[]{
+                            baseType.getTargetNamespace(),
+                            baseType.getName()});
+                SchemaTreeNode newNode3 = new SchemaTreeNode(str,
+                        baseType.getLocator());
+                this.currNode.add(newNode3);
+                this.currNode = newNode3;
+
+                // check if have redefine tag
+                if ((type.getTargetNamespace().compareTo(
+                        baseType.getTargetNamespace()) ==
+                        0)
+                        && (type.getName().compareTo(baseType.getName()) == 0)) {
+                    SchemaTreeNode newNodeRedefine = new SchemaTreeNode(
+                            "redefine", type
+                            .getLocator());
+                    this.currNode.add(newNodeRedefine);
+                    this.currNode = newNodeRedefine;
+                    baseType.visit(this);
+                    this.currNode =
+                            (SchemaTreeNode) newNodeRedefine.getParent();
+                }
+
+                type.getExplicitContent().visit(this);
+                dumpComplexTypeAttribute(type);
+
+                this.currNode = (SchemaTreeNode) this.currNode.getParent();
+            }
+
+            this.currNode = (SchemaTreeNode) this.currNode.getParent();
+        }
+
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /**
+     * Creates node for complex type.
+     *
+     * @param type Complex type.
+     */
+    private void dumpComplexTypeAttribute(XSComplexType type) {
+        Iterator itr;
+
+        itr = type.iterateAttGroups();
+        while (itr.hasNext()) {
+            dumpRef((XSAttGroupDecl) itr.next());
+        }
+
+        itr = type.iterateDeclaredAttributeUses();
+        while (itr.hasNext()) {
+            attributeUse((XSAttributeUse) itr.next());
+        }
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSTermVisitor#elementDecl(com.sun.xml.internal.xsom.XSElementDecl)
+     */
+    public void elementDecl(XSElementDecl decl) {
+        elementDecl(decl, "");
+    }
+
+    /**
+     * Creates node for element declaration with additional attributes.
+     *
+     * @param decl      Element declaration.
+     * @param extraAtts Additional attributes.
+     */
+    private void elementDecl(XSElementDecl decl, String extraAtts) {
+        XSType type = decl.getType();
+
+        // TODO: various other attributes
+
+        String str = MessageFormat.format("Element name=\"{0}\"{1}{2}",
+                new Object[]{
+                    decl.getName(),
+                    type.isLocal() ? "" : " type=\"{"
+                + type.getTargetNamespace() + "}"
+                + type.getName() + "\"", extraAtts});
+
+        SchemaTreeNode newNode = new SchemaTreeNode(str, decl.getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        if (type.isLocal()) {
+            if (type.isLocal()) {
+                type.visit(this);
+            }
+        }
+
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSTermVisitor#modelGroupDecl(com.sun.xml.internal.xsom.XSModelGroupDecl)
+     */
+    public void modelGroupDecl(XSModelGroupDecl decl) {
+        SchemaTreeNode newNode = new SchemaTreeNode(MessageFormat.format(
+                "Group name=\"{0}\"", new Object[]{decl.getName()}),
+                decl.getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        modelGroup(decl.getModelGroup());
+
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSTermVisitor#modelGroup(com.sun.xml.internal.xsom.XSModelGroup)
+     */
+    public void modelGroup(XSModelGroup group) {
+        modelGroup(group, "");
+    }
+
+    /**
+     * Creates node for model group with additional attributes.
+     *
+     * @param group     Model group.
+     * @param extraAtts Additional attributes.
+     */
+    private void modelGroup(XSModelGroup group, String extraAtts) {
+        SchemaTreeNode newNode = new SchemaTreeNode(MessageFormat.format(
+                "{0}{1}", new Object[]{group.getCompositor(), extraAtts}),
+                group.getLocator());
+        this.currNode.add(newNode);
+        this.currNode = newNode;
+
+        final int len = group.getSize();
+        for (int i = 0; i < len; i++) {
+            particle(group.getChild(i));
+        }
+
+        this.currNode = (SchemaTreeNode) this.currNode.getParent();
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor#particle(com.sun.xml.internal.xsom.XSParticle)
+     */
+    public void particle(XSParticle part) {
+        int i;
+
+        StringBuffer buf = new StringBuffer();
+
+        i = part.getMaxOccurs();
+        if (i == XSParticle.UNBOUNDED) {
+            buf.append(" maxOccurs=\"unbounded\"");
+        }
+        else {
+            if (i != 1) {
+                buf.append(" maxOccurs=\"" + i + "\"");
+            }
+        }
+
+        i = part.getMinOccurs();
+        if (i != 1) {
+            buf.append(" minOccurs=\"" + i + "\"");
+        }
+
+        final String extraAtts = buf.toString();
+
+        part.getTerm().visit(new XSTermVisitor() {
+            public void elementDecl(XSElementDecl decl) {
+                if (decl.isLocal()) {
+                    SchemaTreeTraverser.this.elementDecl(decl, extraAtts);
+                }
+                else {
+                    // reference
+                    SchemaTreeNode newNode = new SchemaTreeNode(MessageFormat
+                            .format("Element ref=\"'{'{0}'}'{1}\"{2}",
+                                    new Object[]{decl.getTargetNamespace(),
+                                                 decl.getName(), extraAtts}),
+                            decl.getLocator());
+                    currNode.add(newNode);
+                }
+            }
+
+            public void modelGroupDecl(XSModelGroupDecl decl) {
+                // reference
+                SchemaTreeNode newNode = new SchemaTreeNode(MessageFormat
+                        .format("Group ref=\"'{'{0}'}'{1}\"{2}", new Object[]{
+                            decl.getTargetNamespace(), decl.getName(),
+                            extraAtts}), decl.getLocator());
+                currNode.add(newNode);
+            }
+
+            public void modelGroup(XSModelGroup group) {
+                SchemaTreeTraverser.this.modelGroup(group, extraAtts);
+            }
+
+            public void wildcard(XSWildcard wc) {
+                SchemaTreeTraverser.this.wildcard(wc, extraAtts);
+            }
+        });
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSTermVisitor#wildcard(com.sun.xml.internal.xsom.XSWildcard)
+     */
+    public void wildcard(XSWildcard wc) {
+        wildcard(wc, "");
+    }
+
+    /**
+     * Creates node for wild card with additional attributes.
+     *
+     * @param wc        Wild card.
+     * @param extraAtts Additional attributes.
+     */
+    private void wildcard(XSWildcard wc, String extraAtts) {
+        // TODO
+        SchemaTreeNode newNode = new SchemaTreeNode(MessageFormat.format(
+                "Any ", new Object[]{extraAtts}), wc.getLocator());
+        currNode.add(newNode);
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#annotation(com.sun.xml.internal.xsom.XSAnnotation)
+     */
+    public void annotation(XSAnnotation ann) {
+        // TODO: it would be nice even if we just put <xs:documentation>
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeVisitor#empty(com.sun.xml.internal.xsom.XSContentType)
+     */
+    public void empty(XSContentType t) {
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#identityConstraint(com.sun.xml.internal.xsom.XSIdentityConstraint)
+     */
+    public void identityConstraint(XSIdentityConstraint ic) {
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.visitor.XSVisitor#xpath(com.sun.xml.internal.xsom.XSXPath)
+     */
+    public void xpath(XSXPath xp) {
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/SchemaWriter.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/SchemaWriter.java
new file mode 100644
index 0000000..2b102ae
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/SchemaWriter.java
@@ -0,0 +1,607 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package com.sun.xml.internal.xsom.impl.util;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.impl.Const;
+import com.sun.xml.internal.xsom.visitor.XSSimpleTypeVisitor;
+import com.sun.xml.internal.xsom.visitor.XSTermVisitor;
+import com.sun.xml.internal.xsom.visitor.XSVisitor;
+
+import java.io.IOException;
+import java.io.Writer;
+import java.text.MessageFormat;
+import java.util.Iterator;
+
+/**
+ * Generates approximated XML Schema representation from
+ * a schema component. This is not intended to be a fully-fledged
+ * round-trippable schema writer.
+ *
+ * <h2>Usage of this class</h2>
+ * <ol>
+ *  <li>Create a new instance with whatever Writer
+ *      you'd like to send the output to.
+ *  <li>Call one of the overloaded dump methods.
+ *      You can repeat this process as many times as you want.
+ * </ol>
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ * @author Kirill Grouchnikov (kirillcool@yahoo.com)
+ */
+public class SchemaWriter implements XSVisitor, XSSimpleTypeVisitor {
+    public SchemaWriter( Writer _out ) {
+        this.out=_out;
+    }
+
+    /** output is sent to this object. */
+    private final Writer out;
+
+    /** indentation. */
+    private int indent;
+
+    private void println(String s) {
+        try {
+            for( int i=0; i<indent; i++)    out.write("  ");
+            out.write(s);
+            out.write('\n');
+            // flush stream to make the output appear immediately
+            out.flush();
+        } catch( IOException e ) {
+            // ignore IOException.
+            hadError = true;
+        }
+    }
+    private void println() { println(""); }
+
+    /** If IOException is encountered, this flag is set to true. */
+    private boolean hadError =false;
+
+    /** Flush the stream and check its error state. */
+    public boolean checkError() {
+        try {
+            out.flush();
+        } catch( IOException e ) {
+            hadError=true;
+        }
+        return hadError;
+    }
+
+    public void visit( XSSchemaSet s ) {
+        Iterator itr =  s.iterateSchema();
+        while(itr.hasNext()) {
+            schema((XSSchema)itr.next());
+            println();
+        }
+    }
+
+    public void schema( XSSchema s ) {
+
+        // QUICK HACK: don't print the built-in components
+        if(s.getTargetNamespace().equals(Const.schemaNamespace))
+            return;
+
+        println(MessageFormat.format("<schema targetNamespace=\"{0}\">",
+            new Object[]{
+                s.getTargetNamespace(),
+            }));
+        indent++;
+
+        Iterator itr;
+
+        itr = s.iterateAttGroupDecls();
+        while(itr.hasNext())
+            attGroupDecl( (XSAttGroupDecl)itr.next() );
+
+        itr = s.iterateAttributeDecls();
+        while(itr.hasNext())
+            attributeDecl( (XSAttributeDecl)itr.next() );
+
+        itr = s.iterateComplexTypes();
+        while(itr.hasNext())
+            complexType( (XSComplexType)itr.next() );
+
+        itr = s.iterateElementDecls();
+        while(itr.hasNext())
+            elementDecl( (XSElementDecl)itr.next() );
+
+        itr = s.iterateModelGroupDecls();
+        while(itr.hasNext())
+            modelGroupDecl( (XSModelGroupDecl)itr.next() );
+
+        itr = s.iterateSimpleTypes();
+        while(itr.hasNext())
+            simpleType( (XSSimpleType)itr.next() );
+
+        indent--;
+        println("</schema>");
+    }
+
+    public void attGroupDecl( XSAttGroupDecl decl ) {
+        Iterator itr;
+
+        println(MessageFormat.format("<attGroup name=\"{0}\">",
+            new Object[]{ decl.getName() }));
+        indent++;
+
+        // TODO: wildcard
+
+        itr = decl.iterateAttGroups();
+        while(itr.hasNext())
+            dumpRef( (XSAttGroupDecl)itr.next() );
+
+        itr = decl.iterateDeclaredAttributeUses();
+        while(itr.hasNext())
+            attributeUse( (XSAttributeUse)itr.next() );
+
+        indent--;
+        println("</attGroup>");
+    }
+
+    public void dumpRef( XSAttGroupDecl decl ) {
+        println(MessageFormat.format("<attGroup ref=\"'{'{0}'}'{1}\"/>",
+            new Object[]{ decl.getTargetNamespace(), decl.getName() }));
+    }
+
+    public void attributeUse( XSAttributeUse use ) {
+        XSAttributeDecl decl = use.getDecl();
+
+        String additionalAtts="";
+
+        if(use.isRequired())
+            additionalAtts += " use=\"required\"";
+        if(use.getFixedValue()!=null && use.getDecl().getFixedValue()==null)
+            additionalAtts += " fixed=\""+use.getFixedValue()+'\"';
+        if(use.getDefaultValue()!=null && use.getDecl().getDefaultValue()==null)
+            additionalAtts += " default=\""+use.getDefaultValue()+'\"';
+
+        if(decl.isLocal()) {
+            // this is anonymous attribute use
+            dump(decl,additionalAtts);
+        } else {
+            // reference to a global one
+            println(MessageFormat.format("<attribute ref=\"'{'{0}'}'{1}{2}\"/>",
+                new Object[]{ decl.getTargetNamespace(), decl.getName(),
+                    additionalAtts }));
+        }
+    }
+
+    public void attributeDecl( XSAttributeDecl decl ) {
+        dump(decl,"");
+    }
+
+    private void dump( XSAttributeDecl decl, String additionalAtts ) {
+        XSSimpleType type=decl.getType();
+
+        println(MessageFormat.format("<attribute name=\"{0}\"{1}{2}{3}{4}{5}>",
+            new Object[]{
+                decl.getName(),
+                additionalAtts,
+                type.isLocal()?"":
+                MessageFormat.format(" type=\"'{'{0}'}'{1}\"",
+                new Object[]{
+                    type.getTargetNamespace(),
+                    type.getName()
+                }),
+                decl.getFixedValue()==null ?
+                    "":" fixed=\""+decl.getFixedValue()+'\"',
+                decl.getDefaultValue()==null ?
+                    "":" default=\""+decl.getDefaultValue()+'\"',
+                type.isLocal()?"":" /"
+            }));
+
+        if(type.isLocal()) {
+            indent++;
+            simpleType(type);
+            indent--;
+            println("</attribute>");
+        }
+    }
+
+    public void simpleType( XSSimpleType type ) {
+        println(MessageFormat.format("<simpleType{0}>",
+            new Object[]{
+                type.isLocal()?"":" name=\""+type.getName()+'\"'
+            }));
+        indent++;
+
+        type.visit((XSSimpleTypeVisitor)this);
+
+        indent--;
+        println("</simpleType>");
+    }
+
+    public void listSimpleType( XSListSimpleType type ) {
+        XSSimpleType itemType = type.getItemType();
+
+        if(itemType.isLocal()) {
+            println("<list>");
+            indent++;
+            simpleType(itemType);
+            indent--;
+            println("</list>");
+        } else {
+            // global type
+            println(MessageFormat.format("<list itemType=\"'{'{0}'}'{1}\" />",
+                new Object[]{
+                    itemType.getTargetNamespace(),
+                    itemType.getName()
+                }));
+        }
+    }
+
+    public void unionSimpleType( XSUnionSimpleType type ) {
+        final int len = type.getMemberSize();
+        StringBuffer ref = new StringBuffer();
+
+        for( int i=0; i<len; i++ ) {
+            XSSimpleType member = type.getMember(i);
+            if(member.isGlobal())
+                ref.append(MessageFormat.format(" '{'{0}'}'{1}",
+                    new Object[]{member.getTargetNamespace(),member.getName()}));
+        }
+
+        if(ref.length()==0)
+            println("<union>");
+        else
+            println("<union memberTypes=\""+ref+"\">");
+        indent++;
+
+        for( int i=0; i<len; i++ ) {
+            XSSimpleType member = type.getMember(i);
+            if(member.isLocal())
+                simpleType(member);
+        }
+        indent--;
+        println("</union>");
+    }
+
+    public void restrictionSimpleType( XSRestrictionSimpleType type ) {
+
+        if(type.getBaseType()==null) {
+            // don't print anySimpleType
+            if(!type.getName().equals("anySimpleType"))
+                throw new InternalError();
+            if(!Const.schemaNamespace.equals(type.getTargetNamespace()))
+                throw new InternalError();
+            return;
+        }
+
+        XSSimpleType baseType = type.getSimpleBaseType();
+
+        println(MessageFormat.format("<restriction{0}>",
+            new Object[]{
+                baseType.isLocal()?"":" base=\"{"+
+                baseType.getTargetNamespace()+'}'+
+                baseType.getName()+'\"'
+            }));
+        indent++;
+
+        if(baseType.isLocal())
+            simpleType(baseType);
+
+        Iterator itr = type.iterateDeclaredFacets();
+        while(itr.hasNext())
+            facet( (XSFacet)itr.next() );
+
+        indent--;
+        println("</restriction>");
+    }
+
+    public void facet( XSFacet facet ) {
+        println(MessageFormat.format("<{0} value=\"{1}\"/>",
+            new Object[]{
+                facet.getName(), facet.getValue(),
+            }));
+    }
+
+    public void notation( XSNotation notation ) {
+        println(MessageFormat.format("<notation name='\"0}\" public =\"{1}\" system=\"{2}\" />",
+            new Object[] {
+                notation.getName(),
+                notation.getPublicId(),
+                notation.getSystemId() } ));
+    }
+
+
+
+    public void complexType( XSComplexType type ) {
+        println(MessageFormat.format("<complexType{0}>",
+            new Object[]{
+                type.isLocal()?"":" name=\""+type.getName()+'\"'
+            }));
+        indent++;
+
+        // TODO: wildcard
+
+        if(type.getContentType().asSimpleType()!=null) {
+            // simple content
+            println("<simpleContent>");
+            indent++;
+
+            XSType baseType = type.getBaseType();
+
+            if(type.getDerivationMethod()==XSType.RESTRICTION) {
+                // restriction
+                println(MessageFormat.format("<restriction base=\"<{0}>{1}\">",
+                    new Object[]{
+                        baseType.getTargetNamespace(),
+                        baseType.getName() }));
+                indent++;
+
+                dumpComplexTypeAttribute(type);
+
+                indent--;
+                println("</restriction>");
+            } else {
+                // extension
+                println(MessageFormat.format("<extension base=\"<{0}>{1}\">",
+                    new Object[]{
+                        baseType.getTargetNamespace(),
+                        baseType.getName() }));
+
+                // check if have redefine tag - Kirill
+                if( type.isGlobal()
+                && type.getTargetNamespace().equals(baseType.getTargetNamespace())
+                && type.getName().equals(baseType.getName())) {
+                    indent++;
+                    println("<redefine>");
+                    indent++;
+                    baseType.visit(this);
+                    indent--;
+                    println("</redefine>");
+                    indent--;
+                }
+
+                indent++;
+
+                dumpComplexTypeAttribute(type);
+
+                indent--;
+                println("</extension>");
+            }
+
+            indent--;
+            println("</simpleContent>");
+        } else {
+            // complex content
+            println("<complexContent>");
+            indent++;
+
+            XSComplexType baseType = type.getBaseType().asComplexType();
+
+            if(type.getDerivationMethod()==XSType.RESTRICTION) {
+                // restriction
+                println(MessageFormat.format("<restriction base=\"'{'{0}'}'{1}\">",
+                    new Object[]{
+                        baseType.getTargetNamespace(),
+                        baseType.getName() }));
+                indent++;
+
+                type.getContentType().visit(this);
+                dumpComplexTypeAttribute(type);
+
+                indent--;
+                println("</restriction>");
+            } else {
+                // extension
+                println(MessageFormat.format("<extension base=\"'{'{0}'}'{1}\">",
+                    new Object[]{
+                        baseType.getTargetNamespace(),
+                        baseType.getName() }));
+
+                // check if have redefine - Kirill
+                if( type.isGlobal()
+                && type.getTargetNamespace().equals(baseType.getTargetNamespace())
+                && type.getName().equals(baseType.getName())) {
+                    indent++;
+                    println("<redefine>");
+                    indent++;
+                    baseType.visit(this);
+                    indent--;
+                    println("</redefine>");
+                    indent--;
+                }
+
+                indent++;
+
+                type.getExplicitContent().visit(this);
+                dumpComplexTypeAttribute(type);
+
+                indent--;
+                println("</extension>");
+            }
+
+            indent--;
+            println("</complexContent>");
+        }
+
+        indent--;
+        println("</complexType>");
+    }
+
+    private void dumpComplexTypeAttribute( XSComplexType type ) {
+        Iterator itr;
+
+        itr = type.iterateAttGroups();
+        while(itr.hasNext())
+            dumpRef( (XSAttGroupDecl)itr.next() );
+
+        itr = type.iterateDeclaredAttributeUses();
+        while(itr.hasNext())
+            attributeUse( (XSAttributeUse)itr.next() );
+    }
+
+    public void elementDecl( XSElementDecl decl ) {
+        elementDecl(decl,"");
+    }
+    private void elementDecl( XSElementDecl decl, String extraAtts ) {
+        XSType type = decl.getType();
+
+        // TODO: various other attributes
+
+        println(MessageFormat.format("<element name=\"{0}\"{1}{2}{3}>",
+            new Object[]{
+                decl.getName(),
+                type.isLocal()?"":" type=\"{"+
+                    type.getTargetNamespace()+'}'+
+                    type.getName()+'\"',
+                extraAtts,
+                type.isLocal()?"":"/"
+            }));
+
+        if(type.isLocal()) {
+            indent++;
+
+            if(type.isLocal())  type.visit(this);
+
+            indent--;
+            println("</element>");
+        }
+    }
+
+    public void modelGroupDecl( XSModelGroupDecl decl ) {
+        println(MessageFormat.format("<group name=\"{0}\">",
+            new Object[]{
+                decl.getName()
+            }));
+        indent++;
+
+        modelGroup(decl.getModelGroup());
+
+        indent--;
+        println("</group>");
+    }
+
+    public void modelGroup( XSModelGroup group ) {
+        modelGroup(group,"");
+    }
+    private void modelGroup( XSModelGroup group, String extraAtts ) {
+        println(MessageFormat.format("<{0}{1}>",
+            new Object[]{ group.getCompositor(), extraAtts }));
+        indent++;
+
+        final int len = group.getSize();
+        for( int i=0; i<len; i++ )
+            particle(group.getChild(i));
+
+        indent--;
+        println(MessageFormat.format("</{0}>",
+            new Object[]{ group.getCompositor() }));
+    }
+
+    public void particle( XSParticle part ) {
+        int i;
+
+        StringBuffer buf = new StringBuffer();
+
+        i = part.getMaxOccurs();
+        if(i==XSParticle.UNBOUNDED)
+            buf.append(" maxOccurs=\"unbounded\"");
+        else if(i!=1)
+            buf.append(" maxOccurs=\""+i+'\"');
+
+        i = part.getMinOccurs();
+        if(i!=1)
+            buf.append(" minOccurs=\""+i+'\"');
+
+        final String extraAtts = buf.toString();
+
+        part.getTerm().visit(new XSTermVisitor(){
+            public void elementDecl( XSElementDecl decl ) {
+                if(decl.isLocal())
+                    SchemaWriter.this.elementDecl(decl,extraAtts);
+                else {
+                    // reference
+                    println(MessageFormat.format("<element ref=\"'{'{0}'}'{1}\"{2}/>",
+                        new Object[]{
+                            decl.getTargetNamespace(),
+                            decl.getName(),
+                            extraAtts
+                        }));
+                }
+            }
+            public void modelGroupDecl( XSModelGroupDecl decl ) {
+                // reference
+                println(MessageFormat.format("<group ref=\"'{'{0}'}'{1}\"{2}/>",
+                    new Object[]{
+                        decl.getTargetNamespace(),
+                        decl.getName(),
+                        extraAtts
+                    }));
+            }
+            public void modelGroup( XSModelGroup group ) {
+                SchemaWriter.this.modelGroup(group,extraAtts);
+            }
+            public void wildcard( XSWildcard wc ) {
+                SchemaWriter.this.wildcard(wc,extraAtts);
+            }
+        });
+    }
+
+    public void wildcard( XSWildcard wc ) {
+        wildcard(wc,"");
+    }
+
+    private void wildcard( XSWildcard wc, String extraAtts ) {
+        // TODO
+        println(MessageFormat.format("<any/>", new Object[]{extraAtts}));
+    }
+
+    public void annotation( XSAnnotation ann ) {
+        // TODO: it would be nice even if we just put <xs:documentation>
+    }
+
+    public void identityConstraint(XSIdentityConstraint decl) {
+        // TODO
+    }
+
+    public void xpath(XSXPath xp) {
+        // TODO
+    }
+
+    public void empty( XSContentType t ) {}
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/Uri.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/Uri.java
new file mode 100644
index 0000000..6c38aca
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/impl/util/Uri.java
@@ -0,0 +1,185 @@
+/*
+Copyright (c) 2001, 2002 Thai Open Source Software Center Ltd
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions are
+met:
+
+    Redistributions of source code must retain the above copyright
+    notice, this list of conditions and the following disclaimer.
+
+    Redistributions in binary form must reproduce the above copyright
+    notice, this list of conditions and the following disclaimer in
+    the documentation and/or other materials provided with the
+    distribution.
+
+    Neither the name of the Thai Open Source Software Center Ltd nor
+    the names of its contributors may be used to endorse or promote
+    products derived from this software without specific prior written
+    permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
+CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
+LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+*/
+package com.sun.xml.internal.xsom.impl.util;
+
+import java.io.IOException;
+import java.io.UnsupportedEncodingException;
+import java.net.URL;
+
+public class Uri {
+  private static String utf8 = "UTF-8";
+
+  public static boolean isValid(String s) {
+    return isValidPercent(s) && isValidFragment(s) && isValidScheme(s);
+  }
+
+  private static final String HEX_DIGITS = "0123456789abcdef";
+
+  public static String escapeDisallowedChars(String s) {
+    StringBuffer buf = null;
+    int len = s.length();
+    int done = 0;
+    for (;;) {
+      int i = done;
+      for (;;) {
+        if (i == len) {
+          if (done == 0)
+            return s;
+          break;
+        }
+        if (isExcluded(s.charAt(i)))
+          break;
+        i++;
+      }
+      if (buf == null)
+        buf = new StringBuffer();
+      if (i > done) {
+        buf.append(s.substring(done, i));
+        done = i;
+      }
+      if (i == len)
+        break;
+      for (i++; i < len && isExcluded(s.charAt(i)); i++)
+        ;
+      String tem = s.substring(done, i);
+      byte[] bytes;
+      try {
+        bytes = tem.getBytes(utf8);
+      }
+      catch (UnsupportedEncodingException e) {
+        utf8 = "UTF8";
+        try {
+          bytes = tem.getBytes(utf8);
+        }
+        catch (UnsupportedEncodingException e2) {
+          // Give up
+          return s;
+        }
+      }
+      for (int j = 0; j < bytes.length; j++) {
+        buf.append('%');
+        buf.append(HEX_DIGITS.charAt((bytes[j] & 0xFF) >> 4));
+        buf.append(HEX_DIGITS.charAt(bytes[j] & 0xF));
+      }
+      done = i;
+    }
+    return buf.toString();
+  }
+
+  private static String excluded = "<>\"{}|\\^`";
+
+  private static boolean isExcluded(char c) {
+    return c <= 0x20 || c >= 0x7F || excluded.indexOf(c) >= 0;
+  }
+
+  private static boolean isAlpha(char c) {
+    return ('a' <= c && c <= 'z') || ('A' <= c && c <= 'Z');
+  }
+
+  private static boolean isHexDigit(char c) {
+    return ('a' <= c && c <= 'f') || ('A' <= c && c <= 'F') || isDigit(c);
+  }
+
+  private static boolean isDigit(char c) {
+    return '0' <= c && c <= '9';
+  }
+
+  private static boolean isSchemeChar(char c) {
+    return isAlpha(c) || isDigit(c) || c == '+' || c == '-' || c =='.';
+  }
+
+  private static boolean isValidPercent(String s) {
+    int len = s.length();
+    for (int i = 0; i < len; i++)
+      if (s.charAt(i) == '%') {
+        if (i + 2 >= len)
+          return false;
+        else if (!isHexDigit(s.charAt(i + 1))
+             || !isHexDigit(s.charAt(i + 2)))
+          return false;
+      }
+    return true;
+  }
+
+  private static boolean isValidFragment(String s) {
+    int i = s.indexOf('#');
+    return i < 0 || s.indexOf('#', i + 1) < 0;
+  }
+
+  private static boolean isValidScheme(String s) {
+    if (!isAbsolute(s))
+      return true;
+    int i = s.indexOf(':');
+    if (i == 0
+    || i + 1 == s.length()
+    || !isAlpha(s.charAt(0)))
+      return false;
+    while (--i > 0)
+      if (!isSchemeChar(s.charAt(i)))
+    return false;
+    return true;
+  }
+
+    public static String resolve(String baseUri, String uriReference) throws IOException {
+        if (isAbsolute(uriReference))
+            return uriReference;
+
+        if(baseUri==null)
+            throw new IOException("Unable to resolve relative URI "+uriReference+" without a base URI");
+
+        if(!isAbsolute(baseUri))
+            throw new IOException("Unable to resolve relative URI "+uriReference+" because base URI is not absolute: "+baseUri);
+
+        return new URL(new URL(baseUri), uriReference).toString();
+    }
+
+    public static boolean hasFragmentId(String uri) {
+    return uri.indexOf('#') >= 0;
+  }
+
+  public static boolean isAbsolute(String uri) {
+    int i = uri.indexOf(':');
+    if (i < 0)
+      return false;
+    while (--i >= 0) {
+      switch (uri.charAt(i)) {
+      case '#':
+      case '/':
+      case '?':
+    return false;
+      }
+    }
+    return true;
+  }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/package.html b/jaxws/src/share/classes/com/sun/xml/internal/xsom/package.html
new file mode 100644
index 0000000..0338a6b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/package.html
@@ -0,0 +1,3 @@
+<html><body>
+Interfaces that the client should use to access schema information.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationContext.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationContext.java
new file mode 100644
index 0000000..3109b35
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationContext.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.parser;
+
+/**
+ * Enumeration used to represent the type of the schema component
+ * that is being parsed when the AnnotationParser is called.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+final public class AnnotationContext {
+
+    /** Display name of the context. */
+    private final String name;
+
+    private AnnotationContext( String _name ) {
+        this.name = _name;
+    }
+
+    public String toString() { return name; }
+
+
+
+    public static final AnnotationContext SCHEMA
+        = new AnnotationContext("schema");
+    public static final AnnotationContext NOTATION
+        = new AnnotationContext("notation");
+    public static final AnnotationContext ELEMENT_DECL
+        = new AnnotationContext("element");
+    public static final AnnotationContext IDENTITY_CONSTRAINT
+        = new AnnotationContext("identityConstraint");
+    public static final AnnotationContext XPATH
+        = new AnnotationContext("xpath");
+    public static final AnnotationContext MODELGROUP_DECL
+        = new AnnotationContext("modelGroupDecl");
+    public static final AnnotationContext SIMPLETYPE_DECL
+        = new AnnotationContext("simpleTypeDecl");
+    public static final AnnotationContext COMPLEXTYPE_DECL
+        = new AnnotationContext("complexTypeDecl");
+    public static final AnnotationContext PARTICLE
+        = new AnnotationContext("particle");
+    public static final AnnotationContext MODELGROUP
+        = new AnnotationContext("modelGroup");
+    public static final AnnotationContext ATTRIBUTE_USE
+        = new AnnotationContext("attributeUse");
+    public static final AnnotationContext WILDCARD
+        = new AnnotationContext("wildcard");
+    public static final AnnotationContext ATTRIBUTE_GROUP
+        = new AnnotationContext("attributeGroup");
+    public static final AnnotationContext ATTRIBUTE_DECL
+        = new AnnotationContext("attributeDecl");
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationParser.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationParser.java
new file mode 100644
index 0000000..4f75219
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationParser.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.parser;
+
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+
+/**
+ * Used to parse &lt;xs:annotation>.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class AnnotationParser {
+    /**
+     * Called every time a new &lt;xs:annotation> element
+     * is found.
+     *
+     * The sub-tree rooted at &lt;xs:annotation> will be
+     * sent to this ContentHandler as if it is a whole document.
+     *
+     * @param context
+     *      indicates the schema component that owns this annotation.
+     *      Always non-null.
+     * @param parentElementName
+     *      local name of the element that contains &lt;xs:annotation>.
+     *      (e.g., "element", "attribute", ... )
+     * @param errorHandler
+     *      The error handler that the client application specifies.
+     *      The returned content handler can send its errors to this
+     *      object.
+     * @param entityResolver
+     *      The entity resolver that is currently in use. Again,
+     *      The returned content handler can use this object
+     *      if it needs to resolve entities.
+     */
+    public abstract ContentHandler getContentHandler(
+        AnnotationContext context,
+        String parentElementName,
+        ErrorHandler errorHandler,
+        EntityResolver entityResolver );
+
+    /**
+     * Once the SAX events are fed to the ContentHandler,
+     * this method will be called to retrieve the parsed result.
+     *
+     * @param existing
+     *      An annotation object which was returned from another
+     *      AnnotationParser before. Sometimes, one schema component
+     *      can have multiple &lt:xs:annotation> elements and
+     *      this parameter is used to merge all those annotations
+     *      together. If there is no existing object, null will be
+     *      passed.
+     * @return
+     *      Any object, including null.
+     */
+    public abstract Object getResult( Object existing );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationParserFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationParserFactory.java
new file mode 100644
index 0000000..a44b681
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/AnnotationParserFactory.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.parser;
+
+/**
+ * Factory for {@link AnnotationParser}.
+ *
+ * @author Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface AnnotationParserFactory {
+    AnnotationParser create();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/JAXPParser.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/JAXPParser.java
new file mode 100644
index 0000000..9558220
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/JAXPParser.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.parser;
+
+import java.io.IOException;
+import java.net.URL;
+
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.parsers.SAXParserFactory;
+
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+import com.sun.xml.internal.xsom.impl.parser.Messages;
+
+/**
+ * Standard XMLParser implemented by using JAXP.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JAXPParser implements XMLParser {
+
+    private final SAXParserFactory factory;
+
+    public JAXPParser( SAXParserFactory factory ) {
+        factory.setNamespaceAware(true);    // just in case
+        this.factory = factory;
+    }
+
+    public JAXPParser() {
+        this( SAXParserFactory.newInstance());
+    }
+
+
+
+
+
+
+
+    public void parse( InputSource source, ContentHandler handler,
+        ErrorHandler errorHandler, EntityResolver entityResolver )
+
+        throws SAXException, IOException {
+
+        try {
+            XMLReader reader = factory.newSAXParser().getXMLReader();
+            reader = new XMLReaderEx(reader);
+
+            reader.setContentHandler(handler);
+            if(errorHandler!=null)
+                reader.setErrorHandler(errorHandler);
+            if(entityResolver!=null)
+                reader.setEntityResolver(entityResolver);
+            reader.parse(source);
+        } catch( ParserConfigurationException e ) {
+            // in practice this won't happen
+            SAXParseException spe = new SAXParseException(e.getMessage(),null,e);
+            errorHandler.fatalError(spe);
+            throw spe;
+        }
+    }
+
+
+
+    /**
+     * XMLReader with improved error message for entity resolution failure.
+     *
+     * TODO: this class is completely stand-alone, so it shouldn't be
+     * an inner class.
+     */
+    private static class XMLReaderEx extends XMLFilterImpl {
+
+        private Locator locator;
+
+        XMLReaderEx( XMLReader parent ) {
+            this.setParent(parent);
+        }
+
+        /**
+         * Resolves entities and reports user-friendly error messages.
+         *
+         * <p>
+         * Some XML parser (at least Xerces) does not report much information
+         * when it fails to resolve an entity, which is often quite
+         * frustrating. For example, if you are behind a firewall and the
+         * schema contains a reference to www.w3.org, and there is no
+         * entity resolver, the parser will just throw an IOException
+         * that doesn't contain any information about where that reference
+         * occurs nor what it is accessing.
+         *
+         * <p>
+         * By implementing an EntityResolver and resolving the reference
+         * by ourselves, we can report an error message with all the
+         * necessary information to fix the problem.
+         *
+         * <p>
+         * Note that we still need to the client-specified entity resolver
+         * to let the application handle entity resolution. Here we just catch
+         * an IOException and add more information.
+         */
+        public InputSource resolveEntity(String publicId, String systemId) throws SAXException {
+            try {
+                InputSource is=null;
+
+                // ask the client-specified entity resolver first
+                if( this.getEntityResolver()!=null)
+                    is = this.getEntityResolver().resolveEntity(publicId,systemId);
+                if( is!=null )  return is;  // if that succeeds, fine.
+
+                // rather than returning null, resolve it now
+                // so that we can detect errors.
+                is = new InputSource( new URL(systemId).openStream() );
+                is.setSystemId(systemId);
+                is.setPublicId(publicId);
+                return is;
+            } catch( IOException e ) {
+                // catch this error and provide a nice error message, rather than
+                // just throwing this IOException.
+                SAXParseException spe = new SAXParseException(
+                    Messages.format(Messages.ERR_ENTITY_RESOLUTION_FAILURE,
+                        systemId, e.toString()),    // use the toString method to get the class name
+                    locator, e );
+                if(this.getErrorHandler()!=null)
+                    this.getErrorHandler().fatalError(spe);
+                throw spe;
+            }
+        }
+
+        public void setDocumentLocator(Locator locator) {
+            super.setDocumentLocator(locator);
+            this.locator = locator;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/SchemaDocument.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/SchemaDocument.java
new file mode 100644
index 0000000..cae1aea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/SchemaDocument.java
@@ -0,0 +1,142 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.parser;
+
+import com.sun.xml.internal.xsom.XSSchema;
+
+import java.util.Set;
+
+/**
+ * Represents a parsed XML schema document.
+ *
+ * <p>
+ * Unlike schema components defined in <tt>XS****</tt> interfaces,
+ * which are inherently de-coupled from where it was loaded from,
+ * {@link SchemaDocument} represents a single XML infoset that
+ * is a schema document.
+ *
+ * <p>
+ * This concept is often useful in tracking down the reference
+ * relationship among schema documents.
+ *
+ * @see XSOMParser#getDocuments()
+ * @author Kohsuke Kawaguchi
+ */
+public interface SchemaDocument {
+    /**
+     * Gets the system ID of the schema document.
+     *
+     * @return
+     *      null if {@link XSOMParser} was not given the system Id.
+     */
+    String getSystemId();
+
+    /**
+     * The namespace that this schema defines.
+     *
+     * <p>
+     * More precisely, this method simply returns the <tt>targetNamespace</tt> attribute
+     * of the schema document. When schemas are referenced in certain ways
+     * (AKA chameleon schema), schema components in this schema document
+     * may end up defining components in other namespaces.
+     *
+     * @return
+     *      can be "" but never null.
+     */
+    String getTargetNamespace();
+
+    /**
+     * Gets {@link XSSchema} component that contains all the schema
+     * components defined in this namespace.
+     *
+     * <p>
+     * The returned {@link XSSchema} contains not just components
+     * defined in this {@link SchemaDocument} but all the other components
+     * defined in all the schemas that collectively define this namespace.
+     *
+     * @return
+     *      never null.
+     */
+    XSSchema getSchema();
+
+    /**
+     * Set of {@link SchemaDocument}s that are included/imported from this document.
+     *
+     * @return
+     *      can be empty but never null. read-only.
+     */
+    Set<SchemaDocument> getReferencedDocuments();
+
+    /**
+     * Gets the {@link SchemaDocument}s that are included from this document.
+     *
+     * @return
+     *      can be empty but never null. read-only.
+     *      this set is always a subset of {@link #getReferencedDocuments()}.
+     */
+    Set<SchemaDocument> getIncludedDocuments();
+
+    /**
+     * Gets the {@link SchemaDocument}s that are imported from this document.
+     *
+     * @param targetNamespace
+     *      The namespace URI of the import that you want to
+     *      get {@link SchemaDocument}s for.
+     * @return
+     *      can be empty but never null. read-only.
+     *      this set is always a subset of {@link #getReferencedDocuments()}.
+     */
+    Set<SchemaDocument> getImportedDocuments(String targetNamespace);
+
+    /**
+     * Returns true if this document includes the given document.
+     *
+     * <p>
+     * Note that this method returns false if this document
+     * imports the given document.
+     */
+    boolean includes(SchemaDocument doc);
+
+    /**
+     * Returns true if this document imports the given document.
+     *
+     * <p>
+     * Note that this method returns false if this document
+     * includes the given document.
+     */
+    boolean imports(SchemaDocument doc);
+
+    /**
+     * Set of {@link SchemaDocument}s that include/import this document.
+     *
+     * <p>
+     * This works as the opposite of {@link #getReferencedDocuments()}.
+     *
+     * @return
+     *      can be empty but never null. read-only.
+     */
+    Set<SchemaDocument> getReferers();
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/XMLParser.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/XMLParser.java
new file mode 100644
index 0000000..199778d
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/XMLParser.java
@@ -0,0 +1,67 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.parser;
+
+import java.io.IOException;
+
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+/**
+ * Interface that hides the detail of parsing mechanism.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XMLParser {
+    /**
+     * Parses the document identified by the given input source
+     * and sends SAX events to the given content handler.
+     *
+     * <p>
+     * This method must be re-entrant.
+     *
+     * @param errorHandler
+     *      Errors found during the parsing must be reported to
+     *      this handler so that XSOM can recognize that something went wrong.
+     *      Always a non-null valid object
+     * @param entityResolver
+     *      Entity resolution should be done through this interface.
+     *      Can be null.
+     *
+     * @exception SAXException
+     *      If ErrorHandler throws a SAXException, this method
+     *      will tunnel it to the caller. All the other errors
+     *      must be reported to the error handler.
+     */
+    void parse( InputSource source, ContentHandler handler,
+        ErrorHandler errorHandler, EntityResolver entityResolver )
+
+        throws SAXException, IOException;
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/XSOMParser.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/XSOMParser.java
new file mode 100644
index 0000000..ace1cea
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/XSOMParser.java
@@ -0,0 +1,268 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.parser;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.Reader;
+import java.net.URL;
+import java.util.Set;
+import java.util.HashSet;
+
+import javax.xml.parsers.SAXParserFactory;
+
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+import com.sun.xml.internal.xsom.XSSchemaSet;
+import com.sun.xml.internal.xsom.impl.parser.NGCCRuntimeEx;
+import com.sun.xml.internal.xsom.impl.parser.ParserContext;
+import com.sun.xml.internal.xsom.impl.parser.state.Schema;
+
+/**
+ * Parses possibly multiple W3C XML Schema files and compose
+ * them into one grammar.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public final class XSOMParser {
+
+    private EntityResolver entityResolver;
+    private ErrorHandler userErrorHandler;
+
+    private AnnotationParserFactory apFactory;
+
+    private final ParserContext context;
+
+    /**
+    * Creates a new XSOMParser by using a SAX parser from JAXP.
+    */
+   public XSOMParser() {
+       this(new JAXPParser());
+   }
+
+   /**
+    * Creates a new XSOMParser that uses the given SAXParserFactory
+    * for creating new SAX parsers.
+    *
+    * The caller needs to configure
+    * it properly. Don't forget to call <code>setNamespaceAware(true)</code>
+    * or you'll see some strange errors.
+    */
+   public XSOMParser( SAXParserFactory factory ) {
+       this( new JAXPParser(factory) );
+   }
+
+   /**
+    * Creates a new XSOMParser that reads XML Schema from non-standard
+    * inputs.
+    *
+    * By implementing the {@link XMLParser} interface, XML Schema
+    * can be read from something other than XML.
+    *
+    * @param   parser
+    *      This parser will be called to parse XML Schema documents.
+    */
+    public XSOMParser(XMLParser parser) {
+        context = new ParserContext(this,parser);
+    }
+
+    /**
+     * Parses a new XML Schema document.
+     *
+     * <p>
+     * When using this method, XSOM does not know the system ID of
+     * this document, therefore, when this stream contains relative
+     * references to other schemas, XSOM will fail to resolve them.
+     * To specify an system ID with a stream, use {@link InputSource}
+     */
+    public void parse( InputStream is ) throws SAXException {
+        parse(new InputSource(is));
+    }
+
+    /**
+     * Parses a new XML Schema document.
+     *
+     * <p>
+     * When using this method, XSOM does not know the system ID of
+     * this document, therefore, when this reader contains relative
+     * references to other schemas, XSOM will fail to resolve them.
+     * To specify an system ID with a reader, use {@link InputSource}
+     */
+    public void parse( Reader reader ) throws SAXException {
+        parse(new InputSource(reader));
+    }
+
+    /**
+     * Parses a new XML Schema document.
+     */
+    public void parse( File schema ) throws SAXException, IOException {
+        parse(schema.toURL());
+    }
+
+    /**
+     * Parses a new XML Schema document.
+     */
+    public void parse( URL url ) throws SAXException {
+        parse( url.toExternalForm() );
+    }
+
+    /**
+     * Parses a new XML Schema document.
+     */
+    public void parse( String systemId ) throws SAXException {
+        parse(new InputSource(systemId));
+    }
+
+    /**
+     * Parses a new XML Schema document.
+     *
+     * <p>
+     * Note that if the {@link InputSource} does not have a system ID,
+     * XSOM will fail to resolve them.
+     */
+    public void parse( InputSource source ) throws SAXException {
+        context.parse(source);
+    }
+
+
+
+    /**
+     * Gets the parser implemented as a ContentHandler.
+     *
+     * One can feed XML Schema as SAX events to this interface to
+     * parse a schema. To parse multiple schema files, feed multiple
+     * sets of events.
+     *
+     * <p>
+     * If you don't send a complete event sequence from a startDocument
+     * event to an endDocument event, the state of XSOMParser can become
+     * unstable. This sometimes happen when you encounter an error while
+     * generating SAX events. Don't call the getResult method in that case.
+     *
+     * <p>
+     * This way of reading XML Schema can be useful when XML Schema is
+     * not available as a stand-alone XML document.
+     * For example, one can feed XML Schema inside a WSDL document.
+     */
+    public ContentHandler getParserHandler() {
+        NGCCRuntimeEx runtime = context.newNGCCRuntime();
+        Schema s = new Schema(runtime,false,null);
+        runtime.setRootHandler(s);
+        return runtime;
+    }
+
+    /**
+     * Gets the parsed result. Don't call this method until
+     * you parse all the schemas.
+     *
+     * @return
+     *      If there was any parse error, this method returns null.
+     *      To receive error information, specify your error handler
+     *      through the setErrorHandler method.
+     * @exception SAXException
+     *      This exception will never be thrown unless it is thrown
+     *      by an error handler.
+     */
+    public XSSchemaSet getResult() throws SAXException {
+        return context.getResult();
+    }
+
+    /**
+     * Gets the set of {@link SchemaDocument} that represents
+     * parsed documents so far.
+     *
+     * @return
+     *      can be empty but never null.
+     */
+    public Set<SchemaDocument> getDocuments() {
+        return new HashSet<SchemaDocument>(context.parsedDocuments.keySet());
+    }
+
+    public EntityResolver getEntityResolver() {
+        return entityResolver;
+    }
+    /**
+     * Set an entity resolver that is used to resolve things
+     * like &lt;xsd:import> and &lt;xsd:include>.
+     */
+    public void setEntityResolver( EntityResolver resolver ) {
+        this.entityResolver = resolver;
+    }
+    public ErrorHandler getErrorHandler() {
+        return userErrorHandler;
+    }
+    /**
+     * Set an error handler that receives all the errors encountered
+     * during the parsing.
+     */
+    public void setErrorHandler(ErrorHandler errorHandler) {
+        this.userErrorHandler = errorHandler;
+    }
+
+    /**
+     * Sets the annotation parser.
+     *
+     * Annotation parser can be used to parse application-specific
+     * annotations inside a schema.
+     *
+     * <p>
+     * For each annotation, new instance of this class will be
+     * created and used to parse &lt;xs:annotation>.
+     */
+    public void setAnnotationParser( final Class annParser ) {
+        setAnnotationParser( new AnnotationParserFactory() {
+            public AnnotationParser create() {
+                try {
+                    return (AnnotationParser)annParser.newInstance();
+                } catch( InstantiationException e ) {
+                    throw new InstantiationError(e.getMessage());
+                } catch( IllegalAccessException e ) {
+                    throw new IllegalAccessError(e.getMessage());
+                }
+            }
+        });
+    }
+
+    /**
+     * Sets the annotation parser factory.
+     *
+     * <p>
+     * The specified factory will be used to create AnnotationParsers.
+     */
+    public void setAnnotationParser( AnnotationParserFactory factory ) {
+        this.apFactory = factory;
+    }
+
+    public AnnotationParserFactory getAnnotationParserFactory() {
+        return apFactory;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/package.html b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/package.html
new file mode 100644
index 0000000..eccdc7f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/parser/package.html
@@ -0,0 +1,3 @@
+<html><body>
+Classes to parse XML Schema documents into objects of <code>com.sun.xml.xsom</code> package.
+</body></html>
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/ComponentNameFunction.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/ComponentNameFunction.java
new file mode 100644
index 0000000..9c42e22
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/ComponentNameFunction.java
@@ -0,0 +1,191 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.util;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+
+/**
+ * Extract the name of the components.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ */
+public class ComponentNameFunction implements XSFunction<String> {
+
+    // delegate to this object to get the localized name of the component type
+    private NameGetter nameGetter = new NameGetter(null);
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#annotation(XSAnnotation)
+     */
+    public String annotation(XSAnnotation ann) {
+        // unnamed component
+        return nameGetter.annotation( ann );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#attGroupDecl(XSAttGroupDecl)
+     */
+    public String attGroupDecl(XSAttGroupDecl decl) {
+        String name = decl.getName();
+        if( name == null ) name = "";
+        return name + " " + nameGetter.attGroupDecl( decl );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#attributeDecl(XSAttributeDecl)
+     */
+    public String attributeDecl(XSAttributeDecl decl) {
+        String name = decl.getName();
+        if( name == null ) name = "";
+        return name + " " + nameGetter.attributeDecl( decl );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#attributeUse(XSAttributeUse)
+     */
+    public String attributeUse(XSAttributeUse use) {
+        // unnamed component
+        return nameGetter.attributeUse( use );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#complexType(XSComplexType)
+     */
+    public String complexType(XSComplexType type) {
+        String name = type.getName();
+        if( name == null ) name = "anonymous";
+        return name + " " + nameGetter.complexType( type );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#schema(XSSchema)
+     */
+    public String schema(XSSchema schema) {
+        return nameGetter.schema( schema ) + " \"" + schema.getTargetNamespace()+"\"";
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#facet(XSFacet)
+     */
+    public String facet(XSFacet facet) {
+        String name = facet.getName();
+        if( name == null ) name = "";
+        return name + " " + nameGetter.facet( facet );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#notation(XSNotation)
+     */
+    public String notation(XSNotation notation) {
+        String name = notation.getName();
+        if( name == null ) name = "";
+        return name + " " + nameGetter.notation( notation );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeFunction#simpleType(XSSimpleType)
+     */
+    public String simpleType(XSSimpleType simpleType) {
+        String name = simpleType.getName();
+        if( name == null ) name = "anonymous";
+        return name + " " + nameGetter.simpleType( simpleType );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeFunction#particle(XSParticle)
+     */
+    public String particle(XSParticle particle) {
+        // unnamed component
+        return nameGetter.particle( particle );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeFunction#empty(XSContentType)
+     */
+    public String empty(XSContentType empty) {
+        // unnamed component
+        return nameGetter.empty( empty );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSTermFunction#wildcard(XSWildcard)
+     */
+    public String wildcard(XSWildcard wc) {
+        // unnamed component
+        return nameGetter.wildcard( wc );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSTermFunction#modelGroupDecl(XSModelGroupDecl)
+     */
+    public String modelGroupDecl(XSModelGroupDecl decl) {
+        String name = decl.getName();
+        if( name == null ) name = "";
+        return name + " " + nameGetter.modelGroupDecl( decl );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSTermFunction#modelGroup(XSModelGroup)
+     */
+    public String modelGroup(XSModelGroup group) {
+        // unnamed component
+        return nameGetter.modelGroup( group );
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSTermFunction#elementDecl(XSElementDecl)
+     */
+    public String elementDecl(XSElementDecl decl) {
+        String name = decl.getName();
+        if( name == null ) name = "";
+        return name + " " + nameGetter.elementDecl( decl );
+    }
+
+    public String identityConstraint(XSIdentityConstraint decl) {
+        return decl.getName()+" "+nameGetter.identityConstraint(decl);
+    }
+
+    public String xpath(XSXPath xpath) {
+        return nameGetter.xpath(xpath);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/DomAnnotationParserFactory.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/DomAnnotationParserFactory.java
new file mode 100644
index 0000000..665a125
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/DomAnnotationParserFactory.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.util;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.parser.AnnotationContext;
+import com.sun.xml.internal.xsom.parser.AnnotationParser;
+import com.sun.xml.internal.xsom.parser.AnnotationParserFactory;
+import org.w3c.dom.Element;
+import org.w3c.dom.Document;
+import org.w3c.dom.Node;
+import org.xml.sax.ContentHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+
+import javax.xml.transform.sax.SAXTransformerFactory;
+import javax.xml.transform.sax.TransformerHandler;
+import javax.xml.transform.TransformerConfigurationException;
+import javax.xml.transform.dom.DOMResult;
+
+/**
+ * {@link AnnotationParserFactory} that parses annotations into a W3C DOM.
+ *
+ * <p>
+ * If you use this parser factory, you'll get {@link Element} that represents
+ * &lt;xs:annotation> from {@link XSAnnotation#getAnnotation()}.
+ *
+ * <p>
+ * When multiple &lt;xs:annotation>s are found for the given schema component,
+ * you'll see all &lt;xs:appinfo>s and &lt;xs:documentation>s combined under
+ * one &lt;xs:annotation> element.
+ *
+ * @author Kohsuke Kawaguchi
+ */
+public class DomAnnotationParserFactory implements AnnotationParserFactory {
+    public AnnotationParser create() {
+        return new AnnotationParserImpl();
+    }
+
+    private static final SAXTransformerFactory stf = (SAXTransformerFactory) SAXTransformerFactory.newInstance();
+
+    private static class AnnotationParserImpl extends AnnotationParser {
+
+        /**
+         * Identity transformer used to parse SAX into DOM.
+         */
+        private final TransformerHandler transformer;
+        private DOMResult result;
+
+        AnnotationParserImpl() {
+            try {
+                transformer = stf.newTransformerHandler();
+            } catch (TransformerConfigurationException e) {
+                throw new Error(e); // impossible
+            }
+        }
+
+        public ContentHandler getContentHandler(AnnotationContext context, String parentElementName, ErrorHandler errorHandler, EntityResolver entityResolver) {
+            result = new DOMResult();
+            transformer.setResult(result);
+            return transformer;
+        }
+
+        public Object getResult(Object existing) {
+            Document dom = (Document)result.getNode();
+            Element e = dom.getDocumentElement();
+            if(existing instanceof Element) {
+                // merge all the children
+                Element prev = (Element) existing;
+                Node anchor = e.getFirstChild();
+                while(prev.getFirstChild()!=null)
+                    e.insertBefore(prev.getFirstChild(), anchor );
+            }
+            return e;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/NameGetter.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/NameGetter.java
new file mode 100644
index 0000000..2c506bd
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/NameGetter.java
@@ -0,0 +1,164 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.util;
+
+import java.util.Locale;
+import java.util.ResourceBundle;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+
+/**
+ * Gets the human-readable name of a schema component.
+ *
+ * <p>
+ * This is a function object that returns {@link String}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class NameGetter implements XSFunction<String> {
+    /**
+     * Initializes a NameGetter so that it will return
+     * messages in the specified locale.
+     */
+    public NameGetter( Locale _locale ) {
+        this.locale = _locale;
+    }
+
+    private final Locale locale;
+
+    /**
+     * An instance that gets names in the default locale.
+     * This instance is provided just for convenience.
+     */
+    public final static XSFunction theInstance = new NameGetter(null);
+
+    /**
+     * Gets the name of the specified component in the default locale.
+     * This method is just a wrapper.
+     */
+    public static String get( XSComponent comp ) {
+        return (String)comp.apply(theInstance);
+    }
+
+
+    public String annotation(XSAnnotation ann) {
+        return localize("annotation");
+    }
+
+    public String attGroupDecl(XSAttGroupDecl decl) {
+        return localize("attGroupDecl");
+    }
+
+    public String attributeUse(XSAttributeUse use) {
+        return localize("attributeUse");
+    }
+
+    public String attributeDecl(XSAttributeDecl decl) {
+        return localize("attributeDecl");
+    }
+
+    public String complexType(XSComplexType type) {
+        return localize("complexType");
+    }
+
+    public String schema(XSSchema schema) {
+        return localize("schema");
+    }
+
+    public String facet(XSFacet facet) {
+        return localize("facet");
+    }
+
+    public String simpleType(XSSimpleType simpleType) {
+        return localize("simpleType");
+    }
+
+    public String particle(XSParticle particle) {
+        return localize("particle");
+    }
+
+    public String empty(XSContentType empty) {
+        return localize("empty");
+    }
+
+    public String wildcard(XSWildcard wc) {
+        return localize("wildcard");
+    }
+
+    public String modelGroupDecl(XSModelGroupDecl decl) {
+        return localize("modelGroupDecl");
+    }
+
+    public String modelGroup(XSModelGroup group) {
+         return localize("modelGroup");
+    }
+
+    public String elementDecl(XSElementDecl decl) {
+        return localize("elementDecl");
+    }
+
+    public String notation( XSNotation n ) {
+        return localize("notation");
+    }
+
+    public String identityConstraint(XSIdentityConstraint decl) {
+        return localize("idConstraint");
+    }
+
+    public String xpath(XSXPath xpath) {
+        return localize("xpath");
+    }
+
+    private String localize( String key ) {
+        ResourceBundle rb;
+
+        if(locale==null)
+            rb = ResourceBundle.getBundle(NameGetter.class.getName());
+        else
+            rb = ResourceBundle.getBundle(NameGetter.class.getName(),locale);
+
+        return rb.getString(key);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/NameGetter.properties b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/NameGetter.properties
new file mode 100644
index 0000000..d5838c7
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/NameGetter.properties
@@ -0,0 +1,18 @@
+annotation		= annotation
+attGroupDecl	= attribute group declaration
+attributeDecl	= attribtue declaration
+attributeUse	= attribute use
+complexType		= complex type
+schema			= schema
+facet			= facet
+simpleType		= simple type
+particle		= particle
+empty			= empty content model
+wildcard		= wildcard
+modelGroupDecl	= model group declaration
+modelGroup		= model group
+elementDecl		= element declaration
+notation		= notation declaration
+idConstraint    = identity constraint
+xpath           = xpath
+ 
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/SimpleTypeSet.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/SimpleTypeSet.java
new file mode 100644
index 0000000..88c5bb0
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/SimpleTypeSet.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.util;
+
+import java.util.Set;
+
+import com.sun.xml.internal.xsom.XSType;
+
+/**
+ * A very simple TypeSet.
+ *
+ * The contains method returns true iff the set explicitly contains an
+ * instance of the specified XSType.
+ *
+ * @author <a href="mailto:Ryan.Shoemaker@Sun.COM">Ryan Shoemaker</a>, Sun Microsystems, Inc.
+ */
+public class SimpleTypeSet extends TypeSet {
+
+    private final Set typeSet;
+
+    public SimpleTypeSet(Set s) {
+        typeSet = s;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.util.TypeSet#contains(com.sun.xml.internal.xsom.XSDeclaration)
+     */
+    public boolean contains(XSType type) {
+        return typeSet.contains(type);
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/TypeClosure.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/TypeClosure.java
new file mode 100644
index 0000000..3a4cb82
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/TypeClosure.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.util;
+
+import com.sun.xml.internal.xsom.XSType;
+
+/**
+ * Perform a transitive closure operation on a type to determine if it
+ * belongs to this set.
+ *
+ * The contains method returns true iff the TypeSet contains an instance
+ * of the specified XSType or any of the base types of the XSType.
+ *
+ * @author <a href="mailto:Ryan.Shoemaker@Sun.COM">Ryan Shoemaker</a>, Sun Microsystems, Inc.
+ */
+public class TypeClosure extends TypeSet {
+
+    private final TypeSet typeSet;
+
+    public TypeClosure(TypeSet typeSet) {
+        this.typeSet = typeSet;
+    }
+
+    /* (non-Javadoc)
+     * @see com.sun.xml.internal.xsom.util.TypeSet#contains(com.sun.xml.internal.xsom.XSDeclaration)
+     *
+     * transitive closure variation on the contains method.
+     */
+    public boolean contains(XSType type) {
+        if( typeSet.contains(type) ) {
+            return true;
+        } else {
+            XSType baseType = type.getBaseType();
+            if( baseType == null ) {
+                return false;
+            } else {
+                // climb the super type hierarchy
+                return contains(baseType);
+            }
+        }
+    }
+
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/TypeSet.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/TypeSet.java
new file mode 100644
index 0000000..ea02f19
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/TypeSet.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.util;
+
+import com.sun.xml.internal.xsom.XSType;
+
+/**
+ * A simple abstraction for a set of Types that defines containment functions.
+ *
+ * @author <a href="mailto:Ryan.Shoemaker@Sun.COM">Ryan Shoemaker</a>, Sun Microsystems, Inc.
+ */
+public abstract class TypeSet {
+
+    /**
+     * Return true if this TypeSet contains the specified type.
+     *
+     * Concrete implementations of this method determine what it
+     * means for the TypeSet to "contain" a type.
+     *
+     * @param type the type
+     * @return true iff this TypeSet contains the specified type
+     */
+    public abstract boolean contains(XSType type);
+
+    /**
+     * Calculate the TypeSet formed by the intersection of two
+     * other TypeSet objects.
+     *
+     * @param a a TypeSet
+     * @param b another TypeSet
+     * @return the intersection of a and b
+     */
+    public static TypeSet intersection(final TypeSet a, final TypeSet b) {
+        return new TypeSet(){
+            public boolean contains(XSType type) {
+                return a.contains(type) && b.contains(type);
+            }
+        };
+    }
+
+    /**
+     * Calculate the TypeSet formed by the union of two
+     * other TypeSet objects.
+     *
+     * @param a a TypeSet
+     * @param b another TypeSet
+     * @return the union of a and b
+     */
+    public static TypeSet union(final TypeSet a, final TypeSet b) {
+        return new TypeSet(){
+            public boolean contains(XSType type) {
+                return a.contains(type) || b.contains(type);
+            }
+        };
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/XSFinder.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/XSFinder.java
new file mode 100644
index 0000000..6678f17
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/XSFinder.java
@@ -0,0 +1,181 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.util;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSComponent;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+
+/**
+ * Utility implementation of {@link XSFunction} that returns
+ * {@link Boolean} to find something from schema objects.
+ *
+ * <p>
+ * This implementation returns <code>Boolean.FALSE</code> from
+ * all of the methods. The derived class is expected to override
+ * some of the methods to actually look for something.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class XSFinder implements XSFunction<Boolean> {
+
+    /**
+     * Invokes this object as a visitor with the specified component.
+     */
+    public final boolean find( XSComponent c ) {
+        return c.apply(this);
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#annotation(com.sun.xml.internal.xsom.XSAnnotation)
+     */
+    public Boolean annotation(XSAnnotation ann) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#attGroupDecl(com.sun.xml.internal.xsom.XSAttGroupDecl)
+     */
+    public Boolean attGroupDecl(XSAttGroupDecl decl) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#attributeDecl(com.sun.xml.internal.xsom.XSAttributeDecl)
+     */
+    public Boolean attributeDecl(XSAttributeDecl decl) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#attributeUse(com.sun.xml.internal.xsom.XSAttributeUse)
+     */
+    public Boolean attributeUse(XSAttributeUse use) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#complexType(com.sun.xml.internal.xsom.XSComplexType)
+     */
+    public Boolean complexType(XSComplexType type) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#schema(com.sun.xml.internal.xsom.XSSchema)
+     */
+    public Boolean schema(XSSchema schema) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#facet(com.sun.xml.internal.xsom.XSFacet)
+     */
+    public Boolean facet(XSFacet facet) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSFunction#notation(com.sun.xml.internal.xsom.XSNotation)
+     */
+    public Boolean notation(XSNotation notation) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeFunction#simpleType(com.sun.xml.internal.xsom.XSSimpleType)
+     */
+    public Boolean simpleType(XSSimpleType simpleType) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeFunction#particle(com.sun.xml.internal.xsom.XSParticle)
+     */
+    public Boolean particle(XSParticle particle) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSContentTypeFunction#empty(com.sun.xml.internal.xsom.XSContentType)
+     */
+    public Boolean empty(XSContentType empty) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSTermFunction#wildcard(com.sun.xml.internal.xsom.XSWildcard)
+     */
+    public Boolean wildcard(XSWildcard wc) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSTermFunction#modelGroupDecl(com.sun.xml.internal.xsom.XSModelGroupDecl)
+     */
+    public Boolean modelGroupDecl(XSModelGroupDecl decl) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSTermFunction#modelGroup(com.sun.xml.internal.xsom.XSModelGroup)
+     */
+    public Boolean modelGroup(XSModelGroup group) {
+        return Boolean.FALSE;
+    }
+
+    /**
+     * @see com.sun.xml.internal.xsom.visitor.XSTermFunction#elementDecl(com.sun.xml.internal.xsom.XSElementDecl)
+     */
+    public Boolean elementDecl(XSElementDecl decl) {
+        return Boolean.FALSE;
+    }
+
+    public Boolean identityConstraint(XSIdentityConstraint decl) {
+        return Boolean.FALSE;
+    }
+
+    public Boolean xpath(XSXPath xpath) {
+        return Boolean.FALSE;
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/XSFunctionFilter.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/XSFunctionFilter.java
new file mode 100644
index 0000000..470467b
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/util/XSFunctionFilter.java
@@ -0,0 +1,136 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.util;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSSimpleType;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.visitor.XSFunction;
+
+/**
+ * Filter implementation of XSFilter.
+ * This class forwards all the method calls to another XSFunction.
+ *
+ * <p>
+ * This class is intended to be derived by client application
+ * to add some meaningful behavior.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class XSFunctionFilter<T> implements XSFunction<T> {
+
+    /** This object will receive all forwarded calls. */
+    protected XSFunction<T> core;
+
+    public XSFunctionFilter( XSFunction<T> _core ) {
+        this.core = _core;
+    }
+
+    public XSFunctionFilter() {}
+
+    public T annotation(XSAnnotation ann) {
+        return core.annotation(ann);
+    }
+
+    public T attGroupDecl(XSAttGroupDecl decl) {
+        return core.attGroupDecl(decl);
+    }
+
+    public T attributeDecl(XSAttributeDecl decl) {
+        return core.attributeDecl(decl);
+    }
+
+    public T attributeUse(XSAttributeUse use) {
+        return core.attributeUse(use);
+    }
+
+    public T complexType(XSComplexType type) {
+        return core.complexType(type);
+    }
+
+    public T schema(XSSchema schema) {
+        return core.schema(schema);
+    }
+
+    public T facet(XSFacet facet) {
+        return core.facet(facet);
+    }
+
+    public T notation(XSNotation notation) {
+        return core.notation(notation);
+    }
+
+    public T simpleType(XSSimpleType simpleType) {
+        return core.simpleType(simpleType);
+    }
+
+    public T particle(XSParticle particle) {
+        return core.particle(particle);
+    }
+
+    public T empty(XSContentType empty) {
+        return core.empty(empty);
+    }
+
+    public T wildcard(XSWildcard wc) {
+        return core.wildcard(wc);
+    }
+
+    public T modelGroupDecl(XSModelGroupDecl decl) {
+        return core.modelGroupDecl(decl);
+    }
+
+    public T modelGroup(XSModelGroup group) {
+        return core.modelGroup(group);
+    }
+
+    public T elementDecl(XSElementDecl decl) {
+        return core.elementDecl(decl);
+    }
+
+    public T identityConstraint(XSIdentityConstraint decl) {
+        return core.identityConstraint(decl);
+    }
+
+    public T xpath(XSXPath xpath) {
+        return core.xpath(xpath);
+    }
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSContentTypeFunction.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSContentTypeFunction.java
new file mode 100644
index 0000000..80e326c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSContentTypeFunction.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+
+/**
+ * Function object that works on {@link XSContentType}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSContentTypeFunction<T> {
+    T simpleType( XSSimpleType simpleType );
+    T particle( XSParticle particle );
+    T empty( XSContentType empty );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSContentTypeVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSContentTypeVisitor.java
new file mode 100644
index 0000000..3c9dab1
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSContentTypeVisitor.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSContentType;
+import com.sun.xml.internal.xsom.XSParticle;
+import com.sun.xml.internal.xsom.XSSimpleType;
+
+/**
+ * Visitor that works on {@link XSContentType}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSContentTypeVisitor {
+    void simpleType( XSSimpleType simpleType );
+    void particle( XSParticle particle );
+    void empty( XSContentType empty );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSFunction.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSFunction.java
new file mode 100644
index 0000000..640cc87
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSFunction.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.impl.IdentityConstraintImpl;
+import com.sun.xml.internal.xsom.impl.XPathImpl;
+
+/**
+ * Function object that works on the entire XML Schema components.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSFunction<T> extends XSContentTypeFunction<T>, XSTermFunction<T> {
+
+    T annotation( XSAnnotation ann );
+    T attGroupDecl( XSAttGroupDecl decl );
+    T attributeDecl( XSAttributeDecl decl );
+    T attributeUse( XSAttributeUse use );
+    T complexType( XSComplexType type );
+    T schema( XSSchema schema );
+//    T schemaSet( XSSchemaSet schema );
+    T facet( XSFacet facet );
+    T notation( XSNotation notation );
+    T identityConstraint(XSIdentityConstraint decl);
+    T xpath(XSXPath xpath);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSSimpleTypeFunction.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSSimpleTypeFunction.java
new file mode 100644
index 0000000..87fd750
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSSimpleTypeFunction.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+
+/**
+ * Function object that works on {@link com.sun.xml.internal.xsom.XSSimpleType}
+ * and its derived interfaces.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke,kawaguchi@sun.com)
+ */
+public interface XSSimpleTypeFunction<T> {
+    T listSimpleType( XSListSimpleType type );
+    T unionSimpleType( XSUnionSimpleType type );
+    T restrictionSimpleType( XSRestrictionSimpleType type );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSSimpleTypeVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSSimpleTypeVisitor.java
new file mode 100644
index 0000000..f746d9c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSSimpleTypeVisitor.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSListSimpleType;
+import com.sun.xml.internal.xsom.XSRestrictionSimpleType;
+import com.sun.xml.internal.xsom.XSUnionSimpleType;
+
+/**
+ * Visitor that works on {@link com.sun.xml.internal.xsom.XSSimpleType}
+ * and its derived interfaces.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke,kawaguchi@sun.com)
+ */
+public interface XSSimpleTypeVisitor {
+    void listSimpleType( XSListSimpleType type );
+    void unionSimpleType( XSUnionSimpleType type );
+    void restrictionSimpleType( XSRestrictionSimpleType type );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermFunction.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermFunction.java
new file mode 100644
index 0000000..27b8390
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermFunction.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSTerm;
+
+/**
+ * Function object that works on {@link XSTerm}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSTermFunction<T> {
+    T wildcard( XSWildcard wc );
+    T modelGroupDecl( XSModelGroupDecl decl );
+    T modelGroup( XSModelGroup group );
+    T elementDecl( XSElementDecl decl );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermFunctionWithParam.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermFunctionWithParam.java
new file mode 100644
index 0000000..2e33258
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermFunctionWithParam.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSWildcard;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSTerm;
+
+/**
+ * Function object that works on {@link XSTerm}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSTermFunctionWithParam<T,P> {
+    T wildcard( XSWildcard wc, P param );
+    T modelGroupDecl( XSModelGroupDecl decl, P param );
+    T modelGroup( XSModelGroup group, P param );
+    T elementDecl( XSElementDecl decl, P param );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermVisitor.java
new file mode 100644
index 0000000..5b065a6
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSTermVisitor.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSElementDecl;
+import com.sun.xml.internal.xsom.XSModelGroup;
+import com.sun.xml.internal.xsom.XSModelGroupDecl;
+import com.sun.xml.internal.xsom.XSWildcard;
+
+/**
+ * Visitor that works on {@link com.sun.xml.internal.xsom.XSTerm}.
+ *
+ * @author
+ *  Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSTermVisitor {
+    void wildcard( XSWildcard wc );
+    void modelGroupDecl( XSModelGroupDecl decl );
+    void modelGroup( XSModelGroup group );
+    void elementDecl( XSElementDecl decl );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSVisitor.java
new file mode 100644
index 0000000..b92874c
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSVisitor.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSAnnotation;
+import com.sun.xml.internal.xsom.XSAttGroupDecl;
+import com.sun.xml.internal.xsom.XSAttributeDecl;
+import com.sun.xml.internal.xsom.XSAttributeUse;
+import com.sun.xml.internal.xsom.XSComplexType;
+import com.sun.xml.internal.xsom.XSFacet;
+import com.sun.xml.internal.xsom.XSNotation;
+import com.sun.xml.internal.xsom.XSSchema;
+import com.sun.xml.internal.xsom.XSIdentityConstraint;
+import com.sun.xml.internal.xsom.XSXPath;
+import com.sun.xml.internal.xsom.impl.IdentityConstraintImpl;
+import com.sun.xml.internal.xsom.impl.XPathImpl;
+
+/**
+ * Visitor for {@link com.sun.xml.internal.xsom.XSComponent}
+ */
+public interface XSVisitor extends XSTermVisitor, XSContentTypeVisitor {
+    void annotation( XSAnnotation ann );
+    void attGroupDecl( XSAttGroupDecl decl );
+    void attributeDecl( XSAttributeDecl decl );
+    void attributeUse( XSAttributeUse use );
+    void complexType( XSComplexType type );
+    void schema( XSSchema schema );
+//    void schemaSet( XSSchemaSet schema );
+    void facet( XSFacet facet );
+    void notation( XSNotation notation );
+    void identityConstraint( XSIdentityConstraint decl);
+    void xpath(XSXPath xp);
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSWildcardFunction.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSWildcardFunction.java
new file mode 100644
index 0000000..892d7b3
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSWildcardFunction.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSWildcard;
+
+/**
+ * Visits three kinds of {@link XSWildcard}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSWildcardFunction<T> {
+    T any( XSWildcard.Any wc );
+    T other( XSWildcard.Other wc );
+    T union( XSWildcard.Union wc );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSWildcardVisitor.java b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSWildcardVisitor.java
new file mode 100644
index 0000000..2dca615
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/XSWildcardVisitor.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package com.sun.xml.internal.xsom.visitor;
+
+import com.sun.xml.internal.xsom.XSWildcard;
+
+/**
+ * Visits three kinds of {@link XSWildcard}.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public interface XSWildcardVisitor {
+    void any( XSWildcard.Any wc );
+    void other( XSWildcard.Other wc );
+    void union( XSWildcard.Union wc );
+}
diff --git a/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/package.html b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/package.html
new file mode 100644
index 0000000..9d1a15f
--- /dev/null
+++ b/jaxws/src/share/classes/com/sun/xml/internal/xsom/visitor/package.html
@@ -0,0 +1,3 @@
+<html><body>
+Visitor pattern support for the <code>com.sun.xml.xsom</code> interfaces.
+</body></html>
diff --git a/jaxws/src/share/classes/javax/activation/ActivationDataFlavor.java b/jaxws/src/share/classes/javax/activation/ActivationDataFlavor.java
new file mode 100644
index 0000000..3501435
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/ActivationDataFlavor.java
@@ -0,0 +1,247 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.awt.datatransfer.DataFlavor;
+import java.io.IOException;
+import javax.activation.MimeType;
+
+/**
+ * The ActivationDataFlavor class is a special subclass of
+ * <code>java.awt.datatransfer.DataFlavor</code>. It allows the JAF to
+ * set all three values stored by the DataFlavor class via a new
+ * constructor. It also contains improved MIME parsing in the <code>equals
+ * </code> method. Except for the improved parsing, its semantics are
+ * identical to that of the JDK's DataFlavor class.
+ *
+ * @since 1.6
+ */
+
+public class ActivationDataFlavor extends DataFlavor {
+
+    /*
+     * Raison d'etre:
+     *
+     * The DataFlavor class included in JDK 1.1 has several limitations
+     * including piss poor MIME type parsing, and the limitation of
+     * only supporting serialized objects and InputStreams as
+     * representation objects. This class 'fixes' that.
+     */
+
+    // I think for now I'll keep copies of all the variables and
+    // then later I may choose try to better coexist with the base
+    // class *sigh*
+    private String mimeType = null;
+    private MimeType mimeObject = null;
+    private String humanPresentableName = null;
+    private Class representationClass = null;
+
+    /**
+     * Construct a DataFlavor that represents an arbitrary
+     * Java object. This constructor is an extension of the
+     * JDK's DataFlavor in that it allows the explicit setting
+     * of all three DataFlavor attributes.
+     * <p>
+     * The returned DataFlavor will have the following characteristics:
+     * <p>
+     * representationClass = representationClass<br>
+     * mimeType            = mimeType<br>
+     * humanName           = humanName
+     * <p>
+     *
+     * @param representationClass the class used in this DataFlavor
+     * @param mimeType the MIME type of the data represented by this class
+     * @param humanPresentableName the human presentable name of the flavor
+     */
+    public ActivationDataFlavor(Class representationClass,
+                      String mimeType, String humanPresentableName) {
+        super(mimeType, humanPresentableName); // need to call super
+
+        // init private variables:
+        this.mimeType = mimeType;
+        this.humanPresentableName = humanPresentableName;
+        this.representationClass = representationClass;
+    }
+
+    /**
+     * Construct a DataFlavor that represents a MimeType.
+     * <p>
+     * The returned DataFlavor will have the following characteristics:
+     * <p>
+     * If the mimeType is "application/x-java-serialized-object;
+     * class=", the result is the same as calling new
+     * DataFlavor(Class.forName()) as above.
+     * <p>
+     * otherwise:
+     * <p>
+     * representationClass = InputStream<p>
+     * mimeType = mimeType<p>
+     *
+     * @param representationClass the class used in this DataFlavor
+     * @param humanPresentableName the human presentable name of the flavor
+     */
+    public ActivationDataFlavor(Class representationClass,
+                                String humanPresentableName) {
+        super(representationClass, humanPresentableName);
+        this.mimeType = super.getMimeType();
+        this.representationClass = representationClass;
+        this.humanPresentableName = humanPresentableName;
+    }
+
+    /**
+     * Construct a DataFlavor that represents a MimeType.
+     * <p>
+     * The returned DataFlavor will have the following characteristics:
+     * <p>
+     * If the mimeType is "application/x-java-serialized-object; class=",
+     * the result is the same as calling new DataFlavor(Class.forName()) as
+     * above, otherwise:
+     * <p>
+     * representationClass = InputStream<p>
+     * mimeType = mimeType
+     *
+     * @param mimeType the MIME type of the data represented by this class
+     * @param humanPresentableName the human presentable name of the flavor
+     */
+    public ActivationDataFlavor(String mimeType, String humanPresentableName) {
+        super(mimeType, humanPresentableName);
+        this.mimeType = mimeType;
+        try {
+            this.representationClass = Class.forName("java.io.InputStream");
+        } catch (ClassNotFoundException ex) {
+            // XXX - should never happen, ignore it
+        }
+        this.humanPresentableName = humanPresentableName;
+    }
+
+    /**
+     * Return the MIME type for this DataFlavor.
+     *
+     * @return  the MIME type
+     */
+    public String getMimeType() {
+        return mimeType;
+    }
+
+    /**
+     * Return the representation class.
+     *
+     * @return  the representation class
+     */
+    public Class getRepresentationClass() {
+        return representationClass;
+    }
+
+    /**
+     * Return the Human Presentable name.
+     *
+     * @return  the human presentable name
+     */
+    public String getHumanPresentableName() {
+        return humanPresentableName;
+    }
+
+    /**
+     * Set the human presentable name.
+     *
+     * @param humanPresentableName      the name to set
+     */
+    public void setHumanPresentableName(String humanPresentableName) {
+        this.humanPresentableName = humanPresentableName;
+    }
+
+    /**
+     * Compares the DataFlavor passed in with this DataFlavor; calls
+     * the <code>isMimeTypeEqual</code> method.
+     *
+     * @param dataFlavor        the DataFlavor to compare with
+     * @return                  true if the MIME type and representation class
+     *                          are the same
+     */
+    public boolean equals(DataFlavor dataFlavor) {
+        return (isMimeTypeEqual(dataFlavor) &&
+                dataFlavor.getRepresentationClass() == representationClass);
+    }
+
+    /**
+     * Is the string representation of the MIME type passed in equivalent
+     * to the MIME type of this DataFlavor. <p>
+     *
+     * ActivationDataFlavor delegates the comparison of MIME types to
+     * the MimeType class included as part of the JavaBeans Activation
+     * Framework. This provides a more robust comparison than is normally
+     * available in the DataFlavor class.
+     *
+     * @param mimeType  the MIME type
+     * @return          true if the same MIME type
+     */
+    public boolean isMimeTypeEqual(String mimeType) {
+        MimeType mt = null;
+        try {
+            if (mimeObject == null)
+                mimeObject = new MimeType(this.mimeType);
+            mt = new MimeType(mimeType);
+        } catch (MimeTypeParseException e) {}
+
+        return mimeObject.match(mt);
+    }
+
+    /**
+     * Called on DataFlavor for every MIME Type parameter to allow DataFlavor
+     * subclasses to handle special parameters like the text/plain charset
+     * parameters, whose values are case insensitive.  (MIME type parameter
+     * values are supposed to be case sensitive).
+     * <p>
+     * This method is called for each parameter name/value pair and should
+     * return the normalized representation of the parameterValue.
+     * This method is never invoked by this implementation.
+     *
+     * @param parameterName     the parameter name
+     * @param parameterValue    the parameter value
+     * @return                  the normalized parameter value
+     * @deprecated
+     */
+    protected String normalizeMimeTypeParameter(String parameterName,
+                                                String parameterValue) {
+        return parameterValue;
+    }
+
+    /**
+     * Called for each MIME type string to give DataFlavor subtypes the
+     * opportunity to change how the normalization of MIME types is
+     * accomplished.
+     * One possible use would be to add default parameter/value pairs in cases
+     * where none are present in the MIME type string passed in.
+     * This method is never invoked by this implementation.
+     *
+     * @param mimeType  the MIME type
+     * @return          the normalized MIME type
+     * @deprecated
+     */
+    protected String normalizeMimeType(String mimeType) {
+        return mimeType;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/CommandInfo.java b/jaxws/src/share/classes/javax/activation/CommandInfo.java
new file mode 100644
index 0000000..f90a5d9
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/CommandInfo.java
@@ -0,0 +1,138 @@
+/*
+ * Copyright 1997-1999 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.*;
+import java.beans.Beans;
+
+/**
+ * The CommandInfo class is used by CommandMap implementations to
+ * describe the results of command requests. It provides the requestor
+ * with both the verb requested, as well as an instance of the
+ * bean. There is also a method that will return the name of the
+ * class that implements the command but <i>it is not guaranteed to
+ * return a valid value</i>. The reason for this is to allow CommandMap
+ * implmentations that subclass CommandInfo to provide special
+ * behavior. For example a CommandMap could dynamically generate
+ * JavaBeans. In this case, it might not be possible to create an
+ * object with all the correct state information solely from the class
+ * name.
+ *
+ * @since 1.6
+ */
+
+public class CommandInfo {
+    private String verb;
+    private String className;
+
+    /**
+     * The Constructor for CommandInfo.
+     * @param verb The command verb this CommandInfo decribes.
+     * @param className The command's fully qualified class name.
+     */
+    public CommandInfo(String verb, String className) {
+        this.verb = verb;
+        this.className = className;
+    }
+
+    /**
+     * Return the command verb.
+     *
+     * @return the command verb.
+     */
+    public String getCommandName() {
+        return verb;
+    }
+
+    /**
+     * Return the command's class name. <i>This method MAY return null in
+     * cases where a CommandMap subclassed CommandInfo for its
+     * own purposes.</i> In other words, it might not be possible to
+     * create the correct state in the command by merely knowing
+     * its class name. <b>DO NOT DEPEND ON THIS METHOD RETURNING
+     * A VALID VALUE!</b>
+     *
+     * @return The class name of the command, or <i>null</i>
+     */
+    public String getCommandClass() {
+        return className;
+    }
+
+    /**
+     * Return the instantiated JavaBean component.
+     * <p>
+     * Begin by instantiating the component with
+     * <code>Beans.instantiate()</code>.
+     * <p>
+     * If the bean implements the <code>javax.activation.CommandObject</code>
+     * interface, call its <code>setCommandContext</code> method.
+     * <p>
+     * If the DataHandler parameter is null, then the bean is
+     * instantiated with no data. NOTE: this may be useful
+     * if for some reason the DataHandler that is passed in
+     * throws IOExceptions when this method attempts to
+     * access its InputStream. It will allow the caller to
+     * retrieve a reference to the bean if it can be
+     * instantiated.
+     * <p>
+     * If the bean does NOT implement the CommandObject interface,
+     * this method will check if it implements the
+     * java.io.Externalizable interface. If it does, the bean's
+     * readExternal method will be called if an InputStream
+     * can be acquired from the DataHandler.<p>
+     *
+     * @param dh        The DataHandler that describes the data to be
+     *                  passed to the command.
+     * @param loader    The ClassLoader to be used to instantiate the bean.
+     * @return The bean
+     * @see java.beans.Beans#instantiate
+     * @see javax.activation.CommandObject
+     */
+    public Object getCommandObject(DataHandler dh, ClassLoader loader)
+                        throws IOException, ClassNotFoundException {
+        Object new_bean = null;
+
+        // try to instantiate the bean
+        new_bean = java.beans.Beans.instantiate(loader, className);
+
+        // if we got one and it is a CommandObject
+        if (new_bean != null) {
+            if (new_bean instanceof CommandObject) {
+                ((CommandObject)new_bean).setCommandContext(verb, dh);
+            } else if (new_bean instanceof Externalizable) {
+                if (dh != null) {
+                    InputStream is = dh.getInputStream();
+                    if (is != null) {
+                        ((Externalizable)new_bean).readExternal(
+                                               new ObjectInputStream(is));
+                    }
+                }
+            }
+        }
+
+        return new_bean;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/CommandMap.java b/jaxws/src/share/classes/javax/activation/CommandMap.java
new file mode 100644
index 0000000..bfb07e7
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/CommandMap.java
@@ -0,0 +1,220 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+
+/**
+ * The CommandMap class provides an interface to a registry of
+ * command objects available in the system.
+ * Developers are expected to either use the CommandMap
+ * implementation included with this package (MailcapCommandMap) or
+ * develop their own. Note that some of the methods in this class are
+ * abstract.
+ *
+ * @since 1.6
+ */
+public abstract class CommandMap {
+    private static CommandMap defaultCommandMap = null;
+
+    /**
+     * Get the default CommandMap.
+     * <p>
+     *
+     * <ul>
+     * <li> In cases where a CommandMap instance has been previously set
+     *      to some value (via <i>setDefaultCommandMap</i>)
+     *  return the CommandMap.
+     * <li>
+     *  In cases where no CommandMap has been set, the CommandMap
+     *       creates an instance of <code>MailcapCommandMap</code> and
+     *       set that to the default, returning its value.
+     *
+     * </ul>
+     *
+     * @return the CommandMap
+     */
+    public static CommandMap getDefaultCommandMap() {
+        if (defaultCommandMap == null)
+            defaultCommandMap = new MailcapCommandMap();
+
+        return defaultCommandMap;
+    }
+
+    /**
+     * Set the default CommandMap. Reset the CommandMap to the default by
+     * calling this method with <code>null</code>.
+     *
+     * @param commandMap The new default CommandMap.
+     * @exception SecurityException if the caller doesn't have permission
+     *                                  to change the default
+     */
+    public static void setDefaultCommandMap(CommandMap commandMap) {
+        SecurityManager security = System.getSecurityManager();
+        if (security != null) {
+            try {
+                // if it's ok with the SecurityManager, it's ok with me...
+                security.checkSetFactory();
+            } catch (SecurityException ex) {
+                // otherwise, we also allow it if this code and the
+                // factory come from the same class loader (e.g.,
+                // the JAF classes were loaded with the applet classes).
+                if (CommandMap.class.getClassLoader() !=
+                            commandMap.getClass().getClassLoader())
+                    throw ex;
+            }
+        }
+        defaultCommandMap = commandMap;
+    }
+
+    /**
+     * Get the preferred command list from a MIME Type. The actual semantics
+     * are determined by the implementation of the CommandMap.
+     *
+     * @param mimeType  the MIME type
+     * @return the CommandInfo classes that represent the command Beans.
+     */
+    abstract public  CommandInfo[] getPreferredCommands(String mimeType);
+
+    /**
+     * Get the preferred command list from a MIME Type. The actual semantics
+     * are determined by the implementation of the CommandMap. <p>
+     *
+     * The <code>DataSource</code> provides extra information, such as
+     * the file name, that a CommandMap implementation may use to further
+     * refine the list of commands that are returned.  The implementation
+     * in this class simply calls the <code>getPreferredCommands</code>
+     * method that ignores this argument.
+     *
+     * @param mimeType  the MIME type
+     * @param ds        a DataSource for the data
+     * @return the CommandInfo classes that represent the command Beans.
+     * @since   JAF 1.1
+     */
+    public CommandInfo[] getPreferredCommands(String mimeType, DataSource ds) {
+        return getPreferredCommands(mimeType);
+    }
+
+    /**
+     * Get all the available commands for this type. This method
+     * should return all the possible commands for this MIME type.
+     *
+     * @param mimeType  the MIME type
+     * @return the CommandInfo objects representing all the commands.
+     */
+    abstract public CommandInfo[] getAllCommands(String mimeType);
+
+    /**
+     * Get all the available commands for this type. This method
+     * should return all the possible commands for this MIME type. <p>
+     *
+     * The <code>DataSource</code> provides extra information, such as
+     * the file name, that a CommandMap implementation may use to further
+     * refine the list of commands that are returned.  The implementation
+     * in this class simply calls the <code>getAllCommands</code>
+     * method that ignores this argument.
+     *
+     * @param mimeType  the MIME type
+     * @param ds        a DataSource for the data
+     * @return the CommandInfo objects representing all the commands.
+     * @since   JAF 1.1
+     */
+    public CommandInfo[] getAllCommands(String mimeType, DataSource ds) {
+        return getAllCommands(mimeType);
+    }
+
+    /**
+     * Get the default command corresponding to the MIME type.
+     *
+     * @param mimeType  the MIME type
+     * @param cmdName   the command name
+     * @return the CommandInfo corresponding to the command.
+     */
+    abstract public CommandInfo getCommand(String mimeType, String cmdName);
+
+    /**
+     * Get the default command corresponding to the MIME type. <p>
+     *
+     * The <code>DataSource</code> provides extra information, such as
+     * the file name, that a CommandMap implementation may use to further
+     * refine the command that is chosen.  The implementation
+     * in this class simply calls the <code>getCommand</code>
+     * method that ignores this argument.
+     *
+     * @param mimeType  the MIME type
+     * @param cmdName   the command name
+     * @param ds        a DataSource for the data
+     * @return the CommandInfo corresponding to the command.
+     * @since   JAF 1.1
+     */
+    public CommandInfo getCommand(String mimeType, String cmdName,
+                                DataSource ds) {
+        return getCommand(mimeType, cmdName);
+    }
+
+    /**
+     * Locate a DataContentHandler that corresponds to the MIME type.
+     * The mechanism and semantics for determining this are determined
+     * by the implementation of the particular CommandMap.
+     *
+     * @param mimeType  the MIME type
+     * @return          the DataContentHandler for the MIME type
+     */
+    abstract public DataContentHandler createDataContentHandler(String
+                                                                mimeType);
+
+    /**
+     * Locate a DataContentHandler that corresponds to the MIME type.
+     * The mechanism and semantics for determining this are determined
+     * by the implementation of the particular CommandMap. <p>
+     *
+     * The <code>DataSource</code> provides extra information, such as
+     * the file name, that a CommandMap implementation may use to further
+     * refine the choice of DataContentHandler.  The implementation
+     * in this class simply calls the <code>createDataContentHandler</code>
+     * method that ignores this argument.
+     *
+     * @param mimeType  the MIME type
+     * @param ds        a DataSource for the data
+     * @return          the DataContentHandler for the MIME type
+     * @since   JAF 1.1
+     */
+    public DataContentHandler createDataContentHandler(String mimeType,
+                                DataSource ds) {
+        return createDataContentHandler(mimeType);
+    }
+
+    /**
+     * Get all the MIME types known to this command map.
+     * If the command map doesn't support this operation,
+     * null is returned.
+     *
+     * @return          array of MIME types as strings, or null if not supported
+     * @since   JAF 1.1
+     */
+    public String[] getMimeTypes() {
+        return null;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/CommandObject.java b/jaxws/src/share/classes/javax/activation/CommandObject.java
new file mode 100644
index 0000000..f2caa53
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/CommandObject.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.IOException;
+
+/**
+ * JavaBeans components that are Activation Framework aware implement
+ * this interface to find out which command verb they're being asked
+ * to perform, and to obtain the DataHandler representing the
+ * data they should operate on.  JavaBeans that don't implement
+ * this interface may be used as well.  Such commands may obtain
+ * the data using the Externalizable interface, or using an
+ * application-specific method.<p>
+ *
+ * @since 1.6
+ */
+public interface CommandObject {
+
+    /**
+     * Initialize the Command with the verb it is requested to handle
+     * and the DataHandler that describes the data it will
+     * operate on. <b>NOTE:</b> it is acceptable for the caller
+     * to pass <i>null</i> as the value for <code>DataHandler</code>.
+     *
+     * @param verb The Command Verb this object refers to.
+     * @param dh The DataHandler.
+     */
+    public void setCommandContext(String verb, DataHandler dh)
+                                                throws IOException;
+}
diff --git a/jaxws/src/share/classes/javax/activation/DataContentHandler.java b/jaxws/src/share/classes/javax/activation/DataContentHandler.java
new file mode 100644
index 0000000..0100a94
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/DataContentHandler.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.awt.datatransfer.DataFlavor;
+import java.awt.datatransfer.UnsupportedFlavorException;
+import java.io.InputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import javax.activation.DataSource;
+
+/**
+ * The DataContentHandler interface is implemented by objects that can
+ * be used to extend the capabilities of the DataHandler's implementation
+ * of the Transferable interface. Through <code>DataContentHandlers</code>
+ * the framework can be extended to convert streams in to objects, and
+ * to write objects to streams. <p>
+ *
+ * Applications don't generally call the methods in DataContentHandlers
+ * directly. Instead, an application calls the equivalent methods in
+ * DataHandler. The DataHandler will attempt to find an appropriate
+ * DataContentHandler that corresponds to its MIME type using the
+ * current DataContentHandlerFactory. The DataHandler then calls
+ * through to the methods in the DataContentHandler.
+ *
+ * @since 1.6
+ */
+
+public interface DataContentHandler {
+    /**
+     * Returns an array of DataFlavor objects indicating the flavors the
+     * data can be provided in. The array should be ordered according to
+     * preference for providing the data (from most richly descriptive to
+     * least descriptive).
+     *
+     * @return The DataFlavors.
+     */
+    public DataFlavor[] getTransferDataFlavors();
+
+    /**
+     * Returns an object which represents the data to be transferred.
+     * The class of the object returned is defined by the representation class
+     * of the flavor.
+     *
+     * @param df The DataFlavor representing the requested type.
+     * @param ds The DataSource representing the data to be converted.
+     * @return The constructed Object.
+     * @exception UnsupportedFlavorException    if the handler doesn't
+     *                                          support the requested flavor
+     * @exception IOException   if the data can't be accessed
+     */
+    public Object getTransferData(DataFlavor df, DataSource ds)
+                                throws UnsupportedFlavorException, IOException;
+
+    /**
+     * Return an object representing the data in its most preferred form.
+     * Generally this will be the form described by the first DataFlavor
+     * returned by the <code>getTransferDataFlavors</code> method.
+     *
+     * @param ds The DataSource representing the data to be converted.
+     * @return The constructed Object.
+     * @exception IOException   if the data can't be accessed
+     */
+    public Object getContent(DataSource ds) throws IOException;
+
+    /**
+     * Convert the object to a byte stream of the specified MIME type
+     * and write it to the output stream.
+     *
+     * @param obj       The object to be converted.
+     * @param mimeType  The requested MIME type of the resulting byte stream.
+     * @param os        The output stream into which to write the converted
+     *                  byte stream.
+     * @exception IOException   errors writing to the stream
+     */
+    public void writeTo(Object obj, String mimeType, OutputStream os)
+                                                       throws IOException;
+}
diff --git a/jaxws/src/share/classes/javax/activation/DataContentHandlerFactory.java b/jaxws/src/share/classes/javax/activation/DataContentHandlerFactory.java
new file mode 100644
index 0000000..9d7109e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/DataContentHandlerFactory.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+/**
+ * This interface defines a factory for <code>DataContentHandlers</code>. An
+ * implementation of this interface should map a MIME type into an
+ * instance of DataContentHandler. The design pattern for classes implementing
+ * this interface is the same as for the ContentHandler mechanism used in
+ * <code>java.net.URL</code>.
+ *
+ * @since 1.6
+ */
+
+public interface DataContentHandlerFactory {
+
+    /**
+     * Creates a new DataContentHandler object for the MIME type.
+     *
+     * @param mimeType the MIME type to create the DataContentHandler for.
+     * @return The new <code>DataContentHandler</code>, or <i>null</i>
+     * if none are found.
+     */
+    public DataContentHandler createDataContentHandler(String mimeType);
+}
diff --git a/jaxws/src/share/classes/javax/activation/DataHandler.java b/jaxws/src/share/classes/javax/activation/DataHandler.java
new file mode 100644
index 0000000..4e3527c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/DataHandler.java
@@ -0,0 +1,894 @@
+/*
+ * Copyright 1997-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.InputStream;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.PipedInputStream;
+import java.io.PipedOutputStream;
+import java.io.OutputStreamWriter;
+import java.net.URL;
+import java.awt.datatransfer.Transferable;
+import java.awt.datatransfer.DataFlavor;
+import java.awt.datatransfer.UnsupportedFlavorException;
+
+/**
+ * The DataHandler class provides a consistent interface to data
+ * available in many different sources and formats.
+ * It manages simple stream to string conversions and related operations
+ * using DataContentHandlers.
+ * It provides access to commands that can operate on the data.
+ * The commands are found using a CommandMap. <p>
+ *
+ * <b>DataHandler and the Transferable Interface</b><p>
+ * DataHandler implements the Transferable interface so that data can
+ * be used in AWT data transfer operations, such as cut and paste and
+ * drag and drop. The implementation of the Transferable interface
+ * relies on the availability of an installed DataContentHandler
+ * object corresponding to the MIME type of the data represented in
+ * the specific instance of the DataHandler.<p>
+ *
+ * <b>DataHandler and CommandMaps</b><p>
+ * The DataHandler keeps track of the current CommandMap that it uses to
+ * service requests for commands (<code>getCommand</code>,
+ * <code>getAllCommands</code>, <code>getPreferredCommands</code>).
+ * Each instance of a DataHandler may have a CommandMap associated with
+ * it using the <code>setCommandMap</code> method.  If a CommandMap was
+ * not set, DataHandler calls the <code>getDefaultCommandMap</code>
+ * method in CommandMap and uses the value it returns. See
+ * <i>CommandMap</i> for more information. <p>
+ *
+ * <b>DataHandler and URLs</b><p>
+ * The current DataHandler implementation creates a private
+ * instance of URLDataSource when it is constructed with a URL.
+ *
+ * @see javax.activation.CommandMap
+ * @see javax.activation.DataContentHandler
+ * @see javax.activation.DataSource
+ * @see javax.activation.URLDataSource
+ *
+ * @since 1.6
+ */
+
+public class DataHandler implements Transferable {
+
+    // Use the datasource to indicate whether we were started via the
+    // DataSource constructor or the object constructor.
+    private DataSource dataSource = null;
+    private DataSource objDataSource = null;
+
+    // The Object and mimetype from the constructor (if passed in).
+    // object remains null if it was instantiated with a
+    // DataSource.
+    private Object object = null;
+    private String objectMimeType = null;
+
+    // Keep track of the CommandMap
+    private CommandMap currentCommandMap = null;
+
+    // our transfer flavors
+    private static final DataFlavor emptyFlavors[] = new DataFlavor[0];
+    private DataFlavor transferFlavors[] = emptyFlavors;
+
+    // our DataContentHandler
+    private DataContentHandler dataContentHandler = null;
+    private DataContentHandler factoryDCH = null;
+
+    // our DataContentHandlerFactory
+    private static DataContentHandlerFactory factory = null;
+    private DataContentHandlerFactory oldFactory = null;
+    // the short representation of the ContentType (sans params)
+    private String shortType = null;
+
+    /**
+     * Create a <code>DataHandler</code> instance referencing the
+     * specified DataSource.  The data exists in a byte stream form.
+     * The DataSource will provide an InputStream to access the data.
+     *
+     * @param ds        the DataSource
+     */
+    public DataHandler(DataSource ds) {
+        // save a reference to the incoming DS
+        dataSource = ds;
+        oldFactory = factory; // keep track of the factory
+    }
+
+    /**
+     * Create a <code>DataHandler</code> instance representing an object
+     * of this MIME type.  This constructor is
+     * used when the application already has an in-memory representation
+     * of the data in the form of a Java Object.
+     *
+     * @param obj       the Java Object
+     * @param mimeType  the MIME type of the object
+     */
+    public DataHandler(Object obj, String mimeType) {
+        object = obj;
+        objectMimeType = mimeType;
+        oldFactory = factory; // keep track of the factory
+    }
+
+    /**
+     * Create a <code>DataHandler</code> instance referencing a URL.
+     * The DataHandler internally creates a <code>URLDataSource</code>
+     * instance to represent the URL.
+     *
+     * @param url       a URL object
+     */
+    public DataHandler(URL url) {
+        dataSource = new URLDataSource(url);
+        oldFactory = factory; // keep track of the factory
+    }
+
+    /**
+     * Return the CommandMap for this instance of DataHandler.
+     */
+    private synchronized CommandMap getCommandMap() {
+        if (currentCommandMap != null)
+            return currentCommandMap;
+        else
+            return CommandMap.getDefaultCommandMap();
+    }
+
+    /**
+     * Return the DataSource associated with this instance
+     * of DataHandler.
+     * <p>
+     * For DataHandlers that have been instantiated with a DataSource,
+     * this method returns the DataSource that was used to create the
+     * DataHandler object. In other cases the DataHandler
+     * constructs a DataSource from the data used to construct
+     * the DataHandler. DataSources created for DataHandlers <b>not</b>
+     * instantiated with a DataSource are cached for performance
+     * reasons.
+     *
+     * @return  a valid DataSource object for this DataHandler
+     */
+    public DataSource getDataSource() {
+        if (dataSource == null) {
+            // create one on the fly
+            if (objDataSource == null)
+                objDataSource = new DataHandlerDataSource(this);
+            return objDataSource;
+        }
+        return dataSource;
+    }
+
+    /**
+     * Return the name of the data object. If this DataHandler
+     * was created with a DataSource, this method calls through
+     * to the <code>DataSource.getName</code> method, otherwise it
+     * returns <i>null</i>.
+     *
+     * @return  the name of the object
+     */
+    public String getName() {
+        if (dataSource != null)
+            return dataSource.getName();
+        else
+            return null;
+    }
+
+    /**
+     * Return the MIME type of this object as retrieved from
+     * the source object. Note that this is the <i>full</i>
+     * type with parameters.
+     *
+     * @return  the MIME type
+     */
+    public String getContentType() {
+        if (dataSource != null) // data source case
+            return dataSource.getContentType();
+        else
+            return objectMimeType; // obj/type case
+    }
+
+    /**
+     * Get the InputStream for this object. <p>
+     *
+     * For DataHandlers instantiated with a DataSource, the DataHandler
+     * calls the <code>DataSource.getInputStream</code> method and
+     * returns the result to the caller.
+     * <p>
+     * For DataHandlers instantiated with an Object, the DataHandler
+     * first attempts to find a DataContentHandler for the Object. If
+     * the DataHandler can not find a DataContentHandler for this MIME
+     * type, it throws an UnsupportedDataTypeException.  If it is
+     * successful, it creates a pipe and a thread.  The thread uses the
+     * DataContentHandler's <code>writeTo</code> method to write the
+     * stream data into one end of the pipe.  The other end of the pipe
+     * is returned to the caller.  Because a thread is created to copy
+     * the data, IOExceptions that may occur during the copy can not be
+     * propagated back to the caller. The result is an empty stream.<p>
+     *
+     * @return  the InputStream representing this data
+     * @exception IOException   if an I/O error occurs
+     *
+     * @see javax.activation.DataContentHandler#writeTo
+     * @see javax.activation.UnsupportedDataTypeException
+     */
+    public InputStream getInputStream() throws IOException {
+        InputStream ins = null;
+
+        if (dataSource != null) {
+            ins = dataSource.getInputStream();
+        } else {
+            DataContentHandler dch = getDataContentHandler();
+            // we won't even try if we can't get a dch
+            if (dch == null)
+                throw new UnsupportedDataTypeException(
+                                "no DCH for MIME type " + getBaseType());
+
+            if (dch instanceof ObjectDataContentHandler) {
+                if (((ObjectDataContentHandler)dch).getDCH() == null)
+                    throw new UnsupportedDataTypeException(
+                                "no object DCH for MIME type " + getBaseType());
+            }
+            // there is none but the default^^^^^^^^^^^^^^^^
+            final DataContentHandler fdch = dch;
+
+            // from bill s.
+            // ce n'est pas une pipe!
+            //
+            // NOTE: This block of code needs to throw exceptions, but
+            // can't because it is in another thread!!! ARG!
+            //
+            final PipedOutputStream pos = new PipedOutputStream();
+            PipedInputStream pin = new PipedInputStream(pos);
+            new Thread(
+                       new Runnable() {
+                public void run() {
+                    try {
+                        fdch.writeTo(object, objectMimeType, pos);
+                    } catch (IOException e) {
+
+                    } finally {
+                        try {
+                            pos.close();
+                        } catch (IOException ie) { }
+                    }
+                }
+            },
+                      "DataHandler.getInputStream").start();
+            ins = pin;
+        }
+
+        return ins;
+    }
+
+    /**
+     * Write the data to an <code>OutputStream</code>.<p>
+     *
+     * If the DataHandler was created with a DataSource, writeTo
+     * retrieves the InputStream and copies the bytes from the
+     * InputStream to the OutputStream passed in.
+     * <p>
+     * If the DataHandler was created with an object, writeTo
+     * retrieves the DataContentHandler for the object's type.
+     * If the DataContentHandler was found, it calls the
+     * <code>writeTo</code> method on the <code>DataContentHandler</code>.
+     *
+     * @param os        the OutputStream to write to
+     * @exception IOException   if an I/O error occurs
+     */
+    public void writeTo(OutputStream os) throws IOException {
+        // for the DataSource case
+        if (dataSource != null) {
+            InputStream is = null;
+            byte data[] = new byte[8*1024];
+            int bytes_read;
+
+            is = dataSource.getInputStream();
+
+            try {
+                while ((bytes_read = is.read(data)) > 0) {
+                    os.write(data, 0, bytes_read);
+                }
+            } finally {
+                is.close();
+                is = null;
+            }
+        } else { // for the Object case
+            DataContentHandler dch = getDataContentHandler();
+            dch.writeTo(object, objectMimeType, os);
+        }
+    }
+
+    /**
+     * Get an OutputStream for this DataHandler to allow overwriting
+     * the underlying data.
+     * If the DataHandler was created with a DataSource, the
+     * DataSource's <code>getOutputStream</code> method is called.
+     * Otherwise, <code>null</code> is returned.
+     *
+     * @return the OutputStream
+     *
+     * @see javax.activation.DataSource#getOutputStream
+     * @see javax.activation.URLDataSource
+     */
+    public OutputStream getOutputStream() throws IOException {
+        if (dataSource != null)
+            return dataSource.getOutputStream();
+        else
+            return null;
+    }
+
+    /**
+     * Return the DataFlavors in which this data is available. <p>
+     *
+     * Returns an array of DataFlavor objects indicating the flavors
+     * the data can be provided in. The array is usually ordered
+     * according to preference for providing the data, from most
+     * richly descriptive to least richly descriptive.<p>
+     *
+     * The DataHandler attempts to find a DataContentHandler that
+     * corresponds to the MIME type of the data. If one is located,
+     * the DataHandler calls the DataContentHandler's
+     * <code>getTransferDataFlavors</code> method. <p>
+     *
+     * If a DataContentHandler can <i>not</i> be located, and if the
+     * DataHandler was created with a DataSource (or URL), one
+     * DataFlavor is returned that represents this object's MIME type
+     * and the <code>java.io.InputStream</code> class.  If the
+     * DataHandler was created with an object and a MIME type,
+     * getTransferDataFlavors returns one DataFlavor that represents
+     * this object's MIME type and the object's class.
+     *
+     * @return  an array of data flavors in which this data can be transferred
+     * @see javax.activation.DataContentHandler#getTransferDataFlavors
+     */
+    public synchronized DataFlavor[] getTransferDataFlavors() {
+        if (factory != oldFactory) // if the factory has changed, clear cache
+            transferFlavors = emptyFlavors;
+
+        // if it's not set, set it...
+        if (transferFlavors == emptyFlavors)
+            transferFlavors = getDataContentHandler().getTransferDataFlavors();
+        return transferFlavors;
+    }
+
+    /**
+     * Returns whether the specified data flavor is supported
+     * for this object.<p>
+     *
+     * This method iterates through the DataFlavors returned from
+     * <code>getTransferDataFlavors</code>, comparing each with
+     * the specified flavor.
+     *
+     * @param flavor    the requested flavor for the data
+     * @return          true if the data flavor is supported
+     * @see javax.activation.DataHandler#getTransferDataFlavors
+     */
+    public boolean isDataFlavorSupported(DataFlavor flavor) {
+        DataFlavor[] lFlavors = getTransferDataFlavors();
+
+        for (int i = 0; i < lFlavors.length; i++) {
+            if (lFlavors[i].equals(flavor))
+                return true;
+        }
+        return false;
+    }
+
+    /**
+     * Returns an object that represents the data to be
+     * transferred. The class of the object returned is defined by the
+     * representation class of the data flavor.<p>
+     *
+     * <b>For DataHandler's created with DataSources or URLs:</b><p>
+     *
+     * The DataHandler attempts to locate a DataContentHandler
+     * for this MIME type. If one is found, the passed in DataFlavor
+     * and the type of the data are passed to its <code>getTransferData</code>
+     * method. If the DataHandler fails to locate a DataContentHandler
+     * and the flavor specifies this object's MIME type and the
+     * <code>java.io.InputStream</code> class, this object's InputStream
+     * is returned.
+     * Otherwise it throws an UnsupportedFlavorException. <p>
+     *
+     * <b>For DataHandler's created with Objects:</b><p>
+     *
+     * The DataHandler attempts to locate a DataContentHandler
+     * for this MIME type. If one is found, the passed in DataFlavor
+     * and the type of the data are passed to its getTransferData
+     * method. If the DataHandler fails to locate a DataContentHandler
+     * and the flavor specifies this object's MIME type and its class,
+     * this DataHandler's referenced object is returned.
+     * Otherwise it throws an UnsupportedFlavorException.
+     *
+     * @param flavor    the requested flavor for the data
+     * @return          the object
+     * @exception UnsupportedFlavorException    if the data could not be
+     *                  converted to the requested flavor
+     * @exception IOException   if an I/O error occurs
+     * @see javax.activation.ActivationDataFlavor
+     */
+    public Object getTransferData(DataFlavor flavor)
+                                throws UnsupportedFlavorException, IOException {
+        return getDataContentHandler().getTransferData(flavor, dataSource);
+    }
+
+    /**
+     * Set the CommandMap for use by this DataHandler.
+     * Setting it to <code>null</code> causes the CommandMap to revert
+     * to the CommandMap returned by the
+     * <code>CommandMap.getDefaultCommandMap</code> method.
+     * Changing the CommandMap, or setting it to <code>null</code>,
+     * clears out any data cached from the previous CommandMap.
+     *
+     * @param commandMap        the CommandMap to use in this DataHandler
+     *
+     * @see javax.activation.CommandMap#setDefaultCommandMap
+     */
+    public synchronized void setCommandMap(CommandMap commandMap) {
+        if (commandMap != currentCommandMap || commandMap == null) {
+            // clear cached values...
+            transferFlavors = emptyFlavors;
+            dataContentHandler = null;
+
+            currentCommandMap = commandMap;
+        }
+    }
+
+    /**
+     * Return the <i>preferred</i> commands for this type of data.
+     * This method calls the <code>getPreferredCommands</code> method
+     * in the CommandMap associated with this instance of DataHandler.
+     * This method returns an array that represents a subset of
+     * available commands. In cases where multiple commands for the
+     * MIME type represented by this DataHandler are present, the
+     * installed CommandMap chooses the appropriate commands.
+     *
+     * @return  the CommandInfo objects representing the preferred commands
+     *
+     * @see javax.activation.CommandMap#getPreferredCommands
+     */
+    public CommandInfo[] getPreferredCommands() {
+        if (dataSource != null)
+            return getCommandMap().getPreferredCommands(getBaseType(),
+                                                        dataSource);
+        else
+            return getCommandMap().getPreferredCommands(getBaseType());
+    }
+
+    /**
+     * Return all the commands for this type of data.
+     * This method returns an array containing all commands
+     * for the type of data represented by this DataHandler. The
+     * MIME type for the underlying data represented by this DataHandler
+     * is used to call through to the <code>getAllCommands</code> method
+     * of the CommandMap associated with this DataHandler.
+     *
+     * @return  the CommandInfo objects representing all the commands
+     *
+     * @see javax.activation.CommandMap#getAllCommands
+     */
+    public CommandInfo[] getAllCommands() {
+        if (dataSource != null)
+            return getCommandMap().getAllCommands(getBaseType(), dataSource);
+        else
+            return getCommandMap().getAllCommands(getBaseType());
+    }
+
+    /**
+     * Get the command <i>cmdName</i>. Use the search semantics as
+     * defined by the CommandMap installed in this DataHandler. The
+     * MIME type for the underlying data represented by this DataHandler
+     * is used to call through to the <code>getCommand</code> method
+     * of the CommandMap associated with this DataHandler.
+     *
+     * @param cmdName   the command name
+     * @return  the CommandInfo corresponding to the command
+     *
+     * @see javax.activation.CommandMap#getCommand
+     */
+    public CommandInfo getCommand(String cmdName) {
+        if (dataSource != null)
+            return getCommandMap().getCommand(getBaseType(), cmdName,
+                                                                dataSource);
+        else
+            return getCommandMap().getCommand(getBaseType(), cmdName);
+    }
+
+    /**
+     * Return the data in its preferred Object form. <p>
+     *
+     * If the DataHandler was instantiated with an object, return
+     * the object. <p>
+     *
+     * If the DataHandler was instantiated with a DataSource,
+     * this method uses a DataContentHandler to return the content
+     * object for the data represented by this DataHandler. If no
+     * <code>DataContentHandler</code> can be found for the
+     * the type of this data, the DataHandler returns an
+     * InputStream for the data.
+     *
+     * @return the content.
+     * @exception IOException if an IOException occurs during
+     *                              this operation.
+     */
+    public Object getContent() throws IOException {
+        if (object != null)
+            return object;
+        else
+            return getDataContentHandler().getContent(getDataSource());
+    }
+
+    /**
+     * A convenience method that takes a CommandInfo object
+     * and instantiates the corresponding command, usually
+     * a JavaBean component.
+     * <p>
+     * This method calls the CommandInfo's <code>getCommandObject</code>
+     * method with the <code>ClassLoader</code> used to load
+     * the <code>javax.activation.DataHandler</code> class itself.
+     *
+     * @param cmdinfo   the CommandInfo corresponding to a command
+     * @return  the instantiated command object
+     */
+    public Object getBean(CommandInfo cmdinfo) {
+        Object bean = null;
+
+        try {
+            // make the bean
+            ClassLoader cld = null;
+            // First try the "application's" class loader.
+            cld = SecuritySupport.getContextClassLoader();
+            if (cld == null)
+                cld = this.getClass().getClassLoader();
+            bean = cmdinfo.getCommandObject(this, cld);
+        } catch (IOException e) {
+        } catch (ClassNotFoundException e) { }
+
+        return bean;
+    }
+
+    /**
+     * Get the DataContentHandler for this DataHandler: <p>
+     *
+     * If a DataContentHandlerFactory is set, use it.
+     * Otherwise look for an object to serve DCH in the
+     * following order: <p>
+     *
+     * 1) if a factory is set, use it <p>
+     * 2) if a CommandMap is set, use it <p>
+     * 3) use the default CommandMap <p>
+     *
+     * In any case, wrap the real DataContentHandler with one of our own
+     * to handle any missing cases, fill in defaults, and to ensure that
+     * we always have a non-null DataContentHandler.
+     *
+     * @return  the requested DataContentHandler
+     */
+    private synchronized DataContentHandler getDataContentHandler() {
+
+        // make sure the factory didn't change
+        if (factory != oldFactory) {
+            oldFactory = factory;
+            factoryDCH = null;
+            dataContentHandler = null;
+            transferFlavors = emptyFlavors;
+        }
+
+        if (dataContentHandler != null)
+            return dataContentHandler;
+
+        String simpleMT = getBaseType();
+
+        if (factoryDCH == null && factory != null)
+            factoryDCH = factory.createDataContentHandler(simpleMT);
+
+        if (factoryDCH != null)
+            dataContentHandler = factoryDCH;
+
+        if (dataContentHandler == null) {
+            if (dataSource != null)
+                dataContentHandler = getCommandMap().
+                                createDataContentHandler(simpleMT, dataSource);
+            else
+                dataContentHandler = getCommandMap().
+                                createDataContentHandler(simpleMT);
+        }
+
+        // getDataContentHandler always uses these 'wrapper' handlers
+        // to make sure it returns SOMETHING meaningful...
+        if (dataSource != null)
+            dataContentHandler = new DataSourceDataContentHandler(
+                                                      dataContentHandler,
+                                                      dataSource);
+        else
+            dataContentHandler = new ObjectDataContentHandler(
+                                                      dataContentHandler,
+                                                      object,
+                                                      objectMimeType);
+        return dataContentHandler;
+    }
+
+    /**
+     * Use the MimeType class to extract the MIME type/subtype,
+     * ignoring the parameters.  The type is cached.
+     */
+    private synchronized String getBaseType() {
+        if (shortType == null) {
+            String ct = getContentType();
+            try {
+                MimeType mt = new MimeType(ct);
+                shortType = mt.getBaseType();
+            } catch (MimeTypeParseException e) {
+                shortType = ct;
+            }
+        }
+        return shortType;
+    }
+
+    /**
+     * Sets the DataContentHandlerFactory.  The DataContentHandlerFactory
+     * is called first to find DataContentHandlers.
+     * The DataContentHandlerFactory can only be set once.
+     * <p>
+     * If the DataContentHandlerFactory has already been set,
+     * this method throws an Error.
+     *
+     * @param newFactory        the DataContentHandlerFactory
+     * @exception Error if the factory has already been defined.
+     *
+     * @see javax.activation.DataContentHandlerFactory
+     */
+    public static synchronized void setDataContentHandlerFactory(
+                                         DataContentHandlerFactory newFactory) {
+        if (factory != null)
+            throw new Error("DataContentHandlerFactory already defined");
+
+        SecurityManager security = System.getSecurityManager();
+        if (security != null) {
+            try {
+                // if it's ok with the SecurityManager, it's ok with me...
+                security.checkSetFactory();
+            } catch (SecurityException ex) {
+                // otherwise, we also allow it if this code and the
+                // factory come from the same class loader (e.g.,
+                // the JAF classes were loaded with the applet classes).
+                if (DataHandler.class.getClassLoader() !=
+                        newFactory.getClass().getClassLoader())
+                    throw ex;
+            }
+        }
+        factory = newFactory;
+    }
+}
+
+/**
+ * The DataHanderDataSource class implements the
+ * DataSource interface when the DataHandler is constructed
+ * with an Object and a mimeType string.
+ */
+class DataHandlerDataSource implements DataSource {
+    DataHandler dataHandler = null;
+
+    /**
+     * The constructor.
+     */
+    public DataHandlerDataSource(DataHandler dh) {
+        this.dataHandler = dh;
+    }
+
+    /**
+     * Returns an <code>InputStream</code> representing this object.
+     * @return  the <code>InputStream</code>
+     */
+    public InputStream getInputStream() throws IOException {
+        return dataHandler.getInputStream();
+    }
+
+    /**
+     * Returns the <code>OutputStream</code> for this object.
+     * @return  the <code>OutputStream</code>
+     */
+    public OutputStream getOutputStream() throws IOException {
+        return dataHandler.getOutputStream();
+    }
+
+    /**
+     * Returns the MIME type of the data represented by this object.
+     * @return  the MIME type
+     */
+    public String getContentType() {
+        return dataHandler.getContentType();
+    }
+
+    /**
+     * Returns the name of this object.
+     * @return  the name of this object
+     */
+    public String getName() {
+        return dataHandler.getName(); // what else would it be?
+    }
+}
+
+/*
+ * DataSourceDataContentHandler
+ *
+ * This is a <i>private</i> DataContentHandler that wraps the real
+ * DataContentHandler in the case where the DataHandler was instantiated
+ * with a DataSource.
+ */
+class DataSourceDataContentHandler implements DataContentHandler {
+    private DataSource ds = null;
+    private DataFlavor transferFlavors[] = null;
+    private DataContentHandler dch = null;
+
+    /**
+     * The constructor.
+     */
+    public DataSourceDataContentHandler(DataContentHandler dch, DataSource ds) {
+        this.ds = ds;
+        this.dch = dch;
+    }
+
+    /**
+     * Return the DataFlavors for this <code>DataContentHandler</code>.
+     * @return  the DataFlavors
+     */
+    public DataFlavor[] getTransferDataFlavors() {
+
+        if (transferFlavors == null) {
+            if (dch != null) { // is there a dch?
+                transferFlavors = dch.getTransferDataFlavors();
+            } else {
+                transferFlavors = new DataFlavor[1];
+                transferFlavors[0] =
+                    new ActivationDataFlavor(ds.getContentType(),
+                                             ds.getContentType());
+            }
+        }
+        return transferFlavors;
+    }
+
+    /**
+     * Return the Transfer Data of type DataFlavor from InputStream.
+     * @param df        the DataFlavor
+     * @param ds        the DataSource
+     * @return          the constructed Object
+     */
+    public Object getTransferData(DataFlavor df, DataSource ds) throws
+                                UnsupportedFlavorException, IOException {
+
+        if (dch != null)
+            return dch.getTransferData(df, ds);
+        else if (df.equals(getTransferDataFlavors()[0])) // only have one now
+            return ds.getInputStream();
+        else
+            throw new UnsupportedFlavorException(df);
+    }
+
+    public Object getContent(DataSource ds) throws IOException {
+
+        if (dch != null)
+            return dch.getContent(ds);
+        else
+            return ds.getInputStream();
+    }
+
+    /**
+     * Write the object to the output stream.
+     */
+    public void writeTo(Object obj, String mimeType, OutputStream os)
+                                                throws IOException {
+        if (dch != null)
+            dch.writeTo(obj, mimeType, os);
+        else
+            throw new UnsupportedDataTypeException(
+                        "no DCH for content type " + ds.getContentType());
+    }
+}
+
+/*
+ * ObjectDataContentHandler
+ *
+ * This is a <i>private</i> DataContentHandler that wraps the real
+ * DataContentHandler in the case where the DataHandler was instantiated
+ * with an object.
+ */
+class ObjectDataContentHandler implements DataContentHandler {
+    private DataFlavor transferFlavors[] = null;
+    private Object obj;
+    private String mimeType;
+    private DataContentHandler dch = null;
+
+    /**
+     * The constructor.
+     */
+    public ObjectDataContentHandler(DataContentHandler dch,
+                                    Object obj, String mimeType) {
+        this.obj = obj;
+        this.mimeType = mimeType;
+        this.dch = dch;
+    }
+
+    /**
+     * Return the DataContentHandler for this object.
+     * Used only by the DataHandler class.
+     */
+    public DataContentHandler getDCH() {
+        return dch;
+    }
+
+    /**
+     * Return the DataFlavors for this <code>DataContentHandler</code>.
+     * @return  the DataFlavors
+     */
+    public synchronized DataFlavor[] getTransferDataFlavors() {
+        if (transferFlavors == null) {
+            if (dch != null) {
+                transferFlavors = dch.getTransferDataFlavors();
+            } else {
+                transferFlavors = new DataFlavor[1];
+                transferFlavors[0] = new ActivationDataFlavor(obj.getClass(),
+                                             mimeType, mimeType);
+            }
+        }
+        return transferFlavors;
+    }
+
+    /**
+     * Return the Transfer Data of type DataFlavor from InputStream.
+     * @param df        the DataFlavor
+     * @param ds        the DataSource
+     * @return          the constructed Object
+     */
+    public Object getTransferData(DataFlavor df, DataSource ds)
+                                throws UnsupportedFlavorException, IOException {
+
+        if (dch != null)
+            return dch.getTransferData(df, ds);
+        else if (df.equals(getTransferDataFlavors()[0])) // only have one now
+            return obj;
+        else
+            throw new UnsupportedFlavorException(df);
+
+    }
+
+    public Object getContent(DataSource ds) {
+        return obj;
+    }
+
+    /**
+     * Write the object to the output stream.
+     */
+    public void writeTo(Object obj, String mimeType, OutputStream os)
+                                                throws IOException {
+        if (dch != null)
+            dch.writeTo(obj, mimeType, os);
+        else if (obj instanceof byte[])
+            os.write((byte[])obj);
+        else if (obj instanceof String) {
+            OutputStreamWriter osw = new OutputStreamWriter(os);
+            osw.write((String)obj);
+            osw.flush();
+        } else throw new UnsupportedDataTypeException(
+                "no object DCH for MIME type " + this.mimeType);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/DataSource.java b/jaxws/src/share/classes/javax/activation/DataSource.java
new file mode 100644
index 0000000..9602d8f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/DataSource.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.io.IOException;
+
+/**
+ * The DataSource interface provides the JavaBeans Activation Framework
+ * with an abstraction of an arbitrary collection of data.  It
+ * provides a type for that data as well as access
+ * to it in the form of <code>InputStreams</code> and
+ * <code>OutputStreams</code> where appropriate.
+ *
+ * @since 1.6
+ */
+
+public interface DataSource {
+
+    /**
+     * This method returns an <code>InputStream</code> representing
+     * the data and throws the appropriate exception if it can
+     * not do so.  Note that a new <code>InputStream</code> object must be
+     * returned each time this method is called, and the stream must be
+     * positioned at the beginning of the data.
+     *
+     * @return an InputStream
+     */
+    public InputStream getInputStream() throws IOException;
+
+    /**
+     * This method returns an <code>OutputStream</code> where the
+     * data can be written and throws the appropriate exception if it can
+     * not do so.  Note that a new <code>OutputStream</code> object must
+     * be returned each time this method is called, and the stream must
+     * be positioned at the location the data is to be written.
+     *
+     * @return an OutputStream
+     */
+    public OutputStream getOutputStream() throws IOException;
+
+    /**
+     * This method returns the MIME type of the data in the form of a
+     * string. It should always return a valid type. It is suggested
+     * that getContentType return "application/octet-stream" if the
+     * DataSource implementation can not determine the data type.
+     *
+     * @return the MIME Type
+     */
+    public String getContentType();
+
+    /**
+     * Return the <i>name</i> of this object where the name of the object
+     * is dependant on the nature of the underlying objects. DataSources
+     * encapsulating files may choose to return the filename of the object.
+     * (Typically this would be the last component of the filename, not an
+     * entire pathname.)
+     *
+     * @return the name of the object.
+     */
+    public String getName();
+}
diff --git a/jaxws/src/share/classes/javax/activation/FileDataSource.java b/jaxws/src/share/classes/javax/activation/FileDataSource.java
new file mode 100644
index 0000000..964963c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/FileDataSource.java
@@ -0,0 +1,158 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.io.File;
+import java.io.FileDescriptor;
+import java.io.FileNotFoundException;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import com.sun.activation.registries.MimeTypeFile;
+
+/**
+ * The FileDataSource class implements a simple DataSource object
+ * that encapsulates a file. It provides data typing services via
+ * a FileTypeMap object. <p>
+ *
+ * <b>FileDataSource Typing Semantics</b><p>
+ *
+ * The FileDataSource class delegates data typing of files
+ * to an object subclassed from the FileTypeMap class.
+ * The <code>setFileTypeMap</code> method can be used to explicitly
+ * set the FileTypeMap for an instance of FileDataSource. If no
+ * FileTypeMap is set, the FileDataSource will call the FileTypeMap's
+ * getDefaultFileTypeMap method to get the System's default FileTypeMap.
+ *
+ * @see javax.activation.DataSource
+ * @see javax.activation.FileTypeMap
+ * @see javax.activation.MimetypesFileTypeMap
+ *
+ * @since 1.6
+ */
+public class FileDataSource implements DataSource {
+
+    // keep track of original 'ref' passed in, non-null
+    // one indicated which was passed in:
+    private File _file = null;
+    private FileTypeMap typeMap = null;
+
+    /**
+     * Creates a FileDataSource from a File object. <i>Note:
+     * The file will not actually be opened until a method is
+     * called that requires the file to be opened.</i>
+     *
+     * @param file the file
+     */
+    public FileDataSource(File file) {
+        _file = file;   // save the file Object...
+    }
+
+    /**
+     * Creates a FileDataSource from
+     * the specified path name. <i>Note:
+     * The file will not actually be opened until a method is
+     * called that requires the file to be opened.</i>
+     *
+     * @param name the system-dependent file name.
+     */
+    public FileDataSource(String name) {
+        this(new File(name));   // use the file constructor
+    }
+
+    /**
+     * This method will return an InputStream representing the
+     * the data and will throw an IOException if it can
+     * not do so. This method will return a new
+     * instance of InputStream with each invocation.
+     *
+     * @return an InputStream
+     */
+    public InputStream getInputStream() throws IOException {
+        return new FileInputStream(_file);
+    }
+
+    /**
+     * This method will return an OutputStream representing the
+     * the data and will throw an IOException if it can
+     * not do so. This method will return a new instance of
+     * OutputStream with each invocation.
+     *
+     * @return an OutputStream
+     */
+    public OutputStream getOutputStream() throws IOException {
+        return new FileOutputStream(_file);
+    }
+
+    /**
+     * This method returns the MIME type of the data in the form of a
+     * string. This method uses the currently installed FileTypeMap. If
+     * there is no FileTypeMap explictly set, the FileDataSource will
+     * call the <code>getDefaultFileTypeMap</code> method on
+     * FileTypeMap to acquire a default FileTypeMap. <i>Note: By
+     * default, the FileTypeMap used will be a MimetypesFileTypeMap.</i>
+     *
+     * @return the MIME Type
+     * @see javax.activation.FileTypeMap#getDefaultFileTypeMap
+     */
+    public String getContentType() {
+        // check to see if the type map is null?
+        if (typeMap == null)
+            return FileTypeMap.getDefaultFileTypeMap().getContentType(_file);
+        else
+            return typeMap.getContentType(_file);
+    }
+
+    /**
+     * Return the <i>name</i> of this object. The FileDataSource
+     * will return the file name of the object.
+     *
+     * @return the name of the object.
+     * @see javax.activation.DataSource
+     */
+    public String getName() {
+        return _file.getName();
+    }
+
+    /**
+     * Return the File object that corresponds to this FileDataSource.
+     * @return the File object for the file represented by this object.
+     */
+    public File getFile() {
+        return _file;
+    }
+
+    /**
+     * Set the FileTypeMap to use with this FileDataSource
+     *
+     * @param map The FileTypeMap for this object.
+     */
+    public void setFileTypeMap(FileTypeMap map) {
+        typeMap = map;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/FileTypeMap.java b/jaxws/src/share/classes/javax/activation/FileTypeMap.java
new file mode 100644
index 0000000..b57ce7c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/FileTypeMap.java
@@ -0,0 +1,118 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.File;
+
+/**
+ * The FileTypeMap is an abstract class that provides a data typing
+ * interface for files. Implementations of this class will
+ * implement the getContentType methods which will derive a content
+ * type from a file name or a File object. FileTypeMaps could use any
+ * scheme to determine the data type, from examining the file extension
+ * of a file (like the MimetypesFileTypeMap) to opening the file and
+ * trying to derive its type from the contents of the file. The
+ * FileDataSource class uses the default FileTypeMap (a MimetypesFileTypeMap
+ * unless changed) to determine the content type of files.
+ *
+ * @see javax.activation.FileTypeMap
+ * @see javax.activation.FileDataSource
+ * @see javax.activation.MimetypesFileTypeMap
+ *
+ * @since 1.6
+ */
+
+public abstract class FileTypeMap {
+
+    private static FileTypeMap defaultMap = null;
+
+    /**
+     * The default constructor.
+     */
+    public FileTypeMap() {
+        super();
+    }
+
+    /**
+     * Return the type of the file object. This method should
+     * always return a valid MIME type.
+     *
+     * @param file A file to be typed.
+     * @return The content type.
+     */
+    abstract public String getContentType(File file);
+
+    /**
+     * Return the type of the file passed in.  This method should
+     * always return a valid MIME type.
+     *
+     * @param filename the pathname of the file.
+     * @return The content type.
+     */
+    abstract public String getContentType(String filename);
+
+    /**
+     * Sets the default FileTypeMap for the system. This instance
+     * will be returned to callers of getDefaultFileTypeMap.
+     *
+     * @param map The FileTypeMap.
+     * @exception SecurityException if the caller doesn't have permission
+     *                                  to change the default
+     */
+    public static void setDefaultFileTypeMap(FileTypeMap map) {
+        SecurityManager security = System.getSecurityManager();
+        if (security != null) {
+            try {
+                // if it's ok with the SecurityManager, it's ok with me...
+                security.checkSetFactory();
+            } catch (SecurityException ex) {
+                // otherwise, we also allow it if this code and the
+                // factory come from the same class loader (e.g.,
+                // the JAF classes were loaded with the applet classes).
+                if (FileTypeMap.class.getClassLoader() !=
+                        map.getClass().getClassLoader())
+                    throw ex;
+            }
+        }
+        defaultMap = map;
+    }
+
+    /**
+     * Return the default FileTypeMap for the system.
+     * If setDefaultFileTypeMap was called, return
+     * that instance, otherwise return an instance of
+     * <code>MimetypesFileTypeMap</code>.
+     *
+     * @return The default FileTypeMap
+     * @see javax.activation.FileTypeMap#setDefaultFileTypeMap
+     */
+    public static FileTypeMap getDefaultFileTypeMap() {
+        // XXX - probably should be synchronized
+        if (defaultMap == null)
+            defaultMap = new MimetypesFileTypeMap();
+        return defaultMap;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/MailcapCommandMap.java b/jaxws/src/share/classes/javax/activation/MailcapCommandMap.java
new file mode 100644
index 0000000..f312326
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/MailcapCommandMap.java
@@ -0,0 +1,701 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package javax.activation;
+
+import java.util.*;
+import java.io.*;
+import java.net.*;
+import com.sun.activation.registries.MailcapFile;
+import com.sun.activation.registries.LogSupport;
+
+/**
+ * MailcapCommandMap extends the CommandMap
+ * abstract class. It implements a CommandMap whose configuration
+ * is based on mailcap files
+ * (<A HREF="http://www.ietf.org/rfc/rfc1524.txt">RFC 1524</A>).
+ * The MailcapCommandMap can be configured both programmatically
+ * and via configuration files.
+ * <p>
+ * <b>Mailcap file search order:</b><p>
+ * The MailcapCommandMap looks in various places in the user's
+ * system for mailcap file entries. When requests are made
+ * to search for commands in the MailcapCommandMap, it searches
+ * mailcap files in the following order:
+ * <p>
+ * <ol>
+ * <li> Programatically added entries to the MailcapCommandMap instance.
+ * <li> The file <code>.mailcap</code> in the user's home directory.
+ * <li> The file &lt;<i>java.home</i>&gt;<code>/lib/mailcap</code>.
+ * <li> The file or resources named <code>META-INF/mailcap</code>.
+ * <li> The file or resource named <code>META-INF/mailcap.default</code>
+ * (usually found only in the <code>activation.jar</code> file).
+ * </ol>
+ * <p>
+ * <b>Mailcap file format:</b><p>
+ *
+ * Mailcap files must conform to the mailcap
+ * file specification (RFC 1524, <i>A User Agent Configuration Mechanism
+ * For Multimedia Mail Format Information</i>).
+ * The file format consists of entries corresponding to
+ * particular MIME types. In general, the specification
+ * specifies <i>applications</i> for clients to use when they
+ * themselves cannot operate on the specified MIME type. The
+ * MailcapCommandMap extends this specification by using a parameter mechanism
+ * in mailcap files that allows JavaBeans(tm) components to be specified as
+ * corresponding to particular commands for a MIME type.<p>
+ *
+ * When a mailcap file is
+ * parsed, the MailcapCommandMap recognizes certain parameter signatures,
+ * specifically those parameter names that begin with <code>x-java-</code>.
+ * The MailcapCommandMap uses this signature to find
+ * command entries for inclusion into its registries.
+ * Parameter names with the form <code>x-java-&lt;name></code>
+ * are read by the MailcapCommandMap as identifying a command
+ * with the name <i>name</i>. When the <i>name</i> is <code>
+ * content-handler</code> the MailcapCommandMap recognizes the class
+ * signified by this parameter as a <i>DataContentHandler</i>.
+ * All other commands are handled generically regardless of command
+ * name. The command implementation is specified by a fully qualified
+ * class name of a JavaBean(tm) component. For example; a command for viewing
+ * some data can be specified as: <code>x-java-view=com.foo.ViewBean</code>.<p>
+ *
+ * When the command name is <code>fallback-entry</code>, the value of
+ * the command may be <code>true</code> or <code>false</code>.  An
+ * entry for a MIME type that includes a parameter of
+ * <code>x-java-fallback-entry=true</code> defines fallback commands
+ * for that MIME type that will only be used if no non-fallback entry
+ * can be found.  For example, an entry of the form <code>text/*; ;
+ * x-java-fallback-entry=true; x-java-view=com.sun.TextViewer</code>
+ * specifies a view command to be used for any text MIME type.  This
+ * view command would only be used if a non-fallback view command for
+ * the MIME type could not be found.<p>
+ *
+ * MailcapCommandMap aware mailcap files have the
+ * following general form:<p>
+ * <code>
+ * # Comments begin with a '#' and continue to the end of the line.<br>
+ * &lt;mime type>; ; &lt;parameter list><br>
+ * # Where a parameter list consists of one or more parameters,<br>
+ * # where parameters look like: x-java-view=com.sun.TextViewer<br>
+ * # and a parameter list looks like: <br>
+ * text/plain; ; x-java-view=com.sun.TextViewer; x-java-edit=com.sun.TextEdit
+ * <br>
+ * # Note that mailcap entries that do not contain 'x-java' parameters<br>
+ * # and comply to RFC 1524 are simply ignored:<br>
+ * image/gif; /usr/dt/bin/sdtimage %s<br>
+ *
+ * </code>
+ * <p>
+ *
+ * @author Bart Calder
+ * @author Bill Shannon
+ *
+ * @since 1.6
+ */
+
+public class MailcapCommandMap extends CommandMap {
+    /*
+     * We manage a collection of databases, searched in order.
+     * The default database is shared between all instances
+     * of this class.
+     * XXX - Can we safely share more databases between instances?
+     */
+    private static MailcapFile defDB = null;
+    private MailcapFile[] DB;
+    private static final int PROG = 0;  // programmatically added entries
+
+    /**
+     * The default Constructor.
+     */
+    public MailcapCommandMap() {
+        super();
+        List dbv = new ArrayList(5);    // usually 5 or less databases
+        MailcapFile mf = null;
+        dbv.add(null);          // place holder for PROG entry
+
+        LogSupport.log("MailcapCommandMap: load HOME");
+        try {
+            String user_home = System.getProperty("user.home");
+
+            if (user_home != null) {
+                String path = user_home + File.separator + ".mailcap";
+                mf = loadFile(path);
+                if (mf != null)
+                    dbv.add(mf);
+            }
+        } catch (SecurityException ex) {}
+
+        LogSupport.log("MailcapCommandMap: load SYS");
+        try {
+            // check system's home
+            String system_mailcap = System.getProperty("java.home") +
+                File.separator + "lib" + File.separator + "mailcap";
+            mf = loadFile(system_mailcap);
+            if (mf != null)
+                dbv.add(mf);
+        } catch (SecurityException ex) {}
+
+        LogSupport.log("MailcapCommandMap: load JAR");
+        // load from the app's jar file
+        loadAllResources(dbv, "META-INF/mailcap");
+
+        LogSupport.log("MailcapCommandMap: load DEF");
+        synchronized (MailcapCommandMap.class) {
+            // see if another instance has created this yet.
+            if (defDB == null)
+                defDB = loadResource("/META-INF/mailcap.default");
+        }
+
+        if (defDB != null)
+            dbv.add(defDB);
+
+        DB = new MailcapFile[dbv.size()];
+        DB = (MailcapFile[])dbv.toArray(DB);
+    }
+
+    /**
+     * Load from the named resource.
+     */
+    private MailcapFile loadResource(String name) {
+        InputStream clis = null;
+        try {
+            clis = SecuritySupport.getResourceAsStream(this.getClass(), name);
+            if (clis != null) {
+                MailcapFile mf = new MailcapFile(clis);
+                if (LogSupport.isLoggable())
+                    LogSupport.log("MailcapCommandMap: successfully loaded " +
+                        "mailcap file: " + name);
+                return mf;
+            } else {
+                if (LogSupport.isLoggable())
+                    LogSupport.log("MailcapCommandMap: not loading " +
+                        "mailcap file: " + name);
+            }
+        } catch (IOException e) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("MailcapCommandMap: can't load " + name, e);
+        } catch (SecurityException sex) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("MailcapCommandMap: can't load " + name, sex);
+        } finally {
+            try {
+                if (clis != null)
+                    clis.close();
+            } catch (IOException ex) { }        // ignore it
+        }
+        return null;
+    }
+
+    /**
+     * Load all of the named resource.
+     */
+    private void loadAllResources(List v, String name) {
+        boolean anyLoaded = false;
+        try {
+            URL[] urls;
+            ClassLoader cld = null;
+            // First try the "application's" class loader.
+            cld = SecuritySupport.getContextClassLoader();
+            if (cld == null)
+                cld = this.getClass().getClassLoader();
+            if (cld != null)
+                urls = SecuritySupport.getResources(cld, name);
+            else
+                urls = SecuritySupport.getSystemResources(name);
+            if (urls != null) {
+                if (LogSupport.isLoggable())
+                    LogSupport.log("MailcapCommandMap: getResources");
+                for (int i = 0; i < urls.length; i++) {
+                    URL url = urls[i];
+                    InputStream clis = null;
+                    if (LogSupport.isLoggable())
+                        LogSupport.log("MailcapCommandMap: URL " + url);
+                    try {
+                        clis = SecuritySupport.openStream(url);
+                        if (clis != null) {
+                            v.add(new MailcapFile(clis));
+                            anyLoaded = true;
+                            if (LogSupport.isLoggable())
+                                LogSupport.log("MailcapCommandMap: " +
+                                    "successfully loaded " +
+                                    "mailcap file from URL: " +
+                                    url);
+                        } else {
+                            if (LogSupport.isLoggable())
+                                LogSupport.log("MailcapCommandMap: " +
+                                    "not loading mailcap " +
+                                    "file from URL: " + url);
+                        }
+                    } catch (IOException ioex) {
+                        if (LogSupport.isLoggable())
+                            LogSupport.log("MailcapCommandMap: can't load " +
+                                                url, ioex);
+                    } catch (SecurityException sex) {
+                        if (LogSupport.isLoggable())
+                            LogSupport.log("MailcapCommandMap: can't load " +
+                                                url, sex);
+                    } finally {
+                        try {
+                            if (clis != null)
+                                clis.close();
+                        } catch (IOException cex) { }
+                    }
+                }
+            }
+        } catch (Exception ex) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("MailcapCommandMap: can't load " + name, ex);
+        }
+
+        // if failed to load anything, fall back to old technique, just in case
+        if (!anyLoaded) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("MailcapCommandMap: !anyLoaded");
+            MailcapFile mf = loadResource("/" + name);
+            if (mf != null)
+                v.add(mf);
+        }
+    }
+
+    /**
+     * Load from the named file.
+     */
+    private MailcapFile loadFile(String name) {
+        MailcapFile mtf = null;
+
+        try {
+            mtf = new MailcapFile(name);
+        } catch (IOException e) {
+            //  e.printStackTrace();
+        }
+        return mtf;
+    }
+
+    /**
+     * Constructor that allows the caller to specify the path
+     * of a <i>mailcap</i> file.
+     *
+     * @param fileName The name of the <i>mailcap</i> file to open
+     * @exception       IOException     if the file can't be accessed
+     */
+    public MailcapCommandMap(String fileName) throws IOException {
+        this();
+
+        if (LogSupport.isLoggable())
+            LogSupport.log("MailcapCommandMap: load PROG from " + fileName);
+        if (DB[PROG] == null) {
+            DB[PROG] = new MailcapFile(fileName);
+        }
+    }
+
+
+    /**
+     * Constructor that allows the caller to specify an <i>InputStream</i>
+     * containing a mailcap file.
+     *
+     * @param is        InputStream of the <i>mailcap</i> file to open
+     */
+    public MailcapCommandMap(InputStream is) {
+        this();
+
+        LogSupport.log("MailcapCommandMap: load PROG");
+        if (DB[PROG] == null) {
+            try {
+                DB[PROG] = new MailcapFile(is);
+            } catch (IOException ex) {
+                // XXX - should throw it
+            }
+        }
+    }
+
+    /**
+     * Get the preferred command list for a MIME Type. The MailcapCommandMap
+     * searches the mailcap files as described above under
+     * <i>Mailcap file search order</i>.<p>
+     *
+     * The result of the search is a proper subset of available
+     * commands in all mailcap files known to this instance of
+     * MailcapCommandMap.  The first entry for a particular command
+     * is considered the preferred command.
+     *
+     * @param mimeType  the MIME type
+     * @return the CommandInfo objects representing the preferred commands.
+     */
+    public synchronized CommandInfo[] getPreferredCommands(String mimeType) {
+        List cmdList = new ArrayList();
+        if (mimeType != null)
+            mimeType = mimeType.toLowerCase();
+
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            Map cmdMap = DB[i].getMailcapList(mimeType);
+            if (cmdMap != null)
+                appendPrefCmdsToList(cmdMap, cmdList);
+        }
+
+        // now add the fallback commands
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            Map cmdMap = DB[i].getMailcapFallbackList(mimeType);
+            if (cmdMap != null)
+                appendPrefCmdsToList(cmdMap, cmdList);
+        }
+
+        CommandInfo[] cmdInfos = new CommandInfo[cmdList.size()];
+        cmdInfos = (CommandInfo[])cmdList.toArray(cmdInfos);
+
+        return cmdInfos;
+    }
+
+    /**
+     * Put the commands that are in the hash table, into the list.
+     */
+    private void appendPrefCmdsToList(Map cmdHash, List cmdList) {
+        Iterator verb_enum = cmdHash.keySet().iterator();
+
+        while (verb_enum.hasNext()) {
+            String verb = (String)verb_enum.next();
+            if (!checkForVerb(cmdList, verb)) {
+                List cmdList2 = (List)cmdHash.get(verb); // get the list
+                String className = (String)cmdList2.get(0);
+                cmdList.add(new CommandInfo(verb, className));
+            }
+        }
+    }
+
+    /**
+     * Check the cmdList to see if this command exists, return
+     * true if the verb is there.
+     */
+    private boolean checkForVerb(List cmdList, String verb) {
+        Iterator ee = cmdList.iterator();
+        while (ee.hasNext()) {
+            String enum_verb =
+                (String)((CommandInfo)ee.next()).getCommandName();
+            if (enum_verb.equals(verb))
+                return true;
+        }
+        return false;
+    }
+
+    /**
+     * Get all the available commands in all mailcap files known to
+     * this instance of MailcapCommandMap for this MIME type.
+     *
+     * @param mimeType  the MIME type
+     * @return the CommandInfo objects representing all the commands.
+     */
+    public synchronized CommandInfo[] getAllCommands(String mimeType) {
+        List cmdList = new ArrayList();
+        if (mimeType != null)
+            mimeType = mimeType.toLowerCase();
+
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            Map cmdMap = DB[i].getMailcapList(mimeType);
+            if (cmdMap != null)
+                appendCmdsToList(cmdMap, cmdList);
+        }
+
+        // now add the fallback commands
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            Map cmdMap = DB[i].getMailcapFallbackList(mimeType);
+            if (cmdMap != null)
+                appendCmdsToList(cmdMap, cmdList);
+        }
+
+        CommandInfo[] cmdInfos = new CommandInfo[cmdList.size()];
+        cmdInfos = (CommandInfo[])cmdList.toArray(cmdInfos);
+
+        return cmdInfos;
+    }
+
+    /**
+     * Put the commands that are in the hash table, into the list.
+     */
+    private void appendCmdsToList(Map typeHash, List cmdList) {
+        Iterator verb_enum = typeHash.keySet().iterator();
+
+        while (verb_enum.hasNext()) {
+            String verb = (String)verb_enum.next();
+            List cmdList2 = (List)typeHash.get(verb);
+            Iterator cmd_enum = ((List)cmdList2).iterator();
+
+            while (cmd_enum.hasNext()) {
+                String cmd = (String)cmd_enum.next();
+                cmdList.add(new CommandInfo(verb, cmd));
+                // cmdList.add(0, new CommandInfo(verb, cmd));
+            }
+        }
+    }
+
+    /**
+     * Get the command corresponding to <code>cmdName</code> for the MIME type.
+     *
+     * @param mimeType  the MIME type
+     * @param cmdName   the command name
+     * @return the CommandInfo object corresponding to the command.
+     */
+    public synchronized CommandInfo getCommand(String mimeType,
+                                                        String cmdName) {
+        if (mimeType != null)
+            mimeType = mimeType.toLowerCase();
+
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            Map cmdMap = DB[i].getMailcapList(mimeType);
+            if (cmdMap != null) {
+                // get the cmd list for the cmd
+                List v = (List)cmdMap.get(cmdName);
+                if (v != null) {
+                    String cmdClassName = (String)v.get(0);
+
+                    if (cmdClassName != null)
+                        return new CommandInfo(cmdName, cmdClassName);
+                }
+            }
+        }
+
+        // now try the fallback list
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            Map cmdMap = DB[i].getMailcapFallbackList(mimeType);
+            if (cmdMap != null) {
+                // get the cmd list for the cmd
+                List v = (List)cmdMap.get(cmdName);
+                if (v != null) {
+                    String cmdClassName = (String)v.get(0);
+
+                    if (cmdClassName != null)
+                        return new CommandInfo(cmdName, cmdClassName);
+                }
+            }
+        }
+        return null;
+    }
+
+    /**
+     * Add entries to the registry.  Programmatically
+     * added entries are searched before other entries.<p>
+     *
+     * The string that is passed in should be in mailcap
+     * format.
+     *
+     * @param mail_cap a correctly formatted mailcap string
+     */
+    public synchronized void addMailcap(String mail_cap) {
+        // check to see if one exists
+        LogSupport.log("MailcapCommandMap: add to PROG");
+        if (DB[PROG] == null)
+            DB[PROG] = new MailcapFile();
+
+        DB[PROG].appendToMailcap(mail_cap);
+    }
+
+    /**
+     * Return the DataContentHandler for the specified MIME type.
+     *
+     * @param mimeType  the MIME type
+     * @return          the DataContentHandler
+     */
+    public synchronized DataContentHandler createDataContentHandler(
+                                                        String mimeType) {
+        if (LogSupport.isLoggable())
+            LogSupport.log(
+                "MailcapCommandMap: createDataContentHandler for " + mimeType);
+        if (mimeType != null)
+            mimeType = mimeType.toLowerCase();
+
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            if (LogSupport.isLoggable())
+                LogSupport.log("  search DB #" + i);
+            Map cmdMap = DB[i].getMailcapList(mimeType);
+            if (cmdMap != null) {
+                List v = (List)cmdMap.get("content-handler");
+                if (v != null) {
+                    String name = (String)v.get(0);
+                    DataContentHandler dch = getDataContentHandler(name);
+                    if (dch != null)
+                        return dch;
+                }
+            }
+        }
+
+        // now try the fallback entries
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            if (LogSupport.isLoggable())
+                LogSupport.log("  search fallback DB #" + i);
+            Map cmdMap = DB[i].getMailcapFallbackList(mimeType);
+            if (cmdMap != null) {
+                List v = (List)cmdMap.get("content-handler");
+                if (v != null) {
+                    String name = (String)v.get(0);
+                    DataContentHandler dch = getDataContentHandler(name);
+                    if (dch != null)
+                        return dch;
+                }
+            }
+        }
+        return null;
+    }
+
+    private DataContentHandler getDataContentHandler(String name) {
+        if (LogSupport.isLoggable())
+            LogSupport.log("    got content-handler");
+        if (LogSupport.isLoggable())
+            LogSupport.log("      class " + name);
+        try {
+            ClassLoader cld = null;
+            // First try the "application's" class loader.
+            cld = SecuritySupport.getContextClassLoader();
+            if (cld == null)
+                cld = this.getClass().getClassLoader();
+            Class cl = null;
+            try {
+                cl = cld.loadClass(name);
+            } catch (Exception ex) {
+                // if anything goes wrong, do it the old way
+                cl = Class.forName(name);
+            }
+            if (cl != null)             // XXX - always true?
+                return (DataContentHandler)cl.newInstance();
+        } catch (IllegalAccessException e) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("Can't load DCH " + name, e);
+        } catch (ClassNotFoundException e) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("Can't load DCH " + name, e);
+        } catch (InstantiationException e) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("Can't load DCH " + name, e);
+        }
+        return null;
+    }
+
+    /**
+     * Get all the MIME types known to this command map.
+     *
+     * @return          array of MIME types as strings
+     * @since   JAF 1.1
+     */
+    public synchronized String[] getMimeTypes() {
+        List mtList = new ArrayList();
+
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            String[] ts = DB[i].getMimeTypes();
+            if (ts != null) {
+                for (int j = 0; j < ts.length; j++) {
+                    // eliminate duplicates
+                    if (!mtList.contains(ts[j]))
+                        mtList.add(ts[j]);
+                }
+            }
+        }
+
+        String[] mts = new String[mtList.size()];
+        mts = (String[])mtList.toArray(mts);
+
+        return mts;
+    }
+
+    /**
+     * Get the native commands for the given MIME type.
+     * Returns an array of strings where each string is
+     * an entire mailcap file entry.  The application
+     * will need to parse the entry to extract the actual
+     * command as well as any attributes it needs. See
+     * <A HREF="http://www.ietf.org/rfc/rfc1524.txt">RFC 1524</A>
+     * for details of the mailcap entry syntax.  Only mailcap
+     * entries that specify a view command for the specified
+     * MIME type are returned.
+     *
+     * @return          array of native command entries
+     * @since   JAF 1.1
+     */
+    public synchronized String[] getNativeCommands(String mimeType) {
+        List cmdList = new ArrayList();
+        if (mimeType != null)
+            mimeType = mimeType.toLowerCase();
+
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            String[] cmds = DB[i].getNativeCommands(mimeType);
+            if (cmds != null) {
+                for (int j = 0; j < cmds.length; j++) {
+                    // eliminate duplicates
+                    if (!cmdList.contains(cmds[j]))
+                        cmdList.add(cmds[j]);
+                }
+            }
+        }
+
+        String[] cmds = new String[cmdList.size()];
+        cmds = (String[])cmdList.toArray(cmds);
+
+        return cmds;
+    }
+
+    /**
+     * for debugging...
+     *
+    public static void main(String[] argv) throws Exception {
+        MailcapCommandMap map = new MailcapCommandMap();
+        CommandInfo[] cmdInfo;
+
+        cmdInfo = map.getPreferredCommands(argv[0]);
+        System.out.println("Preferred Commands:");
+        for (int i = 0; i < cmdInfo.length; i++)
+            System.out.println("Command " + cmdInfo[i].getCommandName() + " [" +
+                                            cmdInfo[i].getCommandClass() + "]");
+        cmdInfo = map.getAllCommands(argv[0]);
+        System.out.println();
+        System.out.println("All Commands:");
+        for (int i = 0; i < cmdInfo.length; i++)
+            System.out.println("Command " + cmdInfo[i].getCommandName() + " [" +
+                                            cmdInfo[i].getCommandClass() + "]");
+        DataContentHandler dch = map.createDataContentHandler(argv[0]);
+        if (dch != null)
+            System.out.println("DataContentHandler " +
+                                                dch.getClass().toString());
+        System.exit(0);
+    }
+    */
+}
diff --git a/jaxws/src/share/classes/javax/activation/MimeType.java b/jaxws/src/share/classes/javax/activation/MimeType.java
new file mode 100644
index 0000000..3e309fd
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/MimeType.java
@@ -0,0 +1,343 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.ObjectOutput;
+import java.io.ObjectInput;
+import java.io.IOException;
+import java.io.*;
+
+/**
+ * A Multipurpose Internet Mail Extension (MIME) type, as defined
+ * in RFC 2045 and 2046.
+ *
+ * @since 1.6
+ */
+public class MimeType implements Externalizable {
+
+    private String    primaryType;
+    private String    subType;
+    private MimeTypeParameterList parameters;
+
+    /**
+     * A string that holds all the special chars.
+     */
+    private static final String TSPECIALS = "()<>@,;:/[]?=\\\"";
+
+    /**
+     * Default constructor.
+     */
+    public MimeType() {
+        primaryType = "application";
+        subType = "*";
+        parameters = new MimeTypeParameterList();
+    }
+
+    /**
+     * Constructor that builds a MimeType from a String.
+     *
+     * @param rawdata   the MIME type string
+     */
+    public MimeType(String rawdata) throws MimeTypeParseException {
+        parse(rawdata);
+    }
+
+    /**
+     * Constructor that builds a MimeType with the given primary and sub type
+     * but has an empty parameter list.
+     *
+     * @param primary   the primary MIME type
+     * @param sub       the MIME sub-type
+     * @exception       MimeTypeParseException  if the primary type or subtype
+     *                                          is not a valid token
+     */
+    public MimeType(String primary, String sub) throws MimeTypeParseException {
+        //    check to see if primary is valid
+        if (isValidToken(primary)) {
+            primaryType = primary.toLowerCase();
+        } else {
+            throw new MimeTypeParseException("Primary type is invalid.");
+        }
+
+        //    check to see if sub is valid
+        if (isValidToken(sub)) {
+            subType = sub.toLowerCase();
+        } else {
+            throw new MimeTypeParseException("Sub type is invalid.");
+        }
+
+        parameters = new MimeTypeParameterList();
+    }
+
+    /**
+     * A routine for parsing the MIME type out of a String.
+     */
+    private void parse(String rawdata) throws MimeTypeParseException {
+        int slashIndex = rawdata.indexOf('/');
+        int semIndex = rawdata.indexOf(';');
+        if ((slashIndex < 0) && (semIndex < 0)) {
+            //    neither character is present, so treat it
+            //    as an error
+            throw new MimeTypeParseException("Unable to find a sub type.");
+        } else if ((slashIndex < 0) && (semIndex >= 0)) {
+            //    we have a ';' (and therefore a parameter list),
+            //    but no '/' indicating a sub type is present
+            throw new MimeTypeParseException("Unable to find a sub type.");
+        } else if ((slashIndex >= 0) && (semIndex < 0)) {
+            //    we have a primary and sub type but no parameter list
+            primaryType = rawdata.substring(0, slashIndex).trim().toLowerCase();
+            subType = rawdata.substring(slashIndex + 1).trim().toLowerCase();
+            parameters = new MimeTypeParameterList();
+        } else if (slashIndex < semIndex) {
+            //    we have all three items in the proper sequence
+            primaryType = rawdata.substring(0, slashIndex).trim().toLowerCase();
+            subType = rawdata.substring(slashIndex + 1,
+                                                semIndex).trim().toLowerCase();
+            parameters = new MimeTypeParameterList(rawdata.substring(semIndex));
+        } else {
+            // we have a ';' lexically before a '/' which means we
+            // have a primary type and a parameter list but no sub type
+            throw new MimeTypeParseException("Unable to find a sub type.");
+        }
+
+        //    now validate the primary and sub types
+
+        //    check to see if primary is valid
+        if (!isValidToken(primaryType))
+            throw new MimeTypeParseException("Primary type is invalid.");
+
+        //    check to see if sub is valid
+        if (!isValidToken(subType))
+            throw new MimeTypeParseException("Sub type is invalid.");
+    }
+
+    /**
+     * Retrieve the primary type of this object.
+     *
+     * @return  the primary MIME type
+     */
+    public String getPrimaryType() {
+        return primaryType;
+    }
+
+    /**
+     * Set the primary type for this object to the given String.
+     *
+     * @param primary   the primary MIME type
+     * @exception       MimeTypeParseException  if the primary type
+     *                                          is not a valid token
+     */
+    public void setPrimaryType(String primary) throws MimeTypeParseException {
+        //    check to see if primary is valid
+        if (!isValidToken(primaryType))
+            throw new MimeTypeParseException("Primary type is invalid.");
+        primaryType = primary.toLowerCase();
+    }
+
+    /**
+     * Retrieve the subtype of this object.
+     *
+     * @return  the MIME subtype
+     */
+    public String getSubType() {
+        return subType;
+    }
+
+    /**
+     * Set the subtype for this object to the given String.
+     *
+     * @param sub       the MIME subtype
+     * @exception       MimeTypeParseException  if the subtype
+     *                                          is not a valid token
+     */
+    public void setSubType(String sub) throws MimeTypeParseException {
+        //    check to see if sub is valid
+        if (!isValidToken(subType))
+            throw new MimeTypeParseException("Sub type is invalid.");
+        subType = sub.toLowerCase();
+    }
+
+    /**
+     * Retrieve this object's parameter list.
+     *
+     * @return  a MimeTypeParameterList object representing the parameters
+     */
+    public MimeTypeParameterList getParameters() {
+        return parameters;
+    }
+
+    /**
+     * Retrieve the value associated with the given name, or null if there
+     * is no current association.
+     *
+     * @param name      the parameter name
+     * @return          the paramter's value
+     */
+    public String getParameter(String name) {
+        return parameters.get(name);
+    }
+
+    /**
+     * Set the value to be associated with the given name, replacing
+     * any previous association.
+     *
+     * @param name      the parameter name
+     * @param value     the paramter's value
+     */
+    public void setParameter(String name, String value) {
+        parameters.set(name, value);
+    }
+
+    /**
+     * Remove any value associated with the given name.
+     *
+     * @param name      the parameter name
+     */
+    public void removeParameter(String name) {
+        parameters.remove(name);
+    }
+
+    /**
+     * Return the String representation of this object.
+     */
+    public String toString() {
+        return getBaseType() + parameters.toString();
+    }
+
+    /**
+     * Return a String representation of this object
+     * without the parameter list.
+     *
+     * @return  the MIME type and sub-type
+     */
+    public String getBaseType() {
+        return primaryType + "/" + subType;
+    }
+
+    /**
+     * Determine if the primary and sub type of this object is
+     * the same as what is in the given type.
+     *
+     * @param type      the MimeType object to compare with
+     * @return          true if they match
+     */
+    public boolean match(MimeType type) {
+        return primaryType.equals(type.getPrimaryType())
+                    && (subType.equals("*")
+                            || type.getSubType().equals("*")
+                            || (subType.equals(type.getSubType())));
+    }
+
+    /**
+     * Determine if the primary and sub type of this object is
+     * the same as the content type described in rawdata.
+     *
+     * @param rawdata   the MIME type string to compare with
+     * @return          true if they match
+     */
+    public boolean match(String rawdata) throws MimeTypeParseException {
+        return match(new MimeType(rawdata));
+    }
+
+    /**
+     * The object implements the writeExternal method to save its contents
+     * by calling the methods of DataOutput for its primitive values or
+     * calling the writeObject method of ObjectOutput for objects, strings
+     * and arrays.
+     *
+     * @param out       the ObjectOutput object to write to
+     * @exception IOException Includes any I/O exceptions that may occur
+     */
+    public void writeExternal(ObjectOutput out) throws IOException {
+        out.writeUTF(toString());
+        out.flush();
+    }
+
+    /**
+     * The object implements the readExternal method to restore its
+     * contents by calling the methods of DataInput for primitive
+     * types and readObject for objects, strings and arrays.  The
+     * readExternal method must read the values in the same sequence
+     * and with the same types as were written by writeExternal.
+     *
+     * @param in        the ObjectInput object to read from
+     * @exception ClassNotFoundException If the class for an object being
+     *              restored cannot be found.
+     */
+    public void readExternal(ObjectInput in)
+                                throws IOException, ClassNotFoundException {
+        try {
+            parse(in.readUTF());
+        } catch (MimeTypeParseException e) {
+            throw new IOException(e.toString());
+        }
+    }
+
+    //    below here be scary parsing related things
+
+    /**
+     * Determine whether or not a given character belongs to a legal token.
+     */
+    private static boolean isTokenChar(char c) {
+        return ((c > 040) && (c < 0177)) && (TSPECIALS.indexOf(c) < 0);
+    }
+
+    /**
+     * Determine whether or not a given string is a legal token.
+     */
+    private boolean isValidToken(String s) {
+        int len = s.length();
+        if (len > 0) {
+            for (int i = 0; i < len; ++i) {
+                char c = s.charAt(i);
+                if (!isTokenChar(c)) {
+                    return false;
+                }
+            }
+            return true;
+        } else {
+            return false;
+        }
+    }
+
+    /**
+     * A simple parser test,
+     * for debugging...
+     *
+    public static void main(String[] args)
+                                throws MimeTypeParseException, IOException {
+        for (int i = 0; i < args.length; ++i) {
+            System.out.println("Original: " + args[i]);
+
+            MimeType type = new MimeType(args[i]);
+
+            System.out.println("Short:    " + type.getBaseType());
+            System.out.println("Parsed:   " + type.toString());
+            System.out.println();
+        }
+    }
+    */
+}
diff --git a/jaxws/src/share/classes/javax/activation/MimeTypeParameterList.java b/jaxws/src/share/classes/javax/activation/MimeTypeParameterList.java
new file mode 100644
index 0000000..e4033dc
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/MimeTypeParameterList.java
@@ -0,0 +1,337 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.util.Hashtable;
+import java.util.Enumeration;
+
+/**
+ * A parameter list of a MimeType
+ * as defined in RFC 2045 and 2046. The Primary type of the
+ * object must already be stripped off.
+ *
+ * @see javax.activation.MimeType
+ *
+ * @since 1.6
+ */
+public class MimeTypeParameterList {
+    private Hashtable parameters;
+
+    /**
+     * A string that holds all the special chars.
+     */
+    private static final String TSPECIALS = "()<>@,;:/[]?=\\\"";
+
+
+    /**
+     * Default constructor.
+     */
+    public MimeTypeParameterList() {
+        parameters = new Hashtable();
+    }
+
+    /**
+     * Constructs a new MimeTypeParameterList with the passed in data.
+     *
+     * @param parameterList an RFC 2045, 2046 compliant parameter list.
+     */
+    public MimeTypeParameterList(String parameterList)
+                                        throws MimeTypeParseException {
+        parameters = new Hashtable();
+
+        //    now parse rawdata
+        parse(parameterList);
+    }
+
+    /**
+     * A routine for parsing the parameter list out of a String.
+     *
+     * @param parameterList an RFC 2045, 2046 compliant parameter list.
+     */
+    protected void parse(String parameterList) throws MimeTypeParseException {
+        if (parameterList == null)
+            return;
+
+        int length = parameterList.length();
+        if (length <= 0)
+            return;
+
+        int i;
+        char c;
+        for (i = skipWhiteSpace(parameterList, 0);
+                i < length && (c = parameterList.charAt(i)) == ';';
+                i = skipWhiteSpace(parameterList, i)) {
+            int lastIndex;
+            String name;
+            String value;
+
+            //    eat the ';'
+            i++;
+
+            //    now parse the parameter name
+
+            //    skip whitespace
+            i = skipWhiteSpace(parameterList, i);
+
+            // tolerate trailing semicolon, even though it violates the spec
+            if (i >= length)
+                return;
+
+            //    find the end of the token char run
+            lastIndex = i;
+            while ((i < length) && isTokenChar(parameterList.charAt(i)))
+                i++;
+
+            name = parameterList.substring(lastIndex, i).toLowerCase();
+
+            //    now parse the '=' that separates the name from the value
+            i = skipWhiteSpace(parameterList, i);
+
+            if (i >= length || parameterList.charAt(i) != '=')
+                throw new MimeTypeParseException(
+                    "Couldn't find the '=' that separates a " +
+                    "parameter name from its value.");
+
+            //    eat it and parse the parameter value
+            i++;
+            i = skipWhiteSpace(parameterList, i);
+
+            if (i >= length)
+                throw new MimeTypeParseException(
+                        "Couldn't find a value for parameter named " + name);
+
+            //    now find out whether or not we have a quoted value
+            c = parameterList.charAt(i);
+            if (c == '"') {
+                //    yup it's quoted so eat it and capture the quoted string
+                i++;
+                if (i >= length)
+                    throw new MimeTypeParseException(
+                            "Encountered unterminated quoted parameter value.");
+
+                lastIndex = i;
+
+                //    find the next unescaped quote
+                while (i < length) {
+                    c = parameterList.charAt(i);
+                    if (c == '"')
+                        break;
+                    if (c == '\\') {
+                        //    found an escape sequence
+                        //    so skip this and the
+                        //    next character
+                        i++;
+                    }
+                    i++;
+                }
+                if (c != '"')
+                    throw new MimeTypeParseException(
+                        "Encountered unterminated quoted parameter value.");
+
+                value = unquote(parameterList.substring(lastIndex, i));
+                //    eat the quote
+                i++;
+            } else if (isTokenChar(c)) {
+                //    nope it's an ordinary token so it
+                //    ends with a non-token char
+                lastIndex = i;
+                while (i < length && isTokenChar(parameterList.charAt(i)))
+                    i++;
+                value = parameterList.substring(lastIndex, i);
+            } else {
+                //    it ain't a value
+                throw new MimeTypeParseException(
+                        "Unexpected character encountered at index " + i);
+            }
+
+            //    now put the data into the hashtable
+            parameters.put(name, value);
+        }
+        if (i < length) {
+            throw new MimeTypeParseException(
+                "More characters encountered in input than expected.");
+        }
+    }
+
+    /**
+     * Return the number of name-value pairs in this list.
+     *
+     * @return  the number of parameters
+     */
+    public int size() {
+        return parameters.size();
+    }
+
+    /**
+     * Determine whether or not this list is empty.
+     *
+     * @return  true if there are no parameters
+     */
+    public boolean isEmpty() {
+        return parameters.isEmpty();
+    }
+
+    /**
+     * Retrieve the value associated with the given name, or null if there
+     * is no current association.
+     *
+     * @param name      the parameter name
+     * @return          the parameter's value
+     */
+    public String get(String name) {
+        return (String)parameters.get(name.trim().toLowerCase());
+    }
+
+    /**
+     * Set the value to be associated with the given name, replacing
+     * any previous association.
+     *
+     * @param name      the parameter name
+     * @param value     the parameter's value
+     */
+    public void set(String name, String value) {
+        parameters.put(name.trim().toLowerCase(), value);
+    }
+
+    /**
+     * Remove any value associated with the given name.
+     *
+     * @param name      the parameter name
+     */
+    public void remove(String name) {
+        parameters.remove(name.trim().toLowerCase());
+    }
+
+    /**
+     * Retrieve an enumeration of all the names in this list.
+     *
+     * @return  an enumeration of all parameter names
+     */
+    public Enumeration getNames() {
+        return parameters.keys();
+    }
+
+    /**
+     * Return a string representation of this object.
+     */
+    public String toString() {
+        StringBuffer buffer = new StringBuffer();
+        buffer.ensureCapacity(parameters.size() * 16);
+                        //    heuristic: 8 characters per field
+
+        Enumeration keys = parameters.keys();
+        while (keys.hasMoreElements()) {
+            String key = (String)keys.nextElement();
+            buffer.append("; ");
+            buffer.append(key);
+            buffer.append('=');
+            buffer.append(quote((String)parameters.get(key)));
+        }
+
+        return buffer.toString();
+    }
+
+    //    below here be scary parsing related things
+
+    /**
+     * Determine whether or not a given character belongs to a legal token.
+     */
+    private static boolean isTokenChar(char c) {
+        return ((c > 040) && (c < 0177)) && (TSPECIALS.indexOf(c) < 0);
+    }
+
+    /**
+     * return the index of the first non white space character in
+     * rawdata at or after index i.
+     */
+    private static int skipWhiteSpace(String rawdata, int i) {
+        int length = rawdata.length();
+        while ((i < length) && Character.isWhitespace(rawdata.charAt(i)))
+            i++;
+        return i;
+    }
+
+    /**
+     * A routine that knows how and when to quote and escape the given value.
+     */
+    private static String quote(String value) {
+        boolean needsQuotes = false;
+
+        //    check to see if we actually have to quote this thing
+        int length = value.length();
+        for (int i = 0; (i < length) && !needsQuotes; i++) {
+            needsQuotes = !isTokenChar(value.charAt(i));
+        }
+
+        if (needsQuotes) {
+            StringBuffer buffer = new StringBuffer();
+            buffer.ensureCapacity((int)(length * 1.5));
+
+            //    add the initial quote
+            buffer.append('"');
+
+            //    add the properly escaped text
+            for (int i = 0; i < length; ++i) {
+                char c = value.charAt(i);
+                if ((c == '\\') || (c == '"'))
+                    buffer.append('\\');
+                buffer.append(c);
+            }
+
+            //    add the closing quote
+            buffer.append('"');
+
+            return buffer.toString();
+        } else {
+            return value;
+        }
+    }
+
+    /**
+     * A routine that knows how to strip the quotes and
+     * escape sequences from the given value.
+     */
+    private static String unquote(String value) {
+        int valueLength = value.length();
+        StringBuffer buffer = new StringBuffer();
+        buffer.ensureCapacity(valueLength);
+
+        boolean escaped = false;
+        for (int i = 0; i < valueLength; ++i) {
+            char currentChar = value.charAt(i);
+            if (!escaped && (currentChar != '\\')) {
+                buffer.append(currentChar);
+            } else if (escaped) {
+                buffer.append(currentChar);
+                escaped = false;
+            } else {
+                escaped = true;
+            }
+        }
+
+        return buffer.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/MimeTypeParseException.java b/jaxws/src/share/classes/javax/activation/MimeTypeParseException.java
new file mode 100644
index 0000000..c265403
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/MimeTypeParseException.java
@@ -0,0 +1,50 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+/**
+ * A class to encapsulate MimeType parsing related exceptions.
+ *
+ * @since 1.6
+ */
+public class MimeTypeParseException extends Exception {
+
+    /**
+     * Constructs a MimeTypeParseException with no specified detail message.
+     */
+    public MimeTypeParseException() {
+        super();
+    }
+
+    /**
+     * Constructs a MimeTypeParseException with the specified detail message.
+     *
+     * @param   s   the detail message.
+     */
+    public MimeTypeParseException(String s) {
+        super(s);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/MimetypesFileTypeMap.java b/jaxws/src/share/classes/javax/activation/MimetypesFileTypeMap.java
new file mode 100644
index 0000000..6a8150a
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/MimetypesFileTypeMap.java
@@ -0,0 +1,336 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.*;
+import java.net.*;
+import java.util.*;
+import com.sun.activation.registries.MimeTypeFile;
+import com.sun.activation.registries.LogSupport;
+
+/**
+ * This class extends FileTypeMap and provides data typing of files
+ * via their file extension. It uses the <code>.mime.types</code> format. <p>
+ *
+ * <b>MIME types file search order:</b><p>
+ * The MimetypesFileTypeMap looks in various places in the user's
+ * system for MIME types file entries. When requests are made
+ * to search for MIME types in the MimetypesFileTypeMap, it searches
+ * MIME types files in the following order:
+ * <p>
+ * <ol>
+ * <li> Programmatically added entries to the MimetypesFileTypeMap instance.
+ * <li> The file <code>.mime.types</code> in the user's home directory.
+ * <li> The file &lt;<i>java.home</i>&gt;<code>/lib/mime.types</code>.
+ * <li> The file or resources named <code>META-INF/mime.types</code>.
+ * <li> The file or resource named <code>META-INF/mimetypes.default</code>
+ * (usually found only in the <code>activation.jar</code> file).
+ * </ol>
+ * <p>
+ * <b>MIME types file format:</b><p>
+ *
+ * <code>
+ * # comments begin with a '#'<br>
+ * # the format is &lt;mime type> &lt;space separated file extensions><br>
+ * # for example:<br>
+ * text/plain    txt text TXT<br>
+ * # this would map file.txt, file.text, and file.TXT to<br>
+ * # the mime type "text/plain"<br>
+ * </code>
+ *
+ * @author Bart Calder
+ * @author Bill Shannon
+ *
+ * @since 1.6
+ */
+public class MimetypesFileTypeMap extends FileTypeMap {
+    /*
+     * We manage a collection of databases, searched in order.
+     * The default database is shared between all instances
+     * of this class.
+     * XXX - Can we safely share more databases between instances?
+     */
+    private static MimeTypeFile defDB = null;
+    private MimeTypeFile[] DB;
+    private static final int PROG = 0;  // programmatically added entries
+
+    private static String defaultType = "application/octet-stream";
+
+    /**
+     * The default constructor.
+     */
+    public MimetypesFileTypeMap() {
+        Vector dbv = new Vector(5);     // usually 5 or less databases
+        MimeTypeFile mf = null;
+        dbv.addElement(null);           // place holder for PROG entry
+
+        LogSupport.log("MimetypesFileTypeMap: load HOME");
+        try {
+            String user_home = System.getProperty("user.home");
+
+            if (user_home != null) {
+                String path = user_home + File.separator + ".mime.types";
+                mf = loadFile(path);
+                if (mf != null)
+                    dbv.addElement(mf);
+            }
+        } catch (SecurityException ex) {}
+
+        LogSupport.log("MimetypesFileTypeMap: load SYS");
+        try {
+            // check system's home
+            String system_mimetypes = System.getProperty("java.home") +
+                File.separator + "lib" + File.separator + "mime.types";
+            mf = loadFile(system_mimetypes);
+            if (mf != null)
+                dbv.addElement(mf);
+        } catch (SecurityException ex) {}
+
+        LogSupport.log("MimetypesFileTypeMap: load JAR");
+        // load from the app's jar file
+        loadAllResources(dbv, "META-INF/mime.types");
+
+        LogSupport.log("MimetypesFileTypeMap: load DEF");
+        synchronized (MimetypesFileTypeMap.class) {
+            // see if another instance has created this yet.
+            if (defDB == null)
+                defDB = loadResource("/META-INF/mimetypes.default");
+        }
+
+        if (defDB != null)
+            dbv.addElement(defDB);
+
+        DB = new MimeTypeFile[dbv.size()];
+        dbv.copyInto(DB);
+    }
+
+    /**
+     * Load from the named resource.
+     */
+    private MimeTypeFile loadResource(String name) {
+        InputStream clis = null;
+        try {
+            clis = SecuritySupport.getResourceAsStream(this.getClass(), name);
+            if (clis != null) {
+                MimeTypeFile mf = new MimeTypeFile(clis);
+                if (LogSupport.isLoggable())
+                    LogSupport.log("MimetypesFileTypeMap: successfully " +
+                        "loaded mime types file: " + name);
+                return mf;
+            } else {
+                if (LogSupport.isLoggable())
+                    LogSupport.log("MimetypesFileTypeMap: not loading " +
+                        "mime types file: " + name);
+            }
+        } catch (IOException e) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("MimetypesFileTypeMap: can't load " + name, e);
+        } catch (SecurityException sex) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("MimetypesFileTypeMap: can't load " + name, sex);
+        } finally {
+            try {
+                if (clis != null)
+                    clis.close();
+            } catch (IOException ex) { }        // ignore it
+        }
+        return null;
+    }
+
+    /**
+     * Load all of the named resource.
+     */
+    private void loadAllResources(Vector v, String name) {
+        boolean anyLoaded = false;
+        try {
+            URL[] urls;
+            ClassLoader cld = null;
+            // First try the "application's" class loader.
+            cld = SecuritySupport.getContextClassLoader();
+            if (cld == null)
+                cld = this.getClass().getClassLoader();
+            if (cld != null)
+                urls = SecuritySupport.getResources(cld, name);
+            else
+                urls = SecuritySupport.getSystemResources(name);
+            if (urls != null) {
+                if (LogSupport.isLoggable())
+                    LogSupport.log("MimetypesFileTypeMap: getResources");
+                for (int i = 0; i < urls.length; i++) {
+                    URL url = urls[i];
+                    InputStream clis = null;
+                    if (LogSupport.isLoggable())
+                        LogSupport.log("MimetypesFileTypeMap: URL " + url);
+                    try {
+                        clis = SecuritySupport.openStream(url);
+                        if (clis != null) {
+                            v.addElement(new MimeTypeFile(clis));
+                            anyLoaded = true;
+                            if (LogSupport.isLoggable())
+                                LogSupport.log("MimetypesFileTypeMap: " +
+                                    "successfully loaded " +
+                                    "mime types from URL: " + url);
+                        } else {
+                            if (LogSupport.isLoggable())
+                                LogSupport.log("MimetypesFileTypeMap: " +
+                                    "not loading " +
+                                    "mime types from URL: " + url);
+                        }
+                    } catch (IOException ioex) {
+                        if (LogSupport.isLoggable())
+                            LogSupport.log("MimetypesFileTypeMap: can't load " +
+                                                url, ioex);
+                    } catch (SecurityException sex) {
+                        if (LogSupport.isLoggable())
+                            LogSupport.log("MimetypesFileTypeMap: can't load " +
+                                                url, sex);
+                    } finally {
+                        try {
+                            if (clis != null)
+                                clis.close();
+                        } catch (IOException cex) { }
+                    }
+                }
+            }
+        } catch (Exception ex) {
+            if (LogSupport.isLoggable())
+                LogSupport.log("MimetypesFileTypeMap: can't load " + name, ex);
+        }
+
+        // if failed to load anything, fall back to old technique, just in case
+        if (!anyLoaded) {
+            LogSupport.log("MimetypesFileTypeMap: !anyLoaded");
+            MimeTypeFile mf = loadResource("/" + name);
+            if (mf != null)
+                v.addElement(mf);
+        }
+    }
+
+    /**
+     * Load the named file.
+     */
+    private MimeTypeFile loadFile(String name) {
+        MimeTypeFile mtf = null;
+
+        try {
+            mtf = new MimeTypeFile(name);
+        } catch (IOException e) {
+            //  e.printStackTrace();
+        }
+        return mtf;
+    }
+
+    /**
+     * Construct a MimetypesFileTypeMap with programmatic entries
+     * added from the named file.
+     *
+     * @param mimeTypeFileName  the file name
+     */
+    public MimetypesFileTypeMap(String mimeTypeFileName) throws IOException {
+        this();
+        DB[PROG] = new MimeTypeFile(mimeTypeFileName);
+    }
+
+    /**
+     * Construct a MimetypesFileTypeMap with programmatic entries
+     * added from the InputStream.
+     *
+     * @param is        the input stream to read from
+     */
+    public MimetypesFileTypeMap(InputStream is) {
+        this();
+        try {
+            DB[PROG] = new MimeTypeFile(is);
+        } catch (IOException ex) {
+            // XXX - really should throw it
+        }
+    }
+
+    /**
+     * Prepend the MIME type values to the registry.
+     *
+     * @param mime_types A .mime.types formatted string of entries.
+     */
+    public synchronized void addMimeTypes(String mime_types) {
+        // check to see if we have created the registry
+        if (DB[PROG] == null)
+            DB[PROG] = new MimeTypeFile(); // make one
+
+        DB[PROG].appendToRegistry(mime_types);
+    }
+
+    /**
+     * Return the MIME type of the file object.
+     * The implementation in this class calls
+     * <code>getContentType(f.getName())</code>.
+     *
+     * @param f the file
+     * @return  the file's MIME type
+     */
+    public String getContentType(File f) {
+        return this.getContentType(f.getName());
+    }
+
+    /**
+     * Return the MIME type based on the specified file name.
+     * The MIME type entries are searched as described above under
+     * <i>MIME types file search order</i>.
+     * If no entry is found, the type "application/octet-stream" is returned.
+     *
+     * @param filename  the file name
+     * @return          the file's MIME type
+     */
+    public synchronized String getContentType(String filename) {
+        int dot_pos = filename.lastIndexOf("."); // period index
+
+        if (dot_pos < 0)
+            return defaultType;
+
+        String file_ext = filename.substring(dot_pos + 1);
+        if (file_ext.length() == 0)
+            return defaultType;
+
+        for (int i = 0; i < DB.length; i++) {
+            if (DB[i] == null)
+                continue;
+            String result = DB[i].getMIMETypeString(file_ext);
+            if (result != null)
+                return result;
+        }
+        return defaultType;
+    }
+
+    /**
+     * for debugging...
+     *
+    public static void main(String[] argv) throws Exception {
+        MimetypesFileTypeMap map = new MimetypesFileTypeMap();
+        System.out.println("File " + argv[0] + " has MIME type " +
+                                                map.getContentType(argv[0]));
+        System.exit(0);
+    }
+    */
+}
diff --git a/jaxws/src/share/classes/javax/activation/SecuritySupport.java b/jaxws/src/share/classes/javax/activation/SecuritySupport.java
new file mode 100644
index 0000000..7ebbb04
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/SecuritySupport.java
@@ -0,0 +1,131 @@
+/*
+ * Copyright 2002-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.security.*;
+import java.net.*;
+import java.io.*;
+import java.util.*;
+
+/**
+ * Security related methods that only work on J2SE 1.2 and newer.
+ *
+ * @since 1.6
+ */
+class SecuritySupport {
+
+    private SecuritySupport() {
+        // private constructor, can't create an instance
+    }
+
+    public static ClassLoader getContextClassLoader() {
+        return (ClassLoader)
+                AccessController.doPrivileged(new PrivilegedAction() {
+            public Object run() {
+                ClassLoader cl = null;
+                try {
+                    cl = Thread.currentThread().getContextClassLoader();
+                } catch (SecurityException ex) { }
+                return cl;
+            }
+        });
+    }
+
+    public static InputStream getResourceAsStream(final Class c,
+                                final String name) throws IOException {
+        try {
+            return (InputStream)
+                AccessController.doPrivileged(new PrivilegedExceptionAction() {
+                    public Object run() throws IOException {
+                        return c.getResourceAsStream(name);
+                    }
+                });
+        } catch (PrivilegedActionException e) {
+            throw (IOException)e.getException();
+        }
+    }
+
+    public static URL[] getResources(final ClassLoader cl, final String name) {
+        return (URL[])
+                AccessController.doPrivileged(new PrivilegedAction() {
+            public Object run() {
+                URL[] ret = null;
+                try {
+                    List v = new ArrayList();
+                    Enumeration e = cl.getResources(name);
+                    while (e != null && e.hasMoreElements()) {
+                        URL url = (URL)e.nextElement();
+                        if (url != null)
+                            v.add(url);
+                    }
+                    if (v.size() > 0) {
+                        ret = new URL[v.size()];
+                        ret = (URL[])v.toArray(ret);
+                    }
+                } catch (IOException ioex) {
+                } catch (SecurityException ex) { }
+                return ret;
+            }
+        });
+    }
+
+    public static URL[] getSystemResources(final String name) {
+        return (URL[])
+                AccessController.doPrivileged(new PrivilegedAction() {
+            public Object run() {
+                URL[] ret = null;
+                try {
+                    List v = new ArrayList();
+                    Enumeration e = ClassLoader.getSystemResources(name);
+                    while (e != null && e.hasMoreElements()) {
+                        URL url = (URL)e.nextElement();
+                        if (url != null)
+                            v.add(url);
+                    }
+                    if (v.size() > 0) {
+                        ret = new URL[v.size()];
+                        ret = (URL[])v.toArray(ret);
+                    }
+                } catch (IOException ioex) {
+                } catch (SecurityException ex) { }
+                return ret;
+            }
+        });
+    }
+
+    public static InputStream openStream(final URL url) throws IOException {
+        try {
+            return (InputStream)
+                AccessController.doPrivileged(new PrivilegedExceptionAction() {
+                    public Object run() throws IOException {
+                        return url.openStream();
+                    }
+                });
+        } catch (PrivilegedActionException e) {
+            throw (IOException)e.getException();
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/URLDataSource.java b/jaxws/src/share/classes/javax/activation/URLDataSource.java
new file mode 100644
index 0000000..c62a012
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/URLDataSource.java
@@ -0,0 +1,137 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.net.URL;
+import java.net.URLConnection;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.io.IOException;
+
+/**
+ * The URLDataSource class provides an object that wraps a <code>URL</code>
+ * object in a DataSource interface. URLDataSource simplifies the handling
+ * of data described by URLs within the JavaBeans Activation Framework
+ * because this class can be used to create new DataHandlers. <i>NOTE: The
+ * DataHandler object creates a URLDataSource internally,
+ * when it is constructed with a URL.</i>
+ *
+ * @see javax.activation.DataSource
+ * @see javax.activation.DataHandler
+ *
+ * @since 1.6
+ */
+public class URLDataSource implements DataSource {
+    private URL url = null;
+    private URLConnection url_conn = null;
+
+    /**
+     * URLDataSource constructor. The URLDataSource class will
+     * not open a connection to the URL until a method requiring it
+     * to do so is called.
+     *
+     * @param url The URL to be encapsulated in this object.
+     */
+    public URLDataSource(URL url) {
+        this.url = url;
+    }
+
+    /**
+     * Returns the value of the URL content-type header field.
+     * It calls the URL's <code>URLConnection.getContentType</code> method
+     * after retrieving a URLConnection object.
+     * <i>Note: this method attempts to call the <code>openConnection</code>
+     * method on the URL. If this method fails, or if a content type is not
+     * returned from the URLConnection, getContentType returns
+     * "application/octet-stream" as the content type.</i>
+     *
+     * @return the content type.
+     */
+    public String getContentType() {
+        String type = null;
+
+        try {
+            if (url_conn == null)
+                url_conn = url.openConnection();
+        } catch (IOException e) { }
+
+        if (url_conn != null)
+            type = url_conn.getContentType();
+
+        if (type == null)
+            type = "application/octet-stream";
+
+        return type;
+    }
+
+    /**
+     * Calls the <code>getFile</code> method on the URL used to
+     * instantiate the object.
+     *
+     * @return the result of calling the URL's getFile method.
+     */
+    public String getName() {
+        return url.getFile();
+    }
+
+    /**
+     * The getInputStream method from the URL. Calls the
+     * <code>openStream</code> method on the URL.
+     *
+     * @return the InputStream.
+     */
+    public InputStream getInputStream() throws IOException {
+        return url.openStream();
+    }
+
+    /**
+     * The getOutputStream method from the URL. First an attempt is
+     * made to get the URLConnection object for the URL. If that
+     * succeeds, the getOutputStream method on the URLConnection
+     * is returned.
+     *
+     * @return the OutputStream.
+     */
+    public OutputStream getOutputStream() throws IOException {
+        // get the url connection if it is available
+        url_conn = url.openConnection();
+
+        if (url_conn != null) {
+            url_conn.setDoOutput(true);
+            return url_conn.getOutputStream();
+        } else
+            return null;
+    }
+
+    /**
+     * Return the URL used to create this DataSource.
+     *
+     * @return The URL.
+     */
+    public URL getURL() {
+        return url;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/activation/UnsupportedDataTypeException.java b/jaxws/src/share/classes/javax/activation/UnsupportedDataTypeException.java
new file mode 100644
index 0000000..a9850a9
--- /dev/null
+++ b/jaxws/src/share/classes/javax/activation/UnsupportedDataTypeException.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 1997-2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.activation;
+
+import java.io.IOException;
+
+/**
+ * Signals that the requested operation does not support the
+ * requested data type.
+ *
+ * @see javax.activation.DataHandler
+ *
+ * @since 1.6
+ */
+
+public class UnsupportedDataTypeException extends IOException {
+    /**
+     * Constructs an UnsupportedDataTypeException with no detail
+     * message.
+     */
+    public UnsupportedDataTypeException() {
+        super();
+    }
+
+    /**
+     * Constructs an UnsupportedDataTypeException with the specified
+     * message.
+     *
+     * @param s The detail message.
+     */
+    public UnsupportedDataTypeException(String s) {
+        super(s);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/annotation/Generated.java b/jaxws/src/share/classes/javax/annotation/Generated.java
new file mode 100644
index 0000000..2ec7ef3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/annotation/Generated.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+//Copyright Sun Microsystems Inc. 2004 - 2005.
+
+package javax.annotation;
+import java.lang.annotation.*;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * The Generated annoation is used to mark source code that has been generated.
+ * It can also be used to differentiate user written code from generated code
+ * in a single file. When used, the value element must have the name of the
+ * code generator. The recommended convention is to use the fully qualified
+ * name of the code generator in the value field .
+ * For example: com.company.package.classname.
+ * The date element is used to indicate the date the source was generated.
+ * The date element must follow the ISO 8601 standard. For example the date
+ * element would have the following value 2001-07-04T12:08:56.235-0700
+ * which represents 2001-07-04 12:08:56 local time in the U.S. Pacific
+ * Time time zone.
+ * The comment element is a place holder for any comments that the code
+ * generator may want to include in the generated code.
+ *
+ * @since Common Annotations 1.0
+ */
+
+@Documented
+@Retention(SOURCE)
+@Target({PACKAGE, TYPE, ANNOTATION_TYPE, METHOD, CONSTRUCTOR, FIELD,
+        LOCAL_VARIABLE, PARAMETER})
+public @interface Generated {
+   /**
+    * This is used by the code generator to mark the generated classes
+    * and methods.
+    */
+   String[] value();
+
+   /**
+    * Date when the source was generated.
+    */
+   String date() default "";
+
+   /**
+    * A place holder for any comments that the code generator may want to
+    * include in the generated code.
+    */
+   String comments() default "";
+}
diff --git a/jaxws/src/share/classes/javax/annotation/PostConstruct.java b/jaxws/src/share/classes/javax/annotation/PostConstruct.java
new file mode 100644
index 0000000..3c797c0
--- /dev/null
+++ b/jaxws/src/share/classes/javax/annotation/PostConstruct.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+//Copyright Sun Microsystems Inc. 2004 - 2005.
+
+package javax.annotation;
+
+import java.lang.annotation.*;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * The PostConstruct annotation is used on a method that needs to be executed
+ * after dependency injection is done to perform any initialization. This
+ * method MUST be invoked before the class is put into service. This
+ * annotation MUST be supported on all classes that support dependency
+ * injection. The method annotated with PostConstruct MUST be invoked even
+ * if the class does not request any resources to be injected. Only one
+ * method can be annotated with this annotation. The method on which the
+ * PostConstruct annotation is applied MUST fulfill all of the following
+ * criteria -
+- The method MUST NOT have any parameters except in the case of EJB
+ * interceptors   in which case it takes an InvocationC ontext object as
+ * defined by the EJB   specification.
+ * - The return type of the method MUST be void.
+ * - The method MUST NOT throw a checked exception.
+ * - The method on which PostConstruct is applied MAY be public, protected,
+ * package private or private.
+ * - The method MUST NOT be static except for the application client.
+ * - The method MAY be final.
+ * - If the method throws an unchecked exception the class MUST NOT be put into
+ * service except in the case of EJBs where the EJB can handle exceptions and
+ * even   recover from them.
+ * @since Common Annotations 1.0
+ * @see javax.annotation.PreDestroy
+ * @see javax.annotation.Resource
+ */
+@Documented
+@Retention (RUNTIME)
+@Target(METHOD)
+public @interface PostConstruct {
+}
diff --git a/jaxws/src/share/classes/javax/annotation/PreDestroy.java b/jaxws/src/share/classes/javax/annotation/PreDestroy.java
new file mode 100644
index 0000000..022c58b
--- /dev/null
+++ b/jaxws/src/share/classes/javax/annotation/PreDestroy.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+//Copyright Sun Microsystems Inc. 2004 - 2005.
+
+package javax.annotation;
+
+import java.lang.annotation.*;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * The PreDestroy annotation is used on methods as a callback notification to
+ * signal that the instance is in the process of being removed by the
+ * container. The method annotated with PreDestroy is typically used to
+ * release resources that it has been holding. This annotation MUST be
+ * supported by all container managed objects that support PostConstruct
+ * except the application client container in Java EE 5. The method on which
+ * the PreDestroy annotation is applied MUST fulfill all of the following
+ * criteria -
+ * - The method MUST NOT have any parameters except in the case of EJB
+ * interceptors in which case it takes an InvocationContext object as defined
+ * by the EJB specification.
+ * - The return type of the method MUST be void.
+ * - The method MUST NOT throw a checked exception.
+ * - The method on which PreDestroy is applied MAY be public, protected,
+ * package private or private.
+ * - The method MUST NOT be static.
+ * - The method MAY be final.
+ * - If the method throws an unchecked exception it is ignored except in the
+ * case of EJBs where the EJB can handle exceptions.
+ *
+ * @see javax.annotation.PostConstruct
+ * @see javax.annotation.Resource
+ * @since Common Annotations 1.0
+ */
+
+@Documented
+@Retention (RUNTIME)
+@Target(METHOD)
+public @interface PreDestroy {
+}
diff --git a/jaxws/src/share/classes/javax/annotation/Resource.java b/jaxws/src/share/classes/javax/annotation/Resource.java
new file mode 100644
index 0000000..653c0a6
--- /dev/null
+++ b/jaxws/src/share/classes/javax/annotation/Resource.java
@@ -0,0 +1,125 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+//Copyright Sun Microsystems Inc. 2004 - 2005.
+
+package javax.annotation;
+
+import java.lang.annotation.*;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * The Resource annotation marks a resource that is needed
+ * by the application.  This annotation may be applied to an
+ * application component class, or to fields or methods of the
+ * component class.  When the annotation is applied to a
+ * field or method, the container will inject an instance
+ * of the requested resource into the application component
+ * when the component is initialized.  If the annotation is
+ * applied to the component class, the annotation declares a
+ * resource that the application will look up at runtime. <p>
+ *
+ * Even though this annotation is not marked Inherited, deployment
+ * tools are required to examine all superclasses of any component
+ * class to discover all uses of this annotation in all superclasses.
+ * All such annotation instances specify resources that are needed
+ * by the application component.  Note that this annotation may
+ * appear on private fields and methods of superclasses; the container
+ * is required to perform injection in these cases as well.
+ *
+ * @since Common Annotations 1.0
+ */
+@Target({TYPE, FIELD, METHOD})
+@Retention(RUNTIME)
+public @interface Resource {
+    /**
+     * The JNDI name of the resource.  For field annotations,
+     * the default is the field name.  For method annotations,
+     * the default is the JavaBeans property name corresponding
+     * to the method.  For class annotations, there is no default
+     * and this must be specified.
+     */
+    String name() default "";
+
+    /**
+     * The Java type of the resource.  For field annotations,
+     * the default is the type of the field.  For method annotations,
+     * the default is the type of the JavaBeans property.
+     * For class annotations, there is no default and this must be
+     * specified.
+     */
+    Class type() default java.lang.Object.class;
+
+    /**
+     * The two possible authentication types for a resource.
+     */
+    enum AuthenticationType {
+            CONTAINER,
+            APPLICATION
+    }
+
+    /**
+     * The authentication type to use for this resource.
+     * This may be specified for resources representing a
+     * connection factory of any supported type, and must
+     * not be specified for resources of other types.
+     */
+    AuthenticationType authenticationType() default AuthenticationType.CONTAINER;
+
+    /**
+     * Indicates whether this resource can be shared between
+     * this component and other components.
+     * This may be specified for resources representing a
+     * connection factory of any supported type, and must
+     * not be specified for resources of other types.
+     */
+    boolean shareable() default true;
+
+    /**
+     * A product specific name that this resource should be mapped to.
+     * The name of this resource, as defined by the <code>name</code>
+     * element or defaulted, is a name that is local to the application
+     * component using the resource.  (It's a name in the JNDI
+     * <code>java:comp/env</code> namespace.)  Many application servers
+     * provide a way to map these local names to names of resources
+     * known to the application server.  This mapped name is often a
+     * <i>global</i> JNDI name, but may be a name of any form. <p>
+     *
+     * Application servers are not required to support any particular
+     * form or type of mapped name, nor the ability to use mapped names.
+     * The mapped name is product-dependent and often installation-dependent.
+     * No use of a mapped name is portable.
+     */
+    String mappedName() default "";
+
+    /**
+     * Description of this resource.  The description is expected
+     * to be in the default language of the system on which the
+     * application is deployed.  The description can be presented
+     * to the Deployer to help in choosing the correct resource.
+     */
+    String description() default "";
+}
diff --git a/jaxws/src/share/classes/javax/annotation/Resources.java b/jaxws/src/share/classes/javax/annotation/Resources.java
new file mode 100644
index 0000000..ec9c6f9
--- /dev/null
+++ b/jaxws/src/share/classes/javax/annotation/Resources.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+//Copyright Sun Microsystems Inc. 2004 - 2005.
+
+package javax.annotation;
+import java.lang.annotation.*;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * This class is used to allow multiple resources declarations.
+ *
+ * @see javax.annotation.Resource
+ * @since Common Annotations 1.0
+ */
+
+@Documented
+@Retention(RUNTIME)
+@Target(TYPE)
+public @interface Resources {
+   /**
+    * Array used for multiple resource declarations.
+    */
+   Resource[] value();
+}
diff --git a/jaxws/src/share/classes/javax/jws/HandlerChain.java b/jaxws/src/share/classes/javax/jws/HandlerChain.java
new file mode 100644
index 0000000..669be25
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/HandlerChain.java
@@ -0,0 +1,67 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Associates the Web Service with an externally defined handler chain.  This annotation is typically used in scenarios
+ * where embedding the handler configuration directly in the Java source is not appropriate; for example, where the
+ * handler configuration needs to be shared across multiple Web Services, or where the handler chain consists of
+ * handlers for multiple transports.
+ *
+ * It is an error to combine this annotation with the @SOAPMessageHandlers annotation.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Retention(value = RetentionPolicy.RUNTIME)
+@Target(value = {ElementType.TYPE, ElementType.METHOD, ElementType.FIELD})
+public @interface HandlerChain {
+
+    /**
+     * Location of the handler chain file.
+     * <p>
+     * The location supports 2 formats:
+     * <ol>
+     * <li>An absolute java.net.URL in externalForm (ex: http://myhandlers.foo.com/handlerfile1.xml).
+     * <li>A relative path from the source file or class file (ex: bar/handlerfile1.xml).
+     * </ol>
+     */
+    String file();
+
+    /**
+     * Name of the handler chain in the configuration file
+     *
+     * @deprecated As of JSR-181 2.0 with no replacement.
+     */
+    @Deprecated String name() default "";
+};
diff --git a/jaxws/src/share/classes/javax/jws/Oneway.java b/jaxws/src/share/classes/javax/jws/Oneway.java
new file mode 100644
index 0000000..82e60d1
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/Oneway.java
@@ -0,0 +1,47 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Indicates that the given @WebMethod has only an input message and no output.  Typically, a oneway method returns
+ * the thread of control to the calling application prior to executing the actual business method.  A 181 processor
+ * should report an error if an operation marked @Oneway has a return value or Holder parameters, or declares any
+ * checked exceptions.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Retention(value = RetentionPolicy.RUNTIME)
+@Target(value = {ElementType.METHOD})
+public @interface Oneway {
+}
diff --git a/jaxws/src/share/classes/javax/jws/WebMethod.java b/jaxws/src/share/classes/javax/jws/WebMethod.java
new file mode 100644
index 0000000..24d0de3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/WebMethod.java
@@ -0,0 +1,74 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws;
+
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+
+/**
+ * Customizes a method that is exposed as a Web Service operation.
+ * The associated method must be public and its parameters return value,
+ * and exceptions must follow the rules defined in JAX-RPC 1.1, section 5.
+ *
+ *  The method is not required to throw java.rmi.RemoteException.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Retention(value = RetentionPolicy.RUNTIME)
+@Target({ElementType.METHOD})
+public @interface WebMethod {
+
+    /**
+     * Name of the wsdl:operation matching this method.
+     *
+     * @specdefault Name of the Java method.
+     */
+    String operationName() default "";
+
+    /**
+     * The action for this operation.
+     * <p>
+     * For SOAP bindings, this determines the value of the soap action.
+     */
+    String action() default "";
+
+    /**
+     * Marks a method to NOT be exposed as a web method.
+     * <p>
+     * Used to stop an inherited method from being exposed as part of this web service.
+     * If this element is specified, other elements MUST NOT be specified for the @WebMethod.
+     * <p>
+     * <i>This member-value is not allowed on endpoint interfaces.</i>
+     *
+     * @since 2.0
+     */
+    boolean exclude() default false;
+};
diff --git a/jaxws/src/share/classes/javax/jws/WebParam.java b/jaxws/src/share/classes/javax/jws/WebParam.java
new file mode 100644
index 0000000..2c135fa
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/WebParam.java
@@ -0,0 +1,113 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Customizes the mapping of an individual parameter to a Web Service message part and XML element.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Retention(value = RetentionPolicy.RUNTIME)
+@Target(value = {ElementType.PARAMETER})
+public @interface WebParam {
+
+    /**
+     * The direction in which the parameter flows
+     */
+    public enum Mode {
+        IN,
+        OUT,
+        INOUT
+    };
+
+    /**
+     * Name of the parameter.
+     * <p>
+     * If the operation is rpc style and @WebParam.partName has not been specified, this is name of the wsdl:part
+     * representing the parameter.
+     * <br>
+     * If the operation is document style or the parameter maps to a header, this is the local name of the XML element
+     * representing the parameter.
+     * <p>
+     * A name MUST be specified if the operation is document style, the parameter style is BARE, and the mode is OUT
+     * or INOUT.
+     *
+     * @specdefault
+     *   If the operation is document style and the parameter style is BARE, {@code @WebMethod.operationName}.<br>
+     *   Otherwise, argN, where N represents the index of the parameter in the method signature (starting at arg0).
+     */
+    String name() default "";
+
+    /**
+     * The name of the wsdl:part representing this parameter.
+     * <p>
+     * This is only used if the operation is rpc style or if the operation is document style and the parameter style
+     * is BARE.
+     *
+     * @specdefault {@code @WebParam.name}
+     *
+     * @since 2.0
+     */
+    String partName() default "";
+
+    /**
+     * The XML namespace for the parameter.
+     * <p>
+     * Only used if the operation is document style or the paramater maps to a header.
+     * If the target namespace is set to "", this represents the empty namespace.
+     *
+     * @specdefault
+     *   If the operation is document style, the parameter style is WRAPPED, and the parameter does not map to a
+     *   header, the empty namespace.<br>
+     *   Otherwise, the targetNamespace for the Web Service.
+     */
+    String targetNamespace() default "";
+
+    /**
+     * The direction in which the parameter is flowing (One of IN, OUT, or INOUT).
+     * <p>
+     * The OUT and INOUT modes may only be specified for parameter types that conform to the definition of Holder types
+     * (JAX-WS 2.0 [5], section 2.3.3).  Parameters that are Holder Types MUST be OUT or INOUT.
+     *
+     * @specdefault
+     *   INOUT if a Holder type.<br>
+     *   IN if not a Holder type.
+     */
+    Mode mode() default Mode.IN;
+
+    /**
+     * If true, the parameter is pulled from a message header rather then the message body.
+     */
+    boolean header() default false;
+};
diff --git a/jaxws/src/share/classes/javax/jws/WebResult.java b/jaxws/src/share/classes/javax/jws/WebResult.java
new file mode 100644
index 0000000..2808ca3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/WebResult.java
@@ -0,0 +1,92 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Customizes the mapping of the return value to a WSDL part and XML element.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Retention(value = RetentionPolicy.RUNTIME)
+    @Target(value = {ElementType.METHOD})
+    public @interface WebResult
+{
+
+    /**
+     * Name of return value.
+     * <p>
+     * If the operation is rpc style and @WebResult.partName has not been specified, this is the name of the wsdl:part
+     * representing the return value.
+     * <br>
+     * If the operation is document style or the return value maps to a header, this is the local name of the XML
+     * element representing the return value.
+     *
+     * @specdefault
+     *   If the operation is document style and the parameter style is BARE, {@code @WebParam.operationName}+"Response".<br>
+     *   Otherwise, "return."
+     */
+    String name() default "";
+
+    /**
+     * The name of the wsdl:part representing this return value.
+     * <p>
+     * This is only used if the operation is rpc style, or if the operation is document style and the parameter style
+     * is BARE.
+     *
+     * @specdefault {@code @WebResult.name}
+     *
+     * @since 2.0
+     */
+    String partName() default "";
+
+    /**
+     * The XML namespace for the return value.
+     * <p>
+     * Only used if the operation is document style or the return value maps to a header.
+     * If the target namespace is set to "", this represents the empty namespace.
+     *
+     * @specdefault
+     *   If the operation is document style, the parameter style is WRAPPED, and the return value does not map to a
+     *   header, the empty namespace.<br>
+     *   Otherwise, the targetNamespace for the Web Service.
+     */
+    String targetNamespace() default "";
+
+    /**
+     * If true, the result is pulled from a message header rather then the message body.
+     *
+     * @since 2.0
+     */
+    boolean header() default false;
+}
diff --git a/jaxws/src/share/classes/javax/jws/WebService.java b/jaxws/src/share/classes/javax/jws/WebService.java
new file mode 100644
index 0000000..ca584ca
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/WebService.java
@@ -0,0 +1,123 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws;
+
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.ElementType;
+
+/**
+ * Marks a Java class as implementing a Web Service, or a Java interface as defining a Web Service interface.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Retention(value = RetentionPolicy.RUNTIME)
+@Target(value = {ElementType.TYPE})
+public @interface WebService {
+
+    /**
+     * The name of the Web Service.
+     * <p>
+     * Used as the name of the wsdl:portType when mapped to WSDL 1.1.
+     *
+     * @specdefault The simple name of the Java class or interface.
+     */
+    String name() default "";
+
+    /**
+     * If the @WebService.targetNamespace annotation is on a service endpoint interface, the targetNamespace is used
+     * for the namespace for the wsdl:portType (and associated XML elements).
+     * <p>
+     * If the @WebService.targetNamespace annotation is on a service implementation bean that does NOT reference a
+     * service endpoint interface (through the endpointInterface attribute), the targetNamespace is used for both the
+     * wsdl:portType and the wsdl:service (and associated XML elements).
+     * <p>
+     * If the @WebService.targetNamespace annotation is on a service implementation bean that does reference a service
+     * endpoint interface (through the endpointInterface attribute), the targetNamespace is used for only the
+     * wsdl:service (and associated XML elements).
+     *
+     * @specdefault Implementation-defined, as described in JAX-WS 2.0 [5], section 3.2.
+     */
+    String targetNamespace() default "";
+
+    /**
+     * The service name of the Web Service.
+     * <p>
+     * Used as the name of the wsdl:service when mapped to WSDL 1.1.
+     * <p>
+     * <i>This member-value is not allowed on endpoint interfaces.</i>
+     *
+     * @specdefault The simple name of the Java class + "Service".
+     */
+    String serviceName() default "";
+
+    /**
+     * The port name of the Web Service.
+     * <p>
+     * Used as the name of the wsdl:port when mapped to WSDL 1.1.
+     * <p>
+     * <i>This member-value is not allowed on endpoint interfaces.</i>
+     *
+     * @specdefault {@code @WebService.name}+"Port".
+     *
+     * @since 2.0
+     */
+    String portName() default "";
+
+    /**
+     * The location of a pre-defined WSDL describing the service.
+     * <p>
+     * The wsdlLocation is a URL (relative or absolute) that refers to a pre-existing WSDL file.  The presence of a
+     * wsdlLocation value indicates that the service implementation bean is implementing a pre-defined WSDL contract.
+     * The JSR-181 tool MUST provide feedback if the service implementation bean is inconsistent with the portType and
+     * bindings declared in this WSDL. Note that a single WSDL file might contain multiple portTypes and multiple
+     * bindings.  The annotations on the service implementation bean determine the specific portType and bindings that
+     * correspond to the Web Service.
+     */
+    String wsdlLocation() default "";
+
+    /**
+     * The complete name of the service endpoint interface defining the service's abstract Web Service contract.
+     * <p>
+     * This annotation allows the developer to separate the interface contract from the implementation.  If this
+     * annotation is present, the service endpoint interface is used to determine the abstract WSDL contract (portType
+     * and bindings). The service endpoint interface MAY include JSR-181 annotations to customize the mapping from
+     * Java to WSDL.
+     * <br>
+     * The service implementation bean MAY implement the service endpoint interface, but is not REQUIRED to do so.
+     * <br>
+     * If this member-value is not present, the Web Service contract is generated from annotations on the service
+     * implementation bean.  If a service endpoint interface is required by the target environment, it will be
+     * generated into an implementation-defined package with an implementation- defined name
+     * <p>
+     * <i>This member-value is not allowed on endpoint interfaces.</i>
+     */
+    String endpointInterface() default "";
+};
diff --git a/jaxws/src/share/classes/javax/jws/soap/InitParam.java b/jaxws/src/share/classes/javax/jws/soap/InitParam.java
new file mode 100644
index 0000000..efe3e68
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/soap/InitParam.java
@@ -0,0 +1,49 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws.soap;
+
+/**
+ * An initialization parameter
+ *
+ * @deprecated  As of JSR-181 2.0 with no replacement.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Deprecated public @interface InitParam {
+
+    /**
+     * Name of the initialization parameter
+     */
+    String name();
+
+    /**
+     * Value of the initialization parameter
+     */
+    String value();
+};
diff --git a/jaxws/src/share/classes/javax/jws/soap/SOAPBinding.java b/jaxws/src/share/classes/javax/jws/soap/SOAPBinding.java
new file mode 100644
index 0000000..8444a23
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/soap/SOAPBinding.java
@@ -0,0 +1,85 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws.soap;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Specifies the mapping of the Web Service onto the SOAP message protocol.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ *
+ */
+@Retention(value = RetentionPolicy.RUNTIME)
+@Target(value = {ElementType.TYPE, ElementType.METHOD})
+public @interface SOAPBinding {
+
+    /**
+     * The SOAP binding style
+     */
+    public enum Style {
+      DOCUMENT,
+      RPC
+    };
+
+    /**
+     * The SOAP binding use
+     */
+    public enum Use {
+      LITERAL,
+      ENCODED
+    };
+
+    /**
+     * The style of mapping parameters onto SOAP messages
+     */
+    public enum ParameterStyle {
+      BARE,
+      WRAPPED
+    }
+
+    /**
+     * Defines the encoding style for messages send to and from the Web Service.
+     */
+    Style style() default Style.DOCUMENT;
+
+    /**
+     * Defines the formatting style for messages sent to and from the Web Service.
+     */
+    Use use() default Use.LITERAL;
+
+    /**
+     * Determines whether method parameters represent the entire message body, or whether the parameters are elements
+     * wrapped inside a top-level element named after the operation
+     */
+    ParameterStyle parameterStyle() default ParameterStyle.WRAPPED;
+}
diff --git a/jaxws/src/share/classes/javax/jws/soap/SOAPMessageHandler.java b/jaxws/src/share/classes/javax/jws/soap/SOAPMessageHandler.java
new file mode 100644
index 0000000..2ab4e42
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/soap/SOAPMessageHandler.java
@@ -0,0 +1,66 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws.soap;
+
+/**
+ * A single SOAP message handler
+ *
+ * @deprecated  As of JSR-181 2.0 with no replacement.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Deprecated public @interface SOAPMessageHandler {
+
+    /**
+     * Name of the handler.  Defaults to the name of the handler class.
+     */
+    String name() default "";
+
+    /**
+     * Name of the handler class.
+     */
+    String className();
+
+    /**
+     * Array of name/value pairs that should be passed to the handler during initialization.
+     */
+    InitParam[] initParams() default {};
+
+    /**
+     * List of SOAP roles/actors implemented by the handler
+     */
+    String[] roles() default {};
+
+    /**
+     * List of SOAP headers processed by the handler.  Each element in this array contains a QName which defines the
+     * header element processed by the handler.  The QNames are specified using the string notation described in the
+     * documentation for javax.xml.namespace.QName.valueOf(String qNameAsString)
+     */
+    String[] headers() default {};
+};
diff --git a/jaxws/src/share/classes/javax/jws/soap/SOAPMessageHandlers.java b/jaxws/src/share/classes/javax/jws/soap/SOAPMessageHandlers.java
new file mode 100644
index 0000000..9f93afa
--- /dev/null
+++ b/jaxws/src/share/classes/javax/jws/soap/SOAPMessageHandlers.java
@@ -0,0 +1,52 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+
+package javax.jws.soap;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+
+/**
+ * Specifies a list of SOAP protocol handlers that run before and after business methods on the Web Service.  These
+ * handlers are called in response to SOAP messages targeting the service.
+ * <p>
+ * The @SOAPMessageHandlers annotation is an array of SOAPMessageHandler types.  The handlers are run in the order in
+ * which they appear in the annotation, starting with the first handler in the array.
+ *
+ * @deprecated  As of JSR-181 2.0 with no replacement.
+ *
+ * @author Copyright (c) 2004 by BEA Systems, Inc. All Rights Reserved.
+ */
+@Retention(value = RetentionPolicy.RUNTIME)
+@Target(value = {ElementType.TYPE})
+@Deprecated public @interface SOAPMessageHandlers {
+
+    SOAPMessageHandler[] value();
+};
diff --git a/jaxws/src/share/classes/javax/xml/bind/Binder.java b/jaxws/src/share/classes/javax/xml/bind/Binder.java
new file mode 100644
index 0000000..27057a6
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/Binder.java
@@ -0,0 +1,421 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import org.w3c.dom.Node;
+
+import javax.xml.validation.Schema;
+
+/**
+ * Enable synchronization between XML infoset nodes and JAXB objects
+ * representing same XML document.
+ *
+ * <p>
+ * An instance of this class maintains the association between XML nodes of
+ * an infoset preserving view and a JAXB representation of an XML document.
+ * Navigation between the two views is provided by the methods
+ * {@link #getXMLNode(Object)} and {@link #getJAXBNode(Object)}.
+ *
+ * <p>
+ * Modifications can be made to either the infoset preserving view or the
+ * JAXB representation of the document while the other view remains
+ * unmodified. The binder is able to synchronize the changes made in the
+ * modified view back into the other view using the appropriate
+ * Binder update methods, {@link #updateXML(Object, Object)} or
+ * {@link #updateJAXB(Object)}.
+ *
+ * <p>
+ * A typical usage scenario is the following:
+ * <ul>
+ *   <li>load XML document into an XML infoset representation</li>
+ *   <li>{@link #unmarshal(Object)} XML infoset view to JAXB view.
+ *       (Note to conserve resources, it is possible to only unmarshal a
+ *       subtree of the XML infoset view to the JAXB view.)</li>
+ *   <li>application access/updates JAXB view of XML document.</li>
+ *   <li>{@link #updateXML(Object)} synchronizes modifications to JAXB view
+ *       back into the XML infoset view. Update operation preserves as
+ *       much of original XML infoset as possible (i.e. comments, PI, ...)</li>
+ * </ul>
+ *
+ * <p>
+ * A Binder instance is created using the factory method
+ * {@link JAXBContext#createBinder()} or {@link JAXBContext#createBinder(Class)}.
+ *
+ * <p>
+ * The template parameter, <code>XmlNode</code>, is the
+ * root interface/class for the XML infoset preserving representation.
+ * A Binder implementation is required to minimally support
+ * an <code>XmlNode</code> value of <code>org.w3c.dom.Node.class</code>.
+ * A Binder implementation can support alternative XML infoset
+ * preserving representations.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ *     Joseph Fialli
+ *
+ * @since JAXB 2.0
+ */
+public abstract class Binder<XmlNode> {
+    /**
+     * Unmarshal XML infoset view to a JAXB object tree.
+     *
+     * <p>
+     * This method is similar to {@link Unmarshaller#unmarshal(Node)}
+     * with the addition of maintaining the association between XML nodes
+     * and the produced JAXB objects, enabling future update operations,
+     * {@link #updateXML(Object, Object)} or {@link #updateJAXB(Object)}.
+     *
+     * <p>
+     * When {@link #getSchema()} is non-null, <code>xmlNode</code>
+     * and its descendants is validated during this operation.
+     *
+     * <p>
+     * This method throws {@link UnmarshalException} when the Binder's
+     * {@link JAXBContext} does not have a mapping for the XML element name
+     * or the type, specifiable via <tt>@xsi:type</tt>, of <tt>xmlNode</tt>
+     * to a JAXB mapped class. The method {@link #unmarshal(Object, Class)}
+     * enables an application to specify the JAXB mapped class that
+     * the <tt>xmlNode</tt> should be mapped to.
+     *
+     * @param xmlNode
+     *      the document/element to unmarshal XML data from.
+     *
+     * @return
+     *      the newly created root object of the JAXB object tree.
+     *
+     * @throws JAXBException
+     *      If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Binder</tt> is unable to perform the XML to Java
+     *     binding.
+     * @throws IllegalArgumentException
+     *      If the node parameter is null
+     */
+    public abstract Object unmarshal( XmlNode xmlNode ) throws JAXBException;
+
+    /**
+     * Unmarshal XML root element by provided <tt>declaredType</tt>
+     * to a JAXB object tree.
+     *
+     * <p>
+     * Implements <a href="Unmarshaller.html#unmarshalByDeclaredType">Unmarshal by Declared Type</a>
+     *
+     * <p>
+     * This method is similar to {@link Unmarshaller#unmarshal(Node, Class)}
+     * with the addition of maintaining the association between XML nodes
+     * and the produced JAXB objects, enabling future update operations,
+     * {@link #updateXML(Object, Object)} or {@link #updateJAXB(Object)}.
+     *
+     * <p>
+     * When {@link #getSchema()} is non-null, <code>xmlNode</code>
+     * and its descendants is validated during this operation.
+     *
+     * @param xmlNode
+     *      the document/element to unmarshal XML data from.
+     * @param declaredType
+     *      appropriate JAXB mapped class to hold <tt>node</tt>'s XML data.
+     *
+     * @return
+     * <a href="#unmarshalDeclaredTypeReturn">JAXB Element</a> representation
+     * of <tt>node</tt>
+     *
+     * @throws JAXBException
+     *      If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Binder</tt> is unable to perform the XML to Java
+     *     binding.
+     * @throws IllegalArgumentException
+     *      If any of the input parameters are null
+     * @since JAXB2.0
+     */
+    public abstract <T> JAXBElement<T>
+        unmarshal( XmlNode xmlNode, Class<T> declaredType )
+        throws JAXBException;
+
+    /**
+     * Marshal a JAXB object tree to a new XML document.
+     *
+     * <p>
+     * This method is similar to {@link Marshaller#marshal(Object, Node)}
+     * with the addition of maintaining the association between JAXB objects
+     * and the produced XML nodes,
+     * enabling future update operations such as
+     * {@link #updateXML(Object, Object)} or {@link #updateJAXB(Object)}.
+     *
+     * <p>
+     * When {@link #getSchema()} is non-null, the marshalled
+     * xml content is validated during this operation.
+     *
+     * @param jaxbObject
+     *      The content tree to be marshalled.
+     * @param xmlNode
+     *      The parameter must be a Node that accepts children.
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs during the marshalling.
+     * @throws MarshalException
+     *      If the {@link ValidationEventHandler ValidationEventHandler}
+     *      returns false from its <tt>handleEvent</tt> method or the
+     *      <tt>Binder</tt> is unable to marshal <tt>jaxbObject</tt> (or any
+     *      object reachable from <tt>jaxbObject</tt>).
+     *
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     */
+    public abstract void marshal( Object jaxbObject, XmlNode xmlNode ) throws JAXBException;
+
+    /**
+     * Gets the XML element associated with the given JAXB object.
+     *
+     * <p>
+     * Once a JAXB object tree is associated with an XML fragment,
+     * this method enables navigation between the two trees.
+     *
+     * <p>
+     * An association between an XML element and a JAXB object is
+     * established by the bind methods and the update methods.
+     * Note that this association is partial; not all XML elements
+     * have associated JAXB objects, and not all JAXB objects have
+     * associated XML elements.
+     *
+     * @param jaxbObject An instance that is reachable from a prior
+     *                   call to a bind or update method that returned
+     *                   a JAXB object tree.
+     *
+     * @return
+     *      null if the specified JAXB object is not known to this
+     *      {@link Binder}, or if it is not associated with an
+     *      XML element.
+     *
+     * @throws IllegalArgumentException
+     *      If the jaxbObject parameter is null
+     */
+    public abstract XmlNode getXMLNode( Object jaxbObject );
+
+    /**
+     * Gets the JAXB object associated with the given XML element.
+     *
+     * <p>
+     * Once a JAXB object tree is associated with an XML fragment,
+     * this method enables navigation between the two trees.
+     *
+     * <p>
+     * An association between an XML element and a JAXB object is
+     * established by the unmarshal, marshal and update methods.
+     * Note that this association is partial; not all XML elements
+     * have associated JAXB objects, and not all JAXB objects have
+     * associated XML elements.
+     *
+     * @return
+     *      null if the specified XML node is not known to this
+     *      {@link Binder}, or if it is not associated with a
+     *      JAXB object.
+     *
+     * @throws IllegalArgumentException
+     *      If the node parameter is null
+     */
+    public abstract Object getJAXBNode( XmlNode xmlNode );
+
+    /**
+     * Takes an JAXB object and updates
+     * its associated XML node and its descendants.
+     *
+     * <p>
+     * This is a convenience method of:
+     * <pre>
+     * updateXML( jaxbObject, getXMLNode(jaxbObject));
+     * </pre>
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs updating corresponding XML content.
+     * @throws IllegalArgumentException
+     *      If the jaxbObject parameter is null
+     */
+    public abstract XmlNode updateXML( Object jaxbObject ) throws JAXBException;
+
+    /**
+     * Changes in JAXB object tree are updated in its associated XML parse tree.
+     *
+     * <p>
+     * This operation can be thought of as an "in-place" marshalling.
+     * The difference is that instead of creating a whole new XML tree,
+     * this operation updates an existing tree while trying to preserve
+     * the XML as much as possible.
+     *
+     * <p>
+     * For example, unknown elements/attributes in XML that were not bound
+     * to JAXB will be left untouched (whereas a marshalling operation
+     * would create a new tree that doesn't contain any of those.)
+     *
+     * <p>
+     * As a side-effect, this operation updates the association between
+     * XML nodes and JAXB objects.
+     *
+     * @param jaxbObject root of potentially modified JAXB object tree
+     * @param xmlNode    root of update target XML parse tree
+     *
+     * @return
+     *      Returns the updated XML node. Typically, this is the same
+     *      node you passed in as <i>xmlNode</i>, but it maybe
+     *      a different object, for example when the tag name of the object
+     *      has changed.
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs updating corresponding XML content.
+     * @throws IllegalArgumentException
+     *      If any of the input parameters are null
+     */
+    public abstract XmlNode updateXML( Object jaxbObject, XmlNode xmlNode ) throws JAXBException;
+
+    /**
+     * Takes an XML node and updates its associated JAXB object and its descendants.
+     *
+     * <p>
+     * This operation can be thought of as an "in-place" unmarshalling.
+     * The difference is that instead of creating a whole new JAXB tree,
+     * this operation updates an existing tree, reusing as much JAXB objects
+     * as possible.
+     *
+     * <p>
+     * As a side-effect, this operation updates the association between
+     * XML nodes and JAXB objects.
+     *
+     * @return
+     *      Returns the updated JAXB object. Typically, this is the same
+     *      object that was returned from earlier
+     *      {@link #marshal(Object,Object)} or
+     *      {@link #updateJAXB(Object)} method invocation,
+     *      but it maybe
+     *      a different object, for example when the name of the XML
+     *      element has changed.
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs updating corresponding JAXB mapped content.
+     * @throws IllegalArgumentException
+     *      If node parameter is null
+     */
+    public abstract Object updateJAXB( XmlNode xmlNode ) throws JAXBException;
+
+
+    /**
+     * Specifies whether marshal, unmarshal and update methods
+     * performs validation on their XML content.
+     *
+     * @param schema set to null to disable validation.
+     *
+     * @see Unmarshaller#setSchema(Schema)
+     */
+    public abstract void setSchema( Schema schema );
+
+    /**
+     * Gets the last {@link Schema} object (including null) set by the
+     * {@link #setSchema(Schema)} method.
+     *
+     * @return the Schema object for validation or null if not present
+     */
+    public abstract Schema getSchema();
+
+    /**
+     * Allow an application to register a <tt>ValidationEventHandler</tt>.
+     * <p>
+     * The <tt>ValidationEventHandler</tt> will be called by the JAXB Provider
+     * if any validation errors are encountered during calls to any of the
+     * Binder unmarshal, marshal and update methods.
+     *
+     * <p>
+     * Calling this method with a null parameter will cause the Binder
+     * to revert back to the default default event handler.
+     *
+     * @param handler the validation event handler
+     * @throws JAXBException if an error was encountered while setting the
+     *         event handler
+     */
+    public abstract void setEventHandler( ValidationEventHandler handler ) throws JAXBException;
+
+    /**
+     * Return the current event handler or the default event handler if one
+     * hasn't been set.
+     *
+     * @return the current ValidationEventHandler or the default event handler
+     *         if it hasn't been set
+     * @throws JAXBException if an error was encountered while getting the
+     *         current event handler
+     */
+    public abstract ValidationEventHandler getEventHandler() throws JAXBException;
+
+    /**
+     *
+     * Set the particular property in the underlying implementation of
+     * <tt>Binder</tt>.  This method can only be used to set one of
+     * the standard JAXB defined unmarshal/marshal properties
+     * or a provider specific property for binder, unmarshal or marshal.
+     * Attempting to set an undefined property will result in
+     * a PropertyException being thrown.  See
+     * <a href="Unmarshaller.html#supportedProps">Supported Unmarshal Properties</a>
+     * and
+     * <a href="Marshaller.html#supportedProps">Supported Marshal Properties</a>.
+     *
+     * @param name the name of the property to be set. This value can either
+     *              be specified using one of the constant fields or a user
+     *              supplied string.
+     * @param value the value of the property to be set
+     *
+     * @throws PropertyException when there is an error processing the given
+     *                            property or value
+     * @throws IllegalArgumentException
+     *      If the name parameter is null
+     */
+    abstract public void setProperty( String name, Object value ) throws PropertyException;
+
+
+    /**
+     * Get the particular property in the underlying implementation of
+     * <tt>Binder</tt>.  This method can only
+     * be used to get one of
+     * the standard JAXB defined unmarshal/marshal properties
+     * or a provider specific property for binder, unmarshal or marshal.
+     * Attempting to get an undefined property will result in
+     * a PropertyException being thrown.  See
+     * <a href="Unmarshaller.html#supportedProps">Supported Unmarshal Properties</a>
+     * and
+     * <a href="Marshaller.html#supportedProps">Supported Marshal Properties</a>.
+     *
+     * @param name the name of the property to retrieve
+     * @return the value of the requested property
+     *
+     * @throws PropertyException
+     *      when there is an error retrieving the given property or value
+     *      property name
+     * @throws IllegalArgumentException
+     *      If the name parameter is null
+     */
+    abstract public Object getProperty( String name ) throws PropertyException;
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/ContextFinder.java b/jaxws/src/share/classes/javax/xml/bind/ContextFinder.java
new file mode 100644
index 0000000..335b51e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/ContextFinder.java
@@ -0,0 +1,486 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import java.io.BufferedReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.io.UnsupportedEncodingException;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.net.URL;
+import java.util.Map;
+import java.util.Properties;
+import java.util.StringTokenizer;
+import java.util.logging.ConsoleHandler;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import static javax.xml.bind.JAXBContext.JAXB_CONTEXT_FACTORY;
+
+//import java.lang.reflect.InvocationTargetException;
+
+/**
+ * This class is package private and therefore is not exposed as part of the
+ * JAXB API.
+ *
+ * This code is designed to implement the JAXB 1.0 spec pluggability feature
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBContext
+ */
+class ContextFinder {
+    private static final Logger logger;
+    static {
+        logger = Logger.getLogger("javax.xml.bind");
+        try {
+            if (System.getProperty("jaxb.debug", null) != null) {
+                // disconnect the logger from a bigger framework (if any)
+                // and take the matters into our own hands
+                logger.setUseParentHandlers(false);
+                logger.setLevel(Level.ALL);
+                ConsoleHandler handler = new ConsoleHandler();
+                handler.setLevel(Level.ALL);
+                logger.addHandler(handler);
+            } else {
+                // don't change the setting of this logger
+                // to honor what other frameworks
+                // have done on configurations.
+            }
+        } catch(Throwable t) {
+            // just to be extra safe. in particular System.getProperty may throw
+            // SecurityException.
+        }
+    }
+
+    /**
+     * If the {@link InvocationTargetException} wraps an exception that shouldn't be wrapped,
+     * throw the wrapped exception.
+     */
+    private static void handleInvocationTargetException(InvocationTargetException x) throws JAXBException {
+        Throwable t = x.getTargetException();
+        if( t != null ) {
+            if( t instanceof JAXBException )
+                // one of our exceptions, just re-throw
+                throw (JAXBException)t;
+            if( t instanceof RuntimeException )
+                // avoid wrapping exceptions unnecessarily
+                throw (RuntimeException)t;
+            if( t instanceof Error )
+                throw (Error)t;
+        }
+    }
+
+
+    /**
+     * Determine if two types (JAXBContext in this case) will generate a ClassCastException.
+     *
+     * For example, (targetType)originalType
+     *
+     * @param originalType
+     *          The Class object of the type being cast
+     * @param targetType
+     *          The Class object of the type that is being cast to
+     * @throws JAXBException
+     *          If the cast would fail
+     */
+    private static void handleClassCastException(Class originalType, Class targetType) throws JAXBException {
+        final URL targetTypeURL = which(targetType);
+
+        throw new JAXBException(Messages.format(Messages.ILLEGAL_CAST,
+                // we don't care where the impl class is, we want to know where JAXBContext lives in the impl
+                // class' ClassLoader
+                originalType.getClass().getClassLoader().getResource("javax/xml/bind/JAXBContext.class").toString(),
+                targetTypeURL.toString()));
+    }
+
+    /**
+     * Create an instance of a class using the specified ClassLoader
+     */
+    static JAXBContext newInstance( String contextPath,
+                               String className,
+                               ClassLoader classLoader,
+                               Map properties )
+        throws JAXBException
+    {
+        try {
+            Class spiClass;
+            if (classLoader == null) {
+                spiClass = Class.forName(className);
+            } else {
+                spiClass = classLoader.loadClass(className);
+            }
+
+            /*
+             * javax.xml.bind.context.factory points to a class which has a
+             * static method called 'createContext' that
+             * returns a javax.xml.JAXBContext.
+             */
+
+            Object context = null;
+
+            // first check the method that takes Map as the third parameter.
+            // this is added in 2.0.
+            try {
+                Method m = spiClass.getMethod("createContext",String.class,ClassLoader.class,Map.class);
+                // any failure in invoking this method would be considered fatal
+                context = m.invoke(null,contextPath,classLoader,properties);
+            } catch (NoSuchMethodException e) {
+                ; // it's not an error for the provider not to have this method.
+            }
+
+            if(context==null) {
+                // try the old method that doesn't take properties. compatible with 1.0.
+                // it is an error for an implementation not to have both forms of the createContext method.
+                Method m = spiClass.getMethod("createContext",String.class,ClassLoader.class);
+                // any failure in invoking this method would be considered fatal
+                context = m.invoke(null,contextPath,classLoader);
+            }
+
+            if(!(context instanceof JAXBContext)) {
+                // the cast would fail, so generate an exception with a nice message
+                handleClassCastException(context.getClass(), JAXBContext.class);
+            }
+            return (JAXBContext)context;
+        } catch (ClassNotFoundException x) {
+            throw new JAXBException(
+                Messages.format( Messages.PROVIDER_NOT_FOUND, className ),
+                x);
+        } catch (InvocationTargetException x) {
+            handleInvocationTargetException(x);
+            // for other exceptions, wrap the internal target exception
+            // with a JAXBException
+            Throwable e = x;
+            if(x.getTargetException()!=null)
+                e = x.getTargetException();
+
+            throw new JAXBException( Messages.format( Messages.COULD_NOT_INSTANTIATE, className, e ), e );
+        } catch (RuntimeException x) {
+            // avoid wrapping RuntimeException to JAXBException,
+            // because it indicates a bug in this code.
+            throw x;
+        } catch (Exception x) {
+            // can't catch JAXBException because the method is hidden behind
+            // reflection.  Root element collisions detected in the call to
+            // createContext() are reported as JAXBExceptions - just re-throw it
+            // some other type of exception - just wrap it
+            throw new JAXBException(
+                Messages.format( Messages.COULD_NOT_INSTANTIATE, className, x ),
+                x);
+        }
+    }
+
+
+    /**
+     * Create an instance of a class using the specified ClassLoader
+     */
+    static JAXBContext newInstance(
+                              Class[] classes,
+                              Map properties,
+                              String className) throws JAXBException {
+        ClassLoader cl = Thread.currentThread().getContextClassLoader();
+        Class spi;
+        try {
+            logger.fine("Trying to load "+className);
+            if (cl != null)
+                spi = cl.loadClass(className);
+            else
+                spi = Class.forName(className);
+        } catch (ClassNotFoundException e) {
+            throw new JAXBException(e);
+        }
+
+        if(logger.isLoggable(Level.FINE)) {
+            // extra check to avoid costly which operation if not logged
+            logger.fine("loaded "+className+" from "+which(spi));
+        }
+
+        Method m;
+        try {
+            m = spi.getMethod("createContext", Class[].class, Map.class);
+        } catch (NoSuchMethodException e) {
+            throw new JAXBException(e);
+        }
+        try {
+            Object context = m.invoke(null, classes, properties);
+            if(!(context instanceof JAXBContext)) {
+                // the cast would fail, so generate an exception with a nice message
+                handleClassCastException(context.getClass(), JAXBContext.class);
+            }
+            return (JAXBContext)context;
+        } catch (IllegalAccessException e) {
+            throw new JAXBException(e);
+        } catch (InvocationTargetException e) {
+            handleInvocationTargetException(e);
+
+            Throwable x = e;
+            if (e.getTargetException() != null)
+                x = e.getTargetException();
+
+            throw new JAXBException(x);
+        }
+    }
+
+
+    static JAXBContext find(String factoryId, String contextPath, ClassLoader classLoader, Map properties ) throws JAXBException {
+
+        // TODO: do we want/need another layer of searching in $java.home/lib/jaxb.properties like JAXP?
+
+        final String jaxbContextFQCN = JAXBContext.class.getName();
+
+        // search context path for jaxb.properties first
+        StringBuilder propFileName;
+        StringTokenizer packages = new StringTokenizer( contextPath, ":" );
+        String factoryClassName;
+
+        if(!packages.hasMoreTokens())
+            // no context is specified
+            throw new JAXBException(Messages.format(Messages.NO_PACKAGE_IN_CONTEXTPATH));
+
+
+        logger.fine("Searching jaxb.properties");
+
+        while( packages.hasMoreTokens() ) {
+            String packageName = packages.nextToken(":").replace('.','/');
+            // com.acme.foo - > com/acme/foo/jaxb.properties
+             propFileName = new StringBuilder().append(packageName).append("/jaxb.properties");
+
+            Properties props = loadJAXBProperties( classLoader, propFileName.toString() );
+            if (props == null) {
+                continue;
+            } else {
+                if (props.containsKey(factoryId)) {
+                    factoryClassName = props.getProperty(factoryId);
+                    return newInstance( contextPath, factoryClassName, classLoader, properties );
+                } else {
+                    throw new JAXBException(Messages.format(Messages.MISSING_PROPERTY, packageName, factoryId));
+                }
+            }
+        }
+
+        logger.fine("Searching the system property");
+
+        // search for a system property second (javax.xml.bind.JAXBContext)
+        factoryClassName = System.getProperty(jaxbContextFQCN, null);
+        if(  factoryClassName != null ) {
+            return newInstance( contextPath, factoryClassName, classLoader, properties );
+        }
+
+        logger.fine("Searching META-INF/services");
+
+        // search META-INF services next
+        BufferedReader r;
+        try {
+            final StringBuilder resource = new StringBuilder().append("META-INF/services/").append(jaxbContextFQCN);
+            final InputStream resourceStream =
+                    classLoader.getResourceAsStream(resource.toString());
+
+            if (resourceStream != null) {
+                r = new BufferedReader(new InputStreamReader(resourceStream, "UTF-8"));
+                factoryClassName = r.readLine().trim();
+                return newInstance(contextPath, factoryClassName, classLoader, properties);
+            } else {
+                logger.fine("Unable to load:" + resource.toString());
+            }
+        } catch (UnsupportedEncodingException e) {
+            // should never happen
+            throw new JAXBException(e);
+        } catch (IOException e) {
+            throw new JAXBException(e);
+        }
+
+        // else no provider found
+        logger.fine("Trying to create the platform default provider");
+        return newInstance(contextPath, PLATFORM_DEFAULT_FACTORY_CLASS, classLoader, properties);
+    }
+
+    // TODO: log each step in the look up process
+    static JAXBContext find( Class[] classes, Map properties ) throws JAXBException {
+
+        // TODO: do we want/need another layer of searching in $java.home/lib/jaxb.properties like JAXP?
+
+        final String jaxbContextFQCN = JAXBContext.class.getName();
+        String factoryClassName;
+
+        // search for jaxb.properties in the class loader of each class first
+        for (Class c : classes) {
+            ClassLoader classLoader = c.getClassLoader();
+            Package pkg = c.getPackage();
+            if(pkg==null)
+                continue;       // this is possible for primitives, arrays, and classes that are loaded by poorly implemented ClassLoaders
+            String packageName = pkg.getName().replace('.', '/');
+
+            // TODO: do we want to optimize away searching the same package?  org.Foo, org.Bar, com.Baz
+            //       classes from the same package might come from different class loades, so it might be a bad idea
+
+            // TODO: it's easier to look things up from the class
+            // c.getResourceAsStream("jaxb.properties");
+
+            // build the resource name and use the property loader code
+            String resourceName = packageName+"/jaxb.properties";
+            logger.fine("Trying to locate "+resourceName);
+            Properties props = loadJAXBProperties(classLoader, resourceName);
+            if (props == null) {
+                logger.fine("  not found");
+                continue;
+            } else {
+                logger.fine("  found");
+                if (props.containsKey(JAXB_CONTEXT_FACTORY)) {
+                    // trim() seems redundant, but adding to satisfy customer complaint
+                    factoryClassName = props.getProperty(JAXB_CONTEXT_FACTORY).trim();
+                    return newInstance(classes, properties, factoryClassName);
+                } else {
+                    throw new JAXBException(Messages.format(Messages.MISSING_PROPERTY, packageName, JAXB_CONTEXT_FACTORY));
+                }
+            }
+        }
+
+        // search for a system property second (javax.xml.bind.JAXBContext)
+        logger.fine("Checking system property "+jaxbContextFQCN);
+        factoryClassName = System.getProperty(jaxbContextFQCN, null);
+        if(  factoryClassName != null ) {
+            logger.fine("  found "+factoryClassName);
+            return newInstance( classes, properties, factoryClassName );
+        }
+        logger.fine("  not found");
+
+        // search META-INF services next
+        logger.fine("Checking META-INF/services");
+        BufferedReader r;
+        try {
+            final String resource = new StringBuilder("META-INF/services/").append(jaxbContextFQCN).toString();
+            ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
+            URL resourceURL;
+            if(classLoader==null)
+                resourceURL = ClassLoader.getSystemResource(resource);
+            else
+                resourceURL = classLoader.getResource(resource);
+
+            if (resourceURL != null) {
+                logger.fine("Reading "+resourceURL);
+                r = new BufferedReader(new InputStreamReader(resourceURL.openStream(), "UTF-8"));
+                factoryClassName = r.readLine().trim();
+                return newInstance(classes, properties, factoryClassName);
+            } else {
+                logger.fine("Unable to find: " + resource);
+            }
+        } catch (UnsupportedEncodingException e) {
+            // should never happen
+            throw new JAXBException(e);
+        } catch (IOException e) {
+            throw new JAXBException(e);
+        }
+
+        // else no provider found
+        logger.fine("Trying to create the platform default provider");
+        return newInstance(classes, properties, PLATFORM_DEFAULT_FACTORY_CLASS);
+    }
+
+
+    private static Properties loadJAXBProperties( ClassLoader classLoader,
+                                                  String propFileName )
+        throws JAXBException {
+
+        Properties props = null;
+
+        try {
+            URL url;
+            if(classLoader==null)
+                url = ClassLoader.getSystemResource(propFileName);
+            else
+                url = classLoader.getResource( propFileName );
+
+            if( url != null ) {
+                logger.fine("loading props from "+url);
+                props = new Properties();
+                InputStream is = url.openStream();
+                props.load( is );
+                is.close();
+            }
+        } catch( IOException ioe ) {
+            logger.log(Level.FINE,"Unable to load "+propFileName,ioe);
+            throw new JAXBException( ioe.toString(), ioe );
+        }
+
+        return props;
+    }
+
+
+    /**
+     * Search the given ClassLoader for an instance of the specified class and
+     * return a string representation of the URL that points to the resource.
+     *
+     * @param clazz
+     *          The class to search for
+     * @param loader
+     *          The ClassLoader to search.  If this parameter is null, then the
+     *          system class loader will be searched
+     * @return
+     *          the URL for the class or null if it wasn't found
+     */
+    static URL which(Class clazz, ClassLoader loader) {
+
+        String classnameAsResource = clazz.getName().replace('.', '/') + ".class";
+
+        if(loader == null) {
+            loader = ClassLoader.getSystemClassLoader();
+        }
+
+        return loader.getResource(classnameAsResource);
+    }
+
+    /**
+     * Get the URL for the Class from it's ClassLoader.
+     *
+     * Convenience method for {@link #which(Class, ClassLoader)}.
+     *
+     * Equivalent to calling: which(clazz, clazz.getClassLoader())
+     *
+     * @param clazz
+     *          The class to search for
+     * @return
+     *          the URL for the class or null if it wasn't found
+     */
+    static URL which(Class clazz) {
+        return which(clazz, clazz.getClassLoader());
+    }
+
+    /**
+     * When JAXB is in J2SE, rt.jar has to have a JAXB implementation.
+     * However, rt.jar cannot have META-INF/services/javax.xml.bind.JAXBContext
+     * because if it has, it will take precedence over any file that applications have
+     * in their jar files.
+     *
+     * <p>
+     * When the user bundles his own JAXB implementation, we'd like to use it, and we
+     * want the platform default to be used only when there's no other JAXB provider.
+     *
+     * <p>
+     * For this reason, we have to hard-code the class name into the API.
+     */
+    private static final String PLATFORM_DEFAULT_FACTORY_CLASS = "com.sun.xml.internal.bind.v2.ContextFactory";
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/DatatypeConverter.java b/jaxws/src/share/classes/javax/xml/bind/DatatypeConverter.java
new file mode 100644
index 0000000..3e5ea90
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/DatatypeConverter.java
@@ -0,0 +1,643 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import javax.xml.namespace.NamespaceContext;
+
+/**
+ * <p>
+ * The javaType binding declaration can be used to customize the binding of
+ * an XML schema datatype to a Java datatype. Customizations can involve
+ * writing a parse and print method for parsing and printing lexical
+ * representations of a XML schema datatype respectively. However, writing
+ * parse and print methods requires knowledge of the lexical representations (
+ * <a href="http://www.w3.org/TR/xmlschema-2/"> XML Schema Part2: Datatypes
+ * specification </a>) and hence may be difficult to write.
+ * </p>
+ * <p>
+ * This class makes it easier to write parse and print methods. It defines
+ * static parse and print methods that provide access to a JAXB provider's
+ * implementation of parse and print methods. These methods are invoked by
+ * custom parse and print methods. For example, the binding of xsd:dateTime
+ * to a long can be customized using parse and print methods as follows:
+ * <blockquote>
+ *    <pre>
+ *    // Customized parse method
+ *    public long myParseCal( String dateTimeString ) {
+ *        java.util.Calendar cal = DatatypeConverter.parseDateTime(dateTimeString);
+ *        long longval = convert_calendar_to_long(cal); //application specific
+ *        return longval;
+ *    }
+ *
+ *    // Customized print method
+ *    public String myPrintCal( Long longval ) {
+ *        java.util.Calendar cal = convert_long_to_calendar(longval) ; //application specific
+ *        String dateTimeString = DatatypeConverter.printDateTime(cal);
+ *        return dateTimeString;
+ *    }
+ *    </pre>
+ * </blockquote>
+ * <p>
+ * There is a static parse and print method corresponding to each parse and
+ * print method respectively in the {@link DatatypeConverterInterface
+ * DatatypeConverterInterface}.
+ * <p>
+ * The static methods defined in the class can also be used to specify
+ * a parse or a print method in a javaType binding declaration.
+ * </p>
+ * <p>
+ * JAXB Providers are required to call the
+ * {@link #setDatatypeConverter(DatatypeConverterInterface)
+ * setDatatypeConverter} api at some point before the first marshal or unmarshal
+ * operation (perhaps during the call to JAXBContext.newInstance).  This step is
+ * necessary to configure the converter that should be used to perform the
+ * print and parse functionality.
+ * </p>
+ *
+ * <p>
+ * A print method for a XML schema datatype can output any lexical
+ * representation that is valid with respect to the XML schema datatype.
+ * If an error is encountered during conversion, then an IllegalArgumentException,
+ * or a subclass of IllegalArgumentException must be thrown by the method.
+ * </p>
+ *
+ * @author <ul><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Ryan Shoemaker,Sun Microsystems Inc.</li></ul>
+ * @see DatatypeConverterInterface
+ * @see ParseConversionEvent
+ * @see PrintConversionEvent
+ * @since JAXB1.0
+ */
+
+final public class DatatypeConverter {
+
+    // delegate to this instance of DatatypeConverter
+    private static DatatypeConverterInterface theConverter = null;
+
+    private DatatypeConverter() {
+        // private constructor
+    }
+
+    /**
+     * This method is for JAXB provider use only.
+     * <p>
+     * JAXB Providers are required to call this method at some point before
+     * allowing any of the JAXB client marshal or unmarshal operations to
+     * occur.  This is necessary to configure the datatype converter that
+     * should be used to perform the print and parse conversions.
+     *
+     * <p>
+     * Calling this api repeatedly will have no effect - the
+     * DatatypeConverterInterface instance passed into the first invocation is
+     * the one that will be used from then on.
+     *
+     * @param converter an instance of a class that implements the
+     * DatatypeConverterInterface class - this parameter must not be null.
+     * @throws IllegalArgumentException if the parameter is null
+     */
+    public static void setDatatypeConverter( DatatypeConverterInterface converter ) {
+        if( converter == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.CONVERTER_MUST_NOT_BE_NULL ) );
+        } else if( theConverter == null ) {
+            theConverter = converter;
+        }
+    }
+
+    /**
+     * <p>
+     * Convert the lexical XSD string argument into a String value.
+     * @param lexicalXSDString
+     *     A string containing a lexical representation of
+     *     xsd:string.
+     * @return
+     *     A String value represented by the string argument.
+     */
+    public static String parseString( String lexicalXSDString ) {
+        return theConverter.parseString( lexicalXSDString );
+    }
+
+    /**
+     * <p>
+     * Convert the string argument into a BigInteger value.
+     * @param lexicalXSDInteger
+     *     A string containing a lexical representation of
+     *     xsd:integer.
+     * @return
+     *     A BigInteger value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDInteger</code> is not a valid string representation of a {@link java.math.BigInteger} value.
+     */
+    public static java.math.BigInteger parseInteger( String lexicalXSDInteger ) {
+        return theConverter.parseInteger( lexicalXSDInteger );
+    }
+
+    /**
+     * <p>
+     * Convert the string argument into an int value.
+     * @param lexicalXSDInt
+     *     A string containing a lexical representation of
+     *     xsd:int.
+     * @return
+     *     A int value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDInt</code> is not a valid string representation of an <code>int</code> value.
+     */
+    public static int parseInt( String lexicalXSDInt ) {
+        return theConverter.parseInt( lexicalXSDInt );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a long value.
+     * @param lexicalXSDLong
+     *     A string containing lexical representation of
+     *     xsd:long.
+     * @return
+     *     A long value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDLong</code> is not a valid string representation of a <code>long</code> value.
+     */
+    public static long parseLong( String lexicalXSDLong ) {
+        return theConverter.parseLong( lexicalXSDLong );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a short value.
+     * @param lexicalXSDShort
+     *     A string containing lexical representation of
+     *     xsd:short.
+     * @return
+     *     A short value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDShort</code> is not a valid string representation of a <code>short</code> value.
+     */
+    public static short parseShort( String lexicalXSDShort ) {
+        return theConverter.parseShort( lexicalXSDShort );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a BigDecimal value.
+     * @param lexicalXSDDecimal
+     *     A string containing lexical representation of
+     *     xsd:decimal.
+     * @return
+     *     A BigDecimal value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDDecimal</code> is not a valid string representation of {@link java.math.BigDecimal}.
+     */
+    public static java.math.BigDecimal parseDecimal( String lexicalXSDDecimal ) {
+        return theConverter.parseDecimal( lexicalXSDDecimal );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a float value.
+     * @param lexicalXSDFloat
+     *     A string containing lexical representation of
+     *     xsd:float.
+     * @return
+     *     A float value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDFloat</code> is not a valid string representation of a <code>float</code> value.
+     */
+    public static float parseFloat( String lexicalXSDFloat ) {
+        return theConverter.parseFloat( lexicalXSDFloat );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a double value.
+     * @param lexicalXSDDouble
+     *     A string containing lexical representation of
+     *     xsd:double.
+     * @return
+     *     A double value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDDouble</code> is not a valid string representation of a <code>double</code> value.
+     */
+    public static double parseDouble( String lexicalXSDDouble ) {
+        return theConverter.parseDouble( lexicalXSDDouble );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a boolean value.
+     * @param lexicalXSDBoolean
+     *     A string containing lexical representation of
+     *     xsd:boolean.
+     * @return
+     *     A boolean value represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:boolean.
+     */
+    public static boolean parseBoolean( String lexicalXSDBoolean ) {
+        return theConverter.parseBoolean( lexicalXSDBoolean );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a byte value.
+     * @param lexicalXSDByte
+     *     A string containing lexical representation of
+     *     xsd:byte.
+     * @return
+     *     A byte value represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:byte.
+     */
+    public static byte parseByte( String lexicalXSDByte ) {
+        return theConverter.parseByte( lexicalXSDByte );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a byte value.
+     *
+     * <p>
+     * String parameter <tt>lexicalXSDQname</tt> must conform to lexical value space specifed at
+     * <a href="http://www.w3.org/TR/xmlschema-2/#QName">XML Schema Part 2:Datatypes specification:QNames</a>
+     *
+     * @param lexicalXSDQName
+     *     A string containing lexical representation of xsd:QName.
+     * @param nsc
+     *     A namespace context for interpreting a prefix within a QName.
+     * @return
+     *     A QName value represented by the string argument.
+     * @throws IllegalArgumentException  if string parameter does not conform to XML Schema Part 2 specification or
+     *      if namespace prefix of <tt>lexicalXSDQname</tt> is not bound to a URI in NamespaceContext <tt>nsc</tt>.
+     */
+    public static javax.xml.namespace.QName parseQName( String lexicalXSDQName,
+                                                    NamespaceContext nsc) {
+        return theConverter.parseQName( lexicalXSDQName, nsc );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a Calendar value.
+     * @param lexicalXSDDateTime
+     *     A string containing lexical representation of
+     *     xsd:datetime.
+     * @return
+     *     A Calendar object represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:dateTime.
+     */
+    public static java.util.Calendar parseDateTime( String lexicalXSDDateTime ) {
+        return theConverter.parseDateTime( lexicalXSDDateTime );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into an array of bytes.
+     * @param lexicalXSDBase64Binary
+     *     A string containing lexical representation
+     *     of xsd:base64Binary.
+     * @return
+     *     An array of bytes represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:base64Binary
+     */
+    public static byte[] parseBase64Binary( String lexicalXSDBase64Binary ) {
+        return theConverter.parseBase64Binary( lexicalXSDBase64Binary );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into an array of bytes.
+     * @param lexicalXSDHexBinary
+     *     A string containing lexical representation of
+     *     xsd:hexBinary.
+     * @return
+     *     An array of bytes represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:hexBinary.
+     */
+   public static byte[] parseHexBinary( String lexicalXSDHexBinary ) {
+        return theConverter.parseHexBinary( lexicalXSDHexBinary );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a long value.
+     * @param lexicalXSDUnsignedInt
+     *     A string containing lexical representation
+     *     of xsd:unsignedInt.
+     * @return
+     *     A long value represented by the string argument.
+     * @throws NumberFormatException if string parameter can not be parsed into a <tt>long</tt> value.
+     */
+    public static long parseUnsignedInt( String lexicalXSDUnsignedInt ) {
+        return theConverter.parseUnsignedInt( lexicalXSDUnsignedInt );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into an int value.
+     * @param lexicalXSDUnsignedShort
+     *     A string containing lexical
+     *     representation of xsd:unsignedShort.
+     * @return
+     *     An int value represented by the string argument.
+     * @throws NumberFormatException if string parameter can not be parsed into an <tt>int</tt> value.
+     */
+    public static int   parseUnsignedShort( String lexicalXSDUnsignedShort ) {
+        return theConverter.parseUnsignedShort( lexicalXSDUnsignedShort );
+    }
+
+    /**
+     * <p>
+     * Converts the string argument into a Calendar value.
+     * @param lexicalXSDTime
+     *     A string containing lexical representation of
+     *     xsd:time.
+     * @return
+     *     A Calendar value represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:Time.
+     */
+    public static java.util.Calendar parseTime( String lexicalXSDTime ) {
+        return theConverter.parseTime( lexicalXSDTime );
+    }
+    /**
+     * <p>
+     * Converts the string argument into a Calendar value.
+     * @param lexicalXSDDate
+     *      A string containing lexical representation of
+     *     xsd:Date.
+     * @return
+     *     A Calendar value represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:Date.
+     */
+    public static java.util.Calendar parseDate( String lexicalXSDDate ) {
+        return theConverter.parseDate( lexicalXSDDate );
+    }
+
+    /**
+     * <p>
+     * Return a string containing the lexical representation of the
+     * simple type.
+     * @param lexicalXSDAnySimpleType
+     *     A string containing lexical
+     *     representation of the simple type.
+     * @return
+     *     A string containing the lexical representation of the
+     *     simple type.
+     */
+    public static String parseAnySimpleType( String lexicalXSDAnySimpleType ) {
+        return theConverter.parseAnySimpleType( lexicalXSDAnySimpleType );
+    }
+    /**
+     * <p>
+     * Converts the string argument into a string.
+     * @param val
+     *     A string value.
+     * @return
+     *     A string containing a lexical representation of xsd:string.
+     */
+     // also indicate the print methods produce a lexical
+     // representation for given Java datatypes.
+
+    public static String printString( String val ) {
+        return theConverter.printString( val );
+    }
+
+    /**
+     * <p>
+     * Converts a BigInteger value into a string.
+     * @param val
+     *     A BigInteger value
+     * @return
+     *     A string containing a lexical representation of xsd:integer
+     * @throws IllegalArgumentException <tt>val</tt> is null.
+     */
+    public static String printInteger( java.math.BigInteger val ) {
+        return theConverter.printInteger( val );
+    }
+
+    /**
+     * <p>
+     * Converts an int value into a string.
+     * @param val
+     *     An int value
+     * @return
+     *     A string containing a lexical representation of xsd:int
+     */
+    public static String printInt( int val ) {
+        return theConverter.printInt( val );
+    }
+
+    /**
+     * <p>
+     * Converts A long value into a string.
+     * @param val
+     *     A long value
+     * @return
+     *     A string containing a lexical representation of xsd:long
+     */
+    public static String printLong( long val ) {
+        return theConverter.printLong( val );
+    }
+
+    /**
+     * <p>
+     * Converts a short value into a string.
+     * @param val
+     *     A short value
+     * @return
+     *     A string containing a lexical representation of xsd:short
+     */
+    public static String printShort( short val ) {
+        return theConverter.printShort( val );
+    }
+
+    /**
+     * <p>
+     * Converts a BigDecimal value into a string.
+     * @param val
+     *     A BigDecimal value
+     * @return
+     *     A string containing a lexical representation of xsd:decimal
+     * @throws IllegalArgumentException <tt>val</tt> is null.
+     */
+    public static String printDecimal( java.math.BigDecimal val ) {
+        return theConverter.printDecimal( val );
+    }
+
+    /**
+     * <p>
+     * Converts a float value into a string.
+     * @param val
+     *     A float value
+     * @return
+     *     A string containing a lexical representation of xsd:float
+     */
+    public static String printFloat( float val ) {
+        return theConverter.printFloat( val );
+    }
+
+    /**
+     * <p>
+     * Converts a double value into a string.
+     * @param val
+     *     A double value
+     * @return
+     *     A string containing a lexical representation of xsd:double
+     */
+    public static String printDouble( double val ) {
+        return theConverter.printDouble( val );
+    }
+
+    /**
+     * <p>
+     * Converts a boolean value into a string.
+     * @param val
+     *     A boolean value
+     * @return
+     *     A string containing a lexical representation of xsd:boolean
+     */
+    public static String printBoolean( boolean val ) {
+        return theConverter.printBoolean( val );
+    }
+
+    /**
+     * <p>
+     * Converts a byte value into a string.
+     * @param val
+     *     A byte value
+     * @return
+     *     A string containing a lexical representation of xsd:byte
+     */
+    public static String printByte( byte val ) {
+        return theConverter.printByte( val );
+    }
+
+    /**
+     * <p>
+     * Converts a QName instance into a string.
+     * @param val
+     *     A QName value
+     * @param nsc
+     *     A namespace context for interpreting a prefix within a QName.
+     * @return
+     *     A string containing a lexical representation of QName
+     * @throws IllegalArgumentException if <tt>val</tt> is null or
+     * if <tt>nsc</tt> is non-null or <tt>nsc.getPrefix(nsprefixFromVal)</tt> is null.
+     */
+    public static String printQName( javax.xml.namespace.QName val,
+                                     NamespaceContext nsc ) {
+        return theConverter.printQName( val, nsc );
+    }
+
+    /**
+     * <p>
+     * Converts a Calendar value into a string.
+     * @param val
+     *     A Calendar value
+     * @return
+     *     A string containing a lexical representation of xsd:dateTime
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public static String printDateTime( java.util.Calendar val ) {
+        return theConverter.printDateTime( val );
+    }
+
+    /**
+     * <p>
+     * Converts an array of bytes into a string.
+     * @param val
+     *     An array of bytes
+     * @return
+     *     A string containing a lexical representation of xsd:base64Binary
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public static String printBase64Binary( byte[] val ) {
+        return theConverter.printBase64Binary( val );
+    }
+
+    /**
+     * <p>
+     * Converts an array of bytes into a string.
+     * @param val
+     *     An array of bytes
+     * @return
+     *     A string containing a lexical representation of xsd:hexBinary
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public static String printHexBinary( byte[] val ) {
+        return theConverter.printHexBinary( val );
+    }
+
+    /**
+     * <p>
+     * Converts a long value into a string.
+     * @param val
+     *     A long value
+     * @return
+     *     A string containing a lexical representation of xsd:unsignedInt
+     */
+    public static String printUnsignedInt( long val ) {
+        return theConverter.printUnsignedInt( val );
+    }
+
+    /**
+     * <p>
+     * Converts an int value into a string.
+     * @param val
+     *     An int value
+     * @return
+     *     A string containing a lexical representation of xsd:unsignedShort
+     */
+    public static String printUnsignedShort( int val ) {
+        return theConverter.printUnsignedShort( val );
+    }
+
+    /**
+     * <p>
+     * Converts a Calendar value into a string.
+     * @param val
+     *     A Calendar value
+     * @return
+     *     A string containing a lexical representation of xsd:time
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public static String printTime( java.util.Calendar val ) {
+        return theConverter.printTime( val );
+    }
+
+    /**
+     * <p>
+     * Converts a Calendar value into a string.
+     * @param val
+     *     A Calendar value
+     * @return
+     *     A string containing a lexical representation of xsd:date
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public static String printDate( java.util.Calendar val ) {
+        return theConverter.printDate( val );
+    }
+
+    /**
+     * <p>
+     * Converts a string value into a string.
+     * @param val
+     *     A string value
+     * @return
+     *     A string containing a lexical representation of xsd:AnySimpleType
+     */
+    public static String printAnySimpleType( String val ) {
+        return theConverter.printAnySimpleType( val );
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/DatatypeConverterInterface.java b/jaxws/src/share/classes/javax/xml/bind/DatatypeConverterInterface.java
new file mode 100644
index 0000000..44d950b
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/DatatypeConverterInterface.java
@@ -0,0 +1,523 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * <p>
+ * The DatatypeConverterInterface is for JAXB provider use only. A
+ * JAXB provider must supply a class that implements this interface.
+ * JAXB Providers are required to call the
+ * {@link DatatypeConverter#setDatatypeConverter(DatatypeConverterInterface)
+ * DatatypeConverter.setDatatypeConverter} api at
+ * some point before the first marshal or unmarshal operation (perhaps during
+ * the call to JAXBContext.newInstance).  This step is necessary to configure
+ * the converter that should be used to perform the print and parse
+ * functionality.  Calling this api repeatedly will have no effect - the
+ * DatatypeConverter instance passed into the first invocation is the one that
+ * will be used from then on.
+ * </p>
+ *
+ * <p>
+ * This interface defines the parse and print methods. There is one
+ * parse and print method for each XML schema datatype specified in the
+ * the default binding Table 5-1 in the JAXB specification.
+ * </p>
+ *
+ * <p>
+ * The parse and print methods defined here are invoked by the static parse
+ * and print methods defined in the {@link DatatypeConverter DatatypeConverter}
+ * class.
+ * </p>
+ *
+ * <p>
+ * A parse method for a XML schema datatype must be capable of converting any
+ * lexical representation of the XML schema datatype ( specified by the
+ * <a href="http://www.w3.org/TR/xmlschema-2/"> XML Schema Part2: Datatypes
+ * specification</a> into a value in the value space of the XML schema datatype.
+ * If an error is encountered during conversion, then an IllegalArgumentException
+ * or a subclass of IllegalArgumentException must be thrown by the method.
+ *
+ * </p>
+ *
+ * <p>
+ * A print method for a XML schema datatype can output any lexical
+ * representation that is valid with respect to the XML schema datatype.
+ * If an error is encountered during conversion, then an IllegalArgumentException,
+ * or a subclass of IllegalArgumentException must be thrown by the method.
+ * </p>
+ *
+ * The prefix xsd: is used to refer to XML schema datatypes
+ * <a href="http://www.w3.org/TR/xmlschema-2/"> XML Schema Part2: Datatypes
+ * specification.</a>
+ *
+ * <p>
+ * @author <ul><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Ryan Shoemaker,Sun Microsystems Inc.</li></ul>
+ * @see DatatypeConverter
+ * @see ParseConversionEvent
+ * @see PrintConversionEvent
+ * @since JAXB1.0
+ */
+
+public interface DatatypeConverterInterface {
+    /**
+     * <p>
+     * Convert the string argument into a string.
+     * @param lexicalXSDString
+     *     A lexical representation of the XML Schema datatype xsd:string
+     * @return
+     *     A string that is the same as the input string.
+     */
+    public String parseString( String lexicalXSDString );
+
+    /**
+     * <p>
+     * Convert the string argument into a BigInteger value.
+     * @param lexicalXSDInteger
+     *     A string containing a lexical representation of
+     *     xsd:integer.
+     * @return
+     *     A BigInteger value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDInteger</code> is not a valid string representation of a {@link java.math.BigInteger} value.
+     */
+    public java.math.BigInteger parseInteger( String lexicalXSDInteger );
+
+    /**
+     * <p>
+     * Convert the string argument into an int value.
+     * @param lexicalXSDInt
+     *     A string containing a lexical representation of
+     *     xsd:int.
+     * @return
+     *     An int value represented byte the string argument.
+     * @throws NumberFormatException <code>lexicalXSDInt</code> is not a valid string representation of an <code>int</code> value.
+     */
+    public int parseInt( String lexicalXSDInt );
+
+    /**
+     * <p>
+     * Converts the string argument into a long value.
+     * @param lexicalXSDLong
+     *     A string containing lexical representation of
+     *     xsd:long.
+     * @return
+     *     A long value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDLong</code> is not a valid string representation of a <code>long</code> value.
+     */
+    public long parseLong( String lexicalXSDLong );
+
+    /**
+     * <p>
+     * Converts the string argument into a short value.
+     * @param lexicalXSDShort
+     *     A string containing lexical representation of
+     *     xsd:short.
+     * @return
+     *     A short value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDShort</code> is not a valid string representation of a <code>short</code> value.
+     */
+    public short parseShort( String lexicalXSDShort );
+
+    /**
+     * <p>
+     * Converts the string argument into a BigDecimal value.
+     * @param lexicalXSDDecimal
+     *     A string containing lexical representation of
+     *     xsd:decimal.
+     * @return
+     *     A BigDecimal value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDDecimal</code> is not a valid string representation of {@link java.math.BigDecimal}.
+     */
+    public java.math.BigDecimal parseDecimal( String lexicalXSDDecimal );
+
+    /**
+     * <p>
+     * Converts the string argument into a float value.
+     * @param lexicalXSDFloat
+     *     A string containing lexical representation of
+     *     xsd:float.
+     * @return
+     *     A float value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDFloat</code> is not a valid string representation of a <code>float</code> value.
+     */
+    public float parseFloat( String lexicalXSDFloat );
+
+    /**
+     * <p>
+     * Converts the string argument into a double value.
+     * @param lexicalXSDDouble
+     *     A string containing lexical representation of
+     *     xsd:double.
+     * @return
+     *     A double value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDDouble</code> is not a valid string representation of a <code>double</code> value.
+     */
+    public double parseDouble( String lexicalXSDDouble );
+
+    /**
+     * <p>
+     * Converts the string argument into a boolean value.
+     * @param lexicalXSDBoolean
+     *     A string containing lexical representation of
+     *     xsd:boolean.
+     * @return
+     *     A boolean value represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:boolean.
+     */
+    public boolean parseBoolean( String lexicalXSDBoolean );
+
+    /**
+     * <p>
+     * Converts the string argument into a byte value.
+     * @param lexicalXSDByte
+     *     A string containing lexical representation of
+     *     xsd:byte.
+     * @return
+     *     A byte value represented by the string argument.
+     * @throws NumberFormatException <code>lexicalXSDByte</code> does not contain a parseable byte.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:byte.
+     */
+    public byte parseByte( String lexicalXSDByte );
+
+    /**
+     * <p>
+     * Converts the string argument into a QName value.
+     *
+     * <p>
+     * String parameter <tt>lexicalXSDQname</tt> must conform to lexical value space specifed at
+     * <a href="http://www.w3.org/TR/xmlschema-2/#QName">XML Schema Part 2:Datatypes specification:QNames</a>
+     *
+     * @param lexicalXSDQName
+     *     A string containing lexical representation of xsd:QName.
+     * @param nsc
+     *     A namespace context for interpreting a prefix within a QName.
+     * @return
+     *     A QName value represented by the string argument.
+     * @throws IllegalArgumentException  if string parameter does not conform to XML Schema Part 2 specification or
+     *      if namespace prefix of <tt>lexicalXSDQname</tt> is not bound to a URI in NamespaceContext <tt>nsc</tt>.
+     */
+    public javax.xml.namespace.QName parseQName( String lexicalXSDQName,
+                                             javax.xml.namespace.NamespaceContext nsc);
+
+    /**
+     * <p>
+     * Converts the string argument into a Calendar value.
+     * @param lexicalXSDDateTime
+     *     A string containing lexical representation of
+     *     xsd:datetime.
+     * @return
+     *     A Calendar object represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:dateTime.
+     */
+    public java.util.Calendar parseDateTime( String lexicalXSDDateTime );
+
+    /**
+     * <p>
+     * Converts the string argument into an array of bytes.
+     * @param lexicalXSDBase64Binary
+     *     A string containing lexical representation
+     *     of xsd:base64Binary.
+     * @return
+     *     An array of bytes represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:base64Binary
+     */
+    public byte[] parseBase64Binary( String lexicalXSDBase64Binary );
+
+    /**
+     * <p>
+     * Converts the string argument into an array of bytes.
+     * @param lexicalXSDHexBinary
+     *     A string containing lexical representation of
+     *     xsd:hexBinary.
+     * @return
+     *     An array of bytes represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:hexBinary.
+     */
+    public byte[] parseHexBinary( String lexicalXSDHexBinary );
+
+    /**
+     * <p>
+     * Converts the string argument into a long value.
+     * @param lexicalXSDUnsignedInt
+     *     A string containing lexical representation
+     *     of xsd:unsignedInt.
+     * @return
+     *     A long value represented by the string argument.
+     * @throws NumberFormatException if string parameter can not be parsed into a <tt>long</tt> value.
+     */
+    public long parseUnsignedInt( String lexicalXSDUnsignedInt );
+
+    /**
+     * <p>
+     * Converts the string argument into an int value.
+     * @param lexicalXSDUnsignedShort
+     *     A string containing lexical
+     *     representation of xsd:unsignedShort.
+     * @return
+     *     An int value represented by the string argument.
+     * @throws NumberFormatException if string parameter can not be parsed into an <tt>int</tt> value.
+     */
+    public int parseUnsignedShort( String lexicalXSDUnsignedShort );
+
+    /**
+     * <p>
+     * Converts the string argument into a Calendar value.
+     * @param lexicalXSDTime
+     *     A string containing lexical representation of
+     *     xsd:Time.
+     * @return
+     *     A Calendar value represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:Time.
+     */
+    public java.util.Calendar parseTime( String lexicalXSDTime );
+
+    /**
+     * <p>
+     * Converts the string argument into a Calendar value.
+     * @param lexicalXSDDate
+     *     A string containing lexical representation of
+     *     xsd:Date.
+     * @return
+     *     A Calendar value represented by the string argument.
+     * @throws IllegalArgumentException if string parameter does not conform to lexical value space defined in XML Schema Part 2: Datatypes for xsd:Date.
+     */
+    public java.util.Calendar parseDate( String lexicalXSDDate );
+
+    /**
+     * <p>
+     * Return a string containing the lexical representation of the
+     * simple type.
+     * @param lexicalXSDAnySimpleType
+     *     A string containing lexical
+     *     representation of the simple type.
+     * @return
+     *     A string containing the lexical representation of the
+     *     simple type.
+     */
+    public String parseAnySimpleType( String lexicalXSDAnySimpleType );
+
+    /**
+     * <p>
+     * Converts the string argument into a string.
+     * @param val
+     *     A string value.
+     * @return
+     *     A string containing a lexical representation of xsd:string
+     */
+    public String printString( String val );
+
+    /**
+     * <p>
+     * Converts a BigInteger value into a string.
+     * @param val
+     *     A BigInteger value
+     * @return
+     *     A string containing a lexical representation of xsd:integer
+     * @throws IllegalArgumentException <tt>val</tt> is null.
+     */
+    public String printInteger( java.math.BigInteger val );
+
+    /**
+     * <p>
+     * Converts an int value into a string.
+     * @param val
+     *     An int value
+     * @return
+     *     A string containing a lexical representation of xsd:int
+     */
+    public String printInt( int val );
+
+
+    /**
+     * <p>
+     * Converts a long value into a string.
+     * @param val
+     *     A long value
+     * @return
+     *     A string containing a lexical representation of xsd:long
+     */
+    public String printLong( long val );
+
+    /**
+     * <p>
+     * Converts a short value into a string.
+     * @param val
+     *     A short value
+     * @return
+     *     A string containing a lexical representation of xsd:short
+     */
+    public String printShort( short val );
+
+    /**
+     * <p>
+     * Converts a BigDecimal value into a string.
+     * @param val
+     *     A BigDecimal value
+     * @return
+     *     A string containing a lexical representation of xsd:decimal
+     * @throws IllegalArgumentException <tt>val</tt> is null.
+     */
+    public String printDecimal( java.math.BigDecimal val );
+
+    /**
+     * <p>
+     * Converts a float value into a string.
+     * @param val
+     *     A float value
+     * @return
+     *     A string containing a lexical representation of xsd:float
+     */
+    public String printFloat( float val );
+
+    /**
+     * <p>
+     * Converts a double value into a string.
+     * @param val
+     *     A double value
+     * @return
+     *     A string containing a lexical representation of xsd:double
+     */
+    public String printDouble( double val );
+
+    /**
+     * <p>
+     * Converts a boolean value into a string.
+     * @param val
+     *     A boolean value
+     * @return
+     *     A string containing a lexical representation of xsd:boolean
+     */
+    public String printBoolean( boolean val );
+
+    /**
+     * <p>
+     * Converts a byte value into a string.
+     * @param val
+     *     A byte value
+     * @return
+     *     A string containing a lexical representation of xsd:byte
+     */
+    public String printByte( byte val );
+
+    /**
+     * <p>
+     * Converts a QName instance into a string.
+     * @param val
+     *     A QName value
+     * @param nsc
+     *     A namespace context for interpreting a prefix within a QName.
+     * @return
+     *     A string containing a lexical representation of QName
+     * @throws IllegalArgumentException if <tt>val</tt> is null or
+     * if <tt>nsc</tt> is non-null or <tt>nsc.getPrefix(nsprefixFromVal)</tt> is null.
+     */
+    public String printQName( javax.xml.namespace.QName val,
+                              javax.xml.namespace.NamespaceContext nsc );
+
+    /**
+     * <p>
+     * Converts a Calendar value into a string.
+     * @param val
+     *     A Calendar value
+     * @return
+     *     A string containing a lexical representation of xsd:dateTime
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public String printDateTime( java.util.Calendar val );
+
+    /**
+     * <p>
+     * Converts an array of bytes into a string.
+     * @param val
+     *     an array of bytes
+     * @return
+     *     A string containing a lexical representation of xsd:base64Binary
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public String printBase64Binary( byte[] val );
+
+    /**
+     * <p>
+     * Converts an array of bytes into a string.
+     * @param val
+     *     an array of bytes
+     * @return
+     *     A string containing a lexical representation of xsd:hexBinary
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public String printHexBinary( byte[] val );
+
+    /**
+     * <p>
+     * Converts a long value into a string.
+     * @param val
+     *     A long value
+     * @return
+     *     A string containing a lexical representation of xsd:unsignedInt
+     */
+    public String printUnsignedInt( long val );
+
+    /**
+     * <p>
+     * Converts an int value into a string.
+     * @param val
+     *     An int value
+     * @return
+     *     A string containing a lexical representation of xsd:unsignedShort
+     */
+    public String printUnsignedShort( int val );
+
+    /**
+     * <p>
+     * Converts a Calendar value into a string.
+     * @param val
+     *     A Calendar value
+     * @return
+     *     A string containing a lexical representation of xsd:time
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public String printTime( java.util.Calendar val );
+
+    /**
+     * <p>
+     * Converts a Calendar value into a string.
+     * @param val
+     *     A Calendar value
+     * @return
+     *     A string containing a lexical representation of xsd:date
+     * @throws IllegalArgumentException if <tt>val</tt> is null.
+     */
+    public String printDate( java.util.Calendar val );
+
+    /**
+     * <p>
+     * Converts a string value into a string.
+     * @param val
+     *     A string value
+     * @return
+     *     A string containing a lexical representation of xsd:AnySimpleType
+     */
+    public String printAnySimpleType( String val );
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/Element.java b/jaxws/src/share/classes/javax/xml/bind/Element.java
new file mode 100644
index 0000000..e50635a
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/Element.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This is an element marker interface.
+ *
+ * Under certain circumstances, it is necessary for the binding compiler to
+ * generate derived java content classes that implement this interface.  In
+ * those cases, client applications must supply element instances rather than
+ * types of elements.  For more detail, see section 5.7 "Element Declaration"
+ * and 5.7.1 "Bind to Java Element Interface" of the specification.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @since JAXB1.0
+ */
+
+public interface Element {
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/JAXBContext.java b/jaxws/src/share/classes/javax/xml/bind/JAXBContext.java
new file mode 100644
index 0000000..ce2ba30
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/JAXBContext.java
@@ -0,0 +1,706 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import org.w3c.dom.Node;
+
+import java.util.Collections;
+import java.util.Map;
+import java.io.IOException;
+
+/**
+ * <p>
+ * The <tt>JAXBContext</tt> class provides the client's entry point to the
+ * JAXB API. It provides an abstraction for managing the XML/Java binding
+ * information necessary to implement the JAXB binding framework operations:
+ * unmarshal, marshal and validate.
+ *
+ * <p>A client application normally obtains new instances of this class using
+ * one of these two styles for newInstance methods, although there are other
+ * specialized forms of the method available:
+ *
+ * <ul>
+ *   <li>{@link #newInstance(String,ClassLoader) JAXBContext.newInstance( "com.acme.foo:com.acme.bar" )} <br/>
+ *   The JAXBContext instance is initialized from a list of colon
+ *   separated Java package names. Each java package contains
+ *   JAXB mapped classes, schema-derived classes and/or user annotated
+ *   classes. Additionally, the java package may contain JAXB package annotations
+ *   that must be processed. (see JLS 3rd Edition, Section 7.4.1. Package Annotations).
+ *   </li>
+ *   <li>{@link #newInstance(Class...) JAXBContext.newInstance( com.acme.foo.Foo.class )} <br/>
+ *    The JAXBContext instance is intialized with class(es)
+ *    passed as parameter(s) and classes that are statically reachable from
+ *    these class(es). See {@link #newInstance(Class...)} for details.
+ *   </li>
+ * </ul>
+ *
+ * <p>
+ * <blockquote>
+ * <i><B>SPEC REQUIREMENT:</B> the provider must supply an implementation
+ * class containing the following method signatures:</i>
+ *
+ * <pre>
+ * public static JAXBContext createContext( String contextPath, ClassLoader classLoader, Map<String,Object> properties ) throws JAXBException
+ * public static JAXBContext createContext( Class[] classes, Map<String,Object> properties ) throws JAXBException
+ * </pre>
+ *
+ * <p><i>
+ * The following JAXB 1.0 requirement is only required for schema to
+ * java interface/implementation binding. It does not apply to JAXB annotated
+ * classes. JAXB Providers must generate a <tt>jaxb.properties</tt> file in
+ * each package containing schema derived classes.  The property file must
+ * contain a property named <tt>javax.xml.bind.context.factory</tt> whose
+ * value is the name of the class that implements the <tt>createContext</tt>
+ * APIs.</i>
+ *
+ * <p><i>
+ * The class supplied by the provider does not have to be assignable to
+ * <tt>javax.xml.bind.JAXBContext</tt>, it simply has to provide a class that
+ * implements the <tt>createContext</tt> APIs.</i>
+ *
+ * <p><i>
+ * In addition, the provider must call the
+ * {@link DatatypeConverter#setDatatypeConverter(DatatypeConverterInterface)
+ * DatatypeConverter.setDatatypeConverter} api prior to any client
+ * invocations of the marshal and unmarshal methods.  This is necessary to
+ * configure the datatype converter that will be used during these operations.</i>
+ * </blockquote>
+ *
+ * <p>
+ * <a name="Unmarshalling"></a>
+ * <b>Unmarshalling</b>
+ * <p>
+ * <blockquote>
+ * The {@link Unmarshaller} class provides the client application the ability
+ * to convert XML data into a tree of Java content objects.
+ * The unmarshal method allows for
+ * any global XML element declared in the schema to be unmarshalled as
+ * the root of an instance document.
+ * Additionally, the unmarshal method allows for an unrecognized root element that
+ * has  an xsi:type attribute's value that references a type definition declared in
+ * the schema  to be unmarshalled as the root of an instance document.
+ * The <tt>JAXBContext</tt> object
+ * allows the merging of global elements and type definitions across a set of schemas (listed
+ * in the <tt>contextPath</tt>). Since each schema in the schema set can belong
+ * to distinct namespaces, the unification of schemas to an unmarshalling
+ * context should be namespace independent.  This means that a client
+ * application is able to unmarshal XML documents that are instances of
+ * any of the schemas listed in the <tt>contextPath</tt>.  For example:
+ *
+ * <pre>
+ *        JAXBContext jc = JAXBContext.newInstance( "com.acme.foo:com.acme.bar" );
+ *        Unmarshaller u = jc.createUnmarshaller();
+ *        FooObject fooObj = (FooObject)u.unmarshal( new File( "foo.xml" ) ); // ok
+ *        BarObject barObj = (BarObject)u.unmarshal( new File( "bar.xml" ) ); // ok
+ *        BazObject bazObj = (BazObject)u.unmarshal( new File( "baz.xml" ) ); // error, "com.acme.baz" not in contextPath
+ * </pre>
+ *
+ * <p>
+ * The client application may also generate Java content trees explicitly rather
+ * than unmarshalling existing XML data.  For all JAXB-annotated value classes,
+ * an application can create content using constructors.
+ * For schema-derived interface/implementation classes and for the
+ * creation of elements that are not bound to a JAXB-annotated
+ * class, an application needs to have access and knowledge about each of
+ * the schema derived <tt> ObjectFactory</tt> classes that exist in each of
+ * java packages contained in the <tt>contextPath</tt>.  For each schema
+ * derived java class, there is a static factory method that produces objects
+ * of that type.  For example,
+ * assume that after compiling a schema, you have a package <tt>com.acme.foo</tt>
+ * that contains a schema derived interface named <tt>PurchaseOrder</tt>.  In
+ * order to create objects of that type, the client application would use the
+ * factory method like this:
+ *
+ * <pre>
+ *       com.acme.foo.PurchaseOrder po =
+ *           com.acme.foo.ObjectFactory.createPurchaseOrder();
+ * </pre>
+ *
+ * <p>
+ * Once the client application has an instance of the the schema derived object,
+ * it can use the mutator methods to set content on it.
+ *
+ * <p>
+ * For more information on the generated <tt>ObjectFactory</tt> classes, see
+ * Section 4.2 <i>Java Package</i> of the specification.
+ *
+ * <p>
+ * <i><B>SPEC REQUIREMENT:</B> the provider must generate a class in each
+ * package that contains all of the necessary object factory methods for that
+ * package named ObjectFactory as well as the static
+ * <tt>newInstance( javaContentInterface )</tt> method</i>
+ * </blockquote>
+ *
+ * <p>
+ * <b>Marshalling</b>
+ * <p>
+ * <blockquote>
+ * The {@link Marshaller} class provides the client application the ability
+ * to convert a Java content tree back into XML data.  There is no difference
+ * between marshalling a content tree that is created manually using the factory
+ * methods and marshalling a content tree that is the result an <tt>unmarshal
+ * </tt> operation.  Clients can marshal a java content tree back to XML data
+ * to a <tt>java.io.OutputStream</tt> or a <tt>java.io.Writer</tt>.  The
+ * marshalling process can alternatively produce SAX2 event streams to a
+ * registered <tt>ContentHandler</tt> or produce a DOM Node object.
+ * Client applications have control over the output encoding as well as
+ * whether or not to marshal the XML data as a complete document or
+ * as a fragment.
+ *
+ * <p>
+ * Here is a simple example that unmarshals an XML document and then marshals
+ * it back out:
+ *
+ * <pre>
+ *        JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *
+ *        // unmarshal from foo.xml
+ *        Unmarshaller u = jc.createUnmarshaller();
+ *        FooObject fooObj = (FooObject)u.unmarshal( new File( "foo.xml" ) );
+ *
+ *        // marshal to System.out
+ *        Marshaller m = jc.createMarshaller();
+ *        m.marshal( fooObj, System.out );
+ * </pre>
+ * </blockquote>
+ *
+ * <p>
+ * <b>Validation</b>
+ * <p>
+ * <blockquote>
+ * Validation has been changed significantly since JAXB 1.0.  The {@link Validator}
+ * class has been deprecated and made optional.  This means that you are advised
+ * not to use this class and, in fact, it may not even be available depending on
+ * your JAXB provider.  JAXB 1.0 client applications that rely on <tt>Validator</tt>
+ * will still work properly when deployed with the JAXB 1.0 runtime system.
+ *
+ * In JAXB 2.0, the {@link Unmarshaller} has included convenince methods that expose
+ * the JAXP 1.3 {@link javax.xml.validation} framework.  Please refer to the
+ * {@link Unmarshaller#setSchema(javax.xml.validation.Schema)} API for more
+ * information.
+ * </blockquote>
+ *
+ * <p>
+ * <b>JAXB Runtime Binding Framework Compatibility</b><br>
+ * <blockquote>
+ * The following JAXB 1.0 restriction only applies to binding schema to
+ * interfaces/implementation classes.
+ * Since this binding does not require a common runtime system, a JAXB
+ * client application must not attempt to mix runtime objects (<tt>JAXBContext,
+ * Marshaller</tt>, etc. ) from different providers.  This does not
+ * mean that the client application isn't portable, it simply means that a
+ * client has to use a runtime system provided by the same provider that was
+ * used to compile the schema.
+ * </blockquote>
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see Marshaller
+ * @see Unmarshaller
+ * @see <a href="http://java.sun.com/docs/books/jls">S 7.4.1.1 "Package Annotations" in Java Language Specification, 3rd Edition</a>
+ * @since JAXB1.0
+ */
+public abstract class JAXBContext {
+
+    /**
+     * The name of the property that contains the name of the class capable
+     * of creating new <tt>JAXBContext</tt> objects.
+     */
+    public static final String JAXB_CONTEXT_FACTORY =
+        "javax.xml.bind.context.factory";
+
+
+    protected JAXBContext() {
+    }
+
+
+    /**
+     * <p>
+     * Obtain a new instance of a <tt>JAXBContext</tt> class.
+     *
+     * <p>
+     * This is a convenience method for the
+     * {@link #newInstance(String,ClassLoader) newInstance} method.  It uses
+     * the context class loader of the current thread.  To specify the use of
+     * a different class loader, either set it via the
+     * <tt>Thread.setContextClassLoader()</tt> api or use the
+     * {@link #newInstance(String,ClassLoader) newInstance} method.
+     * @throws JAXBException if an error was encountered while creating the
+     *                       <tt>JAXBContext</tt> such as
+     * <ol>
+     *   <li>failure to locate either ObjectFactory.class or jaxb.index in the packages</li>
+     *   <li>an ambiguity among global elements contained in the contextPath</li>
+     *   <li>failure to locate a value for the context factory provider property</li>
+     *   <li>mixing schema derived packages from different providers on the same contextPath</li>
+     * </ol>
+     */
+    public static JAXBContext newInstance( String contextPath )
+        throws JAXBException {
+
+        //return newInstance( contextPath, JAXBContext.class.getClassLoader() );
+        return newInstance( contextPath, Thread.currentThread().getContextClassLoader() );
+    }
+
+    /**
+     * <p>
+     * Obtain a new instance of a <tt>JAXBContext</tt> class.
+     *
+     * <p>
+     * The client application must supply a context path which is a list of
+     * colon (':', \u005Cu003A) separated java package names that contain
+     * schema-derived classes and/or fully qualified JAXB-annotated classes.
+     * Schema-derived
+     * code is registered with the JAXBContext by the
+     * ObjectFactory.class generated per package.
+     * Alternatively than being listed in the context path, programmer
+     * annotated JAXB mapped classes can be listed in a
+     * <tt>jaxb.index</tt> resource file, format described below.
+     * Note that a java package can contain both schema-derived classes and
+     * user annotated JAXB classes. Additionally, the java package may
+     * contain JAXB package annotations  that must be processed. (see JLS 3rd Edition,
+     * Section 7.4.1. "Package Annotations").
+     * </p>
+     *
+     * <p>
+     * Every package listed on the contextPath must meet <b>one or both</b> of the
+     * following conditions otherwise a <tt>JAXBException</tt> will be thrown:
+     * </p>
+     * <ol>
+     *   <li>it must contain ObjectFactory.class</li>
+     *   <li>it must contain jaxb.index</li>
+     * </ol>
+     *
+     * <p>
+     * <b>Format for jaxb.index</b>
+     * <p>
+     * The file contains a newline-separated list of class names.
+     * Space and tab characters, as well as blank
+     * lines, are ignored. The comment character
+     * is '#' (0x23); on each line all characters following the first comment
+     * character are ignored. The file must be encoded in UTF-8. Classes that
+     * are reachable, as defined in {@link #newInstance(Class...)}, from the
+     * listed classes are also registered with JAXBContext.
+     * <p>
+     * Constraints on class name occuring in a <tt>jaxb.index</tt> file are:
+     * <ul>
+     *   <li>Must not end with ".class".</li>
+     *   <li>Class names are resolved relative to package containing
+     *       <tt>jaxb.index</tt> file. Only classes occuring directly in package
+     *       containing <tt>jaxb.index</tt> file are allowed.</li>
+     *   <li>Fully qualified class names are not allowed.
+     *       A qualified class name,relative to current package,
+     *       is only allowed to specify a nested or inner class.</li>
+     * </ul>
+     *
+     * <p>
+     * To maintain compatibility with JAXB 1.0 schema to java
+     * interface/implementation binding, enabled by schema customization
+     * <tt><jaxb:globalBindings valueClass="false"></tt>,
+     * the JAXB provider will ensure that each package on the context path
+     * has a <tt>jaxb.properties</tt> file which contains a value for the
+     * <tt>javax.xml.bind.context.factory</tt> property and that all values
+     * resolve to the same provider.  This requirement does not apply to
+     * JAXB annotated classes.
+     *
+     * <p>
+     * If there are any global XML element name collisions across the various
+     * packages listed on the <tt>contextPath</tt>, a <tt>JAXBException</tt>
+     * will be thrown.
+     *
+     * <p>
+     * Mixing generated interface/impl bindings from multiple JAXB Providers
+     * in the same context path may result in a <tt>JAXBException</tt>
+     * being thrown.
+     *
+     * @param contextPath list of java package names that contain schema
+     *                    derived class and/or java to schema (JAXB-annotated)
+     *                    mapped classes
+     * @param classLoader
+     *      This class loader will be used to locate the implementation
+     *      classes.
+     *
+     * @return a new instance of a <tt>JAXBContext</tt>
+     * @throws JAXBException if an error was encountered while creating the
+     *                       <tt>JAXBContext</tt> such as
+     * <ol>
+     *   <li>failure to locate either ObjectFactory.class or jaxb.index in the packages</li>
+     *   <li>an ambiguity among global elements contained in the contextPath</li>
+     *   <li>failure to locate a value for the context factory provider property</li>
+     *   <li>mixing schema derived packages from different providers on the same contextPath</li>
+     * </ol>
+     */
+    public static JAXBContext newInstance( String contextPath, ClassLoader classLoader ) throws JAXBException {
+
+        return newInstance(contextPath,classLoader,Collections.<String,Object>emptyMap());
+    }
+
+    /**
+     * <p>
+     * Obtain a new instance of a <tt>JAXBContext</tt> class.
+     *
+     * <p>
+     * This is mostly the same as {@link JAXBContext#newInstance(String, ClassLoader)},
+     * but this version allows you to pass in provider-specific properties to configure
+     * the instanciation of {@link JAXBContext}.
+     *
+     * <p>
+     * The interpretation of properties is up to implementations.
+     *
+     * @param contextPath list of java package names that contain schema derived classes
+     * @param classLoader
+     *      This class loader will be used to locate the implementation classes.
+     * @param properties
+     *      provider-specific properties
+     *
+     * @return a new instance of a <tt>JAXBContext</tt>
+     * @throws JAXBException if an error was encountered while creating the
+     *                       <tt>JAXBContext</tt> such as
+     * <ol>
+     *   <li>failure to locate either ObjectFactory.class or jaxb.index in the packages</li>
+     *   <li>an ambiguity among global elements contained in the contextPath</li>
+     *   <li>failure to locate a value for the context factory provider property</li>
+     *   <li>mixing schema derived packages from different providers on the same contextPath</li>
+     * </ol>
+     * @since JAXB2.0
+     */
+    public static JAXBContext newInstance( String contextPath, ClassLoader classLoader, Map<String,?>  properties  )
+        throws JAXBException {
+
+        return ContextFinder.find(
+                        /* The default property name according to the JAXB spec */
+                        JAXB_CONTEXT_FACTORY,
+
+                        /* the context path supplied by the client app */
+                        contextPath,
+
+                        /* class loader to be used */
+                        classLoader,
+                        properties );
+    }
+
+// TODO: resurrect this once we introduce external annotations
+//    /**
+//     * <p>
+//     * Obtain a new instance of a <tt>JAXBContext</tt> class.
+//     *
+//     * <p>
+//     * The client application must supply a list of classes that the new
+//     * context object needs to recognize.
+//     *
+//     * Not only the new context will recognize all the classes specified,
+//     * but it will also recognize any classes that are directly/indirectly
+//     * referenced statically from the specified classes.
+//     *
+//     * For example, in the following Java code, if you do
+//     * <tt>newInstance(Foo.class)</tt>, the newly created {@link JAXBContext}
+//     * will recognize both <tt>Foo</tt> and <tt>Bar</tt>, but not <tt>Zot</tt>:
+//     * <pre><xmp>
+//     * class Foo {
+//     *      Bar b;
+//     * }
+//     * class Bar { int x; }
+//     * class Zot extends Bar { int y; }
+//     * </xmp></pre>
+//     *
+//     * Therefore, a typical client application only needs to specify the
+//     * top-level classes, but it needs to be careful.
+//     *
+//     * TODO: if we are to define other mechanisms, refer to them.
+//     *
+//     * @param externalBindings
+//     *      list of external binding files. Can be null or empty if none is used.
+//     *      when specified, those files determine how the classes are bound.
+//     *
+//     * @param classesToBeBound
+//     *      list of java classes to be recognized by the new {@link JAXBContext}.
+//     *      Can be empty, in which case a {@link JAXBContext} that only knows about
+//     *      spec-defined classes will be returned.
+//     *
+//     * @return
+//     *      A new instance of a <tt>JAXBContext</tt>. Always non-null valid object.
+//     *
+//     * @throws JAXBException
+//     *      if an error was encountered while creating the
+//     *      <tt>JAXBContext</tt>, such as (but not limited to):
+//     * <ol>
+//     *  <li>No JAXB implementation was discovered
+//     *  <li>Classes use JAXB annotations incorrectly
+//     *  <li>Classes have colliding annotations (i.e., two classes with the same type name)
+//     *  <li>Specified external bindings are incorrect
+//     *  <li>The JAXB implementation was unable to locate
+//     *      provider-specific out-of-band information (such as additional
+//     *      files generated at the development time.)
+//     * </ol>
+//     *
+//     * @throws IllegalArgumentException
+//     *      if the parameter contains {@code null} (i.e., {@code newInstance(null);})
+//     *
+//     * @since JAXB2.0
+//     */
+//    public static JAXBContext newInstance( Source[] externalBindings, Class... classesToBeBound )
+//        throws JAXBException {
+//
+//        // empty class list is not an error, because the context will still include
+//        // spec-specified classes like String and Integer.
+//        // if(classesToBeBound.length==0)
+//        //    throw new IllegalArgumentException();
+//
+//        // but it is an error to have nulls in it.
+//        for( int i=classesToBeBound.length-1; i>=0; i-- )
+//            if(classesToBeBound[i]==null)
+//                throw new IllegalArgumentException();
+//
+//        return ContextFinder.find(externalBindings,classesToBeBound);
+//    }
+
+    /**
+     * <p>
+     * Obtain a new instance of a <tt>JAXBContext</tt> class.
+     *
+     * <p>
+     * The client application must supply a list of classes that the new
+     * context object needs to recognize.
+     *
+     * Not only the new context will recognize all the classes specified,
+     * but it will also recognize any classes that are directly/indirectly
+     * referenced statically from the specified classes. Subclasses of
+     * referenced classes nor <tt>&#64;XmlTransient</tt> referenced classes
+     * are not registered with JAXBContext.
+     *
+     * For example, in the following Java code, if you do
+     * <tt>newInstance(Foo.class)</tt>, the newly created {@link JAXBContext}
+     * will recognize both <tt>Foo</tt> and <tt>Bar</tt>, but not <tt>Zot</tt> or <tt>FooBar</tt>:
+     * <pre>
+     * class Foo {
+     *      &#64;XmlTransient FooBar c;
+     *      Bar b;
+     * }
+     * class Bar { int x; }
+     * class Zot extends Bar { int y; }
+     * class FooBar { }
+     * </pre>
+     *
+     * Therefore, a typical client application only needs to specify the
+     * top-level classes, but it needs to be careful.
+     *
+     * <p>
+     * Note that for each java package registered with JAXBContext,
+     * when the optional package annotations exist, they must be processed.
+     * (see JLS 3rd Edition, Section 7.4.1. "Package Annotations").
+     *
+     * @param classesToBeBound
+     *      list of java classes to be recognized by the new {@link JAXBContext}.
+     *      Can be empty, in which case a {@link JAXBContext} that only knows about
+     *      spec-defined classes will be returned.
+     *
+     * @return
+     *      A new instance of a <tt>JAXBContext</tt>. Always non-null valid object.
+     *
+     * @throws JAXBException
+     *      if an error was encountered while creating the
+     *      <tt>JAXBContext</tt>, such as (but not limited to):
+     * <ol>
+     *  <li>No JAXB implementation was discovered
+     *  <li>Classes use JAXB annotations incorrectly
+     *  <li>Classes have colliding annotations (i.e., two classes with the same type name)
+     *  <li>The JAXB implementation was unable to locate
+     *      provider-specific out-of-band information (such as additional
+     *      files generated at the development time.)
+     * </ol>
+     *
+     * @throws IllegalArgumentException
+     *      if the parameter contains {@code null} (i.e., {@code newInstance(null);})
+     *
+     * @since JAXB2.0
+     */
+    public static JAXBContext newInstance( Class... classesToBeBound )
+        throws JAXBException {
+
+        return newInstance(classesToBeBound,Collections.<String,Object>emptyMap());
+    }
+
+    /**
+     * <p>
+     * Obtain a new instance of a <tt>JAXBContext</tt> class.
+     *
+     * <p>
+     * An overloading of {@link JAXBContext#newInstance(Class...)}
+     * to configure 'properties' for this instantiation of {@link JAXBContext}.
+     *
+     * <p>
+     * The interpretation of properties is implementation specific.
+     *
+     * @param classesToBeBound
+     *      list of java classes to be recognized by the new {@link JAXBContext}.
+     *      Can be empty, in which case a {@link JAXBContext} that only knows about
+     *      spec-defined classes will be returned.
+     *
+     * @return
+     *      A new instance of a <tt>JAXBContext</tt>. Always non-null valid object.
+     *
+     * @throws JAXBException
+     *      if an error was encountered while creating the
+     *      <tt>JAXBContext</tt>, such as (but not limited to):
+     * <ol>
+     *  <li>No JAXB implementation was discovered
+     *  <li>Classes use JAXB annotations incorrectly
+     *  <li>Classes have colliding annotations (i.e., two classes with the same type name)
+     *  <li>The JAXB implementation was unable to locate
+     *      provider-specific out-of-band information (such as additional
+     *      files generated at the development time.)
+     * </ol>
+     *
+     * @throws IllegalArgumentException
+     *      if the parameter contains {@code null} (i.e., {@code newInstance(null);})
+     *
+     * @since JAXB2.0
+     */
+    public static JAXBContext newInstance( Class[] classesToBeBound, Map<String,?> properties )
+        throws JAXBException {
+
+        // empty class list is not an error, because the context will still include
+        // spec-specified classes like String and Integer.
+        // if(classesToBeBound.length==0)
+        //    throw new IllegalArgumentException();
+
+        // but it is an error to have nulls in it.
+        for( int i=classesToBeBound.length-1; i>=0; i-- )
+            if(classesToBeBound[i]==null)
+                throw new IllegalArgumentException();
+
+        return ContextFinder.find(classesToBeBound,properties);
+    }
+
+    /**
+     * Create an <tt>Unmarshaller</tt> object that can be used to convert XML
+     * data into a java content tree.
+     *
+     * @return an <tt>Unmarshaller</tt> object
+     *
+     * @throws JAXBException if an error was encountered while creating the
+     *                       <tt>Unmarshaller</tt> object
+     */
+    public abstract Unmarshaller createUnmarshaller() throws JAXBException;
+
+
+    /**
+     * Create a <tt>Marshaller</tt> object that can be used to convert a
+     * java content tree into XML data.
+     *
+     * @return a <tt>Marshaller</tt> object
+     *
+     * @throws JAXBException if an error was encountered while creating the
+     *                       <tt>Marshaller</tt> object
+     */
+    public abstract Marshaller createMarshaller() throws JAXBException;
+
+
+    /**
+     * {@link Validator} has been made optional and deprecated in JAXB 2.0.  Please
+     * refer to the javadoc for {@link Validator} for more detail.
+     * <p>
+     * Create a <tt>Validator</tt> object that can be used to validate a
+     * java content tree against its source schema.
+     *
+     * @return a <tt>Validator</tt> object
+     *
+     * @throws JAXBException if an error was encountered while creating the
+     *                       <tt>Validator</tt> object
+     * @deprecated since JAXB2.0
+     */
+    public abstract Validator createValidator() throws JAXBException;
+
+    /**
+     * Creates a <tt>Binder</tt> object that can be used for
+     * associative/in-place unmarshalling/marshalling.
+     *
+     * @param domType select the DOM API to use by passing in its DOM Node class.
+     *
+     * @return always a new valid <tt>Binder</tt> object.
+     *
+     * @throws UnsupportedOperationException
+     *      if DOM API corresponding to <tt>domType</tt> is not supported by
+     *      the implementation.
+     *
+     * @since JAXB2.0
+     */
+    public <T> Binder<T> createBinder(Class<T> domType) {
+        // to make JAXB 1.0 implementations work, this method must not be
+        // abstract
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * Creates a <tt>Binder</tt> for W3C DOM.
+     *
+     * @return always a new valid <tt>Binder</tt> object.
+     *
+     * @since JAXB2.0
+     */
+    public Binder<Node> createBinder() {
+        return createBinder(Node.class);
+    }
+
+    /**
+     * Creates a <tt>JAXBIntrospector</tt> object that can be used to
+     * introspect JAXB objects.
+     *
+     * @return
+     *      always return a non-null valid <tt>JAXBIntrospector</tt> object.
+     *
+     * @throws UnsupportedOperationException
+     *      Calling this method on JAXB 1.0 implementations will throw
+     *      an UnsupportedOperationException.
+     *
+     * @since JAXB2.0
+     */
+    public JAXBIntrospector createJAXBIntrospector() {
+        // to make JAXB 1.0 implementations work, this method must not be
+        // abstract
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * Generates the schema documents for this context.
+     *
+     * @param outputResolver
+     *      this object controls the output to which schemas
+     *      will be sent.
+     *
+     * @throws IOException
+     *      if {@link SchemaOutputResolver} throws an {@link IOException}.
+     *
+     * @throws UnsupportedOperationException
+     *      Calling this method on JAXB 1.0 implementations will throw
+     *      an UnsupportedOperationException.
+     *
+     * @since JAXB 2.0
+     */
+    public void generateSchema(SchemaOutputResolver outputResolver) throws IOException  {
+        // to make JAXB 1.0 implementations work, this method must not be
+        // abstract
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/JAXBElement.java b/jaxws/src/share/classes/javax/xml/bind/JAXBElement.java
new file mode 100644
index 0000000..c8db788
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/JAXBElement.java
@@ -0,0 +1,218 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import javax.xml.namespace.QName;
+import java.io.Serializable;
+
+/**
+ * <p>JAXB representation of an Xml Element.</p>
+ *
+ * <p>This class represents information about an Xml Element from both the element
+ * declaration within a schema and the element instance value within an xml document
+ * with the following properties
+ * <ul>
+ *   <li>element's xml tag <b><tt>name</tt></b></li>
+ *   <li><b><tt>value</tt></b> represents the element instance's atttribute(s) and content model</li>
+ *   <li>element declaration's <b><tt>declaredType</tt></b> (<tt>xs:element @type</tt> attribute)</li>
+ *   <li><b><tt>scope</tt></b> of element declaration</li>
+ *   <li>boolean <b><tt>nil</tt></b> property. (element instance's <tt><b>xsi:nil</b></tt> attribute)</li>
+ * </ul>
+ *
+ * <p>The <tt>declaredType</tt> and <tt>scope</tt> property are the
+ * JAXB class binding for the xml type definition.
+ * </p>
+ *
+ * <p><b><tt>Scope</tt></b> is either {@link GlobalScope} or the Java class representing the
+ * complex type definition containing the schema element declaration.
+ * </p>
+ *
+ * <p>There is a property constraint that if <b><tt>value</tt></b> is <tt>null</tt>,
+ * then <tt>nil</tt> must be <tt>true</tt>. The converse is not true to enable
+ * representing a nil element with attribute(s). If <tt>nil</tt> is true, it is possible
+ * that <tt>value</tt> is non-null so it can hold the value of the attributes
+ * associated with a nil element.
+ * </p>
+ *
+ * @author Kohsuke Kawaguchi, Joe Fialli
+ * @since JAXB 2.0
+ */
+
+public class JAXBElement<T> implements Serializable {
+
+    /** xml element tag name */
+    final protected QName name;
+
+    /** Java datatype binding for xml element declaration's type. */
+    final protected Class<T> declaredType;
+
+    /** Scope of xml element declaration representing this xml element instance.
+     *  Can be one of the following values:
+     *  - {@link GlobalScope} for global xml element declaration.
+     *  - local element declaration has a scope set to the Java class
+     *     representation of complex type defintion containing
+     *     xml element declaration.
+     */
+    final protected Class scope;
+
+    /** xml element value.
+        Represents content model and attributes of an xml element instance. */
+    protected T value;
+
+    /** true iff the xml element instance has xsi:nil="true". */
+    protected boolean nil = false;
+
+    /**
+     * Designates global scope for an xml element.
+     */
+    public static final class GlobalScope {}
+
+    /**
+     * <p>Construct an xml element instance.</p>
+     *
+     * @param name          Java binding of xml element tag name
+     * @param declaredType  Java binding of xml element declaration's type
+     * @param scope
+     *      Java binding of scope of xml element declaration.
+     *      Passing null is the same as passing <tt>GlobalScope.class</tt>
+     * @param value
+     *      Java instance representing xml element's value.
+     * @see #getScope()
+     * @see #isTypeSubstituted()
+     */
+    public JAXBElement(QName name,
+                       Class<T> declaredType,
+                       Class scope,
+                       T value) {
+        if(declaredType==null || name==null)
+            throw new IllegalArgumentException();
+        this.declaredType = declaredType;
+        if(scope==null)     scope = GlobalScope.class;
+        this.scope = scope;
+        this.name = name;
+        setValue(value);
+    }
+
+    /**
+     * Construct an xml element instance.
+     *
+     * This is just a convenience method for <tt>new JAXBElement(name,declaredType,GlobalScope.class,value)</tt>
+     */
+    public JAXBElement(QName name, Class<T> declaredType, T value ) {
+        this(name,declaredType,GlobalScope.class,value);
+    }
+
+    /**
+     * Returns the Java binding of the xml element declaration's type attribute.
+     */
+    public Class<T> getDeclaredType() {
+        return declaredType;
+    }
+
+    /**
+     * Returns the xml element tag name.
+     */
+    public QName getName() {
+        return name;
+    }
+
+    /**
+     * <p>Set the content model and attributes of this xml element.</p>
+     *
+     * <p>When this property is set to <tt>null</tt>, <tt>isNil()</tt> must by <tt>true</tt>.
+     *    Details of constraint are described at {@link #isNil()}.</p>
+     *
+     * @see #isTypeSubstituted()
+     */
+    public void setValue(T t) {
+        this.value = t;
+    }
+
+    /**
+     * <p>Return the content model and attribute values for this element.</p>
+     *
+     * <p>See {@link #isNil()} for a description of a property constraint when
+     * this value is <tt>null</tt></p>
+     */
+    public T getValue() {
+        return value;
+    }
+
+    /**
+     * Returns scope of xml element declaration.
+     *
+     * @see #isGlobalScope()
+     * @return <tt>GlobalScope.class</tt> if this element is of global scope.
+     */
+    public Class getScope() {
+        return scope;
+    }
+
+    /**
+     * <p>Returns <tt>true</tt> iff this element instance content model
+     * is nil.</p>
+     *
+     * <p>This property always returns <tt>true</tt> when {@link #getValue()} is null.
+     * Note that the converse is not true, when this property is <tt>true</tt>,
+     * {@link #getValue()} can contain a non-null value for attribute(s). It is
+     * valid for a nil xml element to have attribute(s).</p>
+     */
+    public boolean isNil() {
+        return (value == null) || nil;
+    }
+
+    /**
+     * <p>Set whether this element has nil content.</p>
+     *
+     * @see #isNil()
+     */
+    public void setNil(boolean value) {
+        this.nil = value;
+    }
+
+    /* Convenience methods
+     * (Not necessary but they do unambiguously conceptualize
+     *  the rationale behind this class' fields.)
+     */
+
+    /**
+     * Returns true iff this xml element declaration is global.
+     */
+    public boolean isGlobalScope() {
+        return this.scope == GlobalScope.class;
+    }
+
+    /**
+     * Returns true iff this xml element instance's value has a different
+     * type than xml element declaration's declared type.
+     */
+    public boolean isTypeSubstituted() {
+        if(value==null)     return false;
+        return value.getClass() != declaredType;
+    }
+
+    private static final long serialVersionUID = 1L;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/JAXBException.java b/jaxws/src/share/classes/javax/xml/bind/JAXBException.java
new file mode 100644
index 0000000..55aa587
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/JAXBException.java
@@ -0,0 +1,184 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import java.io.PrintWriter;
+
+/**
+ * This is the root exception class for all JAXB exceptions.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBContext
+ * @see Marshaller
+ * @see Unmarshaller
+ * @since JAXB1.0
+ */
+public class JAXBException extends Exception {
+
+    /**
+     * Vendor specific error code
+     *
+     */
+    private String errorCode;
+
+    /**
+     * Exception reference
+     *
+     */
+    private Throwable linkedException;
+
+    static final long serialVersionUID = -5621384651494307979L;
+
+    /**
+     * Construct a JAXBException with the specified detail message.  The
+     * errorCode and linkedException will default to null.
+     *
+     * @param message a description of the exception
+     */
+    public JAXBException(String message) {
+        this( message, null, null );
+    }
+
+    /**
+     * Construct a JAXBException with the specified detail message and vendor
+     * specific errorCode.  The linkedException will default to null.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     */
+    public JAXBException(String message, String errorCode) {
+        this( message, errorCode, null );
+    }
+
+    /**
+     * Construct a JAXBException with a linkedException.  The detail message and
+     * vendor specific errorCode will default to null.
+     *
+     * @param exception the linked exception
+     */
+    public JAXBException(Throwable exception) {
+        this( null, null, exception );
+    }
+
+    /**
+     * Construct a JAXBException with the specified detail message and
+     * linkedException.  The errorCode will default to null.
+     *
+     * @param message a description of the exception
+     * @param exception the linked exception
+     */
+    public JAXBException(String message, Throwable exception) {
+        this( message, null, exception );
+    }
+
+    /**
+     * Construct a JAXBException with the specified detail message, vendor
+     * specific errorCode, and linkedException.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     * @param exception the linked exception
+     */
+    public JAXBException(String message, String errorCode, Throwable exception) {
+        super( message );
+        this.errorCode = errorCode;
+        this.linkedException = exception;
+    }
+
+    /**
+     * Get the vendor specific error code
+     *
+     * @return a string specifying the vendor specific error code
+     */
+    public String getErrorCode() {
+        return this.errorCode;
+    }
+
+    /**
+     * Get the linked exception
+     *
+     * @return the linked Exception, null if none exists
+     */
+    public Throwable getLinkedException() {
+        return linkedException;
+    }
+
+    /**
+     * Add a linked Exception.
+     *
+     * @param exception the linked Exception (A null value is permitted and
+     *                  indicates that the linked exception does not exist or
+     *                  is unknown).
+     */
+    public synchronized void setLinkedException( Throwable exception ) {
+        this.linkedException = exception;
+    }
+
+    /**
+     * Returns a short description of this JAXBException.
+     *
+     */
+    public String toString() {
+        return linkedException == null ?
+            super.toString() :
+            super.toString() + "\n - with linked exception:\n[" +
+                                linkedException.toString()+ "]";
+    }
+
+    /**
+     * Prints this JAXBException and its stack trace (including the stack trace
+     * of the linkedException if it is non-null) to the PrintStream.
+     *
+     * @param s PrintStream to use for output
+     */
+    public void printStackTrace( java.io.PrintStream s ) {
+        super.printStackTrace(s);
+    }
+
+    /**
+     * Prints this JAXBException and its stack trace (including the stack trace
+     * of the linkedException if it is non-null) to <tt>System.err</tt>.
+     *
+     */
+    public void printStackTrace() {
+        super.printStackTrace();
+    }
+
+    /**
+     * Prints this JAXBException and its stack trace (including the stack trace
+     * of the linkedException if it is non-null) to the PrintWriter.
+     *
+     * @param s PrintWriter to use for output
+     */
+    public void printStackTrace(PrintWriter s) {
+        super.printStackTrace(s);
+    }
+
+    @Override
+    public Throwable getCause() {
+        return linkedException;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/JAXBIntrospector.java b/jaxws/src/share/classes/javax/xml/bind/JAXBIntrospector.java
new file mode 100644
index 0000000..0be32b7
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/JAXBIntrospector.java
@@ -0,0 +1,92 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+import  javax.xml.namespace.QName;
+
+/**
+ * Provide access to JAXB xml binding data for a JAXB object.
+ *
+ * <p>
+ * Intially, the intent of this class is to just conceptualize how
+ * a JAXB application developer can access xml binding information,
+ * independent if binding model is java to schema or schema to java.
+ * Since accessing the XML element name related to a JAXB element is
+ * a highly requested feature, demonstrate access to this
+ * binding information.
+ *
+ * The factory method to get a <code>JAXBIntrospector</code> instance is
+ * {@link JAXBContext#createJAXBIntrospector()}.
+ *
+ * @see JAXBContext#createJAXBIntrospector()
+ * @since JAXB2.0
+ */
+public abstract class JAXBIntrospector {
+
+    /**
+     * <p>Return true iff <code>object</code> represents a JAXB element.</p>
+     * <p>Parameter <code>object</code> is a JAXB element for following cases:
+     * <ol>
+     *   <li>It is an instance of <code>javax.xml.bind.JAXBElement</code>.</li>
+     *   <li>The class of <code>object</code> is annotated with
+     *       <code>&#64XmlRootElement</code>.
+     *   </li>
+     * </ol>
+     *
+     * @see #getElementName(Object)
+     */
+    public abstract boolean isElement(Object object);
+
+    /**
+     * <p>Get xml element qname for <code>jaxbElement</code>.</p>
+     *
+     * @param jaxbElement is an object that {@link #isElement(Object)} returned true.
+     *
+     * @return xml element qname associated with jaxbElement;
+     *         null if <code>jaxbElement</code> is not a JAXB Element.
+     */
+    public abstract QName getElementName(Object jaxbElement);
+
+    /**
+     * <p>Get the element value of a JAXB element.</p>
+     *
+     * <p>Convenience method to abstract whether working with either
+     *    a javax.xml.bind.JAXBElement instance or an instance of
+     *    <tt>&#64XmlRootElement</tt> annotated Java class.</p>
+     *
+     * @param jaxbElement  object that #isElement(Object) returns true.
+     *
+     * @return The element value of the <code>jaxbElement</code>.
+     */
+    public static Object getValue(Object jaxbElement) {
+        if (jaxbElement instanceof JAXBElement) {
+            return ((JAXBElement)jaxbElement).getValue();
+        } else {
+            // assume that class of this instance is
+            // annotated with @XmlRootElement.
+            return jaxbElement;
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/MarshalException.java b/jaxws/src/share/classes/javax/xml/bind/MarshalException.java
new file mode 100644
index 0000000..f3101ce
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/MarshalException.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This exception indicates that an error has occurred while performing
+ * a marshal operation that the provider is unable to recover from.
+ *
+ * <p>
+ * The <tt>ValidationEventHandler</tt> can cause this exception to be thrown
+ * during the marshal operations.  See
+ * {@link ValidationEventHandler#handleEvent(ValidationEvent)
+ * ValidationEventHandler.handleEvent(ValidationEvent)}.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBException
+ * @see Marshaller
+ * @since JAXB1.0
+ */
+public class MarshalException extends JAXBException {
+
+    /**
+     * Construct a MarshalException with the specified detail message.  The
+     * errorCode and linkedException will default to null.
+     *
+     * @param message a description of the exception
+     */
+    public MarshalException( String message ) {
+        this( message, null, null );
+    }
+
+    /**
+     * Construct a MarshalException with the specified detail message and vendor
+     * specific errorCode.  The linkedException will default to null.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     */
+    public MarshalException( String message, String errorCode ) {
+        this( message, errorCode, null );
+    }
+
+    /**
+     * Construct a MarshalException with a linkedException.  The detail message and
+     * vendor specific errorCode will default to null.
+     *
+     * @param exception the linked exception
+     */
+    public MarshalException( Throwable exception ) {
+        this( null, null, exception );
+    }
+
+    /**
+     * Construct a MarshalException with the specified detail message and
+     * linkedException.  The errorCode will default to null.
+     *
+     * @param message a description of the exception
+     * @param exception the linked exception
+     */
+    public MarshalException( String message, Throwable exception ) {
+        this( message, null, exception );
+    }
+
+    /**
+     * Construct a MarshalException with the specified detail message, vendor
+     * specific errorCode, and linkedException.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     * @param exception the linked exception
+     */
+    public MarshalException( String message, String errorCode, Throwable exception ) {
+        super( message, errorCode, exception );
+    }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/Marshaller.java b/jaxws/src/share/classes/javax/xml/bind/Marshaller.java
new file mode 100644
index 0000000..22f9a7e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/Marshaller.java
@@ -0,0 +1,799 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.validation.Schema;
+
+/**
+ * <p>
+ * The <tt>Marshaller</tt> class is responsible for governing the process
+ * of serializing Java content trees back into XML data.  It provides the basic
+ * marshalling methods:
+ *
+ * <p>
+ * <i>Assume the following setup code for all following code fragments:</i>
+ * <blockquote>
+ *    <pre>
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *       Object element = u.unmarshal( new File( "foo.xml" ) );
+ *       Marshaller m = jc.createMarshaller();
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a File:
+ * <blockquote>
+ *    <pre>
+ *       OutputStream os = new FileOutputStream( "nosferatu.xml" );
+ *       m.marshal( element, os );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a SAX ContentHandler:
+ * <blockquote>
+ *    <pre>
+ *       // assume MyContentHandler instanceof ContentHandler
+ *       m.marshal( element, new MyContentHandler() );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a DOM Node:
+ * <blockquote>
+ *    <pre>
+ *       DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+ *       dbf.setNamespaceAware(true);
+ *       DocumentBuilder db = dbf.newDocumentBuilder();
+ *       Document doc = db.newDocument();
+ *
+ *       m.marshal( element, doc );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a java.io.OutputStream:
+ * <blockquote>
+ *    <pre>
+ *       m.marshal( element, System.out );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a java.io.Writer:
+ * <blockquote>
+ *    <pre>
+ *       m.marshal( element, new PrintWriter( System.out ) );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a javax.xml.transform.SAXResult:
+ * <blockquote>
+ *    <pre>
+ *       // assume MyContentHandler instanceof ContentHandler
+ *       SAXResult result = new SAXResult( new MyContentHandler() );
+ *
+ *       m.marshal( element, result );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a javax.xml.transform.DOMResult:
+ * <blockquote>
+ *    <pre>
+ *       DOMResult result = new DOMResult();
+ *
+ *       m.marshal( element, result );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a javax.xml.transform.StreamResult:
+ * <blockquote>
+ *    <pre>
+ *       StreamResult result = new StreamResult( System.out );
+ *
+ *       m.marshal( element, result );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a javax.xml.stream.XMLStreamWriter:
+ * <blockquote>
+ *    <pre>
+ *       XMLStreamWriter xmlStreamWriter =
+ *           XMLOutputFactory.newInstance().createXMLStreamWriter( ... );
+ *
+ *       m.marshal( element, xmlStreamWriter );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Marshalling to a javax.xml.stream.XMLEventWriter:
+ * <blockquote>
+ *    <pre>
+ *       XMLEventWriter xmlEventWriter =
+ *           XMLOutputFactory.newInstance().createXMLEventWriter( ... );
+ *
+ *       m.marshal( element, xmlEventWriter );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * <a name="elementMarshalling"></a>
+ * <b>Marshalling content tree rooted by a JAXB element</b><br>
+ * <blockquote>
+ * The first parameter of the overloaded
+ * <tt>Marshaller.marshal(java.lang.Object, ...)</tt> methods must be a
+ * JAXB element as computed by
+ * {@link JAXBIntrospector#isElement(java.lang.Object)};
+ * otherwise, a <tt>Marshaller.marshal</tt> method must throw a
+ * {@link MarshalException}. There exist two mechanisms
+ * to enable marshalling an instance that is not a JAXB element.
+ * One method is to wrap the instance as a value of a {@link JAXBElement},
+ * and pass the wrapper element as the first parameter to
+ * a <tt>Marshaller.marshal</tt> method. For java to schema binding, it
+ * is also possible to simply annotate the instance's class with
+ * &#64;{@link XmlRootElement}.
+ * </blockquote>
+ *
+ * <p>
+ * <b>Encoding</b><br>
+ * <blockquote>
+ * By default, the Marshaller will use UTF-8 encoding when generating XML data
+ * to a <tt>java.io.OutputStream</tt>, or a <tt>java.io.Writer</tt>.  Use the
+ * {@link #setProperty(String,Object) setProperty} API to change the output
+ * encoding used during these marshal operations.  Client applications are
+ * expected to supply a valid character encoding name as defined in the
+ * <a href="http://www.w3.org/TR/2000/REC-xml-20001006#charencoding">W3C XML 1.0
+ * Recommendation</a> and supported by your
+ * <a href="http://java.sun.com/j2se/1.3/docs/api/java/lang/package-summary.html#charenc">
+ * Java Platform</a>.
+ * </blockquote>
+ *
+ * <p>
+ * <b>Validation and Well-Formedness</b><br>
+ * <blockquote>
+ * <p>
+ * Client applications are not required to validate the Java content tree prior
+ * to calling any of the marshal API's.  Furthermore, there is no requirement
+ * that the Java content tree be valid with respect to its original schema in
+ * order to marshal it back into XML data.  Different JAXB Providers will
+ * support marshalling invalid Java content trees at varying levels, however
+ * all JAXB Providers must be able to marshal a valid content tree back to
+ * XML data.  A JAXB Provider must throw a <tt>MarshalException</tt> when it
+ * is unable to complete the marshal operation due to invalid content.  Some
+ * JAXB Providers will fully allow marshalling invalid content, others will fail
+ * on the first validation error.
+ * <p>
+ * Even when schema validation is not explictly enabled for the marshal operation,
+ * it is possible that certain types of validation events will be detected
+ * during the operation.  Validation events will be reported to the registered
+ * event handler.  If the client application has not registered an event handler
+ * prior to invoking one of the marshal API's, then events will be delivered to
+ * a default event handler which will terminate the marshal operation after
+ * encountering the first error or fatal error. Note that for JAXB 2.0 and
+ * later versions, {@link javax.xml.bind.helpers.DefaultValidationEventHandler} is
+ * no longer used.
+ *
+ * </blockquote>
+ *
+ * <p>
+ * <a name="supportedProps"></a>
+ * <b>Supported Properties</b><br>
+ * <blockquote>
+ * <p>
+ * All JAXB Providers are required to support the following set of properties.
+ * Some providers may support additional properties.
+ * <dl>
+ *   <dt><tt>jaxb.encoding</tt> - value must be a java.lang.String</dd>
+ *   <dd>The output encoding to use when marshalling the XML data.  The
+ *               Marshaller will use "UTF-8" by default if this property is not
+ *       specified.</dd>
+ *   <dt><tt>jaxb.formatted.output</tt> - value must be a java.lang.Boolean</dd>
+ *   <dd>This property controls whether or not the Marshaller will format
+ *       the resulting XML data with line breaks and indentation.  A
+ *       true value for this property indicates human readable indented
+ *       xml data, while a false value indicates unformatted xml data.
+ *       The Marshaller will default to false (unformatted) if this
+ *       property is not specified.</dd>
+ *   <dt><tt>jaxb.schemaLocation</tt> - value must be a java.lang.String</dd>
+ *   <dd>This property allows the client application to specify an
+ *       xsi:schemaLocation attribute in the generated XML data.  The format of
+ *       the schemaLocation attribute value is discussed in an easy to
+ *       understand, non-normative form in
+ *       <a href="http://www.w3.org/TR/xmlschema-0/#schemaLocation">Section 5.6
+ *       of the W3C XML Schema Part 0: Primer</a> and specified in
+ *       <a href="http://www.w3.org/TR/xmlschema-1/#Instance_Document_Constructions">
+ *       Section 2.6 of the W3C XML Schema Part 1: Structures</a>.</dd>
+ *   <dt><tt>jaxb.noNamespaceSchemaLocation</tt> - value must be a java.lang.String</dd>
+ *   <dd>This property allows the client application to specify an
+ *       xsi:noNamespaceSchemaLocation attribute in the generated XML
+ *       data.  The format of the schemaLocation attribute value is discussed in
+ *       an easy to understand, non-normative form in
+ *       <a href="http://www.w3.org/TR/xmlschema-0/#schemaLocation">Section 5.6
+ *       of the W3C XML Schema Part 0: Primer</a> and specified in
+ *       <a href="http://www.w3.org/TR/xmlschema-1/#Instance_Document_Constructions">
+ *       Section 2.6 of the W3C XML Schema Part 1: Structures</a>.</dd>
+ *   <dt><tt>jaxb.fragment</tt> - value must be a java.lang.Boolean</dd>
+ *   <dd>This property determines whether or not document level events will be
+ *       generated by the Marshaller.  If the property is not specified, the
+ *       default is <tt>false</tt>. This property has different implications depending
+ *       on which marshal api you are using - when this property is set to true:<br>
+ *       <ul>
+ *         <li>{@link #marshal(Object,org.xml.sax.ContentHandler) marshal(Object,ContentHandler)} - the Marshaller won't
+ *             invoke {@link org.xml.sax.ContentHandler#startDocument()} and
+ *             {@link org.xml.sax.ContentHandler#endDocument()}.</li>
+ *         <li>{@link #marshal(Object,org.w3c.dom.Node) marshal(Object,Node)} - the property has no effect on this
+ *             API.</li>
+ *         <li>{@link #marshal(Object,java.io.OutputStream) marshal(Object,OutputStream)} - the Marshaller won't
+ *             generate an xml declaration.</li>
+ *         <li>{@link #marshal(Object,java.io.Writer) marshal(Object,Writer)} - the Marshaller won't
+ *             generate an xml declaration.</li>
+ *         <li>{@link #marshal(Object,javax.xml.transform.Result) marshal(Object,Result)} - depends on the kind of
+ *             Result object, see semantics for Node, ContentHandler, and Stream APIs</li>
+ *         <li>{@link #marshal(Object,javax.xml.stream.XMLEventWriter) marshal(Object,XMLEventWriter)} - the
+ *             Marshaller will not generate {@link javax.xml.stream.events.XMLEvent#START_DOCUMENT} and
+ *             {@link javax.xml.stream.events.XMLEvent#END_DOCUMENT} events.</li>
+ *         <li>{@link #marshal(Object,javax.xml.stream.XMLStreamWriter) marshal(Object,XMLStreamWriter)} - the
+ *             Marshaller will not generate {@link javax.xml.stream.events.XMLEvent#START_DOCUMENT} and
+ *             {@link javax.xml.stream.events.XMLEvent#END_DOCUMENT} events.</li>
+ *       </ul>
+ *   </dd>
+ * </dl>
+ * </blockquote>
+ *
+ * <p>
+ * <a name="marshalEventCallback"></a>
+ * <b>Marshal Event Callbacks</b><br>
+ * <blockquote>
+ * "The {@link Marshaller} provides two styles of callback mechanisms
+ * that allow application specific processing during key points in the
+ * unmarshalling process.  In 'class defined' event callbacks, application
+ * specific code placed in JAXB mapped classes is triggered during
+ * marshalling.  'External listeners' allow for centralized processing
+ * of marshal events in one callback method rather than by type event callbacks.
+ *
+ * <p>
+ * Class defined event callback methods allow any JAXB mapped class to specify
+ * its own specific callback methods by defining methods with the following method signatures:
+ * <blockquote>
+ * <pre>
+ *   // Invoked by Marshaller after it has created an instance of this object.
+ *   boolean beforeMarshal(Marshaller, Object parent);
+ *
+ *   // Invoked by Marshaller after it has marshalled all properties of this object.
+ *   void afterMmarshal(Marshaller, Object parent);
+ * </pre>
+ * </blockquote>
+ * The class defined event callback methods should be used when the callback method requires
+ * access to non-public methods and/or fields of the class.
+ * <p>
+ * The external listener callback mechanism enables the registration of a {@link Listener}
+ * instance with a {@link Marshaller#setListener(Listener)}. The external listener receives all callback events,
+ * allowing for more centralized processing than per class defined callback methods.
+ * <p>
+ * The 'class defined' and external listener event callback methods are independent of each other,
+ * both can be called for one event. The invocation ordering when both listener callback methods exist is
+ * defined in {@link Listener#beforeMarshal(Object)} and {@link Listener#afterMarshal(Object)}.
+ * <p>
+ * An event callback method throwing an exception terminates the current marshal process.
+ * </blockquote>
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBContext
+ * @see Validator
+ * @see Unmarshaller
+ * @since JAXB1.0
+ */
+public interface Marshaller {
+
+    /**
+     * The name of the property used to specify the output encoding in
+     * the marshalled XML data.
+     */
+    public static final String JAXB_ENCODING =
+        "jaxb.encoding";
+
+    /**
+     * The name of the property used to specify whether or not the marshalled
+     * XML data is formatted with linefeeds and indentation.
+     */
+    public static final String JAXB_FORMATTED_OUTPUT =
+        "jaxb.formatted.output";
+
+    /**
+     * The name of the property used to specify the xsi:schemaLocation
+     * attribute value to place in the marshalled XML output.
+     */
+    public static final String JAXB_SCHEMA_LOCATION =
+        "jaxb.schemaLocation";
+
+    /**
+     * The name of the property used to specify the
+     * xsi:noNamespaceSchemaLocation attribute value to place in the marshalled
+     * XML output.
+     */
+    public static final String JAXB_NO_NAMESPACE_SCHEMA_LOCATION =
+        "jaxb.noNamespaceSchemaLocation";
+
+    /**
+     * The name of the property used to specify whether or not the marshaller
+     * will generate document level events (ie calling startDocument or endDocument).
+     */
+    public static final String JAXB_FRAGMENT =
+        "jaxb.fragment";
+
+    /**
+     * Marshal the content tree rooted at <tt>jaxbElement</tt> into the specified
+     * <tt>javax.xml.transform.Result</tt>.
+     *
+     * <p>
+     * All JAXB Providers must at least support
+     * {@link javax.xml.transform.dom.DOMResult},
+     * {@link javax.xml.transform.sax.SAXResult}, and
+     * {@link javax.xml.transform.stream.StreamResult}. It can
+     * support other derived classes of <tt>Result</tt> as well.
+     *
+     * @param jaxbElement
+     *      The root of content tree to be marshalled.
+     * @param result
+     *      XML will be sent to this Result
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs during the marshalling.
+     * @throws MarshalException
+     *      If the {@link ValidationEventHandler ValidationEventHandler}
+     *      returns false from its <tt>handleEvent</tt> method or the
+     *      <tt>Marshaller</tt> is unable to marshal <tt>obj</tt> (or any
+     *      object reachable from <tt>obj</tt>).  See <a href="#elementMarshalling">
+     *      Marshalling a JAXB element</a>.
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     */
+    public void marshal( Object jaxbElement, javax.xml.transform.Result result )
+        throws JAXBException;
+
+    /**
+     * Marshal the content tree rooted at <tt>jaxbElement</tt> into an output stream.
+     *
+     * @param jaxbElement
+     *      The root of content tree to be marshalled.
+     * @param os
+     *      XML will be added to this stream.
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs during the marshalling.
+     * @throws MarshalException
+     *      If the {@link ValidationEventHandler ValidationEventHandler}
+     *      returns false from its <tt>handleEvent</tt> method or the
+     *      <tt>Marshaller</tt> is unable to marshal <tt>obj</tt> (or any
+     *      object reachable from <tt>obj</tt>).  See <a href="#elementMarshalling">
+     *      Marshalling a JAXB element</a>.
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     */
+    public void marshal( Object jaxbElement, java.io.OutputStream os )
+        throws JAXBException;
+
+    /**
+     * Marshal the content tree rooted at <tt>jaxbElement</tt> into a Writer.
+     *
+     * @param jaxbElement
+     *      The root of content tree to be marshalled.
+     * @param writer
+     *      XML will be sent to this writer.
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs during the marshalling.
+     * @throws MarshalException
+     *      If the {@link ValidationEventHandler ValidationEventHandler}
+     *      returns false from its <tt>handleEvent</tt> method or the
+     *      <tt>Marshaller</tt> is unable to marshal <tt>obj</tt> (or any
+     *      object reachable from <tt>obj</tt>).  See <a href="#elementMarshalling">
+     *      Marshalling a JAXB element</a>.
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     */
+    public void marshal( Object jaxbElement, java.io.Writer writer )
+        throws JAXBException;
+
+    /**
+     * Marshal the content tree rooted at <tt>jaxbElement</tt> into SAX2 events.
+     *
+     * @param jaxbElement
+     *      The root of content tree to be marshalled.
+     * @param handler
+     *      XML will be sent to this handler as SAX2 events.
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs during the marshalling.
+     * @throws MarshalException
+     *      If the {@link ValidationEventHandler ValidationEventHandler}
+     *      returns false from its <tt>handleEvent</tt> method or the
+     *      <tt>Marshaller</tt> is unable to marshal <tt>obj</tt> (or any
+     *      object reachable from <tt>obj</tt>).  See <a href="#elementMarshalling">
+     *      Marshalling a JAXB element</a>.
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     */
+    public void marshal( Object jaxbElement, org.xml.sax.ContentHandler handler )
+        throws JAXBException;
+
+    /**
+     * Marshal the content tree rooted at <tt>jaxbElement</tt> into a DOM tree.
+     *
+     * @param jaxbElement
+     *      The content tree to be marshalled.
+     * @param node
+     *      DOM nodes will be added as children of this node.
+     *      This parameter must be a Node that accepts children
+     *      ({@link org.w3c.dom.Document},
+     *      {@link  org.w3c.dom.DocumentFragment}, or
+     *      {@link  org.w3c.dom.Element})
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs during the marshalling.
+     * @throws MarshalException
+     *      If the {@link ValidationEventHandler ValidationEventHandler}
+     *      returns false from its <tt>handleEvent</tt> method or the
+     *      <tt>Marshaller</tt> is unable to marshal <tt>jaxbElement</tt> (or any
+     *      object reachable from <tt>jaxbElement</tt>).  See <a href="#elementMarshalling">
+     *      Marshalling a JAXB element</a>.
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     */
+    public void marshal( Object jaxbElement, org.w3c.dom.Node node )
+        throws JAXBException;
+
+    /**
+     * Marshal the content tree rooted at <tt>jaxbElement</tt> into a
+     * {@link javax.xml.stream.XMLStreamWriter}.
+     *
+     * @param jaxbElement
+     *      The content tree to be marshalled.
+     * @param writer
+     *      XML will be sent to this writer.
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs during the marshalling.
+     * @throws MarshalException
+     *      If the {@link ValidationEventHandler ValidationEventHandler}
+     *      returns false from its <tt>handleEvent</tt> method or the
+     *      <tt>Marshaller</tt> is unable to marshal <tt>obj</tt> (or any
+     *      object reachable from <tt>obj</tt>).  See <a href="#elementMarshalling">
+     *      Marshalling a JAXB element</a>.
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     * @since JAXB 2.0
+     */
+    public void marshal( Object jaxbElement, javax.xml.stream.XMLStreamWriter writer )
+        throws JAXBException;
+
+    /**
+     * Marshal the content tree rooted at <tt>jaxbElement</tt> into a
+     * {@link javax.xml.stream.XMLEventWriter}.
+     *
+     * @param jaxbElement
+     *      The content tree rooted at jaxbElement to be marshalled.
+     * @param writer
+     *      XML will be sent to this writer.
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs during the marshalling.
+     * @throws MarshalException
+     *      If the {@link ValidationEventHandler ValidationEventHandler}
+     *      returns false from its <tt>handleEvent</tt> method or the
+     *      <tt>Marshaller</tt> is unable to marshal <tt>obj</tt> (or any
+     *      object reachable from <tt>obj</tt>).  See <a href="#elementMarshalling">
+     *      Marshalling a JAXB element</a>.
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     * @since JAXB 2.0
+     */
+    public void marshal( Object jaxbElement, javax.xml.stream.XMLEventWriter writer )
+        throws JAXBException;
+
+    /**
+     * Get a DOM tree view of the content tree(Optional).
+     *
+     * If the returned DOM tree is updated, these changes are also
+     * visible in the content tree.
+     * Use {@link #marshal(Object, org.w3c.dom.Node)} to force
+     * a deep copy of the content tree to a DOM representation.
+     *
+     * @param contentTree - JAXB Java representation of XML content
+     *
+     * @return the DOM tree view of the contentTree
+     *
+     * @throws UnsupportedOperationException
+     *      If the JAXB provider implementation does not support a
+     *      DOM view of the content tree
+     *
+     * @throws IllegalArgumentException
+     *      If any of the method parameters are null
+     *
+     * @throws JAXBException
+     *      If any unexpected problem occurs
+     *
+     */
+    public org.w3c.dom.Node getNode( java.lang.Object contentTree )
+        throws JAXBException;
+
+    /**
+     * Set the particular property in the underlying implementation of
+     * <tt>Marshaller</tt>.  This method can only be used to set one of
+     * the standard JAXB defined properties above or a provider specific
+     * property.  Attempting to set an undefined property will result in
+     * a PropertyException being thrown.  See <a href="#supportedProps">
+     * Supported Properties</a>.
+     *
+     * @param name the name of the property to be set. This value can either
+     *              be specified using one of the constant fields or a user
+     *              supplied string.
+     * @param value the value of the property to be set
+     *
+     * @throws PropertyException when there is an error processing the given
+     *                            property or value
+     * @throws IllegalArgumentException
+     *      If the name parameter is null
+     */
+    public void setProperty( String name, Object value )
+        throws PropertyException;
+
+    /**
+     * Get the particular property in the underlying implementation of
+     * <tt>Marshaller</tt>.  This method can only be used to get one of
+     * the standard JAXB defined properties above or a provider specific
+     * property.  Attempting to get an undefined property will result in
+     * a PropertyException being thrown.  See <a href="#supportedProps">
+     * Supported Properties</a>.
+     *
+     * @param name the name of the property to retrieve
+     * @return the value of the requested property
+     *
+     * @throws PropertyException
+     *      when there is an error retrieving the given property or value
+     *      property name
+     * @throws IllegalArgumentException
+     *      If the name parameter is null
+     */
+    public Object getProperty( String name ) throws PropertyException;
+
+    /**
+     * Allow an application to register a validation event handler.
+     * <p>
+     * The validation event handler will be called by the JAXB Provider if any
+     * validation errors are encountered during calls to any of the marshal
+     * API's.  If the client application does not register a validation event
+     * handler before invoking one of the marshal methods, then validation
+     * events will be handled by the default event handler which will terminate
+     * the marshal operation after the first error or fatal error is encountered.
+     * <p>
+     * Calling this method with a null parameter will cause the Marshaller
+     * to revert back to the default default event handler.
+     *
+     * @param handler the validation event handler
+     * @throws JAXBException if an error was encountered while setting the
+     *         event handler
+     */
+    public void setEventHandler( ValidationEventHandler handler )
+        throws JAXBException;
+
+    /**
+     * Return the current event handler or the default event handler if one
+     * hasn't been set.
+     *
+     * @return the current ValidationEventHandler or the default event handler
+     *         if it hasn't been set
+     * @throws JAXBException if an error was encountered while getting the
+     *         current event handler
+     */
+    public ValidationEventHandler getEventHandler()
+        throws JAXBException;
+
+
+
+    /**
+     * Associates a configured instance of {@link XmlAdapter} with this marshaller.
+     *
+     * <p>
+     * This is a convenience method that invokes <code>setAdapter(adapter.getClass(),adapter);</code>.
+     *
+     * @see #setAdapter(Class,XmlAdapter)
+     * @throws IllegalArgumentException
+     *      if the adapter parameter is null.
+     * @throws UnsupportedOperationException
+     *      if invoked agains a JAXB 1.0 implementation.
+     * @since JAXB 2.0
+     */
+    public void setAdapter( XmlAdapter adapter );
+
+    /**
+     * Associates a configured instance of {@link XmlAdapter} with this marshaller.
+     *
+     * <p>
+     * Every marshaller internally maintains a
+     * {@link java.util.Map}&lt;{@link Class},{@link XmlAdapter}>,
+     * which it uses for marshalling classes whose fields/methods are annotated
+     * with {@link javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter}.
+     *
+     * <p>
+     * This method allows applications to use a configured instance of {@link XmlAdapter}.
+     * When an instance of an adapter is not given, a marshaller will create
+     * one by invoking its default constructor.
+     *
+     * @param type
+     *      The type of the adapter. The specified instance will be used when
+     *      {@link javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter#value()}
+     *      refers to this type.
+     * @param adapter
+     *      The instance of the adapter to be used. If null, it will un-register
+     *      the current adapter set for this type.
+     * @throws IllegalArgumentException
+     *      if the type parameter is null.
+     * @throws UnsupportedOperationException
+     *      if invoked agains a JAXB 1.0 implementation.
+     * @since JAXB 2.0
+     */
+    public <A extends XmlAdapter> void setAdapter( Class<A> type, A adapter );
+
+    /**
+     * Gets the adapter associated with the specified type.
+     *
+     * This is the reverse operation of the {@link #setAdapter} method.
+     *
+     * @throws IllegalArgumentException
+     *      if the type parameter is null.
+     * @throws UnsupportedOperationException
+     *      if invoked agains a JAXB 1.0 implementation.
+     * @since JAXB 2.0
+     */
+    public <A extends XmlAdapter> A getAdapter( Class<A> type );
+
+
+    /**
+     * <p>Associate a context that enables binary data within an XML document
+     * to be transmitted as XML-binary optimized attachment.
+     * The attachment is referenced from the XML document content model
+     * by content-id URIs(cid) references stored within the xml document.
+     *
+     * @throws IllegalStateException if attempt to concurrently call this
+     *                               method during a marshal operation.
+     */
+    void setAttachmentMarshaller(AttachmentMarshaller am);
+
+    AttachmentMarshaller getAttachmentMarshaller();
+
+    /**
+     * Specify the JAXP 1.3 {@link javax.xml.validation.Schema Schema}
+     * object that should be used to validate subsequent marshal operations
+     * against.  Passing null into this method will disable validation.
+     *
+     * <p>
+     * This method allows the caller to validate the marshalled XML as it's marshalled.
+     *
+     * <p>
+     * Initially this property is set to <tt>null</tt>.
+     *
+     * @param schema Schema object to validate marshal operations against or null to disable validation
+     * @throws UnsupportedOperationException could be thrown if this method is
+     *         invoked on an Marshaller created from a JAXBContext referencing
+     *         JAXB 1.0 mapped classes
+     * @since JAXB2.0
+     */
+    public void setSchema( Schema schema );
+
+    /**
+     * Get the JAXP 1.3 {@link javax.xml.validation.Schema Schema} object
+     * being used to perform marshal-time validation.  If there is no
+     * Schema set on the marshaller, then this method will return null
+     * indicating that marshal-time validation will not be performed.
+     *
+     * @return the Schema object being used to perform marshal-time
+     *      validation or null if not present.
+     * @throws UnsupportedOperationException could be thrown if this method is
+     *         invoked on an Marshaller created from a JAXBContext referencing
+     *         JAXB 1.0 mapped classes
+     * @since JAXB2.0
+     */
+    public Schema getSchema();
+
+    /**
+     * <p/>
+     * Register an instance of an implementation of this class with a {@link Marshaller} to externally listen
+     * for marshal events.
+     * <p/>
+     * <p/>
+     * This class enables pre and post processing of each marshalled object.
+     * The event callbacks are called when marshalling from an instance that maps to an xml element or
+     * complex type definition. The event callbacks are not called when marshalling from an instance of a
+     * Java datatype that represents a simple type definition.
+     * <p/>
+     * <p/>
+     * External listener is one of two different mechanisms for defining marshal event callbacks.
+     * See <a href="Marshaller.html#marshalEventCallback">Marshal Event Callbacks</a> for an overview.
+     *
+     * @see Marshaller#setListener(Listener)
+     * @see Marshaller#getListener()
+     * @since JAXB2.0
+     */
+    public static abstract class Listener {
+        /**
+         * <p/>
+         * Callback method invoked before marshalling from <tt>source</tt> to XML.
+         * <p/>
+         * <p/>
+         * This method is invoked just before marshalling process starts to marshal <tt>source</tt>.
+         * Note that if the class of <tt>source</tt> defines its own <tt>beforeMarshal</tt> method,
+         * the class specific callback method is invoked just before this method is invoked.
+         *
+         * @param source instance of JAXB mapped class prior to marshalling from it.
+         */
+        public void beforeMarshal(Object source) {
+        }
+
+        /**
+         * <p/>
+         * Callback method invoked after marshalling <tt>source</tt> to XML.
+         * <p/>
+         * <p/>
+         * This method is invoked after <tt>source</tt> and all its descendants have been marshalled.
+         * Note that if the class of <tt>source</tt> defines its own <tt>afterMarshal</tt> method,
+         * the class specific callback method is invoked just before this method is invoked.
+         *
+         * @param source instance of JAXB mapped class after marshalling it.
+         */
+        public void afterMarshal(Object source) {
+        }
+    }
+
+    /**
+     * <p>
+     * Register marshal event callback {@link Listener} with this {@link Marshaller}.
+     *
+     * <p>
+     * There is only one Listener per Marshaller. Setting a Listener replaces the previous set Listener.
+     * One can unregister current Listener by setting listener to <tt>null</tt>.
+     *
+     * @param listener an instance of a class that implements {@link Listener}
+     * @since JAXB2.0
+     */
+    public void setListener(Listener listener);
+
+    /**
+     * <p>Return {@link Listener} registered with this {@link Marshaller}.
+     *
+     * @return registered {@link Listener} or <code>null</code> if no Listener is registered with this Marshaller.
+     * @since JAXB2.0
+     */
+    public Listener getListener();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/Messages.java b/jaxws/src/share/classes/javax/xml/bind/Messages.java
new file mode 100644
index 0000000..c6af878
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/Messages.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    static String format( String property ) {
+        return format( property, null );
+    }
+
+    static String format( String property, Object arg1 ) {
+        return format( property, new Object[]{arg1} );
+    }
+
+    static String format( String property, Object arg1, Object arg2 ) {
+        return format( property, new Object[]{arg1,arg2} );
+    }
+
+    static String format( String property, Object arg1, Object arg2, Object arg3 ) {
+        return format( property, new Object[]{arg1,arg2,arg3} );
+    }
+
+    // add more if necessary.
+
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object[] args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getName()).getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+//
+//
+// Message resources
+//
+//
+    static final String PROVIDER_NOT_FOUND = // 1 arg
+        "ContextFinder.ProviderNotFound";
+
+    static final String COULD_NOT_INSTANTIATE = // 2 args
+        "ContextFinder.CouldNotInstantiate";
+
+    static final String CANT_FIND_PROPERTIES_FILE = // 1 arg
+        "ContextFinder.CantFindPropertiesFile";
+
+    static final String CANT_MIX_PROVIDERS = // 0 args
+        "ContextFinder.CantMixProviders";
+
+    static final String MISSING_PROPERTY = // 2 args
+        "ContextFinder.MissingProperty";
+
+    static final String NO_PACKAGE_IN_CONTEXTPATH = // 0 args
+        "ContextFinder.NoPackageInContextPath";
+
+    static final String NAME_VALUE = // 2 args
+        "PropertyException.NameValue";
+
+    static final String CONVERTER_MUST_NOT_BE_NULL = // 0 args
+        "DatatypeConverter.ConverterMustNotBeNull";
+
+    static final String ILLEGAL_CAST = // 2 args
+        "JAXBContext.IllegalCast";
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/Messages.properties b/jaxws/src/share/classes/javax/xml/bind/Messages.properties
new file mode 100644
index 0000000..3797cfd
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/Messages.properties
@@ -0,0 +1,26 @@
+ContextFinder.ProviderNotFound = \
+	Provider {0} not found
+	
+ContextFinder.CouldNotInstantiate = \
+	Provider {0} could not be instantiated: {1}	
+
+ContextFinder.CantFindPropertiesFile = \
+	Unable to locate jaxb.properties for package {0}
+	
+ContextFinder.CantMixProviders = \
+	You may not mix JAXB Providers on the context path
+	
+ContextFinder.MissingProperty = \
+	jaxb.properties in package {0} does not contain the {1} property.
+
+ContextFinder.NoPackageInContextPath = \
+    No package name is given
+
+PropertyException.NameValue = \
+	name: {0} value: {1}
+	
+DatatypeConverter.ConverterMustNotBeNull = \
+	The DatatypeConverterInterface parameter must not be null
+	
+JAXBContext.IllegalCast = \
+ 
diff --git a/jaxws/src/share/classes/javax/xml/bind/NotIdentifiableEvent.java b/jaxws/src/share/classes/javax/xml/bind/NotIdentifiableEvent.java
new file mode 100644
index 0000000..385ca51
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/NotIdentifiableEvent.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This event indicates that a problem was encountered resolving an ID/IDREF.
+ *
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see Validator
+ * @see ValidationEventHandler
+ * @since JAXB1.0
+ */
+public interface NotIdentifiableEvent extends ValidationEvent {
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/ParseConversionEvent.java b/jaxws/src/share/classes/javax/xml/bind/ParseConversionEvent.java
new file mode 100644
index 0000000..095152f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/ParseConversionEvent.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This event indicates that a problem was encountered while converting a
+ * string from the XML data into a value of the target Java data type.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see ValidationEvent
+ * @see ValidationEventHandler
+ * @see Unmarshaller
+ * @since JAXB1.0
+ */
+public interface ParseConversionEvent extends ValidationEvent {
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/PrintConversionEvent.java b/jaxws/src/share/classes/javax/xml/bind/PrintConversionEvent.java
new file mode 100644
index 0000000..60c7dfe
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/PrintConversionEvent.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This event indicates that a problem was encountered while converting data
+ * from the Java content tree into its lexical representation.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see ValidationEvent
+ * @see ValidationEventHandler
+ * @see Marshaller
+ * @since JAXB1.0
+ */
+public interface PrintConversionEvent extends ValidationEvent {
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/PropertyException.java b/jaxws/src/share/classes/javax/xml/bind/PropertyException.java
new file mode 100644
index 0000000..5c548b7
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/PropertyException.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+
+
+/**
+ * This exception indicates that an error was encountered while getting or
+ * setting a property.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBContext
+ * @see Validator
+ * @see Unmarshaller
+ * @since JAXB1.0
+ */
+public class PropertyException extends JAXBException {
+
+    /**
+     * Construct a PropertyException with the specified detail message.  The
+     * errorCode and linkedException will default to null.
+     *
+     * @param message a description of the exception
+     */
+    public PropertyException(String message) {
+        super(message);
+    }
+
+    /**
+     * Construct a PropertyException with the specified detail message and
+     * vendor specific errorCode.  The linkedException will default to null.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     */
+    public PropertyException(String message, String errorCode) {
+        super(message, errorCode);
+    }
+
+    /**
+     * Construct a PropertyException with a linkedException.  The detail
+     * message and vendor specific errorCode will default to null.
+     *
+     * @param exception the linked exception
+     */
+    public PropertyException(Throwable exception) {
+        super(exception);
+    }
+
+    /**
+     * Construct a PropertyException with the specified detail message and
+     * linkedException.  The errorCode will default to null.
+     *
+     * @param message a description of the exception
+     * @param exception the linked exception
+     */
+    public PropertyException(String message, Throwable exception) {
+        super(message, exception);
+    }
+
+    /**
+     * Construct a PropertyException with the specified detail message, vendor
+     * specific errorCode, and linkedException.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     * @param exception the linked exception
+     */
+    public PropertyException(
+        String message,
+        String errorCode,
+        Throwable exception) {
+        super(message, errorCode, exception);
+    }
+
+    /**
+     * Construct a PropertyException whose message field is set based on the
+     * name of the property and value.toString().
+     *
+     * @param name the name of the property related to this exception
+     * @param value the value of the property related to this exception
+     */
+    public PropertyException(String name, Object value) {
+        super( Messages.format( Messages.NAME_VALUE,
+                                        name,
+                                        value.toString() ) );
+    }
+
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/SchemaOutputResolver.java b/jaxws/src/share/classes/javax/xml/bind/SchemaOutputResolver.java
new file mode 100644
index 0000000..e86589c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/SchemaOutputResolver.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import javax.xml.transform.Result;
+import java.io.IOException;
+
+/**
+ * Controls where a JAXB implementation puts the generates
+ * schema files.
+ *
+ * <p>
+ * An implementation of this abstract class has to be provided by the calling
+ * application to generate schemas.
+ *
+ * <p>
+ * This is a class, not an interface so as to allow future versions to evolve
+ * without breaking the compatibility.
+ *
+ * @author
+ *     Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public abstract class SchemaOutputResolver {
+    /**
+     * Decides where the schema file (of the given namespace URI)
+     * will be written, and return it as a {@link Result} object.
+     *
+     * <p>
+     * This method is called only once for any given namespace.
+     * IOW, all the components in one namespace is always written
+     * into the same schema document.
+     *
+     * @param namespaceUri
+     *      The namespace URI that the schema declares.
+     *      Can be the empty string, but never be null.
+     * @param suggestedFileName
+     *      A JAXB implementation generates an unique file name (like "schema1.xsd")
+     *      for the convenience of the callee. This name can be
+     *      used for the file name of the schema, or the callee can just
+     *      ignore this name and come up with its own name.
+     *      This is just a hint.
+     *
+     * @return
+     *      a {@link Result} object that encapsulates the actual destination
+     *      of the schema.
+     *
+     *      If the {@link Result} object has a system ID, it must be an
+     *      absolute system ID. Those system IDs are relativized by the caller and used
+     *      for &lt;xs:import> statements.
+     *
+     *      If the {@link Result} object does not have a system ID, a schema
+     *      for the namespace URI is generated but it won't be explicitly
+     *      &lt;xs:import>ed from other schemas.
+     *
+     *      If {@code null} is returned, the schema generation for this
+     *      namespace URI will be skipped.
+     */
+    public abstract Result createOutput( String namespaceUri, String suggestedFileName ) throws IOException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/TypeConstraintException.java b/jaxws/src/share/classes/javax/xml/bind/TypeConstraintException.java
new file mode 100644
index 0000000..c4d1917
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/TypeConstraintException.java
@@ -0,0 +1,183 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This exception indicates that a violation of a dynamically checked type
+ * constraint was detected.
+ *
+ * <p>
+ * This exception can be thrown by the generated setter methods of the schema
+ * derived Java content classes.  However, since fail-fast validation is
+ * an optional feature for JAXB Providers to support, not all setter methods
+ * will throw this exception when a type constraint is violated.
+ *
+ * <p>
+ * If this exception is throw while invoking a fail-fast setter, the value of
+ * the property is guaranteed to remain unchanged, as if the setter were never
+ * called.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see ValidationEvent
+ * @since JAXB1.0
+ */
+
+public class TypeConstraintException extends java.lang.RuntimeException {
+
+    /**
+     * Vendor specific error code
+     *
+     */
+    private String errorCode;
+
+    /**
+     * Exception reference
+     *
+     */
+    private Throwable linkedException;
+
+
+    /**
+     * Construct a TypeConstraintException with the specified detail message.  The
+     * errorCode and linkedException will default to null.
+     *
+     * @param message a description of the exception
+     */
+    public TypeConstraintException(String message) {
+        this( message, null, null );
+    }
+
+    /**
+     * Construct a TypeConstraintException with the specified detail message and vendor
+     * specific errorCode.  The linkedException will default to null.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     */
+    public TypeConstraintException(String message, String errorCode) {
+        this( message, errorCode, null );
+    }
+
+    /**
+     * Construct a TypeConstraintException with a linkedException.  The detail message and
+     * vendor specific errorCode will default to null.
+     *
+     * @param exception the linked exception
+     */
+    public TypeConstraintException(Throwable exception) {
+        this( null, null, exception );
+    }
+
+    /**
+     * Construct a TypeConstraintException with the specified detail message and
+     * linkedException.  The errorCode will default to null.
+     *
+     * @param message a description of the exception
+     * @param exception the linked exception
+     */
+    public TypeConstraintException(String message, Throwable exception) {
+        this( message, null, exception );
+    }
+
+    /**
+     * Construct a TypeConstraintException with the specified detail message,
+     * vendor specific errorCode, and linkedException.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     * @param exception the linked exception
+     */
+    public TypeConstraintException(String message, String errorCode, Throwable exception) {
+        super( message );
+        this.errorCode = errorCode;
+        this.linkedException = exception;
+    }
+
+    /**
+     * Get the vendor specific error code
+     *
+     * @return a string specifying the vendor specific error code
+     */
+    public String getErrorCode() {
+        return this.errorCode;
+    }
+
+    /**
+     * Get the linked exception
+     *
+     * @return the linked Exception, null if none exists
+     */
+    public Throwable getLinkedException() {
+        return linkedException;
+    }
+
+    /**
+     * Add a linked Exception.
+     *
+     * @param exception the linked Exception (A null value is permitted and
+     *                  indicates that the linked exception does not exist or
+     *                  is unknown).
+     */
+    public synchronized void setLinkedException( Throwable exception ) {
+        this.linkedException = exception;
+    }
+
+    /**
+     * Returns a short description of this TypeConstraintException.
+     *
+     */
+    public String toString() {
+        return linkedException == null ?
+            super.toString() :
+            super.toString() + "\n - with linked exception:\n[" +
+                                linkedException.toString()+ "]";
+    }
+
+    /**
+     * Prints this TypeConstraintException and its stack trace (including the stack trace
+     * of the linkedException if it is non-null) to the PrintStream.
+     *
+     * @param s PrintStream to use for output
+     */
+    public void printStackTrace( java.io.PrintStream s ) {
+        if( linkedException != null ) {
+          linkedException.printStackTrace(s);
+          s.println("--------------- linked to ------------------");
+        }
+
+        super.printStackTrace(s);
+    }
+
+    /**
+     * Prints this TypeConstraintException and its stack trace (including the stack trace
+     * of the linkedException if it is non-null) to <tt>System.err</tt>.
+     *
+     */
+    public void printStackTrace() {
+        printStackTrace(System.err);
+    }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/UnmarshalException.java b/jaxws/src/share/classes/javax/xml/bind/UnmarshalException.java
new file mode 100644
index 0000000..c73ec5c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/UnmarshalException.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This exception indicates that an error has occurred while performing
+ * an unmarshal operation that prevents the JAXB Provider from completing
+ * the operation.
+ *
+ * <p>
+ * The <tt>ValidationEventHandler</tt> can cause this exception to be thrown
+ * during the unmarshal operations.  See
+ * {@link ValidationEventHandler#handleEvent(ValidationEvent)
+ * ValidationEventHandler.handleEvent(ValidationEvent)}.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBException
+ * @see Unmarshaller
+ * @see ValidationEventHandler
+ * @since JAXB1.0
+ */
+public class UnmarshalException extends JAXBException {
+
+    /**
+     * Construct an UnmarshalException with the specified detail message.  The
+     * errorCode and linkedException will default to null.
+     *
+     * @param message a description of the exception
+     */
+    public UnmarshalException( String message ) {
+        this( message, null, null );
+    }
+
+    /**
+     * Construct an UnmarshalException with the specified detail message and vendor
+     * specific errorCode.  The linkedException will default to null.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     */
+    public UnmarshalException( String message, String errorCode ) {
+        this( message, errorCode, null );
+    }
+
+    /**
+     * Construct an UnmarshalException with a linkedException.  The detail message and
+     * vendor specific errorCode will default to null.
+     *
+     * @param exception the linked exception
+     */
+    public UnmarshalException( Throwable exception ) {
+        this( null, null, exception );
+    }
+
+    /**
+     * Construct an UnmarshalException with the specified detail message and
+     * linkedException.  The errorCode will default to null.
+     *
+     * @param message a description of the exception
+     * @param exception the linked exception
+     */
+    public UnmarshalException( String message, Throwable exception ) {
+        this( message, null, exception );
+    }
+
+    /**
+     * Construct an UnmarshalException with the specified detail message, vendor
+     * specific errorCode, and linkedException.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     * @param exception the linked exception
+     */
+    public UnmarshalException( String message, String errorCode, Throwable exception ) {
+        super( message, errorCode, exception );
+    }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/Unmarshaller.java b/jaxws/src/share/classes/javax/xml/bind/Unmarshaller.java
new file mode 100644
index 0000000..2e639ca
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/Unmarshaller.java
@@ -0,0 +1,1143 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+import javax.xml.validation.Schema;
+import java.io.Reader;
+
+/**
+ * The <tt>Unmarshaller</tt> class governs the process of deserializing XML
+ * data into newly created Java content trees, optionally validating the XML
+ * data as it is unmarshalled.  It provides an overloading of unmarshal methods
+ * for many different input kinds.
+ *
+ * <p>
+ * Unmarshalling from a File:
+ * <blockquote>
+ *    <pre>
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *       Object o = u.unmarshal( new File( "nosferatu.xml" ) );
+ *    </pre>
+ * </blockquote>
+ *
+ *
+ * <p>
+ * Unmarshalling from an InputStream:
+ * <blockquote>
+ *    <pre>
+ *       InputStream is = new FileInputStream( "nosferatu.xml" );
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *       Object o = u.unmarshal( is );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Unmarshalling from a URL:
+ * <blockquote>
+ *    <pre>
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *       URL url = new URL( "http://beaker.east/nosferatu.xml" );
+ *       Object o = u.unmarshal( url );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Unmarshalling from a StringBuffer using a
+ * <tt>javax.xml.transform.stream.StreamSource</tt>:
+ * <blockquote>
+ *    <pre>
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *       StringBuffer xmlStr = new StringBuffer( "&lt;?xml version=&quot;1.0&quot;?&gt;..." );
+ *       Object o = u.unmarshal( new StreamSource( new StringReader( xmlStr.toString() ) ) );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Unmarshalling from a <tt>org.w3c.dom.Node</tt>:
+ * <blockquote>
+ *    <pre>
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *
+ *       DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+ *       dbf.setNamespaceAware(true);
+ *       DocumentBuilder db = dbf.newDocumentBuilder();
+ *       Document doc = db.parse(new File( "nosferatu.xml"));
+
+ *       Object o = u.unmarshal( doc );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Unmarshalling from a <tt>javax.xml.transform.sax.SAXSource</tt> using a
+ * client specified validating SAX2.0 parser:
+ * <blockquote>
+ *    <pre>
+ *       // configure a validating SAX2.0 parser (Xerces2)
+ *       static final String JAXP_SCHEMA_LANGUAGE =
+ *           "http://java.sun.com/xml/jaxp/properties/schemaLanguage";
+ *       static final String JAXP_SCHEMA_LOCATION =
+ *           "http://java.sun.com/xml/jaxp/properties/schemaSource";
+ *       static final String W3C_XML_SCHEMA =
+ *           "http://www.w3.org/2001/XMLSchema";
+ *
+ *       System.setProperty( "javax.xml.parsers.SAXParserFactory",
+ *                           "org.apache.xerces.jaxp.SAXParserFactoryImpl" );
+ *
+ *       SAXParserFactory spf = SAXParserFactory.newInstance();
+ *       spf.setNamespaceAware(true);
+ *       spf.setValidating(true);
+ *       SAXParser saxParser = spf.newSAXParser();
+ *
+ *       try {
+ *           saxParser.setProperty(JAXP_SCHEMA_LANGUAGE, W3C_XML_SCHEMA);
+ *           saxParser.setProperty(JAXP_SCHEMA_LOCATION, "http://....");
+ *       } catch (SAXNotRecognizedException x) {
+ *           // exception handling omitted
+ *       }
+ *
+ *       XMLReader xmlReader = saxParser.getXMLReader();
+ *       SAXSource source =
+ *           new SAXSource( xmlReader, new InputSource( "http://..." ) );
+ *
+ *       // Setup JAXB to unmarshal
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *       ValidationEventCollector vec = new ValidationEventCollector();
+ *       u.setEventHandler( vec );
+ *
+ *       // turn off the JAXB provider's default validation mechanism to
+ *       // avoid duplicate validation
+ *       u.setValidating( false )
+ *
+ *       // unmarshal
+ *       Object o = u.unmarshal( source );
+ *
+ *       // check for events
+ *       if( vec.hasEvents() ) {
+ *          // iterate over events
+ *       }
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Unmarshalling from a StAX XMLStreamReader:
+ * <blockquote>
+ *    <pre>
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *
+ *       javax.xml.stream.XMLStreamReader xmlStreamReader =
+ *           javax.xml.stream.XMLInputFactory().newInstance().createXMLStreamReader( ... );
+ *
+ *       Object o = u.unmarshal( xmlStreamReader );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * Unmarshalling from a StAX XMLEventReader:
+ * <blockquote>
+ *    <pre>
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *
+ *       javax.xml.stream.XMLEventReader xmlEventReader =
+ *           javax.xml.stream.XMLInputFactory().newInstance().createXMLEventReader( ... );
+ *
+ *       Object o = u.unmarshal( xmlEventReader );
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * <a name="unmarshalEx"></a>
+ * <b>Unmarshalling XML Data</b><br>
+ * <blockquote>
+ * Unmarshalling can deserialize XML data that represents either an entire XML document
+ * or a subtree of an XML document. Typically, it is sufficient to use the
+ * unmarshalling methods described by
+ * <a href="#unmarshalGlobal">Unmarshal root element that is declared globally</a>.
+ * These unmarshal methods utilize {@link JAXBContext}'s mapping of global XML element
+ * declarations and type definitions to JAXB mapped classes to initiate the
+ * unmarshalling of the root element of  XML data.  When the {@link JAXBContext}'s
+ * mappings are not sufficient to unmarshal the root element of XML data,
+ * the application can assist the unmarshalling process by using the
+ * <a href="#unmarshalByDeclaredType">unmarshal by declaredType methods</a>.
+ * These methods are useful for unmarshalling XML data where
+ * the root element corresponds to a local element declaration in the schema.
+ * </blockquote>
+ *
+ * <blockquote>
+ * An unmarshal method never returns null. If the unmarshal process is unable to unmarshal
+ * the root of XML content to a JAXB mapped object, a fatal error is reported that
+ * terminates processing by throwing JAXBException.
+ * </blockquote>
+ *
+ * <p>
+ * <a name="unmarshalGlobal"></a>
+ * <b>Unmarshal a root element that is globally declared</b><br>
+ * <blockquote>
+ * The unmarshal methods that do not have an <tt>declaredType</tt> parameter use
+ * {@link JAXBContext} to unmarshal the root element of an XML data. The {@link JAXBContext}
+ * instance is the one that was used to create this <tt>Unmarshaller</tt>. The {@link JAXBContext}
+ * instance maintains a mapping of globally declared XML element and type definition names to
+ * JAXB mapped classes. The unmarshal method checks if {@link JAXBContext} has a mapping
+ * from the root element's XML name and/or <tt>@xsi:type</tt> to a JAXB mapped class.  If it does, it umarshalls the
+ * XML data using the appropriate JAXB mapped class. Note that when the root element name is unknown and the root
+ * element has an <tt>@xsi:type</tt>, the XML data is unmarshalled
+ * using that JAXB mapped class as the value of a {@link JAXBElement}.
+ * When the {@link JAXBContext} object does not have a mapping for the root element's name
+ * nor its <tt>@xsi:type</tt>, if it exists,
+ * then the unmarshal operation will abort immediately by throwing a {@link UnmarshalException
+ * UnmarshalException}. This exception scenario can be worked around by using the unmarshal by
+ * declaredType methods described in the next subsection.
+ * </blockquote>
+ *
+ * <p>
+ * <a name="unmarshalByDeclaredType"></a>
+ * <b>Unmarshal by Declared Type</b><br>
+ * <blockquote>
+ * The unmarshal methods with a <code>declaredType</code> parameter enable an
+ * application to deserialize a root element of XML data, even when
+ * there is no mapping in {@link JAXBContext} of the root element's XML name.
+ * The unmarshaller unmarshals the root element using the application provided
+ * mapping specified as the <tt>declaredType</tt> parameter.
+ * Note that even when the root element's element name is mapped by {@link JAXBContext},
+ * the <code>declaredType</code> parameter overrides that mapping for
+ * deserializing the root element when using these unmarshal methods.
+ * Additionally, when the root element of XML data has an <tt>xsi:type</tt> attribute and
+ * that attribute's value references a type definition that is mapped
+ * to a JAXB mapped class by {@link JAXBContext}, that the root
+ * element's <tt>xsi:type</tt> attribute takes
+ * precedence over the unmarshal methods <tt>declaredType</tt> parameter.
+ * These methods always return a <tt>JAXBElement&lt;declaredType></tt>
+ * instance. The table below shows how the properties of the returned JAXBElement
+ * instance are set.
+ *
+ * <a name="unmarshalDeclaredTypeReturn"></a>
+ * <p>
+ *   <table border="2" rules="all" cellpadding="4">
+ *   <thead>
+ *     <tr>
+ *       <th align="center" colspan="2">
+ *       Unmarshal By Declared Type returned JAXBElement
+ *       </tr>
+ *     <tr>
+ *       <th>JAXBElement Property</th>
+ *       <th>Value</th>
+ *     </tr>
+ *     </tr>
+ *     <tr>
+ *       <td>name</td>
+ *       <td><code>xml element name</code></td>
+ *     </tr>
+ *   </thead>
+ *   <tbody>
+ *     <tr>
+ *       <td>value</td>
+ *       <td><code>instanceof declaredType</code></td>
+ *     </tr>
+ *     <tr>
+ *       <td>declaredType</td>
+ *       <td>unmarshal method <code>declaredType</code> parameter</td>
+ *     </tr>
+ *     <tr>
+ *       <td>scope</td>
+ *       <td><code>null</code> <i>(actual scope is unknown)</i></td>
+ *     </tr>
+ *   </tbody>
+ *  </table>
+ * </blockquote>
+ *
+ * <p>
+ * The following is an example of
+ * <a href="#unmarshalByDeclaredType">unmarshal by declaredType method</a>.
+ * <p>
+ * Unmarshal by declaredType from a <tt>org.w3c.dom.Node</tt>:
+ * <blockquote>
+ *    <pre>
+ *       Schema fragment for example
+ *       &lt;xs:schema>
+ *          &lt;xs:complexType name="FooType">...&lt;\xs:complexType>
+ *          &lt;!-- global element declaration "PurchaseOrder" -->
+ *          &lt;xs:element name="PurchaseOrder">
+ *              &lt;xs:complexType>
+ *                 &lt;xs:sequence>
+ *                    &lt;!-- local element declaration "foo" -->
+ *                    &lt;xs:element name="foo" type="FooType"/>
+ *                    ...
+ *                 &lt;/xs:sequence>
+ *              &lt;/xs:complexType>
+ *          &lt;/xs:element>
+ *       &lt;/xs:schema>
+ *
+ *       JAXBContext jc = JAXBContext.newInstance( "com.acme.foo" );
+ *       Unmarshaller u = jc.createUnmarshaller();
+ *
+ *       DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+ *       dbf.setNamespaceAware(true);
+ *       DocumentBuilder db = dbf.newDocumentBuilder();
+ *       Document doc = db.parse(new File( "nosferatu.xml"));
+ *       Element  fooSubtree = ...; // traverse DOM till reach xml element foo, constrained by a
+ *                                  // local element declaration in schema.
+ *
+ *       // FooType is the JAXB mapping of the type of local element declaration foo.
+ *       JAXBElement&lt;FooType> foo = u.unmarshal( fooSubtree, FooType.class);
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * <b>Support for SAX2.0 Compliant Parsers</b><br>
+ * <blockquote>
+ * A client application has the ability to select the SAX2.0 compliant parser
+ * of their choice.  If a SAX parser is not selected, then the JAXB Provider's
+ * default parser will be used.  Even though the JAXB Provider's default parser
+ * is not required to be SAX2.0 compliant, all providers are required to allow
+ * a client application to specify their own SAX2.0 parser.  Some providers may
+ * require the client application to specify the SAX2.0 parser at schema compile
+ * time. See {@link #unmarshal(javax.xml.transform.Source) unmarshal(Source)}
+ * for more detail.
+ * </blockquote>
+ *
+ * <p>
+ * <b>Validation and Well-Formedness</b><br>
+ * <blockquote>
+ * <p>
+ * A client application can enable or disable JAXP 1.3 validation
+ * mechanism via the <tt>setSchema(javax.xml.validation.Schema)</tt> API.
+ * Sophisticated clients can specify their own validating SAX 2.0 compliant
+ * parser and bypass the JAXP 1.3 validation mechanism using the
+ * {@link #unmarshal(javax.xml.transform.Source) unmarshal(Source)}  API.
+ *
+ * <p>
+ * Since unmarshalling invalid XML content is defined in JAXB 2.0,
+ * the Unmarshaller default validation event handler was made more lenient
+ * than in JAXB 1.0.  When schema-derived code generated
+ * by JAXB 1.0 binding compiler is registered with {@link JAXBContext},
+ * the default unmarshal validation handler is
+ * {@link javax.xml.bind.helpers.DefaultValidationEventHandler} and it
+ * terminates the marshal  operation after encountering either a fatal error or an error.
+ * For a JAXB 2.0 client application, there is no explicitly defined default
+ * validation handler and the default event handling only
+ * terminates the marshal operation after encountering a fatal error.
+ *
+ * </blockquote>
+ *
+ * <p>
+ * <a name="supportedProps"></a>
+ * <b>Supported Properties</b><br>
+ * <blockquote>
+ * <p>
+ * There currently are not any properties required to be supported by all
+ * JAXB Providers on Unmarshaller.  However, some providers may support
+ * their own set of provider specific properties.
+ * </blockquote>
+ *
+ * <p>
+ * <a name="unmarshalEventCallback"></a>
+ * <b>Unmarshal Event Callbacks</b><br>
+ * <blockquote>
+ * The {@link Unmarshaller} provides two styles of callback mechanisms
+ * that allow application specific processing during key points in the
+ * unmarshalling process.  In 'class defined' event callbacks, application
+ * specific code placed in JAXB mapped classes is triggered during
+ * unmarshalling.  'External listeners' allow for centralized processing
+ * of unmarshal events in one callback method rather than by type event callbacks.
+ * <p>
+ * 'Class defined' event callback methods allow any JAXB mapped class to specify
+ * its own specific callback methods by defining methods with the following method signature:
+ * <blockquote>
+ * <pre>
+ *   // This method is called immediately after the object is created and before the unmarshalling of this
+ *   // object begins. The callback provides an opportunity to initialize JavaBean properties prior to unmarshalling.
+ *   void beforeUnmarshal(Unmarshaller, Object parent);
+ *
+ *   //This method is called after all the properties (except IDREF) are unmarshalled for this object,
+ *   //but before this object is set to the parent object.
+ *   void afterUnmarshal(Unmarshaller, Object parent);
+ * </pre>
+ * </blockquote>
+ * The class defined callback methods should be used when the callback method requires
+ * access to non-public methods and/or fields of the class.
+ * <p>
+ * The external listener callback mechanism enables the registration of a {@link Listener}
+ * instance with an {@link Unmarshaller#setListener(Listener)}. The external listener receives all callback events,
+ * allowing for more centralized processing than per class defined callback methods.  The external listener
+ * receives events when unmarshalling proces is marshalling to a JAXB element or to JAXB mapped class.
+ * <p>
+ * The 'class defined' and external listener event callback methods are independent of each other,
+ * both can be called for one event.  The invocation ordering when both listener callback methods exist is
+ * defined in {@link Listener#beforeUnmarshal(Object, Object)} and {@link Listener#afterUnmarshal(Object, Object)}.
+* <p>
+ * An event callback method throwing an exception terminates the current unmarshal process.
+ *
+ * </blockquote>
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBContext
+ * @see Marshaller
+ * @see Validator
+ * @since JAXB1.0
+ */
+public interface Unmarshaller {
+
+    /**
+     * Unmarshal XML data from the specified file and return the resulting
+     * content tree.
+     *
+     * <p>
+     * Implements <a href="#unmarshalGlobal">Unmarshal Global Root Element</a>.
+     *
+     * @param f the file to unmarshal XML data from
+     * @return the newly created root object of the java content tree
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the file parameter is null
+     */
+    public Object unmarshal( java.io.File f ) throws JAXBException;
+
+    /**
+     * Unmarshal XML data from the specified InputStream and return the
+     * resulting content tree.  Validation event location information may
+     * be incomplete when using this form of the unmarshal API.
+     *
+     * <p>
+     * Implements <a href="#unmarshalGlobal">Unmarshal Global Root Element</a>.
+     *
+     * @param is the InputStream to unmarshal XML data from
+     * @return the newly created root object of the java content tree
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the InputStream parameter is null
+     */
+    public Object unmarshal( java.io.InputStream is ) throws JAXBException;
+
+    /**
+     * Unmarshal XML data from the specified Reader and return the
+     * resulting content tree.  Validation event location information may
+     * be incomplete when using this form of the unmarshal API,
+     * because a Reader does not provide the system ID.
+     *
+     * <p>
+     * Implements <a href="#unmarshalGlobal">Unmarshal Global Root Element</a>.
+     *
+     * @param reader the Reader to unmarshal XML data from
+     * @return the newly created root object of the java content tree
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the InputStream parameter is null
+     * @since JAXB2.0
+     */
+    public Object unmarshal( Reader reader ) throws JAXBException;
+
+    /**
+     * Unmarshal XML data from the specified URL and return the resulting
+     * content tree.
+     *
+     * <p>
+     * Implements <a href="#unmarshalGlobal">Unmarshal Global Root Element</a>.
+     *
+     * @param url the url to unmarshal XML data from
+     * @return the newly created root object of the java content tree
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the URL parameter is null
+     */
+    public Object unmarshal( java.net.URL url ) throws JAXBException;
+
+    /**
+     * Unmarshal XML data from the specified SAX InputSource and return the
+     * resulting content tree.
+     *
+     * <p>
+     * Implements <a href="#unmarshalGlobal">Unmarshal Global Root Element</a>.
+     *
+     * @param source the input source to unmarshal XML data from
+     * @return the newly created root object of the java content tree
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the InputSource parameter is null
+     */
+    public Object unmarshal( org.xml.sax.InputSource source ) throws JAXBException;
+
+    /**
+     * Unmarshal global XML data from the specified DOM tree and return the resulting
+     * content tree.
+     *
+     * <p>
+     * Implements <a href="#unmarshalGlobal">Unmarshal Global Root Element</a>.
+     *
+     * @param node
+     *      the document/element to unmarshal XML data from.
+     *      The caller must support at least Document and Element.
+     * @return the newly created root object of the java content tree
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the Node parameter is null
+     * @see #unmarshal(org.w3c.dom.Node, Class)
+     */
+    public Object unmarshal( org.w3c.dom.Node node ) throws JAXBException;
+
+    /**
+     * Unmarshal XML data by JAXB mapped <tt>declaredType</tt>
+     * and return the resulting content tree.
+     *
+     * <p>
+     * Implements <a href="#unmarshalByDeclaredType">Unmarshal by Declared Type</a>
+     *
+     * @param node
+     *      the document/element to unmarshal XML data from.
+     *      The caller must support at least Document and Element.
+     * @param declaredType
+     *      appropriate JAXB mapped class to hold <tt>node</tt>'s XML data.
+     *
+     * @return <a href="#unmarshalDeclaredTypeReturn">JAXB Element</a> representation of <tt>node</tt>
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If any parameter is null
+     * @since JAXB2.0
+     */
+    public <T> JAXBElement<T> unmarshal( org.w3c.dom.Node node, Class<T> declaredType ) throws JAXBException;
+
+    /**
+     * Unmarshal XML data from the specified XML Source and return the
+     * resulting content tree.
+     *
+     * <p>
+     * Implements <a href="#unmarshalGlobal">Unmarshal Global Root Element</a>.
+     *
+     * <p>
+     * <a name="saxParserPlugable"></a>
+     * <b>SAX 2.0 Parser Pluggability</b>
+     * <p>
+     * A client application can choose not to use the default parser mechanism
+     * supplied with their JAXB provider.  Any SAX 2.0 compliant parser can be
+     * substituted for the JAXB provider's default mechanism.  To do so, the
+     * client application must properly configure a <tt>SAXSource</tt> containing
+     * an <tt>XMLReader</tt> implemented by the SAX 2.0 parser provider.  If the
+     * <tt>XMLReader</tt> has an <tt>org.xml.sax.ErrorHandler</tt> registered
+     * on it, it will be replaced by the JAXB Provider so that validation errors
+     * can be reported via the <tt>ValidationEventHandler</tt> mechanism of
+     * JAXB.  If the <tt>SAXSource</tt> does not contain an <tt>XMLReader</tt>,
+     * then the JAXB provider's default parser mechanism will be used.
+     * <p>
+     * This parser replacement mechanism can also be used to replace the JAXB
+     * provider's unmarshal-time validation engine.  The client application
+     * must properly configure their SAX 2.0 compliant parser to perform
+     * validation (as shown in the example above).  Any <tt>SAXParserExceptions
+     * </tt> encountered by the parser during the unmarshal operation will be
+     * processed by the JAXB provider and converted into JAXB
+     * <tt>ValidationEvent</tt> objects which will be reported back to the
+     * client via the <tt>ValidationEventHandler</tt> registered with the
+     * <tt>Unmarshaller</tt>.  <i>Note:</i> specifying a substitute validating
+     * SAX 2.0 parser for unmarshalling does not necessarily replace the
+     * validation engine used by the JAXB provider for performing on-demand
+     * validation.
+     * <p>
+     * The only way for a client application to specify an alternate parser
+     * mechanism to be used during unmarshal is via the
+     * <tt>unmarshal(SAXSource)</tt> API.  All other forms of the unmarshal
+     * method (File, URL, Node, etc) will use the JAXB provider's default
+     * parser and validator mechanisms.
+     *
+     * @param source the XML Source to unmarshal XML data from (providers are
+     *        only required to support SAXSource, DOMSource, and StreamSource)
+     * @return the newly created root object of the java content tree
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the Source parameter is null
+     * @see #unmarshal(javax.xml.transform.Source, Class)
+     */
+    public Object unmarshal( javax.xml.transform.Source source )
+        throws JAXBException;
+
+
+    /**
+     * Unmarshal XML data from the specified XML Source by <tt>declaredType</tt> and return the
+     * resulting content tree.
+     *
+     * <p>
+     * Implements <a href="#unmarshalByDeclaredType">Unmarshal by Declared Type</a>
+     *
+     * <p>
+     * See <a href="#saxParserPlugable">SAX 2.0 Parser Pluggability</a>
+     *
+     * @param source the XML Source to unmarshal XML data from (providers are
+     *        only required to support SAXSource, DOMSource, and StreamSource)
+     * @param declaredType
+     *      appropriate JAXB mapped class to hold <tt>source</tt>'s xml root element
+     * @return Java content rooted by <a href="#unmarshalDeclaredTypeReturn">JAXB Element</a>
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If any parameter is null
+     * @since JAXB2.0
+     */
+    public <T> JAXBElement<T> unmarshal( javax.xml.transform.Source source, Class<T> declaredType )
+        throws JAXBException;
+
+    /**
+     * Unmarshal XML data from the specified pull parser and return the
+     * resulting content tree.
+     *
+     * <p>
+     * Implements <a href="#unmarshalGlobal">Unmarshal Global Root Element</a>.
+     *
+     * <p>
+     * This method assumes that the parser is on a START_DOCUMENT or
+     * START_ELEMENT event.  Unmarshalling will be done from this
+     * start event to the corresponding end event.  If this method
+     * returns successfully, the <tt>reader</tt> will be pointing at
+     * the token right after the end event.
+     *
+     * @param reader
+     *      The parser to be read.
+     * @return
+     *      the newly created root object of the java content tree.
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the <tt>reader</tt> parameter is null
+     * @throws IllegalStateException
+     *      If <tt>reader</tt> is not pointing to a START_DOCUMENT or
+     *      START_ELEMENT  event.
+     * @since JAXB2.0
+     * @see #unmarshal(javax.xml.stream.XMLStreamReader, Class)
+     */
+    public Object unmarshal( javax.xml.stream.XMLStreamReader reader )
+        throws JAXBException;
+
+    /**
+     * Unmarshal root element to JAXB mapped <tt>declaredType</tt>
+     * and return the resulting content tree.
+     *
+     * <p>
+     * This method implements <a href="#unmarshalByDeclaredType">unmarshal by declaredType</a>.
+     * <p>
+     * This method assumes that the parser is on a START_DOCUMENT or
+     * START_ELEMENT event. Unmarshalling will be done from this
+     * start event to the corresponding end event.  If this method
+     * returns successfully, the <tt>reader</tt> will be pointing at
+     * the token right after the end event.
+     *
+     * @param reader
+     *      The parser to be read.
+     * @param declaredType
+     *      appropriate JAXB mapped class to hold <tt>reader</tt>'s START_ELEMENT XML data.
+     *
+     * @return   content tree rooted by <a href="#unmarshalDeclaredTypeReturn">JAXB Element representation</a>
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If any parameter is null
+     * @since JAXB2.0
+     */
+    public <T> JAXBElement<T> unmarshal( javax.xml.stream.XMLStreamReader reader, Class<T> declaredType ) throws JAXBException;
+
+    /**
+     * Unmarshal XML data from the specified pull parser and return the
+     * resulting content tree.
+     *
+     * <p>
+     * This method is an <a href="#unmarshalGlobal">Unmarshal Global Root method</a>.
+     *
+     * <p>
+     * This method assumes that the parser is on a START_DOCUMENT or
+     * START_ELEMENT event.  Unmarshalling will be done from this
+     * start event to the corresponding end event.  If this method
+     * returns successfully, the <tt>reader</tt> will be pointing at
+     * the token right after the end event.
+     *
+     * @param reader
+     *      The parser to be read.
+     * @return
+     *      the newly created root object of the java content tree.
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If the <tt>reader</tt> parameter is null
+     * @throws IllegalStateException
+     *      If <tt>reader</tt> is not pointing to a START_DOCUMENT or
+     *      START_ELEMENT event.
+     * @since JAXB2.0
+     * @see #unmarshal(javax.xml.stream.XMLEventReader, Class)
+     */
+    public Object unmarshal( javax.xml.stream.XMLEventReader reader )
+        throws JAXBException;
+
+    /**
+     * Unmarshal root element to JAXB mapped <tt>declaredType</tt>
+     * and return the resulting content tree.
+     *
+     * <p>
+     * This method implements <a href="#unmarshalByDeclaredType">unmarshal by declaredType</a>.
+     *
+     * <p>
+     * This method assumes that the parser is on a START_DOCUMENT or
+     * START_ELEMENT event. Unmarshalling will be done from this
+     * start event to the corresponding end event.  If this method
+     * returns successfully, the <tt>reader</tt> will be pointing at
+     * the token right after the end event.
+     *
+     * @param reader
+     *      The parser to be read.
+     * @param declaredType
+     *      appropriate JAXB mapped class to hold <tt>reader</tt>'s START_ELEMENT XML data.
+     *
+     * @return   content tree rooted by <a href="#unmarshalDeclaredTypeReturn">JAXB Element representation</a>
+     *
+     * @throws JAXBException
+     *     If any unexpected errors occur while unmarshalling
+     * @throws UnmarshalException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Unmarshaller</tt> is unable to perform the XML to Java
+     *     binding.  See <a href="#unmarshalEx">Unmarshalling XML Data</a>
+     * @throws IllegalArgumentException
+     *      If any parameter is null
+     * @since JAXB2.0
+     */
+    public <T> JAXBElement<T> unmarshal( javax.xml.stream.XMLEventReader reader, Class<T> declaredType ) throws JAXBException;
+
+    /**
+     * Get an unmarshaller handler object that can be used as a component in
+     * an XML pipeline.
+     *
+     * <p>
+     * The JAXB Provider can return the same handler object for multiple
+     * invocations of this method. In other words, this method does not
+     * necessarily create a new instance of <tt>UnmarshallerHandler</tt>. If the
+     * application needs to use more than one <tt>UnmarshallerHandler</tt>, it
+     * should create more than one <tt>Unmarshaller</tt>.
+     *
+     * @return the unmarshaller handler object
+     * @see UnmarshallerHandler
+     */
+    public UnmarshallerHandler getUnmarshallerHandler();
+
+    /**
+     * Specifies whether or not the default validation mechanism of the
+     * <tt>Unmarshaller</tt> should validate during unmarshal operations.
+     * By default, the <tt>Unmarshaller</tt> does not validate.
+     * <p>
+     * This method may only be invoked before or after calling one of the
+     * unmarshal methods.
+     * <p>
+     * This method only controls the JAXB Provider's default unmarshal-time
+     * validation mechanism - it has no impact on clients that specify their
+     * own validating SAX 2.0 compliant parser.  Clients that specify their
+     * own unmarshal-time validation mechanism may wish to turn off the JAXB
+     * Provider's default validation mechanism via this API to avoid "double
+     * validation".
+     * <p>
+     * This method is deprecated as of JAXB 2.0 - please use the new
+     * {@link #setSchema(javax.xml.validation.Schema)} API.
+     *
+     * @param validating true if the Unmarshaller should validate during
+     *        unmarshal, false otherwise
+     * @throws JAXBException if an error occurred while enabling or disabling
+     *         validation at unmarshal time
+     * @throws UnsupportedOperationException could be thrown if this method is
+     *         invoked on an Unmarshaller created from a JAXBContext referencing
+     *         JAXB 2.0 mapped classes
+     * @deprecated since JAXB2.0, please see {@link #setSchema(javax.xml.validation.Schema)}
+     */
+    public void setValidating( boolean validating )
+        throws JAXBException;
+
+    /**
+     * Indicates whether or not the <tt>Unmarshaller</tt> is configured to
+     * validate during unmarshal operations.
+     * <p>
+     * This API returns the state of the JAXB Provider's default unmarshal-time
+     * validation mechanism.
+     * <p>
+     * This method is deprecated as of JAXB 2.0 - please use the new
+     * {@link #getSchema()} API.
+     *
+     * @return true if the Unmarshaller is configured to validate during
+     *         unmarshal operations, false otherwise
+     * @throws JAXBException if an error occurs while retrieving the validating
+     *         flag
+     * @throws UnsupportedOperationException could be thrown if this method is
+     *         invoked on an Unmarshaller created from a JAXBContext referencing
+     *         JAXB 2.0 mapped classes
+     * @deprecated since JAXB2.0, please see {@link #getSchema()}
+     */
+    public boolean isValidating()
+        throws JAXBException;
+
+    /**
+     * Allow an application to register a <tt>ValidationEventHandler</tt>.
+     * <p>
+     * The <tt>ValidationEventHandler</tt> will be called by the JAXB Provider
+     * if any validation errors are encountered during calls to any of the
+     * unmarshal methods.  If the client application does not register a
+     * <tt>ValidationEventHandler</tt> before invoking the unmarshal methods,
+     * then <tt>ValidationEvents</tt> will be handled by the default event
+     * handler which will terminate the unmarshal operation after the first
+     * error or fatal error is encountered.
+     * <p>
+     * Calling this method with a null parameter will cause the Unmarshaller
+     * to revert back to the default event handler.
+     *
+     * @param handler the validation event handler
+     * @throws JAXBException if an error was encountered while setting the
+     *         event handler
+     */
+    public void setEventHandler( ValidationEventHandler handler )
+        throws JAXBException;
+
+    /**
+     * Return the current event handler or the default event handler if one
+     * hasn't been set.
+     *
+     * @return the current ValidationEventHandler or the default event handler
+     *         if it hasn't been set
+     * @throws JAXBException if an error was encountered while getting the
+     *         current event handler
+     */
+    public ValidationEventHandler getEventHandler()
+        throws JAXBException;
+
+    /**
+     * Set the particular property in the underlying implementation of
+     * <tt>Unmarshaller</tt>.  This method can only be used to set one of
+     * the standard JAXB defined properties above or a provider specific
+     * property.  Attempting to set an undefined property will result in
+     * a PropertyException being thrown.  See <a href="#supportedProps">
+     * Supported Properties</a>.
+     *
+     * @param name the name of the property to be set. This value can either
+     *              be specified using one of the constant fields or a user
+     *              supplied string.
+     * @param value the value of the property to be set
+     *
+     * @throws PropertyException when there is an error processing the given
+     *                            property or value
+     * @throws IllegalArgumentException
+     *      If the name parameter is null
+     */
+    public void setProperty( String name, Object value )
+        throws PropertyException;
+
+    /**
+     * Get the particular property in the underlying implementation of
+     * <tt>Unmarshaller</tt>.  This method can only be used to get one of
+     * the standard JAXB defined properties above or a provider specific
+     * property.  Attempting to get an undefined property will result in
+     * a PropertyException being thrown.  See <a href="#supportedProps">
+     * Supported Properties</a>.
+     *
+     * @param name the name of the property to retrieve
+     * @return the value of the requested property
+     *
+     * @throws PropertyException
+     *      when there is an error retrieving the given property or value
+     *      property name
+     * @throws IllegalArgumentException
+     *      If the name parameter is null
+     */
+    public Object getProperty( String name ) throws PropertyException;
+
+    /**
+     * Specify the JAXP 1.3 {@link javax.xml.validation.Schema Schema}
+     * object that should be used to validate subsequent unmarshal operations
+     * against.  Passing null into this method will disable validation.
+     * <p>
+     * This method replaces the deprecated {@link #setValidating(boolean) setValidating(boolean)}
+     * API.
+     *
+     * <p>
+     * Initially this property is set to <tt>null</tt>.
+     *
+     * @param schema Schema object to validate unmarshal operations against or null to disable validation
+     * @throws UnsupportedOperationException could be thrown if this method is
+     *         invoked on an Unmarshaller created from a JAXBContext referencing
+     *         JAXB 1.0 mapped classes
+     * @since JAXB2.0
+     */
+    public void setSchema( javax.xml.validation.Schema schema );
+
+    /**
+     * Get the JAXP 1.3 {@link javax.xml.validation.Schema Schema} object
+     * being used to perform unmarshal-time validation.  If there is no
+     * Schema set on the unmarshaller, then this method will return null
+     * indicating that unmarshal-time validation will not be performed.
+     * <p>
+     * This method provides replacement functionality for the deprecated
+     * {@link #isValidating()} API as well as access to the Schema object.
+     * To determine if the Unmarshaller has validation enabled, simply
+     * test the return type for null:
+     * <p>
+     * <code>
+     *   boolean isValidating = u.getSchema()!=null;
+     * </code>
+     *
+     * @return the Schema object being used to perform unmarshal-time
+     *      validation or null if not present
+     * @throws UnsupportedOperationException could be thrown if this method is
+     *         invoked on an Unmarshaller created from a JAXBContext referencing
+     *         JAXB 1.0 mapped classes
+     * @since JAXB2.0
+     */
+    public javax.xml.validation.Schema getSchema();
+
+    /**
+     * Associates a configured instance of {@link XmlAdapter} with this unmarshaller.
+     *
+     * <p>
+     * This is a convenience method that invokes <code>setAdapter(adapter.getClass(),adapter);</code>.
+     *
+     * @see #setAdapter(Class,XmlAdapter)
+     * @throws IllegalArgumentException
+     *      if the adapter parameter is null.
+     * @throws UnsupportedOperationException
+     *      if invoked agains a JAXB 1.0 implementation.
+     * @since JAXB2.0
+     */
+    public void setAdapter( XmlAdapter adapter );
+
+    /**
+     * Associates a configured instance of {@link XmlAdapter} with this unmarshaller.
+     *
+     * <p>
+     * Every unmarshaller internally maintains a
+     * {@link java.util.Map}&lt;{@link Class},{@link XmlAdapter}>,
+     * which it uses for unmarshalling classes whose fields/methods are annotated
+     * with {@link javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter}.
+     *
+     * <p>
+     * This method allows applications to use a configured instance of {@link XmlAdapter}.
+     * When an instance of an adapter is not given, an unmarshaller will create
+     * one by invoking its default constructor.
+     *
+     * @param type
+     *      The type of the adapter. The specified instance will be used when
+     *      {@link javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter#value()}
+     *      refers to this type.
+     * @param adapter
+     *      The instance of the adapter to be used. If null, it will un-register
+     *      the current adapter set for this type.
+     * @throws IllegalArgumentException
+     *      if the type parameter is null.
+     * @throws UnsupportedOperationException
+     *      if invoked agains a JAXB 1.0 implementation.
+     * @since JAXB2.0
+     */
+    public <A extends XmlAdapter> void setAdapter( Class<A> type, A adapter );
+
+    /**
+     * Gets the adapter associated with the specified type.
+     *
+     * This is the reverse operation of the {@link #setAdapter} method.
+     *
+     * @throws IllegalArgumentException
+     *      if the type parameter is null.
+     * @throws UnsupportedOperationException
+     *      if invoked agains a JAXB 1.0 implementation.
+     * @since JAXB2.0
+     */
+    public <A extends XmlAdapter> A getAdapter( Class<A> type );
+
+    /**
+     * <p>Associate a context that resolves cid's, content-id URIs, to
+     * binary data passed as attachments.</p>
+     * <p/>
+     * <p>Unmarshal time validation, enabled via {@link #setSchema(Schema)},
+     * must be supported even when unmarshaller is performing XOP processing.
+     * </p>
+     *
+     * @throws IllegalStateException if attempt to concurrently call this
+     *                               method during a unmarshal operation.
+     */
+    void setAttachmentUnmarshaller(AttachmentUnmarshaller au);
+
+    AttachmentUnmarshaller getAttachmentUnmarshaller();
+
+    /**
+     * <p/>
+     * Register an instance of an implementation of this class with {@link Unmarshaller} to externally listen
+     * for unmarshal events.
+     * <p/>
+     * <p/>
+     * This class enables pre and post processing of an instance of a JAXB mapped class
+     * as XML data is unmarshalled into it. The event callbacks are called when unmarshalling
+     * XML content into a JAXBElement instance or a JAXB mapped class that represents a complex type definition.
+     * The event callbacks are not called when unmarshalling to an instance of a
+     * Java datatype that represents a simple type definition.
+     * <p/>
+     * <p/>
+     * External listener is one of two different mechanisms for defining unmarshal event callbacks.
+     * See <a href="Unmarshaller.html#unmarshalEventCallback">Unmarshal Event Callbacks</a> for an overview.
+     * <p/>
+     * (@link #setListener(Listener)}
+     * (@link #getListener()}
+     *
+     * @since JAXB2.0
+     */
+    public static abstract class Listener {
+        /**
+         * <p/>
+         * Callback method invoked before unmarshalling into <tt>target</tt>.
+         * <p/>
+         * <p/>
+         * This method is invoked immediately after <tt>target</tt> was created and
+         * before the unmarshalling of this object begins. Note that
+         * if the class of <tt>target</tt> defines its own <tt>beforeUnmarshal</tt> method,
+         * the class specific callback method is invoked before this method is invoked.
+         *
+         * @param target non-null instance of JAXB mapped class prior to unmarshalling into it.
+         * @param parent instance of JAXB mapped class that will eventually reference <tt>target</tt>.
+         *               <tt>null</tt> when <tt>target</tt> is root element.
+         */
+        public void beforeUnmarshal(Object target, Object parent) {
+        }
+
+        /**
+         * <p/>
+         * Callback method invoked after unmarshalling XML data into <tt>target</tt>.
+         * <p/>
+         * <p/>
+         * This method is invoked after all the properties (except IDREF) are unmarshalled into <tt>target</tt>,
+         * but before <tt>target</tt> is set into its <tt>parent</tt> object.
+         * Note that if the class of <tt>target</tt> defines its own <tt>afterUnmarshal</tt> method,
+         * the class specific callback method is invoked before this method is invoked.
+         *
+         * @param target non-null instance of JAXB mapped class prior to unmarshalling into it.
+         * @param parent instance of JAXB mapped class that will reference <tt>target</tt>.
+         *               <tt>null</tt> when <tt>target</tt> is root element.
+         */
+        public void afterUnmarshal(Object target, Object parent) {
+        }
+    }
+
+    /**
+     * <p>
+     * Register unmarshal event callback {@link Listener} with this {@link Unmarshaller}.
+     *
+     * <p>
+     * There is only one Listener per Unmarshaller. Setting a Listener replaces the previous set Listener.
+     * One can unregister current Listener by setting listener to <tt>null</tt>.
+     *
+     * @param listener  provides unmarshal event callbacks for this {@link Unmarshaller}
+     * @since JAXB2.0
+     */
+    public void     setListener(Listener listener);
+
+    /**
+     * <p>Return {@link Listener} registered with this {@link Unmarshaller}.
+     *
+     * @return registered {@link Listener} or <code>null</code> if no Listener is registered with this Unmarshaller.
+     * @since JAXB2.0
+     */
+    public Listener getListener();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/UnmarshallerHandler.java b/jaxws/src/share/classes/javax/xml/bind/UnmarshallerHandler.java
new file mode 100644
index 0000000..42193b3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/UnmarshallerHandler.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind;
+
+import org.xml.sax.ContentHandler;
+
+/**
+ * Unmarshaller implemented as SAX ContentHandler.
+ *
+ * <p>
+ * Applications can use this interface to use their JAXB provider as a component
+ * in an XML pipeline.  For example:
+ *
+ * <pre>
+ *       JAXBContext context = JAXBContext.newInstance( "org.acme.foo" );
+ *
+ *       Unmarshaller unmarshaller = context.createUnmarshaller();
+ *
+ *       UnmarshallerHandler unmarshallerHandler = unmarshaller.getUnmarshallerHandler();
+ *
+ *       SAXParserFactory spf = SAXParserFactory.newInstance();
+ *       spf.setNamespaceAware( true );
+ *
+ *       XMLReader xmlReader = spf.newSAXParser().getXMLReader();
+ *       xmlReader.setContentHandler( unmarshallerHandler );
+ *       xmlReader.parse(new InputSource( new FileInputStream( XML_FILE ) ) );
+ *
+ *       MyObject myObject= (MyObject)unmarshallerHandler.getResult();
+ * </pre>
+ *
+ * <p>
+ * This interface is reusable: even if the user fails to unmarshal
+ * an object, s/he can still start a new round of unmarshalling.
+ *
+ * @author <ul><li>Kohsuke KAWAGUCHI, Sun Microsystems, Inc.</li></ul>
+ * @see Unmarshaller#getUnmarshallerHandler()
+ * @since JAXB1.0
+ */
+public interface UnmarshallerHandler extends ContentHandler
+{
+    /**
+     * Obtains the unmarshalled result.
+     *
+     * This method can be called only after this handler
+     * receives the endDocument SAX event.
+     *
+     * @exception IllegalStateException
+     *      if this method is called before this handler
+     *      receives the endDocument event.
+     *
+     * @exception JAXBException
+     *      if there is any unmarshalling error.
+     *      Note that the implementation is allowed to throw SAXException
+     *      during the parsing when it finds an error.
+     *
+     * @return
+     *      always return a non-null valid object which was unmarshalled.
+     */
+    Object getResult() throws JAXBException, IllegalStateException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/ValidationEvent.java b/jaxws/src/share/classes/javax/xml/bind/ValidationEvent.java
new file mode 100644
index 0000000..794ebfb
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/ValidationEvent.java
@@ -0,0 +1,92 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This event indicates that a problem was encountered while validating the
+ * incoming XML data during an unmarshal operation, while performing
+ * on-demand validation of the Java content tree, or while marshalling the
+ * Java content tree back to XML data.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see Validator
+ * @see ValidationEventHandler
+ * @since JAXB1.0
+ */
+public interface ValidationEvent {
+
+    /**
+     * Conditions that are not errors or fatal errors as defined by the
+     * XML 1.0 recommendation
+     */
+    public static final int WARNING     = 0;
+
+    /**
+     * Conditions that correspond to the definition of "error" in section
+     * 1.2 of the W3C XML 1.0 Recommendation
+     */
+    public static final int ERROR       = 1;
+
+    /**
+     * Conditions that correspond to the definition of "fatal error" in section
+     * 1.2 of the W3C XML 1.0 Recommendation
+     */
+    public static final int FATAL_ERROR = 2;
+
+    /**
+     * Retrieve the severity code for this warning/error.
+     *
+     * <p>
+     * Must be one of <tt>ValidationError.WARNING</tt>,
+     * <tt>ValidationError.ERROR</tt>, or <tt>ValidationError.FATAL_ERROR</tt>.
+     *
+     * @return the severity code for this warning/error
+     */
+    public int getSeverity();
+
+    /**
+     * Retrieve the text message for this warning/error.
+     *
+     * @return the text message for this warning/error or null if one wasn't set
+     */
+    public String getMessage();
+
+    /**
+     * Retrieve the linked exception for this warning/error.
+     *
+     * @return the linked exception for this warning/error or null if one
+     *         wasn't set
+     */
+    public Throwable getLinkedException();
+
+    /**
+     * Retrieve the locator for this warning/error.
+     *
+     * @return the locator that indicates where the warning/error occurred
+     */
+    public ValidationEventLocator getLocator();
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/ValidationEventHandler.java b/jaxws/src/share/classes/javax/xml/bind/ValidationEventHandler.java
new file mode 100644
index 0000000..ad184e0
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/ValidationEventHandler.java
@@ -0,0 +1,94 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * A basic event handler interface for validation errors.
+ *
+ * <p>
+ * If an application needs to implement customized event handling, it must
+ * implement this interface and then register it with either the
+ * {@link Unmarshaller#setEventHandler(ValidationEventHandler) Unmarshaller},
+ * the {@link Validator#setEventHandler(ValidationEventHandler) Validator}, or
+ * the {@link Marshaller#setEventHandler(ValidationEventHandler) Marshaller}.
+ * The JAXB Provider will then report validation errors and warnings encountered
+ * during the unmarshal, marshal, and validate operations to these event
+ * handlers.
+ *
+ * <p>
+ * If the <tt>handleEvent</tt> method throws an unchecked runtime exception,
+ * the JAXB Provider must treat that as if the method returned false, effectively
+ * terminating whatever operation was in progress at the time (unmarshal,
+ * validate, or marshal).
+ *
+ * <p>
+ * Modifying the Java content tree within your event handler is undefined
+ * by the specification and may result in unexpected behaviour.
+ *
+ * <p>
+ * Failing to return false from the <tt>handleEvent</tt> method after
+ * encountering a fatal error is undefined by the specification and may result
+ * in unexpected behavior.
+ *
+ * <p>
+ * <b>Default Event Handler</b>
+ * <blockquote>
+ *    See: <a href="Validator.html#defaulthandler">Validator javadocs</a>
+ * </blockquote>
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see Unmarshaller
+ * @see Validator
+ * @see Marshaller
+ * @see ValidationEvent
+ * @see javax.xml.bind.util.ValidationEventCollector
+ * @since JAXB1.0
+ */
+public interface ValidationEventHandler {
+    /**
+     * Receive notification of a validation warning or error.
+     *
+     * The ValidationEvent will have a
+     * {@link ValidationEventLocator ValidationEventLocator} embedded in it that
+     * indicates where the error or warning occurred.
+     *
+     * <p>
+     * If an unchecked runtime exception is thrown from this method, the JAXB
+     * provider will treat it as if the method returned false and interrupt
+     * the current unmarshal, validate, or marshal operation.
+     *
+     * @param event the encapsulated validation event information.  It is a
+     * provider error if this parameter is null.
+     * @return true if the JAXB Provider should attempt to continue the current
+     *         unmarshal, validate, or marshal operation after handling this
+     *         warning/error, false if the provider should terminate the current
+     *         operation with the appropriate <tt>UnmarshalException</tt>,
+     *         <tt>ValidationException</tt>, or <tt>MarshalException</tt>.
+     * @throws IllegalArgumentException if the event object is null.
+     */
+    public boolean handleEvent( ValidationEvent event );
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/ValidationEventLocator.java b/jaxws/src/share/classes/javax/xml/bind/ValidationEventLocator.java
new file mode 100644
index 0000000..e93465a
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/ValidationEventLocator.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * Encapsulate the location of a ValidationEvent.
+ *
+ * <p>
+ * The <tt>ValidationEventLocator</tt> indicates where the <tt>ValidationEvent
+ * </tt> occurred.  Different fields will be set depending on the type of
+ * validation that was being performed when the error or warning was detected.
+ * For example, on-demand validation would produce locators that contained
+ * references to objects in the Java content tree while unmarshal-time
+ * validation would produce locators containing information appropriate to the
+ * source of the XML data (file, url, Node, etc).
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see Validator
+ * @see ValidationEvent
+ * @since JAXB1.0
+ */
+public interface ValidationEventLocator {
+
+    /**
+     * Return the name of the XML source as a URL if available
+     *
+     * @return the name of the XML source as a URL or null if unavailable
+     */
+    public java.net.URL getURL();
+
+    /**
+     * Return the byte offset if available
+     *
+     * @return the byte offset into the input source or -1 if unavailable
+     */
+    public int getOffset();
+
+    /**
+     * Return the line number if available
+     *
+     * @return the line number or -1 if unavailable
+     */
+    public int getLineNumber();
+
+    /**
+     * Return the column number if available
+     *
+     * @return the column number or -1 if unavailable
+     */
+    public int getColumnNumber();
+
+    /**
+     * Return a reference to the object in the Java content tree if available
+     *
+     * @return a reference to the object in the Java content tree or null if
+     *         unavailable
+     */
+    public java.lang.Object getObject();
+
+    /**
+     * Return a reference to the DOM Node if available
+     *
+     * @return a reference to the DOM Node or null if unavailable
+     */
+    public org.w3c.dom.Node getNode();
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/ValidationException.java b/jaxws/src/share/classes/javax/xml/bind/ValidationException.java
new file mode 100644
index 0000000..31d9308
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/ValidationException.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * This exception indicates that an error has occurred while performing
+ * a validate operation.
+ *
+ * <p>
+ * The <tt>ValidationEventHandler</tt> can cause this exception to be thrown
+ * during the validate operations.  See
+ * {@link ValidationEventHandler#handleEvent(ValidationEvent)
+ * ValidationEventHandler.handleEvent(ValidationEvent)}.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBException
+ * @see Validator
+ * @since JAXB1.0
+ */
+public class ValidationException extends JAXBException {
+
+    /**
+     * Construct an ValidationException with the specified detail message.  The
+     * errorCode and linkedException will default to null.
+     *
+     * @param message a description of the exception
+     */
+    public ValidationException(String message) {
+        this( message, null, null );
+    }
+
+    /**
+     * Construct an ValidationException with the specified detail message and vendor
+     * specific errorCode.  The linkedException will default to null.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     */
+    public ValidationException(String message, String errorCode) {
+        this( message, errorCode, null );
+    }
+
+    /**
+     * Construct an ValidationException with a linkedException.  The detail message and
+     * vendor specific errorCode will default to null.
+     *
+     * @param exception the linked exception
+     */
+    public ValidationException(Throwable exception) {
+        this( null, null, exception );
+    }
+
+    /**
+     * Construct an ValidationException with the specified detail message and
+     * linkedException.  The errorCode will default to null.
+     *
+     * @param message a description of the exception
+     * @param exception the linked exception
+     */
+    public ValidationException(String message, Throwable exception) {
+        this( message, null, exception );
+    }
+
+    /**
+     * Construct an ValidationException with the specified detail message, vendor
+     * specific errorCode, and linkedException.
+     *
+     * @param message a description of the exception
+     * @param errorCode a string specifying the vendor specific error code
+     * @param exception the linked exception
+     */
+    public ValidationException(String message, String errorCode, Throwable exception) {
+        super( message, errorCode, exception );
+    }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/Validator.java b/jaxws/src/share/classes/javax/xml/bind/Validator.java
new file mode 100644
index 0000000..06dd8d0
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/Validator.java
@@ -0,0 +1,285 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind;
+
+/**
+ * As of JAXB 2.0, this class is deprecated and optional.
+ * <p>
+ * The <tt>Validator</tt> class is responsible for controlling the validation
+ * of content trees during runtime.
+ *
+ * <p>
+ * <a name="validationtypes"></a>
+ * <b>Three Forms of Validation</b><br>
+ * <blockquote>
+ *    <dl>
+ *        <dt><b>Unmarshal-Time Validation</b></dt>
+ *        <dd>This form of validation enables a client application to receive
+ *            information about validation errors and warnings detected while
+ *            unmarshalling XML data into a Java content tree and is completely
+ *            orthogonal to the other types of validation.  To enable or disable
+ *            it, see the javadoc for
+ *            {@link Unmarshaller#setValidating(boolean) Unmarshaller.setValidating}.
+ *            All JAXB 1.0 Providers are required to support this operation.
+ *        </dd>
+ *
+ *        <dt><b>On-Demand Validation</b></dt>
+ *        <dd> This form of validation enables a client application to receive
+ *             information about validation errors and warnings detected in the
+ *             Java content tree.  At any point, client applications can call
+ *             the {@link Validator#validate(Object) Validator.validate} method
+ *             on the Java content tree (or any sub-tree of it).  All JAXB 1.0
+ *             Providers are required to support this operation.
+ *        </dd>
+ *
+ *        <dt><b>Fail-Fast Validation</b></dt>
+ *        <dd> This form of validation enables a client application to receive
+ *             immediate feedback about modifications to the Java content tree
+ *             that violate type constraints on Java Properties as defined in
+ *             the specification.  JAXB Providers are not required support
+ *             this type of validation.  Of the JAXB Providers that do support
+ *             this type of validation, some may require you to decide at schema
+ *             compile time whether or not a client application will be allowed
+ *             to request fail-fast validation at runtime.
+ *        </dd>
+ *    </dl>
+ * </blockquote>
+ *
+ * <p>
+ * The <tt>Validator</tt> class is responsible for managing On-Demand Validation.
+ * The <tt>Unmarshaller</tt> class is responsible for managing Unmarshal-Time
+ * Validation during the unmarshal operations.  Although there is no formal
+ * method of enabling validation during the marshal operations, the
+ * <tt>Marshaller</tt> may detect errors, which will be reported to the
+ * <tt>ValidationEventHandler</tt> registered on it.
+ *
+ * <p>
+ * <a name="defaulthandler"></a>
+ * <b>Using the Default EventHandler</b><br>
+ * <blockquote>
+ *   If the client application does not set an event handler on their
+ *   <tt>Validator</tt>, <tt>Unmarshaller</tt>, or <tt>Marshaller</tt> prior to
+ *   calling the validate, unmarshal, or marshal methods, then a default event
+ *   handler will receive notification of any errors or warnings encountered.
+ *   The default event handler will cause the current operation to halt after
+ *   encountering the first error or fatal error (but will attempt to continue
+ *   after receiving warnings).
+ * </blockquote>
+ *
+ * <p>
+ * <a name="handlingevents"></a>
+ * <b>Handling Validation Events</b><br>
+ * <blockquote>
+ *   There are three ways to handle events encountered during the unmarshal,
+ *   validate, and marshal operations:
+ *    <dl>
+ *        <dt>Use the default event handler</dt>
+ *        <dd>The default event handler will be used if you do not specify one
+ *            via the <tt>setEventHandler</tt> API's on <tt>Validator</tt>,
+ *            <tt>Unmarshaller</tt>, or <tt>Marshaller</tt>.
+ *        </dd>
+ *
+ *        <dt>Implement and register a custom event handler</dt>
+ *        <dd>Client applications that require sophisticated event processing
+ *            can implement the <tt>ValidationEventHandler</tt> interface and
+ *            register it with the <tt>Unmarshaller</tt> and/or
+ *            <tt>Validator</tt>.
+ *        </dd>
+ *
+ *        <dt>Use the {@link javax.xml.bind.util.ValidationEventCollector ValidationEventCollector}
+ *            utility</dt>
+ *        <dd>For convenience, a specialized event handler is provided that
+ *            simply collects any <tt>ValidationEvent</tt> objects created
+ *            during the unmarshal, validate, and marshal operations and
+ *            returns them to the client application as a
+ *            <tt>java.util.Collection</tt>.
+ *        </dd>
+ *    </dl>
+ * </blockquote>
+ *
+ * <p>
+ * <b>Validation and Well-Formedness</b><br>
+ * <blockquote>
+ * <p>
+ * Validation events are handled differently depending on how the client
+ * application is configured to process them as described in the previous
+ * section.  However, there are certain cases where a JAXB Provider indicates
+ * that it is no longer able to reliably detect and report errors.  In these
+ * cases, the JAXB Provider will set the severity of the ValidationEvent to
+ * FATAL_ERROR to indicate that the unmarshal, validate, or marshal operations
+ * should be terminated.  The default event handler and
+ * <tt>ValidationEventCollector</tt> utility class must terminate processing
+ * after being notified of a fatal error.  Client applications that supply their
+ * own <tt>ValidationEventHandler</tt> should also terminate processing after
+ * being notified of a fatal error.  If not, unexpected behaviour may occur.
+ * </blockquote>
+ *
+ * <p>
+ * <a name="supportedProps"></a>
+ * <b>Supported Properties</b><br>
+ * <blockquote>
+ * <p>
+ * There currently are not any properties required to be supported by all
+ * JAXB Providers on Validator.  However, some providers may support
+ * their own set of provider specific properties.
+ * </blockquote>
+ *
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see JAXBContext
+ * @see Unmarshaller
+ * @see ValidationEventHandler
+ * @see ValidationEvent
+ * @see javax.xml.bind.util.ValidationEventCollector
+ * @since JAXB1.0
+ * @deprecated since JAXB 2.0
+ */
+public interface Validator {
+
+    /**
+     * Allow an application to register a validation event handler.
+     * <p>
+     * The validation event handler will be called by the JAXB Provider if any
+     * validation errors are encountered during calls to
+     * {@link #validate(Object) validate}.  If the client application does not
+     * register a validation event handler before invoking the validate method,
+     * then validation events will be handled by the default event handler which
+     * will terminate the validate operation after the first error or fatal error
+     * is encountered.
+     * <p>
+     * Calling this method with a null parameter will cause the Validator
+     * to revert back to the default default event handler.
+     *
+     * @param handler the validation event handler
+     * @throws JAXBException if an error was encountered while setting the
+     *         event handler
+     * @deprecated since JAXB2.0
+     */
+    public void setEventHandler( ValidationEventHandler handler )
+        throws JAXBException;
+
+    /**
+     * Return the current event handler or the default event handler if one
+     * hasn't been set.
+     *
+     * @return the current ValidationEventHandler or the default event handler
+     *         if it hasn't been set
+     * @throws JAXBException if an error was encountered while getting the
+     *         current event handler
+     * @deprecated since JAXB2.0
+     */
+    public ValidationEventHandler getEventHandler()
+        throws JAXBException;
+
+    /**
+     * Validate the Java content tree starting at <tt>subrootObj</tt>.
+     * <p>
+     * Client applications can use this method to validate Java content trees
+     * on-demand at runtime.  This method can be used to validate any arbitrary
+     * subtree of the Java content tree.  Global constraint checking <b>will not
+     * </b> be performed as part of this operation (i.e. ID/IDREF constraints).
+     *
+     * @param subrootObj the obj to begin validation at
+     * @throws JAXBException if any unexpected problem occurs during validation
+     * @throws ValidationException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Validator</tt> is unable to validate the content tree rooted
+     *     at <tt>subrootObj</tt>
+     * @throws IllegalArgumentException
+     *      If the subrootObj parameter is null
+     * @return true if the subtree rooted at <tt>subrootObj</tt> is valid, false
+     *         otherwise
+     * @deprecated since JAXB2.0
+     */
+    public boolean validate( Object subrootObj ) throws JAXBException;
+
+    /**
+     * Validate the Java content tree rooted at <tt>rootObj</tt>.
+     * <p>
+     * Client applications can use this method to validate Java content trees
+     * on-demand at runtime.  This method is used to validate an entire Java
+     * content tree.  Global constraint checking <b>will</b> be performed as
+     * part of this operation (i.e. ID/IDREF constraints).
+     *
+     * @param rootObj the root obj to begin validation at
+     * @throws JAXBException if any unexpected problem occurs during validation
+     * @throws ValidationException
+     *     If the {@link ValidationEventHandler ValidationEventHandler}
+     *     returns false from its <tt>handleEvent</tt> method or the
+     *     <tt>Validator</tt> is unable to validate the content tree rooted
+     *     at <tt>rootObj</tt>
+     * @throws IllegalArgumentException
+     *      If the rootObj parameter is null
+     * @return true if the tree rooted at <tt>rootObj</tt> is valid, false
+     *         otherwise
+     * @deprecated since JAXB2.0
+     */
+    public boolean validateRoot( Object rootObj ) throws JAXBException;
+
+    /**
+     * Set the particular property in the underlying implementation of
+     * <tt>Validator</tt>.  This method can only be used to set one of
+     * the standard JAXB defined properties above or a provider specific
+     * property.  Attempting to set an undefined property will result in
+     * a PropertyException being thrown.  See <a href="#supportedProps">
+     * Supported Properties</a>.
+     *
+     * @param name the name of the property to be set. This value can either
+     *              be specified using one of the constant fields or a user
+     *              supplied string.
+     * @param value the value of the property to be set
+     *
+     * @throws PropertyException when there is an error processing the given
+     *                            property or value
+     * @throws IllegalArgumentException
+     *      If the name parameter is null
+     * @deprecated since JAXB2.0
+     */
+    public void setProperty( String name, Object value )
+        throws PropertyException;
+
+    /**
+     * Get the particular property in the underlying implementation of
+     * <tt>Validator</tt>.  This method can only be used to get one of
+     * the standard JAXB defined properties above or a provider specific
+     * property.  Attempting to get an undefined property will result in
+     * a PropertyException being thrown.  See <a href="#supportedProps">
+     * Supported Properties</a>.
+     *
+     * @param name the name of the property to retrieve
+     * @return the value of the requested property
+     *
+     * @throws PropertyException
+     *      when there is an error retrieving the given property or value
+     *      property name
+     * @throws IllegalArgumentException
+     *      If the name parameter is null
+     * @deprecated since JAXB2.0
+     */
+    public Object getProperty( String name ) throws PropertyException;
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/DomHandler.java b/jaxws/src/share/classes/javax/xml/bind/annotation/DomHandler.java
new file mode 100644
index 0000000..f02f2f3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/DomHandler.java
@@ -0,0 +1,119 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.transform.Result;
+import javax.xml.transform.Source;
+
+/**
+ * Converts an element (and its descendants)
+ * from/to DOM (or similar) representation.
+ *
+ * <p>
+ * Implementations of this interface will be used in conjunction with
+ * {@link XmlAnyElement} annotation to map an element of XML into a representation
+ * of infoset such as W3C DOM.
+ *
+ * <p>
+ * Implementations hide how a portion of XML is converted into/from such
+ * DOM-like representation, allowing JAXB providers to work with arbitrary
+ * such library.
+ *
+ * <P>
+ * This interface is intended to be implemented by library writers
+ * and consumed by JAXB providers. None of those methods are intended to
+ * be called from applications.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB2.0
+ */
+public interface DomHandler<ElementT,ResultT extends Result> {
+    /**
+     * When a JAXB provider needs to unmarshal a part of a document into an
+     * infoset representation, it first calls this method to create a
+     * {@link Result} object.
+     *
+     * <p>
+     * A JAXB provider will then send a portion of the XML
+     * into the given result. Such a portion always form a subtree
+     * of the whole XML document rooted at an element.
+     *
+     * @param errorHandler
+     *      if any error happens between the invocation of this method
+     *      and the invocation of {@link #getElement(Result)}, they
+     *      must be reported to this handler.
+     *
+     *      The caller must provide a non-null error handler.
+     *
+     *      The {@link Result} object created from this method
+     *      may hold a reference to this error handler.
+     *
+     * @return
+     *      null if the operation fails. The error must have been reported
+     *      to the error handler.
+     */
+    ResultT createUnmarshaller( ValidationEventHandler errorHandler );
+
+    /**
+     * Once the portion is sent to the {@link Result}. This method is called
+     * by a JAXB provider to obtain the unmarshalled element representation.
+     *
+     * <p>
+     * Multiple invocations of this method may return different objects.
+     * This method can be invoked only when the whole sub-tree are fed
+     * to the {@link Result} object.
+     *
+     * @param rt
+     *      The {@link Result} object created by {@link #createUnmarshaller(ValidationEventHandler)}.
+     *
+     * @return
+     *      null if the operation fails. The error must have been reported
+     *      to the error handler.
+     */
+    ElementT getElement(ResultT rt);
+
+    /**
+     * This method is called when a JAXB provider needs to marshal an element
+     * to XML.
+     *
+     * <p>
+     * If non-null, the returned {@link Source} must contain a whole document
+     * rooted at one element, which will then be weaved into a bigger document
+     * that the JAXB provider is marshalling.
+     *
+     * @param errorHandler
+     *      Receives any errors happened during the process of converting
+     *      an element into a {@link Source}.
+     *
+     *      The caller must provide a non-null error handler.
+     *
+     * @return
+     *      null if there was an error. The error should have been reported
+     *      to the handler.
+     */
+    Source marshal( ElementT n, ValidationEventHandler errorHandler );
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/W3CDomHandler.java b/jaxws/src/share/classes/javax/xml/bind/annotation/W3CDomHandler.java
new file mode 100644
index 0000000..2d64ba0
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/W3CDomHandler.java
@@ -0,0 +1,109 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.DocumentFragment;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.transform.Source;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.dom.DOMSource;
+
+/**
+ * {@link DomHandler} implementation for W3C DOM (<code>org.w3c.dom</code> package.)
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB2.0
+ */
+public class W3CDomHandler implements DomHandler<Element,DOMResult> {
+
+    private DocumentBuilder builder;
+
+    /**
+     * Default constructor.
+     *
+     * It is up to a JAXB provider to decide which DOM implementation
+     * to use or how that is configured.
+     */
+    public W3CDomHandler() {
+        this.builder = null;
+    }
+
+    /**
+     * Constructor that allows applications to specify which DOM implementation
+     * to be used.
+     *
+     * @param builder
+     *      must not be null. JAXB uses this {@link DocumentBuilder} to create
+     *      a new element.
+     */
+    public W3CDomHandler(DocumentBuilder builder) {
+        if(builder==null)
+            throw new IllegalArgumentException();
+        this.builder = builder;
+    }
+
+    public DocumentBuilder getBuilder() {
+        return builder;
+    }
+
+    public void setBuilder(DocumentBuilder builder) {
+        this.builder = builder;
+    }
+
+    public DOMResult createUnmarshaller(ValidationEventHandler errorHandler) {
+        if(builder==null)
+            return new DOMResult();
+        else
+            return new DOMResult(builder.newDocument());
+    }
+
+    public Element getElement(DOMResult r) {
+        // JAXP spec is ambiguous about what really happens in this case,
+        // so work defensively
+        Node n = r.getNode();
+        if( n instanceof Document ) {
+            return ((Document)n).getDocumentElement();
+        }
+        if( n instanceof Element )
+            return (Element)n;
+        if( n instanceof DocumentFragment )
+            return (Element)n.getChildNodes().item(0);
+
+        // if the result object contains something strange,
+        // it is not a user problem, but it is a JAXB provider's problem.
+        // That's why we throw a runtime exception.
+        throw new IllegalStateException(n.toString());
+    }
+
+    public Source marshal(Element element, ValidationEventHandler errorHandler) {
+        return new DOMSource(element);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessOrder.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessOrder.java
new file mode 100644
index 0000000..88eea61
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessOrder.java
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+/**
+ * Used by XmlAccessorOrder to control the ordering of properties and
+ * fields in a JAXB bound class.
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ * @see XmlAccessorOrder
+ */
+
+public enum XmlAccessOrder {
+    /**
+     * The ordering of fields and properties in a class is undefined.
+     */
+    UNDEFINED,
+    /**
+     * The ordering of fields and properties in a class is in
+     * alphabetical order as determined by the
+     * method java.lang.String.compareTo(String anotherString).
+     */
+    ALPHABETICAL
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessType.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessType.java
new file mode 100644
index 0000000..d88cccf
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessType.java
@@ -0,0 +1,70 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+
+
+/**
+ * Used by XmlAccessorType to control serialization of fields or
+ * properties.
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ * @see XmlAccessorType
+ */
+
+public enum XmlAccessType {
+    /**
+     * Every getter/setter pair in a JAXB-bound class will be automatically
+     * bound to XML, unless annotated by {@link XmlTransient}.
+     *
+     * Fields are bound to XML only when they are explicitly annotated
+     * by some of the JAXB annotations.
+     */
+    PROPERTY,
+    /**
+     * Every non static, non transient field in a JAXB-bound class will be automatically
+     * bound to XML, unless annotated by {@link XmlTransient}.
+     *
+     * Getter/setter pairs are bound to XML only when they are explicitly annotated
+     * by some of the JAXB annotations.
+     */
+    FIELD,
+    /**
+     * Every public getter/setter pair and every public field will be
+     * automatically bound to XML, unless annotated by {@link XmlTransient}.
+     *
+     * Fields or getter/setter pairs that are private, protected, or
+     * defaulted to package-only access are bound to XML only when they are
+     * explicitly annotated by the appropriate JAXB annotations.
+     */
+    PUBLIC_MEMBER,
+    /**
+     * None of the fields or properties is bound to XML unless they
+     * are specifically  annotated with some of the JAXB annotations.
+     */
+    NONE
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessorOrder.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessorOrder.java
new file mode 100644
index 0000000..aa67d3b
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessorOrder.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Inherited;
+
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * <p> Controls the ordering of fields and properties in a class. </p>
+ *
+ * <p> <b> Usage </b> </p>
+ *
+ * <p> <tt> @XmlAccessorOrder </tt> annotation can be used with the following
+ * program elements:</p>
+ *
+ * <ul>
+ *   <li> package</li>
+ *   <li> a top level class </li>
+ * </ul>
+ *
+ * <p> See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p>The annotation <tt> @XmlAccessorOrder </tt> on a package applies to
+ * all classes in a package. The following inheritance semantics apply:
+ *
+ * <ul>
+ *   <li> If there is a <tt>@XmlAccessorOrder</tt> on a class, then
+ *        it is used. </li>
+ *   <li> Otherwise, if a <tt>@XmlAccessorOrder </tt> exists on one of
+ *        its super classes, then it is inherited.
+ *   <li> Otherwise, the <tt>@XmlAccessorOrder </tt> on a package is
+ *        inherited.
+ * </ul>
+ * <p> <b> Defaulting Rules: </b> </p>
+ *
+ * <p>By default, if <tt>@XmlAccessorOrder </tt> on a package is absent,
+ * then the following package level annotation is assumed.</p>
+ *<pre>
+ *    &#64;XmlAccessorType(XmlAccessOrder.UNDEFINED)
+ *</pre>
+ * <p> By default, if <tt>@XmlAccessorOrder</tt> on a class is absent
+ * and none of super classes is annotated with <tt> XmlAccessorOrder
+ * </tt>, then the following default on the class is assumed: </p>
+ *<pre>
+ *    &#64;XmlAccessorType(XmlAccessOrder.UNDEFINED)
+ *</pre>
+ * <p>This annotation can be used with the following annotations:
+ *    {@link XmlType}, {@link XmlRootElement}, {@link XmlAccessorType},
+ *    {@link XmlSchema}, {@link XmlSchemaType}, {@link XmlSchemaTypes},
+ *    , {@link XmlJavaTypeAdapter}. It can also be used with the
+ *    following annotations at the package level: {@link XmlJavaTypeAdapter}.
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ * @see XmlAccessOrder
+ */
+
+@Inherited @Retention(RUNTIME) @Target({PACKAGE, TYPE})
+public @interface XmlAccessorOrder {
+        XmlAccessOrder value() default XmlAccessOrder.UNDEFINED;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessorType.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessorType.java
new file mode 100644
index 0000000..a14d2c8
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAccessorType.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Inherited;
+
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * <p> Controls whether fields or Javabean properties are serialized by default. </p>
+ *
+ * <p> <b> Usage </b> </p>
+ *
+ * <p> <tt>@XmlAccessorType</tt> annotation can be used with the following program elements:</p>
+ *
+ * <ul>
+ *   <li> package</li>
+ *   <li> a top level class </li>
+ * </ul>
+ *
+ * <p> See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p>This annotation provides control over the default serialization
+ * of properties and fields in a class.
+ *
+ * <p>The annotation <tt> @XmlAccessorType </tt> on a package applies to
+ * all classes in the package. The following inheritance
+ * semantics apply:
+ *
+ * <ul>
+ *   <li> If there is a <tt>@XmlAccessorType</tt> on a class, then it
+ *        is used. </li>
+ *   <li> Otherwise, if a <tt>@XmlAccessorType</tt> exists on one of
+ *        its super classes, then it is inherited.
+ *   <li> Otherwise, the <tt>@XmlAccessorType </tt> on a package is
+ *        inherited.
+ * </ul>
+ * <p> <b> Defaulting Rules: </b> </p>
+ *
+ * <p>By default, if <tt>@XmlAccessorType </tt> on a package is absent,
+ * then the following package level annotation is assumed.</p>
+ * <pre>
+ *   &#64;XmlAccessorType(XmlAccessType.PUBLIC_MEMBER)
+ * </pre>
+ * <p> By default, if <tt>@XmlAccessorType</tt> on a class is absent,
+ * and none of its super classes is annotated with
+ * <tt>@XmlAccessorType</tt>, then the following default on the class
+ * is assumed: </p>
+ * <pre>
+ *   &#64;XmlAccessorType(XmlAccessType.PUBLIC_MEMBER)
+ * </pre>
+ * <p>This annotation can be used with the following annotations:
+ *    {@link XmlType}, {@link XmlRootElement}, {@link XmlAccessorOrder},
+ *    {@link XmlSchema}, {@link XmlSchemaType}, {@link XmlSchemaTypes},
+ *    , {@link XmlJavaTypeAdapter}. It can also be used with the
+ *    following annotations at the package level: {@link XmlJavaTypeAdapter}.
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ * @see XmlAccessType
+ */
+
+@Inherited @Retention(RUNTIME) @Target({PACKAGE, TYPE})
+public @interface XmlAccessorType {
+
+    /**
+     * Specifies whether fields or properties are serialized.
+     *
+     * @see XmlAccessType
+     */
+    XmlAccessType value() default XmlAccessType.PUBLIC_MEMBER;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAnyAttribute.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAnyAttribute.java
new file mode 100644
index 0000000..7244e0d
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAnyAttribute.java
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.namespace.QName;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+import java.util.Map;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+
+/**
+ * <p>
+ * Maps a JavaBean property to a map of wildcard attributes.
+ *
+ * <p> <b>Usage</b> </p>
+ * <p>
+ * The <tt>&#64;XmlAnyAttribute</tt> annotation can be used with the
+ * following program elements:
+ * <ul>
+ *   <li> JavaBean property </li>
+ *   <li> non static, non transient field </li>
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * The usage is subject to the following constraints:
+ * <ul>
+ *   <li> At most one field or property in a class can be annotated
+ *        with <tt>&#64;XmlAnyAttribute</tt>.  </li>
+ *   <li> The type of the property or the field must <tt>java.util.Map</tt> </li>
+ * </ul>
+ *
+ * <p>
+ * While processing attributes to be unmarshalled into a value class,
+ * each attribute that is not statically associated with another
+ * JavaBean property, via {@link XmlAttribute}, is entered into the
+ * wildcard attribute map represented by
+ * {@link Map}&lt;{@link QName},{@link Object}>. The attribute QName is the
+ * map's key. The key's value is the String value of the attribute.
+ *
+ * @author Kohsuke Kawaguchi, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD})
+public @interface XmlAnyAttribute {
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAnyElement.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAnyElement.java
new file mode 100644
index 0000000..a9cbf8e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAnyElement.java
@@ -0,0 +1,290 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import org.w3c.dom.Element;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import javax.xml.bind.annotation.*;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+import java.util.List;
+
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+
+/**
+ * Maps a JavaBean property to XML infoset representation and/or JAXB element.
+ *
+ * <p>
+ * This annotation serves as a "catch-all" property while unmarshalling
+ * xml content into a instance of a JAXB annotated class. It typically
+ * annotates a multi-valued JavaBean property, but it can occur on
+ * single value JavaBean property. During unmarshalling, each xml element
+ * that does not match a static &#64;XmlElement or &#64;XmlElementRef
+ * annotation for the other JavaBean properties on the class, is added to this
+ * "catch-all" property.
+ *
+ * <p>
+ * <h2>Usages:</h2>
+ * <pre>
+ * &#64;XmlAnyElement
+ * public {@link Element}[] others;
+ *
+ * // Collection of {@link Element} or JAXB elements.
+ * &#64;XmlAnyElement(lax="true")
+ * public {@link Object}[] others;
+ *
+ * &#64;XmlAnyElement
+ * private List&lt;{@link Element}> nodes;
+ *
+ * &#64;XmlAnyElement
+ * private {@link Element} node;
+ * </pre>
+ *
+ * <h2>Restriction usage constraints</h2>
+ * <p>
+ * This annotation is mutually exclusive with
+ * {@link XmlElement}, {@link XmlAttribute}, {@link XmlValue},
+ * {@link XmlElements}, {@link XmlID}, and {@link XmlIDREF}.
+ *
+ * <p>
+ * There can be only one {@link XmlAnyElement} annotated JavaBean property
+ * in a class and its super classes.
+ *
+ * <h2>Relationship to other annotations</h2>
+ * <p>
+ * This annotation can be used with {@link XmlJavaTypeAdapter}, so that users
+ * can map their own data structure to DOM, which in turn can be composed
+ * into XML.
+ *
+ * <p>
+ * This annotation can be used with {@link XmlMixed} like this:
+ * <pre>
+ * // List of java.lang.String or DOM nodes.
+ * &#64;XmlAnyElement &#64;XmlMixed
+ * List&lt;Object> others;
+ * </pre>
+ *
+ *
+ * <h2>Schema To Java example</h2>
+ *
+ * The following schema would produce the following Java class:
+ * <pre><xmp>
+ * <xs:complexType name="foo">
+ *   <xs:sequence>
+ *     <xs:element name="a" type="xs:int" />
+ *     <xs:element name="b" type="xs:int" />
+ *     <xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
+ *   </xs:sequence>
+ * </xs:complexType>
+ * </xmp></pre>
+ *
+ * <pre>
+ * class Foo {
+ *   int a;
+ *   int b;
+ *   &#64;{@link XmlAnyElement}
+ *   List&lt;Element> any;
+ * }
+ * </pre>
+ *
+ * It can unmarshal instances like
+ *
+ * <pre><xmp>
+ * <foo xmlns:e="extra">
+ *   <a>1</a>
+ *   <e:other />  // this will be bound to DOM, because unmarshalling is orderless
+ *   <b>3</b>
+ *   <e:other />
+ *   <c>5</c>     // this will be bound to DOM, because the annotation doesn't remember namespaces.
+ * </foo>
+ * </xmp></pre>
+ *
+ *
+ *
+ * The following schema would produce the following Java class:
+ * <pre><xmp>
+ * <xs:complexType name="bar">
+ *   <xs:complexContent>
+ *   <xs:extension base="foo">
+ *     <xs:sequence>
+ *       <xs:element name="c" type="xs:int" />
+ *       <xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
+ *     </xs:sequence>
+ *   </xs:extension>
+ * </xs:complexType>
+ * </xmp></pre>
+ *
+ * <pre><xmp>
+ * class Bar extends Foo {
+ *   int c;
+ *   // Foo.getAny() also represents wildcard content for type definition bar.
+ * }
+ * </xmp></pre>
+ *
+ *
+ * It can unmarshal instances like
+ *
+ * <pre><xmp>
+ * <bar xmlns:e="extra">
+ *   <a>1</a>
+ *   <e:other />  // this will be bound to DOM, because unmarshalling is orderless
+ *   <b>3</b>
+ *   <e:other />
+ *   <c>5</c>     // this now goes to Bar.c
+ *   <e:other />  // this will go to Foo.any
+ * </bar>
+ * </xmp></pre>
+ *
+ *
+ *
+ *
+ * <h2>Using {@link XmlAnyElement} with {@link XmlElementRef}</h2>
+ * <p>
+ * The {@link XmlAnyElement} annotation can be used with {@link XmlElementRef}s to
+ * designate additional elements that can participate in the content tree.
+ *
+ * <p>
+ * The following schema would produce the following Java class:
+ * <pre><xmp>
+ * <xs:complexType name="foo">
+ *   <xs:choice maxOccurs="unbounded" minOccurs="0">
+ *     <xs:element name="a" type="xs:int" />
+ *     <xs:element name="b" type="xs:int" />
+ *     <xs:any namespace="##other" processContents="lax" />
+ *   </xs:choice>
+ * </xs:complexType>
+ * </xmp></pre>
+ *
+ * <pre>
+ * class Foo {
+ *   &#64;{@link XmlAnyElement}(lax="true")
+ *   &#64;{@link XmlElementRefs}({
+ *     &#64;{@link XmlElementRef}(name="a", type="JAXBElement.class")
+ *     &#64;{@link XmlElementRef}(name="b", type="JAXBElement.class")
+ *   })
+ *   {@link List}&lt;{@link Object}> others;
+ * }
+ *
+ * &#64;XmlRegistry
+ * class ObjectFactory {
+ *   ...
+ *   &#64;XmlElementDecl(name = "a", namespace = "", scope = Foo.class)
+ *   {@link JAXBElement}&lt;Integer> createFooA( Integer i ) { ... }
+ *
+ *   &#64;XmlElementDecl(name = "b", namespace = "", scope = Foo.class)
+ *   {@link JAXBElement}&lt;Integer> createFooB( Integer i ) { ... }
+ * </pre>
+ *
+ * It can unmarshal instances like
+ *
+ * <pre><xmp>
+ * <foo xmlns:e="extra">
+ *   <a>1</a>     // this will unmarshal to a {@link JAXBElement} instance whose value is 1.
+ *   <e:other />  // this will unmarshal to a DOM {@link Element}.
+ *   <b>3</b>     // this will unmarshal to a {@link JAXBElement} instance whose value is 1.
+ * </foo>
+ * </xmp></pre>
+ *
+ *
+ *
+ *
+ * <h2>W3C XML Schema "lax" wildcard emulation</h2>
+ * The lax element of the annotation enables the emulation of the "lax" wildcard semantics.
+ * For example, when the Java source code is annotated like this:
+ * <pre>
+ * &#64;{@link XmlRootElement}
+ * class Foo {
+ *   &#64;XmlAnyElement(lax=true)
+ *   public {@link Object}[] others;
+ * }
+ * </pre>
+ * then the following document will unmarshal like this:
+ * <pre><xmp>
+ * <foo>
+ *   <unknown />
+ *   <foo />
+ * </foo>
+ *
+ * Foo foo = unmarshal();
+ * // 1 for 'unknown', another for 'foo'
+ * assert foo.others.length==2;
+ * // 'unknown' unmarshals to a DOM element
+ * assert foo.others[0] instanceof Element;
+ * // because of lax=true, the 'foo' element eagerly
+ * // unmarshals to a Foo object.
+ * assert foo.others[1] instanceof Foo;
+ * </xmp></pre>
+ *
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD})
+public @interface XmlAnyElement {
+
+    /**
+     * Controls the unmarshaller behavior when it sees elements
+     * known to the current {@link JAXBContext}.
+     *
+     * <h3>When false</h3>
+     * <p>
+     * If false, all the elements that match the property will be unmarshalled
+     * to DOM, and the property will only contain DOM elements.
+     *
+     * <h3>When true</h3>
+     * <p>
+     * If true, when an element matches a property marked with {@link XmlAnyElement}
+     * is known to {@link JAXBContext} (for example, there's a class with
+     * {@link XmlRootElement} that has the same tag name, or there's
+     * {@link XmlElementDecl} that has the same tag name),
+     * the unmarshaller will eagerly unmarshal this element to the JAXB object,
+     * instead of unmarshalling it to DOM. Additionally, if the element is
+     * unknown but it has a known xsi:type, the unmarshaller eagerly unmarshals
+     * the element to a {@link JAXBElement}, with the unknown element name and
+     * the JAXBElement value is set to an instance of the JAXB mapping of the
+     * known xsi:type.
+     *
+     * <p>
+     * As a result, after the unmarshalling, the property can become heterogeneous;
+     * it can have both DOM nodes and some JAXB objects at the same time.
+     *
+     * <p>
+     * This can be used to emulate the "lax" wildcard semantics of the W3C XML Schema.
+     */
+    boolean lax() default false;
+
+    /**
+     * Specifies the {@link DomHandler} which is responsible for actually
+     * converting XML from/to a DOM-like data structure.
+     */
+    Class<? extends DomHandler> value() default W3CDomHandler.class;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAttachmentRef.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAttachmentRef.java
new file mode 100644
index 0000000..bbbd67a
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAttachmentRef.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package javax.xml.bind.annotation;
+
+import javax.activation.DataHandler;
+import static java.lang.annotation.ElementType.*;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import java.lang.annotation.Target;
+
+/**
+ * Marks a field/property that its XML form is a uri reference to mime content.
+ * The mime content is optimally stored out-of-line as an attachment.
+ *
+ * A field/property must always map to the {@link DataHandler} class.
+ *
+ * <h2>Usage</h2>
+ * <pre>
+ * &#64;{@link XmlRootElement}
+ * class Foo {
+ *   &#64;{@link XmlAttachmentRef}
+ *   &#64;{@link XmlAttribute}
+ *   {@link DataHandler} data;
+ *
+ *   &#64;{@link XmlAttachmentRef}
+ *   &#64;{@link XmlElement}
+ *   {@link DataHandler} body;
+ * }
+ * </pre>
+ * The above code maps to the following XML:
+ * <pre><xmp>
+ * <xs:element name="foo" xmlns:ref="http://ws-i.org/profiles/basic/1.1/xsd">
+ *   <xs:complexType>
+ *     <xs:sequence>
+ *       <xs:element name="body" type="ref:swaRef" minOccurs="0" />
+ *     </xs:sequence>
+ *     <xs:attribute name="data" type="ref:swaRef" use="optional" />
+ *   </xs:complexType>
+ * </xs:element>
+ * </xmp></pre>
+ *
+ * <p>
+ * The above binding supports WS-I AP 1.0 <a href="http://www.ws-i.org/Profiles/AttachmentsProfile-1.0-2004-08-24.html#Referencing_Attachments_from_the_SOAP_Envelope">WS-I Attachments Profile Version 1.0.</a>
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD,PARAMETER})
+public @interface XmlAttachmentRef {
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAttribute.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAttribute.java
new file mode 100644
index 0000000..2a03c11
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlAttribute.java
@@ -0,0 +1,152 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * <p>
+ * Maps a JavaBean property to a XML attribute.
+ *
+ * <p> <b>Usage</b> </p>
+ * <p>
+ * The <tt>@XmlAttribute</tt> annotation can be used with the
+ * following program elements:
+ * <ul>
+ *   <li> JavaBean property </li>
+ *   <li> field </li>
+ * </ul>
+ *
+ * <p> A static final field is mapped to a XML fixed attribute.
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * The usage is subject to the following constraints:
+ * <ul>
+ *   <li> If type of the field or the property is a collection
+ *        type, then the collection item type must be mapped to schema
+ *        simple type.
+ * <pre>
+ *     // Examples
+ *     &#64;XmlAttribute List&lt;Integer> items; //legal
+ *     &#64;XmlAttribute List&lt;Bar> foo; // illegal if Bar does not map to a schema simple type
+ * </pre>
+ *   </li>
+ *   <li> If the type of the field or the property is a non
+ *         collection type, then the type of the property or field
+ *         must map to a simple schema type.
+ * <pre>
+ *     // Examples
+ *     &#64;XmlAttribute int foo; // legal
+ *     &#64;XmlAttribute Foo foo; // illegal if Foo does not map to a schema simple type
+ * </pre>
+ *   </li>
+ *   <li> This annotation can be used with the following annotations:
+ *            {@link XmlID},
+ *            {@link XmlIDREF},
+ *            {@link XmlList},
+ *            {@link XmlSchemaType},
+ *            {@link XmlValue},
+ *            {@link XmlAttachmentRef},
+ *            {@link XmlMimeType},
+ *            {@link XmlInlineBinaryData},
+ *            {@link javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter}</li>.
+ * </ul>
+ * </p>
+ *
+ * <p> <b>Example 1: </b>Map a JavaBean property to an XML attribute.</p>
+ * <pre>
+ *     //Example: Code fragment
+ *     public class USPrice {
+ *         &#64;XmlAttribute
+ *         public java.math.BigDecimal getPrice() {...} ;
+ *         public void setPrice(java.math.BigDecimal ) {...};
+ *     }
+ *
+ *     &lt;!-- Example: XML Schema fragment -->
+ *     &lt;xs:complexType name="USPrice">
+ *       &lt;xs:sequence>
+ *       &lt;/xs:sequence>
+ *       &lt;xs:attribute name="price" type="xs:decimal"/>
+ *     &lt;/xs:complexType>
+ * </pre>
+ *
+ * <p> <b>Example 2: </b>Map a JavaBean property to an XML attribute with anonymous type.</p>
+ * See Example 7 in @{@link XmlType}.
+ *
+ * <p> <b>Example 3: </b>Map a JavaBean collection property to an XML attribute.</p>
+ * <pre>
+ *     // Example: Code fragment
+ *     class Foo {
+ *         ...
+ *         &#64;XmlAttribute List&lt;Integer> items;
+ *     }
+ *
+ *     &lt;!-- Example: XML Schema fragment -->
+ *     &lt;xs:complexType name="foo">
+ *       ...
+ *       &lt;xs:attribute name="items">
+ *         &lt;xs:simpleType>
+ *           &lt;xs:list itemType="xs:int"/>
+ *         &lt;/xs:simpleType>
+ *     &lt;/xs:complexType>
+ *
+ * </pre>
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @see XmlType
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({FIELD, METHOD})
+public @interface XmlAttribute {
+    /**
+     * Name of the XML Schema attribute. By default, the XML Schema
+     * attribute name is derived from the JavaBean property name.
+     *
+     */
+    String name() default "##default";
+
+    /**
+     * Specifies if the XML Schema attribute is optional or
+     * required. If true, then the JavaBean property is mapped to a
+     * XML Schema attribute that is required. Otherwise it is mapped
+     * to a XML Schema attribute that is optional.
+     *
+     */
+     boolean required() default false;
+
+    /**
+     * Specifies the XML target namespace of the XML Schema
+     * attribute.
+     *
+     */
+    String namespace() default "##default" ;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElement.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElement.java
new file mode 100644
index 0000000..61e2f6b
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElement.java
@@ -0,0 +1,209 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * Maps a JavaBean property to a XML element derived from property name.
+ *
+ * <p> <b>Usage</b> </p>
+ * <p>
+ * <tt>@XmlElement</tt> annotation can be used with the following program
+ * elements:
+ * <ul>
+ *   <li> a JavaBean property </li>
+ *   <li> non static, non transient field </li>
+ *   <li> within {@link XmlElements}
+ * <p>
+ *
+ * </ul>
+ *
+ * The usage is subject to the following constraints:
+ * <ul>
+ *   <li> This annotation can be used with following annotations:
+ *            {@link XmlID},
+ *            {@link XmlIDREF},
+ *            {@link XmlList},
+ *            {@link XmlSchemaType},
+ *            {@link XmlValue},
+ *            {@link XmlAttachmentRef},
+ *            {@link XmlMimeType},
+ *            {@link XmlInlineBinaryData},
+ *            {@link XmlElementWrapper},
+ *            {@link XmlJavaTypeAdapter}</li>
+ *   <li> if the type of JavaBean property is a collection type of
+ *        array, an indexed property, or a parameterized list, and
+ *        this annotation is used with {@link XmlElements} then,
+ *        <tt>@XmlElement.type()</tt> must be DEFAULT.class since the
+ *        collection item type is already known. </li>
+ * </ul>
+ *
+ * <p>
+ * A JavaBean property, when annotated with @XmlElement annotation
+ * is mapped to a local element in the XML Schema complex type to
+ * which the containing class is mapped.
+ *
+ * <p>
+ * <b>Example 1: </b> Map a public non static non final field to local
+ * element
+ * <pre>
+ *     //Example: Code fragment
+ *     public class USPrice {
+ *         &#64;XmlElement(name="itemprice")
+ *         public java.math.BigDecimal price;
+ *     }
+ *
+ *     &lt;!-- Example: Local XML Schema element -->
+ *     &lt;xs:complexType name="USPrice"/>
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="itemprice" type="xs:decimal" minOccurs="0"/>
+ *       &lt;/sequence>
+ *     &lt;/xs:complexType>
+ *   </pre>
+ * <p>
+ *
+ * <b> Example 2: </b> Map a field to a nillable element.
+ *   <pre>
+ *
+ *     //Example: Code fragment
+ *     public class USPrice {
+ *         &#64;XmlElement(nillable=true)
+ *         public java.math.BigDecimal price;
+ *     }
+ *
+ *     &lt;!-- Example: Local XML Schema element -->
+ *     &lt;xs:complexType name="USPrice">
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="price" type="xs:decimal" nillable="true" minOccurs="0"/>
+ *       &lt;/sequence>
+ *     &lt;/xs:complexType>
+ *   </pre>
+ * <p>
+ * <b> Example 3: </b> Map a field to a nillable, required element.
+ *   <pre>
+ *
+ *     //Example: Code fragment
+ *     public class USPrice {
+ *         &#64;XmlElement(nillable=true, required=true)
+ *         public java.math.BigDecimal price;
+ *     }
+ *
+ *     &lt;!-- Example: Local XML Schema element -->
+ *     &lt;xs:complexType name="USPrice">
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="price" type="xs:decimal" nillable="true" minOccurs="1"/>
+ *       &lt;/sequence>
+ *     &lt;/xs:complexType>
+ *   </pre>
+ * <p>
+ *
+ * <p> <b>Example 4: </b>Map a JavaBean property to an XML element
+ * with anonymous type.</p>
+ * <p>
+ * See Example 6 in @{@link XmlType}.
+ *
+ * <p>
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({FIELD, METHOD})
+public @interface XmlElement {
+    /**
+     * Name of the XML Schema element.
+     * <p> If the value is "##default", then element name is derived from the
+     * JavaBean property name.
+     */
+    String name() default "##default";
+
+    /**
+     * Customize the element declaration to be nillable.
+     * <p>If nillable() is true, then the JavaBean property is
+     * mapped to a XML Schema nillable element declaration.
+     */
+    boolean nillable() default false;
+
+    /**
+     * Customize the element declaration to be required.
+     * <p>If required() is true, then Javabean property is mapped to
+     * an XML schema element declaration with minOccurs="1".
+     * maxOccurs is "1" for a single valued property and "unbounded"
+     * for a multivalued property.
+     * <p>If required() is false, then the Javabean property is mapped
+     * to XML Schema element declaration with minOccurs="0".
+     * maxOccurs is "1" for a single valued property and "unbounded"
+     * for a multivalued property.
+     */
+
+    boolean required() default false;
+
+    /**
+     * XML target namespace of the XML Schema element.
+     * <p>
+     * If the value is "##default", then the namespace is determined
+     * as follows:
+     * <ol>
+     *  <li>
+     *  If the enclosing package has {@link XmlSchema} annotation,
+     *  and its {@link XmlSchema#elementFormDefault() elementFormDefault}
+     *  is {@link XmlNsForm#QUALIFIED QUALIFIED}, then the namespace of
+     *  the enclosing class.
+     *
+     *  <li>
+     *  Otherwise "" (which produces unqualified element in the default
+     *  namespace.
+     * </ol>
+     */
+    String namespace() default "##default";
+
+    /**
+     * Default value of this element.
+     *
+     * <p>
+     * The '\u0000' value specified as a default of this annotation element
+     * is used as a poor-man's substitute for null to allow implementations
+     * to recognize the 'no default value' state.
+     */
+    String defaultValue() default "\u0000";
+
+    /**
+     * The Java class being referenced.
+     */
+    Class type() default DEFAULT.class;
+
+    /**
+     * Used in {@link XmlElement#type()} to
+     * signal that the type be inferred from the signature
+     * of the property.
+     */
+    static final class DEFAULT {}
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementDecl.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementDecl.java
new file mode 100644
index 0000000..60ef78e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementDecl.java
@@ -0,0 +1,216 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.METHOD;
+
+/**
+ * Maps a factory method to a XML element.
+ *
+ * <p> <b>Usage</b> </p>
+ *
+ * The annotation creates a mapping between an XML schema element
+ * declaration and a <i> element factory method </i> that returns a
+ * JAXBElement instance representing the element
+ * declaration. Typically, the element factory method is generated
+ * (and annotated) from a schema into the ObjectFactory class in a
+ * Java package that represents the binding of the element
+ * declaration's target namespace. Thus, while the annotation syntax
+ * allows &#64;XmlElementDecl to be used on any method, semantically
+ * its use is restricted to annotation of element factory method.
+ *
+ * The usage is subject to the following constraints:
+ *
+ * <ul>
+ *   <li> The class containing the element factory method annotated
+ *        with &#64;XmlElementDecl must be marked with {@link
+ *        XmlRegistry}. </li>
+ *   <li> The element factory method must take one parameter
+ *        assignable to {@link Object}.</li>
+ * </ul>
+ *
+ * <p><b>Example 1: </b>Annotation on a factory method
+ * <pre>
+ *     // Example: code fragment
+ *     &#64;XmlRegistry
+ *     class ObjectFactory {
+ *         &#64;XmlElementDecl(name="foo")
+ *         JAXBElement&lt;String> createFoo(String s) { ... }
+ *     }
+ * </pre>
+ * <pre><xmp>
+ *     <!-- XML input -->
+ *       <foo>string</foo>
+ *
+ *     // Example: code fragment corresponding to XML input
+ *     JAXBElement<String> o =
+ *     (JAXBElement<String>)unmarshaller.unmarshal(aboveDocument);
+ *     // print JAXBElement instance to show values
+ *     System.out.println(o.getName());   // prints  "{}foo"
+ *     System.out.println(o.getValue());  // prints  "string"
+ *     System.out.println(o.getValue().getClass()); // prints "java.lang.String"
+ *
+ *     <!-- Example: XML schema definition -->
+ *     <xs:element name="foo" type="xs:string"/>
+ * </xmp></pre>
+ *
+ * <p><b>Example 2: </b> Element declaration with non local scope
+ * <p>
+ * The following example illustrates the use of scope annotation
+ * parameter in binding of element declaration in schema derived
+ * code.
+ * <p>
+ * The following example may be replaced in a future revision of
+ * this javadoc.
+ *
+ * <pre><xmp>
+ *     <!-- Example: XML schema definition -->
+ *     <xs:schema>
+ *       <xs:complexType name="pea">
+ *         <xs:choice maxOccurs="unbounded">
+ *           <xs:element name="foo" type="xs:string"/>
+ *           <xs:element name="bar" type="xs:string"/>
+ *         </xs:choice>
+ *       </xs:complexType>
+ *       <xs:element name="foo" type="xs:int"/>
+ *     </xs:schema>
+ * </xmp></pre>
+ * <pre>
+ *     // Example: expected default binding
+ *     class Pea {
+ *         &#64;XmlElementRefs({
+ *             &#64;XmlElementRef(name="foo",type=JAXBElement.class)
+ *             &#64;XmlElementRef(name="bar",type=JAXBElement.class)
+ *         })
+ *         List&lt;JAXBElement&lt;String>> fooOrBar;
+ *     }
+ *
+ *     &#64;XmlRegistry
+ *     class ObjectFactory {
+ *         &#64;XmlElementDecl(scope=Pea.class,name="foo")
+ *         JAXBElement<String> createPeaFoo(String s);
+ *
+ *         &#64;XmlElementDecl(scope=Pea.class,name="bar")
+ *         JAXBElement<String> createPeaBar(String s);
+ *
+ *         &#64;XmlElementDecl(name="foo")
+ *         JAXBElement<Integer> createFoo(Integer i);
+ *     }
+ *
+ * </pre>
+ * Without scope createFoo and createPeaFoo would become ambiguous
+ * since both of them map to a XML schema element with the same local
+ * name "foo".
+ *
+ * @see XmlRegistry
+ * @since JAXB 2.0
+ */
+@Retention(RUNTIME)
+@Target({METHOD})
+public @interface XmlElementDecl {
+    /**
+     * scope of the mapping.
+     *
+     * <p>
+     * If this is not {@link XmlElementDecl.GLOBAL}, then this element
+     * declaration mapping is only active within the specified class.
+     */
+    Class scope() default GLOBAL.class;
+
+    /**
+     * namespace name of the XML element.
+     * <p>
+     * If the value is "##default", then the value is the namespace
+     * name for the package of the class containing this factory method.
+     *
+     * @see #name()
+     */
+    String namespace() default "##default";
+
+    /**
+     * local name of the XML element.
+     *
+     * <p>
+     * <b> Note to reviewers: </b> There is no default name; since
+     * the annotation is on a factory method, it is not clear that the
+     * method name can be derived from the factory method name.
+     * @see #namespace()
+     */
+    String name();
+
+    /**
+     * namespace name of a substitution group's head XML element.
+     * <p>
+     * This specifies the namespace name of the XML element whose local
+     * name is specified by <tt>substitutionHeadName()</tt>.
+     * <p>
+     * If <tt>susbtitutionHeadName()</tt> is "", then this
+     * value can only be "##default". But the value is ignored since
+     * since this element is not part of susbtitution group when the
+     * value of <tt>susbstitutionHeadName()</tt> is "".
+     * <p>
+     * If <tt>susbtitutionHeadName()</tt> is not "" and the value is
+     * "##default", then the namespace name is the namespace name to
+     * which the package of the containing class, marked with {@link
+     * XmlRegistry }, is mapped.
+     * <p>
+     * If <tt>susbtitutionHeadName()</tt> is not "" and the value is
+     * not "##default", then the value is the namespace name.
+     *
+     * @see #substitutionHeadName()
+     */
+    String substitutionHeadNamespace() default "##default";
+
+    /**
+     * XML local name of a substitution group's head element.
+     * <p>
+     * If the value is "", then this element is not part of any
+     * substitution group.
+     *
+     * @see #substitutionHeadNamespace()
+     */
+    String substitutionHeadName() default "";
+
+    /**
+     * Default value of this element.
+     *
+     * <p>
+     * The '\u0000' value specified as a default of this annotation element
+     * is used as a poor-man's substitute for null to allow implementations
+     * to recognize the 'no default value' state.
+     */
+    String defaultValue() default "\u0000";
+
+    /**
+     * Used in {@link XmlElementDecl#scope()} to
+     * signal that the declaration is in the global scope.
+     */
+    public final class GLOBAL {}
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementRef.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementRef.java
new file mode 100644
index 0000000..19a807c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementRef.java
@@ -0,0 +1,268 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+
+/**
+ * <p>
+ * Maps a JavaBean property to a XML element derived from property's type.
+ * <p>
+ * <b>Usage</b>
+ * <p>
+ * <tt>&#64;XmlElementRef</tt> annotation can be used with a
+ * JavaBean property or from within {@link XmlElementRefs}
+ * <p>
+ * This annotation dynamically associates an XML element name with the JavaBean
+ * property. When a JavaBean property is annotated with {@link
+ * XmlElement}, the XML element name is statically derived from the
+ * JavaBean property name. However, when this annotation is used, the
+ * XML element name is derived from the instance of the type of the
+ * JavaBean property at runtime.
+ *
+ * <h3> XML Schema substitution group support </h3>
+ * XML Schema allows a XML document author to use XML element names
+ * that were not statically specified in the content model of a
+ * schema using substitution groups. Schema derived code provides
+ * support for substitution groups using an <i>element property</i>,
+ * (section 5.5.5, "Element Property" of JAXB 2.0 specification). An
+ * element property method signature is of the form:
+ * <pre><xmp>
+ *     public void setTerm(JAXBElement<? extends Operator>);
+ *     public JAXBElement<? extends Operator> getTerm();
+ * </xmp></pre>
+ * <p>
+ * An element factory method annotated with  {@link XmlElementDecl} is
+ * used to create a <tt>JAXBElement</tt> instance, containing an XML
+ * element name. The presence of &#64;XmlElementRef annotation on an
+ * element property indicates that the element name from <tt>JAXBElement</tt>
+ * instance be used instead of deriving an XML element name from the
+ * JavaBean property name.
+ *
+ * <p>
+ * The usage is subject to the following constraints:
+ * <ul>
+ *   <li> If the collection item type (for collection property) or
+ *        property type (for single valued property) is
+ *        {@link javax.xml.bind.JAXBElement}, then
+ *        <tt>&#64;XmlElementRef}.name()</tt> and <tt>&#64;XmlElementRef.namespace()</tt> must
+ *        point an element factory method  with an @XmlElementDecl
+ *        annotation in a class annotated  with @XmlRegistry (usually
+ *        ObjectFactory class generated by  the schema compiler) :
+ *        <ul>
+ *            <li> @XmlElementDecl.name() must equal @XmlElementRef.name()  </li>
+ *            <li> @XmlElementDecl.namespace() must equal @XmlElementRef.namespace(). </li>
+ *        </ul>
+ *   </li>
+ *   <li> If the collection item type (for collection property) or
+ *        property type  (for single valued property) is not
+ *        {@link javax.xml.bind.JAXBElement}, then the type referenced by the
+ *        property or field must be annotated  with {@link XmlRootElement}. </li>
+ *   <li> This annotation can be used with the following annotations:
+ *        {@link XmlElementWrapper}, {@link XmlJavaTypeAdapter}.
+ *   </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p><b>Example 1: Ant Task Example</b></p>
+ * The following Java class hierarchy models an Ant build
+ * script.  An Ant task corresponds to a class in the class
+ * hierarchy. The XML element name of an Ant task is indicated by the
+ * &#64;XmlRootElement annotation on its corresponding class.
+ * <pre>
+ *     &#64;XmlRootElement(name="target")
+ *     class Target {
+ *         // The presence of &#64;XmlElementRef indicates that the XML
+ *         // element name will be derived from the &#64;XmlRootElement
+ *         // annotation on the type (for e.g. "jar" for JarTask).
+ *         &#64;XmlElementRef
+ *         List&lt;Task> tasks;
+ *     }
+ *
+ *     abstract class Task {
+ *     }
+ *
+ *     &#64;XmlRootElement(name="jar")
+ *     class JarTask extends Task {
+ *         ...
+ *     }
+ *
+ *     &#64;XmlRootElement(name="javac")
+ *     class JavacTask extends Task {
+ *         ...
+ *     }
+ *
+ *     &lt;!-- XML Schema fragment -->
+ *     &lt;xs:element name="target" type="Target">
+ *     &lt;xs:complexType name="Target">
+ *       &lt;xs:sequence>
+ *         &lt;xs:choice maxOccurs="unbounded">
+ *           &lt;xs:element ref="jar">
+ *           &lt;xs:element ref="javac">
+ *         &lt;/xs:choice>
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexType>
+ *
+ * </pre>
+ * <p>
+ * Thus the following code fragment:
+ * <pre>
+ *     Target target = new Target();
+ *     target.tasks.add(new JarTask());
+ *     target.tasks.add(new JavacTask());
+ *     marshal(target);
+ * </pre>
+ * will produce the following XML output:
+ * <pre><xmp>
+ *     <target>
+ *       <jar>
+ *         ....
+ *       </jar>
+ *       <javac>
+ *         ....
+ *       </javac>
+ *     </target>
+ * </xmp></pre>
+ * <p>
+ * It is not an error to have a class that extends <tt>Task</tt>
+ * that doesn't have {@link XmlRootElement}. But they can't show up in an
+ * XML instance (because they don't have XML element names).
+ *
+ * <p><b>Example 2: XML Schema Susbstitution group support</b>
+ * <p> The following example shows the annotations for XML Schema
+ * substitution groups.  The annotations and the ObjectFactory are
+ * derived from the schema.
+ *
+ * <pre>
+ *     &#64;XmlElement
+ *     class Math {
+ *         //  The value of {@link #type()}is
+ *         //  JAXBElement.class , which indicates the XML
+ *         //  element name ObjectFactory - in general a class marked
+ *         //  with &#64;XmlRegistry. (See ObjectFactory below)
+ *         //
+ *         //  The {@link #name()} is "operator", a pointer to a
+ *         // factory method annotated with a
+ *         //  {@link XmlElementDecl} with the name "operator". Since
+ *         //  "operator" is the head of a substitution group that
+ *         //  contains elements "add" and "sub" elements, "operator"
+ *         //  element can be substituted in an instance document by
+ *         //  elements "add" or "sub". At runtime, JAXBElement
+ *         //  instance contains the element name that has been
+ *         //  substituted in the XML document.
+ *         //
+ *         &#64;XmlElementRef(type=JAXBElement.class,name="operator")
+ *         JAXBElement&lt;? extends Operator> term;
+ *     }
+ *
+ *     &#64;XmlRegistry
+ *     class ObjectFactory {
+ *         &#64;XmlElementDecl(name="operator")
+ *         JAXBElement&lt;Operator> createOperator(Operator o) {...}
+ *         &#64;XmlElementDecl(name="add",substitutionHeadName="operator")
+ *         JAXBElement&lt;Operator> createAdd(Operator o) {...}
+ *         &#64;XmlElementDecl(name="sub",substitutionHeadName="operator")
+ *         JAXBElement&lt;Operator> createSub(Operator o) {...}
+ *     }
+ *
+ *     class Operator {
+ *         ...
+ *     }
+ * </pre>
+ * <p>
+ * Thus, the following code fragment
+ * <pre>
+ *     Math m = new Math();
+ *     m.term = new ObjectFactory().createAdd(new Operator());
+ *     marshal(m);
+ * </pre>
+ * will produce the following XML output:
+ * <pre>
+ *     &lt;math>
+ *       &lt;add>...&lt;/add>
+ *     &lt;/math>
+ * </pre>
+ *
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems,Inc. </li><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li></ul>
+ * @see XmlElementRefs
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD})
+public @interface XmlElementRef {
+    /**
+     * The Java type being referenced.
+     * <p>
+     * If the value is DEFAULT.class, the type is inferred from the
+     * the type of the JavaBean property.
+     */
+    Class type() default DEFAULT.class;
+
+    /**
+     * This parameter and {@link #name()} are used to determine the
+     * XML element for the JavaBean property.
+     *
+     * <p> If <tt>type()</tt> is <tt>JAXBElement.class</tt> , then
+     * <tt>namespace()</tt> and <tt>name()</tt>
+     * point to a factory method with {@link XmlElementDecl}. The XML
+     * element name is the element name from the factory method's
+     * {@link XmlElementDecl} annotation or if an element from its
+     * substitution group (of which it is a head element) has been
+     * substituted in the XML document, then the element name is from the
+     * {@link XmlElementDecl} on the substituted element.
+     *
+     * <p> If {@link #type()} is not <tt>JAXBElement.class</tt>, then
+     * the XML element name is the XML element name statically
+     * associated with the type using the annotation {@link
+     * XmlRootElement} on the type. If the type is not annotated with
+     * an {@link XmlElementDecl}, then it is an error.
+     *
+     * <p> If <tt>type()</tt> is not <tt>JAXBElement.class</tt>, then
+     * this value must be "".
+     *
+     */
+    String namespace() default "";
+    /**
+     *
+     * @see #namespace()
+     */
+    String name() default "##default";
+
+    /**
+     * Used in {@link XmlElementRef#type()} to
+     * signal that the type be inferred from the signature
+     * of the property.
+     */
+    static final class DEFAULT {}
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementRefs.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementRefs.java
new file mode 100644
index 0000000..ab9809f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementRefs.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+
+/**
+ * Marks a property that refers to classes with {@link XmlElement}
+ * or JAXBElement.
+ *
+ * <p>
+ * Compared to an element property (property with {@link XmlElement}
+ * annotation), a reference property has a different substitution semantics.
+ * When a sub-class is assigned to a property, an element property produces
+ * the same tag name with @xsi:type, whereas a reference property produces
+ * a different tag name (the tag name that's on the the sub-class.)
+ *
+ * <p> This annotation can be used with the following annotations:
+ * {@link XmlJavaTypeAdapter}, {@link XmlElementWrapper}.
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li></ul>
+ *
+ * @see XmlElementWrapper
+ * @see XmlElementRef
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD})
+public @interface XmlElementRefs {
+    XmlElementRef[] value();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementWrapper.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementWrapper.java
new file mode 100644
index 0000000..9163f06
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElementWrapper.java
@@ -0,0 +1,127 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+/**
+ * Generates a wrapper element around XML representation.
+ *
+ * This is primarily intended to be used to produce a wrapper
+ * XML element around collections. The annotation therefore supports
+ * two forms of serialization shown below.
+ *
+ * <pre>
+ *    //Example: code fragment
+ *      int[] names;
+ *
+ *    // XML Serialization Form 1 (Unwrapped collection)
+ *    &lt;names> ... &lt;/names>
+ *    &lt;names> ... &lt;/names>
+ *
+ *    // XML Serialization Form 2 ( Wrapped collection )
+ *    &lt;wrapperElement>
+ *       &lt;names> value-of-item &lt;/names>
+ *       &lt;names> value-of-item &lt;/names>
+ *       ....
+ *    &lt;/wrapperElement>
+ * </pre>
+ *
+ * <p> The two serialized XML forms allow a null collection to be
+ * represented either by absence or presence of an element with a
+ * nillable attribute.
+ *
+ * <p> <b>Usage</b> </p>
+ * <p>
+ * The <tt>@XmlElementWrapper</tt> annotation can be used with the
+ * following program elements:
+ * <ul>
+ *   <li> JavaBean property </li>
+ *   <li> non static, non transient field </li>
+ * </ul>
+ *
+ * <p>The usage is subject to the following constraints:
+ * <ul>
+ *   <li> The property must be a collection property </li>
+ *   <li> This annotation can be used with the following annotations:
+ *            {@link XmlElement},
+ *            {@link XmlElements},
+ *            {@link XmlElementRef},
+ *            {@link XmlElementRefs},
+ *            {@link XmlJavaTypeAdapter}</li>.
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li></ul>
+ * @see XmlElement
+ * @see XmlElements
+ * @see XmlElementRef
+ * @see XmlElementRefs
+ * @since JAXB2.0
+ *
+ */
+
+@Retention(RUNTIME) @Target({FIELD, METHOD})
+public @interface XmlElementWrapper {
+    /**
+     * Name of the XML wrapper element. By default, the XML wrapper
+     * element name is derived from the JavaBean property name.
+     */
+    String name() default "##default";
+
+    /**
+     * XML target namespace of the XML wrapper element.
+     * <p>
+     * If the value is "##default", then the namespace is determined
+     * as follows:
+     * <ol>
+     *  <li>
+     *  If the enclosing package has {@link XmlSchema} annotation,
+     *  and its {@link XmlSchema#elementFormDefault() elementFormDefault}
+     *  is {@link XmlNsForm#QUALIFIED QUALIFIED}, then the namespace of
+     *  the enclosing class.
+     *
+     *  <li>
+     *  Otherwise "" (which produces unqualified element in the default
+     *  namespace.
+     * </ol>
+     */
+    String namespace() default "##default";
+
+    /**
+     * If true, the absence of the collection is represented by
+     * using <tt>xsi:nil='true'</tt>. Otherwise, it is represented by
+     * the absence of the element.
+     */
+    boolean nillable() default false;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElements.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElements.java
new file mode 100644
index 0000000..c40fbb3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlElements.java
@@ -0,0 +1,177 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+/**
+ * <p>
+ * A container for multiple @{@link XmlElement} annotations.
+ *
+ * Multiple annotations of the same type are not allowed on a program
+ * element. This annotation therefore serves as a container annotation
+ * for multiple &#64;XmlElements as follows:
+ *
+ * <pre>
+ * &#64;XmlElements({ @XmlElement(...),@XmlElement(...) })
+ * </pre>
+ *
+ * <p>The <tt>@XmlElements</tt> annnotation can be used with the
+ * following program elements: </p>
+ * <ul>
+ *   <li> a JavaBean property </li>
+ *   <li> non static, non transient field </li>
+ * </ul>
+ *
+ * This annotation is intended for annotation a JavaBean collection
+ * property (e.g. List).
+ *
+ * <p><b>Usage</b></p>
+ *
+ * <p>The usage is subject to the following constraints:
+ * <ul>
+ *   <li> This annotation can be used with the following
+ *        annotations: @{@link XmlIDREF}, @{@link XmlElementWrapper}. </li>
+ *   <li> If @XmlIDREF is also specified on the JavaBean property,
+ *        then each &#64;XmlElement.type() must contain a JavaBean
+ *        property annotated with <tt>&#64;XmlID</tt>.</li>
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <hr>
+ *
+ * <p><b>Example 1:</b> Map to a list of elements</p>
+ * <pre>
+ *
+ *    // Mapped code fragment
+ *    public class Foo {
+ *        &#64;XmlElements(
+ *            &#64;XmlElement(name="A", type=Integer.class),
+ *            &#64;XmlElement(name="B", type=Float.class)
+ *         }
+ *         public List items;
+ *    }
+ *
+ *    &lt;!-- XML Representation for a List of {1,2.5}
+ *            XML output is not wrapped using another element -->
+ *    ...
+ *    <A> 1 </A>
+ *    <B> 2.5 </B>
+ *    ...
+ *
+ *    &lt;!-- XML Schema fragment -->
+ *    &lt;xs:complexType name="Foo">
+ *      &lt;xs:sequence>
+ *        &lt;xs:choice minOccurs="0" maxOccurs="unbounded">
+ *          &lt;xs:element name="A" type="xs:int"/>
+ *          &lt;xs:element name="B" type="xs:float"/>
+ *        &lt;xs:choice>
+ *      &lt;/xs:sequence>
+ *    &lt;/xs:complexType>
+ *
+ * </pre>
+ *
+ * <p><b>Example 2:</b> Map to a list of elements wrapped with another element
+ * </p>
+ * <pre>
+ *
+ *    // Mapped code fragment
+ *    public class Foo {
+ *        &#64;XmlElementWrapper(name="bar")
+ *        &#64;XmlElements(
+ *            &#64;XmlElement(name="A", type=Integer.class),
+ *            &#64;XmlElement(name="B", type=Float.class)
+ *        }
+ *        public List items;
+ *    }
+ *
+ *    &lt;!-- XML Schema fragment -->
+ *    &lt;xs:complexType name="Foo">
+ *      &lt;xs:sequence>
+ *        &lt;xs:element name="bar">
+ *          &lt;xs:complexType>
+ *            &lt;xs:choice minOccurs="0" maxOccurs="unbounded">
+ *              &lt;xs:element name="A" type="xs:int"/>
+ *              &lt;xs:element name="B" type="xs:float"/>
+ *            &lt;/xs:choice>
+ *          &lt;/xs:complexType>
+ *        &lt;/xs:element>
+ *      &lt;/xs:sequence>
+ *    &lt;/xs:complexType>
+ * </pre>
+ *
+ * <p><b>Example 3:</b> Change element name based on type using an adapter.
+ * </p>
+ * <pre>
+ *    class Foo {
+ *       &#64;XmlJavaTypeAdapter(QtoPAdapter.class)
+ *       &#64;XmlElements({
+ *           &#64;XmlElement(name="A",type=PX.class),
+ *           &#64;XmlElement(name="B",type=PY.class)
+ *       })
+ *       Q bar;
+ *    }
+ *
+ *    &#64;XmlType abstract class P {...}
+ *    &#64;XmlType(name="PX") class PX extends P {...}
+ *    &#64;XmlType(name="PY") class PY extends P {...}
+ *
+ *    &lt;!-- XML Schema fragment -->
+ *    &lt;xs:complexType name="Foo">
+ *      &lt;xs:sequence>
+ *        &lt;xs:element name="bar">
+ *          &lt;xs:complexType>
+ *            &lt;xs:choice minOccurs="0" maxOccurs="unbounded">
+ *              &lt;xs:element name="A" type="PX"/>
+ *              &lt;xs:element name="B" type="PY"/>
+ *            &lt;/xs:choice>
+ *          &lt;/xs:complexType>
+ *        &lt;/xs:element>
+ *      &lt;/xs:sequence>
+ *    &lt;/xs:complexType>
+ * </pre>
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li></ul>
+ * @see XmlElement
+ * @see XmlElementRef
+ * @see XmlElementRefs
+ * @see XmlJavaTypeAdapter
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME) @Target({FIELD,METHOD})
+public @interface XmlElements {
+    /**
+     * Collection of @{@link XmlElement} annotations
+     */
+    XmlElement[] value();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlEnum.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlEnum.java
new file mode 100644
index 0000000..d0a864c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlEnum.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import static java.lang.annotation.ElementType.TYPE;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import java.lang.annotation.Target;
+
+/**
+ * <p>
+ * Maps an enum type {@link Enum} to XML representation.
+ *
+ * <p>This annotation, together with {@link XmlEnumValue} provides a
+ * mapping of enum type to XML representation.
+ *
+ * <p> <b>Usage</b> </p>
+ * <p>
+ * The <tt>@XmlEnum</tt> annotation can be used with the
+ * following program elements:
+ * <ul>
+ *   <li>enum type</li>
+ * </ul>
+ *
+ * <p> The usage is subject to the following constraints:
+ * <ul>
+ *   <li> This annotation can be used the following other annotations:
+ *         {@link XmlType},
+ *         {@link XmlRootElement} </li>
+ * </ul>
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information </p>
+ *
+ * <p>An enum type is mapped to a schema simple type with enumeration
+ * facets. The schema type is derived from the Java type to which
+ * <tt>@XmlEnum.value()</tt>. Each enum constant <tt>@XmlEnumValue</tt>
+ * must have a valid lexical representation for the type
+ * <tt>@XmlEnum.value()</tt> .
+ *
+ * <p><b>Examples:</b> See examples in {@link XmlEnumValue}
+ *
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({TYPE})
+public @interface XmlEnum {
+    /**
+     * Java type that is mapped to a XML simple type.
+     *
+     */
+    Class<?> value() default String.class;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlEnumValue.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlEnumValue.java
new file mode 100644
index 0000000..bb74787
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlEnumValue.java
@@ -0,0 +1,123 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+
+/**
+ * Maps an enum constant in {@link Enum} type to XML representation.
+ *
+ * <p> <b>Usage</b> </p>
+ *
+ * <p> The <tt>@XmlEnumValue</tt> annotation can be used with the
+ *     following program elements:
+ * <ul>
+ *   <li>enum constant</li>
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p>This annotation, together with {@link XmlEnum} provides a
+ * mapping of enum type to XML representation.
+ *
+ * <p>An enum type is mapped to a schema simple type with enumeration
+ * facets. The schema type is derived from the Java type specified in
+ * <tt>@XmlEnum.value()</tt>. Each enum constant <tt>@XmlEnumValue</tt>
+ * must have a valid lexical representation for the type
+ * <tt>@XmlEnum.value()</tt>
+ *
+ * <p> In the absence of this annotation, {@link Enum#name()} is used
+ * as the XML representation.
+ *
+ * <p> <b>Example 1: </b>Map enum constant name -> enumeration facet</p>
+ * <pre>
+ *     //Example: Code fragment
+ *     &#64;XmlEnum(String.class)
+ *     public enum Card { CLUBS, DIAMONDS, HEARTS, SPADES }
+ *
+ *     &lt;!-- Example: XML Schema fragment -->
+ *     &lt;xs:simpleType name="Card">
+ *       &lt;xs:restriction base="xs:string"/>
+ *         &lt;xs:enumeration value="CLUBS"/>
+ *         &lt;xs:enumeration value="DIAMONDS"/>
+ *         &lt;xs:enumeration value="HEARTS"/>
+ *         &lt;xs:enumeration value="SPADES"/>
+ *     &lt;/xs:simpleType>
+ * </pre>
+ *
+ * <p><b>Example 2: </b>Map enum constant name(value) -> enumeration facet </p>
+ * <pre>
+ *     //Example: code fragment
+ *     &#64;XmlType
+ *     &#64;XmlEnum(Integer.class)
+ *     public enum Coin {
+ *         &#64;XmlEnumValue("1") PENNY(1),
+ *         &#64;XmlEnumValue("5") NICKEL(5),
+ *         &#64;XmlEnumValue("10") DIME(10),
+ *         &#64;XmlEnumValue("25") QUARTER(25) }
+ *
+ *     &lt;!-- Example: XML Schema fragment -->
+ *     &lt;xs:simpleType name="Coin">
+ *       &lt;xs:restriction base="xs:int">
+ *         &lt;xs:enumeration value="1"/>
+ *         &lt;xs:enumeration value="5"/>
+ *         &lt;xs:enumeration value="10"/>
+ *         &lt;xs:enumeration value="25"/>
+ *       &lt;/xs:restriction>
+ *     &lt;/xs:simpleType>
+ * </pre>
+ *
+ * <p><b>Example 3: </b>Map enum constant name -> enumeration facet </p>
+ *
+ * <pre>
+ *     //Code fragment
+ *     &#64;XmlType
+ *     &#64;XmlEnum(Integer.class)
+ *     public enum Code {
+ *         &#64;XmlEnumValue("1") ONE,
+ *         &#64;XmlEnumValue("2") TWO;
+ *     }
+ *
+ *     &lt;!-- Example: XML Schema fragment -->
+ *     &lt;xs:simpleType name="Code">
+ *       &lt;xs:restriction base="xs:int">
+ *         &lt;xs:enumeration value="1"/>
+ *         &lt;xs:enumeration value="2"/>
+ *       &lt;/xs:restriction>
+ *     &lt;/xs:simpleType>
+ * </pre>
+ *
+ * @since JAXB 2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD})
+public @interface XmlEnumValue {
+    String value();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlID.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlID.java
new file mode 100644
index 0000000..148f80c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlID.java
@@ -0,0 +1,94 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * <p>
+ * Maps a JavaBean property to XML ID.
+ *
+ * <p>
+ * To preserve referential integrity of an object graph across XML
+ * serialization followed by a XML deserialization, requires an object
+ * reference to be marshalled by reference or containment
+ * appropriately. Annotations <tt>&#64;XmlID</tt> and <tt>&#64;XmlIDREF</tt>
+ * together allow a customized mapping of a JavaBean property's
+ * type by containment or reference.
+ *
+ * <p><b>Usage</b> </p>
+ * The <tt>&#64;XmlID</tt> annotation can be used with the following
+ * program elements:
+ * <ul>
+ *   <li> a JavaBean property </li>
+ *   <li> non static, non transient field </li>
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * The usage is subject to the following constraints:
+ * <ul>
+ *   <li> At most one field or property in a class can be annotated
+ *        with <tt>&#64;XmlID</tt>.  </li>
+ *   <li> The JavaBean property's type must be <tt>java.lang.String</tt>.</li>
+ *   <li> The only other mapping annotations that can be used
+ *        with <tt>&#64;XmlID</tt>
+ *        are:<tt>&#64;XmlElement</tt> and <tt>&#64;XmlAttribute</tt>.</li>
+ * </ul>
+ *
+ * <p><b>Example</b>: Map a JavaBean property's type to <tt>xs:ID</tt></p>
+ * <pre>
+ *    // Example: code fragment
+ *    public class Customer {
+ *        &#64;XmlAttribute
+ *        &#64;XmlID
+ *        public String getCustomerID();
+ *        public void setCustomerID(String id);
+ *        .... other properties not shown
+ *    }
+ *
+ *    &lt;!-- Example: XML Schema fragment -->
+ *    &lt;xs:complexType name="Customer">
+ *      &lt;xs:complexContent>
+ *        &lt;xs:sequence>
+ *          ....
+ *        &lt;/xs:sequence>
+ *        &lt;xs:attribute name="customerID" type="xs:ID"/>
+ *      &lt;/xs:complexContent>
+ *    &lt;/xs:complexType>
+ * </pre>
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @see XmlIDREF
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({FIELD, METHOD})
+public @interface XmlID { }
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlIDREF.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlIDREF.java
new file mode 100644
index 0000000..db6f4e7
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlIDREF.java
@@ -0,0 +1,250 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * <p>
+ * Maps a JavaBean property to XML IDREF.
+ *
+ * <p>
+ * To preserve referential integrity of an object graph across XML
+ * serialization followed by a XML deserialization, requires an object
+ * reference to be marshalled by reference or containment
+ * appropriately. Annotations <tt>&#64;XmlID</tt> and <tt>&#64;XmlIDREF</tt>
+ * together allow a customized mapping of a JavaBean property's
+ * type by containment or reference.
+ *
+ * <p><b>Usage</b> </p>
+ * The <tt>&#64;XmlIDREF</tt> annotation can be used with the following
+ * program elements:
+ * <ul>
+ *   <li> a JavaBean property </li>
+ *   <li> non static, non transient field </li>
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p> The usage is subject to the following constraints:
+ * <ul>
+ *
+ *   <li> If the type of the field or property is a collection type,
+ *        then the collection item type must contain a property or
+ *        field annotated with <tt>&#64;XmlID</tt>.  </li>
+ *   <li> If the field or property is single valued, then the type of
+ *        the property or field must contain a property or field
+ *        annotated with <tt>&#64;XmlID</tt>.
+ *        <p>Note: If the collection item type or the type of the
+ *        property (for non collection type) is java.lang.Object, then
+ *        the instance must contain a property/field annotated with
+ *        <tt>&#64;XmlID</tt> attribute.
+ *        </li>
+ *   <li> This annotation can be used with the following annotations:
+ *        {@link XmlElement}, {@link XmlAttribute}, {@link XmlList},
+ *        and {@link XmlElements}.</li>
+ *
+ * </ul>
+ * <p><b>Example:</b> Map a JavaBean property to <tt>xs:IDREF</tt>
+ *   (i.e. by reference rather than by containment)</p>
+ * <pre>
+ *
+ *   //EXAMPLE: Code fragment
+ *   public class Shipping {
+ *       &#64;XmlIDREF public Customer getCustomer();
+ *       public void setCustomer(Customer customer);
+ *       ....
+ *    }
+ *
+ *   &lt;!-- Example: XML Schema fragment -->
+ *   &lt;xs:complexType name="Shipping">
+ *     &lt;xs:complexContent>
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="customer" type="xs:IDREF"/>
+ *         ....
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexContent>
+ *   &lt;/xs:complexType>
+ *
+ * </pre>
+ *
+ *
+ * <p><b>Example 2: </b> The following is a complete example of
+ * containment versus reference.
+ *
+ * <pre>
+ *    // By default, Customer maps to complex type <tt>xs:Customer</tt>
+ *    public class Customer {
+ *
+ *        // map JavaBean property type to <tt>xs:ID</tt>
+ *        &#64;XmlID public String getCustomerID();
+ *        public void setCustomerID(String id);
+ *
+ *        // .... other properties not shown
+ *    }
+ *
+ *
+ *   // By default, Invoice maps to a complex type <tt>xs:Invoice</tt>
+ *   public class Invoice {
+ *
+ *       // map by reference
+ *       &#64;XmlIDREF public Customer getCustomer();
+ *       public void setCustomer(Customer customer);
+ *
+ *      // .... other properties not shown here
+ *   }
+ *
+ *   // By default, Shipping maps to complex type <tt>xs:Shipping</tt>
+ *   public class Shipping {
+ *
+ *       // map by reference
+ *       &#64;XmlIDREF public Customer getCustomer();
+ *       public void setCustomer(Customer customer);
+ *   }
+ *
+ *   // at least one class must reference Customer by containment;
+ *   // Customer instances won't be marshalled.
+ *   &#64;XmlElement(name="CustomerData")
+ *   public class CustomerData {
+ *       // map reference to Customer by containment by default.
+ *       public Customer getCustomer();
+ *
+ *       // maps reference to Shipping by containment by default.
+ *       public Shipping getShipping();
+ *
+ *       // maps reference to Invoice by containment by default.
+ *       public Invoice getInvoice();
+ *   }
+ *
+ *   &lt;!-- XML Schema mapping for above code frament -->
+ *
+ *   &lt;xs:complexType name="Invoice">
+ *     &lt;xs:complexContent>
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="customer" type="xs:IDREF"/>
+ *         ....
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexContent>
+ *   &lt;/xs:complexType>
+ *
+ *   &lt;xs:complexType name="Shipping">
+ *     &lt;xs:complexContent>
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="customer" type="xs:IDREF"/>
+ *         ....
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexContent>
+ *   &lt;/xs:complexType>
+ *
+ *   &lt;xs:complexType name="Customer">
+ *     &lt;xs:complexContent>
+ *       &lt;xs:sequence>
+ *         ....
+ *       &lt;/xs:sequence>
+ *       &lt;xs:attribute name="CustomerID" type="xs:ID"/>
+ *     &lt;/xs:complexContent>
+ *   &lt;/xs:complexType>
+ *
+ *   &lt;xs:complexType name="CustomerData">
+ *     &lt;xs:complexContent>
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="customer" type="xs:Customer"/>
+ *         &lt;xs:element name="shipping" type="xs:Shipping"/>
+ *         &lt;xs:element name="invoice"  type="xs:Invoice"/>
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexContent>
+ *   &lt;/xs:complexType>
+ *
+ *   &lt;xs:element name"customerData" type="xs:CustomerData"/>
+ *
+ *   &lt;!-- Instance document conforming to the above XML Schema -->
+ *    &lt;customerData>
+ *       &lt;customer customerID="Alice">
+ *           ....
+ *       &lt;/customer>
+ *
+ *       &lt;shipping customer="Alice">
+ *           ....
+ *       &lt;/shipping>
+ *
+ *       &lt;invoice customer="Alice">
+ *           ....
+ *       &lt;/invoice>
+ *   &lt;/customerData>
+ *
+ * </pre>
+ *
+ * <p><b>Example 3: </b> Mapping List to repeating element of type IDREF
+ * <pre>
+ *     // Code fragment
+ *     public class Shipping {
+ *         &#64;XmlIDREF
+ *         &#64;XmlElement(name="Alice")
+ *             public List customers;
+ *     }
+ *
+ *     &lt;!-- XML schema fragment -->
+ *     &lt;xs:complexType name="Shipping">
+ *       &lt;xs:sequence>
+ *         &lt;xs:choice minOccurs="0" maxOccurs="unbounded">
+ *           &lt;xs:element name="Alice" type="xs:IDREF"/>
+ *         &lt;/xs:choice>
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexType>
+ * </pre>
+ *
+ * <p><b>Example 4: </b> Mapping a List to a list of elements of type IDREF.
+ * <pre>
+ *     //Code fragment
+ *     public class Shipping {
+ *         &#64;XmlIDREF
+ *         &#64;XmlElements(
+ *             &#64;XmlElement(name="Alice", type="Customer.class")
+ *              &#64;XmlElement(name="John", type="InternationalCustomer.class")
+ *         public List customers;
+ *     }
+ *
+ *     &lt;!-- XML Schema fragment -->
+ *     &lt;xs:complexType name="Shipping">
+ *       &lt;xs:sequence>
+ *         &lt;xs:choice minOccurs="0" maxOccurs="unbounded">
+ *           &lt;xs:element name="Alice" type="xs:IDREF"/>
+ *           &lt;xs:element name="John" type="xs:IDREF"/>
+ *         &lt;/xs:choice>
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexType>
+ * </pre>
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @see XmlID
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({FIELD, METHOD})
+public @interface XmlIDREF {}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlInlineBinaryData.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlInlineBinaryData.java
new file mode 100644
index 0000000..5f0ac75
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlInlineBinaryData.java
@@ -0,0 +1,60 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+import java.awt.*;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.ElementType.TYPE;
+
+import javax.xml.transform.Source;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.activation.DataHandler;
+
+/**
+ * Disable consideration of XOP encoding for datatypes that are bound to
+ * base64-encoded binary data in XML.
+ *
+ * <p>
+ * When XOP encoding is enabled as described in {@link AttachmentMarshaller#isXOPPackage()}, this annotation disables datatypes such as {@link Image} or {@link Source} or <tt>byte[]</tt> that are bound to base64-encoded binary from being considered for
+ * XOP encoding. If a JAXB property is annotated with this annotation or if
+ * the JAXB property's base type is annotated with this annotation,
+ * neither
+ * {@link AttachmentMarshaller#addMtomAttachment(DataHandler, String, String)}
+ * nor
+ * {@link AttachmentMarshaller#addMtomAttachment(byte[], int, int, String, String, String)} is
+ * ever called for the property. The binary data will always be inlined.
+ *
+ * @author Joseph Fialli
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD,TYPE})
+public @interface XmlInlineBinaryData {
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlList.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlList.java
new file mode 100644
index 0000000..5338732
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlList.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.ElementType.PARAMETER;
+
+/**
+ * Used to map a property to a list simple type.
+ *
+ * <p><b>Usage</b> </p>
+ * <p>
+ * The <tt>@XmlList</tt> annotation can be used with the
+ * following program elements:
+ * <ul>
+ *   <li> JavaBean property </li>
+ *   <li> field </li>
+ * </ul>
+ *
+ * <p>
+ * When a collection property is annotated just with @XmlElement,
+ * each item in the collection will be wrapped by an element.
+ * For example,
+ *
+ * <pre>
+ * &#64;XmlRootElement
+ * class Foo {
+ *     &#64;XmlElement
+ *     List&lt;String> data;
+ * }
+ * </pre>
+ *
+ * would produce XML like this:
+ *
+ * <pre><xmp>
+ * <foo>
+ *   <data>abc</data>
+ *   <data>def</data>
+ * </foo>
+ * </xmp></pre>
+ *
+ * &#64;XmlList annotation, on the other hand, allows multiple values to be
+ * represented as whitespace-separated tokens in a single element. For example,
+ *
+ * <pre>
+ * &#64;XmlRootElement
+ * class Foo {
+ *     &#64;XmlElement
+ *     &#64;XmlList
+ *     List&lt;String> data;
+ * }
+ * </pre>
+ *
+ * the above code will produce XML like this:
+ *
+ * <pre><xmp>
+ * <foo>
+ *   <data>abc def</data>
+ * </foo>
+ * </xmp></pre>
+ *
+ * <p>This annotation can be used with the following annotations:
+ *        {@link XmlElement},
+ *        {@link XmlAttribute},
+ *        {@link XmlValue},
+ *        {@link XmlIDREF}.
+ *  <ul>
+ *    <li> The use of <tt>@XmlList</tt> with {@link XmlValue} while
+ *         allowed, is redundant since  {@link XmlList} maps a
+ *         collection type to a simple schema type that derives by
+ *         list just as {@link XmlValue} would. </li>
+ *
+ *    <li> The use of <tt>@XmlList</tt> with {@link XmlAttribute} while
+ *         allowed, is redundant since  {@link XmlList} maps a
+ *         collection type to a simple schema type that derives by
+ *         list just as {@link XmlAttribute} would. </li>
+ *  </ul>
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li></ul>
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME) @Target({FIELD,METHOD,PARAMETER})
+public @interface XmlList {
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlMimeType.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlMimeType.java
new file mode 100644
index 0000000..4ffd378
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlMimeType.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+import java.awt.*;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.ElementType.PARAMETER;
+
+import javax.xml.transform.Source;
+
+/**
+ * Associates the MIME type that controls the XML representation of the property.
+ *
+ * <p>
+ * This annotation is used in conjunction with datatypes such as
+ * {@link Image} or {@link Source} that are bound to base64-encoded binary in XML.
+ *
+ * <p>
+ * If a property that has this annotation has a sibling property bound to
+ * the xmime:contentType attribute, and if in the instance the property has a value,
+ * the value of the attribute takes precedence and that will control the marshalling.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD,PARAMETER})
+public @interface XmlMimeType {
+    /**
+     * The textual representation of the MIME type,
+     * such as "image/jpeg" "image/*", "text/xml; charset=iso-8859-1" and so on.
+     */
+    String value();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlMixed.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlMixed.java
new file mode 100644
index 0000000..477473f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlMixed.java
@@ -0,0 +1,132 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+
+import org.w3c.dom.Element;
+import javax.xml.bind.JAXBElement;
+
+/**
+ * <p>
+ * Annotate a JavaBean multi-valued property to support mixed content.
+ *
+ * <p>
+ * The usage is subject to the following constraints:
+ * <ul>
+ *   <li> can be used with &#64;XmlElementRef, &#64;XmlElementRefs or &#64;XmlAnyElement</li>
+ * </ul>
+ * <p>
+ * The following can be inserted into &#64;XmlMixed annotated multi-valued property
+ * <ul>
+ * <li>XML text information items are added as values of java.lang.String.</li>
+ * <li>Children element information items are added as instances of
+ * {@link JAXBElement} or instances with a class that is annotated with
+ * &#64;XmlRootElement.</li>
+ * <li>Unknown content that is not be bound to a JAXB mapped class is inserted
+ * as {@link Element}. (Assumes property annotated with &#64;XmlAnyElement)</li>
+ * </ul>
+ *
+ * Below is an example of binding and creation of mixed content.
+ * <pre><xmp>
+ *  <!-- schema fragment having  mixed content -->
+ *  <xs:complexType name="letterBody" mixed="true">
+ *    <xs:sequence>
+ *      <xs:element name="name" type="xs:string"/>
+ *      <xs:element name="quantity" type="xs:positiveInteger"/>
+ *      <xs:element name="productName" type="xs:string"/>
+ *      <!-- etc. -->
+ *    </xs:sequence>
+ *  </xs:complexType>
+ *  <xs:element name="letterBody" type="letterBody"/>
+ *
+ * // Schema-derived Java code:
+ * // (Only annotations relevant to mixed content are shown below,
+ * //  others are ommitted.)
+ * import java.math.BigInteger;
+ * public class ObjectFactory {
+ *      // element instance factories
+ *      JAXBElement<LetterBody> createLetterBody(LetterBody value);
+ *      JAXBElement<String>     createLetterBodyName(String value);
+ *      JAXBElement<BigInteger> createLetterBodyQuantity(BigInteger value);
+ *      JAXBElement<String>     createLetterBodyProductName(String value);
+ *      // type instance factory
+ *      LetterBody> createLetterBody();
+ * }
+ * </xmp></pre>
+ * <pre>
+ * public class LetterBody {
+ *      // Mixed content can contain instances of Element classes
+ *      // Name, Quantity and ProductName. Text data is represented as
+ *      // java.util.String for text.
+ *      &#64;XmlMixed
+ *      &#64;XmlElementRefs({
+ *              &#64;XmlElementRef(name="productName", type=JAXBElement.class),
+ *              &#64;XmlElementRef(name="quantity", type=JAXBElement.class),
+ *              &#64;XmlElementRef(name="name", type=JAXBElement.class)})
+ *      List getContent(){...}
+ * }
+ * </pre>
+ * The following is an XML instance document with mixed content
+ * <pre><xmp>
+ * <letterBody>
+ * Dear Mr.<name>Robert Smith</name>
+ * Your order of <quantity>1</quantity> <productName>Baby
+ * Monitor</productName> shipped from our warehouse. ....
+ * </letterBody>
+ * </xmp></pre>
+ * that can be constructed using following JAXB API calls.
+ * <pre><xmp>
+ * LetterBody lb = ObjectFactory.createLetterBody();
+ * JAXBElement<LetterBody> lbe = ObjectFactory.createLetterBody(lb);
+ * List gcl = lb.getContent();  //add mixed content to general content property.
+ * gcl.add("Dear Mr.");  // add text information item as a String.
+ *
+ * // add child element information item
+ * gcl.add(ObjectFactory.createLetterBodyName("Robert Smith"));
+ * gcl.add("Your order of "); // add text information item as a String
+ *
+ * // add children element information items
+ * gcl.add(ObjectFactory.
+ *                      createLetterBodyQuantity(new BigInteger("1")));
+ * gcl.add(ObjectFactory.createLetterBodyProductName("Baby Monitor"));
+ * gcl.add("shipped from our warehouse");  // add text information item
+ * </xmp></pre>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ * @author Kohsuke Kawaguchi
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({FIELD,METHOD})
+public @interface XmlMixed {
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlNs.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlNs.java
new file mode 100644
index 0000000..f814cf2
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlNs.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import java.lang.annotation.Target;
+
+/**
+ * <p>
+ * Associates a namespace prefix with a XML namespace URI.
+ *
+ * <p><b>Usage</b></p>
+ * <p><tt>@XmlNs</tt> annotation is intended for use from other
+ * program annotations.
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p><b>Example:</b>See <tt>XmlSchema</tt> annotation type for an example.
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({})
+public @interface XmlNs {
+    /**
+     * Namespace prefix
+     */
+    String prefix();
+
+    /**
+     * Namespace URI
+     */
+    String namespaceURI();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlNsForm.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlNsForm.java
new file mode 100644
index 0000000..f92fba4
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlNsForm.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+/**
+ * Enumeration of XML Schema namespace qualifications.
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p><b>Usage</b>
+ * <p>
+ * The namespace qualification values are used in the annotations
+ * defined in this packge. The enumeration values are mapped as follows:
+ *
+ * <p>
+ * <table border="1" cellpadding="4" cellspacing="3">
+ *   <tbody>
+ *     <tr>
+ *       <td><b>Enum Value</b></td>
+ *       <td><b>XML Schema Value</b></td>
+ *     </tr>
+ *
+ *     <tr valign="top">
+ *       <td>UNQUALIFIED</td>
+ *       <td>unqualified</td>
+ *     </tr>
+ *     <tr valign="top">
+ *       <td>QUALIFIED</td>
+ *       <td>qualified</td>
+ *     </tr>
+ *     <tr valign="top">
+ *       <td>UNSET</td>
+ *       <td>namespace qualification attribute is absent from the
+ *           XML Schema fragment</td>
+ *     </tr>
+ *   </tbody>
+ * </table>
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ */
+public enum XmlNsForm {UNQUALIFIED, QUALIFIED, UNSET}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlRegistry.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlRegistry.java
new file mode 100644
index 0000000..623dd9e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlRegistry.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+import static java.lang.annotation.ElementType.TYPE;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+
+/**
+ * Marks a class that has {@link XmlElementDecl}s.
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li></ul>
+ * @since JAXB 2.0
+ * @see XmlElementDecl
+ */
+@Retention(RUNTIME)
+@Target({TYPE})
+public @interface XmlRegistry {
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlRootElement.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlRootElement.java
new file mode 100644
index 0000000..9cdae2f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlRootElement.java
@@ -0,0 +1,182 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.TYPE;
+
+/**
+ * Maps a class or an enum type to an XML element.
+ *
+ * <p> <b>Usage</b> </p>
+ * <p>
+ * The &#64;XmlRootElement annotation can be used with the following program
+ * elements:
+ * <ul>
+ *   <li> a top level class </li>
+ *   <li> an enum type </li>
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p>
+ * When a top level class or an enum type is annotated with the
+ * &#64;XmlRootElement annotation, then its value is represented
+ * as XML element in an XML document.
+ *
+ * <p> This annotation can be used with the following annotations:
+ * {@link XmlType}, {@link XmlEnum}, {@link XmlAccessorType},
+ * {@link XmlAccessorOrder}.
+ * <p>
+
+ * <p>
+ * <b>Example 1: </b> Associate an element with XML Schema type
+ * <pre>
+ *     // Example: Code fragment
+ *     &#64;XmlRootElement
+ *     class Point {
+ *        int x;
+ *        int y;
+ *        Point(int _x,int _y) {x=_x;y=_y;}
+ *     }
+ * </pre>
+ *
+ * <pre>
+ *     //Example: Code fragment corresponding to XML output
+ *     marshal( new Point(3,5), System.out);
+ * </pre>
+ *
+ * <pre><xmp>
+ *     <!-- Example: XML output -->
+ *     <point>
+ *       <x> 3 </x>
+ *       <y> 5 </y>
+ *     </point>
+ * </xmp></pre>
+ *
+ * The annotation causes an global element declaration to be produced
+ * in the schema. The global element declaration is associated with
+ * the XML schema type to which the class is mapped.
+ *
+ * <pre><xmp>
+ *     <!-- Example: XML schema definition -->
+ *     <xs:element name="point" type="point"/>
+ *     <xs:complexType name="point">
+ *       <xs:sequence>
+ *         <xs:element name="x" type="xs:int"/>
+ *         <xs:element name="y" type="xs:int"/>
+ *       </xs:sequence>
+ *     </xs:complexType>
+ * </xmp></pre>
+ *
+ * <p>
+ *
+ * <b>Example 2: Orthogonality to type inheritance </b>
+ *
+ * <p>
+ * An element declaration annotated on a type is not inherited by its
+ * derived types. The following example shows this.
+ * <pre>
+ *     // Example: Code fragment
+ *     &#64;XmlRootElement
+ *     class Point3D extends Point {
+ *         int z;
+ *         Point3D(int _x,int _y,int _z) {super(_x,_y);z=_z;}
+ *     }
+ *
+ *     //Example: Code fragment corresponding to XML output *
+ *     marshal( new Point3D(3,5,0), System.out );
+ *
+ *     &lt;!-- Example: XML output -->
+ *     &lt;!-- The element name is point3D not point -->
+ *     &lt;point3D>
+ *       &lt;x>3&lt;/x>
+ *       &lt;y>5&lt;/y>
+ *       &lt;z>0&lt;/z>
+ *     &lt;/point3D>
+ *
+ *     &lt;!-- Example: XML schema definition -->
+ *     &lt;xs:element name="point3D" type="point3D"/>
+ *     &lt;xs:complexType name="point3D">
+ *       &lt;xs:complexContent>
+ *         &lt;xs:extension base="point">
+ *           &lt;xs:sequence>
+ *             &lt;xs:element name="z" type="xs:int"/>
+ *           &lt;/xs:sequence>
+ *         &lt;/xs:extension>
+ *       &lt;/xs:complexContent>
+ *     &lt;/xs:complexType>
+ * </pre>
+ *
+ * <b>Example 3: </b> Associate a global element with XML Schema type
+ * to which the class is mapped.
+ * <pre>
+ *     //Example: Code fragment
+ *     &#64;XmlRootElement(name="PriceElement")
+ *     public class USPrice {
+ *         &#64;XmlElement
+ *         public java.math.BigDecimal price;
+ *     }
+ *
+ *     &lt;!-- Example: XML schema definition -->
+ *     &lt;xs:element name="PriceElement" type="USPrice"/>
+ *     &lt;xs:complexType name="USPrice">
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="price" type="xs:decimal"/>
+ *       &lt;/sequence>
+ *     &lt;/xs:complexType>
+ * </pre>
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME)
+@Target({TYPE})
+public @interface XmlRootElement {
+    /**
+     * namespace name of the XML element.
+     * <p>
+     * If the value is "##default", then the XML namespace name is derived
+     * from the package of the class ( {@link XmlSchema} ). If the
+     * package is unnamed, then the XML namespace is the default empty
+     * namespace.
+     */
+    String namespace() default "##default";
+
+    /**
+     * local name of the XML element.
+     * <p>
+     * If the value is "##default", then the name is derived from the
+     * class name.
+     *
+     */
+    String name() default "##default";
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchema.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchema.java
new file mode 100644
index 0000000..a6a9580
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchema.java
@@ -0,0 +1,145 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * <p> Maps a package name to a XML namespace. </p>
+ *
+ * <p><b>Usage</b> </p>
+ * <p>
+ * The XmlSchema annotation can be used with the following program
+ * elements:
+ * <ul>
+ *   <li>package</li>
+ * </ul>
+ *
+ * This is a package level annotation and follows the recommendations
+ * and restrictions contained in JSR 175, section III, "Annotations".
+ * Thus the usage is subject to the following constraints and
+ * recommendations.
+ * <ul>
+ *   <li> There can only be one package declaration as noted in JSR
+ *        175, section III, "Annotations". </li>
+ *   <li> JSR 175 recommends package-info.java for package level
+ *        annotations. JAXB Providers that follow this recommendation
+ *        will allow the package level annotations to be defined in
+ *        package-info.java.
+ * </ul>
+ * <p>
+ *
+ * <p><b>Example 1:</b> Customize name of XML namespace to which
+ * package is mapped.</p>
+ *
+ * <pre>
+ *    &#64;javax.xml.bind.annotation.XmlSchema (
+ *      namespace = "http://www.example.com/MYPO1"
+ *    )
+ *
+ *    &lt;!-- XML Schema fragment -->
+ *    &lt;schema
+ *      xmlns=...
+ *      xmlns:po=....
+ *      targetNamespace="http://www.example.com/MYPO1"
+ *    >
+ *    &lt;!-- prefixes generated by default are implementation
+ *            depedenent -->
+ * </pre>
+ *
+ * <p><b>Example 2:</b> Customize namespace prefix, namespace URI
+ * mapping</p>
+ *
+ * <pre>
+ *    // Package level annotation
+ *    &#64;javax.xml.bind.annotation.XmlSchema (
+ *      xmlns = {
+ *        &#64;javax.xml.bind.annotation.XmlNs(prefix = "po",
+ *                   namespaceURI="http://www.example.com/myPO1"),
+ *
+ *        &#64;javax.xml.bind.annotation.XmlNs(prefix="xs",
+ *                   namespaceURI="http://www.w3.org/2001/XMLSchema")
+ *      )
+ *    )
+ *
+ *    &lt;!-- XML Schema fragment -->
+ *    &lt;schema
+ *        xmlns:xs="http://www.w3.org/2001/XMLSchema"
+ *        xmlns:po="http://www.example.com/PO1"
+ *        targetNamespace="http://www.example.com/PO1">
+ *
+ * </pre>
+ *
+ * <p><b>Example 3:</b> Customize elementFormDefault</p>
+ * <pre>
+ *    &#64;javax.xml.bind.annotation.XmlSchema (
+ *      elementFormDefault=XmlNsForm.UNQUALIFIED
+ *      ...
+ *    )
+ *
+ *    &lt;!-- XML Schema fragment -->
+ *    &lt;schema
+ *        xmlns="http://www.w3.org/2001/XMLSchema"
+ *        xmlns:po="http://www.example.com/PO1"
+ *        elementFormDefault="unqualified">
+ *
+ * </pre>
+
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({PACKAGE})
+public @interface XmlSchema {
+
+    /**
+     * Customize the namespace URI, prefix associations. By default,
+     * the namespace prefixes for a XML namespace are generated by a
+     * JAXB Provider in an implementation dependent way.
+     */
+    XmlNs[]  xmlns() default {};
+
+    /**
+     * Name of the XML namespace.
+     */
+    String namespace() default "";
+
+    /**
+     * Namespace qualification for elements. By default, element
+     * default attribute will be absent from the XML Schema fragment.
+     */
+    XmlNsForm elementFormDefault() default XmlNsForm.UNSET;
+
+    /**
+     * Namespace qualification for attributes. By default,
+     * attributesFormDefault will be absent from the XML Schema fragment.
+     */
+    XmlNsForm attributeFormDefault() default XmlNsForm.UNSET;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchemaType.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchemaType.java
new file mode 100644
index 0000000..75c51e4
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchemaType.java
@@ -0,0 +1,107 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.ElementType.PACKAGE;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+
+/**
+ * Maps a Java type to a simple schema built-in type.
+ *
+ * <p> <b>Usage</b> </p>
+ * <p>
+ * <tt>@XmlSchemaType</tt> annotation can be used with the following program
+ * elements:
+ * <ul>
+ *   <li> a JavaBean property </li>
+ *   <li> field </li>
+ *   <li> package</li>
+ * </ul>
+ *
+ * <p> <tt>@XmlSchemaType</tt> annotation defined for Java type
+ * applies to all references to the Java type from a property/field.
+ * A <tt>@XmlSchemaType</tt> annotation specified on the
+ * property/field overrides the <tt>@XmlSchemaType</tt> annotation
+ * specified at the package level.
+ *
+ * <p> This annotation can be used with the following annotations:
+ * {@link XmlElement},  {@link XmlAttribute}.
+ * <p>
+ * <b>Example 1: </b> Customize mapping of XMLGregorianCalendar on the
+ *  field.
+ *
+ * <pre>
+ *     //Example: Code fragment
+ *     public class USPrice {
+ *         &#64;XmlElement
+ *         &#64;XmlSchemaType(name="date")
+ *         public XMLGregorianCalendar date;
+ *     }
+ *
+ *     &lt;!-- Example: Local XML Schema element -->
+ *     &lt;xs:complexType name="USPrice"/>
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="date" type="xs:date"/>
+ *       &lt;/sequence>
+ *     &lt;/xs:complexType>
+ * </pre>
+ *
+ * <p> <b> Example 2: </b> Customize mapping of XMLGregorianCalendar at package
+ *     level </p>
+ * <pre>
+ *     package foo;
+ *     &#64;javax.xml.bind.annotation.XmlSchemaType(
+ *          name="date", type=javax.xml.datatype.XMLGregorianCalendar.class)
+ *     }
+ * </pre>
+ *
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({FIELD,METHOD,PACKAGE})
+public @interface XmlSchemaType {
+    String name();
+    String namespace() default "http://www.w3.org/2001/XMLSchema";
+    /**
+     * If this annotation is used at the package level, then value of
+     * the type() must be specified.
+     */
+
+    Class type() default DEFAULT.class;
+
+    /**
+     * Used in {@link XmlSchemaType#type()} to
+     * signal that the type be inferred from the signature
+     * of the property.
+     */
+
+    static final class DEFAULT {}
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchemaTypes.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchemaTypes.java
new file mode 100644
index 0000000..1e8c564
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlSchemaTypes.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.PACKAGE;
+import java.lang.annotation.Retention;
+import java.lang.annotation.Target;
+
+/**
+ * <p>
+ * A container for multiple @{@link XmlSchemaType} annotations.
+ *
+ * <p> Multiple annotations of the same type are not allowed on a program
+ * element. This annotation therefore serves as a container annotation
+ * for multiple &#64;XmlSchemaType annotations as follows:
+ *
+ * <pre>
+ * &#64;XmlSchemaTypes({ @XmlSchemaType(...), @XmlSchemaType(...) })
+ * </pre>
+ * <p>The <tt>@XmlSchemaTypes</tt> annnotation can be used to
+ * define {@link XmlSchemaType} for different types at the
+ * package level.
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * @author <ul><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li></ul>
+ * @see XmlSchemaType
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME) @Target({PACKAGE})
+public @interface XmlSchemaTypes {
+    /**
+     * Collection of @{@link XmlSchemaType} annotations
+     */
+    XmlSchemaType[] value();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlTransient.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlTransient.java
new file mode 100644
index 0000000..c97bf0e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlTransient.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * <p>
+ * Prevents the mapping of a JavaBean property to XML representation.
+ * <p>
+ * The <tt>@XmlTransient</tt> annotation is useful for resolving name
+ * collisions between a JavaBean property name and a field name or
+ * preventing the mapping of a field/property. A name collision can
+ * occur when the decapitalized JavaBean property name and a field
+ * name are the same. If the JavaBean property refers to the field,
+ * then the name collision can be resolved by preventing the
+ * mapping of either the field or the JavaBean property using the
+ * <tt>@XmlTransient</tt> annotation.
+ * <p><b>Usage</b></p>
+ * <p> The <tt>@XmlTransient</tt> annotation can be used with the following
+ *     program elements:
+ * <ul>
+ *   <li> a JavaBean property </li>
+ *   <li> field </li>
+ * </ul>
+ *
+ * <p><tt>@XmlTransient</tt>is mutually exclusive with all other
+ * JAXB defined annotations. </p>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <p><b>Example:</b> Resolve name collision between JavaBean property and
+ *     field name </p>
+ *
+ * <pre>
+ *   // Example: Code fragment
+ *   public class USAddress {
+ *
+ *       // The field name "name" collides with the property name
+ *       // obtained by bean decapitalization of getName() below
+ *       &#64;XmlTransient public String name;
+ *
+ *       String getName() {..};
+ *       String setName() {..};
+ *   }
+ *
+ *
+ *   &lt;!-- Example: XML Schema fragment -->
+ *   &lt;xs:complexType name="USAddress">
+ *     &lt;xs:sequence>
+ *       &lt;xs:element name="name" type="xs:string"/>
+ *     &lt;/xs:sequence>
+ *   &lt;/xs:complexType>
+ * </pre>
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({FIELD, METHOD})
+public @interface XmlTransient {}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlType.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlType.java
new file mode 100644
index 0000000..b076f3e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlType.java
@@ -0,0 +1,452 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import static java.lang.annotation.ElementType.TYPE;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import java.lang.annotation.Target;
+
+/**
+ * <p>
+ * Maps a class or an enum type to a XML Schema type.
+ *
+ * <p><b>Usage</b></p>
+ * <p> The <tt>@XmlType</tt> annnotation can be used with the following program
+ * elements:
+ * <ul>
+ *   <li> a top level class </li>
+ *   <li> an enum type </li>
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * <h3> Mapping a Class </h3>
+ * <p>
+ * A class maps to a XML Schema type. A class is a data container for
+ * values represented by properties and fields. A schema type is a
+ * data container for values represented by schema components within a
+ * schema type's content model (e.g. model groups, attributes etc).
+ * <p> To be mapped, a class must either have a public no-arg
+ * constructor or a static no-arg factory method. The static factory
+ * method can be specified in <tt>factoryMethod()</tt> and
+ * <tt>factoryClass()</tt> annotation elements. The static factory
+ * method or the no-arg constructor is used during unmarshalling to
+ * create an instance of this class. If both are present, the static
+ * factory method overrides the no-arg constructor.
+ * <p>
+ * A class maps to either a XML Schema complex type or a XML Schema simple
+ * type. The XML Schema type is derived based on the
+ * mapping of JavaBean properties and fields contained within the
+ * class. The schema type to which the class is mapped can either be
+ * named or anonymous. A class can be mapped to an anonymous schema
+ * type by annotating the class with <tt>&#64XmlType(name="")</tt>.
+ * <p>
+ * Either a global element, local element or a local attribute can be
+ * associated with an anonymous type as follows:
+ * <ul>
+ *   <li><b>global element: </b> A global element of an anonymous
+ *      type can be derived by annotating the class with @{@link
+ *      XmlRootElement}. See Example 3 below. </li>
+ *
+ *   <li><b>local element: </b> A JavaBean property that references
+ *      a class annotated with @XmlType(name="") and is mapped to the
+ *      element associated with the anonymous type. See Example 4
+ *      below.</li>
+ *
+ *   <li><b>attribute: </b> A JavaBean property that references
+ *      a class annotated with @XmlType(name="") and is mapped to the
+ *      attribute associated with the anonymous type. See Example 5 below. </li>
+ * </ul>
+ * <b> Mapping to XML Schema Complex Type </b>
+ * <ul>
+ *   <li>If class is annotated with <tt>@XmlType(name="") </tt>, it
+ *   is mapped to an anonymous type otherwise, the class name maps
+ *   to a complex type name. The <tt>XmlName()</tt> annotation element
+ *   can be used to customize the name.</li>
+ *
+ *   <li> Properties and fields that are mapped to elements are mapped to a
+ *   content model within a complex type. The annotation element
+ *   <tt>propOrder()</tt> can be used to customize the content model to be
+ *   <tt>xs:all</tt> or <tt>xs:sequence</tt>.  It is used for specifying
+ *   the order of XML elements in <tt>xs:sequence</tt>. </li>
+ *
+ *   <li> Properties and fields can be mapped to attributes within the
+ *        complex type.  </li>
+ *
+ *   <li> The targetnamespace of the XML Schema type can be customized
+ *        using the annotation element <tt>namespace()</tt>. </li>
+ * </ul>
+ *
+ * <p>
+ * <b> Mapping class to XML Schema simple type </b>
+ * <p>
+ * A class can be mapped to a XML Schema simple type using the
+ * <tt>@XmlValue</tt> annotation. For additional details and examples,
+ * see @{@link XmlValue} annotation type.
+ * <p>
+ * The following table shows the mapping of the class to a XML Schema
+ * complex type or simple type. The notational symbols used in the table are:
+ * <ul>
+ *   <li> ->    : represents a mapping </li>
+ *   <li> [x]+  : one or more occurances of x </li>
+ *   <li> [ <tt>@XmlValue</tt> property ]: JavaBean property annotated with
+ *         <tt>@XmlValue</tt></li>
+ *   <li> X     : don't care
+ * </ul>
+ * <blockquote>
+ *   <table border="1" cellpadding="4" cellspacing="3">
+ *     <tbody>
+ *       <tr>
+ *         <td><b>Target</b></td>
+ *         <td><b>propOrder</b></td>
+ *         <td><b>ClassBody</b></td>
+ *         <td><b>ComplexType</b></td>
+ *         <td><b>SimpleType</b></td>
+ *       </tr>
+ *
+ *       <tr valign="top">
+ *         <td>Class</td>
+ *         <td>{}</td>
+ *         <td>[property]+ -> elements</td>
+ *         <td>complexcontent<br>xs:all</td>
+ *         <td> </td>
+ *       </tr>
+ *
+ *       <tr valign="top">
+ *         <td>Class</td>
+ *         <td>non empty</td>
+ *         <td>[property]+ -> elements</td>
+ *         <td>complexcontent<br>xs:sequence</td>
+ *         <td> </td>
+ *       </tr>
+ *
+ *       <tr valign="top">
+ *         <td>Class</td>
+ *         <td>X</td>
+ *         <td>no property -> element</td>
+ *         <td>complexcontent<br>empty sequence</td>
+ *         <td> </td>
+ *       </tr>
+ *
+ *       <tr valign="top">
+ *         <td>Class</td>
+ *         <td>X</td>
+ *         <td>1 [ <tt>@XmlValue</tt> property] && <br> [property]+
+ *             ->attributes</td>
+ *         <td>simplecontent</td>
+ *         <td> </td>
+ *       </tr>
+ *
+ *       <tr valign="top">
+ *         <td>Class</td>
+ *         <td>X</td>
+ *         <td>1 [ <tt>@XmlValue</tt> property ]&& <br> no properties
+ *         -> attribute</td>
+ *         <td> </td>
+ *         <td>simpletype</td>
+ *         <td> </td>
+ *       </tr>
+ *     </tbody>
+ *   </table>
+ * </blockquote>
+ *
+ * <h3> Mapping an enum type </h3>
+ *
+ * An enum type maps to a XML schema simple type with enumeration
+ * facets. The following annotation elements are ignored since they
+ * are not meaningful: <tt>propOrder()</tt> , <tt>factoryMethod()</tt> ,
+ * <tt>factoryClass()</tt> .
+ *
+ *  <h3> Usage with other annotations </h3>
+ * <p> This annotation can be used with the following annotations:
+ * {@link XmlRootElement}, {@link XmlAccessorOrder}, {@link XmlAccessorType},
+ * {@link XmlEnum}. However, {@link
+ * XmlAccessorOrder} and {@link XmlAccessorType} are ignored when this
+ * annotation is used on an enum type.
+ *
+ * <p> <b> Example 1: </b> Map a class to a complex type with
+ *   xs:sequence with a customized ordering of JavaBean properties.
+ * </p>
+ *
+ * <pre>
+ *   &#64;XmlType(propOrder={"street", "city" , "state", "zip", "name" })
+ *   public class USAddress {
+ *     String getName() {..};
+ *     void setName(String) {..};
+ *
+ *     String getStreet() {..};
+ *     void setStreet(String) {..};
+ *
+ *     String getCity() {..};
+ *     void setCity(String) {..};
+ *
+ *     String getState() {..};
+ *     void setState(String) {..};
+ *
+ *     java.math.BigDecimal getZip() {..};
+ *     void setZip(java.math.BigDecimal) {..};
+ *   }
+ *
+ *   &lt;!-- XML Schema mapping for USAddress -->
+ *   &lt;xs:complexType name="USAddress">
+ *     &lt;xs:sequence>
+ *       &lt;xs:element name="street" type="xs:string"/>
+ *       &lt;xs:element name="city" type="xs:string"/>
+ *       &lt;xs:element name="state" type="xs:string"/>
+ *       &lt;xs:element name="zip" type="xs:decimal"/>
+ *       &lt;xs:element name="name" type="xs:string"/>
+ *     &lt;/xs:all>
+ *   &lt;/xs:complexType>
+ * </pre>
+ * <p> <b> Example 2: </b> Map a class to a complex type with
+ *     xs:all </p>
+ * <pre>
+ * &#64;XmlType(propOrder={})
+ * public class USAddress { ...}
+ *
+ * &lt;!-- XML Schema mapping for USAddress -->
+ * &lt;xs:complexType name="USAddress">
+ *   &lt;xs:all>
+ *     &lt;xs:element name="name" type="xs:string"/>
+ *     &lt;xs:element name="street" type="xs:string"/>
+ *     &lt;xs:element name="city" type="xs:string"/>
+ *     &lt;xs:element name="state" type="xs:string"/>
+ *     &lt;xs:element name="zip" type="xs:decimal"/>
+ *   &lt;/xs:sequence>
+ * &lt;/xs:complexType>
+ *</pre>
+ * <p> <b> Example 3: </b> Map a class to a global element with an
+ * anonymous type.
+ * </p>
+ * <pre>
+ *   &#64;XmlRootElement
+ *   &#64;XmlType(name="")
+ *   public class USAddress { ...}
+ *
+ *   &lt;!-- XML Schema mapping for USAddress -->
+ *   &lt;xs:element name="USAddress">
+ *     &lt;xs:complexType>
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="name" type="xs:string"/>
+ *         &lt;xs:element name="street" type="xs:string"/>
+ *         &lt;xs:element name="city" type="xs:string"/>
+ *         &lt;xs:element name="state" type="xs:string"/>
+ *         &lt;xs:element name="zip" type="xs:decimal"/>
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexType>
+ *   &lt;/xs:element>
+ * </pre>
+ *
+ * <p> <b> Example 4: </b> Map a property to a local element with
+ * anonmyous type.
+ * <pre>
+ *   //Example: Code fragment
+ *   public class Invoice {
+ *       USAddress addr;
+ *           ...
+ *       }
+ *
+ *   &#64;XmlType(name="")
+ *   public class USAddress { ... }
+ *   }
+ *
+ *   &lt;!-- XML Schema mapping for USAddress -->
+ *   &lt;xs:complexType name="Invoice">
+ *     &lt;xs:sequence>
+ *       &lt;xs:element name="addr">
+ *         &lt;xs:complexType>
+ *           &lt;xs:element name="name", type="xs:string"/>
+ *           &lt;xs:element name="city", type="xs:string"/>
+ *           &lt;xs:element name="city" type="xs:string"/>
+ *           &lt;xs:element name="state" type="xs:string"/>
+ *           &lt;xs:element name="zip" type="xs:decimal"/>
+ *         &lt;/xs:complexType>
+ *       ...
+ *     &lt;/xs:sequence>
+ *   &lt;/xs:complexType>
+ * </pre>
+ *
+ * <p> <b> Example 5: </b> Map a property to an attribute with
+ * anonymous type.
+ *
+ * <pre>
+ *
+ *     //Example: Code fragment
+ *     public class Item {
+ *         public String name;
+ *         &#64;XmlAttribute
+ *         public USPrice price;
+ *     }
+ *
+ *     // map class to anonymous simple type.
+ *     &#64;XmlType(name="")
+ *     public class USPrice {
+ *         &#64;XmlValue
+ *         public java.math.BigDecimal price;
+ *     }
+ *
+ *     &lt;!-- Example: XML Schema fragment -->
+ *     &lt;xs:complexType name="Item">
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="name" type="xs:string"/>
+ *         &lt;xs:attribute name="price">
+ *           &lt;xs:simpleType>
+ *             &lt;xs:restriction base="xs:decimal"/>
+ *           &lt;/xs:simpleType>
+ *         &lt;/xs:attribute>
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexType>
+ * </pre>
+ *
+ *  <p> <b> Example 6: </b> Define a factoryClass and factoryMethod
+ *
+ * <pre>
+ *      &#64;XmlType(name="USAddressType", factoryClass=USAddressFactory.class,
+ *      factoryMethod="getUSAddress")
+ *      public class USAddress {
+ *
+ *          private String city;
+ *          private String name;
+ *          private String state;
+ *          private String street;
+ *          private int    zip;
+ *
+ *      public USAddress(String name, String street, String city,
+ *          String state, int zip) {
+ *          this.name = name;
+ *          this.street = street;
+ *          this.city = city;
+ *          this.state = state;
+ *          this.zip = zip;
+ *      }
+ *  }
+ *
+ *  public class USAddressFactory {
+ *      public static USAddress getUSAddress(){
+ *       return new USAddress("Mark Baker", "23 Elm St",
+ *          "Dayton", "OH", 90952);
+ *  }
+ *
+ * </pre>
+ *
+ *  <p> <b> Example 7: </b> Define factoryMethod and use the default factoryClass
+ *
+ * <pre>
+ *      &#64;XmlType(name="USAddressType", factoryMethod="getNewInstance")
+ *      public class USAddress {
+ *
+ *          private String city;
+ *          private String name;
+ *          private String state;
+ *          private String street;
+ *          private int    zip;
+ *
+ *          private USAddress() {}
+ *
+ *          public static USAddress getNewInstance(){
+ *              return new USAddress();
+ *          }
+ *      }
+ * </pre>
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @see XmlElement
+ * @see XmlAttribute
+ * @see XmlValue
+ * @see XmlSchema
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({TYPE})
+public @interface XmlType {
+    /**
+     * Name of the XML Schema type which the class is mapped.
+     */
+    String name() default "##default" ;
+
+    /**
+     * Specifies the order for XML Schema elements when class is
+     * mapped to a XML Schema complex type.
+     *
+     * <p> Refer to the table for how the propOrder affects the
+     * mapping of class </p>
+     *
+     * <p> The propOrder is a list of names of JavaBean properties in
+     *     the class. Each name in the list is the name of a Java
+     *     identifier of the JavaBean property. The order in which
+     *     JavaBean properties are listed is the order of XML Schema
+     *     elements to which the JavaBean properties are mapped. </p>
+     * <p> All of the JavaBean properties being mapped to XML Schema elements
+     *     must be listed.
+     * <p> A JavaBean property or field listed in propOrder must not
+     *     be transient or annotated with <tt>@XmlTransient</tt>.
+     * <p> The default ordering of JavaBean properties is determined
+     *     by @{@link XmlAccessorOrder}.
+     */
+    String[] propOrder() default {""};
+
+    /**
+     * Name of the target namespace of the XML Schema type. By
+     * default, this is the target namespace to which the package
+     * containing the class is mapped.
+     */
+    String namespace() default "##default" ;
+
+    /**
+     * Class containing a no-arg factory method for creating an
+     * instance of this class. The default is this class.
+     *
+     * <p>If <tt>factoryClass</tt> is DEFAULT.class and
+     * <tt>factoryMethod</tt> is "", then there is no static factory
+     * method.
+     *
+     * <p>If <tt>factoryClass</tt> is DEFAULT.class and
+     * <tt>factoryMethod</tt> is not "", then
+     * <tt>factoryMethod</tt> is the name of a static factory method
+     * in this class.
+     *
+     * <p>If <tt>factoryClass</tt> is not DEFAULT.class, then
+     * <tt>factoryMethod</tt> must not be "" and must be the name of
+     * a static factory method specified in <tt>factoryClass</tt>.
+     */
+    Class factoryClass() default DEFAULT.class;
+
+    /**
+     * Used in {@link XmlType#factoryClass()} to
+     * signal that either factory mehod is not used or
+     * that it's in the class with this {@link XmlType} itself.
+     */
+    static final class DEFAULT {}
+
+    /**
+     * Name of a no-arg factory method in the class specified in
+     * <tt>factoryClass</tt> factoryClass().
+     *
+     */
+    String factoryMethod() default "";
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/XmlValue.java b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlValue.java
new file mode 100644
index 0000000..9dbcd52
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/XmlValue.java
@@ -0,0 +1,131 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation;
+
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * <p>
+ * Enables mapping a class to a  XML Schema complex type with a
+ * simpleContent or a XML Schema simple type.
+ * </p>
+ *
+ * <p>
+ * <b> Usage: </b>
+ * <p>
+ * The <tt>@XmlValue</tt> annotation can be used with the following program
+ * elements:
+ * <ul>
+ *   <li> a JavaBean property.</li>
+ *   <li> non static, non transient field.</li>
+ * </ul>
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * The usage is subject to the following usage constraints:
+ * <ul>
+ *   <li>At most one field or property can be annotated with the
+ *       <tt>@XmlValue</tt> annotation. </li>
+ *
+ *   <li><tt>@XmlValue</tt> can be used with the following
+ *   annotations: {@link XmlList}. However this is redundant since
+ *   {@link XmlList} maps a type to a simple schema type that derives by
+ *   list just as {@link XmlValue} would. </li>
+ *
+ *   <li>If the type of the field or property is a collection type,
+ *       then the collection item type must map to a simple schema
+ *       type.  </li>
+ *
+ *   <li>If the type of the field or property is not a collection
+ *       type, then the type must map to a XML Schema simple type. </li>
+ *
+ * </ul>
+ * </p>
+ * <p>
+ * If the annotated JavaBean property is the sole class member being
+ * mapped to XML Schema construct, then the class is mapped to a
+ * simple type.
+ *
+ * If there are additional JavaBean properties (other than the
+ * JavaBean property annotated with <tt>@XmlValue</tt> annotation)
+ * that are mapped to XML attributes, then the class is mapped to a
+ * complex type with simpleContent.
+ * </p>
+ *
+ * <p> <b> Example 1: </b> Map a class to XML Schema simpleType</p>
+ *
+ *   <pre>
+ *
+ *     // Example 1: Code fragment
+ *     public class USPrice {
+ *         &#64;XmlValue
+ *         public java.math.BigDecimal price;
+ *     }
+ *
+ *     &lt;!-- Example 1: XML Schema fragment -->
+ *     &lt;xs:simpleType name="USPrice">
+ *       &lt;xs:restriction base="xs:decimal"/>
+ *     &lt;/xs:simpleType>
+ *
+ *   </pre>
+ *
+ * <p><b> Example 2: </b> Map a class to XML Schema complexType with
+ *        with simpleContent.</p>
+ *
+ *   <pre>
+ *
+ *   // Example 2: Code fragment
+ *   public class InternationalPrice {
+ *       &#64;XmlValue
+ *       public java.math.BigDecimal price;
+ *
+ *       &#64;XmlAttribute
+ *       public String currency;
+ *   }
+ *
+ *   &lt;!-- Example 2: XML Schema fragment -->
+ *   &lt;xs:complexType name="InternationalPrice">
+ *     &lt;xs:simpleContent>
+ *       &lt;xs:extension base="xs:decimal">
+ *         &lt;xs:attribute name="currency" type="xs:string"/>
+ *       &lt;/xs:extension>
+ *     &lt;/xs:simpleContent>
+ *   &lt;/xs:complexType>
+ *
+ *   </pre>
+ * </p>
+ *
+ * @author Sekhar Vajjhala, Sun Microsystems, Inc.
+ * @see XmlType
+ * @since JAXB2.0
+ */
+
+@Retention(RUNTIME) @Target({FIELD, METHOD})
+public @interface XmlValue {}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/CollapsedStringAdapter.java b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/CollapsedStringAdapter.java
new file mode 100644
index 0000000..2c2b99c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/CollapsedStringAdapter.java
@@ -0,0 +1,119 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation.adapters;
+
+
+
+/**
+ * Built-in {@link XmlAdapter} to handle <tt>xs:token</tt> and its derived types.
+ *
+ * <p>
+ * This adapter removes leading and trailing whitespaces, then truncate any
+ * sequnce of tab, CR, LF, and SP by a single whitespace character ' '.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB 2.0
+ */
+public class CollapsedStringAdapter extends XmlAdapter<String,String> {
+    /**
+     * Removes leading and trailing whitespaces of the string
+     * given as the parameter, then truncate any
+     * sequnce of tab, CR, LF, and SP by a single whitespace character ' '.
+     */
+    public String unmarshal(String text) {
+        if(text==null)  return null;        // be defensive
+
+        int len = text.length();
+
+        // most of the texts are already in the collapsed form.
+        // so look for the first whitespace in the hope that we will
+        // never see it.
+        int s=0;
+        while(s<len) {
+            if(isWhiteSpace(text.charAt(s)))
+                break;
+            s++;
+        }
+        if(s==len)
+            // the input happens to be already collapsed.
+            return text;
+
+        // we now know that the input contains spaces.
+        // let's sit down and do the collapsing normally.
+
+        StringBuffer result = new StringBuffer(len /*allocate enough size to avoid re-allocation*/ );
+
+        if(s!=0) {
+            for( int i=0; i<s; i++ )
+                result.append(text.charAt(i));
+            result.append(' ');
+        }
+
+        boolean inStripMode = true;
+        for (int i = s+1; i < len; i++) {
+            char ch = text.charAt(i);
+            boolean b = isWhiteSpace(ch);
+            if (inStripMode && b)
+                continue; // skip this character
+
+            inStripMode = b;
+            if (inStripMode)
+                result.append(' ');
+            else
+                result.append(ch);
+        }
+
+        // remove trailing whitespaces
+        len = result.length();
+        if (len > 0 && result.charAt(len - 1) == ' ')
+            result.setLength(len - 1);
+        // whitespaces are already collapsed,
+        // so all we have to do is to remove the last one character
+        // if it's a whitespace.
+
+        return result.toString();
+    }
+
+    /**
+     * No-op.
+     *
+     * Just return the same string given as the parameter.
+     */
+    public String marshal(String s) {
+        return s;
+    }
+
+
+    /** returns true if the specified char is a white space character. */
+    protected static boolean isWhiteSpace(char ch) {
+        // most of the characters are non-control characters.
+        // so check that first to quickly return false for most of the cases.
+        if( ch>0x20 )   return false;
+
+        // other than we have to do four comparisons.
+        return ch == 0x9 || ch == 0xA || ch == 0xD || ch == 0x20;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/HexBinaryAdapter.java b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/HexBinaryAdapter.java
new file mode 100644
index 0000000..83df577
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/HexBinaryAdapter.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation.adapters;
+
+import javax.xml.bind.DatatypeConverter;
+
+/**
+ * {@link XmlAdapter} for <tt>xs:hexBinary</tt>.
+ *
+ * <p>
+ * This {@link XmlAdapter} binds <tt>byte[]</tt> to the hexBinary representation in XML.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB 2.0
+ */
+public final class HexBinaryAdapter extends XmlAdapter<String,byte[]> {
+    public byte[] unmarshal(String s) {
+        return DatatypeConverter.parseHexBinary(s);
+    }
+
+    public String marshal(byte[] bytes) {
+        return DatatypeConverter.printHexBinary(bytes);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/NormalizedStringAdapter.java b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/NormalizedStringAdapter.java
new file mode 100644
index 0000000..aa3d05d
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/NormalizedStringAdapter.java
@@ -0,0 +1,93 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation.adapters;
+
+
+
+/**
+ * {@link XmlAdapter} to handle <tt>xs:normalizedString</tt>.
+ *
+ * <p>
+ * This adapter removes leading and trailing whitespaces, then replace
+ * any tab, CR, and LF by a whitespace character ' '.
+ *
+ * @author Kohsuke Kawaguchi
+ * @since JAXB 2.0
+ */
+public final class NormalizedStringAdapter extends XmlAdapter<String,String> {
+    /**
+     * Removes leading and trailing whitespaces of the string
+     * given as the parameter, then replace
+     * any tab, CR, and LF by a whitespace character ' '.
+     */
+    public String unmarshal(String text) {
+        if(text==null)      return null;    // be defensive
+
+        int i=text.length()-1;
+
+        // look for the first whitespace char.
+        while( i>=0 && !isWhiteSpaceExceptSpace(text.charAt(i)) )
+            i--;
+
+        if( i<0 )
+            // no such whitespace. replace(text)==text.
+            return text;
+
+        // we now know that we need to modify the text.
+        // allocate a char array to do it.
+        char[] buf = text.toCharArray();
+
+        buf[i--] = ' ';
+        for( ; i>=0; i-- )
+            if( isWhiteSpaceExceptSpace(buf[i]))
+                buf[i] = ' ';
+
+        return new String(buf);
+    }
+
+    /**
+     * No-op.
+     *
+     * Just return the same string given as the parameter.
+     */
+        public String marshal(String s) {
+            return s;
+        }
+
+
+    /**
+     * Returns true if the specified char is a white space character
+     * but not 0x20.
+     */
+    protected static boolean isWhiteSpaceExceptSpace(char ch) {
+        // most of the characters are non-control characters.
+        // so check that first to quickly return false for most of the cases.
+        if( ch>=0x20 )   return false;
+
+        // other than we have to do four comparisons.
+        return ch == 0x9 || ch == 0xA || ch == 0xD;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlAdapter.java b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlAdapter.java
new file mode 100644
index 0000000..3fc3e09
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlAdapter.java
@@ -0,0 +1,196 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation.adapters;
+
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.Marshaller;
+
+/**
+ * Adapts a Java type for custom marshaling.
+ *
+ * <p> <b> Usage: </b> </p>
+ *
+ * <p>
+ * Some Java types do not map naturally to a XML representation, for
+ * example <tt>HashMap</tt> or other non JavaBean classes. Conversely,
+ * a XML repsentation may map to a Java type but an application may
+ * choose to accesss the XML representation using another Java
+ * type. For example, the schema to Java binding rules bind
+ * xs:DateTime by default to XmlGregorianCalendar. But an application
+ * may desire to bind xs:DateTime to a custom type,
+ * MyXmlGregorianCalendar, for example. In both cases, there is a
+ * mismatch between <i> bound type </i>, used by an application to
+ * access XML content and the <i> value type</i>, that is mapped to an
+ * XML representation.
+ *
+ * <p>
+ * This abstract class defines methods for adapting a bound type to a value
+ * type or vice versa. The methods are invoked by the JAXB binding
+ * framework during marshaling and unmarshalling:
+ *
+ * <ul>
+ *   <li> <b> XmlAdapter.marshal(...): </b> During marshalling, JAXB
+ *        binding framework invokes XmlAdapter.marshal(..) to adapt a
+ *        bound type to value type, which is then marshaled to XML
+ *        representation. </li>
+ *
+ *   <li> <b> XmlAdapter.unmarshal(...): </b> During unmarshalling,
+ *        JAXB binding framework first unmarshals XML representation
+ *        to a value type and then invokes XmlAdapter.unmarshal(..) to
+ *        adapt the value type to a bound type. </li>
+ * </ul>
+ *
+ * Writing an adapter therefore involves the following steps:
+ *
+ * <ul>
+ *   <li> Write an adapter that implements this abstract class. </li>
+ *   <li> Install the adapter using the annotation {@link
+ *        XmlJavaTypeAdapter} </li>
+ * </ul>
+ *
+ * <p><b>Example:</b> Customized mapping of <tt>HashMap</tt></p>
+ * <p> The following example illustrates the use of
+ * <tt>&#64;XmlAdapter</tt> and <tt>&#64;XmlJavaTypeAdapter</tt> to
+ * customize the mapping of a <tt>HashMap</tt>.
+ *
+ * <p> <b> Step 1: </b> Determine the desired XML representation for HashMap.
+ *
+ * <pre>
+ *     &lt;hashmap>
+ *         &lt;entry key="id123">this is a value&lt;/entry>
+ *         &lt;entry key="id312">this is another value&lt;/entry>
+ *         ...
+ *       &lt;/hashmap>
+ * </pre>
+ *
+ * <p> <b> Step 2: </b> Determine the schema definition that the
+ * desired XML representation shown above should follow.
+ *
+ * <pre>
+ *
+ *     &lt;xs:complexType name="myHashMapType">
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="entry" type="myHashMapEntryType"
+ *                        minOccurs = "0" maxOccurs="unbounded"/>
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexType>
+ *
+ *     &lt;xs:complexType name="myHashMapEntryType">
+ *       &lt;xs:simpleContent>
+ *         &lt;xs:extension base="xs:string">
+ *           &lt;xs:attribute name="key" type="xs:int"/>
+ *         &lt;/xs:extension>
+ *       &lt;/xs:simpleContent>
+ *     &lt;/xs:complexType>
+ *
+ * </pre>
+ *
+ * <p> <b> Step 3: </b> Write value types that can generate the above
+ * schema definition.
+ *
+ * <pre>
+ *     public class MyHashMapType {
+ *         List&lt;MyHashMapEntryType> entry;
+ *     }
+ *
+ *     public class MyHashMapEntryType {
+ *         &#64;XmlAttribute
+ *         public Integer key;
+ *
+ *         &#64;XmlValue
+ *         public String value;
+ *     }
+ * </pre>
+ *
+ * <p> <b> Step 4: </b> Write the adapter that adapts the value type,
+ * MyHashMapType to a bound type, HashMap, used by the application.
+ *
+ * <pre>
+ *     public final class MyHashMapAdapter extends
+ *                        XmlAdapter&lt;HashMap, MyHashMapType> { ... }
+ *
+ * </pre>
+ *
+ * <p> <b> Step 5: </b> Use the adapter.
+ *
+ * <pre>
+ *     public class Foo {
+ *         &#64;XmlJavaTypeAdapter(MyHashMapAdapter.class)
+ *         HashMap hashmap;
+ *         ...
+ *     }
+ * </pre>
+ *
+ * The above code fragment will map to the following schema:
+ *
+ * <pre>
+ *     &lt;xs:complexType name="Foo">
+ *       &lt;xs:sequence>
+ *         &lt;xs:element name="hashmap" type="myHashMapType"
+ *       &lt;/xs:sequence>
+ *     &lt;/xs:complexType>
+ * </pre>
+ *
+ * @param <BoundType>
+ *      The type that JAXB doesn't know how to handle. An adapter is written
+ *      to allow this type to be used as an in-memory representation through
+ *      the <tt>ValueType</tt>.
+ * @param <ValueType>
+ *      The type that JAXB knows how to handle out of the box.
+ *
+ * @author <ul><li>Sekhar Vajjhala, Sun Microsystems Inc.</li> <li> Kohsuke Kawaguchi, Sun Microsystems Inc.</li></ul>
+ * @see XmlJavaTypeAdapter
+ * @since JAXB 2.0
+ */
+public abstract class XmlAdapter<ValueType,BoundType> {
+
+    /**
+     * Do-nothing constructor for the derived classes.
+     */
+    protected XmlAdapter() {}
+
+    /**
+     * Convert a value type to a bound type.
+     *
+     * @param v
+     *      The value to be converted. Can be null.
+     * @throws Exception
+     *      if there's an error during the conversion. The caller is responsible for
+     *      reporting the error to the user through {@link javax.xml.bind.ValidationEventHandler}.
+     */
+    public abstract BoundType unmarshal(ValueType v) throws Exception;
+
+    /**
+     * Convert a bound type to a value type.
+     *
+     * @param v
+     *      The value to be convereted. Can be null.
+     * @throws Exception
+     *      if there's an error during the conversion. The caller is responsible for
+     *      reporting the error to the user through {@link javax.xml.bind.ValidationEventHandler}.
+     */
+    public abstract ValueType marshal(BoundType v) throws Exception;
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlJavaTypeAdapter.java b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlJavaTypeAdapter.java
new file mode 100644
index 0000000..044cb0d
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlJavaTypeAdapter.java
@@ -0,0 +1,116 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation.adapters;
+
+import javax.xml.bind.annotation.XmlAnyElement;
+import javax.xml.bind.annotation.XmlElementRefs;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlSchemaType;
+import javax.xml.bind.annotation.XmlElementRef;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlSchema;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlSchemaTypes;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import static java.lang.annotation.ElementType.FIELD;
+import static java.lang.annotation.ElementType.METHOD;
+import static java.lang.annotation.ElementType.TYPE;
+import static java.lang.annotation.ElementType.PARAMETER;
+import static java.lang.annotation.ElementType.PACKAGE;
+
+
+/**
+ * Use an adapter that implements {@link XmlAdapter} for custom marshaling.
+ *
+ * <p> <b> Usage: </b> </p>
+ *
+ * <p> The <tt>@XmlJavaTypeAdapter</tt> annotation can be used with the
+ * following program elements:
+ * <ul>
+ *   <li> a JavaBean property </li>
+ *   <li> field </li>
+ *   <li> parameter </li>
+ *   <li> package </li>
+ *   <li> from within {@link XmlJavaTypeAdapters} </li>
+ * </ul>
+ *
+ * <p> When <tt>@XmlJavaTypeAdapter</tt> annotation is defined on a
+ * class, it applies to all references to the class.
+ * <p> When <tt>@XmlJavaTypeAdapter</tt> annotation is defined at the
+ * package level it applies to all references from within the package
+ * to <tt>@XmlJavaTypeAdapter.type()</tt>.
+ * <p> When <tt>@XmlJavaTypeAdapter</tt> annotation is defined on the
+ * field, property or parameter, then the annotation applies to the
+ * field, property or the parameter only.
+ * <p> A <tt>@XmlJavaTypeAdapter</tt> annotation on a field, property
+ * or parameter overrides the <tt>@XmlJavaTypeAdapter</tt> annotation
+ * associated with the class being referenced by the field, property
+ * or parameter.
+ * <p> A <tt>@XmlJavaTypeAdapter</tt> annotation on a class overrides
+ * the <tt>@XmlJavaTypeAdapter</tt> annotation specified at the
+ * package level for that class.
+ *
+ * <p>This annotation can be used with the following other annotations:
+ * {@link XmlElement}, {@link XmlAttribute}, {@link XmlElementRef},
+ * {@link XmlElementRefs}, {@link XmlAnyElement}. This can also be
+ * used at the package level with the following annotations:
+ * {@link XmlAccessorType}, {@link XmlSchema}, {@link XmlSchemaType},
+ * {@link XmlSchemaTypes}.
+ *
+ * <p><b> Example: </b> See example in {@link XmlAdapter}
+ *
+ * @author <ul><li>Sekhar Vajjhala, Sun Microsystems Inc.</li> <li> Kohsuke Kawaguchi, Sun Microsystems Inc.</li></ul>
+ * @since JAXB2.0
+ * @see XmlAdapter
+ */
+
+@Retention(RUNTIME) @Target({PACKAGE,FIELD,METHOD,TYPE,PARAMETER})
+public @interface XmlJavaTypeAdapter {
+    /**
+     * Points to the clsss that converts a value type to a bound type or vice versa.
+     * See {@link XmlAdapter} for more details.
+     */
+    Class<? extends XmlAdapter> value();
+
+    /**
+     * If this annotation is used at the package level, then value of
+     * the type() must be specified.
+     */
+
+    Class type() default DEFAULT.class;
+
+    /**
+     * Used in {@link XmlJavaTypeAdapter#type()} to
+     * signal that the type be inferred from the signature
+     * of the field, property, parameter or the class.
+     */
+
+    static final class DEFAULT {}
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlJavaTypeAdapters.java b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlJavaTypeAdapters.java
new file mode 100644
index 0000000..d74cb22
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/XmlJavaTypeAdapters.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.annotation.adapters;
+
+import static java.lang.annotation.ElementType.PACKAGE;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.RetentionPolicy.RUNTIME;
+import java.lang.annotation.Target;
+
+/**
+ * <p>
+ * A container for multiple @{@link XmlJavaTypeAdapter} annotations.
+ *
+ * <p> Multiple annotations of the same type are not allowed on a program
+ * element. This annotation therefore serves as a container annotation
+ * for multiple &#64;XmlJavaTypeAdapter as follows:
+ *
+ * <pre>
+ * &#64;XmlJavaTypeAdapters ({ @XmlJavaTypeAdapter(...),@XmlJavaTypeAdapter(...) })
+ * </pre>
+ *
+ * <p>The <tt>@XmlJavaTypeAdapters</tt> annnotation is useful for
+ * defining {@link XmlJavaTypeAdapter} annotations for different types
+ * at the package level.
+ *
+ * <p>See "Package Specification" in javax.xml.bind.package javadoc for
+ * additional common information.</p>
+ *
+ * @author <ul><li>Sekhar Vajjhala, Sun Microsystems, Inc.</li></ul>
+ * @see XmlJavaTypeAdapter
+ * @since JAXB2.0
+ */
+@Retention(RUNTIME) @Target({PACKAGE})
+public @interface XmlJavaTypeAdapters {
+    /**
+     * Collection of @{@link XmlJavaTypeAdapter} annotations
+     */
+    XmlJavaTypeAdapter[] value();
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/package.html b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/package.html
new file mode 100644
index 0000000..c264668
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/adapters/package.html
@@ -0,0 +1,56 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
+<html>
+    <head>
+        <!--
+Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+This code is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License version 2 only, as
+published by the Free Software Foundation.  Sun designates this
+particular file as subject to the "Classpath" exception as provided
+by Sun in the LICENSE file that accompanied this code.
+
+This code is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+version 2 for more details (a copy is included in the LICENSE file that
+accompanied this code).
+
+You should have received a copy of the GNU General Public License version
+2 along with this work; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+CA 95054 USA or visit www.sun.com if you need additional information or
+have any questions.
+        -->
+    </head>
+
+    <body>
+        <p>
+        {@link javax.xml.bind.annotation.adapters.XmlAdapter} and its spec-defined
+        sub-classes to allow arbitrary Java classes to be used with JAXB.
+
+        <h2>Package Specification</h2>
+
+        <ul>
+            <li><a href="http://java.sun.com/xml/downloads/jaxb.html">JAXB
+                Specification</a>
+        </ul>
+
+        <h2>Related Documentation</h2>
+
+        For overviews, tutorials, examples, guides, and tool documentation,
+        please see:
+        <ul>
+            <li>The <a href="http://java.sun.com/xml/jaxb/index.html">JAXB
+            Website</a>
+        </ul>
+
+        <!-- Put @see and @since tags down here. -->
+
+    </body>
+</html>
+
+
diff --git a/jaxws/src/share/classes/javax/xml/bind/annotation/package.html b/jaxws/src/share/classes/javax/xml/bind/annotation/package.html
new file mode 100644
index 0000000..ea022a7
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/annotation/package.html
@@ -0,0 +1,284 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
+<html>
+    <head>
+        <!--
+Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+This code is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License version 2 only, as
+published by the Free Software Foundation.  Sun designates this
+particular file as subject to the "Classpath" exception as provided
+by Sun in the LICENSE file that accompanied this code.
+
+This code is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+version 2 for more details (a copy is included in the LICENSE file that
+accompanied this code).
+
+You should have received a copy of the GNU General Public License version
+2 along with this work; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+CA 95054 USA or visit www.sun.com if you need additional information or
+have any questions.
+
+        -->
+    </head>
+
+    <body bgcolor="white">
+
+        <p>
+        Defines annotations for customizing Java program elements to XML Schema mapping.
+
+        <h2>Package Specification</h2>
+        <p>The following table shows the JAXB mapping annotations
+           that can be associated with each program element. </p>
+
+        <table border="1" cellpadding="4" cellspacing="3"> 
+          <tbody>
+            <tr>
+              <td><b>Program Element</td>
+              <td><b>JAXB annotation</b></td>
+            </tr>
+            <tr valign="top">
+              <td><b>Package</td>
+              <td>
+                <table>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAccessorOrder.html">XmlAccessorOrder</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAccessorType.html">XmlAccessorType</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlSchema.html">XmlSchema</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlSchemaType.html">XmlSchemaType</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlSchemaTypes.html">XmlSchemaTypes</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/adapters/XmlJavaTypeAdapter.html">XmlJavaTypeAdapter</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/adapters/XmlJavaTypeAdapters.html">XmlJavaTypeAdapters</b></td>
+                  </tr>
+                </table>
+              </td>
+            </tr>
+
+            <tr valign="top">
+              <td><b>Class</td>
+              <td>
+                <table> 
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAccessorOrder.html">XmlAccessorOrder</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAccessorType.html">XmlAccessorType</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlInlineBinaryData.html">XmlInlineBinaryData</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlRootElement.html">XmlRootElement</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlType.html">XmlType</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/adapters/XmlJavaTypeAdapter.html">XmlJavaTypeAdapter</b></td>
+                  </tr>
+                </table>
+              </td>
+            </tr>
+
+            <tr valign="top">
+              <td><b>Enum type</td>
+              <td>
+                <table> 
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlEnum.html">XmlEnum</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlEnumValue.html">XmlEnumValue (enum constant only)</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlRootElement.html">XmlRootElement</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlType.html">XmlType</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/adapters/XmlJavaTypeAdapter.html">XmlJavaTypeAdapter</b></td>
+                  </tr>
+                </table>
+              </td>
+            </tr>
+
+            <tr valign="top">
+              <td><b>JavaBean Property/field</td>
+              <td>
+                <table> 
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlElement.html">XmlElement</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlElements.html">XmlElements</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlElementRef.html">XmlElementRef</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlElementRefs.html">XmlElementRefs</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlElementWrapper.html">XmlElementWrapper</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAnyElement.html">XmlAnyElement</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAttribute.html">XmlAttribute</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAnyAttribute.html">XmlAnyAttribute</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlTransient.html">XmlTransient</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlValue.html">XmlValue</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlID.html">XmlID</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlIDREF.html">XmlIDREF</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlList.html">XmlList</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlMixed.html">XmlMixed</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlMimeType.html">XmlMimeType</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAttachmentRef.html">XmlAttachmentRef</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlInlineBinaryData.html">XmlInlineBinaryData</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlElementDecl.html">XmlElementDecl (only on method)</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/adapters/XmlJavaTypeAdapter.html">XmlJavaTypeAdapter</b></td>
+                  </tr>
+                </table>
+              </td>
+            </tr>
+
+            <tr valign="top">
+              <td><b>Parameter</td>
+              <td>
+                <table> 
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlList.html">XmlList</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlAttachmentRef.html">XmlAttachmentRef</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/XmlMimeType.html">XmlMimeType</b></td>
+                  </tr>
+                  <tr valign="top">
+                    <td><b><a HREF="../../../../javax/xml/bind/annotation/adapters/XmlJavaTypeAdapter.html">XmlJavaTypeAdapter</b></td>
+                  </tr>
+                </table>
+              </td>
+            </tr>
+
+          </tbody>
+        </table>
+        <h3>Terminology</h3> 
+          <p>
+          <b>JavaBean property and field:</b> For the purposes of
+          mapping, there is no semantic difference between a field and
+          a JavaBean property. Thus, an annotation that can be applied
+          to a JavaBean property can always be applied to a
+          field. Hence in the Javadoc documentation, for brevity, the
+          term JavaBean property or property is used to mean either JavaBean
+          property or a field. Where required, both are explicitly
+          mentioned.
+          <p>
+          <b>top level class:</b> For the purpose of mapping, there is
+          no semantic difference between a top level class and a
+          static nested class. Thus, an annotation that can be applied
+          to a top level class, can always be applied to a nested
+          static class. Hence in the Javadoc documentation, for
+          brevity, the term "top level class" or just class is used to
+          mean either a top level class or a nested static
+          class.
+          <p>
+          <b>mapping annotation:</b>A JAXB 2.0 defined program
+          annotation based on the JSR 175 programming annotation
+          facility.
+         <h3>Common Usage Constraints</h3>
+          <p>The following usage constraints are defined here since
+          they apply to more than annotation:
+          <ul>
+            <li> For a property, a given annotation can be applied to
+                 either read or write property but not both. </li>
+    
+            <li> A property name must be different from any other
+                 property name in any of the super classes of the
+                 class being mapped. </li>
+ 
+            <li> A mapped field name or the decapitalized name of a
+                 mapped property must be unique within a class. </li>
+          </ul>
+         <h3>Notations</h3>
+         <b>Namespace prefixes</b> 
+         <p>The following namespace prefixes are used in the XML Schema
+           fragments in this package.<p>
+    
+        <table border="1" cellpadding="4" cellspacing="3">
+          <tbody>
+            <tr>
+              <td><b>Prefix</td>
+              <td><b>Namespace</b></td>
+              <td><b>Notes</b></td>
+           </tr>
+ 
+           <tr valign="top">
+             <td>xs</td>
+             <td>http://www.w3.org/2001/XMLSchema</td>
+             <td>Namespace of XML Schema namespace</td>
+           </tr>
+           <tr valign="top">
+             <td>ref</td>
+             <td>http://ws-i.org/profiles/basic/1.1/xsd</td>
+             <td>Namespace for swaref schema component</td>
+           </tr>
+           <tr valign="top">
+             <td>xsi</td>
+             <td>http://www.w3.org/2001/XMLSchema-instance</td>
+             <td>XML Schema namespace for instances</td>
+           </tr>
+          </tbody>
+        </table>
+
+        <!-- Put @see and @since tags down here. -->
+        @since JAXB 2.0
+    </body>
+</html>
+
+
diff --git a/jaxws/src/share/classes/javax/xml/bind/attachment/AttachmentMarshaller.java b/jaxws/src/share/classes/javax/xml/bind/attachment/AttachmentMarshaller.java
new file mode 100644
index 0000000..a415b39
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/attachment/AttachmentMarshaller.java
@@ -0,0 +1,200 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.attachment;
+
+import javax.activation.DataHandler;
+import javax.xml.bind.Marshaller;
+
+/**
+ * <p>Enable JAXB marshalling to optimize storage of binary data.</p>
+ *
+ * <p>This API enables an efficient cooperative creation of optimized
+ * binary data formats between a JAXB marshalling process and a MIME-based package
+ * processor. A JAXB implementation marshals the root body of a MIME-based package,
+ * delegating the creation of referenceable MIME parts to
+ * the MIME-based package processor that implements this abstraction.</p>
+ *
+ * <p>XOP processing is enabled when {@link #isXOPPackage()} is true.
+ *    See {@link #addMtomAttachment(DataHandler, String, String)} for details.
+ * </p>
+ *
+ * <p>WS-I Attachment Profile 1.0 is supported by
+ * {@link #addSwaRefAttachment(DataHandler)} being called by the
+ * marshaller for each JAXB property related to
+ * {http://ws-i.org/profiles/basic/1.1/xsd}swaRef.</p>
+ *
+ *
+ * @author Marc Hadley
+ * @author Kohsuke Kawaguchi
+ * @author Joseph Fialli
+ * @since JAXB 2.0
+ *
+ * @see Marshaller#setAttachmentMarshaller(AttachmentMarshaller)
+ *
+ * @see <a href="http://www.w3.org/TR/2005/REC-xop10-20050125/">XML-binary Optimized Packaging</a>
+ * @see <a href="http://www.ws-i.org/Profiles/AttachmentsProfile-1.0-2004-08-24.html">WS-I Attachments Profile Version 1.0.</a>
+ */
+public abstract class AttachmentMarshaller {
+
+    /**
+     * <p>Consider MIME content <code>data</code> for optimized binary storage as an attachment.
+     *
+     * <p>
+     * This method is called by JAXB marshal process when {@link #isXOPPackage()} is
+     * <code>true</code>, for each element whose datatype is "base64Binary", as described in
+     * Step 3 in
+     * <a href="http://www.w3.org/TR/2005/REC-xop10-20050125/#creating_xop_packages">Creating XOP Packages</a>.
+     *
+     * <p>
+     * The method implementor determines whether <code>data</code> shall be attached separately
+     * or inlined as base64Binary data. If the implementation chooses to optimize the storage
+     * of the binary data as a MIME part, it is responsible for attaching <code>data</code> to the
+     * MIME-based package, and then assigning an unique content-id, cid, that identifies
+     * the MIME part within the MIME message. This method returns the cid,
+     * which enables the JAXB marshaller to marshal a XOP element that refers to that cid in place
+     * of marshalling the binary data. When the method returns null, the JAXB marshaller
+     * inlines <code>data</code> as base64binary data.
+     *
+     * <p>
+     * The caller of this method is required to meet the following constraint.
+     * If the element infoset item containing <code>data</code> has the attribute
+     * <code>xmime:contentType</code> or if the JAXB property/field representing
+     * <code>data</code>is annotated with a known MIME type,
+     * <code>data.getContentType()</code> should be set to that MIME type.
+     *
+     * <p>
+     * The <code>elementNamespace</code> and <code>elementLocalName</code>
+     * parameters provide the
+     * context that contains the binary data. This information could
+     * be used by the MIME-based package processor to determine if the
+     * binary data should be inlined or optimized as an attachment.
+     *
+     * @param data
+     *       represents the data to be attached. Must be non-null.
+     * @param elementNamespace
+     *      the namespace URI of the element that encloses the base64Binary data.
+     *      Can be empty but never null.
+     * @param elementLocalName
+     *      The local name of the element. Always a non-null valid string.
+     *
+     * @return
+     *     a valid content-id URI (see <a href="http://www.w3.org/TR/xop10/#RFC2387">RFC 2387</a>) that identifies the attachment containing <code>data</code>.
+     *     Otherwise, null if the attachment was not added and should instead be inlined in the message.
+     *
+     * @see <a href="http://www.w3.org/TR/2005/REC-xop10-20050125/">XML-binary Optimized Packaging</a>
+     * @see <a href="http://www.w3.org/TR/xml-media-types/">Describing Media Content of Binary Data in XML</a>
+     */
+    public abstract String addMtomAttachment(DataHandler data, String elementNamespace, String elementLocalName);
+
+    /**
+     * <p>Consider binary <code>data</code> for optimized binary storage as an attachment.
+     *
+     * <p>Since content type is not known, the attachment's MIME content type must be set to "application/octet-stream".</p>
+     *
+     * <p>
+     * The <code>elementNamespace</code> and <code>elementLocalName</code>
+     * parameters provide the
+     * context that contains the binary data. This information could
+     * be used by the MIME-based package processor to determine if the
+     * binary data should be inlined or optimized as an attachment.
+     *
+     * @param data
+     *      represents the data to be attached. Must be non-null. The actual data region is
+     *      specified by <tt>(data,offset,length)</tt> tuple.
+     *
+     * @param offset
+     *       The offset within the array of the first byte to be read;
+     *       must be non-negative and no larger than array.length
+     *
+     * @param length
+     *       The number of bytes to be read from the given array;
+     *       must be non-negative and no larger than array.length
+     *
+     * @param mimeType
+     *      If the data has an associated MIME type known to JAXB, that is passed
+     *      as this parameter. If none is known, "application/octet-stream".
+     *      This parameter may never be null.
+     *
+     * @param elementNamespace
+     *      the namespace URI of the element that encloses the base64Binary data.
+     *      Can be empty but never null.
+     *
+     * @param elementLocalName
+     *      The local name of the element. Always a non-null valid string.
+     *
+     * @return content-id URI, cid, to the attachment containing
+     *         <code>data</code> or null if data should be inlined.
+     *
+     * @see #addMtomAttachment(DataHandler, String, String)
+     */
+    public abstract String addMtomAttachment(byte[] data, int offset, int length, String mimeType, String elementNamespace, String elementLocalName);
+
+    /**
+     * <p>Read-only property that returns true if JAXB marshaller should enable XOP creation.</p>
+     *
+     * <p>This value must not change during the marshalling process. When this
+     * value is true, the <code>addMtomAttachment(...)</code> method
+     * is invoked when the appropriate binary datatypes are encountered by
+     * the marshal process.</p>
+     *
+     * <p>Marshaller.marshal() must throw IllegalStateException if this value is <code>true</code>
+     * and the XML content to be marshalled violates Step 1 in
+     * <a ref="http://www.w3.org/TR/2005/REC-xop10-20050125/#creating_xop_packages">Creating XOP Pacakges</a>
+     * http://www.w3.org/TR/2005/REC-xop10-20050125/#creating_xop_packages.
+     * <i>"Ensure the Original XML Infoset contains no element information item with a
+     * [namespace name] of "http://www.w3.org/2004/08/xop/include" and a [local name] of Include"</i>
+     *
+     * <p>When this method returns true and during the marshal process
+     * at least one call to <code>addMtomAttachment(...)</code> returns
+     * a content-id, the MIME-based package processor must label the
+     * root part with the application/xop+xml media type as described in
+     * Step 5 of
+     * <a ref="http://www.w3.org/TR/2005/REC-xop10-20050125/#creating_xop_packages">Creating XOP Pacakges</a>.<p>
+     *
+     * @return true when MIME context is a XOP Package.
+     */
+    public boolean isXOPPackage() { return false; }
+
+   /**
+    * <p>Add MIME <code>data</code> as an attachment and return attachment's content-id, cid.</p>
+    *
+    * <p>
+    * This method is called by JAXB marshal process for each element/attribute typed as
+    * {http://ws-i.org/profiles/basic/1.1/xsd}swaRef. The MIME-based package processor
+    * implementing this method is responsible for attaching the specified data to a
+    * MIME attachment, and generating a content-id, cid, that uniquely identifies the attachment
+    * within the MIME-based package.
+    *
+    * <p>Caller inserts the returned content-id, cid, into the XML content being marshalled.</p>
+    *
+    * @param data
+    *       represents the data to be attached. Must be non-null.
+    * @return
+    *       must be a valid URI used as cid. Must satisfy Conformance Requirement R2928 from
+    *       <a href="http://www.ws-i.org/Profiles/AttachmentsProfile-1.0-2004-08-24.html#Referencing_Attachments_from_the_SOAP_Envelope">WS-I Attachments Profile Version 1.0.</a>
+    */
+    public abstract String addSwaRefAttachment(DataHandler data);
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/attachment/AttachmentUnmarshaller.java b/jaxws/src/share/classes/javax/xml/bind/attachment/AttachmentUnmarshaller.java
new file mode 100644
index 0000000..dd3bb13
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/attachment/AttachmentUnmarshaller.java
@@ -0,0 +1,140 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.attachment;
+
+import javax.activation.DataHandler;
+
+/**
+ * <p>Enables JAXB unmarshalling of a root document containing optimized binary data formats.</p>
+ *
+ * <p>This API enables an efficient cooperative processing of optimized
+ * binary data formats between a JAXB 2.0 implementation and MIME-based package
+ * processor (MTOM/XOP and WS-I AP 1.0). JAXB unmarshals the body of a package, delegating the
+ * understanding of the packaging format being used to a MIME-based
+ * package processor that implements this abstract class.</p>
+ *
+ * <p>This abstract class identifies if a package requires XOP processing, {@link #isXOPPackage()} and provides retrieval of binary content stored as attachments by content-id.</p>
+ *
+ * <h2>Identifying the content-id, cid, to pass to <code>getAttachment*(String cid)</code></h2>
+ * <ul>
+ * <li>
+ * For XOP processing, the infoset representation of the cid is described
+ * in step 2a in
+ * <a href="http://www.w3.org/TR/2005/REC-xop10-20050125/#interpreting_xop_packages">Section 3.2 Interpreting XOP Packages</a>
+ * </li>
+ * <li>
+ * For WS-I AP 1.0, the cid is identified as an element or attribute of
+ * type <code>ref:swaRef </code> specified in
+ * <a href="http://www.ws-i.org/Profiles/AttachmentsProfile-1.0-2004-08-24.html#Referencing_Attachments_from_the_SOAP_Envelope">Section 4.4 Referencing Attachments from the SOAP Envelope</a>
+ * </li>
+ * </ul>
+ *
+ * @author Marc Hadley
+ * @author Kohsuke Kawaguchi
+ * @author Joseph Fialli
+ *
+ * @since JAXB 2.0
+ *
+ * @see javax.xml.bind.Unmarshaller#setAttachmentUnmarshaller(AttachmentUnmarshaller)
+ *
+ * @see <a href="http://www.w3.org/TR/2005/REC-xop10-20050125/">XML-binary Optimized Packaging</a>
+ * @see <a href="http://www.ws-i.org/Profiles/AttachmentsProfile-1.0-2004-08-24.html">WS-I Attachments Profile Version 1.0.</a>
+ * @see <a href="http://www.w3.org/TR/xml-media-types/">Describing Media Content of Binary Data in XML</a>
+ */
+public abstract class AttachmentUnmarshaller {
+   /**
+    * <p>Lookup MIME content by content-id, <code>cid</code>, and return as a {@link DataHandler}.</p>
+    *
+    * <p>The returned <code>DataHandler</code> instance must be configured
+    * to meet the following required mapping constaint.
+    * <table border="2" rules="all" cellpadding="4">
+    *   <thead>
+    *     <tr>
+    *       <th align="center" colspan="2">
+    *       Required Mappings between MIME and Java Types
+    *       </tr>
+    *     <tr>
+    *       <th>MIME Type</th>
+    *       <th>Java Type</th>
+    *     </tr>
+    *     </tr>
+    *     <tr>
+    *       <th><code>DataHandler.getContentType()</code></th>
+    *       <th><code>instanceof DataHandler.getContent()</code></th>
+    *     </tr>
+    *   </thead>
+    *   <tbody>
+    *     <tr>
+    *       <td>image/gif</td>
+    *       <td>java.awt.Image</td>
+    *     </tr>
+    *     <tr>
+    *       <td>image/jpeg</td>
+    *       <td>java.awt.Image</td>
+    *     </tr>
+    *     <tr>
+    *       <td>text/xml  or application/xml</td>
+    *       <td>javax.xml.transform.Source</td>
+    *     </tr>
+    *   </tbody>
+    *  </table>
+    * Note that it is allowable to support additional mappings.</p>
+    *
+    * @param cid It is expected to be a valid lexical form of the XML Schema
+    * <code>xs:anyURI</code> datatype. If <code>{@link #isXOPPackage()}
+    * ==true</code>, it must be a valid URI per the <code>cid:</code> URI scheme (see <a href="http://www.ietf.org/rfc/rfc2387.txt">RFC 2387</a>)
+    *
+    * @return
+    *       a {@link DataHandler} that represents the MIME attachment.
+    *
+    * @throws IllegalArgumentException if the attachment for the given cid is not found.
+    */
+   public abstract DataHandler getAttachmentAsDataHandler(String cid);
+
+    /**
+     * <p>Retrieve the attachment identified by content-id, <code>cid</code>,  as a <tt>byte[]</tt></p>.
+     *
+     * @param cid It is expected to be a valid lexical form of the XML Schema
+     * <code>xs:anyURI</code> datatype. If <code>{@link #isXOPPackage()}
+     * ==true</code>, it must be a valid URI per the <code>cid:</code> URI scheme (see <a href="http://www.ietf.org/rfc/rfc2387.txt">RFC 2387</a>)
+     *
+     * @return byte[] representation of attachment identified by cid.
+     *
+    * @throws IllegalArgumentException if the attachment for the given cid is not found.
+     */
+    public abstract byte[] getAttachmentAsByteArray(String cid);
+
+    /**
+     * <p>Read-only property that returns true if JAXB unmarshaller needs to perform XOP processing.</p>
+     *
+     * <p>This method returns <code>true</code> when the constraints specified
+     * in  <a href="http://www.w3.org/TR/2005/REC-xop10-20050125/#identifying_xop_documents">Identifying XOP Documents</a> are met.
+     * This value must not change during the unmarshalling process.</p>
+     *
+     * @return true when MIME context is a XOP Document.
+     */
+    public boolean isXOPPackage() { return false; }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/attachment/package.html b/jaxws/src/share/classes/javax/xml/bind/attachment/package.html
new file mode 100644
index 0000000..1b881c6
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/attachment/package.html
@@ -0,0 +1,65 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
+<html>
+    <head>
+        <!--
+Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+This code is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License version 2 only, as
+published by the Free Software Foundation.  Sun designates this
+particular file as subject to the "Classpath" exception as provided
+by Sun in the LICENSE file that accompanied this code.
+
+This code is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+version 2 for more details (a copy is included in the LICENSE file that
+accompanied this code).
+
+You should have received a copy of the GNU General Public License version
+2 along with this work; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+CA 95054 USA or visit www.sun.com if you need additional information or
+have any questions.
+        -->
+    </head>
+
+    <body bgcolor="white">
+
+        <p>
+	This package is implemented by a MIME-based package processor that 
+        enables the interpretation and creation of optimized binary data 
+        within an MIME-based package format.
+
+        <p>
+        Soap MTOM[1], XOP([2][3]) and WS-I AP[4] standardize approaches to 
+        optimized transmission of binary datatypes as an attachment.
+        To optimally support these standards within a message passing 
+        environment, this package enables an integrated solution between 
+        a MIME-based package processor and JAXB unmarshall/marshal processes.
+
+        <h2>Package Specification</h2>
+
+        <ul>
+            <li><a href="http://java.sun.com/xml/downloads/jaxb.html">JAXB 
+                Specification</a>
+        </ul>
+
+        <h2>Related Standards</h2>
+
+        <ul>
+	  <li><a href="http://www.w3.org/TR/2004/WD-soap12-mtom-20040608/">[1]SOAP Message Transmission Optimization Mechanism</a> </li>
+          <li><a href="http://www.w3.org/TR/2005/REC-xop10-20050125/">[2]XML-binary Optimized Packaging</a></li>
+          <li><a href="http://www.ws-i.org/Profiles/AttachmentsProfile-1.0-2004-08-24.html">[3]WS-I Attachments Profile Version 1.0.</a></li>
+           <li><a href="http://www.w3.org/TR/xml-media-types/">[4]Describing Media Content of Binary Data in XML</a></li>
+        </ul>
+
+        <!-- Put @see and @since tags down here. -->
+        @since JAXB 2.0
+    </body>
+</html>
+
+
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/AbstractMarshallerImpl.java b/jaxws/src/share/classes/javax/xml/bind/helpers/AbstractMarshallerImpl.java
new file mode 100644
index 0000000..a414cfa
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/AbstractMarshallerImpl.java
@@ -0,0 +1,480 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.helpers;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.bind.PropertyException;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.attachment.AttachmentMarshaller;
+import javax.xml.stream.XMLEventWriter;
+import javax.xml.stream.XMLStreamWriter;
+import javax.xml.transform.dom.DOMResult;
+import javax.xml.transform.sax.SAXResult;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.validation.Schema;
+import java.io.UnsupportedEncodingException;
+// J2SE1.4 feature
+// import java.nio.charset.Charset;
+// import java.nio.charset.UnsupportedCharsetException;
+
+/**
+ * Partial default <tt>Marshaller</tt> implementation.
+ *
+ * <p>
+ * This class provides a partial default implementation for the
+ * {@link javax.xml.bind.Marshaller} interface.
+ *
+ * <p>
+ * The only methods that a JAXB Provider has to implement are
+ * {@link Marshaller#marshal(Object, javax.xml.transform.Result) marshal(Object, javax.xml.transform.Result)},
+ * {@link Marshaller#marshal(Object, javax.xml.transform.Result) marshal(Object, javax.xml.stream.XMLStreamWriter)}, and
+ * {@link Marshaller#marshal(Object, javax.xml.transform.Result) marshal(Object, javax.xml.stream.XMLEventWriter)}.
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li></ul>
+ * @see javax.xml.bind.Marshaller
+ * @since JAXB1.0
+ */
+public abstract class AbstractMarshallerImpl implements Marshaller
+{
+    /** handler that will be used to process errors and warnings during marshal */
+    private ValidationEventHandler eventHandler =
+        new DefaultValidationEventHandler();
+
+    //J2SE1.4 feature
+    //private Charset encoding = null;
+
+    /** store the value of the encoding property. */
+    private String encoding = "UTF-8";
+
+    /** store the value of the schemaLocation property. */
+    private String schemaLocation = null;
+
+    /** store the value of the noNamespaceSchemaLocation property. */
+    private String noNSSchemaLocation = null;
+
+    /** store the value of the formattedOutput property. */
+    private boolean formattedOutput = false;
+
+    /** store the value of the fragment property. */
+    private boolean fragment = false;
+
+    public final void marshal( Object obj, java.io.OutputStream os )
+        throws JAXBException {
+
+        checkNotNull( obj, "obj", os, "os" );
+        marshal( obj, new StreamResult(os) );
+    }
+
+    public final void marshal( Object obj, java.io.Writer w )
+        throws JAXBException {
+
+        checkNotNull( obj, "obj", w, "writer" );
+        marshal( obj, new StreamResult(w) );
+    }
+
+    public final void marshal( Object obj, org.xml.sax.ContentHandler handler )
+        throws JAXBException {
+
+        checkNotNull( obj, "obj", handler, "handler" );
+        marshal( obj, new SAXResult(handler) );
+    }
+
+    public final void marshal( Object obj, org.w3c.dom.Node node )
+        throws JAXBException {
+
+        checkNotNull( obj, "obj", node, "node" );
+        marshal( obj, new DOMResult(node) );
+    }
+
+    /**
+     * By default, the getNode method is unsupported and throw
+     * an {@link java.lang.UnsupportedOperationException}.
+     *
+     * Implementations that choose to support this method must
+     * override this method.
+     */
+    public org.w3c.dom.Node getNode( Object obj ) throws JAXBException {
+
+        checkNotNull( obj, "obj", Boolean.TRUE, "foo" );
+
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * Convenience method for getting the current output encoding.
+     *
+     * @return the current encoding or "UTF-8" if it hasn't been set.
+     */
+    protected String getEncoding() {
+        return encoding;
+    }
+
+    /**
+     * Convenience method for setting the output encoding.
+     *
+     * @param encoding a valid encoding as specified in the Marshaller class
+     * documentation
+     */
+    protected void setEncoding( String encoding ) {
+        this.encoding = encoding;
+    }
+
+    /**
+     * Convenience method for getting the current schemaLocation.
+     *
+     * @return the current schemaLocation or null if it hasn't been set
+     */
+    protected String getSchemaLocation() {
+        return schemaLocation;
+    }
+
+    /**
+     * Convenience method for setting the schemaLocation.
+     *
+     * @param location the schemaLocation value
+     */
+    protected void setSchemaLocation( String location ) {
+        schemaLocation = location;
+    }
+
+    /**
+     * Convenience method for getting the current noNamespaceSchemaLocation.
+     *
+     * @return the current noNamespaceSchemaLocation or null if it hasn't
+     * been set
+     */
+    protected String getNoNSSchemaLocation() {
+        return noNSSchemaLocation;
+    }
+
+    /**
+     * Convenience method for setting the noNamespaceSchemaLocation.
+     *
+     * @param location the noNamespaceSchemaLocation value
+     */
+    protected void setNoNSSchemaLocation( String location ) {
+        noNSSchemaLocation = location;
+    }
+
+    /**
+     * Convenience method for getting the formatted output flag.
+     *
+     * @return the current value of the formatted output flag or false if
+     * it hasn't been set.
+     */
+    protected boolean isFormattedOutput() {
+        return formattedOutput;
+    }
+
+    /**
+     * Convenience method for setting the formatted output flag.
+     *
+     * @param v value of the formatted output flag.
+     */
+    protected void setFormattedOutput( boolean v ) {
+        formattedOutput = v;
+    }
+
+
+    /**
+     * Convenience method for getting the fragment flag.
+     *
+     * @return the current value of the fragment flag or false if
+     * it hasn't been set.
+     */
+    protected boolean isFragment() {
+        return fragment;
+    }
+
+    /**
+     * Convenience method for setting the fragment flag.
+     *
+     * @param v value of the fragment flag.
+     */
+    protected void setFragment( boolean v ) {
+        fragment = v;
+    }
+
+
+    static String[] aliases = {
+        "UTF-8", "UTF8",
+        "UTF-16", "Unicode",
+        "UTF-16BE", "UnicodeBigUnmarked",
+        "UTF-16LE", "UnicodeLittleUnmarked",
+        "US-ASCII", "ASCII",
+        "TIS-620", "TIS620",
+
+        // taken from the project-X parser
+        "ISO-10646-UCS-2", "Unicode",
+
+        "EBCDIC-CP-US", "cp037",
+        "EBCDIC-CP-CA", "cp037",
+        "EBCDIC-CP-NL", "cp037",
+        "EBCDIC-CP-WT", "cp037",
+
+        "EBCDIC-CP-DK", "cp277",
+        "EBCDIC-CP-NO", "cp277",
+        "EBCDIC-CP-FI", "cp278",
+        "EBCDIC-CP-SE", "cp278",
+
+        "EBCDIC-CP-IT", "cp280",
+        "EBCDIC-CP-ES", "cp284",
+        "EBCDIC-CP-GB", "cp285",
+        "EBCDIC-CP-FR", "cp297",
+
+        "EBCDIC-CP-AR1", "cp420",
+        "EBCDIC-CP-HE", "cp424",
+        "EBCDIC-CP-BE", "cp500",
+        "EBCDIC-CP-CH", "cp500",
+
+        "EBCDIC-CP-ROECE", "cp870",
+        "EBCDIC-CP-YU", "cp870",
+        "EBCDIC-CP-IS", "cp871",
+        "EBCDIC-CP-AR2", "cp918",
+
+        // IANA also defines two that JDK 1.2 doesn't handle:
+        //  EBCDIC-CP-GR        --> CP423
+        //  EBCDIC-CP-TR        --> CP905
+    };
+
+    /**
+     * Gets the corresponding Java encoding name from an IANA name.
+     *
+     * This method is a helper method for the derived class to convert
+     * encoding names.
+     *
+     * @exception UnsupportedEncodingException
+     *      If this implementation couldn't find the Java encoding name.
+     */
+    protected String getJavaEncoding( String encoding ) throws UnsupportedEncodingException {
+        try {
+            "1".getBytes(encoding);
+            return encoding;
+        } catch( UnsupportedEncodingException e ) {
+            // try known alias
+            for( int i=0; i<aliases.length; i+=2 ) {
+                if(encoding.equals(aliases[i])) {
+                    "1".getBytes(aliases[i+1]);
+                    return aliases[i+1];
+                }
+            }
+
+            throw new UnsupportedEncodingException(encoding);
+        }
+        /* J2SE1.4 feature
+        try {
+            this.encoding = Charset.forName( _encoding );
+        } catch( UnsupportedCharsetException uce ) {
+            throw new JAXBException( uce );
+        }
+         */
+    }
+
+    /**
+     * Default implementation of the setProperty method handles
+     * the four defined properties in Marshaller. If a provider
+     * needs to handle additional properties, it should override
+     * this method in a derived class.
+     */
+    public void setProperty( String name, Object value )
+        throws PropertyException {
+
+        if( name == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "name" ) );
+        }
+
+        // recognize and handle four pre-defined properties.
+        if( JAXB_ENCODING.equals(name) ) {
+            checkString( name, value );
+            setEncoding( (String)value );
+            return;
+        }
+        if( JAXB_FORMATTED_OUTPUT.equals(name) ) {
+            checkBoolean( name, value );
+            setFormattedOutput((Boolean) value );
+            return;
+        }
+        if( JAXB_NO_NAMESPACE_SCHEMA_LOCATION.equals(name) ) {
+            checkString( name, value );
+            setNoNSSchemaLocation( (String)value );
+            return;
+        }
+        if( JAXB_SCHEMA_LOCATION.equals(name) ) {
+            checkString( name, value );
+            setSchemaLocation( (String)value );
+            return;
+        }
+        if( JAXB_FRAGMENT.equals(name) )  {
+            checkBoolean(name, value);
+            setFragment((Boolean) value );
+            return;
+        }
+
+        throw new PropertyException(name, value);
+    }
+
+    /**
+     * Default implementation of the getProperty method handles
+     * the four defined properties in Marshaller.  If a provider
+     * needs to support additional provider specific properties,
+     * it should override this method in a derived class.
+     */
+    public Object getProperty( String name )
+        throws PropertyException {
+
+        if( name == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "name" ) );
+        }
+
+        // recognize and handle four pre-defined properties.
+        if( JAXB_ENCODING.equals(name) )
+            return getEncoding();
+        if( JAXB_FORMATTED_OUTPUT.equals(name) )
+            return isFormattedOutput()?Boolean.TRUE:Boolean.FALSE;
+        if( JAXB_NO_NAMESPACE_SCHEMA_LOCATION.equals(name) )
+            return getNoNSSchemaLocation();
+        if( JAXB_SCHEMA_LOCATION.equals(name) )
+            return getSchemaLocation();
+        if( JAXB_FRAGMENT.equals(name) )
+            return isFragment()?Boolean.TRUE:Boolean.FALSE;
+
+        throw new PropertyException(name);
+    }
+    /**
+     * @see javax.xml.bind.Marshaller#getEventHandler()
+     */
+    public ValidationEventHandler getEventHandler() throws JAXBException {
+        return eventHandler;
+    }
+
+    /**
+     * @see javax.xml.bind.Marshaller#setEventHandler(ValidationEventHandler)
+     */
+    public void setEventHandler(ValidationEventHandler handler)
+        throws JAXBException {
+
+        if( handler == null ) {
+            eventHandler = new DefaultValidationEventHandler();
+        } else {
+            eventHandler = handler;
+        }
+    }
+
+
+
+
+    /*
+     * assert that the given object is a Boolean
+     */
+    private void checkBoolean( String name, Object value ) throws PropertyException {
+        if(!(value instanceof Boolean))
+            throw new PropertyException(
+                Messages.format( Messages.MUST_BE_BOOLEAN, name ) );
+    }
+
+    /*
+     * assert that the given object is a String
+     */
+    private void checkString( String name, Object value ) throws PropertyException {
+        if(!(value instanceof String))
+            throw new PropertyException(
+                Messages.format( Messages.MUST_BE_STRING, name ) );
+    }
+
+    /*
+     * assert that the parameters are not null
+     */
+    private void checkNotNull( Object o1, String o1Name,
+                               Object o2, String o2Name ) {
+
+        if( o1 == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, o1Name ) );
+        }
+        if( o2 == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, o2Name ) );
+        }
+    }
+    /* (non-Javadoc)
+     * @see javax.xml.bind.Marshaller#marshal(java.lang.Object, javax.xml.stream.XMLEventWriter)
+     */
+    public void marshal(Object obj, XMLEventWriter writer)
+        throws JAXBException {
+
+        throw new UnsupportedOperationException();
+    }
+
+    /* (non-Javadoc)
+     * @see javax.xml.bind.Marshaller#marshal(java.lang.Object, javax.xml.stream.XMLStreamWriter)
+     */
+    public void marshal(Object obj, XMLStreamWriter writer)
+        throws JAXBException {
+
+        throw new UnsupportedOperationException();
+    }
+
+    public void setSchema(Schema schema) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Schema getSchema() {
+        throw new UnsupportedOperationException();
+    }
+
+    public void setAdapter(XmlAdapter adapter) {
+        if(adapter==null)
+            throw new IllegalArgumentException();
+        setAdapter((Class)adapter.getClass(),adapter);
+    }
+
+    public <A extends XmlAdapter> void setAdapter(Class<A> type, A adapter) {
+        throw new UnsupportedOperationException();
+    }
+
+    public <A extends XmlAdapter> A getAdapter(Class<A> type) {
+        throw new UnsupportedOperationException();
+    }
+
+    public void setAttachmentMarshaller(AttachmentMarshaller am) {
+        throw new UnsupportedOperationException();
+    }
+
+    public AttachmentMarshaller getAttachmentMarshaller() {
+        throw new UnsupportedOperationException();
+    }
+
+    public void setListener(Listener listener) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Listener getListener() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/AbstractUnmarshallerImpl.java b/jaxws/src/share/classes/javax/xml/bind/helpers/AbstractUnmarshallerImpl.java
new file mode 100644
index 0000000..cedc641
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/AbstractUnmarshallerImpl.java
@@ -0,0 +1,434 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.helpers;
+
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.XMLReader;
+import org.w3c.dom.Node;
+
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.PropertyException;
+import javax.xml.bind.UnmarshalException;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.annotation.adapters.XmlAdapter;
+import javax.xml.bind.attachment.AttachmentUnmarshaller;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.parsers.SAXParserFactory;
+import javax.xml.stream.XMLEventReader;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.transform.Source;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.sax.SAXSource;
+import javax.xml.transform.stream.StreamSource;
+import javax.xml.validation.Schema;
+import java.io.File;
+import java.io.Reader;
+import java.net.MalformedURLException;
+import java.net.URL;
+
+/**
+ * Partial default <tt>Unmarshaller</tt> implementation.
+ *
+ * <p>
+ * This class provides a partial default implementation for the
+ * {@link javax.xml.bind.Unmarshaller}interface.
+ *
+ * <p>
+ * A JAXB Provider has to implement five methods (getUnmarshallerHandler,
+ * unmarshal(Node), unmarshal(XMLReader,InputSource),
+ * unmarshal(XMLStreamReader), and unmarshal(XMLEventReader).
+ *
+ * @author <ul>
+ *         <li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li>
+ *         </ul>
+ * @see javax.xml.bind.Unmarshaller
+ * @since JAXB1.0
+ */
+public abstract class AbstractUnmarshallerImpl implements Unmarshaller
+{
+    /** handler that will be used to process errors and warnings during unmarshal */
+    private ValidationEventHandler eventHandler =
+        new DefaultValidationEventHandler();
+
+    /** whether or not the unmarshaller will validate */
+    protected boolean validating = false;
+
+    /**
+     * XMLReader that will be used to parse a document.
+     */
+    private XMLReader reader = null;
+
+    /**
+     * Obtains a configured XMLReader.
+     *
+     * This method is used when the client-specified
+     * {@link SAXSource} object doesn't have XMLReader.
+     *
+     * {@link Unmarshaller} is not re-entrant, so we will
+     * only use one instance of XMLReader.
+     */
+    protected XMLReader getXMLReader() throws JAXBException {
+        if(reader==null) {
+            try {
+                SAXParserFactory parserFactory;
+                parserFactory = SAXParserFactory.newInstance();
+                parserFactory.setNamespaceAware(true);
+                // there is no point in asking a validation because
+                // there is no guarantee that the document will come with
+                // a proper schemaLocation.
+                parserFactory.setValidating(false);
+                reader = parserFactory.newSAXParser().getXMLReader();
+            } catch( ParserConfigurationException e ) {
+                throw new JAXBException(e);
+            } catch( SAXException e ) {
+                throw new JAXBException(e);
+            }
+        }
+        return reader;
+    }
+
+    public Object unmarshal( Source source ) throws JAXBException {
+        if( source == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "source" ) );
+        }
+
+        if(source instanceof SAXSource)
+            return unmarshal( (SAXSource)source );
+        if(source instanceof StreamSource)
+            return unmarshal( streamSourceToInputSource((StreamSource)source));
+        if(source instanceof DOMSource)
+            return unmarshal( ((DOMSource)source).getNode() );
+
+        // we don't handle other types of Source
+        throw new IllegalArgumentException();
+    }
+
+    // use the client specified XMLReader contained in the SAXSource.
+    private Object unmarshal( SAXSource source ) throws JAXBException {
+
+        XMLReader reader = source.getXMLReader();
+        if( reader == null )
+            reader = getXMLReader();
+
+        return unmarshal( reader, source.getInputSource() );
+    }
+
+    /**
+     * Unmarshals an object by using the specified XMLReader and the InputSource.
+     *
+     * The callee should call the setErrorHandler method of the XMLReader
+     * so that errors are passed to the client-specified ValidationEventHandler.
+     */
+    protected abstract Object unmarshal( XMLReader reader, InputSource source ) throws JAXBException;
+
+    public final Object unmarshal( InputSource source ) throws JAXBException {
+        if( source == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "source" ) );
+        }
+
+        return unmarshal( getXMLReader(), source );
+    }
+
+
+    private Object unmarshal( String url ) throws JAXBException {
+        return unmarshal( new InputSource(url) );
+    }
+
+    public final Object unmarshal( URL url ) throws JAXBException {
+        if( url == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "url" ) );
+        }
+
+        return unmarshal( url.toExternalForm() );
+    }
+
+    public final Object unmarshal( File f ) throws JAXBException {
+        if( f == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "file" ) );
+        }
+
+        try {
+            // copied from JAXP
+            String path = f.getAbsolutePath();
+            if (File.separatorChar != '/')
+                path = path.replace(File.separatorChar, '/');
+            if (!path.startsWith("/"))
+                path = "/" + path;
+            if (!path.endsWith("/") && f.isDirectory())
+                path = path + "/";
+            return unmarshal(new URL("file", "", path));
+        } catch( MalformedURLException e ) {
+            throw new IllegalArgumentException(e.getMessage());
+        }
+    }
+
+    public final Object unmarshal( java.io.InputStream is )
+        throws JAXBException {
+
+        if( is == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "is" ) );
+        }
+
+        InputSource isrc = new InputSource( is );
+        return unmarshal( isrc );
+    }
+
+    public final Object unmarshal( Reader reader ) throws JAXBException {
+        if( reader == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "reader" ) );
+        }
+
+        InputSource isrc = new InputSource( reader );
+        return unmarshal( isrc );
+    }
+
+
+    private static InputSource streamSourceToInputSource( StreamSource ss ) {
+        InputSource is = new InputSource();
+        is.setSystemId( ss.getSystemId() );
+        is.setByteStream( ss.getInputStream() );
+        is.setCharacterStream( ss.getReader() );
+
+        return is;
+    }
+
+
+    /**
+     * Indicates whether or not the Unmarshaller is configured to validate
+     * during unmarshal operations.
+     * <p>
+     * <i><b>Note:</b> I named this method isValidating() to stay in-line
+     * with JAXP, as opposed to naming it getValidating(). </i>
+     *
+     * @return true if the Unmarshaller is configured to validate during
+     *        unmarshal operations, false otherwise
+     * @throws JAXBException if an error occurs while retrieving the validating
+     *        flag
+     */
+    public boolean isValidating() throws JAXBException {
+        return validating;
+    }
+
+    /**
+     * Allow an application to register a validation event handler.
+     * <p>
+     * The validation event handler will be called by the JAXB Provider if any
+     * validation errors are encountered during calls to any of the
+     * <tt>unmarshal</tt> methods.  If the client application does not register
+     * a validation event handler before invoking the unmarshal methods, then
+     * all validation events will be silently ignored and may result in
+     * unexpected behaviour.
+     *
+     * @param handler the validation event handler
+     * @throws JAXBException if an error was encountered while setting the
+     *        event handler
+     */
+    public void setEventHandler(ValidationEventHandler handler)
+        throws JAXBException {
+
+        if( handler == null ) {
+            eventHandler = new DefaultValidationEventHandler();
+        } else {
+            eventHandler = handler;
+        }
+    }
+
+    /**
+     * Specifies whether or not the Unmarshaller should validate during
+     * unmarshal operations.  By default, the <tt>Unmarshaller</tt> does
+     * not validate.
+     * <p>
+     * This method may only be invoked before or after calling one of the
+     * unmarshal methods.
+     *
+     * @param validating true if the Unmarshaller should validate during
+     *       unmarshal, false otherwise
+     * @throws JAXBException if an error occurred while enabling or disabling
+     * validation at unmarshal time
+     */
+    public void setValidating(boolean validating) throws JAXBException {
+        this.validating = validating;
+    }
+
+    /**
+     * Return the current event handler or the default event handler if one
+     * hasn't been set.
+     *
+     * @return the current ValidationEventHandler or the default event handler
+     *        if it hasn't been set
+     * @throws JAXBException if an error was encountered while getting the
+     *        current event handler
+     */
+    public ValidationEventHandler getEventHandler() throws JAXBException {
+        return eventHandler;
+    }
+
+
+    /**
+     * Creates an UnmarshalException from a SAXException.
+     *
+     * This is an utility method provided for the derived classes.
+     *
+     * <p>
+     * When a provider-implemented ContentHandler wants to throw a
+     * JAXBException, it needs to wrap the exception by a SAXException.
+     * If the unmarshaller implementation blindly wrap SAXException
+     * by JAXBException, such an exception will be a JAXBException
+     * wrapped by a SAXException wrapped by another JAXBException.
+     * This is silly.
+     *
+     * <p>
+     * This method checks the nested exception of SAXException
+     * and reduce those excessive wrapping.
+     *
+     * @return the resulting UnmarshalException
+     */
+    protected UnmarshalException createUnmarshalException( SAXException e ) {
+        // check the nested exception to see if it's an UnmarshalException
+        Exception nested = e.getException();
+        if(nested instanceof UnmarshalException)
+            return (UnmarshalException)nested;
+
+        if(nested instanceof RuntimeException)
+            // typically this is an unexpected exception,
+            // just throw it rather than wrap it, so that the full stack
+            // trace can be displayed.
+            throw (RuntimeException)nested;
+
+
+        // otherwise simply wrap it
+        if(nested!=null)
+            return new UnmarshalException(nested);
+        else
+            return new UnmarshalException(e);
+    }
+
+    /**
+     * Default implementation of the setProperty method always
+     * throws PropertyException since there are no required
+     * properties. If a provider needs to handle additional
+     * properties, it should override this method in a derived class.
+     */
+    public void setProperty( String name, Object value )
+        throws PropertyException {
+
+        if( name == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "name" ) );
+        }
+
+        throw new PropertyException(name, value);
+    }
+
+    /**
+     * Default implementation of the getProperty method always
+     * throws PropertyException since there are no required
+     * properties. If a provider needs to handle additional
+     * properties, it should override this method in a derived class.
+     */
+    public Object getProperty( String name )
+        throws PropertyException {
+
+        if( name == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "name" ) );
+        }
+
+        throw new PropertyException(name);
+    }
+
+    public Object unmarshal(XMLEventReader reader) throws JAXBException {
+
+        throw new UnsupportedOperationException();
+    }
+
+    public Object unmarshal(XMLStreamReader reader) throws JAXBException {
+
+        throw new UnsupportedOperationException();
+    }
+
+    public <T> JAXBElement<T> unmarshal(Node node, Class<T> expectedType) throws JAXBException {
+        throw new UnsupportedOperationException();
+    }
+
+    public <T> JAXBElement<T> unmarshal(Source source, Class<T> expectedType) throws JAXBException {
+        throw new UnsupportedOperationException();
+    }
+
+    public <T> JAXBElement<T> unmarshal(XMLStreamReader reader, Class<T> expectedType) throws JAXBException {
+        throw new UnsupportedOperationException();
+    }
+
+    public <T> JAXBElement<T> unmarshal(XMLEventReader reader, Class<T> expectedType) throws JAXBException {
+        throw new UnsupportedOperationException();
+    }
+
+    public void setSchema(Schema schema) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Schema getSchema() {
+        throw new UnsupportedOperationException();
+    }
+
+    public void setAdapter(XmlAdapter adapter) {
+        if(adapter==null)
+            throw new IllegalArgumentException();
+        setAdapter((Class)adapter.getClass(),adapter);
+    }
+
+    public <A extends XmlAdapter> void setAdapter(Class<A> type, A adapter) {
+        throw new UnsupportedOperationException();
+    }
+
+    public <A extends XmlAdapter> A getAdapter(Class<A> type) {
+        throw new UnsupportedOperationException();
+    }
+
+    public void setAttachmentUnmarshaller(AttachmentUnmarshaller au) {
+        throw new UnsupportedOperationException();
+    }
+
+    public AttachmentUnmarshaller getAttachmentUnmarshaller() {
+        throw new UnsupportedOperationException();
+    }
+
+    public void setListener(Listener listener) {
+        throw new UnsupportedOperationException();
+    }
+
+    public Listener getListener() {
+        throw new UnsupportedOperationException();
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/DefaultValidationEventHandler.java b/jaxws/src/share/classes/javax/xml/bind/helpers/DefaultValidationEventHandler.java
new file mode 100644
index 0000000..0cfaa88
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/DefaultValidationEventHandler.java
@@ -0,0 +1,130 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.helpers;
+
+import org.w3c.dom.Node;
+
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.ValidationEventLocator;
+import java.net.URL;
+
+/**
+ * <p>
+ * JAXB 1.0 only default validation event handler. This is the default
+ * handler for all objects created from a JAXBContext that is managing
+ * schema-derived code generated by a JAXB 1.0 binding compiler.
+ *
+ * <p>
+ * This handler causes the unmarshal and validate operations to fail on the first
+ * error or fatal error.
+ *
+ * <p>
+ * This handler is not the default handler for JAXB mapped classes following
+ * JAXB 2.0 or later versions. Default validation event handling has changed
+ * and is specified in  {@link javax.xml.bind.Unmarshaller} and
+ * {@link javax.xml.bind.Marshaller}.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see javax.xml.bind.Unmarshaller
+ * @see javax.xml.bind.Validator
+ * @see javax.xml.bind.ValidationEventHandler
+ * @since JAXB1.0
+ */
+public class DefaultValidationEventHandler implements ValidationEventHandler {
+
+    public boolean handleEvent( ValidationEvent event ) {
+
+        if( event == null ) {
+            throw new IllegalArgumentException();
+        }
+
+        // calculate the severity prefix and return value
+        String severity = null;
+        boolean retVal = false;
+        switch ( event.getSeverity() ) {
+            case ValidationEvent.WARNING:
+                severity = Messages.format( Messages.WARNING );
+                retVal = true; // continue after warnings
+                break;
+            case ValidationEvent.ERROR:
+                severity = Messages.format( Messages.ERROR );
+                retVal = false; // terminate after errors
+                break;
+            case ValidationEvent.FATAL_ERROR:
+                severity = Messages.format( Messages.FATAL_ERROR );
+                retVal = false; // terminate after fatal errors
+                break;
+            default:
+                assert false :
+                    Messages.format( Messages.UNRECOGNIZED_SEVERITY,
+                            event.getSeverity() );
+        }
+
+        // calculate the location message
+        String location = getLocation( event );
+
+        System.out.println(
+            Messages.format( Messages.SEVERITY_MESSAGE,
+                             severity,
+                             event.getMessage(),
+                             location ) );
+
+        // fail on the first error or fatal error
+        return retVal;
+    }
+
+    /**
+     * Calculate a location message for the event
+     *
+     */
+    private String getLocation(ValidationEvent event) {
+        StringBuffer msg = new StringBuffer();
+
+        ValidationEventLocator locator = event.getLocator();
+
+        if( locator != null ) {
+
+            URL url = locator.getURL();
+            Object obj = locator.getObject();
+            Node node = locator.getNode();
+            int line = locator.getLineNumber();
+
+            if( url!=null || line!=-1 ) {
+                msg.append( "line " + line );
+                if( url!=null )
+                    msg.append( " of " + url );
+            } else if( obj != null ) {
+                msg.append( " obj: " + obj.toString() );
+            } else if( node != null ) {
+                msg.append( " node: " + node.toString() );
+            }
+        } else {
+            msg.append( Messages.format( Messages.LOCATION_UNAVAILABLE ) );
+        }
+
+        return msg.toString();
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/Messages.java b/jaxws/src/share/classes/javax/xml/bind/helpers/Messages.java
new file mode 100644
index 0000000..a899cc2
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/Messages.java
@@ -0,0 +1,97 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.helpers;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    static String format( String property ) {
+        return format( property, null );
+    }
+
+    static String format( String property, Object arg1 ) {
+        return format( property, new Object[]{arg1} );
+    }
+
+    static String format( String property, Object arg1, Object arg2 ) {
+        return format( property, new Object[]{arg1,arg2} );
+    }
+
+    static String format( String property, Object arg1, Object arg2, Object arg3 ) {
+        return format( property, new Object[]{arg1,arg2,arg3} );
+    }
+
+    // add more if necessary.
+
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object[] args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getName()).getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+//
+//
+// Message resources
+//
+//
+    static final String INPUTSTREAM_NOT_NULL = // 0 args
+        "AbstractUnmarshallerImpl.ISNotNull";
+
+    static final String MUST_BE_BOOLEAN = // 1 arg
+        "AbstractMarshallerImpl.MustBeBoolean";
+
+    static final String MUST_BE_STRING = // 1 arg
+        "AbstractMarshallerImpl.MustBeString";
+
+    static final String SEVERITY_MESSAGE = // 3 args
+        "DefaultValidationEventHandler.SeverityMessage";
+
+    static final String LOCATION_UNAVAILABLE = // 0 args
+        "DefaultValidationEventHandler.LocationUnavailable";
+
+    static final String UNRECOGNIZED_SEVERITY = // 1 arg
+        "DefaultValidationEventHandler.UnrecognizedSeverity";
+
+    static final String WARNING = // 0 args
+        "DefaultValidationEventHandler.Warning";
+
+    static final String ERROR = // 0 args
+        "DefaultValidationEventHandler.Error";
+
+    static final String FATAL_ERROR = // 0 args
+        "DefaultValidationEventHandler.FatalError";
+
+    static final String ILLEGAL_SEVERITY = // 0 args
+        "ValidationEventImpl.IllegalSeverity";
+
+    static final String MUST_NOT_BE_NULL = // 1 arg
+        "Shared.MustNotBeNull";
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/Messages.properties b/jaxws/src/share/classes/javax/xml/bind/helpers/Messages.properties
new file mode 100644
index 0000000..6515c86
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/Messages.properties
@@ -0,0 +1,36 @@
+AbstractUnmarshallerImpl.ISNotNull = \
+	InputStream can not be null
+
+AbstractMarshallerImpl.MustBeBoolean = \
+	{0} must be boolean
+	 
+AbstractMarshallerImpl.MustBeString = \
+	{0} must be a String
+	
+
+DefaultValidationEventHandler.SeverityMessage = \
+	DefaultValidationEventHandler: {0} {1} \n\
+\ \ \ \ \ Location: {2}
+
+DefaultValidationEventHandler.LocationUnavailable = \
+	unavailable
+	
+DefaultValidationEventHandler.UnrecognizedSeverity = \
+	Unrecognized event severity field "{0}"
+
+DefaultValidationEventHandler.Warning = \
+	[WARNING]:
+
+DefaultValidationEventHandler.Error = \
+	[ERROR]:
+
+DefaultValidationEventHandler.FatalError = \
+	[FATAL_ERROR]:
+	
+ValidationEventImpl.IllegalSeverity = \
+	Illegal severity
+	
+Shared.MustNotBeNull = \
+	{0} parameter must not be null
+	
+ 
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/NotIdentifiableEventImpl.java b/jaxws/src/share/classes/javax/xml/bind/helpers/NotIdentifiableEventImpl.java
new file mode 100644
index 0000000..b1f3005
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/NotIdentifiableEventImpl.java
@@ -0,0 +1,85 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.helpers;
+
+import javax.xml.bind.ValidationEventLocator;
+
+/**
+ * Default implementation of the NotIdentifiableEvent interface.
+ *
+ * <p>
+ * JAXB providers are allowed to use whatever class that implements
+ * the ValidationEvent interface. This class is just provided for a
+ * convenience.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see javax.xml.bind.NotIdentifiableEvent
+ * @see javax.xml.bind.Validator
+ * @see javax.xml.bind.ValidationEventHandler
+ * @see javax.xml.bind.ValidationEvent
+ * @see javax.xml.bind.ValidationEventLocator
+ * @since JAXB1.0
+ */
+public class NotIdentifiableEventImpl
+    extends ValidationEventImpl
+    implements javax.xml.bind.NotIdentifiableEvent {
+
+    /**
+     * Create a new NotIdentifiableEventImpl.
+     *
+     * @param _severity The severity value for this event.  Must be one of
+     * ValidationEvent.WARNING, ValidationEvent.ERROR, or
+     * ValidationEvent.FATAL_ERROR
+     * @param _message The text message for this event - may be null.
+     * @param _locator The locator object for this event - may be null.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public NotIdentifiableEventImpl( int _severity, String _message,
+                                      ValidationEventLocator _locator) {
+
+        super(_severity, _message, _locator);
+    }
+
+    /**
+     * Create a new NotIdentifiableEventImpl.
+     *
+     * @param _severity The severity value for this event.  Must be one of
+     * ValidationEvent.WARNING, ValidationEvent.ERROR, or
+     * ValidationEvent.FATAL_ERROR
+     * @param _message The text message for this event - may be null.
+     * @param _locator The locator object for this event - may be null.
+     * @param _linkedException An optional linked exception that may provide
+     * additional information about the event - may be null.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public NotIdentifiableEventImpl( int _severity, String _message,
+                                      ValidationEventLocator _locator,
+                                      Throwable _linkedException) {
+
+        super(_severity, _message, _locator, _linkedException);
+    }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/ParseConversionEventImpl.java b/jaxws/src/share/classes/javax/xml/bind/helpers/ParseConversionEventImpl.java
new file mode 100644
index 0000000..2bc0ab0
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/ParseConversionEventImpl.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.helpers;
+
+import javax.xml.bind.ParseConversionEvent;
+import javax.xml.bind.ValidationEventLocator;
+
+/**
+ * Default implementation of the ParseConversionEvent interface.
+ *
+ * <p>
+ * JAXB providers are allowed to use whatever class that implements
+ * the ValidationEvent interface. This class is just provided for a
+ * convenience.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see javax.xml.bind.ParseConversionEvent
+ * @see javax.xml.bind.Validator
+ * @see javax.xml.bind.ValidationEventHandler
+ * @see javax.xml.bind.ValidationEvent
+ * @see javax.xml.bind.ValidationEventLocator
+ * @since JAXB1.0
+ */
+public class ParseConversionEventImpl
+    extends ValidationEventImpl
+    implements ParseConversionEvent {
+
+    /**
+     * Create a new ParseConversionEventImpl.
+     *
+     * @param _severity The severity value for this event.  Must be one of
+     * ValidationEvent.WARNING, ValidationEvent.ERROR, or
+     * ValidationEvent.FATAL_ERROR
+     * @param _message The text message for this event - may be null.
+     * @param _locator The locator object for this event - may be null.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public ParseConversionEventImpl( int _severity, String _message,
+                                      ValidationEventLocator _locator) {
+
+        super(_severity, _message, _locator);
+    }
+
+    /**
+     * Create a new ParseConversionEventImpl.
+     *
+     * @param _severity The severity value for this event.  Must be one of
+     * ValidationEvent.WARNING, ValidationEvent.ERROR, or
+     * ValidationEvent.FATAL_ERROR
+     * @param _message The text message for this event - may be null.
+     * @param _locator The locator object for this event - may be null.
+     * @param _linkedException An optional linked exception that may provide
+     * additional information about the event - may be null.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public ParseConversionEventImpl( int _severity, String _message,
+                                      ValidationEventLocator _locator,
+                                      Throwable _linkedException) {
+
+        super(_severity, _message, _locator, _linkedException);
+    }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/PrintConversionEventImpl.java b/jaxws/src/share/classes/javax/xml/bind/helpers/PrintConversionEventImpl.java
new file mode 100644
index 0000000..126e725
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/PrintConversionEventImpl.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.helpers;
+
+import javax.xml.bind.PrintConversionEvent;
+import javax.xml.bind.ValidationEventLocator;
+
+/**
+ * Default implementation of the PrintConversionEvent interface.
+ *
+ * <p>
+ * JAXB providers are allowed to use whatever class that implements
+ * the ValidationEvent interface. This class is just provided for a
+ * convenience.
+ *
+ * @author <ul><li>Ryan Shoemaker, Sun Microsystems, Inc.</li></ul>
+ * @see javax.xml.bind.PrintConversionEvent
+ * @see javax.xml.bind.Validator
+ * @see javax.xml.bind.ValidationEventHandler
+ * @see javax.xml.bind.ValidationEvent
+ * @see javax.xml.bind.ValidationEventLocator
+ * @since JAXB1.0
+ */
+public class PrintConversionEventImpl
+    extends ValidationEventImpl
+    implements PrintConversionEvent {
+
+    /**
+     * Create a new PrintConversionEventImpl.
+     *
+     * @param _severity The severity value for this event.  Must be one of
+     * ValidationEvent.WARNING, ValidationEvent.ERROR, or
+     * ValidationEvent.FATAL_ERROR
+     * @param _message The text message for this event - may be null.
+     * @param _locator The locator object for this event - may be null.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public PrintConversionEventImpl( int _severity, String _message,
+                                      ValidationEventLocator _locator) {
+
+        super(_severity, _message, _locator);
+    }
+
+    /**
+     * Create a new PrintConversionEventImpl.
+     *
+     * @param _severity The severity value for this event.  Must be one of
+     * ValidationEvent.WARNING, ValidationEvent.ERROR, or
+     * ValidationEvent.FATAL_ERROR
+     * @param _message The text message for this event - may be null.
+     * @param _locator The locator object for this event - may be null.
+     * @param _linkedException An optional linked exception that may provide
+     * additional information about the event - may be null.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public PrintConversionEventImpl( int _severity, String _message,
+                                      ValidationEventLocator _locator,
+                                      Throwable _linkedException) {
+
+        super(_severity, _message, _locator, _linkedException);
+    }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/ValidationEventImpl.java b/jaxws/src/share/classes/javax/xml/bind/helpers/ValidationEventImpl.java
new file mode 100644
index 0000000..2ccc069
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/ValidationEventImpl.java
@@ -0,0 +1,174 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.helpers;
+
+import java.text.MessageFormat;
+
+import javax.xml.bind.ValidationEvent;
+import javax.xml.bind.ValidationEventLocator;
+
+/**
+ * Default implementation of the ValidationEvent interface.
+ *
+ * <p>
+ * JAXB providers are allowed to use whatever class that implements
+ * the ValidationEvent interface. This class is just provided for a
+ * convenience.
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li></ul>
+ * @see javax.xml.bind.Validator
+ * @see javax.xml.bind.ValidationEventHandler
+ * @see javax.xml.bind.ValidationEvent
+ * @see javax.xml.bind.ValidationEventLocator
+ * @since JAXB1.0
+ */
+public class ValidationEventImpl implements ValidationEvent
+{
+
+    /**
+     * Create a new ValidationEventImpl.
+     *
+     * @param _severity The severity value for this event.  Must be one of
+     * ValidationEvent.WARNING, ValidationEvent.ERROR, or
+     * ValidationEvent.FATAL_ERROR
+     * @param _message The text message for this event - may be null.
+     * @param _locator The locator object for this event - may be null.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public ValidationEventImpl( int _severity, String _message,
+                                 ValidationEventLocator _locator ) {
+
+        this(_severity,_message,_locator,null);
+    }
+
+    /**
+     * Create a new ValidationEventImpl.
+     *
+     * @param _severity The severity value for this event.  Must be one of
+     * ValidationEvent.WARNING, ValidationEvent.ERROR, or
+     * ValidationEvent.FATAL_ERROR
+     * @param _message The text message for this event - may be null.
+     * @param _locator The locator object for this event - may be null.
+     * @param _linkedException An optional linked exception that may provide
+     * additional information about the event - may be null.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public ValidationEventImpl( int _severity, String _message,
+                                 ValidationEventLocator _locator,
+                                 Throwable _linkedException ) {
+
+        setSeverity( _severity );
+        this.message = _message;
+        this.locator = _locator;
+        this.linkedException = _linkedException;
+    }
+
+    private int severity;
+    private String message;
+    private Throwable linkedException;
+    private ValidationEventLocator locator;
+
+    public int getSeverity() {
+        return severity;
+    }
+
+
+    /**
+     * Set the severity field of this event.
+     *
+     * @param _severity Must be one of ValidationEvent.WARNING,
+     * ValidationEvent.ERROR, or ValidationEvent.FATAL_ERROR.
+     * @throws IllegalArgumentException if an illegal severity field is supplied
+     */
+    public void setSeverity( int _severity ) {
+
+        if( _severity != ValidationEvent.WARNING &&
+            _severity != ValidationEvent.ERROR &&
+            _severity != ValidationEvent.FATAL_ERROR ) {
+                throw new IllegalArgumentException(
+                    Messages.format( Messages.ILLEGAL_SEVERITY ) );
+        }
+
+        this.severity = _severity;
+    }
+
+    public String getMessage() {
+        return message;
+    }
+    /**
+     * Set the message field of this event.
+     *
+     * @param _message String message - may be null.
+     */
+    public void setMessage( String _message ) {
+        this.message = _message;
+    }
+
+    public Throwable getLinkedException() {
+        return linkedException;
+    }
+    /**
+     * Set the linked exception field of this event.
+     *
+     * @param _linkedException Optional linked exception - may be null.
+     */
+    public void setLinkedException( Throwable _linkedException ) {
+        this.linkedException = _linkedException;
+    }
+
+    public ValidationEventLocator getLocator() {
+        return locator;
+    }
+    /**
+     * Set the locator object for this event.
+     *
+     * @param _locator The locator - may be null.
+     */
+    public void setLocator( ValidationEventLocator _locator ) {
+        this.locator = _locator;
+    }
+
+    /**
+     * Returns a string representation of this object in a format
+     * helpful to debugging.
+     *
+     * @see Object#equals(Object)
+     */
+    public String toString() {
+        String s;
+        switch(getSeverity()) {
+        case WARNING:   s="WARNING";break;
+        case ERROR: s="ERROR";break;
+        case FATAL_ERROR: s="FATAL_ERROR";break;
+        default: s=String.valueOf(getSeverity());break;
+        }
+        return MessageFormat.format("[severity={0},message={1},locator={2}]",
+            new Object[]{
+                s,
+                getMessage(),
+                getLocator()
+            });
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/ValidationEventLocatorImpl.java b/jaxws/src/share/classes/javax/xml/bind/helpers/ValidationEventLocatorImpl.java
new file mode 100644
index 0000000..214bbab
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/ValidationEventLocatorImpl.java
@@ -0,0 +1,272 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.helpers;
+
+import java.net.URL;
+import java.net.MalformedURLException;
+import java.text.MessageFormat;
+
+import javax.xml.bind.ValidationEventLocator;
+import org.w3c.dom.Node;
+import org.xml.sax.Locator;
+import org.xml.sax.SAXParseException;
+
+/**
+ * Default implementation of the ValidationEventLocator interface.
+ *
+ * <p>
+ * JAXB providers are allowed to use whatever class that implements
+ * the ValidationEventLocator interface. This class is just provided for a
+ * convenience.
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li></ul>
+ * @see javax.xml.bind.Validator
+ * @see javax.xml.bind.ValidationEventHandler
+ * @see javax.xml.bind.ValidationEvent
+ * @see javax.xml.bind.ValidationEventLocator
+ * @since JAXB1.0
+ */
+public class ValidationEventLocatorImpl implements ValidationEventLocator
+{
+    /**
+     * Creates an object with all fields unavailable.
+     */
+    public ValidationEventLocatorImpl() {
+    }
+
+    /**
+     * Constructs an object from an org.xml.sax.Locator.
+     *
+     * The object's ColumnNumber, LineNumber, and URL become available from the
+     * values returned by the locator's getColumnNumber(), getLineNumber(), and
+     * getSystemId() methods respectively. Node, Object, and Offset are not
+     * available.
+     *
+     * @param loc the SAX Locator object that will be used to populate this
+     * event locator.
+     * @throws IllegalArgumentException if the Locator is null
+     */
+    public ValidationEventLocatorImpl( Locator loc ) {
+        if( loc == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "loc" ) );
+        }
+
+        this.url = toURL(loc.getSystemId());
+        this.columnNumber = loc.getColumnNumber();
+        this.lineNumber = loc.getLineNumber();
+    }
+
+    /**
+     * Constructs an object from the location information of a SAXParseException.
+     *
+     * The object's ColumnNumber, LineNumber, and URL become available from the
+     * values returned by the locator's getColumnNumber(), getLineNumber(), and
+     * getSystemId() methods respectively. Node, Object, and Offset are not
+     * available.
+     *
+     * @param e the SAXParseException object that will be used to populate this
+     * event locator.
+     * @throws IllegalArgumentException if the SAXParseException is null
+     */
+    public ValidationEventLocatorImpl( SAXParseException e ) {
+        if( e == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "e" ) );
+        }
+
+        this.url = toURL(e.getSystemId());
+        this.columnNumber = e.getColumnNumber();
+        this.lineNumber = e.getLineNumber();
+    }
+
+    /**
+     * Constructs an object that points to a DOM Node.
+     *
+     * The object's Node becomes available.  ColumnNumber, LineNumber, Object,
+     * Offset, and URL are not available.
+     *
+     * @param _node the DOM Node object that will be used to populate this
+     * event locator.
+     * @throws IllegalArgumentException if the Node is null
+     */
+    public ValidationEventLocatorImpl(Node _node) {
+        if( _node == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "_node" ) );
+        }
+
+        this.node = _node;
+    }
+
+    /**
+     * Constructs an object that points to a JAXB content object.
+     *
+     * The object's Object becomes available. ColumnNumber, LineNumber, Node,
+     * Offset, and URL are not available.
+     *
+     * @param _object the Object that will be used to populate this
+     * event locator.
+     * @throws IllegalArgumentException if the Object is null
+     */
+    public ValidationEventLocatorImpl(Object _object) {
+        if( _object == null ) {
+            throw new IllegalArgumentException(
+                Messages.format( Messages.MUST_NOT_BE_NULL, "_object" ) );
+        }
+
+        this.object = _object;
+    }
+
+    /** Converts a system ID to an URL object. */
+    private static URL toURL( String systemId ) {
+        try {
+            return new URL(systemId);
+        } catch( MalformedURLException e ) {
+            // TODO: how should we handle system id here?
+            return null;    // for now
+        }
+    }
+
+    private URL url = null;
+    private int offset = -1;
+    private int lineNumber = -1;
+    private int columnNumber = -1;
+    private Object object = null;
+    private Node node = null;
+
+
+    /**
+     * @see javax.xml.bind.ValidationEventLocator#getURL()
+     */
+    public URL getURL() {
+        return url;
+    }
+
+    /**
+     * Set the URL field on this event locator.  Null values are allowed.
+     *
+     * @param _url the url
+     */
+    public void setURL( URL _url ) {
+        this.url = _url;
+    }
+
+    /**
+     * @see javax.xml.bind.ValidationEventLocator#getOffset()
+     */
+    public int getOffset() {
+        return offset;
+    }
+
+    /**
+     * Set the offset field on this event locator.
+     *
+     * @param _offset the offset
+     */
+    public void setOffset( int _offset ) {
+        this.offset = _offset;
+    }
+
+    /**
+     * @see javax.xml.bind.ValidationEventLocator#getLineNumber()
+     */
+    public int getLineNumber() {
+        return lineNumber;
+    }
+
+    /**
+     * Set the lineNumber field on this event locator.
+     *
+     * @param _lineNumber the line number
+     */
+    public void setLineNumber( int _lineNumber ) {
+        this.lineNumber = _lineNumber;
+    }
+
+    /**
+     * @see javax.xml.bind.ValidationEventLocator#getColumnNumber()
+     */
+    public int getColumnNumber() {
+        return columnNumber;
+    }
+
+    /**
+     * Set the columnNumber field on this event locator.
+     *
+     * @param _columnNumber the column number
+     */
+    public void setColumnNumber( int _columnNumber ) {
+        this.columnNumber = _columnNumber;
+    }
+
+    /**
+     * @see javax.xml.bind.ValidationEventLocator#getObject()
+     */
+    public Object getObject() {
+        return object;
+    }
+
+    /**
+     * Set the Object field on this event locator.  Null values are allowed.
+     *
+     * @param _object the java content object
+     */
+    public void setObject( Object _object ) {
+        this.object = _object;
+    }
+
+    /**
+     * @see javax.xml.bind.ValidationEventLocator#getNode()
+     */
+    public Node getNode() {
+        return node;
+    }
+
+    /**
+     * Set the Node field on this event locator.  Null values are allowed.
+     *
+     * @param _node the Node
+     */
+    public void setNode( Node _node ) {
+        this.node = _node;
+    }
+
+    /**
+     * Returns a string representation of this object in a format
+     * helpful to debugging.
+     *
+     * @see Object#equals(Object)
+     */
+    public String toString() {
+        return MessageFormat.format("[node={0},object={1},url={2},line={3},col={4},offset={5}]",
+            getNode(),
+            getObject(),
+            getURL(),
+            String.valueOf(getLineNumber()),
+            String.valueOf(getColumnNumber()),
+            String.valueOf(getOffset()));
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/helpers/package.html b/jaxws/src/share/classes/javax/xml/bind/helpers/package.html
new file mode 100644
index 0000000..d92375e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/helpers/package.html
@@ -0,0 +1,61 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
+<html>
+    <head>
+        <!--
+Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+This code is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License version 2 only, as
+published by the Free Software Foundation.  Sun designates this
+particular file as subject to the "Classpath" exception as provided
+by Sun in the LICENSE file that accompanied this code.
+
+This code is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+version 2 for more details (a copy is included in the LICENSE file that
+accompanied this code).
+
+You should have received a copy of the GNU General Public License version
+2 along with this work; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+CA 95054 USA or visit www.sun.com if you need additional information or
+have any questions.
+        -->
+    </head>
+
+    <body bgcolor="white">
+
+        <p>
+        <B>JAXB Provider Use Only:</b> Provides partial default implementations for 
+        some of the <tt>javax.xml.bind</tt> interfaces.
+
+        <p>
+        JAXB Providers can extend these classes and implement the abstract 
+        methods.
+ 
+        <h2>Package Specification</h2>
+
+        <ul>
+            <li><a href="http://java.sun.com/xml/downloads/jaxb.html">JAXB 
+                Specification</a>
+        </ul>
+
+        <h2>Related Documentation</h2>
+
+        For overviews, tutorials, examples, guides, and tool documentation, 
+        please see:
+        <ul>
+            <li>The <a href="http://java.sun.com/xml/jaxb/index.html">JAXB 
+            Website</a>
+        </ul>
+
+        <!-- Put @see and @since tags down here. -->
+
+    </body>
+</html>
+
+
diff --git a/jaxws/src/share/classes/javax/xml/bind/package.html b/jaxws/src/share/classes/javax/xml/bind/package.html
new file mode 100644
index 0000000..48a697a
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/package.html
@@ -0,0 +1,62 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
+<html>
+    <head>
+        <!--
+Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+This code is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License version 2 only, as
+published by the Free Software Foundation.  Sun designates this
+particular file as subject to the "Classpath" exception as provided
+by Sun in the LICENSE file that accompanied this code.
+
+This code is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+version 2 for more details (a copy is included in the LICENSE file that
+accompanied this code).
+
+You should have received a copy of the GNU General Public License version
+2 along with this work; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+CA 95054 USA or visit www.sun.com if you need additional information or
+have any questions.
+        -->
+    </head>
+
+    <body bgcolor="white">
+
+        <p>
+        Provides a runtime binding framework for client applications including
+        unmarshalling, marshalling, and validation capabilities.
+
+        <p>
+        <tt>JAXBContext</tt> is the client-entry point to the runtime binding
+        framework.
+
+
+        <h2>Package Specification</h2>
+
+        <ul>
+            <li><a href="http://java.sun.com/xml/downloads/jaxb.html">JAXB 
+                Specification</a>
+        </ul>
+
+        <h2>Related Documentation</h2>
+
+        For overviews, tutorials, examples, guides, and tool documentation, 
+        please see:
+        <ul>
+            <li>The <a href="http://java.sun.com/xml/jaxb/index.html">JAXB 
+            Website</a>
+        </ul>
+
+        <!-- Put @see and @since tags down here. -->
+
+    </body>
+</html>
+
+
diff --git a/jaxws/src/share/classes/javax/xml/bind/util/JAXBResult.java b/jaxws/src/share/classes/javax/xml/bind/util/JAXBResult.java
new file mode 100644
index 0000000..d008846
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/util/JAXBResult.java
@@ -0,0 +1,149 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.util;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.bind.UnmarshallerHandler;
+import javax.xml.transform.sax.SAXResult;
+
+/**
+ * JAXP {@link javax.xml.transform.Result} implementation
+ * that unmarshals a JAXB object.
+ *
+ * <p>
+ * This utility class is useful to combine JAXB with
+ * other Java/XML technologies.
+ *
+ * <p>
+ * The following example shows how to use JAXB to unmarshal a document
+ * resulting from an XSLT transformation.
+ *
+ * <blockquote>
+ *    <pre>
+ *       JAXBResult result = new JAXBResult(
+ *         JAXBContext.newInstance("org.acme.foo") );
+ *
+ *       // set up XSLT transformation
+ *       TransformerFactory tf = TransformerFactory.newInstance();
+ *       Transformer t = tf.newTransformer(new StreamSource("test.xsl"));
+ *
+ *       // run transformation
+ *       t.transform(new StreamSource("document.xml"),result);
+ *
+ *       // obtain the unmarshalled content tree
+ *       Object o = result.getResult();
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * The fact that JAXBResult derives from SAXResult is an implementation
+ * detail. Thus in general applications are strongly discouraged from
+ * accessing methods defined on SAXResult.
+ *
+ * <p>
+ * In particular it shall never attempt to call the setHandler,
+ * setLexicalHandler, and setSystemId methods.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JAXBResult extends SAXResult {
+
+    /**
+     * Creates a new instance that uses the specified
+     * JAXBContext to unmarshal.
+     *
+     * @param context The JAXBContext that will be used to create the
+     * necessary Unmarshaller.  This parameter must not be null.
+     * @exception JAXBException if an error is encountered while creating the
+     * JAXBResult or if the context parameter is null.
+     */
+    public JAXBResult( JAXBContext context ) throws JAXBException {
+        this( ( context == null ) ? assertionFailed() : context.createUnmarshaller() );
+    }
+
+    /**
+     * Creates a new instance that uses the specified
+     * Unmarshaller to unmarshal an object.
+     *
+     * <p>
+     * This JAXBResult object will use the specified Unmarshaller
+     * instance. It is the caller's responsibility not to use the
+     * same Unmarshaller for other purposes while it is being
+     * used by this object.
+     *
+     * <p>
+     * The primary purpose of this method is to allow the client
+     * to configure Unmarshaller. Unless you know what you are doing,
+     * it's easier and safer to pass a JAXBContext.
+     *
+     * @param _unmarshaller the unmarshaller.  This parameter must not be null.
+     * @throws JAXBException if an error is encountered while creating the
+     * JAXBResult or the Unmarshaller parameter is null.
+     */
+    public JAXBResult( Unmarshaller _unmarshaller ) throws JAXBException {
+        if( _unmarshaller == null )
+            throw new JAXBException(
+                Messages.format( Messages.RESULT_NULL_UNMARSHALLER ) );
+
+        this.unmarshallerHandler = _unmarshaller.getUnmarshallerHandler();
+
+        super.setHandler(unmarshallerHandler);
+    }
+
+    /**
+     * Unmarshaller that will be used to unmarshal
+     * the input documents.
+     */
+    private final UnmarshallerHandler unmarshallerHandler;
+
+    /**
+     * Gets the unmarshalled object created by the transformation.
+     *
+     * @return
+     *      Always return a non-null object.
+     *
+     * @exception IllegalStateException
+     *  if this method is called before an object is unmarshalled.
+     *
+     * @exception JAXBException
+     *      if there is any unmarshalling error.
+     *      Note that the implementation is allowed to throw SAXException
+     *      during the parsing when it finds an error.
+     */
+    public Object getResult() throws JAXBException {
+        return unmarshallerHandler.getResult();
+    }
+
+    /**
+     * Hook to throw exception from the middle of a contructor chained call
+     * to this
+     */
+    private static Unmarshaller assertionFailed() throws JAXBException {
+        throw new JAXBException( Messages.format( Messages.RESULT_NULL_CONTEXT ) );
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/util/JAXBSource.java b/jaxws/src/share/classes/javax/xml/bind/util/JAXBSource.java
new file mode 100644
index 0000000..4d7bb9e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/util/JAXBSource.java
@@ -0,0 +1,270 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.util;
+
+import org.xml.sax.ContentHandler;
+import org.xml.sax.DTDHandler;
+import org.xml.sax.EntityResolver;
+import org.xml.sax.ErrorHandler;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+import org.xml.sax.SAXNotRecognizedException;
+import org.xml.sax.SAXParseException;
+import org.xml.sax.XMLReader;
+import org.xml.sax.ext.LexicalHandler;
+import org.xml.sax.helpers.XMLFilterImpl;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.transform.sax.SAXSource;
+
+/**
+ * JAXP {@link javax.xml.transform.Source} implementation
+ * that marshals a JAXB-generated object.
+ *
+ * <p>
+ * This utility class is useful to combine JAXB with
+ * other Java/XML technologies.
+ *
+ * <p>
+ * The following example shows how to use JAXB to marshal a document
+ * for transformation by XSLT.
+ *
+ * <blockquote>
+ *    <pre>
+ *       MyObject o = // get JAXB content tree
+ *
+ *       // jaxbContext is a JAXBContext object from which 'o' is created.
+ *       JAXBSource source = new JAXBSource( jaxbContext, o );
+ *
+ *       // set up XSLT transformation
+ *       TransformerFactory tf = TransformerFactory.newInstance();
+ *       Transformer t = tf.newTransformer(new StreamSource("test.xsl"));
+ *
+ *       // run transformation
+ *       t.transform(source,new StreamResult(System.out));
+ *    </pre>
+ * </blockquote>
+ *
+ * <p>
+ * The fact that JAXBSource derives from SAXSource is an implementation
+ * detail. Thus in general applications are strongly discouraged from
+ * accessing methods defined on SAXSource. In particular,
+ * the setXMLReader and setInputSource methods shall never be called.
+ * The XMLReader object obtained by the getXMLReader method shall
+ * be used only for parsing the InputSource object returned by
+ * the getInputSource method.
+ *
+ * <p>
+ * Similarly the InputSource object obtained by the getInputSource
+ * method shall be used only for being parsed by the XMLReader object
+ * returned by the getXMLReader.
+ *
+ * @author
+ *      Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com)
+ */
+public class JAXBSource extends SAXSource {
+
+    /**
+     * Creates a new {@link javax.xml.transform.Source} for the given content object.
+     *
+     * @param   context
+     *      JAXBContext that was used to create
+     *      <code>contentObject</code>. This context is used
+     *      to create a new instance of marshaller and must not be null.
+     * @param   contentObject
+     *      An instance of a JAXB-generated class, which will be
+     *      used as a {@link javax.xml.transform.Source} (by marshalling it into XML).  It must
+     *      not be null.
+     * @throws JAXBException if an error is encountered while creating the
+     * JAXBSource or if either of the parameters are null.
+     */
+    public JAXBSource( JAXBContext context, Object contentObject )
+        throws JAXBException {
+
+        this(
+            ( context == null ) ?
+                assertionFailed( Messages.format( Messages.SOURCE_NULL_CONTEXT ) ) :
+                context.createMarshaller(),
+
+            ( contentObject == null ) ?
+                assertionFailed( Messages.format( Messages.SOURCE_NULL_CONTENT ) ) :
+                contentObject);
+    }
+
+    /**
+     * Creates a new {@link javax.xml.transform.Source} for the given content object.
+     *
+     * @param   marshaller
+     *      A marshaller instance that will be used to marshal
+     *      <code>contentObject</code> into XML. This must be
+     *      created from a JAXBContext that was used to build
+     *      <code>contentObject</code> and must not be null.
+     * @param   contentObject
+     *      An instance of a JAXB-generated class, which will be
+     *      used as a {@link javax.xml.transform.Source} (by marshalling it into XML).  It must
+     *      not be null.
+     * @throws JAXBException if an error is encountered while creating the
+     * JAXBSource or if either of the parameters are null.
+     */
+    public JAXBSource( Marshaller marshaller, Object contentObject )
+        throws JAXBException {
+
+        if( marshaller == null )
+            throw new JAXBException(
+                Messages.format( Messages.SOURCE_NULL_MARSHALLER ) );
+
+        if( contentObject == null )
+            throw new JAXBException(
+                Messages.format( Messages.SOURCE_NULL_CONTENT ) );
+
+        this.marshaller = marshaller;
+        this.contentObject = contentObject;
+
+        super.setXMLReader(pseudoParser);
+        // pass a dummy InputSource. We don't care
+        super.setInputSource(new InputSource());
+    }
+
+    private final Marshaller marshaller;
+    private final Object contentObject;
+
+    // this object will pretend as an XMLReader.
+    // no matter what parameter is specified to the parse method,
+    // it just parse the contentObject.
+    private final XMLReader pseudoParser = new XMLReader() {
+        public boolean getFeature(String name) throws SAXNotRecognizedException {
+            if(name.equals("http://xml.org/sax/features/namespaces"))
+                return true;
+            if(name.equals("http://xml.org/sax/features/namespace-prefixes"))
+                return false;
+            throw new SAXNotRecognizedException(name);
+        }
+
+        public void setFeature(String name, boolean value) throws SAXNotRecognizedException {
+            if(name.equals("http://xml.org/sax/features/namespaces") && value)
+                return;
+            if(name.equals("http://xml.org/sax/features/namespace-prefixes") && !value)
+                return;
+            throw new SAXNotRecognizedException(name);
+        }
+
+        public Object getProperty(String name) throws SAXNotRecognizedException {
+            if( "http://xml.org/sax/properties/lexical-handler".equals(name) ) {
+                return lexicalHandler;
+            }
+            throw new SAXNotRecognizedException(name);
+        }
+
+        public void setProperty(String name, Object value) throws SAXNotRecognizedException {
+            if( "http://xml.org/sax/properties/lexical-handler".equals(name) ) {
+                this.lexicalHandler = (LexicalHandler)value;
+                return;
+            }
+            throw new SAXNotRecognizedException(name);
+        }
+
+        private LexicalHandler lexicalHandler;
+
+        // we will store this value but never use it by ourselves.
+        private EntityResolver entityResolver;
+        public void setEntityResolver(EntityResolver resolver) {
+            this.entityResolver = resolver;
+        }
+        public EntityResolver getEntityResolver() {
+            return entityResolver;
+        }
+
+        private DTDHandler dtdHandler;
+        public void setDTDHandler(DTDHandler handler) {
+            this.dtdHandler = handler;
+        }
+        public DTDHandler getDTDHandler() {
+            return dtdHandler;
+        }
+
+        // SAX allows ContentHandler to be changed during the parsing,
+        // but JAXB doesn't. So this repeater will sit between those
+        // two components.
+        private XMLFilterImpl repeater = new XMLFilterImpl();
+
+        public void setContentHandler(ContentHandler handler) {
+            repeater.setContentHandler(handler);
+        }
+        public ContentHandler getContentHandler() {
+            return repeater.getContentHandler();
+        }
+
+        private ErrorHandler errorHandler;
+        public void setErrorHandler(ErrorHandler handler) {
+            this.errorHandler = handler;
+        }
+        public ErrorHandler getErrorHandler() {
+            return errorHandler;
+        }
+
+        public void parse(InputSource input) throws SAXException {
+            parse();
+        }
+
+        public void parse(String systemId) throws SAXException {
+            parse();
+        }
+
+        public void parse() throws SAXException {
+            // parses a content object by using the given marshaller
+            // SAX events will be sent to the repeater, and the repeater
+            // will further forward it to an appropriate component.
+            try {
+                marshaller.marshal( contentObject, repeater );
+            } catch( JAXBException e ) {
+                // wrap it to a SAXException
+                SAXParseException se =
+                    new SAXParseException( e.getMessage(),
+                        null, null, -1, -1, e );
+
+                // if the consumer sets an error handler, it is our responsibility
+                // to notify it.
+                if(errorHandler!=null)
+                    errorHandler.fatalError(se);
+
+                // this is a fatal error. Even if the error handler
+                // returns, we will abort anyway.
+                throw se;
+            }
+        }
+    };
+
+    /**
+     * Hook to throw exception from the middle of a contructor chained call
+     * to this
+     */
+    private static Marshaller assertionFailed( String message )
+        throws JAXBException {
+
+        throw new JAXBException( message );
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/util/Messages.java b/jaxws/src/share/classes/javax/xml/bind/util/Messages.java
new file mode 100644
index 0000000..4ad988f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/util/Messages.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.bind.util;
+
+import java.text.MessageFormat;
+import java.util.ResourceBundle;
+
+/**
+ * Formats error messages.
+ */
+class Messages
+{
+    static String format( String property ) {
+        return format( property, null );
+    }
+
+    static String format( String property, Object arg1 ) {
+        return format( property, new Object[]{arg1} );
+    }
+
+    static String format( String property, Object arg1, Object arg2 ) {
+        return format( property, new Object[]{arg1,arg2} );
+    }
+
+    static String format( String property, Object arg1, Object arg2, Object arg3 ) {
+        return format( property, new Object[]{arg1,arg2,arg3} );
+    }
+
+    // add more if necessary.
+
+    /** Loads a string resource and formats it with specified arguments. */
+    static String format( String property, Object[] args ) {
+        String text = ResourceBundle.getBundle(Messages.class.getName()).getString(property);
+        return MessageFormat.format(text,args);
+    }
+
+//
+//
+// Message resources
+//
+//
+    static final String UNRECOGNIZED_SEVERITY = // 1 arg
+        "ValidationEventCollector.UnrecognizedSeverity";
+
+    static final String RESULT_NULL_CONTEXT = // 0 args
+        "JAXBResult.NullContext";
+
+    static final String RESULT_NULL_UNMARSHALLER = // 0 arg
+        "JAXBResult.NullUnmarshaller";
+
+    static final String SOURCE_NULL_CONTEXT = // 0 args
+        "JAXBSource.NullContext";
+
+    static final String SOURCE_NULL_CONTENT = // 0 arg
+        "JAXBSource.NullContent";
+
+    static final String SOURCE_NULL_MARSHALLER = // 0 arg
+        "JAXBSource.NullMarshaller";
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/util/Messages.properties b/jaxws/src/share/classes/javax/xml/bind/util/Messages.properties
new file mode 100644
index 0000000..09b8163
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/util/Messages.properties
@@ -0,0 +1,18 @@
+ValidationEventCollector.UnrecognizedSeverity = \
+	Unrecognized event severity field "{0}"
+	
+JAXBResult.NullContext = \
+	JAXBContext can not be null
+	
+JAXBResult.NullUnmarshaller = \
+	Unmarshaller can not be null
+	
+JAXBSource.NullContext = \
+	JAXBContext can not be null
+	
+JAXBSource.NullContent = \
+	Content object can not be null
+	
+JAXBSource.NullMarshaller = \
+	Marshaller can not be null
+ 
diff --git a/jaxws/src/share/classes/javax/xml/bind/util/ValidationEventCollector.java b/jaxws/src/share/classes/javax/xml/bind/util/ValidationEventCollector.java
new file mode 100644
index 0000000..70026b0
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/util/ValidationEventCollector.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.bind.util;
+
+import java.util.Vector;
+import javax.xml.bind.ValidationEventHandler;
+import javax.xml.bind.ValidationEvent;
+
+/**
+ * {@link javax.xml.bind.ValidationEventHandler ValidationEventHandler}
+ * implementation that collects all events.
+ *
+ * <p>
+ * To use this class, create a new instance and pass it to the setEventHandler
+ * method of the Validator, Unmarshaller, Marshaller class.  After the call to
+ * validate or unmarshal completes, call the getEvents method to retrieve all
+ * the reported errors and warnings.
+ *
+ * @author <ul><li>Kohsuke Kawaguchi, Sun Microsystems, Inc.</li><li>Ryan Shoemaker, Sun Microsystems, Inc.</li><li>Joe Fialli, Sun Microsystems, Inc.</li></ul>
+ * @see javax.xml.bind.Validator
+ * @see javax.xml.bind.ValidationEventHandler
+ * @see javax.xml.bind.ValidationEvent
+ * @see javax.xml.bind.ValidationEventLocator
+ * @since JAXB1.0
+ */
+public class ValidationEventCollector implements ValidationEventHandler
+{
+    private final Vector<ValidationEvent> events = new Vector<ValidationEvent>();
+
+    /**
+     * Return an array of ValidationEvent objects containing a copy of each of
+     * the collected errors and warnings.
+     *
+     * @return
+     *      a copy of all the collected errors and warnings or an empty array
+     *      if there weren't any
+     */
+    public ValidationEvent[] getEvents() {
+        return events.toArray(new ValidationEvent[events.size()]);
+    }
+
+    /**
+     * Clear all collected errors and warnings.
+     */
+    public void reset() {
+        events.removeAllElements();
+    }
+
+    /**
+     * Returns true if this event collector contains at least one
+     * ValidationEvent.
+     *
+     * @return true if this event collector contains at least one
+     *         ValidationEvent, false otherwise
+     */
+    public boolean hasEvents() {
+        return !events.isEmpty();
+    }
+
+    public boolean handleEvent( ValidationEvent event ) {
+        events.add(event);
+
+        boolean retVal = true;
+        switch( event.getSeverity() ) {
+            case ValidationEvent.WARNING:
+                retVal = true; // continue validation
+                break;
+            case ValidationEvent.ERROR:
+                retVal = true; // continue validation
+                break;
+            case ValidationEvent.FATAL_ERROR:
+                retVal = false; // halt validation
+                break;
+            default:
+                _assert( false,
+                         Messages.format( Messages.UNRECOGNIZED_SEVERITY,
+                                 event.getSeverity() ) );
+                break;
+        }
+
+        return retVal;
+    }
+
+    private static void _assert( boolean b, String msg ) {
+        if( !b ) {
+            throw new InternalError( msg );
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/bind/util/package.html b/jaxws/src/share/classes/javax/xml/bind/util/package.html
new file mode 100644
index 0000000..2a6e209
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/bind/util/package.html
@@ -0,0 +1,56 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
+<html>
+    <head>
+        <!--
+Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+This code is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License version 2 only, as
+published by the Free Software Foundation.  Sun designates this
+particular file as subject to the "Classpath" exception as provided
+by Sun in the LICENSE file that accompanied this code.
+
+This code is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+version 2 for more details (a copy is included in the LICENSE file that
+accompanied this code).
+
+You should have received a copy of the GNU General Public License version
+2 along with this work; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+CA 95054 USA or visit www.sun.com if you need additional information or
+have any questions.
+        -->
+    </head>
+
+    <body bgcolor="white">
+
+        <p>
+        Useful client utility classes.
+
+        <h2>Package Specification</h2>
+
+        <ul>
+            <li><a href="http://java.sun.com/xml/downloads/jaxb.html">JAXB 
+                Specification</a>
+        </ul>
+
+        <h2>Related Documentation</h2>
+
+        For overviews, tutorials, examples, guides, and tool documentation, 
+        please see:
+        <ul>
+            <li>The <a href="http://java.sun.com/xml/jaxb/index.html">JAXB 
+            Website</a>
+        </ul>
+
+        <!-- Put @see and @since tags down here. -->
+
+    </body>
+</html>
+
+
diff --git a/jaxws/src/share/classes/javax/xml/soap/AttachmentPart.java b/jaxws/src/share/classes/javax/xml/soap/AttachmentPart.java
new file mode 100644
index 0000000..98fe277
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/AttachmentPart.java
@@ -0,0 +1,531 @@
+/*
+ * $Id: AttachmentPart.java,v 1.11 2005/08/17 08:13:01 vj135062 Exp $
+ * $Revision: 1.11 $
+ * $Date: 2005/08/17 08:13:01 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import java.io.InputStream;
+import java.io.Reader;
+import java.util.Iterator;
+
+import javax.activation.DataHandler;
+
+/**
+ * A single attachment to a <code>SOAPMessage</code> object. A <code>SOAPMessage</code>
+ * object may contain zero, one, or many <code>AttachmentPart</code> objects.
+ * Each <code>AttachmentPart</code> object consists of two parts,
+ * application-specific content and associated MIME headers. The
+ * MIME headers consists of name/value pairs that can be used to
+ * identify and describe the content.
+ * <p>
+ * An <code>AttachmentPart</code> object must conform to certain standards.
+ * <OL>
+ * <LI>It must conform to <a href="http://www.ietf.org/rfc/rfc2045.txt">
+ *     MIME [RFC2045] standards</a>
+ * <LI>It MUST contain content
+ * <LI>The header portion MUST include the following header:
+ *  <UL>
+ *   <LI><code>Content-Type</code><br>
+ *       This header identifies the type of data in the content of an
+ *       <code>AttachmentPart</code> object and MUST conform to [RFC2045].
+ *       The following is an example of a Content-Type header:
+ *       <PRE>
+ *       Content-Type:  application/xml
+ *       </PRE>
+ *       The following line of code, in which <code>ap</code> is an
+ *       <code>AttachmentPart</code> object, sets the header shown in
+ *       the previous example.
+ *       <PRE>
+ *       ap.setMimeHeader("Content-Type", "application/xml");
+ *       </PRE>
+ * <p>
+ *  </UL>
+ * </OL>
+ * <p>
+ * There are no restrictions on the content portion of an <code>
+ * AttachmentPart</code> object. The content may be anything from a
+ * simple plain text object to a complex XML document or image file.
+ *
+ * <p>
+ * An <code>AttachmentPart</code> object is created with the method
+ * <code>SOAPMessage.createAttachmentPart</code>. After setting its MIME headers,
+ *  the <code>AttachmentPart</code> object is added to the message
+ * that created it with the method <code>SOAPMessage.addAttachmentPart</code>.
+ *
+ * <p>
+ * The following code fragment, in which <code>m</code> is a
+ * <code>SOAPMessage</code> object and <code>contentStringl</code> is a
+ * <code>String</code>, creates an instance of <code>AttachmentPart</code>,
+ * sets the <code>AttachmentPart</code> object with some content and
+ * header information, and adds the <code>AttachmentPart</code> object to
+ * the <code>SOAPMessage</code> object.
+ * <PRE>
+ *     AttachmentPart ap1 = m.createAttachmentPart();
+ *     ap1.setContent(contentString1, "text/plain");
+ *     m.addAttachmentPart(ap1);
+ * </PRE>
+ *
+ *
+ * <p>
+ * The following code fragment creates and adds a second
+ * <code>AttachmentPart</code> instance to the same message. <code>jpegData</code>
+ * is a binary byte buffer representing the jpeg file.
+ * <PRE>
+ *     AttachmentPart ap2 = m.createAttachmentPart();
+ *     byte[] jpegData =  ...;
+ *     ap2.setContent(new ByteArrayInputStream(jpegData), "image/jpeg");
+ *     m.addAttachmentPart(ap2);
+ * </PRE>
+ * <p>
+ * The <code>getContent</code> method retrieves the contents and header from
+ * an <code>AttachmentPart</code> object. Depending on the
+ * <code>DataContentHandler</code> objects present, the returned
+ * <code>Object</code> can either be a typed Java object corresponding
+ * to the MIME type or an <code>InputStream</code> object that contains the
+ * content as bytes.
+ * <PRE>
+ *     String content1 = ap1.getContent();
+ *     java.io.InputStream content2 = ap2.getContent();
+ * </PRE>
+ *
+ * The method <code>clearContent</code> removes all the content from an
+ * <code>AttachmentPart</code> object but does not affect its header information.
+ * <PRE>
+ *     ap1.clearContent();
+ * </PRE>
+ */
+
+public abstract class AttachmentPart {
+    /**
+     * Returns the number of bytes in this <code>AttachmentPart</code>
+     * object.
+     *
+     * @return the size of this <code>AttachmentPart</code> object in bytes
+     *         or -1 if the size cannot be determined
+     * @exception SOAPException if the content of this attachment is
+     *            corrupted of if there was an exception while trying
+     *            to determine the size.
+     */
+    public abstract int getSize() throws SOAPException;
+
+    /**
+     * Clears out the content of this <code>AttachmentPart</code> object.
+     * The MIME header portion is left untouched.
+     */
+    public abstract void clearContent();
+
+    /**
+     * Gets the content of this <code>AttachmentPart</code> object as a Java
+     * object. The type of the returned Java object depends on (1) the
+     * <code>DataContentHandler</code> object that is used to interpret the bytes
+     * and (2) the <code>Content-Type</code> given in the header.
+     * <p>
+     * For the MIME content types "text/plain", "text/html" and "text/xml", the
+     * <code>DataContentHandler</code> object does the conversions to and
+     * from the Java types corresponding to the MIME types.
+     * For other MIME types,the <code>DataContentHandler</code> object
+     * can return an <code>InputStream</code> object that contains the content data
+     * as raw bytes.
+     * <p>
+     * A SAAJ-compliant implementation must, as a minimum, return a
+     * <code>java.lang.String</code> object corresponding to any content
+     * stream with a <code>Content-Type</code> value of
+     * <code>text/plain</code>, a
+     * <code>javax.xml.transform.stream.StreamSource</code> object corresponding to a
+     * content stream with a <code>Content-Type</code> value of
+     * <code>text/xml</code>, a <code>java.awt.Image</code> object
+     * corresponding to a content stream with a
+     * <code>Content-Type</code> value of <code>image/gif</code> or
+     * <code>image/jpeg</code>.  For those content types that an
+     * installed <code>DataContentHandler</code> object does not understand, the
+     * <code>DataContentHandler</code> object is required to return a
+     * <code>java.io.InputStream</code> object with the raw bytes.
+     *
+     * @return a Java object with the content of this <code>AttachmentPart</code>
+     *         object
+     *
+     * @exception SOAPException if there is no content set into this
+     *            <code>AttachmentPart</code> object or if there was a data
+     *            transformation error
+     */
+    public abstract Object getContent() throws SOAPException;
+
+    /**
+     * Gets the content of this <code>AttachmentPart</code> object as an
+     * InputStream as if a call had been made to <code>getContent</code> and no
+     * <code>DataContentHandler</code> had been registered for the
+     * <code>content-type</code> of this <code>AttachmentPart</code>.
+     *<p>
+     * Note that reading from the returned InputStream would result in consuming
+     * the data in the stream. It is the responsibility of the caller to reset
+     * the InputStream appropriately before calling a Subsequent API. If a copy
+     * of the raw attachment content is required then the {@link #getRawContentBytes} API
+     * should be used instead.
+     *
+     * @return an <code>InputStream</code> from which the raw data contained by
+     *      the <code>AttachmentPart</code> can be accessed.
+     *
+     * @throws SOAPException if there is no content set into this
+     *      <code>AttachmentPart</code> object or if there was a data
+     *      transformation error.
+     *
+     * @since SAAJ 1.3
+     * @see #getRawContentBytes
+     */
+    public abstract InputStream getRawContent() throws SOAPException;
+
+    /**
+     * Gets the content of this <code>AttachmentPart</code> object as a
+     * byte[] array as if a call had been made to <code>getContent</code> and no
+     * <code>DataContentHandler</code> had been registered for the
+     * <code>content-type</code> of this <code>AttachmentPart</code>.
+     *
+     * @return a <code>byte[]</code> array containing the raw data of the
+     *      <code>AttachmentPart</code>.
+     *
+     * @throws SOAPException if there is no content set into this
+     *      <code>AttachmentPart</code> object or if there was a data
+     *      transformation error.
+     *
+     * @since SAAJ 1.3
+     */
+    public abstract byte[] getRawContentBytes() throws SOAPException;
+
+    /**
+     * Returns an <code>InputStream</code> which can be used to obtain the
+     * content of <code>AttachmentPart</code>  as Base64 encoded
+     * character data, this method would base64 encode the raw bytes
+     * of the attachment and return.
+     *
+     * @return an <code>InputStream</code> from which the Base64 encoded
+     *       <code>AttachmentPart</code> can be read.
+     *
+     * @throws SOAPException if there is no content set into this
+     *      <code>AttachmentPart</code> object or if there was a data
+     *      transformation error.
+     *
+     * @since SAAJ 1.3
+     */
+    public abstract InputStream getBase64Content() throws SOAPException;
+
+    /**
+     * Sets the content of this attachment part to that of the given
+     * <code>Object</code> and sets the value of the <code>Content-Type</code>
+     * header to the given type. The type of the
+     * <code>Object</code> should correspond to the value given for the
+     * <code>Content-Type</code>. This depends on the particular
+     * set of <code>DataContentHandler</code> objects in use.
+     *
+     *
+     * @param object the Java object that makes up the content for
+     *               this attachment part
+     * @param contentType the MIME string that specifies the type of
+     *                  the content
+     *
+     * @exception IllegalArgumentException may be thrown if the contentType
+     *            does not match the type of the content object, or if there
+     *            was no <code>DataContentHandler</code> object for this
+     *            content object
+     *
+     * @see #getContent
+     */
+    public abstract void setContent(Object object, String contentType);
+
+    /**
+     * Sets the content of this attachment part to that contained by the
+     * <code>InputStream</code> <code>content</code> and sets the value of the
+     * <code>Content-Type</code> header to the value contained in
+     * <code>contentType</code>.
+     * <P>
+     *  A subsequent call to getSize() may not be an exact measure
+     *  of the content size.
+     *
+     * @param content the raw data to add to the attachment part
+     * @param contentType the value to set into the <code>Content-Type</code>
+     * header
+     *
+     * @exception SOAPException if an there is an error in setting the content
+     * @exception NullPointerException if <code>content</code> is null
+     * @since SAAJ 1.3
+     */
+    public abstract void setRawContent(InputStream content, String contentType) throws SOAPException;
+
+    /**
+     * Sets the content of this attachment part to that contained by the
+     * <code>byte[]</code> array <code>content</code> and sets the value of the
+     * <code>Content-Type</code> header to the value contained in
+     * <code>contentType</code>.
+     *
+     * @param content the raw data to add to the attachment part
+     * @param contentType the value to set into the <code>Content-Type</code>
+     * header
+     * @param offset the offset in the byte array of the content
+     * @param len the number of bytes that form the content
+     *
+     * @exception SOAPException if an there is an error in setting the content
+     * or content is null
+     * @since SAAJ 1.3
+     */
+    public abstract void setRawContentBytes(
+        byte[] content, int offset, int len,  String contentType)
+        throws SOAPException;
+
+
+    /**
+     * Sets the content of this attachment part from the Base64 source
+     * <code>InputStream</code>  and sets the value of the
+     * <code>Content-Type</code> header to the value contained in
+     * <code>contentType</code>, This method would first decode the base64
+     * input and write the resulting raw bytes to the attachment.
+     * <P>
+     *  A subsequent call to getSize() may not be an exact measure
+     *  of the content size.
+     *
+     * @param content the base64 encoded data to add to the attachment part
+     * @param contentType the value to set into the <code>Content-Type</code>
+     * header
+     *
+     * @exception SOAPException if an there is an error in setting the content
+     * @exception NullPointerException if <code>content</code> is null
+     *
+     * @since SAAJ 1.3
+     */
+    public abstract void setBase64Content(
+        InputStream content, String contentType) throws SOAPException;
+
+
+    /**
+     * Gets the <code>DataHandler</code> object for this <code>AttachmentPart</code>
+     * object.
+     *
+     * @return the <code>DataHandler</code> object associated with this
+     *         <code>AttachmentPart</code> object
+     *
+     * @exception SOAPException if there is no data in
+     * this <code>AttachmentPart</code> object
+     */
+    public abstract DataHandler getDataHandler()
+        throws SOAPException;
+
+    /**
+     * Sets the given <code>DataHandler</code> object as the data handler
+     * for this <code>AttachmentPart</code> object. Typically, on an incoming
+     * message, the data handler is automatically set. When
+     * a message is being created and populated with content, the
+     * <code>setDataHandler</code> method can be used to get data from
+     * various data sources into the message.
+     *
+     * @param dataHandler the <code>DataHandler</code> object to be set
+     *
+     * @exception IllegalArgumentException if there was a problem with
+     *            the specified <code>DataHandler</code> object
+     */
+    public abstract void setDataHandler(DataHandler dataHandler);
+
+
+    /**
+     * Gets the value of the MIME header whose name is "Content-ID".
+     *
+     * @return a <code>String</code> giving the value of the
+     *          "Content-ID" header or <code>null</code> if there
+     *          is none
+     * @see #setContentId
+     */
+    public String getContentId() {
+        String[] values = getMimeHeader("Content-ID");
+        if (values != null && values.length > 0)
+            return values[0];
+        return null;
+    }
+
+    /**
+     * Gets the value of the MIME header whose name is "Content-Location".
+     *
+     * @return a <code>String</code> giving the value of the
+     *          "Content-Location" header or <code>null</code> if there
+     *          is none
+     */
+    public String getContentLocation() {
+        String[] values = getMimeHeader("Content-Location");
+        if (values != null && values.length > 0)
+            return values[0];
+        return null;
+    }
+
+    /**
+     * Gets the value of the MIME header whose name is "Content-Type".
+     *
+     * @return a <code>String</code> giving the value of the
+     *          "Content-Type" header or <code>null</code> if there
+     *          is none
+     */
+    public String getContentType() {
+        String[] values = getMimeHeader("Content-Type");
+        if (values != null && values.length > 0)
+            return values[0];
+        return null;
+    }
+
+    /**
+     * Sets the MIME header whose name is "Content-ID" with the given value.
+     *
+     * @param contentId a <code>String</code> giving the value of the
+     *          "Content-ID" header
+     *
+     * @exception IllegalArgumentException if there was a problem with
+     *            the specified <code>contentId</code> value
+     * @see #getContentId
+     */
+    public void setContentId(String contentId)
+    {
+        setMimeHeader("Content-ID", contentId);
+    }
+
+
+    /**
+     * Sets the MIME header whose name is "Content-Location" with the given value.
+     *
+     *
+     * @param contentLocation a <code>String</code> giving the value of the
+     *          "Content-Location" header
+     * @exception IllegalArgumentException if there was a problem with
+     *            the specified content location
+     */
+    public void setContentLocation(String contentLocation)
+    {
+        setMimeHeader("Content-Location", contentLocation);
+    }
+
+    /**
+     * Sets the MIME header whose name is "Content-Type" with the given value.
+     *
+     * @param contentType a <code>String</code> giving the value of the
+     *          "Content-Type" header
+     *
+     * @exception IllegalArgumentException if there was a problem with
+     *            the specified content type
+     */
+    public void setContentType(String contentType)
+    {
+        setMimeHeader("Content-Type", contentType);
+    }
+
+    /**
+     * Removes all MIME headers that match the given name.
+     *
+     * @param header the string name of the MIME header/s to
+     *               be removed
+     */
+    public abstract void removeMimeHeader(String header);
+
+    /**
+     * Removes all the MIME header entries.
+     */
+    public abstract void removeAllMimeHeaders();
+
+
+    /**
+     * Gets all the values of the header identified by the given
+     * <code>String</code>.
+     *
+     * @param name the name of the header; example: "Content-Type"
+     * @return a <code>String</code> array giving the value for the
+     *         specified header
+     * @see #setMimeHeader
+     */
+    public abstract String[] getMimeHeader(String name);
+
+
+    /**
+     * Changes the first header entry that matches the given name
+     * to the given value, adding a new header if no existing header
+     * matches. This method also removes all matching headers but the first. <p>
+     *
+     * Note that RFC822 headers can only contain US-ASCII characters.
+     *
+     * @param   name    a <code>String</code> giving the name of the header
+     *                  for which to search
+     * @param   value   a <code>String</code> giving the value to be set for
+     *                  the header whose name matches the given name
+     *
+     * @exception IllegalArgumentException if there was a problem with
+     *            the specified mime header name or value
+     */
+    public abstract void setMimeHeader(String name, String value);
+
+
+    /**
+     * Adds a MIME header with the specified name and value to this
+     * <code>AttachmentPart</code> object.
+     * <p>
+     * Note that RFC822 headers can contain only US-ASCII characters.
+     *
+     * @param   name    a <code>String</code> giving the name of the header
+     *                  to be added
+     * @param   value   a <code>String</code> giving the value of the header
+     *                  to be added
+     *
+     * @exception IllegalArgumentException if there was a problem with
+     *            the specified mime header name or value
+     */
+    public abstract void addMimeHeader(String name, String value);
+
+    /**
+     * Retrieves all the headers for this <code>AttachmentPart</code> object
+     * as an iterator over the <code>MimeHeader</code> objects.
+     *
+     * @return  an <code>Iterator</code> object with all of the Mime
+     *          headers for this <code>AttachmentPart</code> object
+     */
+    public abstract Iterator getAllMimeHeaders();
+
+    /**
+     * Retrieves all <code>MimeHeader</code> objects that match a name in
+     * the given array.
+     *
+     * @param names a <code>String</code> array with the name(s) of the
+     *        MIME headers to be returned
+     * @return  all of the MIME headers that match one of the names in the
+     *           given array as an <code>Iterator</code> object
+     */
+    public abstract Iterator getMatchingMimeHeaders(String[] names);
+
+    /**
+     * Retrieves all <code>MimeHeader</code> objects whose name does
+     * not match a name in the given array.
+     *
+     * @param names a <code>String</code> array with the name(s) of the
+     *        MIME headers not to be returned
+     * @return  all of the MIME headers in this <code>AttachmentPart</code> object
+     *          except those that match one of the names in the
+     *           given array.  The nonmatching MIME headers are returned as an
+     *           <code>Iterator</code> object.
+     */
+    public abstract Iterator getNonMatchingMimeHeaders(String[] names);
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/Detail.java b/jaxws/src/share/classes/javax/xml/soap/Detail.java
new file mode 100644
index 0000000..33176a1
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/Detail.java
@@ -0,0 +1,104 @@
+/*
+ * $Id: Detail.java,v 1.7 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.7 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+/**
+ * A container for <code>DetailEntry</code> objects. <code>DetailEntry</code>
+ * objects give detailed error information that is application-specific and
+ * related to the <code>SOAPBody</code> object that contains it.
+ *<P>
+ * A <code>Detail</code> object, which is part of a <code>SOAPFault</code>
+ * object, can be retrieved using the method <code>SOAPFault.getDetail</code>.
+ * The <code>Detail</code> interface provides two methods. One creates a new
+ * <code>DetailEntry</code> object and also automatically adds it to
+ * the <code>Detail</code> object. The second method gets a list of the
+ * <code>DetailEntry</code> objects contained in a <code>Detail</code>
+ * object.
+ * <P>
+ * The following code fragment, in which <i>sf</i> is a <code>SOAPFault</code>
+ * object, gets its <code>Detail</code> object (<i>d</i>), adds a new
+ * <code>DetailEntry</code> object to <i>d</i>, and then gets a list of all the
+ * <code>DetailEntry</code> objects in <i>d</i>. The code also creates a
+ * <code>Name</code> object to pass to the method <code>addDetailEntry</code>.
+ * The variable <i>se</i>, used to create the <code>Name</code> object,
+ * is a <code>SOAPEnvelope</code> object.
+ * <PRE>
+ *    Detail d = sf.getDetail();
+ *    Name name = se.createName("GetLastTradePrice", "WOMBAT",
+ *                                "http://www.wombat.org/trader");
+ *    d.addDetailEntry(name);
+ *    Iterator it = d.getDetailEntries();
+ * </PRE>
+ */
+public interface Detail extends SOAPFaultElement {
+
+    /**
+     * Creates a new <code>DetailEntry</code> object with the given
+     * name and adds it to this <code>Detail</code> object.
+     *
+     * @param name a <code>Name</code> object identifying the
+     *         new <code>DetailEntry</code> object
+     *
+     * @exception SOAPException thrown when there is a problem in adding a
+     * DetailEntry object to this Detail object.
+     *
+     * @see Detail#addDetailEntry(QName qname)
+     */
+    public DetailEntry addDetailEntry(Name name) throws SOAPException;
+
+    /**
+     * Creates a new <code>DetailEntry</code> object with the given
+     * QName and adds it to this <code>Detail</code> object. This method
+     * is the preferred over the one using Name.
+     *
+     * @param qname a <code>QName</code> object identifying the
+     *         new <code>DetailEntry</code> object
+     *
+     * @exception SOAPException thrown when there is a problem in adding a
+     * DetailEntry object to this Detail object.
+     *
+     * @see Detail#addDetailEntry(Name name)
+     * @since SAAJ 1.3
+     */
+    public DetailEntry addDetailEntry(QName qname) throws SOAPException;
+
+    /**
+     * Gets an Iterator over all of the <code>DetailEntry</code>s in this <code>Detail</code> object.
+     *
+     * @return an <code>Iterator</code> object over the <code>DetailEntry</code>
+     *             objects in this <code>Detail</code> object
+     */
+    public Iterator getDetailEntries();
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/DetailEntry.java b/jaxws/src/share/classes/javax/xml/soap/DetailEntry.java
new file mode 100644
index 0000000..eac373e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/DetailEntry.java
@@ -0,0 +1,41 @@
+/*
+ * $Id: DetailEntry.java,v 1.2 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.2 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * The content for a <code>Detail</code> object, giving details for
+ * a <code>SOAPFault</code> object.  A <code>DetailEntry</code> object,
+ * which carries information about errors related to the <code>SOAPBody</code>
+ * object that contains it, is application-specific.
+ */
+public interface DetailEntry extends SOAPElement {
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/FactoryFinder.java b/jaxws/src/share/classes/javax/xml/soap/FactoryFinder.java
new file mode 100644
index 0000000..67ac61b
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/FactoryFinder.java
@@ -0,0 +1,187 @@
+/*
+ * $Id: FactoryFinder.java,v 1.5 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.5 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.soap;
+
+import java.io.*;
+import java.util.Properties;
+
+
+class FactoryFinder {
+
+    /**
+     * Creates an instance of the specified class using the specified
+     * <code>ClassLoader</code> object.
+     *
+     * @exception SOAPException if the given class could not be found
+     *            or could not be instantiated
+     */
+    private static Object newInstance(String className,
+                                      ClassLoader classLoader)
+        throws SOAPException
+    {
+        try {
+            Class spiClass;
+            if (classLoader == null) {
+                spiClass = Class.forName(className);
+            } else {
+                spiClass = classLoader.loadClass(className);
+            }
+            return spiClass.newInstance();
+        } catch (ClassNotFoundException x) {
+            throw new SOAPException(
+                "Provider " + className + " not found", x);
+        } catch (Exception x) {
+            throw new SOAPException(
+                "Provider " + className + " could not be instantiated: " + x,
+                x);
+        }
+    }
+
+    /**
+     * Finds the implementation <code>Class</code> object for the given
+     * factory name, or null if that fails.
+     * <P>
+     * This method is package private so that this code can be shared.
+     *
+     * @return the <code>Class</code> object of the specified message factory;
+     *         or <code>null</code>
+     *
+     * @param factoryId             the name of the factory to find, which is
+     *                              a system property
+     * @exception SOAPException if there is a SOAP error
+     */
+    static Object find(String factoryId)
+        throws SOAPException
+    {
+        ClassLoader classLoader;
+        try {
+            classLoader = Thread.currentThread().getContextClassLoader();
+        } catch (Exception x) {
+            throw new SOAPException(x.toString(), x);
+        }
+
+        // Use the system property first
+        try {
+            String systemProp =
+                System.getProperty( factoryId );
+            if( systemProp!=null) {
+                return newInstance(systemProp, classLoader);
+            }
+        } catch (SecurityException se) {
+        }
+
+        // try to read from $java.home/lib/jaxm.properties
+        try {
+            String javah=System.getProperty( "java.home" );
+            String configFile = javah + File.separator +
+                "lib" + File.separator + "jaxm.properties";
+            File f=new File( configFile );
+            if( f.exists()) {
+                Properties props=new Properties();
+                props.load( new FileInputStream(f));
+                String factoryClassName = props.getProperty(factoryId);
+                return newInstance(factoryClassName, classLoader);
+            }
+        } catch(Exception ex ) {
+        }
+
+        String serviceId = "META-INF/services/" + factoryId;
+        // try to find services in CLASSPATH
+        try {
+            InputStream is=null;
+            if (classLoader == null) {
+                is=ClassLoader.getSystemResourceAsStream(serviceId);
+            } else {
+                is=classLoader.getResourceAsStream(serviceId);
+            }
+
+            if( is!=null ) {
+                BufferedReader rd =
+                    new BufferedReader(new InputStreamReader(is, "UTF-8"));
+
+                String factoryClassName = rd.readLine();
+                rd.close();
+
+                if (factoryClassName != null &&
+                    ! "".equals(factoryClassName)) {
+                    return newInstance(factoryClassName, classLoader);
+                }
+            }
+        } catch( Exception ex ) {
+        }
+
+        return null;
+    }
+
+    /**
+     * Finds the implementation <code>Class</code> object for the given
+     * factory name, or if that fails, finds the <code>Class</code> object
+     * for the given fallback class name. The arguments supplied must be
+     * used in order. If using the first argument is successful, the second
+     * one will not be used.
+     * <P>
+     * This method is package private so that this code can be shared.
+     *
+     * @return the <code>Class</code> object of the specified message factory;
+     *         may not be <code>null</code>
+     *
+     * @param factoryId             the name of the factory to find, which is
+     *                              a system property
+     * @param fallbackClassName     the implementation class name, which is
+     *                              to be used only if nothing else
+     *                              is found; <code>null</code> to indicate that
+     *                              there is no fallback class name
+     * @exception SOAPException if there is a SOAP error
+     */
+    static Object find(String factoryId, String fallbackClassName)
+        throws SOAPException
+    {
+
+        Object obj = find(factoryId);
+        if (obj != null)
+            return obj;
+
+        ClassLoader classLoader;
+        try {
+            classLoader = Thread.currentThread().getContextClassLoader();
+        } catch (Exception x) {
+            throw new SOAPException(x.toString(), x);
+        }
+
+        if (fallbackClassName == null) {
+            throw new SOAPException(
+                "Provider for " + factoryId + " cannot be found", null);
+        }
+
+        return newInstance(fallbackClassName, classLoader);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/MessageFactory.java b/jaxws/src/share/classes/javax/xml/soap/MessageFactory.java
new file mode 100644
index 0000000..fee378c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/MessageFactory.java
@@ -0,0 +1,201 @@
+/*
+ * $Id: MessageFactory.java,v 1.9 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.9 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+
+import java.io.IOException;
+import java.io.InputStream;
+
+/**
+ * A factory for creating <code>SOAPMessage</code> objects.
+ * <P>
+ * A SAAJ client can create a <code>MessageFactory</code> object
+ * using the method <code>newInstance</code>, as shown in the following
+ * lines of code.
+ * <PRE>
+ *       MessageFactory mf = MessageFactory.newInstance();
+ *       MessageFactory mf12 = MessageFactory.newInstance(SOAPConstants.SOAP_1_2_PROTOCOL);
+ * </PRE>
+ * <P>
+ * All <code>MessageFactory</code> objects, regardless of how they are
+ * created, will produce <code>SOAPMessage</code> objects that
+ * have the following elements by default:
+ * <UL>
+ *  <LI>A <code>SOAPPart</code> object
+ *  <LI>A <code>SOAPEnvelope</code> object
+ *  <LI>A <code>SOAPBody</code> object
+ *  <LI>A <code>SOAPHeader</code> object
+ * </UL>
+ * In some cases, specialized MessageFactory objects may be obtained that produce messages
+ * prepopulated with additional entries in the <code>SOAPHeader</code> object and the
+ * <code>SOAPBody</code> object.
+ * The content of a new <code>SOAPMessage</code> object depends on which of the two
+ * <code>MessageFactory</code> methods is used to create it.
+ * <UL>
+ *  <LI><code>createMessage()</code> <BR>
+ *      This is the method clients would normally use to create a request message.
+ *  <LI><code>createMessage(MimeHeaders, java.io.InputStream)</code> -- message has
+ *       content from the <code>InputStream</code> object and headers from the
+ *       <code>MimeHeaders</code> object <BR>
+ *        This method can be used internally by a service implementation to
+ *        create a message that is a response to a request.
+ * </UL>
+ */
+public abstract class MessageFactory {
+
+    static private final String DEFAULT_MESSAGE_FACTORY
+        = "com.sun.xml.internal.messaging.saaj.soap.ver1_1.SOAPMessageFactory1_1Impl";
+
+    static private final String MESSAGE_FACTORY_PROPERTY
+        = "javax.xml.soap.MessageFactory";
+
+    /**
+     * Creates a new <code>MessageFactory</code> object that is an instance
+     * of the default implementation (SOAP 1.1),
+     *
+     * This method uses the following ordered lookup procedure to determine the MessageFactory implementation class to load:
+     * <UL>
+     *  <LI> Use the javax.xml.soap.MessageFactory system property.
+     *  <LI> Use the properties file "lib/jaxm.properties" in the JRE directory. This configuration file is in standard
+     * java.util.Properties format and contains the fully qualified name of the implementation class with the key being the
+     * system property defined above.
+     *  <LI> Use the Services API (as detailed in the JAR specification), if available, to determine the classname. The Services API
+     * will look for a classname in the file META-INF/services/javax.xml.soap.MessageFactory in jars available to the runtime.
+     *  <LI> Use the SAAJMetaFactory instance to locate the MessageFactory implementation class.
+     * </UL>
+
+     *
+     * @return a new instance of a <code>MessageFactory</code>
+     *
+     * @exception SOAPException if there was an error in creating the
+     *            default implementation of the
+     *            <code>MessageFactory</code>.
+     * @see SAAJMetaFactory
+     */
+
+    public static MessageFactory newInstance()
+        throws SOAPException {
+        try {
+            MessageFactory factory = (MessageFactory)
+                FactoryFinder.find(MESSAGE_FACTORY_PROPERTY);
+
+            if (factory != null)
+                return factory;
+
+            return newInstance(SOAPConstants.SOAP_1_1_PROTOCOL);
+        } catch (Exception ex) {
+            throw new SOAPException(
+                    "Unable to create message factory for SOAP: "
+                                    +ex.getMessage());
+        }
+
+    }
+
+    /**
+     * Creates a new <code>MessageFactory</code> object that is an instance
+     * of the specified implementation.  May be a dynamic message factory,
+     * a SOAP 1.1 message factory, or a SOAP 1.2 message factory. A dynamic
+     * message factory creates messages based on the MIME headers specified
+     * as arguments to the <code>createMessage</code> method.
+     *
+     * This method uses the SAAJMetaFactory to locate the implementation class
+     * and create the MessageFactory instance.
+     *
+     * @return a new instance of a <code>MessageFactory</code>
+     *
+     * @param protocol  a string constant representing the class of the
+     *                   specified message factory implementation. May be
+     *                   either <code>DYNAMIC_SOAP_PROTOCOL</code>,
+     *                   <code>DEFAULT_SOAP_PROTOCOL</code> (which is the same
+     *                   as) <code>SOAP_1_1_PROTOCOL</code>, or
+     *                   <code>SOAP_1_2_PROTOCOL</code>.
+     *
+     * @exception SOAPException if there was an error in creating the
+     *            specified implementation of  <code>MessageFactory</code>.
+     * @see SAAJMetaFactory
+     * @since SAAJ 1.3
+     */
+    public static MessageFactory newInstance(String protocol) throws SOAPException {
+        return SAAJMetaFactory.getInstance().newMessageFactory(protocol);
+    }
+
+    /**
+     * Creates a new <code>SOAPMessage</code> object with the default
+     * <code>SOAPPart</code>, <code>SOAPEnvelope</code>, <code>SOAPBody</code>,
+     * and <code>SOAPHeader</code> objects. Profile-specific message factories
+     * can choose to prepopulate the <code>SOAPMessage</code> object with
+     * profile-specific headers.
+     * <P>
+     * Content can be added to this message's <code>SOAPPart</code> object, and
+     * the message can be sent "as is" when a message containing only a SOAP part
+     * is sufficient. Otherwise, the <code>SOAPMessage</code> object needs
+     * to create one or more <code>AttachmentPart</code> objects and
+     * add them to itself. Any content that is not in XML format must be
+     * in an <code>AttachmentPart</code> object.
+     *
+     * @return a new <code>SOAPMessage</code> object
+     * @exception SOAPException if a SOAP error occurs
+     * @exception UnsupportedOperationException if the protocol of this
+     *      <code>MessageFactory</code> instance is <code>DYNAMIC_SOAP_PROTOCOL</code>
+     */
+    public abstract SOAPMessage createMessage()
+        throws SOAPException;
+
+    /**
+     * Internalizes the contents of the given <code>InputStream</code> object into a
+     * new <code>SOAPMessage</code> object and returns the <code>SOAPMessage</code>
+     * object.
+     *
+     * @param in the <code>InputStream</code> object that contains the data
+     *           for a message
+     * @param headers the transport-specific headers passed to the
+     *        message in a transport-independent fashion for creation of the
+     *        message
+     * @return a new <code>SOAPMessage</code> object containing the data from
+     *         the given <code>InputStream</code> object
+     *
+     * @exception IOException if there is a problem in reading data from
+     *            the input stream
+     *
+     * @exception SOAPException may be thrown if the message is invalid
+     *
+     * @exception IllegalArgumentException if the <code>MessageFactory</code>
+     *      requires one or more MIME headers to be present in the
+     *      <code>headers</code> parameter and they are missing.
+     *      <code>MessageFactory</code> implementations for
+     *      <code>SOAP_1_1_PROTOCOL</code> or
+     *      <code>SOAP_1_2_PROTOCOL</code> must not throw
+     *      <code>IllegalArgumentException</code> for this reason.
+     */
+    public abstract SOAPMessage createMessage(MimeHeaders headers,
+                                              InputStream in)
+        throws IOException, SOAPException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/MimeHeader.java b/jaxws/src/share/classes/javax/xml/soap/MimeHeader.java
new file mode 100644
index 0000000..c4bda58
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/MimeHeader.java
@@ -0,0 +1,75 @@
+/*
+ * $Id: MimeHeader.java,v 1.2 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.2 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+
+/**
+ * An object that stores a MIME header name and its value. One or more
+ * <code>MimeHeader</code> objects may be contained in a <code>MimeHeaders</code>
+ * object.
+ *
+ * @see MimeHeaders
+ */
+public class MimeHeader {
+
+   private String name;
+   private String value;
+
+   /**
+    * Constructs a <code>MimeHeader</code> object initialized with the given
+    * name and value.
+    *
+    * @param name a <code>String</code> giving the name of the header
+    * @param value a <code>String</code> giving the value of the header
+    */
+    public MimeHeader(String name, String value) {
+        this.name = name;
+        this.value = value;
+    }
+
+    /**
+     * Returns the name of this <code>MimeHeader</code> object.
+     *
+     * @return the name of the header as a <code>String</code>
+     */
+    public String getName() {
+        return name;
+    }
+
+    /**
+     * Returns the value of this <code>MimeHeader</code> object.
+     *
+     * @return  the value of the header as a <code>String</code>
+     */
+    public String getValue() {
+        return value;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/MimeHeaders.java b/jaxws/src/share/classes/javax/xml/soap/MimeHeaders.java
new file mode 100644
index 0000000..209131f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/MimeHeaders.java
@@ -0,0 +1,274 @@
+/*
+ * $Id: MimeHeaders.java,v 1.4 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.4 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import java.util.Iterator;
+import java.util.Vector;
+
+/**
+ * A container for <code>MimeHeader</code> objects, which represent
+ * the MIME headers present in a MIME part of a message.
+ *
+ * <p>This class is used primarily when an application wants to
+ * retrieve specific attachments based on certain MIME headers and
+ * values. This class will most likely be used by implementations of
+ * <code>AttachmentPart</code> and other MIME dependent parts of the SAAJ
+ * API.
+ * @see SOAPMessage#getAttachments
+ * @see AttachmentPart
+ */
+public class MimeHeaders {
+    private Vector headers;
+
+   /**
+    * Constructs a default <code>MimeHeaders</code> object initialized with
+    * an empty <code>Vector</code> object.
+    */
+    public MimeHeaders() {
+        headers = new Vector();
+    }
+
+    /**
+     * Returns all of the values for the specified header as an array of
+     * <code>String</code> objects.
+     *
+     * @param   name the name of the header for which values will be returned
+     * @return a <code>String</code> array with all of the values for the
+     *         specified header
+     * @see #setHeader
+     */
+    public String[] getHeader(String name) {
+        Vector values = new Vector();
+
+        for(int i = 0; i < headers.size(); i++) {
+            MimeHeader hdr = (MimeHeader) headers.elementAt(i);
+            if (hdr.getName().equalsIgnoreCase(name)
+                && hdr.getValue() != null)
+                values.addElement(hdr.getValue());
+        }
+
+        if (values.size() == 0)
+            return null;
+
+        String r[] = new String[values.size()];
+        values.copyInto(r);
+        return r;
+    }
+
+    /**
+     * Replaces the current value of the first header entry whose name matches
+     * the given name with the given value, adding a new header if no existing header
+     * name matches. This method also removes all matching headers after the first one.
+     * <P>
+     * Note that RFC822 headers can contain only US-ASCII characters.
+     *
+     * @param   name a <code>String</code> with the name of the header for
+     *          which to search
+     * @param   value a <code>String</code> with the value that will replace the
+     *          current value of the specified header
+     *
+     * @exception IllegalArgumentException if there was a problem in the
+     * mime header name or the value being set
+     * @see #getHeader
+     */
+    public void setHeader(String name, String value)
+    {
+        boolean found = false;
+
+        if ((name == null) || name.equals(""))
+            throw new IllegalArgumentException("Illegal MimeHeader name");
+
+        for(int i = 0; i < headers.size(); i++) {
+            MimeHeader hdr = (MimeHeader) headers.elementAt(i);
+            if (hdr.getName().equalsIgnoreCase(name)) {
+                if (!found) {
+                    headers.setElementAt(new MimeHeader(hdr.getName(),
+                                                        value), i);
+                    found = true;
+                }
+                else
+                    headers.removeElementAt(i--);
+            }
+        }
+
+        if (!found)
+            addHeader(name, value);
+    }
+
+    /**
+     * Adds a <code>MimeHeader</code> object with the specified name and value
+     * to this <code>MimeHeaders</code> object's list of headers.
+     * <P>
+     * Note that RFC822 headers can contain only US-ASCII characters.
+     *
+     * @param   name a <code>String</code> with the name of the header to
+     *          be added
+     * @param   value a <code>String</code> with the value of the header to
+     *          be added
+     *
+     * @exception IllegalArgumentException if there was a problem in the
+     * mime header name or value being added
+     */
+    public void addHeader(String name, String value)
+    {
+        if ((name == null) || name.equals(""))
+            throw new IllegalArgumentException("Illegal MimeHeader name");
+
+        int pos = headers.size();
+
+        for(int i = pos - 1 ; i >= 0; i--) {
+            MimeHeader hdr = (MimeHeader) headers.elementAt(i);
+            if (hdr.getName().equalsIgnoreCase(name)) {
+                headers.insertElementAt(new MimeHeader(name, value),
+                                        i+1);
+                return;
+            }
+        }
+        headers.addElement(new MimeHeader(name, value));
+    }
+
+    /**
+     * Remove all <code>MimeHeader</code> objects whose name matches the
+     * given name.
+     *
+     * @param   name a <code>String</code> with the name of the header for
+     *          which to search
+     */
+    public void removeHeader(String name) {
+        for(int i = 0; i < headers.size(); i++) {
+            MimeHeader hdr = (MimeHeader) headers.elementAt(i);
+            if (hdr.getName().equalsIgnoreCase(name))
+                headers.removeElementAt(i--);
+        }
+    }
+
+    /**
+     * Removes all the header entries from this <code>MimeHeaders</code> object.
+     */
+    public void removeAllHeaders() {
+        headers.removeAllElements();
+    }
+
+
+    /**
+     * Returns all the <code>MimeHeader</code>s in this <code>MimeHeaders</code> object.
+     *
+     * @return  an <code>Iterator</code> object over this <code>MimeHeaders</code>
+     *          object's list of <code>MimeHeader</code> objects
+     */
+    public Iterator getAllHeaders() {
+        return headers.iterator();
+    }
+
+    class MatchingIterator implements Iterator {
+        private boolean match;
+        private Iterator iterator;
+        private String[] names;
+        private Object nextHeader;
+
+        MatchingIterator(String[] names, boolean match) {
+            this.match = match;
+            this.names = names;
+            this.iterator = headers.iterator();
+        }
+
+        private Object nextMatch() {
+        next:
+            while (iterator.hasNext()) {
+                MimeHeader hdr = (MimeHeader) iterator.next();
+
+                if (names == null)
+                    return match ? null : hdr;
+
+                for(int i = 0; i < names.length; i++)
+                    if (hdr.getName().equalsIgnoreCase(names[i]))
+                        if (match)
+                            return hdr;
+                        else
+                            continue next;
+                if (!match)
+                    return hdr;
+            }
+            return null;
+        }
+
+
+        public boolean hasNext() {
+            if (nextHeader == null)
+                nextHeader = nextMatch();
+            return nextHeader != null;
+        }
+
+        public Object next() {
+            // hasNext should've prefetched the header for us,
+            // return it.
+            if (nextHeader != null) {
+                Object ret = nextHeader;
+                nextHeader = null;
+                return ret;
+            }
+            if (hasNext())
+                return nextHeader;
+            return null;
+        }
+
+        public void remove() {
+            iterator.remove();
+        }
+    }
+
+
+    /**
+     * Returns all the <code>MimeHeader</code> objects whose name matches
+     * a name in the given array of names.
+     *
+     * @param names an array of <code>String</code> objects with the names
+     *         for which to search
+     * @return  an <code>Iterator</code> object over the <code>MimeHeader</code>
+     *          objects whose name matches one of the names in the given list
+     */
+    public Iterator getMatchingHeaders(String[] names) {
+        return new MatchingIterator(names, true);
+    }
+
+    /**
+     * Returns all of the <code>MimeHeader</code> objects whose name does not
+     * match a name in the given array of names.
+     *
+     * @param names an array of <code>String</code> objects with the names
+     *         for which to search
+     * @return  an <code>Iterator</code> object over the <code>MimeHeader</code>
+     *          objects whose name does not match one of the names in the given list
+     */
+    public Iterator getNonMatchingHeaders(String[] names) {
+        return new MatchingIterator(names, false);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/Name.java b/jaxws/src/share/classes/javax/xml/soap/Name.java
new file mode 100644
index 0000000..e5699bd
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/Name.java
@@ -0,0 +1,115 @@
+/*
+ * $Id: Name.java,v 1.3 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.3 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * A representation of an XML name.  This interface provides methods for
+ * getting the local and namespace-qualified names and also for getting the
+ * prefix associated with the namespace for the name. It is also possible
+ * to get the URI of the namespace.
+ * <P>
+ * The following is an example of a namespace declaration in an element.
+ * <PRE>
+ *   &lt;wombat:GetLastTradePrice xmlns:wombat="http://www.wombat.org/trader"&gt;
+ * </PRE>
+ * ("xmlns" stands for "XML namespace".)
+ * The following
+ * shows what the methods in the <code>Name</code> interface will return.
+ * <UL>
+ *  <LI><code>getQualifiedName</code> will return "prefix:LocalName" =
+ *      "WOMBAT:GetLastTradePrice"
+ *  <LI><code>getURI</code> will return "http://www.wombat.org/trader"
+ *  <LI><code>getLocalName</code> will return "GetLastTracePrice"
+ *  <LI><code>getPrefix</code> will return "WOMBAT"
+ * </UL>
+ * <P>
+ * XML namespaces are used to disambiguate SOAP identifiers from
+ * application-specific identifiers.
+ * <P>
+ * <code>Name</code> objects are created using the method
+ * <code>SOAPEnvelope.createName</code>, which has two versions.
+ * One method creates <code>Name</code> objects with
+ * a local name, a namespace prefix, and a namespace URI.
+ *  and the second creates <code>Name</code> objects with just a local name.
+ * The following line of
+ * code, in which <i>se</i> is a <code>SOAPEnvelope</code> object, creates a new
+ * <code>Name</code> object with all three.
+ * <PRE>
+ *     Name name = se.createName("GetLastTradePrice", "WOMBAT",
+ *                                "http://www.wombat.org/trader");
+ * </PRE>
+ * The following line of code gives an example of how a <code>Name</code> object
+ * can be used. The variable <i>element</i> is a <code>SOAPElement</code> object.
+ * This code creates a new <code>SOAPElement</code> object with the given name and
+ * adds it to <i>element</i>.
+ * <PRE>
+ *     element.addChildElement(name);
+ * </PRE>
+ * <P>
+ * The <code>Name</code> interface may be deprecated in a future release of SAAJ
+ * in favor of <code>javax.xml.namespace.QName</code>
+ * @see SOAPEnvelope#createName(String, String, String) SOAPEnvelope.createName
+ * @see SOAPFactory#createName(String, String, String) SOAPFactory.createName
+ */
+public interface Name {
+    /**
+     * Gets the local name part of the XML name that this <code>Name</code>
+     * object represents.
+     *
+     * @return a string giving the local name
+     */
+    String getLocalName();
+
+    /**
+     * Gets the namespace-qualified name of the XML name that this
+     * <code>Name</code> object represents.
+     *
+     * @return the namespace-qualified name as a string
+     */
+    String getQualifiedName();
+
+    /**
+     * Returns the prefix that was specified when this <code>Name</code> object
+     * was initialized. This prefix is associated with the namespace for the XML
+     * name that this <code>Name</code> object represents.
+     *
+     * @return the prefix as a string
+     */
+    String getPrefix();
+
+    /**
+     * Returns the URI of the namespace for the XML
+     * name that this <code>Name</code> object represents.
+     *
+     * @return the URI as a string
+     */
+    String getURI();
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/Node.java b/jaxws/src/share/classes/javax/xml/soap/Node.java
new file mode 100644
index 0000000..4695d29
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/Node.java
@@ -0,0 +1,117 @@
+/*
+ * $Id: Node.java,v 1.12 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.12 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * A representation of a node (element) in an XML document.
+ * This interface extnends the standard DOM Node interface with methods for
+ * getting and setting the value of a node, for
+ * getting and setting the parent of a node, and for removing a node.
+ */
+public interface Node extends org.w3c.dom.Node {
+    /**
+     * Returns the value of this node if this is a <code>Text</code> node or the
+     * value of the immediate child of this node otherwise.
+     * If there is an immediate child of this <code>Node</code> that it is a
+     * <code>Text</code> node then it's value will be returned. If there is
+     * more than one <code>Text</code> node then the value of the first
+     * <code>Text</code> Node will be returned.
+     * Otherwise <code>null</code> is returned.
+     *
+     * @return a <code>String</code> with the text of this node if this is a
+     *          <code>Text</code> node or the text contained by the first
+     *          immediate child of this <code>Node</code> object that is a
+     *          <code>Text</code> object if such a child exists;
+     *          <code>null</code> otherwise.
+     */
+    public String getValue();
+
+    /**
+     * If this is a Text node then this method will set its value,
+     * otherwise it sets the value of  the immediate (Text) child of this node.
+     * The value of the immediate child of this node can be set only if, there is
+     * one child node and that node is a <code>Text</code> node, or if
+     * there are no children in which case a child <code>Text</code> node will be
+     * created.
+     *
+     * @exception IllegalStateException if the node is not a <code>Text</code>
+     *              node and either has more than one child node or has a child
+     *              node that is not a <code>Text</code> node.
+     *
+     * @since SAAJ 1.2
+     */
+    public void setValue(String value);
+
+    /**
+     * Sets the parent of this <code>Node</code> object to the given
+     * <code>SOAPElement</code> object.
+     *
+     * @param parent the <code>SOAPElement</code> object to be set as
+     *       the parent of this <code>Node</code> object
+     *
+     * @exception SOAPException if there is a problem in setting the
+     *                          parent to the given element
+     * @see #getParentElement
+     */
+    public void setParentElement(SOAPElement parent) throws SOAPException;
+
+    /**
+     * Returns the parent element of this <code>Node</code> object.
+     * This method can throw an <code>UnsupportedOperationException</code>
+     * if the tree is not kept in memory.
+     *
+     * @return the <code>SOAPElement</code> object that is the parent of
+     *         this <code>Node</code> object or <code>null</code> if this
+     *         <code>Node</code> object is root
+     *
+     * @exception UnsupportedOperationException if the whole tree is not
+     *            kept in memory
+     * @see #setParentElement
+     */
+    public SOAPElement getParentElement();
+
+    /**
+     * Removes this <code>Node</code> object from the tree.
+     */
+    public void detachNode();
+
+    /**
+     * Notifies the implementation that this <code>Node</code>
+     * object is no longer being used by the application and that the
+     * implementation is free to reuse this object for nodes that may
+     * be created later.
+     * <P>
+     * Calling the method <code>recycleNode</code> implies that the method
+     * <code>detachNode</code> has been called previously.
+     */
+    public void recycleNode();
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SAAJMetaFactory.java b/jaxws/src/share/classes/javax/xml/soap/SAAJMetaFactory.java
new file mode 100644
index 0000000..42fcb84
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SAAJMetaFactory.java
@@ -0,0 +1,123 @@
+/*
+ * $Id: SAAJMetaFactory.java,v 1.2.2.15 2005/02/11 07:26:15 vj135062 Exp $
+ * $Revision: 1.2.2.15 $
+ * $Date: 2005/02/11 07:26:15 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+* The access point for the implementation classes of the factories defined in the
+* SAAJ API. All of the <code>newInstance</code> methods defined on factories in
+* SAAJ 1.3 defer to instances of this class to do the actual object creation.
+* The implementations of <code>newInstance()</code> methods (in SOAPFactory and MessageFactory)
+* that existed in SAAJ 1.2 have been updated to also delegate to the SAAJMetaFactory when the SAAJ 1.2
+* defined lookup fails to locate the Factory implementation class name.
+*
+* <p>
+* SAAJMetaFactory is a service provider interface. There are no public methods on this
+* class.
+*
+* @author SAAJ RI Development Team
+* @since SAAJ 1.3
+*/
+
+public abstract class SAAJMetaFactory {
+    static private final String META_FACTORY_CLASS_PROPERTY =
+        "javax.xml.soap.MetaFactory";
+    static private final String DEFAULT_META_FACTORY_CLASS =
+        "com.sun.xml.internal.messaging.saaj.soap.SAAJMetaFactoryImpl";
+
+    static private SAAJMetaFactory instance = null;
+
+    /**
+     * Creates a new instance of a concrete <code>SAAJMetaFactory</code> object.
+     * The SAAJMetaFactory is an SPI, it pulls the creation of the other factories together into a
+     * single place. Changing out the SAAJMetaFactory has the effect of changing out the entire SAAJ
+     * implementation. Service providers provide the name of their <code>SAAJMetaFactory</code>
+     * implementation.
+     *
+     * This method uses the following ordered lookup procedure to determine the SAAJMetaFactory implementation class to load:
+     * <UL>
+     *  <LI> Use the javax.xml.soap.MetaFactory system property.
+     *  <LI> Use the properties file "lib/jaxm.properties" in the JRE directory. This configuration file is in standard
+     * java.util.Properties format and contains the fully qualified name of the implementation class with the key being the
+     * system property defined above.
+     *  <LI> Use the Services API (as detailed in the JAR specification), if available, to determine the classname. The Services API
+     * will look for a classname in the file META-INF/services/javax.xml.soap.MetaFactory in jars available to the runtime.
+     *  <LI> Default to com.sun.xml.internal.messaging.saaj.soap.SAAJMetaFactoryImpl.
+     * </UL>
+     *
+     * @return a concrete <code>SAAJMetaFactory</code> object
+     * @exception SOAPException if there is an error in creating the <code>SAAJMetaFactory</code>
+     */
+    static synchronized SAAJMetaFactory getInstance() throws SOAPException {
+        if (instance == null) {
+            try {
+                instance =
+                    (SAAJMetaFactory) FactoryFinder.find(
+                        META_FACTORY_CLASS_PROPERTY,
+                        DEFAULT_META_FACTORY_CLASS);
+            } catch (Exception e) {
+                throw new SOAPException(
+                    "Unable to create SAAJ meta-factory" + e.getMessage());
+            }
+        }
+
+        return instance;
+    }
+
+    protected SAAJMetaFactory() { }
+
+     /**
+      * Creates a <code>MessageFactory</code> object for
+      * the given <code>String</code> protocol.
+      *
+      * @param protocol a <code>String</code> indicating the protocol
+      * @exception SOAPException if there is an error in creating the
+      *            MessageFactory
+      * @see SOAPConstants#SOAP_1_1_PROTOCOL
+      * @see SOAPConstants#SOAP_1_2_PROTOCOL
+      * @see SOAPConstants#DYNAMIC_SOAP_PROTOCOL
+      */
+    protected abstract MessageFactory newMessageFactory(String protocol)
+        throws SOAPException;
+
+     /**
+      * Creates a <code>SOAPFactory</code> object for
+      * the given <code>String</code> protocol.
+      *
+      * @param protocol a <code>String</code> indicating the protocol
+      * @exception SOAPException if there is an error in creating the
+      *            SOAPFactory
+      * @see SOAPConstants#SOAP_1_1_PROTOCOL
+      * @see SOAPConstants#SOAP_1_2_PROTOCOL
+      * @see SOAPConstants#DYNAMIC_SOAP_PROTOCOL
+      */
+    protected abstract SOAPFactory newSOAPFactory(String protocol)
+        throws SOAPException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SAAJResult.java b/jaxws/src/share/classes/javax/xml/soap/SAAJResult.java
new file mode 100644
index 0000000..f46b06e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SAAJResult.java
@@ -0,0 +1,137 @@
+/*
+ * $Id: SAAJResult.java,v 1.3 2006/03/09 16:09:42 vj135062 Exp $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.soap;
+
+import javax.xml.transform.dom.DOMResult;
+
+/**
+ * Acts as a holder for the results of a JAXP transformation or a JAXB
+ * marshalling, in the form of a SAAJ tree. These results should be accessed
+ * by using the {@link #getResult()} method. The {@link DOMResult#getNode()}
+ * method should be avoided in almost all cases.
+ *
+ * @author XWS-Security Development Team
+ *
+ * @since SAAJ 1.3
+ */
+public class SAAJResult extends DOMResult {
+
+    /**
+     * Creates a <code>SAAJResult</code> that will present results in the form
+     * of a SAAJ tree that supports the default (SOAP 1.1) protocol.
+     * <p>
+     * This kind of <code>SAAJResult</code> is meant for use in situations where the
+     * results will be used as a parameter to a method that takes a parameter
+     * whose type, such as <code>SOAPElement</code>, is drawn from the SAAJ
+     * API. When used in a transformation, the results are populated into the
+     * <code>SOAPPart</code> of a <code>SOAPMessage</code> that is created internally.
+     * The <code>SOAPPart</code> returned by {@link DOMResult#getNode()}
+     * is not guaranteed to be well-formed.
+     *
+     * @throws SOAPException if there is a problem creating a <code>SOAPMessage</code>
+     *
+     * @since SAAJ 1.3
+     */
+    public SAAJResult() throws SOAPException {
+        this(MessageFactory.newInstance().createMessage());
+    }
+
+    /**
+     * Creates a <code>SAAJResult</code> that will present results in the form
+     * of a SAAJ tree that supports the specified protocol. The
+     * <code>DYNAMIC_SOAP_PROTOCOL</code> is ambiguous in this context and will
+     * cause this constructor to throw an <code>UnsupportedOperationException</code>.
+     * <p>
+     * This kind of <code>SAAJResult</code> is meant for use in situations where the
+     * results will be used as a parameter to a method that takes a parameter
+     * whose type, such as <code>SOAPElement</code>, is drawn from the SAAJ
+     * API. When used in a transformation the results are populated into the
+     * <code>SOAPPart</code> of a <code>SOAPMessage</code> that is created
+     * internally. The <code>SOAPPart</code> returned by {@link DOMResult#getNode()}
+     * is not guaranteed to be well-formed.
+     *
+     * @param protocol - the name of the SOAP protocol that the resulting SAAJ
+     *                      tree should support
+     *
+     * @throws SOAPException if a <code>SOAPMessage</code> supporting the
+     *             specified protocol cannot be created
+     *
+     * @since SAAJ 1.3
+     */
+    public SAAJResult(String protocol) throws SOAPException {
+        this(MessageFactory.newInstance(protocol).createMessage());
+    }
+
+    /**
+     * Creates a <code>SAAJResult</code> that will write the results into the
+     * <code>SOAPPart</code> of the supplied <code>SOAPMessage</code>.
+     * In the normal case these results will be written using DOM APIs and,
+     * as a result, the finished <code>SOAPPart</code> will not be guaranteed
+     * to be well-formed unless the data used to create it is also well formed.
+     * When used in a transformation the validity of the <code>SOAPMessage</code>
+     * after the transformation can be guaranteed only by means outside SAAJ
+     * specification.
+     *
+     * @param message - the message whose <code>SOAPPart</code> will be
+     *                  populated as a result of some transformation or
+     *                  marshalling operation
+     *
+     * @since SAAJ 1.3
+     */
+    public SAAJResult(SOAPMessage message) {
+        super(message.getSOAPPart());
+    }
+
+    /**
+     * Creates a <code>SAAJResult</code> that will write the results as a
+     * child node of the <code>SOAPElement</code> specified. In the normal
+     * case these results will be written using DOM APIs and as a result may
+     * invalidate the structure of the SAAJ tree. This kind of
+     * <code>SAAJResult</code> should only be used when the validity of the
+     * incoming data can be guaranteed by means outside of the SAAJ
+     * specification.
+     *
+     * @param rootNode - the root to which the results will be appended
+     *
+     * @since SAAJ 1.3
+     */
+    public SAAJResult(SOAPElement rootNode) {
+        super(rootNode);
+    }
+
+
+    /**
+     * @return the resulting Tree that was created under the specified root Node.
+     * @since SAAJ 1.3
+     */
+    public javax.xml.soap.Node getResult() {
+        return (javax.xml.soap.Node)super.getNode().getFirstChild();
+     }
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPBody.java b/jaxws/src/share/classes/javax/xml/soap/SOAPBody.java
new file mode 100644
index 0000000..86cab0f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPBody.java
@@ -0,0 +1,302 @@
+/*
+ * $Id: SOAPBody.java,v 1.16 2005/04/05 22:28:13 mk125090 Exp $
+ * $Revision: 1.16 $
+ * $Date: 2005/04/05 22:28:13 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import java.util.Locale;
+
+import org.w3c.dom.Document;
+
+import javax.xml.namespace.QName;
+
+/**
+ * An object that represents the contents of the SOAP body
+ * element in a SOAP message. A SOAP body element consists of XML data
+ * that affects the way the application-specific content is processed.
+ * <P>
+ * A <code>SOAPBody</code> object contains <code>SOAPBodyElement</code>
+ * objects, which have the content for the SOAP body.
+ * A <code>SOAPFault</code> object, which carries status and/or
+ * error information, is an example of a <code>SOAPBodyElement</code> object.
+ *
+ * @see SOAPFault
+ */
+public interface SOAPBody extends SOAPElement {
+
+    /**
+     * Creates a new <code>SOAPFault</code> object and adds it to
+     * this <code>SOAPBody</code> object. The new <code>SOAPFault</code> will
+     * have default values set for the mandatory child elements. The type of
+     * the <code>SOAPFault</code> will be a SOAP 1.1 or a SOAP 1.2 <code>SOAPFault</code>
+     * depending on the <code>protocol</code> specified while creating the
+     * <code>MessageFactory</code> instance.
+     * <p>
+     * A <code>SOAPBody</code> may contain at most one <code>SOAPFault</code>
+     * child element.
+     *
+     * @return the new <code>SOAPFault</code> object
+     * @exception SOAPException if there is a SOAP error
+     */
+    public SOAPFault addFault() throws SOAPException;
+
+
+    /**
+     * Creates a new <code>SOAPFault</code> object and adds it to
+     * this <code>SOAPBody</code> object. The type of the
+     * <code>SOAPFault</code> will be a SOAP 1.1  or a SOAP 1.2
+     * <code>SOAPFault</code> depending on the <code>protocol</code>
+     * specified while creating the <code>MessageFactory</code> instance.
+     * <p>
+     * For SOAP 1.2 the <code>faultCode</code> parameter is the value of the
+     * <i>Fault/Code/Value</i> element  and the <code>faultString</code> parameter
+     * is the value of the <i>Fault/Reason/Text</i> element. For SOAP 1.1
+     * the <code>faultCode</code> parameter is the value of the <code>faultcode</code>
+     * element and the <code>faultString</code> parameter is the value of the <code>faultstring</code>
+     * element.
+     * <p>
+     * A <code>SOAPBody</code> may contain at most one <code>SOAPFault</code>
+     * child element.
+     *
+     * @param faultCode a <code>Name</code> object giving the fault
+     *         code to be set; must be one of the fault codes defined in the Version
+     *         of SOAP specification in use
+     * @param faultString a <code>String</code> giving an explanation of
+     *         the fault
+     * @param locale a {@link java.util.Locale} object indicating
+     *         the native language of the <code>faultString</code>
+     * @return the new <code>SOAPFault</code> object
+     * @exception SOAPException if there is a SOAP error
+     * @see SOAPFault#setFaultCode
+     * @see SOAPFault#setFaultString
+     * @since SAAJ 1.2
+     */
+    public SOAPFault addFault(Name faultCode, String faultString, Locale locale) throws SOAPException;
+
+    /**
+     * Creates a new <code>SOAPFault</code> object and adds it to this
+     * <code>SOAPBody</code> object. The type of the <code>SOAPFault</code>
+     * will be a SOAP 1.1 or a SOAP 1.2 <code>SOAPFault</code> depending on
+     * the <code>protocol</code> specified while creating the <code>MessageFactory</code>
+     * instance.
+     * <p>
+     * For SOAP 1.2 the <code>faultCode</code> parameter is the value of the
+     * <i>Fault/Code/Value</i> element  and the <code>faultString</code> parameter
+     * is the value of the <i>Fault/Reason/Text</i> element. For SOAP 1.1
+     * the <code>faultCode</code> parameter is the value of the <code>faultcode</code>
+     * element and the <code>faultString</code> parameter is the value of the <code>faultstring</code>
+     * element.
+     * <p>
+     * A <code>SOAPBody</code> may contain at most one <code>SOAPFault</code>
+     * child element.
+     *
+     * @param faultCode
+     *            a <code>QName</code> object giving the fault code to be
+     *            set; must be one of the fault codes defined in the version
+     *            of SOAP specification in use.
+     * @param faultString
+     *            a <code>String</code> giving an explanation of the fault
+     * @param locale
+     *            a {@link java.util.Locale Locale} object indicating the
+     *            native language of the <code>faultString</code>
+     * @return the new <code>SOAPFault</code> object
+     * @exception SOAPException
+     *                if there is a SOAP error
+     * @see SOAPFault#setFaultCode
+     * @see SOAPFault#setFaultString
+     * @see SOAPBody#addFault(Name faultCode, String faultString, Locale locale)
+     *
+     * @since SAAJ 1.3
+     */
+    public SOAPFault addFault(QName faultCode, String faultString, Locale locale)
+        throws SOAPException;
+
+    /**
+     * Creates a new  <code>SOAPFault</code> object and adds it to this
+     * <code>SOAPBody</code> object. The type of the <code>SOAPFault</code>
+     * will be a SOAP 1.1 or a SOAP 1.2 <code>SOAPFault</code> depending on
+     * the <code>protocol</code> specified while creating the <code>MessageFactory</code>
+     * instance.
+     * <p>
+     * For SOAP 1.2 the <code>faultCode</code> parameter is the value of the
+     * <i>Fault/Code/Value</i> element  and the <code>faultString</code> parameter
+     * is the value of the <i>Fault/Reason/Text</i> element. For SOAP 1.1
+     * the <code>faultCode</code> parameter is the value of the <i>faultcode</i>
+     * element and the <code>faultString</code> parameter is the value of the <i>faultstring</i>
+     * element.
+     * <p>
+     * In case of a SOAP 1.2 fault, the default value for the mandatory <code>xml:lang</code>
+     * attribute on the <i>Fault/Reason/Text</i> element will be set to
+     * <code>java.util.Locale.getDefault()</code>
+     * <p>
+     * A <code>SOAPBody</code> may contain at most one <code>SOAPFault</code>
+     * child element.
+     *
+     * @param faultCode
+     *            a <code>Name</code> object giving the fault code to be set;
+     *            must be one of the fault codes defined in the version of SOAP
+     *            specification in use
+     * @param faultString
+     *            a <code>String</code> giving an explanation of the fault
+     * @return the new <code>SOAPFault</code> object
+     * @exception SOAPException
+     *                if there is a SOAP error
+     * @see SOAPFault#setFaultCode
+     * @see SOAPFault#setFaultString
+     * @since SAAJ 1.2
+     */
+    public SOAPFault addFault(Name faultCode, String faultString)
+        throws SOAPException;
+
+    /**
+     * Creates a new <code>SOAPFault</code> object and adds it to this <code>SOAPBody</code>
+     * object. The type of the <code>SOAPFault</code>
+     * will be a SOAP 1.1 or a SOAP 1.2 <code>SOAPFault</code> depending on
+     * the <code>protocol</code> specified while creating the <code>MessageFactory</code>
+     * instance.
+     * <p>
+     * For SOAP 1.2 the <code>faultCode</code> parameter is the value of the
+     * <i>Fault/Code/Value</i> element  and the <code>faultString</code> parameter
+     * is the value of the <i>Fault/Reason/Text</i> element. For SOAP 1.1
+     * the <code>faultCode</code> parameter is the value of the <i>faultcode</i>
+     * element and the <code>faultString</code> parameter is the value of the <i>faultstring</i>
+     * element.
+     * <p>
+     * In case of a SOAP 1.2 fault, the default value for the mandatory <code>xml:lang</code>
+     * attribute on the <i>Fault/Reason/Text</i> element will be set to
+     * <code>java.util.Locale.getDefault()</code>
+     * <p>
+     * A <code>SOAPBody</code> may contain at most one <code>SOAPFault</code>
+     * child element
+     *
+     * @param faultCode
+     *            a <code>QName</code> object giving the fault code to be
+     *            set; must be one of the fault codes defined in the version
+     *            of  SOAP specification in use
+     * @param faultString
+     *            a <code>String</code> giving an explanation of the fault
+     * @return the new <code>SOAPFault</code> object
+     * @exception SOAPException
+     *                if there is a SOAP error
+     * @see SOAPFault#setFaultCode
+     * @see SOAPFault#setFaultString
+     * @see SOAPBody#addFault(Name faultCode, String faultString)
+     * @since SAAJ 1.3
+     */
+    public SOAPFault addFault(QName faultCode, String faultString)
+        throws SOAPException;
+
+    /**
+     * Indicates whether a <code>SOAPFault</code> object exists in this
+     * <code>SOAPBody</code> object.
+     *
+     * @return <code>true</code> if a <code>SOAPFault</code> object exists
+     *         in this <code>SOAPBody</code> object; <code>false</code>
+     *         otherwise
+     */
+    public boolean hasFault();
+
+    /**
+     * Returns the <code>SOAPFault</code> object in this <code>SOAPBody</code>
+     * object.
+     *
+     * @return the <code>SOAPFault</code> object in this <code>SOAPBody</code>
+     *         object if present, null otherwise.
+     */
+    public SOAPFault getFault();
+
+    /**
+     * Creates a new <code>SOAPBodyElement</code> object with the specified
+     * name and adds it to this <code>SOAPBody</code> object.
+     *
+     * @param name
+     *            a <code>Name</code> object with the name for the new <code>SOAPBodyElement</code>
+     *            object
+     * @return the new <code>SOAPBodyElement</code> object
+     * @exception SOAPException
+     *                if a SOAP error occurs
+     * @see SOAPBody#addBodyElement(javax.xml.namespace.QName)
+     */
+    public SOAPBodyElement addBodyElement(Name name) throws SOAPException;
+
+
+    /**
+     * Creates a new <code>SOAPBodyElement</code> object with the specified
+     * QName and adds it to this <code>SOAPBody</code> object.
+     *
+     * @param qname
+     *            a <code>QName</code> object with the qname for the new
+     *            <code>SOAPBodyElement</code> object
+     * @return the new <code>SOAPBodyElement</code> object
+     * @exception SOAPException
+     *                if a SOAP error occurs
+     * @see SOAPBody#addBodyElement(Name)
+     * @since SAAJ 1.3
+     */
+    public SOAPBodyElement addBodyElement(QName qname) throws SOAPException;
+
+    /**
+     * Adds the root node of the DOM <code>{@link org.w3c.dom.Document}</code>
+     * to this <code>SOAPBody</code> object.
+     * <p>
+     * Calling this method invalidates the <code>document</code> parameter.
+     * The client application should discard all references to this <code>Document</code>
+     * and its contents upon calling <code>addDocument</code>. The behavior
+     * of an application that continues to use such references is undefined.
+     *
+     * @param document
+     *            the <code>Document</code> object whose root node will be
+     *            added to this <code>SOAPBody</code>.
+     * @return the <code>SOAPBodyElement</code> that represents the root node
+     *         that was added.
+     * @exception SOAPException
+     *                if the <code>Document</code> cannot be added
+     * @since SAAJ 1.2
+     */
+    public SOAPBodyElement addDocument(org.w3c.dom.Document document)
+        throws SOAPException;
+
+    /**
+     * Creates a new DOM <code>{@link org.w3c.dom.Document}</code> and sets
+     * the first child of this <code>SOAPBody</code> as it's document
+     * element. The child <code>SOAPElement</code> is removed as part of the
+     * process.
+     *
+     * @return the <code>{@link org.w3c.dom.Document}</code> representation
+     *         of the <code>SOAPBody</code> content.
+     *
+     * @exception SOAPException
+     *                if there is not exactly one child <code>SOAPElement</code> of the
+     *              <code>SOAPBody</code>.
+     *
+     * @since SAAJ 1.3
+     */
+    public org.w3c.dom.Document extractContentAsDocument()
+        throws SOAPException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPBodyElement.java b/jaxws/src/share/classes/javax/xml/soap/SOAPBodyElement.java
new file mode 100644
index 0000000..f1b4926
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPBodyElement.java
@@ -0,0 +1,48 @@
+/*
+ * $Id: SOAPBodyElement.java,v 1.2 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.2 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * A <code>SOAPBodyElement</code> object represents the contents in
+ * a <code>SOAPBody</code> object.  The <code>SOAPFault</code> interface
+ * is a <code>SOAPBodyElement</code> object that has been defined.
+ * <P>
+ * A new <code>SOAPBodyElement</code> object can be created and added
+ * to a <code>SOAPBody</code> object with the <code>SOAPBody</code>
+ * method <code>addBodyElement</code>. In the following line of code,
+ * <code>sb</code> is a <code>SOAPBody</code> object, and
+ * <code>myName</code> is a <code>Name</code> object.
+ * <PRE>
+ *    SOAPBodyElement sbe = sb.addBodyElement(myName);
+ * </PRE>
+ */
+public interface SOAPBodyElement extends SOAPElement {
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPConnection.java b/jaxws/src/share/classes/javax/xml/soap/SOAPConnection.java
new file mode 100644
index 0000000..670af21
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPConnection.java
@@ -0,0 +1,100 @@
+/*
+ * $Id: SOAPConnection.java,v 1.11 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.11 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+
+/**
+ * A point-to-point connection that a client can use for sending messages
+ * directly to a remote party (represented by a URL, for instance).
+ * <p>
+ * The SOAPConnection class is optional. Some implementations may
+ * not implement this interface in which case the call to
+ * <code>SOAPConnectionFactory.newInstance()</code> (see below) will
+ * throw an <code>UnsupportedOperationException</code>.
+ * <p>
+ * A client can obtain a <code>SOAPConnection</code> object using a
+ * {@link SOAPConnectionFactory} object as in the following example:
+ * <PRE>
+ *      SOAPConnectionFactory factory = SOAPConnectionFactory.newInstance();
+ *      SOAPConnection con = factory.createConnection();
+ * </PRE>
+ * A <code>SOAPConnection</code> object can be used to send messages
+ * directly to a URL following the request/response paradigm.  That is,
+ * messages are sent using the method <code>call</code>, which sends the
+ * message and then waits until it gets a reply.
+ */
+public abstract class SOAPConnection {
+
+    /**
+     * Sends the given message to the specified endpoint and blocks until
+     * it has returned the response.
+     *
+     * @param request the <code>SOAPMessage</code> object to be sent
+     * @param to an <code>Object</code> that identifies
+     *         where the message should be sent. It is required to
+     *         support Objects of type
+     *         <code>java.lang.String</code>,
+     *         <code>java.net.URL</code>, and when JAXM is present
+     *         <code>javax.xml.messaging.URLEndpoint</code>
+     *
+     * @return the <code>SOAPMessage</code> object that is the response to the
+     *         message that was sent
+     * @throws SOAPException if there is a SOAP error
+     */
+    public abstract SOAPMessage call(SOAPMessage request,
+                                     Object to) throws SOAPException;
+
+    /**
+     * Gets a message from a specific endpoint and blocks until it receives,
+     *
+     * @param to an <code>Object</code> that identifies where
+     *                  the request should be sent. Objects of type
+     *                 <code>java.lang.String</code> and
+     *                 <code>java.net.URL</code> must be supported.
+     *
+     * @return the <code>SOAPMessage</code> object that is the response to the
+     *                  get message request
+     * @throws SOAPException if there is a SOAP error
+     * @since SAAJ 1.3
+     */
+    public SOAPMessage get(Object to)
+                                throws SOAPException {
+        throw new UnsupportedOperationException("All subclasses of SOAPConnection must override get()");
+    }
+
+    /**
+     * Closes this <code>SOAPConnection</code> object.
+     *
+     * @throws SOAPException if there is a SOAP error
+     */
+    public abstract void close()
+        throws SOAPException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPConnectionFactory.java b/jaxws/src/share/classes/javax/xml/soap/SOAPConnectionFactory.java
new file mode 100644
index 0000000..29bce97
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPConnectionFactory.java
@@ -0,0 +1,91 @@
+/*
+ * $Id: SOAPConnectionFactory.java,v 1.4 2004/04/02 01:24:17 ofung Exp $
+ * $Revision: 1.4 $
+ * $Date: 2004/04/02 01:24:17 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * A factory for creating <code>SOAPConnection</code> objects. Implementation of this class
+ * is optional. If <code>SOAPConnectionFactory.newInstance()</code> throws an
+ * UnsupportedOperationException then the implementation does not support the
+ * SAAJ communication infrastructure. Otherwise {@link SOAPConnection} objects
+ * can be created by calling <code>createConnection()</code> on the newly
+ * created <code>SOAPConnectionFactory</code> object.
+ */
+public abstract class SOAPConnectionFactory {
+    /**
+     * A constant representing the default value for a <code>SOAPConnection</code>
+     * object. The default is the point-to-point SOAP connection.
+     */
+    static private final String DEFAULT_SOAP_CONNECTION_FACTORY
+        = "com.sun.xml.internal.messaging.saaj.client.p2p.HttpSOAPConnectionFactory";
+
+    /**
+     * A constant representing the <code>SOAPConnection</code> class.
+     */
+    static private final String SF_PROPERTY
+        = "javax.xml.soap.SOAPConnectionFactory";
+
+    /**
+     * Creates an instance of the default
+     * <code>SOAPConnectionFactory</code> object.
+     *
+     * @return a new instance of a default
+     *         <code>SOAPConnectionFactory</code> object
+     *
+     * @exception SOAPException if there was an error creating the
+     *            <code>SOAPConnectionFactory</code>
+     *
+     * @exception UnsupportedOperationException if newInstance is not
+     * supported.
+     */
+    public static SOAPConnectionFactory newInstance()
+        throws SOAPException, UnsupportedOperationException
+    {
+        try {
+        return (SOAPConnectionFactory)
+                FactoryFinder.find(SF_PROPERTY,
+                                   DEFAULT_SOAP_CONNECTION_FACTORY);
+        } catch (Exception ex) {
+            throw new SOAPException("Unable to create SOAP connection factory: "
+                                    +ex.getMessage());
+        }
+    }
+
+    /**
+     * Create a new <code>SOAPConnection</code>.
+     *
+     * @return the new <code>SOAPConnection</code> object.
+     *
+     * @exception SOAPException if there was an exception creating the
+     * <code>SOAPConnection</code> object.
+     */
+    public abstract SOAPConnection createConnection()
+        throws SOAPException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPConstants.java b/jaxws/src/share/classes/javax/xml/soap/SOAPConstants.java
new file mode 100644
index 0000000..cfbb9aa
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPConstants.java
@@ -0,0 +1,206 @@
+/*
+ * $Id: $
+ * $Revision: 1.11 $
+ * $Date: 2004/04/02 01:24:18 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import javax.xml.namespace.QName;
+
+/**
+ * The definition of constants pertaining to the SOAP protocol.
+ */
+public interface SOAPConstants {
+    /**
+     * Used to create <code>MessageFactory</code> instances that create
+     * <code>SOAPMessages</code> whose concrete type is based on the
+     * <code>Content-Type</code> MIME header passed to the
+     * <code>createMessage</code> method. If no <code>Content-Type</code>
+     * header is passed then the <code>createMessage</code> may throw an
+     * <code>IllegalArgumentException</code> or, in the case of the no
+     * argument version of <code>createMessage</code>, an
+     * <code>UnsupportedOperationException</code>.
+     *
+     * @since  SAAJ 1.3
+     */
+    public static final String DYNAMIC_SOAP_PROTOCOL = "Dynamic Protocol";
+
+    /**
+     * Used to create <code>MessageFactory</code> instances that create
+     * <code>SOAPMessages</code> whose behavior supports the SOAP 1.1  specification.
+     *
+     * @since  SAAJ 1.3
+     */
+    public static final String SOAP_1_1_PROTOCOL = "SOAP 1.1 Protocol";
+
+    /**
+     * Used to create <code>MessageFactory</code> instances that create
+     * <code>SOAPMessages</code> whose behavior supports the SOAP 1.2
+     * specification
+     *
+     * @since  SAAJ 1.3
+     */
+    public static final String SOAP_1_2_PROTOCOL = "SOAP 1.2 Protocol";
+
+    /**
+     * The default protocol: SOAP 1.1 for backwards compatibility.
+     *
+     * @since SAAJ 1.3
+     */
+    public static final String DEFAULT_SOAP_PROTOCOL = SOAP_1_1_PROTOCOL;
+
+    /**
+     * The namespace identifier for the SOAP 1.1 envelope.
+     * @since SAAJ 1.3
+     */
+    public static final String
+                URI_NS_SOAP_1_1_ENVELOPE = "http://schemas.xmlsoap.org/soap/envelope/";
+    /**
+     * The namespace identifier for the SOAP 1.2 envelope.
+     * @since SAAJ 1.3
+     */
+    public static final String
+                URI_NS_SOAP_1_2_ENVELOPE = "http://www.w3.org/2003/05/soap-envelope";
+
+    /**
+     * The namespace identifier for the SOAP 1.1 envelope, All SOAPElements in this
+     * namespace are defined by the SOAP 1.1 specification.
+     */
+    public static final String
+        URI_NS_SOAP_ENVELOPE = URI_NS_SOAP_1_1_ENVELOPE;
+
+    /**
+     * The namespace identifier for the SOAP 1.1 encoding.
+     * An attribute named <code>encodingStyle</code> in the
+     * <code>URI_NS_SOAP_ENVELOPE</code> namespace and set to the value
+     * <code>URI_NS_SOAP_ENCODING</code> can be added to an element to indicate
+     * that it is encoded using the rules in section 5 of the SOAP 1.1
+     * specification.
+     */
+    public static final String
+        URI_NS_SOAP_ENCODING = "http://schemas.xmlsoap.org/soap/encoding/";
+
+    /**
+     * The namespace identifier for the SOAP 1.2 encoding.
+     * @since SAAJ 1.3
+     */
+    public static final String
+        URI_NS_SOAP_1_2_ENCODING = "http://www.w3.org/2003/05/soap-encoding";
+
+    /**
+     * The media type  of the <code>Content-Type</code> MIME header in SOAP 1.1.
+     * @since SAAJ 1.3
+     */
+    public static final String
+        SOAP_1_1_CONTENT_TYPE = "text/xml";
+
+    /**
+     * The media type  of the <code>Content-Type</code> MIME header in SOAP 1.2.
+     * @since SAAJ 1.3
+     */
+    public static final String
+        SOAP_1_2_CONTENT_TYPE = "application/soap+xml";
+
+    /**
+     * The URI identifying the next application processing a SOAP request as the intended
+     * actor for a SOAP 1.1 header entry (see section 4.2.2 of the SOAP 1.1 specification).
+     * <p>
+     * This value can be passed to
+     * {@link SOAPHeader#examineMustUnderstandHeaderElements(String)},
+     * {@link SOAPHeader#examineHeaderElements(String)} and
+     * {@link SOAPHeader#extractHeaderElements(String)}
+     */
+    public static final String
+        URI_SOAP_ACTOR_NEXT = "http://schemas.xmlsoap.org/soap/actor/next";
+
+    /**
+     * The URI identifying the next application processing a SOAP request as the intended
+     * role for a SOAP 1.2 header entry (see section 2.2 of part 1 of the SOAP 1.2
+     * specification).
+     * @since SAAJ 1.3
+     */
+    public static final String
+        URI_SOAP_1_2_ROLE_NEXT = URI_NS_SOAP_1_2_ENVELOPE + "/role/next";
+
+    /**
+     * The URI specifying the role None in SOAP 1.2.
+     * @since SAAJ 1.3
+     */
+    public static final String
+        URI_SOAP_1_2_ROLE_NONE = URI_NS_SOAP_1_2_ENVELOPE + "/role/none";
+
+    /**
+     * The URI identifying the ultimate receiver of the SOAP 1.2 message.
+     * @since SAAJ 1.3
+     */
+    public static final String
+        URI_SOAP_1_2_ROLE_ULTIMATE_RECEIVER =
+            URI_NS_SOAP_1_2_ENVELOPE + "/role/ultimateReceiver";
+
+    /**
+     * The default namespace prefix for http://www.w3.org/2003/05/soap-envelope
+     * @since SAAJ 1.3
+     */
+    public static final String SOAP_ENV_PREFIX = "env";
+
+    /**
+     * SOAP 1.2 VersionMismatch Fault
+     * @since SAAJ 1.3
+     */
+    public static final QName SOAP_VERSIONMISMATCH_FAULT =
+         new QName(URI_NS_SOAP_1_2_ENVELOPE, "VersionMismatch", SOAP_ENV_PREFIX);
+
+    /**
+     * SOAP 1.2 MustUnderstand Fault
+     * @since SAAJ 1.3
+     */
+    public static final QName SOAP_MUSTUNDERSTAND_FAULT =
+         new QName(URI_NS_SOAP_1_2_ENVELOPE, "MustUnderstand", SOAP_ENV_PREFIX);
+
+    /**
+     * SOAP 1.2 DataEncodingUnknown Fault
+     * @since SAAJ 1.3
+     */
+    public static final QName SOAP_DATAENCODINGUNKNOWN_FAULT =
+         new QName(URI_NS_SOAP_1_2_ENVELOPE, "DataEncodingUnknown", SOAP_ENV_PREFIX);
+
+    /**
+     * SOAP 1.2 Sender Fault
+     * @since SAAJ 1.3
+     */
+    public static final QName SOAP_SENDER_FAULT =
+         new QName(URI_NS_SOAP_1_2_ENVELOPE, "Sender", SOAP_ENV_PREFIX);
+
+    /**
+     * SOAP 1.2 Receiver Fault
+     * @since SAAJ 1.3
+     */
+    public static final QName SOAP_RECEIVER_FAULT =
+         new QName(URI_NS_SOAP_1_2_ENVELOPE, "Receiver", SOAP_ENV_PREFIX);
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPElement.java b/jaxws/src/share/classes/javax/xml/soap/SOAPElement.java
new file mode 100644
index 0000000..c07cacd
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPElement.java
@@ -0,0 +1,529 @@
+/*
+ * $Id: SOAPElement.java,v 1.18 2005/12/07 07:25:37 vj135062 Exp $
+ * $Revision: 1.18 $
+ * $Date: 2005/12/07 07:25:37 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+/**
+ * An object representing an element of a SOAP message that is allowed but not
+ * specifically prescribed by a SOAP specification. This interface serves as the
+ * base interface for those objects that are specifically prescribed by a SOAP
+ * specification.
+ * <p>
+ * Methods in this interface that are required to return SAAJ specific objects
+ * may "silently" replace nodes in the tree as required to successfully return
+ * objects of the correct type. See {@link #getChildElements()} and
+ * {@link <a HREF="package-summary.html#package_description">javax.xml.soap<a>}
+ * for details.
+ */
+public interface SOAPElement extends Node, org.w3c.dom.Element {
+
+    /**
+     * Creates a new <code>SOAPElement</code> object initialized with the
+     * given <code>Name</code> object and adds the new element to this
+     * <code>SOAPElement</code> object.
+     * <P>
+     * This method may be deprecated in a future release of SAAJ in favor of
+     * addChildElement(javax.xml.namespace.QName)
+     *
+     * @param name a <code>Name</code> object with the XML name for the
+     *        new element
+     *
+     * @return the new <code>SOAPElement</code> object that was created
+     * @exception SOAPException if there is an error in creating the
+     *                          <code>SOAPElement</code> object
+     * @see SOAPElement#addChildElement(javax.xml.namespace.QName)
+     */
+    public SOAPElement addChildElement(Name name) throws SOAPException;
+
+    /**
+     * Creates a new <code>SOAPElement</code> object initialized with the given
+     * <code>QName</code> object and adds the new element to this <code>SOAPElement</code>
+     *  object. The  <i>namespace</i>, <i>localname</i> and <i>prefix</i> of the new
+     * <code>SOAPElement</code> are all taken  from the <code>qname</code> argument.
+     *
+     * @param qname a <code>QName</code> object with the XML name for the
+     *        new element
+     *
+     * @return the new <code>SOAPElement</code> object that was created
+     * @exception SOAPException if there is an error in creating the
+     *                          <code>SOAPElement</code> object
+     * @see SOAPElement#addChildElement(Name)
+     * @since SAAJ 1.3
+     */
+    public SOAPElement addChildElement(QName qname) throws SOAPException;
+
+    /**
+     * Creates a new <code>SOAPElement</code> object initialized with the
+     * specified local name and adds the new element to this
+     * <code>SOAPElement</code> object.
+     * The new  <code>SOAPElement</code> inherits any in-scope default namespace.
+     *
+     * @param localName a <code>String</code> giving the local name for
+     *          the element
+     * @return the new <code>SOAPElement</code> object that was created
+     * @exception SOAPException if there is an error in creating the
+     *                          <code>SOAPElement</code> object
+     */
+    public SOAPElement addChildElement(String localName) throws SOAPException;
+
+    /**
+     * Creates a new <code>SOAPElement</code> object initialized with the
+     * specified local name and prefix and adds the new element to this
+     * <code>SOAPElement</code> object.
+     *
+     * @param localName a <code>String</code> giving the local name for
+     *        the new element
+     * @param prefix a <code>String</code> giving the namespace prefix for
+     *        the new element
+     *
+     * @return the new <code>SOAPElement</code> object that was created
+     * @exception SOAPException if the <code>prefix</code> is not valid in the
+     *         context of this <code>SOAPElement</code> or  if there is an error in creating the
+     *                          <code>SOAPElement</code> object
+     */
+    public SOAPElement addChildElement(String localName, String prefix)
+        throws SOAPException;
+
+    /**
+     * Creates a new <code>SOAPElement</code> object initialized with the
+     * specified local name, prefix, and URI and adds the new element to this
+     * <code>SOAPElement</code> object.
+     *
+     * @param localName a <code>String</code> giving the local name for
+     *        the new element
+     * @param prefix a <code>String</code> giving the namespace prefix for
+     *        the new element
+     * @param uri a <code>String</code> giving the URI of the namespace
+     *        to which the new element belongs
+     *
+     * @return the new <code>SOAPElement</code> object that was created
+     * @exception SOAPException if there is an error in creating the
+     *                          <code>SOAPElement</code> object
+     */
+    public SOAPElement addChildElement(String localName, String prefix,
+                                       String uri)
+        throws SOAPException;
+
+    /**
+     * Add a <code>SOAPElement</code> as a child of this
+     * <code>SOAPElement</code> instance. The <code>SOAPElement</code>
+     * is expected to be created by a
+     * <code>SOAPFactory</code>. Callers should not rely on the
+     * element instance being added as is into the XML
+     * tree. Implementations could end up copying the content
+     * of the <code>SOAPElement</code> passed into an instance of
+     * a different <code>SOAPElement</code> implementation. For
+     * instance if <code>addChildElement()</code> is called on a
+     * <code>SOAPHeader</code>, <code>element</code> will be copied
+     * into an instance of a <code>SOAPHeaderElement</code>.
+     *
+     * <P>The fragment rooted in <code>element</code> is either added
+     * as a whole or not at all, if there was an error.
+     *
+     * <P>The fragment rooted in <code>element</code> cannot contain
+     * elements named "Envelope", "Header" or "Body" and in the SOAP
+     * namespace. Any namespace prefixes present in the fragment
+     * should be fully resolved using appropriate namespace
+     * declarations within the fragment itself.
+     *
+     * @param element the <code>SOAPElement</code> to be added as a
+     *                new child
+     *
+     * @exception SOAPException if there was an error in adding this
+     *                          element as a child
+     *
+     * @return an instance representing the new SOAP element that was
+     *         actually added to the tree.
+     */
+    public SOAPElement addChildElement(SOAPElement element)
+        throws SOAPException;
+
+    /**
+     * Detaches all children of this <code>SOAPElement</code>.
+     * <p>
+     * This method is useful for rolling back the construction of partially
+     * completed <code>SOAPHeaders</code> and <code>SOAPBodys</code> in
+     * preparation for sending a fault when an error condition is detected. It
+     * is also useful for recycling portions of a document within a SOAP
+     * message.
+     *
+     * @since SAAJ 1.2
+     */
+    public abstract void removeContents();
+
+    /**
+     * Creates a new <code>Text</code> object initialized with the given
+     * <code>String</code> and adds it to this <code>SOAPElement</code> object.
+     *
+     * @param text a <code>String</code> object with the textual content to be added
+     *
+     * @return the <code>SOAPElement</code> object into which
+     *         the new <code>Text</code> object was inserted
+     * @exception SOAPException if there is an error in creating the
+     *                    new <code>Text</code> object or if it is not legal to
+     *                      attach it as a child to this
+     *                      <code>SOAPElement</code>
+     */
+    public SOAPElement addTextNode(String text) throws SOAPException;
+
+    /**
+     * Adds an attribute with the specified name and value to this
+     * <code>SOAPElement</code> object.
+     *
+     * @param name a <code>Name</code> object with the name of the attribute
+     * @param value a <code>String</code> giving the value of the attribute
+     * @return the <code>SOAPElement</code> object into which the attribute was
+     *         inserted
+     *
+     * @exception SOAPException if there is an error in creating the
+     *                          Attribute, or it is invalid to set
+                                an attribute with <code>Name</code>
+                                 <code>name</code> on this SOAPElement.
+     * @see SOAPElement#addAttribute(javax.xml.namespace.QName, String)
+     */
+    public SOAPElement addAttribute(Name name, String value)
+        throws SOAPException;
+
+    /**
+     * Adds an attribute with the specified name and value to this
+     * <code>SOAPElement</code> object.
+     *
+     * @param qname a <code>QName</code> object with the name of the attribute
+     * @param value a <code>String</code> giving the value of the attribute
+     * @return the <code>SOAPElement</code> object into which the attribute was
+     *         inserted
+     *
+     * @exception SOAPException if there is an error in creating the
+     *                          Attribute, or it is invalid to set
+                                an attribute with <code>QName</code>
+                                <code>qname</code> on this SOAPElement.
+     * @see SOAPElement#addAttribute(Name, String)
+     * @since SAAJ 1.3
+     */
+    public SOAPElement addAttribute(QName qname, String value)
+        throws SOAPException;
+
+    /**
+     * Adds a namespace declaration with the specified prefix and URI to this
+     * <code>SOAPElement</code> object.
+     *
+     * @param prefix a <code>String</code> giving the prefix of the namespace
+     * @param uri a <code>String</code> giving the uri of the namespace
+     * @return the <code>SOAPElement</code> object into which this
+     *          namespace declaration was inserted.
+     *
+     * @exception SOAPException if there is an error in creating the
+     *                          namespace
+     */
+    public SOAPElement addNamespaceDeclaration(String prefix, String uri)
+        throws SOAPException;
+
+    /**
+     * Returns the value of the attribute with the specified name.
+     *
+     * @param name a <code>Name</code> object with the name of the attribute
+     * @return a <code>String</code> giving the value of the specified
+     *         attribute, Null if there is no such attribute
+     * @see SOAPElement#getAttributeValue(javax.xml.namespace.QName)
+     */
+    public String getAttributeValue(Name name);
+
+    /**
+     * Returns the value of the attribute with the specified qname.
+     *
+     * @param qname a <code>QName</code> object with the qname of the attribute
+     * @return a <code>String</code> giving the value of the specified
+     *         attribute, Null if there is no such attribute
+     * @see SOAPElement#getAttributeValue(Name)
+     * @since SAAJ 1.3
+     */
+    public String getAttributeValue(QName qname);
+
+    /**
+     * Returns an <code>Iterator</code> over all of the attribute
+     * <code>Name</code> objects in this
+     * <code>SOAPElement</code> object. The iterator can be used to get
+     * the attribute names, which can then be passed to the method
+     * <code>getAttributeValue</code> to retrieve the value of each
+     * attribute.
+     *
+     * @see SOAPElement#getAllAttributesAsQNames()
+     * @return an iterator over the names of the attributes
+     */
+    public Iterator getAllAttributes();
+
+    /**
+     * Returns an <code>Iterator</code> over all of the attributes
+     * in this <code>SOAPElement</code>  as <code>QName</code> objects.
+     * The iterator can be used to get the attribute QName, which can then
+     * be passed to the method <code>getAttributeValue</code> to retrieve
+     * the value of each attribute.
+     *
+     * @return an iterator over the QNames of the attributes
+     * @see SOAPElement#getAllAttributes()
+     * @since SAAJ 1.3
+     */
+    public Iterator getAllAttributesAsQNames();
+
+
+    /**
+     * Returns the URI of the namespace that has the given prefix.
+     *
+     * @param prefix a <code>String</code> giving the prefix of the namespace
+     *        for which to search
+     * @return a <code>String</code> with the uri of the namespace that has
+     *        the given prefix
+     */
+    public String getNamespaceURI(String prefix);
+
+    /**
+     * Returns an <code>Iterator</code> over the namespace prefix
+     * <code>String</code>s declared by this element. The prefixes returned by
+     * this iterator can be passed to the method
+     * <code>getNamespaceURI</code> to retrieve the URI of each namespace.
+     *
+     * @return an iterator over the namespace prefixes in this
+     *         <code>SOAPElement</code> object
+     */
+    public Iterator getNamespacePrefixes();
+
+    /**
+     * Returns an <code>Iterator</code> over the namespace prefix
+     * <code>String</code>s visible to this element. The prefixes returned by
+     * this iterator can be passed to the method
+     * <code>getNamespaceURI</code> to retrieve the URI of each namespace.
+     *
+     * @return an iterator over the namespace prefixes are within scope of this
+     *         <code>SOAPElement</code> object
+     *
+     * @since SAAJ 1.2
+     */
+    public Iterator getVisibleNamespacePrefixes();
+
+    /**
+     * Creates a <code>QName</code> whose namespace URI is the one associated
+     * with the parameter, <code>prefix</code>, in the context of this
+     * <code>SOAPElement</code>. The remaining elements of the new
+     * <code>QName</code> are taken directly from the parameters,
+     * <code>localName</code> and <code>prefix</code>.
+     *
+     * @param localName
+     *          a <code>String</code> containing the local part of the name.
+     * @param prefix
+     *          a <code>String</code> containing the prefix for the name.
+     *
+     * @return a <code>QName</code> with the specified <code>localName</code>
+     *          and <code>prefix</code>, and with a namespace that is associated
+     *          with the <code>prefix</code> in the context of this
+     *          <code>SOAPElement</code>. This namespace will be the same as
+     *          the one that would be returned by
+     *          <code>{@link #getNamespaceURI(String)}</code> if it were given
+     *          <code>prefix</code> as it's parameter.
+     *
+     * @exception SOAPException if the <code>QName</code> cannot be created.
+     *
+     * @since SAAJ 1.3
+     */
+    public QName createQName(String localName, String prefix)
+        throws SOAPException;
+    /**
+     * Returns the name of this <code>SOAPElement</code> object.
+     *
+     * @return a <code>Name</code> object with the name of this
+     *         <code>SOAPElement</code> object
+     */
+    public Name getElementName();
+
+    /**
+     * Returns the qname of this <code>SOAPElement</code> object.
+     *
+     * @return a <code>QName</code> object with the qname of this
+     *         <code>SOAPElement</code> object
+     * @see SOAPElement#getElementName()
+     * @since SAAJ 1.3
+     */
+    public QName getElementQName();
+
+    /**
+    * Changes the name of this <code>Element</code> to <code>newName</code> if
+    * possible. SOAP Defined elements such as SOAPEnvelope, SOAPHeader, SOAPBody
+    * etc. cannot have their names changed using this method. Any attempt to do
+    * so will result in a  SOAPException being thrown.
+    *<P>
+    * Callers should not rely on the element instance being renamed as is.
+    * Implementations could end up copying the content of the
+    * <code>SOAPElement</code> to a renamed instance.
+    *
+    * @param newName the new name for the <code>Element</code>.
+    *
+    * @exception SOAPException if changing the name of this <code>Element</code>
+    *                          is not allowed.
+    * @return The renamed Node
+    *
+    * @since SAAJ 1.3
+    */
+   public SOAPElement setElementQName(QName newName) throws SOAPException;
+
+   /**
+     * Removes the attribute with the specified name.
+     *
+     * @param name the <code>Name</code> object with the name of the
+     *        attribute to be removed
+     * @return <code>true</code> if the attribute was
+     *         removed successfully; <code>false</code> if it was not
+     * @see SOAPElement#removeAttribute(javax.xml.namespace.QName)
+     */
+    public boolean removeAttribute(Name name);
+
+    /**
+     * Removes the attribute with the specified qname.
+     *
+     * @param qname the <code>QName</code> object with the qname of the
+     *        attribute to be removed
+     * @return <code>true</code> if the attribute was
+     *         removed successfully; <code>false</code> if it was not
+     * @see SOAPElement#removeAttribute(Name)
+     * @since SAAJ 1.3
+     */
+    public boolean removeAttribute(QName qname);
+
+    /**
+     * Removes the namespace declaration corresponding to the given prefix.
+     *
+     * @param prefix a <code>String</code> giving the prefix for which
+     *        to search
+     * @return <code>true</code> if the namespace declaration was
+     *         removed successfully; <code>false</code> if it was not
+     */
+    public boolean removeNamespaceDeclaration(String prefix);
+
+    /**
+     * Returns an <code>Iterator</code> over all the immediate child
+     * {@link Node}s of this element. This includes <code>javax.xml.soap.Text</code>
+     * objects as well as <code>SOAPElement</code> objects.
+     * <p>
+     * Calling this method may cause child <code>Element</code>,
+     * <code>SOAPElement</code> and <code>org.w3c.dom.Text</code> nodes to be
+     * replaced by <code>SOAPElement</code>, <code>SOAPHeaderElement</code>,
+     * <code>SOAPBodyElement</code> or <code>javax.xml.soap.Text</code> nodes as
+     * appropriate for the type of this parent node. As a result the calling
+     * application must treat any existing references to these child nodes that
+     * have been obtained through DOM APIs as invalid and either discard them or
+     * refresh them with the values returned by this <code>Iterator</code>. This
+     * behavior can be avoided by calling the equivalent DOM APIs. See
+     * {@link <a HREF="package-summary.html#package_description">javax.xml.soap<a>}
+     * for more details.
+     *
+     * @return an iterator with the content of this <code>SOAPElement</code>
+     *         object
+     */
+    public Iterator getChildElements();
+
+    /**
+     * Returns an <code>Iterator</code> over all the immediate child
+     * {@link Node}s of this element with the specified name. All of these
+     * children will be <code>SOAPElement</code> nodes.
+     * <p>
+     * Calling this method may cause child <code>Element</code>,
+     * <code>SOAPElement</code> and <code>org.w3c.dom.Text</code> nodes to be
+     * replaced by <code>SOAPElement</code>, <code>SOAPHeaderElement</code>,
+     * <code>SOAPBodyElement</code> or <code>javax.xml.soap.Text</code> nodes as
+     * appropriate for the type of this parent node. As a result the calling
+     * application must treat any existing references to these child nodes that
+     * have been obtained through DOM APIs as invalid and either discard them or
+     * refresh them with the values returned by this <code>Iterator</code>. This
+     * behavior can be avoided by calling the equivalent DOM APIs. See
+     * {@link <a HREF="package-summary.html#package_description">javax.xml.soap<a>}
+     * for more details.
+     *
+     * @param name a <code>Name</code> object with the name of the child
+     *        elements to be returned
+     *
+     * @return an <code>Iterator</code> object over all the elements
+     *         in this <code>SOAPElement</code> object with the
+     *         specified name
+     * @see SOAPElement#getChildElements(javax.xml.namespace.QName)
+     */
+    public Iterator getChildElements(Name name);
+
+    /**
+     * Returns an <code>Iterator</code> over all the immediate child
+     * {@link Node}s of this element with the specified qname. All of these
+     * children will be <code>SOAPElement</code> nodes.
+     * <p>
+     * Calling this method may cause child <code>Element</code>,
+     * <code>SOAPElement</code> and <code>org.w3c.dom.Text</code> nodes to be
+     * replaced by <code>SOAPElement</code>, <code>SOAPHeaderElement</code>,
+     * <code>SOAPBodyElement</code> or <code>javax.xml.soap.Text</code> nodes as
+     * appropriate for the type of this parent node. As a result the calling
+     * application must treat any existing references to these child nodes that
+     * have been obtained through DOM APIs as invalid and either discard them or
+     * refresh them with the values returned by this <code>Iterator</code>. This
+     * behavior can be avoided by calling the equivalent DOM APIs. See
+     * {@link <a HREF="package-summary.html#package_description">javax.xml.soap<a>}
+     * for more details.
+     *
+     * @param qname a <code>QName</code> object with the qname of the child
+     *        elements to be returned
+     *
+     * @return an <code>Iterator</code> object over all the elements
+     *         in this <code>SOAPElement</code> object with the
+     *         specified qname
+     * @see SOAPElement#getChildElements(Name)
+     * @since SAAJ 1.3
+     */
+    public Iterator getChildElements(QName qname);
+
+    /**
+     * Sets the encoding style for this <code>SOAPElement</code> object
+     * to one specified.
+     *
+     * @param encodingStyle a <code>String</code> giving the encoding style
+     *
+     * @exception IllegalArgumentException if there was a problem in the
+     *            encoding style being set.
+     * @exception SOAPException if setting the encodingStyle is invalid for this SOAPElement.
+     * @see #getEncodingStyle
+     */
+    public void setEncodingStyle(String encodingStyle)
+        throws SOAPException;
+    /**
+     * Returns the encoding style for this <code>SOAPElement</code> object.
+     *
+     * @return a <code>String</code> giving the encoding style
+     *
+     * @see #setEncodingStyle
+     */
+    public String getEncodingStyle();
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPElementFactory.java b/jaxws/src/share/classes/javax/xml/soap/SOAPElementFactory.java
new file mode 100644
index 0000000..d1a5837
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPElementFactory.java
@@ -0,0 +1,143 @@
+/*
+ * $Id: SOAPElementFactory.java,v 1.4.2.7 2004/08/27 19:00:36 goodwin Exp $
+ * $Revision: 1.4.2.7 $
+ * $Date: 2004/08/27 19:00:36 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.soap;
+
+/**
+ * <code>SOAPElementFactory</code> is a factory for XML fragments that
+ * will eventually end up in the SOAP part. These fragments
+ * can be inserted as children of the <code>SOAPHeader</code> or
+ * <code>SOAPBody</code> or <code>SOAPEnvelope</code>.
+ *
+ * <p>Elements created using this factory do not have the properties
+ * of an element that lives inside a SOAP header document. These
+ * elements are copied into the XML document tree when they are
+ * inserted.
+ * @deprecated - Use <code>javax.xml.soap.SOAPFactory</code> for creating SOAPElements.
+ * @see javax.xml.soap.SOAPFactory
+ */
+public class SOAPElementFactory {
+
+    private SOAPFactory soapFactory;
+
+    private SOAPElementFactory(SOAPFactory soapFactory) {
+        this.soapFactory = soapFactory;
+    }
+
+    /**
+     * Create a <code>SOAPElement</code> object initialized with the
+     * given <code>Name</code> object.
+     *
+     * @param name a <code>Name</code> object with the XML name for
+     *             the new element
+     *
+     * @return the new <code>SOAPElement</code> object that was
+     *         created
+     *
+     * @exception SOAPException if there is an error in creating the
+     *            <code>SOAPElement</code> object
+     *
+     * @deprecated Use
+     * javax.xml.soap.SOAPFactory.createElement(javax.xml.soap.Name)
+     * instead
+     *
+     * @see javax.xml.soap.SOAPFactory#createElement(javax.xml.soap.Name)
+     * @see javax.xml.soap.SOAPFactory#createElement(javax.xml.namespace.QName)
+     */
+    public SOAPElement create(Name name) throws SOAPException {
+        return soapFactory.createElement(name);
+    }
+
+    /**
+     * Create a <code>SOAPElement</code> object initialized with the
+     * given local name.
+     *
+     * @param localName a <code>String</code> giving the local name for
+     *             the new element
+     *
+     * @return the new <code>SOAPElement</code> object that was
+     *         created
+     *
+     * @exception SOAPException if there is an error in creating the
+     *            <code>SOAPElement</code> object
+     *
+     * @deprecated Use
+     * javax.xml.soap.SOAPFactory.createElement(String localName) instead
+     *
+     * @see javax.xml.soap.SOAPFactory#createElement(java.lang.String)
+     */
+    public SOAPElement create(String localName) throws SOAPException {
+        return soapFactory.createElement(localName);
+    }
+
+    /**
+     * Create a new <code>SOAPElement</code> object with the given
+     * local name, prefix and uri.
+     *
+     * @param localName a <code>String</code> giving the local name
+     *                  for the new element
+     * @param prefix the prefix for this <code>SOAPElement</code>
+     * @param uri a <code>String</code> giving the URI of the
+     *            namespace to which the new element belongs
+     *
+     * @exception SOAPException if there is an error in creating the
+     *            <code>SOAPElement</code> object
+     *
+     * @deprecated Use
+     * javax.xml.soap.SOAPFactory.createElement(String localName,
+     *                      String prefix,
+     *                      String uri)
+     * instead
+     *
+     * @see javax.xml.soap.SOAPFactory#createElement(java.lang.String, java.lang.String, java.lang.String)
+     */
+    public SOAPElement create(String localName, String prefix, String uri)
+        throws SOAPException {
+        return soapFactory.createElement(localName, prefix, uri);
+    }
+
+    /**
+     * Creates a new instance of <code>SOAPElementFactory</code>.
+     *
+     * @return a new instance of a <code>SOAPElementFactory</code>
+     *
+     * @exception SOAPException if there was an error creating the
+     *            default <code>SOAPElementFactory</code>
+     */
+    public static SOAPElementFactory newInstance() throws SOAPException {
+        try {
+            return new SOAPElementFactory(SOAPFactory.newInstance());
+        } catch (Exception ex) {
+            throw new SOAPException(
+                "Unable to create SOAP Element Factory: " + ex.getMessage());
+        }
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPEnvelope.java b/jaxws/src/share/classes/javax/xml/soap/SOAPEnvelope.java
new file mode 100644
index 0000000..96ed2b4
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPEnvelope.java
@@ -0,0 +1,205 @@
+/*
+ * $Id: SOAPEnvelope.java,v 1.5 2004/04/02 01:24:18 ofung Exp $
+ * $Revision: 1.5 $
+ * $Date: 2004/04/02 01:24:18 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+
+/**
+ * The container for the SOAPHeader and SOAPBody portions of a
+ * <code>SOAPPart</code> object. By default, a <code>SOAPMessage</code>
+ * object is created with a <code>SOAPPart</code> object that has a
+ * <code>SOAPEnvelope</code> object. The <code>SOAPEnvelope</code> object
+ * by default has an empty <code>SOAPBody</code> object and an empty
+ * <code>SOAPHeader</code> object.  The <code>SOAPBody</code> object is
+ * required, and the <code>SOAPHeader</code> object, though
+ * optional, is used in the majority of cases. If the
+ * <code>SOAPHeader</code> object is not needed, it can be deleted,
+ * which is shown later.
+ * <P>
+ * A client can access the <code>SOAPHeader</code> and <code>SOAPBody</code>
+ * objects by calling the methods <code>SOAPEnvelope.getHeader</code> and
+ * <code>SOAPEnvelope.getBody</code>. The
+ * following  lines of code use these two methods after starting with
+ * the <code>SOAPMessage</code>
+ * object <i>message</i> to get the <code>SOAPPart</code> object <i>sp</i>,
+ * which is then used to get the <code>SOAPEnvelope</code> object <i>se</i>.
+ *
+ * <PRE>
+ *     SOAPPart sp = message.getSOAPPart();
+ *     SOAPEnvelope se = sp.getEnvelope();
+ *     SOAPHeader sh = se.getHeader();
+ *     SOAPBody sb = se.getBody();
+ * </PRE>
+ * <P>
+ * It is possible to change the body or header of a <code>SOAPEnvelope</code>
+ * object by retrieving the current one, deleting it, and then adding
+ * a new body or header. The <code>javax.xml.soap.Node</code> method
+ * <code>deleteNode</code> deletes the XML element (node) on which it is
+ * called.  For example, the following line of code deletes the
+ * <code>SOAPBody</code> object that is retrieved by the method <code>getBody</code>.
+ * <PRE>
+ *      se.getBody().detachNode();
+ * </PRE>
+ * To create a <code>SOAPHeader</code> object to replace the one that was removed,
+ * a client uses
+ * the method <code>SOAPEnvelope.addHeader</code>, which creates a new header and
+ * adds it to the <code>SOAPEnvelope</code> object. Similarly, the method
+ * <code>addBody</code> creates a new <code>SOAPBody</code> object and adds
+ * it to the <code>SOAPEnvelope</code> object. The following code fragment
+ * retrieves the current header, removes it, and adds a new one. Then
+ * it retrieves the current body, removes it, and adds a new one.
+ *
+ * <PRE>
+ *     SOAPPart sp = message.getSOAPPart();
+ *     SOAPEnvelope se = sp.getEnvelope();
+ *     se.getHeader().detachNode();
+ *     SOAPHeader sh = se.addHeader();
+ *     se.getBody().detachNode();
+ *     SOAPBody sb = se.addBody();
+ * </PRE>
+ * It is an error to add a <code>SOAPBody</code> or <code>SOAPHeader</code>
+ * object if one already exists.
+ * <P>
+ * The <code>SOAPEnvelope</code> interface provides three methods for creating
+ * <code>Name</code> objects. One method creates <code>Name</code> objects with
+ * a local name, a namespace prefix, and a namesapce URI. The second method creates
+ * <code>Name</code> objects with a local name and a namespace prefix, and the third
+ * creates <code>Name</code> objects with just a local name.  The following line of
+ * code, in which <i>se</i> is a <code>SOAPEnvelope</code> object, creates a new
+ * <code>Name</code> object with all three.
+ * <PRE>
+ *     Name name = se.createName("GetLastTradePrice", "WOMBAT",
+ *                                "http://www.wombat.org/trader");
+ * </PRE>
+ */
+public interface SOAPEnvelope extends SOAPElement {
+
+    /**
+     * Creates a new <code>Name</code> object initialized with the
+     * given local name, namespace prefix, and namespace URI.
+     * <P>
+     * This factory method creates <code>Name</code> objects for use in
+     * the SOAP/XML document.
+     *
+     * @param localName a <code>String</code> giving the local name
+     * @param prefix a <code>String</code> giving the prefix of the namespace
+     * @param uri a <code>String</code> giving the URI of the namespace
+     * @return a <code>Name</code> object initialized with the given
+     *         local name, namespace prefix, and namespace URI
+     * @throws SOAPException if there is a SOAP error
+     */
+    public abstract Name createName(String localName, String prefix,
+                                    String uri)
+        throws SOAPException;
+
+    /**
+     * Creates a new <code>Name</code> object initialized with the
+     * given local name.
+     * <P>
+     * This factory method creates <code>Name</code> objects for use in
+     * the SOAP/XML document.
+     *
+     * @param localName a <code>String</code> giving the local name
+     * @return a <code>Name</code> object initialized with the given
+     *         local name
+     * @throws SOAPException if there is a SOAP error
+     */
+    public abstract Name createName(String localName)
+        throws SOAPException;
+
+    /**
+     * Returns the <code>SOAPHeader</code> object for
+     * this <code>SOAPEnvelope</code> object.
+     * <P>
+     * A new <code>SOAPMessage</code> object is by default created with a
+     * <code>SOAPEnvelope</code> object that contains an empty
+     * <code>SOAPHeader</code> object.  As a result, the method
+     * <code>getHeader</code> will always return a <code>SOAPHeader</code>
+     * object unless the header has been removed and a new one has not
+     * been added.
+     *
+     * @return the <code>SOAPHeader</code> object or <code>null</code> if
+     *         there is none
+     * @exception SOAPException if there is a problem obtaining the
+     *            <code>SOAPHeader</code> object
+     */
+    public SOAPHeader getHeader() throws SOAPException;
+
+    /**
+     * Returns the <code>SOAPBody</code> object associated with this
+     * <code>SOAPEnvelope</code> object.
+     * <P>
+     * A new <code>SOAPMessage</code> object is by default created with a
+     * <code>SOAPEnvelope</code> object that contains an empty
+     * <code>SOAPBody</code> object.  As a result, the method
+     * <code>getBody</code> will always return a <code>SOAPBody</code>
+     * object unless the body has been removed and a new one has not
+     * been added.
+     *
+     * @return the <code>SOAPBody</code> object for this
+     *         <code>SOAPEnvelope</code> object or <code>null</code>
+     *         if there is none
+     * @exception SOAPException if there is a problem obtaining the
+     *            <code>SOAPBody</code> object
+     */
+    public SOAPBody getBody() throws SOAPException;
+    /**
+     * Creates a <code>SOAPHeader</code> object and sets it as the
+     * <code>SOAPHeader</code> object for this <code>SOAPEnvelope</code>
+     * object.
+     * <P>
+     * It is illegal to add a header when the envelope already
+     * contains a header.  Therefore, this method should be called
+     * only after the existing header has been removed.
+     *
+     * @return the new <code>SOAPHeader</code> object
+     *
+     * @exception SOAPException if this
+     *            <code>SOAPEnvelope</code> object already contains a
+     *            valid <code>SOAPHeader</code> object
+     */
+    public SOAPHeader addHeader() throws SOAPException;
+    /**
+     * Creates a <code>SOAPBody</code> object and sets it as the
+     * <code>SOAPBody</code> object for this <code>SOAPEnvelope</code>
+     * object.
+     * <P>
+     * It is illegal to add a body when the envelope already
+     * contains a body. Therefore, this method should be called
+     * only after the existing body has been removed.
+     *
+     * @return the new <code>SOAPBody</code> object
+     *
+     * @exception SOAPException if this
+     *            <code>SOAPEnvelope</code> object already contains a
+     *            valid <code>SOAPBody</code> object
+     */
+    public SOAPBody addBody() throws SOAPException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPException.java b/jaxws/src/share/classes/javax/xml/soap/SOAPException.java
new file mode 100644
index 0000000..ef80335
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPException.java
@@ -0,0 +1,168 @@
+/*
+ * $Id: SOAPException.java,v 1.5 2004/04/02 01:24:18 ofung Exp $
+ * $Revision: 1.5 $
+ * $Date: 2004/04/02 01:24:18 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * An exception that signals that a SOAP exception has occurred. A
+ * <code>SOAPException</code> object may contain a <code>String</code>
+ * that gives the reason for the exception, an embedded
+ * <code>Throwable</code> object, or both. This class provides methods
+ * for retrieving reason messages and for retrieving the embedded
+ * <code>Throwable</code> object.
+ *
+ * <P> Typical reasons for throwing a <code>SOAPException</code>
+ * object are problems such as difficulty setting a header, not being
+ * able to send a message, and not being able to get a connection with
+ * the provider.  Reasons for embedding a <code>Throwable</code>
+ * object include problems such as input/output errors or a parsing
+ * problem, such as an error in parsing a header.
+ */
+public class SOAPException extends Exception {
+    private Throwable cause;
+
+    /**
+     * Constructs a <code>SOAPException</code> object with no
+     * reason or embedded <code>Throwable</code> object.
+     */
+    public SOAPException() {
+        super();
+        this.cause = null;
+    }
+
+    /**
+     * Constructs a <code>SOAPException</code> object with the given
+     * <code>String</code> as the reason for the exception being thrown.
+     *
+     * @param reason a description of what caused the exception
+     */
+    public SOAPException(String reason) {
+        super(reason);
+        this.cause = null;
+    }
+
+    /**
+     * Constructs a <code>SOAPException</code> object with the given
+     * <code>String</code> as the reason for the exception being thrown
+     * and the given <code>Throwable</code> object as an embedded
+     * exception.
+     *
+     * @param reason a description of what caused the exception
+     * @param cause a <code>Throwable</code> object that is to
+     *        be embedded in this <code>SOAPException</code> object
+     */
+    public SOAPException(String reason, Throwable cause) {
+        super(reason);
+        initCause(cause);
+    }
+
+    /**
+     * Constructs a <code>SOAPException</code> object initialized
+     * with the given <code>Throwable</code> object.
+     */
+    public SOAPException(Throwable cause) {
+        super(cause.toString());
+        initCause(cause);
+    }
+
+    /**
+     * Returns the detail message for this <code>SOAPException</code>
+     * object.
+     * <P>
+     * If there is an embedded <code>Throwable</code> object, and if the
+     * <code>SOAPException</code> object has no detail message of its
+     * own, this method will return the detail message from the embedded
+     * <code>Throwable</code> object.
+     *
+     * @return the error or warning message for this
+     *         <code>SOAPException</code> or, if it has none, the
+     *         message of the embedded <code>Throwable</code> object,
+     *         if there is one
+     */
+    public String getMessage() {
+        String message = super.getMessage();
+        if (message == null && cause != null) {
+            return cause.getMessage();
+        } else {
+            return message;
+        }
+    }
+
+    /**
+     * Returns the <code>Throwable</code> object embedded in this
+     * <code>SOAPException</code> if there is one. Otherwise, this method
+     * returns <code>null</code>.
+     *
+     * @return the embedded <code>Throwable</code> object or <code>null</code>
+     *         if there is none
+     */
+
+    public Throwable getCause() {
+        return cause;
+    }
+
+    /**
+     * Initializes the <code>cause</code> field of this <code>SOAPException</code>
+     * object with the given <code>Throwable</code> object.
+     * <P>
+     * This method can be called at most once.  It is generally called from
+     * within the constructor or immediately after the constructor has
+     * returned a new <code>SOAPException</code> object.
+     * If this <code>SOAPException</code> object was created with the
+     * constructor {@link #SOAPException(Throwable)} or
+     * {@link #SOAPException(String,Throwable)}, meaning that its
+     * <code>cause</code> field already has a value, this method cannot be
+     * called even once.
+     *
+     * @param  cause the <code>Throwable</code> object that caused this
+     *         <code>SOAPException</code> object to be thrown.  The value of this
+     *         parameter is saved for later retrieval by the
+     *         {@link #getCause()} method.  A <tt>null</tt> value is
+     *         permitted and indicates that the cause is nonexistent or
+     *         unknown.
+     * @return  a reference to this <code>SOAPException</code> instance
+     * @throws IllegalArgumentException if <code>cause</code> is this
+     *         <code>Throwable</code> object.  (A <code>Throwable</code> object
+     *         cannot be its own cause.)
+     * @throws IllegalStateException if the cause for this <code>SOAPException</code> object
+     *         has already been initialized
+     */
+    public synchronized Throwable initCause(Throwable cause) {
+        if (this.cause != null) {
+            throw new IllegalStateException("Can't override cause");
+        }
+        if (cause == this) {
+            throw new IllegalArgumentException("Self-causation not permitted");
+        }
+        this.cause = cause;
+
+        return this;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPFactory.java b/jaxws/src/share/classes/javax/xml/soap/SOAPFactory.java
new file mode 100644
index 0000000..3e29e984
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPFactory.java
@@ -0,0 +1,298 @@
+/*
+ * $Id: SOAPFactory.java,v 1.12 2005/04/05 22:46:26 mk125090 Exp $
+ * $Revision: 1.12 $
+ * $Datae$
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.soap;
+
+import javax.xml.namespace.QName;
+
+import org.w3c.dom.Element;
+
+/**
+ * <code>SOAPFactory</code> is a factory for creating various objects
+ * that exist in the SOAP XML tree.
+
+ * <code>SOAPFactory</code> can be
+ * used to create XML fragments that will eventually end up in the
+ * SOAP part. These fragments can be inserted as children of the
+ * {@link SOAPHeaderElement} or {@link SOAPBodyElement} or
+ * {@link SOAPEnvelope} or other {@link SOAPElement} objects.
+ *
+ * <code>SOAPFactory</code> also has methods to create
+ * <code>javax.xml.soap.Detail</code> objects as well as
+ * <code>java.xml.soap.Name</code> objects.
+ *
+ */
+public abstract class SOAPFactory {
+
+    /**
+     * A constant representing the property used to lookup the name of
+     * a <code>SOAPFactory</code> implementation class.
+     */
+    static private final String SOAP_FACTORY_PROPERTY =
+        "javax.xml.soap.SOAPFactory";
+
+    /**
+     * Creates a <code>SOAPElement</code> object from an existing DOM
+     * <code>Element</code>. If the DOM <code>Element</code> that is passed in
+     * as an argument is already a <code>SOAPElement</code> then this method
+     * must return it unmodified without any further work. Otherwise, a new
+     * <code>SOAPElement</code> is created and a deep copy is made of the
+     * <code>domElement</code> argument. The concrete type of the return value
+     * will depend on the name of the <code>domElement</code> argument. If any
+     * part of the tree rooted in <code>domElement</code> violates SOAP rules, a
+     * <code>SOAPException</code> will be thrown.
+     *
+     * @param domElement - the <code>Element</code> to be copied.
+     *
+     * @return a new <code>SOAPElement</code> that is a copy of <code>domElement</code>.
+     *
+     * @exception SOAPException if there is an error in creating the
+     *            <code>SOAPElement</code> object
+     *
+     * @since SAAJ 1.3
+     */
+    public SOAPElement createElement(Element domElement) throws SOAPException {
+        throw new UnsupportedOperationException("createElement(org.w3c.dom.Element) must be overridden by all subclasses of SOAPFactory.");
+    }
+
+    /**
+     * Creates a <code>SOAPElement</code> object initialized with the
+     * given <code>Name</code> object. The concrete type of the return value
+     * will depend on the name given to the new <code>SOAPElement</code>. For
+     * instance, a new <code>SOAPElement</code> with the name
+     * "{http://www.w3.org/2003/05/soap-envelope}Envelope" would cause a
+     * <code>SOAPEnvelope</code> that supports SOAP 1.2 behavior to be created.
+     *
+     * @param name a <code>Name</code> object with the XML name for
+     *             the new element
+     *
+     * @return the new <code>SOAPElement</code> object that was
+     *         created
+     *
+     * @exception SOAPException if there is an error in creating the
+     *            <code>SOAPElement</code> object
+     * @see SOAPFactory#createElement(javax.xml.namespace.QName)
+     */
+    public abstract SOAPElement createElement(Name name) throws SOAPException;
+
+    /**
+     * Creates a <code>SOAPElement</code> object initialized with the
+     * given <code>QName</code> object. The concrete type of the return value
+     * will depend on the name given to the new <code>SOAPElement</code>. For
+     * instance, a new <code>SOAPElement</code> with the name
+     * "{http://www.w3.org/2003/05/soap-envelope}Envelope" would cause a
+     * <code>SOAPEnvelope</code> that supports SOAP 1.2 behavior to be created.
+     *
+     * @param qname a <code>QName</code> object with the XML name for
+     *             the new element
+     *
+     * @return the new <code>SOAPElement</code> object that was
+     *         created
+     *
+     * @exception SOAPException if there is an error in creating the
+     *            <code>SOAPElement</code> object
+     * @see SOAPFactory#createElement(Name)
+     * @since SAAJ 1.3
+     */
+    public  SOAPElement createElement(QName qname) throws SOAPException {
+        throw new UnsupportedOperationException("createElement(QName) must be overridden by all subclasses of SOAPFactory.");
+    }
+
+    /**
+     * Creates a <code>SOAPElement</code> object initialized with the
+     * given local name.
+     *
+     * @param localName a <code>String</code> giving the local name for
+     *             the new element
+     *
+     * @return the new <code>SOAPElement</code> object that was
+     *         created
+     *
+     * @exception SOAPException if there is an error in creating the
+     *            <code>SOAPElement</code> object
+     */
+    public abstract SOAPElement createElement(String localName)
+        throws SOAPException;
+
+
+    /**
+     * Creates a new <code>SOAPElement</code> object with the given
+     * local name, prefix and uri. The concrete type of the return value
+     * will depend on the name given to the new <code>SOAPElement</code>. For
+     * instance, a new <code>SOAPElement</code> with the name
+     * "{http://www.w3.org/2003/05/soap-envelope}Envelope" would cause a
+     * <code>SOAPEnvelope</code> that supports SOAP 1.2 behavior to be created.
+     *
+     * @param localName a <code>String</code> giving the local name
+     *                  for the new element
+     * @param prefix the prefix for this <code>SOAPElement</code>
+     * @param uri a <code>String</code> giving the URI of the
+     *            namespace to which the new element belongs
+     *
+     * @exception SOAPException if there is an error in creating the
+     *            <code>SOAPElement</code> object
+     */
+    public abstract SOAPElement createElement(
+        String localName,
+        String prefix,
+        String uri)
+        throws SOAPException;
+
+    /**
+     * Creates a new <code>Detail</code> object which serves as a container
+     * for <code>DetailEntry</code> objects.
+     * <P>
+     * This factory method creates <code>Detail</code> objects for use in
+     * situations where it is not practical to use the <code>SOAPFault</code>
+     * abstraction.
+     *
+     * @return a <code>Detail</code> object
+     * @throws SOAPException if there is a SOAP error
+     * @throws UnsupportedOperationException if the protocol specified
+     *         for the SOAPFactory was <code>DYNAMIC_SOAP_PROTOCOL</code>
+     */
+    public abstract Detail createDetail() throws SOAPException;
+
+    /**
+     *Creates a new <code>SOAPFault</code> object initialized with the given <code>reasonText</code>
+     *  and <code>faultCode</code>
+     *@param reasonText the ReasonText/FaultString for the fault
+     *@param faultCode the FaultCode for the fault
+     *@return a <code>SOAPFault</code> object
+     *@throws SOAPException if there is a SOAP error
+     *@since SAAJ 1.3
+     */
+    public abstract SOAPFault createFault(String reasonText, QName faultCode) throws SOAPException;
+
+    /**
+     *Creates a new default <code>SOAPFault</code> object
+     *@return a <code>SOAPFault</code> object
+     *@throws SOAPException if there is a SOAP error
+     *@since SAAJ 1.3
+     */
+    public abstract SOAPFault createFault() throws SOAPException;
+
+    /**
+     * Creates a new <code>Name</code> object initialized with the
+     * given local name, namespace prefix, and namespace URI.
+     * <P>
+     * This factory method creates <code>Name</code> objects for use in
+     * situations where it is not practical to use the <code>SOAPEnvelope</code>
+     * abstraction.
+     *
+     * @param localName a <code>String</code> giving the local name
+     * @param prefix a <code>String</code> giving the prefix of the namespace
+     * @param uri a <code>String</code> giving the URI of the namespace
+     * @return a <code>Name</code> object initialized with the given
+     *         local name, namespace prefix, and namespace URI
+     * @throws SOAPException if there is a SOAP error
+     */
+    public abstract Name createName(
+        String localName,
+        String prefix,
+        String uri)
+        throws SOAPException;
+
+    /**
+     * Creates a new <code>Name</code> object initialized with the
+     * given local name.
+     * <P>
+     * This factory method creates <code>Name</code> objects for use in
+     * situations where it is not practical to use the <code>SOAPEnvelope</code>
+     * abstraction.
+     *
+     * @param localName a <code>String</code> giving the local name
+     * @return a <code>Name</code> object initialized with the given
+     *         local name
+     * @throws SOAPException if there is a SOAP error
+     */
+    public abstract Name createName(String localName) throws SOAPException;
+
+    /**
+     * Creates a new <code>SOAPFactory</code> object that is an instance of
+     * the default implementation (SOAP 1.1),
+     *
+     * This method uses the following ordered lookup procedure to determine the SOAPFactory implementation class to load:
+     * <UL>
+     *  <LI> Use the javax.xml.soap.SOAPFactory system property.
+     *  <LI> Use the properties file "lib/jaxm.properties" in the JRE directory. This configuration file is in standard
+     * java.util.Properties format and contains the fully qualified name of the implementation class with the key being the
+     * system property defined above.
+     *  <LI> Use the Services API (as detailed in the JAR specification), if available, to determine the classname. The Services API
+     * will look for a classname in the file META-INF/services/javax.xml.soap.SOAPFactory in jars available to the runtime.
+     *  <LI> Use the SAAJMetaFactory instance to locate the SOAPFactory implementation class.
+     * </UL>
+     *
+     * @return a new instance of a <code>SOAPFactory</code>
+     *
+     * @exception SOAPException if there was an error creating the
+     *            default <code>SOAPFactory</code>
+     * @see SAAJMetaFactory
+     */
+    public static SOAPFactory newInstance()
+        throws SOAPException
+    {
+        try {
+            SOAPFactory factory = (SOAPFactory) FactoryFinder.find(SOAP_FACTORY_PROPERTY);
+            if (factory != null)
+                return factory;
+            return newInstance(SOAPConstants.SOAP_1_1_PROTOCOL);
+        } catch (Exception ex) {
+            throw new SOAPException(
+                "Unable to create SOAP Factory: " + ex.getMessage());
+        }
+
+    }
+
+    /**
+     * Creates a new <code>SOAPFactory</code> object that is an instance of
+     * the specified implementation, this method uses the SAAJMetaFactory to
+     * locate the implementation class and create the SOAPFactory instance.
+     *
+     * @return a new instance of a <code>SOAPFactory</code>
+     *
+     * @param protocol  a string constant representing the protocol of the
+     *                   specified SOAP factory implementation. May be
+     *                   either <code>DYNAMIC_SOAP_PROTOCOL</code>,
+     *                   <code>DEFAULT_SOAP_PROTOCOL</code> (which is the same
+     *                   as) <code>SOAP_1_1_PROTOCOL</code>, or
+     *                   <code>SOAP_1_2_PROTOCOL</code>.
+     *
+     * @exception SOAPException if there was an error creating the
+     *            specified <code>SOAPFactory</code>
+     * @see SAAJMetaFactory
+     * @since SAAJ 1.3
+     */
+    public static SOAPFactory newInstance(String protocol)
+        throws SOAPException {
+            return SAAJMetaFactory.getInstance().newSOAPFactory(protocol);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPFault.java b/jaxws/src/share/classes/javax/xml/soap/SOAPFault.java
new file mode 100644
index 0000000..a50de16
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPFault.java
@@ -0,0 +1,516 @@
+/*
+ * $Id: SOAPFault.java,v 1.19 2005/09/26 21:09:04 mk125090 Exp $
+ * $Revision: 1.19 $
+ * $Date: 2005/09/26 21:09:04 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import java.util.Iterator;
+import java.util.Locale;
+
+import javax.xml.namespace.QName;
+
+/**
+ * An element in the <code>SOAPBody</code> object that contains
+ * error and/or status information. This information may relate to
+ * errors in the <code>SOAPMessage</code> object or to problems
+ * that are not related to the content in the message itself. Problems
+ * not related to the message itself are generally errors in
+ * processing, such as the inability to communicate with an upstream
+ * server.
+ * <P>
+ * Depending on the <code>protocol</code> specified while creating the
+ * <code>MessageFactory</code> instance,  a <code>SOAPFault</code> has
+ * sub-elements as defined in the SOAP 1.1/SOAP 1.2 specification.
+ */
+public interface SOAPFault extends SOAPBodyElement {
+
+    /**
+     * Sets this <code>SOAPFault</code> object with the given fault code.
+     *
+     * <P> Fault codes, which give information about the fault, are defined
+     * in the SOAP 1.1 specification. A fault code is mandatory and must
+     * be of type <code>Name</code>. This method provides a convenient
+     * way to set a fault code. For example,
+     *
+     * <PRE>
+     * SOAPEnvelope se = ...;
+     * // Create a qualified name in the SOAP namespace with a localName
+     * // of "Client". Note that prefix parameter is optional and is null
+     * // here which causes the implementation to use an appropriate prefix.
+     * Name qname = se.createName("Client", null,
+     *                            SOAPConstants.URI_NS_SOAP_ENVELOPE);
+     * SOAPFault fault = ...;
+     * fault.setFaultCode(qname);
+     * </PRE>
+     * It is preferable to use this method over {@link #setFaultCode(String)}.
+     *
+     * @param faultCodeQName a <code>Name</code> object giving the fault
+     * code to be set. It must be namespace qualified.
+     * @see #getFaultCodeAsName
+     *
+     * @exception SOAPException if there was an error in adding the
+     *            <i>faultcode</i> element to the underlying XML tree.
+     *
+     * @since SAAJ 1.2
+     */
+    public void setFaultCode(Name faultCodeQName) throws SOAPException;
+
+    /**
+     * Sets this <code>SOAPFault</code> object with the given fault code.
+     *
+     * It is preferable to use this method over {@link #setFaultCode(Name)}.
+     *
+     * @param faultCodeQName a <code>QName</code> object giving the fault
+     * code to be set. It must be namespace qualified.
+     * @see #getFaultCodeAsQName
+     *
+     * @exception SOAPException if there was an error in adding the
+     *            <code>faultcode</code> element to the underlying XML tree.
+     *
+     * @see #setFaultCode(Name)
+     * @see #getFaultCodeAsQName()
+     *
+     * @since SAAJ 1.3
+     */
+    public void setFaultCode(QName faultCodeQName) throws SOAPException;
+
+    /**
+     * Sets this <code>SOAPFault</code> object with the give fault code.
+     * <P>
+     * Fault codes, which given information about the fault, are defined in
+     * the SOAP 1.1 specification. This element is mandatory in SOAP 1.1.
+     * Because the fault code is required to be a QName it is preferable to
+     * use the {@link #setFaultCode(Name)} form of this method.
+     *
+     * @param faultCode a <code>String</code> giving the fault code to be set.
+     *         It must be of the form "prefix:localName" where the prefix has
+     *         been defined in a namespace declaration.
+     * @see #setFaultCode(Name)
+     * @see #getFaultCode
+     * @see SOAPElement#addNamespaceDeclaration
+     *
+     * @exception SOAPException if there was an error in adding the
+     *            <code>faultCode</code> to the underlying XML tree.
+     */
+    public void setFaultCode(String faultCode) throws SOAPException;
+
+    /**
+     * Gets the mandatory SOAP 1.1 fault code for this
+     * <code>SOAPFault</code> object as a SAAJ <code>Name</code> object.
+     * The SOAP 1.1 specification requires the value of the "faultcode"
+     * element to be of type QName. This method returns the content of the
+     * element as a QName in the form of a SAAJ Name object. This method
+     * should be used instead of the <code>getFaultCode</code> method since
+     * it allows applications to easily access the namespace name without
+     * additional parsing.
+     *
+     * @return a <code>Name</code> representing the faultcode
+     * @see #setFaultCode(Name)
+     *
+     * @since SAAJ 1.2
+     */
+    public Name getFaultCodeAsName();
+
+
+    /**
+     * Gets the fault code for this
+     * <code>SOAPFault</code> object as a <code>QName</code> object.
+     *
+     * @return a <code>QName</code> representing the faultcode
+     *
+     * @see #setFaultCode(QName)
+     *
+     * @since SAAJ 1.3
+     */
+    public QName getFaultCodeAsQName();
+
+    /**
+     * Gets the Subcodes for this <code>SOAPFault</code> as an iterator over
+     * <code>QNames</code>.
+     *
+     * @return an <code>Iterator</code> that accesses a sequence of
+     *      <code>QNames</code>. This <code>Iterator</code> should not support
+     *      the optional <code>remove</code> method. The order in which the
+     *      Subcodes are returned reflects the hierarchy of Subcodes present
+     *      in the fault from top to bottom.
+     *
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Subcode.
+     *
+     * @since SAAJ 1.3
+     */
+    public Iterator getFaultSubcodes();
+
+    /**
+     * Removes any Subcodes that may be contained by this
+     * <code>SOAPFault</code>. Subsequent calls to
+     * <code>getFaultSubcodes</code> will return an empty iterator until a call
+     * to <code>appendFaultSubcode</code> is made.
+     *
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Subcode.
+     *
+     * @since SAAJ 1.3
+     */
+    public void removeAllFaultSubcodes();
+
+    /**
+     * Adds a Subcode to the end of the sequence of Subcodes contained by this
+     * <code>SOAPFault</code>. Subcodes, which were introduced in SOAP 1.2, are
+     * represented by a recursive sequence of subelements rooted in the
+     * mandatory Code subelement of a SOAP Fault.
+     *
+     * @param subcode a QName containing the Value of the Subcode.
+     *
+     * @exception SOAPException if there was an error in setting the Subcode
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Subcode.
+     *
+     * @since SAAJ 1.3
+     */
+    public void appendFaultSubcode(QName subcode) throws SOAPException;
+
+    /**
+     * Gets the fault code for this <code>SOAPFault</code> object.
+     *
+     * @return a <code>String</code> with the fault code
+     * @see #getFaultCodeAsName
+     * @see #setFaultCode
+     */
+    public String getFaultCode();
+
+    /**
+     * Sets this <code>SOAPFault</code> object with the given fault actor.
+     * <P>
+     * The fault actor is the recipient in the message path who caused the
+     * fault to happen.
+     * <P>
+     * If this <code>SOAPFault</code> supports SOAP 1.2 then this call is
+     * equivalent to {@link #setFaultRole(String)}
+     *
+     * @param faultActor a <code>String</code> identifying the actor that
+     *        caused this <code>SOAPFault</code> object
+     * @see #getFaultActor
+     *
+     * @exception SOAPException if there was an error in adding the
+     *            <code>faultActor</code> to the underlying XML tree.
+     */
+    public void setFaultActor(String faultActor) throws SOAPException;
+
+    /**
+     * Gets the fault actor for this <code>SOAPFault</code> object.
+     * <P>
+     * If this <code>SOAPFault</code> supports SOAP 1.2 then this call is
+     * equivalent to {@link #getFaultRole()}
+     *
+     * @return a <code>String</code> giving the actor in the message path
+     *         that caused this <code>SOAPFault</code> object
+     * @see #setFaultActor
+     */
+    public String getFaultActor();
+
+    /**
+     * Sets the fault string for this <code>SOAPFault</code> object
+     * to the given string.
+     * <P>
+     * If this
+     * <code>SOAPFault</code> is part of a message that supports SOAP 1.2 then
+     * this call is equivalent to:
+     * <pre>
+     *      addFaultReasonText(faultString, Locale.getDefault());
+     * </pre>
+     *
+     * @param faultString a <code>String</code> giving an explanation of
+     *        the fault
+     * @see #getFaultString
+     *
+     * @exception SOAPException if there was an error in adding the
+     *            <code>faultString</code> to the underlying XML tree.
+     */
+    public void setFaultString(String faultString) throws SOAPException;
+
+    /**
+     * Sets the fault string for this <code>SOAPFault</code> object
+     * to the given string and localized to the given locale.
+     * <P>
+     * If this
+     * <code>SOAPFault</code> is part of a message that supports SOAP 1.2 then
+     * this call is equivalent to:
+     * <pre>
+     *      addFaultReasonText(faultString, locale);
+     * </pre>
+     *
+     * @param faultString a <code>String</code> giving an explanation of
+     *         the fault
+     * @param locale a {@link java.util.Locale Locale} object indicating
+     *         the native language of the <code>faultString</code>
+     * @see #getFaultString
+     *
+     * @exception SOAPException if there was an error in adding the
+     *            <code>faultString</code> to the underlying XML tree.
+     *
+     * @since SAAJ 1.2
+     */
+    public void setFaultString(String faultString, Locale locale)
+        throws SOAPException;
+
+    /**
+     * Gets the fault string for this <code>SOAPFault</code> object.
+     * <P>
+     * If this
+     * <code>SOAPFault</code> is part of a message that supports SOAP 1.2 then
+     * this call is equivalent to:
+     * <pre>
+     *    String reason = null;
+     *    try {
+     *        reason = (String) getFaultReasonTexts().next();
+     *    } catch (SOAPException e) {}
+     *    return reason;
+     * </pre>
+     *
+     * @return a <code>String</code> giving an explanation of
+     *        the fault
+     * @see #setFaultString(String)
+     * @see #setFaultString(String, Locale)
+     */
+    public String getFaultString();
+
+    /**
+     * Gets the locale of the fault string for this <code>SOAPFault</code>
+     * object.
+     * <P>
+     * If this
+     * <code>SOAPFault</code> is part of a message that supports SOAP 1.2 then
+     * this call is equivalent to:
+     * <pre>
+     *    Locale locale = null;
+     *    try {
+     *        locale = (Locale) getFaultReasonLocales().next();
+     *    } catch (SOAPException e) {}
+     *    return locale;
+     * </pre>
+     *
+     * @return a <code>Locale</code> object indicating the native language of
+     *          the fault string or <code>null</code> if no locale was specified
+     * @see #setFaultString(String, Locale)
+     *
+     * @since SAAJ 1.2
+     */
+    public Locale getFaultStringLocale();
+
+    /**
+     * Returns true if this <code>SOAPFault</code> has a <code>Detail</code>
+     * subelement and false otherwise. Equivalent to
+     * <code>(getDetail()!=null)</code>.
+     *
+     * @return true if this <code>SOAPFault</code> has a <code>Detail</code>
+     * subelement and false otherwise.
+     *
+     * @since SAAJ 1.3
+     */
+    public boolean hasDetail();
+
+    /**
+     * Returns the optional detail element for this <code>SOAPFault</code>
+     * object.
+     * <P>
+     * A <code>Detail</code> object carries application-specific error
+     * information, the scope of the error information is restricted to
+     * faults in the <code>SOAPBodyElement</code> objects if this is a
+     * SOAP 1.1 Fault.
+     *
+     * @return a <code>Detail</code> object with application-specific
+     *         error information if present, null otherwise
+     */
+    public Detail getDetail();
+
+    /**
+     * Creates an optional <code>Detail</code> object and sets it as the
+     * <code>Detail</code> object for this <code>SOAPFault</code>
+     * object.
+     * <P>
+     * It is illegal to add a detail when the fault already
+     * contains a detail. Therefore, this method should be called
+     * only after the existing detail has been removed.
+     *
+     * @return the new <code>Detail</code> object
+     *
+     * @exception SOAPException if this
+     *            <code>SOAPFault</code> object already contains a
+     *            valid <code>Detail</code> object
+     */
+    public Detail addDetail() throws SOAPException;
+
+    /**
+     * Returns an <code>Iterator</code> over a distinct sequence of
+     * <code>Locale</code>s for which there are associated Reason Text items.
+     * Any of these <code>Locale</code>s can be used in a call to
+     * <code>getFaultReasonText</code> in order to obtain a localized version
+     * of the Reason Text string.
+     *
+     * @return an <code>Iterator</code> over a sequence of <code>Locale</code>
+     *      objects for which there are associated Reason Text items.
+     *
+     * @exception SOAPException if there was an error in retrieving
+     * the  fault Reason locales.
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Reason.
+     *
+     * @since SAAJ 1.3
+     */
+    public Iterator getFaultReasonLocales() throws SOAPException;
+
+    /**
+     * Returns an <code>Iterator</code> over a sequence of
+     * <code>String</code> objects containing all of the Reason Text items for
+     * this <code>SOAPFault</code>.
+     *
+     * @return an <code>Iterator</code> over env:Fault/env:Reason/env:Text items.
+     *
+     * @exception SOAPException if there was an error in retrieving
+     * the  fault Reason texts.
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Reason.
+     *
+     * @since SAAJ 1.3
+     */
+    public Iterator getFaultReasonTexts() throws SOAPException;
+
+    /**
+     * Returns the Reason Text associated with the given <code>Locale</code>.
+     * If more than one such Reason Text exists the first matching Text is
+     * returned
+     *
+     * @param locale -- the <code>Locale</code> for which a localized
+     *      Reason Text is desired
+     *
+     * @return the Reason Text associated with <code>locale</code>
+     *
+     * @see #getFaultString
+     *
+     * @exception SOAPException if there was an error in retrieving
+     * the  fault Reason text for the specified locale .
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Reason.
+     *
+     * @since SAAJ 1.3
+     */
+    public String getFaultReasonText(Locale locale) throws SOAPException;
+
+    /**
+     * Appends or replaces a Reason Text item containing the specified
+     * text message and an <i>xml:lang</i> derived from
+     * <code>locale</code>. If a Reason Text item with this
+     * <i>xml:lang</i> already exists its text value will be replaced
+     * with <code>text</code>.
+     * The <code>locale</code> parameter should not be <code>null</code>
+     * <P>
+     * Code sample:
+     *
+     * <PRE>
+     * SOAPFault fault = ...;
+     * fault.addFaultReasonText("Version Mismatch", Locale.ENGLISH);
+     * </PRE>
+     *
+     * @param text -- reason message string
+     * @param locale -- Locale object representing the locale of the message
+     *
+     * @exception SOAPException if there was an error in adding the Reason text
+     * or the <code>locale</code> passed was <code>null</code>.
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Reason.
+     *
+     * @since SAAJ 1.3
+     */
+    public void addFaultReasonText(String text, java.util.Locale locale)
+        throws SOAPException;
+
+    /**
+     * Returns the optional Node element value for this
+     * <code>SOAPFault</code> object. The Node element is
+     * optional in SOAP 1.2.
+     *
+     * @return Content of the env:Fault/env:Node element as a String
+     * or <code>null</code> if none
+     *
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Node.
+     *
+     * @since SAAJ 1.3
+     */
+    public String getFaultNode();
+
+    /**
+     * Creates or replaces any existing Node element value for
+     * this <code>SOAPFault</code> object. The Node element
+     * is optional in SOAP 1.2.
+     *
+     * @exception SOAPException  if there was an error in setting the
+     *            Node for this  <code>SOAPFault</code> object.
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Node.
+     *
+     *
+     * @since SAAJ 1.3
+     */
+    public void setFaultNode(String uri) throws SOAPException;
+
+    /**
+     * Returns the optional Role element value for this
+     * <code>SOAPFault</code> object. The Role element is
+     * optional in SOAP 1.2.
+     *
+     * @return Content of the env:Fault/env:Role element as a String
+     * or <code>null</code> if none
+     *
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Role.
+     *
+     * @since SAAJ 1.3
+     */
+    public String getFaultRole();
+
+    /**
+     * Creates or replaces any existing Role element value for
+     * this <code>SOAPFault</code> object. The Role element
+     * is optional in SOAP 1.2.
+     *
+     * @param uri - the URI of the Role
+     *
+     * @exception SOAPException  if there was an error in setting the
+     *            Role for this  <code>SOAPFault</code> object.
+     *
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Role.
+     *
+     * @since SAAJ 1.3
+     */
+    public void setFaultRole(String uri) throws SOAPException;
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPFaultElement.java b/jaxws/src/share/classes/javax/xml/soap/SOAPFaultElement.java
new file mode 100644
index 0000000..7323f64
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPFaultElement.java
@@ -0,0 +1,42 @@
+/*
+ * $Id: SOAPFaultElement.java,v 1.3 2004/04/02 01:24:18 ofung Exp $
+ * $Revision: 1.3 $
+ * $Date: 2004/04/02 01:24:18 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * A representation of the contents in
+ * a <code>SOAPFault</code> object.  The <code>Detail</code> interface
+ * is a <code>SOAPFaultElement</code>.
+ * <P>
+ * Content is added to a <code>SOAPFaultElement</code> using the
+ * <code>SOAPElement</code> method <code>addTextNode</code>.
+ */
+public interface SOAPFaultElement extends SOAPElement {
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPHeader.java b/jaxws/src/share/classes/javax/xml/soap/SOAPHeader.java
new file mode 100644
index 0000000..2781e01
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPHeader.java
@@ -0,0 +1,267 @@
+/*
+ * $Id: SOAPHeader.java,v 1.5.2.12 2004/11/17 13:59:28 vj135062 Exp $
+ * $Revision: 1.5.2.12 $
+ * $Date: 2004/11/17 13:59:28 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import java.util.Iterator;
+
+import javax.xml.namespace.QName;
+
+/**
+ * A representation of the SOAP header
+ * element. A SOAP header element consists of XML data that affects
+ * the way the application-specific content is processed by the message
+ * provider. For example, transaction semantics, authentication information,
+ * and so on, can be specified as the content of a <code>SOAPHeader</code>
+ * object.
+ * <P>
+ * A <code>SOAPEnvelope</code> object contains an empty
+ * <code>SOAPHeader</code> object by default. If the <code>SOAPHeader</code>
+ * object, which is optional, is not needed, it can be retrieved and deleted
+ * with the following line of code. The variable <i>se</i> is a
+ * <code>SOAPEnvelope</code> object.
+ * <PRE>
+ *      se.getHeader().detachNode();
+ * </PRE>
+ *
+ * A <code>SOAPHeader</code> object is created with the <code>SOAPEnvelope</code>
+ * method <code>addHeader</code>. This method, which creates a new header and adds it
+ * to the envelope, may be called only after the existing header has been removed.
+ *
+ * <PRE>
+ *      se.getHeader().detachNode();
+ *      SOAPHeader sh = se.addHeader();
+ * </PRE>
+ * <P>
+ * A <code>SOAPHeader</code> object can have only <code>SOAPHeaderElement</code>
+ * objects as its immediate children. The method <code>addHeaderElement</code>
+ * creates a new <code>HeaderElement</code> object and adds it to the
+ * <code>SOAPHeader</code> object. In the following line of code, the
+ * argument to the method <code>addHeaderElement</code> is a <code>Name</code>
+ * object that is the name for the new <code>HeaderElement</code> object.
+ * <PRE>
+ *      SOAPHeaderElement shElement = sh.addHeaderElement(name);
+ * </PRE>
+ *
+ * @see SOAPHeaderElement
+ */
+public interface SOAPHeader extends SOAPElement {
+    /**
+     * Creates a new <code>SOAPHeaderElement</code> object initialized with the
+     * specified name and adds it to this <code>SOAPHeader</code> object.
+     *
+     * @param name a <code>Name</code> object with the name of the new
+     *        <code>SOAPHeaderElement</code> object
+     * @return the new <code>SOAPHeaderElement</code> object that was
+     *          inserted into this <code>SOAPHeader</code> object
+     * @exception SOAPException if a SOAP error occurs
+     * @see SOAPHeader#addHeaderElement(javax.xml.namespace.QName)
+     */
+    public SOAPHeaderElement addHeaderElement(Name name)
+        throws SOAPException;
+
+    /**
+     * Creates a new <code>SOAPHeaderElement</code> object initialized with the
+     * specified qname and adds it to this <code>SOAPHeader</code> object.
+     *
+     * @param qname a <code>QName</code> object with the qname of the new
+     *        <code>SOAPHeaderElement</code> object
+     * @return the new <code>SOAPHeaderElement</code> object that was
+     *          inserted into this <code>SOAPHeader</code> object
+     * @exception SOAPException if a SOAP error occurs
+     * @see SOAPHeader#addHeaderElement(Name)
+     * @since SAAJ 1.3
+     */
+    public SOAPHeaderElement addHeaderElement(QName qname)
+        throws SOAPException;
+
+    /**
+     * Returns an <code>Iterator</code> over all the <code>SOAPHeaderElement</code> objects
+     * in this <code>SOAPHeader</code> object
+     * that have the specified <i>actor</i> and that have a MustUnderstand attribute
+     * whose value is equivalent to <code>true</code>.
+     * <p>
+     * In SOAP 1.2 the <i>env:actor</i> attribute is replaced by the <i>env:role</i>
+     * attribute, but with essentially the same semantics.
+     *
+     * @param actor a <code>String</code> giving the URI of the <code>actor</code> / <code>role</code>
+     *        for which to search
+     * @return an <code>Iterator</code> object over all the
+     *         <code>SOAPHeaderElement</code> objects that contain the specified
+     *          <code>actor</code> / <code>role</code> and are marked as MustUnderstand
+     * @see #examineHeaderElements
+     * @see #extractHeaderElements
+     * @see SOAPConstants#URI_SOAP_ACTOR_NEXT
+     *
+     * @since SAAJ 1.2
+     */
+    public Iterator examineMustUnderstandHeaderElements(String actor);
+
+    /**
+     * Returns an <code>Iterator</code> over all the <code>SOAPHeaderElement</code> objects
+     * in this <code>SOAPHeader</code> object
+     * that have the specified <i>actor</i>.
+     *
+     * An <i>actor</i> is a global attribute that indicates the intermediate
+     * parties that should process a message before it reaches its ultimate
+     * receiver. An actor receives the message and processes it before sending
+     * it on to the next actor. The default actor is the ultimate intended
+     * recipient for the message, so if no actor attribute is included in a
+     * <code>SOAPHeader</code> object, it is sent to the ultimate receiver
+     * along with the message body.
+     * <p>
+     * In SOAP 1.2 the <i>env:actor</i> attribute is replaced by the <i>env:role</i>
+     * attribute, but with essentially the same semantics.
+     *
+     * @param actor a <code>String</code> giving the URI of the <code>actor</code> / <code>role</code>
+     *        for which to search
+     * @return an <code>Iterator</code> object over all the
+     *         <code>SOAPHeaderElement</code> objects that contain the specified
+     *          <code>actor</code> / <code>role</code>
+     * @see #extractHeaderElements
+     * @see SOAPConstants#URI_SOAP_ACTOR_NEXT
+     */
+    public Iterator examineHeaderElements(String actor);
+
+    /**
+     * Returns an <code>Iterator</code> over all the <code>SOAPHeaderElement</code> objects
+     * in this <code>SOAPHeader</code> object
+     * that have the specified <i>actor</i> and detaches them
+     * from this <code>SOAPHeader</code> object.
+     * <P>
+     * This method allows an actor to process the parts of the
+     * <code>SOAPHeader</code> object that apply to it and to remove
+     * them before passing the message on to the next actor.
+     * <p>
+     * In SOAP 1.2 the <i>env:actor</i> attribute is replaced by the <i>env:role</i>
+     * attribute, but with essentially the same semantics.
+     *
+     * @param actor a <code>String</code> giving the URI of the <code>actor</code> / <code>role</code>
+     *        for which to search
+     * @return an <code>Iterator</code> object over all the
+     *         <code>SOAPHeaderElement</code> objects that contain the specified
+     *          <code>actor</code> / <code>role</code>
+     *
+     * @see #examineHeaderElements
+     * @see SOAPConstants#URI_SOAP_ACTOR_NEXT
+     */
+    public Iterator extractHeaderElements(String actor);
+
+    /**
+     * Creates a new NotUnderstood <code>SOAPHeaderElement</code> object initialized
+     * with the specified name and adds it to this <code>SOAPHeader</code> object.
+     * This operation is supported only by SOAP 1.2.
+     *
+     * @param name a <code>QName</code> object with the name of the
+     *        <code>SOAPHeaderElement</code> object that was not understood.
+     * @return the new <code>SOAPHeaderElement</code> object that was
+     *          inserted into this <code>SOAPHeader</code> object
+     * @exception SOAPException if a SOAP error occurs.
+     * @exception UnsupportedOperationException if this is a SOAP 1.1 Header.
+     * @since SAAJ 1.3
+     */
+    public SOAPHeaderElement addNotUnderstoodHeaderElement(QName name)
+        throws SOAPException;
+
+    /**
+     * Creates a new Upgrade <code>SOAPHeaderElement</code> object initialized
+     * with the specified List of supported SOAP URIs and adds it to this
+     * <code>SOAPHeader</code> object.
+     * This operation is supported on both SOAP 1.1 and SOAP 1.2 header.
+     *
+     * @param supportedSOAPURIs an <code>Iterator</code> object with the URIs of SOAP
+     *          versions supported.
+     * @return the new <code>SOAPHeaderElement</code> object that was
+     *          inserted into this <code>SOAPHeader</code> object
+     * @exception SOAPException if a SOAP error occurs.
+     * @since SAAJ 1.3
+     */
+    public SOAPHeaderElement addUpgradeHeaderElement(Iterator supportedSOAPURIs)
+        throws SOAPException;
+
+    /**
+     * Creates a new Upgrade <code>SOAPHeaderElement</code> object initialized
+     * with the specified array of supported SOAP URIs and adds it to this
+     * <code>SOAPHeader</code> object.
+     * This operation is supported on both SOAP 1.1 and SOAP 1.2 header.
+     *
+     * @param  supportedSoapUris an array of the URIs of SOAP versions supported.
+     * @return the new <code>SOAPHeaderElement</code> object that was
+     *          inserted into this <code>SOAPHeader</code> object
+     * @exception SOAPException if a SOAP error occurs.
+     * @since SAAJ 1.3
+     */
+    public SOAPHeaderElement addUpgradeHeaderElement(String[] supportedSoapUris)
+        throws SOAPException;
+
+    /**
+     * Creates a new Upgrade <code>SOAPHeaderElement</code> object initialized
+     * with the specified supported SOAP URI and adds it to this
+     * <code>SOAPHeader</code> object.
+     * This operation is supported on both SOAP 1.1 and SOAP 1.2 header.
+     *
+     * @param supportedSoapUri the URI of SOAP the version that is supported.
+     * @return the new <code>SOAPHeaderElement</code> object that was
+     *          inserted into this <code>SOAPHeader</code> object
+     * @exception SOAPException if a SOAP error occurs.
+     * @since SAAJ 1.3
+     */
+    public SOAPHeaderElement addUpgradeHeaderElement(String supportedSoapUri)
+        throws SOAPException;
+
+    /**
+     * Returns an <code>Iterator</code> over all the <code>SOAPHeaderElement</code> objects
+     * in this <code>SOAPHeader</code> object.
+     *
+     * @return an <code>Iterator</code> object over all the
+     *          <code>SOAPHeaderElement</code> objects contained by this
+     *          <code>SOAPHeader</code>
+     * @see #extractAllHeaderElements
+     *
+     * @since SAAJ 1.2
+     */
+    public Iterator examineAllHeaderElements();
+
+    /**
+     * Returns an <code>Iterator</code> over all the <code>SOAPHeaderElement</code> objects
+     * in this <code>SOAPHeader</code> object and detaches them
+     * from this <code>SOAPHeader</code> object.
+     *
+     * @return an <code>Iterator</code> object over all the
+     *          <code>SOAPHeaderElement</code> objects contained by this
+     *          <code>SOAPHeader</code>
+     *
+     * @see #examineAllHeaderElements
+     *
+     * @since SAAJ 1.2
+     */
+    public Iterator extractAllHeaderElements();
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPHeaderElement.java b/jaxws/src/share/classes/javax/xml/soap/SOAPHeaderElement.java
new file mode 100644
index 0000000..cd3623b
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPHeaderElement.java
@@ -0,0 +1,171 @@
+/*
+ * $Id: SOAPHeaderElement.java,v 1.5.2.11 2005/02/09 07:39:03 vj135062 Exp $
+ * $Revision: 1.5.2.11 $
+ * $Date: 2005/02/09 07:39:03 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * An object representing the contents in the SOAP header part of the
+ * SOAP envelope.
+ * The immediate children of a <code>SOAPHeader</code> object can
+ * be represented only as <code>SOAPHeaderElement</code> objects.
+ * <P>
+ * A <code>SOAPHeaderElement</code> object can have other
+ * <code>SOAPElement</code> objects as its children.
+ */
+public interface SOAPHeaderElement extends SOAPElement {
+
+    /**
+     * Sets the actor associated with this <code>SOAPHeaderElement</code>
+     * object to the specified actor. The default value of an actor is:
+     *          <code>SOAPConstants.URI_SOAP_ACTOR_NEXT</code>
+     * <P>
+     * If this <code>SOAPHeaderElement</code> supports SOAP 1.2 then this call is
+     * equivalent to {@link #setRole(String)}
+     *
+     * @param  actorURI a <code>String</code> giving the URI of the actor
+     *           to set
+     *
+     * @exception IllegalArgumentException if there is a problem in
+     * setting the actor.
+     *
+     * @see #getActor
+     */
+    public void setActor(String actorURI);
+
+    /**
+     * Sets the <code>Role</code> associated with this <code>SOAPHeaderElement</code>
+     * object to the specified <code>Role</code>.
+     *
+     * @param uri - the URI of the <code>Role</code>
+     *
+     * @throws SOAPException if there is an error in setting the role
+     *
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Role.
+     *
+     * @since SAAJ 1.3
+     */
+    public void setRole(String uri) throws SOAPException;
+
+    /**
+     * Returns the uri of the <i>actor</i> attribute of this
+     * <code>SOAPHeaderElement</code>.
+     *<P>
+     * If this <code>SOAPHeaderElement</code> supports SOAP 1.2 then this call is
+     * equivalent to {@link #getRole()}
+     * @return  a <code>String</code> giving the URI of the actor
+     * @see #setActor
+     */
+    public String getActor();
+
+    /**
+     * Returns the value of the <i>Role</i> attribute of this
+     * <code>SOAPHeaderElement</code>.
+     *
+     * @return a <code>String</code> giving the URI of the <code>Role</code>
+     *
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Fault Role.
+     *
+     * @since SAAJ 1.3
+     */
+    public String getRole();
+
+    /**
+     * Sets the mustUnderstand attribute for this <code>SOAPHeaderElement</code>
+     * object to be either true or false.
+     * <P>
+     * If the mustUnderstand attribute is on, the actor who receives the
+     * <code>SOAPHeaderElement</code> must process it correctly. This
+     * ensures, for example, that if the <code>SOAPHeaderElement</code>
+     * object modifies the message, that the message is being modified correctly.
+     *
+     * @param mustUnderstand <code>true</code> to set the mustUnderstand
+     *        attribute to true; <code>false</code> to set it to false
+     *
+     * @exception IllegalArgumentException if there is a problem in
+     * setting the mustUnderstand attribute
+     * @see #getMustUnderstand
+     * @see #setRelay
+     */
+    public void setMustUnderstand(boolean mustUnderstand);
+
+    /**
+     * Returns the boolean value of the mustUnderstand attribute for this
+     * <code>SOAPHeaderElement</code>.
+     *
+     * @return <code>true</code> if the mustUnderstand attribute of this
+     *        <code>SOAPHeaderElement</code> object is turned on; <code>false</code>
+     *         otherwise
+     */
+    public boolean getMustUnderstand();
+
+    /**
+     * Sets the <i>relay</i> attribute for this <code>SOAPHeaderElement</code> to be
+     * either true or false.
+     * <P>
+     * The SOAP relay attribute is set to true to indicate that the SOAP header
+     * block must be relayed by any node that is targeted by the header block
+     * but not actually process it. This attribute is ignored on header blocks
+     * whose mustUnderstand attribute is set to true or that are targeted at
+     * the ultimate reciever (which is the default). The default value of this
+     * attribute is <code>false</code>.
+     *
+     * @param relay the new value of the <i>relay</i> attribute
+     *
+     * @exception SOAPException if there is a problem in setting the
+     * relay attribute.
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Relay attribute.
+     *
+     * @see #setMustUnderstand
+     * @see #getRelay
+     *
+     * @since SAAJ 1.3
+     */
+    public void setRelay(boolean relay) throws SOAPException;
+
+    /**
+     * Returns the boolean value of the <i>relay</i> attribute for this
+     * <code>SOAPHeaderElement</code>
+     *
+     * @return <code>true</code> if the relay attribute is turned on;
+     * <code>false</code> otherwise
+     *
+     * @exception UnsupportedOperationException if this message does not
+     *      support the SOAP 1.2 concept of Relay attribute.
+     *
+     * @see #getMustUnderstand
+     * @see #setRelay
+     *
+     * @since SAAJ 1.3
+     */
+    public boolean getRelay();
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPMessage.java b/jaxws/src/share/classes/javax/xml/soap/SOAPMessage.java
new file mode 100644
index 0000000..6bc99a7
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPMessage.java
@@ -0,0 +1,461 @@
+/*
+ * $Id: SOAPMessage.java,v 1.21 2005/06/21 17:49:12 mk125090 Exp $
+ * $Revision: 1.21 $
+ * $Date: 2005/06/21 17:49:12 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+import java.io.OutputStream;
+import java.io.IOException;
+
+import java.util.Iterator;
+
+import javax.activation.DataHandler;
+
+/**
+ * The root class for all SOAP messages. As transmitted on the "wire", a SOAP
+ * message is an XML document or a MIME message whose first body part is an
+ * XML/SOAP document.
+ * <P>
+ * A <code>SOAPMessage</code> object consists of a SOAP part and optionally
+ * one or more attachment parts. The SOAP part for a <code>SOAPMessage</code>
+ * object is a <code>SOAPPart</code> object, which contains information used
+ * for message routing and identification, and which can contain
+ * application-specific content. All data in the SOAP Part of a message must be
+ * in XML format.
+ * <P>
+ * A new <code>SOAPMessage</code> object contains the following by default:
+ * <UL>
+ *   <LI>A <code>SOAPPart</code> object
+ *   <LI>A <code>SOAPEnvelope</code> object
+ *   <LI>A <code>SOAPBody</code> object
+ *   <LI>A <code>SOAPHeader</code> object
+ * </UL>
+ * The SOAP part of a message can be retrieved by calling the method <code>SOAPMessage.getSOAPPart()</code>.
+ * The <code>SOAPEnvelope</code> object is retrieved from the <code>SOAPPart</code>
+ * object, and the <code>SOAPEnvelope</code> object is used to retrieve the
+ * <code>SOAPBody</code> and <code>SOAPHeader</code> objects.
+ *
+ * <PRE>
+ *     SOAPPart sp = message.getSOAPPart();
+ *     SOAPEnvelope se = sp.getEnvelope();
+ *     SOAPBody sb = se.getBody();
+ *     SOAPHeader sh = se.getHeader();
+ * </PRE>
+ *
+ * <P>
+ * In addition to the mandatory <code>SOAPPart</code> object, a <code>SOAPMessage</code>
+ * object may contain zero or more <code>AttachmentPart</code> objects, each
+ * of which contains application-specific data. The <code>SOAPMessage</code>
+ * interface provides methods for creating <code>AttachmentPart</code>
+ * objects and also for adding them to a <code>SOAPMessage</code> object. A
+ * party that has received a <code>SOAPMessage</code> object can examine its
+ * contents by retrieving individual attachment parts.
+ * <P>
+ * Unlike the rest of a SOAP message, an attachment is not required to be in
+ * XML format and can therefore be anything from simple text to an image file.
+ * Consequently, any message content that is not in XML format must be in an
+ * <code>AttachmentPart</code> object.
+ * <P>
+ * A <code>MessageFactory</code> object may create <code>SOAPMessage</code>
+ * objects with behavior that is specialized to a particular implementation or
+ * application of SAAJ. For instance, a <code>MessageFactory</code> object
+ * may produce <code>SOAPMessage</code> objects that conform to a particular
+ * Profile such as ebXML. In this case a <code>MessageFactory</code> object
+ * might produce <code>SOAPMessage</code> objects that are initialized with
+ * ebXML headers.
+ * <P>
+ * In order to ensure backward source compatibility, methods that are added to
+ * this class after version 1.1 of the SAAJ specification are all concrete
+ * instead of abstract and they all have default implementations. Unless
+ * otherwise noted in the JavaDocs for those methods the default
+ * implementations simply throw an <code>UnsupportedOperationException</code>
+ * and the SAAJ implementation code must override them with methods that
+ * provide the specified behavior. Legacy client code does not have this
+ * restriction, however, so long as there is no claim made that it conforms to
+ * some later version of the specification than it was originally written for.
+ * A legacy class that extends the SOAPMessage class can be compiled and/or run
+ * against succeeding versions of the SAAJ API without modification. If such a
+ * class was correctly implemented then it will continue to behave correctly
+ * relative to the version of the specification against which it was written.
+ *
+ * @see MessageFactory
+ * @see AttachmentPart
+ */
+public abstract class SOAPMessage {
+    /**
+         * Specifies the character type encoding for the SOAP Message. Valid values
+         * include "utf-8" and "utf-16". See vendor documentation for additional
+         * supported values. The default is "utf-8".
+         *
+         * @see SOAPMessage#setProperty(String, Object) SOAPMessage.setProperty
+         * @since SAAJ 1.2
+         */
+    public static final String CHARACTER_SET_ENCODING =
+        "javax.xml.soap.character-set-encoding";
+
+    /**
+     * Specifies whether the SOAP Message will contain an XML declaration when
+     * it is sent. The only valid values are "true" and "false". The default is
+     * "false".
+     *
+     * @see SOAPMessage#setProperty(String, Object) SOAPMessage.setProperty
+     * @since SAAJ 1.2
+     */
+    public static final String WRITE_XML_DECLARATION =
+        "javax.xml.soap.write-xml-declaration";
+
+    /**
+     * Sets the description of this <code>SOAPMessage</code> object's
+     * content with the given description.
+     *
+     * @param description a <code>String</code> describing the content of this
+     *         message
+     * @see #getContentDescription
+     */
+    public abstract void setContentDescription(String description);
+
+    /**
+     * Retrieves a description of this <code>SOAPMessage</code> object's
+     * content.
+     *
+     * @return a <code>String</code> describing the content of this
+     *         message or <code>null</code> if no description has been set
+     * @see #setContentDescription
+     */
+    public abstract String getContentDescription();
+
+    /**
+         * Gets the SOAP part of this <code>SOAPMessage</code> object.
+         * <P>
+         * <code>SOAPMessage</code> object contains one or more attachments, the
+         * SOAP Part must be the first MIME body part in the message.
+         *
+         * @return the <code>SOAPPart</code> object for this <code>SOAPMessage</code>
+         *         object
+         */
+    public abstract SOAPPart getSOAPPart();
+
+    /**
+         * Gets the SOAP Body contained in this <code>SOAPMessage</code> object.
+         * <p>
+         *
+         * @return the <code>SOAPBody</code> object contained by this <code>SOAPMessage</code>
+         *         object
+         * @exception SOAPException
+         *               if the SOAP Body does not exist or cannot be retrieved
+         * @since SAAJ 1.2
+         */
+    public SOAPBody getSOAPBody() throws SOAPException {
+        throw new UnsupportedOperationException("getSOAPBody must be overridden by all subclasses of SOAPMessage");
+    }
+
+    /**
+         * Gets the SOAP Header contained in this <code>SOAPMessage</code>
+         * object.
+         * <p>
+         *
+         * @return the <code>SOAPHeader</code> object contained by this <code>SOAPMessage</code>
+         *         object
+         * @exception SOAPException
+         *               if the SOAP Header does not exist or cannot be retrieved
+         * @since SAAJ 1.2
+         */
+    public SOAPHeader getSOAPHeader() throws SOAPException {
+        throw new UnsupportedOperationException("getSOAPHeader must be overridden by all subclasses of SOAPMessage");
+    }
+
+    /**
+         * Removes all <code>AttachmentPart</code> objects that have been added
+         * to this <code>SOAPMessage</code> object.
+         * <P>
+         * This method does not touch the SOAP part.
+         */
+    public abstract void removeAllAttachments();
+
+    /**
+         * Gets a count of the number of attachments in this message. This count
+         * does not include the SOAP part.
+         *
+         * @return the number of <code>AttachmentPart</code> objects that are
+         *         part of this <code>SOAPMessage</code> object
+         */
+    public abstract int countAttachments();
+
+    /**
+         * Retrieves all the <code>AttachmentPart</code> objects that are part of
+         * this <code>SOAPMessage</code> object.
+         *
+         * @return an iterator over all the attachments in this message
+         */
+    public abstract Iterator getAttachments();
+
+    /**
+         * Retrieves all the <code>AttachmentPart</code> objects that have header
+         * entries that match the specified headers. Note that a returned
+         * attachment could have headers in addition to those specified.
+         *
+         * @param headers
+         *           a <code>MimeHeaders</code> object containing the MIME
+         *           headers for which to search
+         * @return an iterator over all attachments that have a header that matches
+         *         one of the given headers
+         */
+    public abstract Iterator getAttachments(MimeHeaders headers);
+
+    /**
+     * Removes all the <code>AttachmentPart</code> objects that have header
+     * entries that match the specified headers. Note that the removed
+     * attachment could have headers in addition to those specified.
+     *
+     * @param headers
+     *           a <code>MimeHeaders</code> object containing the MIME
+     *           headers for which to search
+     * @since SAAJ 1.3
+     */
+    public abstract void removeAttachments(MimeHeaders headers);
+
+
+    /**
+     * Returns an <code>AttachmentPart</code> object that is associated with an
+     * attachment that is referenced by this <code>SOAPElement</code> or
+     * <code>null</code> if no such attachment exists. References can be made
+     * via an <code>href</code> attribute as described in
+     * {@link <a href="http://www.w3.org/TR/SOAP-attachments#SOAPReferenceToAttachements">SOAP Messages with Attachments</a>},
+     * or via a single <code>Text</code> child node containing a URI as
+     * described in the WS-I Attachments Profile 1.0 for elements of schema
+     * type <i>ref:swaRef</i>({@link <a href=http://www.ws-i.org/Profiles/AttachmentsProfile-1.0-2004-08-24.html">ref:swaRef</a>}).  These two mechanisms must be supported.
+     * The support for references via <code>href</code> attribute also implies that
+     * this method should also be supported on an element that is an
+     * <i>xop:Include</i> element (
+     * {@link <a  href="http://www.w3.org/2000/xp/Group/3/06/Attachments/XOP.html">XOP</a>}).
+     * other reference mechanisms may be supported by individual
+     * implementations of this standard. Contact your vendor for details.
+     *
+     * @param  element The <code>SOAPElement</code> containing the reference to an Attachment
+     * @return the referenced <code>AttachmentPart</code> or null if no such
+     *          <code>AttachmentPart</code> exists or no reference can be
+     *          found in this <code>SOAPElement</code>.
+     * @throws SOAPException if there is an error in the attempt to access the
+     *          attachment
+     *
+     * @since SAAJ 1.3
+     */
+    public abstract AttachmentPart getAttachment(SOAPElement element) throws SOAPException;
+
+
+    /**
+     * Adds the given <code>AttachmentPart</code> object to this <code>SOAPMessage</code>
+     * object. An <code>AttachmentPart</code> object must be created before
+     * it can be added to a message.
+     *
+     * @param AttachmentPart
+     *           an <code>AttachmentPart</code> object that is to become part
+     *           of this <code>SOAPMessage</code> object
+     * @exception IllegalArgumentException
+     */
+    public abstract void addAttachmentPart(AttachmentPart AttachmentPart);
+
+    /**
+     * Creates a new empty <code>AttachmentPart</code> object. Note that the
+     * method <code>addAttachmentPart</code> must be called with this new
+     * <code>AttachmentPart</code> object as the parameter in order for it to
+     * become an attachment to this <code>SOAPMessage</code> object.
+     *
+     * @return a new <code>AttachmentPart</code> object that can be populated
+     *         and added to this <code>SOAPMessage</code> object
+     */
+    public abstract AttachmentPart createAttachmentPart();
+
+    /**
+     * Creates an <code>AttachmentPart</code> object and populates it using
+     * the given <code>DataHandler</code> object.
+     *
+     * @param dataHandler
+     *           the <code>javax.activation.DataHandler</code> object that
+     *           will generate the content for this <code>SOAPMessage</code>
+     *           object
+     * @return a new <code>AttachmentPart</code> object that contains data
+     *         generated by the given <code>DataHandler</code> object
+     * @exception IllegalArgumentException
+     *               if there was a problem with the specified <code>DataHandler</code>
+     *               object
+     * @see javax.activation.DataHandler
+     * @see javax.activation.DataContentHandler
+     */
+    public AttachmentPart createAttachmentPart(DataHandler dataHandler) {
+        AttachmentPart attachment = createAttachmentPart();
+        attachment.setDataHandler(dataHandler);
+        return attachment;
+    }
+
+    /**
+     * Returns all the transport-specific MIME headers for this <code>SOAPMessage</code>
+     * object in a transport-independent fashion.
+     *
+     * @return a <code>MimeHeaders</code> object containing the <code>MimeHeader</code>
+     *         objects
+     */
+    public abstract MimeHeaders getMimeHeaders();
+
+    /**
+     * Creates an <code>AttachmentPart</code> object and populates it with
+     * the specified data of the specified content type. The type of the
+     * <code>Object</code> should correspond to the value given for the
+     * <code>Content-Type</code>.
+     *
+     * @param content
+     *           an <code>Object</code> containing the content for the
+     *           <code>AttachmentPart</code> object to be created
+     * @param contentType
+     *           a <code>String</code> object giving the type of content;
+     *           examples are "text/xml", "text/plain", and "image/jpeg"
+     * @return a new <code>AttachmentPart</code> object that contains the
+     *         given data
+     * @exception IllegalArgumentException
+     *               may be thrown if the contentType does not match the type
+     *               of the content object, or if there was no
+     *               <code>DataContentHandler</code> object for the given
+     *               content object
+     * @see javax.activation.DataHandler
+     * @see javax.activation.DataContentHandler
+     */
+    public AttachmentPart createAttachmentPart(
+        Object content,
+        String contentType) {
+        AttachmentPart attachment = createAttachmentPart();
+        attachment.setContent(content, contentType);
+        return attachment;
+    }
+
+    /**
+     * Updates this <code>SOAPMessage</code> object with all the changes that
+     * have been made to it. This method is called automatically when
+     * {@link SOAPMessage#writeTo(OutputStream)} is  called. However, if
+     * changes are made to a message that was received or to one that has
+     * already been sent, the method <code>saveChanges</code> needs to be
+     * called explicitly in order to save the changes. The method <code>saveChanges</code>
+     * also generates any changes that can be read back (for example, a
+     * MessageId in profiles that support a message id). All MIME headers in a
+     * message that is created for sending purposes are guaranteed to have
+     * valid values only after <code>saveChanges</code> has been called.
+     * <P>
+     * In addition, this method marks the point at which the data from all
+     * constituent <code>AttachmentPart</code> objects are pulled into the
+     * message.
+     * <P>
+     *
+     * @exception <code>SOAPException</code> if there was a problem saving
+     *               changes to this message.
+     */
+    public abstract void saveChanges() throws SOAPException;
+
+    /**
+     * Indicates whether this <code>SOAPMessage</code> object needs to have
+     * the method <code>saveChanges</code> called on it.
+     *
+     * @return <code>true</code> if <code>saveChanges</code> needs to be
+     *         called; <code>false</code> otherwise.
+     */
+    public abstract boolean saveRequired();
+
+    /**
+     * Writes this <code>SOAPMessage</code> object to the given output
+     * stream. The externalization format is as defined by the SOAP 1.1 with
+     * Attachments specification.
+     * <P>
+     * If there are no attachments, just an XML stream is written out. For
+     * those messages that have attachments, <code>writeTo</code> writes a
+     * MIME-encoded byte stream.
+     * <P>
+     * Note that this method does not write the transport-specific MIME Headers
+     * of the Message
+     *
+     * @param out
+     *           the <code>OutputStream</code> object to which this <code>SOAPMessage</code>
+     *           object will be written
+     * @exception IOException
+     *               if an I/O error occurs
+     * @exception SOAPException
+     *               if there was a problem in externalizing this SOAP message
+     */
+    public abstract void writeTo(OutputStream out)
+        throws SOAPException, IOException;
+
+    /**
+     * Associates the specified value with the specified property. If there was
+     * already a value associated with this property, the old value is
+     * replaced.
+     * <p>
+     * The valid property names include
+     * {@link SOAPMessage#WRITE_XML_DECLARATION}  and
+     * {@link SOAPMessage#CHARACTER_SET_ENCODING}. All of these standard SAAJ
+     * properties are prefixed by "javax.xml.soap". Vendors may also add
+     * implementation specific properties. These properties must be prefixed
+     * with package names that are unique to the vendor.
+     * <p>
+     * Setting the property <code>WRITE_XML_DECLARATION</code> to <code>"true"</code>
+     * will cause an XML Declaration to be written out at the start of the SOAP
+     * message. The default value of "false" suppresses this declaration.
+     * <p>
+     * The property <code>CHARACTER_SET_ENCODING</code> defaults to the value
+     * <code>"utf-8"</code> which causes the SOAP message to be encoded using
+     * UTF-8. Setting <code>CHARACTER_SET_ENCODING</code> to <code>"utf-16"</code>
+     * causes the SOAP message to be encoded using UTF-16.
+     * <p>
+     * Some implementations may allow encodings in addition to UTF-8 and
+     * UTF-16. Refer to your vendor's documentation for details.
+     *
+     * @param property
+     *           the property with which the specified value is to be
+     *           associated.
+     * @param value
+     *           the value to be associated with the specified property
+     * @exception SOAPException
+     *               if the property name is not recognized.
+     * @since SAAJ 1.2
+     */
+    public void setProperty(String property, Object value)
+        throws SOAPException {
+            throw new UnsupportedOperationException("setProperty must be overridden by all subclasses of SOAPMessage");
+    }
+
+    /**
+     * Retrieves value of the specified property.
+     *
+     * @param property
+     *           the name of the property to retrieve
+     * @return the value associated with the named property or <code>null</code>
+     *         if no such property exists.
+     * @exception SOAPException
+     *               if the property name is not recognized.
+     * @since SAAJ 1.2
+     */
+    public Object getProperty(String property) throws SOAPException {
+        throw new UnsupportedOperationException("getProperty must be overridden by all subclasses of SOAPMessage");
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/SOAPPart.java b/jaxws/src/share/classes/javax/xml/soap/SOAPPart.java
new file mode 100644
index 0000000..26193de
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/SOAPPart.java
@@ -0,0 +1,270 @@
+/*
+ * $Id: SOAPPart.java,v 1.8 2005/06/20 12:07:05 vj135062 Exp $
+ * $Revision: 1.8 $
+ * $Date: 2005/06/20 12:07:05 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+import java.util.Iterator;
+
+import javax.xml.transform.Source;
+
+/**
+ * The container for the SOAP-specific portion of a <code>SOAPMessage</code>
+ * object. All messages are required to have a SOAP part, so when a
+ * <code>SOAPMessage</code> object is created, it will automatically
+ * have a <code>SOAPPart</code> object.
+ *<P>
+ * A <code>SOAPPart</code> object is a MIME part and has the MIME headers
+ * Content-Id, Content-Location, and Content-Type.  Because the value of
+ * Content-Type must be "text/xml", a <code>SOAPPart</code> object automatically
+ * has a MIME header of Content-Type with its value set to "text/xml".
+ * The value must be "text/xml" because content in the SOAP part of a
+ * message must be in XML format.  Content that is not of type "text/xml"
+ * must be in an <code>AttachmentPart</code> object rather than in the
+ * <code>SOAPPart</code> object.
+ * <P>
+ * When a message is sent, its SOAP part must have the MIME header Content-Type
+ * set to "text/xml". Or, from the other perspective, the SOAP part of any
+ * message that is received must have the MIME header Content-Type with a
+ * value of "text/xml".
+ * <P>
+ * A client can access the <code>SOAPPart</code> object of a
+ * <code>SOAPMessage</code> object by
+ * calling the method <code>SOAPMessage.getSOAPPart</code>. The
+ * following  line of code, in which <code>message</code> is a
+ * <code>SOAPMessage</code> object, retrieves the SOAP part of a message.
+ * <PRE>
+ *   SOAPPart soapPart = message.getSOAPPart();
+ * </PRE>
+ * <P>
+ * A <code>SOAPPart</code> object contains a <code>SOAPEnvelope</code> object,
+ * which in turn contains a <code>SOAPBody</code> object and a
+ * <code>SOAPHeader</code> object.
+ * The <code>SOAPPart</code> method <code>getEnvelope</code> can be used
+ * to retrieve the <code>SOAPEnvelope</code> object.
+ * <P>
+ */
+public abstract class SOAPPart implements org.w3c.dom.Document, Node {
+
+    /**
+     * Gets the <code>SOAPEnvelope</code> object associated with this
+     * <code>SOAPPart</code> object. Once the SOAP envelope is obtained, it
+     * can be used to get its contents.
+     *
+     * @return the <code>SOAPEnvelope</code> object for this
+     *           <code>SOAPPart</code> object
+     * @exception SOAPException if there is a SOAP error
+     */
+    public abstract SOAPEnvelope getEnvelope() throws SOAPException;
+
+    /**
+     * Retrieves the value of the MIME header whose name is "Content-Id".
+     *
+     * @return a <code>String</code> giving the value of the MIME header
+     *         named "Content-Id"
+     * @see #setContentId
+     */
+    public String getContentId() {
+        String[] values = getMimeHeader("Content-Id");
+        if (values != null && values.length > 0)
+            return values[0];
+        return null;
+    }
+
+    /**
+     * Retrieves the value of the MIME header whose name is "Content-Location".
+     *
+     * @return a <code>String</code> giving the value of the MIME header whose
+     *          name is "Content-Location"
+     * @see #setContentLocation
+     */
+    public String getContentLocation() {
+        String[] values = getMimeHeader("Content-Location");
+        if (values != null && values.length > 0)
+            return values[0];
+        return null;
+    }
+
+    /**
+     * Sets the value of the MIME header named "Content-Id"
+     * to the given <code>String</code>.
+     *
+     * @param contentId a <code>String</code> giving the value of the MIME
+     *        header "Content-Id"
+     *
+     * @exception IllegalArgumentException if there is a problem in
+     * setting the content id
+     * @see #getContentId
+     */
+    public void setContentId(String contentId)
+    {
+        setMimeHeader("Content-Id", contentId);
+    }
+    /**
+     * Sets the value of the MIME header "Content-Location"
+     * to the given <code>String</code>.
+     *
+     * @param contentLocation a <code>String</code> giving the value
+     *        of the MIME
+     *        header "Content-Location"
+     * @exception IllegalArgumentException if there is a problem in
+     *            setting the content location.
+     * @see #getContentLocation
+     */
+    public void setContentLocation(String contentLocation)
+    {
+        setMimeHeader("Content-Location", contentLocation);
+    }
+    /**
+     * Removes all MIME headers that match the given name.
+     *
+     * @param header a <code>String</code> giving the name of the MIME header(s) to
+     *               be removed
+     */
+    public abstract void removeMimeHeader(String header);
+
+    /**
+     * Removes all the <code>MimeHeader</code> objects for this
+     * <code>SOAPEnvelope</code> object.
+     */
+    public abstract void removeAllMimeHeaders();
+
+    /**
+     * Gets all the values of the <code>MimeHeader</code> object
+     * in this <code>SOAPPart</code> object that
+     * is identified by the given <code>String</code>.
+     *
+     * @param name the name of the header; example: "Content-Type"
+     * @return a <code>String</code> array giving all the values for the
+     *         specified header
+     * @see #setMimeHeader
+     */
+    public abstract String[] getMimeHeader(String name);
+
+    /**
+     * Changes the first header entry that matches the given header name
+     * so that its value is the given value, adding a new header with the
+     * given name and value if no
+     * existing header is a match. If there is a match, this method clears
+     * all existing values for the first header that matches and sets the
+     * given value instead. If more than one header has
+     * the given name, this method removes all of the matching headers after
+     * the first one.
+     * <P>
+     * Note that RFC822 headers can contain only US-ASCII characters.
+     *
+     * @param   name    a <code>String</code> giving the header name
+     *                  for which to search
+     * @param   value   a <code>String</code> giving the value to be set.
+     *                  This value will be substituted for the current value(s)
+     *                  of the first header that is a match if there is one.
+     *                  If there is no match, this value will be the value for
+     *                  a new <code>MimeHeader</code> object.
+     *
+     * @exception IllegalArgumentException if there was a problem with
+     *            the specified mime header name or value
+     * @see #getMimeHeader
+     */
+    public abstract void setMimeHeader(String name, String value);
+
+    /**
+     * Creates a <code>MimeHeader</code> object with the specified
+     * name and value and adds it to this <code>SOAPPart</code> object.
+     * If a <code>MimeHeader</code> with the specified name already
+     * exists, this method adds the specified value to the already
+     * existing value(s).
+     * <P>
+     * Note that RFC822 headers can contain only US-ASCII characters.
+     *
+     * @param   name    a <code>String</code> giving the header name
+     * @param   value   a <code>String</code> giving the value to be set
+     *                  or added
+     * @exception IllegalArgumentException if there was a problem with
+     *            the specified mime header name or value
+     */
+    public abstract void addMimeHeader(String name, String value);
+
+    /**
+     * Retrieves all the headers for this <code>SOAPPart</code> object
+     * as an iterator over the <code>MimeHeader</code> objects.
+     *
+     * @return  an <code>Iterator</code> object with all of the Mime
+     *          headers for this <code>SOAPPart</code> object
+     */
+    public abstract Iterator getAllMimeHeaders();
+
+    /**
+     * Retrieves all <code>MimeHeader</code> objects that match a name in
+     * the given array.
+     *
+     * @param names a <code>String</code> array with the name(s) of the
+     *        MIME headers to be returned
+     * @return  all of the MIME headers that match one of the names in the
+     *           given array, returned as an <code>Iterator</code> object
+     */
+    public abstract Iterator getMatchingMimeHeaders(String[] names);
+
+    /**
+     * Retrieves all <code>MimeHeader</code> objects whose name does
+     * not match a name in the given array.
+     *
+     * @param names a <code>String</code> array with the name(s) of the
+     *        MIME headers not to be returned
+     * @return  all of the MIME headers in this <code>SOAPPart</code> object
+     *          except those that match one of the names in the
+     *           given array.  The nonmatching MIME headers are returned as an
+     *           <code>Iterator</code> object.
+     */
+    public abstract Iterator getNonMatchingMimeHeaders(String[] names);
+
+    /**
+     * Sets the content of the <code>SOAPEnvelope</code> object with the data
+     * from the given <code>Source</code> object. This <code>Source</code>
+     * must contain a valid SOAP document.
+     *
+     * @param source the <code>javax.xml.transform.Source</code> object with the
+     *        data to be set
+     *
+     * @exception SOAPException if there is a problem in setting the source
+     * @see #getContent
+     */
+    public abstract void setContent(Source source) throws SOAPException;
+
+    /**
+     * Returns the content of the SOAPEnvelope as a JAXP <code>Source</code>
+     * object.
+     *
+     * @return the content as a <code>javax.xml.transform.Source</code> object
+     *
+     * @exception SOAPException if the implementation cannot convert
+     *                          the specified <code>Source</code> object
+     * @see #setContent
+     */
+    public abstract Source getContent() throws SOAPException;
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/Text.java b/jaxws/src/share/classes/javax/xml/soap/Text.java
new file mode 100644
index 0000000..e7492b1
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/Text.java
@@ -0,0 +1,47 @@
+/*
+ * $Id: Text.java,v 1.2 2004/04/02 01:24:19 ofung Exp $
+ * $Revision: 1.2 $
+ * $Date: 2004/04/02 01:24:19 $
+ */
+
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+package javax.xml.soap;
+
+/**
+ * A representation of a node whose value is text.  A <code>Text</code> object
+ * may represent text that is content or text that is a comment.
+ *
+ */
+public interface Text extends Node, org.w3c.dom.Text {
+
+    /**
+     * Retrieves whether this <code>Text</code> object represents a comment.
+     *
+     * @return <code>true</code> if this <code>Text</code> object is a
+     *         comment; <code>false</code> otherwise
+     */
+    public boolean isComment();
+}
diff --git a/jaxws/src/share/classes/javax/xml/soap/package.html b/jaxws/src/share/classes/javax/xml/soap/package.html
new file mode 100644
index 0000000..9028815
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/soap/package.html
@@ -0,0 +1,91 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
+<html>
+<head>
+   <!--
+
+Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+
+This code is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License version 2 only, as
+published by the Free Software Foundation.  Sun designates this
+particular file as subject to the "Classpath" exception as provided
+by Sun in the LICENSE file that accompanied this code.
+
+This code is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+version 2 for more details (a copy is included in the LICENSE file that
+accompanied this code).
+
+You should have received a copy of the GNU General Public License version
+2 along with this work; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+CA 95054 USA or visit www.sun.com if you need additional information or
+have any questions.
+-->
+  <title></title>
+
+</head>
+   <body bgcolor="white">
+    Provides the API for creating and building SOAP messages. This package
+ is defined in the <i>SOAP with Attachments API for Java<sup><font
+ size="-2">TM</font></sup> (SAAJ) 1.3</i> specification.
+<p> The API in the <code>javax.xml.soap</code> package allows you to do the
+ following: </p>
+
+<ul>
+     <li>create a point-to-point connection to a specified endpoint   </li>
+    <li>create a SOAP message   </li>
+    <li>create an XML fragment   </li>
+    <li>add content to the header of a SOAP message   </li>
+    <li>add content to the body of a SOAP message   </li>
+    <li>create attachment parts and add content to them   </li>
+    <li>access/add/modify parts of a SOAP message   </li>
+    <li>create/add/modify SOAP fault information   </li>
+    <li>extract content from a SOAP message   </li>
+    <li>send a SOAP request-response message   </li>
+
+</ul>
+
+<p>   <!-- <h2>Package Specification</h2> -->  <!-- The SAAJ 1.1 specification gives an overview of the  -->
+ <!-- <code>javax.xml.soap</code> package and --> <!-- explains how its classes and interfaces work. -->
+ <!-- <ul> --> <!--   <li><a href="http://java.sun.com/xml/downloads/jaxm.html"> -->
+ <!-- 	SAAJ 1.1 Specification</a> --> <!-- </ul> -->  <!-- <h2>Related Documentation</h2> -->
+ <!-- 	For overviews, tutorials, examples, guides, and tool documentation, please see: -->
+ <!-- 	<ul> --> <!-- 	  <li><a href="../../../../tutorial/doc/JAXM.html">JAXM Tutorial</a> -->
+ <!-- 	  <li><a href="../../../../jaxm/index.html">JAXM Reference Implementation (RI) -->
+ <!-- 			  Documentation</a> --> <!-- 	</ul> -->  </p>
+In addition the APIs in the <code>javax.xml.soap</code> package extend
+their  counterparts in the <code>org.w3c.dom</code> package. This means that
+the  <code>SOAPPart</code> of a <code>SOAPMessage</code> is also a DOM Level
+2 <code>Document</code>, and can be manipulated as such by applications,
+tools and libraries that use DOM (see http://www.w3.org/DOM/ for more information).
+It is important to note that, while it is possible to use DOM APIs to add
+ordinary DOM nodes to a SAAJ tree, the SAAJ APIs are still required to return
+SAAJ types when examining or manipulating the tree. In order to accomplish
+this the SAAJ APIs (specifically {@link javax.xml.soap.SOAPElement#getChildElements()})
+are allowed to silently replace objects that are incorrectly typed relative
+to SAAJ requirements with equivalent objects of the required type. These
+replacements must never cause the logical structure of the tree to change,
+so from the perspective of the DOM APIs the tree will remain unchanged. However,
+the physical composition of the tree will have changed so that references
+to the nodes that were replaced will refer to nodes that are no longer a
+part of the tree. The SAAJ APIs are not allowed to make these replacements
+if they are not required so the replacement objects will never subsequently
+be silently replaced by future calls to the SAAJ API.
+<p>
+What this means in
+practical terms is that an application that starts to use SAAJ APIs on a
+tree after manipulating it using DOM APIs must assume that the tree has been
+translated into an all SAAJ tree and that any references to objects within
+the tree that were obtained using DOM APIs are no longer valid. Switching
+from SAAJ APIs to DOM APIs is not allowed to cause invalid references and
+neither is using SAAJ APIs exclusively. It is only switching from using DOM
+APIs on a particular SAAJ tree to using SAAJ APIs that causes the risk of
+invalid references.<br>
+
+</body>
+</html>
diff --git a/jaxws/src/share/classes/javax/xml/ws/AsyncHandler.java b/jaxws/src/share/classes/javax/xml/ws/AsyncHandler.java
new file mode 100644
index 0000000..b1ff3dc
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/AsyncHandler.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+/** The <code>AsyncHandler</code> interface is implemented by
+ * clients that wish to receive callback notification of the completion of
+ * service endpoint operations invoked asynchronously.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface AsyncHandler<T> {
+
+    /** Called when the response to an asynchronous operation is available.
+     *
+     * @param res The response to the operation invocation.
+     *
+    **/
+    void handleResponse(Response<T> res);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/Binding.java b/jaxws/src/share/classes/javax/xml/ws/Binding.java
new file mode 100644
index 0000000..0c998e9
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/Binding.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+/** The <code>Binding</code> interface is the base interface
+ *  for JAX-WS protocol bindings.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface Binding {
+
+  /** Gets a copy of the handler chain for a protocol binding instance.
+   *  If the returned chain is modified a call to <code>setHandlerChain</code>
+   * is required to configure the binding instance with the new chain.
+   *
+   *  @return java.util.List<javax.xml.ws.handler.HandlerInfo> Handler chain
+  **/
+  public java.util.List<javax.xml.ws.handler.Handler> getHandlerChain();
+
+  /** Sets the handler chain for the protocol binding instance.
+   *
+   *  @param chain    A List of handler configuration entries
+   *  @throws WebServiceException On an error in the configuration of
+   *                  the handler chain
+   *  @throws java.lang.UnsupportedOperationException If this
+   *          operation is not supported. This may be done to
+   *          avoid any overriding of a pre-configured handler
+   *          chain.
+  **/
+  public void setHandlerChain(java.util.List<javax.xml.ws.handler.Handler> chain);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/BindingProvider.java b/jaxws/src/share/classes/javax/xml/ws/BindingProvider.java
new file mode 100644
index 0000000..5d3557f
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/BindingProvider.java
@@ -0,0 +1,116 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.util.Map;
+
+/** The <code>BindingProvider</code> interface provides access to the
+ *  protocol binding and associated context objects for request and
+ *  response message processing.
+ *
+ *  @since JAX-WS 2.0
+ *
+ *  @see javax.xml.ws.Binding
+**/
+public interface BindingProvider {
+    /** Standard property: User name for authentication.
+     *  <p>Type: java.lang.String
+    **/
+    public static final String USERNAME_PROPERTY =
+                      "javax.xml.ws.security.auth.username";
+
+    /** Standard property: Password for authentication.
+     *  <p>Type: java.lang.String
+    **/
+    public static final String PASSWORD_PROPERTY =
+                      "javax.xml.ws.security.auth.password";
+
+    /** Standard property: Target service endpoint address. The
+     *  URI scheme for the endpoint address specification must
+     *  correspond to the protocol/transport binding for the
+     *  binding in use.
+     *  <p>Type: java.lang.String
+    **/
+    public static final String ENDPOINT_ADDRESS_PROPERTY =
+                      "javax.xml.ws.service.endpoint.address";
+
+    /** Standard property: This boolean property is used by a service
+     *  client to indicate whether or not it wants to participate in
+     *  a session with a service endpoint. If this property is set to
+     *  true, the service client indicates that it wants the session
+     *  to be maintained. If set to false, the session is not maintained.
+     *  The default value for this property is false.
+     *  <p>Type: java.lang.Boolean
+    **/
+    public static final String SESSION_MAINTAIN_PROPERTY =
+                      "javax.xml.ws.session.maintain";
+
+    /** Standard property for SOAPAction. This boolean property
+     *  indicates whether or not SOAPAction is to be used. The
+     *  default value of this property is false indicating that
+     *  the SOAPAction is not used.
+     *  <p>Type: <code>java.lang.Boolean</code>
+    **/
+    public static final String SOAPACTION_USE_PROPERTY =
+                      "javax.xml.ws.soap.http.soapaction.use";
+
+    /** Standard property for SOAPAction. Indicates the SOAPAction
+     *  URI if the <code>javax.xml.ws.soap.http.soapaction.use</code>
+     *  property is set to <code>true</code>.
+     *  <p>Type: <code>java.lang.String</code>
+    **/
+    public static final String SOAPACTION_URI_PROPERTY =
+                      "javax.xml.ws.soap.http.soapaction.uri";
+
+    /** Get the context that is used to initialize the message context
+     *  for request messages.
+     *
+     * Modifications to the request context do not affect the message context of
+     * either synchronous or asynchronous operations that have already been
+     * started.
+     *
+     * @return The context that is used in processing request messages.
+    **/
+    Map<String, Object> getRequestContext();
+
+    /** Get the context that resulted from processing a response message.
+     *
+     * The returned context is for the most recently completed synchronous
+     * operation. Subsequent synchronous operation invocations overwrite the
+     * response context. Asynchronous operations return their response context
+     * via the Response interface.
+     *
+     * @return The context that resulted from processing the latest
+     * response messages.
+    **/
+    Map<String, Object> getResponseContext();
+
+    /** Get the Binding for this binding provider.
+     *
+     * @return The Binding for this binding provider.
+    **/
+    Binding getBinding();
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/BindingType.java b/jaxws/src/share/classes/javax/xml/ws/BindingType.java
new file mode 100644
index 0000000..da1f23c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/BindingType.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+
+/**
+ *  The <code>BindingType</code> annotation is used to
+ *  specify the binding to use for a web service
+ *  endpoint implementation class.
+ *  <p>
+ *  This annotation may be overriden programmatically or via
+ *  deployment descriptors, depending on the platform in use.
+ *
+ *  @since JAX-WS 2.0
+ *
+ **/
+@Target(ElementType.TYPE)
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface BindingType {
+     /**
+      * A binding identifier (a URI).
+      * If not specified, the default is the SOAP 1.1 / HTTP binding.
+      * <p>
+      * See the <code>SOAPBinding</code> and <code>HTTPBinding</code>
+      * for the definition of the standard binding identifiers.
+      *
+      * @see javax.xml.ws.Binding
+      * @see javax.xml.ws.soap.SOAPBinding#SOAP11HTTP_BINDING
+      * @see javax.xml.ws.soap.SOAPBinding#SOAP12HTTP_BINDING
+      * @see javax.xml.ws.http.HTTPBinding#HTTP_BINDING
+      */
+     String value() default "" ;
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/Dispatch.java b/jaxws/src/share/classes/javax/xml/ws/Dispatch.java
new file mode 100644
index 0000000..12ce6d3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/Dispatch.java
@@ -0,0 +1,116 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.util.concurrent.Future;
+
+/** The <code>Dispatch</code> interface provides support
+ *  for the dynamic invocation of a service endpoint operations. The
+ *  <code>javax.xml.ws.Service</code>
+ *  interface acts as a factory for the creation of <code>Dispatch</code>
+ *  instances.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface Dispatch<T> extends BindingProvider {
+
+    /** Invoke a service operation synchronously.
+     *
+     * The client is responsible for ensuring that the <code>msg</code> object
+     * when marshalled is formed according to the requirements of the protocol
+     * binding in use.
+     *
+     * @param msg An object that will form the message or payload of
+     *     the message used to invoke the operation.
+     * @return The response message or message payload to the
+     *     operation invocation.
+     * @throws WebServiceException If a fault occurs during communication with
+     *     the service
+     * @throws WebServiceException If there is any error in the configuration of
+     *     the <code>Dispatch</code> instance
+    **/
+    public T invoke(T msg);
+
+    /** Invoke a service operation asynchronously.  The
+     *  method returns without waiting for the response to the operation
+     *  invocation, the results of the operation are obtained by polling the
+     *  returned <code>Response</code>.
+     *
+     * The client is responsible for ensuring that the <code>msg</code> object
+     * when marshalled is formed according to the requirements of the protocol
+     * binding in use.
+     *
+     * @param msg An object that will form the message or payload of
+     *     the message used to invoke the operation.
+     * @return The response message or message payload to the
+     *     operation invocation.
+     * @throws WebServiceException If there is any error in the configuration of
+     *     the <code>Dispatch</code> instance
+    **/
+    public Response<T> invokeAsync(T msg);
+
+    /** Invoke a service operation asynchronously. The
+     *  method returns without waiting for the response to the operation
+     *  invocation, the results of the operation are communicated to the client
+     *  via the passed in handler.
+     *
+     * The client is responsible for ensuring that the <code>msg</code> object
+     * when marshalled is formed according to the requirements of the protocol
+     * binding in use.
+     *
+     * @param msg An object that will form the message or payload of
+     *     the message used to invoke the operation.
+     * @param handler The handler object that will receive the
+     *     response to the operation invocation.
+     * @return A <code>Future</code> object that may be used to check the status
+     *     of the operation invocation. This object must not be used to try to
+     *     obtain the results of the operation - the object returned from
+     *     <code>Future<?>.get()</code> is implementation dependent
+     *     and any use of it will result in non-portable behaviour.
+     * @throws WebServiceException If there is any error in the configuration of
+     *     the <code>Dispatch</code> instance
+    **/
+    public Future<?> invokeAsync(T msg, AsyncHandler<T> handler);
+
+    /** Invokes a service operation using the one-way
+     *  interaction mode. The operation invocation is logically non-blocking,
+     *  subject to the capabilities of the underlying protocol, no results
+     *  are returned. When
+     *  the protocol in use is SOAP/HTTP, this method must block until
+     *  an HTTP response code has been received or an error occurs.
+     *
+     * The client is responsible for ensuring that the <code>msg</code> object
+     * when marshalled is formed according to the requirements of the protocol
+     * binding in use.
+     *
+     * @param msg An object that will form the message or payload of
+     *     the message used to invoke the operation.
+     * @throws WebServiceException If there is any error in the configuration of
+     *     the <code>Dispatch</code> instance or if an error occurs during the
+     *     invocation.
+    **/
+    public void invokeOneWay(T msg);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/Endpoint.java b/jaxws/src/share/classes/javax/xml/ws/Endpoint.java
new file mode 100644
index 0000000..7b79fce
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/Endpoint.java
@@ -0,0 +1,287 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.util.List;
+import java.util.Map;
+import javax.xml.ws.spi.Provider;
+
+/**
+ * A Web service endpoint.
+ *
+ * <p>Endpoints are created using the static methods defined in this
+ * class. An endpoint is always tied to one <code>Binding</code>
+ * and one implementor, both set at endpoint creation time.
+ *
+ * <p>An endpoint is either in a published or an unpublished state.
+ * The <code>publish</code> methods can be used to start publishing
+ * an endpoint, at which point it starts accepting incoming requests.
+ * Conversely, the <code>stop</code> method can be used to stop
+ * accepting incoming requests and take the endpoint down.
+ * Once stopped, an endpoint cannot be published again.
+ *
+ * <p>An <code>Executor</code> may be set on the endpoint in order
+ * to gain better control over the threads used to dispatch incoming
+ * requests. For instance, thread pooling with certain parameters
+ * can be enabled by creating a <code>ThreadPoolExecutor</code> and
+ * registering it with the endpoint.
+ *
+ * <p>Handler chains can be set using the contained <code>Binding</code>.
+ *
+ * <p>An endpoint may have a list of metadata documents, such as WSDL
+ * and XMLSchema documents, bound to it. At publishing time, the
+ * JAX-WS implementation will try to reuse as much of that metadata
+ * as possible instead of generating new one based on the annotations
+ * present on the implementor.
+ *
+ * @since JAX-WS 2.0
+ *
+ * @see javax.xml.ws.Binding
+ * @see javax.xml.ws.BindingType
+ * @see javax.xml.ws.soap.SOAPBinding
+ * @see java.util.concurrent.Executor
+ *
+**/
+public abstract class Endpoint {
+
+  /** Standard property: name of WSDL service.
+   *  <p>Type: javax.xml.namespace.QName
+   **/
+  public static final String WSDL_SERVICE = "javax.xml.ws.wsdl.service";
+
+  /** Standard property: name of WSDL port.
+   *  <p>Type: javax.xml.namespace.QName
+   **/
+  public static final String WSDL_PORT = "javax.xml.ws.wsdl.port";
+
+
+  /**
+   * Creates an endpoint with the specified implementor object. If there is
+   * a binding specified via a BindingType annotation then it MUST be used else
+   * a default of SOAP 1.1 / HTTP binding MUST be used.
+   * <p>
+   * The newly created endpoint may be published by calling
+   * one of the javax.xml.ws.Endpoint#publish(String) and
+   * javax.xml.ws.Endpoint#publish(Object) methods.
+   *
+   *
+   * @param implementor The endpoint implementor.
+   *
+   * @return The newly created endpoint.
+   *
+   **/
+  public static Endpoint create(Object implementor) {
+    return create(null, implementor);
+  }
+
+  /**
+   * Creates an endpoint with the specified binding type and
+   * implementor object.
+   * <p>
+   * The newly created endpoint may be published by calling
+   * one of the javax.xml.ws.Endpoint#publish(String) and
+   * javax.xml.ws.Endpoint#publish(Object) methods.
+   *
+   * @param bindingId A URI specifying the binding to use. If the bindingID is
+   * <code>null</code> and no binding is specified via a BindingType
+   * annotation then a default SOAP 1.1 / HTTP binding MUST be used.
+   *
+   * @param implementor The endpoint implementor.
+   *
+   * @return The newly created endpoint.
+   *
+   **/
+  public static Endpoint create(String bindingId, Object implementor) {
+    return Provider.provider().createEndpoint(bindingId, implementor);
+  }
+
+  /**
+   * Returns the binding for this endpoint.
+   *
+   * @return The binding for this endpoint
+  **/
+  public abstract Binding getBinding();
+
+  /**
+   * Returns the implementation object for this endpoint.
+   *
+   * @return The implementor for this endpoint
+  **/
+  public abstract Object getImplementor();
+
+  /**
+   * Publishes this endpoint at the given address.
+   * The necessary server infrastructure will be created and
+   * configured by the JAX-WS implementation using some default configuration.
+   * In order to get more control over the server configuration, please
+   * use the javax.xml.ws.Endpoint#publish(Object) method instead.
+   *
+   * @param address A URI specifying the address to use. The address
+   *        must be compatible with the binding specified at the
+   *        time the endpoint was created.
+   *
+   * @throws java.lang.IllegalArgumentException
+   *              If the provided address URI is not usable
+   *              in conjunction with the endpoint's binding.
+   *
+   * @throws java.lang.IllegalStateException
+   *         If the endpoint has been published already or it has been stopped.
+  **/
+  public abstract void publish(String address);
+
+  /**
+   * Creates and publishes an endpoint for the specified implementor
+   * object at the given address.
+   * <p>
+   * The necessary server infrastructure will be created and
+   * configured by the JAX-WS implementation using some default configuration.
+   *
+   * In order to get more control over the server configuration, please
+   * use the javax.xml.ws.Endpoint#create(String,Object) and
+   * javax.xml.ws.Endpoint#publish(Object) method instead.
+   *
+   * @param address A URI specifying the address and transport/protocol
+   *        to use. A http: URI must result in the SOAP 1.1/HTTP
+   *        binding being used. Implementations may support other
+   *        URI schemes.
+   * @param implementor The endpoint implementor.
+   *
+   * @return The newly created endpoint.
+   *
+   **/
+  public static Endpoint publish (String address, Object implementor) {
+    return Provider.provider().createAndPublishEndpoint(address, implementor);
+  }
+
+  /**
+   * Publishes this endpoint at the provided server context.
+   * A server context encapsulates the server infrastructure
+   * and addressing information for a particular transport.
+   * For a call to this method to succeed, the server context
+   * passed as an argument to it must be compatible with the
+   * endpoint's binding.
+   *
+   * @param serverContext An object representing a server
+   *           context to be used for publishing the endpoint.
+   *
+   * @throws java.lang.IllegalArgumentException
+   *              If the provided server context is not
+   *              supported by the implementation or turns
+   *              out to be unusable in conjunction with the
+   *              endpoint's binding.
+   *
+   * @throws java.lang.IllegalStateException
+   *         If the endpoint has been published already or it has been stopped.
+  **/
+  public abstract void publish(Object serverContext);
+
+  /**
+   * Stops publishing this endpoint.
+   *
+   * If the endpoint is not in a published state, this method
+   * has not effect.
+   *
+  **/
+  public abstract void stop();
+
+  /**
+   * Returns true if the endpoint is in the published state.
+   *
+   * @return <code>true</code> if the endpoint is in the published state.
+  **/
+  public abstract boolean isPublished();
+
+  /**
+   * Returns a list of metadata documents for the service.
+   *
+   * @return <code>List&lt;javax.xml.transform.Source&gt;</code> A list of metadata documents for the service
+  **/
+  public abstract List<javax.xml.transform.Source> getMetadata();
+
+  /**
+   * Sets the metadata for this endpoint.
+   *
+   * @param metadata A list of XML document sources containing
+   *           metadata information for the endpoint (e.g.
+   *           WSDL or XML Schema documents)
+   *
+   * @throws java.lang.IllegalStateException If the endpoint
+   *         has already been published.
+  **/
+  public abstract void setMetadata(List<javax.xml.transform.Source> metadata);
+
+  /**
+   * Returns the executor for this <code>Endpoint</code>instance.
+   *
+   * The executor is used to dispatch an incoming request to
+   * the implementor object.
+   *
+   * @return The <code>java.util.concurrent.Executor</code> to be
+   *         used to dispatch a request.
+   *
+   * @see java.util.concurrent.Executor
+   **/
+   public abstract java.util.concurrent.Executor getExecutor();
+
+  /**
+   * Sets the executor for this <code>Endpoint</code> instance.
+   *
+   * The executor is used to dispatch an incoming request to
+   * the implementor object.
+   *
+   * If this <code>Endpoint</code> is published using the
+   * <code>publish(Object)</code> method and the specified server
+   * context defines its own threading behavior, the executor
+   * may be ignored.
+   *
+   * @param executor The <code>java.util.concurrent.Executor</code>
+   *        to be used to dispatch a request.
+   *
+   * @throws SecurityException If the instance does not support
+   *         setting an executor for security reasons (e.g. the
+   *         necessary permissions are missing).
+   *
+   * @see java.util.concurrent.Executor
+   **/
+   public abstract void setExecutor(java.util.concurrent.Executor executor);
+
+
+    /**
+     * Returns the property bag for this <code>Endpoint</code> instance.
+     *
+     * @return Map&lt;String,Object&gt; The property bag
+     *         associated with this instance.
+     **/
+     public abstract Map<String,Object> getProperties();
+
+    /**
+     * Sets the property bag for this <code>Endpoint</code> instance.
+     *
+     * @param properties The property bag associated with
+     *        this instance.
+     **/
+     public abstract void setProperties(Map<String,Object> properties);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/Holder.java b/jaxws/src/share/classes/javax/xml/ws/Holder.java
new file mode 100644
index 0000000..091dac4
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/Holder.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+/**
+ *  Holds a value of type <code>T</code>.
+ *
+ *  @since JAX-WS 2.0
+**/
+public final class Holder<T> {
+
+  /**
+   * The value contained in the holder.
+   **/
+  public T value;
+
+  /**
+   * Creates a new holder with a <code>null</code> value.
+   **/
+  public Holder() {
+  }
+
+  /**
+   * Create a new holder with the specified value.
+   *
+   * @param value The value to be stored in the holder.
+   **/
+  public Holder(T value) {
+      this.value = value;
+  }
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/LogicalMessage.java b/jaxws/src/share/classes/javax/xml/ws/LogicalMessage.java
new file mode 100644
index 0000000..b166a59
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/LogicalMessage.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import javax.xml.transform.Source;
+import javax.xml.bind.JAXBContext;
+
+/** The <code>LogicalMessage</code> interface represents a
+ *  protocol agnostic XML message and contains methods that
+ *  provide access to the payload of the message.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface LogicalMessage {
+
+  /** Gets the message payload as an XML source, may be called
+   *  multiple times on the same LogicalMessage instance, always
+   *  returns a new Source that may be used to retrieve the entire
+   *  message payload.
+   *
+   *  <p>If the returned Source is an instance of DOMSource, then
+   *  modifications to the encapsulated DOM tree change the message
+   *  payload in-place, there is no need to susequently call
+   *  <code>setPayload</code>. Other types of Source provide only
+   *  read access to the message payload.
+   *
+   *  @return The contained message payload; returns null if no
+   *          payload is present in this message.
+  **/
+  public Source getPayload();
+
+  /** Sets the message payload
+   *
+   *  @param  payload message payload
+   *  @throws WebServiceException If any error during the setting
+   *          of the payload in this message
+   *  @throws java.lang.UnsupportedOperationException If this
+   *          operation is not supported
+  **/
+  public void setPayload(Source payload);
+
+  /** Gets the message payload as a JAXB object. Note that there is no
+   *  connection between the returned object and the message payload,
+   *  changes to the payload require calling <code>setPayload</code>.
+   *
+   *  @param  context The JAXBContext that should be used to unmarshall
+   *          the message payload
+   *  @return The contained message payload; returns null if no
+   *          payload is present in this message
+   *  @throws WebServiceException If an error occurs when using a supplied
+   *     JAXBContext to unmarshall the payload. The cause of
+   *     the WebServiceException is the original JAXBException.
+  **/
+  public Object getPayload(JAXBContext context);
+
+  /** Sets the message payload
+   *
+   *  @param  payload message payload
+   *  @param  context The JAXBContext that should be used to marshall
+   *          the payload
+   *  @throws java.lang.UnsupportedOperationException If this
+   *          operation is not supported
+   *  @throws WebServiceException If an error occurs when using the supplied
+   *     JAXBContext to marshall the payload. The cause of
+   *     the WebServiceException is the original JAXBException.
+  **/
+  public void setPayload(Object payload, JAXBContext context);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/ProtocolException.java b/jaxws/src/share/classes/javax/xml/ws/ProtocolException.java
new file mode 100644
index 0000000..7d5883d
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/ProtocolException.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+/** The <code>ProtocolException</code> class is a
+ *  base class for exceptions related to a specific protocol binding. Subclasses
+ *  are used to communicate protocol level fault information to clients and may
+ *  be used on the server to control the protocol specific fault representation.
+ *
+ *  @since JAX-WS 2.0
+**/
+public class ProtocolException extends WebServiceException {
+    /**
+     * Constructs a new protocol exception with null as its detail message. The
+     * cause is not initialized, and may subsequently be initialized by a call
+     * to Throwable.initCause(java.lang.Throwable).
+     */
+    public ProtocolException() {
+        super();
+    }
+
+    /**
+     * Constructs a new protocol exception with the specified detail message.
+     * The cause is not initialized, and may subsequently be initialized by a
+     * call to Throwable.initCause(java.lang.Throwable).
+     *
+     * @param message the detail message. The detail message is saved for later
+     *   retrieval by the Throwable.getMessage() method.
+     */
+    public ProtocolException(String message) {
+        super(message);
+    }
+
+    /**
+     * Constructs a new runtime exception with the specified detail message and
+     * cause.
+     *
+     * Note that the detail message associated with  cause is not automatically
+     * incorporated in  this runtime exception's detail message.
+     *
+     * @param message the detail message (which is saved for later retrieval  by
+     *   the Throwable.getMessage() method).
+     * @param cause the cause (which is saved for later retrieval by the
+     * Throwable.getCause() method). (A null value is  permitted, and indicates
+     * that the cause is nonexistent or  unknown.)
+     */
+    public ProtocolException(String message,  Throwable cause) {
+        super(message, cause);
+    }
+
+    /**
+     * Constructs a new runtime exception with the specified cause and a  detail
+     * message of (cause==null ? null : cause.toString())  (which typically
+     * contains the class and detail message of  cause). This constructor is
+     * useful for runtime exceptions  that are little more than wrappers for
+     * other throwables.
+     *
+     * @param cause the cause (which is saved for later retrieval by the
+     * Throwable.getCause() method). (A null value is  permitted, and indicates
+     * that the cause is nonexistent or  unknown.)
+     */
+    public ProtocolException(Throwable cause) {
+        super(cause);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/Provider.java b/jaxws/src/share/classes/javax/xml/ws/Provider.java
new file mode 100644
index 0000000..ffb9e08
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/Provider.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+/**
+ *  <p>Service endpoints may implement the <code>Provider</code>
+ *  interface as a dynamic alternative to an SEI.
+ *
+ *  <p>Implementations are required to support <code>Provider&lt;Source&gt;</code>,
+ *  <code>Provider&lt;SOAPMessage&gt;</code> and
+ *  <code>Provider&lt;DataSource&gt;</code>, depending on the binding
+ *  in use and the service mode.
+ *
+ *  <p>The <code>ServiceMode</code> annotation can be used to control whether
+ *  the <code>Provider</code> instance will receive entire protocol messages
+ *  or just message payloads.
+ *
+ *  @since JAX-WS 2.0
+ *
+ *  @see javax.xml.transform.Source
+ *  @see javax.xml.soap.SOAPMessage
+ *  @see javax.xml.ws.ServiceMode
+**/
+public interface Provider<T> {
+
+  /** Invokes an operation occording to the contents of the request
+   *  message.
+   *
+   *  @param  request The request message or message payload.
+   *  @return The response message or message payload. May be null if
+              there is no response.
+   *  @throws WebServiceException if there is an error processing request.
+   *          The cause of the WebServiceException may be set to a subclass
+   *          of ProtocolException to control the protocol level
+   *          representation of the exception.
+   *  @see javax.xml.ws.handler.MessageContext
+   *  @see javax.xml.ws.ProtocolException
+  **/
+  public T invoke(T request);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/RequestWrapper.java b/jaxws/src/share/classes/javax/xml/ws/RequestWrapper.java
new file mode 100644
index 0000000..65efff7a
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/RequestWrapper.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.RetentionPolicy;
+
+/**
+
+ * Used to annotate methods in the Service Endpoint Interface with the request
+ * wrapper bean to be used at runtime. The default value of the localName is
+ * the operationName, as defined in WebMethod annotation and the
+ * targetNamespace is the target namespace of the SEI.
+ * <p> When starting from Java this annotation is used resolve
+ * overloading conflicts in document literal mode. Only the className
+ * is required in this case.
+ *
+ *  @since JAX-WS 2.0
+ **/
+
+@Target(ElementType.METHOD)
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface RequestWrapper {
+  /**
+   *  Elements local name.
+  **/
+  public String localName() default "";
+
+  /**
+   *  Elements namespace name.
+  **/
+  public String targetNamespace() default "";
+
+  /**
+   *  Request wrapper bean name.
+  **/
+  public String className() default "";
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/Response.java b/jaxws/src/share/classes/javax/xml/ws/Response.java
new file mode 100644
index 0000000..e0dc3ac
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/Response.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.util.Map;
+import java.util.concurrent.Future;
+
+/** The <code>Response</code> interface provides methods used to obtain the
+ *  payload and context of a message sent in response to an operation
+ *  invocation.
+ *
+ *  <p>For asynchronous operation invocations it provides additional methods
+ *  to check the status of the request. The <code>get(...)</code> methods may
+ *  throw the standard
+ *  set of exceptions and their cause may be a RemoteException or a
+ *  WebServiceException that represents the error that occured during the
+ *  asynchronous method invocation.</p>
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface Response<T> extends Future<T> {
+    /** Gets the contained response context.
+     *
+     * @return The contained response context. May be <code>null</code> if a
+     * response is not yet available.
+     *
+    **/
+    Map<String,Object> getContext();
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/ResponseWrapper.java b/jaxws/src/share/classes/javax/xml/ws/ResponseWrapper.java
new file mode 100644
index 0000000..9528f07
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/ResponseWrapper.java
@@ -0,0 +1,77 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.RetentionPolicy;
+/**
+ * Used to annotate methods in the Service Endpoint Interface with the response
+ * wrapper bean to be used at runtime. The default value of the localName is
+ * the operationName as defined in WebMethod annotation appended with
+ * Response and the targetNamespace is the target namespace of the SEI.
+ * <p> When starting from Java this annotation is used resolve
+ * overloading conflicts in document literal mode. Only the className
+ * is required in this case.
+ *
+ *  @since JAX-WS 2.0
+**/
+
+@Target(ElementType.METHOD)
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface ResponseWrapper {
+
+  /**
+
+   *  Elements local name.
+
+  **/
+
+  public String localName() default "";
+
+
+
+  /**
+
+   *  Elements namespace name.
+
+  **/
+
+  public String targetNamespace() default "";
+
+
+
+  /**
+
+   *  Response wrapper bean name.
+
+  **/
+
+  public String className() default "";
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/Service.java b/jaxws/src/share/classes/javax/xml/ws/Service.java
new file mode 100644
index 0000000..82b3f5e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/Service.java
@@ -0,0 +1,335 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import javax.xml.namespace.QName;
+import java.util.Iterator;
+import javax.xml.ws.handler.HandlerResolver;
+import javax.xml.bind.JAXBContext;
+import javax.xml.ws.spi.ServiceDelegate;
+import javax.xml.ws.spi.Provider;
+
+/**
+ *  <code>Service</code> objects provide the client view of a Web service.
+ *  <p><code>Service</code> acts as a factory of the following:
+ *  <ul>
+ *  <li>Proxies for a target service endpoint.
+ *  <li>Instances of <code>javax.xml.ws.Dispatch</code> for
+ *      dynamic message-oriented invocation of a remote
+ *      operation.
+ *  </li>
+ *
+ * <p>The ports available on a service can be enumerated using the
+ * <code>getPorts</code> method. Alternatively, you can pass a
+ * service endpoint interface to the unary <code>getPort</code> method
+ * and let the runtime select a compatible port.
+ *
+ * <p>Handler chains for all the objects created by a <code>Service</code>
+ * can be set by means of a <code>HandlerResolver</code>.
+ *
+ * <p>An <code>Executor</code> may be set on the service in order
+ * to gain better control over the threads used to dispatch asynchronous
+ * callbacks. For instance, thread pooling with certain parameters
+ * can be enabled by creating a <code>ThreadPoolExecutor</code> and
+ * registering it with the service.
+ *
+ *  @since JAX-WS 2.0
+ *
+ *  @see javax.xml.ws.spi.Provider
+ *  @see javax.xml.ws.handler.HandlerResolver
+ *  @see java.util.concurrent.Executor
+**/
+public class Service {
+
+  private ServiceDelegate delegate;
+  /**
+   * The orientation of a dynamic client or service. MESSAGE provides
+   * access to entire protocol message, PAYLOAD to protocol message
+   * payload only.
+  **/
+  public enum Mode { MESSAGE, PAYLOAD };
+
+  protected Service(java.net.URL wsdlDocumentLocation, QName serviceName)
+  {
+      delegate = Provider.provider().createServiceDelegate(wsdlDocumentLocation,
+                                                           serviceName,
+                                                           this.getClass());
+  }
+
+
+  /** The getPort method returns a stub. A service client
+   *  uses this stub to invoke operations on the target
+   *  service endpoint. The <code>serviceEndpointInterface</code>
+   *  specifies the service endpoint interface that is supported by
+   *  the created dynamic proxy or stub instance.
+   *
+   *  @param portName  Qualified name of the service endpoint in
+   *                   the WSDL service description
+   *  @param serviceEndpointInterface Service endpoint interface
+   *                   supported by the dynamic proxy or stub
+   *                   instance
+   *  @return Object Proxy instance that
+   *                 supports the specified service endpoint
+   *                 interface
+   *  @throws WebServiceException This exception is thrown in the
+   *                   following cases:
+   *                   <UL>
+   *                   <LI>If there is an error in creation of
+   *                       the proxy
+   *                   <LI>If there is any missing WSDL metadata
+   *                       as required by this method
+   *                   <LI>Optionally, if an illegal
+   *                       <code>serviceEndpointInterface</code>
+   *                       or <code>portName</code> is specified
+   *                   </UL>
+   *  @see java.lang.reflect.Proxy
+   *  @see java.lang.reflect.InvocationHandler
+  **/
+  public <T> T getPort(QName portName,
+                                 Class<T> serviceEndpointInterface)
+  {
+      return delegate.getPort(portName, serviceEndpointInterface);
+  }
+
+  /** The getPort method returns a stub. The parameter
+   *  <code>serviceEndpointInterface</code> specifies the service
+   *  endpoint interface that is supported by the returned proxy.
+   *  In the implementation of this method, the JAX-WS
+   *  runtime system takes the responsibility of selecting a protocol
+   *  binding (and a port) and configuring the proxy accordingly.
+   *  The returned proxy should not be reconfigured by the client.
+   *
+   *  @param serviceEndpointInterface Service endpoint interface
+   *  @return Object instance that supports the
+   *                   specified service endpoint interface
+   *  @throws WebServiceException
+   *                   <UL>
+   *                   <LI>If there is an error during creation
+   *                       of the proxy
+   *                   <LI>If there is any missing WSDL metadata
+   *                       as required by this method
+   *                   <LI>Optionally, if an illegal
+   *                       <code>serviceEndpointInterface</code>
+   *                       is specified
+   *                   </UL>
+  **/
+  public <T> T getPort(Class<T> serviceEndpointInterface) {
+      return delegate.getPort(serviceEndpointInterface);
+  }
+
+  /** Creates a new port for the service. Ports created in this way contain
+   *  no WSDL port type information and can only be used for creating
+   *  <code>Dispatch</code>instances.
+   *
+   *  @param portName  Qualified name for the target service endpoint
+   *  @param bindingId A String identifier of a binding.
+   *  @param endpointAddress Address of the target service endpoint as a URI
+   *  @throws WebServiceException If any error in the creation of
+   *  the port
+   *
+   *  @see javax.xml.ws.soap.SOAPBinding#SOAP11HTTP_BINDING
+   *  @see javax.xml.ws.soap.SOAPBinding#SOAP12HTTP_BINDING
+   *  @see javax.xml.ws.http.HTTPBinding#HTTP_BINDING
+   **/
+  public void addPort(QName portName, String bindingId, String endpointAddress)
+  {
+      delegate.addPort(portName, bindingId, endpointAddress);
+  }
+
+  /** Creates a <code>Dispatch</code> instance for use with objects of
+   *  the users choosing.
+   *
+   *  @param portName  Qualified name for the target service endpoint
+   *  @param type The class of object used to messages or message
+   *  payloads. Implementations are required to support
+   *  <code>javax.xml.transform.Source</code>, <code>javax.xml.soap.SOAPMessage</code>
+   *  and <code>javax.activation.DataSource</code>, depending on
+   *  the binding in use.
+   *  @param mode Controls whether the created dispatch instance is message
+   *  or payload oriented, i.e. whether the user will work with complete
+   *  protocol messages or message payloads. E.g. when using the SOAP
+   *  protocol, this parameter controls whether the user will work with
+   *  SOAP messages or the contents of a SOAP body. Mode must be MESSAGE
+   *  when type is SOAPMessage.
+   *
+   *  @return Dispatch instance
+   *  @throws WebServiceException If any error in the creation of
+   *                   the <code>Dispatch</code> object
+   *  @see javax.xml.transform.Source
+   *  @see javax.xml.soap.SOAPMessage
+   **/
+  public <T> Dispatch<T> createDispatch(QName portName, Class<T> type, Mode mode)
+  {
+      return delegate.createDispatch(portName, type, mode);
+  }
+
+  /** Creates a <code>Dispatch</code> instance for use with JAXB
+   *  generated objects.
+   *
+   *  @param portName  Qualified name for the target service endpoint
+   *  @param context The JAXB context used to marshall and unmarshall
+   *  messages or message payloads.
+   *  @param mode Controls whether the created dispatch instance is message
+   *  or payload oriented, i.e. whether the user will work with complete
+   *  protocol messages or message payloads. E.g. when using the SOAP
+   *  protocol, this parameter controls whether the user will work with
+   *  SOAP messages or the contents of a SOAP body.
+   *
+   *  @return Dispatch instance
+   *  @throws ServiceException If any error in the creation of
+   *                   the <code>Dispatch</code> object
+   *
+   *  @see javax.xml.bind.JAXBContext
+   **/
+  public Dispatch<Object> createDispatch(QName portName, JAXBContext context,
+      Mode mode)
+  {
+      return delegate.createDispatch(portName, context,  mode);
+  }
+
+
+
+  /** Gets the name of this service.
+   *  @return Qualified name of this service
+  **/
+  public QName getServiceName() {
+      return delegate.getServiceName();
+  }
+
+  /** Returns an <code>Iterator</code> for the list of
+   *  <code>QName</code>s of service endpoints grouped by this
+   *  service
+   *
+   *  @return Returns <code>java.util.Iterator</code> with elements
+   *          of type <code>javax.xml.namespace.QName</code>
+   *  @throws WebServiceException If this Service class does not
+   *          have access to the required WSDL metadata
+  **/
+  public Iterator<javax.xml.namespace.QName> getPorts() {
+      return delegate.getPorts();
+  }
+
+  /** Gets the location of the WSDL document for this Service.
+   *
+   *  @return URL for the location of the WSDL document for
+   *          this service
+  **/
+  public java.net.URL getWSDLDocumentLocation() {
+      return delegate.getWSDLDocumentLocation();
+  }
+
+  /**
+   * Returns the configured handler resolver.
+   *
+   *  @return HandlerResolver The <code>HandlerResolver</code> being
+   *          used by this <code>Service</code> instance, or <code>null</code>
+   *          if there isn't one.
+  **/
+    public HandlerResolver getHandlerResolver() {
+        return delegate.getHandlerResolver();
+    }
+
+  /**
+   *  Sets the <code>HandlerResolver</code> for this <code>Service</code>
+   *  instance.
+   *  <p>
+   *  The handler resolver, if present, will be called once for each
+   *  proxy or dispatch instance that is created, and the handler chain
+   *  returned by the resolver will be set on the instance.
+   *
+   *  @param handlerResolver The <code>HandlerResolver</code> to use
+   *         for all subsequently created proxy/dispatch objects.
+   *
+   *  @see javax.xml.ws.handler.HandlerResolver
+  **/
+   public void setHandlerResolver(HandlerResolver handlerResolver) {
+       delegate.setHandlerResolver(handlerResolver);
+   }
+
+  /**
+   * Returns the executor for this <code>Service</code>instance.
+   *
+   * The executor is used for all asynchronous invocations that
+   * require callbacks.
+   *
+   * @return The <code>java.util.concurrent.Executor</code> to be
+   *         used to invoke a callback.
+   *
+   * @see java.util.concurrent.Executor
+   **/
+   public java.util.concurrent.Executor getExecutor() {
+       return delegate.getExecutor();
+   }
+
+  /**
+   * Sets the executor for this <code>Service</code> instance.
+   *
+   * The executor is used for all asynchronous invocations that
+   * require callbacks.
+   *
+   * @param executor The <code>java.util.concurrent.Executor</code>
+   *        to be used to invoke a callback.
+   *
+   * @throws SecurityException If the instance does not support
+   *         setting an executor for security reasons (e.g. the
+   *         necessary permissions are missing).
+   *
+   * @see java.util.concurrent.Executor
+   **/
+   public void setExecutor(java.util.concurrent.Executor executor) {
+       delegate.setExecutor(executor);
+   }
+
+  /**
+   *  Create a <code>Service</code> instance.
+   *
+   *  The specified WSDL document location and service qualified name must
+   *  uniquely identify a <code>wsdl:service</code> element.
+   *
+   *  @param wsdlDocumentLocation URL for the WSDL document location
+   *                              for the service
+   *  @param serviceName QName for the service
+   *  @throws WebServiceException If any error in creation of the
+   *                     specified service
+  **/
+  public static Service create(
+                            java.net.URL wsdlDocumentLocation,
+                            QName serviceName)
+  {
+      return new Service(wsdlDocumentLocation, serviceName);
+  }
+
+  /**
+   *  Create a <code>Service</code> instance.
+   *
+   *  @param serviceName QName for the service
+   *  @throws WebServiceException If any error in creation of the
+   *                     specified service
+   */
+  public static Service create(QName serviceName) {
+      return new Service(null, serviceName);
+  }
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/ServiceMode.java b/jaxws/src/share/classes/javax/xml/ws/ServiceMode.java
new file mode 100644
index 0000000..abaa38b
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/ServiceMode.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Inherited;
+
+/**
+ * Used to indicate whether a Provider implementation wishes to work
+ * with entire protocol messages or just with protocol message payloads.
+ *
+ *  @since JAX-WS 2.0
+**/
+@Target({ElementType.TYPE})
+@Retention(RetentionPolicy.RUNTIME)
+@Inherited
+@Documented
+public @interface ServiceMode {
+  /**
+   * Service mode. PAYLOAD indicates that the Provider implementation
+   * wishes to work with protocol message payloads only. MESSAGE indicates
+   * that the Provider implementation wishes to work with entire protocol
+   * messages.
+  **/
+  public Service.Mode value() default Service.Mode.PAYLOAD;
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebEndpoint.java b/jaxws/src/share/classes/javax/xml/ws/WebEndpoint.java
new file mode 100644
index 0000000..778167b
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebEndpoint.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.RetentionPolicy;
+
+/**
+ *  Used to annotate the <code>get<em>PortName</em>()</code>
+ *  methods of a generated service interface.
+ *
+ *  <p>The information specified in this annotation is sufficient
+ *  to uniquely identify a <code>wsdl:port</code> element
+ *  inside a <code>wsdl:service</code>. The latter is
+ *  determined based on the value of the <code>WebServiceClient</code>
+ *  annotation on the generated service interface itself.
+ *
+ *  @since JAX-WS 2.0
+ *
+ *  @see javax.xml.ws.WebServiceClient
+**/
+@Target({ElementType.METHOD})
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface WebEndpoint {
+  /**
+   *  The local name of the endpoint.
+  **/
+  String name() default "";
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebFault.java b/jaxws/src/share/classes/javax/xml/ws/WebFault.java
new file mode 100644
index 0000000..7fa2a5c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebFault.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.RetentionPolicy;
+
+/**
+ * Used to annotate service specific exception classes to customize
+ * to the local and namespace name of the fault element and the name
+ * of the fault bean.
+ *
+ *  @since JAX-WS 2.0
+**/
+@Target({ElementType.TYPE})
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface WebFault {
+  /**
+   *  Elements local name.
+  **/
+  public String name() default "";
+
+  /**
+   *  Elements namespace name.
+  **/
+  public String targetNamespace() default "";
+
+  /**
+   *  Fault bean name.
+  **/
+  public String faultBean() default "";
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebServiceClient.java b/jaxws/src/share/classes/javax/xml/ws/WebServiceClient.java
new file mode 100644
index 0000000..431ecce
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebServiceClient.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.RetentionPolicy;
+
+/**
+ *  Used to annotate a generated service interface.
+ *
+ *  <p>The information specified in this annotation is sufficient
+ *  to uniquely identify a <code>wsdl:service</code>
+ *  element inside a WSDL document. This <code>wsdl:service</code>
+ *  element represents the Web service for which the generated
+ *  service interface provides a client view.
+ *
+ *  @since JAX-WS 2.0
+**/
+@Target({ElementType.TYPE})
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface WebServiceClient {
+  /**
+   *  The local name of the Web service.
+  **/
+  String name() default "";
+
+  /**
+   *  The namespace for the Web service.
+  **/
+  String targetNamespace() default "";
+
+  /**
+   *  The location of the WSDL document for the service (a URL).
+  **/
+  String wsdlLocation() default "";
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebServiceContext.java b/jaxws/src/share/classes/javax/xml/ws/WebServiceContext.java
new file mode 100644
index 0000000..39631fe
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebServiceContext.java
@@ -0,0 +1,97 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.security.Principal;
+import javax.xml.ws.handler.MessageContext;
+
+/**
+ *  A <code>WebServiceContext</code> makes it possible for
+ *  a web service endpoint implementation class to access
+ *  message context and security information relative to
+ *  a request being served.
+ *
+ *  Typically a <code>WebServiceContext</code> is injected
+ *  into an endpoint implementation class using the
+ *  <code>Resource</code> annotation.
+ *
+ *  @since JAX-WS 2.0
+ *
+ *  @see javax.annotation.Resource
+**/
+public interface WebServiceContext {
+
+  /**
+   *  Returns the MessageContext for the request being served
+   *  at the time this method is called. Only properties with
+   *  APPLICATION scope will be visible to the application.
+   *
+   *  @return MessageContext The message context.
+   *
+   *  @throws IllegalStateException This exception is thrown
+   *          if the method is called while no request is
+   *          being serviced.
+   *
+   *  @see javax.xml.ws.handler.MessageContext
+   *  @see javax.xml.ws.handler.MessageContext.Scope
+   *  @see java.lang.IllegalStateException
+  **/
+  public MessageContext getMessageContext();
+
+  /**
+   *  Returns the Principal that identifies the sender
+   *  of the request currently being serviced. If the
+   *  sender has not been authenticated, the method
+   *  returns <code>null</code>.
+   *
+   *  @return Principal The principal object.
+   *
+   *  @throws IllegalStateException This exception is thrown
+   *          if the method is called while no request is
+   *          being serviced.
+   *
+   *  @see java.security.Principal
+   *  @see java.lang.IllegalStateException
+  **/
+  public Principal getUserPrincipal();
+
+  /**
+   *  Returns a boolean indicating whether the
+   *  authenticated user is included in the specified
+   *  logical role. If the user has not been
+   *  authenticated, the method returns </code>false</code>.
+   *
+   *  @param role  A <code>String</code> specifying the name of the role
+   *
+   *  @return a <code>boolean</code> indicating whether
+   *  the sender of the request belongs to a given role
+   *
+   *  @throws IllegalStateException This exception is thrown
+   *          if the method is called while no request is
+   *          being serviced.
+  **/
+  public boolean isUserInRole(String role);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebServiceException.java b/jaxws/src/share/classes/javax/xml/ws/WebServiceException.java
new file mode 100644
index 0000000..3cc5a08
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebServiceException.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+/** The <code>WebServiceException</code> class is the base
+ *  exception class for all JAX-WS API runtime exceptions.
+ *
+ *  @since JAX-WS 2.0
+**/
+
+public class WebServiceException extends java.lang.RuntimeException {
+
+  /** Constructs a new exception with <code>null</code> as its
+   *  detail message. The cause is not initialized.
+  **/
+  public WebServiceException() {
+    super();
+  }
+
+  /** Constructs a new exception with the specified detail
+   *  message.  The cause is not initialized.
+   *  @param message The detail message which is later
+   *                 retrieved using the getMessage method
+  **/
+  public WebServiceException(String message) {
+    super(message);
+  }
+
+  /** Constructs a new exception with the specified detail
+   *  message and cause.
+   *
+   *  @param message The detail message which is later retrieved
+   *                 using the getMessage method
+   *  @param cause   The cause which is saved for the later
+   *                 retrieval throw by the getCause method
+  **/
+  public WebServiceException(String message, Throwable cause) {
+    super(message,cause);
+  }
+
+  /** Constructs a new WebServiceException with the specified cause
+   *  and a detail message of <tt>(cause==null ? null :
+   *  cause.toString())</tt> (which typically contains the
+   *  class and detail message of <tt>cause</tt>).
+   *
+   *  @param cause   The cause which is saved for the later
+   *                 retrieval throw by the getCause method.
+   *                 (A <tt>null</tt> value is permitted, and
+   *                 indicates that the cause is nonexistent or
+     *               unknown.)
+  **/
+  public WebServiceException(Throwable cause) {
+    super(cause);
+  }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebServicePermission.java b/jaxws/src/share/classes/javax/xml/ws/WebServicePermission.java
new file mode 100644
index 0000000..3fc5134
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebServicePermission.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.security.BasicPermission;
+
+/**
+ * This class defines web service permissions.
+ * <p>
+ * Web service Permissions are identified by name (also referred to as
+ * a "target name") alone. There are no actions associated
+ * with them.
+ * <p>
+ * The following permission target name is defined:
+ * <p>
+ * <dl>
+ *   <dt>publishEndpoint
+ * </dl>
+ * <p>
+ * The <code>publishEndpoint</code> permission allows publishing a
+ * web service endpoint using the <code>publish</code> methods
+ * defined by the <code>javax.xml.ws.Endpoint</code> class.
+ *
+ * @see javax.xml.ws.Endpoint
+ * @see java.security.BasicPermission
+ * @see java.security.Permission
+ * @see java.security.Permissions
+ * @see java.lang.SecurityManager
+ */
+public final class WebServicePermission extends BasicPermission {
+
+    private static final long serialVersionUID = -146474640053770988L;
+
+    /**
+     * Creates a new permission with the specified name.
+     *
+     * @param name the name of the <code>WebServicePermission</code>
+     */
+    public WebServicePermission(String name) {
+        super(name);
+    }
+
+    /**
+     * Creates a new permission with the specified name and actions.
+     *
+     * The <code>actions</code> parameter is currently unused and
+     * it should be <code>null</code>.
+     *
+     * @param name the name of the <code>WebServicePermission</code>
+     * @param actions should be <code>null</code>
+     */
+    public WebServicePermission(String name, String actions) {
+        super(name, actions);
+    }
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebServiceProvider.java b/jaxws/src/share/classes/javax/xml/ws/WebServiceProvider.java
new file mode 100644
index 0000000..feaa5a3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebServiceProvider.java
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.RetentionPolicy;
+/**
+ * Used to annotate a Provider implementation class.
+ *
+ * @since JAX-WS 2.0
+ * @see javax.xml.ws.Provider
+ */
+@Target(ElementType.TYPE)
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface WebServiceProvider {
+    /**
+     * Location of the WSDL description for the service.
+     */
+    String wsdlLocation() default "";
+
+    /**
+     * Service name.
+     */
+    String serviceName() default "";
+
+    /**
+     * Target namespace for the service
+     */
+    String targetNamespace() default "";
+
+    /**
+     * Port name.
+     */
+    String portName() default "";
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebServiceRef.java b/jaxws/src/share/classes/javax/xml/ws/WebServiceRef.java
new file mode 100644
index 0000000..98ca206
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebServiceRef.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+
+/**
+ *  The <code>WebServiceRef</code> annotation is used to
+ *  define a reference to a web service and
+ *  (optionally) an injection target for it.
+ *
+ *  Web service references are resources in the Java EE 5 sense.
+ *
+ *  @see javax.annotation.Resource
+ *
+ *  @since JAX-WS 2.0
+ *
+**/
+
+@Target({ElementType.TYPE, ElementType.METHOD, ElementType.FIELD})
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface WebServiceRef {
+     /**
+      * The JNDI name of the resource.  For field annotations,
+      * the default is the field name.  For method annotations,
+      * the default is the JavaBeans property name corresponding
+      * to the method.  For class annotations, there is no default
+      * and this must be specified.
+      */
+     String name() default "";
+
+     /**
+      * The Java type of the resource.  For field annotations,
+      * the default is the type of the field.  For method annotations,
+      * the default is the type of the JavaBeans property.
+      * For class annotations, there is no default and this must be
+      * specified.
+      */
+     Class type() default Object.class ;
+
+     /**
+      * A product specific name that this resource should be mapped to.
+      * The name of this resource, as defined by the <code>name</code>
+      * element or defaulted, is a name that is local to the application
+      * component using the resource.  (It's a name in the JNDI
+      * <code>java:comp/env</code> namespace.)  Many application servers
+      * provide a way to map these local names to names of resources
+      * known to the application server.  This mapped name is often a
+      * <i>global</i> JNDI name, but may be a name of any form. <p>
+      *
+      * Application servers are not required to support any particular
+      * form or type of mapped name, nor the ability to use mapped names.
+      * The mapped name is product-dependent and often installation-dependent.
+      * No use of a mapped name is portable.
+      */
+     String mappedName() default "";
+
+     /**
+      * The service class, always a type extending
+      * <code>javax.xml.ws.Service</code>. This element must be specified
+      * whenever the type of the reference is a service endpoint interface.
+      */
+     Class value() default Object.class ;
+
+     /**
+      * A URL pointing to the WSDL document for the web service.
+      * If not specified, the WSDL location specified by annotations
+      * on the resource type is used instead.
+      */
+     String wsdlLocation() default "";
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/WebServiceRefs.java b/jaxws/src/share/classes/javax/xml/ws/WebServiceRefs.java
new file mode 100644
index 0000000..3cbd360
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/WebServiceRefs.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright 2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.Target;
+import java.lang.annotation.Retention;
+import static java.lang.annotation.ElementType.*;
+import static java.lang.annotation.RetentionPolicy.*;
+
+/**
+ * The <code>WebServiceRefs</code> annotation allows
+ * multiple web service references to be declared at the
+ * class level.
+ *
+ * @see javax.xml.ws.WebServiceRef
+ * @since 2.0
+ */
+
+@Documented
+@Retention(RUNTIME)
+@Target(TYPE)
+public @interface WebServiceRefs {
+   /**
+    * Array used for multiple web service reference declarations.
+    */
+   WebServiceRef[] value();
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/Handler.java b/jaxws/src/share/classes/javax/xml/ws/handler/Handler.java
new file mode 100644
index 0000000..d2598bd
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/Handler.java
@@ -0,0 +1,87 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.handler;
+
+import javax.xml.ws.ProtocolException;
+import javax.xml.ws.handler.MessageContext;
+
+/** The <code>Handler</code> interface
+ *  is the base interface for JAX-WS handlers.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface Handler<C extends MessageContext> {
+
+  /** The <code>handleMessage</code> method is invoked for normal processing
+   *  of inbound and outbound messages. Refer to the description of the handler
+   *  framework in the JAX-WS specification for full details.
+   *
+   *  @param context the message context.
+   *  @return An indication of whether handler processing should continue for
+   *  the current message
+   *                 <ul>
+   *                 <li>Return <code>true</code> to continue
+   *                     processing.</li>
+   *                 <li>Return <code>false</code> to block
+   *                     processing.</li>
+   *                  </ul>
+   *  @throws RuntimeException Causes the JAX-WS runtime to cease
+   *    handler processing and generate a fault.
+   *  @throws ProtocolException Causes the JAX-WS runtime to switch to
+   *    fault message processing.
+  **/
+  public boolean handleMessage(C context);
+
+  /** The <code>handleFault</code> method is invoked for fault message
+   *  processing.  Refer to the description of the handler
+   *  framework in the JAX-WS specification for full details.
+   *
+   *  @param context the message context
+   *  @return An indication of whether handler fault processing should continue
+   *  for the current message
+   *                 <ul>
+   *                 <li>Return <code>true</code> to continue
+   *                     processing.</li>
+   *                 <li>Return <code>false</code> to block
+   *                     processing.</li>
+   *                  </ul>
+   *  @throws RuntimeException Causes the JAX-WS runtime to cease
+   *    handler fault processing and dispatch the fault.
+   *  @throws ProtocolException Causes the JAX-WS runtime to cease
+   *    handler fault processing and dispatch the fault.
+  **/
+  public boolean handleFault(C context);
+
+  /**
+   * Called at the conclusion of a message exchange pattern just prior to
+   * the JAX-WS runtime disptaching a message, fault or exception.  Refer to
+   * the description of the handler
+   * framework in the JAX-WS specification for full details.
+   *
+   * @param context the message context
+  **/
+  public void close(MessageContext context);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/HandlerResolver.java b/jaxws/src/share/classes/javax/xml/ws/handler/HandlerResolver.java
new file mode 100644
index 0000000..0f18052
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/HandlerResolver.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.handler;
+
+/**
+ *  <code>HandlerResolver</code> is an interface implemented
+ *  by an application to get control over the handler chain
+ *  set on proxy/dispatch objects at the time of their creation.
+ *  <p>
+ *  A <code>HandlerResolver</code> may be set on a <code>Service</code>
+ *  using the <code>setHandlerResolver</code> method.
+ * <p>
+ *  When the runtime invokes a <code>HandlerResolver</code>, it will
+ *  pass it a <code>PortInfo</code> object containing information
+ *  about the port that the proxy/dispatch object will be accessing.
+ *
+ *  @see javax.xml.ws.Service#setHandlerResolver
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface HandlerResolver {
+
+  /**
+   *  Gets the handler chain for the specified port.
+   *
+   *  @param portInfo Contains information about the port being accessed.
+   *  @return java.util.List Handler chain
+  **/
+  public java.util.List<Handler> getHandlerChain(PortInfo portInfo);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/LogicalHandler.java b/jaxws/src/share/classes/javax/xml/ws/handler/LogicalHandler.java
new file mode 100644
index 0000000..9632776
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/LogicalHandler.java
@@ -0,0 +1,34 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.handler;
+
+/** The <code>LogicalHandler</code> extends
+ *  Handler to provide typesafety for the message context parameter.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface LogicalHandler<C extends LogicalMessageContext> extends Handler<C> {
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/LogicalMessageContext.java b/jaxws/src/share/classes/javax/xml/ws/handler/LogicalMessageContext.java
new file mode 100644
index 0000000..ebf356d
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/LogicalMessageContext.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.handler;
+
+import javax.xml.ws.LogicalMessage;
+
+/** The <code>LogicalMessageContext</code> interface extends
+ *  <code>MessageContext</code> to
+ *  provide access to a the contained message as a protocol neutral
+ *  LogicalMessage
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface LogicalMessageContext
+                    extends MessageContext {
+
+  /** Gets the message from this message context
+   *
+   *  @return The contained message; returns null if no
+   *          message is present in this message context
+  **/
+  public LogicalMessage getMessage();
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/MessageContext.java b/jaxws/src/share/classes/javax/xml/ws/handler/MessageContext.java
new file mode 100644
index 0000000..b8be744
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/MessageContext.java
@@ -0,0 +1,176 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.handler;
+import java.util.Map;
+
+/** The interface <code>MessageContext</code> abstracts the message
+ *  context that is processed by a handler in the <code>handle</code>
+ *  method.
+ *
+ *  <p>The <code>MessageContext</code> interface provides methods to
+ *  manage a property set. <code>MessageContext</code> properties
+ *  enable handlers in a handler chain to share processing related
+ *  state.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface MessageContext extends Map<String, Object> {
+
+  /** Standard property: message direction, <code>true</code> for
+   *  outbound messages, <code>false</code> for inbound.
+   *  <p>Type: boolean
+  **/
+  public static final String MESSAGE_OUTBOUND_PROPERTY =
+                      "javax.xml.ws.handler.message.outbound";
+
+  /** Standard property: Map of attachments to a message for the inbound
+   * message, key is  the MIME Content-ID, value is a DataHandler.
+   *  <p>Type: java.util.Map<String,DataHandler>
+  **/
+  public static final String INBOUND_MESSAGE_ATTACHMENTS =
+        "javax.xml.ws.binding.attachments.inbound";
+
+  /** Standard property: Map of attachments to a message for the outbound
+   * message, key is the MIME Content-ID, value is a DataHandler.
+   *  <p>Type: java.util.Map<String,DataHandler>
+  **/
+  public static final String OUTBOUND_MESSAGE_ATTACHMENTS =
+        "javax.xml.ws.binding.attachments.outbound";
+
+  /** Standard property: input source for WSDL document.
+   *  <p>Type: org.xml.sax.InputSource
+  **/
+  public static final String WSDL_DESCRIPTION =
+        "javax.xml.ws.wsdl.description";
+
+  /** Standard property: name of WSDL service.
+   *  <p>Type: javax.xml.namespace.QName
+  **/
+  public static final String WSDL_SERVICE =
+        "javax.xml.ws.wsdl.service";
+
+  /** Standard property: name of WSDL port.
+   *  <p>Type: javax.xml.namespace.QName
+  **/
+  public static final String WSDL_PORT =
+        "javax.xml.ws.wsdl.port";
+
+  /** Standard property: name of wsdl interface (2.0) or port type (1.1).
+   *  <p>Type: javax.xml.namespace.QName
+  **/
+  public static final String WSDL_INTERFACE =
+        "javax.xml.ws.wsdl.interface";
+
+  /** Standard property: name of WSDL operation.
+   *  <p>Type: javax.xml.namespace.QName
+  **/
+  public static final String WSDL_OPERATION =
+        "javax.xml.ws.wsdl.operation";
+
+  /** Standard property: HTTP response status code.
+   *  <p>Type: java.lang.Integer
+  **/
+  public static final String HTTP_RESPONSE_CODE =
+        "javax.xml.ws.http.response.code";
+
+  /** Standard property: HTTP request headers.
+   *  <p>Type: java.util.Map<java.lang.String, java.util.List<java.lang.String>>
+  **/
+  public static final String HTTP_REQUEST_HEADERS =
+        "javax.xml.ws.http.request.headers";
+
+  /** Standard property: HTTP response headers.
+   *  <p>Type: java.util.Map<java.lang.String, java.util.List<java.lang.String>>
+  **/
+  public static final String HTTP_RESPONSE_HEADERS =
+        "javax.xml.ws.http.response.headers";
+
+  /** Standard property: HTTP request method.
+   *  <p>Type: java.lang.String
+  **/
+  public static final String HTTP_REQUEST_METHOD =
+        "javax.xml.ws.http.request.method";
+
+  /** Standard property: servlet request object.
+   *  <p>Type: javax.servlet.http.HttpServletRequest
+  **/
+  public static final String SERVLET_REQUEST =
+        "javax.xml.ws.servlet.request";
+
+  /** Standard property: servlet response object.
+   *  <p>Type: javax.servlet.http.HttpServletResponse
+  **/
+  public static final String SERVLET_RESPONSE =
+        "javax.xml.ws.servlet.response";
+
+  /** Standard property: servlet context object.
+   *  <p>Type: javax.servlet.ServletContext
+  **/
+  public static final String SERVLET_CONTEXT =
+        "javax.xml.ws.servlet.context";
+
+  /** Standard property: Query string for request.
+   *  <p>Type: String
+  **/
+  public static final String QUERY_STRING =
+        "javax.xml.ws.http.request.querystring";
+
+  /** Standard property: Request Path Info
+   *  <p>Type: String
+  **/
+  public static final String PATH_INFO =
+        "javax.xml.ws.http.request.pathinfo";
+
+  /**
+   * Property scope. Properties scoped as <code>APPLICATION</code> are
+   * visible to handlers,
+   * client applications and service endpoints; properties scoped as
+   * <code>HANDLER</code>
+   * are only normally visible to handlers.
+  **/
+  public enum Scope {APPLICATION, HANDLER};
+
+  /** Sets the scope of a property.
+   *
+   *  @param name Name of the property associated with the
+   *              <code>MessageContext</code>
+   *  @param scope Desired scope of the property
+   *  @throws java.lang.IllegalArgumentException if an illegal
+   *              property name is specified
+   *
+  **/
+  public void setScope(String name,  Scope scope);
+
+  /** Gets the scope of a property.
+   *
+   *  @param name Name of the property
+   *  @return Scope of the property
+   *  @throws java.lang.IllegalArgumentException if a non-existant
+   *              property name is specified
+   *
+  **/
+  public Scope getScope(String  name);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/PortInfo.java b/jaxws/src/share/classes/javax/xml/ws/handler/PortInfo.java
new file mode 100644
index 0000000..469baad
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/PortInfo.java
@@ -0,0 +1,66 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.handler;
+
+import javax.xml.namespace.QName;
+
+/**
+ *  The <code>PortInfo</code> interface is used by a
+ *  <code>HandlerResolver</code> to query information about
+ *  the port it is being asked to create a handler chain for.
+ *  <p>
+ *  This interface is never implemented by an application,
+ *  only by a JAX-WS implementation.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface PortInfo {
+
+  /**
+   *  Gets the qualified name of the WSDL service name containing
+   *  the port being accessed.
+   *
+   *  @return javax.xml.namespace.QName The qualified name of the WSDL service.
+  **/
+  public QName getServiceName();
+
+  /**
+   *  Gets the qualified name of the WSDL port being accessed.
+   *
+   *  @return javax.xml.namespace.QName The qualified name of the WSDL port.
+  **/
+  public QName getPortName();
+
+  /**
+   *  Gets the URI identifying the binding used by the port being accessed.
+   *
+   *  @return String The binding identifier for the port.
+   *
+   *  @see javax.xml.ws.Binding
+  **/
+  public String getBindingID();
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/package.html b/jaxws/src/share/classes/javax/xml/ws/handler/package.html
new file mode 100644
index 0000000..d37dcab
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+This package defines APIs for message handlers.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/soap/SOAPHandler.java b/jaxws/src/share/classes/javax/xml/ws/handler/soap/SOAPHandler.java
new file mode 100644
index 0000000..9da41eb
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/soap/SOAPHandler.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.handler.soap;
+
+import javax.xml.namespace.QName;
+import javax.xml.ws.handler.Handler;
+import java.util.Set;
+
+/** The <code>SOAPHandler</code> class extends <code>Handler</code>
+ *  to provide typesafety for the message context parameter and add a method
+ *  to obtain access to the headers that may be processed by the handler.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface SOAPHandler<T extends SOAPMessageContext>
+    extends Handler<T> {
+
+  /** Gets the header blocks that can be processed by this Handler
+   *  instance.
+   *
+   *  @return Set of QNames of header blocks processed by this
+   *           handler instance. <code>QName</code> is the qualified
+   *           name of the outermost element of the Header block.
+  **/
+  Set<QName> getHeaders();
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/soap/SOAPMessageContext.java b/jaxws/src/share/classes/javax/xml/ws/handler/soap/SOAPMessageContext.java
new file mode 100644
index 0000000..a5b0a3e
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/soap/SOAPMessageContext.java
@@ -0,0 +1,99 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.handler.soap;
+
+import javax.xml.soap.SOAPMessage;
+import javax.xml.bind.JAXBContext;
+import javax.xml.namespace.QName;
+import java.util.Set;
+
+/** The interface <code>SOAPMessageContext</code>
+ *  provides access to the SOAP message for either RPC request or
+ *  response. The <code>javax.xml.soap.SOAPMessage</code> specifies
+ *  the standard Java API for the representation of a SOAP 1.1 message
+ *  with attachments.
+ *
+ *  @see javax.xml.soap.SOAPMessage
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface SOAPMessageContext
+                    extends javax.xml.ws.handler.MessageContext {
+
+  /** Gets the SOAPMessage from this message context. Modifications
+   *  to the returned SOAPMessage change the message in-place, there
+   *  is no need to susequently call <code>setMessage</code>.
+   *
+   *  @return Returns the SOAPMessage; returns null if no
+   *          SOAPMessage is present in this message context
+  **/
+  public SOAPMessage getMessage();
+
+  /** Sets the SOAPMessage in this message context
+   *
+   *  @param  message SOAP message
+   *  @throws WebServiceException If any error during the setting
+   *          of the SOAPMessage in this message context
+   *  @throws java.lang.UnsupportedOperationException If this
+   *          operation is not supported
+  **/
+  public void setMessage(SOAPMessage message);
+
+  /** Gets headers that have a particular qualified name from the message in the
+   *  message context. Note that a SOAP message can contain multiple headers
+   *  with the same qualified name.
+   *
+   *  @param  header The XML qualified name of the SOAP header(s).
+   *  @param  context The JAXBContext that should be used to unmarshall the
+   *          header
+   *  @param  allRoles If <code>true</code> then returns headers for all SOAP
+   *          roles, if <code>false</code> then only returns headers targetted
+   *          at the roles currently being played by this SOAP node, see
+   *          <code>getRoles</code>.
+   *  @return An array of unmarshalled headers; returns an empty array if no
+   *          message is present in this message context or no headers match
+   *          the supplied qualified name.
+   *  @throws WebServiceException If an error occurs when using the supplied
+   *     JAXBContext to unmarshall. The cause of
+   *     the WebServiceException is the original JAXBException.
+  **/
+  public Object[] getHeaders(QName header, JAXBContext context,
+    boolean allRoles);
+
+  /** Gets the SOAP actor roles associated with an execution
+   *  of the handler chain.
+   *  Note that SOAP actor roles apply to the SOAP node and
+   *  are managed using <code>SOAPBinding.setRoles</code> and
+   *  <code>SOAPBinding.getRoles</code>. Handler instances in
+   *  the handler chain use this information about the SOAP actor
+   *  roles to process the SOAP header blocks. Note that the
+   *  SOAP actor roles are invariant during the processing of
+   *  SOAP message through the handler chain.
+   *
+   *  @return Array of String for SOAP actor roles
+  **/
+  public Set<String> getRoles();
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/handler/soap/package.html b/jaxws/src/share/classes/javax/xml/ws/handler/soap/package.html
new file mode 100644
index 0000000..ed4fb04
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/handler/soap/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+This package defines APIs for SOAP message handlers.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/javax/xml/ws/http/HTTPBinding.java b/jaxws/src/share/classes/javax/xml/ws/http/HTTPBinding.java
new file mode 100644
index 0000000..ffe482c
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/http/HTTPBinding.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.http;
+
+
+import javax.xml.ws.Binding;
+
+/** The <code>HTTPBinding</code> interface is an
+ *  abstraction for the XML/HTTP binding.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface HTTPBinding extends Binding {
+
+  /**
+   * A constant representing the identity of the XML/HTTP binding.
+   */
+  public static final String HTTP_BINDING = "http://www.w3.org/2004/08/wsdl/http";
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/http/HTTPException.java b/jaxws/src/share/classes/javax/xml/ws/http/HTTPException.java
new file mode 100644
index 0000000..0d062a0
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/http/HTTPException.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.http;
+
+
+/** The <code>HTTPException</code> exception represents a
+ *  XML/HTTP fault.
+ *
+ *  <p>Since there is no standard format for faults or exceptions
+ *  in XML/HTTP messaging, only the HTTP status code is captured.
+ *
+ *  @since JAX-WS 2.0
+**/
+public class HTTPException extends javax.xml.ws.ProtocolException  {
+
+  private int statusCode;
+
+  /** Constructor for the HTTPException
+   *  @param statusCode   <code>int</code> for the HTTP status code
+  **/
+  public HTTPException(int statusCode) {
+    super();
+    this.statusCode = statusCode;
+  }
+
+  /** Gets the HTTP status code.
+   *
+   *  @return HTTP status code
+  **/
+  public int getStatusCode() {
+    return statusCode;
+  }
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/http/package.html b/jaxws/src/share/classes/javax/xml/ws/http/package.html
new file mode 100644
index 0000000..41b5f87
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/http/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+This package defines APIs specific to the HTTP binding.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/javax/xml/ws/package.html b/jaxws/src/share/classes/javax/xml/ws/package.html
new file mode 100644
index 0000000..49f69bb
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+This package contains the core JAX-WS APIs.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/javax/xml/ws/soap/SOAPBinding.java b/jaxws/src/share/classes/javax/xml/ws/soap/SOAPBinding.java
new file mode 100644
index 0000000..166f2ce
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/soap/SOAPBinding.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.soap;
+
+
+import java.util.Set;
+import javax.xml.ws.Binding;
+import javax.xml.soap.SOAPFactory;
+import javax.xml.soap.MessageFactory;
+
+/** The <code>SOAPBinding</code> interface is an abstraction for
+ *  the SOAP binding.
+ *
+ *  @since JAX-WS 2.0
+**/
+public interface SOAPBinding extends Binding {
+
+  /**
+   * A constant representing the identity of the SOAP 1.1 over HTTP binding.
+   */
+  public static final String SOAP11HTTP_BINDING = "http://schemas.xmlsoap.org/wsdl/soap/http";
+
+  /**
+   * A constant representing the identity of the SOAP 1.2 over HTTP binding.
+   */
+  public static final String SOAP12HTTP_BINDING = "http://www.w3.org/2003/05/soap/bindings/HTTP/";
+
+  /**
+   * A constant representing the identity of the SOAP 1.1 over HTTP binding
+   * with MTOM enabled by default.
+   */
+  public static final String SOAP11HTTP_MTOM_BINDING = "http://schemas.xmlsoap.org/wsdl/soap/http?mtom=true";
+
+  /**
+   * A constant representing the identity of the SOAP 1.2 over HTTP binding
+   * with MTOM enabled by default.
+   */
+  public static final String SOAP12HTTP_MTOM_BINDING = "http://www.w3.org/2003/05/soap/bindings/HTTP/?mtom=true";
+
+  /** Gets the roles played by the SOAP binding instance.
+   *
+   *  @return Set<String> The set of roles played by the binding instance.
+  **/
+  public Set<String> getRoles();
+
+  /** Sets the roles played by the SOAP binding instance.
+   *
+   *  @param roles    The set of roles played by the binding instance.
+   *  @throws WebServiceException On an error in the configuration of
+   *                  the list of roles.
+  **/
+  public void setRoles(Set<String> roles);
+
+  /**
+   * Returns <code>true</code> if the use of MTOM is enabled.
+   *
+   * @return <code>true</code> if and only if the use of MTOM is enabled.
+  **/
+
+  public boolean isMTOMEnabled();
+
+  /**
+   * Enables or disables use of MTOM.
+   *
+   * @param flag   A <code>boolean</code> specifying whether the use of MTOM should
+   *               be enabled or disabled.
+   *  @throws WebServiceException If the specified setting is not supported
+   *                  by this binding instance.
+  **/
+  public void setMTOMEnabled(boolean flag);
+
+  /**
+   * Gets the SAAJ <code>SOAPFactory</code> instance used by this SOAP binding.
+   *
+   * @return SOAPFactory instance used by this SOAP binding.
+  **/
+  public SOAPFactory getSOAPFactory();
+
+  /**
+   * Gets the SAAJ <code>MessageFactory</code> instance used by this SOAP binding.
+   *
+   * @return MessageFactory instance used by this SOAP binding.
+  **/
+  public MessageFactory getMessageFactory();
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/soap/SOAPFaultException.java b/jaxws/src/share/classes/javax/xml/ws/soap/SOAPFaultException.java
new file mode 100644
index 0000000..a42de1d
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/soap/SOAPFaultException.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.soap;
+
+import javax.xml.soap.SOAPFault;
+
+/** The <code>SOAPFaultException</code> exception represents a
+ *  SOAP 1.1 or 1.2 fault.
+ *
+ *  <p>A <code>SOAPFaultException</code> wraps a SAAJ <code>SOAPFault</code>
+ *  that manages the SOAP-specific representation of faults.
+ *  The <code>createFault</code> method of
+ *  <code>javax.xml.soap.SOAPFactory</code> may be used to create an instance
+ *  of <code>javax.xml.soap.SOAPFault</code> for use with the
+ *  constructor. <code>SOAPBinding</code> contains an accessor for the
+ *  <code>SOAPFactory</code> used by the binding instance.
+ *
+ *  <p>Note that the value of <code>getFault</code> is the only part of the
+ *  exception used when searializing a SOAP fault.
+ *
+ *  <p>Refer to the SOAP specification for a complete
+ *  description of SOAP faults.
+ *
+ *  @see javax.xml.soap.SOAPFault
+ *  @see javax.xml.ws.soap.SOAPBinding#getSOAPFactory
+ *  @see javax.xml.ws.ProtocolException
+ *
+ *  @since JAX-WS 2.0
+ **/
+public class SOAPFaultException extends javax.xml.ws.ProtocolException  {
+
+    private SOAPFault fault;
+
+    /** Constructor for SOAPFaultException
+     *  @param fault   <code>SOAPFault</code> representing the fault
+     *
+     *  @see javax.xml.soap.SOAPFactory#createFault
+     **/
+    public SOAPFaultException(SOAPFault fault) {
+        super(fault.getFaultString());
+        this.fault = fault;
+    }
+
+    /** Gets the embedded <code>SOAPFault</code> instance.
+     *
+     *  @return <code>javax.xml.soap.SOAPFault</code> SOAP
+     *          fault element
+     **/
+    public javax.xml.soap.SOAPFault getFault() {
+        return this.fault;
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/soap/package.html b/jaxws/src/share/classes/javax/xml/ws/soap/package.html
new file mode 100644
index 0000000..7e46cdb
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/soap/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+This package defines APIs specific to the SOAP binding.
+</body>
+</html>
diff --git a/jaxws/src/share/classes/javax/xml/ws/spi/FactoryFinder.java b/jaxws/src/share/classes/javax/xml/ws/spi/FactoryFinder.java
new file mode 100644
index 0000000..5cd2666
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/spi/FactoryFinder.java
@@ -0,0 +1,155 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.spi;
+
+import java.io.InputStream;
+import java.io.File;
+import java.io.FileInputStream;
+
+import java.util.Properties;
+import java.io.BufferedReader;
+import java.io.InputStreamReader;
+import javax.xml.ws.WebServiceException;
+
+class FactoryFinder {
+
+    /**
+     * Creates an instance of the specified class using the specified
+     * <code>ClassLoader</code> object.
+     *
+     * @exception WebServiceException if the given class could not be found
+     *            or could not be instantiated
+     */
+    private static Object newInstance(String className,
+                                      ClassLoader classLoader)
+    {
+        try {
+            Class spiClass;
+            if (classLoader == null) {
+                spiClass = Class.forName(className);
+            } else {
+                spiClass = classLoader.loadClass(className);
+            }
+            return spiClass.newInstance();
+        } catch (ClassNotFoundException x) {
+            throw new WebServiceException(
+                "Provider " + className + " not found", x);
+        } catch (Exception x) {
+            throw new WebServiceException(
+                "Provider " + className + " could not be instantiated: " + x,
+                x);
+        }
+    }
+
+    /**
+     * Finds the implementation <code>Class</code> object for the given
+     * factory name, or if that fails, finds the <code>Class</code> object
+     * for the given fallback class name. The arguments supplied must be
+     * used in order. If using the first argument is successful, the second
+     * one will not be used.
+     * <P>
+     * This method is package private so that this code can be shared.
+     *
+     * @return the <code>Class</code> object of the specified message factory;
+     *         may not be <code>null</code>
+     *
+     * @param factoryId             the name of the factory to find, which is
+     *                              a system property
+     * @param fallbackClassName     the implementation class name, which is
+     *                              to be used only if nothing else
+     *                              is found; <code>null</code> to indicate that
+     *                              there is no fallback class name
+     * @exception WebServiceException if there is an error
+     */
+    static Object find(String factoryId, String fallbackClassName)
+    {
+        ClassLoader classLoader;
+        try {
+            classLoader = Thread.currentThread().getContextClassLoader();
+        } catch (Exception x) {
+            throw new WebServiceException(x.toString(), x);
+        }
+
+        String serviceId = "META-INF/services/" + factoryId;
+        // try to find services in CLASSPATH
+        try {
+            InputStream is=null;
+            if (classLoader == null) {
+                is=ClassLoader.getSystemResourceAsStream(serviceId);
+            } else {
+                is=classLoader.getResourceAsStream(serviceId);
+            }
+
+            if( is!=null ) {
+                BufferedReader rd =
+                    new BufferedReader(new InputStreamReader(is, "UTF-8"));
+
+                String factoryClassName = rd.readLine();
+                rd.close();
+
+                if (factoryClassName != null &&
+                    ! "".equals(factoryClassName)) {
+                    return newInstance(factoryClassName, classLoader);
+                }
+            }
+        } catch( Exception ex ) {
+        }
+
+
+        // try to read from $java.home/lib/jaxws.properties
+        try {
+            String javah=System.getProperty( "java.home" );
+            String configFile = javah + File.separator +
+                "lib" + File.separator + "jaxws.properties";
+            File f=new File( configFile );
+            if( f.exists()) {
+                Properties props=new Properties();
+                props.load( new FileInputStream(f));
+                String factoryClassName = props.getProperty(factoryId);
+                return newInstance(factoryClassName, classLoader);
+            }
+        } catch(Exception ex ) {
+        }
+
+
+        // Use the system property
+        try {
+            String systemProp =
+                System.getProperty( factoryId );
+            if( systemProp!=null) {
+                return newInstance(systemProp, classLoader);
+            }
+        } catch (SecurityException se) {
+        }
+
+        if (fallbackClassName == null) {
+            throw new WebServiceException(
+                "Provider for " + factoryId + " cannot be found", null);
+        }
+
+        return newInstance(fallbackClassName, classLoader);
+    }
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/spi/Provider.java b/jaxws/src/share/classes/javax/xml/ws/spi/Provider.java
new file mode 100644
index 0000000..e17c771
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/spi/Provider.java
@@ -0,0 +1,153 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.spi;
+
+import javax.xml.ws.Endpoint;
+import javax.xml.ws.WebServiceException;
+import javax.xml.namespace.QName;
+
+/**
+ * Service provider for <code>ServiceDelegate</code> and
+ * <code>Endpoint</code> objects.
+ * <p>
+ *
+ * @since JAX-WS 2.0
+ */
+public abstract class Provider {
+
+  /**
+   * A constant representing the property used to lookup the
+   * name of a <code>Provider</code> implementation
+   * class.
+   */
+  static public final String JAXWSPROVIDER_PROPERTY
+        = "javax.xml.ws.spi.Provider";
+
+  /**
+   * A constant representing the name of the default
+   * <code>Provider</code> implementation class.
+  **/
+  static private final String DEFAULT_JAXWSPROVIDER
+        = "com.sun.xml.internal.ws.spi.ProviderImpl";
+
+
+    /**
+     * Creates a new instance of Provider
+     */
+    protected Provider() {
+    }
+
+    /**
+     *
+     * Creates a new provider object.
+     * <p>
+     * The algorithm used to locate the provider subclass to use consists
+     * of the following steps:
+     * <p>
+     * <ul>
+     * <li>
+     *   If a resource with the name of
+     *   <code>META-INF/services/javax.xml.ws.spi.Provider</code>
+     *   exists, then its first line, if present, is used as the UTF-8 encoded
+     *   name of the implementation class.
+     * </li>
+     * <li>
+     *   If the $java.home/lib/jaxws.properties file exists and it is readable by
+     *   the <code>java.util.Properties.load(InputStream)</code> method and it contains
+     *   an entry whose key is <code>javax.xml.ws.spi.Provider</code>, then the value of
+     *   that entry is used as the name of the implementation class.
+     * </li>
+     * <li>
+     *   If a system property with the name <code>javax.xml.ws.spi.Provider</code>
+     *   is defined, then its value is used as the name of the implementation class.
+     * </li>
+     * <li>
+     *   Finally, a default implementation class name is used.
+     * </li>
+     * </ul>
+     *
+     */
+    public static Provider provider() {
+        try {
+            return (Provider)
+            FactoryFinder.find(JAXWSPROVIDER_PROPERTY,
+                               DEFAULT_JAXWSPROVIDER);
+        } catch (WebServiceException ex) {
+            throw ex;
+        } catch (Exception ex) {
+            throw new WebServiceException("Unable to create Provider: "+
+                                ex.getMessage());
+        }
+
+    }
+
+    /**
+     * Creates a service delegate object.
+     * <p>
+     * @param wsdlDocumentLocation A URL pointing to the WSDL document
+     *        for the service, or <code>null</code> if there isn't one.
+     * @param serviceName The qualified name of the service.
+     * @param serviceClass The service class, which must be either
+     *        <code>javax.xml.ws.Service</code> or a subclass thereof.
+     * @return The newly created service delegate.
+     */
+    public abstract ServiceDelegate createServiceDelegate(
+                                    java.net.URL wsdlDocumentLocation,
+                                    QName serviceName, Class serviceClass);
+
+
+    /**
+     *
+     * Creates an endpoint object with the provided binding and implementation
+     * object.
+     *
+     * @param bindingId A URI specifying the desired binding (e.g. SOAP/HTTP)
+     * @param implementor A service implementation object to which
+     *        incoming requests will be dispatched. The corresponding
+     *        class must be annotated with all the necessary Web service
+     *        annotations.
+     * @return The newly created endpoint.
+     */
+    public abstract Endpoint createEndpoint(String bindingId,
+                                            Object implementor);
+
+    /**
+     * Creates and publishes an endpoint object with the specified
+     * address and implementation object.
+     *
+     * @param address A URI specifying the address and transport/protocol
+     *        to use. A http: URI must result in the SOAP 1.1/HTTP
+     *        binding being used. Implementations may support other
+     *        URI schemes.
+     * @param implementor A service implementation object to which
+     *        incoming requests will be dispatched. The corresponding
+     *        class must be annotated with all the necessary Web service
+     *        annotations.
+     * @return The newly created endpoint.
+     */
+    public abstract Endpoint createAndPublishEndpoint(String address,
+                                                      Object implementor);
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/spi/ServiceDelegate.java b/jaxws/src/share/classes/javax/xml/ws/spi/ServiceDelegate.java
new file mode 100644
index 0000000..daa21a3
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/spi/ServiceDelegate.java
@@ -0,0 +1,249 @@
+/*
+ * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.  Sun designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Sun in the LICENSE file that accompanied this code.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+package javax.xml.ws.spi;
+
+import java.util.Iterator;
+import javax.xml.namespace.QName;
+import javax.xml.ws.Dispatch;
+import javax.xml.ws.Service;
+import javax.xml.ws.handler.HandlerResolver;
+import javax.xml.bind.JAXBContext;
+
+/**
+ * Service delegates are used internally by <code>Service</code> objects
+ * to allow pluggability of JAX-WS implementations.
+ * <p>
+ * Every <code>Service</code> object has its own delegate, created using
+ * the javax.xml.ws.Provider#createServiceDelegate method. A <code>Service</code>
+ * object delegates all of its instance methods to its delegate.
+ *
+ * @see javax.xml.ws.Service
+ * @see javax.xml.ws.spi.Provider
+ *
+ * @since JAX-WS 2.0
+ */
+public abstract class ServiceDelegate {
+
+    protected ServiceDelegate() {
+    }
+
+  /** The getPort method returns a stub. A service client
+   *  uses this stub to invoke operations on the target
+   *  service endpoint. The <code>serviceEndpointInterface</code>
+   *  specifies the service endpoint interface that is supported by
+   *  the created dynamic proxy or stub instance.
+   *
+   *  @param portName  Qualified name of the service endpoint in
+   *                   the WSDL service description
+   *  @param serviceEndpointInterface Service endpoint interface
+   *                   supported by the dynamic proxy or stub
+   *                   instance
+   *  @return Object Proxy instance that
+   *                 supports the specified service endpoint
+   *                 interface
+   *  @throws WebServiceException This exception is thrown in the
+   *                   following cases:
+   *                   <UL>
+   *                   <LI>If there is an error in creation of
+   *                       the proxy
+   *                   <LI>If there is any missing WSDL metadata
+   *                       as required by this method
+   *                   <LI>Optionally, if an illegal
+   *                       <code>serviceEndpointInterface</code>
+   *                       or <code>portName</code> is specified
+   *                   </UL>
+   *  @see java.lang.reflect.Proxy
+   *  @see java.lang.reflect.InvocationHandler
+  **/
+
+
+  public abstract <T> T getPort(QName portName,
+                                 Class<T> serviceEndpointInterface);
+
+
+  /** The getPort method returns a stub. The parameter
+   *  <code>serviceEndpointInterface</code> specifies the service
+   *  endpoint interface that is supported by the returned proxy.
+   *  In the implementation of this method, the JAX-WS
+   *  runtime system takes the responsibility of selecting a protocol
+   *  binding (and a port) and configuring the proxy accordingly.
+   *  The returned proxy should not be reconfigured by the client.
+   *
+   *  @param serviceEndpointInterface Service endpoint interface
+   *  @return Object instance that supports the
+   *                   specified service endpoint interface
+   *  @throws WebServiceException
+   *                   <UL>
+   *                   <LI>If there is an error during creation
+   *                       of the proxy
+   *                   <LI>If there is any missing WSDL metadata
+   *                       as required by this method
+   *                   <LI>Optionally, if an illegal
+   *                       <code>serviceEndpointInterface</code>
+   *                       is specified
+   *                   </UL>
+  **/
+  public abstract <T> T getPort(Class<T> serviceEndpointInterface);
+
+  /** Creates a new port for the service. Ports created in this way contain
+   *  no WSDL port type information and can only be used for creating
+   *  <code>Dispatch</code>instances.
+   *
+   *  @param portName  Qualified name for the target service endpoint
+   *  @param bindingId A URI identifier of a binding.
+   *  @param endpointAddress Address of the target service endpoint as a URI
+   *  @throws WebServiceException If any error in the creation of
+   *  the port
+   *
+   *  @see javax.xml.ws.soap.SOAPBinding#SOAP11HTTP_BINDING
+   *  @see javax.xml.ws.soap.SOAPBinding#SOAP12HTTP_BINDING
+   *  @see javax.xml.ws.http.HTTPBinding#HTTP_BINDING
+   **/
+  public abstract void addPort(QName portName, String bindingId,
+      String endpointAddress);
+
+  /** Creates a <code>Dispatch</code> instance for use with objects of
+   *  the users choosing.
+   *
+   *  @param portName  Qualified name for the target service endpoint
+   *  @param type The class of object used to messages or message
+   *  payloads. Implementations are required to support
+   *  javax.xml.transform.Source and javax.xml.soap.SOAPMessage.
+   *  @param mode Controls whether the created dispatch instance is message
+   *  or payload oriented, i.e. whether the user will work with complete
+   *  protocol messages or message payloads. E.g. when using the SOAP
+   *  protocol, this parameter controls whether the user will work with
+   *  SOAP messages or the contents of a SOAP body. Mode must be MESSAGE
+   *  when type is SOAPMessage.
+   *
+   *  @return Dispatch instance
+   *  @throws WebServiceException If any error in the creation of
+   *                   the <code>Dispatch</code> object
+   *  @see javax.xml.transform.Source
+   *  @see javax.xml.soap.SOAPMessage
+   **/
+  public abstract <T> Dispatch<T> createDispatch(QName portName, Class<T> type, Service.Mode mode);
+
+  /** Creates a <code>Dispatch</code> instance for use with JAXB
+   *  generated objects.
+   *
+   *  @param portName  Qualified name for the target service endpoint
+   *  @param context The JAXB context used to marshall and unmarshall
+   *  messages or message payloads.
+   *  @param mode Controls whether the created dispatch instance is message
+   *  or payload oriented, i.e. whether the user will work with complete
+   *  protocol messages or message payloads. E.g. when using the SOAP
+   *  protocol, this parameter controls whether the user will work with
+   *  SOAP messages or the contents of a SOAP body.
+   *
+   *  @return Dispatch instance
+   *  @throws ServiceException If any error in the creation of
+   *                   the <code>Dispatch</code> object
+   *
+   *  @see javax.xml.bind.JAXBContext
+   **/
+  public abstract Dispatch<Object> createDispatch(QName portName,
+              JAXBContext context, Service.Mode mode);
+
+
+  /** Gets the name of this service.
+   *  @return Qualified name of this service
+  **/
+  public abstract QName getServiceName();
+
+  /** Returns an <code>Iterator</code> for the list of
+   *  <code>QName</code>s of service endpoints grouped by this
+   *  service
+   *
+   *  @return Returns <code>java.util.Iterator</code> with elements
+   *          of type <code>javax.xml.namespace.QName</code>
+   *  @throws WebServiceException If this Service class does not
+   *          have access to the required WSDL metadata
+  **/
+  public abstract Iterator<javax.xml.namespace.QName> getPorts();
+
+  /** Gets the location of the WSDL document for this Service.
+   *
+   *  @return URL for the location of the WSDL document for
+   *          this service
+  **/
+  public abstract java.net.URL getWSDLDocumentLocation();
+
+  /**
+   * Returns the configured handler resolver.
+   *
+   *  @return HandlerResolver The <code>HandlerResolver</code> being
+   *          used by this <code>Service</code> instance, or <code>null</code>
+   *          if there isn't one.
+  **/
+  public abstract HandlerResolver getHandlerResolver();
+
+  /**
+   *  Sets the <code>HandlerResolver</code> for this <code>Service</code>
+   *  instance.
+   *  <p>
+   *  The handler resolver, if present, will be called once for each
+   *  proxy or dispatch instance that is created, and the handler chain
+   *  returned by the resolver will be set on the instance.
+   *
+   *  @param handlerResolver The <code>HandlerResolver</code> to use
+   *         for all subsequently created proxy/dispatch objects.
+   *
+   *  @see javax.xml.ws.handler.HandlerResolver
+  **/
+  public abstract void setHandlerResolver(HandlerResolver handlerResolver);
+
+  /**
+   * Returns the executor for this <code>Service</code>instance.
+   *
+   * The executor is used for all asynchronous invocations that
+   * require callbacks.
+   *
+   * @return The <code>java.util.concurrent.Executor</code> to be
+   *         used to invoke a callback.
+   *
+   * @see java.util.concurrent.Executor
+   **/
+   public abstract java.util.concurrent.Executor getExecutor();
+
+  /**
+   * Sets the executor for this <code>Service</code> instance.
+   *
+   * The executor is used for all asynchronous invocations that
+   * require callbacks.
+   *
+   * @param executor The <code>java.util.concurrent.Executor</code>
+   *        to be used to invoke a callback.
+   *
+   * @throws SecurityException If the instance does not support
+   *         setting an executor for security reasons (e.g. the
+   *         necessary permissions are missing).
+   *
+   * @see java.util.concurrent.Executor
+   **/
+   public abstract void setExecutor(java.util.concurrent.Executor executor);
+
+}
diff --git a/jaxws/src/share/classes/javax/xml/ws/spi/package.html b/jaxws/src/share/classes/javax/xml/ws/spi/package.html
new file mode 100644
index 0000000..3866126
--- /dev/null
+++ b/jaxws/src/share/classes/javax/xml/ws/spi/package.html
@@ -0,0 +1,5 @@
+<html>
+<body>
+This package defines SPIs for JAX-WS 2.0.
+</body>
+</html>